{-# 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.CloudFormation.GetTemplate
(
getTemplate
, GetTemplate
, gtStackName
, getTemplateResponse
, GetTemplateResponse
, gtrsTemplateBody
, gtrsResponseStatus
) where
import Network.AWS.CloudFormation.Types
import Network.AWS.CloudFormation.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
newtype GetTemplate = GetTemplate'
{ _gtStackName :: Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
getTemplate
:: Text
-> GetTemplate
getTemplate pStackName_ =
GetTemplate'
{ _gtStackName = pStackName_
}
gtStackName :: Lens' GetTemplate Text
gtStackName = lens _gtStackName (\ s a -> s{_gtStackName = a});
instance AWSRequest GetTemplate where
type Rs GetTemplate = GetTemplateResponse
request = postQuery cloudFormation
response
= receiveXMLWrapper "GetTemplateResult"
(\ s h x ->
GetTemplateResponse' <$>
(x .@? "TemplateBody") <*> (pure (fromEnum s)))
instance Hashable GetTemplate
instance NFData GetTemplate
instance ToHeaders GetTemplate where
toHeaders = const mempty
instance ToPath GetTemplate where
toPath = const "/"
instance ToQuery GetTemplate where
toQuery GetTemplate'{..}
= mconcat
["Action" =: ("GetTemplate" :: ByteString),
"Version" =: ("2010-05-15" :: ByteString),
"StackName" =: _gtStackName]
data GetTemplateResponse = GetTemplateResponse'
{ _gtrsTemplateBody :: !(Maybe Text)
, _gtrsResponseStatus :: !Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
getTemplateResponse
:: Int
-> GetTemplateResponse
getTemplateResponse pResponseStatus_ =
GetTemplateResponse'
{ _gtrsTemplateBody = Nothing
, _gtrsResponseStatus = pResponseStatus_
}
gtrsTemplateBody :: Lens' GetTemplateResponse (Maybe Text)
gtrsTemplateBody = lens _gtrsTemplateBody (\ s a -> s{_gtrsTemplateBody = a});
gtrsResponseStatus :: Lens' GetTemplateResponse Int
gtrsResponseStatus = lens _gtrsResponseStatus (\ s a -> s{_gtrsResponseStatus = a});
instance NFData GetTemplateResponse