Re: [Last-Call] [OAUTH-WG] Last Call: <draft-ietf-oauth-jwt-introspection-response-09.txt> (JWT Response for OAuth Token Introspection) to Proposed Standard

Denis <denis.ietf@free.fr> Mon, 31 August 2020 08:05 UTC

Return-Path: <denis.ietf@free.fr>
X-Original-To: last-call@ietfa.amsl.com
Delivered-To: last-call@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 9C1423A10A0 for <last-call@ietfa.amsl.com>; Mon, 31 Aug 2020 01:05:51 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.444
X-Spam-Level:
X-Spam-Status: No, score=-2.444 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, FREEMAIL_FROM=0.001, HTML_FONT_LOW_CONTRAST=0.001, HTML_MESSAGE=0.001, KHOP_HELO_FCRDNS=0.399, NICE_REPLY_A=-0.948, RCVD_IN_MSPIKE_H2=-0.001, SPF_HELO_NONE=0.001, SPF_NONE=0.001, URIBL_BLOCKED=0.001] autolearn=unavailable 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 NtT5t1jy1L-J for <last-call@ietfa.amsl.com>; Mon, 31 Aug 2020 01:05:49 -0700 (PDT)
Received: from smtp.smtpout.orange.fr (smtp04.smtpout.orange.fr [80.12.242.126]) by ietfa.amsl.com (Postfix) with ESMTP id 6675C3A109E for <last-call@ietf.org>; Mon, 31 Aug 2020 01:05:46 -0700 (PDT)
Received: from [192.168.1.11] ([90.79.51.120]) by mwinf5d60 with ME id N7yB2300T2bcEcA037yBA0; Mon, 31 Aug 2020 09:58:14 +0200
X-ME-Helo: [192.168.1.11]
X-ME-Auth: ZGVuaXMucGlua2FzQG9yYW5nZS5mcg==
X-ME-Date: Mon, 31 Aug 2020 09:58:14 +0200
X-ME-IP: 90.79.51.120
To: Torsten Lodderstedt <torsten=40lodderstedt.net@dmarc.ietf.org>
Cc: Dick Hardt <dick.hardt@gmail.com>, Justin Richer <jricher@mit.edu>, "last-call@ietf.org" <last-call@ietf.org>, Mike Jones <Michael.Jones=40microsoft.com@dmarc.ietf.org>, oauth <oauth@ietf.org>
From: Denis <denis.ietf@free.fr>
References: <CH2PR00MB0678DA2BC7234C2AC1CE784DF5541@CH2PR00MB0678.namprd00.prod.outlook.com> <412A63AD-DDE1-4BFE-8234-5A721A0ED88D@lodderstedt.net> <D68FCD40-7365-446A-9F64-2BB59C11B7AE@mit.edu> <CAD9ie-uqeM5jwQKuvO+X4NC5oXZkoLrRu1NWC2rrE4CD=ypa+g@mail.gmail.com> <08D01F36-367B-4F23-9602-9C2A2AE49DA3@mit.edu> <CAD9ie-s+MmtFHRNzym74cHBcBxu-yKCSH+r898TJ_dtmPDMK2Q@mail.gmail.com>
Message-ID: <65a7f2c0-c7e3-5c67-1be6-1dfb2b77779e@free.fr>
Date: Mon, 31 Aug 2020 09:58:11 +0200
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.11.0
MIME-Version: 1.0
In-Reply-To: <CAD9ie-s+MmtFHRNzym74cHBcBxu-yKCSH+r898TJ_dtmPDMK2Q@mail.gmail.com>
Content-Type: multipart/alternative; boundary="------------964D13DDADA0E9C9AF1A299A"
Content-Language: en-GB
Archived-At: <https://mailarchive.ietf.org/arch/msg/last-call/nSx94gnduwFkVxUt5icXnAre_18>
Subject: Re: [Last-Call] [OAUTH-WG] Last Call: <draft-ietf-oauth-jwt-introspection-response-09.txt> (JWT Response for OAuth Token Introspection) to Proposed Standard
X-BeenThere: last-call@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: IETF Last Calls <last-call.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/last-call>, <mailto:last-call-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/last-call/>
List-Post: <mailto:last-call@ietf.org>
List-Help: <mailto:last-call-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/last-call>, <mailto:last-call-request@ietf.org?subject=subscribe>
X-List-Received-Date: Mon, 31 Aug 2020 08:05:52 -0000

