{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.GuardDuty.DescribeOrganizationConfiguration -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns information about the account selected as the delegated -- administrator for GuardDuty. module Amazonka.GuardDuty.DescribeOrganizationConfiguration ( -- * Creating a Request DescribeOrganizationConfiguration (..), newDescribeOrganizationConfiguration, -- * Request Lenses describeOrganizationConfiguration_detectorId, -- * Destructuring the Response DescribeOrganizationConfigurationResponse (..), newDescribeOrganizationConfigurationResponse, -- * Response Lenses describeOrganizationConfigurationResponse_dataSources, describeOrganizationConfigurationResponse_httpStatus, describeOrganizationConfigurationResponse_autoEnable, describeOrganizationConfigurationResponse_memberAccountLimitReached, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.GuardDuty.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDescribeOrganizationConfiguration' smart constructor. data DescribeOrganizationConfiguration = DescribeOrganizationConfiguration' { -- | The ID of the detector to retrieve information about the delegated -- administrator from. detectorId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeOrganizationConfiguration' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'detectorId', 'describeOrganizationConfiguration_detectorId' - The ID of the detector to retrieve information about the delegated -- administrator from. newDescribeOrganizationConfiguration :: -- | 'detectorId' Prelude.Text -> DescribeOrganizationConfiguration newDescribeOrganizationConfiguration pDetectorId_ = DescribeOrganizationConfiguration' { detectorId = pDetectorId_ } -- | The ID of the detector to retrieve information about the delegated -- administrator from. describeOrganizationConfiguration_detectorId :: Lens.Lens' DescribeOrganizationConfiguration Prelude.Text describeOrganizationConfiguration_detectorId = Lens.lens (\DescribeOrganizationConfiguration' {detectorId} -> detectorId) (\s@DescribeOrganizationConfiguration' {} a -> s {detectorId = a} :: DescribeOrganizationConfiguration) instance Core.AWSRequest DescribeOrganizationConfiguration where type AWSResponse DescribeOrganizationConfiguration = DescribeOrganizationConfigurationResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeOrganizationConfigurationResponse' Prelude.<$> (x Data..?> "dataSources") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "autoEnable") Prelude.<*> (x Data..:> "memberAccountLimitReached") ) instance Prelude.Hashable DescribeOrganizationConfiguration where hashWithSalt _salt DescribeOrganizationConfiguration' {..} = _salt `Prelude.hashWithSalt` detectorId instance Prelude.NFData DescribeOrganizationConfiguration where rnf DescribeOrganizationConfiguration' {..} = Prelude.rnf detectorId instance Data.ToHeaders DescribeOrganizationConfiguration where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath DescribeOrganizationConfiguration where toPath DescribeOrganizationConfiguration' {..} = Prelude.mconcat ["/detector/", Data.toBS detectorId, "/admin"] instance Data.ToQuery DescribeOrganizationConfiguration where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeOrganizationConfigurationResponse' smart constructor. data DescribeOrganizationConfigurationResponse = DescribeOrganizationConfigurationResponse' { -- | Describes which data sources are enabled automatically for member -- accounts. dataSources :: Prelude.Maybe OrganizationDataSourceConfigurationsResult, -- | The response's http status code. httpStatus :: Prelude.Int, -- | Indicates whether GuardDuty is automatically enabled for accounts added -- to the organization. autoEnable :: Prelude.Bool, -- | Indicates whether the maximum number of allowed member accounts are -- already associated with the delegated administrator account for your -- organization. memberAccountLimitReached :: Prelude.Bool } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeOrganizationConfigurationResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'dataSources', 'describeOrganizationConfigurationResponse_dataSources' - Describes which data sources are enabled automatically for member -- accounts. -- -- 'httpStatus', 'describeOrganizationConfigurationResponse_httpStatus' - The response's http status code. -- -- 'autoEnable', 'describeOrganizationConfigurationResponse_autoEnable' - Indicates whether GuardDuty is automatically enabled for accounts added -- to the organization. -- -- 'memberAccountLimitReached', 'describeOrganizationConfigurationResponse_memberAccountLimitReached' - Indicates whether the maximum number of allowed member accounts are -- already associated with the delegated administrator account for your -- organization. newDescribeOrganizationConfigurationResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'autoEnable' Prelude.Bool -> -- | 'memberAccountLimitReached' Prelude.Bool -> DescribeOrganizationConfigurationResponse newDescribeOrganizationConfigurationResponse pHttpStatus_ pAutoEnable_ pMemberAccountLimitReached_ = DescribeOrganizationConfigurationResponse' { dataSources = Prelude.Nothing, httpStatus = pHttpStatus_, autoEnable = pAutoEnable_, memberAccountLimitReached = pMemberAccountLimitReached_ } -- | Describes which data sources are enabled automatically for member -- accounts. describeOrganizationConfigurationResponse_dataSources :: Lens.Lens' DescribeOrganizationConfigurationResponse (Prelude.Maybe OrganizationDataSourceConfigurationsResult) describeOrganizationConfigurationResponse_dataSources = Lens.lens (\DescribeOrganizationConfigurationResponse' {dataSources} -> dataSources) (\s@DescribeOrganizationConfigurationResponse' {} a -> s {dataSources = a} :: DescribeOrganizationConfigurationResponse) -- | The response's http status code. describeOrganizationConfigurationResponse_httpStatus :: Lens.Lens' DescribeOrganizationConfigurationResponse Prelude.Int describeOrganizationConfigurationResponse_httpStatus = Lens.lens (\DescribeOrganizationConfigurationResponse' {httpStatus} -> httpStatus) (\s@DescribeOrganizationConfigurationResponse' {} a -> s {httpStatus = a} :: DescribeOrganizationConfigurationResponse) -- | Indicates whether GuardDuty is automatically enabled for accounts added -- to the organization. describeOrganizationConfigurationResponse_autoEnable :: Lens.Lens' DescribeOrganizationConfigurationResponse Prelude.Bool describeOrganizationConfigurationResponse_autoEnable = Lens.lens (\DescribeOrganizationConfigurationResponse' {autoEnable} -> autoEnable) (\s@DescribeOrganizationConfigurationResponse' {} a -> s {autoEnable = a} :: DescribeOrganizationConfigurationResponse) -- | Indicates whether the maximum number of allowed member accounts are -- already associated with the delegated administrator account for your -- organization. describeOrganizationConfigurationResponse_memberAccountLimitReached :: Lens.Lens' DescribeOrganizationConfigurationResponse Prelude.Bool describeOrganizationConfigurationResponse_memberAccountLimitReached = Lens.lens (\DescribeOrganizationConfigurationResponse' {memberAccountLimitReached} -> memberAccountLimitReached) (\s@DescribeOrganizationConfigurationResponse' {} a -> s {memberAccountLimitReached = a} :: DescribeOrganizationConfigurationResponse) instance Prelude.NFData DescribeOrganizationConfigurationResponse where rnf DescribeOrganizationConfigurationResponse' {..} = Prelude.rnf dataSources `Prelude.seq` Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf autoEnable `Prelude.seq` Prelude.rnf memberAccountLimitReached