{-# LANGUAGE DataKinds #-} {-# LANGUAGE DerivingStrategies #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE ImportQualifiedPost #-} {-# LANGUAGE LambdaCase #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE PatternSynonyms #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-duplicate-exports #-} {-# OPTIONS_GHC -fno-warn-name-shadowing #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- | -- Module : Gogol.Gmail.Users.Watch -- Copyright : (c) 2015-2025 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Toni Cebrián -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Set up or update a push notification watch on the given user mailbox. -- -- /See:/ for @gmail.users.watch@. module Gogol.Gmail.Users.Watch ( -- * Resource GmailUsersWatchResource, -- ** Constructing a Request GmailUsersWatch (..), newGmailUsersWatch, ) where import Gogol.Gmail.Types import Gogol.Prelude qualified as Core -- | A resource alias for @gmail.users.watch@ method which the -- 'GmailUsersWatch' request conforms to. type GmailUsersWatchResource = "gmail" Core.:> "v1" Core.:> "users" Core.:> Core.Capture "userId" Core.Text Core.:> "watch" Core.:> Core.QueryParam "$.xgafv" Xgafv Core.:> Core.QueryParam "access_token" Core.Text Core.:> Core.QueryParam "callback" Core.Text Core.:> Core.QueryParam "uploadType" Core.Text Core.:> Core.QueryParam "upload_protocol" Core.Text Core.:> Core.QueryParam "alt" Core.AltJSON Core.:> Core.ReqBody '[Core.JSON] WatchRequest Core.:> Core.Post '[Core.JSON] WatchResponse -- | Set up or update a push notification watch on the given user mailbox. -- -- /See:/ 'newGmailUsersWatch' smart constructor. data GmailUsersWatch = GmailUsersWatch { -- | V1 error format. xgafv :: (Core.Maybe Xgafv), -- | OAuth access token. accessToken :: (Core.Maybe Core.Text), -- | JSONP callback :: (Core.Maybe Core.Text), -- | Multipart request metadata. payload :: WatchRequest, -- | Legacy upload protocol for media (e.g. \"media\", \"multipart\"). uploadType :: (Core.Maybe Core.Text), -- | Upload protocol for media (e.g. \"raw\", \"multipart\"). uploadProtocol :: (Core.Maybe Core.Text), -- | The user\'s email address. The special value @me@ can be used to indicate the authenticated user. userId :: Core.Text } deriving (Core.Eq, Core.Show, Core.Generic) -- | Creates a value of 'GmailUsersWatch' with the minimum fields required to make a request. newGmailUsersWatch :: -- | Multipart request metadata. See 'payload'. WatchRequest -> GmailUsersWatch newGmailUsersWatch payload = GmailUsersWatch { xgafv = Core.Nothing, accessToken = Core.Nothing, callback = Core.Nothing, payload = payload, uploadType = Core.Nothing, uploadProtocol = Core.Nothing, userId = "me" } instance Core.GoogleRequest GmailUsersWatch where type Rs GmailUsersWatch = WatchResponse type Scopes GmailUsersWatch = '[Gmail'FullControl, Gmail'Metadata, Gmail'Modify, Gmail'Readonly] requestClient GmailUsersWatch {..} = go userId xgafv accessToken callback uploadType uploadProtocol (Core.Just Core.AltJSON) payload gmailService where go = Core.buildClient (Core.Proxy :: Core.Proxy GmailUsersWatchResource) Core.mempty