fido-alliance / conformance-test-tools-resources

Certification Test Tools Resources. For security and privacy related issues email tools@certification.fidoalliance.org
https://fidoalliance.org/certification/functional-certification/conformance/
40 stars 14 forks source link

Virtual Secp256K1 FIDO2 Conformance Testing U2F Authenticator is missing aaguid field #728

Closed igmor closed 10 months ago

igmor commented 10 months ago

By submitting this issue you are acknowledging that any information regarding this issue will be publicly available.

If you have privacy concerns, please email conformance-tools@fidoalliance.org

FIRST PRE CHECK

What protocol are you implementing?

NOTE: UAF 1.0 certification have been officially sunset. U2F 1.2 only supported version of U2F.

What is your implementation class?

If you are platform authenticator vendor, please email conformance-tools@fidoalliance.org

What is the version of the tool are you using?

v1.7.15

What is the OS and the version are you running?

For desktop tools

For UAF mobile tools

Issue description

One of the Conformance Test Metadata's authenticator is missing aaguid field that prevents attestations from this authenticator to be verified.

Virtual Secp256K1 FIDO2 Conformance Testing U2F Authenticator.json

{
    "legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
    "description": "Virtual Secp256K1 FIDO2 Conformance Testing U2F Authenticator",
    "alternativeDescriptions": {
        "ru-RU": "Виртуальный Secp256K1 U2F аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"
    },
    "attestationCertificateKeyIdentifiers": [
        "564df7c0f8c655b6a11f6c4d19f3bf41e2fd0179"
    ],
    "protocolFamily": "u2f",
    "schema": 3,
    "authenticatorVersion": 2,
    "upv": [
        {
            "major": 1,
            "minor": 0
        },
        {
            "major": 1,
            "minor": 1
        },
        {
            "major": 1,
            "minor": 2
        }
    ],
    "authenticationAlgorithms": [
        "secp256r1_ecdsa_sha256_raw"
    ],
    "publicKeyAlgAndEncodings": [
        "ecc_x962_raw"
    ],
    "attestationTypes": [
        "basic_full"
    ],
    "userVerificationDetails": [
        [
            {
                "userVerificationMethod": "none"
            }
        ],
        [
            {
                "userVerificationMethod": "presence_internal"
            }
        ]
    ],
    "keyProtection": [
        "hardware",
        "secure_element"
    ],
    "matcherProtection": [
        "on_chip"
    ],
    "cryptoStrength": 128,
    "attachmentHint": [
        "external",
        "wired",
        "nfc",
        "wireless"
    ],
    "tcDisplay": [],
    "attestationRootCertificates": [
        "MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"
    ],
    "icon": ""
}
iirachek commented 10 months ago

@igmor The lack of aaguid is intentional.

As per note in metadata specification, FIDO U2F authenticators typically do not support AAID nor AAGUID. Instead they use attestation certificates dedicated to a single authenticator model.

The same can be observed in the example at the end of specification.

igmor commented 10 months ago

How would one build x509 trust chain rolling up to a trust anchor in the authenticator's metadata and verify it in this case? Is there a way to connect attestations with metadata to do that if aaguids are not defined?

-Igor

On Wed, Nov 1, 2023 at 7:58 AM Illia Irachek @.***> wrote:

@igmor https://github.com/igmor The lack of aaguid is intentional.

As per note in metadata specification https://fidoalliance.org/specs/mds/fido-metadata-statement-v3.0-ps-20210518.html#dom-metadatastatement-attestationcertificatekeyidentifiers, FIDO U2F authenticators typically do not support AAID nor AAGUID. Instead they use attestation certificates dedicated to a single authenticator model.

The same can be observed in the example https://fidoalliance.org/specs/mds/fido-metadata-statement-v3.0-ps-20210518.html#u2f-example at the end of specification.

— Reply to this email directly, view it on GitHub https://github.com/fido-alliance/conformance-test-tools-resources/issues/728#issuecomment-1789106479, or unsubscribe https://github.com/notifications/unsubscribe-auth/AAJFEVYGZWZXLNZSCNZVBJLYCJPQJAVCNFSM6AAAAAA6TMDRYOVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTOOBZGEYDMNBXHE . You are receiving this because you were mentioned.Message ID: <fido-alliance/conformance-test-tools-resources/issues/728/1789106479@ github.com>

-- -Igor

iirachek commented 10 months ago

For U2F, attestations and metadata can be connected using attestationCertificateKeyIdentifiers.

To do that, you need to calculate Subject Key Identifier from certificate received in authenticator response, which can be done by following method 1 specified in RFC 5280 section 4.2.1.2.

Calculated Subject Key Identifier values can then be matched against attestationCertificateKeyIdentifiers in published metadata statements to find one for the current authenticator.

igmor commented 10 months ago

Thank you so much for this clarification. -Igor

On Wed, Nov 1, 2023 at 12:03 PM Illia Irachek @.***> wrote:

For U2F, attestations and metadata can be connected using attestationCertificateKeyIdentifiers.

To do that, you need to calculate Subject Key Identifier from certificate received in authenticator response, which can be done by following method 1 specified in RFC 5280 https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.2 section 4.2.1.2.

Calculated Subject Key Identifier values can then be matched against attestationCertificateKeyIdentifiers in published metadata statements to find one for the current authenticator.

— Reply to this email directly, view it on GitHub https://github.com/fido-alliance/conformance-test-tools-resources/issues/728#issuecomment-1789497074, or unsubscribe https://github.com/notifications/unsubscribe-auth/AAJFEV3FLLX73ZBIA7E7ZRLYCKMI5AVCNFSM6AAAAAA6TMDRYOVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTOOBZGQ4TOMBXGQ . You are receiving this because you were mentioned.Message ID: <fido-alliance/conformance-test-tools-resources/issues/728/1789497074@ github.com>

-- -Igor