{-# 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.DeletePolicy
(
deletePolicy
, DeletePolicy
, dpAutoScalingGroupName
, dpPolicyName
, deletePolicyResponse
, DeletePolicyResponse
) 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 DeletePolicy = DeletePolicy'
{ _dpAutoScalingGroupName :: !(Maybe Text)
, _dpPolicyName :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
deletePolicy
:: Text
-> DeletePolicy
deletePolicy pPolicyName_ =
DeletePolicy'
{_dpAutoScalingGroupName = Nothing, _dpPolicyName = pPolicyName_}
dpAutoScalingGroupName :: Lens' DeletePolicy (Maybe Text)
dpAutoScalingGroupName = lens _dpAutoScalingGroupName (\ s a -> s{_dpAutoScalingGroupName = a})
dpPolicyName :: Lens' DeletePolicy Text
dpPolicyName = lens _dpPolicyName (\ s a -> s{_dpPolicyName = a})
instance AWSRequest DeletePolicy where
type Rs DeletePolicy = DeletePolicyResponse
request = postQuery autoScaling
response = receiveNull DeletePolicyResponse'
instance Hashable DeletePolicy where
instance NFData DeletePolicy where
instance ToHeaders DeletePolicy where
toHeaders = const mempty
instance ToPath DeletePolicy where
toPath = const "/"
instance ToQuery DeletePolicy where
toQuery DeletePolicy'{..}
= mconcat
["Action" =: ("DeletePolicy" :: ByteString),
"Version" =: ("2011-01-01" :: ByteString),
"AutoScalingGroupName" =: _dpAutoScalingGroupName,
"PolicyName" =: _dpPolicyName]
data DeletePolicyResponse =
DeletePolicyResponse'
deriving (Eq, Read, Show, Data, Typeable, Generic)
deletePolicyResponse
:: DeletePolicyResponse
deletePolicyResponse = DeletePolicyResponse'
instance NFData DeletePolicyResponse where