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

Mike Jones <Michael.Jones@microsoft.com> Wed, 25 November 2015 03:25 UTC

Return-Path: <Michael.Jones@microsoft.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 6279A1A8AAB for <oauth@ietfa.amsl.com>; Tue, 24 Nov 2015 19:25:55 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.002
X-Spam-Level:
X-Spam-Status: No, score=-2.002 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_PASS=-0.001, 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 sxMxCX6tW4LQ for <oauth@ietfa.amsl.com>; Tue, 24 Nov 2015 19:25:50 -0800 (PST)
Received: from na01-by2-obe.outbound.protection.outlook.com (mail-by2on0131.outbound.protection.outlook.com [207.46.100.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id DD8161ACE32 for <oauth@ietf.org>; Tue, 24 Nov 2015 19:25:50 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector1; h=From:To:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=D/c1UIiVaMQbSYeY6Q86mpgLpb+/6bCxyVw/exSHBew=; b=DrB17yAfxQB1bfzdFlvdUmWJfIDOtHJ9T+zTWfnYrp8gr7gnytA2Cku0wsSWBdYs9R4zIj/a9qsPQneSAzrfZ3yqnZ4QhHIwvJdk5ELsLWKbNyYY/1CnGtFD1l719yngrp1UUZCdhXOxdw9VGKub/8HJyQUhIDPXXxxSEzjTQEM=
Received: from BY2PR03MB442.namprd03.prod.outlook.com (10.141.141.145) by BY2PR03MB442.namprd03.prod.outlook.com (10.141.141.145) with Microsoft SMTP Server (TLS) id 15.1.331.20; Wed, 25 Nov 2015 03:25:48 +0000
Received: from BY2PR03MB442.namprd03.prod.outlook.com ([10.141.141.145]) by BY2PR03MB442.namprd03.prod.outlook.com ([10.141.141.145]) with mapi id 15.01.0331.023; Wed, 25 Nov 2015 03:25:48 +0000
From: Mike Jones <Michael.Jones@microsoft.com>
To: Kathleen Moriarty <kathleen.moriarty.ietf@gmail.com>
Thread-Topic: [OAUTH-WG] AD review of draft-ietf-oauth-proof-of-possession
Thread-Index: AQHRJt++kWDp0FqlfEmPEzc+Ih7voJ6r6UxQgAAee4CAAAb2QIAAAjcAgAAA9fA=
Date: Wed, 25 Nov 2015 03:25:48 +0000
Message-ID: <BY2PR03MB44297DA1D6A4C4F125EBCFCF5050@BY2PR03MB442.namprd03.prod.outlook.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>
In-Reply-To: <CAHbuEH6x4fxPmho8RbgFLngXGROcDfGhSWkDAAciVkYa7AOXTw@mail.gmail.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
authentication-results: spf=none (sender IP is ) smtp.mailfrom=Michael.Jones@microsoft.com;
x-originating-ip: [50.47.85.157]
x-microsoft-exchange-diagnostics: 1; BY2PR03MB442; 5:hmWTn9dLSnpQL7LUJVdk62b6bamex6Xk9TLgi9qvzsvGlINXpK4Yer42EmiH7fP0V/BZfAE+X2lEHV+7i2pLLkp78DmSMBa1jx1AHU1AVvUDmZLSVAfM5uGJkpQDEvLcbzzllB01kzb8OOoyeVgBIQ==; 24:WDMfrdCis73jdfAuQ0EVNjtCwJQ6pLIFVLmntxJDL2AitHiYLlLEvdGs9B6XnZojrBfJgM58HvC0PpRKiKtb75WUyK+yn1Bl3kyg2Ze8s7Q=
x-microsoft-antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BY2PR03MB442;
x-microsoft-antispam-prvs: <BY2PR03MB442C92DCC9FD5DE1413285CF5050@BY2PR03MB442.namprd03.prod.outlook.com>
x-exchange-antispam-report-test: UriScan:(108003899814671);
x-exchange-antispam-report-cfa-test: BCL:0; PCL:0; RULEID:(61425024)(601004)(2401047)(520078)(5005006)(8121501046)(10201501046)(3002001)(61426024)(61427024); SRVR:BY2PR03MB442; BCL:0; PCL:0; RULEID:; SRVR:BY2PR03MB442;
x-forefront-prvs: 0771670921
x-forefront-antispam-report: SFV:NSPM; SFS:(10019020)(6009001)(164054003)(43784003)(13464003)(377454003)(51914003)(189002)(24454002)(199003)(10090500001)(5003600100002)(5002640100001)(5005710100001)(586003)(92566002)(10400500002)(3846002)(76176999)(10290500002)(76576001)(102836003)(50986999)(106356001)(110136002)(105586002)(5001960100002)(106116001)(189998001)(8990500004)(99286002)(2900100001)(6116002)(86362001)(81156007)(40100003)(5004730100002)(5007970100001)(97736004)(2950100001)(93886004)(87936001)(33656002)(5008740100001)(15975445007)(74316001)(11100500001)(101416001)(66066001)(122556002)(230783001)(77096005)(86612001)(19580395003)(19580405001)(54356999); DIR:OUT; SFP:1102; SCL:1; SRVR:BY2PR03MB442; H:BY2PR03MB442.namprd03.prod.outlook.com; FPR:; SPF:None; PTR:InfoNoRecords; MX:1; A:1; LANG:en;
received-spf: None (protection.outlook.com: microsoft.com does not designate permitted sender hosts)
spamdiagnosticoutput: 1:23
spamdiagnosticmetadata: NSPM
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: base64
MIME-Version: 1.0
X-OriginatorOrg: microsoft.com
X-MS-Exchange-CrossTenant-originalarrivaltime: 25 Nov 2015 03:25:48.3793 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47
X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY2PR03MB442
Archived-At: <http://mailarchive.ietf.org/arch/msg/oauth/2VOEeQsp-NF7P01Poxx9L_74nno>
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 03:25:55 -0000

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