summary, read_when, title
| summary |
read_when |
title |
| CLI reference for `openclaw webhooks` (Gmail Pub/Sub setup and runner) |
| You want to wire Gmail Pub/Sub events into OpenClaw |
| You need the full flag list and default values |
|
Webhooks |
openclaw webhooks
Webhook helpers and integrations. Today this surface is scoped to Gmail Pub/Sub flows that integrate with the bundled gog watcher.
Subcommands
| Subcommand |
Description |
gmail setup |
Configure Gmail watch, Pub/Sub topic/subscription, and the OpenClaw webhook delivery target. |
gmail run |
Run gog watch serve plus the watch auto-renew loop. |
webhooks gmail setup
Configure Gmail watch, Pub/Sub, and OpenClaw webhook delivery.
Required
| Flag |
Description |
--account <email> |
Gmail account to watch. |
Pub/Sub options
| Flag |
Default |
Description |
--project <id> |
(none) |
GCP project id (the OAuth client owner). |
--topic <name> |
gog-gmail-watch |
Pub/Sub topic name. |
--subscription <name> |
gog-gmail-watch-push |
Pub/Sub subscription name. |
--label <label> |
INBOX |
Gmail label to watch. |
--push-endpoint <url> |
(none) |
Explicit Pub/Sub push endpoint. Overrides Tailscale. |
OpenClaw delivery options
| Flag |
Default |
Description |
--hook-url <url> |
(none) |
OpenClaw webhook URL. |
--hook-token <token> |
(none) |
OpenClaw webhook token. |
--push-token <token> |
(none) |
Push token forwarded to gog watch serve. |
gog watch serve options
| Flag |
Default |
Description |
--bind <host> |
127.0.0.1 |
gog watch serve bind host. |
--port <port> |
8788 |
gog watch serve port. |
--path <path> |
/gmail-pubsub |
gog watch serve path. |
--include-body |
true |
Include email body snippets. Pass --no-include-body to disable. |
--max-bytes <n> |
20000 |
Max bytes per body snippet. |
--renew-minutes <n> |
720 (12h) |
Renew Gmail watch every N minutes. |
Tailscale exposure
| Flag |
Default |
Description |
--tailscale <mode> |
funnel |
Expose push endpoint via tailscale: funnel, serve, or off. |
--tailscale-path <path> |
(none) |
Path for tailscale serve/funnel. |
--tailscale-target <t> |
(none) |
Tailscale serve/funnel target (port, host:port, or URL). |
Output
| Flag |
Description |
--json |
Print a machine-readable summary instead of text. |
webhooks gmail run
Run gog watch serve plus the watch auto-renew loop in the foreground.
run accepts the same gog watch serve, OpenClaw delivery, Pub/Sub, and Tailscale flags as setup, except:
--account is optional on run (it falls back to the configured account).
run does not accept --project, --push-endpoint, or --json.
run flags have no built-in defaults; missing values fall back to the values written by setup.
| Category |
Flags |
| Pub/Sub |
--account, --topic, --subscription, --label |
| OpenClaw delivery |
--hook-url, --hook-token, --push-token |
gog watch serve |
--bind, --port, --path, --include-body, --max-bytes, --renew-minutes |
| Tailscale |
--tailscale, --tailscale-path, --tailscale-target |
For `run`, the `--topic` value is the full Pub/Sub topic path (`projects/.../topics/...`), not just the short topic name.
End-to-end flow
See Gmail Pub/Sub integration for the GCP project, OAuth, and gateway-side setup that pairs with these CLI commands.
Related