{-# 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.Settings.Delegates.Create -- 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) -- -- Adds a delegate with its verification status set directly to @accepted@, without sending any verification email. The delegate user must be a member of the same Google Workspace organization as the delegator user. Gmail imposes limitations on the number of delegates and delegators each user in a Google Workspace organization can have. These limits depend on your organization, but in general each user can have up to 25 delegates and up to 10 delegators. Note that a delegate user must be referred to by their primary email address, and not an email alias. Also note that when a new delegate is created, there may be up to a one minute delay before the new delegate is available for use. This method is only available to service account clients that have been delegated domain-wide authority. -- -- /See:/ for @gmail.users.settings.delegates.create@. module Gogol.Gmail.Users.Settings.Delegates.Create ( -- * Resource GmailUsersSettingsDelegatesCreateResource, -- ** Constructing a Request GmailUsersSettingsDelegatesCreate (..), newGmailUsersSettingsDelegatesCreate, ) where import Gogol.Gmail.Types import Gogol.Prelude qualified as Core -- | A resource alias for @gmail.users.settings.delegates.create@ method which the -- 'GmailUsersSettingsDelegatesCreate' request conforms to. type GmailUsersSettingsDelegatesCreateResource = "gmail" Core.:> "v1" Core.:> "users" Core.:> Core.Capture "userId" Core.Text Core.:> "settings" Core.:> "delegates" 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] Delegate Core.:> Core.Post '[Core.JSON] Delegate -- | Adds a delegate with its verification status set directly to @accepted@, without sending any verification email. The delegate user must be a member of the same Google Workspace organization as the delegator user. Gmail imposes limitations on the number of delegates and delegators each user in a Google Workspace organization can have. These limits depend on your organization, but in general each user can have up to 25 delegates and up to 10 delegators. Note that a delegate user must be referred to by their primary email address, and not an email alias. Also note that when a new delegate is created, there may be up to a one minute delay before the new delegate is available for use. This method is only available to service account clients that have been delegated domain-wide authority. -- -- /See:/ 'newGmailUsersSettingsDelegatesCreate' smart constructor. data GmailUsersSettingsDelegatesCreate = GmailUsersSettingsDelegatesCreate { -- | 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 :: Delegate, -- | 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), -- | 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 'GmailUsersSettingsDelegatesCreate' with the minimum fields required to make a request. newGmailUsersSettingsDelegatesCreate :: -- | Multipart request metadata. See 'payload'. Delegate -> GmailUsersSettingsDelegatesCreate newGmailUsersSettingsDelegatesCreate payload = GmailUsersSettingsDelegatesCreate { xgafv = Core.Nothing, accessToken = Core.Nothing, callback = Core.Nothing, payload = payload, uploadType = Core.Nothing, uploadProtocol = Core.Nothing, userId = "me" } instance Core.GoogleRequest GmailUsersSettingsDelegatesCreate where type Rs GmailUsersSettingsDelegatesCreate = Delegate type Scopes GmailUsersSettingsDelegatesCreate = '[Gmail'Settings'Sharing] requestClient GmailUsersSettingsDelegatesCreate {..} = go userId xgafv accessToken callback uploadType uploadProtocol (Core.Just Core.AltJSON) payload gmailService where go = Core.buildClient ( Core.Proxy :: Core.Proxy GmailUsersSettingsDelegatesCreateResource ) Core.mempty