An OpenCode plugin that enables Claude Pro/Max subscription access via the official @anthropic-ai/sdk, using OAuth credentials from Claude Code (~/.claude/.credentials.json).
- Use your Claude subscription — Automatically reads OAuth credentials from Claude Code, no separate API key needed
- Matches Claude Code 2.1.154 — Same request format and behavior as the official CLI
- Prompt caching — Multi-turn conversations cache properly, keeping costs and latency low
- All Claude models — Opus 4.8, Opus 4.7, Opus 4.6, Sonnet 4.6, Haiku 4.5
- Extended / adaptive thinking — Full reasoning support across models, including Opus 4.7+'s adaptive thinking
- Usage tracking — Sidebar widget with live progress bars +
/usagecommand - Self-registering — Models are registered automatically, no manual provider config needed
Add the plugin to your opencode.json (project-level or ~/.config/opencode/opencode.json globally):
{
"$schema": "https://opencode.ai/config.json",
"plugin": ["@xtruder/opencode-claude-max-plugin"]
}That's it. The plugin self-registers the anthropic-sdk provider and its models (Haiku 4.5, Sonnet 4.6, Opus 4.6, Opus 4.7, Opus 4.8) at startup via the OpenCode config hook. No separate provider block is needed.
Then open OpenCode and models will automatically be available under anthropic-sdk provider.
The plugin includes a TUI component that shows subscription usage in the sidebar and registers a /usage slash command. To enable it, add the plugin to your tui.json as well:
Project-level (.opencode/tui.json):
{
"plugin": ["@xtruder/opencode-claude-max-plugin"]
}Or globally (~/.config/opencode/tui.json):
{
"plugin": ["@xtruder/opencode-claude-max-plugin"]
}The TUI plugin provides:
- Sidebar widget — Compact progress bars for 5-hour session and 7-day weekly usage
/usagecommand — Opens a dialog with full usage breakdown (per-model, extra usage)- Auto-refresh — Polls the usage API every 60s and after each inference call
Options can be set in the tui.json plugin entry:
{
"plugin": [
[
"@xtruder/opencode-claude-max-plugin",
{
"enabled": true,
"sidebar": true,
"poll_interval": 60
}
]
]
}| Option | Type | Default | Description |
|---|---|---|---|
enabled |
boolean | true |
Enable/disable the TUI plugin entirely |
sidebar |
boolean | true |
Show/hide sidebar usage widget |
poll_interval |
number | 60 |
Seconds between usage API polls (min: 10) |
If you want to override model settings (e.g. thinking budgets, variants), you can add a provider block alongside the plugin:
{
"$schema": "https://opencode.ai/config.json",
"plugin": ["@xtruder/opencode-claude-max-plugin"],
"provider": {
"anthropic-sdk": {
"models": {
"claude-sonnet-4-6": {
"options": {
"thinking": { "type": "enabled", "budgetTokens": 1024 }
},
"variants": {
"high": { "thinking": { "type": "enabled", "budgetTokens": 10000 } },
"max": { "thinking": { "type": "enabled", "budgetTokens": 32000 } }
}
}
}
}
}
}Config-level settings are merged with plugin defaults — you only need to specify what you want to override.
Credentials are resolved in order:
ANTHROPIC_API_KEYenv var orapiKeyprovider option- Claude Code credentials — auto-read from
~/.claude/.credentials.json
For Claude Code credentials, log in via claude CLI first (claude auth login).
- Streaming and non-streaming completions
- Tool/function calling with Claude Code tool name mapping (
task→Agent,webfetch→WebFetch, etc.) - MCP tool name remapping (
server_tool→mcp__server__tool) - Extended thinking (Sonnet/Opus 4.6) and adaptive thinking (Opus 4.7+) with effort levels and multi-turn signature passthrough
- Prompt caching that holds across long, tool-heavy conversations
- Subscription rate limit detection — fails fast with a clear message instead of hanging
- Long-context auto-detection for large prompts
- TUI sidebar with live usage bars +
/usageslash command
The plugin also works as a standalone Vercel AI SDK provider:
import { CLAUDE_CODE_SYSTEM_PROMPT, createAnthropicSDK } from "@xtruder/opencode-claude-max-plugin"
import { streamText } from "ai"
// Uses ~/.claude/.credentials.json automatically
const provider = createAnthropicSDK()
const model = provider.languageModel("claude-sonnet-4-6")
const result = streamText({
model,
system: CLAUDE_CODE_SYSTEM_PROMPT,
prompt: "Hello!",
})
for await (const chunk of result.textStream) {
process.stdout.write(chunk)
}When using Claude Code OAuth credentials outside OpenCode, you must pass a Claude-compatible system prompt yourself. Exported CLAUDE_CODE_SYSTEM_PROMPT is the prompt used by the OpenCode plugin hook.
bun install
bun run build
bun test src/*.test.ts # unit + integration tests (model tests require ANTHROPIC_API_KEY or Claude Code credentials)See RESEARCH.md for detailed reverse-engineering findings on how we matched Claude Code's request format.
MIT
