disable_ot (For OneTouch)
disable_otp (For OTP email/onepass/sms etc)
Note that is enough for the property to exist that value of the property does not matter.
More information here:
https://document.phenixid.net/m/90910/l/1138846-disable-otp-one-touch-for-radius-authenticators
And of course just to mention this again this is not recommended.
Disable OTP if you are memeber of specific group
This assumes that you have created your standard Username, password & token scenario. Go to your scenario and the Execution flow tab and add two valves after the LDAPSearchValve:
PropertyContainsValve
{
"name" : "PropertyContainsValve",
"config" : {
"dest" : "disable_otp",
"source" : "memberOf",
"token" : "CN=NoOTP,OU=SecurityGroups,DC=company,DC=local"
}
},
This will look for the token in the memberOf property and and if it exist disable_otp will be equal to “true” and if not “false”
PropertyRemoveValve
{
"name" : "PropertyRemoveValve",
"config" : {
"name" : "disable_otp",
"skip_if_expr" : "flow.getPropertyValue('disable_otp','')==('true')"
}
}
Now we need to remove the property disable_otp if its set to false otherwise OTP will be disabled for all users.
Note that we need have the property memberOf on the current Item for this to work so that LDAPSearchValve need to look for this attribute:
LDAPSearchValve
{
"name": "LDAPSearchValve",
"config": {
"connection_ref":"b0f2ddff-9585-47c5-9286-2bee2b731197",
"base_dn":"dc=example,dc=com",
"scope":"SUB",
"size_limit":"0",
"filter":"uid=",
"attributes":"memberOf"
}
}
Disable OTP if there is no OTP enrolled (onepass)
This will show how to disable OTP if there is no OnePass token enrolled.
This assumes that you have created your standard Username, password & Token scenario or Username and Token. Go to your scenario and the Execution flow tab and add three valves after the LDAPSearchValve in the following order:
First we will add a property containing what type of token we want to check for, for OneTouch it is OATH:
PropertyAddValve
{
"name": "PropertyAddValve",
"config": {
"name":"get_value_attribute",
"value":"TOKEN",
"splitter" : ";"
}
}
Next we will check in database if the user has a OATH token enrolled, it will be either true or false and stored in the get_value property on the item.
GetTokenExistsValve
{
"name": "GetTokenExistsValve",
"config": {
"get_value_attribute_key": "get_value",
"username_attribute":"User-Name",
"get_value_attribute":"get_value_attribute"
}
}
next we will add a property but only if the user does not have a token enrolled:
PropertyAddValve
{
"name" : "PropertyAddValve",
"config" : {
"name" : "disable_otp",
"skip_if_expr" : "flow.getPropertyValue('get_value','')==('false')"
}
}
This will disable OTP if the user haven’t enrolled a OnePass token.
Disable Onetouch if you are member of specific group
We can also do the same as for OTP with oneTocuh by setting the disable_ot property in the flow.
This assumes that you have created your standard Username, password & OneTouch scenario or Username and OneTouch. Go to your scenario and the Execution flow tab and add two valves after the LDAPSearchValve:
PropertyContainsValve
{
"name" : "PropertyContainsValve",
"config" : {
"dest" : "disable_ot",
"source" : "memberOf",
"token" : "CN=NoOT,OU=SecurityGroups,DC=company,DC=local"
}
},
This will look for the token in the memberOf property and and if it exist disable_ot will be equal to “true” and if not “false”
PropertyRemoveValve
{
"name" : "PropertyRemoveValve",
"config" : {
"name" : "disable_otp",
"skip_if_expr" : "flow.getPropertyValue('disable_ot','')==('true')"
}
}
Now we need to remove the property disable_ot if its set to false otherwise OTP will be disabled for all users.
Note that we need have the property memberOf on the current Item for this to work so that LDAPSearchValve need to look for this attribute:
LDAPSearchValve
{
"name": "LDAPSearchValve",
"config": {
"connection_ref":"b0f2ddff-9585-47c5-9286-2bee2b731197",
"base_dn":"dc=example,dc=com",
"scope":"SUB",
"size_limit":"0",
"filter":"uid=",
"attributes":"memberOf"
}
}
Disable Onetouch if there is no Onetouch enrolled
We can also do the same as for OTP with oneTocuh by setting the disable_ot property in the flow.
This assumes that you have created your standard Username, password & OneTouch scenario or Username and OneTouch. Go to your scenario and the Execution flow tab and add three valves after the LDAPSearchValve in the following order:
First we will add a property containing what type of token we want to check for, for OneTouch it is PKI:
PropertyAddValve
{
"name": "PropertyAddValve",
"config": {
"name":"get_value_attribute",
"value":"PKI",
"splitter" : ";"
}
}
Next we will check in database if the user has a OATH token enrolled, it will be either true or false and stored in the get_value property on the item.
GetTokenExistsValve
{
"name": "GetTokenExistsValve",
"config": {
"get_value_attribute_key": "get_value",
"username_attribute":"User-Name",
"get_value_attribute":"get_value_attribute"
}
}
next we will add a property but only if the user does not have a token enrolled:
PropertyAddValve
{
"name" : "PropertyAddValve",
"config" : {
"name" : "disable_ot",
"skip_if_expr" : "flow.getPropertyValue('get_value','')==('false')"
}
}
This will disable OneTouch if the user haven’t enrolled a OneTouch token.
Related articles
10 Mar, 2023 core vpn ikev2 windows radius certificate
24 Apr, 2023 core legacy activedirectory radius userauth
4 May, 2021 easyaccess incenter syslog
11 Apr, 2023 ldap core authentication radius
30 Mar, 2021 linux easyaccess
21 Jan, 2021 easyaccess radius
24 Feb, 2021 easyaccess radius saml sso onetouch
26 Mar, 2024 oneconnect sase cloud radius
16 Aug, 2024 changeme easyaccess phenixid pas
21 Jan, 2021 easyaccess
6 Apr, 2023 core radius authentication
18 May, 2021 easyaccess myapps
5 Apr, 2023 core nps ipsec radius legacy
14 Dec, 2021 easyaccess log4j
18 Jan, 2021 easyaccess hotp
21 Nov, 2022 radius ldap authentication core