{-# 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.DescribeCrossAccountAccessRole
-- 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 IAM role that enables Amazon Inspector to access your AWS
-- account.
module Amazonka.Inspector.DescribeCrossAccountAccessRole
  ( -- * Creating a Request
    DescribeCrossAccountAccessRole (..),
    newDescribeCrossAccountAccessRole,

    -- * Destructuring the Response
    DescribeCrossAccountAccessRoleResponse (..),
    newDescribeCrossAccountAccessRoleResponse,

    -- * Response Lenses
    describeCrossAccountAccessRoleResponse_httpStatus,
    describeCrossAccountAccessRoleResponse_roleArn,
    describeCrossAccountAccessRoleResponse_valid,
    describeCrossAccountAccessRoleResponse_registeredAt,
  )
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:/ 'newDescribeCrossAccountAccessRole' smart constructor.
data DescribeCrossAccountAccessRole = DescribeCrossAccountAccessRole'
  {
  }
  deriving (DescribeCrossAccountAccessRole
-> DescribeCrossAccountAccessRole -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeCrossAccountAccessRole
-> DescribeCrossAccountAccessRole -> Bool
$c/= :: DescribeCrossAccountAccessRole
-> DescribeCrossAccountAccessRole -> Bool
== :: DescribeCrossAccountAccessRole
-> DescribeCrossAccountAccessRole -> Bool
$c== :: DescribeCrossAccountAccessRole
-> DescribeCrossAccountAccessRole -> Bool
Prelude.Eq, ReadPrec [DescribeCrossAccountAccessRole]
ReadPrec DescribeCrossAccountAccessRole
Int -> ReadS DescribeCrossAccountAccessRole
ReadS [DescribeCrossAccountAccessRole]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeCrossAccountAccessRole]
$creadListPrec :: ReadPrec [DescribeCrossAccountAccessRole]
readPrec :: ReadPrec DescribeCrossAccountAccessRole
$creadPrec :: ReadPrec DescribeCrossAccountAccessRole
readList :: ReadS [DescribeCrossAccountAccessRole]
$creadList :: ReadS [DescribeCrossAccountAccessRole]
readsPrec :: Int -> ReadS DescribeCrossAccountAccessRole
$creadsPrec :: Int -> ReadS DescribeCrossAccountAccessRole
Prelude.Read, Int -> DescribeCrossAccountAccessRole -> ShowS
[DescribeCrossAccountAccessRole] -> ShowS
DescribeCrossAccountAccessRole -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeCrossAccountAccessRole] -> ShowS
$cshowList :: [DescribeCrossAccountAccessRole] -> ShowS
show :: DescribeCrossAccountAccessRole -> String
$cshow :: DescribeCrossAccountAccessRole -> String
showsPrec :: Int -> DescribeCrossAccountAccessRole -> ShowS
$cshowsPrec :: Int -> DescribeCrossAccountAccessRole -> ShowS
Prelude.Show, forall x.
Rep DescribeCrossAccountAccessRole x
-> DescribeCrossAccountAccessRole
forall x.
DescribeCrossAccountAccessRole
-> Rep DescribeCrossAccountAccessRole x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeCrossAccountAccessRole x
-> DescribeCrossAccountAccessRole
$cfrom :: forall x.
DescribeCrossAccountAccessRole
-> Rep DescribeCrossAccountAccessRole x
Prelude.Generic)

-- |
-- Create a value of 'DescribeCrossAccountAccessRole' 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.
newDescribeCrossAccountAccessRole ::
  DescribeCrossAccountAccessRole
newDescribeCrossAccountAccessRole :: DescribeCrossAccountAccessRole
newDescribeCrossAccountAccessRole =
  DescribeCrossAccountAccessRole
DescribeCrossAccountAccessRole'

instance
  Core.AWSRequest
    DescribeCrossAccountAccessRole
  where
  type
    AWSResponse DescribeCrossAccountAccessRole =
      DescribeCrossAccountAccessRoleResponse
  request :: (Service -> Service)
-> DescribeCrossAccountAccessRole
-> Request DescribeCrossAccountAccessRole
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 DescribeCrossAccountAccessRole
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse (AWSResponse DescribeCrossAccountAccessRole)))
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
-> Text -> Bool -> POSIX -> DescribeCrossAccountAccessRoleResponse
DescribeCrossAccountAccessRoleResponse'
            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 a
Data..:> Key
"roleArn")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"valid")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"registeredAt")
      )

instance
  Prelude.Hashable
    DescribeCrossAccountAccessRole
  where
  hashWithSalt :: Int -> DescribeCrossAccountAccessRole -> Int
