鉤子
Hooks 提供可擴充的事件驅動系統,用於回應代理指令與事件來自動化動作。 Hooks 會從目錄中自動探索,並可透過 CLI 指令管理,方式類似 OpenClaw 中的 skills。入門引導
Hooks 是在事件發生時執行的小型腳本。 有兩種類型:- Hooks(本頁):在 Gateway 閘道器 內執行,當代理程式事件觸發時運作,例如
/new、/reset、/stop,或生命週期事件。 - Webhooks:外部的 HTTP webhooks,讓其他系統觸發 OpenClaw 中的工作。 Webhooks:外部 HTTP webhook,讓其他系統在 OpenClaw 中觸發工作。請參閱 Webhook Hooks,或使用
openclaw webhooks來進行 Gmail 輔助指令。 Webhooks:外部 HTTP webhook,讓其他系統在 OpenClaw 中觸發工作。請參閱 Webhook Hooks,或使用openclaw webhooks來進行 Gmail 輔助指令。
- 在重置工作階段時儲存記憶快照
- 為疑難排解或合規需求保留指令稽核紀錄
- 在工作階段開始或結束時觸發後續自動化
- 在事件發生時,將檔案寫入代理程式工作區或呼叫外部 API
概覽
Hooks 系統可讓你:- 在發出
/new時將工作階段上下文儲存到記憶中 - 記錄所有指令以供稽核
- 在代理程式生命週期事件上觸發自訂自動化
- 不需修改核心程式碼即可擴充 OpenClaw 的行為
入門指南
內建 Hooks
OpenClaw 隨附四個會自動被探索的內建 hooks:- 💾 session-memory:在你發出
/new時,將工作階段內容儲存至你的代理程式工作區(預設為~/.openclaw/workspace/memory/) - 在 Gateway 閘道器 啟動時(頻道啟動後)執行
BOOT.md。 必須啟用內部 hooks 才會執行。 Internal hooks must be enabled for this to run. - 📝 command-logger:將所有指令事件記錄到
~/.openclaw/logs/commands.log - 🚀 boot-md:在 Gateway 閘道器 啟動時執行
BOOT.md(需要啟用內部 hooks)
新手導覽
在新手導覽(openclaw onboard)期間,系統會提示你啟用建議的 hooks。 在新手導覽(openclaw onboard)期間,系統會提示你啟用建議的 hooks。 The wizard automatically discovers eligible hooks and presents them for selection.
Hook 探索機制
Hooks 會從三個目錄中自動探索(依優先順序):- 工作區 hooks:
<workspace>/hooks/(每個代理程式一組,最高優先順序) - 受管理 hooks:
~/.openclaw/hooks/(使用者安裝,跨工作區共用) - 內建 hooks:
<openclaw>/dist/hooks/bundled/(隨 OpenClaw 一同提供)
Hook 套件(npm/封存檔)
Hook 套件是標準的 npm 套件,透過package.json 中的 openclaw.hooks 匯出一個或多個 hooks。使用以下指令安裝: Install them with: Install them with:
package.json 範例:
HOOK.md 與 handler.ts(或 index.ts)。
Hook 套件可以攜帶相依套件;它們會被安裝在 ~/.openclaw/hooks/<id> 下。
每個項目都指向一個 hook 目錄,該目錄包含 HOOK.md 與 handler.ts(或 index.ts)。
Hook 套件可以攜帶相依套件;它們會被安裝在 ~/.openclaw/hooks/<id> 下。
Hook packs can ship dependencies; they will be installed under ~/.openclaw/hooks/<id>.
安全性說明:openclaw hooks install 會使用 npm install --ignore-scripts 安裝相依套件
(不執行 lifecycle scripts)。 請保持 hook 套件的相依樹為「純 JS/TS」,並避免使用依賴
postinstall 建置的套件。
架構
HOOK.md 格式
HOOK.md 檔案包含 YAML frontmatter 的中繼資料,以及 Markdown 文件說明:
Metadata Fields
metadata.openclaw 物件支援:
emoji:CLI 顯示用的表情符號(例如"💾")events:要監聽的事件陣列(例如["command:new", "command:reset"])export:要使用的具名匯出(預設為"default")homepage:文件 URLrequires:選用需求bins:PATH 中需要的二進位檔(例如["git", "node"])anyBins:至少必須存在其中一個二進位檔env:必要的環境變數config:必要的設定路徑(例如["workspace.dir"])os:必要的平台(例如["darwin", "linux"])
always:略過資格檢查(布林值)install:安裝方式(對於內建 hooks:[{"id":"bundled","kind":"bundled"}])
Handler Implementation
handler.ts 檔案會匯出一個 HookHandler 函式:
Event Context
每個事件包含:事件類型
指令事件
當代理程式指令被發出時觸發:command:所有指令事件(通用監聽器)command:new:當發出/new指令時command:reset:當發出/reset指令時command:stop:當發出/stop指令時
代理程式事件
agent:bootstrap:在工作區啟動檔案被注入之前(hooks 可能會修改context.bootstrapFiles)
Gateway 事件
在 Gateway 閘道器 啟動時觸發:gateway:startup:在頻道啟動且 hooks 載入完成之後
工具結果 Hooks(外掛 API)
這些 hooks 並非事件串流監聽器;它們允許外掛在 OpenClaw 儲存結果之前,同步調整工具結果。tool_result_persist: transform tool results before they are written to the session transcript. Must be synchronous; return the updated tool result payload orundefinedto keep it as-is. See Agent Loop.
未來事件
規劃中的事件類型:session:start:當新的工作階段開始時session:end:當工作階段結束時agent:error:當代理程式遇到錯誤時message:sent:當訊息被送出時message:received:當訊息被接收時
建立自訂 Hooks
1. 選擇位置
- 工作區 hooks(
<workspace>/hooks/):每個代理程式一組,最高優先順序 - 受管理 hooks(
~/.openclaw/hooks/):跨工作區共用
2. 建立目錄結構
3. 建立 HOOK.md
4. 建立 handler.ts
5. 啟用並測試
設定
新的設定格式(建議)
每個 Hook 的設定
Hooks 可以有自訂設定:Extra Directories
Load hooks from additional directories:舊版設定格式(仍支援)
舊的設定格式仍可使用,以維持向後相容:module 必須是相對於 workspace 的路徑。 絕對路徑與超出 workspace 的路徑遍歷會被拒絕。
Migration: Use the new discovery-based system for new hooks. Legacy handlers are loaded after directory-based hooks.
CLI 指令
列出 Hooks
Hook 資訊
檢查資格
啟用/停用
Bundled hook reference
session-memory
Saves session context to memory when you issue/new.
事件:command:new
文件:SOUL Evil Hook
輸出:<workspace>/memory/YYYY-MM-DD-slug.md(預設為 ~/.openclaw/workspace)
功能說明:
- Uses the pre-reset session entry to locate the correct transcript
- 擷取最後 15 行對話
- 使用 LLM 產生具描述性的檔名 slug
- Saves session metadata to a dated memory file
2026-01-16-vendor-pitch.md2026-01-16-api-design.md2026-01-16-1430.md(若 slug 產生失敗時的後備時間戳)
bootstrap-extra-files
在清除期間或隨機情況下,將注入的SOUL.md 內容替換為 SOUL_EVIL.md。
事件:agent:bootstrap
需求:必須設定 workspace.dir
輸出:不寫入任何檔案;交換僅在記憶體中進行。
設定:
- 路徑會以 workspace 為基準解析。
- 檔案必須保留在 workspace 內(經 realpath 檢查)。
- 僅會載入已識別的 bootstrap 基本檔名。
- 子代理 allowlist 會被保留(僅
AGENTS.md與TOOLS.md)。
command-logger
將所有指令事件記錄到集中式稽核檔案。 事件:command
需求:無
輸出:~/.openclaw/logs/commands.log
功能說明:
- Captures event details (command action, timestamp, session key, sender ID, source)
- 以 JSONL 格式附加至記錄檔
- 在背景中靜默執行
boot-md
在 Gateway 閘道器 啟動時(頻道啟動後)執行BOOT.md。
必須啟用內部 hooks 才會執行。
Internal hooks must be enabled for this to run.
事件:gateway:startup
需求:必須設定 workspace.dir
功能說明:
- 從你的工作區讀取
BOOT.md - 透過代理程式執行器執行指示
- 透過訊息工具送出任何要求的對外訊息
最佳實務
保持處理器快速
Hooks run during command processing. Keep them lightweight:妥善處理錯誤
Always wrap risky operations:儘早過濾事件
如果事件不相關,請提早返回:使用明確的事件鍵
盡可能在中繼資料中指定精確的事件:Debugging
啟用 Hook 記錄
Gateway 閘道器 會在啟動時記錄 hook 載入情況:檢查探索結果
列出所有已探索到的 hooks:檢查註冊狀態
In your handler, log when it’s called:Verify Eligibility
檢查為何 hook 不符合資格:測試
Gateway 記錄
監控 Gateway 閘道器 記錄以查看 hook 的執行情況:直接測試 Hooks
以隔離方式測試你的處理器:Architecture
核心元件
src/hooks/types.ts:型別定義src/hooks/workspace.ts:目錄掃描與載入src/hooks/frontmatter.ts:HOOK.md 中繼資料解析src/hooks/config.ts:資格檢查src/hooks/hooks-status.ts:狀態回報src/hooks/loader.ts:動態模組載入器src/cli/hooks-cli.ts:CLI 指令src/gateway/server-startup.ts:在 Gateway 閘道器 啟動時載入 hookssrc/auto-reply/reply/commands-core.ts:觸發指令事件
探索流程
事件流程
Troubleshooting
Hook 未被探索
-
Check directory structure:
-
驗證 HOOK.md 格式:
-
列出所有已探索的 hooks:
Hook 未執行
檢查需求:- Binaries (check PATH)
- 環境變數
- 設定值
- 作業系統相容性
Hook 不符合資格
-
確認 hook 已啟用:
- Restart your gateway process so hooks reload.
-
檢查 Gateway 記錄中的錯誤:
Handler Errors
檢查是否有 TypeScript/import 錯誤:遷移指南
From Legacy Config to Discovery
之前:-
建立 hook 目錄:
-
建立 HOOK.md:
-
更新設定:
-
驗證並重新啟動你的 Gateway 閘道器 行程:
- 自動探索
- CLI 管理
- Eligibility checking
- 更完善的文件
- Consistent structure