Re: [OAUTH-WG] New Version Notification for draft-fett-oauth-dpop-03.txt

Torsten Lodderstedt <torsten@lodderstedt.net> Fri, 22 November 2019 07:53 UTC

Return-Path: <torsten@lodderstedt.net>
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 450A112011E for <oauth@ietfa.amsl.com>; Thu, 21 Nov 2019 23:53:54 -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, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=lodderstedt.net
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 5767lAhCCifh for <oauth@ietfa.amsl.com>; Thu, 21 Nov 2019 23:53:52 -0800 (PST)
Received: from mail-pj1-x102f.google.com (mail-pj1-x102f.google.com [IPv6:2607:f8b0:4864:20::102f]) (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 EC25E1200B5 for <oauth@ietf.org>; Thu, 21 Nov 2019 23:53:51 -0800 (PST)
Received: by mail-pj1-x102f.google.com with SMTP id ep1so2711356pjb.7 for <oauth@ietf.org>; Thu, 21 Nov 2019 23:53:51 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=lodderstedt.net; s=google; h=from:message-id:mime-version:subject:date:in-reply-to:cc:to :references; bh=P2Fw4Hf93wdDmE87X0PqRskW5huArnWa/3G/8ssqHMs=; b=Vt5FCpgUD6Ud6gUJqe/ePSlqv+KiosUxXxvRTNDV/ybVwvgaS1UwOsQ4dV5UkWTq+d 1QRVe5qfo5S8gx/pEX9oASXg+Nq85zo5lwnE1RPRYX5WzB/RmsAOoBqALoe8iIll1UUp w6qc3xHEhYTDZuTEoZsBxcSx6P5K5p5ZVhGyBadoMmEsXcv9bjtjldVm6oIxL1enKvrm +I3AOqTB/GKs3garayi39995vdHoQQNPRYwLj1LQvdn26ijX3BgdQl+SHGKuzL/nQX+9 UZz4NsRaLDdcB1Pp1w8EIXq4DDrOn8ue20GaSbYwNjGJkiFLDo3WqLkD/O2hafNkJqlV QgbA==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:message-id:mime-version:subject:date :in-reply-to:cc:to:references; bh=P2Fw4Hf93wdDmE87X0PqRskW5huArnWa/3G/8ssqHMs=; b=g/jIOeKgz2pxxHNW9i92OwPGR8D89JNlmcp4X7O/iweuv8djs7t5g90qA23sMzhlth J+rksCztOGj/jMSQIVxcQ+vEUerCy5Ycavir+XpVNTx9PsAb7uU4Um5iVi9RyoqNpEGW 9NV/H+Ix5oCGv6zHjEde+EHExKpwbLYLsE1FGMGs/d6PAh4kViOWjKUf4FL6VJOk0u7n 5NGP/8v6aOebCva+mDv3vAMnfLz9Nu36UnSsBo5VQ6adzFvHskwa5FonB97nU46CnH+H s92wm/GM8a/um3rtAC0XV7QD94kEwd2JiGJo1BddLYVdvmuCupG5BlOSj4P0J1thDbnk v3VA==
X-Gm-Message-State: APjAAAUNPNS4X9TsfB0GFEXJRpnERM/yC/oSnnBZeRMoDUvHYdc2bz6q EPCJ8wP82/gxD8IQXq7k86aIBQ==
X-Google-Smtp-Source: APXvYqyBov1ZQxsc8Pf2NOc4cWyVA7/r/ERJvi1tNFMIsoAjPmMjIKX+br/v6Hd+8X+xJxCsov17Yg==
X-Received: by 2002:a17:902:aa0b:: with SMTP id be11mr13155594plb.258.1574409231251; Thu, 21 Nov 2019 23:53:51 -0800 (PST)
Received: from [10.80.110.155] ([103.137.210.130]) by smtp.gmail.com with ESMTPSA id r4sm6435030pfl.61.2019.11.21.23.53.49 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 21 Nov 2019 23:53:50 -0800 (PST)
From: Torsten Lodderstedt <torsten@lodderstedt.net>
Message-Id: <0235F8A2-83C4-4804-8805-F50305E263BB@lodderstedt.net>
Content-Type: multipart/signed; boundary="Apple-Mail=_6F9378CF-02D0-4963-A5BE-BC05C56A9C13"; protocol="application/pkcs7-signature"; micalg="sha-256"
Mime-Version: 1.0 (Mac OS X Mail 13.0 \(3601.0.10\))
Date: Fri, 22 Nov 2019 15:53:43 +0800
In-Reply-To: <6DECA422-AACC-4DAA-8CD2-FF57CE02DE3E@mit.edu>
Cc: Dick Hardt <dick.hardt@gmail.com>, oauth <oauth@ietf.org>
To: Justin Richer <jricher@mit.edu>
References: <2EF412B8-AF8C-4642-9BE0-1B528B0C63D5@amazon.com> <288343F2-ACF0-43E0-8577-26AF45330E5C@forgerock.com> <CAD9ie-u_SM+1hRuBWR7zBGSi4Ex59Ht0SzoVTeFuWTRc3cFJXw@mail.gmail.com> <6DECA422-AACC-4DAA-8CD2-FF57CE02DE3E@mit.edu>
X-Mailer: Apple Mail (2.3601.0.10)
Archived-At: <https://mailarchive.ietf.org/arch/msg/oauth/kEnLAp6IrVw3jOotJAecmH7DXfQ>
Subject: Re: [OAUTH-WG] New Version Notification for draft-fett-oauth-dpop-03.txt
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, 22 Nov 2019 07:53:54 -0000


> On 22. Nov 2019, at 15:24, Justin Richer <jricher@mit.edu> wrote:
> 
> I’m going to +1 Dick and Annabelle’s question about the scope here. That was the one major thing that struck me during the DPoP discussions in Singapore yesterday: we don’t seem to agree on what DPoP is for. Some (including the authors, it seems) see it as a quick point-solution to a specific use case. Others see it as a general PoP mechanism. 
> 
> If it’s the former, then it should be explicitly tied to one specific set of things. If it’s the latter, then it needs to be expanded. 

as a co-author of the DPoP draft I state again what I said yesterday: DPoP is a mechanism for sender-constraining access tokens sent from SPAs only. The threat to be prevented is token replay.

The general mechanism for sender constrained access token should be TLS-based as recommended by the Security BCP (see https://tools.ietf.org/html/draft-ietf-oauth-security-topics-13#section-3.2)

Why: that’s the easiest way from a client developer's perspective. 

Application level signatures, on the other hand, are inherently more fragile as illustrated by the OAuth 1 experience. They also require additional effort (and state) on the server side to implement replay detection. 

As kind of an entertaining read I added two posts/threads from 2010, when this WG discussed whether TLS/SSL should be the primary OAuth 2.0 security mechanism.

https://mailarchive.ietf.org/arch/msg/oauth/crVvDNtbdN0E0ccmk5fLdNS66v0
https://mailarchive.ietf.org/arch/browse/oauth/?gbt=1&index=xvlxuly1DjQiZgWZpHwgj7q2k0g

The decision to go with TLS only was, in my opinion, one of the key success factors that made OAuth 2 so incredibly successful.

To re-state: From my perspective, DPoP is intended to be used by SPA developers only for token replay detection (or better put to provide RSs with the pre-requisites to do so).  

Why? Because we unfortunately currently lack a TLS-based mechanism for sender-constraining.

Building it on asymmetrical crypto only makes it easier to implement and to handle than methods based on shared secrets.

I also think we must look for alternative methods to enable TLS-based methods in the browser. 


> 
> I’ll repeat what I said at the mic line: My take is that we should explicitly narrow down DPoP so that it does exactly one thing and solves one narrow use case. And for a general solution? Let’s move that discussion into the next major revision of the protocol where we’ll have a bit more running room to figure things out.
> 
>  — Justin
> 
>> On Nov 22, 2019, at 3:13 PM, Dick Hardt <dick.hardt@gmail.com> wrote:
>> 
>> 
>> 
>> On Fri, Nov 22, 2019 at 3:08 PM Neil Madden <neil.madden@forgerock.com> wrote:
>> On 22 Nov 2019, at 01:42, Richard Backman, Annabelle <richanna@amazon.com> wrote:
>>> There are key distribution challenges with that if you are doing validation at the RS, but validation at the RS using either approach means you’ve lost protection against replay by the RS. This brings us back to a core question: what threats are in scope for DPoP, and in what contexts?
>> 
>> Agreed, but validation at the RS is premature optimisation in many cases. And if you do need protection against that the client can even append a confirmation key as a caveat and retrospectively upgrade a bearer token to a pop token. They can even do transfer of ownership by creating copies of the original token bound to other certificates/public keys. 
>> 
>> While validation at the RS may be an optimization in many cases, it is still a requirement for deployments.
>> 
>> I echo Annabelle's last question: what threats are in scope (and out of scope) for DPoP?
>> 
>> 
>> _______________________________________________
>> OAuth mailing list
>> OAuth@ietf.org
>> https://www.ietf.org/mailman/listinfo/oauth
> 
> _______________________________________________
> OAuth mailing list
> OAuth@ietf.org
> https://www.ietf.org/mailman/listinfo/oauth