Hello Jim,

Thanks for your comments! I understand and I agree. In any case, my point 
wasn’t really that there was no situation in which a 4.01 reply would make 
sense. My point was that, in the way the draft is currently written, it asks a 
RS to return 4.01 in certain cases, and in at least some of those cases, the RS 
can’t really reply with a 4.01 (and as Carsten mentioned, the RS can’t even get 
the actual request). I am not sure what the best way to clarify that is, but 
when we were trying to implement that part of the draft, it was confusing 
because we couldn’t really comply with what is requested there, at least in the 
specific case I described.

As a separate comment, I am not sure I understand the specific examples you 
mention. From the draft (same section 5.8.2), it looks as if, in the first case 
you are describing (different action on the same resource), 4.05 should be 
returned. And in your second example (same action on a different resource), it 
looks as if the RS should return 4.03. Is this correct? We are just trying to 
ensure we are implementing error handling properly here. This is only a comment 
on these specific examples; I am not saying there is no situation where 4.01 
could be returned.

Sebastian

From: Jim Schaad <i...@augustcellars.com>
Date: Tuesday, February 19, 2019 at 6:17 PM
To: Sebastian Echeverria <sechever...@sei.cmu.edu>, "ace@ietf.org" 
<ace@ietf.org>
Subject: RE: [Ace] Comment about error responses in 
draft-ietf-ace-oauth-authz-21

Sebastian,

The 4.01 is not restricted to just the DTLS case.  One could get this error 
from just trying to get the resource on the schema coap rather than coaps.  
However, this could occur even in the DTLS profile case.  Consider the 
situation of the following:

I have a token which allows me to do a get on a resource
I setup the DTLS session with that token and preform the get
I then attempt to do a PUT on that same resource.

This would then return a 4.01 (Unauthorized) because I don’t have a valid 
access token for the purpose of doing the action.  The same thing would be true 
if I attempted to do a GET on a different resource.

Jim


From: Ace <ace-boun...@ietf.org> On Behalf Of Sebastian Echeverria
Sent: Monday, February 18, 2019 6:59 AM
To: ace@ietf.org
Subject: [Ace] Comment about error responses in draft-ietf-ace-oauth-authz-21

Hello,

I have a short comment about error responses from an RS in 
draft-ietf-ace-oauth-authz-21. More specifically, my question is about section 
5.8.2. In the second paragraph, it states “The response code MUST be 4.01 
(Unauthorized) in case the client has not performed the proof-of-possession, or 
if RS has no valid access token for the client.” I am assuming this means that 
if the client is trying to access a resource and sending a pop key id that is 
not known by the RS, either because the RS has never seen it or because it is 
associated to a token that has already been removed from the RS, then this is 
how the RS should reply.

If this is the case, I am a bit confused on how to implement this when using 
the DTLS profile. When using this profile, a client will first try to establish 
a DTLS session with the RS when accessing a resource. Once the session is 
established, it will actually try to access the resource over that DTLS 
connection. The pop key id to be used is sent when establishing the DTLS 
connection in the DTLS handshake messages, but if the RS does not have a 
key+token associated to that id for whatever reason, then it will cancel the 
DTLS handshake. If the DTLS handshake is never completed, then the RS can’t 
really send a reply at all, much less a 4.01 reply.

Thanks,

Sebastian Echeverria
_______________________________________________
Ace mailing list
Ace@ietf.org
https://www.ietf.org/mailman/listinfo/ace

Reply via email to