{-# 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.ListTemplates
(
listTemplates
, ListTemplates
, ltNextToken
, ltMaxItems
, listTemplatesResponse
, ListTemplatesResponse
, ltrsTemplatesMetadata
, ltrsNextToken
, ltrsResponseStatus
) 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 ListTemplates = ListTemplates'
{ _ltNextToken :: !(Maybe Text)
, _ltMaxItems :: !(Maybe Int)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listTemplates
:: ListTemplates
listTemplates = ListTemplates' {_ltNextToken = Nothing, _ltMaxItems = Nothing}
ltNextToken :: Lens' ListTemplates (Maybe Text)
ltNextToken = lens _ltNextToken (\ s a -> s{_ltNextToken = a})
ltMaxItems :: Lens' ListTemplates (Maybe Int)
ltMaxItems = lens _ltMaxItems (\ s a -> s{_ltMaxItems = a})
instance AWSRequest ListTemplates where
type Rs ListTemplates = ListTemplatesResponse
request = postQuery ses
response
= receiveXMLWrapper "ListTemplatesResult"
(\ s h x ->
ListTemplatesResponse' <$>
(x .@? "TemplatesMetadata" .!@ mempty >>=
may (parseXMLList "member"))
<*> (x .@? "NextToken")
<*> (pure (fromEnum s)))
instance Hashable ListTemplates where
instance NFData ListTemplates where
instance ToHeaders ListTemplates where
toHeaders = const mempty
instance ToPath ListTemplates where
toPath = const "/"
instance ToQuery ListTemplates where
toQuery ListTemplates'{..}
= mconcat
["Action" =: ("ListTemplates" :: ByteString),
"Version" =: ("2010-12-01" :: ByteString),
"NextToken" =: _ltNextToken,
"MaxItems" =: _ltMaxItems]
data ListTemplatesResponse = ListTemplatesResponse'
{ _ltrsTemplatesMetadata :: !(Maybe [TemplateMetadata])
, _ltrsNextToken :: !(Maybe Text)
, _ltrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listTemplatesResponse
:: Int
-> ListTemplatesResponse
listTemplatesResponse pResponseStatus_ =
ListTemplatesResponse'
{ _ltrsTemplatesMetadata = Nothing
, _ltrsNextToken = Nothing
, _ltrsResponseStatus = pResponseStatus_
}
ltrsTemplatesMetadata :: Lens' ListTemplatesResponse [TemplateMetadata]
ltrsTemplatesMetadata = lens _ltrsTemplatesMetadata (\ s a -> s{_ltrsTemplatesMetadata = a}) . _Default . _Coerce
ltrsNextToken :: Lens' ListTemplatesResponse (Maybe Text)
ltrsNextToken = lens _ltrsNextToken (\ s a -> s{_ltrsNextToken = a})
ltrsResponseStatus :: Lens' ListTemplatesResponse Int
ltrsResponseStatus = lens _ltrsResponseStatus (\ s a -> s{_ltrsResponseStatus = a})
instance NFData ListTemplatesResponse where