Config
Korištenje OpenCode JSON konfiguracije.
Možete konfigurirati OpenCode koristeći JSON konfiguracijski fajl.
Format
OpenCode podržava i JSON i JSONC (JSON sa komentarima) formate.
{ "$schema": "https://opencode.ai/config.json", // Theme configuration "theme": "opencode", "model": "anthropic/claude-sonnet-4-5", "autoupdate": true,}Lokacije
Možete postaviti svoju konfiguraciju na nekoliko različitih lokacija i one imaju a drugačiji redosled prioriteta.
Konfiguracijski fajlovi se spajaju, ne zamjenjuju. Kombiniraju se postavke sa sljedećih konfiguracijskih lokacija. Kasnije konfiguracije poništavaju prethodne samo za konfliktne ključeve. Nekonfliktne postavke iz svih konfiguracija su sačuvane.
Na primjer, ako vaša globalna konfiguracija postavlja theme: "opencode" i autoupdate: true, a vaša projektna konfiguracija postavlja model: "anthropic/claude-sonnet-4-5", konačna konfiguracija će uključivati sve tri postavke.
Redoslijed prioriteta
Izvori konfiguracije se učitavaju ovim redoslijedom (kasniji izvori poništavaju ranije):
- Udaljena konfiguracija (od
.well-known/opencode) - organizacione postavke - Globalna konfiguracija (
~/.config/opencode/opencode.json) - korisničke postavke - Prilagođena konfiguracija (
OPENCODE_CONFIGenv var) - prilagođena zaobilaženja - Konfiguracija projekta (
opencode.jsonu projektu) - postavke specifične za projekat .opencodedirektoriji - agenti, komande, dodaci- Inline config (
OPENCODE_CONFIG_CONTENTenv var) - runtime nadjačava To znači da konfiguracije projekta mogu nadjačati globalne zadane postavke, a globalne konfiguracije mogu nadjačati postavke udaljene organizacije.
Daljinski
Organizacije mogu pružiti zadanu konfiguraciju preko .well-known/opencode krajnje točke. Ovo se automatski preuzima kada se autentifikujete kod provajdera koji to podržava.
Prvo se učitava udaljena konfiguracija koja služi kao osnovni sloj. Svi ostali izvori konfiguracije (globalni, projektni) mogu nadjačati ove zadane postavke.
Na primjer, ako vaša organizacija nudi MCP servere koji su po defaultu onemogućeni:
{ "mcp": { "jira": { "type": "remote", "url": "https://jira.example.com/mcp", "enabled": false } }}Možete omogućiti određene servere u vašoj lokalnoj konfiguraciji:
{ "mcp": { "jira": { "type": "remote", "url": "https://jira.example.com/mcp", "enabled": true } }}Global
Postavite svoju globalnu OpenCode konfiguraciju u ~/.config/opencode/opencode.json. Koristite globalnu konfiguraciju za korisničke preferencije kao što su teme, provajderi ili veze tipki.
Globalna konfiguracija poništava zadane postavke udaljene organizacije.
Project
Dodajte opencode.json u korijen projekta. Konfiguracija projekta ima najveći prioritet među standardnim konfiguracijskim datotekama - ona nadjačava globalne i udaljene konfiguracije.
Kada se OpenCode pokrene, traži konfiguracijsku datoteku u trenutnom direktoriju ili prelazi do najbližeg Git direktorija. Ovo je također sigurno provjeriti u Git i koristi istu shemu kao globalna.
Custom config
Navedite prilagođenu putanju konfiguracijske datoteke koristeći varijablu okruženja OPENCODE_CONFIG.
export OPENCODE_CONFIG=/path/to/my/custom-config.jsonopencode run "Hello world"Prilagođena konfiguracija se učitava između globalne i projektne konfiguracije po redoslijedu prioriteta.
Custom directory
Navedite prilagođeni konfiguracijski direktorij koristeći OPENCODE_CONFIG_DIR
varijabla okruženja. U ovom direktoriju će se tražiti agenti, komande,
modove i dodatke baš kao standardni .opencode direktorij, i trebali bi
prate istu strukturu.
export OPENCODE_CONFIG_DIR=/path/to/my/config-directoryopencode run "Hello world"Prilagođeni direktorij se učitava nakon direktorija globalne konfiguracije i .opencode, tako da može nadjačati njihove postavke.
Shema
Konfiguracijski fajl ima šemu koja je definirana u opencode.ai/config.json.
Vaš uređivač bi trebao biti u mogućnosti da potvrdi i autodovršava na osnovu šeme.
TUI
Možete konfigurirati postavke specifične za TUI putem opcije tui.
{ "$schema": "https://opencode.ai/config.json", "tui": { "scroll_speed": 3, "scroll_acceleration": { "enabled": true }, "diff_style": "auto" }}Dostupne opcije:
scroll_acceleration.enabled- Omogući ubrzanje skrolovanja u macOS stilu. Ima prednost nadscroll_speed.scroll_speed- Prilagođeni množitelj brzine pomicanja (podrazumevano:3, minimalno:1). Zanemareno ako jescroll_acceleration.enabledtrue.diff_style- Kontrola prikaza razlike."auto"se prilagođava širini terminala,"stacked"uvijek prikazuje jednu kolonu. Ovdje saznajte više o korištenju TUI.
Server
Možete konfigurirati postavke servera za komande opencode serve i opencode web putem opcije server.
{ "$schema": "https://opencode.ai/config.json", "server": { "port": 4096, "hostname": "0.0.0.0", "mdns": true, "mdnsDomain": "myproject.local", "cors": ["http://localhost:5173"] }}Dostupne opcije:
port- Port za slušanje.hostname- Ime hosta za slušanje. Kada jemdnsomogućen i nije postavljeno ime hosta, podrazumevano je0.0.0.0.mdns- Omogući otkrivanje mDNS usluge. Ovo omogućava drugim uređajima na mreži da otkriju vaš OpenCode server.mdnsDomain- Prilagođeno ime domene za mDNS uslugu. Zadano jeopencode.local. Korisno za pokretanje više instanci na istoj mreži.cors- Dodatni izvori koji omogućavaju CORS kada koristite HTTP server iz klijenta baziranog na pretraživaču. Vrijednosti moraju biti punog porijekla (šema + host + opcijski port), npr.https://app.example.com. Saznajte više o serveru ovdje.
Tools
Možete upravljati alatima koje LLM može koristiti putem opcije tools.
{ "$schema": "https://opencode.ai/config.json", "tools": { "write": false, "bash": false }}Saznajte više o alatima ovdje.
Model
Možete konfigurirati dobavljače i modele koje želite koristiti u svojoj OpenCode konfiguraciji kroz opcije provider, model i small_model.
{ "$schema": "https://opencode.ai/config.json", "provider": {}, "model": "anthropic/claude-sonnet-4-5", "small_model": "anthropic/claude-haiku-4-5"}Opcija small_model konfigurira poseban model za lagane zadatke poput generiranja naslova. Podrazumevano, OpenCode pokušava da koristi jeftiniji model ako je dostupan od vašeg provajdera, inače se vraća na vaš glavni model.
Opcije provajdera mogu uključivati timeout i setCacheKey:
{ "$schema": "https://opencode.ai/config.json", "provider": { "anthropic": { "options": { "timeout": 600000, "setCacheKey": true } } }}timeout- Vrijeme čekanja zahtjeva u milisekundama (podrazumevano: 300000). Postavite nafalseda onemogućite.setCacheKey- Osigurajte da je ključ keš memorije uvijek postavljen za određenog provajdera. Također možete konfigurirati lokalni modeli. Saznajte više.
Opcije specifične za provajdere
Neki provajderi podržavaju dodatne opcije konfiguracije osim generičkih postavki timeout i apiKey.
Amazon Bedrock
Amazon Bedrock podržava konfiguraciju specifičnu za 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- AWS regija za Bedrock (zadano naAWS_REGIONenv var ilius-east-1)profile- AWS imenovan profil od~/.aws/credentials(podrazumevano naAWS_PROFILEenv var)endpoint- URL prilagođene krajnje tačke za VPC krajnje tačke. Ovo je pseudonim za generičku opcijubaseURLkoristeći terminologiju specifičnu za AWS. Ako su oba navedena,endpointima prednost. Saznajte više o konfiguraciji Amazon Bedrock.
Theme
Možete konfigurirati temu koju želite koristiti u svojoj OpenCode konfiguraciji putem opcije theme.
{ "$schema": "https://opencode.ai/config.json", "theme": ""}Agenti
Možete konfigurirati specijalizirane agente za određene zadatke putem opcije 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, }, }, },}Također možete definirati agente koristeći markdown datoteke u ~/.config/opencode/agents/ ili .opencode/agents/. Saznajte više ovdje.
Zadani agent
Možete postaviti zadanog agenta koristeći opciju default_agent. Ovo određuje koji se agent koristi kada nijedan nije eksplicitno specificiran.
{ "$schema": "https://opencode.ai/config.json", "default_agent": "plan"}Zadani agent mora biti primarni agent (ne podagent). Ovo može biti ugrađeni agent kao što je "build" ili "plan", ili prilagođeni agent koji ste definirali. Ako navedeni agent ne postoji ili je subagent, OpenCode će se vratiti na "build" s upozorenjem.
Ova postavka se primjenjuje na sva sučelja: TUI, CLI (opencode run), desktop aplikaciju i GitHub Action.
Dijeljenje
Možete konfigurirati funkciju share putem opcije share.
{ "$schema": "https://opencode.ai/config.json", "share": "manual"}Ovo traje:
"manual"- Dozvoli ručno dijeljenje putem komandi (podrazumevano)"auto"- Automatski dijelite nove razgovore"disabled"- Onemogući dijeljenje u potpunosti Podrazumevano, dijeljenje je postavljeno na ručni način rada gdje trebate eksplicitno dijeliti razgovore pomoću naredbe/share.
Command
Možete konfigurirati prilagođene komande za ponavljanje zadataka putem opcije 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", }, },}Također možete definirati komande koristeći markdown fajlove u ~/.config/opencode/commands/ ili .opencode/commands/. Saznajte više ovdje.
Keybinds
Možete prilagoditi svoje veze ključeva putem opcije keybinds.
{ "$schema": "https://opencode.ai/config.json", "keybinds": {}}Automatsko ažuriranje
OpenCode će automatski preuzeti sva nova ažuriranja kada se pokrene. Ovo možete onemogućiti opcijom autoupdate.
{ "$schema": "https://opencode.ai/config.json", "autoupdate": false}Ako ne želite ažuriranja, ali želite biti obaviješteni kada nova verzija bude dostupna, postavite autoupdate na "notify".
Imajte na umu da ovo funkcionira samo ako nije instalirano pomoću upravitelja paketa kao što je Homebrew.
Formatters
Možete konfigurirati formatere koda putem opcije 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"] } }}Saznajte više o formatterima ovdje.
Dozvole
Prema zadanim postavkama, opencode dopušta sve operacije bez potrebe za eksplicitnim dopuštenjem. Ovo možete promijeniti koristeći opciju permission.
Na primjer, da osigurate da alati edit i bash zahtijevaju odobrenje korisnika:
{ "$schema": "https://opencode.ai/config.json", "permission": { "edit": "ask", "bash": "ask" }}Ovdje saznajte više o dozvolama.
Compaction
Možete kontrolirati ponašanje sažimanja konteksta putem opcije compaction.
{ "$schema": "https://opencode.ai/config.json", "compaction": { "auto": true, "prune": true }}auto- Automatski sažimanje sesije kada je kontekst pun (podrazumevano:true).prune- Uklonite stare izlaze alata da sačuvate tokene (podrazumevano:true).
Watcher
Možete konfigurirati obrasce ignoriranja promatrača datoteka putem opcije watcher.
{ "$schema": "https://opencode.ai/config.json", "watcher": { "ignore": ["node_modules/**", "dist/**", ".git/**"] }}Obrasci prate glob sintaksu. Koristite ovo da isključite bučne direktorije iz pregleda datoteka.
MCP serveri
Možete konfigurirati MCP servere koje želite koristiti putem opcije mcp.
{ "$schema": "https://opencode.ai/config.json", "mcp": {}}Extras
Plugins proširuju OpenCode sa prilagođenim alatima, kukicama i integracijama.
Postavite datoteke dodataka u .opencode/plugins/ ili ~/.config/opencode/plugins/. Također možete učitati dodatke iz npm-a preko opcije plugin.
{ "$schema": "https://opencode.ai/config.json", "plugin": ["opencode-helicone-session", "@my-org/custom-plugin"]}Uputstva
Možete konfigurirati upute za model koji koristite putem opcije instructions.
{ "$schema": "https://opencode.ai/config.json", "instructions": ["CONTRIBUTING.md", "docs/guidelines.md", ".cursor/rules/*.md"]}Ovo uzima niz putanja i uzoraka globusa do datoteka instrukcija. Saznajte više o pravilima ovdje.
Onemogućeni provajderi
Možete onemogućiti dobavljače koji se automatski učitavaju preko opcije disabled_providers. Ovo je korisno kada želite spriječiti učitavanje određenih provajdera čak i ako su njihovi vjerodajnici dostupni.
{ "$schema": "https://opencode.ai/config.json", "disabled_providers": ["openai", "gemini"]}Opcija disabled_providers prihvata niz ID-ova provajdera. Kada je provajder onemogućen:
- Neće se učitati čak i ako su varijable okruženja postavljene.
- Neće se učitati čak i ako su API ključevi konfigurirani putem
/connectkomande. - Modeli dobavljača se neće pojaviti na listi za odabir modela.
Omogućeni provajderi
Možete odrediti listu dozvoljenih dobavljača putem opcije enabled_providers. Kada se podesi, samo navedeni provajderi će biti omogućeni, a svi ostali će biti zanemareni.
{ "$schema": "https://opencode.ai/config.json", "enabled_providers": ["anthropic", "openai"]}Ovo je korisno kada želite da ograničite OpenCode da koristi samo određene provajdere umesto da ih onemogućavate jednog po jednog.
Ako se provajder pojavljuje i u enabled_providers i disabled_providers, disabled_providers ima prioritet za kompatibilnost unatrag.
Eksperimentalno
Ključ experimental sadrži opcije koje su u aktivnom razvoju.
{ "$schema": "https://opencode.ai/config.json", "experimental": {}}Varijable
Možete koristiti zamjenu varijabli u vašim konfiguracijskim datotekama da biste referencirali varijable okruženja i sadržaj datoteke.
Env vars
Koristite {env:VARIABLE_NAME} za zamjenu varijabli okruženja:
{ "$schema": "https://opencode.ai/config.json", "model": "{env:OPENCODE_MODEL}", "provider": { "anthropic": { "models": {}, "options": { "apiKey": "{env:ANTHROPIC_API_KEY}" } } }}Ako varijabla okruženja nije postavljena, bit će zamijenjena praznim nizom.
Fajlovi
Koristite {file:path/to/file} da zamijenite sadržaj fajla:
{ "$schema": "https://opencode.ai/config.json", "instructions": ["./custom-instructions.md"], "provider": { "openai": { "options": { "apiKey": "{file:~/.secrets/openai-key}" } } }}Putanja fajla mogu biti:
- U odnosu na direktorij konfiguracijskih datoteka
- Ili apsolutne staze koje počinju sa
/ili~Ovo je korisno za: - Pohranjivanje osjetljivih podataka poput API ključeva u odvojenim datotekama.
- Uključujući velike datoteke instrukcija bez zatrpavanja vaše konfiguracije.
- Dijeljenje zajedničkih isječaka konfiguracije u više konfiguracijskih datoteka.