Config
Usa la config JSON di OpenCode.
Puoi configurare OpenCode usando un file di configurazione JSON.
Formato
OpenCode supporta sia JSON sia JSONC (JSON con commenti).
{ "$schema": "https://opencode.ai/config.json", // Theme configuration "theme": "opencode", "model": "anthropic/claude-sonnet-4-5", "autoupdate": true,}Posizioni
Puoi mettere la configurazione in diverse posizioni e ognuna ha un ordine di precedenza diverso.
I file di configurazione vengono uniti (merge), non sostituiti. Le impostazioni provenienti dalle posizioni qui sotto vengono combinate. Le configurazioni caricate dopo sovrascrivono quelle precedenti solo per le chiavi in conflitto. Le impostazioni non in conflitto vengono preservate.
Per esempio, se la tua configurazione globale imposta theme: "opencode" e autoupdate: true, e la configurazione del progetto imposta model: "anthropic/claude-sonnet-4-5", la configurazione finale includera tutte e tre le impostazioni.
Ordine di precedenza
Le sorgenti di configurazione vengono caricate in questo ordine (le successive sovrascrivono le precedenti):
- Config remota (da
.well-known/opencode) - default dell’organizzazione - Config globale (
~/.config/opencode/opencode.json) - preferenze utente - Config personalizzata (variabile d’ambiente
OPENCODE_CONFIG) - sovrascritture personalizzate - Config di progetto (
opencode.jsonnel progetto) - impostazioni specifiche del progetto - Directory
.opencode- agenti, comandi, plugin - Config inline (variabile d’ambiente
OPENCODE_CONFIG_CONTENT) - sovrascritture a runtime
Questo significa che la configurazione di progetto puo sovrascrivere i default globali, e la configurazione globale puo sovrascrivere i default remoti dell’organizzazione.
Remota
Le organizzazioni possono fornire una configurazione predefinita tramite l’endpoint .well-known/opencode. Viene recuperata automaticamente quando ti autentichi con un provider che lo supporta.
La configurazione remota viene caricata per prima e fa da livello base. Tutte le altre sorgenti (globale, progetto) possono sovrascrivere questi default.
Per esempio, se la tua organizzazione fornisce server MCP disabilitati per impostazione predefinita:
{ "mcp": { "jira": { "type": "remote", "url": "https://jira.example.com/mcp", "enabled": false } }}Puoi abilitare server specifici nella tua configurazione locale:
{ "mcp": { "jira": { "type": "remote", "url": "https://jira.example.com/mcp", "enabled": true } }}Globale
Metti la configurazione globale di OpenCode in ~/.config/opencode/opencode.json. Usa la configurazione globale per preferenze valide per l’utente (ad es. temi, provider o keybind).
La configurazione globale sovrascrive i default remoti dell’organizzazione.
Per progetto
Aggiungi opencode.json nella root del progetto. La configurazione di progetto ha la precedenza piu alta tra i file standard: sovrascrive sia la configurazione globale sia quella remota.
Quando OpenCode si avvia, cerca un file di configurazione nella directory corrente oppure risale fino alla directory Git piu vicina.
Questo file puo essere tranquillamente versionato in Git e usa lo stesso schema di quello globale.
Percorso personalizzato
Specifica un percorso personalizzato per il file di configurazione usando la variabile d’ambiente OPENCODE_CONFIG.
export OPENCODE_CONFIG=/path/to/my/custom-config.jsonopencode run "Hello world"La configurazione personalizzata viene caricata tra quella globale e quella di progetto nell’ordine di precedenza.
Directory personalizzata
Specifica una directory di configurazione personalizzata usando la variabile d’ambiente OPENCODE_CONFIG_DIR. Questa directory verra usata per cercare agenti, comandi, modalita e plugin proprio come la directory standard .opencode e dovrebbe seguire la stessa struttura.
export OPENCODE_CONFIG_DIR=/path/to/my/config-directoryopencode run "Hello world"La directory personalizzata viene caricata dopo la configurazione globale e le directory .opencode, quindi puo sovrascrivere le loro impostazioni.
Schema
Il file di configurazione ha uno schema definito in opencode.ai/config.json.
Il tuo editor dovrebbe poter validare e suggerire l’autocompletamento in base allo schema.
TUI
Puoi configurare impostazioni specifiche della TUI tramite l’opzione tui.
{ "$schema": "https://opencode.ai/config.json", "tui": { "scroll_speed": 3, "scroll_acceleration": { "enabled": true }, "diff_style": "auto" }}Opzioni disponibili:
scroll_acceleration.enabled- Abilita l’accelerazione di scorrimento in stile macOS. Ha precedenza suscroll_speed.scroll_speed- Moltiplicatore personalizzato della velocita di scorrimento (predefinito:3, minimo:1). Ignorato sescroll_acceleration.enabledetrue.diff_style- Controlla la resa delle diff."auto"si adatta alla larghezza del terminale,"stacked"mostra sempre una singola colonna.
Scopri di piu sull’uso della TUI.
Server
Puoi configurare le impostazioni del server per i comandi opencode serve e opencode web tramite l’opzione server.
{ "$schema": "https://opencode.ai/config.json", "server": { "port": 4096, "hostname": "0.0.0.0", "mdns": true, "mdnsDomain": "myproject.local", "cors": ["http://localhost:5173"] }}Opzioni disponibili:
port- Porta su cui ascoltare.hostname- Nome host su cui ascoltare. Quandomdnse abilitato e non e impostato alcun hostname, il default e0.0.0.0.mdns- Abilita la scoperta del servizio mDNS. Questo permette ad altri dispositivi sulla rete di scoprire il tuo server OpenCode.mdnsDomain- Nome di dominio personalizzato per il servizio mDNS. Predefinito:opencode.local. Utile per eseguire piu istanze sulla stessa rete.cors- Origini aggiuntive da consentire per CORS quando usi il server HTTP da un client basato su browser. I valori devono essere origini complete (schema + host + porta opzionale), ad es.https://app.example.com.
Strumenti
Puoi gestire gli strumenti che un LLM puo usare tramite l’opzione tools.
{ "$schema": "https://opencode.ai/config.json", "tools": { "write": false, "bash": false }}Scopri di piu sugli strumenti.
Modelli
Puoi configurare provider e modelli da usare in OpenCode tramite le opzioni provider, model e small_model.
{ "$schema": "https://opencode.ai/config.json", "provider": {}, "model": "anthropic/claude-sonnet-4-5", "small_model": "anthropic/claude-haiku-4-5"}L’opzione small_model configura un modello separato per task leggeri come la generazione dei titoli. Per impostazione predefinita, OpenCode prova a usare un modello più economico se disponibile dal tuo provider, altrimenti fa fallback sul tuo modello principale.
Le opzioni del provider possono includere timeout e setCacheKey:
{ "$schema": "https://opencode.ai/config.json", "provider": { "anthropic": { "options": { "timeout": 600000, "setCacheKey": true } } }}timeout- Timeout della richiesta in millisecondi (predefinito: 300000). Imposta afalseper disabilitare.setCacheKey- Assicura che venga sempre impostata una cache key per il provider indicato.
Puoi anche configurare i modelli locali. Scopri di piu.
Opzioni specifiche del provider
Alcuni provider supportano opzioni di configurazione aggiuntive oltre alle impostazioni generiche timeout e apiKey.
Amazon Bedrock
Amazon Bedrock supporta una configurazione specifica per AWS:
{ "$schema": "https://opencode.ai/config.json", "provider": { "amazon-bedrock": { "options": { "region": "us-east-1", "profile": "my-aws-profile", "endpoint": "https://bedrock-runtime.us-east-1.vpce-xxxxx.amazonaws.com" } } }}region- Regione AWS per Bedrock (default: variabile d’ambienteAWS_REGIONoppureus-east-1)profile- Profilo AWS nominato da~/.aws/credentials(default: variabile d’ambienteAWS_PROFILE)endpoint- URL endpoint personalizzato per gli endpoint VPC. E un alias dell’opzione genericabaseURLusando la terminologia AWS. Se sono specificati siaendpointsiabaseURL,endpointha precedenza.
Scopri di piu sulla configurazione di Amazon Bedrock.
Temi
Puoi configurare il tema da usare in OpenCode tramite l’opzione theme.
{ "$schema": "https://opencode.ai/config.json", "theme": ""}Agenti
Puoi configurare agenti specializzati per task specifici tramite l’opzione agent.
{ "$schema": "https://opencode.ai/config.json", "agent": { "code-reviewer": { "description": "Reviews code for best practices and potential issues", "model": "anthropic/claude-sonnet-4-5", "prompt": "You are a code reviewer. Focus on security, performance, and maintainability.", "tools": { // Disable file modification tools for review-only agent "write": false, "edit": false, }, }, },}Puoi anche definire agenti usando file markdown in ~/.config/opencode/agents/ o .opencode/agents/. Scopri di piu.
Agente predefinito
Puoi impostare l’agente predefinito usando l’opzione default_agent. Questo determina quale agente viene usato quando non ne specifichi uno esplicitamente.
{ "$schema": "https://opencode.ai/config.json", "default_agent": "plan"}L’agente predefinito deve essere un agente primary (non un subagent). Puo essere un agente integrato come "build" o "plan", oppure un agente personalizzato che hai definito. Se l’agente specificato non esiste o e un subagent, OpenCode fara fallback su "build" mostrando un avviso.
Questa impostazione si applica a tutte le interfacce: TUI, CLI (opencode run), app desktop e GitHub Action.
Condivisione
Puoi configurare la funzione di condivisione tramite l’opzione share.
{ "$schema": "https://opencode.ai/config.json", "share": "manual"}Valori supportati:
"manual"- Consenti la condivisione manuale tramite comandi (predefinito)"auto"- Condividi automaticamente le nuove conversazioni"disabled"- Disabilita completamente la condivisione
Per impostazione predefinita, la condivisione e in modalita manuale e devi condividere esplicitamente le conversazioni usando il comando /share.
Comandi
Puoi configurare comandi personalizzati per task ripetitivi tramite l’opzione command.
{ "$schema": "https://opencode.ai/config.json", "command": { "test": { "template": "Run the full test suite with coverage report and show any failures.\nFocus on the failing tests and suggest fixes.", "description": "Run tests with coverage", "agent": "build", "model": "anthropic/claude-haiku-4-5", }, "component": { "template": "Create a new React component named $ARGUMENTS with TypeScript support.\nInclude proper typing and basic structure.", "description": "Create a new component", }, },}Puoi anche definire comandi usando file markdown in ~/.config/opencode/commands/ o .opencode/commands/. Scopri di piu.
Scorciatoie
Puoi personalizzare i keybind tramite l’opzione keybinds.
{ "$schema": "https://opencode.ai/config.json", "keybinds": {}}Aggiornamenti automatici
OpenCode scarichera automaticamente eventuali aggiornamenti quando si avvia. Puoi disabilitare questa funzione con l’opzione autoupdate.
{ "$schema": "https://opencode.ai/config.json", "autoupdate": false}Se non vuoi aggiornamenti automatici ma vuoi essere avvisato quando e disponibile una nuova versione, imposta autoupdate a "notify".
Nota che questo funziona solo se non e stato installato con un package manager come Homebrew.
Formatter
Puoi configurare i formatter di codice tramite l’opzione formatter.
{ "$schema": "https://opencode.ai/config.json", "formatter": { "prettier": { "disabled": true }, "custom-prettier": { "command": ["npx", "prettier", "--write", "$FILE"], "environment": { "NODE_ENV": "development" }, "extensions": [".js", ".ts", ".jsx", ".tsx"] } }}Permessi
Per impostazione predefinita, opencode consente tutte le operazioni senza richiedere un’approvazione esplicita. Puoi cambiarlo usando l’opzione permission.
Per esempio, per fare in modo che gli strumenti edit e bash richiedano l’approvazione dell’utente:
{ "$schema": "https://opencode.ai/config.json", "permission": { "edit": "ask", "bash": "ask" }}Compattazione
Puoi controllare il comportamento di compattazione del contesto tramite l’opzione compaction.
{ "$schema": "https://opencode.ai/config.json", "compaction": { "auto": true, "prune": true }}auto- Compatta automaticamente la sessione quando il contesto e pieno (predefinito:true).prune- Rimuove output vecchi degli strumenti per risparmiare token (predefinito:true).
Monitoraggio file
Puoi configurare i pattern di ignoramento del file watcher tramite l’opzione watcher.
{ "$schema": "https://opencode.ai/config.json", "watcher": { "ignore": ["node_modules/**", "dist/**", ".git/**"] }}I pattern seguono la sintassi glob. Usali per escludere directory rumorose dal monitoraggio dei file.
Server MCP
Puoi configurare i server MCP che vuoi usare tramite l’opzione mcp.
{ "$schema": "https://opencode.ai/config.json", "mcp": {}}Plugin
I plugin estendono OpenCode con strumenti personalizzati, hook e integrazioni.
Metti i file dei plugin in .opencode/plugins/ o ~/.config/opencode/plugins/. Puoi anche caricare plugin da npm tramite l’opzione plugin.
{ "$schema": "https://opencode.ai/config.json", "plugin": ["opencode-helicone-session", "@my-org/custom-plugin"]}Istruzioni
Puoi configurare le istruzioni per il modello che stai usando tramite l’opzione instructions.
{ "$schema": "https://opencode.ai/config.json", "instructions": ["CONTRIBUTING.md", "docs/guidelines.md", ".cursor/rules/*.md"]}Accetta un array di percorsi e pattern glob verso file di istruzioni. Scopri di piu sulle regole.
Provider disabilitati
Puoi disabilitare i provider caricati automaticamente tramite l’opzione disabled_providers. E utile quando vuoi impedire il caricamento di alcuni provider anche se le credenziali sono disponibili.
{ "$schema": "https://opencode.ai/config.json", "disabled_providers": ["openai", "gemini"]}L’opzione disabled_providers accetta un array di ID provider. Quando un provider e disabilitato:
- Non verra caricato anche se sono impostate variabili d’ambiente.
- Non verra caricato anche se le chiavi API sono configurate tramite il comando
/connect. - I modelli del provider non appariranno nella lista di selezione dei modelli.
Provider abilitati
Puoi specificare un’allowlist di provider tramite l’opzione enabled_providers. Se impostata, solo i provider indicati verranno abilitati e tutti gli altri saranno ignorati.
{ "$schema": "https://opencode.ai/config.json", "enabled_providers": ["anthropic", "openai"]}E utile quando vuoi limitare OpenCode a usare solo alcuni provider invece di disabilitarli uno per uno.
Se un provider appare sia in enabled_providers sia in disabled_providers, disabled_providers ha priorita per retrocompatibilita.
Sperimentale
La chiave experimental contiene opzioni in sviluppo attivo.
{ "$schema": "https://opencode.ai/config.json", "experimental": {}}Variabili
Puoi usare la sostituzione di variabili nei file di configurazione per referenziare variabili d’ambiente e contenuti di file.
Variabili d’ambiente
Usa {env:VARIABLE_NAME} per sostituire variabili d’ambiente:
{ "$schema": "https://opencode.ai/config.json", "model": "{env:OPENCODE_MODEL}", "provider": { "anthropic": { "models": {}, "options": { "apiKey": "{env:ANTHROPIC_API_KEY}" } } }}Se la variabile d’ambiente non e impostata, verra sostituita con una stringa vuota.
File
Usa {file:path/to/file} per sostituire il contenuto di un file:
{ "$schema": "https://opencode.ai/config.json", "instructions": ["./custom-instructions.md"], "provider": { "openai": { "options": { "apiKey": "{file:~/.secrets/openai-key}" } } }}I percorsi dei file possono essere:
- Relativi alla directory del file di configurazione
- Oppure percorsi assoluti che iniziano con
/o~
Sono utili per:
- Tenere dati sensibili (come chiavi API) in file separati.
- Includere file di istruzioni grandi senza appesantire la configurazione.
- Condividere snippet di configurazione comuni tra piu file di configurazione.