Gmail Pub/Sub -> OpenClaw
目標: Gmail watch -> Pub/Sub プッシュ ->gog gmail watch serve -> OpenClaw Webhook。
Prereq
gcloudがインストールされ、ログイン済みであること(インストールガイド)。gog(gogcli)がインストールされ、Gmail アカウントに対して認可済みであること(gogcli.sh)。- OpenClaw のフックが有効になっていること(Webhooks を参照)。
tailscalelogged in (tailscale.com). サポートされているセットアップでは、パブリック HTTPS エンドポイントの Tailscale Funnel が使用されます。 他のトンネルサービスは機能しますが、DIY/サポートされておらず、手動配線が必要です。 現在、私たちが支援しているのは、大規模なものです。 他のトンネルサービスは機能しますが、DIY/サポートされておらず、手動配線が必要です。 現在、私たちが支援しているのは、大規模なものです。
deliver と、任意で channel/to を設定するマッピングでプリセットを上書きします。
channel + to を設定します。 固定チャンネルにしたい場合は、channel と to を設定します。そうでない場合、channel: "last" は直近の配信ルートを使用します(WhatsApp にフォールバックします)。
Gmail 実行時により安価なモデルを強制するには、マッピング内で model を設定します(provider/model またはエイリアス)。agents.defaults.models を強制する場合は、そこに含めてください。 agents.defaults.models を強制する場合は、そこに含めます。 agents.defaults.models を強制する場合は、そこに含めます。
Gmail フック専用のデフォルトモデルと思考レベルを設定するには、設定に hooks.gmail.model / hooks.gmail.thinking を追加します。
- マッピング内のフック単位の
model/thinkingは、これらのデフォルトを引き続き上書きします。 - フォールバック順序:
hooks.gmail.model→agents.defaults.model.fallbacks→ プライマリ(認証/レート制限/タイムアウト)。 agents.defaults.modelsが設定されている場合、Gmail モデルは許可リストに含まれている必要があります。- Gmail フックのコンテンツは、デフォルトで外部コンテンツの安全境界でラップされます。
無効化するには(危険)、
hooks.gmail.allowUnsafeExternalContent: trueを設定してください。 無効にするには、hooks.gmail.allowUnsafeExternalContent: trueを設定します。 無効にするには、hooks.gmail.allowUnsafeExternalContent: trueを設定します。
hooks.mappings を追加するか、hooks.transformsDir 配下に JS/TS の変換モジュールを追加します(Webhooks を参照)。
ウィザード(推奨)
OpenClaw ヘルパーを使用して、すべてをまとめて配線します(macOS では brew 経由で依存関係をインストールします)。- 公開プッシュエンドポイントに Tailscale Funnel を使用します。
openclaw webhooks gmail run向けにhooks.gmail設定を書き込みます。- Gmail フックのプリセット(
hooks.presets: ["gmail"])を有効化します。
tailscale.mode が有効な場合、OpenClaw は自動的に
hooks.gmail.serve.path を / に設定し、公開パスを
hooks.gmail.tailscale.path(デフォルト /gmail-pubsub)に保持します。これは Tailscale が
プロキシ時に set-path のプレフィックスを削除するためです。
バックエンドでプレフィックス付きパスを受信する必要がある場合は、
hooks.gmail.tailscale.target(または --tailscale-target)を
http://127.0.0.1:8788/gmail-pubsub のような完全な URL に設定し、hooks.gmail.serve.path を一致させてください。
接頭辞付きパスを受け取るためにバックエンドが必要な場合は、
hooks.gmail.tailscale.target (または --tailscale-target ) に
http://127.0.0.1:8788/gmail-pubsub のような完全な URL を設定し、hooks.gmail.serve.path と一致します。
接頭辞付きパスを受け取るためにバックエンドが必要な場合は、
hooks.gmail.tailscale.target (または --tailscale-target ) に
http://127.0.0.1:8788/gmail-pubsub のような完全な URL を設定し、hooks.gmail.serve.path と一致します。
カスタムエンドポイントをご希望ですか? カスタムエンドポイントをご希望ですか? カスタムエンドポイントを使用したい場合は、--push-endpoint <url> または --tailscale off を使用してください。
プラットフォームに関する注意: macOS では、ウィザードが Homebrew 経由で gcloud、gogcli、tailscale をインストールします。
Linux では、事前に手動でインストールしてください。
Gateway の自動起動(推奨):
hooks.enabled=trueとhooks.gmail.accountが設定されている場合、Gateway は 起動時にgog gmail watch serveを開始し、watch を自動更新します。- オプトアウトするには
OPENCLAW_SKIP_GMAIL_WATCHER=1を設定します(デーモンを自分で実行する場合に有用です)。 - 手動デーモンを同時に実行しないでください。
listen tcp 127.0.0.1:8788: bind: address already in useが発生します。
gog gmail watch serve を開始 + 自動更新):
初回セットアップ
gogが使用する OAuth クライアントを所有する GCP プロジェクトを選択します。
- API を有効化します。
- トピックを作成します。
- Gmail プッシュの公開を許可します。
watch を開始
history_id を保存してください(デバッグ用)。
プッシュハンドラーを実行
ローカル例(共有トークン認証):--tokenはプッシュエンドポイント(x-gog-tokenまたは?token=)を保護します。--hook-urlは OpenClaw の/hooks/gmailを指します(マッピング済み;分離実行 + メインへのサマリー)。--include-bodyと--max-bytesは、OpenClaw に送信される本文スニペットを制御します。
openclaw webhooks gmail run は同じフローをラップし、watch を自動更新します。
ハンドラーを公開(高度、非サポート)
Tailscale 以外のトンネルが必要な場合は、手動で配線し、プッシュサブスクリプションに公開 URL を使用してください(非サポート、ガードレールなし)。テスト
ウォッチした受信トレイにメッセージを送信:トラブルシューティング
Invalid topicName: プロジェクトの不一致(トピックが OAuth クライアントのプロジェクトにありません)。User not authorized: トピックにroles/pubsub.publisherがありません。- 空のメッセージ: Gmail プッシュは
historyIdのみを提供します。gog gmail history経由で取得してください。