{-# 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.EC2.DeleteVolume
(
deleteVolume
, DeleteVolume
, dvvDryRun
, dvvVolumeId
, deleteVolumeResponse
, DeleteVolumeResponse
) where
import Network.AWS.EC2.Types
import Network.AWS.EC2.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data DeleteVolume = DeleteVolume'
{ _dvvDryRun :: !(Maybe Bool)
, _dvvVolumeId :: !Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteVolume
:: Text
-> DeleteVolume
deleteVolume pVolumeId_ =
DeleteVolume'
{ _dvvDryRun = Nothing
, _dvvVolumeId = pVolumeId_
}
dvvDryRun :: Lens' DeleteVolume (Maybe Bool)
dvvDryRun = lens _dvvDryRun (\ s a -> s{_dvvDryRun = a});
dvvVolumeId :: Lens' DeleteVolume Text
dvvVolumeId = lens _dvvVolumeId (\ s a -> s{_dvvVolumeId = a});
instance AWSRequest DeleteVolume where
type Rs DeleteVolume = DeleteVolumeResponse
request = postQuery ec2
response = receiveNull DeleteVolumeResponse'
instance Hashable DeleteVolume
instance NFData DeleteVolume
instance ToHeaders DeleteVolume where
toHeaders = const mempty
instance ToPath DeleteVolume where
toPath = const "/"
instance ToQuery DeleteVolume where
toQuery DeleteVolume'{..}
= mconcat
["Action" =: ("DeleteVolume" :: ByteString),
"Version" =: ("2016-04-01" :: ByteString),
"DryRun" =: _dvvDryRun, "VolumeId" =: _dvvVolumeId]
data DeleteVolumeResponse =
DeleteVolumeResponse'
deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteVolumeResponse
:: DeleteVolumeResponse
deleteVolumeResponse = DeleteVolumeResponse'
instance NFData DeleteVolumeResponse