Skip to content
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

support provider device_authorization_endpoint #365

Merged
merged 1 commit into from
Nov 28, 2023
Merged

Conversation

cbodonnell
Copy link
Contributor

@cbodonnell cbodonnell commented Feb 9, 2023

DeviceAuthURL was added to oauth2.Endpoint in golang.org/x/oauth2 v0.13.0

This PR adds support for parsing the provider device_authorization_endpoint from the OIDC discovery endpoint and populates DeviceAuthURL for the oauth2.Endpoint returned by Provider.Endpoint().

Related issue: #357

Copy link

@somersf somersf left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Device code flow support, and the additional DeviceAuthURL field in Endpoint finally merged into golang.org/x/oauth2 @ v0.13.0.

Perhaps this PR could be updated and made ready for review by the package maintainers?

Some mini comments:

The "coreos/cbodonnell" search/replace in README.md, go.mod, example/{idtoken,userinfo}/app.go, and test should't be part of the PR.

I'd be inclined to update go.mod to depend golang.org/x/oauth2 v0.13.0, and to
update oidc/oidc.go func (p *Provider) Endpoint() oauth2.Endpoint { to have it initialize the DeviceAuthURL field; that way it's auto-populated in the Endpoint for any existing code using Provider.Endpoint() - though I'm not sure if the package maintainers would agree or not...

Thanks!

@ericchiang
Copy link
Collaborator

I don't see device_authorization_endpoint as a field provided by OpenID Connect discovery https://openid.net/specs/openid-connect-discovery-1_0.html

Is there another spec I should be looking at?

@ericchiang
Copy link
Collaborator

An to be clear, you can retrieve any additional discovery fields through https://pkg.go.dev/github.com/coreos/go-oidc/v3/oidc#Provider.Claims

So users can already access device_authorization_endpoint if a provider returns it today

@somersf
Copy link

somersf commented Oct 24, 2023

I don't see device_authorization_endpoint as a field provided by OpenID Connect discovery https://openid.net/specs/openid-connect-discovery-1_0.html

Is there another spec I should be looking at?

RFC-8628: OAuth 2.0 Device Authorization Grant -(section 4) defines device_authorization_endpoint, and says it can optionally be included in RFC-8414: OAuth 2.0 Authorization Server Metadata. The latter RFC's introduction says: This specification generalizes the metadata format defined by "OpenID Connect Discovery 1.0" [OpenID.Discovery] in a way that is compatible with OpenID Connect Discovery while being applicable to a wider set of OAuth 2.0 use cases.

So, whilst device_authorization_endpoint might not be specifically mentioned in an OIDC specification, it can be included/found in .well-known/openid-configuration - for example see the final paragraph of RFC-8414: OAuth 2.0 Authorization Server Metadata - Section 3 says: Some OAuth applications will choose to use the well-known URI suffix "openid-configuration". As described in Section 5, despite the identifier "/.well-known/openid-configuration", appearing to be OpenID specific, its usage in this specification is actually referring to a general OAuth 2.0 feature that is not specific to OpenID Connect.

I also felt that because go-oidc's Provider.Endpoint() populates an oauth2.Endpoint, that it should ideally populate all of the fields in the oauth2.Endpoint. If go-oidc had instead defined/populated its own Endpoint type, I wouldn't have felt that way, as it would have been something independent of the oauth2 struct / OIDC spec-defined only.

Hope that helps.

@somersf
Copy link

somersf commented Oct 24, 2023

An to be clear, you can retrieve any additional discovery fields through https://pkg.go.dev/github.com/coreos/go-oidc/v3/oidc#Provider.Claims

So users can already access device_authorization_endpoint if a provider returns it today

Yes, thanks, I was aware that it could be extracted this way. I've tried to provide some references / perspective as to why I felt it should be filled out by Endpoint() (now that it is part of oauth2.Endpoint) in my reply to your first comment #365 (comment)

@cbodonnell
Copy link
Contributor Author

Thanks @somersf - I see both sides here since it's technically not part of the OIDC spec, but I also see how it fits in given the change to oauth2.Endpoint. I'll rebase this PR and address your comments in #365 (review) this week and we can go from there.

@cbodonnell cbodonnell requested a review from somersf October 29, 2023 19:01
@cbodonnell
Copy link
Contributor Author

@somersf the PR has been updated.

@ericchiang Let us know if this is something reasonable for this project based on the thoughts above. If not, I'd suggest we add a small snippet to the linked issue with the recommended way to retrieve this information for reference.

Copy link

@somersf somersf left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the updates - LGTM. It's over to the project maintainers for their say though!

Copy link
Collaborator

@ericchiang ericchiang left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lgtm, can you please squash and resolve conflicts? Also do we need to update our go.mod to support newer versions of oauth2 with the added endpoint field?

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
@cbodonnell
Copy link
Contributor Author

lgtm, can you please squash and resolve conflicts? Also do we need to update our go.mod to support newer versions of oauth2 with the added endpoint field?

@ericchiang done! the go.mod is already on the latest version v0.13.0 of golang.org/x/oauth2 as of 3ebd0c9, so we are good there.

@cbodonnell
Copy link
Contributor Author

@ericchiang anything else we need to do for this one based on my last comment?

Copy link
Collaborator

@ericchiang ericchiang left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry for the delay here! lgtm

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

3 participants