This document was published by the FIDO Alliance as a Final Document. If you wish to make comments regarding this document, please Contact Us. All comments are welcome.

Implementation of certain elements of this Document may require licenses under third party intellectual property rights, including without limitation, patent rights. The FIDO Alliance, Inc. and its Members and any other contributors to this Document are not, and shall not be held, responsible in any manner for identifying or failing to identify any or all such third party intellectual property rights.

THIS FIDO ALLIANCE DOCUMENT IS PROVIDED “AS IS” AND WITHOUT ANY WARRANTY OF ANY KIND, INCLUDING, WITHOUT LIMITATION, ANY EXPRESS OR IMPLIED WARRANTY OF NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.

This documents defines the security requirements for FIDO Authenticators.

Notation

Key Words

The key words “MUST”, “MUST NOT”, “REQUIRED”, “SHALL”, “SHALL NOT”, “SHOULD”, “SHOULD NOT”, “RECOMMENDED”, “MAY”, and “OPTIONAL” in this document are to be interpreted as described in [[RFC2119]].

Security Levels

All requirements apply at all levels unless otherwise noted. Requirements marked with L3+, L4+, or L5+ are intended to be requirements that apply only to higher level Authenticators, not FIDO Authenticators certified to Level 1 or Level 2. They are present only for the reader’s reference.

Phrases starting with 'At L<n> ...' refine the requirement(s) stated above that apply in the scope of an L<n> certification.

FIDO Specifications

Some requirements are prefaced by “(UAF)” or “(U2F)”. These are applicability statements indicating that the requirement applies only to the UAF or U2F protocol families.

For requirements that relate to normative requirements of the UAF or U2F specifications, a reference is included citing the relevant section of the specifications. These references are included in square brackets, for example “[[U2FRawMsgs]], [Section 5.1]” refers to the U2F Authenticator specification, section 5.1.

Security Measures

All of the requirements end with a reference to the security measures that are supported by the requirement in question. These references are included within parentheses, for example “(SM2)”. The security measure references are described in the the FIDO Security Reference document [[FIDOSecRef]].

Testing Style

Each requirement is also tagged with the testing style.

The following testing styles are included in this document:

Test Assurance Modes

Because GaVR and TVFR relate to functional requirements, there are different modes of test assurance that we can seek depending on the importance of the requirement in question. These are as follows:

  • A0: The vendor asserts compliance to the requirement. For GaVR, a rationale for how the requirement is met is required.
    • Guidance: This rationale can be a specially constructed document that addresses this particular requirement, or can be one or more existing design documents which, together, convince the tester that the requirement is fulfilled.
  • A1: In addition to the testing for A0, the FIDO Security Secretariat additionally confirms that there is design documentation that describes how the requirement is fulfilled.
  • A2: In addition to the testing for A0, the tester (FIDO Accredited Security Laboratory) additionally confirms that there is design documentation that describes how the requirement is fulfilled.
  • A3: In addition to the testing for A2, the tester confirms that the Authenticator satisfies the requirement by targeted review of the implementation (by source / HDL / schematic code review).
    • Guidance: If this requirement has been verified as part of a separate FIPS 140-2 or Common Criteria validation effort for the Authenticator or one of its subcomponents, this verification can be used to fulfill the A3 assurance mode tests.
  • A4: In addition to the testing for A3, the tester confirms that the Authenticator satisfies the requirement by exercising the Authenticator (through operational testing).

Requirements

Authenticator Definition and Derived Authenticator Requirements

The FIDO Authenticator (Authenticator, for short) is a set of hardware and software that implements the Authenticator portion of the FIDO UAF or FIDO U2F protocols. For the purpose of this requirements, the Authenticator is the set of hardware and software within the Authenticator boundary, as defined in the response to requirement 1.1.

We use the term Authenticator Application to refer to the entity that (a) is provided by the Authenticator vendor and (b) combines with the underlying operating environment (hardware and firmware) in a way that results in a FIDO Authenticator. This operating environment might be clearly separated from a high-level operating system (HLOS). In this case we call it "Restricted Operating Environment" (ROE). If such separation meets the requirements defined in [[!FIDORestrictedOperatingEnv]], we call it Allowed Restricted Operating Environment (AROE).

Restricted Operating Environments Overview
Restricted Operating Environments Architectural Overview

At L1, the Restricted Operating Environment as used in the figure above might be identical with the HLOS plus underlying HW and doesn't need to be an Allowed Restricted Operating Environment (AROE).

At L2 and above the Restricted Operating Environment must be an Allowed Restricted Operating Environment according to [[!FIDORestrictedOperatingEnv]], e.g. a Trusted Execution Environment or a Secure Element.

In these requirements, the term “FIDO Relevant” means “used to fulfill or support FIDO Security Goals or FIDO Authenticator Security Requirements”.

For the certification levels L1 and L2 the Authenticator doesn't need to restrict the private authentication key (Uauth.priv) to signing valid FIDO messages only (see requirement 2.1.15 being labeled L3+). As a consequence, the generation of the to-be-signed object could be performed outside of the Authenticator.

Use the buttons below and within the requirement boxes to toggle the different elements of this document.

  • VQ will show and hide Vendor Questionnaire boxes.
  • TP will show and hide Test Procedure boxes.
  • L1-L5 will show and hide boxes for the Level selected.

When used inside a Requirement the buttons will show and hide for that Requirement only.

No. Requirement Security Measures
1.1UAF + U2F; DaD; L1+
The vendor shall document an explicit Authenticator boundary. The Authenticator’s boundary shall include any hardware that performs or software that implements functionality used to fulfill FIDO Authenticator Security Requirements, or FIDO Relevant user verification, key generation, secure transaction confirmation display, or signature generation. If the Authenticator includes a software component, the boundary shall contain the processor that executes this software.

