{-# 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.SendAs.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) -- -- Creates a custom \"from\" send-as alias. If an SMTP MSA is specified, Gmail will attempt to connect to the SMTP service to validate the configuration before creating the alias. If ownership verification is required for the alias, a message will be sent to the email address and the resource\'s verification status will be set to @pending@; otherwise, the resource will be created with verification status set to @accepted@. If a signature is provided, Gmail will sanitize the HTML before saving it with the alias. This method is only available to service account clients that have been delegated domain-wide authority. -- -- /See:/ for @gmail.users.settings.sendAs.create@. module Gogol.Gmail.Users.Settings.SendAs.Create ( -- * Resource GmailUsersSettingsSendAsCreateResource, -- ** Constructing a Request GmailUsersSettingsSendAsCreate (..), newGmailUsersSettingsSendAsCreate, ) where import Gogol.Gmail.Types import Gogol.Prelude qualified as Core -- | A resource alias for @gmail.users.settings.sendAs.create@ method which the -- 'GmailUsersSettingsSendAsCreate' request conforms to. type GmailUsersSettingsSendAsCreateResource = "gmail" Core.:> "v1" Core.:> "users" Core.:> Core.Capture "userId" Core.Text Core.:> "settings" Core.:> "sendAs" 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] SendAs Core.:> Core.Post '[Core.JSON] SendAs -- | Creates a custom \"from\" send-as alias. If an SMTP MSA is specified, Gmail will attempt to connect to the SMTP service to validate the configuration before creating the alias. If ownership verification is required for the alias, a message will be sent to the email address and the resource\'s verification status will be set to @pending@; otherwise, the resource will be created with verification status set to @accepted@. If a signature is provided, Gmail will sanitize the HTML before saving it with the alias. This method is only available to service account clients that have been delegated domain-wide authority. -- -- /See:/ 'newGmailUsersSettingsSendAsCreate' smart constructor. data GmailUsersSettingsSendAsCreate = GmailUsersSettingsSendAsCreate { -- | 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 :: SendAs, -- | 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 'GmailUsersSettingsSendAsCreate' with the minimum fields required to make a request. newGmailUsersSettingsSendAsCreate :: -- | Multipart request metadata. See 'payload'. SendAs -> GmailUsersSettingsSendAsCreate newGmailUsersSettingsSendAsCreate payload = GmailUsersSettingsSendAsCreate { xgafv = Core.Nothing, accessToken = Core.Nothing, callback = Core.Nothing, payload = payload, uploadType = Core.Nothing, uploadProtocol = Core.Nothing, userId = "me" } instance Core.GoogleRequest GmailUsersSettingsSendAsCreate where type Rs GmailUsersSettingsSendAsCreate = SendAs type Scopes GmailUsersSettingsSendAsCreate = '[Gmail'Settings'Sharing] requestClient GmailUsersSettingsSendAsCreate {..} = go userId xgafv accessToken callback uploadType uploadProtocol (Core.Just Core.AltJSON) payload gmailService where go = Core.buildClient (Core.Proxy :: Core.Proxy GmailUsersSettingsSendAsCreateResource) Core.mempty