-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Rework W3C DC API examples #254
Conversation
Are we expecting breaking changes to the Browser API, I thought it was fairly settled for now? I'm not sure that removing the examples helps. The examples are non-normative and don't really show anything that's not already described in the normative text. (We can actually update the examples relatively easily, both during any public review period for the 1.0 spec revision, and even after 1.0 is published by making an errata update, but if the normative text is likely to require changes as well that's a much bigger problem.) |
Ah, I guess WICG/digital-credentials#165 may be the driver? Although the 'providers' -> 'requests' change itself looks like it shouldn't break normative text in VP, It is slightly concerning that there are suggestions on that PR that would affect the normative text, like changing 'request' to 'query'. |
I'm concerned about this here: WICG/digital-credentials#164 |
Maybe leaving a link for where to see current examples would be better than just removing them? Eg. maybe they belong in this GitHub repo but in their own non-normative file for easier updating? |
I don't think we should lock in this spec with the other at all. We might want to move things around and we haven't yet added the examples to the Digital Credentials Spec. Rest assured that we will add examples, but it might not happen in the accelerated timeframe OpenID4VP is currently on. We can add examples to a future version of OpenID4VP once the W3C Spec is a) in a working group, and b) we are confident on the design (e.g. the spec reaches CR on the W3C side). We don't have enough implementation experience yet to be confident we won't change more things - specially as the W3C spec hasn't been road tested with more request formats, which may change the underlying request model/structure. |
// Handle errors and/or fallback to other invocation mechanisms | ||
} | ||
``` | ||
The W3C Digital Credentials API [@!w3c.digital_credentials_api] contains an OpenID4VP Authorization Request, where every OpenID4VP Authorization Request parameter is represented as a top-level JavaScript object member. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
where every OpenID4VP Authorization Request parameter is represented as a top-level JavaScript object member
Is this a new development in Digital Credentials API? How would this work for signed requests?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The change here is removing "request
member", I think that's okay, it's removing the coupling between the two specs but it doesn't change how signed requests are handled.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is there any risk of this changing in the future? wouldn't this prevent passing multiple requests in an array? Would really prefer a text like The Verifier MAY send all the OpenID4VP request parameters to the W3C Digital Credentials API as defined in [@!w3c.digital_credentials_api]
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's best to say less. We don't know what the final API will look like.
@@ -1591,7 +1568,7 @@ Any OpenID4VP request compliant to this section of this specification can be use | |||
|
|||
### Unsigned Request {#unsigned_request} | |||
|
|||
The Verifier MAY send all the OpenID4VP request parameters as members in the `request` member passed to the API. In this case, the Wallet will use the Verifier's origin as asserted by the user agent as the Verifer's Client Identifier. | |||
The Verifier MAY send all the OpenID4VP request parameters as members to the W3C Digital Credentials API [@!w3c.digital_credentials_api]. In this case, the Wallet will use the Verifier's origin as asserted by the user agent as the Verifer's Client Identifier. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Again, how does this work for signed request where all the parameters are within a signed JWT which contains all of the parameters?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is in the "Unsigned request" section, this text won't affect signed requests.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
i would prefer something like this:
The Verifier MAY send all the OpenID4VP request parameters as members to the W3C Digital Credentials API [@!w3c.digital_credentials_api]. In this case, the Wallet will use the Verifier's origin as asserted by the user agent as the Verifer's Client Identifier. | |
The Verifier MAY send all the OpenID4VP request parameters to the W3C Digital Credentials API as defined in [@!w3c.digital_credentials_api]. In this case, the Wallet will use the Verifier's origin as asserted by the user agent as the Verifer's Client Identifier. |
Text in this PR does not sufficiently decouple openid4vp text and still makes it susceptible to any future breaking changes in the credentials API. "Put openid4vp request parameters in an appropriate place as defined in digital credentials API; the openid4vp parameter is X for signed requests and Y for unsigned requests" is what I would expect. Also very unsure about removing all of the examples. Will digital credentials API provide examples how to include openid4vp request there once it is stable? If not, we should keep some examples as of today in the spec. If the text is generic enough, changing the examples later as digital credentials API evolves is possible. |
As the W3C spec is changing a lot, it's best yet to not include any examples.
a3ed327
to
3b0d32c
Compare
Co-authored-by: Kristina <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks Marcos! Some small comments, could you update the PR title/first comment to reflect what is changing now too please?
Co-authored-by: Joseph Heenan <[email protected]>
Co-authored-by: Joseph Heenan <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM++
This would make it easier to decouple the OpenID4VP spec and the Digital Credentials API spec.
Hopefully better now... did this in a hurry at the ARF event last week. |
Co-authored-by: Giuseppe De Marco <[email protected]>
Co-authored-by: Giuseppe De Marco <[email protected]>
Co-authored-by: Giuseppe De Marco <[email protected]>
Co-authored-by: Giuseppe De Marco <[email protected]>
@@ -14,11 +14,7 @@ participant "App Platform" as ap | |||
participant "Wallet" as w | |||
|
|||
u --> r : use | |||
activate r | |||
|
|||
r -> wp: navigator.identity.get(\nprotocol="openid4vp",\nrequest="client_id, \nrequest_uri, request_uri_method=post, \npresentation_definition") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
so isn't this better be something like
r -> wp: send OpenID4VP request over the W3C Digital Credentials API
@@ -14,11 +14,7 @@ participant "App Platform" as ap | |||
participant "Wallet" as w | |||
|
|||
u --> r : use | |||
activate r | |||
|
|||
r -> wp: navigator.identity.get(\nprotocol="openid4vp",\nrequest="client_id, \nrequest_uri, request_uri_method=post, \npresentation_definition") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
same as above. shouldn't this better be something like
r -> wp: send OpenID4VP request over the W3C Digital Credentials API
@@ -19,7 +19,6 @@ activate r | |||
note over r,wp | |||
Note that the signed request object contains the Verifier's origin. | |||
end note | |||
r -> wp: navigator.identity.get(\nprotocol="openid4vp",\nrequest="client_id, request") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
same as above. shouldn't this better be something like
r -> wp: send OpenID4VP request over the W3C Digital Credentials API
As agreed on WG call Co-authored-by: Kristina <[email protected]>
response_mode: "w3c_dc_api", | ||
nonce: "n-0S6_WzA2Mj", | ||
client_metadata: {...}, | ||
presentation_definition: {...} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
or 🐶 #266 (comment) and now https://github.com/openid/OpenID4VP/pull/266/files#diff-3118c9756a1d7b361bb53af8bd9d65666476a27cfeeced56c47a5dccc38eac55R269 cc @danielfett
presentation_definition: {...} | |
dcql_query: {...} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
approved per WG discussion yesterday
As the W3C spec is changing a lot, it's best to not include any examples yet. That way, this spec can progress without locking in changes on the W3C side.