{-# 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.DeleteTags
(
deleteTags
, DeleteTags
, dtsDryRun
, dtsTags
, dtsResources
, deleteTagsResponse
, DeleteTagsResponse
) 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 DeleteTags = DeleteTags'
{ _dtsDryRun :: !(Maybe Bool)
, _dtsTags :: !(Maybe [Tag])
, _dtsResources :: ![Text]
} deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteTags
:: DeleteTags
deleteTags =
DeleteTags'
{ _dtsDryRun = Nothing
, _dtsTags = Nothing
, _dtsResources = mempty
}
dtsDryRun :: Lens' DeleteTags (Maybe Bool)
dtsDryRun = lens _dtsDryRun (\ s a -> s{_dtsDryRun = a});
dtsTags :: Lens' DeleteTags [Tag]
dtsTags = lens _dtsTags (\ s a -> s{_dtsTags = a}) . _Default . _Coerce;
dtsResources :: Lens' DeleteTags [Text]
dtsResources = lens _dtsResources (\ s a -> s{_dtsResources = a}) . _Coerce;
instance AWSRequest DeleteTags where
type Rs DeleteTags = DeleteTagsResponse
request = postQuery ec2
response = receiveNull DeleteTagsResponse'
instance Hashable DeleteTags
instance NFData DeleteTags
instance ToHeaders DeleteTags where
toHeaders = const mempty
instance ToPath DeleteTags where
toPath = const "/"
instance ToQuery DeleteTags where
toQuery DeleteTags'{..}
= mconcat
["Action" =: ("DeleteTags" :: ByteString),
"Version" =: ("2016-04-01" :: ByteString),
"DryRun" =: _dtsDryRun,
toQuery (toQueryList "Tag" <$> _dtsTags),
toQueryList "ResourceId" _dtsResources]
data DeleteTagsResponse =
DeleteTagsResponse'
deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteTagsResponse
:: DeleteTagsResponse
deleteTagsResponse = DeleteTagsResponse'
instance NFData DeleteTagsResponse