{-# 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 #-}
module Amazonka.LakeFormation.CommitTransaction
(
CommitTransaction (..),
newCommitTransaction,
commitTransaction_transactionId,
CommitTransactionResponse (..),
newCommitTransactionResponse,
commitTransactionResponse_transactionStatus,
commitTransactionResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.LakeFormation.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data CommitTransaction = CommitTransaction'
{
CommitTransaction -> Text
transactionId :: Prelude.Text
}
deriving (CommitTransaction -> CommitTransaction -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CommitTransaction -> CommitTransaction -> Bool
$c/= :: CommitTransaction -> CommitTransaction -> Bool
== :: CommitTransaction -> CommitTransaction -> Bool
$c== :: CommitTransaction -> CommitTransaction -> Bool
Prelude.Eq, ReadPrec [CommitTransaction]
ReadPrec CommitTransaction
Int -> ReadS CommitTransaction
ReadS [CommitTransaction]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CommitTransaction]
$creadListPrec :: ReadPrec [CommitTransaction]
readPrec :: ReadPrec CommitTransaction
$creadPrec :: ReadPrec CommitTransaction
readList :: ReadS [CommitTransaction]
$creadList :: ReadS [CommitTransaction]
readsPrec :: Int -> ReadS CommitTransaction
$creadsPrec :: Int -> ReadS CommitTransaction
Prelude.Read, Int -> CommitTransaction -> ShowS
[CommitTransaction] -> ShowS
CommitTransaction -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CommitTransaction] -> ShowS
$cshowList :: [CommitTransaction] -> ShowS
show :: CommitTransaction -> String
$cshow :: CommitTransaction -> String
showsPrec :: Int -> CommitTransaction -> ShowS
$cshowsPrec :: Int -> CommitTransaction -> ShowS
Prelude.Show, forall x. Rep CommitTransaction x -> CommitTransaction
forall x. CommitTransaction -> Rep CommitTransaction x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CommitTransaction x -> CommitTransaction
$cfrom :: forall x. CommitTransaction -> Rep CommitTransaction x
Prelude.Generic)
newCommitTransaction ::
Prelude.Text ->
CommitTransaction
newCommitTransaction :: Text -> CommitTransaction
newCommitTransaction Text
pTransactionId_ =
CommitTransaction' {$sel:transactionId:CommitTransaction' :: Text
transactionId = Text
pTransactionId_}
commitTransaction_transactionId :: Lens.Lens' CommitTransaction Prelude.Text
commitTransaction_transactionId :: Lens' CommitTransaction Text
commitTransaction_transactionId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CommitTransaction' {Text
transactionId :: Text
$sel:transactionId:CommitTransaction' :: CommitTransaction -> Text
transactionId} -> Text
transactionId) (\s :: CommitTransaction
s@CommitTransaction' {} Text
a -> CommitTransaction
s {$sel:transactionId:CommitTransaction' :: Text
transactionId = Text
a} :: CommitTransaction)
instance Core.AWSRequest CommitTransaction where
type
AWSResponse CommitTransaction =
CommitTransactionResponse
request :: (Service -> Service)
-> CommitTransaction -> Request CommitTransaction
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 CommitTransaction
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse CommitTransaction)))
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 TransactionStatus -> Int -> CommitTransactionResponse
CommitTransactionResponse'
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
"TransactionStatus")
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 CommitTransaction where
hashWithSalt :: Int -> CommitTransaction -> Int
hashWithSalt Int
_salt CommitTransaction' {Text
transactionId :: Text
$sel:transactionId:CommitTransaction' :: CommitTransaction -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
transactionId
instance Prelude.NFData CommitTransaction where
rnf :: CommitTransaction -> ()
rnf CommitTransaction' {Text
transactionId :: Text
$sel:transactionId:CommitTransaction' :: CommitTransaction -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
transactionId
instance Data.ToHeaders CommitTransaction where
toHeaders :: CommitTransaction -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON CommitTransaction where
toJSON :: CommitTransaction -> Value
toJSON CommitTransaction' {Text
transactionId :: Text
$sel:transactionId:CommitTransaction' :: CommitTransaction -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just
(Key
"TransactionId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
transactionId)
]
)
instance Data.ToPath CommitTransaction where
toPath :: CommitTransaction -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/CommitTransaction"
instance Data.ToQuery CommitTransaction where
toQuery :: CommitTransaction -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data CommitTransactionResponse = CommitTransactionResponse'
{
CommitTransactionResponse -> Maybe TransactionStatus
transactionStatus :: Prelude.Maybe TransactionStatus,
CommitTransactionResponse -> Int
httpStatus :: Prelude.Int
}
deriving (CommitTransactionResponse -> CommitTransactionResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CommitTransactionResponse -> CommitTransactionResponse -> Bool
$c/= :: CommitTransactionResponse -> CommitTransactionResponse -> Bool
== :: CommitTransactionResponse -> CommitTransactionResponse -> Bool
$c== :: CommitTransactionResponse -> CommitTransactionResponse -> Bool
Prelude.Eq, ReadPrec [CommitTransactionResponse]
ReadPrec CommitTransactionResponse
Int -> ReadS CommitTransactionResponse
ReadS [CommitTransactionResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CommitTransactionResponse]
$creadListPrec :: ReadPrec [CommitTransactionResponse]
readPrec :: ReadPrec CommitTransactionResponse
$creadPrec :: ReadPrec CommitTransactionResponse
readList :: ReadS [CommitTransactionResponse]
$creadList :: ReadS [CommitTransactionResponse]
readsPrec :: Int -> ReadS CommitTransactionResponse
$creadsPrec :: Int -> ReadS CommitTransactionResponse
Prelude.Read, Int -> CommitTransactionResponse -> ShowS
[CommitTransactionResponse] -> ShowS
CommitTransactionResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CommitTransactionResponse] -> ShowS
$cshowList :: [CommitTransactionResponse] -> ShowS
show :: CommitTransactionResponse -> String
$cshow :: CommitTransactionResponse -> String
showsPrec :: Int -> CommitTransactionResponse -> ShowS
$cshowsPrec :: Int -> CommitTransactionResponse -> ShowS
Prelude.Show, forall x.
Rep CommitTransactionResponse x -> CommitTransactionResponse
forall x.
CommitTransactionResponse -> Rep CommitTransactionResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CommitTransactionResponse x -> CommitTransactionResponse
$cfrom :: forall x.
CommitTransactionResponse -> Rep CommitTransactionResponse x
Prelude.Generic)
newCommitTransactionResponse ::
Prelude.Int ->
CommitTransactionResponse
newCommitTransactionResponse :: Int -> CommitTransactionResponse
newCommitTransactionResponse Int
pHttpStatus_ =
CommitTransactionResponse'
{ $sel:transactionStatus:CommitTransactionResponse' :: Maybe TransactionStatus
transactionStatus =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:CommitTransactionResponse' :: Int
httpStatus = Int
pHttpStatus_
}
commitTransactionResponse_transactionStatus :: Lens.Lens' CommitTransactionResponse (Prelude.Maybe TransactionStatus)
commitTransactionResponse_transactionStatus :: Lens' CommitTransactionResponse (Maybe TransactionStatus)
commitTransactionResponse_transactionStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CommitTransactionResponse' {Maybe TransactionStatus
transactionStatus :: Maybe TransactionStatus
$sel:transactionStatus:CommitTransactionResponse' :: CommitTransactionResponse -> Maybe TransactionStatus
transactionStatus} -> Maybe TransactionStatus
transactionStatus) (\s :: CommitTransactionResponse
s@CommitTransactionResponse' {} Maybe TransactionStatus
a -> CommitTransactionResponse
s {$sel:transactionStatus:CommitTransactionResponse' :: Maybe TransactionStatus
transactionStatus = Maybe TransactionStatus
a} :: CommitTransactionResponse)
commitTransactionResponse_httpStatus :: Lens.Lens' CommitTransactionResponse Prelude.Int
commitTransactionResponse_httpStatus :: Lens' CommitTransactionResponse Int
commitTransactionResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CommitTransactionResponse' {Int
httpStatus :: Int
$sel:httpStatus:CommitTransactionResponse' :: CommitTransactionResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: CommitTransactionResponse
s@CommitTransactionResponse' {} Int
a -> CommitTransactionResponse
s {$sel:httpStatus:CommitTransactionResponse' :: Int
httpStatus = Int
a} :: CommitTransactionResponse)
instance Prelude.NFData CommitTransactionResponse where
rnf :: CommitTransactionResponse -> ()
rnf CommitTransactionResponse' {Int
Maybe TransactionStatus
httpStatus :: Int
transactionStatus :: Maybe TransactionStatus
$sel:httpStatus:CommitTransactionResponse' :: CommitTransactionResponse -> Int
$sel:transactionStatus:CommitTransactionResponse' :: CommitTransactionResponse -> Maybe TransactionStatus
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe TransactionStatus
transactionStatus
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus