{-# 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.EnableMetricsCollection
(
enableMetricsCollection
, EnableMetricsCollection
, emcMetrics
, emcAutoScalingGroupName
, emcGranularity
, enableMetricsCollectionResponse
, EnableMetricsCollectionResponse
) 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 EnableMetricsCollection = EnableMetricsCollection'
{ _emcMetrics :: !(Maybe [Text])
, _emcAutoScalingGroupName :: !Text
, _emcGranularity :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
enableMetricsCollection
:: Text
-> Text
-> EnableMetricsCollection
enableMetricsCollection pAutoScalingGroupName_ pGranularity_ =
EnableMetricsCollection'
{ _emcMetrics = Nothing
, _emcAutoScalingGroupName = pAutoScalingGroupName_
, _emcGranularity = pGranularity_
}
emcMetrics :: Lens' EnableMetricsCollection [Text]
emcMetrics = lens _emcMetrics (\ s a -> s{_emcMetrics = a}) . _Default . _Coerce
emcAutoScalingGroupName :: Lens' EnableMetricsCollection Text
emcAutoScalingGroupName = lens _emcAutoScalingGroupName (\ s a -> s{_emcAutoScalingGroupName = a})
emcGranularity :: Lens' EnableMetricsCollection Text
emcGranularity = lens _emcGranularity (\ s a -> s{_emcGranularity = a})
instance AWSRequest EnableMetricsCollection where
type Rs EnableMetricsCollection =
EnableMetricsCollectionResponse
request = postQuery autoScaling
response
= receiveNull EnableMetricsCollectionResponse'
instance Hashable EnableMetricsCollection where
instance NFData EnableMetricsCollection where
instance ToHeaders EnableMetricsCollection where
toHeaders = const mempty
instance ToPath EnableMetricsCollection where
toPath = const "/"
instance ToQuery EnableMetricsCollection where
toQuery EnableMetricsCollection'{..}
= mconcat
["Action" =:
("EnableMetricsCollection" :: ByteString),
"Version" =: ("2011-01-01" :: ByteString),
"Metrics" =:
toQuery (toQueryList "member" <$> _emcMetrics),
"AutoScalingGroupName" =: _emcAutoScalingGroupName,
"Granularity" =: _emcGranularity]
data EnableMetricsCollectionResponse =
EnableMetricsCollectionResponse'
deriving (Eq, Read, Show, Data, Typeable, Generic)
enableMetricsCollectionResponse
:: EnableMetricsCollectionResponse
enableMetricsCollectionResponse = EnableMetricsCollectionResponse'
instance NFData EnableMetricsCollectionResponse where