{-# 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.SSM.DescribeActivations
(
describeActivations
, DescribeActivations
, daFilters
, daNextToken
, daMaxResults
, describeActivationsResponse
, DescribeActivationsResponse
, darsActivationList
, darsNextToken
, darsResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.Pager
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
import Network.AWS.SSM.Types
import Network.AWS.SSM.Types.Product
data DescribeActivations = DescribeActivations'
{ _daFilters :: !(Maybe [DescribeActivationsFilter])
, _daNextToken :: !(Maybe Text)
, _daMaxResults :: !(Maybe Nat)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeActivations
:: DescribeActivations
describeActivations =
DescribeActivations'
{_daFilters = Nothing, _daNextToken = Nothing, _daMaxResults = Nothing}
daFilters :: Lens' DescribeActivations [DescribeActivationsFilter]
daFilters = lens _daFilters (\ s a -> s{_daFilters = a}) . _Default . _Coerce
daNextToken :: Lens' DescribeActivations (Maybe Text)
daNextToken = lens _daNextToken (\ s a -> s{_daNextToken = a})
daMaxResults :: Lens' DescribeActivations (Maybe Natural)
daMaxResults = lens _daMaxResults (\ s a -> s{_daMaxResults = a}) . mapping _Nat
instance AWSPager DescribeActivations where
page rq rs
| stop (rs ^. darsNextToken) = Nothing
| stop (rs ^. darsActivationList) = Nothing
| otherwise =
Just $ rq & daNextToken .~ rs ^. darsNextToken
instance AWSRequest DescribeActivations where
type Rs DescribeActivations =
DescribeActivationsResponse
request = postJSON ssm
response
= receiveJSON
(\ s h x ->
DescribeActivationsResponse' <$>
(x .?> "ActivationList" .!@ mempty) <*>
(x .?> "NextToken")
<*> (pure (fromEnum s)))
instance Hashable DescribeActivations where
instance NFData DescribeActivations where
instance ToHeaders DescribeActivations where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AmazonSSM.DescribeActivations" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DescribeActivations where
toJSON DescribeActivations'{..}
= object
(catMaybes
[("Filters" .=) <$> _daFilters,
("NextToken" .=) <$> _daNextToken,
("MaxResults" .=) <$> _daMaxResults])
instance ToPath DescribeActivations where
toPath = const "/"
instance ToQuery DescribeActivations where
toQuery = const mempty
data DescribeActivationsResponse = DescribeActivationsResponse'
{ _darsActivationList :: !(Maybe [Activation])
, _darsNextToken :: !(Maybe Text)
, _darsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeActivationsResponse
:: Int
-> DescribeActivationsResponse
describeActivationsResponse pResponseStatus_ =
DescribeActivationsResponse'
{ _darsActivationList = Nothing
, _darsNextToken = Nothing
, _darsResponseStatus = pResponseStatus_
}
darsActivationList :: Lens' DescribeActivationsResponse [Activation]
darsActivationList = lens _darsActivationList (\ s a -> s{_darsActivationList = a}) . _Default . _Coerce
darsNextToken :: Lens' DescribeActivationsResponse (Maybe Text)
darsNextToken = lens _darsNextToken (\ s a -> s{_darsNextToken = a})
darsResponseStatus :: Lens' DescribeActivationsResponse Int
darsResponseStatus = lens _darsResponseStatus (\ s a -> s{_darsResponseStatus = a})
instance NFData DescribeActivationsResponse where