Teknium
38d8446011
feat: implement MCP OAuth 2.1 PKCE client support (#5420)
Implement tools/mcp_oauth.py — the OAuth adapter that mcp_tool.py's
existing auth: oauth hook has been waiting for.
Components:
- HermesTokenStorage: persists tokens + client registration to
HERMES_HOME/mcp-tokens/<server>.json with 0o600 permissions
- Callback handler factory: per-flow isolated HTTP handlers (safe for
concurrent OAuth flows across multiple MCP servers)
- OAuthClientProvider integration: wraps the MCP SDK's httpx.Auth
subclass which handles discovery, DCR, PKCE, token exchange,
refresh, and step-up auth (403 insufficient_scope) automatically
- Non-interactive detection: warns when gateway/cron environments
try to OAuth without cached tokens
- Pre-registered client support: injects client_id/secret from config
for servers that don't support Dynamic Client Registration (e.g. Slack)
- Path traversal protection on server names
- remove_oauth_tokens() for cleanup
Config format:
mcp_servers:
sentry:
url: 'https://mcp.sentry.dev/mcp'
auth: oauth
oauth: # all optional
client_id: '...' # skip DCR
client_secret: '...' # confidential client
scope: 'read write' # server-provided by default
Also passes oauth config dict through from mcp_tool.py (was passing
only server_name and url before).
E2E verified: full OAuth flow (401 → discovery → DCR → authorize →
token exchange → authenticated request → tokens persisted) against
local test servers. 23 unit tests + 186 MCP suite tests pass.
2026-04-05 22:08:00 -07:00
..
2026-03-30 20:36:56 -07:00
2026-03-14 11:28:26 -07:00
2026-03-17 02:02:57 -07:00
2026-02-27 03:29:26 -05:00
2026-04-04 10:18:57 -07:00
2026-03-27 13:22:01 -07:00
2026-04-03 21:14:42 -07:00
2026-03-17 01:40:02 -07:00
2026-03-02 04:34:21 -08:00
2026-03-10 20:45:13 -07:00
2026-03-24 08:19:34 -07:00
2026-03-08 16:47:20 -07:00
2026-04-01 00:50:08 -07:00
2026-02-26 03:20:08 +03:00
2026-03-28 14:43:41 -07:00
2026-04-03 02:29:20 -07:00
2026-04-03 13:10:11 -07:00
2026-03-26 19:38:04 -07:00
2026-03-17 03:52:15 -07:00
2026-03-26 14:35:31 -07:00
2026-03-26 13:40:21 -07:00
2026-03-26 01:08:02 +05:30
2026-03-28 17:52:32 -07:00
2026-03-15 21:13:40 -07:00
2026-03-16 23:39:41 -07:00
2026-03-29 20:55:04 -07:00
2026-03-30 08:10:14 -07:00
2026-03-01 01:54:27 +03:00