{-# 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.Glue.BatchDeleteTable
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Deletes multiple tables at once.
--
-- After completing this operation, you no longer have access to the table
-- versions and partitions that belong to the deleted table. Glue deletes
-- these \"orphaned\" resources asynchronously in a timely manner, at the
-- discretion of the service.
--
-- To ensure the immediate deletion of all related resources, before
-- calling @BatchDeleteTable@, use @DeleteTableVersion@ or
-- @BatchDeleteTableVersion@, and @DeletePartition@ or
-- @BatchDeletePartition@, to delete any resources that belong to the
-- table.
module Amazonka.Glue.BatchDeleteTable
  ( -- * Creating a Request
    BatchDeleteTable (..),
    newBatchDeleteTable,

    -- * Request Lenses
    batchDeleteTable_catalogId,
    batchDeleteTable_transactionId,
    batchDeleteTable_databaseName,
    batchDeleteTable_tablesToDelete,

    -- * Destructuring the Response
    BatchDeleteTableResponse (..),
    newBatchDeleteTableResponse,

    -- * Response Lenses
    batchDeleteTableResponse_errors,
    batchDeleteTableResponse_httpStatus,
  )
where

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

-- | /See:/ 'newBatchDeleteTable' smart constructor.
data BatchDeleteTable = BatchDeleteTable'
  { -- | The ID of the Data Catalog where the table resides. If none is provided,
    -- the Amazon Web Services account ID is used by default.
    BatchDeleteTable -> Maybe Text
catalogId :: Prelude.Maybe Prelude.Text,
    -- | The transaction ID at which to delete the table contents.
    BatchDeleteTable -> Maybe Text
transactionId :: Prelude.Maybe Prelude.Text,
    -- | The name of the catalog database in which the tables to delete reside.
    -- For Hive compatibility, this name is entirely lowercase.
    BatchDeleteTable -> Text
databaseName :: Prelude.Text,
    -- | A list of the table to delete.
    BatchDeleteTable -> [Text]
tablesToDelete :: [Prelude.Text]
  }
  deriving (BatchDeleteTable -> BatchDeleteTable -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: BatchDeleteTable -> BatchDeleteTable -> Bool
$c/= :: BatchDeleteTable -> BatchDeleteTable -> Bool
== :: BatchDeleteTable -> BatchDeleteTable -> Bool
$c== :: BatchDeleteTable -> BatchDeleteTable -> Bool
Prelude.Eq, ReadPrec [BatchDeleteTable]
ReadPrec BatchDeleteTable
Int -> ReadS BatchDeleteTable
ReadS [BatchDeleteTable]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [BatchDeleteTable]
$creadListPrec :: ReadPrec [BatchDeleteTable]
readPrec :: ReadPrec BatchDeleteTable
$creadPrec :: ReadPrec BatchDeleteTable
readList :: ReadS [BatchDeleteTable]
$creadList :: ReadS [BatchDeleteTable]
readsPrec :: Int -> ReadS BatchDeleteTable
$creadsPrec :: Int -> ReadS BatchDeleteTable
Prelude.Read, Int -> BatchDeleteTable -> ShowS
[BatchDeleteTable] -> ShowS
BatchDeleteTable -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [BatchDeleteTable] -> ShowS
$cshowList :: [BatchDeleteTable] -> ShowS
show :: BatchDeleteTable -> String
$cshow :: BatchDeleteTable -> String
showsPrec :: Int -> BatchDeleteTable -> ShowS
$cshowsPrec :: Int -> BatchDeleteTable -> ShowS
Prelude.Show, forall x. Rep BatchDeleteTable x -> BatchDeleteTable
forall x. BatchDeleteTable -> Rep BatchDeleteTable x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep BatchDeleteTable x -> BatchDeleteTable
$cfrom :: forall x. BatchDeleteTable -> Rep BatchDeleteTable x
Prelude.Generic)

-- |
-- Create a value of 'BatchDeleteTable' 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:
--
-- 'catalogId', 'batchDeleteTable_catalogId' - The ID of the Data Catalog where the table resides. If none is provided,
-- the Amazon Web Services account ID is used by default.
--
-- 'transactionId', 'batchDeleteTable_transactionId' - The transaction ID at which to delete the table contents.
--
-- 'databaseName', 'batchDeleteTable_databaseName' - The name of the catalog database in which the tables to delete reside.
-- For Hive compatibility, this name is entirely lowercase.
--
-- 'tablesToDelete', 'batchDeleteTable_tablesToDelete' - A list of the table to delete.
newBatchDeleteTable ::
  -- | 'databaseName'
  Prelude.Text ->
  BatchDeleteTable
newBatchDeleteTable :: Text -> BatchDeleteTable
newBatchDeleteTable Text
pDatabaseName_ =
  BatchDeleteTable'
    { $sel:catalogId:BatchDeleteTable' :: Maybe Text
catalogId = forall a. Maybe a
Prelude.Nothing,
      $sel:transactionId:BatchDeleteTable' :: Maybe Text
transactionId = forall a. Maybe a
Prelude.Nothing,
      $sel:databaseName:BatchDeleteTable' :: Text
databaseName = Text
pDatabaseName_,
      $sel:tablesToDelete:BatchDeleteTable' :: [Text]
tablesToDelete = forall a. Monoid a => a
Prelude.mempty
    }

-- | The ID of the Data Catalog where the table resides. If none is provided,
-- the Amazon Web Services account ID is used by default.
batchDeleteTable_catalogId :: Lens.Lens' BatchDeleteTable (Prelude.Maybe Prelude.Text)
batchDeleteTable_catalogId :: Lens' BatchDeleteTable (Maybe Text)
batchDeleteTable_catalogId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\BatchDeleteTable' {Maybe Text
catalogId :: Maybe Text
$sel:catalogId:BatchDeleteTable' :: BatchDeleteTable -> Maybe Text
catalogId} -> Maybe Text
catalogId) (\s :: BatchDeleteTable
s@BatchDeleteTable' {} Maybe Text
a -> BatchDeleteTable
s {$sel:catalogId:BatchDeleteTable' :: Maybe Text
catalogId = Maybe Text
a} :: BatchDeleteTable)

-- | The transaction ID at which to delete the table contents.
batchDeleteTable_transactionId :: Lens.Lens' BatchDeleteTable (Prelude.Maybe Prelude.Text)
batchDeleteTable_transactionId :: Lens' BatchDeleteTable (Maybe Text)
batchDeleteTable_transactionId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\BatchDeleteTable' {Maybe Text
transactionId :: Maybe Text
$sel:transactionId:BatchDeleteTable' :: BatchDeleteTable -> Maybe Text
transactionId} -> Maybe Text
transactionId) (\s :: BatchDeleteTable
s@BatchDeleteTable' {} Maybe Text
a -> BatchDeleteTable
s {$sel:transactionId:BatchDeleteTable' :: Maybe Text
transactionId = Maybe Text
a} :: BatchDeleteTable)

-- | The name of the catalog database in which the tables to delete reside.
-- For Hive compatibility, this name is entirely lowercase.
batchDeleteTable_databaseName :: Lens.Lens' BatchDeleteTable Prelude.Text
batchDeleteTable_databaseName :: Lens' BatchDeleteTable Text
batchDeleteTable_databaseName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\BatchDeleteTable' {Text
databaseName :: Text
$sel:databaseName:BatchDeleteTable' :: BatchDeleteTable -> Text
databaseName} -> Text
databaseName) (\s :: BatchDeleteTable
s@BatchDeleteTable' {} Text
a -> BatchDeleteTable
s {$sel:databaseName:BatchDeleteTable' :: Text
databaseName = Text
a} :: BatchDeleteTable)

-- | A list of the table to delete.
batchDeleteTable_tablesToDelete :: Lens.Lens' BatchDeleteTable [Prelude.Text]
batchDeleteTable_tablesToDelete :: Lens' BatchDeleteTable [Text]
batchDeleteTable_tablesToDelete = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\BatchDeleteTable' {[Text]
tablesToDelete :: [Text]
$sel:tablesToDelete:BatchDeleteTable' :: BatchDeleteTable -> [Text]
tablesToDelete} -> [Text]
tablesToDelete) (\s :: BatchDeleteTable
s@BatchDeleteTable' {} [Text]
a -> BatchDeleteTable
s {$sel:tablesToDelete:BatchDeleteTable' :: [Text]
tablesToDelete = [Text]
a} :: BatchDeleteTable) 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 BatchDeleteTable where
  type
    AWSResponse BatchDeleteTable =
      BatchDeleteTableResponse
  request :: (Service -> Service)
