{-# 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.SESV2.CreateEmailTemplate
(
CreateEmailTemplate (..),
newCreateEmailTemplate,
createEmailTemplate_templateName,
createEmailTemplate_templateContent,
CreateEmailTemplateResponse (..),
newCreateEmailTemplateResponse,
createEmailTemplateResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
import Amazonka.SESV2.Types
data CreateEmailTemplate = CreateEmailTemplate'
{
CreateEmailTemplate -> Text
templateName :: Prelude.Text,
CreateEmailTemplate -> EmailTemplateContent
templateContent :: EmailTemplateContent
}
deriving (CreateEmailTemplate -> CreateEmailTemplate -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateEmailTemplate -> CreateEmailTemplate -> Bool
$c/= :: CreateEmailTemplate -> CreateEmailTemplate -> Bool
== :: CreateEmailTemplate -> CreateEmailTemplate -> Bool
$c== :: CreateEmailTemplate -> CreateEmailTemplate -> Bool
Prelude.Eq, ReadPrec [CreateEmailTemplate]
ReadPrec CreateEmailTemplate
Int -> ReadS CreateEmailTemplate
ReadS [CreateEmailTemplate]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateEmailTemplate]
$creadListPrec :: ReadPrec [CreateEmailTemplate]
readPrec :: ReadPrec CreateEmailTemplate
$creadPrec :: ReadPrec CreateEmailTemplate
readList :: ReadS [CreateEmailTemplate]
$creadList :: ReadS [CreateEmailTemplate]
readsPrec :: Int -> ReadS CreateEmailTemplate
$creadsPrec :: Int -> ReadS CreateEmailTemplate
Prelude.Read, Int -> CreateEmailTemplate -> ShowS
[CreateEmailTemplate] -> ShowS
CreateEmailTemplate -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateEmailTemplate] -> ShowS
$cshowList :: [CreateEmailTemplate] -> ShowS
show :: CreateEmailTemplate -> String
$cshow :: CreateEmailTemplate -> String
showsPrec :: Int -> CreateEmailTemplate -> ShowS
$cshowsPrec :: Int -> CreateEmailTemplate -> ShowS
Prelude.Show, forall x. Rep CreateEmailTemplate x -> CreateEmailTemplate
forall x. CreateEmailTemplate -> Rep CreateEmailTemplate x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateEmailTemplate x -> CreateEmailTemplate
$cfrom :: forall x. CreateEmailTemplate -> Rep CreateEmailTemplate x
Prelude.Generic)
newCreateEmailTemplate ::
Prelude.Text ->
EmailTemplateContent ->
CreateEmailTemplate
newCreateEmailTemplate :: Text -> EmailTemplateContent -> CreateEmailTemplate
newCreateEmailTemplate
Text
pTemplateName_
EmailTemplateContent
pTemplateContent_ =
CreateEmailTemplate'
{ $sel:templateName:CreateEmailTemplate' :: Text
templateName = Text
pTemplateName_,
$sel:templateContent:CreateEmailTemplate' :: EmailTemplateContent
templateContent = EmailTemplateContent
pTemplateContent_
}
createEmailTemplate_templateName :: Lens.Lens' CreateEmailTemplate Prelude.Text
createEmailTemplate_templateName :: Lens' CreateEmailTemplate Text
createEmailTemplate_templateName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateEmailTemplate' {Text
templateName :: Text
$sel:templateName:CreateEmailTemplate' :: CreateEmailTemplate -> Text
templateName} -> Text
templateName) (\s :: CreateEmailTemplate
s@CreateEmailTemplate' {} Text
a -> CreateEmailTemplate
s {$sel:templateName:CreateEmailTemplate' :: Text
templateName = Text
a} :: CreateEmailTemplate)
createEmailTemplate_templateContent :: Lens.Lens' CreateEmailTemplate EmailTemplateContent
createEmailTemplate_templateContent :: Lens' CreateEmailTemplate EmailTemplateContent
createEmailTemplate_templateContent = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateEmailTemplate' {EmailTemplateContent
templateContent :: EmailTemplateContent
$sel:templateContent:CreateEmailTemplate' :: CreateEmailTemplate -> EmailTemplateContent
templateContent} -> EmailTemplateContent
templateContent) (\s :: CreateEmailTemplate
s@CreateEmailTemplate' {} EmailTemplateContent
a -> CreateEmailTemplate
s {$sel:templateContent:CreateEmailTemplate' :: EmailTemplateContent
templateContent = EmailTemplateContent
a} :: CreateEmailTemplate)
instance Core.AWSRequest CreateEmailTemplate where
type
AWSResponse CreateEmailTemplate =
CreateEmailTemplateResponse
request :: (Service -> Service)
-> CreateEmailTemplate -> Request CreateEmailTemplate
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 CreateEmailTemplate
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse CreateEmailTemplate)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> () -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveEmpty
( \Int
s ResponseHeaders
h ()
x ->
Int -> CreateEmailTemplateResponse
CreateEmailTemplateResponse'
forall (f :: * -> *) a b. Functor 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 CreateEmailTemplate where
hashWithSalt :: Int -> CreateEmailTemplate -> Int
hashWithSalt Int
_salt CreateEmailTemplate' {Text
EmailTemplateContent
templateContent :: EmailTemplateContent
templateName :: Text
$sel:templateContent:CreateEmailTemplate' :: CreateEmailTemplate -> EmailTemplateContent
$sel:templateName:CreateEmailTemplate' :: CreateEmailTemplate -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
templateName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` EmailTemplateContent
templateContent
instance Prelude.NFData CreateEmailTemplate where
rnf :: CreateEmailTemplate -> ()
rnf CreateEmailTemplate' {Text
EmailTemplateContent
templateContent :: EmailTemplateContent
templateName :: Text
$sel:templateContent:CreateEmailTemplate' :: CreateEmailTemplate -> EmailTemplateContent
$sel:templateName:CreateEmailTemplate' :: CreateEmailTemplate -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
templateName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf EmailTemplateContent
templateContent
instance Data.ToHeaders CreateEmailTemplate where
toHeaders :: CreateEmailTemplate -> 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 CreateEmailTemplate where
toJSON :: CreateEmailTemplate -> Value
toJSON CreateEmailTemplate' {Text
EmailTemplateContent
templateContent :: EmailTemplateContent
templateName :: Text
$sel:templateContent:CreateEmailTemplate' :: CreateEmailTemplate -> EmailTemplateContent
$sel:templateName:CreateEmailTemplate' :: CreateEmailTemplate -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just (Key
"TemplateName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
templateName),
forall a. a -> Maybe a
Prelude.Just
(Key
"TemplateContent" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= EmailTemplateContent
templateContent)
]
)
instance Data.ToPath CreateEmailTemplate where
toPath :: CreateEmailTemplate -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/v2/email/templates"
instance Data.ToQuery CreateEmailTemplate where
toQuery :: CreateEmailTemplate -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data CreateEmailTemplateResponse = CreateEmailTemplateResponse'
{
CreateEmailTemplateResponse -> Int
httpStatus :: Prelude.Int
}
deriving (CreateEmailTemplateResponse -> CreateEmailTemplateResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateEmailTemplateResponse -> CreateEmailTemplateResponse -> Bool
$c/= :: CreateEmailTemplateResponse -> CreateEmailTemplateResponse -> Bool
== :: CreateEmailTemplateResponse -> CreateEmailTemplateResponse -> Bool
$c== :: CreateEmailTemplateResponse -> CreateEmailTemplateResponse -> Bool
Prelude.Eq, ReadPrec [CreateEmailTemplateResponse]
ReadPrec CreateEmailTemplateResponse
Int -> ReadS CreateEmailTemplateResponse
ReadS [CreateEmailTemplateResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateEmailTemplateResponse]
$creadListPrec :: ReadPrec [CreateEmailTemplateResponse]
readPrec :: ReadPrec CreateEmailTemplateResponse
$creadPrec :: ReadPrec CreateEmailTemplateResponse
readList :: ReadS [CreateEmailTemplateResponse]
$creadList :: ReadS [CreateEmailTemplateResponse]
readsPrec :: Int -> ReadS CreateEmailTemplateResponse
$creadsPrec :: Int -> ReadS CreateEmailTemplateResponse
Prelude.Read, Int -> CreateEmailTemplateResponse -> ShowS
[CreateEmailTemplateResponse] -> ShowS
CreateEmailTemplateResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateEmailTemplateResponse] -> ShowS
$cshowList :: [CreateEmailTemplateResponse] -> ShowS
show :: CreateEmailTemplateResponse -> String
$cshow :: CreateEmailTemplateResponse -> String
showsPrec :: Int -> CreateEmailTemplateResponse -> ShowS
$cshowsPrec :: Int -> CreateEmailTemplateResponse -> ShowS
Prelude.Show, forall x.
Rep CreateEmailTemplateResponse x -> CreateEmailTemplateResponse
forall x.
CreateEmailTemplateResponse -> Rep CreateEmailTemplateResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateEmailTemplateResponse x -> CreateEmailTemplateResponse
$cfrom :: forall x.
CreateEmailTemplateResponse -> Rep CreateEmailTemplateResponse x
Prelude.Generic)
newCreateEmailTemplateResponse ::
Prelude.Int ->
CreateEmailTemplateResponse
newCreateEmailTemplateResponse :: Int -> CreateEmailTemplateResponse
newCreateEmailTemplateResponse Int
pHttpStatus_ =
CreateEmailTemplateResponse'
{ $sel:httpStatus:CreateEmailTemplateResponse' :: Int
httpStatus =
Int
pHttpStatus_
}
createEmailTemplateResponse_httpStatus :: Lens.Lens' CreateEmailTemplateResponse Prelude.Int
createEmailTemplateResponse_httpStatus :: Lens' CreateEmailTemplateResponse Int
createEmailTemplateResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateEmailTemplateResponse' {Int
httpStatus :: Int
$sel:httpStatus:CreateEmailTemplateResponse' :: CreateEmailTemplateResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: CreateEmailTemplateResponse
s@CreateEmailTemplateResponse' {} Int
a -> CreateEmailTemplateResponse
s {$sel:httpStatus:CreateEmailTemplateResponse' :: Int
httpStatus = Int
a} :: CreateEmailTemplateResponse)
instance Prelude.NFData CreateEmailTemplateResponse where
rnf :: CreateEmailTemplateResponse -> ()
rnf CreateEmailTemplateResponse' {Int
httpStatus :: Int
$sel:httpStatus:CreateEmailTemplateResponse' :: CreateEmailTemplateResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus