{-# 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.AutoScaling.SuspendProcesses
(
suspendProcesses
, SuspendProcesses
, spScalingProcesses
, spAutoScalingGroupName
, suspendProcessesResponse
, SuspendProcessesResponse
) where
import Network.AWS.AutoScaling.Types
import Network.AWS.AutoScaling.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data SuspendProcesses = SuspendProcesses'
{ _spScalingProcesses :: !(Maybe [Text])
, _spAutoScalingGroupName :: !Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
suspendProcesses
:: Text
-> SuspendProcesses
suspendProcesses pAutoScalingGroupName_ =
SuspendProcesses'
{ _spScalingProcesses = Nothing
, _spAutoScalingGroupName = pAutoScalingGroupName_
}
spScalingProcesses :: Lens' SuspendProcesses [Text]
spScalingProcesses = lens _spScalingProcesses (\ s a -> s{_spScalingProcesses = a}) . _Default . _Coerce;
spAutoScalingGroupName :: Lens' SuspendProcesses Text
spAutoScalingGroupName = lens _spAutoScalingGroupName (\ s a -> s{_spAutoScalingGroupName = a});
instance AWSRequest SuspendProcesses where
type Rs SuspendProcesses = SuspendProcessesResponse
request = postQuery autoScaling
response = receiveNull SuspendProcessesResponse'
instance Hashable SuspendProcesses
instance NFData SuspendProcesses
instance ToHeaders SuspendProcesses where
toHeaders = const mempty
instance ToPath SuspendProcesses where
toPath = const "/"
instance ToQuery SuspendProcesses where
toQuery SuspendProcesses'{..}
= mconcat
["Action" =: ("SuspendProcesses" :: ByteString),
"Version" =: ("2011-01-01" :: ByteString),
"ScalingProcesses" =:
toQuery
(toQueryList "member" <$> _spScalingProcesses),
"AutoScalingGroupName" =: _spAutoScalingGroupName]
data SuspendProcessesResponse =
SuspendProcessesResponse'
deriving (Eq,Read,Show,Data,Typeable,Generic)
suspendProcessesResponse
:: SuspendProcessesResponse
suspendProcessesResponse = SuspendProcessesResponse'
instance NFData SuspendProcessesResponse