Hooks
Hooks adalah skrip kecil yang berjalan saat sesuatu terjadi di dalam Gateway. Hooks ditemukan secara otomatis dari direktori dan dapat diperiksa dengan openclaw hooks.
Ada dua jenis hook di OpenClaw:
- Hook internal (halaman ini): berjalan di dalam Gateway saat peristiwa agen dipicu, seperti
/new, /reset, /stop, atau peristiwa siklus hidup.
- Webhook: endpoint HTTP eksternal yang memungkinkan sistem lain memicu pekerjaan di OpenClaw. Lihat Webhooks.
Hooks juga dapat dibundel di dalam plugin. openclaw hooks list menampilkan hook mandiri dan hook yang dikelola plugin.
Mulai cepat
# Daftar hook yang tersedia
openclaw hooks list
# Aktifkan hook
openclaw hooks enable session-memory
# Periksa status hook
openclaw hooks check
# Dapatkan informasi terperinci
openclaw hooks info session-memory
Jenis peristiwa
| Peristiwa | Kapan dipicu |
|---|
command:new | Perintah /new dijalankan |
command:reset | Perintah /reset dijalankan |
command:stop | Perintah /stop dijalankan |
command | Peristiwa perintah apa pun (listener umum) |
session:compact:before | Sebelum pemadatan merangkum riwayat |
session:compact:after | Setelah pemadatan selesai |
session:patch | Saat properti sesi diubah |
agent:bootstrap | Sebelum file bootstrap workspace disisipkan |
gateway:startup | Setelah channel dimulai dan hook dimuat |
message:received | Pesan masuk dari channel mana pun |
message:transcribed | Setelah transkripsi audio selesai |
message:preprocessed | Setelah semua pemahaman media dan tautan selesai |
message:sent | Pesan keluar terkirim |
Struktur hook
Setiap hook adalah direktori yang berisi dua file:
my-hook/
├── HOOK.md # Metadata + dokumentasi
└── handler.ts # Implementasi handler
---
name: my-hook
description: "Deskripsi singkat tentang apa yang dilakukan hook ini"
metadata:
{ "openclaw": { "emoji": "🔗", "events": ["command:new"], "requires": { "bins": ["node"] } } }
---
# My Hook
Dokumentasi terperinci ada di sini.
Bidang metadata (metadata.openclaw):
| Bidang | Deskripsi |
|---|
emoji | Emoji tampilan untuk CLI |
events | Array peristiwa yang akan didengarkan |
export | Named export yang akan digunakan (default "default") |
os | Platform yang diperlukan (misalnya ["darwin", "linux"]) |
requires | bins, anyBins, env, atau jalur config yang diperlukan |
always | Lewati pemeriksaan kelayakan (boolean) |
install | Metode instalasi |
Implementasi handler
const handler = async (event) => {
if (event.type !== "command" || event.action !== "new") {
return;
}
console.log(`[my-hook] New command triggered`);
// Your logic here
// Optionally send message to user
event.messages.push("Hook executed!");
};
export default handler;
Setiap peristiwa mencakup: type, action, sessionKey, timestamp, messages (push untuk mengirim ke pengguna), dan context (data spesifik peristiwa).
Sorotan konteks peristiwa
Peristiwa perintah (command:new, command:reset): context.sessionEntry, context.previousSessionEntry, context.commandSource, context.workspaceDir, context.cfg.
Peristiwa pesan (message:received): context.from, context.content, context.channelId, context.metadata (data spesifik provider termasuk senderId, senderName, guildId).
Peristiwa pesan (message:sent): context.to, context.content, context.success, context.channelId.
Peristiwa pesan (message:transcribed): context.transcript, context.from, context.channelId, context.mediaPath.
Peristiwa pesan (message:preprocessed): context.bodyForAgent (isi akhir yang telah diperkaya), context.from, context.channelId.
Peristiwa bootstrap (agent:bootstrap): context.bootstrapFiles (array yang dapat diubah), context.agentId.
Peristiwa patch sesi (session:patch): context.sessionEntry, context.patch (hanya bidang yang berubah), context.cfg. Hanya klien dengan hak istimewa yang dapat memicu peristiwa patch.
Peristiwa pemadatan: session:compact:before mencakup messageCount, tokenCount. session:compact:after menambahkan compactedCount, summaryLength, tokensBefore, tokensAfter.
Penemuan hook
Hooks ditemukan dari direktori berikut, dalam urutan prioritas override yang meningkat:
- Hook bawaan: dikirim bersama OpenClaw
- Hook plugin: hook yang dibundel di dalam plugin yang terinstal
- Hook terkelola:
~/.openclaw/hooks/ (diinstal pengguna, dibagikan di seluruh workspace). Direktori tambahan dari hooks.internal.load.extraDirs berbagi prioritas ini.
- Hook workspace:
<workspace>/hooks/ (per agen, dinonaktifkan secara default sampai diaktifkan secara eksplisit)
Hook workspace dapat menambahkan nama hook baru tetapi tidak dapat mengganti hook bawaan, terkelola, atau yang disediakan plugin dengan nama yang sama.
Paket hook
Paket hook adalah paket npm yang mengekspor hook melalui openclaw.hooks di package.json. Instal dengan:
openclaw plugins install <path-or-spec>
Spesifikasi npm hanya untuk registry (nama paket + versi tepat opsional atau dist-tag). Spesifikasi Git/URL/file dan rentang semver ditolak.
Hook bawaan
| Hook | Peristiwa | Fungsinya |
|---|
| session-memory | command:new, command:reset | Menyimpan konteks sesi ke <workspace>/memory/ |
| bootstrap-extra-files | agent:bootstrap | Menyisipkan file bootstrap tambahan dari pola glob |
| command-logger | command | Mencatat semua perintah ke ~/.openclaw/logs/commands.log |
| boot-md | gateway:startup | Menjalankan BOOT.md saat gateway dimulai |
Aktifkan hook bawaan apa pun:
openclaw hooks enable <hook-name>
Detail session-memory
Mengekstrak 15 pesan pengguna/asisten terakhir, menghasilkan slug nama file deskriptif melalui LLM, dan menyimpannya ke <workspace>/memory/YYYY-MM-DD-slug.md. Memerlukan workspace.dir dikonfigurasi.
{
"hooks": {
"internal": {
"entries": {
"bootstrap-extra-files": {
"enabled": true,
"paths": ["packages/*/AGENTS.md", "packages/*/TOOLS.md"]
}
}
}
}
}
Path diselesaikan relatif terhadap workspace. Hanya basename bootstrap yang dikenali yang dimuat (AGENTS.md, SOUL.md, TOOLS.md, IDENTITY.md, USER.md, HEARTBEAT.md, BOOTSTRAP.md, MEMORY.md).
Hook plugin
Plugin dapat mendaftarkan hook melalui Plugin SDK untuk integrasi yang lebih dalam: mencegat panggilan alat, memodifikasi prompt, mengontrol alur pesan, dan banyak lagi. Plugin SDK menyediakan 28 hook yang mencakup resolusi model, siklus hidup agen, alur pesan, eksekusi alat, koordinasi subagen, dan siklus hidup gateway.
Untuk referensi hook plugin lengkap termasuk before_tool_call, before_agent_reply, before_install, dan semua hook plugin lainnya, lihat Plugin Architecture.
Konfigurasi
{
"hooks": {
"internal": {
"enabled": true,
"entries": {
"session-memory": { "enabled": true },
"command-logger": { "enabled": false }
}
}
}
}
Variabel lingkungan per hook:
{
"hooks": {
"internal": {
"entries": {
"my-hook": {
"enabled": true,
"env": { "MY_CUSTOM_VAR": "value" }
}
}
}
}
}
Direktori hook tambahan:
{
"hooks": {
"internal": {
"load": {
"extraDirs": ["/path/to/more/hooks"]
}
}
}
}
Format konfigurasi array legacy hooks.internal.handlers masih didukung untuk kompatibilitas mundur, tetapi hook baru sebaiknya menggunakan sistem berbasis penemuan.
Referensi CLI
# Daftar semua hook (tambahkan --eligible, --verbose, atau --json)
openclaw hooks list
# Tampilkan info terperinci tentang sebuah hook
openclaw hooks info <hook-name>
# Tampilkan ringkasan kelayakan
openclaw hooks check
# Aktifkan/nonaktifkan
openclaw hooks enable <hook-name>
openclaw hooks disable <hook-name>
Praktik terbaik
- Jaga handler tetap cepat. Hooks berjalan selama pemrosesan perintah. Jalankan pekerjaan berat secara fire-and-forget dengan
void processInBackground(event).
- Tangani error dengan baik. Bungkus operasi berisiko dalam try/catch; jangan throw agar handler lain tetap dapat berjalan.
- Filter peristiwa lebih awal. Segera return jika tipe/aksi peristiwa tidak relevan.
- Gunakan kunci peristiwa spesifik. Pilih
"events": ["command:new"] daripada "events": ["command"] untuk mengurangi overhead.
Pemecahan masalah
Hook tidak ditemukan
# Verifikasi struktur direktori
ls -la ~/.openclaw/hooks/my-hook/
# Seharusnya menampilkan: HOOK.md, handler.ts
# Daftar semua hook yang ditemukan
openclaw hooks list
openclaw hooks info my-hook
Periksa biner yang hilang (PATH), variabel lingkungan, nilai konfigurasi, atau kompatibilitas OS.
Hook tidak berjalan
- Verifikasi hook diaktifkan:
openclaw hooks list
- Mulai ulang proses gateway Anda agar hook dimuat ulang.
- Periksa log gateway:
./scripts/clawlog.sh | grep hook
Terkait