{-# 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.NetworkFirewall.DescribeFirewall
-- 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 data objects for the specified firewall.
module Amazonka.NetworkFirewall.DescribeFirewall
  ( -- * Creating a Request
    DescribeFirewall (..),
    newDescribeFirewall,

    -- * Request Lenses
    describeFirewall_firewallArn,
    describeFirewall_firewallName,

    -- * Destructuring the Response
    DescribeFirewallResponse (..),
    newDescribeFirewallResponse,

    -- * Response Lenses
    describeFirewallResponse_firewall,
    describeFirewallResponse_firewallStatus,
    describeFirewallResponse_updateToken,
    describeFirewallResponse_httpStatus,
  )
where

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

-- | /See:/ 'newDescribeFirewall' smart constructor.
data DescribeFirewall = DescribeFirewall'
  { -- | The Amazon Resource Name (ARN) of the firewall.
    --
    -- You must specify the ARN or the name, and you can specify both.
    DescribeFirewall -> Maybe Text
firewallArn :: Prelude.Maybe Prelude.Text,
    -- | The descriptive name of the firewall. You can\'t change the name of a
    -- firewall after you create it.
    --
    -- You must specify the ARN or the name, and you can specify both.
    DescribeFirewall -> Maybe Text
firewallName :: Prelude.Maybe Prelude.Text
  }
  deriving (DescribeFirewall -> DescribeFirewall -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeFirewall -> DescribeFirewall -> Bool
$c/= :: DescribeFirewall -> DescribeFirewall -> Bool
== :: DescribeFirewall -> DescribeFirewall -> Bool
$c== :: DescribeFirewall -> DescribeFirewall -> Bool
Prelude.Eq, ReadPrec [DescribeFirewall]
ReadPrec DescribeFirewall
Int -> ReadS DescribeFirewall
ReadS [DescribeFirewall]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeFirewall]
$creadListPrec :: ReadPrec [DescribeFirewall]
readPrec :: ReadPrec DescribeFirewall
$creadPrec :: ReadPrec DescribeFirewall
readList :: ReadS [DescribeFirewall]
$creadList :: ReadS [DescribeFirewall]
readsPrec :: Int -> ReadS DescribeFirewall
$creadsPrec :: Int -> ReadS DescribeFirewall
Prelude.Read, Int -> DescribeFirewall -> ShowS
[DescribeFirewall] -> ShowS
DescribeFirewall -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeFirewall] -> ShowS
$cshowList :: [DescribeFirewall] -> ShowS
show :: DescribeFirewall -> String
$cshow :: DescribeFirewall -> String
showsPrec :: Int -> DescribeFirewall -> ShowS
$cshowsPrec :: Int -> DescribeFirewall -> ShowS
Prelude.Show, forall x. Rep DescribeFirewall x -> DescribeFirewall
forall x. DescribeFirewall -> Rep DescribeFirewall x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeFirewall x -> DescribeFirewall
$cfrom :: forall x. DescribeFirewall -> Rep DescribeFirewall x
Prelude.Generic)

-- |
-- Create a value of 'DescribeFirewall' 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:
--
-- 'firewallArn', 'describeFirewall_firewallArn' - The Amazon Resource Name (ARN) of the firewall.
--
-- You must specify the ARN or the name, and you can specify both.
--
-- 'firewallName', 'describeFirewall_firewallName' - The descriptive name of the firewall. You can\'t change the name of a
-- firewall after you create it.
--
-- You must specify the ARN or the name, and you can specify both.
newDescribeFirewall ::
  DescribeFirewall
newDescribeFirewall :: DescribeFirewall
newDescribeFirewall =
  DescribeFirewall'
    { $sel:firewallArn:DescribeFirewall' :: Maybe Text
firewallArn = forall a. Maybe a
Prelude.Nothing,
      $sel:firewallName:DescribeFirewall' :: Maybe Text
firewallName = forall a. Maybe a
Prelude.Nothing
    }

-- | The Amazon Resource Name (ARN) of the firewall.
--
-- You must specify the ARN or the name, and you can specify both.
describeFirewall_firewallArn :: Lens.Lens' DescribeFirewall (Prelude.Maybe Prelude.Text)
describeFirewall_firewallArn :: Lens' DescribeFirewall (Maybe Text)
describeFirewall_firewallArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFirewall' {Maybe Text
firewallArn :: Maybe Text
$sel:firewallArn:DescribeFirewall' :: DescribeFirewall -> Maybe Text
firewallArn} -> Maybe Text
firewallArn) (\s :: DescribeFirewall
s@DescribeFirewall' {} Maybe Text
a -> DescribeFirewall
s {$sel:firewallArn:DescribeFirewall' :: Maybe Text
firewallArn = Maybe Text
a} :: DescribeFirewall)

