{-# 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.AndroidEnterprise.Enterprises.GetServiceAccount -- 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) -- -- Returns a service account and credentials. The service account can be bound to the enterprise by calling setAccount. The service account is unique to this enterprise and EMM, and will be deleted if the enterprise is unbound. The credentials contain private key data and are not stored server-side. This method can only be called after calling Enterprises.Enroll or Enterprises.CompleteSignup, and before Enterprises.SetAccount; at other times it will return an error. Subsequent calls after the first will generate a new, unique set of credentials, and invalidate the previously generated credentials. Once the service account is bound to the enterprise, it can be managed using the serviceAccountKeys resource. -- -- /See:/ for @androidenterprise.enterprises.getServiceAccount@. module Gogol.AndroidEnterprise.Enterprises.GetServiceAccount ( -- * Resource AndroidEnterpriseEnterprisesGetServiceAccountResource, -- ** Constructing a Request AndroidEnterpriseEnterprisesGetServiceAccount (..), newAndroidEnterpriseEnterprisesGetServiceAccount, ) where import Gogol.AndroidEnterprise.Types import Gogol.Prelude qualified as Core -- | A resource alias for @androidenterprise.enterprises.getServiceAccount@ method which the -- 'AndroidEnterpriseEnterprisesGetServiceAccount' request conforms to. type AndroidEnterpriseEnterprisesGetServiceAccountResource = "androidenterprise" Core.:> "v1" Core.:> "enterprises" Core.:> Core.Capture "enterpriseId" Core.Text Core.:> "serviceAccount" Core.:> Core.QueryParam "$.xgafv" Xgafv Core.:> Core.QueryParam "access_token" Core.Text Core.:> Core.QueryParam "callback" Core.Text Core.:> Core.QueryParam "keyType" EnterprisesGetServiceAccountKeyType Core.:> Core.QueryParam "uploadType" Core.Text Core.:> Core.QueryParam "upload_protocol" Core.Text Core.:> Core.QueryParam "alt" Core.AltJSON Core.:> Core.Get '[Core.JSON] ServiceAccount -- | Returns a service account and credentials. The service account can be bound to the enterprise by calling setAccount. The service account is unique to this enterprise and EMM, and will be deleted if the enterprise is unbound. The credentials contain private key data and are not stored server-side. This method can only be called after calling Enterprises.Enroll or Enterprises.CompleteSignup, and before Enterprises.SetAccount; at other times it will return an error. Subsequent calls after the first will generate a new, unique set of credentials, and invalidate the previously generated credentials. Once the service account is bound to the enterprise, it can be managed using the serviceAccountKeys resource. -- -- /See:/ 'newAndroidEnterpriseEnterprisesGetServiceAccount' smart constructor. data AndroidEnterpriseEnterprisesGetServiceAccount = AndroidEnterpriseEnterprisesGetServiceAccount { -- | V1 error format. xgafv :: (Core.Maybe Xgafv), -- | OAuth access token. accessToken :: (Core.Maybe Core.Text), -- | JSONP callback :: (Core.Maybe Core.Text), -- | The ID of the enterprise. enterpriseId :: Core.Text, -- | The type of credential to return with the service account. Required. keyType :: (Core.Maybe EnterprisesGetServiceAccountKeyType), -- | 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 'AndroidEnterpriseEnterprisesGetServiceAccount' with the minimum fields required to make a request. newAndroidEnterpriseEnterprisesGetServiceAccount :: -- | The ID of the enterprise. See 'enterpriseId'. Core.Text -> AndroidEnterpriseEnterprisesGetServiceAccount newAndroidEnterpriseEnterprisesGetServiceAccount enterpriseId = AndroidEnterpriseEnterprisesGetServiceAccount { xgafv = Core.Nothing, accessToken = Core.Nothing, callback = Core.Nothing, enterpriseId = enterpriseId, keyType = Core.Nothing, uploadType = Core.Nothing, uploadProtocol = Core.Nothing } instance Core.GoogleRequest AndroidEnterpriseEnterprisesGetServiceAccount where type Rs AndroidEnterpriseEnterprisesGetServiceAccount = ServiceAccount type Scopes AndroidEnterpriseEnterprisesGetServiceAccount = '[Androidenterprise'FullControl] requestClient AndroidEnterpriseEnterprisesGetServiceAccount {..} = go enterpriseId xgafv accessToken callback keyType uploadType uploadProtocol (Core.Just Core.AltJSON) androidEnterpriseService where go = Core.buildClient ( Core.Proxy :: Core.Proxy AndroidEnterpriseEnterprisesGetServiceAccountResource ) Core.mempty