Plugins
Skriv dine egne plugins for å utvide opencode.
Plugins lar deg utvide OpenCode ved å koble til ulike arrangementer og tilpasse atferd. Du kan lage plugins for å legge til nye funksjoner, integrere med eksterne tjenester eller endre standardoppførselen til OpenCode.
For eksempler, sjekk ut plugins opprettet av fellesskapet.
Bruk en plugin
Det er to måter å laste inn plugins.
Fra lokale filer
Plasser JavaScript- eller TypeScript-filer i plugin-katalogen.
.opencode/plugins/- Programtillegg på prosjektnivå~/.config/opencode/plugins/- Globale plugins
Filer i disse katalogene lastes automatisk ved oppstart.
Fra npm
Spesifiser npm-pakker i konfigurasjonsfilen.
{ "$schema": "https://opencode.ai/config.json", "plugin": ["opencode-helicone-session", "opencode-wakatime", "@my-org/custom-plugin"]}Både vanlige og scoped npm-pakker støttes.
Bla gjennom tilgjengelige plugins i økosystemet.
Hvordan plugins installeres
npm-plugins installeres automatisk ved hjelp av Bun ved oppstart. Pakker og deres avhengigheter er bufret i ~/.cache/opencode/node_modules/.
Lokale plugins lastes direkte fra plugin-katalogen. For å bruke eksterne pakker, må du opprette en package.json i konfigurasjonskatalogen din (se Dependencies), eller publisere plugin-en til npm og legg den til i konfigurasjonen din.
Lasterekkefølge
Plugins lastes inn fra alle kilder og alle kroker kjøres i rekkefølge. Lastrekkefølgen er:
- Global konfigurasjon (
~/.config/opencode/opencode.json) - Prosjektkonfigurasjon (
opencode.json) - Global plugin-katalog (
~/.config/opencode/plugins/) - Prosjektpluginkatalog (
.opencode/plugins/)
Dupliserte npm-pakker med samme navn og versjon lastes inn én gang. Imidlertid lastes en lokal plugin og en npm plugin med lignende navn begge separat.
Opprett en plugin
En plugin er en JavaScript/TypeScript-modul som eksporterer en eller flere plugin-moduler funksjoner. Hver funksjon mottar et kontekstobjekt og returnerer et krokobjekt.
Avhengigheter
Lokale plugins og tilpassede verktøy kan bruke eksterne npm-pakker. Legg til en package.json til konfigurasjonskatalogen med avhengighetene du trenger.
{ "dependencies": { "shescape": "^2.1.0" }}OpenCode kjører bun install ved oppstart for å installere disse. Programtilleggene og verktøyene dine kan deretter importere dem.
import { escape } from "shescape"
export const MyPlugin = async (ctx) => { return { "tool.execute.before": async (input, output) => { if (input.tool === "bash") { output.args.command = escape(output.args.command) } }, }}Grunnleggende struktur
export const MyPlugin = async ({ project, client, $, directory, worktree }) => { console.log("Plugin initialized!")
return { // Hook implementations go here }}Plugin-funksjonen mottar:
project: Gjeldende prosjektinformasjon.directory: Gjeldende arbeidskatalog.worktree: Git-arbeidstrebanen.client: En OpenCode SDK klient for samhandling med AI.$: Buns shell API for å utføre kommandoer.
TypeScript-støtte
For TypeScript-plugins kan du importere typer fra plugin-pakken:
import type { Plugin } from "@opencode-ai/plugin"
export const MyPlugin: Plugin = async ({ project, client, $, directory, worktree }) => { return { // Type-safe hook implementations }}Hendelser
Plugins kan abonnere på arrangementer som vist nedenfor i Eksempler-delen. Her er en liste over de forskjellige arrangementene som er tilgjengelige.
Kommandohendelser
command.executed
Filhendelser
file.editedfile.watcher.updated
Installasjonshendelser
installation.updated
LSP Hendelser
lsp.client.diagnosticslsp.updated
Meldingshendelser
message.part.removedmessage.part.updatedmessage.removedmessage.updated
Tillatelseshendelser
permission.askedpermission.replied
Serverhendelser
server.connected
Sesjonshendelser
session.createdsession.compactedsession.deletedsession.diffsession.errorsession.idlesession.statussession.updated
Todo-hendelser
todo.updated
Shell-hendelser
shell.env
Verktøyhendelser
tool.execute.aftertool.execute.before
TUI Hendelser
tui.prompt.appendtui.command.executetui.toast.show
Eksempler
Her er noen eksempler på plugins du kan bruke for å utvide OpenCode.
Send varsler
Send varsler når visse hendelser inntreffer:
export const NotificationPlugin = async ({ project, client, $, directory, worktree }) => { return { event: async ({ event }) => { // Send notification on session completion if (event.type === "session.idle") { await $`osascript -e 'display notification "Session completed!" with title "opencode"'` } }, }}Vi bruker osascript for å kjøre AppleScript på macOS. Her bruker vi den til å sende varsler.
.env-beskyttelse
Hindre OpenCode fra å lese .env filer:
export const EnvProtection = async ({ project, client, $, directory, worktree }) => { return { "tool.execute.before": async (input, output) => { if (input.tool === "read" && output.args.filePath.includes(".env")) { throw new Error("Do not read .env files") } }, }}Injiser miljøvariabler
Injiser miljøvariabler i all shell-utførelse (AI-verktøy og brukerterminaler):
export const InjectEnvPlugin = async () => { return { "shell.env": async (input, output) => { output.env.MY_API_KEY = "secret" output.env.PROJECT_ROOT = input.cwd }, }}Egendefinerte verktøy
Plugins kan også legge til egendefinerte verktøy til OpenCode:
import { type Plugin, tool } from "@opencode-ai/plugin"
export const CustomToolsPlugin: Plugin = async (ctx) => { return { tool: { mytool: tool({ description: "This is a custom tool", args: { foo: tool.schema.string(), }, async execute(args, context) { const { directory, worktree } = context return `Hello ${args.foo} from ${directory} (worktree: ${worktree})` }, }), }, }}tool-hjelperen lager et tilpasset verktøy som OpenCode kan kalle. Den tar en Zod-skjemafunksjon og returnerer en verktøydefinisjon med:
description: Hva verktøyet gjørargs: Zod-skjema for verktøyets argumenterexecute: Funksjon som kjører når verktøyet kalles
Dine egendefinerte verktøy vil være tilgjengelige for å OpenCode sammen med innebygde verktøy.
Logging
Bruk client.app.log() i stedet for console.log for strukturert logging:
export const MyPlugin = async ({ client }) => { await client.app.log({ body: { service: "my-plugin", level: "info", message: "Plugin initialized", extra: { foo: "bar" }, }, })}Nivåer: debug, info, warn, error. Se SDK dokumentasjon for detaljer.
Komprimeringskroker
Tilpass konteksten inkludert når en økt komprimeres:
import type { Plugin } from "@opencode-ai/plugin"
export const CompactionPlugin: Plugin = async (ctx) => { return { "experimental.session.compacting": async (input, output) => { // Inject additional context into the compaction prompt output.context.push(`## Custom Context
Include any state that should persist across compaction:- Current task status- Important decisions made- Files being actively worked on`) }, }}experimental.session.compacting-kroken avfyres før LLM genererer et fortsettelsessammendrag. Bruk den til å injisere domenespesifikk kontekst som standard komprimeringsforespørsel ville gå glipp av.
Du kan også erstatte komprimeringsmeldingen helt ved å stille inn output.prompt:
import type { Plugin } from "@opencode-ai/plugin"
export const CustomCompactionPlugin: Plugin = async (ctx) => { return { "experimental.session.compacting": async (input, output) => { // Replace the entire compaction prompt output.prompt = `You are generating a continuation prompt for a multi-agent swarm session.
Summarize:1. The current task and its status2. Which files are being modified and by whom3. Any blockers or dependencies between agents4. The next steps to complete the work
Format as a structured prompt that a new agent can use to resume work.` }, }}Når output.prompt er angitt, erstatter den standard komprimeringsprompt fullstendig. output.context-matrisen ignoreres i dette tilfellet.