The last text that has been proposed on the list about this thread is 
the following:

Implementers should be aware that a token introspection request lets the 
AS know when the client is accessing the RS,
       which can also indicate when the user is using the client. If 
this implication is not acceptable, implementers can use other means
       to carry access token data, e.g. directly transferring the data 
needed by the RS within the access token.

The concerns of the implementers have nothing to do with the concerns of 
the Users. Such a text proposal has nothing to do with a "User consent".

*Towards an RFC Errata to RFC 7662*

Mike Jones wrote:

I agree with Dick’s observation about the privacy implications of using 
an Introspection Endpoint. That’s why it’s preferable to not use one at all
       and instead directly have the Resource understand the Access 
Token. One way of doing this is the JWT Access Token spec. There are 
plenty of others.

I fully agree.

RFC 7662 should have incorporated a more detailed content such as:

      In OAuth 2.0 [RFC6749], the contents of tokens are opaque to 
clients. However, the contents of tokens is not intended to be opaque to 
RSs.
      Token introspection is an OPTIONAL feature of an AS described in 
OAuth Introspection [RFC 7662] intended for clients that are unable
      to support structured access tokens including their validation. 
The use of this call allows an AS to track where and when its clients 
have indeed
      presented an issued access token. As soon as the RS knows the 
format of the access token, e.g. using structured token formats such as
      JWT [RFC7519], and is able to validate its security features, the 
call described in OAuth Introspection [RFC 7662] should be avoided, 
otherwise
      the AS will know exactly when the introspection call has been made 
and thus be able to make sure which client has attempted perform an access
      to that RS and at which instant of time. As soon as this call is 
supported by an AS, the client or the user have no way to prevent the RS 
to use it.

It might be useful to add it, e.g. using an RFC Errata.

*Differences with RFC 7662*

RFC 7662 defines a protocol that allows authorized protected resources 
to query the authorization server to determine
the set of metadata for a given token that was presented to them by an 
OAuth 2.0 client.

At a first glance, draft-ietf-oauth-jwt-introspection-response-09 seems 
to be simply a JWT Response for OAuth Token Introspection
instead of a JSON document representing the meta information surrounding 
the token.

However, this is not the case since major differences can be identified.

RFC 7662 describes an OPTIONAL call able to return a JSON object with 
the following top-level members: active (REQUIRED), scope (OPTIONAL),
client_id (OPTIONAL), username (OPTIONAL), token_type (OPTIONAL), exp 
(OPTIONAL), iat (OPTIONAL), nbf (OPTIONAL), sub (OPTIONAL),
aud (OPTIONAL), iss (OPTIONAL), jti (OPTIONAL) and claims from the "JSON 
Web Token Claims" registry (OPTIONAL).

draft-ietf-oauth-jwt-introspection-response-09 is able to return a JWT 
as the introspection response. However, the request and the returned 
information
are not the same.

Section 4 (Requesting a JWT Response) only provides an example and does 
not describe the mandatory and optional parameters from the request.
Are they identical to those described in RFC 7662 ? No one is able to say.

draft-ietf-oauth-jwt-introspection-response-09 describes a response 
structure which is different from RFC 7662 where a single top-level 
member is required,
i.e. active. The text from 
draft-ietf-oauth-jwt-introspection-response-09 requires three (in fact 
four) top-level members. The text states:

The JWT MUST include the following top-level claims:

  * issMUST be set to the issuer URL of the authorization server.
  * audMUST identify the resource server receiving the token
    introspection response.
  * iatMUST be set to the time when the introspection response was
    created by the authorization server.

Note that the text about "active" (i.e. the fourth top-level member) is 
misplaced in the middle of the token_introspection claim and does not allow
to easily understand that the top-level claim "active" MUST be set to 
either true or false.

The text states:

The AS determines based on its RS-specific policy what claims about the 
resource owner to return in the token introspection response.

Such a sentence (which does not exist in RFC 7662) is a door wide-opened 
to return claims that are NOT included into the access token.
This protocol should NOT be a protocol that allows authorized RSs to 
query the AS to obtain metadata that was NOT included into an access token
that was presented to them.

Torsten wrote:

Token introspection has several advantages over structured access 
tokens, also when it comes to privacy. If one uses a structured access 
token
       in conjunction with different *services*, then this access token 
needs to contain ALL data required to call ALL these services. This 
effectively means
       the services learn more data than required. One could try to 
mitigate this by carrying encrypted compartments in the same token, each 
of them
       encrypted with for a certain service. That would be complex and 
is not covered by current technical standards. Introspection, however, 
allows the AS
       issue a minimal access token (even without any id) and mint 
specific response for the different RSs.

Instead of attempting to imagine complex mechanisms like "encrypted 
compartments in the same token", it is much simpler to use different 
access tokens.
AFAIK, in addition, there is no notion of "services" in OAuth in RFC 
6749, but only a notion of "server". A "server" is not a "service".

resource server

The server hosting the protected resources, capable of accepting
and responding to protected resource requests using access tokens.

RFC 6750 is using the wording "audience restriction" to restrict the use 
of a token to "the intended relying party or set of relying parties"
(i.e. to one or more RSs).

So if the access token is targeted to one or more RSs, it should only 
contain what is necessary to accomplish the call on these RSs.
This means the RS(s) learn(s) exactly the data that it required. If it 
is not the case, several access tokens should be used.

The principle of "data minimization" implies that an access token should 
only contain what is necessary to accomplish a call to a given RS.

Since this new call is meant to be OPTIONAL, there should be no 
difference whether the RS decodes and validates the access token by itself
or sub-contracts the same operations to the AS.

The explanations from Torsten imply that there can be a difference .... 
which furthermore is left at the full discretion of the AS.

*About the secondary use*

I wrote:

This concern is identified in RFC 6973 as:

5.2.3.Secondary Use

Secondary use is the use of collected information about an individual
without the individual’s consent for a purpose different from that
for which the information was collected.Secondary use may violate
people’s expectations or desires.The potential for secondary use
can generate uncertainty as to how one’s information will be used in
the future, potentially discouraging information exchange in the
first place.Secondary use encompasses any use of data, including
disclosure.

Torsten replied:

       This is no secondary use, it’s the primary use *the user 
consented with*.

No "user consent" phase is ever mentioned in order to allow a RS to ask 
and receive a jwt-introspection-response.

The text states:

The AS MUST ensure the release of any privacy-sensitive data is legally 
based.

Such a statement does not make sense in practice. A different legal 
system applies depending upon three factors:
the location of the client, the location of the AS and the location of 
the RS.

Unless these three entities are located within the same country (e.g. 
Switzerland), the same state (e.g. Maryland) or
the same union (e.g. the European Union), the AS will be unable to know 
how to enforce such a statement.

The release of any privacy-sensitive data must be under the control of 
the user who must consent to the release
of that privacy-sensitive data. This makes it independent from any legal 
system.

*About the token introspection endpoint
*
The token introspection endpoint is advertised in RFC 8414 in the 
following way:

introspection_endpoint
OPTIONAL.URL of the authorization server’s OAuth 2.0 introspection 
endpoint [RFC7662].

This endpoint is intended to explicitly support RFC 7662, but not 
anything else. This draft is intended to support a new functionality 
that is different
from RFC 7662. This means that the AS should not use the same token 
introspection endpoint. If supported, this new functionality should be 
supported
using a new endpoint, e.g. an introspection_JWT_endpoint.

