packages/web/src/content/docs/nb/config.mdx
Du kan konfigurere OpenCode ved å bruke en JSON konfigurasjonsfil.
OpenCode støtter både JSON og JSONC (JSON med kommentarer) formater.
{
"$schema": "https://opencode.ai/config.json",
"model": "anthropic/claude-sonnet-4-5",
"autoupdate": true,
"server": {
"port": 4096,
},
}
Du kan plassere konfigurasjonen på et par forskjellige steder, og de har en annen rekkefølge.
:::note Konfigurasjonsfiler er slått sammen, ikke erstattet. :::
Konfigurasjonsfiler slås sammen, ikke erstattes. Innstillinger fra følgende konfigurasjonsplasseringer kombineres. Senere konfigurasjoner overstyrer tidligere kun for motstridende nøkler. Ikke-motstridende innstillinger fra alle konfigurasjoner er bevart.
For eksempel, hvis din globale konfigurasjon setter theme: "opencode" og autoupdate: true, og prosjektkonfigurasjonen setter model: "anthropic/claude-sonnet-4-5", vil den endelige konfigurasjonen inkludere alle tre innstillingene.
Konfigurasjonskilder lastes inn i denne rekkefølgen (senere kilder overstyrer tidligere):
.well-known/opencode) - organisasjonsstandarder~/.config/opencode/opencode.json) - brukerinnstillingerOPENCODE_CONFIG env var) - egendefinerte overstyringeropencode.json i prosjekt) - prosjektspesifikke innstillinger.opencode kataloger - agenter, kommandoer, pluginsOPENCODE_CONFIG_CONTENT env var) - kjøretidsoverstyringerDette betyr at prosjektkonfigurasjoner kan overstyre globale standardinnstillinger, og globale konfigurasjoner kan overstyre eksterne organisasjonsstandarder.
:::note
.opencode og ~/.config/opencode katalogene bruker flertallsnavn på underkataloger: agents/, commands/, modes/, plugins/, skills/, tools/ og themes/. Enkeltnavn (f.eks. agent/) støttes også for bakoverkompatibilitet.
:::
Organisasjoner kan tilby standardkonfigurasjon via .well-known/opencode-endepunktet. Dette hentes automatisk når du autentiserer med en leverandør som støtter det.
Ekstern konfigurasjon lastes først, og fungerer som grunnlaget. Alle andre konfigurasjonskilder (global, prosjekt) kan overstyre disse standardinnstillingene.
For eksempel, hvis organisasjonen din tilbyr MCP servere som er deaktivert som standard:
{
"mcp": {
"jira": {
"type": "remote",
"url": "https://jira.example.com/mcp",
"enabled": false
}
}
}
Du kan aktivere spesifikke servere i din lokale konfigurasjon:
{
"mcp": {
"jira": {
"type": "remote",
"url": "https://jira.example.com/mcp",
"enabled": true
}
}
}
Plasser din globale OpenCode-konfigurasjon i ~/.config/opencode/opencode.json. Bruk global konfigurasjon for brukerspesifikke preferanser som temaer, leverandører eller nøkkelbindinger.
Global konfigurasjon overstyrer eksterne organisasjonsstandarder.
Legg til opencode.json i prosjektroten din. Prosjektkonfigurasjon har den høyeste prioritet blant standard config-filer - den overstyrer både globale og eksterne konfigurasjoner.
:::tip Plasser prosjektspesifikk konfigurasjon i roten til prosjektet ditt. :::
Når OpenCode starter opp, ser den etter en konfigurasjonsfil i gjeldende katalog eller går opp til nærmeste Git-katalog.
Det er også trygt å sjekke inn dette i Git og bruker samme skjema som det globale.
Spesifiser en tilpasset konfigurasjonsfilbane ved å bruke miljøvariabelen OPENCODE_CONFIG.
export OPENCODE_CONFIG=/path/to/my/custom-config.json
opencode run "Hello world"
Egendefinert konfigurasjon lastes inn mellom globale og prosjektkonfigurasjoner i prioritetsrekkefølge.
Spesifiser en tilpasset konfigurasjonskatalog ved å bruke OPENCODE_CONFIG_DIR
miljøvariabel. Denne katalogen vil bli søkt etter agenter, kommandoer,
moduser og plugins akkurat som standard .opencode katalog, og bør
følge samme struktur.
export OPENCODE_CONFIG_DIR=/path/to/my/config-directory
opencode run "Hello world"
Den egendefinerte katalogen lastes inn etter den globale konfigurasjonen og .opencode-katalogene, slik at den kan overstyre innstillingene deres.
Konfigurasjonsfilen har et skjema som er definert i opencode.ai/config.json.
Redaktøren din skal kunne validere og autofullføre basert på skjemaet.
Du kan konfigurere TUI-spesifikke innstillinger gjennom alternativet tui.
{
"$schema": "https://opencode.ai/config.json",
"tui": {
"scroll_speed": 3,
"scroll_acceleration": {
"enabled": true
},
"diff_style": "auto"
}
}
Tilgjengelige alternativer:
scroll_acceleration.enabled - Aktiver rulleakselerasjon i macOS-stil. Tar forrang over scroll_speed.scroll_speed - Egendefinert rullehastighetsmultiplikator (standard: 3, minimum: 1). Ignorert hvis scroll_acceleration.enabled er true.diff_style - Kontroller diff-gjengivelse. "auto" tilpasser seg terminalbredden, "stacked" viser alltid en kolonne.Du kan konfigurere serverinnstillinger for kommandoene opencode serve og opencode web gjennom alternativet server.
{
"$schema": "https://opencode.ai/config.json",
"server": {
"port": 4096,
"hostname": "0.0.0.0",
"mdns": true,
"mdnsDomain": "myproject.local",
"cors": ["http://localhost:5173"]
}
}
Tilgjengelige alternativer:
port - Port å lytte på.hostname - Vertsnavn å lytte på. Når mdns er aktivert og ingen vertsnavn er angitt, er standard 0.0.0.0.mdns - Aktiver mDNS-tjenesteoppdagelse. Dette lar andre enheter på nettverket oppdage OpenCode-serveren din.mdnsDomain - Egendefinert domenenavn for mDNS-tjeneste. Standard er opencode.local. Nyttig for å kjøre flere forekomster på samme nettverk.cors - Ytterligere opprinnelser for å tillate CORS når du bruker HTTP-serveren fra en nettleserbasert klient. Verdiene må være fullstendige opprinnelser (skjema + vert + valgfri port), f.eks. https://app.example.com.Du kan administrere verktøyene en LLM kan bruke gjennom alternativet tools.
{
"$schema": "https://opencode.ai/config.json",
"tools": {
"write": false,
"bash": false
}
}
Du kan konfigurere leverandørene og modellene du vil bruke i OpenCode-konfigurasjonen gjennom alternativene provider, model og small_model.
{
"$schema": "https://opencode.ai/config.json",
"provider": {},
"model": "anthropic/claude-sonnet-4-5",
"small_model": "anthropic/claude-haiku-4-5"
}
Alternativet small_model konfigurerer en egen modell for lette oppgaver som tittelgenerering. Som standard prøver OpenCode å bruke en rimeligere modell hvis en er tilgjengelig fra leverandøren din, ellers faller den tilbake til hovedmodellen din.
Leverandøralternativer kan inkludere timeout og setCacheKey:
{
"$schema": "https://opencode.ai/config.json",
"provider": {
"anthropic": {
"options": {
"timeout": 600000,
"setCacheKey": true
}
}
}
}
timeout - Tidsavbrudd for forespørsler i millisekunder (standard: 300 000). Sett til false for å deaktivere.setCacheKey - Sørg for at en hurtigbuffernøkkel alltid settes for valgt leverandør.Du kan også konfigurere lokale modeller. Finn ut mer.
Noen leverandører støtter flere konfigurasjonsalternativer utover de generiske innstillingene timeout og apiKey.
Amazon Bedrock støtter AWS-spesifikk konfigurasjon:
{
"$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-region for Bedrock (standard er AWS_REGION env var eller us-east-1)profile - AWS navngitt profil fra ~/.aws/credentials (standard til AWS_PROFILE env var)endpoint - Egendefinert endepunkt URL for VPC endepunkter. Dette er et alias for det generiske baseURL-alternativet som bruker AWS-spesifikk terminologi. Hvis begge er spesifisert, har endpoint forrang.:::note
Bærer-tokens (AWS_BEARER_TOKEN_BEDROCK eller /connect) har forrang over profilbasert autentisering. Se autentiseringsprioritet for detaljer.
:::
Les mer om konfigurasjon av Amazon Bedrock.
Angi UI-temaet ditt i tui.json.
{
"$schema": "https://opencode.ai/tui.json",
"theme": "tokyonight"
}
Du kan konfigurere spesialiserte agenter for spesifikke oppgaver gjennom alternativet 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,
},
},
},
}
Du kan også definere agenter ved å bruke markdown-filer i ~/.config/opencode/agents/ eller .opencode/agents/. Les mer her.
Du kan angi standard agent ved å bruke alternativet default_agent. Dette bestemmer hvilken agent som brukes når ingen er eksplisitt spesifisert.
{
"$schema": "https://opencode.ai/config.json",
"default_agent": "plan"
}
Standardagenten må være en primæragent (ikke en underagent). Dette kan være en innebygd agent som "build" eller "plan", eller en egendefinert agent du har definert. Hvis den angitte agenten ikke eksisterer eller er en subagent, vil OpenCode falle tilbake til "build" med en advarsel.
Denne innstillingen gjelder for alle grensesnitt: TUI, CLI (opencode run), skrivebordsapp og GitHub Action.
Du kan konfigurere share-funksjonen gjennom alternativet share.
{
"$schema": "https://opencode.ai/config.json",
"share": "manual"
}
Dette krever:
"manual" - Tillat manuell deling via kommandoer (standard)"auto" - Del nye samtaler automatisk"disabled" - Deaktiver deling heltSom standard er deling satt til manuell modus der du eksplisitt må dele samtaler ved å bruke kommandoen /share.
Du kan konfigurere egendefinerte kommandoer for repeterende oppgaver gjennom alternativet 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",
},
},
}
Du kan også definere kommandoer ved å bruke markdown-filer i ~/.config/opencode/commands/ eller .opencode/commands/. Les mer her.
Tilpass tastebindinger i tui.json.
{
"$schema": "https://opencode.ai/tui.json",
"keybinds": {}
}
OpenCode vil automatisk laste ned eventuelle nye oppdateringer når den starter opp. Du kan deaktivere dette med alternativet autoupdate.
{
"$schema": "https://opencode.ai/config.json",
"autoupdate": false
}
Hvis du ikke vil ha oppdateringer, men ønsker å bli varslet når en ny versjon er tilgjengelig, sett autoupdate til "notify".
Legg merke til at dette bare fungerer hvis det ikke ble installert med en pakkebehandling som Homebrew.
Du kan konfigurere kodeformatere gjennom alternativet 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"]
}
}
}
Som standard tillater OpenCode alle operasjoner uten å kreve eksplisitt godkjenning. Du kan endre dette ved å bruke alternativet permission.
Slik sikrer du at verktøyene edit og bash krever brukergodkjenning:
{
"$schema": "https://opencode.ai/config.json",
"permission": {
"edit": "ask",
"bash": "ask"
}
}
Du kan styre kontekstkomprimering gjennom alternativet compaction.
{
"$schema": "https://opencode.ai/config.json",
"compaction": {
"auto": true,
"prune": true,
"reserved": 10000
}
}
auto - Komprimer økten automatisk når konteksten er full (standard: true).prune - Fjern gamle verktøyutdata for å spare tokens (standard: true).reserved - Token-buffer for komprimering. Etterlater nok vindu til å unngå overflyt under komprimeringDu kan konfigurere ignoreringsmønstre for filovervåking gjennom alternativet watcher.
{
"$schema": "https://opencode.ai/config.json",
"watcher": {
"ignore": ["node_modules/**", "dist/**", ".git/**"]
}
}
Mønstre følger glob-syntaks. Bruk dette for å ekskludere støyende kataloger fra filovervåking.
Du kan konfigurere MCP-servere du vil bruke gjennom alternativet mcp.
{
"$schema": "https://opencode.ai/config.json",
"mcp": {}
}
Plugins utvider OpenCode med tilpassede verktøy, kroker og integrasjoner.
Plasser plugin-filer i .opencode/plugins/ eller ~/.config/opencode/plugins/. Du kan også laste inn plugins fra npm gjennom alternativet plugin.
{
"$schema": "https://opencode.ai/config.json",
"plugin": ["opencode-helicone-session", "@my-org/custom-plugin"]
}
Du kan konfigurere instruksjoner for modellen du bruker gjennom alternativet instructions.
{
"$schema": "https://opencode.ai/config.json",
"instructions": ["CONTRIBUTING.md", "docs/guidelines.md", ".cursor/rules/*.md"]
}
Dette krever en liste med baner og globmønstre til instruksjonsfiler. Les mer om regler her.
Du kan deaktivere leverandører som lastes automatisk gjennom alternativet disabled_providers. Dette er nyttig når du vil forhindre at enkelte leverandører lastes inn selv om deres legitimasjon er tilgjengelig.
{
"$schema": "https://opencode.ai/config.json",
"disabled_providers": ["openai", "gemini"]
}
:::note
disabled_providers har prioritet over enabled_providers.
:::
Alternativet disabled_providers godtar en rekke leverandør-ID-er. Når en leverandør er deaktivert:
/connect-kommandoen.Du kan spesifisere en godkjenningsliste over leverandører gjennom alternativet enabled_providers. Når angitt, vil bare de angitte leverandørene være aktivert og alle andre vil bli ignorert.
{
"$schema": "https://opencode.ai/config.json",
"enabled_providers": ["anthropic", "openai"]
}
Dette er nyttig når du vil begrense OpenCode til kun å bruke spesifikke leverandører i stedet for å deaktivere dem én etter én.
:::note
disabled_providers har prioritet over enabled_providers.
:::
Hvis en leverandør vises i både enabled_providers og disabled_providers, har disabled_providers prioritet for bakoverkompatibilitet.
experimental-nøkkelen inneholder alternativer som er under aktiv utvikling.
{
"$schema": "https://opencode.ai/config.json",
"experimental": {}
}
:::caution Eksperimentelle alternativer er ikke stabile. De kan endres eller fjernes uten varsel. :::
Du kan bruke variabelerstatning i konfigurasjonsfilene dine for å referere til miljøvariabler og filinnhold.
Bruk {env:VARIABLE_NAME} for å erstatte miljøvariabler:
{
"$schema": "https://opencode.ai/config.json",
"model": "{env:OPENCODE_MODEL}",
"provider": {
"anthropic": {
"models": {},
"options": {
"apiKey": "{env:ANTHROPIC_API_KEY}"
}
}
}
}
Hvis miljøvariabelen ikke er angitt, vil den bli erstattet med en tom streng.
Bruk {file:path/to/file} for å erstatte innholdet i en fil:
{
"$schema": "https://opencode.ai/config.json",
"instructions": ["./custom-instructions.md"],
"provider": {
"openai": {
"options": {
"apiKey": "{file:~/.secrets/openai-key}"
}
}
}
}
Filbaner kan være:
/ eller ~Disse er nyttige for: