Re: [OAUTH-WG] Registration: Scope Values

"Donald F Coffin" <donald.coffin@reminetworks.com> Fri, 12 April 2013 20:27 UTC

Return-Path: <donald.coffin@reminetworks.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 11EBE21F8F01 for <oauth@ietfa.amsl.com>; Fri, 12 Apr 2013 13:27:02 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.264
X-Spam-Level:
X-Spam-Status: No, score=-2.264 tagged_above=-999 required=5 tests=[BAYES_00=-2.599, HTML_MESSAGE=0.001, IP_NOT_FRIENDLY=0.334]
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 Fk1UoXDkNWX2 for <oauth@ietfa.amsl.com>; Fri, 12 Apr 2013 13:26:58 -0700 (PDT)
Received: from oproxy5-pub.bluehost.com (oproxy5-pub.bluehost.com [67.222.38.55]) by ietfa.amsl.com (Postfix) with SMTP id A759821F8EBE for <oauth@ietf.org>; Fri, 12 Apr 2013 13:26:58 -0700 (PDT)
Received: (qmail 2252 invoked by uid 0); 12 Apr 2013 20:26:37 -0000
Received: from unknown (HELO host125.hostmonster.com) (74.220.207.125) by cpoproxy2.bluehost.com with SMTP; 12 Apr 2013 20:26:37 -0000
DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=reminetworks.com; s=default; h=Content-Type:MIME-Version:Message-ID:Date:Subject:In-Reply-To:References:Cc:To:From; bh=3JKJcx4M13dGNBQITuoQioZLf5sGbe1b/bAARw7bu3o=; b=BcwDeTQbTqqcK1Z1JnWij+wuSIfpWNoiHeE7hIaF0zqh3KI+xgRxif+OEZbIK1TFILpO3B0PKoHj0Bsb864P3UnFinsB8JeyE3JBSLh0FdRY5TECNetzfFZrh19rDb+R;
Received: from [68.4.207.246] (port=3304 helo=HPPavilionElite) by host125.hostmonster.com with esmtpa (Exim 4.80) (envelope-from <donald.coffin@reminetworks.com>) id 1UQkYO-0004Pn-WB; Fri, 12 Apr 2013 14:26:37 -0600
From: Donald F Coffin <donald.coffin@reminetworks.com>
To: 'Justin Richer' <jricher@mitre.org>
References: <51685177.8060603@mitre.org> <00c901ce37b5$443c3dd0$ccb4b970$@reminetworks.com> <5168650F.1070709@mitre.org>
In-Reply-To: <5168650F.1070709@mitre.org>
Date: Fri, 12 Apr 2013 13:25:00 -0700
Message-ID: <010401ce37bb$cf0582e0$6d1088a0$@reminetworks.com>
MIME-Version: 1.0
Content-Type: multipart/alternative; boundary="----=_NextPart_000_0105_01CE3781.22AB65D0"
X-Mailer: Microsoft Outlook 14.0
Thread-Index: AQKhIF8eX/RIXMm9kgogxQzt5YcUwgGN6dx1Asn442uXCnevwA==
Content-Language: en-us
X-Identified-User: {1395:host125.hostmonster.com:reminetw:reminetworks.com} {sentby:smtp auth 68.4.207.246 authed with donald.coffin@reminetworks.com}
Cc: oauth@ietf.org
Subject: Re: [OAUTH-WG] Registration: Scope Values
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: Fri, 12 Apr 2013 20:27:02 -0000

Justin,

 

Thanks for the clarification.

 

Best regards,

Don

Donald F. Coffin

Founder/CTO

 

REMI Networks

22751 El Prado Suite 6216

Rancho Santa Margarita, CA  92688-3836

 

Phone:      (949) 636-8571

Email:        <mailto:donald.coffin@reminetworks.com>
donald.coffin@reminetworks.com

 

From: Justin Richer [mailto:jricher@mitre.org] 
Sent: Friday, April 12, 2013 12:49 PM
To: Donald F Coffin
Cc: oauth@ietf.org
Subject: Re: [OAUTH-WG] Registration: Scope Values

 

The question refers to the Dynamic Registration draft specifically, since
that's what's still editable. RFC6749 treats scopes as bags of strings that
are specific to the API that they're protecting, which lets them be either
static strings or expressions (or, really, whatever you like them to be).
The problem is that the Dynamic Registration draft isn't defining just the
conveyance of the scope string during the authorization process, it's got to
have language on what a scope is *for* in order for it to make sense in
registration. In other words, what does it mean to be "registered" with a
scope? What does it mean to ask for a scope at registration time? What does
it mean for a server to "grant" a scope at registration time? 

I had thought that the current language (which is mostly lifted from
RFC6749) was sufficient, but there's been question as to its intent, so I
want to make sure that it's very clear that Dynamic Registration is as
hands-off about scope values as RFC6749 is.

 -- Justin

On 04/12/2013 03:38 PM, Donald F Coffin wrote:

Justin,

 

While I understand the need to clarify the usage of the scope metadata, I'm
not clear on whether your question refers to the Dynamic Registration draft
or to RFC 6749?  

 

The current language of the Dynamic Registration draft to describe the scope
metadata usage is the same language used to describe the scope parameter
that appears in Section 3.3 of RFC 6749.  If the Dynamic Registration draft
uses language different than what is contained in the scope parameter
definition of RFC 6749 additional confusion about the usage of the scope
parameter may arise.  Perhaps the best way to address the issue within the
Dynamic Registration draft is to provide an explanation.  The examples you
provided in your posting could easily be included in the Dynamic
Registration draft and would achieve the desired effect of demonstrating how
the OAuth 2.0 scope parameter might be used.

 

Best regards,

Don

Donald F. Coffin

Founder/CTO

 

REMI Networks

22751 El Prado Suite 6216

Rancho Santa Margarita, CA  92688-3836

 

Phone:      (949) 636-8571

Email:       donald.coffin@reminetworks.com

 

From: Justin Richer [mailto:jricher@mitre.org] 
Sent: Friday, April 12, 2013 11:25 AM
To: oauth@ietf.org
Subject: [OAUTH-WG] Registration: Scope Values

 

Currently, the Dynamic Registration draft defines a "scope" value as part of
the client metadata table, with the following definition:

   scope
      OPTIONAL.  Space separated list of scope values (as described in
      OAuth 2.0 Section <http://tools.ietf.org/html/rfc6749#section-3.3>
3.3 [RFC6749]) that the client is declaring that
      it may use when requesting access tokens.  If omitted, an
      Authorization Server MAY register a Client with a default set of
      scopes.


The idea here is that a client can request a particular set of available
scopes from the AS (analogous as to what's available from many/most manual
registration pages today), and the AS can communicate back to the client
what scopes it's allowed to ask for at authz time. In a strictly-enforced
implementation, the client wouldn't be able to ask for any scopes that it
wasn't registered for in the first place.

However, it's been brought up in some side conversations that the language
as found in the DynReg spec might get in the way of people using the "scope"
field as an expression language. That is to say, you could have a scope like
<mailto:send_email_to:myaddress@email.com>
"send_email_to:myaddress@email.com" where the email address portion is
variable, or something like "read:*" which stands in for any scopes starting
with "read:" like "read:profile", "read:lists", etc. Precluding this
behavior wasn't my intent, and a liberal interpretation of the text
as-written would (I believe) lead to this being perfectly OK. Namely:

Client requests and is granted a service specific scope value like
"send_email_to" in registration. At runtime, the client knows how to turn
"send_email_to" into  <mailto:send_email_to:myaddress@email.com>
"send_email_to:myaddress@email.com", and the AS knows that a client that's
been granted "send_email_to" can ask for
<mailto:send_email_to:myaddress@email.com>
"send_email_to:myaddress@email.com". The fact that "send_email_to" expands
into an expression language is something specific to the service, and I
personally think it's up to the service to document "register for this" and
"ask for this at authn time" for clients, since this is all part of the API
more than it is part of the underlying OAuth protocol. OAuth merely provides
a handy place to communicate these values in an interoperable way, the
values themselves aren't intended to be interoperable. 


But my question to the group is simple: how can we rework the "scope"
metadata claim such that it works in both the simple "bag of discreet
strings" approach to scope as well as the "list of expressions" approach?
Does the language need to change at all?

 -- Justin