The Authenticator boundary as defined by FIDO is comprised of the hardware and software where the Authenticator runs. The Authenticator Application is always inside the authenticator boundary. The vendor must describe the operational environment for the Authenticator Application, including any specific hardware or operating system requirements to completely define this boundary. The Authenticator always comprises hardware and software and the vendor shall describe the boundary.

For L1 the vendor shall also describe what portions of functionality the Authenticator uses from any underlying operating environment that belongs to the Authenticator but that is not included in the Authenticator Application.

At L1, the Authenticator typically belongs to one of the 4 categories:
  1. Authenticator Application running on some HLOS without an effective protection of the Authenticator Security Parameters against most other applications running in the same environment.
  2. Authenticator Application running on some HLOS with an effective protection of the Authenticator Security Parameters against most other applications running in the same environment - without breaking the HLOS.
  3. as #2, but having the Secret Authenticator Security Parameters protected by an AROE
  4. entire Authenticator is implemented in an AROE (i.e. typically qualifying for L2+)

At L1, the Authenticator vendor shall declare and describe to which of the above mentioned categories the Authenticator Application belongs.

The documentation provided by the vendor should cover software attack protection and, if required, hardware attack protection.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The Security Secretariat shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-9, SM-26)
1.2UAF + U2F; DaD; L1+
The vendor shall document all FIDO Relevant security and cryptographic functions implemented within the Authenticator, both those on the “Allowed Cryptography List” [[FIDOAllowedCrypto]] and those not on this list.

At L1, the vendor shall mark the FIDO Relevant security and cryptographic functions implemented in the Authenticator but implemented outside the Authenticator Application (i.e. in the underlying OS or HW).

Some algorithms may only be allowed for certain Security Certification Levels. For example, not all cryptographic algorithms that are acceptable for L1 may be acceptable for L3.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The Security Secretariat shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-9, SM-16, SM-26)
1.3UAF + U2F; DaD; L1+
The vendor shall document where Authenticator User Private Keys (Uauth.priv) are stored, the structure of all KeyIDs and Key Handles used by the Authenticator, and explain how these private keys are related to the KeyIDs and Key Handles used by the Authenticator.

At L1, the private keys, KeyIDs etc. that are generated outside the Authenticator Application shall be documented, but their internal structure does not need to be explained in detail.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The Security Secretariat shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-6, SM-26)
1.4UAF; DaD; L1+
The vendor shall document an Authenticator as a first-factor Authenticator or a second-factor Authenticator. [[!UAFAuthnrCommands]], [Section 6.3.4] and [[FIDOGlossary]] entries "Authenticator, 1stF / First Factor" and "Authenticator, 2ndF / Second Factor".

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-26)
1.5UAF; TVFR; L1+
If the Authenticator is a second-factor Authenticator, then the Authenticator shall not store user names inside a Raw Key Handle [[!UAFAuthnrCommands]], [Section 5.1]. A cryptographically wrapped Raw Key Handle is called Key Handle.

Vendor Questionnaire

Is this requirement applicable to the Authenticator? If No, then describe why.
Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-23)
1.6UAF; TVFR; L1+
If the Authenticator supports Transaction Confirmation Display, then it shall hash the Transaction Content using an Allowed Hashing Cryptographic Function. [[!UAFAuthnrCommands]], [Section 6.3.4]

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-16)
1.7UAF; TVFR; L1+
If the Authenticator uses the KHAccessToken method of binding keys to apps, then when responding to a “Register”, “Sign”, or “Deregister” command which includes the AppID, the Authenticator shall use an Allowed Hashing or Data Authentication Cryptographic Function to mix the ASM-provided KHAccessToken and AppID.

If the Authenticator uses an alternative method of binding keys to apps, the vendor shall describe why this method provides equivalent security. Equivalent security means, (1) it prevents other apps (not originating from the same RP) from using the key and (2) in the case of bound Authenticators, it prevents other FIDO Clients of triggering the use of that key, and (3) it relies on the underlying HLOS platform to work as expected.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-16)
1.8UAF; TVFR; L1+
If the Authenticator uses the KHAccessToken method of binding keys to apps, then the Authenticator shall not process a “Deregister” command prior to validating the KHAccessToken. [[!UAFAuthnrCommands]], [Section 6.4.4]

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-13)
1.9UAF; TVFR; L1+
If the Authenticator supports Transaction Confirmation Display, then it shall display the transaction content supplied in the “Sign” command. [[!UAFAuthnrCommands]], [Section 6.3.4] and [[FIDOGlossary]].

Vendor Questionnaire

Is this requirement applicable to the Authenticator? If No, then describe why.
If Yes, describe how this requirement can be verified through documentation review. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-10)
1.10UAF + U2F; GaVR-3; L1+
Authenticators shall validate all data input to the Authenticator to defend against buffer overruns, stack overflows, integer under/overflow or other such invalid input-based attack vectors.

At L1, the Authenticator Application needs to verify only the inputs to the Authenticator Application before they are processed further by the underlying operating environment.

Vendor Questionnaire

Provide a rationale that the Authenticator validates all data input to the Authenticator.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall verify that the requirement is met by running test tools. Additionally, the Security Secretariat shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-28)
1.11UAF; DaD; L3+
If the Authenticator has a Transaction Confirmation Display, the AppID shall be displayed to the user when a “Register”, “Sign”, or “Deregister” command is received.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L3 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-10)

Key Management and Authenticator Security Parameters

Documentation

No. Requirement Security Measures
2.1.1UAF + U2F; DaD; L1+
The vendor shall document all Authenticator Security Parameters (ASPs). Data parameters used by or stored within the Authenticator which are FIDO Relevant are called Authenticator Security Parameter. These shall, at minimum, include all FIDO user verification reference data, FIDO biometric data, Key Handle Access Tokens, User Verification Tokens, signature or registration operation counters, FIDO Relevant cryptographic keys, and FIDO relevant Allowed Random Number Generator state data. Biometric data is defined as raw captures off the sensor, stored templates, candidate match templates, and any intermediate forms of biometric data. Biometric data not used with FIDO is excluded.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The Security Secretariat shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-2, SM-6, SM-13, SM-15, SM-16, SM-26)
2.1.2UAF + U2F; DaD; L1+
For each Authenticator Security Parameter, the vendor shall document the protections that are implemented for this parameter in order to support the FIDO Authenticator Security Goals or FIDO Authenticator Security Requirements, the location where this parameter is stored, how the parameter is protected in each storage location, how and when the parameter is input or output from the Authenticator, in what form the parameter is input or output, and when (if ever) the parameter is destroyed. Those Authenticator Security Parameters whose confidentiality must be protected in order to support the FIDO Security Goals or FIDO Authenticator Security Requirements shall be documented as “Secret Authenticator Security Parameters”; these shall, at minimum, include any of the following that are FIDO Relevant: secret and private keys, Allowed Random Number Generators’ state data, FIDO user verification reference data, and FIDO biometric data.

At L1, the vendor shall describe the reliance of the Authenticator Application on the underlying operating environment for those Authenticator Security Parameters which are not fully maintained in the Authenticator Application.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The Security Secretariat shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-2, SM-6, SM-13, SM-15, SM-16, SM-26)
2.1.3UAF + U2F; DaD; L1+
For each Authenticator Security Parameter that is a cryptographic key that is generated, used, or stored within the Authenticator, the vendor shall document how this key is generated, whether the key is unique to a particular Authenticator or shared between multiple Authenticators, and the key’s claimed cryptographic strength. This claimed cryptographic strength shall not be larger than the maximal allowed claimed cryptographic strength for the underlying algorithm, as specified in the “Allowed Cryptography List” [[FIDOAllowedCrypto]]. If the key is used with an algorithm not listed on the “Allowed Cryptography List” [[FIDOAllowedCrypto]], then the claimed cryptographic strength for this key shall be zero.

At L1, the vendor shall describe the reliance of the Authenticator Application on the underlying operating environment for those Authenticator Security Parameters (where stored, how protected, ...) which are not fully maintained in the Authenticator Application.

If a cryptographic key is generated using an RNG with an unknown cryptographic strength, the cryptographic strength of that key is unknown.

This requirement interacts with requirement 5.4 as the cryptographic strength of a key might get degraded - depending on potential side channel attacks - slightly each time the key is used.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-2, SM-6, SM-13, SM-16, SM-26)
2.1.4UAF + U2F; DaD; L1+
The vendor shall document the Authenticator’s Overall Claimed Cryptographic Strength; the Overall Authenticator Claimed Cryptographic Strength shall be less than or equal to the claimed cryptographic strength of all the Authenticator Security Parameters that are cryptographic keys.

At L2+, the Authenticator’s Overall Claimed Cryptographic Strength shall be greater than or equal to 112 bits.

At L1, if the security strength for the RNG is not known, an unknown Overall Claimed Cryptographic Strength shall be assumed - which is allowed at L1.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The Security Secretariat shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-16, SM-26)
2.1.5UAF + U2F; GaVR-3; L1+
All Authenticator Security Parameters within the Authenticator shall be protected against modification and substitution.

At L1, the Authenticator Application shall follow best security practices specific to the underlying operating environment for protecting the Authenticator Security Parameters against being modified or substituted by (1) the user and (2) other applications.

Due to the nature of L1 it is acceptable for the Authenticator Application to rely on the underlying operating environment for protecting the Authenticator Security Parameters against other applications running in the same operating environment.

Vendor Questionnaire

Provide a rationale that all Authenticator Security Parameters within the Authenticator are protected against modification and substitution.

Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Secrity Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1, SM-6, SM-13, SM-15, SM-16)
2.1.6UAF + U2F; GaVR-3; L1+
All Secret Authenticator Security Parameters within the Authenticator shall be protected against unauthorized disclosure.

At L1, the Authenticator Application shall follow best security practices specific to the underlying operating environment for protecting the Authenticator Security Parameters against being modified or substituted by (1) the user and (2) other applications.

At L1, the Authenticator Application (either by implementing appropriate protection mechanisms directly in the Authenticator Application or by leveraging the underlying operating environment for implementing those) shall protect the Secret Authenticator Security Parameters from being disclosed to other application running in the same operating environment. If the Authenticator Application cannot leverage mechanisms of the underlying operating environment for that, it shall at least store such parameters in encrypted form such that the decryption key is not available to the other applications running in the same operating environment. For example by using a user provided secret to be entered or a key derived from some biometric at startup of the Authenticator Application using a best practice key derivation function (for converting a low entropy password into a cryptographic key, e.g. according to [[SP800-132]]).

Vendor Questionnaire

Provide a rationale that all Secret Authenticator Security Parameters within the Authenticator are protected against unauthorized disclosure.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1, SM-13, SM-16)
2.1.7UAF + U2F; TVFR; L1+
The Authenticator shall use an Allowed Data Authentication, Signature, or Key Protection Cryptographic Function to protect any externally-stored Authenticator Security Parameters against modification or the replay of stale (but possibly previously authenticated) data.

In this requirement, externally-stored refers to parameters stored outside of the Authenticator boundary. For example, cloud storage services.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-6, SM-13, SM-15, SM-16, SM-25)
2.1.8UAF + U2F; TVFR; L1+
The Authenticator shall protect any externally-stored Secret Authenticator Security Parameters using an Allowed Key Protection Cryptographic Function. [[!UAFAuthnrCommands]], [Sections 5.1, 6.3.4] for RawKeyHandles.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-6, SM-13, SM-15, SM-16, SM-25)
2.1.9UAF + U2F; TVFR; L1+
Any key used with an Allowed Key Protection Cryptographic Function to protect an externally-stored secret or private key which is an Authenticator Security Parameter shall have a claimed cryptographic strength greater than or equal to the claimed cryptographic strength of the key being wrapped.

L1 externally-stored means stored outside the Authenticator boundary. In the case of L1 this Authenticator boundary includes the underlying operating environment.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-6, SM-16, SM-25)
2.1.10UAF + U2F; TVFR; L1+
Authenticators might offload the persistent storage of key material to components outside the Authenticator boundary if they cryptographically wrap it appropriately. Such structure containing cryptographically wrapped key material or information related to keys is called Key Handle containing a key.

If the Authenticator uses such Key Handle approach, the Authenticator shall verify that any Key Handle containing a key provided to the Authenticator was generated by that Authenticator using an Allowed Data Authentication or Signature Cryptographic Function; if not, then no signature using this key shall be generated. [[!U2FRawMsgs]], [Section 5.1] and [[!UAFAuthnrCommands]], [Annex A Security Guidelines, entry Wrap.sym].

In the case of L1 this Authenticator boundary includes the underlying operating environment.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-2, SM-16, SM-25, SM-27)
2.1.11UAF; TVFR; L1+
If the Authenticator supports the KHAccessToken [[!UAFAuthnrCommands]] method of binding keys to apps, then the Authenticator shall verify that the supplied KHAccessToken is associated with the referenced Key Handle prior to using that Key Handle to generate a signature; if not, then no signature associated with this Key Handle shall be generated. [[!UAFAuthnrCommands]], [Section 6.3.4]

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-13)
2.1.12UAF + U2F; TVFR; L1+
If the Authenticator supports the Key Handle approach, then the Authenticator shall verify that any Key Handle containing a key provided to the Authenticator is associated with the application parameter (U2F) or AppID (UAF) by using an Allowed Data Authentication or Signature Cryptographic Function; if not, then no signature using this key shall be generated. [[!U2FRawMsgs]], [Section 5.1] and [[!UAFAuthnrCommands]], [Section 6.3.4].

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-2, SM-16, SM-25, SM-27)
2.1.13UAF + U2F; GaVR-1; L1+
The Authenticator shall generate an independent User Authentication Key for each registration [[!UAFAuthnrCommands]], [Section 6.2.4].

Any User Authentication Key (Uauth) shall only be used for authenticating one user account to one particular Relying Party.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1, SM-2, SM-27)
2.1.14UAF + U2F; TVFR; L2+
The Authenticator shall support Full Basic attestation (or an attestation method with equal or better security) or ECDAA attestation.

The Attestation Private Key shall only be used to sign well-formed FIDO attestation objects.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-3)
2.1.15UAF + U2F; TVFR; L3+
All Authenticator User Private Keys (Uauth.priv) shall only be usable for generating well-formed FIDO signature assertions. [[!U2FImplCons]], [Section 2.7] and [[UAFAuthnrCommands]], [Section 5.2].

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L3 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1)
2.1.16UAF + U2F; TVFR; L1+
In the event that an Authenticator Security Parameter is destroyed, all plaintext instances of that parameter within the Authenticator shall be overwritten by data that is not dependent on the value of the parameter, e.g., overwriting the parameter with all 0s or some other fixed bit pattern. Authenticator Security Parameters that are cryptographically protected using an Allowed Confidentiality or Key Protection Cryptographic Function shall either be treated as plaintext (as above), or the key used to protect these Authenticator Security Parameters shall be destroyed.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-24)
2.1.17UAF + U2F; TVFR; L2+
Authenticators might support a function allowing the user resetting the Authenticator to the original (factory) state, i.e. deleting all user specific information. This process is called factory reset in this document.

In the event of a factory reset, the Authenticator shall destroy all User-specific Secret Authenticator Security Parameters other than any Allowed Random Number Generator’s state.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-18, SM-19)
2.1.18UAF + U2F; TVFR; L1+
Any time the Authenticator generates an Authenticator Security Parameter which is a key for use with an algorithm specified in the “Allowed Cryptography List” [[FIDOAllowedCrypto]], the Authenticator shall generate keys as required by the standard referenced in the “Allowed Cryptography List” [[FIDOAllowedCrypto]] for that algorithm.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-16, SM-21)
2.1.19UAF + U2F; GaVR-1; L1+
Any wrapped FIDO biometric data and FIDO user verification reference data that is output from the Authenticator shall only be able to be unwrapped by the Authenticator that produced this data.

Cryptographic Collision would be an exception.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-31)
2.1.20UAF + U2F; GaVR-1; L1+
Any wrapped Authenticator User Private Key (UAuth.priv) that is output from the Authenticator shall only be able to be unwrapped by the Authenticator that produced this data.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1, SM-6, SM-26)

Random Number Generation

No. Requirement Security Measures
2.2.1UAF + U2F; TVFR; L1+
An Allowed Random Number Generator or Allowed Key Derivation Function shall be used for all key generation resulting in an Authenticator Security Parameter and for any random input for FIDO Relevant signature generation.

At L1, the Authenticator Application should use the OSes RNG if it is an Allowed RNG according to [[!FIDOAllowedCrypto]] and add entropy as described in [[!FIDOAllowedCrypto]], section "Random Number Generator". Otherwise the Authenticator Application shall implement its own Allowed RNG using the OSes RNG and potentially other sources for seeding entropy.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-16)
2.2.2UAF + U2F; DaD; L1+
The security strength (see the relevant Allowed Deterministic Random Number Generator specification document cited in the “Allowed Cryptography List” [[FIDOAllowedCrypto]]) of any Authenticator’s Allowed Deterministic Random Number Generator shall be at least as large as the largest claimed cryptographic strength of any key generated or used.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-26)
2.2.3UAF + U2F; TVFR; L1+
If the Authenticator adds Authenticator generated nonces and the nonces are produced randomly, then an Allowed Random Number Generator shall be used for nonce generation.

Authenticators with unrestricted keys (i.e. Metadata Statement isKeyRestricted: false) don't exclusively control the to-be-signed message and hence have no need to generate a nonce.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-16)
2.2.4UAF; TVFR; L3+
The Authenticator generated nonce shall be of sufficient length to guarantee that the probability of collision between produced Authenticator nonces for a particular User Authentication Key is less than 2^-32 after the maximum number of signatures allowed to be generated using that key.

If a 16 byte Authenticator generated nonce value is added, no key use limit (see requirement 5.4) is required.

This interacts with requirement 5.4, describing the maximum possible number of signatures.

Bytes in Nonce Log Base 2 of Allowed Operations
8 16
9 20
10 24
11 28
12 32

Vendor Questionnaire

Is this requirement applicable to the Authenticator? If No, then describe why.
Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L3 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-8, SM-22)
2.2.5UAF + U2F; L4+

If the authenticator implements a Deterministic Random Number Generator, then Authenticator’s Allowed Deterministic Random Number Generator shall be seeded using an Allowed Physical True Random Number Generator.

Random Numbers means non-reproducible random numbers. In the instance that reproducible values are desired, using a Key Derivation Function (KDF) is dealt with elsewhere in this requirement set.

(SM-16)

Signature Counters

Support of Signature counters is optional.

Authenticators with unrestricted keys (i.e. Metadata Statement field isKeyRestricted: false) cannot support these counters.

Authenticators with restricted keys (i.e. Metadata Statement field isKeyRestricted: true), shall set the signature counter value in the assertions to "0" to indicate that they are not supported.

An Authenticator using (1) restricted keys (i.e. Metadata Statement field isKeyRestricted: true) and (2) including values other than "0" for the counter "claims" to support the counter.

If the Authenticator claims supporting signature counter(s), it may implement a single signature counter for all keys or one signature counter per key.

No. Requirement Security Measures
2.3.1UAF + U2F; DaD; L1+
The vendor shall document whether the Authenticator supports Signature Counters and if they are supported, the vendor shall document whether one Signature Counter per authentication key is implemented or one (global) Signature Counter for all authentication keys.

Authenticators not running in an Allowed Restricted Operating Environment (AROE) [[!FIDORestrictedOperatingEnv]], shall support signature counter(s).

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L1 Test Procedure

{A1} The Security Secretariat shall verify that the documentation meets the requirement.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-15)
2.3.2UAF + U2F; GaVR-2; L1+
If the Authenticator claims supporting signature counter(s), then the Authenticator shall ensure that the signature counter value contained in FIDO signature assertions related to one specific authentication key either
  1. is (a) greater than "0" and always has been greater than "0" for any previously generated FIDO signature assertion related to the same authentication key and is (b) greater than the signature counter value contained in any previously generated FIDO signature assertion related to the same authentication key, or
  2. is set to "0" indicating that the signature counter is not supported any longer (e.g. in the case of a counter error).

    Once a signature counter value contained in a FIDO signature assertion for one specific authentication key has been set to "0" in must stay at such value for that specific authentication key (due to the requirement 1).

[[!U2FImplCons]], [Section 2.6] and [[!UAFAuthnrCommands]] [Section 6.3.4].

If one signature counter per authentication key is implemented (recommended option), it shall be incremented by 1 per signature operation. If a global signature counter is implemented, it shall be incremented by a positive random number per signature operation (see [[!UAFAuthnrCommands]] [Section A Security Guidelines, entry SignCounter]).

Vendor Questionnaire

Is this requirement applicable to the Authenticator? If No, then describe why.
Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-15)

Authenticator’s Test for User Presence and User Verification

No. Requirement Security Measures
3.1UAF + U2F; TVFR; L1+
The Authenticator shall provide a mechanism to establish if the user authorizes a given action. (For a U2F, this is the “Test for User Presence”. Generically, the term “User Verification” may also refer to this “Test for User Presence”.)

This requirement prevents remote attacks. The user has to confirm an action by pressing a button or providing some other (physical) gesture.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-1, SM-5)
3.2UAF + U2F; GaVR-2; L1+
The Authenticator shall not generate User Authentication Keys or produce signatures using such keys without first establishing that a user has requested this operation by verifying the user. [[!UAFAuthnrCommands]], [section 6.2.4, 6.3.4]

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1, SM-5)
3.3U2F; TVFR; L1+
Once the Authenticator’s test for user presence is successful (and user presence is detected), the user shall be deemed “present” for no more than 10 seconds, or until the next operation which requires user presence is performed, whichever comes first.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-5)
3.4UAF; GaVR-1; L1+
Once the Authenticator’s user verification is successful, the user shall be deemed “verified” for no more than 10 seconds, or until the next operation which requires user verification, whichever comes first. Any provided User Verification Token shall not be valid after this time period. [[!UAFAuthnrCommands]], [Appendix A Security Guideleines]

This security requirement helps mitigating timing attacks (e.g. cache-based timing attacks).

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-5)
3.5UAF; GaVR-1; L1+
The Authenticator shall not reveal the stored username(s) prior to verifying the user. [[!UAFAuthnrCommands]], [Section 6.3.4]

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-5, SM-10)
3.6UAF; GaVR-1; L1+
The Authenticator shall not output unencrypted AppIDs or KeyIDs that are associated with a Key Handle prior to verifying the user.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-5, SM-23)
3.7UAF + U2F; L3+
If the Authenticator accepts input directly from the user or provides outputs directly to the user, then this communication shall be protected from data injection, disclosure, modification or substitution through use of a Trusted Path. This Trusted Path shall allow a user to communicate directly with the Authenticator, shall only be able to be activated by the Authenticator or the user, and cannot be imitated by untrusted software.

At L4+, the Authenticator shall implement protection measures for such trusted path against hardware based attacks.

A Trusted Path is the means by which a user and a security functionality of the Authenticator can communicate with the necessary confidence. In other words, a Trusted Path allows users to perform functions through an assured direct interaction with the security functionality of the Authenticator. For instance, plaintext ASPs may be entered into or output from the Authenticator in an encrypted form (e.g. display text digitaly signed).

This means that if the Authenticator has a Transaction Confirmation Display, it shall be protected from a display overlay attack.

Vendor Questionnaire

Provide documentation that specifies how the requirement above is met.
(SM-5, SM-10, SM-29)
3.8UAF + U2F; GaVR-3; L1+
The Authenticator shall protect against injection or replay of FIDO user verification data (e.g. user presence status, PIN, or biometric data).

At L1, the Authenticator Application shall follow best security practices specific to the underlying operating environment for protecting against injection or replay of FIDO user verification data. This especially means that the Authenticator Application shall not provide any API for injecting FIDO user verification data.

At L4+, the Authenticator shall implement protection measures against hardware based attacks of this kind.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-5, SM-31)
3.9UAF + U2F; GaVR-3; L1+
Authenticators implementing user verification methods other than user presence check [[FIDOGlossary]], shall rate-limit user verification attempts in order to prevent brute force attacks. [[!FIDOMetadataStatement]], sections 3.1, 3.2, 3.3 and [[UAFAuthnrCommands]], Appendix A Security Guidelines, entry "Matcher".

After the 5th (and subsequent) failed user verification attempts, the Authenticator shall enforce a delay of (at least) 30 seconds before accepting further user verification attempts.

Counting failed attempts separately per user verification method is acceptable for no more than three different user verification methods (e.g. one counter for fingerprint, second counter for iris, third counter for PIN).

The retry counter(s) shall be reset if and only if the user verification succeeds with some of the supported alternative user verification methods.

This means that an Authenticator supporting only a single user verification method could only reset the retry counter if that user verification method succeeds.

  • The rate limiting requirement applies to all user verification methods.
  • Implementing a more strict rate limiting method is allowed.
  • We recommend
    1. an exponential increase of such delay, (e.g. 1 minute after the 6th+ false attempt, 2 minutes after the 7th+ false attempt, 4 minutes after the 8th+, etc.), or
    2. disabling biometric user verification after the 5th (and subsequent) failed attempt and falling back to an alternative knowledge based user verification method (e.g. PIN/Passcode/Pattern) if such alternative method is already implemented.
  • We are considering making this recommendation mandatory in upcoming versions of these security requirements document.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1, SM-5, SM-31)

Privacy

No. Requirement Security Measures
4.1UAF + U2F; GaVR-1; L1+
An Authenticator shall not have any Correlation Handle that is visible across multiple Relying Parties.

If the authenticator uses a shared attestation key (e.g. Full Basic Attestation), the minimum number of Authenticators sharing this key must be at least 100000.

The goal of this requirement is that, for privacy reasons, the Authenticator must not leak information about the user across multiple Relying Parties by sharing a Correlation Handle.

This requirement specifically applies to KeyIDs, KeyHandles etc.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-23)
4.2UAF + U2F; GaVR-1; L1+
An Authenticator shall not provide information to one Relying Party that can be used to uniquely identify that Authenticator instance to a different Relying Party.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-23)
4.3UAF; GaVR-1; L1+
An external party with two (AAID, KeyID) tuples produced using the Authenticator shall not be able to establish that they were produced using the same Authenticator.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-23)
4.4UAF; GaVR-1; L1+
The Authenticator’s response to a “Deregister” command shall not reveal whether the provided KeyID was registered.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-23)

Physical Security, Side Channel Attack Resistance and Fault Injection Resistance

No. Requirement Security Measures
5.1UAF + U2F; DaD; L2+
The vendor shall document the physical security and side channel attack protections used by the Authenticator.

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-1, SM-20, SM-24, SM-26, SM-33)
5.2UAF + U2F; L4+
The Authenticator shall provide evidence of physical tampering that allows the attacker to violate FIDO Security Goals or FIDO Authenticator Security Requirements.

At L3 such evidence shall be visible to the user (and not necessarily to the RP). As a consequence, a level of cooperation from the user is expected to protect the RP.

(SM-20, SM-24, SM-26)
5.3UAF + U2F; L5+
The Authenticator shall resist physical tampering that allows the attacker to violate FIDO Security Goals or FIDO Authenticator Security Requirements.

The keys can be zeroed in response to an attack so the Authenticator is no longer usable. This is the way the relying party can be informed of the attack.

(SM-20, SM-24, SM-26)
5.4UAF + U2F; TVFR; L2+
Each secret or private key that is an Authenticator Security Parameter shall have a key use limit establishing the maximal number of times that particular key can be used within a particular Authenticator.

If the Authenticator adds a 16 byte nonce value (see requirement 2.2.4), no key use limit is required.

Key refresh needs to be initiated by the RP for ideal user experience. In the current protocol, there is no provision for the Authenticator to initiate key refresh.

This requirement interacts with requirements 2.3, 2.25, 5.5, 5.6.

This is a requirement that provides flexibility in satisfying other requirements. The idea is that key use limit should be established such that the other requirements cited here are fulfilled (providing the vendor the ability to restrict the number of possible key uses rather than using longer nonces or better side-channel countermeasures), and additionally provides the option for the vendor to defend the Authenticator against attacks that are not yet known.

Both cryptographic and side-channel attacks on the Authenticator can be enabled by having access to information associated with distinct cryptographic operations under the same key, so the vendor may elect to impose a conservative key use limit in order to defend against such attacks, especially for attacks that are not yet known and thus cannot easily be otherwise defended against.

Any limit that allows the Authenticator to fulfil the other related requirements is sufficient for compliance to the requirement set. Some examples follow:

If a vendor doesn't require any particular key use limit to satisfy additional requirements, and they are not concerned with the possibility of unknown cryptographic attack, then this limit can be simply the maximal possible uses of this key, given the hardware constraints of the Authenticator (i.e., the rate of key use that the hardware can support multiplied by the total expected lifetime of the Authenticator). In this instance, the Authenticator need not retain the number of uses of each key. For example, if a device can perform one key use per second and has an expected lifetime of 5 years, then a reported key use limit of roughly (5*365+1)*86400 (less than 2^28) would be sufficient.

If the vendor does wish to limit the number of possible key uses, but does not wish to store state associated with this data, then the vendor can limit the average key use rate such that the total number of uses of a given key throughout the expected lifetime of the Authenticator is sufficiently low. For an example, if an Authenticator vendor wishes to limit the total number of key uses of a user key to 10,000,000 (less than 2^24) and the Authenticator has a expected lifetime of 5 years, then the Authenticator must enforce a long term average key use rate of roughly 1 key use every 158 seconds.

If a vendor does not wish to arbitrarily limit the rate at which keys can be used, but does wish to restrict the number of possible key uses, then they can store a count of the number of times a particular key has been used, and then disable use of the key at the limit.

Some keys (e.g., the User Private Key, or the Attestation key) cannot be painlessly replaced within the FIDO protocol (this requires re-enrolling, or replacing the Authenticator, respectively), so a suitably large limit should be chosen to prevent usability problems.

FIDO Authenticators typically require a user verification before using a private key. Such manual interaction requires a minimum amount of time.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-24, SM-26)
5.5UAF + U2F; L4+
The Authenticator shall not leak Secret Authenticator Security Parameter data (e.g. due to power, near field, or radio leakage) at a rate that would allow an attacker to weaken the key below the claimed cryptographic strength of the key, even after an attacker has observed all allowed key uses.

This interacts with requirement 5.4.

(SM-20)
5.6UAF + U2F; GaVR-3; L3+
The variations in the amount of time required to perform a cryptographic algorithm shall not allow remote attackers to reduce the security of Authenticator Security Parameters which are secret or private keys below their claimed cryptographic strength.

This requirement is mandatory for L3+ but it remains relevant for L2 as a developer guideline. It refers to all Secret Authenticator Security Parameters, and not just the authentication and attestation keys. This means it includes keys used to wrap these parameters, including keys that might be used to wrap biometric reference data.

The defense against remote timing attacks requires securing the cryptographic operation implementations and/or hardening the Allowed Restricted Operating Environment (AROE, see [[FIDORestrictedOperatingEnv]]) cache implementation:

Securing cryptographic operations: Concerning symmetric-key algorithms, It is recommended to use Hardware-based cryptographic algorithms replacing the software-based implementation and thus eliminating the side-channel information leaked from the execution of cryptographic operations. Otherwise, the software implementation must consider randomization of the control flow so that there is no fixed relation between the execution path and the cache set. Or, must enable using the same amount of cache independently from the keys used.

AROE cache enhanced implementations: It is recommended to secure the cache memory implementation in order to restrict the impact from the Rich OS on the AROE cache memory. This could be done by programming memory allocations so that the Rich OS memory will never be mapped to the AROE cache memory. The implementation can also consider flushing sensitive secure cache to memory to eliminate the information on the table access.

For more details on how to implement adequate counter-measures please review the following research papers:

This interacts with requirement 5.4.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L3 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-20, SM-33)
5.7UAF + U2F; L4+
The length of time required to perform a cryptographic algorithm using a Secret Authenticator Security Parameter shall not be dependent on the value of that secret or private key.

No time variations are allowed in this requirement, in comparison to requirement 5.6, in which some time variations are allowed.

(SM-20, SM-33)
5.8UAF + U2F; GaVR-2; L2+
All physical and logical debug interfaces to the Authenticator which enable violation of FIDO Authenticator Security Goals or FIDO Authenticator Security Requirements shall be disabled and unusable in fielded Authenticators.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-23, SM-26)
5.9UAF + U2F; L4+
The Authenticator shall be resistant to induced fault attacks.

This requirement is mandatory for L4+ but it is still relevant for L2+ as a developer guideline. The developer shall take into account SW-based fault induction side channel attack and implement relevant countermeasures such as enabling memory error detection.

(SM-32, SM-21)

Attestation

For compliance with L1, Surrogate Basic Attestation [[!UAFProtocol]] in the case of UAF / self-signed attestation certificates in the case of U2F is acceptable.

No. Requirement Security Measures
6.1UAF + U2F; TVFR; L2+
The vendor shall use attestation certificates / ECDAA Issuer public keys [[!FIDOEcdaaAlgorithm]] dedicated to a single Authenticator model.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-3)
6.2UAF + U2F; TVFR; L1+
Each Authenticator being declared as the same model (i.e. having the same AAID, AAGUID or having at least one common attestationCertificateKeyIdentifier in the MetadataStatement), shall fulfill at least the security characteristics stated for that Authenticator model.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-3)
6.3UAF + U2F; GaVR-1; L1+
The Authenticator shall accurately describe itself in its provided metadata, or alternately describe an Authenticator of lesser security. The vendor shall provide all mandatory Metadata Statement fields.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

At L1, this requirement must be demonstrated to the Test Proctor during Interoperability Testing. Documentation is not required.

L1 Test Procedure

{A1} The Security Secretariat shall verify the requirement during Interoperability Testing.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-3)
6.4UAF + U2F; DaD; L2+
The vendor shall document whether the attestation root certificate is shared across multiple Authenticator models.

In such case, the attestation certificate MUST contain an extension indicating the Authenticator model (e.g. AAID or AAGUID).

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-3)
6.5UAF + FIDO2; DaD; L2+
The vendor shall document whether the attestation certificate includes the Authenticator model (e.g. AAID or AAGUID).

Vendor Questionnaire

Provide the tester with documentation that specifies how the requirement above is met.

L2 Test Procedure

{A2} The tester shall verify that the documentation meets the requirement.
(SM-3)

Operating Environment

At L1 we allow the Authenticator Application to run in any operating environment. For the levels L2-L5, the Authenticator Application needs to run in an Allowed Restricted Operating Environment [[!FIDORestrictedOperatingEnv]].

