{-# LANGUAGE DataKinds #-} {-# LANGUAGE DeriveDataTypeable #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE FlexibleInstances #-} {-# LANGUAGE NoImplicitPrelude #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE TypeOperators #-} {-# OPTIONS_GHC -fno-warn-duplicate-exports #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} -- | -- Module : Network.Google.Resource.Gmail.Users.Settings.SendAs.Create -- Copyright : (c) 2015-2016 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- 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 Network.Google.Resource.Gmail.Users.Settings.SendAs.Create ( -- * REST Resource UsersSettingsSendAsCreateResource -- * Creating a Request , usersSettingsSendAsCreate , UsersSettingsSendAsCreate -- * Request Lenses , ussacPayload , ussacUserId ) where import Network.Google.Gmail.Types import Network.Google.Prelude -- | A resource alias for @gmail.users.settings.sendAs.create@ method which the -- 'UsersSettingsSendAsCreate' request conforms to. type UsersSettingsSendAsCreateResource = "gmail" :> "v1" :> "users" :> Capture "userId" Text :> "settings" :> "sendAs" :> QueryParam "alt" AltJSON :> ReqBody '[JSON] SendAs :> Post '[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:/ 'usersSettingsSendAsCreate' smart constructor. data UsersSettingsSendAsCreate = UsersSettingsSendAsCreate' { _ussacPayload :: !SendAs , _ussacUserId :: !Text } deriving (Eq,Show,Data,Typeable,Generic) -- | Creates a value of 'UsersSettingsSendAsCreate' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'ussacPayload' -- -- * 'ussacUserId' usersSettingsSendAsCreate :: SendAs -- ^ 'ussacPayload' -> UsersSettingsSendAsCreate usersSettingsSendAsCreate pUssacPayload_ = UsersSettingsSendAsCreate' { _ussacPayload = pUssacPayload_ , _ussacUserId = "me" } -- | Multipart request metadata. ussacPayload :: Lens' UsersSettingsSendAsCreate SendAs ussacPayload = lens _ussacPayload (\ s a -> s{_ussacPayload = a}) -- | User\'s email address. The special value \"me\" can be used to indicate -- the authenticated user. ussacUserId :: Lens' UsersSettingsSendAsCreate Text ussacUserId = lens _ussacUserId (\ s a -> s{_ussacUserId = a}) instance GoogleRequest UsersSettingsSendAsCreate where type Rs UsersSettingsSendAsCreate = SendAs type Scopes UsersSettingsSendAsCreate = '["https://www.googleapis.com/auth/gmail.settings.sharing"] requestClient UsersSettingsSendAsCreate'{..} = go _ussacUserId (Just AltJSON) _ussacPayload gmailService where go = buildClient (Proxy :: Proxy UsersSettingsSendAsCreateResource) mempty