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.
{ "$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):
- Ekstern konfig (fra
.well-known/opencode) - organisasjonsstandarder - Global konfig (
~/.config/opencode/opencode.json) - brukerinnstillinger - Egendefinert konfigurasjon (
OPENCODE_CONFIGenv var) - egendefinerte overstyringer - Prosjektkonfigurasjon (
opencode.jsoni prosjekt) - prosjektspesifikke innstillinger .opencodekataloger - agenter, kommandoer, plugins- Inline config (
OPENCODE_CONFIG_CONTENTenv 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:
{ "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 } }}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.
export OPENCODE_CONFIG=/path/to/my/custom-config.jsonopencode 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.
export OPENCODE_CONFIG_DIR=/path/to/my/config-directoryopencode 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.
{ "$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 overscroll_speed.scroll_speed- Egendefinert rullehastighetsmultiplikator (standard:3, minimum:1). Ignorert hvisscroll_acceleration.enabledertrue.diff_style- Kontroller diff-gjengivelse."auto"tilpasser seg terminalbredden,"stacked"viser alltid en kolonne.
Server
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 for å lytte på.hostname- Vertsnavn å lytte på. Nårmdnser aktivert og ingen vertsnavn er angitt, er standard0.0.0.0.mdns- Aktiver mDNS-tjenesteoppdagelse. Dette lar andre enheter på nettverket oppdage OpenCode-serveren din.mdnsDomain- Egendefinert domenenavn for mDNS-tjeneste. Standard eropencode.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.
Verktøy
Du kan administrere verktøyene en LLM kan bruke gjennom alternativet tools.
{ "$schema": "https://opencode.ai/config.json", "tools": { "write": false, "bash": false }}Modeller
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 billigere 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- Be om tidsavbrudd i millisekunder (standard: 300 000). Sett tilfalsefor å 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:
{ "$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 erAWS_REGIONenv var ellerus-east-1)profile- AWS navngitt profil fra~/.aws/credentials(standard tilAWS_PROFILEenv var)endpoint- Egendefinert endepunkt URL for VPC endepunkter. Dette er et alias for det generiskebaseURL-alternativet som bruker AWS-spesifikk terminologi. Hvis begge er spesifisert, harendpointforrang.
Les mer om konfigurasjon av Amazon Bedrock.
Temaer
Du kan konfigurere temaet du vil bruke i OpenCode-konfigurasjonen gjennom alternativet theme.
{ "$schema": "https://opencode.ai/config.json", "theme": ""}Agenter
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.
Standard agent
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.
Deling
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 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.
{ "$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.
{ "$schema": "https://opencode.ai/config.json", "keybinds": {}}Autooppdatering
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.
Formatere
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"] } }}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:
{ "$schema": "https://opencode.ai/config.json", "permission": { "edit": "ask", "bash": "ask" }}Komprimering
Du kan kontrollere atferden for kontekstkomprimering gjennom alternativet compaction.
{ "$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.
{ "$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.
{ "$schema": "https://opencode.ai/config.json", "mcp": {}}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.
{ "$schema": "https://opencode.ai/config.json", "plugin": ["opencode-helicone-session", "@my-org/custom-plugin"]}Instruksjoner
Du kan konfigurere instruksjonene 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 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.
{ "$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.
{ "$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.
{ "$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:
{ "$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:
{ "$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.