為特定使用者信箱設定或更新推播通知智慧手錶。
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「publish」權限授予該專案的權限例如「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 將停止傳送信箱更新通知的時間 (epoch 毫秒)。在此之前再次呼叫 |
授權範圍
需要下列其中一種 OAuth 範圍:
https://mail.google.com/
https://www.googleapis.com/auth/gmail.modify
https://www.googleapis.com/auth/gmail.readonly
https://www.googleapis.com/auth/gmail.metadata
詳情請參閱授權指南。
LabelFilterAction
指定的 labelIds 清單的篩選行為。
列舉 | |
---|---|
include |
只有在訊息變更與指定的 labelId 相關時,您才會收到推播通知。 |
exclude |
接收所有郵件變更的推播通知,但與指定的 labelIds 相關時除外。 |