Bundled plugin guides

Webhook Plugin

Webhooks Plugin は、外部オートメーションを OpenClaw TaskFlow にバインドする認証付き HTTP ルートを追加します。

Zapier、n8n、CI ジョブ、内部サービスなどの信頼済みシステムで、先にカスタム Plugin を書かずに管理対象 TaskFlow を作成して進めたい場合に使用します。

実行場所

Webhooks Plugin は Gateway プロセス内で実行されます。

Gateway が別のマシンで実行されている場合は、その Gateway ホストに Plugin をインストールして設定し、その後 Gateway を再起動します。

ルートを設定する

plugins.entries.webhooks.config 配下に設定します。

json5
{  plugins: {    entries: {      webhooks: {        enabled: true,        config: {          routes: {            zapier: {              path: "/plugins/webhooks/zapier",              sessionKey: "agent:main:main",              secret: {                source: "env",                provider: "default",                id: "OPENCLAW_WEBHOOK_SECRET",              },              controllerId: "webhooks/zapier",              description: "Zapier TaskFlow bridge",            },          },        },      },    },  },}

ルートフィールド:

  • enabled: 省略可能。デフォルトは true
  • path: 省略可能。デフォルトは /plugins/webhooks/<routeId>
  • sessionKey: バインドされた TaskFlow を所有する必須セッション
  • secret: 必須の共有シークレットまたは SecretRef
  • controllerId: 作成される管理対象フロー用の省略可能なコントローラー ID
  • description: 省略可能なオペレーター向けメモ

サポートされる secret 入力:

  • プレーン文字列
  • source: "env" | "file" | "exec" を持つ SecretRef

シークレットに基づくルートが起動時にシークレットを解決できない場合、Plugin は壊れたエンドポイントを公開する代わりに、そのルートをスキップして警告をログに記録します。

セキュリティモデル

各ルートは、設定された sessionKey の TaskFlow 権限で動作するものとして信頼されます。

つまり、ルートはそのセッションが所有する TaskFlow を検査および変更できるため、次のことを行うべきです。

  • ルートごとに強力で一意のシークレットを使用する
  • インラインの平文シークレットよりシークレット参照を優先する
  • ワークフローに適合する最も狭いセッションにルートをバインドする
  • 必要な特定の Webhook パスだけを公開する

Plugin は次を適用します。

  • 共有シークレット認証
  • リクエスト本文サイズとタイムアウトのガード
  • 固定ウィンドウのレート制限
  • 実行中リクエストの制限
  • api.runtime.tasks.managedFlows.bindSession(...) による所有者バインドの TaskFlow アクセス

リクエスト形式

次を含む POST リクエストを送信します。

  • Content-Type: application/json
  • Authorization: Bearer <secret> または x-openclaw-webhook-secret: <secret>

例:

bash
curl -X POST https://gateway.example.com/plugins/webhooks/zapier \  -H 'Content-Type: application/json' \  -H 'Authorization: Bearer YOUR_SHARED_SECRET' \  -d '{"action":"create_flow","goal":"Review inbound queue"}'

サポートされるアクション

Plugin は現在、次の JSON action 値を受け付けます。

  • create_flow
  • get_flow
  • list_flows
  • find_latest_flow
  • resolve_flow
  • get_task_summary
  • set_waiting
  • resume_flow
  • finish_flow
  • fail_flow
  • request_cancel
  • cancel_flow
  • run_task

create_flow

ルートにバインドされたセッション用の管理対象 TaskFlow を作成します。

例:

json
{  "action": "create_flow",  "goal": "Review inbound queue",  "status": "queued",  "notifyPolicy": "done_only"}

run_task

既存の管理対象 TaskFlow 内に管理対象の子タスクを作成します。

許可されるランタイムは次のとおりです。

  • subagent
  • acp

例:

json
{  "action": "run_task",  "flowId": "flow_123",  "runtime": "acp",  "childSessionKey": "agent:main:acp:worker",  "task": "Inspect the next message batch"}

レスポンス形式

成功したレスポンスは次を返します。

json
{  "ok": true,  "routeId": "zapier",  "result": {}}

拒否されたリクエストは次を返します。

json
{  "ok": false,  "routeId": "zapier",  "code": "not_found",  "error": "TaskFlow not found.",  "result": {}}

Plugin は意図的に、Webhook レスポンスから所有者/セッションのメタデータを取り除きます。

関連ドキュメント

Was this useful?