Re: [Acme] Remove the hyphen from the acceptable character set for _acme-challenge TXT records.

Michael Richardson <mcr+ietf@sandelman.ca> Thu, 26 November 2020 01:34 UTC

Return-Path: <mcr+ietf@sandelman.ca>
X-Original-To: acme@ietfa.amsl.com
Delivered-To: acme@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id C02C83A0FE2 for <acme@ietfa.amsl.com>; Wed, 25 Nov 2020 17:34:36 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.899
X-Spam-Level:
X-Spam-Status: No, score=-1.899 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id 2peAHZRwRIap for <acme@ietfa.amsl.com>; Wed, 25 Nov 2020 17:34:35 -0800 (PST)
Received: from tuna.sandelman.ca (tuna.sandelman.ca [IPv6:2607:f0b0:f:3:216:3eff:fe7c:d1f3]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 01ECE3A0FC7 for <acme@ietf.org>; Wed, 25 Nov 2020 17:34:34 -0800 (PST)
Received: from localhost (localhost [127.0.0.1]) by tuna.sandelman.ca (Postfix) with ESMTP id 2FA01389EB; Wed, 25 Nov 2020 20:35:58 -0500 (EST)
Received: from tuna.sandelman.ca ([127.0.0.1]) by localhost (localhost [127.0.0.1]) (amavisd-new, port 10024) with LMTP id 1A-6pubCW570; Wed, 25 Nov 2020 20:35:55 -0500 (EST)
Received: from sandelman.ca (obiwan.sandelman.ca [209.87.249.21]) by tuna.sandelman.ca (Postfix) with ESMTP id 29E56389EA; Wed, 25 Nov 2020 20:35:55 -0500 (EST)
Received: from localhost (localhost [IPv6:::1]) by sandelman.ca (Postfix) with ESMTP id 260C586; Wed, 25 Nov 2020 20:34:31 -0500 (EST)
From: Michael Richardson <mcr+ietf@sandelman.ca>
To: "Manger, James" <James.H.Manger@team.telstra.com>, Mark Tomlin <Mark@mimocad.io>, "acme@ietf.org" <acme@ietf.org>
In-Reply-To: <ME2PR01MB3011314A35F36BF0CE1033D7E5FA0@ME2PR01MB3011.ausprd01.prod.outlook.com>
References: <CAPOmKtNvUS_hjJFm6=6yV-ep0jqmEkr49kwLTZQDEQb8MPQa-A@mail.gmail.com> <8312.1606343826@localhost> <ME2PR01MB3011314A35F36BF0CE1033D7E5FA0@ME2PR01MB3011.ausprd01.prod.outlook.com>
X-Mailer: MH-E 8.6+git; nmh 1.7+dev; GNU Emacs 26.1
X-Face: $\n1pF)h^`}$H>Hk{L"x@)JS7<%Az}5RyS@k9X%29-lHB$Ti.V>2bi.~ehC0; <'$9xN5Ub# z!G,p`nR&p7Fz@^UXIn156S8.~^@MJ*mMsD7=QFeq%AL4m<nPbLgmtKK-5dC@#:k
MIME-Version: 1.0
Content-Type: multipart/signed; boundary="=-=-="; micalg="pgp-sha512"; protocol="application/pgp-signature"
Date: Wed, 25 Nov 2020 20:34:31 -0500
Message-ID: <20158.1606354471@localhost>
Archived-At: <https://mailarchive.ietf.org/arch/msg/acme/mpAM8P_IkVlaxbIsBOQLJDrMCrc>
Subject: Re: [Acme] Remove the hyphen from the acceptable character set for _acme-challenge TXT records.
X-BeenThere: acme@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: Automated Certificate Management Environment <acme.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/acme>, <mailto:acme-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/acme/>
List-Post: <mailto:acme@ietf.org>
List-Help: <mailto:acme-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/acme>, <mailto:acme-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 26 Nov 2020 01:34:37 -0000

Manger, James <James.H.Manger@team.telstra.com> wrote:
    > An Acme CA may choose the dns-01 challenge token, but what goes in the
    > DNS TXT record is base64url(SHA-256(f(token and account key))).

I don't see this anywhere in RFC8555.
I see section 8.1, which deals with a keyAuthorization.

section 8.4 says that the token must have 128-bits of entropy,
and that it should restrict itself to the base64url alphabet.

Beyond that, I don't see any formula like above: an ACME server could, as you
say below, notice when needed "-" in the result and try again.
I think we are agreeing, but you are just telling me what current code does?

    > So to avoid hyphens in that result the CA would need to: pick a random
    > token; do the hash & base64url calculations; then repeat with a new
    > random token if any hyphens are present. It will only take 2 tries on
    > average ; - )

--
Michael Richardson <mcr+IETF@sandelman.ca>   . o O ( IPv6 IøT consulting )
           Sandelman Software Works Inc, Ottawa and Worldwide