module Network.AWS.Discovery.DescribeTags
(
describeTags
, DescribeTags
, dtFilters
, dtNextToken
, dtMaxResults
, describeTagsResponse
, DescribeTagsResponse
, dtrsNextToken
, dtrsTags
, dtrsResponseStatus
) where
import Network.AWS.Discovery.Types
import Network.AWS.Discovery.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data DescribeTags = DescribeTags'
{ _dtFilters :: !(Maybe [TagFilter])
, _dtNextToken :: !(Maybe Text)
, _dtMaxResults :: !(Maybe Int)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeTags
:: DescribeTags
describeTags =
DescribeTags'
{_dtFilters = Nothing, _dtNextToken = Nothing, _dtMaxResults = Nothing}
dtFilters :: Lens' DescribeTags [TagFilter]
dtFilters = lens _dtFilters (\ s a -> s{_dtFilters = a}) . _Default . _Coerce;
dtNextToken :: Lens' DescribeTags (Maybe Text)
dtNextToken = lens _dtNextToken (\ s a -> s{_dtNextToken = a});
dtMaxResults :: Lens' DescribeTags (Maybe Int)
dtMaxResults = lens _dtMaxResults (\ s a -> s{_dtMaxResults = a});
instance AWSRequest DescribeTags where
type Rs DescribeTags = DescribeTagsResponse
request = postJSON discovery
response
= receiveJSON
(\ s h x ->
DescribeTagsResponse' <$>
(x .?> "nextToken") <*> (x .?> "tags" .!@ mempty) <*>
(pure (fromEnum s)))
instance Hashable DescribeTags where
instance NFData DescribeTags where
instance ToHeaders DescribeTags where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AWSPoseidonService_V2015_11_01.DescribeTags" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DescribeTags where
toJSON DescribeTags'{..}
= object
(catMaybes
[("filters" .=) <$> _dtFilters,
("nextToken" .=) <$> _dtNextToken,
("maxResults" .=) <$> _dtMaxResults])
instance ToPath DescribeTags where
toPath = const "/"
instance ToQuery DescribeTags where
toQuery = const mempty
data DescribeTagsResponse = DescribeTagsResponse'
{ _dtrsNextToken :: !(Maybe Text)
, _dtrsTags :: !(Maybe [ConfigurationTag])
, _dtrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeTagsResponse
:: Int
-> DescribeTagsResponse
describeTagsResponse pResponseStatus_ =
DescribeTagsResponse'
{ _dtrsNextToken = Nothing
, _dtrsTags = Nothing
, _dtrsResponseStatus = pResponseStatus_
}
dtrsNextToken :: Lens' DescribeTagsResponse (Maybe Text)
dtrsNextToken = lens _dtrsNextToken (\ s a -> s{_dtrsNextToken = a});
dtrsTags :: Lens' DescribeTagsResponse [ConfigurationTag]
dtrsTags = lens _dtrsTags (\ s a -> s{_dtrsTags = a}) . _Default . _Coerce;
dtrsResponseStatus :: Lens' DescribeTagsResponse Int
dtrsResponseStatus = lens _dtrsResponseStatus (\ s a -> s{_dtrsResponseStatus = a});
instance NFData DescribeTagsResponse where