Skip to content

節點

節點 是一個伴隨裝置(macOS/iOS/Android/headless),使用 role: "node" 連接到 Gateway WebSocket(與操作員相同的連接埠),並透過 node.invoke 暴露指令介面(例如 canvas.*camera.*device.*notifications.*system.*)。協議詳情:Gateway protocol

舊版傳輸:Bridge protocol (TCP JSONL; 僅供當前節點參考歷史使用)。

macOS 也可以在 節點模式 下運行:選單列應用程式連接到 Gateway 的 WS 伺服器,並將其本機的 canvas/camera 指令作為節點暴露(因此 openclaw nodes … 可針對此 Mac 運作)。在遠端 Gateway 模式下,瀏覽器 自動化由 CLI 節點主機(openclaw node run 或已 安裝的節點服務)處理,而非由原生應用程式節點處理。

注意:

  • 節點是 外設,不是 Gateway。它們不運行 gateway 服務。
  • Telegram/WhatsApp/等訊息會落在 閘道器 上,而不是節點上。
  • 疑難排解手冊:/nodes/troubleshooting

WS 節點使用裝置配對。 節點在 connect 期間出示裝置身分識別;閘道器 會為 role: node 建立裝置配對請求。透過裝置 CLI(或 UI)批准。

快速 CLI:

Terminal window
openclaw devices list
openclaw devices approve <requestId>
openclaw devices reject <requestId>
openclaw nodes status
openclaw nodes describe --node <idOrNameOrIp>

如果節點使用變更後的驗證詳細資料(角色/範圍/公開金鑰)重試,則先前的 待處理請求將被取代,並建立一個新的 requestId。請在批准前 重新執行 openclaw devices list

注意:

  • 當節點的裝置配對角色包含 node 時,nodes status 會將節點標記為 已配對
  • 裝置配對記錄是持久化的已批准角色契約。Token 輪換 保持在該契約範圍內;它無法將已配對的節點升級為 配對批准從未授予的不同角色。
  • node.pair.* (CLI: openclaw nodes pending/approve/reject/remove/rename) 是一個獨立的閘道器擁有的 節點配對存儲;它會阻擋 WS connect 交握。
  • openclaw nodes remove --node <id|name|ip> 會從該獨立的閘道擁有的節點配對儲存空間中刪除過時的條目。
  • 批准範圍遵循待處理請求中聲明的命令:
    • 無指令請求:operator.pairing
    • 非執行節點指令:operator.pairing + operator.write
    • system.run / system.run.prepare / system.whichoperator.pairing + operator.admin

當您的閘道在一台機器上運行,並且您希望指令在另一台機器上執行時,請使用 節點主機。模型仍然與 閘道 對話;當選擇 host=node 時,閘道會將 exec 呼叫轉發給 節點主機

  • Gateway host:接收訊息,運行模型,路由工具呼叫。
  • 節點主機:在節點機器上執行 system.run/system.which
  • 審批:透過 ~/.openclaw/exec-approvals.json 在節點主機上強制執行。

批准注意事項:

  • 批准支援的節點運行綁定確切的請求上下文。
  • 對於直接的 shell/runtime 執行檔案,OpenClaw 也會盡最大努力綁定一個具體的本機 檔案操作數,並且如果該檔案在執行前被變更,則拒絕執行。
  • 如果 OpenClaw 無法為解譯器/runtime 指令確切識別一個具體的本機檔案, 將會拒絕需要批准的執行,而不是假設具有完整的 runtime 涵蓋範圍。請使用沙盒、 獨立的主機,或明確的信任允許清單/完整工作流程,以獲得更廣泛的解譯器語意。

在節點機器上:

Terminal window
openclaw node run --host <gateway-host> --port 18789 --display-name "Build Node"

透過 SSH 通道 (loopback bind) 連線遠端閘道

Section titled “透過 SSH 通道 (loopback bind) 連線遠端閘道”

如果閘道綁定到 loopback (gateway.bind=loopback,本地模式下的預設值),遠端節點主機將無法直接連線。建立 SSH 隧道並將節點主機指向隧道的本地端。

範例 (節點主機 -> 閘道主機):

Terminal window
# Terminal A (keep running): forward local 18790 -> gateway 127.0.0.1:18789
ssh -N -L 18790:127.0.0.1:18789 user@gateway-host
# Terminal B: export the gateway token and connect through the tunnel
export OPENCLAW_GATEWAY_TOKEN="<gateway-token>"
openclaw node run --host 127.0.0.1 --port 18790 --display-name "Build Node"

