packages/web/src/content/docs/bs/plugins.mdx
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.
Postoje dva načina za učitavanje dodataka.
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.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.
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.
Dodaci se učitavaju iz svih izvora i svi zakačnjaci rade u nizu. Redoslijed učitavanja je:
~/.config/opencode/opencode.json)opencode.json)~/.config/opencode/plugins/).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.Dodatak je JavaScript/TypeScript modul koji izvozi jedan ili više dodataka funkcije. Svaka funkcija prima objekt konteksta i vraća hooks objekt.
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)
}
},
}
}
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.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
}
}
Dodaci se mogu pretplatiti na događaje kao što je prikazano ispod u odjeljku Primjeri. Evo liste različitih dostupnih događaja.
command.executedfile.editedfile.watcher.updatedinstallation.updatedlsp.client.diagnosticslsp.updatedmessage.part.removedmessage.part.updatedmessage.removedmessage.updatedpermission.askedpermission.repliedserver.connectedsession.createdsession.compactedsession.deletedsession.diffsession.errorsession.idlesession.statussession.updatedtodo.updatedshell.envtool.execute.aftertool.execute.beforetui.prompt.appendtui.command.executetui.toast.showEvo nekoliko primjera dodataka koje možete koristiti za proširenje OpenCode.
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.
:::note
Ako alat dodatka koristi isto ime kao ugrađeni alat, alat dodatka ima prednost.
:::
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 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
},
}
}
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.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.
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 status
2. Which files are being modified and by whom
3. Any blockers or dependencies between agents
4. 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.