{-# 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.Personalize.StopRecommender
(
StopRecommender (..),
newStopRecommender,
stopRecommender_recommenderArn,
StopRecommenderResponse (..),
newStopRecommenderResponse,
stopRecommenderResponse_recommenderArn,
stopRecommenderResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.Personalize.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data StopRecommender = StopRecommender'
{
StopRecommender -> Text
recommenderArn :: Prelude.Text
}
deriving (StopRecommender -> StopRecommender -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: StopRecommender -> StopRecommender -> Bool
$c/= :: StopRecommender -> StopRecommender -> Bool
== :: StopRecommender -> StopRecommender -> Bool
$c== :: StopRecommender -> StopRecommender -> Bool
Prelude.Eq, ReadPrec [StopRecommender]
ReadPrec StopRecommender
Int -> ReadS StopRecommender
ReadS [StopRecommender]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [StopRecommender]
$creadListPrec :: ReadPrec [StopRecommender]
readPrec :: ReadPrec StopRecommender
$creadPrec :: ReadPrec StopRecommender
readList :: ReadS [StopRecommender]
$creadList :: ReadS [StopRecommender]
readsPrec :: Int -> ReadS StopRecommender
$creadsPrec :: Int -> ReadS StopRecommender
Prelude.Read, Int -> StopRecommender -> ShowS
[StopRecommender] -> ShowS
StopRecommender -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [StopRecommender] -> ShowS
$cshowList :: [StopRecommender] -> ShowS
show :: StopRecommender -> String
$cshow :: StopRecommender -> String
showsPrec :: Int -> StopRecommender -> ShowS
$cshowsPrec :: Int -> StopRecommender -> ShowS
Prelude.Show, forall x. Rep StopRecommender x -> StopRecommender
forall x. StopRecommender -> Rep StopRecommender x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep StopRecommender x -> StopRecommender
$cfrom :: forall x. StopRecommender -> Rep StopRecommender x
Prelude.Generic)
newStopRecommender ::
Prelude.Text ->
StopRecommender
newStopRecommender :: Text -> StopRecommender
newStopRecommender Text
pRecommenderArn_ =
StopRecommender' {$sel:recommenderArn:StopRecommender' :: Text
recommenderArn = Text
pRecommenderArn_}
stopRecommender_recommenderArn :: Lens.Lens' StopRecommender Prelude.Text
stopRecommender_recommenderArn :: Lens' StopRecommender Text
stopRecommender_recommenderArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StopRecommender' {Text
recommenderArn :: Text
$sel:recommenderArn:StopRecommender' :: StopRecommender -> Text
recommenderArn} -> Text
recommenderArn) (\s :: StopRecommender
s@StopRecommender' {} Text
a -> StopRecommender
s {$sel:recommenderArn:StopRecommender' :: Text
recommenderArn = Text
a} :: StopRecommender)
instance Core.AWSRequest StopRecommender where
type
AWSResponse StopRecommender =
StopRecommenderResponse
request :: (Service -> Service) -> StopRecommender -> Request StopRecommender
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 StopRecommender
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse StopRecommender)))
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 Text -> Int -> StopRecommenderResponse
StopRecommenderResponse'
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
"recommenderArn")
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 StopRecommender where
hashWithSalt :: Int -> StopRecommender -> Int
hashWithSalt Int
_salt StopRecommender' {Text
recommenderArn :: Text
$sel:recommenderArn:StopRecommender' :: StopRecommender -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
recommenderArn
instance Prelude.NFData StopRecommender where
rnf :: StopRecommender -> ()
rnf StopRecommender' {Text
recommenderArn :: Text
$sel:recommenderArn:StopRecommender' :: StopRecommender -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
recommenderArn
instance Data.ToHeaders StopRecommender where
toHeaders :: StopRecommender -> 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
"AmazonPersonalize.StopRecommender" ::
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 StopRecommender where
toJSON :: StopRecommender -> Value
toJSON StopRecommender' {Text
recommenderArn :: Text
$sel:recommenderArn:StopRecommender' :: StopRecommender -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just
(Key
"recommenderArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
recommenderArn)
]
)
instance Data.ToPath StopRecommender where
toPath :: StopRecommender -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery StopRecommender where
toQuery :: StopRecommender -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data StopRecommenderResponse = StopRecommenderResponse'
{
StopRecommenderResponse -> Maybe Text
recommenderArn :: Prelude.Maybe Prelude.Text,
StopRecommenderResponse -> Int
httpStatus :: Prelude.Int
}
deriving (StopRecommenderResponse -> StopRecommenderResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: StopRecommenderResponse -> StopRecommenderResponse -> Bool
$c/= :: StopRecommenderResponse -> StopRecommenderResponse -> Bool
== :: StopRecommenderResponse -> StopRecommenderResponse -> Bool
$c== :: StopRecommenderResponse -> StopRecommenderResponse -> Bool
Prelude.Eq, ReadPrec [StopRecommenderResponse]
ReadPrec StopRecommenderResponse
Int -> ReadS StopRecommenderResponse
ReadS [StopRecommenderResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [StopRecommenderResponse]
$creadListPrec :: ReadPrec [StopRecommenderResponse]
readPrec :: ReadPrec StopRecommenderResponse
$creadPrec :: ReadPrec StopRecommenderResponse
readList :: ReadS [StopRecommenderResponse]
$creadList :: ReadS [StopRecommenderResponse]
readsPrec :: Int -> ReadS StopRecommenderResponse
$creadsPrec :: Int -> ReadS StopRecommenderResponse
Prelude.Read, Int -> StopRecommenderResponse -> ShowS
[StopRecommenderResponse] -> ShowS
StopRecommenderResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [StopRecommenderResponse] -> ShowS
$cshowList :: [StopRecommenderResponse] -> ShowS
show :: StopRecommenderResponse -> String
$cshow :: StopRecommenderResponse -> String
showsPrec :: Int -> StopRecommenderResponse -> ShowS
$cshowsPrec :: Int -> StopRecommenderResponse -> ShowS
Prelude.Show, forall x. Rep StopRecommenderResponse x -> StopRecommenderResponse
forall x. StopRecommenderResponse -> Rep StopRecommenderResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep StopRecommenderResponse x -> StopRecommenderResponse
$cfrom :: forall x. StopRecommenderResponse -> Rep StopRecommenderResponse x
Prelude.Generic)
newStopRecommenderResponse ::
Prelude.Int ->
StopRecommenderResponse
newStopRecommenderResponse :: Int -> StopRecommenderResponse
newStopRecommenderResponse Int
pHttpStatus_ =
StopRecommenderResponse'
{ $sel:recommenderArn:StopRecommenderResponse' :: Maybe Text
recommenderArn =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:StopRecommenderResponse' :: Int
httpStatus = Int
pHttpStatus_
}
stopRecommenderResponse_recommenderArn :: Lens.Lens' StopRecommenderResponse (Prelude.Maybe Prelude.Text)
stopRecommenderResponse_recommenderArn :: Lens' StopRecommenderResponse (Maybe Text)
stopRecommenderResponse_recommenderArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StopRecommenderResponse' {Maybe Text
recommenderArn :: Maybe Text
$sel:recommenderArn:StopRecommenderResponse' :: StopRecommenderResponse -> Maybe Text
recommenderArn} -> Maybe Text
recommenderArn) (\s :: StopRecommenderResponse
s@StopRecommenderResponse' {} Maybe Text
a -> StopRecommenderResponse
s {$sel:recommenderArn:StopRecommenderResponse' :: Maybe Text
recommenderArn = Maybe Text
a} :: StopRecommenderResponse)
stopRecommenderResponse_httpStatus :: Lens.Lens' StopRecommenderResponse Prelude.Int
stopRecommenderResponse_httpStatus :: Lens' StopRecommenderResponse Int
stopRecommenderResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StopRecommenderResponse' {Int
httpStatus :: Int
$sel:httpStatus:StopRecommenderResponse' :: StopRecommenderResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: StopRecommenderResponse
s@StopRecommenderResponse' {} Int
a -> StopRecommenderResponse
s {$sel:httpStatus:StopRecommenderResponse' :: Int
httpStatus = Int
a} :: StopRecommenderResponse)
instance Prelude.NFData StopRecommenderResponse where
rnf :: StopRecommenderResponse -> ()
rnf StopRecommenderResponse' {Int
Maybe Text
httpStatus :: Int
recommenderArn :: Maybe Text
$sel:httpStatus:StopRecommenderResponse' :: StopRecommenderResponse -> Int
$sel:recommenderArn:StopRecommenderResponse' :: StopRecommenderResponse -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
recommenderArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus