{-# 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.Admin.Directory.Roles.Get -- 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) -- -- Retrieves a role. -- -- /See:/ for @directory.roles.get@. module Gogol.Admin.Directory.Roles.Get ( -- * Resource DirectoryRolesGetResource, -- ** Constructing a Request DirectoryRolesGet (..), newDirectoryRolesGet, ) where import Gogol.Admin.Directory.Types import Gogol.Prelude qualified as Core -- | A resource alias for @directory.roles.get@ method which the -- 'DirectoryRolesGet' request conforms to. type DirectoryRolesGetResource = "admin" Core.:> "directory" Core.:> "v1" Core.:> "customer" Core.:> Core.Capture "customer" Core.Text Core.:> "roles" Core.:> Core.Capture "roleId" Core.Text 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.Get '[Core.JSON] Role -- | Retrieves a role. -- -- /See:/ 'newDirectoryRolesGet' smart constructor. data DirectoryRolesGet = DirectoryRolesGet { -- | V1 error format. xgafv :: (Core.Maybe Xgafv), -- | OAuth access token. accessToken :: (Core.Maybe Core.Text), -- | JSONP callback :: (Core.Maybe Core.Text), -- | The unique ID for the customer\'s Google Workspace account. In case of a multi-domain account, to fetch all groups for a customer, use this field instead of @domain@. You can also use the @my_customer@ alias to represent your account\'s @customerId@. The @customerId@ is also returned as part of the resource. You must provide either the @customer@ or the @domain@ parameter. customer :: Core.Text, -- | Immutable ID of the role. roleId :: Core.Text, -- | 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) } deriving (Core.Eq, Core.Show, Core.Generic) -- | Creates a value of 'DirectoryRolesGet' with the minimum fields required to make a request. newDirectoryRolesGet :: -- | The unique ID for the customer\'s Google Workspace account. In case of a multi-domain account, to fetch all groups for a customer, use this field instead of @domain@. You can also use the @my_customer@ alias to represent your account\'s @customerId@. The @customerId@ is also returned as part of the resource. You must provide either the @customer@ or the @domain@ parameter. See 'customer'. Core.Text -> -- | Immutable ID of the role. See 'roleId'. Core.Text -> DirectoryRolesGet newDirectoryRolesGet customer roleId = DirectoryRolesGet { xgafv = Core.Nothing, accessToken = Core.Nothing, callback = Core.Nothing, customer = customer, roleId = roleId, uploadType = Core.Nothing, uploadProtocol = Core.Nothing } instance Core.GoogleRequest DirectoryRolesGet where type Rs DirectoryRolesGet = Role type Scopes DirectoryRolesGet = '[ Admin'Directory'Rolemanagement, Admin'Directory'Rolemanagement'Readonly ] requestClient DirectoryRolesGet {..} = go customer roleId xgafv accessToken callback uploadType uploadProtocol (Core.Just Core.AltJSON) adminDirectoryService where go = Core.buildClient (Core.Proxy :: Core.Proxy DirectoryRolesGetResource) Core.mempty