When this new functionality is advertised by an AS by the disclosure of 
an access point, this does not necessarily mean that it is supported for 
all the RSs
with which that AS has a relationship.

The current situation is that the User and his client have no way to 
know whether or not this new call will indeed be supported by the AS for 
a given RS.
Even the RS can't know it directly, since the only way to know it is to 
use a "trial and error" mechanism.

*A proposal on how to solve the issue*

Hereafter is one way on how to solve the issue.

The User is the entity that is the best placed to give the User Consent. 
It would be simpler if the user could ask to the AS to provide to his 
client
a JWT for a given RS that could be used to issue certificates usable for 
creating qualified electronic signatures. A specific scope could be defined
for such a purpose which would detail the claims to be incorporated into 
the access token and say that these claims shall be verified according to
sections 6.2.2 (Initial identity validation) of both ETSI EN 319 411-1 
and ETSI EN 319 411-2.

The client supporting the user would then communicate that JWT to the RS 
of its choice. The scope placed into the access token would testify
that the claims have indeed been verified according to sections 6.2.2 of 
both ETSI EN 319 411-1 and ETSI EN 319 411-2.

Such a functionality cannot be supported using 
draft-ietf-oauth-jwt-introspection-response.

In case the RS would be unable to decode the access token and/or to 
validate it, it might make attempt to make a call to the AS according to 
RFC 7662,
if this service is available (but the user has no way to indicate that 
he consents for making such a call).

As a conclusion, since draft-ietf-oauth-jwt-introspection-response harms 
the user's privacy and fully by-passes the User consent,
this draft should not be progressed to the RFC level.

Denis


