Wtyczki
Napisz własną wtyczkę, aby rozszerzyć opencode.
Wtyczki umożliwiające wyłączenie opencode poprzez podjęcie różnych zdarzeń i zachowanie. Można utworzyć wtyczkę, aby sprawdzić nowe funkcje, integrować się z usługami lub sprawdzaniem zachowania opencode.
Aby znaleźć się z przykładami, przejrzyj wtyczki utworzone przez społeczność.
użyj wtyczki
Istnieją dwa sposoby ładowania wtyczek.
Z plików lokalnych
Miejsce plików JavaScript lub TypeScript w katalogu wtyczki.
.opencode/plugins/- Wtyczki na poziomie projektu~/.config/opencode/plugins/- Wtyczki globalne
Pliki w tych katalogach są automatycznie ładowane podczas uruchamiania.
Z npm
szczegółowy pakiet npm w pliku konfiguracyjnym.
{ "$schema": "https://opencode.ai/config.json", "plugin": ["opencode-helicone-session", "opencode-wakatime", "@my-org/custom-plugin"]}Obsługiwane są zarówno pakiety zwykłe, jak i pakiety npm o określonym zakresie.
Przeglądaj dostępną wtyczkę w ekosystemie.
Sposób instalacji wtyczek
wtyczki npm są instalowane automatycznie przy użyciu Bun podczas uruchamiania. Pakiety i ich zależności są buforowane w ~/.cache/opencode/node_modules/.
Wtyczki lokalne są ładowane bezpośrednio z katalogu wtyczek. Aby uzyskać dostęp do zewnętrznych pakietów, musisz zainstalować package.json w swoim katalogu konfiguracyjnym (zobacz Zależności) lub opublikować wtyczkę w npm i dodaj ją do swojej konfiguracji.
Załaduj zamówienie
Wtyczki są ładowane ze wszystkich źródeł, a wszystkie hooki napisane po kolei. Kolejność ładowania do:
- Konfiguracja globalna (
~/.config/opencode/opencode.json) - Konfiguracja projektu (
opencode.json) - Globalny katalog wtyczek (
~/.config/opencode/plugins/) - Katalog wtyczek projektu (
.opencode/plugins/)
Zduplikowane pakiety npm o tej samej nazwie i wersji są ładowane raz. Równie ważny jest dostęp lokalny i zewnętrzny npm o dodatkowych nazwach, które są zewnętrzne.
Utwórz wtyczkę
Wtyczka do moduł JavaScript/TypeScript, który eksportuje jeden lub więcej wtyczek funkcje. dostępna funkcja korzystania z obiektu kontekstu i głównego obiektu hooks.
Zależności
Lokalne narzędzie i narzędzie, które można wykorzystać z zewnętrznych pakietów npm. Dodaj package.json do swojego katalogu konfiguracyjnego z zależnościami.
{ "dependencies": { "shescape": "^2.1.0" }}opencode uruchomienie bun install przy uruchomieniu, aby je uruchomić. Twoje dodatkowe funkcje będą dostępne po zaimportowaniu.
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) } }, }}Podstawowa struktura
export const MyPlugin = async ({ project, client, $, directory, worktree }) => { console.log("Plugin initialized!")
return { // Hook implementations go here }}Funkcja dostępu do:
project: Aktualne informacje o projekcie.directory: Bieżący katalog roboczy.worktree: Ścieżka eksploatacyjna Git.client: Klient SDK z opencode do sztucznej inteligencji.$: API obudowy Buna do wykonywania oprogramowania.
Obsługa TypeScriptu
W przypadku wtyczek TypeScript możesz importować typy z pakietu wtyczek:
import type { Plugin } from "@opencode-ai/plugin"
export const MyPlugin: Plugin = async ({ project, client, $, directory, worktree }) => { return { // Type-safe hook implementations }}Wydarzenia
Wtyczki mogą subskrybować zdarzenia, jak zastosować poniżej sekcji Przykłady. Oto lista różnych działań.
Wydarzenia dowodzenia
command.executed
Plik Wydarzenia
file.editedfile.watcher.updated
Wydarzenia instalacyjne
installation.updated
Wydarzenia LSP
lsp.client.diagnosticslsp.updated
Wydarzenia w wiadomościach
message.part.removedmessage.part.updatedmessage.removedmessage.updated
Wydarzenia związane z uprawnieniami
permission.askedpermission.replied
Wydarzenia serwerowe
server.connected
Wydarzenia sesyjne
session.createdsession.compactedsession.deletedsession.diffsession.errorsession.idlesession.statussession.updated
Wydarzenia do zrobienia
todo.updated
Wydarzenia shell
shell.env
Wydarzenia narzędziowe
tool.execute.aftertool.execute.before
Wydarzenia TUI
tui.prompt.appendtui.command.executetui.toast.show
Przykłady
Oto kilka dostępnych wtyczek, które można udostępnić do opencode.
Wysyłaj powiadomienia
Wysyłaj powiadomienia, gdy wystąpią określone zdarzenia:
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"'` } }, }}Używamy osascript do uruchamiania AppleScript na macOS. Tutaj możesz przejść do wysyłania pozostałości.
ochrona .env
Zablokuj opencode czytanie plików .env:
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") } }, }}Wstrzyknij zmienne środowiskowe
Wstrzyknij zmienne konsekwencje dla wszystkich wykonań (narzędzia AI i terminale użytkownika):
export const InjectEnvPlugin = async () => { return { "shell.env": async (input, output) => { output.env.MY_API_KEY = "secret" output.env.PROJECT_ROOT = input.cwd }, }}Niestandardowe narzędzia
Wtyczki mogą również dodawać niestandardowe narzędzia do 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})` }, }), }, }}Pomocnik tool tworzy narzędzie użytkowe, które może wywołać kod opencode. Pobierane schematu Zoda i narzędzie wyszukiwania za pomocą:
description: Co robi do narzędziaargs: Schemat Zoda dla narzędzi argumentówexecute: Funkcja uruchamiania po wywołaniu narzędzia
Twoje narzędzie będzie dostępne dla otwartego kodu wraz z narzędziami użytkowymi.
Wycięcie lasu
użyj client.app.log() zamiast console.log do rejestracji strukturalnego:
export const MyPlugin = async ({ client }) => { await client.app.log({ body: { service: "my-plugin", level: "info", message: "Plugin initialized", extra: { foo: "bar" }, }, })}Poziomy: debug, info, warn, error. Aby uzyskać szczegółowe informacje, zobacz dokumentację pakietu SDK.
Haki zagęszczające
Dostosuj kontekst dołączony podczas kompaktowania sesji:
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`) }, }}Hak experimental.session.compacting jest uruchamiany, zanim LLM wygeneruje podsumowanie kontynuacji. go, aby wstrzyknąć kontekst kontekstu dla domeny, której nie dostrzeżono przez domyślny monit o zagęszczenie.
Można także umieścić kompletny monit o zagęszczenie, ustawiając 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.` }, }}Gdy urządzenie jest output.prompt, jest całkowicie dostępne na domyślnym monit o zagęszczanie. Tablica output.context jest w tym przypadku poniesiona.