Exec 工具
在工作区中运行 shell 命令。通过process 支持前台和后台执行。
如果 process 被禁用,exec 将同步运行并忽略 yieldMs/background。
后台会话按智能体隔离;process 只能查看同一智能体的会话。
参数
command(必填)workdir(默认为当前工作目录)env(键/值覆盖)yieldMs(默认 10000):延迟后自动转为后台运行background(布尔值):立即转为后台运行timeout(秒,默认 1800):超时后终止pty(布尔值):在可用时使用伪终端运行(仅 TTY 的 CLI、编程智能体、终端 UI)host(sandbox | gateway | node):执行位置security(deny | allowlist | full):gateway/node的执行策略模式ask(off | on-miss | always):gateway/node的审批提示node(字符串):host=node时的节点 ID/名称elevated(布尔值):请求提权模式(gateway 主机);仅当提权解析为full时才强制security=full
host默认为sandbox。- 当沙箱关闭时,
elevated被忽略(exec 已直接在主机上运行)。 gateway/node的审批由~/.openclaw/exec-approvals.json控制。node需要已配对的节点(伴侣应用或无头节点主机)。- 如果有多个节点可用,请设置
exec.node或tools.exec.node来选择一个。 - 在非 Windows 主机上,exec 在设置了
SHELL时使用该 shell;如果SHELL是fish,它会优先从PATH中选择bash(或sh)以避免 fish 不兼容的脚本,如果两者都不存在则回退到SHELL。 - 重要:沙箱默认关闭。如果沙箱关闭,
host=sandbox将直接在 Gateway网关主机上运行(无容器)且不需要审批。要启用审批,请使用host=gateway并配置 exec 审批(或启用沙箱)。
配置
tools.exec.notifyOnExit(默认:true):为 true 时,后台 exec 会话在退出时会排入系统事件并请求心跳。tools.exec.approvalRunningNoticeMs(默认:10000):当需要审批的 exec 运行超过此时间时,发出一条”运行中”通知(设为 0 禁用)。tools.exec.host(默认:sandbox)tools.exec.security(默认:sandbox 为deny,未设置时 gateway + node 为allowlist)tools.exec.ask(默认:on-miss)tools.exec.node(默认:未设置)tools.exec.pathPrepend:exec 运行时要添加到PATH前面的目录列表。tools.exec.safeBins:仅通过标准输入的安全二进制文件,无需显式添加到允许列表即可运行。
PATH 处理
host=gateway:将你的登录 shellPATH合并到 exec 环境中(除非 exec 调用已设置env.PATH)。守护进程本身仍使用最小PATH运行:- macOS:
/opt/homebrew/bin、/usr/local/bin、/usr/bin、/bin - Linux:
/usr/local/bin、/usr/bin、/bin
- macOS:
host=sandbox:在容器内运行sh -lc(登录 shell),因此/etc/profile可能会重置PATH。OpenClaw 在 profile 加载后通过内部环境变量添加env.PATH(无 shell 插值);tools.exec.pathPrepend在此同样适用。host=node:仅发送你传递的 env 覆盖到节点。tools.exec.pathPrepend仅在 exec 调用已设置env.PATH时适用。无头节点主机仅在PATH为节点主机 PATH 前缀时接受PATH覆盖(不支持替换)。macOS 节点完全忽略PATH覆盖。
会话覆盖(/exec)
使用 /exec 设置 host、security、ask 和 node 的按会话默认值。
不带参数发送 /exec 可查看当前值。
示例:
授权模型
/exec 仅对已授权的发送者生效(渠道允许列表/配对加 commands.useAccessGroups)。
它仅更新会话状态,不会写入配置。要彻底禁用 exec,请通过工具策略拒绝它(tools.deny: ["exec"] 或按智能体设置)。除非你显式设置 security=full 和 ask=off,否则主机审批仍然适用。
Exec 审批(伴侣应用 / 节点主机)
沙箱隔离的智能体可以要求在exec 于 Gateway网关或节点主机上运行前进行逐次审批。
请参阅 Exec 审批 了解策略、允许列表和 UI 流程。
当需要审批时,exec 工具会立即返回 status: "approval-pending" 和一个审批 ID。一旦被批准(或拒绝/超时),Gateway网关会发出系统事件(Exec finished / Exec denied)。如果命令在 tools.exec.approvalRunningNoticeMs 之后仍在运行,会发出一条 Exec running 通知。
允许列表与安全二进制文件
允许列表执行仅匹配已解析的二进制文件路径(不匹配基本名称)。当security=allowlist 时,shell 命令仅在每个管道段都在允许列表中或属于安全二进制文件时才会自动放行。在允许列表模式下,链式操作(;、&&、||)和重定向会被拒绝。
示例
前台:apply_patch(实验性)
apply_patch 是 exec 的子工具,用于结构化的多文件编辑。
需显式启用:
- 仅适用于 OpenAI/OpenAI Codex 模型。
- 工具策略仍然适用;
allow: ["exec"]隐式允许apply_patch。 - 配置位于
tools.exec.applyPatch下。