hashWithSalt Int
_salt DescribeCrossAccountAccessRole
_ =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` ()

instance
  Prelude.NFData
    DescribeCrossAccountAccessRole
  where
  rnf :: DescribeCrossAccountAccessRole -> ()
rnf DescribeCrossAccountAccessRole
_ = ()

instance
  Data.ToHeaders
    DescribeCrossAccountAccessRole
  where
  toHeaders :: DescribeCrossAccountAccessRole -> 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.DescribeCrossAccountAccessRole" ::
                          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 DescribeCrossAccountAccessRole where
  toJSON :: DescribeCrossAccountAccessRole -> Value
toJSON = forall a b. a -> b -> a
Prelude.const (Object -> Value
Data.Object forall a. Monoid a => a
Prelude.mempty)

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

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

-- | /See:/ 'newDescribeCrossAccountAccessRoleResponse' smart constructor.
data DescribeCrossAccountAccessRoleResponse = DescribeCrossAccountAccessRoleResponse'
  { -- | The response's http status code.
    DescribeCrossAccountAccessRoleResponse -> Int
httpStatus :: Prelude.Int,
    -- | The ARN that specifies the IAM role that Amazon Inspector uses to access
    -- your AWS account.
    DescribeCrossAccountAccessRoleResponse -> Text
roleArn :: Prelude.Text,
    -- | A Boolean value that specifies whether the IAM role has the necessary
    -- policies attached to enable Amazon Inspector to access your AWS account.
    DescribeCrossAccountAccessRoleResponse -> Bool
valid :: Prelude.Bool,
    -- | The date when the cross-account access role was registered.
    DescribeCrossAccountAccessRoleResponse -> POSIX
registeredAt :: Data.POSIX
  }
  deriving (DescribeCrossAccountAccessRoleResponse
-> DescribeCrossAccountAccessRoleResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeCrossAccountAccessRoleResponse
-> DescribeCrossAccountAccessRoleResponse -> Bool
$c/= :: DescribeCrossAccountAccessRoleResponse
-> DescribeCrossAccountAccessRoleResponse -> Bool
== :: DescribeCrossAccountAccessRoleResponse
-> DescribeCrossAccountAccessRoleResponse -> Bool
$c== :: DescribeCrossAccountAccessRoleResponse
-> DescribeCrossAccountAccessRoleResponse -> Bool
Prelude.Eq, ReadPrec [DescribeCrossAccountAccessRoleResponse]
ReadPrec DescribeCrossAccountAccessRoleResponse
Int -> ReadS DescribeCrossAccountAccessRoleResponse
ReadS [DescribeCrossAccountAccessRoleResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeCrossAccountAccessRoleResponse]
$creadListPrec :: ReadPrec [DescribeCrossAccountAccessRoleResponse]
readPrec :: ReadPrec DescribeCrossAccountAccessRoleResponse
$creadPrec :: ReadPrec DescribeCrossAccountAccessRoleResponse
readList :: ReadS [DescribeCrossAccountAccessRoleResponse]
$creadList :: ReadS [DescribeCrossAccountAccessRoleResponse]
readsPrec :: Int -> ReadS DescribeCrossAccountAccessRoleResponse
$creadsPrec :: Int -> ReadS DescribeCrossAccountAccessRoleResponse
Prelude.Read, Int -> DescribeCrossAccountAccessRoleResponse -> ShowS
[DescribeCrossAccountAccessRoleResponse] -> ShowS
DescribeCrossAccountAccessRoleResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeCrossAccountAccessRoleResponse] -> ShowS
$cshowList :: [DescribeCrossAccountAccessRoleResponse] -> ShowS
show :: DescribeCrossAccountAccessRoleResponse -> String
$cshow :: DescribeCrossAccountAccessRoleResponse -> String
showsPrec :: Int -> DescribeCrossAccountAccessRoleResponse -> ShowS
$cshowsPrec :: Int -> DescribeCrossAccountAccessRoleResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeCrossAccountAccessRoleResponse x
-> DescribeCrossAccountAccessRoleResponse
forall x.
DescribeCrossAccountAccessRoleResponse
-> Rep DescribeCrossAccountAccessRoleResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeCrossAccountAccessRoleResponse x
-> DescribeCrossAccountAccessRoleResponse
$cfrom :: forall x.
DescribeCrossAccountAccessRoleResponse
-> Rep DescribeCrossAccountAccessRoleResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeCrossAccountAccessRoleResponse' 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', 'describeCrossAccountAccessRoleResponse_httpStatus' - The response's http status code.
--
-- 'roleArn', 'describeCrossAccountAccessRoleResponse_roleArn' - The ARN that specifies the IAM role that Amazon Inspector uses to access
-- your AWS account.
--
-- 'valid', 'describeCrossAccountAccessRoleResponse_valid' - A Boolean value that specifies whether the IAM role has the necessary
-- policies attached to enable Amazon Inspector to access your AWS account.
--
-- 'registeredAt', 'describeCrossAccountAccessRoleResponse_registeredAt' - The date when the cross-account access role was registered.
newDescribeCrossAccountAccessRoleResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'roleArn'
  Prelude.Text ->
  -- | 'valid'
  Prelude.Bool ->
  -- | 'registeredAt'
  Prelude.UTCTime ->
  DescribeCrossAccountAccessRoleResponse
newDescribeCrossAccountAccessRoleResponse :: Int
-> Text
-> Bool
-> UTCTime
-> DescribeCrossAccountAccessRoleResponse
newDescribeCrossAccountAccessRoleResponse
  Int
pHttpStatus_
  Text
pRoleArn_
  Bool
pValid_
  UTCTime
pRegisteredAt_ =
    DescribeCrossAccountAccessRoleResponse'
      { $sel:httpStatus:DescribeCrossAccountAccessRoleResponse' :: Int
httpStatus =
          Int
pHttpStatus_,
        $sel:roleArn:DescribeCrossAccountAccessRoleResponse' :: Text
roleArn = Text
pRoleArn_,
        $sel:valid:DescribeCrossAccountAccessRoleResponse' :: Bool
valid = Bool
pValid_,
        $sel:registeredAt:DescribeCrossAccountAccessRoleResponse' :: POSIX
registeredAt =
          forall (a :: Format). Iso' (Time a) UTCTime
Data._Time forall t b. AReview t b -> b -> t
Lens.# UTCTime
pRegisteredAt_
      }

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

-- | The ARN that specifies the IAM role that Amazon Inspector uses to access
-- your AWS account.
describeCrossAccountAccessRoleResponse_roleArn :: Lens.Lens' DescribeCrossAccountAccessRoleResponse Prelude.Text
describeCrossAccountAccessRoleResponse_roleArn :: Lens' DescribeCrossAccountAccessRoleResponse Text
describeCrossAccountAccessRoleResponse_roleArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeCrossAccountAccessRoleResponse' {Text
roleArn :: Text
$sel:roleArn:DescribeCrossAccountAccessRoleResponse' :: DescribeCrossAccountAccessRoleResponse -> Text
roleArn} -> Text
roleArn) (\s :: DescribeCrossAccountAccessRoleResponse
s@DescribeCrossAccountAccessRoleResponse' {} Text
a -> DescribeCrossAccountAccessRoleResponse
s {$sel:roleArn:DescribeCrossAccountAccessRoleResponse' :: Text
roleArn = Text
a} :: DescribeCrossAccountAccessRoleResponse)

-- | A Boolean value that specifies whether the IAM role has the necessary
-- policies attached to enable Amazon Inspector to access your AWS account.
describeCrossAccountAccessRoleResponse_valid :: Lens.Lens' DescribeCrossAccountAccessRoleResponse Prelude.Bool
describeCrossAccountAccessRoleResponse_valid :: Lens' DescribeCrossAccountAccessRoleResponse Bool
describeCrossAccountAccessRoleResponse_valid = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeCrossAccountAccessRoleResponse' {Bool
valid :: Bool
$sel:valid:DescribeCrossAccountAccessRoleResponse' :: DescribeCrossAccountAccessRoleResponse -> Bool
valid} -> Bool
valid) (\s :: DescribeCrossAccountAccessRoleResponse
s@DescribeCrossAccountAccessRoleResponse' {} Bool
a -> DescribeCrossAccountAccessRoleResponse
s {$sel:valid:DescribeCrossAccountAccessRoleResponse' :: Bool
valid = Bool
a} :: DescribeCrossAccountAccessRoleResponse)

-- | The date when the cross-account access role was registered.
describeCrossAccountAccessRoleResponse_registeredAt :: Lens.Lens' DescribeCrossAccountAccessRoleResponse Prelude.UTCTime
describeCrossAccountAccessRoleResponse_registeredAt :: Lens' DescribeCrossAccountAccessRoleResponse UTCTime
describeCrossAccountAccessRoleResponse_registeredAt = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeCrossAccountAccessRoleResponse' {POSIX
registeredAt :: POSIX
$sel:registeredAt:DescribeCrossAccountAccessRoleResponse' :: DescribeCrossAccountAccessRoleResponse -> POSIX
registeredAt} -> POSIX
registeredAt) (\s :: DescribeCrossAccountAccessRoleResponse
s@DescribeCrossAccountAccessRoleResponse' {} POSIX
a -> DescribeCrossAccountAccessRoleResponse
s {$sel:registeredAt:DescribeCrossAccountAccessRoleResponse' :: POSIX
registeredAt = POSIX
a} :: DescribeCrossAccountAccessRoleResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (a :: Format). Iso' (Time a) UTCTime
Data._Time

instance
  Prelude.NFData
    DescribeCrossAccountAccessRoleResponse
  where
  rnf :: DescribeCrossAccountAccessRoleResponse -> ()
rnf DescribeCrossAccountAccessRoleResponse' {Bool
Int
Text
POSIX
registeredAt :: POSIX
valid :: Bool
roleArn :: Text
httpStatus :: Int
$sel:registeredAt:DescribeCrossAccountAccessRoleResponse' :: DescribeCrossAccountAccessRoleResponse -> POSIX
$sel:valid:DescribeCrossAccountAccessRoleResponse' :: DescribeCrossAccountAccessRoleResponse -> Bool
$sel:roleArn:DescribeCrossAccountAccessRoleResponse' :: DescribeCrossAccountAccessRoleResponse -> Text
$sel:httpStatus:DescribeCrossAccountAccessRoleResponse' :: DescribeCrossAccountAccessRoleResponse -> 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 Text
roleArn
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Bool
valid
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf POSIX
registeredAt