No. Requirement Security Measures
7.1UAF + U2F; GaVR-1; L2+
The Authenticator Application shall run in an Allowed Restricted Operating Environment (AROE)[[!FIDORestrictedOperatingEnv]].

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1)
7.2UAF + U2F; GaVR-3; L2+
The operating environment shall be configured so that all operating environment security functions used by the Authenticator are active and available for use to support the FIDO Authenticator Security Goals or FIDO Authenticator Security Requirements.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1)
7.3UAF + U2F; GaVR-3; L2+
The operating environment shall prevent non-Authenticator processes from reading, writing and modifying running or stored Authenticator software and its associated memory.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1)
7.4UAF + U2F; GaVR-3; L2+
The operating environment shall not be able to be modified in a way that undermines the security of the Authenticator.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1)
7.5UAF + U2F; GaVR-1; L2+
The security configuration of the operating environment shall be fully under control of the Authenticator vendor or its delegates such that the security configuration present at commercial shipment cannot be changed except for in-the-field updates that are also fully under control of the Authenticator device vendor or its delegates.

In some environments (e.g. PC), the user (i.e. anyone other than the Authenticator vendor or its delegates) might change the security configuration of the Authenticator. However, it is the responsibility of the Authenticator to detect potential changes in the Authenticator security configuration and provide the appropriate RP response through a FIDO assertion if the changed configuration still meets the expected security characteristics according to the Metadata Statement (or stop working and either protect the security paramters at the prior level or securely destroy them if it doesn't). The Authenticator certification must include all security configuration items available to the user.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1, SM-28)
7.6UAF + U2F; GaVR-1; L2+
The security characteristics of the Authenticator shall not be modifiable by anyone other than the Authenticator device vendor or its delegates.

Vendor Questionnaire

Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-1, SM-28)

Self-Tests and Firmware Updates

No. Requirement Security Measures
8.1UAF + U2F; GaVR-2; L2+
An Authenticator shall either (a) be resistant to induced fault analysis (requirement 5.7) or (b) after powering up, an Authenticator shall run a known answer self-test for any deterministic cryptographic function prior to using that function, or (c) the Authenticator shall verify the validity of its software and Firmware using an Allowed Signature Algorithm. If the most recent known answer self-test did not pass, the corresponding cryptographic function shall not be used.

Vendor Questionnaire

Is this requirement applicable to the Authenticator? If No, then describe why.
Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this are consistent with the vendor's provided rationale.
(SM-21, SM-24)
8.2UAF + U2F; TVFR; L1+
If the Authenticator mediates the update of its software, then the Authenticator shall use an Allowed Data Authentication or Signature Cryptographic Function to verify that the software being loaded has not been tampered with. If the loaded software does not pass, then the Authenticator shall not update the software.

At L1, if the Authenticator Application mediates its own update, then it shall use an Allowed Data Authentication or Signature Cryptographic Function to verify that the software being loaded has not been tampered with. If the loaded software does not pass, then the Authenticator shall not update the software.

Vendor Questionnaire

Is this requirement applicable to the Authenticator? If No, then describe why.
Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-16, SM-26, SM-24)
8.3UAF + U2F; TVFR; L2+
An Authenticator shall either (a) be resistant to induced fault analysis (requirement 5.7) or (b) the Authenticator shall verify that any generated Authenticator Security Parameters which are public / private keys have the correct mathematical relationships prior to outputting the public key or using the private key for signature generation, or (c) the Authenticator shall verify the validity of its software and Firmware using an Allowed Signature Algorithm.

Vendor Questionnaire

Is this requirement applicable to the Authenticator? If No, then describe why.
Provide a rationale for how the requirement above is met.
Provide a documentation review procedure to confirm that the Authenticator’s design is consistent with the provided rationale. Please provide explicit design document references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-21)
8.4UAF + U2F; L3+
An Authenticator shall either be resistant to induced fault analysis (requirement 5.7) or the Authenticator shall verify that any produced signature is valid prior to outputting the signature.

(SM-21)

Manufacturing and Development

At L1, the creation of the final Authenticator Application is considered the Authenticator manufacturing.

No. Requirement Security Measures
9.1UAF + U2F; TVFR; L1+
If Authenticator Security Parameters which are cryptographic keys are generated during manufacturing, then these keys shall be generated as required by the standard referenced in the “Allowed Cryptography List” [[FIDOAllowedCrypto]] for that algorithm using an Allowed Random Number Generator.

Vendor Questionnaire

Is this requirement applicable to the Authenticator? If No, then describe why.
Describe how this requirement can be verified through documentation review. Please provide explicit design documentation references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-28)
9.2UAF + U2F; TVFR; L2+
Access to the private component of any Authenticator's attestation key shall be restricted to security-qualified authorized factory personnel.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design documentation references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-28)
9.3UAF + U2F; TVFR; L2+
The manufacturing environment used to provision Authenticators with Authenticator Security Parameters which are keys shall be secured against electronic attacks aimed at capturing keying material.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design documentation references.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-28)
9.4UAF + U2F; TVFR; L1+
A revision control system shall be implemented for the Authenticator and all of its components, and for all associated Authenticator documentation. This revision control system shall, at minimum, track changes to all software or hardware specifications, implementation files, and all tool chains used in the production of the final Authenticator.

At L1, the use of a revision control system shall only be proven for the Authenticator Application.

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design documentation references.

L1 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-28)
9.5UAF + U2F; TVFR; L1+
Each version of each configuration item that comprises the Authenticator and associated documentation shall be assigned a unique identification.

At L1, the configuration items comprising the Authenticator Application are relevant.

"Configuration item" stands for all the objects managed by the configuration management system during the product development. These may be either parts of the product (e.g. source code) or objects related to the development of the product like guidance documents, development tools, tests results, etc.)

Vendor Questionnaire

Describe how this requirement can be verified through documentation review. Please provide explicit design documentation references.

L1 Test Procedure

{A1} The Security Secretariat shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.

L2 Test Procedure

{A2} The tester shall conduct the documentation review described by the vendor, and confirm that all the results of this review meet the requirement.
(SM-28)