> The "can" works better, agreed. Thanks!
> ᐧ
>
> On Sat, Aug 29, 2020 at 8:25 AM Justin Richer <jricher@mit.edu 
> <mailto:jricher@mit.edu>> wrote:
>
>     Thanks, Dick. I agree with removing the excess parenthetical, but
>     I intentionally avoided using a lowercase “may” in the middle of
>     the text  (in favor of “can”) to avoid normative-sounding
>     non-normative language, so I’d recommend that change be kept:
>
>     Implementers should be aware that a token introspection request
>     lets the AS know when the client
>         is accessing the RS, which can also indicate when the user is
>     using
>         the client. If this implication is not acceptable,
>     implementers can use other means to carry
>         access token data, e.g. directly transferring the data needed
>     by the RS within the access token.
>
>>     On Aug 27, 2020, at 12:15 PM, Dick Hardt <dick.hardt@gmail.com
>>     <mailto:dick.hardt@gmail.com>> wrote:
>>
>>     Here is a crisper revision.
>>
>>     Implementers should be aware that a token introspection request
>>     lets the AS know when the client
>>         is accessing the RS, which may indicate when the user is using
>>         the client. If this implication is not acceptable,
>>     implementers can use other means to carry
>>         access token data, e.g. directly transferring the data needed
>>     by the RS within the access token.
>>     ᐧ
>>
>>     On Thu, Aug 27, 2020 at 7:19 AM Justin Richer <jricher@mit.edu
>>     <mailto:jricher@mit.edu>> wrote:
>>
>>         I would clarify that this doesn’t necessarily say that the
>>         user’s there, and remove the normative requirement (which
>>         doesn’t have enforceable teeth in this context):
>>
>>         Implementers should be aware that a token introspection
>>         request lets the AS know when the client
>>             (and potentially the user) is accessing the RS, which
>>         *can also indicate* when the user is using
>>             the client. If this implication is not acceptable,
>>         *implementers can use other means* to carry
>>             access token data, e.g. directly transferring the data
>>         needed by the RS within the access token.
>>
>>
>>          — Justin
>>
>>>         On Aug 27, 2020, at 9:48 AM, Torsten Lodderstedt
>>>         <torsten=40lodderstedt.net@dmarc.ietf.org
>>>         <mailto:torsten=40lodderstedt.net@dmarc.ietf.org>> wrote:
>>>
>>>         Will the following text work for you?
>>>
>>>         Implementers should be aware that a token introspection
>>>         request lets the AS know when the client
>>>             (and potentially the user) is accessing the RS, which is
>>>         also an indication of when the user is using
>>>             the client. If this impliction is not accepatable,
>>>         implementars MUST use other means to carry
>>>             access token data, e.g. directly transferring the data
>>>         needed by the RS within the access token.
>>>
>>>
>>>>         On 26. Aug 2020, at 23:12, Mike Jones
>>>>         <Michael.Jones=40microsoft.com@dmarc.ietf.org
>>>>         <mailto:Michael.Jones=40microsoft.com@dmarc.ietf.org>> wrote:
>>>>
>>>>         I agree with Dick’s observation about the privacy
>>>>         implications of using an Introspection Endpoint. That’s why
>>>>         it’s preferable to not use one at all and instead directly
>>>>         have the Resource understand the Access Token.  One way of
>>>>         doing this is the JWT Access Token spec.  There are plenty
>>>>         of others.
>>>>
>>>>         The downsides of using an Introspection Endpoint should be
>>>>         described in the Privacy Considerations section.
>>>>
>>>>                                                               -- Mike
>>>>
>>>>         From: OAuth <oauth-bounces@ietf.org
>>>>         <mailto:oauth-bounces@ietf.org>> On Behalf Of Dick Hardt
>>>>         Sent: Wednesday, August 26, 2020 9:52 AM
>>>>         To: Torsten Lodderstedt
>>>>         <torsten=40lodderstedt.net@dmarc.ietf.org
>>>>         <mailto:torsten=40lodderstedt.net@dmarc.ietf.org>>
>>>>         Cc: last-call@ietf.org <mailto:last-call@ietf.org>; oauth
>>>>         <oauth@ietf.org <mailto:oauth@ietf.org>>
>>>>         Subject: Re: [OAUTH-WG] Last Call:
>>>>         <draft-ietf-oauth-jwt-introspection-response-09.txt> (JWT
>>>>         Response for OAuth Token Introspection) to Proposed Standard
>>>>
>>>>
>>>>
>>>>         On Wed, Aug 26, 2020 at 4:37 AM Torsten Lodderstedt
>>>>         <torsten=40lodderstedt.net@dmarc.ietf.org
>>>>         <mailto:torsten=40lodderstedt.net@dmarc.ietf.org>> wrote:
>>>>         Hi Denis,
>>>>
>>>>>         On 25. Aug 2020, at 16:55, Denis <denis.ietf@free.fr
>>>>>         <mailto:denis.ietf@free.fr>> wrote:
>>>>
>>>>>         The fact that the AS will know exactly when the
>>>>>         introspection call has been made and thus be able to make
>>>>>         sure which client
>>>>>         has attempted perform an access to that RS and at which
>>>>>         instant of time. The use of this call allows an AS to
>>>>>         track where and when
>>>>>         its clients have indeed presented an issued access token.
>>>>
>>>>         That is a fact. I don’t think it is an issue per se. Please
>>>>         explain the privacy implications.
>>>>
>>>>         As I see it, the privacy implication is that the AS knows
>>>>         when the client (and potentially the user) is accessing the
>>>>         RS, which is also an indication of when the user is using
>>>>         the client.
>>>>
>>>>         I think including this implication would be important to
>>>>         have in a Privacy Considerations section.
>>>>
>>>>         /Dick
>>>>         ᐧ
>>>
>>>         _______________________________________________
>>>         OAuth mailing list
>>>         OAuth@ietf.org <mailto:OAuth@ietf.org>
>>>         https://www.ietf.org/mailman/listinfo/oauth
>>
>
>
> _______________________________________________
> OAuth mailing list
> OAuth@ietf.org
> https://www.ietf.org/mailman/listinfo/oauth