Building plugins
Membangun plugin
Plugin memperluas OpenClaw tanpa mengubah core. Sebuah plugin dapat menambahkan channel pesan, penyedia model, backend CLI lokal, alat agen, hook, penyedia media, atau kapabilitas lain yang dimiliki plugin.
Anda tidak perlu menambahkan plugin eksternal ke repositori OpenClaw. Publikasikan paket ke ClawHub dan pengguna memasangnya dengan:
openclaw plugins install clawhub:<package-name>Spesifikasi paket polos tetap dipasang dari npm selama transisi peluncuran. Gunakan
prefiks clawhub: saat Anda menginginkan resolusi ClawHub.
Persyaratan
- Gunakan Node 22.19+, Node 23.11+, atau Node 24+ dan manajer paket seperti
npmataupnpm. - Pahami modul TypeScript ESM.
- Untuk pekerjaan plugin bawaan di dalam repo, clone repositori dan jalankan
pnpm install. Pengembangan plugin dari checkout sumber hanya mendukung pnpm karena OpenClaw memuat plugin bawaan dari paket workspaceextensions/*.
Pilih bentuk plugin
Hubungkan OpenClaw ke platform perpesanan.
Tambahkan penyedia model, media, pencarian, pengambilan, ucapan, atau realtime.
Jalankan CLI AI lokal melalui fallback model OpenClaw.
Daftarkan alat agen.
Mulai cepat
Bangun plugin alat minimal dengan mendaftarkan satu alat agen wajib. Ini adalah bentuk plugin berguna yang paling singkat dan menunjukkan paket, manifest, entry point, dan bukti lokal.
Create package metadata
{"name": "@myorg/openclaw-my-plugin","version": "1.0.0","type": "module","dependencies": {"typebox": "1.1.39"},"peerDependencies": {"openclaw": ">=2026.3.24-beta.2"},"openclaw": {"extensions": ["./index.ts"],"compat": {"pluginApi": ">=2026.3.24-beta.2","minGatewayVersion": "2026.3.24-beta.2"},"build": {"openclawVersion": "2026.3.24-beta.2","pluginSdkVersion": "2026.3.24-beta.2"}}}{"id": "my-plugin","name": "My Plugin","description": "Adds a custom tool to OpenClaw","contracts": {"tools": ["my_tool"]},"activation": {"onStartup": true},"configSchema": {"type": "object","additionalProperties": false}}Plugin eksternal yang dipublikasikan sebaiknya mengarahkan entri runtime ke file JavaScript hasil build. Lihat entry point SDK untuk kontrak entry point lengkap.
Setiap plugin membutuhkan manifest, bahkan ketika tidak memiliki config. Alat runtime
harus muncul di contracts.tools agar OpenClaw dapat menemukan kepemilikan tanpa
memuat setiap runtime plugin secara bersemangat. Atur activation.onStartup
secara sengaja. Contoh ini dimulai saat startup Gateway.
Surface plugin tepercaya host juga dibatasi manifest dan memerlukan pengaktifan
eksplisit untuk plugin yang dipasang. Jika plugin yang dipasang mendaftarkan
api.registerAgentToolResultMiddleware(...), deklarasikan setiap target runtime di
contracts.agentToolResultMiddleware. Jika mendaftarkan
api.registerTrustedToolPolicy(...), deklarasikan setiap id kebijakan di
contracts.trustedToolPolicies. Deklarasi ini menjaga inspeksi saat pemasangan
dan pendaftaran runtime tetap selaras.
Untuk setiap field manifest, lihat Manifest plugin.
Register the tool
import { Type } from "typebox";import { definePluginEntry } from "openclaw/plugin-sdk/plugin-entry"; export default definePluginEntry({ id: "my-plugin", name: "My Plugin", description: "Adds a custom tool to OpenClaw", register(api) { api.registerTool({ name: "my_tool", description: "Echo one input value", parameters: Type.Object({ input: Type.String() }), async execute(_id, params) { return { content: [{ type: "text", text: `Got: ${params.input}` }], }; }, }); },});Gunakan definePluginEntry untuk plugin non-channel. Plugin channel menggunakan
defineChannelPluginEntry.
Test the runtime
Untuk plugin yang dipasang atau plugin eksternal, inspeksi runtime yang dimuat:
openclaw plugins inspect my-plugin --runtime --jsonJika plugin mendaftarkan perintah CLI, jalankan juga perintah tersebut. Misalnya,
perintah demo sebaiknya memiliki bukti eksekusi seperti
openclaw demo-plugin ping.
Untuk plugin bawaan dalam repositori ini, OpenClaw menemukan paket plugin
checkout sumber dari workspace extensions/*. Jalankan pengujian tertarget
terdekat:
pnpm test -- extensions/my-plugin/pnpm checkTest the package install
Sebelum memublikasikan plugin yang siap dipaketkan, uji bentuk pemasangan yang sama dengan
yang akan diterima pengguna. Pertama tambahkan langkah build, arahkan entri runtime seperti
openclaw.extensions ke JavaScript hasil build seperti ./dist/index.js, dan pastikan
npm pack menyertakan output dist/ tersebut. Entri sumber TypeScript hanya
untuk checkout sumber dan jalur pengembangan lokal.
Lalu paketkan plugin dan pasang tarball dengan npm-pack::
npm pack --pack-destination /tmpopenclaw plugins install npm-pack:/tmp/<plugin-package>.tgz --forceopenclaw plugins inspect my-plugin --runtime --jsonnpm-pack: menggunakan proyek npm per-plugin terkelola milik OpenClaw, sehingga menangkap
kesalahan dependensi runtime yang dapat tersembunyi oleh pengujian checkout sumber. Ini membuktikan
bentuk paket dan dependensi, bukan kepercayaan resmi yang tertaut katalog.
Impor runtime harus berada di dependencies atau optionalDependencies;
dependensi yang hanya tersisa di devDependencies tidak akan dipasang untuk proyek
runtime terkelola.
Jangan gunakan pemasangan arsip/path mentah sebagai bukti akhir untuk perilaku plugin resmi atau dengan hak istimewa. Sumber mentah berguna untuk debugging lokal, tetapi tidak membuktikan jalur dependensi yang sama seperti pemasangan npm atau ClawHub. Jika plugin Anda bergantung pada status plugin resmi tepercaya, tambahkan bukti kedua melalui pemasangan resmi berbasis katalog atau jalur paket yang dipublikasikan yang mencatat kepercayaan resmi. Lihat Resolusi dependensi plugin untuk detail root pemasangan dan kepemilikan dependensi.
Publish
Validasi paket sebelum memublikasikan:
clawhub package publish your-org/your-plugin --dry-runclawhub package publish your-org/your-pluginCuplikan ClawHub kanonis berada di docs/snippets/plugin-publish/.
Install
Pasang paket yang dipublikasikan melalui ClawHub:
openclaw plugins install clawhub:your-org/your-pluginMendaftarkan alat
Alat dapat bersifat wajib atau opsional. Alat wajib selalu tersedia ketika plugin diaktifkan. Alat opsional memerlukan opt-in pengguna.
register(api) { api.registerTool( { name: "workflow_tool", description: "Run a workflow", parameters: Type.Object({ pipeline: Type.String() }), async execute(_id, params) { return { content: [{ type: "text", text: params.pipeline }] }; }, }, { optional: true }, );}Setiap alat yang didaftarkan dengan api.registerTool(...) juga harus dideklarasikan dalam
manifest plugin:
{ "contracts": { "tools": ["workflow_tool"] }, "toolMetadata": { "workflow_tool": { "optional": true } }}Pengguna opt in dengan tools.allow:
{ tools: { allow: ["workflow_tool"] }, // or ["my-plugin"] for all tools from one plugin}Alat opsional mengontrol apakah alat diekspos ke model. Gunakan permintaan izin plugin ketika alat atau hook harus meminta persetujuan setelah model memilihnya dan sebelum aksi berjalan.
Gunakan alat opsional untuk efek samping, binary yang tidak biasa, atau kapabilitas yang
sebaiknya tidak diekspos secara default. Nama alat tidak boleh bentrok dengan alat core;
konflik dilewati dan dilaporkan dalam diagnostik plugin. Pendaftaran yang salah bentuk,
termasuk deskriptor alat tanpa parameters, dilewati dan dilaporkan dengan
cara yang sama. Alat terdaftar adalah fungsi bertipe yang dapat dipanggil model
setelah pemeriksaan kebijakan dan allowlist lolos.
Factory alat menerima objek konteks yang disediakan runtime. Gunakan ctx.activeModel
ketika alat perlu mencatat log, menampilkan, atau beradaptasi dengan model aktif untuk
turn saat ini. Objek dapat menyertakan provider, modelId, dan modelRef. Perlakukan sebagai
metadata runtime informasional, bukan sebagai batas keamanan terhadap operator lokal,
kode plugin yang dipasang, atau runtime OpenClaw yang dimodifikasi. Alat lokal sensitif
tetap harus memerlukan opt-in plugin atau operator yang eksplisit dan gagal tertutup
ketika metadata model aktif hilang atau tidak sesuai.
Manifest mendeklarasikan kepemilikan dan discovery; eksekusi tetap memanggil implementasi alat
terdaftar yang aktif. Jaga toolMetadata.<tool>.optional: true
tetap selaras dengan api.registerTool(..., { optional: true }) agar OpenClaw dapat menghindari
memuat runtime plugin tersebut sampai alat secara eksplisit masuk allowlist.
Konvensi impor
Impor dari subpath SDK yang terfokus:
Jangan impor dari barrel root yang sudah deprecated:
Di dalam paket plugin Anda, gunakan file barrel lokal seperti api.ts dan
runtime-api.ts untuk impor internal. Jangan impor plugin Anda sendiri melalui
path SDK. Helper khusus penyedia sebaiknya tetap berada di paket penyedia kecuali
seam tersebut benar-benar generik.
Metode RPC Gateway kustom adalah entry point lanjutan. Pertahankan pada
prefiks khusus plugin; namespace admin core seperti config.*,
exec.approvals.*, operator.admin.*, wizard.*, dan update.* tetap dicadangkan
dan di-resolve ke operator.admin. Bridge
openclaw/plugin-sdk/gateway-method-runtime dicadangkan untuk route HTTP plugin
yang mendeklarasikan contracts.gatewayMethodDispatch: ["authenticated-request"].
Untuk peta impor lengkap, lihat Gambaran umum SDK plugin.
Checklist pra-pengajuan
OPENCLAW_DOCS_MARKER:calloutOpen:Q2hlY2s
package.json memiliki metadata openclaw yang benar
OPENCLAW_DOCS_MARKER:calloutClose:
OPENCLAW_DOCS_MARKER:calloutOpen:Q2hlY2s Manifest openclaw.plugin.json ada dan valid OPENCLAW_DOCS_MARKER:calloutClose:
OPENCLAW_DOCS_MARKER:calloutOpen:Q2hlY2s
Entry point menggunakan defineChannelPluginEntry atau definePluginEntry
OPENCLAW_DOCS_MARKER:calloutClose:
OPENCLAW_DOCS_MARKER:calloutOpen:Q2hlY2s
Semua impor menggunakan path plugin-sdk/<subpath> yang terfokus
OPENCLAW_DOCS_MARKER:calloutClose: