OTPByVoiceValve
Valve for delivering one-time passwords by voice call message, using PhenixID Message Gateway .
Supported voice languages can be found here.
Properties
SMS request rate limiter
The rate at which SMS messages can be sent to any single recipient number is limited by the system, based on a moving average of the delay between consecutive requests. This functionality is characterised by four parameters, described below.
Example, based on the default settings: a user that requests five SMS OTP:s, to the same number, within a period of 2.5 minutes will be quarantined for a period of 10 minutes, after which the limiter is reset and the user can start requesting SMS OTP:s again.
The parameters are global and specified on the phenix-pipes module configuration, not on the valve configuration. Changes will affect all SMS valves.
Name | Description | Default value |
---|---|---|
request_interval_mean | A lower bound for the moving average delay between consecutive requests, in seconds. | 30 |
request_lookback | The number of recent requests that are used to calculate the moving average. | 5 |
request_quarantine_period | If the average delay between requests in the lookback period drops below the lower bound, the recipient number will be quarantined for the period specified by this parameter, in seconds. After the quarantine period expires, the average delay calculation is reset. | 600 |
request_limiter_disabled | Disables the limiter function. | false |
Example Configuration
{
"name": "OTPByVoiceValve",
"config": {
"recipient_param_name":"{{item.mobile}}",
"userid_param_name":"{{request.username}}",
"generated_otp_name" : "generated_otp",
"default_language" : "sv",
"language_param_name" : "countryCode",
"use_country_code_language" : "true",
"wash_recipient_number" : "true",
"recipient_prefix" : "+46",
"force_prefix" : "true",
"message_gateway_settings" : "ce4d2wer-css0-42ec-9800-129a6212",
"message" : "Your OTP is: $$OTP"
}
}
In the example above the value for attribute mobile has been picked up earlier in the flow.
The value for userid_param_name has been picked up from the request. Most common values are {{request.User-Name}} for RADIUS and {{request.username}} for HTTP.
Requirements
Item set must have at least one entry.