{-# 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.GetAggregateComplianceDetailsByConfigRule
-- 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 evaluation results for the specified Config rule for a
-- specific resource in a rule. The results indicate which Amazon Web
-- Services resources were evaluated by the rule, when each resource was
-- last evaluated, and whether each resource complies with the rule.
--
-- The results can return an empty result page. But if you have a
-- @nextToken@, the results are displayed on the next page.
--
-- This operation returns paginated results.
module Amazonka.Config.GetAggregateComplianceDetailsByConfigRule
  ( -- * Creating a Request
    GetAggregateComplianceDetailsByConfigRule (..),
    newGetAggregateComplianceDetailsByConfigRule,

    -- * Request Lenses
    getAggregateComplianceDetailsByConfigRule_complianceType,
    getAggregateComplianceDetailsByConfigRule_limit,
    getAggregateComplianceDetailsByConfigRule_nextToken,
    getAggregateComplianceDetailsByConfigRule_configurationAggregatorName,
    getAggregateComplianceDetailsByConfigRule_configRuleName,
    getAggregateComplianceDetailsByConfigRule_accountId,
    getAggregateComplianceDetailsByConfigRule_awsRegion,

    -- * Destructuring the Response
    GetAggregateComplianceDetailsByConfigRuleResponse (..),
    newGetAggregateComplianceDetailsByConfigRuleResponse,

    -- * Response Lenses
    getAggregateComplianceDetailsByConfigRuleResponse_aggregateEvaluationResults,
    getAggregateComplianceDetailsByConfigRuleResponse_nextToken,
    getAggregateComplianceDetailsByConfigRuleResponse_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:/ 'newGetAggregateComplianceDetailsByConfigRule' smart constructor.
data GetAggregateComplianceDetailsByConfigRule = GetAggregateComplianceDetailsByConfigRule'
  { -- | The resource compliance status.
    --
    -- For the @GetAggregateComplianceDetailsByConfigRuleRequest@ data type,
    -- Config supports only the @COMPLIANT@ and @NON_COMPLIANT@. Config does
    -- not support the @NOT_APPLICABLE@ and @INSUFFICIENT_DATA@ values.
    GetAggregateComplianceDetailsByConfigRule -> Maybe ComplianceType
complianceType :: Prelude.Maybe ComplianceType,
    -- | The maximum number of evaluation results returned on each page. The
    -- default is 50. You cannot specify a number greater than 100. If you
    -- specify 0, Config uses the default.
    GetAggregateComplianceDetailsByConfigRule -> Maybe Natural
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.
    GetAggregateComplianceDetailsByConfigRule -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The name of the configuration aggregator.
    GetAggregateComplianceDetailsByConfigRule -> Text
configurationAggregatorName :: Prelude.Text,
    -- | The name of the Config rule for which you want compliance information.
    GetAggregateComplianceDetailsByConfigRule -> Text
configRuleName :: Prelude.Text,
    -- | The 12-digit account ID of the source account.
    GetAggregateComplianceDetailsByConfigRule -> Text
accountId :: Prelude.Text,
    -- | The source region from where the data is aggregated.
    GetAggregateComplianceDetailsByConfigRule -> Text
awsRegion :: Prelude.Text
  }
  deriving (GetAggregateComplianceDetailsByConfigRule
-> GetAggregateComplianceDetailsByConfigRule -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetAggregateComplianceDetailsByConfigRule
-> GetAggregateComplianceDetailsByConfigRule -> Bool
$c/= :: GetAggregateComplianceDetailsByConfigRule
-> GetAggregateComplianceDetailsByConfigRule -> Bool
== :: GetAggregateComplianceDetailsByConfigRule
-> GetAggregateComplianceDetailsByConfigRule -> Bool
$c== :: GetAggregateComplianceDetailsByConfigRule
-> GetAggregateComplianceDetailsByConfigRule -> Bool
Prelude.Eq, ReadPrec [GetAggregateComplianceDetailsByConfigRule]
ReadPrec GetAggregateComplianceDetailsByConfigRule
Int -> ReadS GetAggregateComplianceDetailsByConfigRule
ReadS [GetAggregateComplianceDetailsByConfigRule]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetAggregateComplianceDetailsByConfigRule]
$creadListPrec :: ReadPrec [GetAggregateComplianceDetailsByConfigRule]
readPrec :: ReadPrec GetAggregateComplianceDetailsByConfigRule
$creadPrec :: ReadPrec GetAggregateComplianceDetailsByConfigRule
readList :: ReadS [GetAggregateComplianceDetailsByConfigRule]
$creadList :: ReadS [GetAggregateComplianceDetailsByConfigRule]
readsPrec :: Int -> ReadS GetAggregateComplianceDetailsByConfigRule
$creadsPrec :: Int -> ReadS GetAggregateComplianceDetailsByConfigRule
Prelude.Read, Int -> GetAggregateComplianceDetailsByConfigRule -> ShowS
[GetAggregateComplianceDetailsByConfigRule] -> ShowS
GetAggregateComplianceDetailsByConfigRule -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetAggregateComplianceDetailsByConfigRule] -> ShowS
$cshowList :: [GetAggregateComplianceDetailsByConfigRule] -> ShowS
show :: GetAggregateComplianceDetailsByConfigRule -> String
$cshow :: GetAggregateComplianceDetailsByConfigRule -> String
showsPrec :: Int -> GetAggregateComplianceDetailsByConfigRule -> ShowS
$cshowsPrec :: Int -> GetAggregateComplianceDetailsByConfigRule -> ShowS
Prelude.Show, forall x.
Rep GetAggregateComplianceDetailsByConfigRule x
-> GetAggregateComplianceDetailsByConfigRule
forall x.
GetAggregateComplianceDetailsByConfigRule
-> Rep GetAggregateComplianceDetailsByConfigRule x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetAggregateComplianceDetailsByConfigRule x
-> GetAggregateComplianceDetailsByConfigRule
$cfrom :: forall x.
GetAggregateComplianceDetailsByConfigRule
-> Rep GetAggregateComplianceDetailsByConfigRule x
Prelude.Generic)

