This section describes the available options of the SPS Duo plugin.
The plugin uses an ini-style configuration file with sections and name=value pairs. This format consists of sections, led by a [section] header and followed by name=value entries. Note that the leading whitespace is removed from values. The values can contain format strings, which refer to other values in the same section. For example, the following section would resolve the %(dir)s value to the value of the dir entry (/var in this case).
[section name] dirname=%(dir)s/mydirectory dir=/var
All reference expansions are done on demand. Lines beginning with # or ; are ignored and may be used to provide comments.
You can edit the configuration file from the SPS web interface. The following code snippet is a sample configuration file.
[duo]
# Do NOT use ikey and skey in production
; ikey=<API-integration-key>
; skey=<API-security-key>
host=<API-hostname>
timeout=60
ignore_conn_err=no
[plugin]
config_version=1
log_level=info
cred_store=<name-of-credstore-storing-sensitive-data>
[auth]
prompt=Hit Enter to send Duo push notification or provide the OTP:
whitelist=name-of-a-userlist
[username_transform]
append_domain=""
[ldap]
ldap_server_config=<SPS-LDAP-server-policy-name>
filter=(&(samAccountName={})(objectClass=user))
user_attribute=mail
[cache]
soft_timeout=15
hard_timeout=90
conn_limit=5
[question_1]
key=<name-of-name-value-pair>
prompt=<the-question-itself-in-text>
disable_echo=No
		
[question_2]...
    This section contains the options related to your Duo account.
[duo] # Do NOT use ikey and skey in production ; ikey=<API-integration-key> ; skey=<API-security-key> host=<API-hostname> timeout=60 ignore_conn_err=no
| Type: | string | 
| Required: | yes | 
| Default: | N/A | 
| 
 | Caution: This parameter contains sensitive data. Make sure to store this data in your local Credential Store. Type the $ value for this parameter in production. For details, see "Store sensitive plugin data securely". Only enter a value different than $ for this parameter in the configuration for testing purposes in a secure, non-production environment. | 
Description: The API integration key.
| Type: | string | 
| Required: | yes | 
| Default: | N/A | 
| 
 | Caution: This parameter contains sensitive data. Make sure to store this data in your local Credential Store. Type the $ value for this parameter in production. For details, see "Store sensitive plugin data securely". Only enter a value different than $ for this parameter in the configuration for testing purposes in a secure, non-production environment. | 
Description: The API security key.
| Type: | string | 
| Required: | yes | 
| Default: | N/A | 
Description: The API host name.
| Type: | integer [seconds] | 
| Required: | no | 
| Default: | 60 | 
Description: How long an HTTP request can take during the communication with the Duo server.
| Type: | yes | no | 
| Required: | no | 
| Default: | no | 
Description: Determines how to handle the sessions if the Duo service is not available. If set to yes, the plugin assumes that the user successfully authenticated even if the plugin cannot access Duo to verify this.
| 
 | Caution: Enabling this option allows the users to bypass multi-factor authentication if SPS cannot access the Duo service for any reason, for example, a network configuration error in your environment. | 
This section contains general plugin-related settings.
[plugin] config_version=1 log_level=20 cred_store=<name-of-credstore-hosting-sensitive-data>
| Type: | integer | 
| Required: | yes | 
| Default: | 1 | 
Description: The version number of the configuration format. This is used to enable potentially incompatible changes in the future. If provided, the configuration will not be upgraded automatically. If not provided, the configuration will be upgraded automatically.
| Type: | string | 
| Required: | no | 
| Default: | N/A | 
Description: The name of a local credential store policy configured on SPS. You can use this credential store to store sensitive information of the plugin in a secure way, for example, the ikey/skey values in the [duo] section. For details, see Store sensitive plugin data securely.
| Type: | integer or string | 
| Required: | no | 
| Default: | info | 
Description: The logging verbosity of the plugin. The plugin sends the generated log messages to the SPS syslog system. You can check the log messages in the Basic settings > Troubleshooting > View log files section of the SPS web interface. Filter on the plugin: string to show only the messages generated by the plugins.
The possible values are:
debug or 10
info or 20
warning or 30
error or 40
critical or 50
For details, see Python logging API's log levels: Logging Levels.
This section contains the options related to authentication.
[auth] prompt=Hit Enter to send Duo push notification or provide the OTP: whitelist=name-of-a-userlist
| Type: | string | 
| Required: | no | 
| Default: | Hit Enter to send push notification or provide the OTP: | 
Description: SPS displays this text to the user in a terminal connection to request an OTP interactively. The text is displayed only if the user uses an OTP-like factor, and does not send the OTP in the connection request.
prompt=Hit Enter to send Duo push notification or provide the OTP:
| Type: | string | 
| Required: | no | 
| Default: | N/A | 
Description: The name of a user list containing gateway users configured on SPS (Policies > User Lists). You can use this option to selectively require multi-factor authentication for your users, for example, to create break-glass access for specific users.
If you set the Default Policy of the user list to Reject, then the list is a whitelist, so the plugin will not request Duo authentication from the users on the list.
If you set the Default Policy of the user list to Accept, then the list is a blacklist, so the plugin will request Duo authentication only from the users on the list.
For details on creating user lists, see "Creating and editing user lists" in the Administration Guide.
© 2025 One Identity LLC. ALL RIGHTS RESERVED. 使用条款 隐私 Cookie首选项中心