Webhooks¶
Gateway(ゲートウェイ)は、外部トリガー用に小規模な HTTP ウェブフックエンドポイントを公開できます。
有効化¶
{
hooks: {
enabled: true,
token: "shared-secret",
path: "/hooks",
},
}
注記:
hooks.tokenは、hooks.enabled=trueの場合に必須です。hooks.pathのデフォルトは/hooksです。
認証¶
すべてのリクエストにはフックトークンを含める必要があります。ヘッダーの使用を推奨します。 ヘッダーを優先:
Authorization: Bearer <token>(推奨)x-openclaw-token: <token>?token=<token>(非推奨。警告がログに記録され、将来のメジャーリリースで削除されます)
エンドポイント¶
POST /hooks/wake¶
ペイロード:
{ "text": "System line", "mode": "now" }
text必須(string): イベントの説明(例: 「New email received」)。mode任意(now|next-heartbeat): 即時ハートビートをトリガーするか(デフォルトはnow)、次回の定期チェックまで待機するか。
効果:
- main セッション向けにシステムイベントをキューに追加します。
mode=nowの場合、即時ハートビートをトリガーします。
POST /hooks/agent¶
ペイロード:
{
"message": "Run this",
"name": "Email",
"sessionKey": "hook:email:msg-123",
"wakeMode": "now",
"deliver": true,
"channel": "last",
"to": "+15551234567",
"model": "openai/gpt-5.2-mini",
"thinking": "low",
"timeoutSeconds": 120
}
message必須(string): エージェントが処理するプロンプトまたはメッセージ。name任意(string): フックの人間可読な名前(例: 「GitHub」)。セッションサマリーのプレフィックスとして使用されます。sessionKey任意(string): エージェントのセッションを識別するためのキー。デフォルトはランダムなhook:<uuid>です。一貫したキーを使用すると、フックコンテキスト内でのマルチターン会話が可能になります。 デフォルトはランダムなフック:<uuid>です。 一貫性のあるキーを使用すると、フックコンテキスト内で複数回会話が可能になります。wakeMode任意(now|next-heartbeat): 即時ハートビートをトリガーするか(デフォルトはnow)、次回の定期チェックまで待機するか。deliver任意(boolean):trueの場合、エージェントの応答がメッセージングチャンネルに送信されます。デフォルトはtrueです。ハートビート確認のみの応答は自動的にスキップされます。 デフォルトはtrueです。 ハートビート認識のみのレスポンスは自動的にスキップされます。channeloptional (string): 配信のためのメッセージングチャネル。channel任意(string): 配信先のメッセージングチャンネル。次のいずれか:last,whatsapp,telegram,discord,slack,mattermost(plugin),signal,imessage,msteams。デフォルトはlastです。 デフォルトはlastです。to任意(string): チャンネルの受信者識別子(例: WhatsApp/Signal の電話番号、Telegram の chat ID、Discord/Slack/Mattermost(plugin)の channel ID、MS Teams の conversation ID)。デフォルトは main セッションの最後の受信者です。 デフォルトは、メインセッションの最後の受信者です。model任意(string): モデルのオーバーライド(例:anthropic/claude-3-5-sonnetまたはエイリアス)。制限されている場合は、許可されたモデルリストに含まれている必要があります。 制限されている場合は、許可されているモデルリスト内にある必要があります。thinking任意(string): 思考レベルのオーバーライド(例:low,medium,high)。timeoutSeconds任意(number): エージェント実行の最大時間(秒)。
効果:
- 分離された エージェントターンを実行します(独自のセッションキー)。
- 常に main セッションにサマリーを投稿します。
wakeMode=nowの場合、即時ハートビートをトリガーします。
POST /hooks/<name>(mapped)¶
カスタムフック名は hooks.mappings で解決されます (構成を参照)。 カスタムフック名は hooks.mappings(設定を参照)によって解決されます。マッピングにより、
任意のペイロードを wake または agent アクションに変換できます。テンプレートや
コード変換は任意です。
マッピングオプション(概要):
hooks.presets: ["gmail"]は、組み込みの Gmail マッピングを有効にします。hooks.mappingsを使用すると、設定内でmatch,action, およびテンプレートを定義できます。hooks.transformsDir+transform.moduleは、カスタムロジック用の JS/TS モジュールを読み込みます。match.sourceを使用して、汎用的なインジェストエンドポイント(ペイロード駆動のルーティング)を維持できます。- TS 変換には、TS ローダー(例:
bunまたはtsx)または、実行時に事前コンパイルされた.jsが必要です。 - マッピングに
deliver: true+channel/toを設定すると、返信をチャットサーフェスへルーティングします (channelのデフォルトはlastで、WhatsApp にフォールバックします)。 allowUnsafeExternalContent: trueは、そのフックに対して外部コンテンツ安全ラッパーを無効化します (危険です。信頼された内部ソースのみに使用してください)。openclaw webhooks gmail setupは、openclaw webhooks gmail run用のhooks.gmail設定を書き込みます。 Gmail の完全なウォッチフローについては Gmail Pub/Sub を参照してください。 Gmail のウォッチフローについては、Gmail Pub/Subを参照してください。
Responses¶
/hooks/wakeに対して200/hooks/agentに対して202(非同期実行が開始されました)- 認証失敗時は
401 - 無効なペイロード時は
400 - ペイロードが過大な場合は
413
Examples¶
curl -X POST http://127.0.0.1:18789/hooks/wake \
-H 'Authorization: Bearer SECRET' \
-H 'Content-Type: application/json' \
-d '{"text":"New email received","mode":"now"}'
curl -X POST http://127.0.0.1:18789/hooks/agent \
-H 'x-openclaw-token: SECRET' \
-H 'Content-Type: application/json' \
-d '{"message":"Summarize inbox","name":"Email","wakeMode":"next-heartbeat"}'
Use a different model¶
エージェントのペイロード(またはマッピング)に model を追加すると、その実行に対してモデルをオーバーライドできます。
curl -X POST http://127.0.0.1:18789/hooks/agent \
-H 'x-openclaw-token: SECRET' \
-H 'Content-Type: application/json' \
-d '{"message":"Summarize inbox","name":"Email","model":"openai/gpt-5.2-mini"}'
agents.defaults.models を強制している場合は、オーバーライドするモデルがそこに含まれていることを確認してください。
curl -X POST http://127.0.0.1:18789/hooks/gmail \
-H 'Authorization: Bearer SECRET' \
-H 'Content-Type: application/json' \
-d '{"source":"gmail","messages":[{"from":"Ada","subject":"Hello","snippet":"Hi"}]}'
Security¶
- フックエンドポイントは、loopback、tailnet、または信頼されたリバースプロキシの背後に配置してください。
- 専用のフックトークンを使用し、ゲートウェイ認証トークンを再利用しないでください。
- ウェブフックログに機密性の高い生のペイロードを含めないようにしてください。
- フックペイロードは、デフォルトで信頼されていないものとして扱われ、安全境界でラップされます。
特定のフックに対してこれを無効にする必要がある場合は、そのフックのマッピングに
allowUnsafeExternalContent: trueを設定してください(危険)。