{-# 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.MarketplaceMetering.MeterUsage
(
meterUsage
, MeterUsage
, muProductCode
, muTimestamp
, muUsageDimension
, muUsageQuantity
, muDryRun
, meterUsageResponse
, MeterUsageResponse
, mursMeteringRecordId
, mursResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.MarketplaceMetering.Types
import Network.AWS.MarketplaceMetering.Types.Product
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data MeterUsage = MeterUsage'
{ _muProductCode :: !Text
, _muTimestamp :: !POSIX
, _muUsageDimension :: !Text
, _muUsageQuantity :: !Nat
, _muDryRun :: !Bool
} deriving (Eq, Read, Show, Data, Typeable, Generic)
meterUsage
:: Text
-> UTCTime
-> Text
-> Natural
-> Bool
-> MeterUsage
meterUsage pProductCode_ pTimestamp_ pUsageDimension_ pUsageQuantity_ pDryRun_ =
MeterUsage'
{ _muProductCode = pProductCode_
, _muTimestamp = _Time # pTimestamp_
, _muUsageDimension = pUsageDimension_
, _muUsageQuantity = _Nat # pUsageQuantity_
, _muDryRun = pDryRun_
}
muProductCode :: Lens' MeterUsage Text
muProductCode = lens _muProductCode (\ s a -> s{_muProductCode = a})
muTimestamp :: Lens' MeterUsage UTCTime
muTimestamp = lens _muTimestamp (\ s a -> s{_muTimestamp = a}) . _Time
muUsageDimension :: Lens' MeterUsage Text
muUsageDimension = lens _muUsageDimension (\ s a -> s{_muUsageDimension = a})
muUsageQuantity :: Lens' MeterUsage Natural
muUsageQuantity = lens _muUsageQuantity (\ s a -> s{_muUsageQuantity = a}) . _Nat
muDryRun :: Lens' MeterUsage Bool
muDryRun = lens _muDryRun (\ s a -> s{_muDryRun = a})
instance AWSRequest MeterUsage where
type Rs MeterUsage = MeterUsageResponse
request = postJSON marketplaceMetering
response
= receiveJSON
(\ s h x ->
MeterUsageResponse' <$>
(x .?> "MeteringRecordId") <*> (pure (fromEnum s)))
instance Hashable MeterUsage where
instance NFData MeterUsage where
instance ToHeaders MeterUsage where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AWSMPMeteringService.MeterUsage" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON MeterUsage where
toJSON MeterUsage'{..}
= object
(catMaybes
[Just ("ProductCode" .= _muProductCode),
Just ("Timestamp" .= _muTimestamp),
Just ("UsageDimension" .= _muUsageDimension),
Just ("UsageQuantity" .= _muUsageQuantity),
Just ("DryRun" .= _muDryRun)])
instance ToPath MeterUsage where
toPath = const "/"
instance ToQuery MeterUsage where
toQuery = const mempty
data MeterUsageResponse = MeterUsageResponse'
{ _mursMeteringRecordId :: !(Maybe Text)
, _mursResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
meterUsageResponse
:: Int
-> MeterUsageResponse
meterUsageResponse pResponseStatus_ =
MeterUsageResponse'
{_mursMeteringRecordId = Nothing, _mursResponseStatus = pResponseStatus_}
mursMeteringRecordId :: Lens' MeterUsageResponse (Maybe Text)
mursMeteringRecordId = lens _mursMeteringRecordId (\ s a -> s{_mursMeteringRecordId = a})
mursResponseStatus :: Lens' MeterUsageResponse Int
mursResponseStatus = lens _mursResponseStatus (\ s a -> s{_mursResponseStatus = a})
instance NFData MeterUsageResponse where