-- |
-- Create a value of 'GetAggregateComplianceDetailsByConfigRule' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'complianceType', 'getAggregateComplianceDetailsByConfigRule_complianceType' - The resource compliance status.
--
-- For the @GetAggregateComplianceDetailsByConfigRuleRequest@ data type,
-- Config supports only the @COMPLIANT@ and @NON_COMPLIANT@. Config does
-- not support the @NOT_APPLICABLE@ and @INSUFFICIENT_DATA@ values.
--
-- 'limit', 'getAggregateComplianceDetailsByConfigRule_limit' - The maximum number of evaluation results returned on each page. The
-- default is 50. You cannot specify a number greater than 100. If you
-- specify 0, Config uses the default.
--
-- 'nextToken', 'getAggregateComplianceDetailsByConfigRule_nextToken' - The @nextToken@ string returned on a previous page that you use to get
-- the next page of results in a paginated response.
--
-- 'configurationAggregatorName', 'getAggregateComplianceDetailsByConfigRule_configurationAggregatorName' - The name of the configuration aggregator.
--
-- 'configRuleName', 'getAggregateComplianceDetailsByConfigRule_configRuleName' - The name of the Config rule for which you want compliance information.
--
-- 'accountId', 'getAggregateComplianceDetailsByConfigRule_accountId' - The 12-digit account ID of the source account.
--
-- 'awsRegion', 'getAggregateComplianceDetailsByConfigRule_awsRegion' - The source region from where the data is aggregated.
newGetAggregateComplianceDetailsByConfigRule ::
  -- | 'configurationAggregatorName'
  Prelude.Text ->
  -- | 'configRuleName'
  Prelude.Text ->
  -- | 'accountId'
  Prelude.Text ->
  -- | 'awsRegion'
  Prelude.Text ->
  GetAggregateComplianceDetailsByConfigRule
newGetAggregateComplianceDetailsByConfigRule :: Text
-> Text
-> Text
-> Text
-> GetAggregateComplianceDetailsByConfigRule
newGetAggregateComplianceDetailsByConfigRule
  Text
pConfigurationAggregatorName_
  Text
pConfigRuleName_
  Text
pAccountId_
  Text
