{-# 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.RequestSpotFleet
(
requestSpotFleet
, RequestSpotFleet
, rsfDryRun
, rsfSpotFleetRequestConfig
, requestSpotFleetResponse
, RequestSpotFleetResponse
, rsfrsResponseStatus
, rsfrsSpotFleetRequestId
) 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 RequestSpotFleet = RequestSpotFleet'
{ _rsfDryRun :: !(Maybe Bool)
, _rsfSpotFleetRequestConfig :: !SpotFleetRequestConfigData
} deriving (Eq,Read,Show,Data,Typeable,Generic)
requestSpotFleet
:: SpotFleetRequestConfigData
-> RequestSpotFleet
requestSpotFleet pSpotFleetRequestConfig_ =
RequestSpotFleet'
{ _rsfDryRun = Nothing
, _rsfSpotFleetRequestConfig = pSpotFleetRequestConfig_
}
rsfDryRun :: Lens' RequestSpotFleet (Maybe Bool)
rsfDryRun = lens _rsfDryRun (\ s a -> s{_rsfDryRun = a});
rsfSpotFleetRequestConfig :: Lens' RequestSpotFleet SpotFleetRequestConfigData
rsfSpotFleetRequestConfig = lens _rsfSpotFleetRequestConfig (\ s a -> s{_rsfSpotFleetRequestConfig = a});
instance AWSRequest RequestSpotFleet where
type Rs RequestSpotFleet = RequestSpotFleetResponse
request = postQuery ec2
response
= receiveXML
(\ s h x ->
RequestSpotFleetResponse' <$>
(pure (fromEnum s)) <*> (x .@ "spotFleetRequestId"))
instance Hashable RequestSpotFleet
instance NFData RequestSpotFleet
instance ToHeaders RequestSpotFleet where
toHeaders = const mempty
instance ToPath RequestSpotFleet where
toPath = const "/"
instance ToQuery RequestSpotFleet where
toQuery RequestSpotFleet'{..}
= mconcat
["Action" =: ("RequestSpotFleet" :: ByteString),
"Version" =: ("2016-04-01" :: ByteString),
"DryRun" =: _rsfDryRun,
"SpotFleetRequestConfig" =:
_rsfSpotFleetRequestConfig]
data RequestSpotFleetResponse = RequestSpotFleetResponse'
{ _rsfrsResponseStatus :: !Int
, _rsfrsSpotFleetRequestId :: !Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
requestSpotFleetResponse
:: Int
-> Text
-> RequestSpotFleetResponse
requestSpotFleetResponse pResponseStatus_ pSpotFleetRequestId_ =
RequestSpotFleetResponse'
{ _rsfrsResponseStatus = pResponseStatus_
, _rsfrsSpotFleetRequestId = pSpotFleetRequestId_
}
rsfrsResponseStatus :: Lens' RequestSpotFleetResponse Int
rsfrsResponseStatus = lens _rsfrsResponseStatus (\ s a -> s{_rsfrsResponseStatus = a});
rsfrsSpotFleetRequestId :: Lens' RequestSpotFleetResponse Text
rsfrsSpotFleetRequestId = lens _rsfrsSpotFleetRequestId (\ s a -> s{_rsfrsSpotFleetRequestId = a});
instance NFData RequestSpotFleetResponse