RFC 9495: Certification Authority Authorization (CAA) Processing for Email Addresses
- C. Bonnell
Abstract
The Certification Authority Authorization (CAA) DNS resource record (RR)
provides a mechanism for domains to express the allowed set of
Certification Authorities that are authorized to issue
certificates for the domain. RFC 8659 contains the core CAA
specification, where Property Tags that restrict the issuance of
certificates that certify domain names are defined. This specification
defines a Property Tag that grants authorization to Certification Authorities to issue
certificates that contain the id key purpose in
the extendedKeyUsage extension and at least one rfc822Name value or
otherName value of type id that includes the domain name
in the subjectAltName extension.¶
Status of This Memo
This is an Internet Standards Track document.¶
This document is a product of the Internet Engineering Task Force (IETF). It represents the consensus of the IETF community. It has received public review and has been approved for publication by the Internet Engineering Steering Group (IESG). Further information on Internet Standards is available in Section 2 of RFC 7841.¶
Information about the current status of this document, any
errata, and how to provide feedback on it may be obtained at
https://
Copyright Notice
Copyright (c) 2023 IETF Trust and the persons identified as the document authors. All rights reserved.¶
This document is subject to BCP 78 and the IETF Trust's Legal
Provisions Relating to IETF Documents
(https://
1. Introduction
The Certification Authority Authorization (CAA) DNS resource record (RR)
provides a mechanism for domains to express the allowed set of
Certification Authorities that are authorized to issue
certificates for the domain. [RFC8659] contains the core CAA
specification, where Property Tags that restrict the issuance of
certificates that certify domain names are defined. [RFC8659] does not
define a mechanism to restrict the issuance of certificates that
certify email addresses. For the purposes of this document, a
certificate "certifies" an email address if the certificate contains the
id key purpose in
the extendedKeyUsage extension and at least one rfc822Name value or
otherName value of type id that includes the domain name
in the subjectAltName extension.¶
This document defines a CAA Property Tag that restricts the allowed set of issuers of certificates that certify email addresses. Its syntax and processing are similar to the "issue" Property Tag as defined in Section 4.2 of [RFC8659].¶
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. Syntax of the "issuemail" Property Tag
This document defines the "issuemail" Property Tag. The presence of one or more "issuemail" Properties in the Relevant Resource Record Set (RRSet) [RFC8659] indicates that the domain is requesting that Certification Authorities restrict the issuance of certificates that certify email addresses.¶
The CAA "issuemail" Property Value has the following sub-syntax (specified in ABNF as per [RFC5234]):¶
The production rules for "WSP", "ALPHA", and "DIGIT" are defined in Appendix B.1 of [RFC5234]. Readers who are familiar with the sub-syntax of the "issue" and "issuewild" Property Tags will recognize that this sub-syntax is identical.¶
The meanings of each production rule within "issuemail
- "issuer
-domain -name" : - A domain name of the Certification Authority comprised of one or more labels¶
- "label":
- A single domain label that consists solely of ASCII letters, digits, and the hyphen (known as an "LDH label")¶
- "parameters":
- A semicolon
-separated list of parameters¶ - "parameter":
- A tag and a value, separated by an equals sign ("=")¶
- "tag":
- A keyword that identifies the type of parameter¶
- "value":
- The string value for a parameter¶
4. Processing of the "issuemail" Property Tag
Prior to issuing a certificate that certifies an email address, the
Certification Authority MUST check for publication of a Relevant
RRSet. The discovery of such a Relevant RRSet MUST
be performed using the algorithm specified in Section 3 of [RFC8659].
The input domain to the discovery algorithm SHALL be the domain "part"
[RFC5322] of the email address that is being certified. If the domain
"part" of the email address being certified is an Internationaliz
If the Relevant RRSet is empty or if it does not contain any "issuemail" Properties, then the domain has not requested any restrictions on the issuance of certificates for email addresses. The presence of other Property Tags, such as "issue" or "issuewild", does not restrict the issuance of certificates that certify email addresses.¶
For each "issuemail" Property in the Relevant RRSet, the
Certification Authority SHALL compare its issuer
If the certificate certifies more than one email address, then the Certification Authority MUST perform the above procedure for each email address being certified.¶
The assignment of issuer
Parameters may be defined by a Certification Authority as a means for domains to further restrict the issuance of certificates. For example, a Certification Authority may define a parameter that contains an account identifier. If the domain elects to add this parameter in an "issuemail" Property, the Certification Authority will verify that the account that is requesting the certificate matches the account specified in the Property and will refuse to issue the certificate if they do not match.¶
The processing of parameters in the issuemail-value is specific to each
Certification Authority and is beyond the scope of this document. In
particular, this document does not define any parameters and does not
specify any processing rules for when parameters must be acknowledged by
a Certification Authority. However, parameters that do not conform to
the ABNF syntax as defined in Section 3 will result in the
issuemail-value being not conformant with the ABNF syntax. As stated
above, a Property whose issuemail-value is malformed SHALL be treated as
if the issuer
5. Examples of the "issuemail" Property Tag
Several illustrative examples of Relevant RRSets and their expected
processing semantics follow. All examples assume that the
issuer
5.1. No "issuemail" Property
The following RRSet does not contain any "issuemail" Properties, so there are no restrictions on the issuance of certificates that certify email addresses for that domain:¶
5.2. Single "issuemail" Property
The following RRSet contains a single "issuemail" Property where the
issuer
5.3. Single "issuemail" Property with Parameters
The following RRSet contains a single "issuemail" Property where the
issuer
5.4. Multiple "issuemail" Properties
The following RRSet contains multiple "issuemail" Properties,
where one Property matches the issuer
5.5. Malformed "issuemail" Property
The following RRSet contains a single "issuemail" Property whose
sub-syntax does not conform to the ABNF as specified in Section 3.
Given that "issuemail" Properties with malformed syntax are treated the
same as "issuemail" Properties whose issuer
6. Security Considerations
The security considerations that are expressed in [RFC8659] are relevant to this specification.¶
The processing of "issuemail" Properties as specified in this document
is a supplement to the Certification Authority's validation process.
The Certification Authority MUST NOT treat solely the presence of an
"issuemail" Property with its issuer
CAA Properties may have the "critical" flag asserted, which specifies that a given Property is critical and must be processed by conforming Certification Authorities. If a Certification Authority does not understand the Property, then it MUST NOT issue the certificate in question.¶
If a single CAA RRSet is processed by multiple Certification Authorities for the issuance of multiple certificate types, then a Certification Authority's lack of support for a critical CAA Property in the RRSet will prevent the Certification Authority from issuing any certificates for that domain.¶
For example, assume that an RRSet contains the following Properties:¶
In this case, if the Certification Authority whose issuer
7. IANA Considerations
IANA has registered the following entry in the "Certification Authority Restriction Properties" subregistry of the "Public Key Infrastructure using X.509 (PKIX) Parameters" registry group:¶
8. References
8.1. Normative References
- [RFC2119]
-
Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10
.17487 , , <https:///RFC2119 www >..rfc -editor .org /info /rfc2119 - [RFC5234]
-
Crocker, D., Ed. and P. Overell, "Augmented BNF for Syntax Specifications: ABNF", STD 68, RFC 5234, DOI 10
.17487 , , <https:///RFC5234 www >..rfc -editor .org /info /rfc5234 - [RFC5322]
-
Resnick, P., Ed., "Internet Message Format", RFC 5322, DOI 10
.17487 , , <https:///RFC5322 www >..rfc -editor .org /info /rfc5322 - [RFC5891]
-
Klensin, J., "Internationaliz
ed Domain Names in Applications (IDNA): Protocol" , RFC 5891, DOI 10.17487 , , <https:///RFC5891 www >..rfc -editor .org /info /rfc5891 - [RFC8174]
-
Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10
.17487 , , <https:///RFC8174 www >..rfc -editor .org /info /rfc8174 - [RFC8659]
-
Hallam-Baker, P., Stradling, R., and J. Hoffman-Andrews, "DNS Certification Authority Authorization (CAA) Resource Record", RFC 8659, DOI 10
.17487 , , <https:///RFC8659 www >..rfc -editor .org /info /rfc8659
8.2. Informative References
- [RFC5890]
-
Klensin, J., "Internationaliz
ed Domain Names for Applications (IDNA): Definitions and Document Framework" , RFC 5890, DOI 10.17487 , , <https:///RFC5890 www >..rfc -editor .org /info /rfc5890
Acknowledgments
The author would like to thank the participants on the LAMPS Working Group mailing list for their insightful feedback and comments. In particular, the author extends sincere appreciation to Alexey Melnikov, Christer Holmberg, Éric Vyncke, John Levine, Lars Eggert, Michael Richardson, Murray Kucherawy, Paul Wouters, Phillip Hallam-Baker, Roman Danyliw, Russ Housley, Sean Turner, Seo Suchan, Tim Chown, and Tim Wicinski for their official reviews and suggestions, which greatly improved the quality of this document.¶