Re: [OAUTH-WG] JSON Web Token (JWT) Profile for OAuth 2.0 Access Tokens

Denis <denis.ietf@free.fr> Tue, 02 June 2020 08:20 UTC

Return-Path: <denis.ietf@free.fr>
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 DFD4B3A0A47 for <oauth@ietfa.amsl.com>; Tue, 2 Jun 2020 01:20:44 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.621
X-Spam-Level:
X-Spam-Status: No, score=-1.621 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, FREEMAIL_FROM=0.001, HTML_MESSAGE=0.001, KHOP_HELO_FCRDNS=0.276, RCVD_IN_MSPIKE_H2=-0.001, SPF_HELO_NONE=0.001, SPF_NONE=0.001] autolearn=no 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 Cooc83eekjup for <oauth@ietfa.amsl.com>; Tue, 2 Jun 2020 01:20:43 -0700 (PDT)
Received: from smtp.smtpout.orange.fr (smtp09.smtpout.orange.fr [80.12.242.131]) (using TLSv1 with cipher DHE-RSA-AES128-SHA (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 4F9673A09D9 for <oauth@ietf.org>; Tue, 2 Jun 2020 01:20:42 -0700 (PDT)
Received: from [192.168.1.11] ([86.238.65.197]) by mwinf5d69 with ME id m8Lb2200a4FMSmm038LbhK; Tue, 02 Jun 2020 10:20:40 +0200
X-ME-Helo: [192.168.1.11]
X-ME-Auth: ZGVuaXMucGlua2FzQG9yYW5nZS5mcg==
X-ME-Date: Tue, 02 Jun 2020 10:20:40 +0200
X-ME-IP: 86.238.65.197
To: Benjamin Kaduk <kaduk@mit.edu>
Cc: oauth@ietf.org, Vittorio Bertocci <vittorio.bertocci@auth0.com>
References: <CADNypP8t4oVUpoqOFhb-Aft-5C4Z2F9O2vBxh6QxmkHrWkN_gw@mail.gmail.com> <7cf781ef-67c9-eddd-3076-403e59e371bc@free.fr> <20200521200735.GL58497@kduck.mit.edu> <e835def4-9688-112f-eadc-f645a303fa40@free.fr> <20200530205522.GV58497@kduck.mit.edu>
From: Denis <denis.ietf@free.fr>
Message-ID: <0c2a52b0-f05b-38c6-6e37-7aacd6c98a24@free.fr>
Date: Tue, 02 Jun 2020 10:20:36 +0200
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.8.1
MIME-Version: 1.0
In-Reply-To: <20200530205522.GV58497@kduck.mit.edu>
Content-Type: multipart/alternative; boundary="------------0AF47E7B1E810AF327DFB3E1"
Content-Language: en-GB
Archived-At: <https://mailarchive.ietf.org/arch/msg/oauth/s8N-970EmjeLjGDL6gAkGZnon0w>
Subject: Re: [OAUTH-WG] JSON Web Token (JWT) Profile for OAuth 2.0 Access Tokens
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: Tue, 02 Jun 2020 08:20:46 -0000

Hi Benjamin,

Responses are between the lines.

> On Fri, May 22, 2020 at 11:37:28AM +0200, Denis wrote:
>> Hi Benjamin,
>>> On Thu, May 14, 2020 at 04:29:43PM +0200, Denis wrote:
>>>> Since then, I questioned myself how a client would be able to 
>>>> request an access token that would be *strictly compliant with this 
>>>> Profile*.
>>> I don't understand why this is an interesting question to ask. The 
>>> access token and interpretation thereof is (AIUI) generally seen as 
>>> an internal matter between AS and RS, with the client having no need 
>>> to care about the specifics.
>> This document is*_a_* Profile for OAuth 2.0 Access Tokens. It is not 
>> _*the*_ Profile for *_all_ *OAuth 2.0 Access Tokens.
> Sure. But (in my understanding), in common usage, the contents and 
> interpretation of the access token is set by common agreement between 
> AS and RS, with the client serving only as a "dumb" channel for 
> transporting the token. That is, we're providing a token format that 
> an RS and AS can agree to use, most likely for all tokens issued by 
> the AS for that RS. I don't know of any existing mechanisms, or desire 
> for such mechanisms by deployments, for using a different token format 
> for different tokens issued by a given AS for a given RS.

Since this document is *_a_* Profile for OAuth 2.0 Access Tokens, it 
means that potentially other Profiles could be defined in the future.
In the request, there is no parameter for a client to indicate that it 
wants a JWT conformant to _this_ profile and no parameter either
in the response to indicate to the client that it got a JWT that is 
conformant to _this_ profile.

The processing mandated in the document of a request made by a client to 
an AS only applies for a request conformant to this profile
which may or may not include a scope parameter and which may or may not 
include a "resource" parameter (and, if it does not, shall
include an "aud" claim). Currently, it is not possible to make a 
difference between a JWT request or response conformant to this profile
and other JWT requests or responses.

> Attempting to have the client provide input that would affect such a 
> mechanism seems like complexity with no market demand; a "solution in 
> search of a problem" as it were. Is there some pent-up demand among 
> OAuth deployments that I'm not aware of? I freely admit to not being 
> very on top of the broad spectrum of what's deployed...
>> 1) A client may wish to obtain an Access Token that corresponds to 
>> this Profile because, for example, this document mandates the "sub" 
>> claim to be present". Hence, the content of the Access Token is not 
>> totally "/an internal matter between AS and RS/". However, I have not 
>> understood how a client could request an Access Token that 
>> corresponds to *_this_***Profile, since there is no mandatory 
>> parameter in the request (both the "scope" parameter and the 
>> "resource" parameter are optional). In the future, we could define 
>> _*another*_**Profile. Hence, there is the same question:  How could a 
>> client request an Access Token that corresponds to *_that 
>> other_***Profile ? 2) When getting a JWT,  how can the client make 
>> sure that the access token it got is compliant with this Profile ? 
>> RFC 8725 states in section 3.11 : 3.11. Use Explicit Typing 
>> Sometimes, one kind of JWT can be confused for another. If a 
>> particular kind of JWT is subject to such confusion, that JWT can 
>> include an explicit JWT type value, and the validation rules can 
>> specify checking the type (...). Explicit JWT typing is accomplished 
>> by using the "typ" Header Parameter. Wouldn't be wise to include an 
>> explicit JWT type value for JWTs conformant to this Profile ?
> In the model where the client is a "dumb" communications channel, this 
> question does not seem interesting. But the related question of "how 
> can the RS make sure that the access token it got was generated 
> according to this profile?" does seem interesting, and seems like it 
> would benefit from the same proposed solution.

An explicit JWT type value added both in the JWT request and in the JWT 
response would solve this problem.

>> This relates to an email posted by Dominick Baier under the topic 
>> "JAR: JWT typ" on May 19 : This has been brought up before - but no 
>> response. Either I can’t find it - or it is missing. But is the 
>> setting the JWT typ explicitly mentioned somewhere?
> It is fairly likely that I will remember to ask about explicit "typ" 
> usage if I'm still on the IESG when this document gets there: I think 
> I've been making a habit of doing so.

Once again, an explicit "typ" sould be considered for both the JWT 
request and the JWT response. This implies that the client "MUST" be 
able to inspect the content of the access token.

Denis

> Thanks, Ben