{-# 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.WorkMail.ListGroups
(
listGroups
, ListGroups
, lgNextToken
, lgMaxResults
, lgOrganizationId
, listGroupsResponse
, ListGroupsResponse
, lgrsGroups
, lgrsNextToken
, lgrsResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.Pager
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
import Network.AWS.WorkMail.Types
import Network.AWS.WorkMail.Types.Product
data ListGroups = ListGroups'
{ _lgNextToken :: !(Maybe Text)
, _lgMaxResults :: !(Maybe Nat)
, _lgOrganizationId :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listGroups
:: Text
-> ListGroups
listGroups pOrganizationId_ =
ListGroups'
{ _lgNextToken = Nothing
, _lgMaxResults = Nothing
, _lgOrganizationId = pOrganizationId_
}
lgNextToken :: Lens' ListGroups (Maybe Text)
lgNextToken = lens _lgNextToken (\ s a -> s{_lgNextToken = a})
lgMaxResults :: Lens' ListGroups (Maybe Natural)
lgMaxResults = lens _lgMaxResults (\ s a -> s{_lgMaxResults = a}) . mapping _Nat
lgOrganizationId :: Lens' ListGroups Text
lgOrganizationId = lens _lgOrganizationId (\ s a -> s{_lgOrganizationId = a})
instance AWSPager ListGroups where
page rq rs
| stop (rs ^. lgrsNextToken) = Nothing
| stop (rs ^. lgrsGroups) = Nothing
| otherwise =
Just $ rq & lgNextToken .~ rs ^. lgrsNextToken
instance AWSRequest ListGroups where
type Rs ListGroups = ListGroupsResponse
request = postJSON workMail
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
["X-Amz-Target" =#
("WorkMailService.ListGroups" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON ListGroups where
toJSON ListGroups'{..}
= object
(catMaybes
[("NextToken" .=) <$> _lgNextToken,
("MaxResults" .=) <$> _lgMaxResults,
Just ("OrganizationId" .= _lgOrganizationId)])
instance ToPath ListGroups where
toPath = const "/"
instance ToQuery ListGroups where
toQuery = const mempty
data ListGroupsResponse = ListGroupsResponse'
{ _lgrsGroups :: !(Maybe [Group])
, _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 [Group]
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