{-# 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.Greengrass.ListDeployments
(
listDeployments
, ListDeployments
, lNextToken
, lMaxResults
, lGroupId
, listDeploymentsResponse
, ListDeploymentsResponse
, ldrsNextToken
, ldrsDeployments
, ldrsResponseStatus
) where
import Network.AWS.Greengrass.Types
import Network.AWS.Greengrass.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data ListDeployments = ListDeployments'
{ _lNextToken :: !(Maybe Text)
, _lMaxResults :: !(Maybe Text)
, _lGroupId :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listDeployments
:: Text
-> ListDeployments
listDeployments pGroupId_ =
ListDeployments'
{_lNextToken = Nothing, _lMaxResults = Nothing, _lGroupId = pGroupId_}
lNextToken :: Lens' ListDeployments (Maybe Text)
lNextToken = lens _lNextToken (\ s a -> s{_lNextToken = a})
lMaxResults :: Lens' ListDeployments (Maybe Text)
lMaxResults = lens _lMaxResults (\ s a -> s{_lMaxResults = a})
lGroupId :: Lens' ListDeployments Text
lGroupId = lens _lGroupId (\ s a -> s{_lGroupId = a})
instance AWSRequest ListDeployments where
type Rs ListDeployments = ListDeploymentsResponse
request = get greengrass
response
= receiveJSON
(\ s h x ->
ListDeploymentsResponse' <$>
(x .?> "NextToken") <*>
(x .?> "Deployments" .!@ mempty)
<*> (pure (fromEnum s)))
instance Hashable ListDeployments where
instance NFData ListDeployments where
instance ToHeaders ListDeployments where
toHeaders
= const
(mconcat
["Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToPath ListDeployments where
toPath ListDeployments'{..}
= mconcat
["/greengrass/groups/", toBS _lGroupId,
"/deployments"]
instance ToQuery ListDeployments where
toQuery ListDeployments'{..}
= mconcat
["NextToken" =: _lNextToken,
"MaxResults" =: _lMaxResults]
data ListDeploymentsResponse = ListDeploymentsResponse'
{ _ldrsNextToken :: !(Maybe Text)
, _ldrsDeployments :: !(Maybe [Deployment])
, _ldrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listDeploymentsResponse
:: Int
-> ListDeploymentsResponse
listDeploymentsResponse pResponseStatus_ =
ListDeploymentsResponse'
{ _ldrsNextToken = Nothing
, _ldrsDeployments = Nothing
, _ldrsResponseStatus = pResponseStatus_
}
ldrsNextToken :: Lens' ListDeploymentsResponse (Maybe Text)
ldrsNextToken = lens _ldrsNextToken (\ s a -> s{_ldrsNextToken = a})
ldrsDeployments :: Lens' ListDeploymentsResponse [Deployment]
ldrsDeployments = lens _ldrsDeployments (\ s a -> s{_ldrsDeployments = a}) . _Default . _Coerce
ldrsResponseStatus :: Lens' ListDeploymentsResponse Int
ldrsResponseStatus = lens _ldrsResponseStatus (\ s a -> s{_ldrsResponseStatus = a})
instance NFData ListDeploymentsResponse where