Re: [OAUTH-WG] AD review of draft-ietf-oauth-proof-of-possession

John Bradley <ve7jtb@ve7jtb.com> Wed, 25 November 2015 21:42 UTC

Return-Path: <ve7jtb@ve7jtb.com>
X-Original-To: oauth@ietfa.amsl.com
Delivered-To: oauth@ietfa.amsl.com
Received: from localhost (ietfa.amsl.com [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id D13021B30D4 for <oauth@ietfa.amsl.com>; Wed, 25 Nov 2015 13:42:12 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.901
X-Spam-Level:
X-Spam-Status: No, score=-1.901 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, SPF_PASS=-0.001] autolearn=ham
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 zhY-mYPjYGQe for <oauth@ietfa.amsl.com>; Wed, 25 Nov 2015 13:42:10 -0800 (PST)
Received: from mail-qg0-x231.google.com (mail-qg0-x231.google.com [IPv6:2607:f8b0:400d:c04::231]) (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 00BDE1B30D3 for <oauth@ietf.org>; Wed, 25 Nov 2015 13:42:09 -0800 (PST)
Received: by qgec40 with SMTP id c40so42060332qge.2 for <oauth@ietf.org>; Wed, 25 Nov 2015 13:42:09 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ve7jtb-com.20150623.gappssmtp.com; s=20150623; h=content-type:mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=KcP1q1jIQMlbCLClAvBHLKoriNIQNa3Op9wyvvojgnU=; b=ZbyEYnjSek6czqaINrxQCdBlkd4hP6rNk+w83W7/dH6I5hts5+I7SucSlj1oy9YXC7 RfegDo+P4oOl/DOtqxWKmaj7eriqVQAChcgsilBQ4g5JNZMro/b5LjWSsZ6JCf0LjWBQ ufHy9r5cr6ODsXNidP3ASJoe1zH5v6CrsZzdjK7xSnQ05/k687LTuVV801mPwjv8J+Hn RIzFU4Y0y3rmQVDx9BClaPuahZQ/vWDg3In4GrcDp4PMPnLtuIWWRP9xfWmfuw4TxMwo tPQ6L2iDcqOm9svF4mYH54o1B37s45jFRjGU2oEwDdfQYoPQFbjPHfcrM8Z3zzA1CV6b vSEA==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:content-type:mime-version:subject:from :in-reply-to:date:cc:content-transfer-encoding:message-id:references :to; bh=KcP1q1jIQMlbCLClAvBHLKoriNIQNa3Op9wyvvojgnU=; b=ZDmI6kIeURMw0S6vMqtMB9HuEIwu0T7eAqCiUyaVI39Fs5C5yOcHiab7dZ2eMfth1L tN6keQOPKiQL0BjtCQtzpwhZGjFIfHamgTw8Jiy0CDiHrsdjuwyaaOIdbNoQIxZwBOWi MwXNRo/H7nZ/+Aq6mtG5pR9DtlxRubGpWawlPJ3XZqcEFj/ZDDK17Dg2UNrVzI4LDY2G CuVSHxCwFzmlEZRXGiMHnNs1Eh0lY2KrCI8xeoTqVfRr3Sy7c19+tSOWGZohhjzSbrTH l6ID9BrDc5O25UaxvLWiAZRPMb5UW6J1L7jETYRkMLwbynIvCkMxQgDJjZvo/ouIpbU/ 2CWQ==
X-Gm-Message-State: ALoCoQm3cdobsxoMhGVwiqHw8thW/AIhTQLu5mfd3huqXWoUPSCWteFyWaLRtyLjPqjTsJ6Uk20c
X-Received: by 10.140.29.7 with SMTP id a7mr5074141qga.6.1448487728918; Wed, 25 Nov 2015 13:42:08 -0800 (PST)
Received: from [192.168.1.216] ([191.115.122.254]) by smtp.gmail.com with ESMTPSA id x129sm6041782qhc.33.2015.11.25.13.42.01 (version=TLS1 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Wed, 25 Nov 2015 13:42:07 -0800 (PST)
Content-Type: text/plain; charset="utf-8"
Mime-Version: 1.0 (Mac OS X Mail 8.2 \(2104\))
From: John Bradley <ve7jtb@ve7jtb.com>
In-Reply-To: <BY2PR03MB44297DA1D6A4C4F125EBCFCF5050@BY2PR03MB442.namprd03.prod.outlook.com>
Date: Wed, 25 Nov 2015 18:41:50 -0300
Content-Transfer-Encoding: quoted-printable
Message-Id: <4AF8FE9C-3484-410B-B52F-C1F9706B18A5@ve7jtb.com>
References: <CAHbuEH4J5SYVuWe5+OHfCQARuZhOJ6hG=5RqUkh5Ebad_RneAg@mail.gmail.com> <BY2PR03MB442BD8E7C5AFA8D79C79AEAF5050@BY2PR03MB442.namprd03.prod.outlook.com> <CAHbuEH7pJFKH_gJE6aSHCBQZL5eZ9qxyHajzjwz=5v8+LD7ywQ@mail.gmail.com> <BY2PR03MB4422F5F3905D4118D9D540BF5050@BY2PR03MB442.namprd03.prod.outlook.com> <CAHbuEH6x4fxPmho8RbgFLngXGROcDfGhSWkDAAciVkYa7AOXTw@mail.gmail.com> <BY2PR03MB44297DA1D6A4C4F125EBCFCF5050@BY2PR03MB442.namprd03.prod.outlook.com>
To: Michael Jones <Michael.Jones@microsoft.com>
X-Mailer: Apple Mail (2.2104)
Archived-At: <http://mailarchive.ietf.org/arch/msg/oauth/Gwiu4hB-QfIjkTnQZ0uhitwaU68>
Cc: "oauth@ietf.org" <oauth@ietf.org>
Subject: Re: [OAUTH-WG] AD review of draft-ietf-oauth-proof-of-possession
X-BeenThere: oauth@ietf.org
X-Mailman-Version: 2.1.15
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: Wed, 25 Nov 2015 21:42:13 -0000

I prefer the new wording.

However the last part could be clearer.
>  use be implemented by recipients.

Or perhaps the blunter “Recipients only understanding bearer tokens may accept JWT containing “cnf” elements if all the other required claims are valid.  It is important for security to audience restrict tokens using the JWT “aud claim.  The “cnf” claim MUST NOT be used as a pseudo audience restriction.”

Looking at the comments, I get the feeling that some people might think that cnf may restrict what endpoints can receive the token (because of the key distribution)  it only allows endpoints that should receive the token to reject ones that come from entities who don’t possess the correct confirmation.

John B.

> On Nov 25, 2015, at 12:25 AM, Mike Jones <Michael.Jones@microsoft.com> wrote:
> 
> Rather than elaborating, having looked at the text we're discussing again, I'm going to counter-propose that we instead simplify - sticking only to the point that the paragraph is intending to get across.  Would it work for you to simplify the current text:
> 
>    "A recipient might not understand the cnf claim, in which case it will typically be ignored. Unless this is acceptable behavior, applications that need the proof-of-possession keys communicated with it to be understood and processed must require that the parts of this specification that they use be implemented."
> 
> to this simpler text?
> 
>    "A recipient might not understand the cnf claim.  Applications that need the proof-of-possession keys communicated with it to be understood and processed must require that the parts of this specification that they use be implemented."
> 
> The "must ignore" topic is already addressed in the second paragraph of 3.1 (and with exactly the semantics as the rest of JWT), and so doesn't have to be re-raised here, as it currently is.  Re-raising it is clearly a point of distraction.
> 
> For what it's worth, I don't remember any DISCUSSes on this topic (although it's possible that your memory is better than mine on this point).
> 
> 				Best wishes,
> 				-- Mike
> 
> -----Original Message-----
> From: Kathleen Moriarty [mailto:kathleen.moriarty.ietf@gmail.com] 
> Sent: Tuesday, November 24, 2015 7:14 PM
> To: Mike Jones <Michael.Jones@microsoft.com>
> Cc: oauth@ietf.org
> Subject: Re: [OAUTH-WG] AD review of draft-ietf-oauth-proof-of-possession
> 
> On Tue, Nov 24, 2015 at 10:10 PM, Mike Jones <Michael.Jones@microsoft.com> wrote:
>> Fair question about the use of "typically".  The reason it's there is that this language in JWT [RFC 7519] Section 4 does permit applications to require that JWTs with not-understood claims be rejected, rather than ignored, even though that's not the default behavior:
>> 
>>   The set of claims that a JWT must contain to be considered valid is
>>   context dependent and is outside the scope of this specification.
>>   Specific applications of JWTs will require implementations to
>>   understand and process some claims in particular ways.  However, in
>>   the absence of such requirements, all claims that are not understood
>>   by implementations MUST be ignored.
>> 
>> So when not understood, "cnf" would typically be ignored, but might not be.
> 
> I find that confusing and am now thinking this came up in a discuss as well during the review for 7519, didn't it?  Can you elaborate int eh security considerations section a bit more, otherwise this text appears to be conflicting and even with what you intend, it's confusing for implementers and will lead to issues with interoperability.
> 
> Thanks,
> Kathleen
> 
> 
>> 
>>                                -- Mike
>> 
>> -----Original Message-----
>> From: Kathleen Moriarty [mailto:kathleen.moriarty.ietf@gmail.com]
>> Sent: Tuesday, November 24, 2015 6:41 PM
>> To: Mike Jones <Michael.Jones@microsoft.com>
>> Cc: oauth@ietf.org
>> Subject: Re: [OAUTH-WG] AD review of 
>> draft-ietf-oauth-proof-of-possession
>> 
>> Hi Mike,
>> 
>> Thanks for the quick turn-around.  Just one more comment on my comments.
>> 
>> On Tue, Nov 24, 2015 at 9:10 PM, Mike Jones <Michael.Jones@microsoft.com> wrote:
>>> Thanks for your review comments, Kathleen.  Responses are inline below...
>>> 
>>>> -----Original Message-----
>>>> From: OAuth [mailto:oauth-bounces@ietf.org] On Behalf Of Kathleen 
>>>> Moriarty
>>>> Sent: Tuesday, November 24, 2015 9:44 AM
>>>> To: oauth@ietf.org
>>>> Subject: [OAUTH-WG] AD review of 
>>>> draft-ietf-oauth-proof-of-possession
>>>> 
>>>> Hi,
>>>> 
>>>> Thank you all for your work on this draft!  I just have a few questions:
>>>> 
>>>> 1. Security considerations section says:
>>>> 
>>>> "All of the normal security issues, especially in relationship to
>>>>   comparing URIs and dealing with unrecognized values, that are
>>>>   discussed in JWT [JWT] also apply here."
>>>> 
>>>> I find that to be odd phrasing that would likely be picked up in 
>>>> subsequent reviews.  Please remove the word "normal" so that all of 
>>>> the security issues discusses in JWT are included.  Are there other 
>>>> 'normal considerations in addition to those in JWT that need to be 
>>>> listed?  The phrasing reads as if that may the case and would be 
>>>> better to include them all or pointers or change the phrasing.
>>> 
>>> You're right.  I removed this awkward wording.
>>> 
>>>> 2. Also in the security considerations section,
>>>> 
>>>>   "A recipient may not understand the newly introduced "cnf" claim and
>>>>   may consequently treat it as a bearer token."
>>>> 
>>>> What is the proper handling requirement when an unknown claim is 
>>>> present?  Section 3.1 says:
>>>>  "When a recipient receives a "cnf" claim with a
>>>>   member that it does not understand, it MUST ignore that member."
>>>> 
>>>> Is this why it is treated as a bearer token rather than being 
>>>> rejected?  Is this really the action you want to see with cnf?  Why 
>>>> isn't there an error and a resend as a bearer token so that parties 
>>>> understand (or have an opportunity to understand) that there were issues?
>>>> 
>>>> Then the following text in the security section says:
>>>>  "While this is a
>>>>   legitimate concern, it is outside the scope of this specification,
>>>>   since demonstration the possession of the key associated with the
>>>>   "cnf" claim is not covered by this specification. For more 
>>>> details,
>>>> 
>>>> How is this outside of the scope of this draft?  cnf is defined in 
>>>> this draft, so handling should be covered in this draft.  A pointer 
>>>> to the POP architecture draft is not helpful as it is not defined 
>>>> there, it's covered int his draft.  Should this text just be removed 
>>>> and replaced with more explicit handling information int he body of this draft?
>>> 
>>> Good catch.  JWT [RFC 7519] Section 4 says that claims that are not understood must be ignored unless otherwise specified by the application.  This allows new claims to be dynamically added without breaking existing applications.  For the same reason, I have incorporated this language about understanding claims from 7519, but having it be about understanding confirmation members.  Ultimately, what features must be implemented are always up to the application, just as with JWT claims.
>> 
>> The new text in Section 3.1 looks good.  I'm not sure why the word "typically" appears int he new text of the security considerations section though after reading the new text in 3.1.  Wouldn't it just be ignored since 3.1 now says:
>> 
>>   "However, in the absence of such requirements,
>>    all confirmation members that are not understood by implementations
>>    MUST be ignored."
>> 
>> Thanks,
>> Kathleen
>> 
>> 
>>> 
>>>> Thanks!
>>>> 
>>>> --
>>>> 
>>>> Best regards,
>>>> Kathleen
>>>> 
>>>> _______________________________________________
>>>> OAuth mailing list
>>>> OAuth@ietf.org
>>>> https://www.ietf.org/mailman/listinfo/oauth
>>> 
>>>                                Thanks again,
>>>                                -- Mike
>>> 
>> 
>> 
>> 
>> --
>> 
>> Best regards,
>> Kathleen
> 
> 
> 
> -- 
> 
> Best regards,
> Kathleen
> _______________________________________________
> OAuth mailing list
> OAuth@ietf.org
> https://www.ietf.org/mailman/listinfo/oauth