{-# 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.Config.GetAggregateConformancePackComplianceSummary -- 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 the count of compliant and noncompliant conformance packs across -- all Amazon Web Services accounts and Amazon Web Services Regions in an -- aggregator. You can filter based on Amazon Web Services account ID or -- Amazon Web Services Region. -- -- The results can return an empty result page, but if you have a -- nextToken, the results are displayed on the next page. module Amazonka.Config.GetAggregateConformancePackComplianceSummary ( -- * Creating a Request GetAggregateConformancePackComplianceSummary (..), newGetAggregateConformancePackComplianceSummary, -- * Request Lenses getAggregateConformancePackComplianceSummary_filters, getAggregateConformancePackComplianceSummary_groupByKey, getAggregateConformancePackComplianceSummary_limit, getAggregateConformancePackComplianceSummary_nextToken, getAggregateConformancePackComplianceSummary_configurationAggregatorName, -- * Destructuring the Response GetAggregateConformancePackComplianceSummaryResponse (..), newGetAggregateConformancePackComplianceSummaryResponse, -- * Response Lenses getAggregateConformancePackComplianceSummaryResponse_aggregateConformancePackComplianceSummaries, getAggregateConformancePackComplianceSummaryResponse_groupByKey, getAggregateConformancePackComplianceSummaryResponse_nextToken, getAggregateConformancePackComplianceSummaryResponse_httpStatus, ) where import Amazonka.Config.Types import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newGetAggregateConformancePackComplianceSummary' smart constructor. data GetAggregateConformancePackComplianceSummary = GetAggregateConformancePackComplianceSummary' { -- | Filters the results based on the -- @AggregateConformancePackComplianceSummaryFilters@ object. filters :: Prelude.Maybe AggregateConformancePackComplianceSummaryFilters, -- | Groups the result based on Amazon Web Services account ID or Amazon Web -- Services Region. groupByKey :: Prelude.Maybe AggregateConformancePackComplianceSummaryGroupKey, -- | The maximum number of results returned on each page. The default is -- maximum. If you specify 0, Config uses the default. limit :: Prelude.Maybe Prelude.Natural, -- | The @nextToken@ string returned on a previous page that you use to get -- the next page of results in a paginated response. nextToken :: Prelude.Maybe Prelude.Text, -- | The name of the configuration aggregator. configurationAggregatorName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetAggregateConformancePackComplianceSummary' 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: -- -- 'filters', 'getAggregateConformancePackComplianceSummary_filters' - Filters the results based on the -- @AggregateConformancePackComplianceSummaryFilters@ object. -- -- 'groupByKey', 'getAggregateConformancePackComplianceSummary_groupByKey' - Groups the result based on Amazon Web Services account ID or Amazon Web -- Services Region. -- -- 'limit', 'getAggregateConformancePackComplianceSummary_limit' - The maximum number of results returned on each page. The default is -- maximum. If you specify 0, Config uses the default. -- -- 'nextToken', 'getAggregateConformancePackComplianceSummary_nextToken' - The @nextToken@ string returned on a previous page that you use to get -- the next page of results in a paginated response. -- -- 'configurationAggregatorName', 'getAggregateConformancePackComplianceSummary_configurationAggregatorName' - The name of the configuration aggregator. newGetAggregateConformancePackComplianceSummary :: -- | 'configurationAggregatorName' Prelude.Text -> GetAggregateConformancePackComplianceSummary newGetAggregateConformancePackComplianceSummary pConfigurationAggregatorName_ = GetAggregateConformancePackComplianceSummary' { filters = Prelude.Nothing, groupByKey = Prelude.Nothing, limit = Prelude.Nothing, nextToken = Prelude.Nothing, configurationAggregatorName = pConfigurationAggregatorName_ } -- | Filters the results based on the -- @AggregateConformancePackComplianceSummaryFilters@ object. getAggregateConformancePackComplianceSummary_filters :: Lens.Lens' GetAggregateConformancePackComplianceSummary (Prelude.Maybe AggregateConformancePackComplianceSummaryFilters) getAggregateConformancePackComplianceSummary_filters = Lens.lens (\GetAggregateConformancePackComplianceSummary' {filters} -> filters) (\s@GetAggregateConformancePackComplianceSummary' {} a -> s {filters = a} :: GetAggregateConformancePackComplianceSummary) -- | Groups the result based on Amazon Web Services account ID or Amazon Web -- Services Region. getAggregateConformancePackComplianceSummary_groupByKey :: Lens.Lens' GetAggregateConformancePackComplianceSummary (Prelude.Maybe AggregateConformancePackComplianceSummaryGroupKey) getAggregateConformancePackComplianceSummary_groupByKey = Lens.lens (\GetAggregateConformancePackComplianceSummary' {groupByKey} -> groupByKey) (\s@GetAggregateConformancePackComplianceSummary' {} a -> s {groupByKey = a} :: GetAggregateConformancePackComplianceSummary) -- | The maximum number of results returned on each page. The default is -- maximum. If you specify 0, Config uses the default. getAggregateConformancePackComplianceSummary_limit :: Lens.Lens' GetAggregateConformancePackComplianceSummary (Prelude.Maybe Prelude.Natural) getAggregateConformancePackComplianceSummary_limit = Lens.lens (\GetAggregateConformancePackComplianceSummary' {limit} -> limit) (\s@GetAggregateConformancePackComplianceSummary' {} a -> s {limit = a} :: GetAggregateConformancePackComplianceSummary) -- | The @nextToken@ string returned on a previous page that you use to get -- the next page of results in a paginated response. getAggregateConformancePackComplianceSummary_nextToken :: Lens.Lens' GetAggregateConformancePackComplianceSummary (Prelude.Maybe Prelude.Text) getAggregateConformancePackComplianceSummary_nextToken = Lens.lens (\GetAggregateConformancePackComplianceSummary' {nextToken} -> nextToken) (\s@GetAggregateConformancePackComplianceSummary' {} a -> s {nextToken = a} :: GetAggregateConformancePackComplianceSummary) -- | The name of the configuration aggregator. getAggregateConformancePackComplianceSummary_configurationAggregatorName :: Lens.Lens' GetAggregateConformancePackComplianceSummary Prelude.Text getAggregateConformancePackComplianceSummary_configurationAggregatorName = Lens.lens (\GetAggregateConformancePackComplianceSummary' {configurationAggregatorName} -> configurationAggregatorName) (\s@GetAggregateConformancePackComplianceSummary' {} a -> s {configurationAggregatorName = a} :: GetAggregateConformancePackComplianceSummary) instance Core.AWSRequest GetAggregateConformancePackComplianceSummary where type AWSResponse GetAggregateConformancePackComplianceSummary = GetAggregateConformancePackComplianceSummaryResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetAggregateConformancePackComplianceSummaryResponse' Prelude.<$> ( x Data..?> "AggregateConformancePackComplianceSummaries" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "GroupByKey") Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetAggregateConformancePackComplianceSummary where hashWithSalt _salt GetAggregateConformancePackComplianceSummary' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` groupByKey `Prelude.hashWithSalt` limit `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` configurationAggregatorName instance Prelude.NFData GetAggregateConformancePackComplianceSummary where rnf GetAggregateConformancePackComplianceSummary' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf groupByKey `Prelude.seq` Prelude.rnf limit `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf configurationAggregatorName instance Data.ToHeaders GetAggregateConformancePackComplianceSummary where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "StarlingDoveService.GetAggregateConformancePackComplianceSummary" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON GetAggregateConformancePackComplianceSummary where toJSON GetAggregateConformancePackComplianceSummary' {..} = Data.object ( Prelude.catMaybes [ ("Filters" Data..=) Prelude.<$> filters, ("GroupByKey" Data..=) Prelude.<$> groupByKey, ("Limit" Data..=) Prelude.<$> limit, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ( "ConfigurationAggregatorName" Data..= configurationAggregatorName ) ] ) instance Data.ToPath GetAggregateConformancePackComplianceSummary where toPath = Prelude.const "/" instance Data.ToQuery GetAggregateConformancePackComplianceSummary where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetAggregateConformancePackComplianceSummaryResponse' smart constructor. data GetAggregateConformancePackComplianceSummaryResponse = GetAggregateConformancePackComplianceSummaryResponse' { -- | Returns a list of @AggregateConformancePackComplianceSummary@ object. aggregateConformancePackComplianceSummaries :: Prelude.Maybe [AggregateConformancePackComplianceSummary], -- | Groups the result based on Amazon Web Services account ID or Amazon Web -- Services Region. groupByKey :: Prelude.Maybe Prelude.Text, -- | The @nextToken@ string returned on a previous page that you use to get -- the next page of results in a paginated response. nextToken :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetAggregateConformancePackComplianceSummaryResponse' 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: -- -- 'aggregateConformancePackComplianceSummaries', 'getAggregateConformancePackComplianceSummaryResponse_aggregateConformancePackComplianceSummaries' - Returns a list of @AggregateConformancePackComplianceSummary@ object. -- -- 'groupByKey', 'getAggregateConformancePackComplianceSummaryResponse_groupByKey' - Groups the result based on Amazon Web Services account ID or Amazon Web -- Services Region. -- -- 'nextToken', 'getAggregateConformancePackComplianceSummaryResponse_nextToken' - The @nextToken@ string returned on a previous page that you use to get -- the next page of results in a paginated response. -- -- 'httpStatus', 'getAggregateConformancePackComplianceSummaryResponse_httpStatus' - The response's http status code. newGetAggregateConformancePackComplianceSummaryResponse :: -- | 'httpStatus' Prelude.Int -> GetAggregateConformancePackComplianceSummaryResponse newGetAggregateConformancePackComplianceSummaryResponse pHttpStatus_ = GetAggregateConformancePackComplianceSummaryResponse' { aggregateConformancePackComplianceSummaries = Prelude.Nothing, groupByKey = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Returns a list of @AggregateConformancePackComplianceSummary@ object. getAggregateConformancePackComplianceSummaryResponse_aggregateConformancePackComplianceSummaries :: Lens.Lens' GetAggregateConformancePackComplianceSummaryResponse (Prelude.Maybe [AggregateConformancePackComplianceSummary]) getAggregateConformancePackComplianceSummaryResponse_aggregateConformancePackComplianceSummaries = Lens.lens (\GetAggregateConformancePackComplianceSummaryResponse' {aggregateConformancePackComplianceSummaries} -> aggregateConformancePackComplianceSummaries) (\s@GetAggregateConformancePackComplianceSummaryResponse' {} a -> s {aggregateConformancePackComplianceSummaries = a} :: GetAggregateConformancePackComplianceSummaryResponse) Prelude.. Lens.mapping Lens.coerced -- | Groups the result based on Amazon Web Services account ID or Amazon Web -- Services Region. getAggregateConformancePackComplianceSummaryResponse_groupByKey :: Lens.Lens' GetAggregateConformancePackComplianceSummaryResponse (Prelude.Maybe Prelude.Text) getAggregateConformancePackComplianceSummaryResponse_groupByKey = Lens.lens (\GetAggregateConformancePackComplianceSummaryResponse' {groupByKey} -> groupByKey) (\s@GetAggregateConformancePackComplianceSummaryResponse' {} a -> s {groupByKey = a} :: GetAggregateConformancePackComplianceSummaryResponse) -- | The @nextToken@ string returned on a previous page that you use to get -- the next page of results in a paginated response. getAggregateConformancePackComplianceSummaryResponse_nextToken :: Lens.Lens' GetAggregateConformancePackComplianceSummaryResponse (Prelude.Maybe Prelude.Text) getAggregateConformancePackComplianceSummaryResponse_nextToken = Lens.lens (\GetAggregateConformancePackComplianceSummaryResponse' {nextToken} -> nextToken) (\s@GetAggregateConformancePackComplianceSummaryResponse' {} a -> s {nextToken = a} :: GetAggregateConformancePackComplianceSummaryResponse) -- | The response's http status code. getAggregateConformancePackComplianceSummaryResponse_httpStatus :: Lens.Lens' GetAggregateConformancePackComplianceSummaryResponse Prelude.Int getAggregateConformancePackComplianceSummaryResponse_httpStatus = Lens.lens (\GetAggregateConformancePackComplianceSummaryResponse' {httpStatus} -> httpStatus) (\s@GetAggregateConformancePackComplianceSummaryResponse' {} a -> s {httpStatus = a} :: GetAggregateConformancePackComplianceSummaryResponse) instance Prelude.NFData GetAggregateConformancePackComplianceSummaryResponse where rnf GetAggregateConformancePackComplianceSummaryResponse' {..} = Prelude.rnf aggregateConformancePackComplianceSummaries `Prelude.seq` Prelude.rnf groupByKey `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus