Plugins
Napišite vlastite dodatke za proširenje OpenCode.
Dodaci vam omogućavaju da proširite OpenCode spajanjem na različite događaje i prilagođavanjem ponašanja. Možete kreirati dodatke za dodavanje novih funkcija, integraciju sa eksternim uslugama ili izmenu zadanog ponašanja OpenCode. Za primjere, pogledajte plugins kreirane od strane zajednice.
Koristite dodatak
Postoje dva načina za učitavanje dodataka.
Iz lokalnih datoteka
Postavite JavaScript ili TypeScript datoteke u direktorij dodataka.
.opencode/plugins/- Dodaci na nivou projekta~/.config/opencode/plugins/- Globalni dodaci Datoteke u ovim direktorijumima se automatski učitavaju pri pokretanju.
Od npm
Navedite npm pakete u vašoj konfiguracijskoj datoteci.
{ "$schema": "https://opencode.ai/config.json", "plugin": ["opencode-helicone-session", "opencode-wakatime", "@my-org/custom-plugin"]}Podržani su i regularni i npm paketi sa opsegom. Pregledajte dostupne dodatke u ecosystem.
Kako se instaliraju dodaci
npm dodaci se instaliraju automatski pomoću Bun pri pokretanju. Paketi i njihove zavisnosti su keširani u ~/.cache/opencode/node_modules/.
Lokalni dodaci se učitavaju direktno iz direktorija dodataka. Da biste koristili vanjske pakete, morate kreirati package.json unutar svog konfiguracijskog direktorija (pogledajte Zavisnosti) ili objaviti dodatak na npm i dodati ga u svoju konfiguraciju.
Učitaj redoslijed
Dodaci se učitavaju iz svih izvora i svi zakačnjaci rade u nizu. Redoslijed učitavanja je:
- Globalna konfiguracija (
~/.config/opencode/opencode.json) - Konfiguracija projekta (
opencode.json) - Globalni direktorij dodataka (
~/.config/opencode/plugins/) - Direktorij dodataka projekta (
.opencode/plugins/) Duplicirani npm paketi sa istim imenom i verzijom se učitavaju jednom. Međutim, lokalni dodatak i npm dodatak sa sličnim nazivima se učitavaju odvojeno.
Kreirajte dodatak
Dodatak je JavaScript/TypeScript modul koji izvozi jedan ili više dodataka funkcije. Svaka funkcija prima objekt konteksta i vraća hooks objekt.
Zavisnosti
Lokalni dodaci i prilagođeni alati mogu koristiti vanjske npm pakete. Dodajte package.json u svoj konfiguracijski direktorij sa zavisnostima koje su vam potrebne.
{ "dependencies": { "shescape": "^2.1.0" }}OpenCode pokreće bun install pri pokretanju da ih instalira. Vaši dodaci i alati ih zatim mogu uvesti.
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) } }, }}Osnovna struktura
export const MyPlugin = async ({ project, client, $, directory, worktree }) => { console.log("Plugin initialized!")
return { // Hook implementations go here }}Funkcija dodatka prima:
project: Trenutne informacije o projektu.directory: Trenutni radni direktorij.worktree: Putanja git radnog stabla.client: Opencode SDK klijent za interakciju sa AI.$: Bun’s shell API za izvršavanje naredbi.
Podrška za TypeScript
Za TypeScript dodatke, možete uvesti tipove iz paketa dodataka:
import type { Plugin } from "@opencode-ai/plugin"
export const MyPlugin: Plugin = async ({ project, client, $, directory, worktree }) => { return { // Type-safe hook implementations }}Događaji
Dodaci se mogu pretplatiti na događaje kao što je prikazano ispod u odjeljku Primjeri. Evo liste različitih dostupnih događaja.
Komandni događaji
command.executed
Događaji datoteka
file.editedfile.watcher.updated
Instalacijski događaji
installation.updated
LSP događaji
lsp.client.diagnosticslsp.updated
Poruka Događaji
message.part.removedmessage.part.updatedmessage.removedmessage.updated
Događaji dozvole
permission.askedpermission.replied
Serverski događaji
server.connected
Događaji sesije
session.createdsession.compactedsession.deletedsession.diffsession.errorsession.idlesession.statussession.updated
Todo događaji
todo.updated
Shell događaji
shell.env
Alat Događaji
tool.execute.aftertool.execute.before
TUI događaji
tui.prompt.appendtui.command.executetui.toast.show
Primjeri
Evo nekoliko primjera dodataka koje možete koristiti za proširenje OpenCode.
Šalji obavještenja
Pošaljite obavještenja kada se dogode određeni događaji:
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"'` } }, }}Koristimo osascript za pokretanje AppleScript-a na macOS-u. Ovdje ga koristimo za slanje obavještenja.
.env zaštita
Spriječite opencode da čita .env fajlove:
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") } }, }}Ubacite varijable okruženja
Ubacite varijable okruženja u sva izvršavanja ljuske (AI alati i korisnički terminali):
export const InjectEnvPlugin = async () => { return { "shell.env": async (input, output) => { output.env.MY_API_KEY = "secret" output.env.PROJECT_ROOT = input.cwd }, }}Prilagođeni alati
Dodaci također mogu dodati prilagođene alate u 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})` }, }), }, }}Pomoćnik tool kreira prilagođeni alat koji opencode može pozvati. Uzima funkciju Zod sheme i vraća definiciju alata sa:
description: Šta alat radiargs: Zod šema za argumente alataexecute: Funkcija koja se pokreće kada se pozove alat Vaši prilagođeni alati će biti dostupni za opencode zajedno sa ugrađenim alatima.
Logging
Koristite client.app.log() umjesto console.log za strukturirano bilježenje:
export const MyPlugin = async ({ client }) => { await client.app.log({ body: { service: "my-plugin", level: "info", message: "Plugin initialized", extra: { foo: "bar" }, }, })}Nivoi su: debug, info, warn, error. Pogledajte SDK dokumentaciju za detalje.
Kuke za sabijanje
Prilagodite kontekst uključen kada se sesija zbije:
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 kuka se aktivira prije nego što LLM generira sažetak nastavka. Koristite ga za ubacivanje konteksta specifičnog za domenu koji bi zadani prompt za sažimanje propustio.
Također možete u potpunosti zamijeniti prompt za sabijanje postavljanjem 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.` }, }}Kada je output.prompt postavljen, on u potpunosti zamjenjuje zadani prompt za sažimanje. Niz output.context se zanemaruje u ovom slučaju.