Plugins
Menambahkan kapabilitas (panduan kontributor)
Gunakan ini saat OpenClaw membutuhkan domain bersama baru seperti 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 saat semua hal berikut benar:
- Lebih dari satu vendor secara masuk akal dapat mengimplementasikannya.
- Channel, tool, atau Plugin fitur harus dapat mengonsumsinya tanpa peduli pada 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 pendaftaran 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 dihadapi operator dan model kepemilikan.
Apa ditempatkan di mana
Inti:
- Tipe permintaan/respons.
- Registry penyedia + 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.
- Pendaftaran implementasi kapabilitas.
Plugin fitur/channel:
- Memanggil
api.runtime.*atau helperplugin-sdk/*-runtimeyang sesuai. - Tidak pernah memanggil implementasi vendor secara langsung.
Seam penyedia dan harness
Gunakan hook penyedia saat perilaku termasuk dalam kontrak penyedia model, bukan loop agen generik. Contohnya mencakup parameter permintaan khusus penyedia setelah pemilihan transport, preferensi profil autentikasi, overlay prompt, dan perutean fallback lanjutan setelah failover model/profil.
Gunakan hook harness agen saat perilaku termasuk dalam runtime yang mengeksekusi satu giliran. Harness dapat mengklasifikasikan hasil percobaan yang berhasil tetapi tidak dapat digunakan, seperti respons kosong, hanya penalaran, atau hanya perencanaan, sehingga kebijakan fallback model luar dapat membuat keputusan coba ulang.
Jaga kedua seam tetap sempit:
- Inti memiliki kebijakan coba ulang/fallback.
- Plugin penyedia memiliki petunjuk permintaan/autentikasi/perutean khusus penyedia.
- Plugin harness memiliki klasifikasi percobaan khusus runtime.
- Plugin pihak ketiga mengembalikan petunjuk, bukan mutasi langsung pada status 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 perutean analisis visi:
agents.defaults.imageModelmenganalisis gambar.agents.defaults.imageGenerationModelmenghasilkan gambar.
Pisahkan keduanya agar fallback dan kebijakan tetap eksplisit.
Checklist tinjauan
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 menamai 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 — referensi peta impor dan API pendaftaran.
- Membuat Skills — permukaan kontributor pendamping.