Building plugins
Menambahkan kapabilitas (panduan kontributor)
Gunakan ini ketika OpenClaw membutuhkan domain bersama baru seperti embedding, pembuatan gambar, pembuatan video, atau area fitur masa depan yang didukung vendor.
Aturannya:
- plugin = batas kepemilikan
- kapabilitas = kontrak inti bersama
Jangan mulai dengan menghubungkan vendor langsung ke channel atau tool. Mulailah dengan mendefinisikan kapabilitas.
Kapan membuat kapabilitas
Buat kapabilitas baru ketika semua hal berikut benar:
- Lebih dari satu vendor secara masuk akal dapat mengimplementasikannya.
- Channel, tool, atau plugin fitur harus dapat menggunakannya tanpa peduli tentang vendornya.
- Inti perlu memiliki perilaku fallback, kebijakan, konfigurasi, atau pengiriman.
Jika pekerjaannya hanya untuk vendor dan belum ada kontrak bersama, berhenti dan definisikan kontraknya terlebih dahulu.
Urutan standar
- Definisikan kontrak inti bertipe.
- Tambahkan registrasi plugin untuk kontrak tersebut.
- Tambahkan helper runtime bersama.
- Hubungkan satu plugin vendor nyata sebagai bukti.
- Pindahkan konsumen fitur/channel ke helper runtime.
- Tambahkan pengujian kontrak.
- Dokumentasikan konfigurasi yang terlihat oleh operator dan model kepemilikannya.
Apa ditempatkan di mana
Inti:
- Tipe permintaan/respons.
- Registry provider + resolusi.
- Perilaku fallback.
- Skema konfigurasi dengan metadata dokumentasi
title/descriptionyang dipropagasikan pada node objek bertingkat, wildcard, item array, dan komposisi. - Permukaan helper runtime.
Plugin vendor:
- Panggilan API vendor.
- Penanganan autentikasi vendor.
- Normalisasi permintaan khusus vendor.
- Registrasi implementasi kapabilitas.
Plugin fitur/channel:
- Memanggil
api.runtime.*atau helperplugin-sdk/*-runtimeyang sesuai. - Tidak pernah memanggil implementasi vendor secara langsung.
Seam provider dan harness
Gunakan hook provider ketika perilaku tersebut termasuk dalam kontrak provider model, bukan loop agen generik. Contohnya mencakup parameter permintaan khusus provider setelah pemilihan transport, preferensi profil autentikasi, overlay prompt, dan routing fallback lanjutan setelah failover model/profil.
Gunakan hook harness agen ketika perilaku tersebut termasuk dalam runtime yang mengeksekusi sebuah giliran. Harness dapat mengklasifikasikan hasil protokol eksplisit seperti output kosong, reasoning tanpa output terlihat, atau rencana terstruktur tanpa jawaban akhir agar kebijakan fallback model luar dapat membuat keputusan retry.
Jaga kedua seam tetap sempit:
- Inti memiliki kebijakan retry/fallback.
- Plugin provider memiliki petunjuk permintaan/autentikasi/routing khusus provider.
- Plugin harness memiliki klasifikasi percobaan khusus runtime.
- Plugin pihak ketiga mengembalikan petunjuk, bukan mutasi langsung pada state inti.
Checklist file
Untuk kapabilitas baru, perkirakan menyentuh area berikut:
src/<capability>/types.tssrc/<capability>/...registry/runtime.tssrc/plugins/types.tssrc/plugins/registry.tssrc/plugins/captured-registration.tssrc/plugins/contracts/registry.tssrc/plugins/runtime/types-core.tssrc/plugins/runtime/index.tssrc/plugin-sdk/<capability>.tssrc/plugin-sdk/<capability>-runtime.ts- Satu atau beberapa paket plugin bundel.
- Konfigurasi, dokumentasi, pengujian.
Contoh kerja: pembuatan gambar
Pembuatan gambar mengikuti bentuk standar:
- Inti mendefinisikan
ImageGenerationProvider. - Inti mengekspos
registerImageGenerationProvider(...). - Inti mengekspos
runtime.imageGeneration.generate(...). - Plugin
openai,google,fal, danminimaxmendaftarkan implementasi yang didukung vendor. - Vendor masa depan mendaftarkan kontrak yang sama tanpa mengubah channel/tool.
Kunci konfigurasi sengaja dipisahkan dari routing analisis visi:
agents.defaults.imageModelmenganalisis gambar.agents.defaults.imageGenerationModelmenghasilkan gambar.
Jaga keduanya tetap terpisah agar fallback dan kebijakan tetap eksplisit.
Provider embedding
Gunakan embeddingProviders untuk provider embedding vektor yang dapat digunakan ulang. Kontrak ini sengaja lebih luas daripada memori: tool, pencarian, retrieval, importer, atau plugin fitur masa depan dapat menggunakan embedding tanpa bergantung pada mesin memori.
Pencarian memori dapat menggunakan embeddingProviders generik. Kontrak lama memoryEmbeddingProviders adalah kompatibilitas yang sudah deprecated sementara provider khusus memori yang ada bermigrasi; provider embedding baru yang dapat digunakan ulang harus menggunakan embeddingProviders.
Checklist review
Sebelum mengirim kapabilitas baru, verifikasi:
- Tidak ada channel/tool yang mengimpor kode vendor secara langsung.
- Helper runtime adalah jalur bersama.
- Setidaknya satu pengujian kontrak menegaskan kepemilikan bundel.
- Dokumentasi konfigurasi menyebutkan model/kunci konfigurasi baru.
- Dokumentasi plugin menjelaskan batas kepemilikan.
Jika sebuah PR melewati lapisan kapabilitas dan meng-hardcode perilaku vendor ke dalam channel/tool, kembalikan dan definisikan kontraknya terlebih dahulu.
Terkait
- Internal plugin — model kapabilitas, kepemilikan, pipeline pemuatan, helper runtime.
- Membangun plugin — tutorial plugin pertama.
- Ikhtisar SDK — peta impor dan referensi API registrasi.
- Membuat skills — permukaan kontributor pendamping.