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(布尔值):请求提升模式(网关主机);只有当提升解析为full时,才会强制启用security=full
host默认为sandbox。- 当沙箱关闭时,
elevated被忽略(exec 已在主机上运行)。 gateway/node审批由~/.openclaw/exec-approvals.json控制。node需要配对节点(配套应用或无头节点主机)。- 如果有多个节点可用,设置
exec.node或tools.exec.node来选择一个。 - 在非 Windows 主机上,如果设置了
SHELL,exec 将使用它;如果SHELL是fish,则优先使用bash(或sh)
PATH,以避免与 fish 不兼容的脚本,如果两者都不存在,则回退到 SHELL。
- 重要提示:沙箱默认关闭。如果沙箱关闭,
host=sandbox将直接在网关主机上运行(无需容器),并且不需要审批。若需审批,请使用host=gateway运行,并配置 exec 审批(或启用沙箱)。
配置
tools.exec.notifyOnExit(默认:真):当设置为真时,后台 exec 会话在退出时会排队系统事件并请求心跳。tools.exec.approvalRunningNoticeMs(默认:10000):当受审批限制的 exec 运行时间超过此值时,系统会发出一条“正在运行”的通知(0 表示禁用)。tools.exec.host(默认:sandbox)tools.exec.security(默认:沙箱为deny,网关 + 节点未设置时为allowlist)tools.exec.ask(默认:on-miss)tools.exec.node(默认:未设置)tools.exec.pathPrepend:用于在 exec 运行时预置到PATH的目录列表。tools.exec.safeBins:无需显式白名单条目即可运行的仅 stdin 安全二进制文件。
路径处理
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。
env.PATH(无需 shell 插值);
tools.exec.pathPrepend 在此处同样适用。
host=node:只有您传递的环境变量覆盖会被发送到节点。tools.exec.pathPrepend仅在 exec 调用已设置env.PATH时生效。无头节点主机仅在PATH预先添加节点主机 PATH 时接受(不替换)。macOS 节点完全忽略PATH覆盖。
会话覆盖(/exec)
使用 /exec 设置 host、security、ask 和 node 的每会话默认值。
发送 /exec 且不带参数以显示当前值。
示例:
授权模型
/exec 仅对 授权发件人 有效(渠道白名单/配对加上 commands.useAccessGroups)。
它仅更新 会话状态,不会写入配置。要硬性禁用 exec,请通过工具策略(tools.deny: ["exec"] 或按代理)拒绝它。主机审批仍然适用,除非您明确设置 security=full 和 ask=off。
执行审批(配套应用 / 节诺主机)
沙箱代理可在exec在网关或节点主机上运行前要求逐次审批。
有关政策、白名单和 UI 流程,请参阅Exec 审批。
当需要审批时,exec 工具会立即返回 status: "approval-pending" 和审批 ID。一旦获得批准(或被拒绝/超时),
网关会发出系统事件(Exec finished/Exec denied)。如果命令在 tools.exec.approvalRunningNoticeMs 后仍在运行,
则会发出一条 Exec running 通知。
白名单 + 安全二进制文件
白名单强制仅匹配解析后的二进制路径(不匹配基本文件名)。当security=allowlist时,
Shell 命令仅在每个管道段都列入白名单或为安全二进制文件时才自动允许。在白名单模式下,
链式调用(;、&&、||)和重定向将被拒绝。
示例
前台:应用补丁(实验性)
apply_patch 是 exec 的子工具,用于结构化多文件编辑。
请显式启用:
- 仅适用于 OpenAI/OpenAI Codex 模型。
- 工具策略仍然适用;
allow: ["exec"]默默允许apply_patch。 - 配置位于
tools.exec.applyPatch下。