-> BatchDeleteTable -> Request BatchDeleteTable
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 BatchDeleteTable
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse BatchDeleteTable)))
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 [TableError] -> Int -> BatchDeleteTableResponse
BatchDeleteTableResponse'
            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
"Errors" 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.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance Prelude.Hashable BatchDeleteTable where
  hashWithSalt :: Int -> BatchDeleteTable -> Int
hashWithSalt Int
_salt BatchDeleteTable' {[Text]
Maybe Text
Text
tablesToDelete :: [Text]
databaseName :: Text
transactionId :: Maybe Text
catalogId :: Maybe Text
$sel:tablesToDelete:BatchDeleteTable' :: BatchDeleteTable -> [Text]
$sel:databaseName:BatchDeleteTable' :: BatchDeleteTable -> Text
$sel:transactionId:BatchDeleteTable' :: BatchDeleteTable -> Maybe Text
$sel:catalogId:BatchDeleteTable' :: BatchDeleteTable -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
catalogId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
transactionId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
databaseName
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
tablesToDelete

instance Prelude.NFData BatchDeleteTable where
  rnf :: BatchDeleteTable -> ()
rnf BatchDeleteTable' {[Text]
Maybe Text
Text
tablesToDelete :: [Text]
databaseName :: Text
transactionId :: Maybe Text
catalogId :: Maybe Text
$sel:tablesToDelete:BatchDeleteTable' :: BatchDeleteTable -> [Text]
$sel:databaseName:BatchDeleteTable' :: BatchDeleteTable -> Text
$sel:transactionId:BatchDeleteTable' :: BatchDeleteTable -> Maybe Text
$sel:catalogId:BatchDeleteTable' :: BatchDeleteTable -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
catalogId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
transactionId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
databaseName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [Text]
tablesToDelete

instance Data.ToHeaders BatchDeleteTable where
  toHeaders :: BatchDeleteTable -> 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
"AWSGlue.BatchDeleteTable" :: 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 BatchDeleteTable where
  toJSON :: BatchDeleteTable -> Value
toJSON BatchDeleteTable' {[Text]
Maybe Text
Text
tablesToDelete :: [Text]
databaseName :: Text
transactionId :: Maybe Text
catalogId :: Maybe Text
$sel:tablesToDelete:BatchDeleteTable' :: BatchDeleteTable -> [Text]
$sel:databaseName:BatchDeleteTable' :: BatchDeleteTable -> Text
$sel:transactionId:BatchDeleteTable' :: BatchDeleteTable -> Maybe Text
$sel:catalogId:BatchDeleteTable' :: BatchDeleteTable -> Maybe Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"CatalogId" 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
catalogId,
            (Key
"TransactionId" 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
transactionId,
            forall a. a -> Maybe a
Prelude.Just (Key
"DatabaseName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
databaseName),
            forall a. a -> Maybe a
Prelude.Just
              (Key
"TablesToDelete" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= [Text]
tablesToDelete)
          ]
      )

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

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

