module Network.AWS.Kinesis.EnableEnhancedMonitoring
(
enableEnhancedMonitoring
, EnableEnhancedMonitoring
, eemStreamName
, eemShardLevelMetrics
, enhancedMonitoringOutput
, EnhancedMonitoringOutput
, emoDesiredShardLevelMetrics
, emoCurrentShardLevelMetrics
, emoStreamName
) where
import Network.AWS.Kinesis.Types
import Network.AWS.Kinesis.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data EnableEnhancedMonitoring = EnableEnhancedMonitoring'
{ _eemStreamName :: !Text
, _eemShardLevelMetrics :: !(List1 MetricsName)
} deriving (Eq,Read,Show,Data,Typeable,Generic)
enableEnhancedMonitoring
:: Text
-> NonEmpty MetricsName
-> EnableEnhancedMonitoring
enableEnhancedMonitoring pStreamName_ pShardLevelMetrics_ =
EnableEnhancedMonitoring'
{ _eemStreamName = pStreamName_
, _eemShardLevelMetrics = _List1 # pShardLevelMetrics_
}
eemStreamName :: Lens' EnableEnhancedMonitoring Text
eemStreamName = lens _eemStreamName (\ s a -> s{_eemStreamName = a});
eemShardLevelMetrics :: Lens' EnableEnhancedMonitoring (NonEmpty MetricsName)
eemShardLevelMetrics = lens _eemShardLevelMetrics (\ s a -> s{_eemShardLevelMetrics = a}) . _List1;
instance AWSRequest EnableEnhancedMonitoring where
type Rs EnableEnhancedMonitoring =
EnhancedMonitoringOutput
request = postJSON kinesis
response = receiveJSON (\ s h x -> eitherParseJSON x)
instance Hashable EnableEnhancedMonitoring
instance NFData EnableEnhancedMonitoring
instance ToHeaders EnableEnhancedMonitoring where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("Kinesis_20131202.EnableEnhancedMonitoring" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON EnableEnhancedMonitoring where
toJSON EnableEnhancedMonitoring'{..}
= object
(catMaybes
[Just ("StreamName" .= _eemStreamName),
Just ("ShardLevelMetrics" .= _eemShardLevelMetrics)])
instance ToPath EnableEnhancedMonitoring where
toPath = const "/"
instance ToQuery EnableEnhancedMonitoring where
toQuery = const mempty