oauth2
commandThis package is not in the latest version of its module.
Details
Validgo.mod file
The Go module system was introduced in Go 1.11 and is the official dependency management solution for Go.
Redistributable license
Redistributable licenses place minimal restrictions on how software can be used, modified, and redistributed.
Tagged version
Modules with tagged versions give importers more predictable builds.
Stable version
When a project reaches major version v1 it is considered stable.
- Learn more about best practices
Repository
Links
README¶
OAuth2 Test Scripts
This directory contains test scripts for the MCP OAuth2 implementation in Coder.
Prerequisites
Start Coder in development mode:
./scripts/develop.shLogin to get a session token:
./scripts/coder-dev.sh login
Scripts
test-mcp-oauth2.sh
Complete automated test suite that verifies all OAuth2 functionality:
- Metadata endpoint
- PKCE flow
- Resource parameter support
- Token refresh
- Error handling
Usage:
chmod +x ./scripts/oauth2/test-mcp-oauth2.sh./scripts/oauth2/test-mcp-oauth2.shsetup-test-app.sh
Creates a test OAuth2 application and outputs environment variables.
Usage:
eval $(./scripts/oauth2/setup-test-app.sh)echo "Client ID: $CLIENT_ID"cleanup-test-app.sh
Deletes a test OAuth2 application.
Usage:
./scripts/oauth2/cleanup-test-app.sh $CLIENT_ID# Or if CLIENT_ID is set as environment variable:./scripts/oauth2/cleanup-test-app.shgenerate-pkce.sh
Generates PKCE code verifier and challenge for manual testing.
Usage:
./scripts/oauth2/generate-pkce.shtest-manual-flow.sh
Launches a local Go web server to test the OAuth2 flow interactively. The server automatically handles the OAuth2 callback and token exchange, providing a user-friendly web interface with results.
Usage:
# First set up an appeval $(./scripts/oauth2/setup-test-app.sh)# Then run the test server./scripts/oauth2/test-manual-flow.shFeatures:
- Starts a local web server on port 9876
- Automatically captures the authorization code
- Performs token exchange without manual intervention
- Displays results in a clean web interface
- Shows example API calls you can make with the token
oauth2-test-server.go
A Go web server that handles OAuth2 callbacks and token exchange. Used internally bytest-manual-flow.sh but can also be run standalone:
export CLIENT_ID="your-client-id"export CLIENT_SECRET="your-client-secret"export CODE_VERIFIER="your-code-verifier"export STATE="your-state"go run ./scripts/oauth2/oauth2-test-server.goExample Workflow
Run automated tests:
./scripts/oauth2/test-mcp-oauth2.shInteractive browser testing:
# Create appeval $(./scripts/oauth2/setup-test-app.sh)# Run the test server (opens in browser automatically)./scripts/oauth2/test-manual-flow.sh# - Opens authorization URL in terminal# - Handles callback automatically# - Shows token exchange results# Clean up when done./scripts/oauth2/cleanup-test-app.shGenerate PKCE for custom testing:
./scripts/oauth2/generate-pkce.sh# Use the generated values in your own curl commands
Environment Variables
All scripts respect these environment variables:
SESSION_TOKEN: Coder session token (auto-read from.coderv2/session)BASE_URL: Coder server URL (default:http://localhost:3000)CLIENT_ID: OAuth2 client IDCLIENT_SECRET: OAuth2 client secret
OAuth2 Endpoints
- Metadata:
GET /.well-known/oauth-authorization-server - Authorization:
GET/POST /oauth2/authorize - Token:
POST /oauth2/tokens - Apps API:
/api/v2/oauth2-provider/apps
Documentation¶
There is no documentation for this package.