備註:

  • openclaw node run 支援權杖或密碼驗證。
  • 偏好使用環境變數:OPENCLAW_GATEWAY_TOKEN / OPENCLAW_GATEWAY_PASSWORD
  • 組態備援方案是 gateway.auth.token / gateway.auth.password
  • 在本地模式下,節點主機會故意忽略 gateway.remote.token / gateway.remote.password
  • 在遠端模式下,根據遠端優先順序規則,gateway.remote.token / gateway.remote.password 是符合資格的。
  • 如果配置了作用中的本地 gateway.auth.* SecretRefs 但未解析,節點主機驗證將失敗關閉。
  • 節點主機驗證解析僅接受 OPENCLAW_GATEWAY_* 環境變數。
Terminal window
openclaw node install --host <gateway-host> --port 18789 --display-name "Build Node"
openclaw node start
openclaw node restart

在閘道主機上:

Terminal window
openclaw devices list
openclaw devices approve <requestId>
openclaw nodes status

如果節點使用變更的驗證詳細資訊重試,請重新執行 openclaw devices list 並批准目前的 requestId

命名選項:

  • --display-nameopenclaw node run / openclaw node install (持續存在於節點上的 ~/.openclaw/node.json 中)。
  • openclaw nodes rename --node <id|name|ip> --name "Build Node" (閘道覆寫)。

執行核准是針對每個節點主機的。請從閘道新增允許清單項目:

Terminal window
openclaw approvals allowlist add --node <id|name|ip> "/usr/bin/uname"
openclaw approvals allowlist add --node <id|name|ip> "/usr/bin/sw_vers"

審批位於節點主機的 ~/.openclaw/exec-approvals.json

設定預設值 (閘道組態):

Terminal window
openclaw config set tools.exec.host node
openclaw config set tools.exec.security allowlist
openclaw config set tools.exec.node "<id-or-name>"

或是每個階段:

/exec host=node security=allowlist node=<id-or-name>

設定後,任何帶有 host=nodeexec 呼叫都會在節點主機上執行(受限於 節點允許清單/核准)。

host=auto 不會自行隱含地選擇節點,但允許從 auto 發出明確的單次呼叫 host=node 請求。如果您希望節點 exec 成為該階段的預設值,請明確設定 tools.exec.host=node/exec host=node ...

相關:

底層 (原始 RPC):

Terminal window
openclaw nodes invoke --node <idOrNameOrIp> --command canvas.eval --params '{"javaScript":"location.href"}'

針對常見的「給予代理程式 MEDIA 附件」工作流程,存在更高層級的輔助工具。

節點指令必須通過兩道關卡才能被叫用:

  1. 節點必須在其 WebSocket connect.commands 列表中宣告該指令。
  2. Gateway 的平台政策必須允許該已宣告的指令。

Windows 和 macOS 伴隨節點預設允許安全的已宣告命令,例如 canvas.*camera.listlocation.getscreen.snapshot。 廣告 talk 功能或宣告 talk.* 命令的受信任節點 也預設允許已宣告的按住通話命令(talk.ptt.starttalk.ptt.stoptalk.ptt.canceltalk.ptt.once),與平台標籤無關。 危險或涉及隱私的命令,例如 camera.snapcamera.clipscreen.record,仍然需要透過 gateway.nodes.allowCommands 明確選擇加入。 gateway.nodes.denyCommands 始終優先於 預設值和額外的允許清單項目。

外掛程式擁有的節點命令可以新增 Gateway 節點調用原則。該原則 在允許清單檢查之後且轉發到節點之前執行,因此原始 node.invoke、CLI 助手和專用的代理程式工具共享相同的外掛程式 權限邊界。危險的外掛程式節點命令仍然需要明確 gateway.nodes.allowCommands 選擇加入。

節點變更其宣告的命令清單後,請拒絕舊的裝置配對 並批准新請求,以便 Gateway 儲存更新後的命令快照。

如果節點正在顯示 Canvas (WebView),canvas.snapshot 會傳回 { format, base64 }

CLI 助手(寫入暫存檔案並列印 MEDIA:<path>):

Terminal window
openclaw nodes canvas snapshot --node <idOrNameOrIp> --format png
openclaw nodes canvas snapshot --node <idOrNameOrIp> --format jpg --max-width 1200 --quality 0.9
Terminal window
openclaw nodes canvas present --node <idOrNameOrIp> --target https://example.com
openclaw nodes canvas hide --node <idOrNameOrIp>
openclaw nodes canvas navigate https://example.com --node <idOrNameOrIp>
openclaw nodes canvas eval --node <idOrNameOrIp> --js "document.title"

備註:

  • canvas present 接受 URL 或本機檔案路徑(--target),以及用於定位的可選 --x/--y/--width/--height
  • canvas eval 接受內聯 JS(--js)或位置引數。
Terminal window
openclaw nodes canvas a2ui push --node <idOrNameOrIp> --text "Hello"
openclaw nodes canvas a2ui push --node <idOrNameOrIp> --jsonl ./payload.jsonl
openclaw nodes canvas a2ui reset --node <idOrNameOrIp>

備註:

  • 僅支援 A2UI v0.8 JSONL(拒絕 v0.9/createSurface)。

照片(jpg):

Terminal window
openclaw nodes camera list --node <idOrNameOrIp>
openclaw nodes camera snap --node <idOrNameOrIp> # default: both facings (2 MEDIA lines)
openclaw nodes camera snap --node <idOrNameOrIp> --facing front

視訊片段(mp4):

Terminal window
openclaw nodes camera clip --node <idOrNameOrIp> --duration 10s
openclaw nodes camera clip --node <idOrNameOrIp> --duration 3000 --no-audio

備註:

  • 節點必須處於前景才能使用 canvas.*camera.*(背景呼叫會傳回 NODE_BACKGROUND_UNAVAILABLE)。
  • 剪輯持續時間會被限制(目前為 <= 60s),以避免 base64 載荷過大。
  • 在可能的情況下,Android 會提示授與 CAMERA/RECORD_AUDIO 權限;拒絕權限將導致失敗並傳回 *_PERMISSION_REQUIRED

支援的節點會公開 screen.record (mp4)。例如:

Terminal window
openclaw nodes screen record --node <idOrNameOrIp> --duration 10s --fps 10
openclaw nodes screen record --node <idOrNameOrIp> --duration 10s --fps 10 --no-audio

備註:

  • screen.record 的可用性取決於節點平台。
  • 螢幕錄製會被限制為 <= 60s
  • 在支援的平台上,--no-audio 會停用麥克風擷取。
  • 當有多個螢幕可用時,使用 --screen <index> 來選擇顯示器。

當在設定中啟用位置時,節點會公開 location.get

CLI 輔助工具:

Terminal window
openclaw nodes location get --node <idOrNameOrIp>
openclaw nodes location get --node <idOrNameOrIp> --accuracy precise --max-age 15000 --location-timeout 10000

備註:

  • 位置預設為關閉
  • 「始終」需要系統權限;背景擷取為盡力而為。
  • 回應包括經緯度、準確度(公尺)和時間戳記。

當使用者授予 SMS 權限且裝置支援電話功能時,Android 節點可以公開 sms.send

低層級調用:

Terminal window
openclaw nodes invoke --node <idOrNameOrIp> --command sms.send --params '{"to":"+15555550123","message":"Hello from OpenClaw"}'

備註:

  • 必須在 Android 裝置上接受權限提示,才會宣佈此功能。
  • 不具電話功能的僅 Wi-Fi 裝置將不會宣佈 sms.send

當啟用對應的功能時,Android 節點可以宣佈額外的指令系列。

可用的系列:

  • device.statusdevice.infodevice.permissionsdevice.health
  • notifications.listnotifications.actions
  • photos.latest
  • contacts.searchcontacts.add
  • calendar.eventscalendar.add
  • callLog.search
  • sms.search
  • motion.activity, motion.pedometer

範例呼叫:

Terminal window
openclaw nodes invoke --node <idOrNameOrIp> --command device.status --params '{}'
openclaw nodes invoke --node <idOrNameOrIp> --command notifications.list --params '{}'
openclaw nodes invoke --node <idOrNameOrIp> --command photos.latest --params '{"limit":1}'

註記:

  • 動作指令視可用感應器而定。

macOS 節點公開了 system.runsystem.notifysystem.execApprovals.get/set。 無頭節點主機公開了 system.runsystem.whichsystem.execApprovals.get/set

範例:

Terminal window
openclaw nodes notify --node <idOrNameOrIp> --title "Ping" --body "Gateway ready"
openclaw nodes invoke --node <idOrNameOrIp> --command system.which --params '{"name":"git"}'

註記:

  • system.run 會在 payload 中回傳 stdout/stderr/exit code。
  • Shell 執行現在透過 exec 工具並搭配 host=node 進行;nodes 仍是明確節點指令的直接 RPC 介面。
  • nodes invoke 不會公開 system.runsystem.run.prepare;這些僅保留在 exec 路徑上。
  • exec 路徑會在核准前準備一個標準的 systemRunPlan。一旦 核准通過,gateway 會轉發該儲存的計劃,而非任何後續 呼叫者編輯過的 command/cwd/session 欄位。
  • system.notify 會遵守 macOS 應用程式上的通知權限狀態。
  • 無法辨識的節點 platform / deviceFamily 中繼資料會使用保守的預設允許清單,其中排除 system.runsystem.which。如果您刻意需要在未知平台上使用這些指令,請透過 gateway.nodes.allowCommands 明確新增它們。
  • system.run 支援 --cwd--env KEY=VAL--command-timeout--needs-screen-recording
  • 對於 shell 包裝器 (bash|sh|zsh ... -c/-lc),請求範圍的 --env 值會縮減為明確的允許清單 (TERMLANGLC_*COLORTERMNO_COLORFORCE_COLOR)。
  • 在允許清單模式下,對於始終允許的決策,已知的分發包裝器 (env, nice, nohup, stdbuf, timeout) 會保留內部可執行檔路徑而非包裝器路徑。如果解包不安全,則不會自動保留允許清單條目。
  • 在允許清單模式下的 Windows 節點主機上,透過 cmd.exe /c 執行的 shell 包裝器需要核准(僅有允許清單條目不會自動允許包裝器形式)。
  • system.notify 支援 --priority <passive|active|timeSensitive>--delivery <system|overlay|auto>
  • 節點主機會忽略 PATH 覆蓋設定,並移除危險的啟動/shell 金鑰 (DYLD_*, LD_*, NODE_OPTIONS, PYTHON*, PERL*, RUBYOPT, SHELLOPTS, PS4)。如果您需要額外的 PATH 項目,請設定節點主機服務環境(或將工具安裝在標準位置),而不是透過 --env 傳遞 PATH
  • 在 macOS 節點模式下,system.run 受 macOS 應用程式中的執行核准限制(設定 → 執行核准)。 詢問/允許清單/完整 的行為與無頭節點主機相同;拒絕的提示會傳回 SYSTEM_RUN_DENIED
  • 在無頭節點主機上,system.run 受執行核准限制 (~/.openclaw/exec-approvals.json)。

當有多個節點可用時,您可以將 exec 綁定到特定節點。 這會設定 exec host=node 的預設節點(並且可以針對每個代理程式進行覆蓋)。

全域預設值:

Terminal window
openclaw config set tools.exec.node "node-id-or-name"

針對每個代理程式的覆蓋:

Terminal window
openclaw config get agents.list
openclaw config set agents.list[0].tools.exec.node "node-id-or-name"

取消設定以允許任何節點:

Terminal window
openclaw config unset tools.exec.node
openclaw config unset agents.list[0].tools.exec.node

節點可以在 node.list / node.describe 中包含 permissions 映射,以權限名稱為鍵(例如 screenRecording, accessibility),值為布林值(true = 已授予)。

OpenClaw 可以運行一個 無頭節點主機(無 UI),它連接到 Gateway WebSocket 並暴露 system.run / system.which。這在 Linux/Windows 上很有用,或者用於在伺服器旁運行一個最小化的節點。

啟動它:

Terminal window
openclaw node run --host <gateway-host> --port 18789

注意:

  • 仍然需要配對(Gateway 將顯示設備配對提示)。
  • 節點主機將其節點 ID、令牌、顯示名稱和 Gateway 連接資訊存儲在 ~/.openclaw/node.json 中。
  • 執行批准通過 ~/.openclaw/exec-approvals.json 在本地執行 (請參閱 執行批准)。
  • 在 macOS 上,無頭節點主機預設在本地執行 system.run。設置 OPENCLAW_NODE_EXEC_HOST=app 以通過配套應用程式執行主機路由 system.run;添加 OPENCLAW_NODE_EXEC_FALLBACK=0 以要求應用程式主機,並在不可用時以封閉模式失敗。
  • 當 Gateway WS 使用 TLS 時,添加 --tls / --tls-fingerprint
  • macOS 選單列應用程式作為節點連接到 Gateway WS 伺服器(因此 openclaw nodes … 可以針對此 Mac 運作)。
  • 在遠端模式下,應用程式會為 Gateway 埠打開 SSH 隧道並連接到 localhost