pAwsRegion_ =
    GetAggregateComplianceDetailsByConfigRule'
      { $sel:complianceType:GetAggregateComplianceDetailsByConfigRule' :: Maybe ComplianceType
complianceType =
          forall a. Maybe a
Prelude.Nothing,
        $sel:limit:GetAggregateComplianceDetailsByConfigRule' :: Maybe Natural
limit = forall a. Maybe a
Prelude.Nothing,
        $sel:nextToken:GetAggregateComplianceDetailsByConfigRule' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
        $sel:configurationAggregatorName:GetAggregateComplianceDetailsByConfigRule' :: Text
configurationAggregatorName =
          Text
pConfigurationAggregatorName_,
        $sel:configRuleName:GetAggregateComplianceDetailsByConfigRule' :: Text
configRuleName =
          Text
pConfigRuleName_,
        $sel:accountId:GetAggregateComplianceDetailsByConfigRule' :: Text
accountId = Text
pAccountId_,
        $sel:awsRegion:GetAggregateComplianceDetailsByConfigRule' :: Text
awsRegion = Text
pAwsRegion_
      }

-- | The resource compliance status.
--
-- For the @GetAggregateComplianceDetailsByConfigRuleRequest@ data type,
-- Config supports only the @COMPLIANT@ and @NON_COMPLIANT@. Config does
-- not support the @NOT_APPLICABLE@ and @INSUFFICIENT_DATA@ values.
getAggregateComplianceDetailsByConfigRule_complianceType :: Lens.Lens' GetAggregateComplianceDetailsByConfigRule (Prelude.Maybe ComplianceType)
getAggregateComplianceDetailsByConfigRule_complianceType :: Lens'
  GetAggregateComplianceDetailsByConfigRule (Maybe ComplianceType)
getAggregateComplianceDetailsByConfigRule_complianceType = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRule' {Maybe ComplianceType
complianceType :: Maybe ComplianceType
$sel:complianceType:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe ComplianceType
complianceType} -> Maybe ComplianceType
complianceType) (\s :: GetAggregateComplianceDetailsByConfigRule
s@GetAggregateComplianceDetailsByConfigRule' {} Maybe ComplianceType
a -> GetAggregateComplianceDetailsByConfigRule
s {$sel:complianceType:GetAggregateComplianceDetailsByConfigRule' :: Maybe ComplianceType
complianceType = Maybe ComplianceType
a} :: GetAggregateComplianceDetailsByConfigRule)

-- | The maximum number of evaluation results returned on each page. The
-- default is 50. You cannot specify a number greater than 100. If you
-- specify 0, Config uses the default.
getAggregateComplianceDetailsByConfigRule_limit :: Lens.Lens' GetAggregateComplianceDetailsByConfigRule (Prelude.Maybe Prelude.Natural)
getAggregateComplianceDetailsByConfigRule_limit :: Lens' GetAggregateComplianceDetailsByConfigRule (Maybe Natural)
getAggregateComplianceDetailsByConfigRule_limit = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRule' {Maybe Natural
limit :: Maybe Natural
$sel:limit:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe Natural
limit} -> Maybe Natural
limit) (\s :: GetAggregateComplianceDetailsByConfigRule
s@GetAggregateComplianceDetailsByConfigRule' {} Maybe Natural
a -> GetAggregateComplianceDetailsByConfigRule
s {$sel:limit:GetAggregateComplianceDetailsByConfigRule' :: Maybe Natural
limit = Maybe Natural
a} :: GetAggregateComplianceDetailsByConfigRule)

-- | The @nextToken@ string returned on a previous page that you use to get
-- the next page of results in a paginated response.
getAggregateComplianceDetailsByConfigRule_nextToken :: Lens.Lens' GetAggregateComplianceDetailsByConfigRule (Prelude.Maybe Prelude.Text)
getAggregateComplianceDetailsByConfigRule_nextToken :: Lens' GetAggregateComplianceDetailsByConfigRule (Maybe Text)
getAggregateComplianceDetailsByConfigRule_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRule' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: GetAggregateComplianceDetailsByConfigRule
s@GetAggregateComplianceDetailsByConfigRule' {} Maybe Text
a -> GetAggregateComplianceDetailsByConfigRule
s {$sel:nextToken:GetAggregateComplianceDetailsByConfigRule' :: Maybe Text
nextToken = Maybe Text
a} :: GetAggregateComplianceDetailsByConfigRule)

