module Network.AWS.CloudWatchLogs.DeleteMetricFilter
    (
    
      deleteMetricFilter
    , DeleteMetricFilter
    
    , delLogGroupName
    , delFilterName
    
    , deleteMetricFilterResponse
    , DeleteMetricFilterResponse
    ) where
import           Network.AWS.CloudWatchLogs.Types
import           Network.AWS.CloudWatchLogs.Types.Product
import           Network.AWS.Prelude
import           Network.AWS.Request
import           Network.AWS.Response
data DeleteMetricFilter = DeleteMetricFilter'
    { _delLogGroupName :: !Text
    , _delFilterName   :: !Text
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteMetricFilter
    :: Text 
    -> Text 
    -> DeleteMetricFilter
deleteMetricFilter pLogGroupName_ pFilterName_ =
    DeleteMetricFilter'
    { _delLogGroupName = pLogGroupName_
    , _delFilterName = pFilterName_
    }
delLogGroupName :: Lens' DeleteMetricFilter Text
delLogGroupName = lens _delLogGroupName (\ s a -> s{_delLogGroupName = a});
delFilterName :: Lens' DeleteMetricFilter Text
delFilterName = lens _delFilterName (\ s a -> s{_delFilterName = a});
instance AWSRequest DeleteMetricFilter where
        type Rs DeleteMetricFilter =
             DeleteMetricFilterResponse
        request = postJSON cloudWatchLogs
        response = receiveNull DeleteMetricFilterResponse'
instance ToHeaders DeleteMetricFilter where
        toHeaders
          = const
              (mconcat
                 ["X-Amz-Target" =#
                    ("Logs_20140328.DeleteMetricFilter" :: ByteString),
                  "Content-Type" =#
                    ("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DeleteMetricFilter where
        toJSON DeleteMetricFilter'{..}
          = object
              (catMaybes
                 [Just ("logGroupName" .= _delLogGroupName),
                  Just ("filterName" .= _delFilterName)])
instance ToPath DeleteMetricFilter where
        toPath = const "/"
instance ToQuery DeleteMetricFilter where
        toQuery = const mempty
data DeleteMetricFilterResponse =
    DeleteMetricFilterResponse'
    deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteMetricFilterResponse
    :: DeleteMetricFilterResponse
deleteMetricFilterResponse = DeleteMetricFilterResponse'