{-# 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.EC2.DescribeSecurityGroupReferences
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- [VPC only] Describes the VPCs on the other side of a VPC peering
-- connection that are referencing the security groups you\'ve specified in
-- this request.
module Amazonka.EC2.DescribeSecurityGroupReferences
  ( -- * Creating a Request
    DescribeSecurityGroupReferences (..),
    newDescribeSecurityGroupReferences,

    -- * Request Lenses
    describeSecurityGroupReferences_dryRun,
    describeSecurityGroupReferences_groupId,

    -- * Destructuring the Response
    DescribeSecurityGroupReferencesResponse (..),
    newDescribeSecurityGroupReferencesResponse,

    -- * Response Lenses
    describeSecurityGroupReferencesResponse_securityGroupReferenceSet,
    describeSecurityGroupReferencesResponse_httpStatus,
  )
where

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

-- | /See:/ 'newDescribeSecurityGroupReferences' smart constructor.
data DescribeSecurityGroupReferences = DescribeSecurityGroupReferences'
  { -- | Checks whether you have the required permissions for the action, without
    -- actually making the request, and provides an error response. If you have
    -- the required permissions, the error response is @DryRunOperation@.
    -- Otherwise, it is @UnauthorizedOperation@.
    DescribeSecurityGroupReferences -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool,
    -- | The IDs of the security groups in your account.
    DescribeSecurityGroupReferences -> [Text]
groupId :: [Prelude.Text]
  }
  deriving (DescribeSecurityGroupReferences
-> DescribeSecurityGroupReferences -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeSecurityGroupReferences
-> DescribeSecurityGroupReferences -> Bool
$c/= :: DescribeSecurityGroupReferences
-> DescribeSecurityGroupReferences -> Bool
== :: DescribeSecurityGroupReferences
-> DescribeSecurityGroupReferences -> Bool
$c== :: DescribeSecurityGroupReferences
-> DescribeSecurityGroupReferences -> Bool
Prelude.Eq, ReadPrec [DescribeSecurityGroupReferences]
ReadPrec DescribeSecurityGroupReferences
Int -> ReadS DescribeSecurityGroupReferences
ReadS [DescribeSecurityGroupReferences]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeSecurityGroupReferences]
$creadListPrec :: ReadPrec [DescribeSecurityGroupReferences]
readPrec :: ReadPrec DescribeSecurityGroupReferences
$creadPrec :: ReadPrec DescribeSecurityGroupReferences
readList :: ReadS [DescribeSecurityGroupReferences]
$creadList :: ReadS [DescribeSecurityGroupReferences]
readsPrec :: Int -> ReadS DescribeSecurityGroupReferences
$creadsPrec :: Int -> ReadS DescribeSecurityGroupReferences
Prelude.Read, Int -> DescribeSecurityGroupReferences -> ShowS
[DescribeSecurityGroupReferences] -> ShowS
DescribeSecurityGroupReferences -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeSecurityGroupReferences] -> ShowS
$cshowList :: [DescribeSecurityGroupReferences] -> ShowS
show :: DescribeSecurityGroupReferences -> String
$cshow :: DescribeSecurityGroupReferences -> String
showsPrec :: Int -> DescribeSecurityGroupReferences -> ShowS
$cshowsPrec :: Int -> DescribeSecurityGroupReferences -> ShowS
Prelude.Show, forall x.
Rep DescribeSecurityGroupReferences x
-> DescribeSecurityGroupReferences
forall x.
DescribeSecurityGroupReferences
-> Rep DescribeSecurityGroupReferences x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeSecurityGroupReferences x
-> DescribeSecurityGroupReferences
$cfrom :: forall x.
DescribeSecurityGroupReferences
-> Rep DescribeSecurityGroupReferences x
Prelude.Generic)

-- |
-- Create a value of 'DescribeSecurityGroupReferences' 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:
--
-- 'dryRun', 'describeSecurityGroupReferences_dryRun' - Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
--
-- 'groupId', 'describeSecurityGroupReferences_groupId' - The IDs of the security groups in your account.
newDescribeSecurityGroupReferences ::
  DescribeSecurityGroupReferences
newDescribeSecurityGroupReferences :: DescribeSecurityGroupReferences
newDescribeSecurityGroupReferences =
  DescribeSecurityGroupReferences'
    { $sel:dryRun:DescribeSecurityGroupReferences' :: Maybe Bool
dryRun =
        forall a. Maybe a
Prelude.Nothing,
      $sel:groupId:DescribeSecurityGroupReferences' :: [Text]
groupId = forall a. Monoid a => a
Prelude.mempty
    }

-- | Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
describeSecurityGroupReferences_dryRun :: Lens.Lens' DescribeSecurityGroupReferences (Prelude.Maybe Prelude.Bool)
describeSecurityGroupReferences_dryRun :: Lens' DescribeSecurityGroupReferences (Maybe Bool)
describeSecurityGroupReferences_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSecurityGroupReferences' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:DescribeSecurityGroupReferences' :: DescribeSecurityGroupReferences -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: DescribeSecurityGroupReferences
s@DescribeSecurityGroupReferences' {} Maybe Bool
a -> DescribeSecurityGroupReferences
s {$sel:dryRun:DescribeSecurityGroupReferences' :: Maybe Bool
dryRun = Maybe Bool
a} :: DescribeSecurityGroupReferences)

-- | The IDs of the security groups in your account.
describeSecurityGroupReferences_groupId :: Lens.Lens' DescribeSecurityGroupReferences [Prelude.Text]
describeSecurityGroupReferences_groupId :: Lens' DescribeSecurityGroupReferences [Text]
describeSecurityGroupReferences_groupId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSecurityGroupReferences' {[Text]
groupId :: [Text]
$sel:groupId:DescribeSecurityGroupReferences' :: DescribeSecurityGroupReferences -> [Text]
groupId} -> [Text]
groupId) (\s :: DescribeSecurityGroupReferences
s@DescribeSecurityGroupReferences' {} [Text]
a -> DescribeSecurityGroupReferences
s {$sel:groupId:DescribeSecurityGroupReferences' :: [Text]
groupId = [Text]
a} :: DescribeSecurityGroupReferences) 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
    DescribeSecurityGroupReferences
  where
  type
    AWSResponse DescribeSecurityGroupReferences =
      DescribeSecurityGroupReferencesResponse
  request :: (Service -> Service)
-> DescribeSecurityGroupReferences
-> Request DescribeSecurityGroupReferences
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeSecurityGroupReferences
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse (AWSResponse DescribeSecurityGroupReferences)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe [SecurityGroupReference]
-> Int -> DescribeSecurityGroupReferencesResponse
DescribeSecurityGroupReferencesResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ( [Node]
x
                            forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"securityGroupReferenceSet"
                            forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
                            forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= forall (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"item")
                        )
            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
    DescribeSecurityGroupReferences
  where
  hashWithSalt :: Int -> DescribeSecurityGroupReferences -> Int
hashWithSalt
    Int
_salt
    DescribeSecurityGroupReferences' {[Text]
Maybe Bool
groupId :: [Text]
dryRun :: Maybe Bool
$sel:groupId:DescribeSecurityGroupReferences' :: DescribeSecurityGroupReferences -> [Text]
$sel:dryRun:DescribeSecurityGroupReferences' :: DescribeSecurityGroupReferences -> Maybe Bool
..} =
      Int
_salt
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
groupId

instance
  Prelude.NFData
    DescribeSecurityGroupReferences
  where
  rnf :: DescribeSecurityGroupReferences -> ()
rnf DescribeSecurityGroupReferences' {[Text]
Maybe Bool
groupId :: [Text]
dryRun :: Maybe Bool
$sel:groupId:DescribeSecurityGroupReferences' :: DescribeSecurityGroupReferences -> [Text]
$sel:dryRun:DescribeSecurityGroupReferences' :: DescribeSecurityGroupReferences -> Maybe Bool
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
dryRun
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [Text]
groupId

