Skip to content
✨ agentgateway has joined the Agentic AI Foundation (AAIF) — Learn more

For the complete documentation index, see llms.txt. Markdown versions of all docs pages are available by appending .md to any docs URL.

Page as Markdown

OAuth2 Proxy

Add user authentication with GitHub, Google, Azure AD, and other OAuth providers by integrating agentgateway with OAuth2 Proxy.

Agentgateway can integrate with OAuth2 Proxy to add user authentication through GitHub, Google, Azure AD, and other OAuth providers. Agentgateway uses an external authorization (extAuthz) policy to delegate authentication checks to OAuth2 Proxy, which redirects unauthenticated users to the provider’s login page.

This guide uses GitHub as the example provider. For other providers, see Use other OAuth providers.

Before you begin

Step 1: Create a GitHub OAuth application

  1. Go to GitHub Developer Settings.
  2. Click OAuth Apps > New OAuth App.
  3. Fill in the application details.
    • Application name: agentgateway dev, or any name you choose.
    • Homepage URL: http://localhost:3000
    • Authorization callback URL: http://localhost:4180/oauth2/callback
  4. Click Register application.
  5. Copy the Client ID.
  6. Click Generate a new client secret and copy the Client Secret.

Step 2: Set up your environment

Create a working directory and set your GitHub OAuth credentials.

mkdir oauth2-proxy-test && cd oauth2-proxy-test

export OAUTH2_PROXY_CLIENT_ID=your-github-client-id
export OAUTH2_PROXY_CLIENT_SECRET=your-github-client-secret

# Generate a random cookie secret
export OAUTH2_PROXY_COOKIE_SECRET=$(python3 -c 'import os,base64; print(base64.b64encode(os.urandom(32)).decode()[:32])')

Step 3: Start OAuth2 Proxy

  1. Run OAuth2 Proxy in Docker.

    docker run -d --name oauth2-proxy \
      -p 4180:4180 \
      --add-host=host.docker.internal:host-gateway \
      -e OAUTH2_PROXY_CLIENT_ID=$OAUTH2_PROXY_CLIENT_ID \
      -e OAUTH2_PROXY_CLIENT_SECRET=$OAUTH2_PROXY_CLIENT_SECRET \
      -e OAUTH2_PROXY_COOKIE_SECRET=$OAUTH2_PROXY_COOKIE_SECRET \
      -e OAUTH2_PROXY_COOKIE_SECURE=false \
      quay.io/oauth2-proxy/oauth2-proxy:latest \
      --provider=github \
      --email-domain=* \
      --upstream=file:///dev/null \
      --http-address=0.0.0.0:4180 \
      --set-xauthrequest \
      --reverse-proxy=true
  2. Verify that OAuth2 Proxy is running.

    docker logs oauth2-proxy

Step 4: Create the agentgateway configuration

Create a config.yaml file. The configuration routes /oauth2/* requests to OAuth2 Proxy for login and callback handling, and protects the MCP application with an extAuthz policy that checks authentication and extracts the user’s identity.

# yaml-language-server: $schema=https://agentgateway.dev/schema/config
frontendPolicies:
  accessLog:
    add:
      # Log the authenticated user's GitHub username and email
      github.user: 'extauthz.githubUser'
      github.email: 'extauthz.githubEmail'

binds:
- port: 3000
  listeners:
  - name: default
    protocol: HTTP
    routes:
    # Route OAuth2 Proxy endpoints (login, callback, and so on)
    - name: oauth2-proxy
      matches:
      - path:
          pathPrefix: /oauth2
      policies:
        urlRewrite:
          authority: none
      backends:
      - host: localhost:4180

    # Protected MCP application
    - name: application
      backends:
      - mcp:
          targets:
          - name: everything
            stdio:
              cmd: npx
              args: ["@modelcontextprotocol/server-everything"]
      policies:
        cors:
          allowOrigins: ["*"]
          allowHeaders: ["*"]
          exposeHeaders: ["Mcp-Session-Id"]
        extAuthz:
          host: localhost:4180
          includeRequestHeaders:
          - cookie
          protocol:
            http:
              # Check authentication status
              path: '"/oauth2/auth"'
              # Redirect unauthenticated users to login
              redirect: '"/oauth2/start?rd=" + request.path'
              # Extract user info from OAuth2 Proxy response headers
              metadata:
                githubUser: response.headers["x-auth-request-user"]
                githubEmail: response.headers["x-auth-request-email"]
              addRequestHeaders:
                x-forwarded-host: request.host
              includeResponseHeaders:
              - x-auth-request-user

The following table describes the key settings in the configuration.

SettingDescription
frontendPolicies.accessLog.addLogs the GitHub username and email from authenticated requests.
routes (oauth2-proxy)Routes /oauth2/* requests to OAuth2 Proxy for login and callback handling.
routes (application)The protected MCP endpoint with external authorization.
extAuthz.hostThe OAuth2 Proxy address for authentication checks.
extAuthz.protocol.http.pathThe endpoint that OAuth2 Proxy uses to validate authentication.
extAuthz.protocol.http.redirectWhere to send unauthenticated users.
extAuthz.protocol.http.metadataExtracts user information from the OAuth2 Proxy response headers.

Step 5: Start agentgateway

agentgateway -f config.yaml

Step 6: Test the authentication flow

  1. Send an unauthenticated request. Because the request has no session cookie, agentgateway redirects it to the login flow.

    curl -i http://localhost:3000/mcp

    Example output:

    HTTP/1.1 302 Found
    location: /oauth2/start?rd=/mcp
  2. Test the flow in a browser.

    1. Open http://localhost:3000/mcp.
    2. You are redirected to GitHub for authentication.
    3. After you log in, you are redirected back to the MCP endpoint.
    4. The agentgateway logs show your GitHub username and email in the github.user and github.email access log fields.

Use other OAuth providers

OAuth2 Proxy supports many providers. To use a different provider, update the Docker command from Step 3.

docker run -d --name oauth2-proxy \
  -p 4180:4180 \
  --add-host=host.docker.internal:host-gateway \
  -e OAUTH2_PROXY_CLIENT_ID=$GOOGLE_CLIENT_ID \
  -e OAUTH2_PROXY_CLIENT_SECRET=$GOOGLE_CLIENT_SECRET \
  -e OAUTH2_PROXY_COOKIE_SECRET=$OAUTH2_PROXY_COOKIE_SECRET \
  -e OAUTH2_PROXY_COOKIE_SECURE=false \
  quay.io/oauth2-proxy/oauth2-proxy:latest \
  --provider=google \
  --email-domain=* \
  --upstream=file:///dev/null \
  --http-address=0.0.0.0:4180 \
  --set-xauthrequest \
  --reverse-proxy=true

Production considerations

For production deployments, consider the following.

  • Set OAUTH2_PROXY_COOKIE_SECURE=true and use HTTPS.
  • Restrict email-domain to your organization’s domain.
  • Use a persistent cookie secret instead of a randomly generated one.
  • See the OAuth2 Proxy documentation for additional security options.

Cleanup

Stop and remove the OAuth2 Proxy container, then remove the working directory.

docker stop oauth2-proxy && docker rm oauth2-proxy
cd .. && rm -rf oauth2-proxy-test

Learn more

Was this page helpful?
Agentgateway assistant

Ask me anything about agentgateway configuration, features, or usage.

Note: AI-generated content might contain errors; please verify and test all returned information.

Tip: one topic per conversation gives the best results. Use the + button in the chat header to start a new conversation.

Switching topics? Starting a new conversation improves accuracy.
↑↓ navigate select esc dismiss

What could be improved?

Your feedback helps us improve assistant answers and identify docs gaps we should fix.

Need more help? Join us on Discord: https://discord.gg/y9efgEmppm

Want to use your own agent? Add the Solo MCP server to query our docs directly. Get started here: https://search.solo.io/.