{-# 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.ELBv2.DescribeTags
(
describeTags
, DescribeTags
, dtResourceARNs
, describeTagsResponse
, DescribeTagsResponse
, dtrsTagDescriptions
, dtrsResponseStatus
) where
import Network.AWS.ELBv2.Types
import Network.AWS.ELBv2.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
newtype DescribeTags = DescribeTags'
{ _dtResourceARNs :: [Text]
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeTags
:: DescribeTags
describeTags = DescribeTags' {_dtResourceARNs = mempty}
dtResourceARNs :: Lens' DescribeTags [Text]
dtResourceARNs = lens _dtResourceARNs (\ s a -> s{_dtResourceARNs = a}) . _Coerce
instance AWSRequest DescribeTags where
type Rs DescribeTags = DescribeTagsResponse
request = postQuery eLBv2
response
= receiveXMLWrapper "DescribeTagsResult"
(\ s h x ->
DescribeTagsResponse' <$>
(x .@? "TagDescriptions" .!@ mempty >>=
may (parseXMLList "member"))
<*> (pure (fromEnum s)))
instance Hashable DescribeTags where
instance NFData DescribeTags where
instance ToHeaders DescribeTags where
toHeaders = const mempty
instance ToPath DescribeTags where
toPath = const "/"
instance ToQuery DescribeTags where
toQuery DescribeTags'{..}
= mconcat
["Action" =: ("DescribeTags" :: ByteString),
"Version" =: ("2015-12-01" :: ByteString),
"ResourceArns" =:
toQueryList "member" _dtResourceARNs]
data DescribeTagsResponse = DescribeTagsResponse'
{ _dtrsTagDescriptions :: !(Maybe [TagDescription])
, _dtrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeTagsResponse
:: Int
-> DescribeTagsResponse
describeTagsResponse pResponseStatus_ =
DescribeTagsResponse'
{_dtrsTagDescriptions = Nothing, _dtrsResponseStatus = pResponseStatus_}
dtrsTagDescriptions :: Lens' DescribeTagsResponse [TagDescription]
dtrsTagDescriptions = lens _dtrsTagDescriptions (\ s a -> s{_dtrsTagDescriptions = a}) . _Default . _Coerce
dtrsResponseStatus :: Lens' DescribeTagsResponse Int
dtrsResponseStatus = lens _dtrsResponseStatus (\ s a -> s{_dtrsResponseStatus = a})
instance NFData DescribeTagsResponse where