{-# 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.Inspector.DescribeAssessmentTargets
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Describes the assessment targets that are specified by the ARNs of the
-- assessment targets.
module Amazonka.Inspector.DescribeAssessmentTargets
  ( -- * Creating a Request
    DescribeAssessmentTargets (..),
    newDescribeAssessmentTargets,

    -- * Request Lenses
    describeAssessmentTargets_assessmentTargetArns,

    -- * Destructuring the Response
    DescribeAssessmentTargetsResponse (..),
    newDescribeAssessmentTargetsResponse,

    -- * Response Lenses
    describeAssessmentTargetsResponse_httpStatus,
    describeAssessmentTargetsResponse_assessmentTargets,
    describeAssessmentTargetsResponse_failedItems,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.Inspector.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newDescribeAssessmentTargets' smart constructor.
data DescribeAssessmentTargets = DescribeAssessmentTargets'
  { -- | The ARNs that specifies the assessment targets that you want to
    -- describe.
    DescribeAssessmentTargets -> NonEmpty Text
assessmentTargetArns :: Prelude.NonEmpty Prelude.Text
  }
  deriving (DescribeAssessmentTargets -> DescribeAssessmentTargets -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeAssessmentTargets -> DescribeAssessmentTargets -> Bool
$c/= :: DescribeAssessmentTargets -> DescribeAssessmentTargets -> Bool
== :: DescribeAssessmentTargets -> DescribeAssessmentTargets -> Bool
$c== :: DescribeAssessmentTargets -> DescribeAssessmentTargets -> Bool
Prelude.Eq, ReadPrec [DescribeAssessmentTargets]
ReadPrec DescribeAssessmentTargets
Int -> ReadS DescribeAssessmentTargets
ReadS [DescribeAssessmentTargets]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeAssessmentTargets]
$creadListPrec :: ReadPrec [DescribeAssessmentTargets]
readPrec :: ReadPrec DescribeAssessmentTargets
$creadPrec :: ReadPrec DescribeAssessmentTargets
readList :: ReadS [DescribeAssessmentTargets]
$creadList :: ReadS [DescribeAssessmentTargets]
readsPrec :: Int -> ReadS DescribeAssessmentTargets
$creadsPrec :: Int -> ReadS DescribeAssessmentTargets
Prelude.Read, Int -> DescribeAssessmentTargets -> ShowS
[DescribeAssessmentTargets] -> ShowS
DescribeAssessmentTargets -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeAssessmentTargets] -> ShowS
$cshowList :: [DescribeAssessmentTargets] -> ShowS
show :: DescribeAssessmentTargets -> String
$cshow :: DescribeAssessmentTargets -> String
showsPrec :: Int -> DescribeAssessmentTargets -> ShowS
$cshowsPrec :: Int -> DescribeAssessmentTargets -> ShowS
Prelude.Show, forall x.
Rep DescribeAssessmentTargets x -> DescribeAssessmentTargets
forall x.
DescribeAssessmentTargets -> Rep DescribeAssessmentTargets x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeAssessmentTargets x -> DescribeAssessmentTargets
$cfrom :: forall x.
DescribeAssessmentTargets -> Rep DescribeAssessmentTargets x
Prelude.Generic)

-- |
-- Create a value of 'DescribeAssessmentTargets' 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:
--
-- 'assessmentTargetArns', 'describeAssessmentTargets_assessmentTargetArns' - The ARNs that specifies the assessment targets that you want to
-- describe.
newDescribeAssessmentTargets ::
  -- | 'assessmentTargetArns'
  Prelude.NonEmpty Prelude.Text ->
  DescribeAssessmentTargets
newDescribeAssessmentTargets :: NonEmpty Text -> DescribeAssessmentTargets
newDescribeAssessmentTargets NonEmpty Text
pAssessmentTargetArns_ =
  DescribeAssessmentTargets'
    { $sel:assessmentTargetArns:DescribeAssessmentTargets' :: NonEmpty Text
assessmentTargetArns =
        forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced forall t b. AReview t b -> b -> t
Lens.# NonEmpty Text
pAssessmentTargetArns_
    }

-- | The ARNs that specifies the assessment targets that you want to
-- describe.
describeAssessmentTargets_assessmentTargetArns :: Lens.Lens' DescribeAssessmentTargets (Prelude.NonEmpty Prelude.Text)
describeAssessmentTargets_assessmentTargetArns :: Lens' DescribeAssessmentTargets (NonEmpty Text)
describeAssessmentTargets_assessmentTargetArns = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAssessmentTargets' {NonEmpty Text
assessmentTargetArns :: NonEmpty Text
$sel:assessmentTargetArns:DescribeAssessmentTargets' :: DescribeAssessmentTargets -> NonEmpty Text
assessmentTargetArns} -> NonEmpty Text
assessmentTargetArns) (\s :: DescribeAssessmentTargets
s@DescribeAssessmentTargets' {} NonEmpty Text
a -> DescribeAssessmentTargets
s {$sel:assessmentTargetArns:DescribeAssessmentTargets' :: NonEmpty Text
assessmentTargetArns = NonEmpty Text
a} :: DescribeAssessmentTargets) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance Core.AWSRequest DescribeAssessmentTargets where
  type
    AWSResponse DescribeAssessmentTargets =
      DescribeAssessmentTargetsResponse
  request :: (Service -> Service)
-> DescribeAssessmentTargets -> Request DescribeAssessmentTargets
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 DescribeAssessmentTargets
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeAssessmentTargets)))
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 ->
          Int
-> [AssessmentTarget]
-> HashMap Text FailedItemDetails
-> DescribeAssessmentTargetsResponse
DescribeAssessmentTargetsResponse'
            forall (f :: * -> *) a b. Functor 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))
            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
"assessmentTargets"
                            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
"failedItems" forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty)
      )

instance Prelude.Hashable DescribeAssessmentTargets where
  hashWithSalt :: Int -> DescribeAssessmentTargets -> Int
hashWithSalt Int
_salt DescribeAssessmentTargets' {NonEmpty Text
assessmentTargetArns :: NonEmpty Text
$sel:assessmentTargetArns:DescribeAssessmentTargets' :: DescribeAssessmentTargets -> NonEmpty Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` NonEmpty Text
assessmentTargetArns

instance Prelude.NFData DescribeAssessmentTargets where
  rnf :: DescribeAssessmentTargets -> ()
rnf DescribeAssessmentTargets' {NonEmpty Text
assessmentTargetArns :: NonEmpty Text
$sel:assessmentTargetArns:DescribeAssessmentTargets' :: DescribeAssessmentTargets -> NonEmpty Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf NonEmpty Text
assessmentTargetArns

instance Data.ToHeaders DescribeAssessmentTargets where
  toHeaders :: DescribeAssessmentTargets -> 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
"InspectorService.DescribeAssessmentTargets" ::
                          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 DescribeAssessmentTargets where
  toJSON :: DescribeAssessmentTargets -> Value
toJSON DescribeAssessmentTargets' {NonEmpty Text
assessmentTargetArns :: NonEmpty Text
$sel:assessmentTargetArns:DescribeAssessmentTargets' :: DescribeAssessmentTargets -> NonEmpty Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just
              ( Key
"assessmentTargetArns"
                  forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= NonEmpty Text
assessmentTargetArns
              )
          ]
      )

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

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

-- | /See:/ 'newDescribeAssessmentTargetsResponse' smart constructor.
data DescribeAssessmentTargetsResponse = DescribeAssessmentTargetsResponse'
  { -- | The response's http status code.
    DescribeAssessmentTargetsResponse -> Int
httpStatus :: Prelude.Int,
    -- | Information about the assessment targets.
    DescribeAssessmentTargetsResponse -> [AssessmentTarget]
assessmentTargets :: [AssessmentTarget],
    -- | Assessment target details that cannot be described. An error code is
    -- provided for each failed item.
    DescribeAssessmentTargetsResponse -> HashMap Text FailedItemDetails
failedItems :: Prelude.HashMap Prelude.Text FailedItemDetails
  }
  deriving (DescribeAssessmentTargetsResponse
-> DescribeAssessmentTargetsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeAssessmentTargetsResponse
-> DescribeAssessmentTargetsResponse -> Bool
$c/= :: DescribeAssessmentTargetsResponse
-> DescribeAssessmentTargetsResponse -> Bool
== :: DescribeAssessmentTargetsResponse
-> DescribeAssessmentTargetsResponse -> Bool
$c== :: DescribeAssessmentTargetsResponse
-> DescribeAssessmentTargetsResponse -> Bool
Prelude.Eq, ReadPrec [DescribeAssessmentTargetsResponse]
ReadPrec DescribeAssessmentTargetsResponse
Int -> ReadS DescribeAssessmentTargetsResponse
ReadS [DescribeAssessmentTargetsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeAssessmentTargetsResponse]
$creadListPrec :: ReadPrec [DescribeAssessmentTargetsResponse]
readPrec :: ReadPrec DescribeAssessmentTargetsResponse
$creadPrec :: ReadPrec DescribeAssessmentTargetsResponse
readList :: ReadS [DescribeAssessmentTargetsResponse]
$creadList :: ReadS [DescribeAssessmentTargetsResponse]
readsPrec :: Int -> ReadS DescribeAssessmentTargetsResponse
$creadsPrec :: Int -> ReadS DescribeAssessmentTargetsResponse
Prelude.Read, Int -> DescribeAssessmentTargetsResponse -> ShowS
[DescribeAssessmentTargetsResponse] -> ShowS
DescribeAssessmentTargetsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeAssessmentTargetsResponse] -> ShowS
$cshowList :: [DescribeAssessmentTargetsResponse] -> ShowS
show :: DescribeAssessmentTargetsResponse -> String
$cshow :: DescribeAssessmentTargetsResponse -> String
showsPrec :: Int -> DescribeAssessmentTargetsResponse -> ShowS
$cshowsPrec :: Int -> DescribeAssessmentTargetsResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeAssessmentTargetsResponse x
-> DescribeAssessmentTargetsResponse
forall x.
DescribeAssessmentTargetsResponse
-> Rep DescribeAssessmentTargetsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeAssessmentTargetsResponse x
-> DescribeAssessmentTargetsResponse
$cfrom :: forall x.
DescribeAssessmentTargetsResponse
-> Rep DescribeAssessmentTargetsResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeAssessmentTargetsResponse' 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:
--
-- 'httpStatus', 'describeAssessmentTargetsResponse_httpStatus' - The response's http status code.
--
-- 'assessmentTargets', 'describeAssessmentTargetsResponse_assessmentTargets' - Information about the assessment targets.
--
-- 'failedItems', 'describeAssessmentTargetsResponse_failedItems' - Assessment target details that cannot be described. An error code is
-- provided for each failed item.
newDescribeAssessmentTargetsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeAssessmentTargetsResponse
newDescribeAssessmentTargetsResponse :: Int -> DescribeAssessmentTargetsResponse
newDescribeAssessmentTargetsResponse Int
pHttpStatus_ =
  DescribeAssessmentTargetsResponse'
    { $sel:httpStatus:DescribeAssessmentTargetsResponse' :: Int
httpStatus =
        Int
pHttpStatus_,
      $sel:assessmentTargets:DescribeAssessmentTargetsResponse' :: [AssessmentTarget]
assessmentTargets = forall a. Monoid a => a
Prelude.mempty,
      $sel:failedItems:DescribeAssessmentTargetsResponse' :: HashMap Text FailedItemDetails
failedItems = forall a. Monoid a => a
Prelude.mempty
    }

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

