{-# 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.IAM.Organizations.Roles.Delete -- Copyright : (c) 2015-2016 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Soft deletes a role. The role is suspended and cannot be used to create -- new IAM Policy Bindings. The Role will not be included in -- \`ListRoles()\` unless \`show_deleted\` is set in the -- \`ListRolesRequest\`. The Role contains the deleted boolean set. -- Existing Bindings remains, but are inactive. The Role can be undeleted -- within 7 days. After 7 days the Role is deleted and all Bindings -- associated with the role are removed. -- -- /See:/ for @iam.organizations.roles.delete@. module Network.Google.Resource.IAM.Organizations.Roles.Delete ( -- * REST Resource OrganizationsRolesDeleteResource -- * Creating a Request , organizationsRolesDelete , OrganizationsRolesDelete -- * Request Lenses , ordXgafv , ordEtag , ordUploadProtocol , ordAccessToken , ordUploadType , ordName , ordCallback ) where import Network.Google.IAM.Types import Network.Google.Prelude -- | A resource alias for @iam.organizations.roles.delete@ method which the -- 'OrganizationsRolesDelete' request conforms to. type OrganizationsRolesDeleteResource = "v1" :> Capture "name" Text :> QueryParam "$.xgafv" Xgafv :> QueryParam "etag" Bytes :> QueryParam "upload_protocol" Text :> QueryParam "access_token" Text :> QueryParam "uploadType" Text :> QueryParam "callback" Text :> QueryParam "alt" AltJSON :> Delete '[JSON] Role -- | Soft deletes a role. The role is suspended and cannot be used to create -- new IAM Policy Bindings. The Role will not be included in -- \`ListRoles()\` unless \`show_deleted\` is set in the -- \`ListRolesRequest\`. The Role contains the deleted boolean set. -- Existing Bindings remains, but are inactive. The Role can be undeleted -- within 7 days. After 7 days the Role is deleted and all Bindings -- associated with the role are removed. -- -- /See:/ 'organizationsRolesDelete' smart constructor. data OrganizationsRolesDelete = OrganizationsRolesDelete' { _ordXgafv :: !(Maybe Xgafv) , _ordEtag :: !(Maybe Bytes) , _ordUploadProtocol :: !(Maybe Text) , _ordAccessToken :: !(Maybe Text) , _ordUploadType :: !(Maybe Text) , _ordName :: !Text , _ordCallback :: !(Maybe Text) } deriving (Eq,Show,Data,Typeable,Generic) -- | Creates a value of 'OrganizationsRolesDelete' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'ordXgafv' -- -- * 'ordEtag' -- -- * 'ordUploadProtocol' -- -- * 'ordAccessToken' -- -- * 'ordUploadType' -- -- * 'ordName' -- -- * 'ordCallback' organizationsRolesDelete :: Text -- ^ 'ordName' -> OrganizationsRolesDelete organizationsRolesDelete pOrdName_ = OrganizationsRolesDelete' { _ordXgafv = Nothing , _ordEtag = Nothing , _ordUploadProtocol = Nothing , _ordAccessToken = Nothing , _ordUploadType = Nothing , _ordName = pOrdName_ , _ordCallback = Nothing } -- | V1 error format. ordXgafv :: Lens' OrganizationsRolesDelete (Maybe Xgafv) ordXgafv = lens _ordXgafv (\ s a -> s{_ordXgafv = a}) -- | Used to perform a consistent read-modify-write. ordEtag :: Lens' OrganizationsRolesDelete (Maybe ByteString) ordEtag = lens _ordEtag (\ s a -> s{_ordEtag = a}) . mapping _Bytes -- | Upload protocol for media (e.g. \"raw\", \"multipart\"). ordUploadProtocol :: Lens' OrganizationsRolesDelete (Maybe Text) ordUploadProtocol = lens _ordUploadProtocol (\ s a -> s{_ordUploadProtocol = a}) -- | OAuth access token. ordAccessToken :: Lens' OrganizationsRolesDelete (Maybe Text) ordAccessToken = lens _ordAccessToken (\ s a -> s{_ordAccessToken = a}) -- | Legacy upload protocol for media (e.g. \"media\", \"multipart\"). ordUploadType :: Lens' OrganizationsRolesDelete (Maybe Text) ordUploadType = lens _ordUploadType (\ s a -> s{_ordUploadType = a}) -- | The resource name of the role in one of the following formats: -- \`organizations\/{ORGANIZATION_ID}\/roles\/{ROLE_NAME}\` -- \`projects\/{PROJECT_ID}\/roles\/{ROLE_NAME}\` ordName :: Lens' OrganizationsRolesDelete Text ordName = lens _ordName (\ s a -> s{_ordName = a}) -- | JSONP ordCallback :: Lens' OrganizationsRolesDelete (Maybe Text) ordCallback = lens _ordCallback (\ s a -> s{_ordCallback = a}) instance GoogleRequest OrganizationsRolesDelete where type Rs OrganizationsRolesDelete = Role type Scopes OrganizationsRolesDelete = '["https://www.googleapis.com/auth/cloud-platform"] requestClient OrganizationsRolesDelete'{..} = go _ordName _ordXgafv _ordEtag _ordUploadProtocol _ordAccessToken _ordUploadType _ordCallback (Just AltJSON) iAMService where go = buildClient (Proxy :: Proxy OrganizationsRolesDeleteResource) mempty