跳转到主要内容

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

工具调用 (HTTP)

OpenClaw 的 Gateway 网关公开了一个简单的 HTTP 端点,用于直接调用单个工具。它始终启用,并使用 Gateway 网关认证加工具策略。与 OpenAI 兼容的 /v1/* 接口一样,共享密钥 Bearer 认证会被视为整个 Gateway 网关的受信任操作员访问权限。
  • POST /tools/invoke
  • 与 Gateway 网关相同端口(WS + HTTP 多路复用):http://<gateway-host>:<port>/tools/invoke
默认最大载荷大小为 2 MB。

认证

使用 Gateway 网关认证配置。 常见 HTTP 认证路径:
  • 共享密钥认证(gateway.auth.mode="token""password"): Authorization: Bearer <token-or-password>
  • 携带受信任身份的 HTTP 认证(gateway.auth.mode="trusted-proxy"): 通过已配置的身份感知代理路由,并让它注入所需的身份标头
  • 私有入口开放认证(gateway.auth.mode="none"): 不需要认证标头
注意:
  • gateway.auth.mode="token" 时,使用 gateway.auth.token(或 OPENCLAW_GATEWAY_TOKEN)。
  • gateway.auth.mode="password" 时,使用 gateway.auth.password(或 OPENCLAW_GATEWAY_PASSWORD)。
  • gateway.auth.mode="trusted-proxy" 时,HTTP 请求必须来自已配置的受信任代理来源;同主机 loopback 代理需要显式设置 gateway.auth.trustedProxy.allowLoopback = true
  • 如果配置了 gateway.auth.rateLimit 且认证失败次数过多,该端点会返回 429,并带有 Retry-After

安全边界(重要)

将此端点视为 Gateway 网关实例的完整操作员访问接口。
  • 这里的 HTTP Bearer 认证不是狭义的按用户范围模型。
  • 此端点的有效 Gateway 网关令牌/密码应被视为所有者/操作员凭据。
  • 对于共享密钥认证模式(tokenpassword),即使调用方发送范围更窄的 x-openclaw-scopes 标头,该端点也会恢复正常的完整操作员默认值。
  • 共享密钥认证还会将此端点上的直接工具调用视为所有者发送方轮次。
  • 携带受信任身份的 HTTP 模式(例如受信任代理认证,或私有入口上的 gateway.auth.mode="none")会在存在 x-openclaw-scopes 时遵循该标头,否则回退到正常的操作员默认范围集。
  • 仅将此端点保留在 loopback/tailnet/私有入口上;不要将它直接暴露到公网。
认证矩阵:
  • gateway.auth.mode="token""password" + Authorization: Bearer ...
    • 证明持有共享的 Gateway 网关操作员密钥
    • 忽略范围更窄的 x-openclaw-scopes
    • 恢复完整的默认操作员范围集: operator.admin, operator.approvals, operator.pairing, operator.read, operator.talk.secrets, operator.write
    • 将此端点上的直接工具调用视为所有者发送方轮次
  • 携带受信任身份的 HTTP 模式(例如受信任代理认证,或私有入口上的 gateway.auth.mode="none"
    • 对某个外部受信任身份或部署边界进行认证
    • 当标头存在时遵循 x-openclaw-scopes
    • 当标头缺失时回退到正常的操作员默认范围集
    • 仅当调用方显式缩小范围并省略 operator.admin 时,才会失去所有者语义

请求正文

{
  "tool": "sessions_list",
  "action": "json",
  "args": {},
  "sessionKey": "main",
  "dryRun": false
}
字段:
  • tool(字符串,必填):要调用的工具名称。
  • action(字符串,可选):如果工具 schema 支持 action,且 args 载荷中省略了它,则映射到 args 中。
  • args(对象,可选):工具特定的参数。
  • sessionKey(字符串,可选):目标会话键。如果省略或为 "main",Gateway 网关会使用已配置的主会话键(遵循 session.mainKey 和默认智能体,或全局范围中的 global)。
  • dryRun(布尔值,可选):保留供将来使用;当前会被忽略。

策略 + 路由行为

工具可用性会通过 Gateway 网关智能体使用的同一策略链进行过滤:
  • tools.profile / tools.byProvider.profile
  • tools.allow / tools.byProvider.allow
  • agents.<id>.tools.allow / agents.<id>.tools.byProvider.allow
  • 组策略(如果会话键映射到组或渠道)
  • 子智能体策略(使用子智能体会话键调用时)
如果策略不允许某个工具,该端点会返回 404 重要边界说明:
  • Exec 审批是操作员防护机制,不是此 HTTP 端点的独立授权边界。如果某个工具可通过 Gateway 网关认证 + 工具策略在这里访问,/tools/invoke 不会添加额外的逐调用审批提示。
  • 不要与不受信任的调用方共享 Gateway 网关 Bearer 凭据。如果你需要跨信任边界隔离,请运行独立的 Gateway 网关(理想情况下也使用独立的 OS 用户/主机)。
Gateway 网关 HTTP 默认还会应用硬性拒绝列表(即使会话策略允许该工具):
  • exec — 直接命令执行(RCE 接口)
  • spawn — 任意子进程创建(RCE 接口)
  • shell — shell 命令执行(RCE 接口)
  • fs_write — 主机上的任意文件变更
  • fs_delete — 主机上的任意文件删除
  • fs_move — 主机上的任意文件移动/重命名
  • apply_patch — 补丁应用可以重写任意文件
  • sessions_spawn — 会话编排;远程生成智能体属于 RCE
  • sessions_send — 跨会话消息注入
  • cron — 持久化自动化控制平面
  • gateway — Gateway 网关控制平面;防止通过 HTTP 重新配置
  • nodes — 节点命令中继可以访问配对主机上的 system.run
  • whatsapp_login — 需要终端 QR 扫描的交互式设置;在 HTTP 上会挂起
你可以通过 gateway.tools 自定义此拒绝列表:
{
  gateway: {
    tools: {
      // Additional tools to block over HTTP /tools/invoke
      deny: ["browser"],
      // Remove tools from the default deny list
      allow: ["gateway"],
    },
  },
}
为帮助组策略解析上下文,你可以选择设置:
  • x-openclaw-message-channel: <channel>(示例:slacktelegram
  • x-openclaw-account-id: <accountId>(存在多个账号时)

响应

  • 200{ ok: true, result }
  • 400{ ok: false, error: { type, message } }(无效请求或工具输入错误)
  • 401 → 未授权
  • 429 → 认证被限速(已设置 Retry-After
  • 404 → 工具不可用(未找到或未加入允许列表)
  • 405 → 方法不允许
  • 500{ ok: false, error: { type, message } }(意外的工具执行错误;消息已脱敏)

示例

curl -sS http://127.0.0.1:18789/tools/invoke \
  -H 'Authorization: Bearer secret' \
  -H 'Content-Type: application/json' \
  -d '{
    "tool": "sessions_list",
    "action": "json",
    "args": {}
  }'

相关