Konfig
Ved at bruge OpenCode JSON konfig.
Du kan konfigurere OpenCode ved hjælp af en JSON-konfigurationsfil.
Format
OpenCode understø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 placere din konfiguration et par forskellige steder, og de har en forskellig rækkefølge.
Konfigurationsfiler flettes sammen, erstattes ikke. Indstillinger fra følgende konfigurationssteder kombineret. Senere konfigurationer tilsidesætter kun tidligere konfigurationer for modstridende nøgler. Ikke-modstridende indstillinger fra alle konfigurationer bevares.
For eksempel, hvis dine globale konfigurationssæt theme: "opencode" og autoupdate: true, og dine projektkonfigurationssæt model: "anthropic/claude-sonnet-4-5", vil den endelige konfiguration integrere alle tre indstillinger.
Prioritetsrækkefølge
Konfigurationskilder indlæses i denne rækkefølge (senere kilder tilsidesætter tidligere):
- Fjernkonfiguration (fra
.well-known/opencode) - organisatoriske standardindstillinger - Global config (
~/.config/opencode/opencode.json) - brugerpræferencer - Tilpasset konfiguration (
OPENCODE_CONFIGenv var) - tilpassede tilsidesættelser - Project config (
opencode.jsoni projekt) - projektspecifikke indstillinger .opencodemapper - agent, kommandoer, plugins- Inline config (
OPENCODE_CONFIG_CONTENTenv var) - runtime tilsidesættelser
Dette betyder, at projektkonfigurationer kan tilsidesætte globale standardindstillinger, og globale konfigurationer kan tilsidesætte eksterne organisatoriske standarder.
Ekstern konfiguration
Organisationer kan levere standardkonfiguration via .well-known/opencode-slutpunktet. Dette hentes automatisk, når du godkender med en udbyder, der understøtter det.
Remote config indlæses først og fungerer som basislaget. Alle andre konfigurationskilder (global, projekt) kan tilsidesætte disse standardindstillinger.
Hvis din organisation f.eks. leverer MCP-servere, der er deaktiveret som standard:
{ "mcp": { "jira": { "type": "remote", "url": "https://jira.example.com/mcp", "enabled": false } }}Du kan aktivere specifikke servere i din lokale konfiguration:
{ "mcp": { "jira": { "type": "remote", "url": "https://jira.example.com/mcp", "enabled": true } }}Global
Placer din globale OpenCode-konfiguration i ~/.config/opencode/opencode.json. Brug global konfiguration til brugerdækkende præferencer som temaer, udbydere eller nøglebindinger.
Global config tilsidesætter eksterne organisatoriske standarder.
Pr. projekt
Tilføj opencode.json i dit projektrod. Project config har den højeste forrang blandt standard config-filer - den tilsidesætter både globale og eksterne config.
Når OpenCode starter op, søger den efter en konfigurationsfil i den aktuelle mappe eller går op til den nærmeste Git-mappe.
Dette er også sikkert at blive tjekket ind i Git og bruger det samme skema som det globale.
Brugerdefineret sti
Angiv en brugerdefineret konfigurationsfilsti ved hjælp af miljøvariablen OPENCODE_CONFIG.
export OPENCODE_CONFIG=/path/to/my/custom-config.jsonopencode run "Hello world"Brugerdefineret konfigurationsindlæses mellem globale konfigurationer og projektkonfigurationer i prioriteret rækkefølge.
Brugerdefineret bibliotek
Angiv en brugerdefineret konfigurationsmappe ved hjælp af OPENCODE_CONFIG_DIR
miljøvariabel. Dette kort vil blive søgt efter agenter, kommandoer,
modes og plugins ligesom standard .opencode mappen, og bør
følge samme struktur.
export OPENCODE_CONFIG_DIR=/path/to/my/config-directoryopencode run "Hello world"Den brugerdefinerede mappe indlæses efter den globale konfig og .opencode mapper, så den kan tilsidesætte deres indstillinger.
Skema
Konfigurationsfilen har et skema, der defineres i opencode.ai/config.json.
Din editor skal være i stand til at validere og autofuldføre baseret på skemaet.
TUI
Du kan konfigurere TUI-specifikke indstillinger gennem indstillingen tui.
{ "$schema": "https://opencode.ai/config.json", "tui": { "scroll_speed": 3, "scroll_acceleration": { "enabled": true }, "diff_style": "auto" }}Tilgængelige muligheder:
scroll_acceleration.enabled- Aktiver macOS-stil rulleacceleration. Har forrang frem forscroll_speed.scroll_speed- Brugerdefineret rullehastighedsmultiplikator (standard:3, minimum:1). Ignoreres, hvisscroll_acceleration.enabledertrue.diff_style- Kontroller diff-gengivelse."auto"tilpasser sig terminalbredden,"stacked"viser altid en enkelt kolonne.
Learn more about using the TUI here.
Server
Du kan konfigurere serverindstillinger for kommandoerne opencode serve og opencode web gennem indstillingen server.
{ "$schema": "https://opencode.ai/config.json", "server": { "port": 4096, "hostname": "0.0.0.0", "mdns": true, "mdnsDomain": "myproject.local", "cors": ["http://localhost:5173"] }}Tilgængelige muligheder:
port- Port til at lytte på.hostname- Værtsnavn at lytte på. Nårmdnser aktiveret, og der ikke er angivet noget værtsnavn, er standarden0.0.0.0.mdns- Aktiver mDNS-tjenesteopdagelse. Dette gør det muligt for andre enheder på netværket at opdage din OpenCode-server.mdnsDomain- Brugerdefineret domænenavn til mDNS-tjeneste. Som standard eropencode.local. Nyttigt til at køre flere forekomster på det samme netværk.cors- Yderligere oprindelser for at tillade CORS ved brug af HTTP-serveren fra en browserbaseret klient. Værdier skal være fulde oprindelser (skema + vært + valgfri port), f.eks.https://app.example.com.
Learn more about the server here.
Værktøjer
Du kan administrere de værktøjer, en LLM kan bruge, gennem indstillingen tools.
{ "$schema": "https://opencode.ai/config.json", "tools": { "write": false, "bash": false }}Modeller
Du kan konfigurere de udbydere og modeller, du vil bruge i din OpenCode-konfiguration, gennem mulighederne 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"}Indstillingen small_model konfigurerer en separat model til lette opgaver som titelgenerering. Som standard forsøger OpenCode at bruge en billigere model, hvis en er tilgængelig fra din udbyder, ellers falder den tilbage til din hovedmodel.
Udbydermuligheder kan omfatte timeout og setCacheKey:
{ "$schema": "https://opencode.ai/config.json", "provider": { "anthropic": { "options": { "timeout": 600000, "setCacheKey": true } } }}timeout- Anmodningstimeout i millisekunder (standard: 300000). Indstil tilfalsefor at deaktivere.setCacheKey- Sørg for, at en cache-nøgle altid er indstillet til den udpegede udbyder.
Du kan også konfigurere local models. Learn more.
Udbyder-specifikke muligheder
Nogle udbydere understøtter yderligere konfigurationsmuligheder ud over de generiske timeout og apiKey indstillinger.
Amazon Bedrock
Amazon Bedrock understøtter AWS-specifik konfiguration:
{ "$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 tilAWS_REGIONenv var ellerus-east-1)profile- AWS navngivet profil fra~/.aws/credentials(standard tilAWS_PROFILEenv var)endpoint- Brugerdefineret slutpunkt URL for VPC-endepunkter. Dette er et alias for den generiskebaseURL-indstilling, der bruger AWS-specifik terminologi. Hvis begge er angivet, harendpointforrang.
Learn more about Amazon Bedrock configuration.
Temaer
Du kan konfigurere det tema, du vil bruge i din OpenCode-konfiguration, gennem indstillingen theme.
{ "$schema": "https://opencode.ai/config.json", "theme": ""}Agent
Du kan konfigurere opgaver specialiserede agenter til specifikke indstillinger gennem indstillingen 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 at bruge markdown-filer i ~/.config/opencode/agents/ eller .opencode/agents/. Learn more here.
Standardagent
Du kan indstille standardagenten ved at bruge indstillingen default_agent. Dette bestemmer, hvilken agent der bruges, når ingen er eksplicit angivet.
{ "$schema": "https://opencode.ai/config.json", "default_agent": "plan"}Standardagenten skal være en primær agent (ikke en subagent). Dette kan være en indbygget agent som "build" eller "plan", eller en custom agent, du har defineret. Hvis den angivne agent ikke eksisterer eller er en underagent, vil OpenCode falde tilbage til "build" med en advarsel.
Denne indstilling gælder på tværs af alle grænseflader: TUI, CLI (opencode run), desktop-app og GitHub Action.
Deling
Du kan konfigurere funktionen share gennem indstillingen share.
{ "$schema": "https://opencode.ai/config.json", "share": "manual"}Dette kræver:
"manual"- Tillad manuel deling via kommandoer (standard)"auto"- Del automatisk nye samtaler"disabled"- Deaktiver deling helt
Som standard er deling indstillet til manuel tilstand, hvor du eksplicit skal dele samtaler ved hjælp af kommandoen /share.
Kommandoer
Du kan konfigurere brugerdefinerede kommandoer til gentagne opgaver gennem indstillingen 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 hjælp af markdown-filer i ~/.config/opencode/commands/ eller .opencode/commands/. Learn more here.
Nøglebindinger
Du kan tilpasse dine nøglebindinger gennem indstillingen keybinds.
{ "$schema": "https://opencode.ai/config.json", "keybinds": {}}Autoopdatering
OpenCode vil automatisk downloade alle nye opdateringer, når den starter op. Du kan deaktivere dette med indstillingen autoupdate.
{ "$schema": "https://opencode.ai/config.json", "autoupdate": false}Hvis du ikke ønsker opdatering, men ønsker at blive underrettet, når en ny version er tilgængelig, skal du indstille autoupdate til "notify".
Bemærk, at dette kun virker, hvis det ikke blev installeret ved hjælp af en pakkehåndtering såsom Homebrew.
Formatere
Du kan konfigurere kodeformatere gennem indstillingen 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"] } }}Learn more about formatters here.
Tilladelser
Som standard opencode tillader alle operationer uden at kræve eksplicit godkendelse. Du kan ændre dette ved at bruge indstillingen permission.
For at sikre, at værktøjerne edit og bash for eksempel kræver brugergodkendelse:
{ "$schema": "https://opencode.ai/config.json", "permission": { "edit": "ask", "bash": "ask" }}Learn more about permissions here.
Komprimering
Du kan styre kontekstkomprimeringsadfærd gennem indstillingen compaction.
{ "$schema": "https://opencode.ai/config.json", "compaction": { "auto": true, "prune": true }}auto- Komprimer automatisk sessionen, når konteksten er fuld (standard:true).prune- Fjern gamle værktøjsudgange for at gemme tokens (standard:true).
Watcher
Du kan konfigurere ignoreringsmønstre for filovervåger gennem indstillingen watcher.
{ "$schema": "https://opencode.ai/config.json", "watcher": { "ignore": ["node_modules/**", "dist/**", ".git/**"] }}Mønstre følger glob-syntaks. Brug dette til at udelukke støjende mapper fra filvisning.
MCP servere
Du kan konfigurere MCP-servere, som du vil bruge, gennem indstillingen mcp.
{ "$schema": "https://opencode.ai/config.json", "mcp": {}}Plugins
Plugins udvide OpenCode med brugerdefinerede værktøjer, kroge og integrationer.
Placer plugin-filer i .opencode/plugins/ eller ~/.config/opencode/plugins/. Du kan også indlæse plugins fra npm gennem indstillingen plugin.
{ "$schema": "https://opencode.ai/config.json", "plugin": ["opencode-helicone-session", "@my-org/custom-plugin"]}Instruktioner
Du kan konfigurere brugervejledningen til den model, du kan gennem indstillingen instructions.
{ "$schema": "https://opencode.ai/config.json", "instructions": ["CONTRIBUTING.md", "docs/guidelines.md", ".cursor/rules/*.md"]}Dette kræver en række stier og globmønstre til instruktionsfiler. Læs mere om regler her.
Deaktiverede udbydere
Du kan deaktivere udbydere, der indlæses automatisk gennem disabled_providers-indstillingen. Dette er nyttigt, når du vil forhindre visse udbydere i at blive indlæst, deres legitimationsoplysninger er tilgængelige.
{ "$schema": "https://opencode.ai/config.json", "disabled_providers": ["openai", "gemini"]}Indstillingen disabled_providers accepterer en række udbyder-id’er. Når en udbyder er deaktiveret:
- Det vil ikke blive indlæst, omgivelserne miljøvariabler er indstillet.
- Den vil ikke blive indlæst, gennem API-nøgler er konfigureret kommandoen
/connect. - Udbyderens modeller vises ikke på modelvalgslisten.
Aktiverede udbydere
Du kan angive en tilladelsesliste over udbydere gennem muligheden enabled_providers. Når den er indstillet, vil kun de angivne udbydere blive aktiveret, og alle andre vil blive ignoreret.
{ "$schema": "https://opencode.ai/config.json", "enabled_providers": ["anthropic", "openai"]}Dette er nyttigt, når du vil begrænse OpenCode til kun at bruge specifikke udbydere i stedet for at deaktivere dem én efter én.
Hvis en udbyder optræder i både enabled_providers og disabled_providers, har disabled_providers prioritet for bagudkompatibilitet.
Eksperimentel
Nøglen experimental indeholder muligheder, der er under aktiv udvikling.
{ "$schema": "https://opencode.ai/config.json", "experimental": {}}Variabel
Du kan bruge variabelsubstitution i dine konfigurationsfiler til at referere til miljøvariabler og filindhold.
Env vars
Brug {env:VARIABLE_NAME} til at erstatte miljøvariabler:
{ "$schema": "https://opencode.ai/config.json", "model": "{env:OPENCODE_MODEL}", "provider": { "anthropic": { "models": {}, "options": { "apiKey": "{env:ANTHROPIC_API_KEY}" } } }}Hvis miljøvariablen ikke er indstillet, vil den blive erstattet med en tom streng.
Filer
Brug {file:path/to/file} til at erstatte indholdet af en fil:
{ "$schema": "https://opencode.ai/config.json", "instructions": ["./custom-instructions.md"], "provider": { "openai": { "options": { "apiKey": "{file:~/.secrets/openai-key}" } } }}Filstier kan være:
- I forhold til konfigurationsfilbiblioteket
- Eller absolutte stier, der starter med
/eller~
Disse er nyttige til:
- Opbevaring af følsomme data som API-nøgler i separate filer.
- Inklusiv store instruktionsfiler uden at rode i din konfiguration.
- Deling af fælles konfigurationsuddrag på tværs af flere konfigurationsfiler.