-- | Information about the assessment targets.
describeAssessmentTargetsResponse_assessmentTargets :: Lens.Lens' DescribeAssessmentTargetsResponse [AssessmentTarget]
describeAssessmentTargetsResponse_assessmentTargets :: Lens' DescribeAssessmentTargetsResponse [AssessmentTarget]
describeAssessmentTargetsResponse_assessmentTargets = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAssessmentTargetsResponse' {[AssessmentTarget]
assessmentTargets :: [AssessmentTarget]
$sel:assessmentTargets:DescribeAssessmentTargetsResponse' :: DescribeAssessmentTargetsResponse -> [AssessmentTarget]
assessmentTargets} -> [AssessmentTarget]
assessmentTargets) (\s :: DescribeAssessmentTargetsResponse
s@DescribeAssessmentTargetsResponse' {} [AssessmentTarget]
a -> DescribeAssessmentTargetsResponse
s {$sel:assessmentTargets:DescribeAssessmentTargetsResponse' :: [AssessmentTarget]
assessmentTargets = [AssessmentTarget]
a} :: DescribeAssessmentTargetsResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | Assessment target details that cannot be described. An error code is
-- provided for each failed item.
describeAssessmentTargetsResponse_failedItems :: Lens.Lens' DescribeAssessmentTargetsResponse (Prelude.HashMap Prelude.Text FailedItemDetails)
describeAssessmentTargetsResponse_failedItems :: Lens'
  DescribeAssessmentTargetsResponse (HashMap Text FailedItemDetails)
describeAssessmentTargetsResponse_failedItems = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAssessmentTargetsResponse' {HashMap Text FailedItemDetails
failedItems :: HashMap Text FailedItemDetails
$sel:failedItems:DescribeAssessmentTargetsResponse' :: DescribeAssessmentTargetsResponse -> HashMap Text FailedItemDetails
failedItems} -> HashMap Text FailedItemDetails
failedItems) (\s :: DescribeAssessmentTargetsResponse
s@DescribeAssessmentTargetsResponse' {} HashMap Text FailedItemDetails
a -> DescribeAssessmentTargetsResponse
s {$sel:failedItems:DescribeAssessmentTargetsResponse' :: HashMap Text FailedItemDetails
failedItems = HashMap Text FailedItemDetails
a} :: DescribeAssessmentTargetsResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance
  Prelude.NFData
    DescribeAssessmentTargetsResponse
  where
  rnf :: DescribeAssessmentTargetsResponse -> ()
rnf DescribeAssessmentTargetsResponse' {Int
[AssessmentTarget]
HashMap Text FailedItemDetails
failedItems :: HashMap Text FailedItemDetails
assessmentTargets :: [AssessmentTarget]
httpStatus :: Int
$sel:failedItems:DescribeAssessmentTargetsResponse' :: DescribeAssessmentTargetsResponse -> HashMap Text FailedItemDetails
$sel:assessmentTargets:DescribeAssessmentTargetsResponse' :: DescribeAssessmentTargetsResponse -> [AssessmentTarget]
$sel:httpStatus:DescribeAssessmentTargetsResponse' :: DescribeAssessmentTargetsResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [AssessmentTarget]
assessmentTargets
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf HashMap Text FailedItemDetails
failedItems