Internet-Draft OIDC standard claims for CWT November 2024
Maldant Expires 9 May 2025 [Page]
Workgroup:
Secure Patterns for Internet CrEdentials
Internet-Draft:
draft-maldant-spice-oidc-cwt-01
Published:
Intended Status:
Informational
Expires:
Author:
B. Maldant
SimpleLogin

OpenID Connect standard claims registration for CBOR Web Tokens

Abstract

This document registers OpenId Connect standards claims already used in JSON Web Tokens for CBOR Web Tokens.

About This Document

This note is to be removed before publishing as an RFC.

The latest revision of this draft can be found at https://beltram.github.io/rfc-spice-oidc-cwt/draft-maldant-spice-oidc-cwt.html. Status information for this document may be found at https://datatracker.ietf.org/doc/draft-maldant-spice-oidc-cwt/.

Discussion of this document takes place on the Secure Patterns for Internet CrEdentials Working Group mailing list (mailto:[email protected]), which is archived at https://mailarchive.ietf.org/arch/browse/spice/. Subscribe at https://www.ietf.org/mailman/listinfo/spice/.

Source for this draft and an issue tracker can be found at https://github.com/beltram/rfc-spice-oidc-cwt.

Status of This Memo

This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.

Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at https://datatracker.ietf.org/drafts/current/.

Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."

This Internet-Draft will expire on 9 May 2025.

Table of Contents

1. Introduction

OpenId Connect [OIDCCore] is an authentication standard including standard claims already in use for JSON Web Tokens (JWT) [RFC7519]. CBOR Web Tokens (CWT) [RFC8392] have a claims registry, but do not include most of these claims. This draft aims at unifying use of OIDC claims in JWTs and CWTs.

2. Conventions and Definitions

The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.

3. Security Considerations

This document registers existing OpenID Connect standard claims already used in JSON Web Tokens [RFC7519] for use in CBOR Web Tokens [RFC8392] without changing their semantics. The Security and Privacy Considerations respectively of Sections 16 and 17 of [OIDCCore] also apply.

4. IANA Considerations

All claims defined in this document are placed in the (CBOR Web Token (CWT) Claims) [IANA.CWT.Claims] Registry (part of the eponymous registry group). No new IANA registry is created.

In case any of the suggested code points would have been claimed by the time of the Working Group last call, IANA is asked to assign Claim Key values from the 170-256 range.

4.1. name

  • Claim Name: name

  • Claim Description: End-User's full name in displayable form including all name parts, possibly including titles and suffixes, ordered according to the End-User's locale and preferences.

  • JWT Claim Name: name

  • Claim Key: TBD1 (170 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.2. given_name

  • Claim Name: given_name

  • Claim Description: Given name(s) or first name(s) of the End-User.

  • JWT Claim Name: given_name

  • Claim Key: TBD2 (171 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.3. family_name

  • Claim Name: family_name

  • Claim Description: Surname(s) or last name(s) of the End-User.

  • JWT Claim Name: family_name

  • Claim Key: TBD3 (172 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.4. middle_name

  • Claim Name: middle_name

  • Claim Description: Middle name(s) of the End-User.

  • JWT Claim Name: middle_name

  • Claim Key: TBD4 (173 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.5. nickname

  • Claim Name: nickname

  • Claim Description: Casual name of the End-User that may or may not be the same as the given_name.

  • JWT Claim Name: nickname

  • Claim Key: TBD5 (174 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.6. preferred_username

  • Claim Name: preferred_username

  • Claim Description: Shorthand name by which the End-User wishes to be referred to at the Resource Server.

  • JWT Claim Name: preferred_username

  • Claim Key: TBD6 (175 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.7. profile

  • Claim Name: profile

  • Claim Description: URL of the End-User's profile page.

  • JWT Claim Name: profile

  • Claim Key: TBD7 (176 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.8. picture

  • Claim Name: picture

  • Claim Description: URL of the End-User's profile picture. This URL MUST refer to an image file, rather than to a Web page containing an image.

  • JWT Claim Name: picture

  • Claim Key: TBD8 (177 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.9. website

  • Claim Name: website

  • Claim Description: URL of the End-User's Web page or blog.

  • JWT Claim Name: website

  • Claim Key: TBD9 (178 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.10. email

  • Claim Name: email

  • Claim Description: End-User's preferred e-mail address.

  • JWT Claim Name: email

  • Claim Key: TBD10 (179 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.11. email_verified

  • Claim Name: email_verified

  • Claim Description: True if the End-User's e-mail address has been verified; otherwise false.

  • JWT Claim Name: email_verified

  • Claim Key: TBD11 (180 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.12. gender

  • Claim Name: gender

  • Claim Description: End-User's defined gender.

  • JWT Claim Name: gender

  • Claim Key: TBD12 (181 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.13. birthdate

  • Claim Name: birthdate

  • Claim Description: End-User's birthday, represented as an [ISO8601_1] YYYY-MM-DD format.

  • JWT Claim Name: birthdate

  • Claim Key: TBD13 (182 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.14. zoneinfo

  • Claim Name: zoneinfo

  • Claim Description: String from IANA Time Zone Database [IANAtimezones] representing the End-User's time zone.

  • JWT Claim Name: zoneinfo

  • Claim Key: TBD14 (183 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.15. locale

  • Claim Name: locale

  • Claim Description: End-User's locale, represented as a BCP47 [RFC5646] language tag.

  • JWT Claim Name: locale

  • Claim Key: TBD15 (184 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.16. phone_number

  • Claim Name: phone_number

  • Claim Description: End-User's preferred telephone number.

  • JWT Claim Name: phone_number

  • Claim Key: TBD16 (185 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.17. phone_number_verified

  • Claim Name: phone_number_verified

  • Claim Description: True if the End-User's phone number has been verified; otherwise false.

  • JWT Claim Name: phone_number_verified

  • Claim Key: TBD17 (186 suggested)

  • Claim Value Type(s): text string

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.18. address

  • Claim Name: address

  • Claim Description: End-User's preferred postal address.

  • JWT Claim Name: address

  • Claim Key: TBD18 (187 suggested)

  • Claim Value Type(s): text string (the content is a JSON array)

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

4.19. updated_at

  • Claim Name: updated_at

  • Claim Description: Time the End-User's information was last updated. Its value is a number representing the number of seconds from 1970-01-01T00:00:00Z as measured in UTC until the date/time.

  • JWT Claim Name: updated_at

  • Claim Key: TBD19 (188 suggested)

  • Claim Value Type(s): uint

  • Change Controller: IETF

  • Specification Document(s): Section 5.1 of [OIDCCore]

5. References

5.1. Normative References

[IANA.CWT.Claims]
IANA, "CBOR Web Token (CWT) Claims", <https://www.iana.org/assignments/cwt>.
[IANAtimezones]
"IANA time zones", n.d., <https://www.iana.org/time-zones>.
[ISO8601_1]
"ISO8601‑1", n.d., <https://www.iso.org/standard/81801.html>.
[OIDCCore]
Sakimura, N., Bradley, J., Jones, M. B., Medeiros, B. de., and C. Mortimore, "OpenID Connect Core 1.0 incorporating errata set 2", , <https://openid.net/specs/openid-connect-core-1_0.html>.
[RFC2119]
Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, , <https://www.rfc-editor.org/rfc/rfc2119>.
[RFC5646]
Phillips, A., Ed. and M. Davis, Ed., "Tags for Identifying Languages", BCP 47, RFC 5646, DOI 10.17487/RFC5646, , <https://www.rfc-editor.org/rfc/rfc5646>.
[RFC8174]
Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, , <https://www.rfc-editor.org/rfc/rfc8174>.
[RFC8392]
Jones, M., Wahlstroem, E., Erdtman, S., and H. Tschofenig, "CBOR Web Token (CWT)", RFC 8392, DOI 10.17487/RFC8392, , <https://www.rfc-editor.org/rfc/rfc8392>.

5.2. Informative References

[RFC7519]
Jones, M., Bradley, J., and N. Sakimura, "JSON Web Token (JWT)", RFC 7519, DOI 10.17487/RFC7519, , <https://www.rfc-editor.org/rfc/rfc7519>.

Appendix A. CDDL Schema

name = (TBD1 => tstr) ; "Jane Doe"
given_name = (TBD2 => tstr) ; "Jane"
family_name = (TBD3 => tstr) ; "Doe"
middle_name = (TBD4 => tstr) ; "Ellen"
nickname = (TBD5 => tstr) ; "Jane D."
preferred_username = (TBD6 => tstr) ; "j.doe"
profile = (TBD7 => tstr) ; "https://example.org/about.html"
picture = (TBD8 => tstr) ; "https://example.org/avatar.png"
website = (TBD9 => tstr) ; "https://example.org"
email = (TBD10 => tstr) ; "[email protected]"
email_verified = (TBD11 => tstr) ; "true"
gender = (TBD12 => tstr) ; "female"
birthdate = (TBD13 => tstr) ; "1970-03-22"
zoneinfo = (TBD14 => tstr) ; "America/Los_Angeles"
locale = (TBD15 => tstr) ; "en_US"
phone_number = (TBD16 => tstr) ; "+1 (425) 555-1212"
phone_number_verified = (TBD17 => tstr) ; "true"
address = (TBD18 => tstr) ; "{"street_address": "1234 Hollywood Blvd.", "locality": "Los Angeles", "region": "CA", "postal_code": "90210", "country": "United States of America"}"
updated_at = (TBD19 => uint) ; 1730123071

TBD1 = 170
TBD2 = 171
TBD3 = 172
TBD4 = 173
TBD5 = 174
TBD6 = 175
TBD7 = 176
TBD8 = 177
TBD9 = 178
TBD10 = 179
TBD11 = 180
TBD12 = 181
TBD13 = 182
TBD14 = 183
TBD15 = 184
TBD16 = 185
TBD17 = 186
TBD18 = 187
TBD19 = 188
Figure 1: A CDDL description of each claim

Author's Address

Beltram Maldant
SimpleLogin