FIDO Convenience Metadata Service

Proposed Standard,

This version:
http://fidoalliance.org/specs/mds/fido-convenience-metadata-service-v1.0-ps-20250521.html
Issue Tracking:
GitHub
Editors:
(Yubico)
(Nok Nok Labs)

Abstract

FIDO Metadata Service providing convenience centric information about authenticators, like friendly names and icons. For security related aspects, look at the FIDO Metadata Service [FIDOMetadataService].

Status of This Document

This section describes the status of this document at the time of its publication. Other documents may supersede this document. A list of current FIDO Alliance publications and the latest revision of this technical report can be found in the FIDO Alliance specifications index at https://www.fidoalliance.org/specifications/.

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

Implementation of certain elements of this Specification 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 the Specification 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 SPECIFICATION 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.

1. Notation

Type names, attribute names and element names are written as code

String literals are enclosed in “”, e.g. “iconLight”.

In formulas we use “|” to denote byte wise concatenation operations.

The notation base64url(byte[8..64]) reads as 8-64 bytes of data encoded in base64url, "Base 64 Encoding with URL and Filename Safe Alphabet" [RFC4648] without padding.

Following [WebIDL-ED], dictionary members are optional unless they are explicitly marked as required.

WebIDL dictionary members MUST NOT have a value of null.

Unless otherwise specified, if a WebIDL dictionary member is DOMString, it MUST NOT be empty.

Unless otherwise specified, if a WebIDL dictionary member is a List, it MUST NOT be an empty list.

For definitions of terms, please refer to the FIDO Glossary [FIDOGlossary].

All diagrams, examples, notes in this specification are non-normative.

Note: Certain dictionary members need to be present in order to comply with FIDO requirements. Such members are marked in the WebIDL definitions found in this document, as required. The keyword required has been introduced by [WebIDL-ED], which is a work-in-progress. If you are using a WebIDL parser which implements [WebIDL], then you may remove the keyword required from your WebIDL and use other means to ensure those fields are present.

1.1. 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].

2. Overview

This section is not normative.

This document specifies how convenience related details about authenticators can be retrieved.

These details can be used when showing existing credentials to the user.

For security related information about authenticators, look at the FIDO Metadata Service [FIDOMetadataService].

All details provided by the Convenience Metadata Service are also included in the FIDO Metadata Service [FIDOMetadataService].

3. Convenience Metadata Service Details

This section is normative.

The details about authenticators as provided by this service originates from the authenticator vendors and hence provides a good way to consistently describe those authenticators across relying parties.

3.1. Convenience Metadata Format

3.1.1. FriendlyNames dictionary

This descriptor contains friendly names (e.g., public trade name) of the authenticator in multiple languages.

dictionary FriendlyNames {
    DOMString *IETFLanguageCodes-members...;
};
*IETFLanguageCodes-members...

IETF language codes ([RFC5646]), defined by a primary language subtag, followed by a region subtag based on a two-letter country code from [ISO3166] alpha-2 (usually written in upper case), e.g: Austrian-German - "de-AT". In case of absence of the specific territorial language definition, vendor should fallback to the more general language option, e.g: If "de" is given, but "de-AT" is missing, the use "de" entry instead. Description values can contain any UTF-8 characters.

For example:

{
  "en-US": "FIDO Sample Security Key"
}

Each entry SHOULD NOT exceed a maximum length of 63 characters to ensure proper display.

3.1.2. ConvenienceDetails dictionary

dictionary ConvenienceDetails {
  FriendlyNames friendlyNames;
  DOMString     icon;
  DOMString     iconDark;
  DOMString     providerLogoLight;
  DOMString     providerLogoDark;
};
friendlyNames, of type FriendlyNames

A human-readable friendly name of the authenticator / passkey provider in multiple languages. The name is intended to be shown to end users. A name in English language ("en-US") is mandatory, localized names for other languages are optional.

icon, of type DOMString

A data: url [RFC2397] encoded [PNG] or [SVG11] (light mode) icon for the Authenticator (e.g., depicting the security key). This icon is intended to be shown to users by RPs. Use of [SVG11] format is mandatory if any of the iconDark, providerLogoLight and/or providerLogoDark is used in addition to icon. Use of [SVG11] is recommended if only icon is used. The icon is more specific than the provider logo and should be shown if present.

iconDark, of type DOMString

A data: url [RFC2397] encoded [SVG11] dark mode icon for the Authenticator (e.g., depicting the security key). This icon is intended to be shown to users by RPs. The icon is more specific than the provider logo and should be shown if present.

providerLogoLight, of type DOMString

A data: url [RFC2397] encoded [SVG11] light mode icon for the provider (e.g., logomark of the passkey provider). The SVG MUST meet all of the requirements defined in § 4 SVG requirements. This icon is intended to be shown to users by RPs.

providerLogoDark, of type DOMString

A data: url [RFC2397] encoded [SVG11] dark mode icon for the provider (e.g., logomark of the passkey provider). The SVG MUST meet all of the requirements defined in § 4 SVG requirements. This icon is intended to be shown to users by RPs.

3.1.3. Convenience Metadata Payload Entry dictionary

Represents the ConvenienceMetadataPayload

dictionary ConvenienceMetadataPayload {
    required Number    no;
    DOMString *AAGUIDandConvenienceDetails...;
};
no

The serial number of this Metadata BLOB Payload. This serial number MUST be incremented whenever the contents of the Convenience Metadata Payload BLOB or the full Metadata Payload BLOB [FIDOMetadataService] changes. Serial numbers MUST be consecutive and strictly monotonic, i.e. the successor BLOB will have a no value exactly incremented by one.

*AAGUIDandConvenienceDetails...

Authenticator AAGUID followed by the ConvenienceDetails.

{
    "no": 85,
    "ea9b8d66-4d01-1d21-3ce4-b6b48cb575d4": {
        "friendlyNames": {"en-US": "Google Password Manager"},
        "providerLogoDark": "",
        "providerLogoLight": ""
    },
    "08987058-cadc-4b81-b6e1-30de50dcbe96": {
        "friendlyNames": {"en-US": "Windows Hello"},
        "providerLogoDark": "",
        "providerLogoLight": ""
    },
   "a25342c0-3cdc-4414-8e46-f4807fca511c": {
       "friendlyNames": {"en-US": "YubiKey 5 Series with NFC", "ja-Hani-JP": "YubiKey 5 シリーズ (NFC 搭載)"},
       "icon": ""
   }
}

3.2. Metadata BLOB object processing rules

The FIDO Server SHOULD follow these processing rules:
  1. Download and cache the Convenience Metadata BLOB from the Convenience MDS root location "c-mds.fidoalliance.org". More information can be found at https://fidoalliance.org/metadata/

    The system may pass the serial number of the latest cached Convenience Metadata Service BLOB to the service (GET /?localCopySerial=77). In that case, the MDS will return HTTP code 304 (Not Modified) if no newer MDS blob is available. Alternatively, the serial number of the local copy could be provided through the "If-None-Match" header field. The server will always return the serial number in the ETag header field. If both, the "localCopySerial" parameter and the "If-None-Match" header are provided, the server will only process the "localCopySerial" parameter.

4. SVG requirements

This section is normative.

All [SVG11] provider icons MUST adhere to the SVG Portable/Secure (SVG-P/S) profile defined in https://datatracker.ietf.org/doc/draft-svg-tiny-ps-abrotman/09/.

Additional requirements:

  1. Format: SVG Version: 1.2 with baseProfile as “tiny-ps"
  2. Elements: vector-based (cannot contain raster components)
  3. Dimensions: square aspect ratio
  4. The <title> element MUST be populated with the English version of the provider friendly name
  5. The SVG MUST not contain comments or extra text

5. Considerations

This section is not normative.

This section describes the key considerations for designing this metadata service.

Index

Terms defined by this specification

Terms defined by reference

References

Normative References

[PNG]
Chris Lilley; et al. Portable Network Graphics (PNG) Specification (Third Edition). URL: https://w3c.github.io/png/
[RFC2397]
L. Masinter. The "data" URL scheme. August 1998. Proposed Standard. URL: https://www.rfc-editor.org/rfc/rfc2397
[RFC4648]
S. Josefsson. The Base16, Base32, and Base64 Data Encodings (RFC 4648). October 2006. URL: http://www.ietf.org/rfc/rfc4648.txt
[SVG11]
Erik Dahlström; et al. Scalable Vector Graphics (SVG) 1.1 (Second Edition). 16 August 2011. REC. URL: https://www.w3.org/TR/SVG11/
[WebIDL]
Edgar Chen; Timothy Gu. Web IDL Standard. Living Standard. URL: https://webidl.spec.whatwg.org/
[WebIDL-ED]
Cameron McCormack. Web IDL. 13 November 2014. Editor's Draft. URL: http://heycam.github.io/webidl/

Informative References

[FIDOGlossary]
R. Lindemann; et al. FIDO Technical Glossary. 23 May 2022. Proposed Standard. URL: https://fidoalliance.org/specs/common-specs/fido-glossary-v2.1-ps-20220523.html
[FIDOMetadataService]
B. Jack; R. Lindemann; Y. Ackermann. FIDO Metadata Service. 21 May 2025. Proposed Standard. URL: https://fidoalliance.org/specs/mds/fido-metadata-service-v3.1-ps-20250521.html
[ISO3166]
Codes for the representation of names of countries and their subdivisions — Part 1: Country code. August 2020. Published. URL: https://www.iso.org/standard/72482.html
[RFC2119]
S. Bradner. Key words for use in RFCs to Indicate Requirement Levels. March 1997. Best Current Practice. URL: https://tools.ietf.org/html/rfc2119
[RFC5646]
A. Phillips, Ed.; M. Davis, Ed.. Tags for Identifying Languages. September 2009. Best Current Practice. URL: https://www.rfc-editor.org/rfc/rfc5646

IDL Index

dictionary ConvenienceDetails {
  FriendlyNames friendlyNames;
  DOMString     icon;
  DOMString     iconDark;
  DOMString     providerLogoLight;
  DOMString     providerLogoDark;
};