{-# 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.EC2.CreateLaunchTemplate
(
createLaunchTemplate
, CreateLaunchTemplate
, cltClientToken
, cltVersionDescription
, cltDryRun
, cltLaunchTemplateName
, cltLaunchTemplateData
, createLaunchTemplateResponse
, CreateLaunchTemplateResponse
, cltrsLaunchTemplate
, cltrsResponseStatus
) where
import Network.AWS.EC2.Types
import Network.AWS.EC2.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data CreateLaunchTemplate = CreateLaunchTemplate'
{ _cltClientToken :: !(Maybe Text)
, _cltVersionDescription :: !(Maybe Text)
, _cltDryRun :: !(Maybe Bool)
, _cltLaunchTemplateName :: !Text
, _cltLaunchTemplateData :: !RequestLaunchTemplateData
} deriving (Eq, Read, Show, Data, Typeable, Generic)
createLaunchTemplate
:: Text
-> RequestLaunchTemplateData
-> CreateLaunchTemplate
createLaunchTemplate pLaunchTemplateName_ pLaunchTemplateData_ =
CreateLaunchTemplate'
{ _cltClientToken = Nothing
, _cltVersionDescription = Nothing
, _cltDryRun = Nothing
, _cltLaunchTemplateName = pLaunchTemplateName_
, _cltLaunchTemplateData = pLaunchTemplateData_
}
cltClientToken :: Lens' CreateLaunchTemplate (Maybe Text)
cltClientToken = lens _cltClientToken (\ s a -> s{_cltClientToken = a})
cltVersionDescription :: Lens' CreateLaunchTemplate (Maybe Text)
cltVersionDescription = lens _cltVersionDescription (\ s a -> s{_cltVersionDescription = a})
cltDryRun :: Lens' CreateLaunchTemplate (Maybe Bool)
cltDryRun = lens _cltDryRun (\ s a -> s{_cltDryRun = a})
cltLaunchTemplateName :: Lens' CreateLaunchTemplate Text
cltLaunchTemplateName = lens _cltLaunchTemplateName (\ s a -> s{_cltLaunchTemplateName = a})
cltLaunchTemplateData :: Lens' CreateLaunchTemplate RequestLaunchTemplateData
cltLaunchTemplateData = lens _cltLaunchTemplateData (\ s a -> s{_cltLaunchTemplateData = a})
instance AWSRequest CreateLaunchTemplate where
type Rs CreateLaunchTemplate =
CreateLaunchTemplateResponse
request = postQuery ec2
response
= receiveXML
(\ s h x ->
CreateLaunchTemplateResponse' <$>
(x .@? "launchTemplate") <*> (pure (fromEnum s)))
instance Hashable CreateLaunchTemplate where
instance NFData CreateLaunchTemplate where
instance ToHeaders CreateLaunchTemplate where
toHeaders = const mempty
instance ToPath CreateLaunchTemplate where
toPath = const "/"
instance ToQuery CreateLaunchTemplate where
toQuery CreateLaunchTemplate'{..}
= mconcat
["Action" =: ("CreateLaunchTemplate" :: ByteString),
"Version" =: ("2016-11-15" :: ByteString),
"ClientToken" =: _cltClientToken,
"VersionDescription" =: _cltVersionDescription,
"DryRun" =: _cltDryRun,
"LaunchTemplateName" =: _cltLaunchTemplateName,
"LaunchTemplateData" =: _cltLaunchTemplateData]
data CreateLaunchTemplateResponse = CreateLaunchTemplateResponse'
{ _cltrsLaunchTemplate :: !(Maybe LaunchTemplate)
, _cltrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
createLaunchTemplateResponse
:: Int
-> CreateLaunchTemplateResponse
createLaunchTemplateResponse pResponseStatus_ =
CreateLaunchTemplateResponse'
{_cltrsLaunchTemplate = Nothing, _cltrsResponseStatus = pResponseStatus_}
cltrsLaunchTemplate :: Lens' CreateLaunchTemplateResponse (Maybe LaunchTemplate)
cltrsLaunchTemplate = lens _cltrsLaunchTemplate (\ s a -> s{_cltrsLaunchTemplate = a})
cltrsResponseStatus :: Lens' CreateLaunchTemplateResponse Int
cltrsResponseStatus = lens _cltrsResponseStatus (\ s a -> s{_cltrsResponseStatus = a})
instance NFData CreateLaunchTemplateResponse where