-- | The name of the configuration aggregator.
getAggregateComplianceDetailsByConfigRule_configurationAggregatorName :: Lens.Lens' GetAggregateComplianceDetailsByConfigRule Prelude.Text
getAggregateComplianceDetailsByConfigRule_configurationAggregatorName :: Lens' GetAggregateComplianceDetailsByConfigRule Text
getAggregateComplianceDetailsByConfigRule_configurationAggregatorName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRule' {Text
configurationAggregatorName :: Text
$sel:configurationAggregatorName:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
configurationAggregatorName} -> Text
configurationAggregatorName) (\s :: GetAggregateComplianceDetailsByConfigRule
s@GetAggregateComplianceDetailsByConfigRule' {} Text
a -> GetAggregateComplianceDetailsByConfigRule
s {$sel:configurationAggregatorName:GetAggregateComplianceDetailsByConfigRule' :: Text
configurationAggregatorName = Text
a} :: GetAggregateComplianceDetailsByConfigRule)

-- | The name of the Config rule for which you want compliance information.
getAggregateComplianceDetailsByConfigRule_configRuleName :: Lens.Lens' GetAggregateComplianceDetailsByConfigRule Prelude.Text
getAggregateComplianceDetailsByConfigRule_configRuleName :: Lens' GetAggregateComplianceDetailsByConfigRule Text
getAggregateComplianceDetailsByConfigRule_configRuleName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRule' {Text
configRuleName :: Text
$sel:configRuleName:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
configRuleName} -> Text
configRuleName) (\s :: GetAggregateComplianceDetailsByConfigRule
s@GetAggregateComplianceDetailsByConfigRule' {} Text
a -> GetAggregateComplianceDetailsByConfigRule
s {$sel:configRuleName:GetAggregateComplianceDetailsByConfigRule' :: Text
configRuleName = Text
a} :: GetAggregateComplianceDetailsByConfigRule)

-- | The 12-digit account ID of the source account.
getAggregateComplianceDetailsByConfigRule_accountId :: Lens.Lens' GetAggregateComplianceDetailsByConfigRule Prelude.Text
getAggregateComplianceDetailsByConfigRule_accountId :: Lens' GetAggregateComplianceDetailsByConfigRule Text
getAggregateComplianceDetailsByConfigRule_accountId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRule' {Text
accountId :: Text
$sel:accountId:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
accountId} -> Text
accountId) (\s :: GetAggregateComplianceDetailsByConfigRule
s@GetAggregateComplianceDetailsByConfigRule' {} Text
a -> GetAggregateComplianceDetailsByConfigRule
s {$sel:accountId:GetAggregateComplianceDetailsByConfigRule' :: Text
accountId = Text
a} :: GetAggregateComplianceDetailsByConfigRule)

-- | The source region from where the data is aggregated.
getAggregateComplianceDetailsByConfigRule_awsRegion :: Lens.Lens' GetAggregateComplianceDetailsByConfigRule Prelude.Text
getAggregateComplianceDetailsByConfigRule_awsRegion :: Lens' GetAggregateComplianceDetailsByConfigRule Text
getAggregateComplianceDetailsByConfigRule_awsRegion = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRule' {Text
awsRegion :: Text
$sel:awsRegion:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
awsRegion} -> Text
awsRegion) (\s :: GetAggregateComplianceDetailsByConfigRule
s@GetAggregateComplianceDetailsByConfigRule' {} Text
a -> GetAggregateComplianceDetailsByConfigRule
s {$sel:awsRegion:GetAggregateComplianceDetailsByConfigRule' :: Text
awsRegion = Text
a} :: GetAggregateComplianceDetailsByConfigRule)

instance
  Core.AWSPager
    GetAggregateComplianceDetailsByConfigRule
  where
  page :: GetAggregateComplianceDetailsByConfigRule
-> AWSResponse GetAggregateComplianceDetailsByConfigRule
-> Maybe GetAggregateComplianceDetailsByConfigRule
page GetAggregateComplianceDetailsByConfigRule
rq AWSResponse GetAggregateComplianceDetailsByConfigRule
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse GetAggregateComplianceDetailsByConfigRule
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens'
  GetAggregateComplianceDetailsByConfigRuleResponse (Maybe Text)
getAggregateComplianceDetailsByConfigRuleResponse_nextToken
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse GetAggregateComplianceDetailsByConfigRule
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens'
  GetAggregateComplianceDetailsByConfigRuleResponse
  (Maybe [AggregateEvaluationResult])
getAggregateComplianceDetailsByConfigRuleResponse_aggregateEvaluationResults
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | Bool
Prelude.otherwise =
        forall a. a -> Maybe a
Prelude.Just
          forall a b. (a -> b) -> a -> b
Prelude.$ GetAggregateComplianceDetailsByConfigRule
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' GetAggregateComplianceDetailsByConfigRule (Maybe Text)
getAggregateComplianceDetailsByConfigRule_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse GetAggregateComplianceDetailsByConfigRule
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens'
  GetAggregateComplianceDetailsByConfigRuleResponse (Maybe Text)
getAggregateComplianceDetailsByConfigRuleResponse_nextToken
          forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just

instance
  Core.AWSRequest
    GetAggregateComplianceDetailsByConfigRule
  where
  type
    AWSResponse
      GetAggregateComplianceDetailsByConfigRule =
      GetAggregateComplianceDetailsByConfigRuleResponse
  request :: (Service -> Service)
-> GetAggregateComplianceDetailsByConfigRule
-> Request GetAggregateComplianceDetailsByConfigRule
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetAggregateComplianceDetailsByConfigRule
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse
           (AWSResponse GetAggregateComplianceDetailsByConfigRule)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Maybe [AggregateEvaluationResult]
-> Maybe Text
-> Int
-> GetAggregateComplianceDetailsByConfigRuleResponse
GetAggregateComplianceDetailsByConfigRuleResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ( Object
x
                            forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"AggregateEvaluationResults"
                            forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
                        )
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"NextToken")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance
  Prelude.Hashable
    GetAggregateComplianceDetailsByConfigRule
  where
  hashWithSalt :: Int -> GetAggregateComplianceDetailsByConfigRule -> Int
hashWithSalt
    Int
_salt
    GetAggregateComplianceDetailsByConfigRule' {Maybe Natural
Maybe Text
Maybe ComplianceType
Text
awsRegion :: Text
accountId :: Text
configRuleName :: Text
configurationAggregatorName :: Text
nextToken :: Maybe Text
limit :: Maybe Natural
complianceType :: Maybe ComplianceType
$sel:awsRegion:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:accountId:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:configRuleName:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:configurationAggregatorName:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:nextToken:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe Text
$sel:limit:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe Natural
$sel:complianceType:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe ComplianceType
..} =
      Int
_salt
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ComplianceType
complianceType
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
limit
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
configurationAggregatorName
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
configRuleName
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
accountId
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
awsRegion

instance
  Prelude.NFData
    GetAggregateComplianceDetailsByConfigRule
  where
  rnf :: GetAggregateComplianceDetailsByConfigRule -> ()
rnf GetAggregateComplianceDetailsByConfigRule' {Maybe Natural
Maybe Text
Maybe ComplianceType
Text
awsRegion :: Text
accountId :: Text
configRuleName :: Text
configurationAggregatorName :: Text
nextToken :: Maybe Text
limit :: Maybe Natural
complianceType :: Maybe ComplianceType
$sel:awsRegion:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:accountId:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:configRuleName:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:configurationAggregatorName:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:nextToken:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe Text
$sel:limit:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe Natural
$sel:complianceType:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe ComplianceType
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe ComplianceType
complianceType
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Natural
limit
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
configurationAggregatorName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
configRuleName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
accountId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
awsRegion

instance
  Data.ToHeaders
    GetAggregateComplianceDetailsByConfigRule
  where
  toHeaders :: GetAggregateComplianceDetailsByConfigRule -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"StarlingDoveService.GetAggregateComplianceDetailsByConfigRule" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance
  Data.ToJSON
    GetAggregateComplianceDetailsByConfigRule
  where
  toJSON :: GetAggregateComplianceDetailsByConfigRule -> Value
toJSON GetAggregateComplianceDetailsByConfigRule' {Maybe Natural
Maybe Text
Maybe ComplianceType
Text
awsRegion :: Text
accountId :: Text
configRuleName :: Text
configurationAggregatorName :: Text
nextToken :: Maybe Text
limit :: Maybe Natural
complianceType :: Maybe ComplianceType
$sel:awsRegion:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:accountId:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:configRuleName:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:configurationAggregatorName:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Text
$sel:nextToken:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe Text
$sel:limit:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe Natural
$sel:complianceType:GetAggregateComplianceDetailsByConfigRule' :: GetAggregateComplianceDetailsByConfigRule -> Maybe ComplianceType
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"ComplianceType" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=)
              forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe ComplianceType
complianceType,
            (Key
"Limit" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Natural
limit,
            (Key
"NextToken" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
nextToken,
            forall a. a -> Maybe a
Prelude.Just
              ( Key
"ConfigurationAggregatorName"
                  forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
configurationAggregatorName
              ),
            forall a. a -> Maybe a
Prelude.Just
              (Key
"ConfigRuleName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
configRuleName),
            forall a. a -> Maybe a
Prelude.Just (Key
"AccountId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
accountId),
            forall a. a -> Maybe a
Prelude.Just (Key
"AwsRegion" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
awsRegion)
          ]
      )

instance
  Data.ToPath
    GetAggregateComplianceDetailsByConfigRule
  where
  toPath :: GetAggregateComplianceDetailsByConfigRule -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance
  Data.ToQuery
    GetAggregateComplianceDetailsByConfigRule
  where
  toQuery :: GetAggregateComplianceDetailsByConfigRule -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newGetAggregateComplianceDetailsByConfigRuleResponse' smart constructor.
data GetAggregateComplianceDetailsByConfigRuleResponse = GetAggregateComplianceDetailsByConfigRuleResponse'
  { -- | Returns an AggregateEvaluationResults object.
    GetAggregateComplianceDetailsByConfigRuleResponse
-> Maybe [AggregateEvaluationResult]
aggregateEvaluationResults :: Prelude.Maybe [AggregateEvaluationResult],
    -- | The @nextToken@ string returned on a previous page that you use to get
    -- the next page of results in a paginated response.
    GetAggregateComplianceDetailsByConfigRuleResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    GetAggregateComplianceDetailsByConfigRuleResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (GetAggregateComplianceDetailsByConfigRuleResponse
-> GetAggregateComplianceDetailsByConfigRuleResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetAggregateComplianceDetailsByConfigRuleResponse
-> GetAggregateComplianceDetailsByConfigRuleResponse -> Bool
$c/= :: GetAggregateComplianceDetailsByConfigRuleResponse
-> GetAggregateComplianceDetailsByConfigRuleResponse -> Bool
== :: GetAggregateComplianceDetailsByConfigRuleResponse
-> GetAggregateComplianceDetailsByConfigRuleResponse -> Bool
$c== :: GetAggregateComplianceDetailsByConfigRuleResponse
-> GetAggregateComplianceDetailsByConfigRuleResponse -> Bool
Prelude.Eq, ReadPrec [GetAggregateComplianceDetailsByConfigRuleResponse]
ReadPrec GetAggregateComplianceDetailsByConfigRuleResponse
Int -> ReadS GetAggregateComplianceDetailsByConfigRuleResponse
ReadS [GetAggregateComplianceDetailsByConfigRuleResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetAggregateComplianceDetailsByConfigRuleResponse]
$creadListPrec :: ReadPrec [GetAggregateComplianceDetailsByConfigRuleResponse]
readPrec :: ReadPrec GetAggregateComplianceDetailsByConfigRuleResponse
$creadPrec :: ReadPrec GetAggregateComplianceDetailsByConfigRuleResponse
readList :: ReadS [GetAggregateComplianceDetailsByConfigRuleResponse]
$creadList :: ReadS [GetAggregateComplianceDetailsByConfigRuleResponse]
readsPrec :: Int -> ReadS GetAggregateComplianceDetailsByConfigRuleResponse
$creadsPrec :: Int -> ReadS GetAggregateComplianceDetailsByConfigRuleResponse
Prelude.Read, Int -> GetAggregateComplianceDetailsByConfigRuleResponse -> ShowS
[GetAggregateComplianceDetailsByConfigRuleResponse] -> ShowS
GetAggregateComplianceDetailsByConfigRuleResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetAggregateComplianceDetailsByConfigRuleResponse] -> ShowS
$cshowList :: [GetAggregateComplianceDetailsByConfigRuleResponse] -> ShowS
show :: GetAggregateComplianceDetailsByConfigRuleResponse -> String
$cshow :: GetAggregateComplianceDetailsByConfigRuleResponse -> String
showsPrec :: Int -> GetAggregateComplianceDetailsByConfigRuleResponse -> ShowS
$cshowsPrec :: Int -> GetAggregateComplianceDetailsByConfigRuleResponse -> ShowS
Prelude.Show, forall x.
Rep GetAggregateComplianceDetailsByConfigRuleResponse x
-> GetAggregateComplianceDetailsByConfigRuleResponse
forall x.
GetAggregateComplianceDetailsByConfigRuleResponse
-> Rep GetAggregateComplianceDetailsByConfigRuleResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetAggregateComplianceDetailsByConfigRuleResponse x
-> GetAggregateComplianceDetailsByConfigRuleResponse
$cfrom :: forall x.
GetAggregateComplianceDetailsByConfigRuleResponse
-> Rep GetAggregateComplianceDetailsByConfigRuleResponse x
Prelude.Generic)

-- |
-- Create a value of 'GetAggregateComplianceDetailsByConfigRuleResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'aggregateEvaluationResults', 'getAggregateComplianceDetailsByConfigRuleResponse_aggregateEvaluationResults' - Returns an AggregateEvaluationResults object.
--
-- 'nextToken', 'getAggregateComplianceDetailsByConfigRuleResponse_nextToken' - The @nextToken@ string returned on a previous page that you use to get
-- the next page of results in a paginated response.
--
-- 'httpStatus', 'getAggregateComplianceDetailsByConfigRuleResponse_httpStatus' - The response's http status code.
newGetAggregateComplianceDetailsByConfigRuleResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  GetAggregateComplianceDetailsByConfigRuleResponse
newGetAggregateComplianceDetailsByConfigRuleResponse :: Int -> GetAggregateComplianceDetailsByConfigRuleResponse
newGetAggregateComplianceDetailsByConfigRuleResponse
  Int
pHttpStatus_ =
    GetAggregateComplianceDetailsByConfigRuleResponse'
      { $sel:aggregateEvaluationResults:GetAggregateComplianceDetailsByConfigRuleResponse' :: Maybe [AggregateEvaluationResult]
aggregateEvaluationResults =
          forall a. Maybe a
Prelude.Nothing,
        $sel:nextToken:GetAggregateComplianceDetailsByConfigRuleResponse' :: Maybe Text
nextToken =
          forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:GetAggregateComplianceDetailsByConfigRuleResponse' :: Int
httpStatus =
          Int
pHttpStatus_
      }

-- | Returns an AggregateEvaluationResults object.
getAggregateComplianceDetailsByConfigRuleResponse_aggregateEvaluationResults :: Lens.Lens' GetAggregateComplianceDetailsByConfigRuleResponse (Prelude.Maybe [AggregateEvaluationResult])
getAggregateComplianceDetailsByConfigRuleResponse_aggregateEvaluationResults :: Lens'
  GetAggregateComplianceDetailsByConfigRuleResponse
  (Maybe [AggregateEvaluationResult])
getAggregateComplianceDetailsByConfigRuleResponse_aggregateEvaluationResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRuleResponse' {Maybe [AggregateEvaluationResult]
aggregateEvaluationResults :: Maybe [AggregateEvaluationResult]
$sel:aggregateEvaluationResults:GetAggregateComplianceDetailsByConfigRuleResponse' :: GetAggregateComplianceDetailsByConfigRuleResponse
-> Maybe [AggregateEvaluationResult]
aggregateEvaluationResults} -> Maybe [AggregateEvaluationResult]
aggregateEvaluationResults) (\s :: GetAggregateComplianceDetailsByConfigRuleResponse
s@GetAggregateComplianceDetailsByConfigRuleResponse' {} Maybe [AggregateEvaluationResult]
a -> GetAggregateComplianceDetailsByConfigRuleResponse
s {$sel:aggregateEvaluationResults:GetAggregateComplianceDetailsByConfigRuleResponse' :: Maybe [AggregateEvaluationResult]
aggregateEvaluationResults = Maybe [AggregateEvaluationResult]
a} :: GetAggregateComplianceDetailsByConfigRuleResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | The @nextToken@ string returned on a previous page that you use to get
-- the next page of results in a paginated response.
getAggregateComplianceDetailsByConfigRuleResponse_nextToken :: Lens.Lens' GetAggregateComplianceDetailsByConfigRuleResponse (Prelude.Maybe Prelude.Text)
getAggregateComplianceDetailsByConfigRuleResponse_nextToken :: Lens'
  GetAggregateComplianceDetailsByConfigRuleResponse (Maybe Text)
getAggregateComplianceDetailsByConfigRuleResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRuleResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:GetAggregateComplianceDetailsByConfigRuleResponse' :: GetAggregateComplianceDetailsByConfigRuleResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: GetAggregateComplianceDetailsByConfigRuleResponse
s@GetAggregateComplianceDetailsByConfigRuleResponse' {} Maybe Text
a -> GetAggregateComplianceDetailsByConfigRuleResponse
s {$sel:nextToken:GetAggregateComplianceDetailsByConfigRuleResponse' :: Maybe Text
nextToken = Maybe Text
a} :: GetAggregateComplianceDetailsByConfigRuleResponse)

-- | The response's http status code.
getAggregateComplianceDetailsByConfigRuleResponse_httpStatus :: Lens.Lens' GetAggregateComplianceDetailsByConfigRuleResponse Prelude.Int
getAggregateComplianceDetailsByConfigRuleResponse_httpStatus :: Lens' GetAggregateComplianceDetailsByConfigRuleResponse Int
getAggregateComplianceDetailsByConfigRuleResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAggregateComplianceDetailsByConfigRuleResponse' {Int
httpStatus :: Int
$sel:httpStatus:GetAggregateComplianceDetailsByConfigRuleResponse' :: GetAggregateComplianceDetailsByConfigRuleResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: GetAggregateComplianceDetailsByConfigRuleResponse
s@GetAggregateComplianceDetailsByConfigRuleResponse' {} Int
a -> GetAggregateComplianceDetailsByConfigRuleResponse
s {$sel:httpStatus:GetAggregateComplianceDetailsByConfigRuleResponse' :: Int
httpStatus = Int
a} :: GetAggregateComplianceDetailsByConfigRuleResponse)

instance
  Prelude.NFData
    GetAggregateComplianceDetailsByConfigRuleResponse
  where
  rnf :: GetAggregateComplianceDetailsByConfigRuleResponse -> ()
rnf
    GetAggregateComplianceDetailsByConfigRuleResponse' {Int
Maybe [AggregateEvaluationResult]
Maybe Text
httpStatus :: Int
nextToken :: Maybe Text
aggregateEvaluationResults :: Maybe [AggregateEvaluationResult]
$sel:httpStatus:GetAggregateComplianceDetailsByConfigRuleResponse' :: GetAggregateComplianceDetailsByConfigRuleResponse -> Int
$sel:nextToken:GetAggregateComplianceDetailsByConfigRuleResponse' :: GetAggregateComplianceDetailsByConfigRuleResponse -> Maybe Text
$sel:aggregateEvaluationResults:GetAggregateComplianceDetailsByConfigRuleResponse' :: GetAggregateComplianceDetailsByConfigRuleResponse
-> Maybe [AggregateEvaluationResult]
..} =
      forall a. NFData a => a -> ()
Prelude.rnf Maybe [AggregateEvaluationResult]
aggregateEvaluationResults
        seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
        seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus