Gmail Pub/Sub -> OpenClaw
目標:Gmail watch -> Pub/Sub push ->gog gmail watch serve -> OpenClaw webhook。
Prereqs
- 已安裝並登入
gcloud(安裝指南)。 - 已安裝並授權 Gmail 帳戶使用的
gog(gogcli)(gogcli.sh)。 - 已啟用 OpenClaw hooks(請參閱 Webhooks)。
tailscale已登入(tailscale.com)。 支援的設定使用 Tailscale Funnel 作為公開的 HTTPS 端點。 其他通道服務也可行,但屬於 DIY/未支援,且需要手動設定。 目前我們支援的是 Tailscale。 支援的設定使用 Tailscale Funnel 作為公開的 HTTPS 端點。 其他通道服務也可行,但屬於 DIY/未支援,且需要手動設定。 目前我們支援的是 Tailscale。
deliver + 選用的 channel/to:
channel + to。 如果你想要固定的頻道,請設定 channel + to。 若要固定頻道,請設定 channel + to。否則 channel: "last"
會使用最後一次的傳送路由(回退至 WhatsApp)。
若要在 Gmail 執行時強制使用較便宜的模型,請在對應中設定 model
(provider/model 或別名)。如果你強制 agents.defaults.models,也請在此加入。 若要在 Gmail 執行時強制使用較便宜的模型,請在對應中設定 model
(provider/model 或別名)。如果你強制 agents.defaults.models,也請在此加入。 如果你強制使用 agents.defaults.models,請在那裡包含它。
若要專門為 Gmail hooks 設定預設模型與思考層級,請在設定中加入
hooks.gmail.model / hooks.gmail.thinking:
- 對應表中每個 hook 的
model/thinking仍會覆寫這些預設值。 - 回退順序:
hooks.gmail.model→agents.defaults.model.fallbacks→ 主要(驗證/速率限制/逾時)。 - 若已設定
agents.defaults.models,Gmail 模型必須在允許清單中。 - Gmail hook 的內容預設會以外部內容安全邊界包裹。
若要停用(有風險),請設定
hooks.gmail.allowUnsafeExternalContent: true。
hooks.mappings 或在
hooks.transformsDir 下放置 JS/TS 轉換模組(請參閱 Webhooks)。
Wizard(建議)
使用 OpenClaw 輔助工具將所有項目接線完成(在 macOS 上透過 brew 安裝相依套件):- 使用 Tailscale Funnel 作為公開推送端點。
- 為
openclaw webhooks gmail run寫入hooks.gmail設定。 - 啟用 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。
如果你需要後端接收帶前綴的路徑,請將
hooks.gmail.tailscale.target(或 --tailscale-target)設定為完整的 URL,例如
http://127.0.0.1:8788/gmail-pubsub,並與 hooks.gmail.serve.path 相符。
如果你需要後端接收帶前綴的路徑,請將
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並自動續期 watch。 - 設定
OPENCLAW_SKIP_GMAIL_WATCHER=1以選擇退出(若你自行執行守護程式時很有用)。 - 請勿同時執行手動守護程式,否則會遇到
listen tcp 127.0.0.1:8788: bind: address already in use。
gog gmail watch serve + 自動續期):
一次性設定
- 選擇 擁有 OAuth 用戶端 的 GCP 專案,該用戶端由
gog使用。
- 啟用 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擷取。