-
Notifications
You must be signed in to change notification settings - Fork 929
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 our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Open
ThomasK33
wants to merge
1
commit into
thomask33/feat_add_Go_LSP_configuration_and_code_navigation_documentation
Choose a base branch
from
thomask33/06-27-feat_oauth2_implement_rfc_9728_protected_resource_metadata_endpoint
base: thomask33/feat_add_Go_LSP_configuration_and_code_navigation_documentation
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
+233
−2
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
This was referenced Jun 27, 2025
5be6c6a
to
fded148
Compare
1e2bc51
to
3de973b
Compare
3de973b
to
9f159b0
Compare
9b7f5d9
to
7ef25b1
Compare
47d9a0a
to
bffc160
Compare
7ef25b1
to
f0608bc
Compare
bffc160
to
e733c7b
Compare
c68a923
to
f55771a
Compare
e733c7b
to
70e8be9
Compare
f55771a
to
34af681
Compare
70e8be9
to
476c079
Compare
34af681
to
e72476e
Compare
476c079
to
d2eb876
Compare
d2eb876
to
bb57d1e
Compare
e72476e
to
1a99f3c
Compare
johnstcn
reviewed
Jun 30, 2025
bb57d1e
to
8949808
Compare
1a99f3c
to
01a10ef
Compare
johnstcn
approved these changes
Jul 1, 2025
01a10ef
to
3b6d8ba
Compare
8949808
to
373faa2
Compare
3b6d8ba
to
dac326d
Compare
373faa2
to
79a40a3
Compare
79a40a3
to
2621adf
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 metadata This implements RFC 9728 OAuth 2.0 Protected Resource Metadata to enable MCP clients to discover resource server capabilities and authorization servers. Change-Id: I089232ae755acf13eb0a7be46944c9eeaaafb75b Signed-off-by: Thomas Kosiewski <tk@coder.com>
dac326d
to
1858134
Compare
Emyrk
approved these changes
Jul 1, 2025
defer cancel() | ||
|
||
// Use a plain HTTP client since this endpoint doesn't require authentication | ||
req, err := http.NewRequestWithContext(ctx, http.MethodGet, serverURL.String()+"/.well-known/oauth-protected-resource", nil) |
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 prefer using something that handles a trailing slash on serverURL
. Just a nit though, your call 👍
endpoint := serverURL.ResolveReference(&url.URL{Path: "/.well-known/oauth-authorization-server"}).String()
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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.