module Network.AWS.Greengrass.ListGroups
(
listGroups
, ListGroups
, lgNextToken
, lgMaxResults
, listGroupsResponse
, ListGroupsResponse
, lgrsGroups
, lgrsNextToken
, lgrsResponseStatus
) 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 ListGroups = ListGroups'
{ _lgNextToken :: !(Maybe Text)
, _lgMaxResults :: !(Maybe Text)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listGroups
:: ListGroups
listGroups = ListGroups' {_lgNextToken = Nothing, _lgMaxResults = Nothing}
lgNextToken :: Lens' ListGroups (Maybe Text)
lgNextToken = lens _lgNextToken (\ s a -> s{_lgNextToken = a});
lgMaxResults :: Lens' ListGroups (Maybe Text)
lgMaxResults = lens _lgMaxResults (\ s a -> s{_lgMaxResults = a});
instance AWSRequest ListGroups where
type Rs ListGroups = ListGroupsResponse
request = get greengrass
response
= receiveJSON
(\ s h x ->
ListGroupsResponse' <$>
(x .?> "Groups" .!@ mempty) <*> (x .?> "NextToken")
<*> (pure (fromEnum s)))
instance Hashable ListGroups where
instance NFData ListGroups where
instance ToHeaders ListGroups where
toHeaders
= const
(mconcat
["Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToPath ListGroups where
toPath = const "/greengrass/groups"
instance ToQuery ListGroups where
toQuery ListGroups'{..}
= mconcat
["NextToken" =: _lgNextToken,
"MaxResults" =: _lgMaxResults]
data ListGroupsResponse = ListGroupsResponse'
{ _lgrsGroups :: !(Maybe [GroupInformation])
, _lgrsNextToken :: !(Maybe Text)
, _lgrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listGroupsResponse
:: Int
-> ListGroupsResponse
listGroupsResponse pResponseStatus_ =
ListGroupsResponse'
{ _lgrsGroups = Nothing
, _lgrsNextToken = Nothing
, _lgrsResponseStatus = pResponseStatus_
}
lgrsGroups :: Lens' ListGroupsResponse [GroupInformation]
lgrsGroups = lens _lgrsGroups (\ s a -> s{_lgrsGroups = a}) . _Default . _Coerce;
lgrsNextToken :: Lens' ListGroupsResponse (Maybe Text)
lgrsNextToken = lens _lgrsNextToken (\ s a -> s{_lgrsNextToken = a});
lgrsResponseStatus :: Lens' ListGroupsResponse Int
lgrsResponseStatus = lens _lgrsResponseStatus (\ s a -> s{_lgrsResponseStatus = a});
instance NFData ListGroupsResponse where