Add Custom FIDO Device - fido2
POST {{apiPath}}/environments/{{envID}}/fidoDevicesMetadata
Use POST {{apiPath}}/environments/{{envID}}/fidoDevicesMetadata to add a custom FIDO device to the Global Authenticators table.
The data included in the request should comform with the Metadata Statement Format provided by the FIDO Alliance.
If you are 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. This example adds a device that is compliant with the FIDO2 protocol so the relevant identifier is theaaguidfield.
Prerequisites
-
Refer to FIDO Policies for important overview information.
Request Model
| Property | Type | Required? |
|---|---|---|
|
String |
Required |
|
Object |
Required |
Body
raw ( application/json )
{
"aaguid": "{{aaguid}}",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "{{aaguid}}",
"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": "{{aaguid}}",
"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
}
}
}
Example Request
-
cURL
-
C#
-
Go
-
HTTP
-
Java
-
jQuery
-
NodeJS
-
Python
-
PHP
-
Ruby
-
Swift
curl --location --globoff '{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer {{accessToken}}' \
--data '{
"aaguid": "{{aaguid}}",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "{{aaguid}}",
"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": "{{aaguid}}",
"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
}
}
}'
var options = new RestClientOptions("{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata")
{
MaxTimeout = -1,
};
var client = new RestClient(options);
var request = new RestRequest("", Method.Post);
request.AddHeader("Content-Type", "application/json");
request.AddHeader("Authorization", "Bearer {{accessToken}}");
var body = @"{" + "\n" +
@" ""aaguid"": ""{{aaguid}}""," + "\n" +
@" ""metadataStatement"": {" + "\n" +
@" ""legalHeader"": ""https://fidoalliance.org/metadata/metadata-statement-legal-header/""," + "\n" +
@" ""aaguid"": ""{{aaguid}}""," + "\n" +
@" ""description"": ""ATKey.Pro CTAP2.0""," + "\n" +
@" ""authenticatorVersion"": 2," + "\n" +
@" ""protocolFamily"": ""fido2""," + "\n" +
@" ""schema"": 3," + "\n" +
@" ""upv"": [" + "\n" +
@" {" + "\n" +
@" ""major"": 1," + "\n" +
@" ""minor"": 0" + "\n" +
@" }" + "\n" +
@" ]," + "\n" +
@" ""authenticationAlgorithms"": [" + "\n" +
@" ""secp256r1_ecdsa_sha256_raw""" + "\n" +
@" ]," + "\n" +
@" ""publicKeyAlgAndEncodings"": [" + "\n" +
@" ""cose""" + "\n" +
@" ]," + "\n" +
@" ""attestationTypes"": [" + "\n" +
@" ""basic_full""" + "\n" +
@" ]," + "\n" +
@" ""userVerificationDetails"": [" + "\n" +
@" [" + "\n" +
@" {" + "\n" +
@" ""userVerificationMethod"": ""fingerprint_internal""," + "\n" +
@" ""baDesc"": {" + "\n" +
@" ""selfAttestedFRR"": 0," + "\n" +
@" ""selfAttestedFAR"": 0," + "\n" +
@" ""maxTemplates"": 0," + "\n" +
@" ""maxRetries"": 0," + "\n" +
@" ""blockSlowdown"": 0" + "\n" +
@" }" + "\n" +
@" }," + "\n" +
@" {" + "\n" +
@" ""userVerificationMethod"": ""presence_internal""" + "\n" +
@" }," + "\n" +
@" {" + "\n" +
@" ""userVerificationMethod"": ""passcode_internal""" + "\n" +
@" }" + "\n" +
@" ]" + "\n" +
@" ]," + "\n" +
@" ""keyProtection"": [" + "\n" +
@" ""hardware""" + "\n" +
@" ]," + "\n" +
@" ""isKeyRestricted"": false," + "\n" +
@" ""isFreshUserVerificationRequired"": true," + "\n" +
@" ""matcherProtection"": [" + "\n" +
@" ""on_chip""" + "\n" +
@" ]," + "\n" +
@" ""attachmentHint"": [" + "\n" +
@" ""external""" + "\n" +
@" ]," + "\n" +
@" ""attestationRootCertificates"": [" + "\n" +
@" ""MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAf8CAQAwCgYIKoZIzj0EAwIDSQAwRgIhAPuVS4Pm2KFXdUMi5Pb/Xy+gCROOuRPZ6I57vWc0EvkBAiEA8aRCnXppAffCEOQBJ7vlgwiiHMXA2tpWX+ObvVKxXbM=""," + "\n" +
@" ""MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAQECAQAwCgYIKoZIzj0EAwIDSQAwRgIhAMqIc/Qtr+jZbnrJB7g7W8r/DHmDe+IyFvzwpzdSrxEXAiEAtXcixZznhcDzlnIqFqkIJRGmvL9Yr6lVoP1ZkDeqmjk=""" + "\n" +
@" ]," + "\n" +
@" ""icon"": """"," + "\n" +
@" ""authenticatorGetInfo"": {" + "\n" +
@" ""versions"": [" + "\n" +
@" ""U2F_V2""," + "\n" +
@" ""FIDO_2_0""," + "\n" +
@" ""FIDO_2_1_PRE""" + "\n" +
@" ]," + "\n" +
@" ""extensions"": [" + "\n" +
@" ""credBlob""," + "\n" +
@" ""credProtect""," + "\n" +
@" ""hmac-secret""" + "\n" +
@" ]," + "\n" +
@" ""aaguid"": ""{{aaguid}}""," + "\n" +
@" ""options"": {" + "\n" +
@" ""uv"": true," + "\n" +
@" ""userVerificationMgmtPreview"": true," + "\n" +
@" ""credMgmt"": true," + "\n" +
@" ""uvBioEnroll"": true," + "\n" +
@" ""rk"": true," + "\n" +
@" ""plat"": false," + "\n" +
@" ""clientPin"": false," + "\n" +
@" ""up"": true," + "\n" +
@" ""bioEnroll"": true," + "\n" +
@" ""credentialMgmtPreview"": true" + "\n" +
@" }," + "\n" +
@" ""maxMsgSize"": 2048," + "\n" +
@" ""pinUvAuthProtocols"": [" + "\n" +
@" 1" + "\n" +
@" ]," + "\n" +
@" ""maxCredentialCountInList"": 20," + "\n" +
@" ""maxCredentialIdLength"": 128," + "\n" +
@" ""transports"": [" + "\n" +
@" ""usb""" + "\n" +
@" ]," + "\n" +
@" ""algorithms"": [" + "\n" +
@" {" + "\n" +
@" ""type"": ""public-key""," + "\n" +
@" ""alg"": -7" + "\n" +
@" }," + "\n" +
@" {" + "\n" +
@" ""type"": ""public-key""," + "\n" +
@" ""alg"": -8" + "\n" +
@" }" + "\n" +
@" ]," + "\n" +
@" ""firmwareVersion"": 10013" + "\n" +
@" }" + "\n" +
@" }" + "\n" +
@"}";
request.AddStringBody(body, DataFormat.Json);
RestResponse response = await client.ExecuteAsync(request);
Console.WriteLine(response.Content);
package main
import (
"fmt"
"strings"
"net/http"
"io"
)
func main() {
url := "{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata"
method := "POST"
payload := strings.NewReader(`{
"aaguid": "{{aaguid}}",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "{{aaguid}}",
"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": "{{aaguid}}",
"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
}
}
}`)
client := &http.Client {
}
req, err := http.NewRequest(method, url, payload)
if err != nil {
fmt.Println(err)
return
}
req.Header.Add("Content-Type", "application/json")
req.Header.Add("Authorization", "Bearer {{accessToken}}")
res, err := client.Do(req)
if err != nil {
fmt.Println(err)
return
}
defer res.Body.Close()
body, err := io.ReadAll(res.Body)
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
POST /environments/{{envID}}/fidoDevicesMetadata HTTP/1.1
Host: {{apiPath}}
Content-Type: application/json
Authorization: Bearer {{accessToken}}
{
"aaguid": "{{aaguid}}",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "{{aaguid}}",
"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": "{{aaguid}}",
"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
}
}
}
OkHttpClient client = new OkHttpClient().newBuilder()
.build();
MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType, "{\n \"aaguid\": \"{{aaguid}}\",\n \"metadataStatement\": {\n \"legalHeader\": \"https://fidoalliance.org/metadata/metadata-statement-legal-header/\",\n \"aaguid\": \"{{aaguid}}\",\n \"description\": \"ATKey.Pro CTAP2.0\",\n \"authenticatorVersion\": 2,\n \"protocolFamily\": \"fido2\",\n \"schema\": 3,\n \"upv\": [\n {\n \"major\": 1,\n \"minor\": 0\n }\n ],\n \"authenticationAlgorithms\": [\n \"secp256r1_ecdsa_sha256_raw\"\n ],\n \"publicKeyAlgAndEncodings\": [\n \"cose\"\n ],\n \"attestationTypes\": [\n \"basic_full\"\n ],\n \"userVerificationDetails\": [\n [\n {\n \"userVerificationMethod\": \"fingerprint_internal\",\n \"baDesc\": {\n \"selfAttestedFRR\": 0,\n \"selfAttestedFAR\": 0,\n \"maxTemplates\": 0,\n \"maxRetries\": 0,\n \"blockSlowdown\": 0\n }\n },\n {\n \"userVerificationMethod\": \"presence_internal\"\n },\n {\n \"userVerificationMethod\": \"passcode_internal\"\n }\n ]\n ],\n \"keyProtection\": [\n \"hardware\"\n ],\n \"isKeyRestricted\": false,\n \"isFreshUserVerificationRequired\": true,\n \"matcherProtection\": [\n \"on_chip\"\n ],\n \"attachmentHint\": [\n \"external\"\n ],\n \"attestationRootCertificates\": [\n \"MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAf8CAQAwCgYIKoZIzj0EAwIDSQAwRgIhAPuVS4Pm2KFXdUMi5Pb/Xy+gCROOuRPZ6I57vWc0EvkBAiEA8aRCnXppAffCEOQBJ7vlgwiiHMXA2tpWX+ObvVKxXbM=\",\n \"MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAQECAQAwCgYIKoZIzj0EAwIDSQAwRgIhAMqIc/Qtr+jZbnrJB7g7W8r/DHmDe+IyFvzwpzdSrxEXAiEAtXcixZznhcDzlnIqFqkIJRGmvL9Yr6lVoP1ZkDeqmjk=\"\n ],\n \"icon\": \"\",\n \"authenticatorGetInfo\": {\n \"versions\": [\n \"U2F_V2\",\n \"FIDO_2_0\",\n \"FIDO_2_1_PRE\"\n ],\n \"extensions\": [\n \"credBlob\",\n \"credProtect\",\n \"hmac-secret\"\n ],\n \"aaguid\": \"{{aaguid}}\",\n \"options\": {\n \"uv\": true,\n \"userVerificationMgmtPreview\": true,\n \"credMgmt\": true,\n \"uvBioEnroll\": true,\n \"rk\": true,\n \"plat\": false,\n \"clientPin\": false,\n \"up\": true,\n \"bioEnroll\": true,\n \"credentialMgmtPreview\": true\n },\n \"maxMsgSize\": 2048,\n \"pinUvAuthProtocols\": [\n 1\n ],\n \"maxCredentialCountInList\": 20,\n \"maxCredentialIdLength\": 128,\n \"transports\": [\n \"usb\"\n ],\n \"algorithms\": [\n {\n \"type\": \"public-key\",\n \"alg\": -7\n },\n {\n \"type\": \"public-key\",\n \"alg\": -8\n }\n ],\n \"firmwareVersion\": 10013\n }\n }\n}");
Request request = new Request.Builder()
.url("{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata")
.method("POST", body)
.addHeader("Content-Type", "application/json")
.addHeader("Authorization", "Bearer {{accessToken}}")
.build();
Response response = client.newCall(request).execute();
var settings = {
"url": "{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata",
"method": "POST",
"timeout": 0,
"headers": {
"Content-Type": "application/json",
"Authorization": "Bearer {{accessToken}}"
},
"data": JSON.stringify({
"aaguid": "{{aaguid}}",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "{{aaguid}}",
"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": "{{aaguid}}",
"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
}
}
}),
};
$.ajax(settings).done(function (response) {
console.log(response);
});
var request = require('request');
var options = {
'method': 'POST',
'url': '{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata',
'headers': {
'Content-Type': 'application/json',
'Authorization': 'Bearer {{accessToken}}'
},
body: JSON.stringify({
"aaguid": "{{aaguid}}",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "{{aaguid}}",
"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": "{{aaguid}}",
"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
}
}
})
};
request(options, function (error, response) {
if (error) throw new Error(error);
console.log(response.body);
});
import requests
import json
url = "{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata"
payload = json.dumps({
"aaguid": "{{aaguid}}",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "{{aaguid}}",
"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": "{{aaguid}}",
"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
}
}
})
headers = {
'Content-Type': 'application/json',
'Authorization': 'Bearer {{accessToken}}'
}
response = requests.request("POST", url, headers=headers, data=payload)
print(response.text)
<?php
require_once 'HTTP/Request2.php';
$request = new HTTP_Request2();
$request->setUrl('{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata');
$request->setMethod(HTTP_Request2::METHOD_POST);
$request->setConfig(array(
'follow_redirects' => TRUE
));
$request->setHeader(array(
'Content-Type' => 'application/json',
'Authorization' => 'Bearer {{accessToken}}'
));
$request->setBody('{\n "aaguid": "{{aaguid}}",\n "metadataStatement": {\n "legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",\n "aaguid": "{{aaguid}}",\n "description": "ATKey.Pro CTAP2.0",\n "authenticatorVersion": 2,\n "protocolFamily": "fido2",\n "schema": 3,\n "upv": [\n {\n "major": 1,\n "minor": 0\n }\n ],\n "authenticationAlgorithms": [\n "secp256r1_ecdsa_sha256_raw"\n ],\n "publicKeyAlgAndEncodings": [\n "cose"\n ],\n "attestationTypes": [\n "basic_full"\n ],\n "userVerificationDetails": [\n [\n {\n "userVerificationMethod": "fingerprint_internal",\n "baDesc": {\n "selfAttestedFRR": 0,\n "selfAttestedFAR": 0,\n "maxTemplates": 0,\n "maxRetries": 0,\n "blockSlowdown": 0\n }\n },\n {\n "userVerificationMethod": "presence_internal"\n },\n {\n "userVerificationMethod": "passcode_internal"\n }\n ]\n ],\n "keyProtection": [\n "hardware"\n ],\n "isKeyRestricted": false,\n "isFreshUserVerificationRequired": true,\n "matcherProtection": [\n "on_chip"\n ],\n "attachmentHint": [\n "external"\n ],\n "attestationRootCertificates": [\n "MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAf8CAQAwCgYIKoZIzj0EAwIDSQAwRgIhAPuVS4Pm2KFXdUMi5Pb/Xy+gCROOuRPZ6I57vWc0EvkBAiEA8aRCnXppAffCEOQBJ7vlgwiiHMXA2tpWX+ObvVKxXbM=",\n "MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAQECAQAwCgYIKoZIzj0EAwIDSQAwRgIhAMqIc/Qtr+jZbnrJB7g7W8r/DHmDe+IyFvzwpzdSrxEXAiEAtXcixZznhcDzlnIqFqkIJRGmvL9Yr6lVoP1ZkDeqmjk="\n ],\n "icon": "",\n "authenticatorGetInfo": {\n "versions": [\n "U2F_V2",\n "FIDO_2_0",\n "FIDO_2_1_PRE"\n ],\n "extensions": [\n "credBlob",\n "credProtect",\n "hmac-secret"\n ],\n "aaguid": "{{aaguid}}",\n "options": {\n "uv": true,\n "userVerificationMgmtPreview": true,\n "credMgmt": true,\n "uvBioEnroll": true,\n "rk": true,\n "plat": false,\n "clientPin": false,\n "up": true,\n "bioEnroll": true,\n "credentialMgmtPreview": true\n },\n "maxMsgSize": 2048,\n "pinUvAuthProtocols": [\n 1\n ],\n "maxCredentialCountInList": 20,\n "maxCredentialIdLength": 128,\n "transports": [\n "usb"\n ],\n "algorithms": [\n {\n "type": "public-key",\n "alg": -7\n },\n {\n "type": "public-key",\n "alg": -8\n }\n ],\n "firmwareVersion": 10013\n }\n }\n}');
try {
$response = $request->send();
if ($response->getStatus() == 200) {
echo $response->getBody();
}
else {
echo 'Unexpected HTTP status: ' . $response->getStatus() . ' ' .
$response->getReasonPhrase();
}
}
catch(HTTP_Request2_Exception $e) {
echo 'Error: ' . $e->getMessage();
}
require "uri"
require "json"
require "net/http"
url = URI("{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata")
http = Net::HTTP.new(url.host, url.port);
request = Net::HTTP::Post.new(url)
request["Content-Type"] = "application/json"
request["Authorization"] = "Bearer {{accessToken}}"
request.body = JSON.dump({
"aaguid": "{{aaguid}}",
"metadataStatement": {
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
"aaguid": "{{aaguid}}",
"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": "{{aaguid}}",
"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
}
}
})
response = http.request(request)
puts response.read_body
let parameters = "{\n \"aaguid\": \"{{aaguid}}\",\n \"metadataStatement\": {\n \"legalHeader\": \"https://fidoalliance.org/metadata/metadata-statement-legal-header/\",\n \"aaguid\": \"{{aaguid}}\",\n \"description\": \"ATKey.Pro CTAP2.0\",\n \"authenticatorVersion\": 2,\n \"protocolFamily\": \"fido2\",\n \"schema\": 3,\n \"upv\": [\n {\n \"major\": 1,\n \"minor\": 0\n }\n ],\n \"authenticationAlgorithms\": [\n \"secp256r1_ecdsa_sha256_raw\"\n ],\n \"publicKeyAlgAndEncodings\": [\n \"cose\"\n ],\n \"attestationTypes\": [\n \"basic_full\"\n ],\n \"userVerificationDetails\": [\n [\n {\n \"userVerificationMethod\": \"fingerprint_internal\",\n \"baDesc\": {\n \"selfAttestedFRR\": 0,\n \"selfAttestedFAR\": 0,\n \"maxTemplates\": 0,\n \"maxRetries\": 0,\n \"blockSlowdown\": 0\n }\n },\n {\n \"userVerificationMethod\": \"presence_internal\"\n },\n {\n \"userVerificationMethod\": \"passcode_internal\"\n }\n ]\n ],\n \"keyProtection\": [\n \"hardware\"\n ],\n \"isKeyRestricted\": false,\n \"isFreshUserVerificationRequired\": true,\n \"matcherProtection\": [\n \"on_chip\"\n ],\n \"attachmentHint\": [\n \"external\"\n ],\n \"attestationRootCertificates\": [\n \"MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAf8CAQAwCgYIKoZIzj0EAwIDSQAwRgIhAPuVS4Pm2KFXdUMi5Pb/Xy+gCROOuRPZ6I57vWc0EvkBAiEA8aRCnXppAffCEOQBJ7vlgwiiHMXA2tpWX+ObvVKxXbM=\",\n \"MIIBzDCCAXGgAwIBAgIBATAKBggqhkjOPQQDAjBiMQswCQYDVQQGEwJTRTESMBAGA1UECgwJQVRLZXlDQTAwMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMRswGQYDVQQDExJBdXRoZW50cmVuZCBDQSAwMDAwIBcNMTYwMjI2MDgxMTA2WhgPMjA1MDAyMjUwODExMDZaMGIxCzAJBgNVBAYTAlNFMRIwEAYDVQQKDAlBVEtleUNBMDAxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xGzAZBgNVBAMTEkF1dGhlbnRyZW5kIENBIDAwMDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABAJcWqeCxga9KJbFO2TZdjcgrtZAgfi8TXKu+v5lcR5ceb5GJYxyoCjhueESL3ddmMIkpGyhsEEtfFUyBwsyFVCjFjAUMBIGA1UdEwEB/wQIMAYBAQECAQAwCgYIKoZIzj0EAwIDSQAwRgIhAMqIc/Qtr+jZbnrJB7g7W8r/DHmDe+IyFvzwpzdSrxEXAiEAtXcixZznhcDzlnIqFqkIJRGmvL9Yr6lVoP1ZkDeqmjk=\"\n ],\n \"icon\": \"\",\n \"authenticatorGetInfo\": {\n \"versions\": [\n \"U2F_V2\",\n \"FIDO_2_0\",\n \"FIDO_2_1_PRE\"\n ],\n \"extensions\": [\n \"credBlob\",\n \"credProtect\",\n \"hmac-secret\"\n ],\n \"aaguid\": \"{{aaguid}}\",\n \"options\": {\n \"uv\": true,\n \"userVerificationMgmtPreview\": true,\n \"credMgmt\": true,\n \"uvBioEnroll\": true,\n \"rk\": true,\n \"plat\": false,\n \"clientPin\": false,\n \"up\": true,\n \"bioEnroll\": true,\n \"credentialMgmtPreview\": true\n },\n \"maxMsgSize\": 2048,\n \"pinUvAuthProtocols\": [\n 1\n ],\n \"maxCredentialCountInList\": 20,\n \"maxCredentialIdLength\": 128,\n \"transports\": [\n \"usb\"\n ],\n \"algorithms\": [\n {\n \"type\": \"public-key\",\n \"alg\": -7\n },\n {\n \"type\": \"public-key\",\n \"alg\": -8\n }\n ],\n \"firmwareVersion\": 10013\n }\n }\n}"
let postData = parameters.data(using: .utf8)
var request = URLRequest(url: URL(string: "{{apiPath}}/environments/{{envID}}/fidoDevicesMetadata")!,timeoutInterval: Double.infinity)
request.addValue("application/json", forHTTPHeaderField: "Content-Type")
request.addValue("Bearer {{accessToken}}", forHTTPHeaderField: "Authorization")
request.httpMethod = "POST"
request.httpBody = postData
let task = URLSession.shared.dataTask(with: request) { data, response, error in
guard let data = data else {
print(String(describing: error))
return
}
print(String(data: data, encoding: .utf8)!)
}
task.resume()
Example Response
201 Created
{
"environment": {
"id": "abfba8f6-49eb-49f5-a5d9-80ad5c98f9f6"
},
"aaguid": "e1a96183-5016-4f24-b55b-e3ae23614cc6",
"metadataStatement": {
"aaguid": "e1a96183-5016-4f24-b55b-e3ae23614cc6",
"description": "ATKey.Pro CTAP2.0",
"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"
],
"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
},
"keyRestricted": false,
"freshUserVerificationRequired": false
},
"createdAt": "2022-07-26T13:22:25.846Z",
"updatedAt": "2022-07-26T13:22:25.846Z"
}