Re: [OAUTH-WG] Mail regarding draft-ietf-oauth-mtls

Brian Campbell <bcampbell@pingidentity.com> Fri, 16 November 2018 22:44 UTC

Return-Path: <bcampbell@pingidentity.com>
X-Original-To: oauth@ietfa.amsl.com
Delivered-To: oauth@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 5E4C8130E6E for <oauth@ietfa.amsl.com>; Fri, 16 Nov 2018 14:44:24 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.999
X-Spam-Level:
X-Spam-Status: No, score=-1.999 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=pingidentity.com
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 RrVJo9M9JkgX for <oauth@ietfa.amsl.com>; Fri, 16 Nov 2018 14:44:20 -0800 (PST)
Received: from mail-io1-xd2e.google.com (mail-io1-xd2e.google.com [IPv6:2607:f8b0:4864:20::d2e]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 54747130E39 for <oauth@ietf.org>; Fri, 16 Nov 2018 14:44:20 -0800 (PST)
Received: by mail-io1-xd2e.google.com with SMTP id f6so15262598iob.1 for <oauth@ietf.org>; Fri, 16 Nov 2018 14:44:20 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=pingidentity.com; s=gmail; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=Mzoc3wNXdQiNTm3S5NQZ7v8SmRiZIsBCuSBjJUImGUU=; b=cunStdKu1Hk5IVrGIchmQ/uBLb0knMzt+hwgu3wPUu6o9hdyT5s568cyM3bYnUSH4I cvYJAZzv6L/xKFcJeis7dNBxiaS46EYig5l9/Ix0GOgh6FZnMNbp7uSeYcDQEQsA57ZB i1sAlTnBQJ2Qu1mHmXtMPdmt8qV0P7oXPCkL4=
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=Mzoc3wNXdQiNTm3S5NQZ7v8SmRiZIsBCuSBjJUImGUU=; b=oKvlTFuEjz09ewjytx2lJWu7strx/QDr3BDT31HIt7NrGXpsWg6t/PQhBqsLOmH8XN 0enwT4HaoV6Mop+bBGDM0De59x0wYP6uROjhAxTNC9bpS31RR0DkJ9ezxoZL4f0ObibV IMUqmi2ITgbMq3dL5Y8Ss/+//XFi62qwMEfgnC9jIf7Ap3pLrzczWag2A/c/04WRexYu /NEb5NE5OR78+Ue84DCJpBG2ULdKKeUU/1ZGPjTcBuScex2dxs4VEUJmrcku/qdhiftq MZft0o1aSRmYI4NXnuXbksCPirRaQmj74tiEqfi8xgeeYApaqzssfChXUW+RfnBH3vcD IDHA==
X-Gm-Message-State: AA+aEWaEYLOLKJW4xUBx9A53T93G2Ptz2NriS9SCBCXBMPNZJJeu+wXo zFG3Vh5+ppd4xHHzDPG62dCF/ijycnDL9h8Pm1i242tK7LgAbZPfOHVYHeBS21ohF6f/+TF4FQ9 itPdcg/gD5okqGQ==
X-Google-Smtp-Source: AFSGD/WpJSKSne+M46PZptHF8OZqmyMdzByDIq5jzaRGh9wrJqELGk10S4iOg4ZMAXwo6i/mBBl7z5qWzO9B1fPIGJM=
X-Received: by 2002:a6b:710b:: with SMTP id q11mr8958997iog.138.1542408259304; Fri, 16 Nov 2018 14:44:19 -0800 (PST)
MIME-Version: 1.0
References: <CAL841A_29YGLC-LtQcj1Mw15skys59V0DvDmyOpDS6V+x1LxWw@mail.gmail.com> <CA+k3eCSuU=3ENrYk75e5waGD7erKsf5mX1vT+wfjkqL76QomwQ@mail.gmail.com> <369D0056-3FC0-417A-ADF0-7550EBB9794E@forgerock.com> <CAL841A90GbZ7c47Lpv=c5mmVRQUwZFVSZ_4CCu10xAsUsk11mg@mail.gmail.com> <129B91F9-E471-4AE4-98D3-F534D6BF09C1@mit.edu> <CA+k3eCRWGOoRJ9MK27EZ8m_2RrcbGxCiMYU+25C88s8hLhmPTA@mail.gmail.com> <CAL841A_V96Zhm4tSyMFfK8CWNKSh4diSS-SnqtG+bZ269eaeSA@mail.gmail.com> <1AEDD443-72AD-4F46-9005-D64794C055AA@lodderstedt.net> <CAL841A9qsrD1dZqbYb2jyJx+VeDGsz0OiSSGxgTM0=pmUeLGNw@mail.gmail.com>
In-Reply-To: <CAL841A9qsrD1dZqbYb2jyJx+VeDGsz0OiSSGxgTM0=pmUeLGNw@mail.gmail.com>
From: Brian Campbell <bcampbell@pingidentity.com>
Date: Fri, 16 Nov 2018 15:43:52 -0700
Message-ID: <CA+k3eCSdnRY=N=zgJ1vHzxrbMk_ttimjCAGQLxkmmfU-r=Xz1A@mail.gmail.com>
To: Evan Gilman <evan2645@gmail.com>
Cc: Torsten Lodderstedt <torsten@lodderstedt.net>, oauth <oauth@ietf.org>
Content-Type: multipart/alternative; boundary="0000000000006517a3057acfe8ca"
Archived-At: <https://mailarchive.ietf.org/arch/msg/oauth/6DmMw5rv5Q7F1RrbUuFa7jIRDoQ>
Subject: Re: [OAUTH-WG] Mail regarding draft-ietf-oauth-mtls
X-BeenThere: oauth@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: OAUTH WG <oauth.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/oauth>, <mailto:oauth-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/oauth/>
List-Post: <mailto:oauth@ietf.org>
List-Help: <mailto:oauth-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/oauth>, <mailto:oauth-request@ietf.org?subject=subscribe>
X-List-Received-Date: Fri, 16 Nov 2018 22:44:24 -0000

Thanks Evan.

This seems like a good start and I'll plan to work to incorporate the
proposal in some/similar form into the next revision of the document.
Comments, clarifications, etc. from the WG are also always welcome too in
the meantime. Or from the AD, who also suggested allowing for the use of
SAN. But this seems to generally fit the bill to allow for SAN-based
subject identification of the client in the certificate.

Having thought a bit more about the structured vs. flat metadata, I think
I've come to a similar conclusion as you have.









On Thu, Nov 15, 2018 at 5:41 PM Evan Gilman <evan2645@gmail.com> wrote:

> I have taken a stab at some text that will open the door for SAN-based
> subject identity support. Some minor modifications in section 2.1, and
> additional metadata parameters in section 2.1.2. Please find that text
> below.
>
> > I scanned through the SPIFFE docs but didn’t any mentioning of OAuth
> (just plain X.509). What’s your plan for introducing OAuth and mtls?
>
> That is correct - SPIFFE does not currently involve any OAuth works...
> the use case for this change was brought to my attention a couple of
> weeks ago: use SPIFFE identities in "cloud native" environments to
> authenticate to an OAuth server in order to receive an access token
> for authentication with on-prem infrastructure which is OAuth-enabled.
> Doing so relieves a good deal of pressure around OAuth client (and
> secret) management. That said, I think the proposed change here is
> beneficial on all counts, and not just an accommodation for SPIFFE
> authentication. As I mentioned previously, there are several other
> projects that are relying on SAN rather than DN for subject identity
> and the number is growing.
>
> I tried to think through what the text would look like to support a
> structured value for a parameter named `tls_client_auth_san`, but ran
> into a couple sticking points... the first is that it is certainly
> more complex and would require more text, and feels more error prone
> than simply introducing additional metadata parameters. Second, we
> would need to strictly define supported values for `type`, and it
> wasn't immediately clear if this is something that would need to be
> centrally registered. I am curious to hear thoughts on the structured
> value approach versus that which I took below.
>
> 2.1.  PKI Mutual TLS OAuth Client Authentication Method
>
>    The PKI (public key infrastructure) method of mutual TLS OAuth client
>    authentication uses a subject name (DN or SAN) and validated
>    certificate chain to identify the client.  The TLS handshake is
>    utilized to validate the client's possession of the private key
>    corresponding to the public key in the certificate and to validate
>    the corresponding certificate chain.  The client is successfully
>    authenticated if the subject information in the certificate matches
>    the expected subject configured or registered for that particular
>    client (note that a predictable treatment of DN values, such as the
>    distinguishedNameMatch rule from [RFC4517], is needed in comparing
>    the certificate's subject DN to the client's registered DN).  If and
>    how to check a certificate's revocation status is a deployment
>    decision at the discretion of the authorization server.  The PKI
>    method facilitates the way X.509 certificates are traditionally being
>    used for authentication.  It also allows the client to rotate its
>    X.509 certificates without the need to modify its respective
>    authentication data at the authorization server by obtaining a new
>    certificate with the same subject from a trusted certificate
>    authority (CA).
>
> and
>
> 2.1.2.  Client Registration Metadata
>
>    The following metadata parameters are introduced for the OAuth 2.0
>    Dynamic Client Registration Protocol [RFC7591] in support of the PKI
>    method of binding a certificate to a client:
>
>    tls_client_auth_subject_dn
>       An [RFC4514] string representation of the expected subject
>       distinguished name of the certificate, which the OAuth client will
>       use in mutual TLS authentication.
>
>    tls_client_auth_san_dns
>       A string containing the value of an expected dNSName SAN entry
>       in the certificate, which the OAuth client will use in mutual TLS
>       authentication.
>
>    tls_client_auth_san_uri
>       A string containing the value of an expected
>       uniformResourceIdentifier SAN entry in the certificate, which
>       the OAuth client will use in mutual TLS authentication.
>
>    tls_client_auth_san_ip
>       A string representation of an IP address in either dotted decimal
>       notation (for IPv4) or colon-delimited hexadecimal (for IPv6, as
>       defined in [RFC4291] section 2.2) that is expected to be present
>       as an iPAddress SAN entry in the certificate, which the OAuth
>       client will use in mutual TLS authentication.
>
>    tls_client_auth_san_email
>       A string containing the value of an expected rfc822Name SAN
>       entry in the certificate, which the OAuth client will use in
>       mutual TLS authentication.
>
> On Tue, Nov 13, 2018 at 6:24 AM Torsten Lodderstedt
> <torsten@lodderstedt.net> wrote:
> >
> > Hi Evan,
> >
> > I scanned through the SPIFFE docs but didn’t any mentioning of OAuth
> (just plain X.509). What’s your plan for introducing OAuth and mtls?
> >
> > kind regards,
> > Torsten.
> >
> > > Am 13.11.2018 um 00:59 schrieb Evan Gilman <evan2645@gmail.com>:
> > >
> > > Thank you everyone for the feedback.
> > >
> > > I am currently working on the sample text, and should be complete in
> > > the next couple days. Apologies for the delay.
> > > On Wed, Nov 7, 2018 at 12:51 AM Brian Campbell
> > > <bcampbell@pingidentity.com> wrote:
> > >>
> > >> Sure, I think they could be treated as different different
> client_auth_methods. But there is a lot more commonality than differences
> to the point where I think it makes sense to keep it all in a single
> document and under a single client auth method with just the variation on
> which name is being used.
> > >>
> > >> On Tue, Nov 6, 2018 at 5:11 PM Justin P Richer <jricher@mit.edu>
> wrote:
> > >>>
> > >>> Would it make sense for these to be a different client_auth_method
> entirely? Much the same way that we have private_key_jwt and
> client_secret_jwt today, both of which use the JWT assertion framework but
> have very different keying and security assumptions. In the same way, here
> you’re still validating the cert but the means by which it’s validated is
> different, so the auth method is arguably not going to benefit from being
> overloaded. Caveat, I’ve not built out a system using SANs in any
> meaningful way.
> > >>>
> > >>> If we were to do that, this draft could go forward as-is (since it’s
> fairly done in my opinion) and a new document could better define the
> semantics for the various SAN types, but while building on the framework
> and concepts listed in here.
> > >>>
> > >>> — Justin
> > >>>
> > >>> On Nov 6, 2018, at 3:52 PM, Evan Gilman <evan2645@gmail.com> wrote:
> > >>>
> > >>> Response(s) inline
> > >>>
> > >>> On Mon, Nov 5, 2018 at 11:53 PM Neil Madden <
> neil.madden@forgerock.com> wrote:
> > >>>
> > >>>
> > >>> Is there an intention that any semantics are attached to the SAN
> being a URI or DNS name or IP or ...? Or is it still intended to be an
> opaque identifier?
> > >>>
> > >>>
> > >>> There are some extra things we could do if we attached type-specific
> > >>> semantics to the matching (e.g. DNS wildcarding etc), however I think
> > >>> that continuing to use the values as opaque identifiers would get us
> > >>> most of what we need while keeping things simple.
> > >>>
> > >>> On 6 Nov 2018, at 01:55, Brian Campbell <bcampbell=
> 40pingidentity.com@dmarc.ietf.org> wrote:
> > >>>
> > >>> Thanks Evan for bringing this to the WG's attention. More or less
> the same question/issue was raised yesterday in the area director's review
> of the document as well. I plan to bring this up as a discussion item in
> the meeting today. But my sense from some early discussions is that there
> is likely to be (rough) consensus to make some change in order to allow a
> SAN to be specified as the certificate subject identifier in the PKI client
> auth mode. We'll need to figure out the specifics of how that works. I
> don't think there are significant drawbacks to extending the number of
> client registration metadata parameters per se. I guess I've just been
> attracted to the idea of overloading the existing value because that felt
> like maybe a less invasive change. But perhaps that's shortsighted. And
> there's nothing inherently wrong with additional client metadata parameters.
> > >>>
> > >>> I don't know if we could get away with a single new parameter that
> could carry the value for any SAN type. Something like, { ...
> "tls_client_auth_san": "spiffe://trust-domain/path" ...}. In practice I
> feel like that'd probably be okay but in theory there's the potential for
> confusion of the value across different types. So probably there's a need
> to indicate the SAN type too. Either with more client metadata parameters
> like tls_client_auth_san_uir, tls_client_auth_san_email,
> tls_client_auth_san_ip, etc. or maybe with a structured value of some sort
> like {... "tls_client_auth_san": {"type":"URI",
> "value":"spiffe://trust-domain/path"} ... }. And then deciding which types
> to support and if/how to allow for the extensible types.
> > >>>
> > >>>
> > >>> I am far from an authority here, but it is my understanding that one
> > >>> of the primary drivers in supporting SAN over Subject is that the
> > >>> values are strongly typed. While some of the advantages gained from
> > >>> this may be less useful in our own context, I feel that it make sense
> > >>> to keep the values separate and not overload a single value. Whether
> > >>> that means dedicated metadata parameters or a structured parameter
> > >>> value, I am not sure what the tradeoffs would be, but both options
> > >>> sound suitable to me.
> > >>>
> > >>> Anyway, those are just some thoughts on it. And it'll be discussed
> more today. Suggested/proposed text is always helpful though (even if it's
> not used directly it can help move the conversation forward and/or help
> editor(s) to have prospective wording).
> > >>>
> > >>>
> > >>> Great. I will work on some sample text since it sounds like that
> would
> > >>> be generally helpful
> > >>>
> > >>> On Tue, Nov 6, 2018 at 5:53 AM Evan Gilman <evan2645@gmail.com>
> wrote:
> > >>>
> > >>>
> > >>> Hello everyone..
> > >>>
> > >>> Very excited to see this draft. It helps tremendously in addressing
> > >>> use cases around oauth client management in machine-to-machine
> > >>> scenarios. Particularly, the PKI authentication method.
> > >>>
> > >>> In reviewing the document, I noticed that the only supported method
> > >>> for identifying a client using the PKI authentication method is by
> > >>> referencing its distinguished name. This caught me a bit by surprise
> -
> > >>> many newer projects aimed at automating X.509 issuance in the
> > >>> datacenter utilize SAN extensions rather than distinguished name in
> > >>> order to encode identity. I am further under the impression that the
> > >>> community is, in general, moving away from the subject extension
> > >>> altogether in favor of SAN-based identification.
> > >>>
> > >>> Full disclosure: I am one of the maintainers on a project called
> > >>> SPIFFE, which provides identity specifications for datacenter
> workload
> > >>> applications. For X.509, SPIFFE encodes identity into a URI SAN
> > >>> extension. A number of projects using SPIFFE do not configure the
> > >>> subject with identifying information (SPIRE and Google Istio being
> > >>> just a couple). I am also hearing of other X.509 automation projects
> > >>> which are moving away from subject/distinguished name (even if they
> > >>> are not using SPIFFE).
> > >>>
> > >>> While I think support for distinguished name is absolutely necessary,
> > >>> I worry that supporting it solely will render it incompatible with
> > >>> some of the more modern PKIX systems and not stand the test of time.
> I
> > >>> know that I am a little late to this, and for that I apologize... but
> > >>> I feel this is a significant point.
> > >>>
> > >>> I would like to open a discussion on supporting the most commonly
> used
> > >>> SAN extension types in addition to distinguished name. To accomplish
> > >>> this, amending section 2.1.2 `Client Registration Metadata` with
> > >>> additional parameters seems appropriate. In my experience, the most
> > >>> commonly used SAN extensions are: DNS name, IP address, URI, and
> email
> > >>> address.
> > >>>
> > >>> Are there significant drawbacks to extending the number of client
> > >>> registration metadata parameters? I would very much like to see this
> -
> > >>> without it, many existing projects will be unable to use the spec. I
> > >>> am happy to contribute time and text to this, assuming people feel
> > >>> that this is a beneficial addition. Sorry again for the timing
> > >>>
> > >>> --
> > >>> evan
> > >>>
> > >>> _______________________________________________
> > >>> OAuth mailing list
> > >>> OAuth@ietf.org
> > >>> https://www.ietf.org/mailman/listinfo/oauth
> > >>>
> > >>>
> > >>>
> > >>> CONFIDENTIALITY NOTICE: This email may contain confidential and
> privileged material for the sole use of the intended recipient(s). Any
> review, use, distribution or disclosure by others is strictly prohibited..
> If you have received this communication in error, please notify the sender
> immediately by e-mail and delete the message and any file attachments from
> your computer. Thank you.
> > >>>
> > >>> _______________________________________________
> > >>> OAuth mailing list
> > >>> OAuth@ietf.org
> > >>> https://www.ietf.org/mailman/listinfo/oauth
> > >>>
> > >>>
> > >>>
> > >>>
> > >>> --
> > >>> evan
> > >>>
> > >>> _______________________________________________
> > >>> OAuth mailing list
> > >>> OAuth@ietf.org
> > >>> https://www.ietf.org/mailman/listinfo/oauth
> > >>>
> > >>>
> > >>
> > >> CONFIDENTIALITY NOTICE: This email may contain confidential and
> privileged material for the sole use of the intended recipient(s). Any
> review, use, distribution or disclosure by others is strictly prohibited.
> If you have received this communication in error, please notify the sender
> immediately by e-mail and delete the message and any file attachments from
> your computer. Thank you.
> > >
> > >
> > >
> > > --
> > > evan
> > >
> > > _______________________________________________
> > > OAuth mailing list
> > > OAuth@ietf.org
> > > https://www.ietf.org/mailman/listinfo/oauth
> >
>
>
> --
> evan
>

-- 
_CONFIDENTIALITY NOTICE: This email may contain confidential and privileged 
material for the sole use of the intended recipient(s). Any review, use, 
distribution or disclosure by others is strictly prohibited.  If you have 
received this communication in error, please notify the sender immediately 
by e-mail and delete the message and any file attachments from your 
computer. Thank you._