content/providers/03-community-providers/31-opencode-sdk.mdx
The ai-sdk-provider-opencode-sdk community provider enables using multiple AI providers (Anthropic, OpenAI, Google) through the OpenCode SDK. OpenCode is a terminal-based AI coding assistant that provides a unified interface to various AI models.
| Provider Version | AI SDK Version | NPM Tag | Status |
|---|---|---|---|
| 1.x | v6 | latest | Stable |
| 0.x | v5 | ai-sdk-v5 | Maintenance |
# AI SDK v6 (default)
npm install ai-sdk-provider-opencode-sdk ai
# AI SDK v5
npm install ai-sdk-provider-opencode-sdk@ai-sdk-v5 ai@^5.0.0
<Tabs items={['pnpm', 'npm', 'yarn', 'bun']}> <Tab> <Snippet text="pnpm add ai-sdk-provider-opencode-sdk" dark /> </Tab> <Tab> <Snippet text="npm install ai-sdk-provider-opencode-sdk" dark /> </Tab> <Tab> <Snippet text="yarn add ai-sdk-provider-opencode-sdk" dark /> </Tab> <Tab> <Snippet text="bun add ai-sdk-provider-opencode-sdk" dark /> </Tab> </Tabs>
You can import the default provider instance opencode from ai-sdk-provider-opencode-sdk:
import { opencode } from 'ai-sdk-provider-opencode-sdk';
If you need a customized setup, you can import createOpencode and create a provider instance with your settings:
import { createOpencode } from 'ai-sdk-provider-opencode-sdk';
const opencode = createOpencode({
autoStartServer: true,
serverTimeout: 10000,
defaultSettings: {
agent: 'build',
},
});
Provider settings:
127.0.0.1).4096).true).10000).Models are specified using the providerID/modelID format:
const model = opencode('anthropic/claude-sonnet-4-5-20250929');
Model Shortcuts (exported as OpencodeModels):
import { OpencodeModels } from 'ai-sdk-provider-opencode-sdk';
// Anthropic Claude
opencode(OpencodeModels['claude-opus-4-5']); // anthropic/claude-opus-4-5-20251101
opencode(OpencodeModels['claude-sonnet-4-5']); // anthropic/claude-sonnet-4-5-20250929
opencode(OpencodeModels['claude-haiku-4-5']); // anthropic/claude-haiku-4-5-20251001
// OpenAI GPT
opencode(OpencodeModels['gpt-4o']); // openai/gpt-4o
opencode(OpencodeModels['gpt-4o-mini']); // openai/gpt-4o-mini
// Google Gemini
opencode(OpencodeModels['gemini-3.1-pro-preview']); // google/gemini-3.1-pro-preview
opencode(OpencodeModels['gemini-2.5-pro']); // google/gemini-2.5-pro
opencode(OpencodeModels['gemini-2.5-flash']); // google/gemini-2.5-flash
opencode(OpencodeModels['gemini-2.0-flash']); // google/gemini-2.0-flash
You can also use full model identifiers:
opencode('openai/gpt-5.1-codex');
opencode('openai/gpt-5.1-codex-max');
opencode('google/gemini-3.1-pro-preview');
import { opencode } from 'ai-sdk-provider-opencode-sdk';
import { generateText } from 'ai';
const { text } = await generateText({
model: opencode('anthropic/claude-sonnet-4-5-20250929'),
prompt: 'Write a vegetarian lasagna recipe for 4 people.',
});
const model = opencode('anthropic/claude-opus-4-5-20251101', {
agent: 'build', // 'build' | 'plan' | 'general' | 'explore'
sessionTitle: 'My Task',
systemPrompt: 'You are a helpful assistant.',
});
| Provider | Image Input | Object Generation | Tool Usage | Tool Streaming |
|---|---|---|---|---|
| Anthropic | <Check size={18} /> | <Check size={18} /> | <Cross size={18} /> | <Cross size={18} /> |
| OpenAI | <Check size={18} /> | <Check size={18} /> | <Cross size={18} /> | <Cross size={18} /> |
| <Check size={18} /> | <Check size={18} /> | <Cross size={18} /> | <Cross size={18} /> |
OpenCode runs as a managed server. Make sure to dispose of the provider when done:
import { opencode } from 'ai-sdk-provider-opencode-sdk';
// After you're done
await opencode.dispose();
// Or if you need direct access to the client manager:
// await opencode.getClientManager().dispose();
The client manager automatically cleans up on process exit (SIGINT, SIGTERM).
npm install -g opencode)For more details, see the provider documentation.