4.8 KiB
summary, read_when
| summary | read_when | ||||
|---|---|---|---|---|---|
| OAuth in Clawdbot: token exchange, storage, CLI sync, and multi-account patterns |
|
OAuth
Clawdbot supports “subscription auth” via OAuth for providers that offer it (notably Anthropic (Claude Pro/Max) and OpenAI Codex (ChatGPT OAuth)). This page explains:
- how the OAuth token exchange works (PKCE)
- where tokens are stored (and why)
- how we reuse external CLI tokens (Claude Code / Codex CLI)
- how to handle multiple accounts (profiles + per-session overrides)
The token sink (why it exists)
OAuth providers commonly mint a new refresh token during login/refresh flows. Some providers (or OAuth clients) can invalidate older refresh tokens when a new one is issued for the same user/app.
Practical symptom:
- you log in via Clawdbot and via Claude Code / Codex CLI → one of them randomly gets “logged out” later
To reduce that, Clawdbot treats auth-profiles.json as a token sink:
- the runtime reads credentials from one place
- we can sync in credentials from external CLIs instead of doing a second login
- we can keep multiple profiles and route them deterministically
Storage (where tokens live)
Secrets are stored per-agent:
- Auth profiles (OAuth + API keys):
~/.clawdbot/agents/<agentId>/agent/auth-profiles.json - Runtime cache (managed automatically; don’t edit):
~/.clawdbot/agents/<agentId>/agent/auth.json
Legacy import-only file (still supported, but not the main store):
~/.clawdbot/credentials/oauth.json(imported intoauth-profiles.jsonon first use)
All of the above also respect $CLAWDBOT_STATE_DIR (state dir override). Full reference: /gateway/configuration
Reusing Claude Code / Codex CLI OAuth tokens (recommended)
If you already signed in with the external CLIs on the gateway host, Clawdbot can reuse those tokens without starting a separate OAuth flow:
- Claude Code: reads
~/.claude/.credentials.json→ profileanthropic:claude-cli - Codex CLI: reads
~/.codex/auth.json→ profileopenai-codex:codex-cli
Sync happens when Clawdbot loads the auth store (so it stays up-to-date when the CLIs refresh tokens).
How to verify:
clawdbot providers list
Or JSON:
clawdbot providers list --json
OAuth exchange (how login works)
Clawdbot’s interactive login flows are implemented in @mariozechner/pi-ai and wired into the wizards/commands.
Anthropic (Claude Pro/Max)
Flow shape (PKCE):
- generate PKCE verifier/challenge
- open
https://claude.ai/oauth/authorize?... - user pastes
code#state - exchange at
https://console.anthropic.com/v1/oauth/token - store
{ access, refresh, expires }under an auth profile
The wizard path is clawdbot onboard → auth choice oauth (Anthropic).
OpenAI Codex (ChatGPT OAuth)
Flow shape (PKCE):
- generate PKCE verifier/challenge + random
state - open
https://auth.openai.com/oauth/authorize?... - try to capture callback on
http://127.0.0.1:1455/auth/callback - if callback can’t bind (or you’re remote/headless), paste the redirect URL/code
- exchange at
https://auth.openai.com/oauth/token - extract
accountIdfrom the access token and store{ access, refresh, expires, accountId }
Wizard path is clawdbot onboard → auth choice openai-codex (or codex-cli to reuse an existing Codex CLI login).
Refresh + expiry
Profiles store an expires timestamp.
At runtime:
- if
expiresis in the future → use the stored access token - if expired → refresh (under a file lock) and overwrite the stored credentials
The refresh flow is automatic; you generally don’t need to manage tokens manually.
Multiple accounts (profiles) + routing
Two patterns:
1) Preferred: separate agents
If you want “personal” and “work” to never interact, use isolated agents (separate sessions + credentials + workspace):
clawdbot agents add work
clawdbot agents add personal
Then configure auth per-agent (wizard) and route chats to the right agent.
2) Advanced: multiple profiles in one agent
auth-profiles.json supports multiple profile IDs for the same provider.
Pick which profile is used:
- globally via config ordering (
auth.order) - per-session via
/model ...@<profileId>
Example (session override):
/model Opus@anthropic:work
How to see what profile IDs exist:
clawdbot providers list --json(showsauth[])
Related docs:
- /concepts/model-failover (rotation + cooldown rules)
- /tools/slash-commands (command surface)