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-02-26 03:20:08 +03:00
2026-03-23 07:43:12 -07:00
2026-04-03 17:50:01 -07:00
2026-04-01 04:18:50 -07:00
2026-04-01 04:34:04 -07:00
2026-03-30 20:36:56 -07:00
2026-03-19 10:17:03 -07:00
2026-03-14 11:28:26 -07:00
2026-03-17 02:02:57 -07:00
2026-03-28 17:25:04 -07:00
2026-03-23 22:45:55 -07:00
2026-04-01 12:03:56 -07:00
2026-03-31 10:40:13 -07:00
2026-03-13 22:14:00 -07:00
2026-02-27 03:29:26 -05:00
2026-03-13 21:32:53 -07:00
2026-04-04 10:18:57 -07:00
2026-03-27 13:22:01 -07:00
2026-03-27 04:03:00 -07:00
2026-04-03 21:14:42 -07:00
2026-02-26 13:55:54 +03:00
2026-03-17 01:40:02 -07:00
2026-03-30 02:45:41 -07:00
2026-03-02 04:34:21 -08:00
2026-03-26 14:50:26 -07:00
2026-04-05 12:05:13 -07:00
2026-04-03 23:30:12 -07: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-03-31 12:53:19 -07:00
2026-04-01 00:50:08 -07:00
2026-04-04 10:18:57 -07:00
2026-03-23 07:43:12 -07:00
2026-03-17 02:22:12 -07:00
2026-03-14 11:27:02 -07:00
2026-02-26 03:20:08 +03:00
2026-03-04 18:34:16 +03:00
2026-03-01 11:53:50 +03:00
2026-03-13 02:51:51 -07:00
2026-03-27 15:28:19 -07:00
2026-03-23 22:45:55 -07:00
2026-03-28 14:43:41 -07:00
2026-03-31 08:48:54 +09:00
2026-03-30 13:28:10 +09:00
2026-04-02 08:43:06 -07:00
2026-03-30 13:28:10 +09:00
2026-03-29 15:52:54 -07:00
2026-04-05 22:08:00 -07:00
2026-04-04 10:18:57 -07:00
2026-04-03 02:29:20 -07:00
2026-04-04 10:18:57 -07:00
2026-04-02 20:54:27 -07:00
2026-04-03 13:10:11 -07:00
2026-03-14 07:53:56 -07:00
2026-03-28 11:21:44 -07:00
2026-03-31 09:29:59 +09:00
2026-04-05 12:46:07 -07:00
2026-03-17 02:34:35 -07:00
2026-03-26 19:38:04 -07:00
2026-03-17 03:52:15 -07:00
2026-03-20 14:54:25 -07:00
2026-03-27 07:49:44 -07:00
2026-03-10 17:09:51 -07:00
2026-03-17 02:02:57 -07:00
2026-03-29 15:17:46 -07:00
2026-04-05 11:59:28 -07:00
2026-03-26 14:35:31 -07:00
2026-03-16 19:01:39 +03:00
2026-03-28 17:52:32 -07:00
2026-04-01 04:19:19 -07:00
2026-04-01 04:19:19 -07:00
2026-04-01 04:19:19 -07:00
2026-03-04 05:30:43 -08:00
2026-03-02 02:00:09 -08:00
2026-03-26 13:40:21 -07:00
2026-03-14 23:15:04 -07:00
2026-03-30 08:37:19 -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-04 17:23:23 +03:00
2026-03-21 17:10:17 -07:00
2026-04-04 16:57:24 -07:00
2026-03-31 08:48:54 +09:00
2026-03-29 21:51:44 -07:00
2026-03-30 13:28:10 +09:00
2026-03-16 23:39:41 -07:00
2026-03-08 23:07:38 +03:00
2026-03-31 08:48:54 +09:00
2026-03-31 03:10:01 -07:00
2026-03-23 15:40:42 -07:00
2026-03-29 20:55:04 -07:00
2026-03-14 14:27:21 +03:00
2026-03-31 12:13:33 -07:00
2026-03-31 08:48:54 +09:00
2026-03-17 04:28:03 -07:00
2026-03-30 08:10:14 -07:00
2026-03-01 01:54:27 +03:00
2026-02-26 13:30:55 +03:00
2026-03-17 02:22:12 -07:00