- Notifications
You must be signed in to change notification settings - Fork1k
feat: add OAuth2 protected resource metadata endpoint for RFC 9728#18643
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 ourterms of service andprivacy statement. We’ll occasionally send you account related emails.
Already on GitHub?Sign in to your account
Merged
ThomasK33 merged 1 commit intomainfromthomask33/06-27-feat_oauth2_implement_rfc_9728_protected_resource_metadata_endpointJul 2, 2025
Merged
feat: add OAuth2 protected resource metadata endpoint for RFC 9728#18643
ThomasK33 merged 1 commit intomainfromthomask33/06-27-feat_oauth2_implement_rfc_9728_protected_resource_metadata_endpointJul 2, 2025
Uh oh!
There was an error while loading.Please reload this page.
Conversation
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.Learn more about bidirectional Unicode characters
MemberAuthor
ThomasK33 commentedJun 27, 2025 • edited
Loading Uh oh!
There was an error while loading.Please reload this page.
edited
Uh oh!
There was an error while loading.Please reload this page.
This was referencedJun 27, 2025
5be6c6a
tofded148
Compare1e2bc51
to3de973b
Compare3de973b
to9f159b0
Compare9b7f5d9
to7ef25b1
Compare47d9a0a
tobffc160
Compare7ef25b1
tof0608bc
Comparebffc160
toe733c7b
Comparec68a923
tof55771a
Comparee733c7b
to70e8be9
Comparef55771a
to34af681
Compare70e8be9
to476c079
Compare34af681
toe72476e
Compare476c079
tod2eb876
CompareEmyrk approved these changesJul 1, 2025
Uh oh!
There was an error while loading.Please reload this page.
1858134
toa239eaa
Compare2621adf
to661c0e6
Comparea239eaa
to4ca3595
Compare661c0e6
to5be06e7
Compare4ca3595
to23374cd
Compare5be06e7
to3275584
Compare43fcceb
todb5e215
Compare3275584
to9bd7ff5
Comparedb5e215
to953036f
Compare9bd7ff5
to1d7dbb1
Compare1d7dbb1
to7cab8d5
Compare953036f
to22c2dc6
Comparea1cb748
to1809030
Compare22c2dc6
to14e6e22
Compare1809030
to910d2c8
Compare14e6e22
to5791cb0
Compare5791cb0
to7e0ce8a
Compare- Add OAuth2ProtectedResourceMetadata struct in codersdk/oauth2.go- Implement /.well-known/oauth-protected-resource endpoint handler- Register route in coderd.go for Protected Resource Metadata discovery- Add comprehensive test coverage in oauth2_metadata_test.go- Update OpenAPI documentation and generated API types- Correctly omit bearer_methods_supported field (Coder uses custom auth)- Support MCP OAuth2 compliance requirement for resource server metadataThis implements RFC 9728 OAuth 2.0 Protected Resource Metadata to enableMCP clients to discover resource server capabilities and authorization servers.Change-Id: I089232ae755acf13eb0a7be46944c9eeaaafb75bSigned-off-by: Thomas Kosiewski <tk@coder.com>
7e0ce8a
to59b7a9d
Compare33bbf18
intomain 35 checks passed
Uh oh!
There was an error while loading.Please reload this page.
Merge activity
|
Sign up for freeto subscribe to this conversation on GitHub. Already have an account?Sign in.
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Add OAuth2 Protected Resource Metadata Endpoint
This PR implements the OAuth2 Protected Resource Metadata endpoint according to RFC 9728. The endpoint is available at
/.well-known/oauth-protected-resource
and provides information about Coder as an OAuth2 protected resource.Key changes:
/.well-known/oauth-protected-resource
that returns metadata about Coder as an OAuth2 protected resourceOAuth2ProtectedResourceMetadata
struct in the SDKThe implementation currently returns basic metadata including the resource identifier and authorization server URL. The
scopes_supported
field is empty until a scope system based on RBAC permissions is implemented. Thebearer_methods_supported
field is omitted as Coder uses custom authentication methods rather than standard RFC 6750 bearer tokens.A TODO has been added to implement RFC 6750 bearer token support in the future.