Returns user's challenge preferences as available in the OAA
put
/oaa/runtime/preferences/v1/fetchuserpreferencessecurely
Returns a list of challenge preferences for user. Error is returned for user not found in the OAA.
The call can be made using userId and groupId. If uniqueUserId is provided, userId and groupId is ignored.
The call can be made using userId and groupId. If uniqueUserId is provided, userId and groupId is ignored.
Request
There are no request parameters for this operation.
Supported Media Types
- application/xml
- application/json
Root Schema : schema
Type:
object
Request Object contains userId and groupId.
Show Source
-
groupId: string
Default Value:
Default
Group to which user belongs.If this parameter is not present then, a value of Default is used. -
uniqueUserId: string
Canonical ID of the user in the external systems. If this is present, then it takes precedence over userId + groupId combination.
-
userId(required): string
Identifier of the user. May be further qualified by groupId.
Root Schema : schema
Type:
object
Request Object contains userId and groupId.
Show Source
-
groupId: string
Default Value:
Default
Group to which user belongs.If this parameter is not present then, a value of Default is used. -
uniqueUserId: string
Canonical ID of the user in the external systems. If this is present, then it takes precedence over userId + groupId combination.
-
userId(required): string
Identifier of the user. May be further qualified by groupId.
Response
Supported Media Types
- application/xml
- application/json
- text/plain
200 Response
Success.
Root Schema : schema
Type:
object
Information about the user and user's challenge registration for each type of challenge factor.
Show Source
-
alternateName: string
User's altername name that may be used in the user screens.
-
defaultlocale: string
The default locale of the user. If not provided then a default value of "en_US" will be used.
-
displayName: string
User's display name that may be used in the user screens.
-
factorsRegistered: array
factorsRegistered
Array of factor registration data for user.
-
groupId: string
GroupId / ApplicationId of the user whose preferences data is required. If this parameter is not present a value of "Default" is used.
-
imageReference: string
Location of the secureImage. Example:/images/secureImage01.jpg. If system is configured to return the image path as a full URL, then following two properties need to be configured. 1.)oaa.preferences.prependBasePath = true (default is false), 2.)oaa.preferences.imageBasePath=
. If system property oaa.preferences.prependBasePath = false, then only the location of the secureImage is returned as is. For set(post) only the relative path should be used and for get full URL will be returned if configured as above. -
phraseString: string
User preferred phrase string ex Hello World!
-
uniqueUserId: string
Canonical ID of the user. If this is present, then it takes precedence over userId + groupId combination.
-
userId: string
Identifier of the user. May be further qualified by groupId.
Nested Schema : factorsRegistered
Type:
array
Array of factor registration data for user.
Show Source
-
Array of:
object FactorRegData
Entry containing a factorName and map of keys and a values. Map of keys and values will contain attributes specific to that factor.
Nested Schema : FactorRegData
Type:
object
Entry containing a factorName and map of keys and a values. Map of keys and values will contain attributes specific to that factor.
Show Source
-
factorAttributes: array
factorAttributes
Collection of attributes for a factor for this user.
-
factorKey: string
Key of the factor. This is the name that should map to one of the available factors in the OAA system. This should be one of the enum name in challenge.type.enum. Examples are ChallengeEmail, ChallengeSMS, ChallengeOMATOTP, ChallangeYOTP and ChallengeFIDO2.
-
factorName: string
This is the name that should map to one of the available factors in the OAA system. This should be one of the enum name in challenge.type.enum. For Example if factor is email then factorName should be Email Challenge. Examples are Email Challenge, SMS Challenge, OMA TOTP Challenge, Yubikey OTP Challange and FIDO2 Challenge.
-
isPreferred: boolean
Is the factor is preferred factor for the user to challenge.
Nested Schema : factorAttributes
Type:
array
Collection of attributes for a factor for this user.
Show Source
-
Array of:
object PrefFactorAttribute
A map represented as an array of entries.
Nested Schema : PrefFactorAttribute
Type:
object
A map represented as an array of entries.
Show Source
-
factorAttributeName: string
Name of factor specific attribute.
-
factorAttributeValue: array
factorAttributeValue
Value of factor specific attribute. Multiple values can be specified in the array.
Nested Schema : factorAttributeValue
Type:
array
Value of factor specific attribute. Multiple values can be specified in the array.
Show Source
-
Array of:
object PrefFactorAttributeValue
Attribute value of the factor.
Nested Schema : PrefFactorAttributeValue
Type:
object
Attribute value of the factor.
Show Source
-
createTime: string
(date-time)
"Date time string in the format rfc3339 sec 5.6. https://tools.ietf.org/html/rfc3339#section-5.6"
-
isEnabled: boolean
Indicates if the factor attribute is enabled or not. By default, it is set as true.
-
isPreferred: boolean
Indicates if the value of the attribute is preferred over other similar values in the array.
-
isValidated: boolean
Default Value:
true
Indicates if the given attribute is validated. Some attributes do not require validation hence this field is optional. -
isVerified: boolean
Default Value:
true
Indicates if the given attribute is verified. Some attributes do not require verification hence this field is optional. -
name: string
Friendly name of the device.
-
value: string
Value of the factor attribute.
401 Response
Unauthorized
412 Response
Invalid input
500 Response
Internal server error
503 Response
Service Unavailable
Examples
The following example shows a sample request and response for retrieving a list of the user's challenge preferences.
cURL Command to Retrieve a List of Challenge Preferences in JSON Format
curl --location --request PUT '<OAAService>/oaa/runtime/preferences/v1/fetchuserpreferencessecurely' \ --header 'Content-Type: application/json' \ --header 'Authorization: Basic <Base64Encoded(<username>:<password>)>' \ --data '{ "userId": "user1", "groupId": "financeapp", "uniqueUserId": "22a29071-16f2-4b69-a94c-73be672e34eb" }'
Sample Response in JSON Format
{ "userId": "user1", "groupId": "financeapp", "uniqueUserId": "22a29071-16f2-4b69-a94c-73be672e34eb", "imageReference": "/u01/oracle/service/store/img001.jpg", "phraseString": "Hello World!", "factorsRegistered": [ { "isPreferred": false, "factorName": "Oracle Mobile Authenticator", "factorKey": "ChallengeOMATOTP", "factorAttributes": [ { "factorAttributeName": "omatotpsecretkey", "factorAttributeValue": [ { "value": "secret_key", "isPreferred": false, "isVerified": true, "isValidated": true, "name": "Device1", "isEnabled": true, "createTime": { "parseFailed": false, "dateTime": "2025-03-07T19:57:47.262Z", "rawParam": "2025-03-07T19:57:47.262Z" } } ] } ] }, { "isPreferred": false, "factorName": "Email Challenge", "factorKey": "ChallengeEmail", "factorAttributes": [ { "factorAttributeName": "email", "factorAttributeValue": [ { "value": "user1@example.com", "isPreferred": false, "isVerified": true, "isValidated": true, "name": "Device1", "isEnabled": true, "createTime": { "parseFailed": false, "dateTime": "2025-03-07T19:57:47.261Z", "rawParam": "2025-03-07T19:57:47.261Z" } } ] } ] } ] }
cURL Command to Retrieve a List of Challenge Preferences in XML Format
curl --location --request PUT '<OAAService>/oaa/runtime/preferences/v1/fetchuserpreferencessecurely' \ --header 'Content-Type: application/xml' \ --header 'Accept: application/xml' \ --header 'Authorization: Basic <Base64Encoded(<username>:<password>)>' \ --data '<?xml version="1.0" encoding="UTF-8" ?> <PrefUserData> <userId>user1</userId> <groupId>financeapp</groupId> <uniqueUserId>22a29071-16f2-4b69-a94c-73be672e34eb</uniqueUserId> </PrefUserData> '
Sample Response in XML Format
<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <UserPreferences> <userId>user1</userId> <groupId>financeapp</groupId> <uniqueUserId>22a29071-16f2-4b69-a94c-73be672e34eb</uniqueUserId> <imageReference>/u01/oracle/service/store/img001.jpg</imageReference> <phraseString>Hello World!</phraseString> <factorsRegistered> <isPreferred>false</isPreferred> <factorName>Oracle Mobile Authenticator</factorName> <factorKey>ChallengeOMATOTP</factorKey> <factorAttributes> <factorAttributeName>omatotpsecretkey</factorAttributeName> <factorAttributeValue> <value>secret_key</value> <isPreferred>false</isPreferred> <isVerified>true</isVerified> <isValidated>true</isValidated> <name>Device1</name> <isEnabled>true</isEnabled> <createTime> <dateTime>2025-03-07T20:31:43.782Z</dateTime> <parseFailed>false</parseFailed> <rawParam>2025-03-07T20:31:43.782Z</rawParam> </createTime> </factorAttributeValue> </factorAttributes> </factorsRegistered> <factorsRegistered> <isPreferred>false</isPreferred> <factorName>Email Challenge</factorName> <factorKey>ChallengeEmail</factorKey> <factorAttributes> <factorAttributeName>Device1</factorAttributeName> <factorAttributeValue> <value>true</value> <isPreferred>false</isPreferred> <isVerified>true</isVerified> <isValidated>true</isValidated> <name>isValidated</name> <isEnabled>true</isEnabled> <createTime> <dateTime>2025-03-07T20:31:43.783Z</dateTime> <parseFailed>false</parseFailed> <rawParam>2025-03-07T20:31:43.783Z</rawParam> </createTime> </factorAttributeValue> <factorAttributeValue> <value>val2</value> <isPreferred>false</isPreferred> <isVerified>true</isVerified> <isValidated>true</isValidated> <name>attr2</name> <isEnabled>true</isEnabled> <createTime> <dateTime>2025-03-07T20:31:43.783Z</dateTime> <parseFailed>false</parseFailed> <rawParam>2025-03-07T20:31:43.783Z</rawParam> </createTime> </factorAttributeValue> <factorAttributeValue> <value>value1</value> <isPreferred>false</isPreferred> <isVerified>true</isVerified> <isValidated>true</isValidated> <name>attr1</name> <isEnabled>true</isEnabled> <createTime> <dateTime>2025-03-07T20:31:43.783Z</dateTime> <parseFailed>false</parseFailed> <rawParam>2025-03-07T20:31:43.783Z</rawParam> </createTime> </factorAttributeValue> </factorAttributes> <factorAttributes> <factorAttributeName>email</factorAttributeName> <factorAttributeValue> <value>user1@example.com</value> <isPreferred>false</isPreferred> <isVerified>true</isVerified> <isValidated>true</isValidated> <name>Device1</name> <isEnabled>true</isEnabled> <createTime> <dateTime>2025-03-07T20:31:43.783Z</dateTime> <parseFailed>false</parseFailed> <rawParam>2025-03-07T20:31:43.783Z</rawParam> </createTime> </factorAttributeValue> </factorAttributes> </factorsRegistered> </UserPreferences>