Gmail Pub/Sub -> OpenClaw
目標:Gmail watch -> Pub/Sub push ->gog gmail watch serve -> OpenClaw Webhook。
前置條件
gcloud已安裝且已登入(安裝指南)。gog(gogcli) 已安裝且授權給 Gmail 帳戶(gogcli.sh)。- OpenClaw Hooks 已啟用(見 Webhooks)。
tailscale已登入(tailscale.com)。支援的設定使用 Tailscale Funnel 作為公開 HTTPS 端點。 其他隧道服務可以工作,但自行管理/不支援,需要手動接線。 現在,Tailscale 是我們支援的內容。
deliver + 選用的 channel/to:
channel + to。否則 channel: "last" 使用最後投遞路由(回退到 WhatsApp)。
若要為 Gmail 執行強制更便宜的模型,請在映射中設定 model(provider/model 或別名)。若您強制執行 agents.defaults.models,請將其包含在其中。
若要專門為 Gmail Hooks 設定預設模型和思考等級,請在設定中加入 hooks.gmail.model / hooks.gmail.thinking:
- 映射中的各 Hook
model/thinking仍然覆寫這些預設。 - 回退順序:
hooks.gmail.model→agents.defaults.model.fallbacks→ primary (auth/rate-limit/timeouts)。 - 若設定了
agents.defaults.models,Gmail 模型必須在允許清單中。 - Gmail Hook 內容預設使用外部內容安全邊界進行包裝。
若要禁用(危險),設定
hooks.gmail.allowUnsafeExternalContent: true。
hooks.mappings 或 JS/TS 轉換模組,位於 hooks.transformsDir 下(見 Webhooks)。
精靈(推薦)
使用 OpenClaw 助手將所有內容接線(在 macOS 上透過 brew 安裝 deps):- 使用 Tailscale Funnel 作為公開推送端點。
- 寫入
hooks.gmail設定供openclaw webhooks gmail run使用。 - 啟用 Gmail Hook 預設(
hooks.presets: ["gmail"])。
tailscale.mode 時,OpenClaw 自動將 hooks.gmail.serve.path 設為 / 並將公開路徑保持在 hooks.gmail.tailscale.path(預設 /gmail-pubsub),因為 Tailscale 在代理前會移除設定路徑前綴。
若您需要後端接收前綴路徑,設定 hooks.gmail.tailscale.target(或 --tailscale-target)為完整 URL,例如 http://127.0.0.1:8788/gmail-pubsub 並符合 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並自動續訂監看。 - 設定
OPENCLAW_SKIP_GMAIL_WATCHER=1以選擇不參與(若您自行執行守護程式很有用)。 - 不要同時執行手動守護程式,否則會遇到
listen tcp 127.0.0.1:8788: bind: address already in use。
gog gmail watch serve + 自動續訂):
一次性設定
- 選擇 GCP 專案 擁有
gog使用的 OAuth 客戶端。
- 啟用 API:
- 建立主題:
- 允許 Gmail 推送發佈:
啟動監看
history_id(用於除錯)。
執行推送處理器
本地範例(共享 Token 認證):--token保護推送端點(x-gog-token或?token=)。--hook-url指向 OpenClaw/hooks/gmail(已映射;隔離執行 + 摘要至主會話)。--include-body和--max-bytes控制傳送給 OpenClaw 的 Body 片段。
openclaw webhooks gmail run 包裝相同的流程並自動續訂監看。
公開處理器(進階、不支援)
若您需要非 Tailscale 隧道,手動接線並在推送訂閱中使用公開 URL(不支援、無保障):測試
傳送訊息到受監看的收件匣:故障排除
Invalid topicName:專案不符(主題不在 OAuth 客戶端專案中)。User not authorized:主題上遺失roles/pubsub.publisher。- 空訊息:Gmail 推送僅提供
historyId;透過gog gmail history擷取。