{-# 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.ModifySpotFleetRequest
(
modifySpotFleetRequest
, ModifySpotFleetRequest
, msfrTargetCapacity
, msfrExcessCapacityTerminationPolicy
, msfrSpotFleetRequestId
, modifySpotFleetRequestResponse
, ModifySpotFleetRequestResponse
, msfrrsReturn
, msfrrsResponseStatus
) 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 ModifySpotFleetRequest = ModifySpotFleetRequest'
{ _msfrTargetCapacity :: !(Maybe Int)
, _msfrExcessCapacityTerminationPolicy :: !(Maybe ExcessCapacityTerminationPolicy)
, _msfrSpotFleetRequestId :: !Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
modifySpotFleetRequest
:: Text
-> ModifySpotFleetRequest
modifySpotFleetRequest pSpotFleetRequestId_ =
ModifySpotFleetRequest'
{ _msfrTargetCapacity = Nothing
, _msfrExcessCapacityTerminationPolicy = Nothing
, _msfrSpotFleetRequestId = pSpotFleetRequestId_
}
msfrTargetCapacity :: Lens' ModifySpotFleetRequest (Maybe Int)
msfrTargetCapacity = lens _msfrTargetCapacity (\ s a -> s{_msfrTargetCapacity = a});
msfrExcessCapacityTerminationPolicy :: Lens' ModifySpotFleetRequest (Maybe ExcessCapacityTerminationPolicy)
msfrExcessCapacityTerminationPolicy = lens _msfrExcessCapacityTerminationPolicy (\ s a -> s{_msfrExcessCapacityTerminationPolicy = a});
msfrSpotFleetRequestId :: Lens' ModifySpotFleetRequest Text
msfrSpotFleetRequestId = lens _msfrSpotFleetRequestId (\ s a -> s{_msfrSpotFleetRequestId = a});
instance AWSRequest ModifySpotFleetRequest where
type Rs ModifySpotFleetRequest =
ModifySpotFleetRequestResponse
request = postQuery ec2
response
= receiveXML
(\ s h x ->
ModifySpotFleetRequestResponse' <$>
(x .@? "return") <*> (pure (fromEnum s)))
instance Hashable ModifySpotFleetRequest
instance NFData ModifySpotFleetRequest
instance ToHeaders ModifySpotFleetRequest where
toHeaders = const mempty
instance ToPath ModifySpotFleetRequest where
toPath = const "/"
instance ToQuery ModifySpotFleetRequest where
toQuery ModifySpotFleetRequest'{..}
= mconcat
["Action" =:
("ModifySpotFleetRequest" :: ByteString),
"Version" =: ("2016-11-15" :: ByteString),
"TargetCapacity" =: _msfrTargetCapacity,
"ExcessCapacityTerminationPolicy" =:
_msfrExcessCapacityTerminationPolicy,
"SpotFleetRequestId" =: _msfrSpotFleetRequestId]
data ModifySpotFleetRequestResponse = ModifySpotFleetRequestResponse'
{ _msfrrsReturn :: !(Maybe Bool)
, _msfrrsResponseStatus :: !Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
modifySpotFleetRequestResponse
:: Int
-> ModifySpotFleetRequestResponse
modifySpotFleetRequestResponse pResponseStatus_ =
ModifySpotFleetRequestResponse'
{ _msfrrsReturn = Nothing
, _msfrrsResponseStatus = pResponseStatus_
}
msfrrsReturn :: Lens' ModifySpotFleetRequestResponse (Maybe Bool)
msfrrsReturn = lens _msfrrsReturn (\ s a -> s{_msfrrsReturn = a});
msfrrsResponseStatus :: Lens' ModifySpotFleetRequestResponse Int
msfrrsResponseStatus = lens _msfrrsResponseStatus (\ s a -> s{_msfrrsResponseStatus = a});
instance NFData ModifySpotFleetRequestResponse