{-# 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.StartRecommender
(
StartRecommender (..),
newStartRecommender,
startRecommender_recommenderArn,
StartRecommenderResponse (..),
newStartRecommenderResponse,
startRecommenderResponse_recommenderArn,
startRecommenderResponse_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 StartRecommender = StartRecommender'
{
StartRecommender -> Text
recommenderArn :: Prelude.Text
}
deriving (StartRecommender -> StartRecommender -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: StartRecommender -> StartRecommender -> Bool
$c/= :: StartRecommender -> StartRecommender -> Bool
== :: StartRecommender -> StartRecommender -> Bool
$c== :: StartRecommender -> StartRecommender -> Bool
Prelude.Eq, ReadPrec [StartRecommender]
ReadPrec StartRecommender
Int -> ReadS StartRecommender
ReadS [StartRecommender]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [StartRecommender]
$creadListPrec :: ReadPrec [StartRecommender]
readPrec :: ReadPrec StartRecommender
$creadPrec :: ReadPrec StartRecommender
readList :: ReadS [StartRecommender]
$creadList :: ReadS [StartRecommender]
readsPrec :: Int -> ReadS StartRecommender
$creadsPrec :: Int -> ReadS StartRecommender
Prelude.Read, Int -> StartRecommender -> ShowS
[StartRecommender] -> ShowS
StartRecommender -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [StartRecommender] -> ShowS
$cshowList :: [StartRecommender] -> ShowS
show :: StartRecommender -> String
$cshow :: StartRecommender -> String
showsPrec :: Int -> StartRecommender -> ShowS
$cshowsPrec :: Int -> StartRecommender -> ShowS
Prelude.Show, forall x. Rep StartRecommender x -> StartRecommender
forall x. StartRecommender -> Rep StartRecommender x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep StartRecommender x -> StartRecommender
$cfrom :: forall x. StartRecommender -> Rep StartRecommender x
Prelude.Generic)
newStartRecommender ::
Prelude.Text ->
StartRecommender
newStartRecommender :: Text -> StartRecommender
newStartRecommender Text
pRecommenderArn_ =
StartRecommender'
{ $sel:recommenderArn:StartRecommender' :: Text
recommenderArn =
Text
pRecommenderArn_
}
startRecommender_recommenderArn :: Lens.Lens' StartRecommender Prelude.Text
startRecommender_recommenderArn :: Lens' StartRecommender Text
startRecommender_recommenderArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartRecommender' {Text
recommenderArn :: Text
$sel:recommenderArn:StartRecommender' :: StartRecommender -> Text
recommenderArn} -> Text
recommenderArn) (\s :: StartRecommender
s@StartRecommender' {} Text
a -> StartRecommender
s {$sel:recommenderArn:StartRecommender' :: Text
recommenderArn = Text
a} :: StartRecommender)
instance Core.AWSRequest StartRecommender where
type
AWSResponse StartRecommender =
StartRecommenderResponse
request :: (Service -> Service)
-> StartRecommender -> Request StartRecommender
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 StartRecommender
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse StartRecommender)))
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 -> StartRecommenderResponse
StartRecommenderResponse'
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 StartRecommender where
hashWithSalt :: Int -> StartRecommender -> Int
hashWithSalt Int
_salt StartRecommender' {Text
recommenderArn :: Text
$sel:recommenderArn:StartRecommender' :: StartRecommender -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
recommenderArn
instance Prelude.NFData StartRecommender where
rnf :: StartRecommender -> ()
rnf StartRecommender' {Text
recommenderArn :: Text
$sel:recommenderArn:StartRecommender' :: StartRecommender -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
recommenderArn
instance Data.ToHeaders StartRecommender where
toHeaders :: StartRecommender -> 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.StartRecommender" ::
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 StartRecommender where
toJSON :: StartRecommender -> Value
toJSON StartRecommender' {Text
recommenderArn :: Text
$sel:recommenderArn:StartRecommender' :: StartRecommender -> 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 StartRecommender where
toPath :: StartRecommender -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery StartRecommender where
toQuery :: StartRecommender -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data StartRecommenderResponse = StartRecommenderResponse'
{
StartRecommenderResponse -> Maybe Text
recommenderArn :: Prelude.Maybe Prelude.Text,
StartRecommenderResponse -> Int
httpStatus :: Prelude.Int
}
deriving (StartRecommenderResponse -> StartRecommenderResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: StartRecommenderResponse -> StartRecommenderResponse -> Bool
$c/= :: StartRecommenderResponse -> StartRecommenderResponse -> Bool
== :: StartRecommenderResponse -> StartRecommenderResponse -> Bool
$c== :: StartRecommenderResponse -> StartRecommenderResponse -> Bool
Prelude.Eq, ReadPrec [StartRecommenderResponse]
ReadPrec StartRecommenderResponse
Int -> ReadS StartRecommenderResponse
ReadS [StartRecommenderResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [StartRecommenderResponse]
$creadListPrec :: ReadPrec [StartRecommenderResponse]
readPrec :: ReadPrec StartRecommenderResponse
$creadPrec :: ReadPrec StartRecommenderResponse
readList :: ReadS [StartRecommenderResponse]
$creadList :: ReadS [StartRecommenderResponse]
readsPrec :: Int -> ReadS StartRecommenderResponse
$creadsPrec :: Int -> ReadS StartRecommenderResponse
Prelude.Read, Int -> StartRecommenderResponse -> ShowS
[StartRecommenderResponse] -> ShowS
StartRecommenderResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [StartRecommenderResponse] -> ShowS
$cshowList :: [StartRecommenderResponse] -> ShowS
show :: StartRecommenderResponse -> String
$cshow :: StartRecommenderResponse -> String
showsPrec :: Int -> StartRecommenderResponse -> ShowS
$cshowsPrec :: Int -> StartRecommenderResponse -> ShowS
Prelude.Show, forall x.
Rep StartRecommenderResponse x -> StartRecommenderResponse
forall x.
StartRecommenderResponse -> Rep StartRecommenderResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep StartRecommenderResponse x -> StartRecommenderResponse
$cfrom :: forall x.
StartRecommenderResponse -> Rep StartRecommenderResponse x
Prelude.Generic)
newStartRecommenderResponse ::
Prelude.Int ->
StartRecommenderResponse
newStartRecommenderResponse :: Int -> StartRecommenderResponse
newStartRecommenderResponse Int
pHttpStatus_ =
StartRecommenderResponse'
{ $sel:recommenderArn:StartRecommenderResponse' :: Maybe Text
recommenderArn =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:StartRecommenderResponse' :: Int
httpStatus = Int
pHttpStatus_
}
startRecommenderResponse_recommenderArn :: Lens.Lens' StartRecommenderResponse (Prelude.Maybe Prelude.Text)
startRecommenderResponse_recommenderArn :: Lens' StartRecommenderResponse (Maybe Text)
startRecommenderResponse_recommenderArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartRecommenderResponse' {Maybe Text
recommenderArn :: Maybe Text
$sel:recommenderArn:StartRecommenderResponse' :: StartRecommenderResponse -> Maybe Text
recommenderArn} -> Maybe Text
recommenderArn) (\s :: StartRecommenderResponse
s@StartRecommenderResponse' {} Maybe Text
a -> StartRecommenderResponse
s {$sel:recommenderArn:StartRecommenderResponse' :: Maybe Text
recommenderArn = Maybe Text
a} :: StartRecommenderResponse)
startRecommenderResponse_httpStatus :: Lens.Lens' StartRecommenderResponse Prelude.Int
startRecommenderResponse_httpStatus :: Lens' StartRecommenderResponse Int
startRecommenderResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartRecommenderResponse' {Int
httpStatus :: Int
$sel:httpStatus:StartRecommenderResponse' :: StartRecommenderResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: StartRecommenderResponse
s@StartRecommenderResponse' {} Int
a -> StartRecommenderResponse
s {$sel:httpStatus:StartRecommenderResponse' :: Int
httpStatus = Int
a} :: StartRecommenderResponse)
instance Prelude.NFData StartRecommenderResponse where
rnf :: StartRecommenderResponse -> ()
rnf StartRecommenderResponse' {Int
Maybe Text
httpStatus :: Int
recommenderArn :: Maybe Text
$sel:httpStatus:StartRecommenderResponse' :: StartRecommenderResponse -> Int
$sel:recommenderArn:StartRecommenderResponse' :: StartRecommenderResponse -> 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