FIDO Policies
FIDO policies allow you to fine-tune the use of FIDO2 authentication in authentication flows, for example, by limiting authentication to specific types of FIDO2 devices.
An endpoint (fidoDevicesMetadata) is also provided for reading information from the device metadata table stored by PingOne, and for adding or removing custom devices.
FIDO policies data model
| Property | Type | Required? | Mutable? | Description |
|---|---|---|---|---|
|
Boolean |
Optional |
Mutable |
By default, when the user is presented with a list of available authentication methods, each paired FIDO2 device is displayed separately. If you prefer to have only one generic FIDO2 option displayed in the list, set |
|
String |
Required |
Mutable |
Set to DIRECT if you want to require some sort of attestation. Set to NONE if you don’t want to require attestation. If you set |
|
String |
Required |
Mutable |
Used to control the type of authenticators that are allowed. Can be one of the following values: * PLATFORM - only allow the use of FIDO device authenticators that contain an internal authenticator (such as a face or fingerprint scanner) * CROSS_PLATFORM - allow use of cross-platform authenticators, which are external to the accessing device (such as a security key) * BOTH - allow both categories of authenticators |
|
Object |
Required |
Mutable |
Used to control whether users should be allowed to register and authenticate with a device that uses cloud-synced credentials, such as a passkey. |
|
Boolean |
Required |
Mutable |
Set to true if you want to let users register and authenticate with a device that uses cloud-synced credentials. Set to false if you don’t want to allow this. |
|
Boolean |
Required |
Mutable |
Set to true if you want the backup eligibility of the device to be checked again at each authentication attempt and not just once during registration. Set to false to have it checked only at registration. |
|
Boolean |
Optional |
Mutable |
Whether this policy should serve as the default FIDO policy. |
|
String |
Optional |
Mutable |
Description of the FIDO policy. |
|
Array |
N/A |
Read-only |
The device authentication policies that use the relevant FIDO policy. If you include the parameter |
|
String |
Required |
Mutable |
The name to display for FIDO2 devices in registration and authentication windows. Can be up to 100 characters. If you want to use translatable text, you can use any of the keys listed on the FIDO Policy page of the Self-Service module and the Sign On Policy module. The value of the parameter should include only the part of the key name that comes after the module name, for example, |
|
String |
Required |
Mutable |
Use this field to specify when registered users can authenticate without providing credentials. The possible values are: * DISCOURAGED - discoverable credentials are not used, even when supported by the FIDO device. In cases where use of discoverable credentials is required by the FIDO device itself, this setting does not override the device setting. * REQUIRED - require the use of discoverable credentials. This option is required for usernameless authentication. * PREFERRED - use discoverable credentials where possible. |
|
String |
Optional |
Mutable |
When defining a FIDO policy that requires enterprise attestation, you can add an additional layer of security by using |
|
Object |
Required |
Mutable |
Used to specify whether attestation is requested from the authenticator, and whether this information is used to restrict authenticator usage. |
|
Array |
Required |
Mutable |
If you set |
|
String |
Required |
Mutable |
The mdsIdentitfer of the authenticator to allow. |
|
Boolean |
Required |
Mutable |
Set to true if you want the device characteristics related to attestation to be checked again at each authentication attempt and not just once during registration. Set to false to have them checked only at registration. |
|
String |
Required |
Mutable |
Use * NONE - do not request attestation, allow all FIDO devices * AUDIT_ONLY - attestation is requested and the information is used for logging purposes, but the information is not used for filtering authenticators * GLOBAL - allow use of all FIDO authenticators listed in the Global Authenticators table. * CERTIFIED - allow only FIDO Certified authenticators * SPECIFIC - allow only the authenticators specified with the |
|
String |
Required |
Mutable |
The name to use for the FIDO policy. Can be up to 256 characters. |
|
Array |
Optional |
Mutable |
The |
|
String |
Required |
Mutable |
The ID of the relying party. The value should be a domain name, such as example.com (in lower-case characters). For Sandbox environments in PingOne, you can also use the value |
|
Object |
Required |
Mutable |
Used to specify the string associated with the users’s account that is displayed during registration and authentication. |
|
Array |
Required |
Mutable |
List of strings associated with the users’s account that can be displayed during registration and authentication. Each object in the array is a name:value pair where the first part is "name" and the second is the name of the user attribute, for example, * The content of the list should reflect the preferred order. * If the first attribute is empty for the user, PingOne will continue through the list until a non-empty attribute is found. * You can specify any user attribute (including custom attributes) that meet the following criteria: attribute type must be String, validation cannot be set to enumerated values. * The array must contain the user attribute "username" - to ensure that there is at least one non-empty attribute. * You can have a maximum of six user attributes in the list. |
|
String |
Optional |
Mutable |
Include |
|
Object |
Optional |
Mutable |
Used to specify the amount of time the user has to perform a user presence gesture with their FIDO device before the request expires. The defined timeout applies also to the pairing of the device. Note that the information is provided as a hint to the authenticator so the actual time given may differ from what you defined. |
|
Integer |
Optional |
Mutable |
The amount of time a user presence gesture will be accepted for the authentication request. Minimum is one minute, maximum is ten minutes. Can be set in minutes or seconds. |
|
String |
Optional |
Mutable |
The units to use for specifying the amount of time a user presence gesture will be accepted for the authentication request. Can be set to |
|
Object |
Required |
Mutable |
Used to control whether the user must perform a gesture (such as a public key credential, fingerprint scan, or a PIN code) when registering or authenticating with their FIDO device. |
|
Boolean |
Optional |
Mutable |
Set to true if you want the device characteristics related to user verification to be checked again at each authentication attempt and not just once during registration. Set to false to have them checked only at registration. |
|
String |
Required |
Mutable |
Can be one of the following values: * REQUIRED - only FIDO devices supporting user verification can be used * DISCOURAGED - user verification is not required, even when supported by the FIDO device. In cases where user verification is required by the FIDO device itself, this setting does not override the device setting. * PREFERRED - user verification is required if the user’s FIDO device supports it, but is not required if the user’s device does not support it. For usernameless flows, only FIDO devices supporting user verification can be used, regardless of the value you set for |
|
Object |
Optional |
Mutable |
Include the |
|
Integer |
Optional |
Mutable |
When |
|
String |
Required |
Mutable |
Can take any of the following values: * DISABLED - PIN code length is not checked. * ENABLED - For devices that return the PIN code length, the code is checked to verify that it meets the minimum length you specified. For devices that don’t return PIN code length, authentication fails. * OPTIONAL - For devices that return the PIN code length, the code is checked to verify that it meets the minimum length you specified. For devices that don’t return PIN code length, the check is not carried out. |
Additional information returned in responses
-
id- the ID assigned to the policy -
createdAt -
updatedAt -
_embedded.deviceAuthenticationPolicies- array of the device authentication polices that the FIDO policy is used by. Each object in the array consists of the ID of the device authentication policy and the name of the device authentication policy. Returned only if the query includes the parameterexpand=deviceAuthenticationPolicies.
FIDO policies events generated
Refer to Audit Reporting Events for the events generated.
FIDO device metadata
PingOne maintains a global authenticator table, which presents metadata for indvidual authenticators. This includes both authenticators that are represented in the FIDO Alliance Metadata Service (MDS), and custom authenticator data that you add to the table via the UI or the API.
The endpoints provided for FIDO device metadata allow you to:
-
Retrieve the basic metadata for all of the authenticators in the table
-
Retrieve detailed metadata for a specific authenticator from the table
-
Add metadata for custom authenticators
-
Delete from the table a custom authenticator that you added
Adding a custom authenticator
When you use the fidoDevicesMetadata endpoint to add a custom authenticator to the global authenticator table, the data included in the request should comform with the Metadata Statement Format provided by the FIDO Alliance.
Before adding an authenticator, using JSON data provided by a manufacturer, verify that it conforms to the following details expected by the PingOne API:
-
The metadata outlined in the standard should be enclosed in an object called
metadataStatement. -
The
metadataStatementshould be enclosed in an object that also includes the relevant key identifier: theattestationCertificateKeyIdentifiersarray for devices conforming with the U2F protocol, and theaaguidfield for devices conforming with the FIDO2 protocol.
Sample body for request - U2F device
{
"attestationCertificateKeyIdentifiers": [
"31116a647069d1493f58fc5b54e5449e2a52d43e"
],
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"attestationCertificateKeyIdentifiers": [
"31116a647069d1493f58fc5b54e5449e2a52d43e"
],
"description": "Yubikey Edge",
"authenticatorVersion": 1,
"protocolFamily": "u2f",
"schema": 3,
"upv": [
{
"major": 1,
"minor": 1
}
],
"authenticationAlgorithms": [
"secp256r1_ecdsa_sha256_raw"
],
"publicKeyAlgAndEncodings": [
"ecc_x962_raw"
],
"attestationTypes": [
"basic_full"
],
"userVerificationDetails": [
[
{
"userVerificationMethod": "presence_internal"
}
]
],
"keyProtection": [
"hardware",
"secure_element",
"remote_handle"
],
"isKeyRestricted": false,
"isFreshUserVerificationRequired": false,
"matcherProtection": [
"on_chip"
],
"cryptoStrength": 128,
"attachmentHint": [
"external",
"wired"
],
"attestationRootCertificates": [
"MIIDHjCCAgagAwIBAgIEG0BT9zANBgkqhkiG9w0BAQsFADAuMSwwKgYDVQQDEyNZdWJpY28gVTJGIFJvb3QgQ0EgU2VyaWFsIDQ1NzIwMDYzMTAgFw0xNDA4MDEwMDAwMDBaGA8yMDUwMDkwNDAwMDAwMFowLjEsMCoGA1UEAxMjWXViaWNvIFUyRiBSb290IENBIFNlcmlhbCA0NTcyMDA2MzEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC/jwYuhBVlqaiYWEMsrWFisgJ+PtM91eSrpI4TK7U53mwCIawSDHy8vUmk5N2KAj9abvT9NP5SMS1hQi3usxoYGonXQgfO6ZXyUA9a+KAkqdFnBnlyugSeCOep8EdZFfsaRFtMjkwz5Gcz2Py4vIYvCdMHPtwaz0bVuzneueIEz6TnQjE63Rdt2zbwnebwTG5ZybeWSwbzy+BJ34ZHcUhPAY89yJQXuE0IzMZFcEBbPNRbWECRKgjq//qT9nmDOFVlSRCt2wiqPSzluwn+v+suQEBsUjTGMEd25tKXXTkNW21wIWbxeSyUoTXwLvGS6xlwQSgNpk2qXYwf8iXg7VWZAgMBAAGjQjBAMB0GA1UdDgQWBBQgIvz0bNGJhjgpToksyKpP9xv9oDAPBgNVHRMECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAQEAjvjuOMDSa+JXFCLyBKsycXtBVZsJ4Ue3LbaEsPY4MYN/hIQ5ZM5p7EjfcnMG4CtYkNsfNHc0AhBLdq45rnT87q/6O3vUEtNMafbhU6kthX7Y+9XFN9NpmYxr+ekVY5xOxi8h9JDIgoMP4VB1uS0aunL1IGqrNooL9mmFnL2kLVVee6/VR6C5+KSTCMCWppMuJIZII2v9o4dkoZ8Y7QRjQlLfYzd3qGtKbw7xaF1UsG/5xUb/Btwb2X2g4InpiB/yt/3CpQXpiWX/K4mBvUKiGn05ZsqeY1gx4g0xLBqcU9psmyPzK+Vsgw2jeRQ5JlKDyqE0hebfC1tvFu0CCrJFcw=="
],
"icon": ""
}
}
Sample body for request - FIDO2 device
{
"aaguid": "e1a96183-5016-4f24-b55b-e3ae23614cc6",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "e1a96183-5016-4f24-b55b-e3ae23614cc6",
"description": "ATKey.Pro CTAP2.0",
"authenticatorVersion": 2,
"protocolFamily": "fido2",
"schema": 3,
"upv": [
{
"major": 1,
"minor": 0
}
],
"authenticationAlgorithms": [
"secp256r1_ecdsa_sha256_raw"
],
"publicKeyAlgAndEncodings": [
"cose"
],
"attestationTypes": [
"basic_full"
],
"userVerificationDetails": [
[
{
"userVerificationMethod": "fingerprint_internal",
"baDesc": {
"selfAttestedFRR": 0,
"selfAttestedFAR": 0,
"maxTemplates": 0,
"maxRetries": 0,
"blockSlowdown": 0
}
},
{
"userVerificationMethod": "presence_internal"
},
{
"userVerificationMethod": "passcode_internal"
}
]
],
"keyProtection": [
"hardware"
],
"isKeyRestricted": false,
"isFreshUserVerificationRequired": true,
"matcherProtection": [
"on_chip"
],
"attachmentHint": [
"external"
],
"attestationRootCertificates": [
"MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAf8CAQAwCgYIKoZIzj0EAwIDSQAwRgIhAPuVS4Pm2KFXdUMi5Pb/Xy+gCROOuRPZ6I57vWc0EvkBAiEA8aRCnXppAffCEOQBJ7vlgwiiHMXA2tpWX+ObvVKxXbM=",
"MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAQECAQAwCgYIKoZIzj0EAwIDSQAwRgIhAMqIc/Qtr+jZbnrJB7g7W8r/DHmDe+IyFvzwpzdSrxEXAiEAtXcixZznhcDzlnIqFqkIJRGmvL9Yr6lVoP1ZkDeqmjk="
],
"icon": "",
"authenticatorGetInfo": {
"versions": [
"U2F_V2",
"FIDO_2_0",
"FIDO_2_1_PRE"
],
"extensions": [
"credBlob",
"credProtect",
"hmac-secret"
],
"aaguid": "e1a9618350164f24b55be3ae23614cc6",
"options": {
"uv": true,
"userVerificationMgmtPreview": true,
"credMgmt": true,
"uvBioEnroll": true,
"rk": true,
"plat": false,
"clientPin": false,
"up": true,
"bioEnroll": true,
"credentialMgmtPreview": true
},
"maxMsgSize": 2048,
"pinUvAuthProtocols": [
1
],
"maxCredentialCountInList": 20,
"maxCredentialIdLength": 128,
"transports": [
"usb"
],
"algorithms": [
{
"type": "public-key",
"alg": -7
},
{
"type": "public-key",
"alg": -8
}
],
"firmwareVersion": 10013
}
}
}