{-# 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.SES.DeleteReceiptRule
    (
    
      deleteReceiptRule
    , DeleteReceiptRule
    
    , delRuleSetName
    , delRuleName
    
    , deleteReceiptRuleResponse
    , DeleteReceiptRuleResponse
    
    , delrsResponseStatus
    ) where
import           Network.AWS.Lens
import           Network.AWS.Prelude
import           Network.AWS.Request
import           Network.AWS.Response
import           Network.AWS.SES.Types
import           Network.AWS.SES.Types.Product
data DeleteReceiptRule = DeleteReceiptRule'
    { _delRuleSetName :: !Text
    , _delRuleName    :: !Text
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteReceiptRule
    :: Text 
    -> Text 
    -> DeleteReceiptRule
deleteReceiptRule pRuleSetName_ pRuleName_ =
    DeleteReceiptRule'
    { _delRuleSetName = pRuleSetName_
    , _delRuleName = pRuleName_
    }
delRuleSetName :: Lens' DeleteReceiptRule Text
delRuleSetName = lens _delRuleSetName (\ s a -> s{_delRuleSetName = a});
delRuleName :: Lens' DeleteReceiptRule Text
delRuleName = lens _delRuleName (\ s a -> s{_delRuleName = a});
instance AWSRequest DeleteReceiptRule where
        type Rs DeleteReceiptRule = DeleteReceiptRuleResponse
        request = postQuery ses
        response
          = receiveXMLWrapper "DeleteReceiptRuleResult"
              (\ s h x ->
                 DeleteReceiptRuleResponse' <$> (pure (fromEnum s)))
instance Hashable DeleteReceiptRule
instance NFData DeleteReceiptRule
instance ToHeaders DeleteReceiptRule where
        toHeaders = const mempty
instance ToPath DeleteReceiptRule where
        toPath = const "/"
instance ToQuery DeleteReceiptRule where
        toQuery DeleteReceiptRule'{..}
          = mconcat
              ["Action" =: ("DeleteReceiptRule" :: ByteString),
               "Version" =: ("2010-12-01" :: ByteString),
               "RuleSetName" =: _delRuleSetName,
               "RuleName" =: _delRuleName]
newtype DeleteReceiptRuleResponse = DeleteReceiptRuleResponse'
    { _delrsResponseStatus :: Int
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteReceiptRuleResponse
    :: Int 
    -> DeleteReceiptRuleResponse
deleteReceiptRuleResponse pResponseStatus_ =
    DeleteReceiptRuleResponse'
    { _delrsResponseStatus = pResponseStatus_
    }
delrsResponseStatus :: Lens' DeleteReceiptRuleResponse Int
delrsResponseStatus = lens _delrsResponseStatus (\ s a -> s{_delrsResponseStatus = a});
instance NFData DeleteReceiptRuleResponse