-- | The descriptive name of the firewall. You can\'t change the name of a
-- firewall after you create it.
--
-- You must specify the ARN or the name, and you can specify both.
describeFirewall_firewallName :: Lens.Lens' DescribeFirewall (Prelude.Maybe Prelude.Text)
describeFirewall_firewallName :: Lens' DescribeFirewall (Maybe Text)
describeFirewall_firewallName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFirewall' {Maybe Text
firewallName :: Maybe Text
$sel:firewallName:DescribeFirewall' :: DescribeFirewall -> Maybe Text
firewallName} -> Maybe Text
firewallName) (\s :: DescribeFirewall
s@DescribeFirewall' {} Maybe Text
a -> DescribeFirewall
s {$sel:firewallName:DescribeFirewall' :: Maybe Text
firewallName = Maybe Text
a} :: DescribeFirewall)

instance Core.AWSRequest DescribeFirewall where
  type
    AWSResponse DescribeFirewall =
      DescribeFirewallResponse
  request :: (Service -> Service)
-> DescribeFirewall -> Request DescribeFirewall
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 DescribeFirewall
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeFirewall)))
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 Firewall
-> Maybe FirewallStatus
-> Maybe Text
-> Int
-> DescribeFirewallResponse
DescribeFirewallResponse'
            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
"Firewall")
            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
"FirewallStatus")
            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
"UpdateToken")
            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 DescribeFirewall where
  hashWithSalt :: Int -> DescribeFirewall -> Int
hashWithSalt Int
_salt DescribeFirewall' {Maybe Text
firewallName :: Maybe Text
firewallArn :: Maybe Text
$sel:firewallName:DescribeFirewall' :: DescribeFirewall -> Maybe Text
$sel:firewallArn:DescribeFirewall' :: DescribeFirewall -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
firewallArn
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
firewallName

instance Prelude.NFData DescribeFirewall where
  rnf :: DescribeFirewall -> ()
rnf DescribeFirewall' {Maybe Text
firewallName :: Maybe Text
firewallArn :: Maybe Text
$sel:firewallName:DescribeFirewall' :: DescribeFirewall -> Maybe Text
$sel:firewallArn:DescribeFirewall' :: DescribeFirewall -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
firewallArn
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
firewallName

instance Data.ToHeaders DescribeFirewall where
  toHeaders :: DescribeFirewall -> 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
"NetworkFirewall_20201112.DescribeFirewall" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.0" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON DescribeFirewall where
  toJSON :: DescribeFirewall -> Value
toJSON DescribeFirewall' {Maybe Text
firewallName :: Maybe Text
firewallArn :: Maybe Text
$sel:firewallName:DescribeFirewall' :: DescribeFirewall -> Maybe Text
$sel:firewallArn:DescribeFirewall' :: DescribeFirewall -> Maybe Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"FirewallArn" 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
firewallArn,
            (Key
"FirewallName" 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
firewallName
          ]
      )

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

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

-- | /See:/ 'newDescribeFirewallResponse' smart constructor.
data DescribeFirewallResponse = DescribeFirewallResponse'
  { -- | The configuration settings for the firewall. These settings include the
    -- firewall policy and the subnets in your VPC to use for the firewall
    -- endpoints.
    DescribeFirewallResponse -> Maybe Firewall
firewall :: Prelude.Maybe Firewall,
    -- | Detailed information about the current status of a Firewall. You can
    -- retrieve this for a firewall by calling DescribeFirewall and providing
    -- the firewall name and ARN.
    DescribeFirewallResponse -> Maybe FirewallStatus
firewallStatus :: Prelude.Maybe FirewallStatus,
    -- | An optional token that you can use for optimistic locking. Network
    -- Firewall returns a token to your requests that access the firewall. The
    -- token marks the state of the firewall resource at the time of the
    -- request.
    --
    -- To make an unconditional change to the firewall, omit the token in your
    -- update request. Without the token, Network Firewall performs your
    -- updates regardless of whether the firewall has changed since you last
    -- retrieved it.
    --
    -- To make a conditional change to the firewall, provide the token in your
    -- update request. Network Firewall uses the token to ensure that the
    -- firewall hasn\'t changed since you last retrieved it. If it has changed,
    -- the operation fails with an @InvalidTokenException@. If this happens,
    -- retrieve the firewall again to get a current copy of it with a new
    -- token. Reapply your changes as needed, then try the operation again
    -- using the new token.
    DescribeFirewallResponse -> Maybe Text
updateToken :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    DescribeFirewallResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeFirewallResponse -> DescribeFirewallResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeFirewallResponse -> DescribeFirewallResponse -> Bool
$c/= :: DescribeFirewallResponse -> DescribeFirewallResponse -> Bool
== :: DescribeFirewallResponse -> DescribeFirewallResponse -> Bool
$c== :: DescribeFirewallResponse -> DescribeFirewallResponse -> Bool
Prelude.Eq, ReadPrec [DescribeFirewallResponse]
ReadPrec DescribeFirewallResponse
Int -> ReadS DescribeFirewallResponse
ReadS [DescribeFirewallResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeFirewallResponse]
$creadListPrec :: ReadPrec [DescribeFirewallResponse]
readPrec :: ReadPrec DescribeFirewallResponse
$creadPrec :: ReadPrec DescribeFirewallResponse
readList :: ReadS [DescribeFirewallResponse]
$creadList :: ReadS [DescribeFirewallResponse]
readsPrec :: Int -> ReadS DescribeFirewallResponse
$creadsPrec :: Int -> ReadS DescribeFirewallResponse
Prelude.Read, Int -> DescribeFirewallResponse -> ShowS
[DescribeFirewallResponse] -> ShowS
DescribeFirewallResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeFirewallResponse] -> ShowS
$cshowList :: [DescribeFirewallResponse] -> ShowS
show :: DescribeFirewallResponse -> String
$cshow :: DescribeFirewallResponse -> String
showsPrec :: Int -> DescribeFirewallResponse -> ShowS
$cshowsPrec :: Int -> DescribeFirewallResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeFirewallResponse x -> DescribeFirewallResponse
forall x.
DescribeFirewallResponse -> Rep DescribeFirewallResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeFirewallResponse x -> DescribeFirewallResponse
$cfrom :: forall x.
DescribeFirewallResponse -> Rep DescribeFirewallResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeFirewallResponse' 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:
--
-- 'firewall', 'describeFirewallResponse_firewall' - The configuration settings for the firewall. These settings include the
-- firewall policy and the subnets in your VPC to use for the firewall
-- endpoints.
--
-- 'firewallStatus', 'describeFirewallResponse_firewallStatus' - Detailed information about the current status of a Firewall. You can
-- retrieve this for a firewall by calling DescribeFirewall and providing
-- the firewall name and ARN.
--
-- 'updateToken', 'describeFirewallResponse_updateToken' - An optional token that you can use for optimistic locking. Network
-- Firewall returns a token to your requests that access the firewall. The
-- token marks the state of the firewall resource at the time of the
-- request.
--
-- To make an unconditional change to the firewall, omit the token in your
-- update request. Without the token, Network Firewall performs your
-- updates regardless of whether the firewall has changed since you last
-- retrieved it.
--
-- To make a conditional change to the firewall, provide the token in your
-- update request. Network Firewall uses the token to ensure that the
-- firewall hasn\'t changed since you last retrieved it. If it has changed,
-- the operation fails with an @InvalidTokenException@. If this happens,
-- retrieve the firewall again to get a current copy of it with a new
-- token. Reapply your changes as needed, then try the operation again
-- using the new token.
--
-- 'httpStatus', 'describeFirewallResponse_httpStatus' - The response's http status code.
newDescribeFirewallResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeFirewallResponse
newDescribeFirewallResponse :: Int -> DescribeFirewallResponse
newDescribeFirewallResponse Int
pHttpStatus_ =
  DescribeFirewallResponse'
    { $sel:firewall:DescribeFirewallResponse' :: Maybe Firewall
firewall =
        forall a. Maybe a
Prelude.Nothing,
      $sel:firewallStatus:DescribeFirewallResponse' :: Maybe FirewallStatus
firewallStatus = forall a. Maybe a
Prelude.Nothing,
      $sel:updateToken:DescribeFirewallResponse' :: Maybe Text
updateToken = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeFirewallResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The configuration settings for the firewall. These settings include the
-- firewall policy and the subnets in your VPC to use for the firewall
-- endpoints.
describeFirewallResponse_firewall :: Lens.Lens' DescribeFirewallResponse (Prelude.Maybe Firewall)
describeFirewallResponse_firewall :: Lens' DescribeFirewallResponse (Maybe Firewall)
describeFirewallResponse_firewall = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFirewallResponse' {Maybe Firewall
firewall :: Maybe Firewall
$sel:firewall:DescribeFirewallResponse' :: DescribeFirewallResponse -> Maybe Firewall
firewall} -> Maybe Firewall
firewall) (\s :: DescribeFirewallResponse
s@DescribeFirewallResponse' {} Maybe Firewall
a -> DescribeFirewallResponse
s {$sel:firewall:DescribeFirewallResponse' :: Maybe Firewall
firewall = Maybe Firewall
a} :: DescribeFirewallResponse)

-- | Detailed information about the current status of a Firewall. You can
-- retrieve this for a firewall by calling DescribeFirewall and providing
-- the firewall name and ARN.
describeFirewallResponse_firewallStatus :: Lens.Lens' DescribeFirewallResponse (Prelude.Maybe FirewallStatus)
describeFirewallResponse_firewallStatus :: Lens' DescribeFirewallResponse (Maybe FirewallStatus)
describeFirewallResponse_firewallStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFirewallResponse' {Maybe FirewallStatus
firewallStatus :: Maybe FirewallStatus
$sel:firewallStatus:DescribeFirewallResponse' :: DescribeFirewallResponse -> Maybe FirewallStatus
firewallStatus} -> Maybe FirewallStatus
firewallStatus) (\s :: DescribeFirewallResponse
s@DescribeFirewallResponse' {} Maybe FirewallStatus
a -> DescribeFirewallResponse
s {$sel:firewallStatus:DescribeFirewallResponse' :: Maybe FirewallStatus
firewallStatus = Maybe FirewallStatus
a} :: DescribeFirewallResponse)

-- | An optional token that you can use for optimistic locking. Network
-- Firewall returns a token to your requests that access the firewall. The
-- token marks the state of the firewall resource at the time of the
-- request.
--
-- To make an unconditional change to the firewall, omit the token in your
-- update request. Without the token, Network Firewall performs your
-- updates regardless of whether the firewall has changed since you last
-- retrieved it.
--
-- To make a conditional change to the firewall, provide the token in your
-- update request. Network Firewall uses the token to ensure that the
-- firewall hasn\'t changed since you last retrieved it. If it has changed,
-- the operation fails with an @InvalidTokenException@. If this happens,
-- retrieve the firewall again to get a current copy of it with a new
-- token. Reapply your changes as needed, then try the operation again
-- using the new token.
describeFirewallResponse_updateToken :: Lens.Lens' DescribeFirewallResponse (Prelude.Maybe Prelude.Text)
describeFirewallResponse_updateToken :: Lens' DescribeFirewallResponse (Maybe Text)
describeFirewallResponse_updateToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFirewallResponse' {Maybe Text
updateToken :: Maybe Text
$sel:updateToken:DescribeFirewallResponse' :: DescribeFirewallResponse -> Maybe Text
updateToken} -> Maybe Text
updateToken) (\s :: DescribeFirewallResponse
s@DescribeFirewallResponse' {} Maybe Text
a -> DescribeFirewallResponse
s {$sel:updateToken:DescribeFirewallResponse' :: Maybe Text
updateToken = Maybe Text
a} :: DescribeFirewallResponse)

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

instance Prelude.NFData DescribeFirewallResponse where
  rnf :: DescribeFirewallResponse -> ()
rnf DescribeFirewallResponse' {Int
Maybe Text
Maybe FirewallStatus
Maybe Firewall
httpStatus :: Int
updateToken :: Maybe Text
firewallStatus :: Maybe FirewallStatus
firewall :: Maybe Firewall
$sel:httpStatus:DescribeFirewallResponse' :: DescribeFirewallResponse -> Int
$sel:updateToken:DescribeFirewallResponse' :: DescribeFirewallResponse -> Maybe Text
$sel:firewallStatus:DescribeFirewallResponse' :: DescribeFirewallResponse -> Maybe FirewallStatus
$sel:firewall:DescribeFirewallResponse' :: DescribeFirewallResponse -> Maybe Firewall
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Firewall
firewall
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe FirewallStatus
firewallStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
updateToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus