{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Network.AWS.SES.TestRenderTemplate
(
testRenderTemplate
, TestRenderTemplate
, trtTemplateName
, trtTemplateData
, testRenderTemplateResponse
, TestRenderTemplateResponse
, trtrsRenderedTemplate
, trtrsResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
import Network.AWS.SES.Types
import Network.AWS.SES.Types.Product
data TestRenderTemplate = TestRenderTemplate'
{ _trtTemplateName :: !Text
, _trtTemplateData :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
testRenderTemplate
:: Text
-> Text
-> TestRenderTemplate
testRenderTemplate pTemplateName_ pTemplateData_ =
TestRenderTemplate'
{_trtTemplateName = pTemplateName_, _trtTemplateData = pTemplateData_}
trtTemplateName :: Lens' TestRenderTemplate Text
trtTemplateName = lens _trtTemplateName (\ s a -> s{_trtTemplateName = a})
trtTemplateData :: Lens' TestRenderTemplate Text
trtTemplateData = lens _trtTemplateData (\ s a -> s{_trtTemplateData = a})
instance AWSRequest TestRenderTemplate where
type Rs TestRenderTemplate =
TestRenderTemplateResponse
request = postQuery ses
response
= receiveXMLWrapper "TestRenderTemplateResult"
(\ s h x ->
TestRenderTemplateResponse' <$>
(x .@? "RenderedTemplate") <*> (pure (fromEnum s)))
instance Hashable TestRenderTemplate where
instance NFData TestRenderTemplate where
instance ToHeaders TestRenderTemplate where
toHeaders = const mempty
instance ToPath TestRenderTemplate where
toPath = const "/"
instance ToQuery TestRenderTemplate where
toQuery TestRenderTemplate'{..}
= mconcat
["Action" =: ("TestRenderTemplate" :: ByteString),
"Version" =: ("2010-12-01" :: ByteString),
"TemplateName" =: _trtTemplateName,
"TemplateData" =: _trtTemplateData]
data TestRenderTemplateResponse = TestRenderTemplateResponse'
{ _trtrsRenderedTemplate :: !(Maybe Text)
, _trtrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
testRenderTemplateResponse
:: Int
-> TestRenderTemplateResponse
testRenderTemplateResponse pResponseStatus_ =
TestRenderTemplateResponse'
{_trtrsRenderedTemplate = Nothing, _trtrsResponseStatus = pResponseStatus_}
trtrsRenderedTemplate :: Lens' TestRenderTemplateResponse (Maybe Text)
trtrsRenderedTemplate = lens _trtrsRenderedTemplate (\ s a -> s{_trtrsRenderedTemplate = a})
trtrsResponseStatus :: Lens' TestRenderTemplateResponse Int
trtrsResponseStatus = lens _trtrsResponseStatus (\ s a -> s{_trtrsResponseStatus = a})
instance NFData TestRenderTemplateResponse where