> ## Documentation Index
> Fetch the complete documentation index at: https://docs.openclaw.kr/llms.txt
> Use this file to discover all available pages before exploring further.

# 도구 호출 API

# 도구 호출 (HTTP)

OpenClaw의 게이트웨이는 단일 도구를 직접 호출하기 위한 간단한 HTTP 엔드포인트를 제공합니다. 항상 활성화되어 있으며 게이트웨이 인증 및 도구 정책에 의해 제어됩니다.

* `POST /tools/invoke`
* 게이트웨이와 동일한 포트 (WS + HTTP 멀티플렉스): `http://<gateway-host>:<port>/tools/invoke`

기본 최대 페이로드 크기는 2MB입니다.

## 인증

게이트웨이 인증 설정을 사용합니다. 베어러 토큰(Bearer token)을 전송하세요:

* `Authorization: Bearer <token>`

주의사항:

* `gateway.auth.mode="token"`일 때, `gateway.auth.token`(또는 `OPENCLAW_GATEWAY_TOKEN`)을 사용하세요.
* `gateway.auth.mode="password"`일 때, `gateway.auth.password`(또는 `OPENCLAW_GATEWAY_PASSWORD`)를 사용하세요.
* `gateway.auth.rateLimit`이 설정되어 있고 인증 실패가 너무 많이 발생하면, 엔드포인트는 `429`와 함께 `Retry-After`를 반환합니다.

## 요청 본문

```json theme={"theme":{"light":"min-light","dark":"min-dark"}}
{
  "tool": "sessions_list",
  "action": "json",
  "args": {},
  "sessionKey": "main",
  "dryRun": false
}
```

필드:

* `tool` (string, 필수): 호출할 도구 이름.
* `action` (string, 선택): 도구 스키마가 `action`을 지원하며 args 페이로드에서 생략된 경우 args에 매핑됩니다.
* `args` (object, 선택): 도구별 인수.
* `sessionKey` (string, 선택): 대상 세션 키. 생략되거나 `"main"`인 경우, 게이트웨이는 설정된 메인 세션 키를 사용합니다(`session.mainKey` 및 기본 에이전트, 또는 전역 범위에서 `global` 준수).
* `dryRun` (boolean, 선택): 향후 사용을 위해 예약됨; 현재는 무시됩니다.

## 정책 + 라우팅 동작

도구 가용성은 게이트웨이 에이전트에서 사용하는 동일한 정책 체인을 통해 필터링됩니다:

* `tools.profile` / `tools.byProvider.profile`
* `tools.allow` / `tools.byProvider.allow`
* `agents.<id>.tools.allow` / `agents.<id>.tools.byProvider.allow`
* 그룹 정책 (세션 키가 그룹 또는 채널에 매핑될 경우)
* 서브에이전트 정책 (서브에이전트 세션 키로 호출할 때)

정책에 의해 도구가 허용되지 않으면, 엔드포인트는 **404**를 반환합니다.

게이트웨이 HTTP는 기본적으로 하드 거부 목록을 적용합니다 (세션 정책이 도구를 허용하더라도):

* `sessions_spawn`
* `sessions_send`
* `gateway`
* `whatsapp_login`

이 거부 목록은 `gateway.tools`를 통해 사용자 지정할 수 있습니다:

```json5 theme={"theme":{"light":"min-light","dark":"min-dark"}}
{
  gateway: {
    tools: {
      // HTTP /tools/invoke에서 추가로 차단할 도구
      deny: ["browser"],
      // 기본 거부 목록에서 도구 제거
      allow: ["gateway"],
    },
  },
}
```

그룹 정책이 컨텍스트를 올바르게 해석할 수 있도록, 다음을 선택적으로 설정할 수 있습니다:

* `x-openclaw-message-channel: <channel>` (예: `slack`, `telegram`)
* `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 } }` (예상치 못한 도구 실행 오류; 메시지 정제됨)

## 예시

```bash theme={"theme":{"light":"min-light","dark":"min-dark"}}
curl -sS http://127.0.0.1:18789/tools/invoke \
  -H 'Authorization: Bearer YOUR_TOKEN' \
  -H 'Content-Type: application/json' \
  -d '{
    "tool": "sessions_list",
    "action": "json",
    "args": {}
  }'
```