instance
  Data.ToHeaders
    DescribeSecurityGroupReferences
  where
  toHeaders :: DescribeSecurityGroupReferences -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

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

instance Data.ToQuery DescribeSecurityGroupReferences where
  toQuery :: DescribeSecurityGroupReferences -> QueryString
toQuery DescribeSecurityGroupReferences' {[Text]
Maybe Bool
groupId :: [Text]
dryRun :: Maybe Bool
$sel:groupId:DescribeSecurityGroupReferences' :: DescribeSecurityGroupReferences -> [Text]
$sel:dryRun:DescribeSecurityGroupReferences' :: DescribeSecurityGroupReferences -> Maybe Bool
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: ( ByteString
"DescribeSecurityGroupReferences" ::
                      Prelude.ByteString
                  ),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
        ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun,
        forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"GroupId" [Text]
groupId
      ]

-- | /See:/ 'newDescribeSecurityGroupReferencesResponse' smart constructor.
data DescribeSecurityGroupReferencesResponse = DescribeSecurityGroupReferencesResponse'
  { -- | Information about the VPCs with the referencing security groups.
    DescribeSecurityGroupReferencesResponse
-> Maybe [SecurityGroupReference]
securityGroupReferenceSet :: Prelude.Maybe [SecurityGroupReference],
    -- | The response's http status code.
    DescribeSecurityGroupReferencesResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeSecurityGroupReferencesResponse
-> DescribeSecurityGroupReferencesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeSecurityGroupReferencesResponse
-> DescribeSecurityGroupReferencesResponse -> Bool
$c/= :: DescribeSecurityGroupReferencesResponse
-> DescribeSecurityGroupReferencesResponse -> Bool
== :: DescribeSecurityGroupReferencesResponse
-> DescribeSecurityGroupReferencesResponse -> Bool
$c== :: DescribeSecurityGroupReferencesResponse
-> DescribeSecurityGroupReferencesResponse -> Bool
Prelude.Eq, ReadPrec [DescribeSecurityGroupReferencesResponse]
ReadPrec DescribeSecurityGroupReferencesResponse
Int -> ReadS DescribeSecurityGroupReferencesResponse
ReadS [DescribeSecurityGroupReferencesResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeSecurityGroupReferencesResponse]
$creadListPrec :: ReadPrec [DescribeSecurityGroupReferencesResponse]
readPrec :: ReadPrec DescribeSecurityGroupReferencesResponse
$creadPrec :: ReadPrec DescribeSecurityGroupReferencesResponse
readList :: ReadS [DescribeSecurityGroupReferencesResponse]
$creadList :: ReadS [DescribeSecurityGroupReferencesResponse]
readsPrec :: Int -> ReadS DescribeSecurityGroupReferencesResponse
$creadsPrec :: Int -> ReadS DescribeSecurityGroupReferencesResponse
Prelude.Read, Int -> DescribeSecurityGroupReferencesResponse -> ShowS
[DescribeSecurityGroupReferencesResponse] -> ShowS
DescribeSecurityGroupReferencesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeSecurityGroupReferencesResponse] -> ShowS
$cshowList :: [DescribeSecurityGroupReferencesResponse] -> ShowS
show :: DescribeSecurityGroupReferencesResponse -> String
$cshow :: DescribeSecurityGroupReferencesResponse -> String
showsPrec :: Int -> DescribeSecurityGroupReferencesResponse -> ShowS
$cshowsPrec :: Int -> DescribeSecurityGroupReferencesResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeSecurityGroupReferencesResponse x
-> DescribeSecurityGroupReferencesResponse
forall x.
DescribeSecurityGroupReferencesResponse
-> Rep DescribeSecurityGroupReferencesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeSecurityGroupReferencesResponse x
-> DescribeSecurityGroupReferencesResponse
$cfrom :: forall x.
DescribeSecurityGroupReferencesResponse
-> Rep DescribeSecurityGroupReferencesResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeSecurityGroupReferencesResponse' 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:
--
-- 'securityGroupReferenceSet', 'describeSecurityGroupReferencesResponse_securityGroupReferenceSet' - Information about the VPCs with the referencing security groups.
--
-- 'httpStatus', 'describeSecurityGroupReferencesResponse_httpStatus' - The response's http status code.
newDescribeSecurityGroupReferencesResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeSecurityGroupReferencesResponse
newDescribeSecurityGroupReferencesResponse :: Int -> DescribeSecurityGroupReferencesResponse
newDescribeSecurityGroupReferencesResponse
  Int
pHttpStatus_ =
    DescribeSecurityGroupReferencesResponse'
      { $sel:securityGroupReferenceSet:DescribeSecurityGroupReferencesResponse' :: Maybe [SecurityGroupReference]
securityGroupReferenceSet =
          forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:DescribeSecurityGroupReferencesResponse' :: Int
httpStatus = Int
pHttpStatus_
      }

-- | Information about the VPCs with the referencing security groups.
describeSecurityGroupReferencesResponse_securityGroupReferenceSet :: Lens.Lens' DescribeSecurityGroupReferencesResponse (Prelude.Maybe [SecurityGroupReference])
describeSecurityGroupReferencesResponse_securityGroupReferenceSet :: Lens'
  DescribeSecurityGroupReferencesResponse
  (Maybe [SecurityGroupReference])
describeSecurityGroupReferencesResponse_securityGroupReferenceSet = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSecurityGroupReferencesResponse' {Maybe [SecurityGroupReference]
securityGroupReferenceSet :: Maybe [SecurityGroupReference]
$sel:securityGroupReferenceSet:DescribeSecurityGroupReferencesResponse' :: DescribeSecurityGroupReferencesResponse
-> Maybe [SecurityGroupReference]
securityGroupReferenceSet} -> Maybe [SecurityGroupReference]
securityGroupReferenceSet) (\s :: DescribeSecurityGroupReferencesResponse
s@DescribeSecurityGroupReferencesResponse' {} Maybe [SecurityGroupReference]
a -> DescribeSecurityGroupReferencesResponse
s {$sel:securityGroupReferenceSet:DescribeSecurityGroupReferencesResponse' :: Maybe [SecurityGroupReference]
securityGroupReferenceSet = Maybe [SecurityGroupReference]
a} :: DescribeSecurityGroupReferencesResponse) 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 response's http status code.
describeSecurityGroupReferencesResponse_httpStatus :: Lens.Lens' DescribeSecurityGroupReferencesResponse Prelude.Int
describeSecurityGroupReferencesResponse_httpStatus :: Lens' DescribeSecurityGroupReferencesResponse Int
describeSecurityGroupReferencesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSecurityGroupReferencesResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeSecurityGroupReferencesResponse' :: DescribeSecurityGroupReferencesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeSecurityGroupReferencesResponse
s@DescribeSecurityGroupReferencesResponse' {} Int
a -> DescribeSecurityGroupReferencesResponse
s {$sel:httpStatus:DescribeSecurityGroupReferencesResponse' :: Int
httpStatus = Int
a} :: DescribeSecurityGroupReferencesResponse)

instance
  Prelude.NFData
    DescribeSecurityGroupReferencesResponse
  where
  rnf :: DescribeSecurityGroupReferencesResponse -> ()
rnf DescribeSecurityGroupReferencesResponse' {Int
Maybe [SecurityGroupReference]
httpStatus :: Int
securityGroupReferenceSet :: Maybe [SecurityGroupReference]
$sel:httpStatus:DescribeSecurityGroupReferencesResponse' :: DescribeSecurityGroupReferencesResponse -> Int
$sel:securityGroupReferenceSet:DescribeSecurityGroupReferencesResponse' :: DescribeSecurityGroupReferencesResponse
-> Maybe [SecurityGroupReference]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [SecurityGroupReference]
securityGroupReferenceSet
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus