{-# 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.DescribeCampaign
(
DescribeCampaign (..),
newDescribeCampaign,
describeCampaign_campaignArn,
DescribeCampaignResponse (..),
newDescribeCampaignResponse,
describeCampaignResponse_campaign,
describeCampaignResponse_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 DescribeCampaign = DescribeCampaign'
{
DescribeCampaign -> Text
campaignArn :: Prelude.Text
}
deriving (DescribeCampaign -> DescribeCampaign -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeCampaign -> DescribeCampaign -> Bool
$c/= :: DescribeCampaign -> DescribeCampaign -> Bool
== :: DescribeCampaign -> DescribeCampaign -> Bool
$c== :: DescribeCampaign -> DescribeCampaign -> Bool
Prelude.Eq, ReadPrec [DescribeCampaign]
ReadPrec DescribeCampaign
Int -> ReadS DescribeCampaign
ReadS [DescribeCampaign]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeCampaign]
$creadListPrec :: ReadPrec [DescribeCampaign]
readPrec :: ReadPrec DescribeCampaign
$creadPrec :: ReadPrec DescribeCampaign
readList :: ReadS [DescribeCampaign]
$creadList :: ReadS [DescribeCampaign]
readsPrec :: Int -> ReadS DescribeCampaign
$creadsPrec :: Int -> ReadS DescribeCampaign
Prelude.Read, Int -> DescribeCampaign -> ShowS
[DescribeCampaign] -> ShowS
DescribeCampaign -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeCampaign] -> ShowS
$cshowList :: [DescribeCampaign] -> ShowS
show :: DescribeCampaign -> String
$cshow :: DescribeCampaign -> String
showsPrec :: Int -> DescribeCampaign -> ShowS
$cshowsPrec :: Int -> DescribeCampaign -> ShowS
Prelude.Show, forall x. Rep DescribeCampaign x -> DescribeCampaign
forall x. DescribeCampaign -> Rep DescribeCampaign x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeCampaign x -> DescribeCampaign
$cfrom :: forall x. DescribeCampaign -> Rep DescribeCampaign x
Prelude.Generic)
newDescribeCampaign ::
Prelude.Text ->
DescribeCampaign
newDescribeCampaign :: Text -> DescribeCampaign
newDescribeCampaign Text
pCampaignArn_ =
DescribeCampaign' {$sel:campaignArn:DescribeCampaign' :: Text
campaignArn = Text
pCampaignArn_}
describeCampaign_campaignArn :: Lens.Lens' DescribeCampaign Prelude.Text
describeCampaign_campaignArn :: Lens' DescribeCampaign Text
describeCampaign_campaignArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeCampaign' {Text
campaignArn :: Text
$sel:campaignArn:DescribeCampaign' :: DescribeCampaign -> Text
campaignArn} -> Text
campaignArn) (\s :: DescribeCampaign
s@DescribeCampaign' {} Text
a -> DescribeCampaign
s {$sel:campaignArn:DescribeCampaign' :: Text
campaignArn = Text
a} :: DescribeCampaign)
instance Core.AWSRequest DescribeCampaign where
type
AWSResponse DescribeCampaign =
DescribeCampaignResponse
request :: (Service -> Service)
-> DescribeCampaign -> Request DescribeCampaign
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 DescribeCampaign
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeCampaign)))
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 Campaign -> Int -> DescribeCampaignResponse
DescribeCampaignResponse'
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
"campaign")
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 DescribeCampaign where
hashWithSalt :: Int -> DescribeCampaign -> Int
hashWithSalt Int
_salt DescribeCampaign' {Text
campaignArn :: Text
$sel:campaignArn:DescribeCampaign' :: DescribeCampaign -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
campaignArn
instance Prelude.NFData DescribeCampaign where
rnf :: DescribeCampaign -> ()
rnf DescribeCampaign' {Text
campaignArn :: Text
$sel:campaignArn:DescribeCampaign' :: DescribeCampaign -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
campaignArn
instance Data.ToHeaders DescribeCampaign where
toHeaders :: DescribeCampaign -> 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.DescribeCampaign" ::
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 DescribeCampaign where
toJSON :: DescribeCampaign -> Value
toJSON DescribeCampaign' {Text
campaignArn :: Text
$sel:campaignArn:DescribeCampaign' :: DescribeCampaign -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[forall a. a -> Maybe a
Prelude.Just (Key
"campaignArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
campaignArn)]
)
instance Data.ToPath DescribeCampaign where
toPath :: DescribeCampaign -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DescribeCampaign where
toQuery :: DescribeCampaign -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DescribeCampaignResponse = DescribeCampaignResponse'
{
DescribeCampaignResponse -> Maybe Campaign
campaign :: Prelude.Maybe Campaign,
DescribeCampaignResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DescribeCampaignResponse -> DescribeCampaignResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeCampaignResponse -> DescribeCampaignResponse -> Bool
$c/= :: DescribeCampaignResponse -> DescribeCampaignResponse -> Bool
== :: DescribeCampaignResponse -> DescribeCampaignResponse -> Bool
$c== :: DescribeCampaignResponse -> DescribeCampaignResponse -> Bool
Prelude.Eq, ReadPrec [DescribeCampaignResponse]
ReadPrec DescribeCampaignResponse
Int -> ReadS DescribeCampaignResponse
ReadS [DescribeCampaignResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeCampaignResponse]
$creadListPrec :: ReadPrec [DescribeCampaignResponse]
readPrec :: ReadPrec DescribeCampaignResponse
$creadPrec :: ReadPrec DescribeCampaignResponse
readList :: ReadS [DescribeCampaignResponse]
$creadList :: ReadS [DescribeCampaignResponse]
readsPrec :: Int -> ReadS DescribeCampaignResponse
$creadsPrec :: Int -> ReadS DescribeCampaignResponse
Prelude.Read, Int -> DescribeCampaignResponse -> ShowS
[DescribeCampaignResponse] -> ShowS
DescribeCampaignResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeCampaignResponse] -> ShowS
$cshowList :: [DescribeCampaignResponse] -> ShowS
show :: DescribeCampaignResponse -> String
$cshow :: DescribeCampaignResponse -> String
showsPrec :: Int -> DescribeCampaignResponse -> ShowS
$cshowsPrec :: Int -> DescribeCampaignResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeCampaignResponse x -> DescribeCampaignResponse
forall x.
DescribeCampaignResponse -> Rep DescribeCampaignResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeCampaignResponse x -> DescribeCampaignResponse
$cfrom :: forall x.
DescribeCampaignResponse -> Rep DescribeCampaignResponse x
Prelude.Generic)
newDescribeCampaignResponse ::
Prelude.Int ->
DescribeCampaignResponse
newDescribeCampaignResponse :: Int -> DescribeCampaignResponse
newDescribeCampaignResponse Int
pHttpStatus_ =
DescribeCampaignResponse'
{ $sel:campaign:DescribeCampaignResponse' :: Maybe Campaign
campaign =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DescribeCampaignResponse' :: Int
httpStatus = Int
pHttpStatus_
}
describeCampaignResponse_campaign :: Lens.Lens' DescribeCampaignResponse (Prelude.Maybe Campaign)
describeCampaignResponse_campaign :: Lens' DescribeCampaignResponse (Maybe Campaign)
describeCampaignResponse_campaign = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeCampaignResponse' {Maybe Campaign
campaign :: Maybe Campaign
$sel:campaign:DescribeCampaignResponse' :: DescribeCampaignResponse -> Maybe Campaign
campaign} -> Maybe Campaign
campaign) (\s :: DescribeCampaignResponse
s@DescribeCampaignResponse' {} Maybe Campaign
a -> DescribeCampaignResponse
s {$sel:campaign:DescribeCampaignResponse' :: Maybe Campaign
campaign = Maybe Campaign
a} :: DescribeCampaignResponse)
describeCampaignResponse_httpStatus :: Lens.Lens' DescribeCampaignResponse Prelude.Int
describeCampaignResponse_httpStatus :: Lens' DescribeCampaignResponse Int
describeCampaignResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeCampaignResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeCampaignResponse' :: DescribeCampaignResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeCampaignResponse
s@DescribeCampaignResponse' {} Int
a -> DescribeCampaignResponse
s {$sel:httpStatus:DescribeCampaignResponse' :: Int
httpStatus = Int
a} :: DescribeCampaignResponse)
instance Prelude.NFData DescribeCampaignResponse where
rnf :: DescribeCampaignResponse -> ()
rnf DescribeCampaignResponse' {Int
Maybe Campaign
httpStatus :: Int
campaign :: Maybe Campaign
$sel:httpStatus:DescribeCampaignResponse' :: DescribeCampaignResponse -> Int
$sel:campaign:DescribeCampaignResponse' :: DescribeCampaignResponse -> Maybe Campaign
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Campaign
campaign
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus