工具调用(HTTP)
OpenClaw的网关公开了一个简单的HTTP端点,用于直接调用单个工具。该端点始终启用,但受网关身份验证和工具策略的限制。POST /tools/invoke- 与网关相同的端口(WS + HTTP多路复用):
http://<gateway-host>:<port>/tools/invoke
身份验证
使用网关的身份验证配置。发送一个承载令牌:Authorization: Bearer <token>
- 当
gateway.auth.mode="token"时,使用gateway.auth.token(或OPENCLAW_GATEWAY_TOKEN)。 - 当
gateway.auth.mode="password"时,使用gateway.auth.password(或OPENCLAW_GATEWAY_PASSWORD)。
请求体
tool(字符串,必填):要调用的工具名称。action(字符串,可选):如果工具模式支持action且参数负载未提供,则映射到args。args(对象,可选):特定于工具的参数。sessionKey(字符串,可选):目标会话密钥。如果省略或为"main",网关将使用配置的主会话密钥(尊重session.mainKey和默认代理,或在全局范围内使用global)。dryRun(布尔值,可选):保留供将来使用;目前被忽略。
策略与路由行为
工具可用性通过与网关代理使用的相同策略链进行过滤:tools.profile/tools.byProvider.profiletools.allow/tools.byProvider.allowagents.<id>.tools.allow/agents.<id>.tools.byProvider.allow- 组策略(如果会话密钥映射到组或频道)
- 子代理策略(使用子代理会话密钥调用时)
x-openclaw-message-channel: <channel>(示例:slack,telegram)x-openclaw-account-id: <accountId>(当存在多个账户时)
响应
200→{ ok: true, result }400→{ ok: false, error: { type, message } }(无效请求或工具错误)401→ 未授权404→ 工具不可用(未找到或未列入白名单)405→ 方法不允许