diff --git a/.gitignore b/.gitignore index e9601e7a..698019c3 100644 --- a/.gitignore +++ b/.gitignore @@ -82,7 +82,7 @@ env3/ .tags* targets/*/docs/ main - +.vscode/ builds/* tools/testing/.idea/* tools/testing/tests/__pycache__/* diff --git a/fido2/ctap.c b/fido2/ctap.c index f752c67b..05029d32 100644 --- a/fido2/ctap.c +++ b/fido2/ctap.c @@ -26,6 +26,7 @@ #include "device.h" #include "data_migration.h" +#include "version.h" uint8_t PIN_TOKEN[PIN_TOKEN_SIZE]; uint8_t KEY_AGREEMENT_PUB[64]; @@ -135,10 +136,11 @@ uint8_t ctap_get_info(CborEncoder * encoder) CborEncoder map; CborEncoder options; CborEncoder pins; + CborEncoder algorithms; uint8_t aaguid[16]; device_read_aaguid(aaguid); - ret = cbor_encoder_create_map(encoder, &map, 8); + ret = cbor_encoder_create_map(encoder, &map, 11); check_ret(ret); { @@ -202,16 +204,6 @@ uint8_t ctap_get_info(CborEncoder * encoder) check_ret(ret); } - // NOT [yet] capable of verifying user - // Do not add option if UV isn't supported. - // - // ret = cbor_encode_text_string(&options, "uv", 2); - // check_ret(ret); - // { - // ret = cbor_encode_boolean(&options, 0); - // check_ret(ret); - // } - ret = cbor_encode_text_string(&options, "plat", 4); check_ret(ret); { @@ -232,10 +224,15 @@ uint8_t ctap_get_info(CborEncoder * encoder) ret = cbor_encode_boolean(&options, ctap_is_pin_set()); check_ret(ret); } - - - - + // NOT [yet] capable of verifying user + // Do not add option if UV isn't supported. + // + // ret = cbor_encode_text_string(&options, "uv", 2); + // check_ret(ret); + // { + // ret = cbor_encode_boolean(&options, 0); + // check_ret(ret); + // } } ret = cbor_encoder_close_container(&map, &options); check_ret(ret); @@ -261,21 +258,92 @@ uint8_t ctap_get_info(CborEncoder * encoder) check_ret(ret); } - - ret = cbor_encode_uint(&map, 0x07); //maxCredentialCountInList + ret = cbor_encode_uint(&map, RESP_maxCredentialCountInList); check_ret(ret); { ret = cbor_encode_uint(&map, ALLOW_LIST_MAX_SIZE); check_ret(ret); } - ret = cbor_encode_uint(&map, 0x08); // maxCredentialIdLength + ret = cbor_encode_uint(&map, RESP_maxCredentialIdLength); check_ret(ret); { ret = cbor_encode_uint(&map, 128); check_ret(ret); } + ret = cbor_encode_uint(&map, RESP_transports); + check_ret(ret); + { + ret = cbor_encoder_create_array(&map, &array, device_is_nfc() == NFC_IS_NA? 1 : 2); + check_ret(ret); + { + if (device_is_nfc() != NFC_IS_NA) + { + ret = cbor_encode_text_stringz(&array, "nfc"); + check_ret(ret); + } + + ret = cbor_encode_text_stringz(&array, "usb"); + check_ret(ret); + } + ret = cbor_encoder_close_container(&map, &array); + check_ret(ret); + } + + ret = cbor_encode_uint(&map, RESP_algorithms); + check_ret(ret); + { + ret = cbor_encoder_create_array(&map, &array, 2); + check_ret(ret); + { + ret = cbor_encoder_create_map(&array, &algorithms, 2); + check_ret(ret); + { + ret = cbor_encode_text_string(&algorithms, "alg", 3); + check_ret(ret); + { + ret = cbor_encode_int(&algorithms, COSE_ALG_EDDSA); + check_ret(ret); + } + ret = cbor_encode_text_string(&algorithms, "type", 4); + check_ret(ret); + { + ret = cbor_encode_text_string(&algorithms, "public-key", 10); + check_ret(ret); + } + } + ret = cbor_encoder_close_container(&array, &algorithms); + check_ret(ret); + + ret = cbor_encoder_create_map(&array, &algorithms, 2); + check_ret(ret); + { + ret = cbor_encode_text_string(&algorithms, "alg", 3); + check_ret(ret); + { + ret = cbor_encode_int(&algorithms, COSE_ALG_ES256); + check_ret(ret); + } + ret = cbor_encode_text_string(&algorithms, "type", 4); + check_ret(ret); + { + ret = cbor_encode_text_string(&algorithms, "public-key", 10); + check_ret(ret); + } + } + ret = cbor_encoder_close_container(&array, &algorithms); + check_ret(ret); + } + ret = cbor_encoder_close_container(&map, &array); + check_ret(ret); + } + ret = cbor_encode_uint(&map, RESP_firmwareVersion); + check_ret(ret); + { + ret = cbor_encode_uint(&map, __builtin_bswap32(firmware_version.raw) >> 8); + check_ret(ret); + } } ret = cbor_encoder_close_container(encoder, &map); check_ret(ret); @@ -283,8 +351,6 @@ uint8_t ctap_get_info(CborEncoder * encoder) return CTAP1_ERR_SUCCESS; } - - static int ctap_add_cose_key(CborEncoder * cose_key, uint8_t * x, uint8_t * y, uint8_t credtype, int32_t algtype) { int ret; @@ -315,7 +381,6 @@ static int ctap_add_cose_key(CborEncoder * cose_key, uint8_t * x, uint8_t * y, u check_ret(ret); } - { ret = cbor_encode_int(&map, COSE_KEY_LABEL_X); check_ret(ret); @@ -336,6 +401,7 @@ static int ctap_add_cose_key(CborEncoder * cose_key, uint8_t * x, uint8_t * y, u return 0; } + static int ctap_generate_cose_key(CborEncoder * cose_key, uint8_t * hmac_input, int len, uint8_t credtype, int32_t algtype) { uint8_t x[32], y[32]; @@ -407,6 +473,7 @@ static void ctap_increment_rk_store() STATE.rk_stored++; ctap_flush_state(); } + static void ctap_decrement_rk_store() { STATE.rk_stored--; @@ -916,8 +983,6 @@ int ctap_authenticate_credential(struct rpId * rp, CTAP_credentialDescriptor * d return 0; } - - uint8_t ctap_make_credential(CborEncoder * encoder, uint8_t * request, int length) { CTAP_makeCredential MC; @@ -1080,7 +1145,6 @@ static uint8_t ctap_add_credential_descriptor(CborEncoder * map, struct Credenti check_ret(ret); } - ret = cbor_encoder_close_container(map, &desc); check_ret(ret); @@ -1264,7 +1328,6 @@ int ctap_filter_invalid_credentials(CTAP_getAssertion * GA) return count; } - static int8_t save_credential_list( uint8_t * clientDataHash, CTAP_credentialDescriptor * creds, uint32_t count, @@ -1364,7 +1427,6 @@ uint8_t ctap_end_get_assertion(CborEncoder * map, CTAP_credentialDescriptor * cr check_retr(ret); } - return 0; } @@ -2350,7 +2412,6 @@ uint8_t ctap_request(uint8_t * pkt_raw, int length, CTAP_RESPONSE * resp) status = ctap_get_info(&encoder); resp->length = cbor_encoder_get_buffer_size(&encoder, buf); - dump_hex1(TAG_DUMP, buf, resp->length); break; @@ -2452,7 +2513,6 @@ void ctap_load_external_keys(uint8_t * keybytes){ crypto_load_master_secret(STATE.key_space); } -#include "version.h" void ctap_init() { printf1(TAG_ERR,"Current firmware version address: %p\r\n", &firmware_version); diff --git a/fido2/ctap.h b/fido2/ctap.h index c08f9360..1f88bdc2 100644 --- a/fido2/ctap.h +++ b/fido2/ctap.h @@ -81,12 +81,27 @@ #define CREDID_ALG_ES256 0x0 #define CREDID_ALG_EDDSA 0x1 -#define RESP_versions 0x1 -#define RESP_extensions 0x2 -#define RESP_aaguid 0x3 -#define RESP_options 0x4 -#define RESP_maxMsgSize 0x5 -#define RESP_pinProtocols 0x6 +#define RESP_versions 0x01 +#define RESP_extensions 0x02 +#define RESP_aaguid 0x03 +#define RESP_options 0x04 +#define RESP_maxMsgSize 0x05 +#define RESP_pinProtocols 0x06 +#define RESP_maxCredentialCountInList 0x07 +#define RESP_maxCredentialIdLength 0x08 +#define RESP_transports 0x09 +#define RESP_algorithms 0x0A +#define RESP_maxSerializedLargeBlobArray 0x0B +#define RESP_forcePINChange 0x0C +#define RESP_minPINLength 0x0D +#define RESP_firmwareVersion 0X0E +#define RESP_maxCredBlobLength 0x0F +#define RESP_maxRPIDsForSetMinPINLength 0x10 +#define RESP_preferredPlatformUvAttempts 0x11 +#define RESP_uvModality 0x12 +#define RESP_certifications 0x13 +#define RESP_remainingDiscoverableCredentials 0x14 +#define RESP_vendorPrototypeConfigCommands 0x15 #define RESP_fmt 0x01 #define RESP_authData 0x02 diff --git a/metadata/Solo-FIDO2-CTAP2-Authenticator.json b/metadata/Solo-FIDO2-CTAP2-Authenticator.json index 2d35c35d..dda0fc17 100644 --- a/metadata/Solo-FIDO2-CTAP2-Authenticator.json +++ b/metadata/Solo-FIDO2-CTAP2-Authenticator.json @@ -1,41 +1,101 @@ { - "description": "Solo Secp256R1 FIDO2 CTAP2 Authenticator", "aaguid": "8876631b-d4a0-427f-5773-0ec71c9e0279", - "alternativeDescriptions": { + "metadataStatement": { + "legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/", + "aaguid": "8876631b-d4a0-427f-5773-0ec71c9e0279", + "description": "Solo Secp256R1 FIDO2 CTAP2 Authenticator", + "authenticatorVersion": 2, + "protocolFamily": "fido2", + "schema": 3, + "upv": [ + { + "major": 1, + "minor": 0 + } + ], + "authenticationAlgorithms": [ + "ed25519_eddsa_sha512_raw", + "secp256r1_ecdsa_sha256_raw" + ], + "publicKeyAlgAndEncodings": ["cose"], + "attestationTypes": ["basic_full"], + "userVerificationDetails": [ + [ + { + "userVerificationMethod": "passcode_external" + }, + { + "userVerificationMethod": "presence_internal" + } + ], + [ + { + "userVerificationMethod": "none" + } + ], + [ + { + "userVerificationMethod": "passcode_external" + } + ], + [ + { + "userVerificationMethod": "presence_internal" + } + ] + ], + "keyProtection": ["hardware", "secure_element"], + "matcherProtection": ["on_chip"], + "cryptoStrength": 128, + "attachmentHint": ["external", "wired"], + "tcDisplay": [], + "attestationRootCertificates": [ + "MIIB9DCCAZoCCQDER2OSj/S+jDAKBggqhkjOPQQDAjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMCAXDTE4MTExMTEyNTE0MloYDzIwNjgxMDI5MTI1MTQyWjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEWHAN0CCJVZdMs0oktZ5m93uxmB1iyq8ELRLtqVFLSOiHQEab56qRTB/QzrpGAY++Y2mw+vRuQMNhBiU0KzwjBjAKBggqhkjOPQQDAgNIADBFAiEAz9SlrAXIlEu87vra54rICPs+4b0qhp3PdzcTg7rvnP0CIGjxzlteQQx+jQGd7rwSZuE5RWUPVygYhUstQO9zNUOs" + ], + "icon": "", + "authenticatorGetInfo": { + "versions": ["U2F_V2", "FIDO_2_0", "FIDO_2_1_PRE"], + "extensions": ["credProtect", "hmac-secret"], + "aaguid": "8876631bd4a0427f57730ec71c9e0279", + "options": { + "plat": false, + "rk": true, + "clientPin": true, + "credMgmt": true, + "up": false + }, + "maxMsgSize": 1200, + "pinUvAuthProtocols": [1], + "maxCredentialCountInList ": 20, + "maxCredentialIdLength": 128, + "transports": ["usb"], + "algorithms": [ + { + "type": "public-key", + "alg": -8 + }, + { + "type": "public-key", + "alg": -7 + } + ], + "firmwareVersion": 262401 + } }, - "protocolFamily": "fido2", - "authenticatorVersion": 2, - "upv": [ + "statusReports": [ + { + "status": "FIDO_CERTIFIED_L1", + "effectiveDate": "2020-04-02", + "url": "https://solokeys.com", + "certificationDescriptor": "Solo FIDO2 Authenticator", + "certificateNumber": "FIDO20020191001001", + "certificationPolicyVersion": "1.3.6", + "certificationRequirementsVersion": "1.0.0" + }, { - "major": 1, - "minor": 0 + "status": "FIDO_CERTIFIED", + "effectiveDate": "2020-04-02" } ], - "assertionScheme": "FIDOV2", - "authenticationAlgorithm": 1, - "publicKeyAlgAndEncoding": 260, - "attestationTypes": [ - 15879 - ], - "userVerificationDetails": [ - [ - { - "userVerification": 1 - }, - { - "userVerification": 4 - } - ] - ], - "keyProtection": 2, - "matcherProtection": 4, - "cryptoStrength": 128, - "attachmentHint": 2, - "isSecondFactorOnly": false, - "tcDisplay": 0, - "attestationRootCertificates": [ -"MIIB9DCCAZoCCQDER2OSj/S+jDAKBggqhkjOPQQDAjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMCAXDTE4MTExMTEyNTE0MloYDzIwNjgxMDI5MTI1MTQyWjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEWHAN0CCJVZdMs0oktZ5m93uxmB1iyq8ELRLtqVFLSOiHQEab56qRTB/QzrpGAY++Y2mw+vRuQMNhBiU0KzwjBjAKBggqhkjOPQQDAgNIADBFAiEAz9SlrAXIlEu87vra54rICPs+4b0qhp3PdzcTg7rvnP0CIGjxzlteQQx+jQGd7rwSZuE5RWUPVygYhUstQO9zNUOs" - ], - "icon": "" - + "timeOfLastStatusChange": "2020-04-02" } diff --git a/metadata/Solo-FIDO2-U2F-Authenticator.json b/metadata/Solo-FIDO2-U2F-Authenticator.json index 71a711f3..f5fe12ee 100644 --- a/metadata/Solo-FIDO2-U2F-Authenticator.json +++ b/metadata/Solo-FIDO2-U2F-Authenticator.json @@ -1,37 +1,53 @@ { - "description": "Solo Secp256R1 U2F Authenticator", - "attestationCertificateKeyIdentifiers": ["3be6d2c06ff2e7b07c9d9e28c020b00d07c815c8"], - "alternativeDescriptions": { - }, - "protocolFamily": "u2f", - "authenticatorVersion": 2, - "upv": [ - { - "major": 1, - "minor": 2 - } + "attestationCertificateKeyIdentifiers": [ + "3be6d2c06ff2e7b07c9d9e28c020b00d07c815c8" ], - "assertionScheme": "U2FV1BIN", - "authenticationAlgorithm": 1, - "publicKeyAlgAndEncoding": 256, - "attestationTypes": [ - 15879 - ], - "userVerificationDetails": [ - [ + "metadataStatement": { + "legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/", + "attestationCertificateKeyIdentifiers": [ + "3be6d2c06ff2e7b07c9d9e28c020b00d07c815c8" + ], + "description": "Solo Secp256R1 U2F Authenticator", + "authenticatorVersion": 2, + "protocolFamily": "u2f", + "schema": 3, + "upv": [ { - "userVerification": 1 + "major": 1, + "minor": 2 } - ] - ], - "keyProtection": 2, - "matcherProtection": 4, - "cryptoStrength": 128, - "attachmentHint": 2, - "isSecondFactorOnly": true, - "tcDisplay": 0, - "attestationRootCertificates": [ -"MIIB9DCCAZoCCQDER2OSj/S+jDAKBggqhkjOPQQDAjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMCAXDTE4MTExMTEyNTE0MloYDzIwNjgxMDI5MTI1MTQyWjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEWHAN0CCJVZdMs0oktZ5m93uxmB1iyq8ELRLtqVFLSOiHQEab56qRTB/QzrpGAY++Y2mw+vRuQMNhBiU0KzwjBjAKBggqhkjOPQQDAgNIADBFAiEAz9SlrAXIlEu87vra54rICPs+4b0qhp3PdzcTg7rvnP0CIGjxzlteQQx+jQGd7rwSZuE5RWUPVygYhUstQO9zNUOs" + ], + "authenticationAlgorithms": ["secp256r1_ecdsa_sha256_raw"], + "publicKeyAlgAndEncodings": ["ecc_x962_raw"], + "attestationTypes": ["basic_full"], + "userVerificationDetails": [ + [ + { + "userVerificationMethod": "presence_internal" + } + ] + ], + "keyProtection": ["hardware", "secure_element"], + "matcherProtection": ["on_chip"], + "cryptoStrength": 128, + "attachmentHint": ["external", "wired", "wireless", "nfc"], + "tcDisplay": [], + "attestationRootCertificates": [ + "MIIB9DCCAZoCCQDER2OSj/S+jDAKBggqhkjOPQQDAjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMCAXDTE4MTExMTEyNTE0MloYDzIwNjgxMDI5MTI1MTQyWjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEWHAN0CCJVZdMs0oktZ5m93uxmB1iyq8ELRLtqVFLSOiHQEab56qRTB/QzrpGAY++Y2mw+vRuQMNhBiU0KzwjBjAKBggqhkjOPQQDAgNIADBFAiEAz9SlrAXIlEu87vra54rICPs+4b0qhp3PdzcTg7rvnP0CIGjxzlteQQx+jQGd7rwSZuE5RWUPVygYhUstQO9zNUOs" + ], + "icon": "" + }, + "statusReports": [ + { + "status": "NOT_FIDO_CERTIFIED", + "effectiveDate": "2020-04-02", + "url": "https://solokeys.com", + "certificationDescriptor": "Solo Secp256R1 U2F Authenticator" + }, + { + "status": "NOT_FIDO_CERTIFIED", + "effectiveDate": "2020-04-02" + } ], - "icon": "" + "timeOfLastStatusChange": "2020-04-02" } diff --git a/metadata/SoloTap-FIDO2-CTAP2-Authenticator.json b/metadata/SoloTap-FIDO2-CTAP2-Authenticator.json index 7e265c68..1e9e15bd 100644 --- a/metadata/SoloTap-FIDO2-CTAP2-Authenticator.json +++ b/metadata/SoloTap-FIDO2-CTAP2-Authenticator.json @@ -1,41 +1,101 @@ { - "description": "Solo Tap Secp256R1 FIDO2 CTAP2 Authenticator", "aaguid": "8976631b-d4a0-427f-5773-0ec71c9e0279", - "alternativeDescriptions": { + "metadataStatement": { + "legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/", + "aaguid": "8976631b-d4a0-427f-5773-0ec71c9e0279", + "description": "Solo Tap Secp256R1 FIDO2 CTAP2 Authenticator", + "authenticatorVersion": 2, + "protocolFamily": "fido2", + "schema": 3, + "upv": [ + { + "major": 1, + "minor": 0 + } + ], + "authenticationAlgorithms": [ + "ed25519_eddsa_sha512_raw", + "secp256r1_ecdsa_sha256_raw" + ], + "publicKeyAlgAndEncodings": ["cose"], + "attestationTypes": ["basic_full"], + "userVerificationDetails": [ + [ + { + "userVerificationMethod": "passcode_external" + }, + { + "userVerificationMethod": "presence_internal" + } + ], + [ + { + "userVerificationMethod": "none" + } + ], + [ + { + "userVerificationMethod": "passcode_external" + } + ], + [ + { + "userVerificationMethod": "presence_internal" + } + ] + ], + "keyProtection": ["hardware", "secure_element"], + "matcherProtection": ["on_chip"], + "cryptoStrength": 128, + "attachmentHint": ["external", "wired", "wireless", "nfc"], + "tcDisplay": [], + "attestationRootCertificates": [ + "MIIB9DCCAZoCCQDER2OSj/S+jDAKBggqhkjOPQQDAjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMCAXDTE4MTExMTEyNTE0MloYDzIwNjgxMDI5MTI1MTQyWjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEWHAN0CCJVZdMs0oktZ5m93uxmB1iyq8ELRLtqVFLSOiHQEab56qRTB/QzrpGAY++Y2mw+vRuQMNhBiU0KzwjBjAKBggqhkjOPQQDAgNIADBFAiEAz9SlrAXIlEu87vra54rICPs+4b0qhp3PdzcTg7rvnP0CIGjxzlteQQx+jQGd7rwSZuE5RWUPVygYhUstQO9zNUOs" + ], + "icon": "", + "authenticatorGetInfo": { + "versions": ["U2F_V2", "FIDO_2_0", "FIDO_2_1_PRE"], + "extensions": ["credProtect", "hmac-secret"], + "aaguid": "8976631bd4a0427f57730ec71c9e0279", + "options": { + "plat": false, + "rk": true, + "clientPin": true, + "credMgmt": true, + "up": false + }, + "maxMsgSize": 1200, + "pinUvAuthProtocols": [1], + "maxCredentialCountInList ": 20, + "maxCredentialIdLength": 128, + "transports": ["nfc", "usb"], + "algorithms": [ + { + "type": "public-key", + "alg": -8 + }, + { + "type": "public-key", + "alg": -7 + } + ], + "firmwareVersion": 262401 + } }, - "protocolFamily": "fido2", - "authenticatorVersion": 2, - "upv": [ + "statusReports": [ + { + "status": "FIDO_CERTIFIED_L1", + "effectiveDate": "2020-04-03", + "url": "https://solokeys.com", + "certificationDescriptor": "Solo Tap FIDO2 Authenticator", + "certificateNumber": "FIDO20020191206003", + "certificationPolicyVersion": "1.3.7", + "certificationRequirementsVersion": "1.0.0" + }, { - "major": 1, - "minor": 0 + "status": "FIDO_CERTIFIED", + "effectiveDate": "2020-04-03" } ], - "assertionScheme": "FIDOV2", - "authenticationAlgorithm": 1, - "publicKeyAlgAndEncoding": 260, - "attestationTypes": [ - 15879 - ], - "userVerificationDetails": [ - [ - { - "userVerification": 1 - }, - { - "userVerification": 4 - } - ] - ], - "keyProtection": 2, - "matcherProtection": 4, - "cryptoStrength": 128, - "attachmentHint": 26, - "isSecondFactorOnly": false, - "tcDisplay": 0, - "attestationRootCertificates": [ -"MIIB9DCCAZoCCQDER2OSj/S+jDAKBggqhkjOPQQDAjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMCAXDTE4MTExMTEyNTE0MloYDzIwNjgxMDI5MTI1MTQyWjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEWHAN0CCJVZdMs0oktZ5m93uxmB1iyq8ELRLtqVFLSOiHQEab56qRTB/QzrpGAY++Y2mw+vRuQMNhBiU0KzwjBjAKBggqhkjOPQQDAgNIADBFAiEAz9SlrAXIlEu87vra54rICPs+4b0qhp3PdzcTg7rvnP0CIGjxzlteQQx+jQGd7rwSZuE5RWUPVygYhUstQO9zNUOs" - ], - "icon": "" - + "timeOfLastStatusChange": "2020-04-03" } diff --git a/metadata/Somu-FIDO2-CTAP2-Authenticator.json b/metadata/Somu-FIDO2-CTAP2-Authenticator.json index 0a5e558f..b1dc5715 100644 --- a/metadata/Somu-FIDO2-CTAP2-Authenticator.json +++ b/metadata/Somu-FIDO2-CTAP2-Authenticator.json @@ -1,41 +1,101 @@ { - "description": "Somu Secp256R1 FIDO2 CTAP2 Authenticator", "aaguid": "9876631b-d4a0-427f-5773-0ec71c9e0279", - "alternativeDescriptions": { + "metadataStatement": { + "legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/", + "aaguid": "9876631b-d4a0-427f-5773-0ec71c9e0279", + "description": "Somu Secp256R1 FIDO2 CTAP2 Authenticator", + "authenticatorVersion": 2, + "protocolFamily": "fido2", + "schema": 3, + "upv": [ + { + "major": 1, + "minor": 0 + } + ], + "authenticationAlgorithms": [ + "ed25519_eddsa_sha512_raw", + "secp256r1_ecdsa_sha256_raw" + ], + "publicKeyAlgAndEncodings": ["cose"], + "attestationTypes": ["basic_full"], + "userVerificationDetails": [ + [ + { + "userVerificationMethod": "passcode_external" + }, + { + "userVerificationMethod": "presence_internal" + } + ], + [ + { + "userVerificationMethod": "none" + } + ], + [ + { + "userVerificationMethod": "passcode_external" + } + ], + [ + { + "userVerificationMethod": "presence_internal" + } + ] + ], + "keyProtection": ["hardware", "secure_element"], + "matcherProtection": ["on_chip"], + "cryptoStrength": 128, + "attachmentHint": ["external", "wired"], + "tcDisplay": [], + "attestationRootCertificates": [ + "MIIB9DCCAZoCCQDER2OSj/S+jDAKBggqhkjOPQQDAjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMCAXDTE4MTExMTEyNTE0MloYDzIwNjgxMDI5MTI1MTQyWjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEWHAN0CCJVZdMs0oktZ5m93uxmB1iyq8ELRLtqVFLSOiHQEab56qRTB/QzrpGAY++Y2mw+vRuQMNhBiU0KzwjBjAKBggqhkjOPQQDAgNIADBFAiEAz9SlrAXIlEu87vra54rICPs+4b0qhp3PdzcTg7rvnP0CIGjxzlteQQx+jQGd7rwSZuE5RWUPVygYhUstQO9zNUOs" + ], + "icon": "", + "authenticatorGetInfo": { + "versions": ["U2F_V2", "FIDO_2_0", "FIDO_2_1_PRE"], + "extensions": ["credProtect", "hmac-secret"], + "aaguid": "9876631bd4a0427f57730ec71c9e0279", + "options": { + "plat": false, + "rk": true, + "clientPin": true, + "credMgmt": true, + "up": false + }, + "maxMsgSize": 1200, + "pinUvAuthProtocols": [1], + "maxCredentialCountInList ": 20, + "maxCredentialIdLength": 128, + "transports": ["usb"], + "algorithms": [ + { + "type": "public-key", + "alg": -8 + }, + { + "type": "public-key", + "alg": -7 + } + ], + "firmwareVersion": 262401 + } }, - "protocolFamily": "fido2", - "authenticatorVersion": 2, - "upv": [ + "statusReports": [ + { + "status": "FIDO_CERTIFIED_L1", + "effectiveDate": "2020-04-03", + "url": "https://solokeys.com", + "certificationDescriptor": "Somu FIDO2 Authenticator", + "certificateNumber": "FIDO20020191206004", + "certificationPolicyVersion": "1.3.7", + "certificationRequirementsVersion": "1.0.0" + }, { - "major": 1, - "minor": 0 + "status": "FIDO_CERTIFIED", + "effectiveDate": "2020-04-03" } ], - "assertionScheme": "FIDOV2", - "authenticationAlgorithm": 1, - "publicKeyAlgAndEncoding": 260, - "attestationTypes": [ - 15879 - ], - "userVerificationDetails": [ - [ - { - "userVerification": 1 - }, - { - "userVerification": 4 - } - ] - ], - "keyProtection": 2, - "matcherProtection": 4, - "cryptoStrength": 128, - "attachmentHint": 2, - "isSecondFactorOnly": false, - "tcDisplay": 0, - "attestationRootCertificates": [ -"MIIB9DCCAZoCCQDER2OSj/S+jDAKBggqhkjOPQQDAjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMCAXDTE4MTExMTEyNTE0MloYDzIwNjgxMDI5MTI1MTQyWjCBgDELMAkGA1UEBhMCVVMxETAPBgNVBAgMCE1hcnlsYW5kMRIwEAYDVQQKDAlTb2xvIEtleXMxEDAOBgNVBAsMB1Jvb3QgQ0ExFTATBgNVBAMMDHNvbG9rZXlzLmNvbTEhMB8GCSqGSIb3DQEJARYSaGVsbG9Ac29sb2tleXMuY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEWHAN0CCJVZdMs0oktZ5m93uxmB1iyq8ELRLtqVFLSOiHQEab56qRTB/QzrpGAY++Y2mw+vRuQMNhBiU0KzwjBjAKBggqhkjOPQQDAgNIADBFAiEAz9SlrAXIlEu87vra54rICPs+4b0qhp3PdzcTg7rvnP0CIGjxzlteQQx+jQGd7rwSZuE5RWUPVygYhUstQO9zNUOs" - ], - "icon": "" - + "timeOfLastStatusChange": "2020-04-03" }