Re: [OAUTH-WG] question about the b64token syntax in draft-ietf-oauth-v2-bearer

Brian Campbell <bcampbell@pingidentity.com> Tue, 06 March 2012 16:23 UTC

Return-Path: <bcampbell@pingidentity.com>
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 2F86721F8964 for <oauth@ietfa.amsl.com>; Tue, 6 Mar 2012 08:23:57 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -5.768
X-Spam-Level:
X-Spam-Status: No, score=-5.768 tagged_above=-999 required=5 tests=[AWL=0.209, BAYES_00=-2.599, FM_FORGED_GMAIL=0.622, RCVD_IN_DNSWL_MED=-4]
Received: from mail.ietf.org ([12.22.58.30]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Q7mp5RPZci-x for <oauth@ietfa.amsl.com>; Tue, 6 Mar 2012 08:23:56 -0800 (PST)
Received: from na3sys009aog110.obsmtp.com (na3sys009aog110.obsmtp.com [74.125.149.203]) by ietfa.amsl.com (Postfix) with ESMTP id 9A02A21F8970 for <oauth@ietf.org>; Tue, 6 Mar 2012 08:23:55 -0800 (PST)
Received: from mail-vx0-f175.google.com ([209.85.220.175]) (using TLSv1) by na3sys009aob110.postini.com ([74.125.148.12]) with SMTP ID DSNKT1Y6Gh+ewUKZf96+zKVqPUFwgndQr8vF@postini.com; Tue, 06 Mar 2012 08:23:55 PST
Received: by mail-vx0-f175.google.com with SMTP id fl13so5052235vcb.20 for <oauth@ietf.org>; Tue, 06 Mar 2012 08:23:54 -0800 (PST)
Received-SPF: pass (google.com: domain of bcampbell@pingidentity.com designates 10.220.59.133 as permitted sender) client-ip=10.220.59.133;
Authentication-Results: mr.google.com; spf=pass (google.com: domain of bcampbell@pingidentity.com designates 10.220.59.133 as permitted sender) smtp.mail=bcampbell@pingidentity.com
Received: from mr.google.com ([10.220.59.133]) by 10.220.59.133 with SMTP id l5mr3423655vch.6.1331051034871 (num_hops = 1); Tue, 06 Mar 2012 08:23:54 -0800 (PST)
Received: by 10.220.59.133 with SMTP id l5mr2943000vch.6.1331051034235; Tue, 06 Mar 2012 08:23:54 -0800 (PST)
MIME-Version: 1.0
Received: by 10.52.171.172 with HTTP; Tue, 6 Mar 2012 08:23:23 -0800 (PST)
In-Reply-To: <4E1F6AAD24975D4BA5B1680429673943663DB078@TK5EX14MBXC283.redmond.corp.microsoft.com>
References: <CA+k3eCTTsqJZ7XzjA1qgxEJcyU0uio5EN2=yvs+h6ja1JEymiQ@mail.gmail.com> <255B9BB34FB7D647A506DC292726F6E114EDF66EE8@WSMSG3153V.srv.dir.telstra.com> <4E1F6AAD24975D4BA5B1680429673943663DB078@TK5EX14MBXC283.redmond.corp.microsoft.com>
From: Brian Campbell <bcampbell@pingidentity.com>
Date: Tue, 06 Mar 2012 08:23:24 -0800
Message-ID: <CA+k3eCS71Lhfffu-D_mZ=emk_rR7FASdSjpu+j1KnJWytSEXLw@mail.gmail.com>
To: Mike Jones <Michael.Jones@microsoft.com>
Content-Type: text/plain; charset="ISO-8859-1"
Content-Transfer-Encoding: quoted-printable
X-Gm-Message-State: ALoCoQlie52G6OQkbvhpeEP5VJNKzQ0teWwY9ADJPJRv3pHSGW6CZy7nL+7Hr7884RlJwuhtWYhR
Cc: oauth <oauth@ietf.org>
Subject: Re: [OAUTH-WG] question about the b64token syntax in draft-ietf-oauth-v2-bearer
X-BeenThere: oauth@ietf.org
X-Mailman-Version: 2.1.12
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: <http://www.ietf.org/mail-archive/web/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, 06 Mar 2012 16:23:57 -0000

Thanks Mike, I think changing the example would be helpful.

However I think that including some text along the lines of what James
suggested would also be very valuable. I agree that the connection
between OAuth and Bearer could and should be made more explicit. And
that the implications of the b64token syntax, particularly on what AS
can use to construct ATs, could/should be made more clear.

I can propose some specific text (building on James') if others in the WG agree?


On Mon, Mar 5, 2012 at 5:32 PM, Mike Jones <Michael.Jones@microsoft.com> wrote:
> I'm fine with changing the example to make it clearer that b64token allows a wider range of characters than just those legal for base64 and base64url encodings of data values.
>
> I'll add it to my to-do list for any additional edits for the Bearer spec.
>
>                                -- Mike
>
> -----Original Message-----
> From: oauth-bounces@ietf.org [mailto:oauth-bounces@ietf.org] On Behalf Of Manger, James H
> Sent: Monday, March 05, 2012 3:33 PM
> To: Brian Campbell; oauth
> Subject: Re: [OAUTH-WG] question about the b64token syntax in draft-ietf-oauth-v2-bearer
>
> Brian,
>
>> On casual reading of "The OAuth 2.0 Authorization Protocol: Bearer
>> Tokens"* I've encountered several people (including myself) who have
>> made the assumption that the name b64token implies that some kind of
>> base64 encoding/decoding on the access token is taking place between
>> the client and RS.
>>
>> Digging a bit deeper in to "HTTP/1.1, part 7: Authentication"**,
>> however, I see that b64token is just an ABNF syntax definition
>> allowing for characters typically used in base64, base64url, etc.. So
>> the b64token doesn't define any encoding or decoding but rather just
>> defines what characters can be used in the part of the Authorization
>> header that will contain the access token.
>>
>> Do I read this correctly?
>
> Yes.
>
>> If so, I feel like some additional clarifying text in the Bearer
>> Tokens draft might help avoid what is (based on my small sample) a
>> common point of misunderstanding.
>
> Changing the example bearer token should be a simple way to avoid some confusion by showing that it does not have to be base64 encoding. How about changing:
>  Authorization: Bearer vF9dft4qmT
> to
>  Authorization: Bearer vF9.dft4.qmT
>
> The Bearer spec has lots of (unnecessary) text about OAuth, but doesn't quite manage to be precise about how OAuth and Bearer connect. It could explicitly state that the string value of the "access_token" member of an access token response is the bearer token. The "access_token" string value (after unescaping any JSON-escapes) MUST match the b64token ABNF so it can be used with the Bearer HTTP scheme. Such text could be put in §5.1.1 where the "Bearer" OAuth access token type is defined.
>
>
>> Also, does the use of b64token implicitly limit the allowed characters
>> that an AS can use to construct a bearer access token?
>
> Yes.
>
>
>> * http://tools.ietf.org/html/draft-ietf-oauth-v2-bearer-17#section-2.1
>> **
>> http://tools.ietf.org/html/draft-ietf-httpbis-p7-auth-18#section-2.1
>
> --
> James Manger
> _______________________________________________
> OAuth mailing list
> OAuth@ietf.org
> https://www.ietf.org/mailman/listinfo/oauth
>
>