{-# 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.MechanicalTurk.UpdateExpirationForHIT
(
UpdateExpirationForHIT (..),
newUpdateExpirationForHIT,
updateExpirationForHIT_hITId,
updateExpirationForHIT_expireAt,
UpdateExpirationForHITResponse (..),
newUpdateExpirationForHITResponse,
updateExpirationForHITResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Lens as Lens
import Amazonka.MechanicalTurk.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data UpdateExpirationForHIT = UpdateExpirationForHIT'
{
UpdateExpirationForHIT -> Text
hITId :: Prelude.Text,
UpdateExpirationForHIT -> POSIX
expireAt :: Core.POSIX
}
deriving (UpdateExpirationForHIT -> UpdateExpirationForHIT -> Bool
(UpdateExpirationForHIT -> UpdateExpirationForHIT -> Bool)
-> (UpdateExpirationForHIT -> UpdateExpirationForHIT -> Bool)
-> Eq UpdateExpirationForHIT
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateExpirationForHIT -> UpdateExpirationForHIT -> Bool
$c/= :: UpdateExpirationForHIT -> UpdateExpirationForHIT -> Bool
== :: UpdateExpirationForHIT -> UpdateExpirationForHIT -> Bool
$c== :: UpdateExpirationForHIT -> UpdateExpirationForHIT -> Bool
Prelude.Eq, ReadPrec [UpdateExpirationForHIT]
ReadPrec UpdateExpirationForHIT
Int -> ReadS UpdateExpirationForHIT
ReadS [UpdateExpirationForHIT]
(Int -> ReadS UpdateExpirationForHIT)
-> ReadS [UpdateExpirationForHIT]
-> ReadPrec UpdateExpirationForHIT
-> ReadPrec [UpdateExpirationForHIT]
-> Read UpdateExpirationForHIT
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateExpirationForHIT]
$creadListPrec :: ReadPrec [UpdateExpirationForHIT]
readPrec :: ReadPrec UpdateExpirationForHIT
$creadPrec :: ReadPrec UpdateExpirationForHIT
readList :: ReadS [UpdateExpirationForHIT]
$creadList :: ReadS [UpdateExpirationForHIT]
readsPrec :: Int -> ReadS UpdateExpirationForHIT
$creadsPrec :: Int -> ReadS UpdateExpirationForHIT
Prelude.Read, Int -> UpdateExpirationForHIT -> ShowS
[UpdateExpirationForHIT] -> ShowS
UpdateExpirationForHIT -> String
(Int -> UpdateExpirationForHIT -> ShowS)
-> (UpdateExpirationForHIT -> String)
-> ([UpdateExpirationForHIT] -> ShowS)
-> Show UpdateExpirationForHIT
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateExpirationForHIT] -> ShowS
$cshowList :: [UpdateExpirationForHIT] -> ShowS
show :: UpdateExpirationForHIT -> String
$cshow :: UpdateExpirationForHIT -> String
showsPrec :: Int -> UpdateExpirationForHIT -> ShowS
$cshowsPrec :: Int -> UpdateExpirationForHIT -> ShowS
Prelude.Show, (forall x. UpdateExpirationForHIT -> Rep UpdateExpirationForHIT x)
-> (forall x.
Rep UpdateExpirationForHIT x -> UpdateExpirationForHIT)
-> Generic UpdateExpirationForHIT
forall x. Rep UpdateExpirationForHIT x -> UpdateExpirationForHIT
forall x. UpdateExpirationForHIT -> Rep UpdateExpirationForHIT x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateExpirationForHIT x -> UpdateExpirationForHIT
$cfrom :: forall x. UpdateExpirationForHIT -> Rep UpdateExpirationForHIT x
Prelude.Generic)
newUpdateExpirationForHIT ::
Prelude.Text ->
Prelude.UTCTime ->
UpdateExpirationForHIT
newUpdateExpirationForHIT :: Text -> UTCTime -> UpdateExpirationForHIT
newUpdateExpirationForHIT Text
pHITId_ UTCTime
pExpireAt_ =
UpdateExpirationForHIT' :: Text -> POSIX -> UpdateExpirationForHIT
UpdateExpirationForHIT'
{ $sel:hITId:UpdateExpirationForHIT' :: Text
hITId = Text
pHITId_,
$sel:expireAt:UpdateExpirationForHIT' :: POSIX
expireAt = Tagged UTCTime (Identity UTCTime) -> Tagged POSIX (Identity POSIX)
forall (a :: Format). Iso' (Time a) UTCTime
Core._Time (Tagged UTCTime (Identity UTCTime)
-> Tagged POSIX (Identity POSIX))
-> UTCTime -> POSIX
forall t b. AReview t b -> b -> t
Lens.# UTCTime
pExpireAt_
}
updateExpirationForHIT_hITId :: Lens.Lens' UpdateExpirationForHIT Prelude.Text
updateExpirationForHIT_hITId :: (Text -> f Text)
-> UpdateExpirationForHIT -> f UpdateExpirationForHIT
updateExpirationForHIT_hITId = (UpdateExpirationForHIT -> Text)
-> (UpdateExpirationForHIT -> Text -> UpdateExpirationForHIT)
-> Lens UpdateExpirationForHIT UpdateExpirationForHIT Text Text
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateExpirationForHIT' {Text
hITId :: Text
$sel:hITId:UpdateExpirationForHIT' :: UpdateExpirationForHIT -> Text
hITId} -> Text
hITId) (\s :: UpdateExpirationForHIT
s@UpdateExpirationForHIT' {} Text
a -> UpdateExpirationForHIT
s {$sel:hITId:UpdateExpirationForHIT' :: Text
hITId = Text
a} :: UpdateExpirationForHIT)
updateExpirationForHIT_expireAt :: Lens.Lens' UpdateExpirationForHIT Prelude.UTCTime
updateExpirationForHIT_expireAt :: (UTCTime -> f UTCTime)
-> UpdateExpirationForHIT -> f UpdateExpirationForHIT
updateExpirationForHIT_expireAt = (UpdateExpirationForHIT -> POSIX)
-> (UpdateExpirationForHIT -> POSIX -> UpdateExpirationForHIT)
-> Lens UpdateExpirationForHIT UpdateExpirationForHIT POSIX POSIX
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateExpirationForHIT' {POSIX
expireAt :: POSIX
$sel:expireAt:UpdateExpirationForHIT' :: UpdateExpirationForHIT -> POSIX
expireAt} -> POSIX
expireAt) (\s :: UpdateExpirationForHIT
s@UpdateExpirationForHIT' {} POSIX
a -> UpdateExpirationForHIT
s {$sel:expireAt:UpdateExpirationForHIT' :: POSIX
expireAt = POSIX
a} :: UpdateExpirationForHIT) ((POSIX -> f POSIX)
-> UpdateExpirationForHIT -> f UpdateExpirationForHIT)
-> ((UTCTime -> f UTCTime) -> POSIX -> f POSIX)
-> (UTCTime -> f UTCTime)
-> UpdateExpirationForHIT
-> f UpdateExpirationForHIT
forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. (UTCTime -> f UTCTime) -> POSIX -> f POSIX
forall (a :: Format). Iso' (Time a) UTCTime
Core._Time
instance Core.AWSRequest UpdateExpirationForHIT where
type
AWSResponse UpdateExpirationForHIT =
UpdateExpirationForHITResponse
request :: UpdateExpirationForHIT -> Request UpdateExpirationForHIT
request = Service -> UpdateExpirationForHIT -> Request UpdateExpirationForHIT
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON Service
defaultService
response :: Logger
-> Service
-> Proxy UpdateExpirationForHIT
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse UpdateExpirationForHIT)))
response =
(Int
-> ResponseHeaders
-> ()
-> Either String (AWSResponse UpdateExpirationForHIT))
-> Logger
-> Service
-> Proxy UpdateExpirationForHIT
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse UpdateExpirationForHIT)))
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> () -> Either String (AWSResponse a))
-> Logger
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveEmpty
( \Int
s ResponseHeaders
h ()
x ->
Int -> UpdateExpirationForHITResponse
UpdateExpirationForHITResponse'
(Int -> UpdateExpirationForHITResponse)
-> Either String Int
-> Either String UpdateExpirationForHITResponse
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Int -> Either String Int
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (Int -> Int
forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
)
instance Prelude.Hashable UpdateExpirationForHIT
instance Prelude.NFData UpdateExpirationForHIT
instance Core.ToHeaders UpdateExpirationForHIT where
toHeaders :: UpdateExpirationForHIT -> ResponseHeaders
toHeaders =
ResponseHeaders -> UpdateExpirationForHIT -> ResponseHeaders
forall a b. a -> b -> a
Prelude.const
( [ResponseHeaders] -> ResponseHeaders
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"X-Amz-Target"
HeaderName -> ByteString -> ResponseHeaders
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Core.=# ( ByteString
"MTurkRequesterServiceV20170117.UpdateExpirationForHIT" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
HeaderName -> ByteString -> ResponseHeaders
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Core.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Core.ToJSON UpdateExpirationForHIT where
toJSON :: UpdateExpirationForHIT -> Value
toJSON UpdateExpirationForHIT' {Text
POSIX
expireAt :: POSIX
hITId :: Text
$sel:expireAt:UpdateExpirationForHIT' :: UpdateExpirationForHIT -> POSIX
$sel:hITId:UpdateExpirationForHIT' :: UpdateExpirationForHIT -> Text
..} =
[Pair] -> Value
Core.object
( [Maybe Pair] -> [Pair]
forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ Pair -> Maybe Pair
forall a. a -> Maybe a
Prelude.Just (Text
"HITId" Text -> Text -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Core..= Text
hITId),
Pair -> Maybe Pair
forall a. a -> Maybe a
Prelude.Just (Text
"ExpireAt" Text -> POSIX -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Core..= POSIX
expireAt)
]
)
instance Core.ToPath UpdateExpirationForHIT where
toPath :: UpdateExpirationForHIT -> ByteString
toPath = ByteString -> UpdateExpirationForHIT -> ByteString
forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Core.ToQuery UpdateExpirationForHIT where
toQuery :: UpdateExpirationForHIT -> QueryString
toQuery = QueryString -> UpdateExpirationForHIT -> QueryString
forall a b. a -> b -> a
Prelude.const QueryString
forall a. Monoid a => a
Prelude.mempty
data UpdateExpirationForHITResponse = UpdateExpirationForHITResponse'
{
UpdateExpirationForHITResponse -> Int
httpStatus :: Prelude.Int
}
deriving (UpdateExpirationForHITResponse
-> UpdateExpirationForHITResponse -> Bool
(UpdateExpirationForHITResponse
-> UpdateExpirationForHITResponse -> Bool)
-> (UpdateExpirationForHITResponse
-> UpdateExpirationForHITResponse -> Bool)
-> Eq UpdateExpirationForHITResponse
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateExpirationForHITResponse
-> UpdateExpirationForHITResponse -> Bool
$c/= :: UpdateExpirationForHITResponse
-> UpdateExpirationForHITResponse -> Bool
== :: UpdateExpirationForHITResponse
-> UpdateExpirationForHITResponse -> Bool
$c== :: UpdateExpirationForHITResponse
-> UpdateExpirationForHITResponse -> Bool
Prelude.Eq, ReadPrec [UpdateExpirationForHITResponse]
ReadPrec UpdateExpirationForHITResponse
Int -> ReadS UpdateExpirationForHITResponse
ReadS [UpdateExpirationForHITResponse]
(Int -> ReadS UpdateExpirationForHITResponse)
-> ReadS [UpdateExpirationForHITResponse]
-> ReadPrec UpdateExpirationForHITResponse
-> ReadPrec [UpdateExpirationForHITResponse]
-> Read UpdateExpirationForHITResponse
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateExpirationForHITResponse]
$creadListPrec :: ReadPrec [UpdateExpirationForHITResponse]
readPrec :: ReadPrec UpdateExpirationForHITResponse
$creadPrec :: ReadPrec UpdateExpirationForHITResponse
readList :: ReadS [UpdateExpirationForHITResponse]
$creadList :: ReadS [UpdateExpirationForHITResponse]
readsPrec :: Int -> ReadS UpdateExpirationForHITResponse
$creadsPrec :: Int -> ReadS UpdateExpirationForHITResponse
Prelude.Read, Int -> UpdateExpirationForHITResponse -> ShowS
[UpdateExpirationForHITResponse] -> ShowS
UpdateExpirationForHITResponse -> String
(Int -> UpdateExpirationForHITResponse -> ShowS)
-> (UpdateExpirationForHITResponse -> String)
-> ([UpdateExpirationForHITResponse] -> ShowS)
-> Show UpdateExpirationForHITResponse
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateExpirationForHITResponse] -> ShowS
$cshowList :: [UpdateExpirationForHITResponse] -> ShowS
show :: UpdateExpirationForHITResponse -> String
$cshow :: UpdateExpirationForHITResponse -> String
showsPrec :: Int -> UpdateExpirationForHITResponse -> ShowS
$cshowsPrec :: Int -> UpdateExpirationForHITResponse -> ShowS
Prelude.Show, (forall x.
UpdateExpirationForHITResponse
-> Rep UpdateExpirationForHITResponse x)
-> (forall x.
Rep UpdateExpirationForHITResponse x
-> UpdateExpirationForHITResponse)
-> Generic UpdateExpirationForHITResponse
forall x.
Rep UpdateExpirationForHITResponse x
-> UpdateExpirationForHITResponse
forall x.
UpdateExpirationForHITResponse
-> Rep UpdateExpirationForHITResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep UpdateExpirationForHITResponse x
-> UpdateExpirationForHITResponse
$cfrom :: forall x.
UpdateExpirationForHITResponse
-> Rep UpdateExpirationForHITResponse x
Prelude.Generic)
newUpdateExpirationForHITResponse ::
Prelude.Int ->
UpdateExpirationForHITResponse
newUpdateExpirationForHITResponse :: Int -> UpdateExpirationForHITResponse
newUpdateExpirationForHITResponse Int
pHttpStatus_ =
UpdateExpirationForHITResponse' :: Int -> UpdateExpirationForHITResponse
UpdateExpirationForHITResponse'
{ $sel:httpStatus:UpdateExpirationForHITResponse' :: Int
httpStatus =
Int
pHttpStatus_
}
updateExpirationForHITResponse_httpStatus :: Lens.Lens' UpdateExpirationForHITResponse Prelude.Int
updateExpirationForHITResponse_httpStatus :: (Int -> f Int)
-> UpdateExpirationForHITResponse
-> f UpdateExpirationForHITResponse
updateExpirationForHITResponse_httpStatus = (UpdateExpirationForHITResponse -> Int)
-> (UpdateExpirationForHITResponse
-> Int -> UpdateExpirationForHITResponse)
-> Lens
UpdateExpirationForHITResponse
UpdateExpirationForHITResponse
Int
Int
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateExpirationForHITResponse' {Int
httpStatus :: Int
$sel:httpStatus:UpdateExpirationForHITResponse' :: UpdateExpirationForHITResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: UpdateExpirationForHITResponse
s@UpdateExpirationForHITResponse' {} Int
a -> UpdateExpirationForHITResponse
s {$sel:httpStatus:UpdateExpirationForHITResponse' :: Int
httpStatus = Int
a} :: UpdateExpirationForHITResponse)
instance
Prelude.NFData
UpdateExpirationForHITResponse