openclaw acp 是由 Gateway 支援的 ACP 橋接器,而不是完整 ACP 原生編輯器執行階段。它聚焦於工作階段路由、提示傳遞,以及基本串流更新。
如果你想讓外部 MCP 用戶端直接與 OpenClaw 頻道對話通訊,而不是託管 ACP harness 工作階段,請改用 openclaw mcp serve。
這不是什麼
此頁面常與 ACP harness 工作階段混淆。openclaw acp 表示:
- OpenClaw 充當 ACP 伺服器
- IDE 或 ACP 用戶端連線到 OpenClaw
- OpenClaw 將該工作轉送到 Gateway 工作階段
acpx 執行 Codex 或 Claude Code 等外部 harness。
快速規則:
- 編輯器/用戶端想用 ACP 與 OpenClaw 通訊:使用
openclaw acp - OpenClaw 應以 ACP harness 方式啟動 Codex/Claude/Gemini:使用
/acp spawn和 ACP 代理
相容性矩陣
| ACP 區域 | 狀態 | 備註 |
|---|---|---|
initialize, newSession, prompt, cancel | 已實作 | 核心橋接流程透過 stdio 到 Gateway chat/send + abort。 |
listSessions, slash commands | 已實作 | 工作階段清單會針對 Gateway 工作階段狀態運作,具備有界游標分頁,且在 Gateway 工作階段列帶有工作區中繼資料時支援 cwd 篩選;命令會透過 available_commands_update 公告。 |
| 工作階段譜系中繼資料 | 已實作 | 工作階段列表和工作階段資訊快照會在 _meta 中包含 OpenClaw 父子譜系,讓 ACP 用戶端不需使用私有 Gateway 側通道即可呈現子代理圖。 |
resumeSession, closeSession | 已實作 | Resume 會將 ACP 工作階段重新繫結到既有 Gateway 工作階段,而不重播歷史。Close 會取消作用中的橋接工作、將待處理提示解析為已取消,並釋放橋接工作階段狀態。 |
loadSession | 部分支援 | 將 ACP 工作階段重新繫結到 Gateway 工作階段金鑰,並為橋接器建立的工作階段重播 ACP 事件帳本歷史。較舊/無帳本的工作階段會退回使用已儲存的使用者/助理文字。 |
提示內容(text、嵌入式 resource、圖片) | 部分支援 | 文字/資源會扁平化為聊天輸入;圖片會成為 Gateway 附件。 |
| 工作階段模式 | 部分支援 | 支援 session/set_mode,且橋接器會公開初始 Gateway 支援的工作階段控制,用於思考層級、工具詳細程度、推理、用量細節和提升權限動作。更廣泛的 ACP 原生模式/設定表面仍不在範圍內。 |
| 工作階段資訊和用量更新 | 部分支援 | 橋接器會從快取的 Gateway 工作階段快照發出 session_info_update 和盡力而為的 usage_update 通知。用量為近似值,且只會在 Gateway token 總數標示為新鮮時傳送。 |
| 工具串流 | 部分支援 | tool_call / tool_call_update 事件會在 Gateway 工具引數/結果公開時包含原始 I/O、文字內容,以及盡力而為的檔案位置。嵌入式終端機和更豐富的 diff 原生輸出仍未公開。 |
| Exec 核准 | 部分支援 | 作用中的 ACP 提示回合期間,Gateway exec 核准提示會以 session/request_permission 轉送到 ACP 用戶端。 |
每工作階段 MCP 伺服器(mcpServers) | 不支援 | 橋接模式會拒絕每工作階段 MCP 伺服器請求。請改在 OpenClaw gateway 或代理上設定 MCP。 |
用戶端檔案系統方法(fs/read_text_file, fs/write_text_file) | 不支援 | 橋接器不會呼叫 ACP 用戶端檔案系統方法。 |
用戶端終端機方法(terminal/*) | 不支援 | 橋接器不會建立 ACP 用戶端終端機,也不會透過工具呼叫串流終端機 ID。 |
| 工作階段計畫 / 思考串流 | 不支援 | 橋接器目前會發出輸出文字和工具狀態,而不是 ACP 計畫或思考更新。 |
已知限制
loadSession只能為橋接器建立的工作階段重播完整 ACP 事件帳本歷史。較舊/無帳本的工作階段仍使用逐字稿退回機制,且不會重建歷史工具呼叫或系統通知。- 如果多個 ACP 用戶端共用同一個 Gateway 工作階段金鑰,事件和取消路由會是盡力而為,而不是依用戶端嚴格隔離。需要乾淨的編輯器本機回合時,請偏好預設隔離的
acp:<uuid>工作階段。 - Gateway 停止狀態會轉譯為 ACP 停止原因,但該對應不如完整 ACP 原生執行階段具表達力。
- 初始工作階段控制目前公開一組聚焦的 Gateway 調整項:思考層級、工具詳細程度、推理、用量細節和提升權限動作。模型選擇和 exec-host 控制尚未公開為 ACP 設定選項。
session_info_update和usage_update來自 Gateway 工作階段快照,而不是即時 ACP 原生執行階段計量。用量為近似值、不含成本資料,且只會在 Gateway 將 token 總數資料標示為新鮮時發出。- 工具跟隨資料是盡力而為。橋接器可以顯示出現在已知工具引數/結果中的檔案路徑,但尚未發出 ACP 終端機或結構化檔案 diff。
- Exec 核准轉送範圍限於作用中的 ACP 提示回合;來自其他 Gateway 工作階段的核准會被忽略。
用法
ACP 用戶端(偵錯)
使用內建 ACP 用戶端可在沒有 IDE 的情況下對橋接器進行基本檢查。 它會產生 ACP 橋接器,並讓你以互動方式輸入提示。- 自動核准以允許清單為基礎,且只適用於受信任的核心工具 ID。
read自動核准的範圍限於目前工作目錄(設定時為--cwd)。- ACP 只會自動核准狹窄的唯讀類別:作用中 cwd 下的範圍化
read呼叫,以及唯讀搜尋工具(search,web_search,memory_search)。未知/非核心工具、超出範圍的讀取、具 exec 能力的工具、控制平面工具、會變更狀態的工具,以及互動式流程一律需要明確提示核准。 - 伺服器提供的
toolCall.kind會視為不受信任的中繼資料(不是授權來源)。 - 此 ACP 橋接器政策與 ACPX harness 權限不同。如果你透過
acpx後端執行 OpenClaw,plugins.entries.acpx.config.permissionMode=approve-all是該 harness 工作階段的緊急「yolo」開關。
通訊協定冒煙測試
若要進行通訊協定層級偵錯,請使用隔離狀態啟動 Gateway,並透過 stdio 以 ACP JSON-RPC 用戶端驅動openclaw acp。涵蓋 initialize、session/new、帶絕對 cwd 的 session/list、session/resume、session/close、重複 close,以及缺少 resume。
證明應包含公告的生命週期能力、Gateway 支援的工作階段列、更新通知,以及 Gateway sessions.list 記錄:
openclaw gateway call sessions.list 作為唯一 ACP 證明。該 CLI 路徑可能會請求 fresh-token 操作者範圍升級;ACP 橋接器正確性是由 ACP stdio frames 加上 Gateway sessions.list 記錄證明。
如何使用這個功能
當 IDE(或其他用戶端)使用 Agent Client Protocol,且你希望它驅動 OpenClaw Gateway 工作階段時,請使用 ACP。- 確認 Gateway 正在執行(本機或遠端)。
- 設定 Gateway 目標(設定或旗標)。
- 將 IDE 指向透過 stdio 執行
openclaw acp。
選擇代理
ACP 不會直接選擇代理。它會依 Gateway 工作階段金鑰進行路由。 使用代理範圍工作階段金鑰來指定特定代理:acp:<uuid> 工作階段。
橋接模式不支援每個工作階段個別設定 mcpServers。如果 ACP 用戶端在
newSession 或 loadSession 期間傳送它們,橋接器會回傳清楚的錯誤,
而不是默默忽略。
如果你想讓 ACPX 後端支援的工作階段看見 OpenClaw Plugin 工具,或所選的
內建工具例如 cron,請改為啟用 Gateway 端的 ACPX MCP 橋接器,
而不是嘗試傳遞每個工作階段的 mcpServers。請參閱
ACP 代理和
OpenClaw 工具 MCP 橋接器。
從 acpx 使用(Codex、Claude、其他 ACP 用戶端)
如果你想讓 Codex 或 Claude Code 等程式碼代理透過 ACP 與你的
OpenClaw bot 溝通,請使用 acpx 及其內建的 openclaw 目標。
典型流程:
- 執行 Gateway,並確認 ACP 橋接器可以連上它。
- 將
acpx openclaw指向openclaw acp。 - 指定你想讓程式碼代理使用的 OpenClaw 工作階段金鑰。
acpx openclaw 每次都指向特定的 Gateway 和工作階段金鑰,
請在 ~/.acpx/config.json 中覆寫 openclaw 代理命令:
Zed 編輯器設定
在~/.config/zed/settings.json 中新增自訂 ACP 代理(或使用 Zed 的設定 UI):
工作階段對應
預設情況下,ACP 工作階段會取得帶有acp: 前綴的隔離 Gateway 工作階段金鑰。
若要重用已知工作階段,請傳入工作階段金鑰或標籤:
--session <key>:使用特定 Gateway 工作階段金鑰。--session-label <label>:依標籤解析現有工作階段。--reset-session:為該金鑰產生新的工作階段 ID(相同金鑰,新的逐字稿)。
選項
--url <url>:Gateway WebSocket URL(設定時預設為 gateway.remote.url)。--token <token>:Gateway 驗證權杖。--token-file <path>:從檔案讀取 Gateway 驗證權杖。--password <password>:Gateway 驗證密碼。--password-file <path>:從檔案讀取 Gateway 驗證密碼。--session <key>:預設工作階段金鑰。--session-label <label>:要解析的預設工作階段標籤。--require-existing:如果工作階段金鑰/標籤不存在則失敗。--reset-session:在第一次使用前重設工作階段金鑰。--no-prefix-cwd:不要在提示前加上工作目錄前綴。--provenance <off|meta|meta+receipt>:包含 ACP 來源中繼資料或收據。--verbose, -v:將詳細記錄輸出到 stderr。
- 在某些系統上,
--token和--password可能會顯示在本機程序列表中。 - 建議使用
--token-file/--password-file或環境變數(OPENCLAW_GATEWAY_TOKEN、OPENCLAW_GATEWAY_PASSWORD)。 - Gateway 驗證解析會遵循其他 Gateway 用戶端使用的共用合約:
- 本機模式:env(
OPENCLAW_GATEWAY_*)->gateway.auth.*-> 僅在未設定gateway.auth.*時才 fallback 至gateway.remote.*(已設定但未解析的本機 SecretRefs 會安全失敗) - 遠端模式:
gateway.remote.*搭配 env/config fallback,依遠端優先順序規則處理 --url可安全覆寫,且不會重用隱含的 config/env 憑證;請傳入明確的--token/--password(或檔案變體)
- 本機模式:env(
- ACP 執行階段後端子程序會收到
OPENCLAW_SHELL=acp,可用於特定情境的 shell/profile 規則。 openclaw acp client會在產生的橋接程序上設定OPENCLAW_SHELL=acp-client。
acp client 選項
--cwd <dir>:ACP 工作階段的工作目錄。--server <command>:ACP 伺服器命令(預設:openclaw)。--server-args <args...>:傳遞給 ACP 伺服器的額外引數。--server-verbose:在 ACP 伺服器上啟用詳細記錄。--verbose, -v:詳細用戶端記錄。