Forum Discussion
Datagroup with address and value
awan_m I believe the following link is a similar rule to what you're looking for.
Selective URL client cert authentication with OU check | DevCentral
To go a bit further, do you require an IP match first or an OU match first?
- awan_mOct 30, 2024Cirrostratus
its a key pair match
ip and OU need to match as they are locked to each other
10.10.10.0/24 IPs must have Prod - else drop
20.20.20.0/24 Must have Staff - else drop
- PauliusOct 30, 2024MVP
awan_m I believe the following will work for you but I'm not 100% positive because I can't lab it. This is assuming you intend to send it to a specific pool but if not you can change the action in the if statement matching TEMP_OU to whatever action you would like.
when CLIENTSSL_CLIENTCERT priority 500 { set cert_subject [X509::subject [SSL::cert 0]] # release any stored data just in case HTTP::release # if there is still no cert after the SSL renegotiation kill the connection by sending a reset back to the client if { [SSL::cert count] < 1 } { reject } } when HTTP_REQUEST priority 500 { if { [class --match [getfield [IP::client_addr] "%" 1] equals ip_allow] } { set TEMP_OU [class --match -value [getfield [IP::client_addr] "%" 1] equals ip_allow] if { ${cert_subject} == ${TEMP_OU} } { pool <pool_name> } } else { reject } }
- awan_mNov 04, 2024Cirrostratus
thanks - i will start testing it this week
Recent Discussions
Related Content
* Getting Started on DevCentral
* Community Guidelines
* Community Terms of Use / EULA
* Community Ranking Explained
* Community Resources
* Contact the DevCentral Team
* Update MFA on account.f5.com