Plugins
Plugin Webhook
Plugin Webhooks menambahkan rute HTTP terautentikasi yang menghubungkan otomatisasi eksternal ke OpenClaw TaskFlows.
Gunakan ini saat Anda ingin sistem tepercaya seperti Zapier, n8n, job CI, atau layanan internal membuat dan mengendalikan TaskFlows terkelola tanpa perlu menulis plugin kustom terlebih dahulu.
Tempat dijalankan
Plugin Webhooks berjalan di dalam proses Gateway.
Jika Gateway Anda berjalan di mesin lain, instal dan konfigurasikan plugin di host Gateway tersebut, lalu mulai ulang Gateway.
Mengonfigurasi rute
Atur konfigurasi di bawah plugins.entries.webhooks.config:
{
plugins: {
entries: {
webhooks: {
enabled: true,
config: {
routes: {
zapier: {
path: "/plugins/webhooks/zapier",
sessionKey: "agent:main:main",
secret: {
source: "env",
provider: "default",
id: "OPENCLAW_WEBHOOK_SECRET",
},
controllerId: "webhooks/zapier",
description: "Jembatan TaskFlow Zapier",
},
},
},
},
},
},
}
Kolom rute:
enabled: opsional, default ketruepath: opsional, default ke/plugins/webhooks/<routeId>sessionKey: sesi wajib yang memiliki TaskFlows terikatsecret: shared secret atau SecretRef wajibcontrollerId: id pengontrol opsional untuk alur terkelola yang dibuatdescription: catatan operator opsional
Input secret yang didukung:
- String polos
- SecretRef dengan
source: "env" | "file" | "exec"
Jika rute berbasis secret tidak dapat menyelesaikan secret-nya saat startup, plugin akan melewati rute tersebut dan mencatat peringatan alih-alih mengekspos endpoint yang rusak.
Model keamanan
Setiap rute dipercaya untuk bertindak dengan otoritas TaskFlow dari sessionKey yang dikonfigurasi.
Ini berarti rute dapat memeriksa dan mengubah TaskFlows yang dimiliki oleh sesi tersebut, jadi Anda sebaiknya:
- Gunakan secret unik yang kuat untuk setiap rute
- Utamakan referensi secret daripada secret plaintext inline
- Ikat rute ke sesi paling sempit yang sesuai dengan alur kerja
- Ekspos hanya path webhook spesifik yang Anda perlukan
Plugin menerapkan:
- Autentikasi shared-secret
- Penjaga ukuran body permintaan dan timeout
- Pembatasan laju fixed-window
- Pembatasan permintaan in-flight
- Akses TaskFlow yang terikat pemilik melalui
api.runtime.tasks.managedFlows.bindSession(...)
Format permintaan
Kirim permintaan POST dengan:
Content-Type: application/jsonAuthorization: Bearer <secret>ataux-openclaw-webhook-secret: <secret>
Contoh:
curl -X POST https://gateway.example.com/plugins/webhooks/zapier \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer YOUR_SHARED_SECRET' \
-d '{"action":"create_flow","goal":"Review inbound queue"}'
Tindakan yang didukung
Plugin saat ini menerima nilai JSON action berikut:
create_flowget_flowlist_flowsfind_latest_flowresolve_flowget_task_summaryset_waitingresume_flowfinish_flowfail_flowrequest_cancelcancel_flowrun_task
create_flow
Membuat TaskFlow terkelola untuk sesi terikat milik rute.
Contoh:
{
"action": "create_flow",
"goal": "Review inbound queue",
"status": "queued",
"notifyPolicy": "done_only"
}
run_task
Membuat tugas turunan terkelola di dalam TaskFlow terkelola yang sudah ada.
Runtime yang diizinkan adalah:
subagentacp
Contoh:
{
"action": "run_task",
"flowId": "flow_123",
"runtime": "acp",
"childSessionKey": "agent:main:acp:worker",
"task": "Inspect the next message batch"
}
Bentuk respons
Respons yang berhasil mengembalikan:
{
"ok": true,
"routeId": "zapier",
"result": {}
}
Permintaan yang ditolak mengembalikan:
{
"ok": false,
"routeId": "zapier",
"code": "not_found",
"error": "TaskFlow not found.",
"result": {}
}
Plugin secara sengaja membersihkan metadata pemilik/sesi dari respons webhook.