Gå til innholdet

Konfig

Ved å bruke opencode JSON-konfigurasjonen.

Du kan konfigurere OpenCode ved å bruke en JSON konfigurasjonsfil.


Format

OpenCode støtter både JSON og JSONC (JSON med kommentarer) formater.

opencode.jsonc
{
"$schema": "https://opencode.ai/config.json",
// Theme configuration
"theme": "opencode",
"model": "anthropic/claude-sonnet-4-5",
"autoupdate": true,
}

Steder

Du kan plassere konfigurasjonen på et par forskjellige steder, og de har en annen rekkefølge.

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 dine globale konfigurasjonssett theme: "opencode" og autoupdate: true, og prosjektkonfigurasjonen setter model: "anthropic/claude-sonnet-4-5", vil den endelige konfigurasjonen inkludere alle tre innstillingene.


Forrangsrekkefølge

Konfigurasjonskilder lastes inn i denne rekkefølgen (senere kilder overstyrer tidligere):

  1. Ekstern konfig (fra .well-known/opencode) - organisasjonsstandarder
  2. Global konfig (~/.config/opencode/opencode.json) - brukerinnstillinger
  3. Egendefinert konfigurasjon (OPENCODE_CONFIG env var) - egendefinerte overstyringer
  4. Prosjektkonfigurasjon (opencode.json i prosjekt) - prosjektspesifikke innstillinger
  5. .opencode kataloger - agenter, kommandoer, plugins
  6. Inline config (OPENCODE_CONFIG_CONTENT env var) - kjøretidsoverstyringer

Dette betyr at prosjektkonfigurasjoner kan overstyre globale standardinnstillinger, og globale konfigurasjoner kan overstyre eksterne organisasjonsstandarder.


Ekstern

Organisasjoner kan gi 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 basislaget. Alle andre konfigurasjonskilder (global, prosjekt) kan overstyre disse standardinnstillingene.

For eksempel, hvis organisasjonen din tilbyr MCP servere som er deaktivert som standard:

Remote config from .well-known/opencode
{
"mcp": {
"jira": {
"type": "remote",
"url": "https://jira.example.com/mcp",
"enabled": false
}
}
}

Du kan aktivere spesifikke servere i din lokale konfigurasjon:

opencode.json
{
"mcp": {
"jira": {
"type": "remote",
"url": "https://jira.example.com/mcp",
"enabled": true
}
}
}

Globalt

Plasser din globale OpenCode-konfigurasjon i ~/.config/opencode/opencode.json. Bruk global konfigurasjon for brukeromfattende preferanser som temaer, leverandører eller nøkkelbindinger.

Global konfigurasjon overstyrer eksterne organisasjonsstandarder.


Per prosjekt

Legg til opencode.json i prosjektroten din. Project config har den høyeste prioritet blant standard config-filer - den overstyrer både globale og eksterne konfigurasjoner.

Når OpenCode starter opp, ser den etter en konfigurasjonsfil i gjeldende katalog eller går opp til nærmeste Git-katalog.

Dette er også trygt å bli sjekket inn i Git og bruker samme skjema som det globale.


Egendefinert bane

Spesifiser en tilpasset konfigurasjonsfilbane ved å bruke miljøvariabelen OPENCODE_CONFIG.

Terminal window
export OPENCODE_CONFIG=/path/to/my/custom-config.json
opencode run "Hello world"

Egendefinert konfigurasjon lastes inn mellom globale og prosjektkonfigurasjoner i prioritetsrekkefølge.


Egendefinert katalog

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.

Terminal window
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.


Skjema

Konfigurasjonsfilen har et skjema som er definert i opencode.ai/config.json.

Redaktøren din skal kunne validere og autofullføre basert på skjemaet.


TUI

Du kan konfigurere TUI-spesifikke innstillinger gjennom alternativet tui.

opencode.json
{
"$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.

Les mer om bruk av TUI her.


Server

Du kan konfigurere serverinnstillinger for kommandoene opencode serve og opencode web gjennom alternativet server.

opencode.json
{
"$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 for å 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.

Les mer om serveren her.


Verktøy

Du kan administrere verktøyene en LLM kan bruke gjennom alternativet tools.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"tools": {
"write": false,
"bash": false
}
}

Les mer om verktøy her.


Modeller

Du kan konfigurere leverandørene og modellene du vil bruke i OpenCode-konfigurasjonen gjennom alternativene provider, model og small_model.

opencode.json
{
"$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 billigere modell hvis en er tilgjengelig fra leverandøren din, ellers faller den tilbake til hovedmodellen din.

Leverandøralternativer kan inkludere timeout og setCacheKey:

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"provider": {
"anthropic": {
"options": {
"timeout": 600000,
"setCacheKey": true
}
}
}
}
  • timeout - Be om tidsavbrudd i millisekunder (standard: 300 000). Sett til false for å deaktivere.
  • setCacheKey - Sørg for at en hurtigbuffernøkkel alltid er angitt for utpekt leverandør.

Du kan også konfigurere lokale modeller. Finn ut mer.


Leverandørspesifikke alternativer

Noen leverandører støtter flere konfigurasjonsalternativer utover de generiske innstillingene timeout og apiKey.

Amazon Bedrock

Amazon Bedrock støtter AWS-spesifikk konfigurasjon:

opencode.json
{
"$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.

Les mer om konfigurasjon av Amazon Bedrock.


Temaer

Du kan konfigurere temaet du vil bruke i OpenCode-konfigurasjonen gjennom alternativet theme.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"theme": ""
}

Les mer her.


Agenter

Du kan konfigurere spesialiserte agenter for spesifikke oppgaver gjennom alternativet agent.

opencode.jsonc
{
"$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.


Standard agent

Du kan angi standard agent ved å bruke alternativet default_agent. Dette bestemmer hvilken agent som brukes når ingen er eksplisitt spesifisert.

opencode.json
{
"$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.


Deling

Du kan konfigurere share-funksjonen gjennom alternativet share.

opencode.json
{
"$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 helt

Som standard er deling satt til manuell modus der du eksplisitt må dele samtaler ved å bruke kommandoen /share.


Kommandoer

Du kan konfigurere egendefinerte kommandoer for repeterende oppgaver gjennom alternativet command.

opencode.jsonc
{
"$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.


Nøkkelbindinger

Du kan tilpasse nøkkelbindingene dine gjennom alternativet keybinds.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"keybinds": {}
}

Les mer her.


Autooppdatering

OpenCode vil automatisk laste ned eventuelle nye oppdateringer når den starter opp. Du kan deaktivere dette med alternativet autoupdate.

opencode.json
{
"$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.


Formatere

Du kan konfigurere kodeformatere gjennom alternativet formatter.

opencode.json
{
"$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"]
}
}
}

Les mer om formattere her.


Tillatelser

Som standard tillater OpenCode alle operasjoner uten å kreve eksplisitt godkjenning. Du kan endre dette ved å bruke alternativet permission.

For å sikre at verktøyene edit og bash krever brukergodkjenning:

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"permission": {
"edit": "ask",
"bash": "ask"
}
}

Les mer om tillatelser her.


Komprimering

Du kan kontrollere atferden for kontekstkomprimering gjennom alternativet compaction.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"compaction": {
"auto": true,
"prune": true
}
}
  • auto - Komprimer økten automatisk når konteksten er full (standard: true).
  • prune - Fjern gamle verktøyutganger for å lagre tokens (standard: true).

Overvåker

Du kan konfigurere ignoreringsmønstre for filovervåking gjennom alternativet watcher.

opencode.json
{
"$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 filvisning.


MCP servere

Du kan konfigurere MCP-servere du vil bruke gjennom alternativet mcp.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"mcp": {}
}

Les mer her.


Plugins

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.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"plugin": ["opencode-helicone-session", "@my-org/custom-plugin"]
}

Les mer her.


Instruksjoner

Du kan konfigurere instruksjonene for modellen du bruker gjennom alternativet instructions.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"instructions": ["CONTRIBUTING.md", "docs/guidelines.md", ".cursor/rules/*.md"]
}

Dette krever en rekke baner og globmønstre til instruksjonsfiler. Les mer om regler her.


Deaktiverte leverandører

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.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"disabled_providers": ["openai", "gemini"]
}

Alternativet disabled_providers godtar en rekke leverandør-ID-er. Når en leverandør er deaktivert:

  • Den blir ikke lastet selv om miljøvariabler er angitt.
  • Den vil ikke bli lastet inn selv om API-nøkler er konfigurert gjennom /connect-kommandoen.
  • Leverandørens modeller vises ikke i modellvalglisten.

Aktiverte leverandører

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.

opencode.json
{
"$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.

Hvis en leverandør vises i både enabled_providers og disabled_providers, har disabled_providers prioritet for bakoverkompatibilitet.


Eksperimentell

experimental-nøkkelen inneholder alternativer som er under aktiv utvikling.

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"experimental": {}
}

Variabler

Du kan bruke variabelerstatning i konfigurasjonsfilene dine for å referere til miljøvariabler og filinnhold.


Env vars

Bruk {env:VARIABLE_NAME} for å erstatte miljøvariabler:

opencode.json
{
"$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.


Filer

Bruk {file:path/to/file} for å erstatte innholdet i en fil:

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"instructions": ["./custom-instructions.md"],
"provider": {
"openai": {
"options": {
"apiKey": "{file:~/.secrets/openai-key}"
}
}
}
}

Filbaner kan være:

  • I forhold til konfigurasjonsfilkatalogen
  • Eller absolutte baner som begynner med / eller ~

Disse er nyttige for:

  • Oppbevaring av sensitive data som API-nøkler i separate filer.
  • Inkludert store instruksjonsfiler uten å rote konfigurasjonen din.
  • Deling av vanlige konfigurasjonsbiter på tvers av flere konfigurasjonsfiler.