针对指定用户邮箱设置或更新推送通知监控。如需了解详情,请参阅在 Gmail API 中配置推送通知。
HTTP 请求
POST https://gmail.googleapis.com/gmail/v1/users/{userId}/watch
网址采用 gRPC 转码语法。
路径参数
| 参数 | |
|---|---|
userId |
用户的电子邮件地址。特殊值 |
请求正文
请求正文中包含结构如下的数据:
| JSON 表示法 |
|---|
{ "labelIds": [ string ], "labelFilterAction": enum ( |
| 字段 | |
|---|---|
labelIds[] |
用于限制通知的 labelId 列表。默认情况下,如果未指定,系统会推送所有更改。如果指定,则会决定生成推送通知所需的标签。 |
labelFilterAction |
指定 |
labelFilterBehavior |
指定 |
topicName |
用于发布事件的完全限定 Google Cloud Pub/Sub API 主题名称。此主题名称必须 已存在于 Cloud Pub/Sub 中,并且您必须 已向 Gmail 授予“发布”权限。例如,“projects/my-project-identifier/topics/my-topic-name”(使用 Cloud Pub/Sub“v1”主题命名格式)。 请注意,“my-project-identifier”部分必须与您的 Google 开发者项目 ID(执行此监控请求的项目 ID)完全一致。 |
响应正文
推送通知监控响应。
如果成功,响应正文将包含结构如下的数据:
| JSON 表示法 |
|---|
{ "historyId": string, "expiration": string } |
| 字段 | |
|---|---|
historyId |
邮箱当前历史记录的 ID。 |
expiration |
Gmail 何时停止发送邮箱更新通知(纪元毫秒)。请在此时间之前再次调用 |
授权范围
需要以下 OAuth 范围之一:
https://mail.google.com/https://www.googleapis.com/auth/gmail.modifyhttps://www.googleapis.com/auth/gmail.readonlyhttps://www.googleapis.com/auth/gmail.metadata
如需了解详情,请参阅授权指南。
LabelFilterAction
指定 labelIds 列表的过滤行为。
| 枚举 | |
|---|---|
include |
仅针对与指定 labelIds 相关的消息更改接收推送通知。 |
exclude |
针对所有消息更改接收推送通知,但与指定 labelIds 相关的消息更改除外。 |