-- | /See:/ 'newBatchDeleteTableResponse' smart constructor.
data BatchDeleteTableResponse = BatchDeleteTableResponse'
  { -- | A list of errors encountered in attempting to delete the specified
    -- tables.
    BatchDeleteTableResponse -> Maybe [TableError]
errors :: Prelude.Maybe [TableError],
    -- | The response's http status code.
    BatchDeleteTableResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (BatchDeleteTableResponse -> BatchDeleteTableResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: BatchDeleteTableResponse -> BatchDeleteTableResponse -> Bool
$c/= :: BatchDeleteTableResponse -> BatchDeleteTableResponse -> Bool
== :: BatchDeleteTableResponse -> BatchDeleteTableResponse -> Bool
$c== :: BatchDeleteTableResponse -> BatchDeleteTableResponse -> Bool
Prelude.Eq, ReadPrec [BatchDeleteTableResponse]
ReadPrec BatchDeleteTableResponse
Int -> ReadS BatchDeleteTableResponse
ReadS [BatchDeleteTableResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [BatchDeleteTableResponse]
$creadListPrec :: ReadPrec [BatchDeleteTableResponse]
readPrec :: ReadPrec BatchDeleteTableResponse
$creadPrec :: ReadPrec BatchDeleteTableResponse
readList :: ReadS [BatchDeleteTableResponse]
$creadList :: ReadS [BatchDeleteTableResponse]
readsPrec :: Int -> ReadS BatchDeleteTableResponse
$creadsPrec :: Int -> ReadS BatchDeleteTableResponse
Prelude.Read, Int -> BatchDeleteTableResponse -> ShowS
[BatchDeleteTableResponse] -> ShowS
BatchDeleteTableResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [BatchDeleteTableResponse] -> ShowS
$cshowList :: [BatchDeleteTableResponse] -> ShowS
show :: BatchDeleteTableResponse -> String
$cshow :: BatchDeleteTableResponse -> String
showsPrec :: Int -> BatchDeleteTableResponse -> ShowS
$cshowsPrec :: Int -> BatchDeleteTableResponse -> ShowS
Prelude.Show, forall x.
Rep BatchDeleteTableResponse x -> BatchDeleteTableResponse
forall x.
BatchDeleteTableResponse -> Rep BatchDeleteTableResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep BatchDeleteTableResponse x -> BatchDeleteTableResponse
$cfrom :: forall x.
BatchDeleteTableResponse -> Rep BatchDeleteTableResponse x
Prelude.Generic)

-- |
-- Create a value of 'BatchDeleteTableResponse' 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:
--
-- 'errors', 'batchDeleteTableResponse_errors' - A list of errors encountered in attempting to delete the specified
-- tables.
--
-- 'httpStatus', 'batchDeleteTableResponse_httpStatus' - The response's http status code.
newBatchDeleteTableResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  BatchDeleteTableResponse
newBatchDeleteTableResponse :: Int -> BatchDeleteTableResponse
newBatchDeleteTableResponse Int
pHttpStatus_ =
  BatchDeleteTableResponse'
    { $sel:errors:BatchDeleteTableResponse' :: Maybe [TableError]
errors = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:BatchDeleteTableResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | A list of errors encountered in attempting to delete the specified
-- tables.
batchDeleteTableResponse_errors :: Lens.Lens' BatchDeleteTableResponse (Prelude.Maybe [TableError])
batchDeleteTableResponse_errors :: Lens' BatchDeleteTableResponse (Maybe [TableError])
batchDeleteTableResponse_errors = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\BatchDeleteTableResponse' {Maybe [TableError]
errors :: Maybe [TableError]
$sel:errors:BatchDeleteTableResponse' :: BatchDeleteTableResponse -> Maybe [TableError]
errors} -> Maybe [TableError]
errors) (\s :: BatchDeleteTableResponse
s@BatchDeleteTableResponse' {} Maybe [TableError]
a -> BatchDeleteTableResponse
s {$sel:errors:BatchDeleteTableResponse' :: Maybe [TableError]
errors = Maybe [TableError]
a} :: BatchDeleteTableResponse) 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.
batchDeleteTableResponse_httpStatus :: Lens.Lens' BatchDeleteTableResponse Prelude.Int
batchDeleteTableResponse_httpStatus :: Lens' BatchDeleteTableResponse Int
batchDeleteTableResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\BatchDeleteTableResponse' {Int
httpStatus :: Int
$sel:httpStatus:BatchDeleteTableResponse' :: BatchDeleteTableResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: BatchDeleteTableResponse
s@BatchDeleteTableResponse' {} Int
a -> BatchDeleteTableResponse
s {$sel:httpStatus:BatchDeleteTableResponse' :: Int
httpStatus = Int
a} :: BatchDeleteTableResponse)

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