Internet-Draft | ACME-DNS-ACCOUNT-01 | October 2022 |
Chariton, et al. | Expires 24 April 2023 | [Page] |
This document specifies a new challenge type for the Automated Certificate Management Environment (ACME) protocol which allows an ACME client to respond to a domain control validation challenge presented by an ACME server with a DNS resource that is keyed by the ACME account identification.¶
This note is to be removed before publishing as an RFC.¶
The latest revision of this draft can be found at https://daknob.github.io/draft-todo-chariton-dns-account-01/. Status information for this document may be found at https://datatracker.ietf.org/doc/draft-todo-chariton-dns-account-01/.¶
Discussion of this document takes place on the WG Working Group mailing list (mailto:acme@ietf.org), which is archived at https://datatracker.ietf.org/wg/acme/about/. Subscribe at https://www.ietf.org/mailman/listinfo/acme/.¶
Source for this draft and an issue tracker can be found at https://github.com/daknob/draft-todo-chariton-dns-account-01.¶
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 24 April 2023.¶
Copyright (c) 2022 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://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.¶
The dns-01
challenge specified in section 8.4 of [RFC8555] requires that ACME clients validate the domain under the _acme-challenge
label for the TXT
record. This unique label creates an impediment limiting the number of other entities domain validation can be delegated to.¶
This document specifies a new challenge type, dns-account-01
. This challenge leverages the ACME Account Resource URL to present an account-unique stable challenge to an ACME server. This challenge allows any domain name to delegate its domain validation to more than one service through ACME account-unique DNS records.¶
This RFC does not intend to deprecate the dns-01
challenge specified in [RFC8555]. Since this new challenge does not modify or build on any pre-existing challenges, the ability to complete the dns-account-01
challenge requires ACME server operators to deploy new changes to their codebase. This makes adopting and using this challenge an opt-in process.¶
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.¶
When the identifier being validated is a domain name, the client can prove control of that domain by provisioning a TXT
resource record containing a designated value for a specific validation domain name.¶
{ "type": "dns-account-01", "url": "https://example.com/acme/chall/i00MGYwLWIx", "status": "pending", "token": "ODE4OWY4NTktYjhmYS00YmY1LTk5MDgtZTFjYTZmNjZlYTUx" }¶
A client can fulfill this challenge by performing the following steps:¶
token
value provided in the challenge and the client's account key¶
Construct the validation domain name by prepending the following label to the domain name being validated:¶
"_acme-challenge_" || base32(SHA-256(Account Resource URL)[0:10])¶
[0:10]
is the operation that selects the first ten bytes (bytes 0 through 9 inclusive) from the previous SHA256 operation¶
"||"
operator indicates concatenation of strings¶
TXT
record with the base64url digest value under the constructed domain validation name¶
For example, if the domain name being validated is "www.example.org", and the account URL of "https://example.com/acme/acct/ExampleAccount" then the client would provision the following DNS record:¶
_acme-challenge_ujmmovf2vn55tgye.www.example.org 300 IN TXT "LoqXcYV8...jxAjEuX0.9jg46WB3...fm21mqTI"¶
(In the above, "..." indicates that the token and the JWK thumbprint in the key authorization have been truncated to fit on the page.)¶
Respond to the ACME server with an empty object ({}) to acknowledge that the challenge can be validated by the server¶
POST /acme/chall/Rg5dV14Gh1Q Host: example.com Content-Type: application/jose+json { "protected": base64url({ "alg": "ES256", "kid": "https://example.com/acme/acct/evOfKhNU60wg", "nonce": "SS2sSl1PtspvFZ08kNtzKd", "url": "https://example.com/acme/chall/Rg5dV14Gh1Q" }), "payload": base64url({}), "signature": "Q1bURgJoEslbD1c5...3pYdSMLio57mQNN4" }¶
On receiving a response, the server constructs and stores the key authorization from the challenge token
value and the current client account key.¶
To validate the dns-account-01
challenge, the server performs the following steps:¶
TXT
records for the validation domain name¶
If all the above verifications succeed, then the validation is successful. If no DNS record is found, or DNS record and response payload do not pass these checks, then the server MUST fail the validation and mark the challenge as invalid.¶
The client SHOULD de-provision the resource record(s) provisioned for this challenge once the challenge is complete, i.e., once the "status" field of the challenge has the value "valid" or "invalid".¶
As this challenge that is introduced only differs in the left-most label of the domain name from the existing dns-01
challenge, the same security considerations apply.¶
In terms of the construction of the label prepended to the domain name, there is no need for a cryptographic hash. The purpose of that is to create a long-lived and statistically distinctive record of minimal size.¶
SHA-256 was picked due to its broad adoption, hardware support, and existing need in implementations that would likely support dns-account-01
.¶
The first 10 bytes were picked as a tradeoff: the value needs to be short enough to not significantly impact DNS record and response size, long enough to provide sufficient probability of collision avoidance across ACME accounts, and just the right size to have Base32 require no padding. As the algorithm is used for uniform distribution of inputs, and not for integrity, we do not consider the trimming a security issue.¶
The Underscored and Globally Scoped DNS Node Names is to be updated to include the following entry:¶
RR Type: TXT _NODE NAME: _acme-challenge_* Reference: This document¶
Where _acme-challenge_*
denotes all node names beginning with the string _acme-challenge_
. It does NOT refer to a DNS wildcard specification.¶
The "ACME Validation Methods" registry is to be updated to include the following entry:¶
label: dns-account-01 identifier-type: dns ACME: Y Reference: This document¶