Gmail Pub/Sub -> OpenClaw
목표: Gmail watch -> Pub/Sub push ->gog gmail watch serve -> OpenClaw 웹훅.
Prereqs
gcloud설치 및 로그인 완료 (설치 가이드).gog(gogcli) 설치 및 Gmail 계정에 대해 인증 완료 (gogcli.sh).- OpenClaw 훅 활성화됨 (Webhooks 참고).
tailscale로그인 완료 (tailscale.com). 지원되는 설정은 공개 HTTPS 엔드포인트로 Tailscale Funnel 을 사용합니다. 다른 터널 서비스도 동작할 수 있으나 DIY/미지원이며 수동 연결이 필요합니다. 현재로서는 Tailscale 만 지원합니다.
deliver + 선택적 channel/to 를 설정하는 매핑을 사용하십시오:
channel + to 를 설정하십시오. 그렇지 않으면 channel: "last" 이
마지막 전달 경로를 사용합니다 (WhatsApp 으로 폴백).
Gmail 실행에 더 저렴한 모델을 강제하려면 매핑에서 model 를 설정하십시오
(provider/model 또는 별칭). agents.defaults.models 를 강제하는 경우, 여기에 포함하십시오.
Gmail 훅 전용 기본 모델과 thinking 레벨을 설정하려면,
구성에 hooks.gmail.model / hooks.gmail.thinking 를 추가하십시오:
- 매핑 내 훅별
model/thinking는 여전히 이 기본값을 덮어씁니다. - 폴백 순서:
hooks.gmail.model→agents.defaults.model.fallbacks→ 기본값 (인증/레이트 리밋/타임아웃). agents.defaults.models이 설정된 경우, Gmail 모델은 allowlist 에 포함되어야 합니다.- Gmail 훅 콘텐츠는 기본적으로 외부 콘텐츠 안전 경계로 감싸집니다.
비활성화하려면 (위험)
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 를 일치시키십시오.
커스텀 엔드포인트가 필요하신가요? --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 시작 + 자동 갱신):
1회 설정
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를 통해 가져오십시오.