Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Ini adalah panduan kontributor untuk developer inti OpenClaw. Jika Anda
membangun Plugin eksternal, lihat Membangun Plugin
sebagai gantinya. Untuk referensi arsitektur mendalam (model kapabilitas, kepemilikan,
pipeline pemuatan, helper runtime), lihat Internal Plugin.
- Plugin = batas kepemilikan
- kapabilitas = kontrak inti bersama
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.
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.
- Panggilan API vendor.
- Penanganan autentikasi vendor.
- Normalisasi permintaan khusus vendor.
- Pendaftaran implementasi kapabilitas.
- 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.
agents.defaults.imageModelmenganalisis gambar.agents.defaults.imageGenerationModelmenghasilkan gambar.
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.
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.