{-# 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.IoT.ListThingsInThingGroup
(
listThingsInThingGroup
, ListThingsInThingGroup
, ltitgNextToken
, ltitgRecursive
, ltitgMaxResults
, ltitgThingGroupName
, listThingsInThingGroupResponse
, ListThingsInThingGroupResponse
, ltitgrsNextToken
, ltitgrsThings
, ltitgrsResponseStatus
) where
import Network.AWS.IoT.Types
import Network.AWS.IoT.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data ListThingsInThingGroup = ListThingsInThingGroup'
{ _ltitgNextToken :: !(Maybe Text)
, _ltitgRecursive :: !(Maybe Bool)
, _ltitgMaxResults :: !(Maybe Nat)
, _ltitgThingGroupName :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listThingsInThingGroup
:: Text
-> ListThingsInThingGroup
listThingsInThingGroup pThingGroupName_ =
ListThingsInThingGroup'
{ _ltitgNextToken = Nothing
, _ltitgRecursive = Nothing
, _ltitgMaxResults = Nothing
, _ltitgThingGroupName = pThingGroupName_
}
ltitgNextToken :: Lens' ListThingsInThingGroup (Maybe Text)
ltitgNextToken = lens _ltitgNextToken (\ s a -> s{_ltitgNextToken = a})
ltitgRecursive :: Lens' ListThingsInThingGroup (Maybe Bool)
ltitgRecursive = lens _ltitgRecursive (\ s a -> s{_ltitgRecursive = a})
ltitgMaxResults :: Lens' ListThingsInThingGroup (Maybe Natural)
ltitgMaxResults = lens _ltitgMaxResults (\ s a -> s{_ltitgMaxResults = a}) . mapping _Nat
ltitgThingGroupName :: Lens' ListThingsInThingGroup Text
ltitgThingGroupName = lens _ltitgThingGroupName (\ s a -> s{_ltitgThingGroupName = a})
instance AWSRequest ListThingsInThingGroup where
type Rs ListThingsInThingGroup =
ListThingsInThingGroupResponse
request = get ioT
response
= receiveJSON
(\ s h x ->
ListThingsInThingGroupResponse' <$>
(x .?> "nextToken") <*> (x .?> "things" .!@ mempty)
<*> (pure (fromEnum s)))
instance Hashable ListThingsInThingGroup where
instance NFData ListThingsInThingGroup where
instance ToHeaders ListThingsInThingGroup where
toHeaders = const mempty
instance ToPath ListThingsInThingGroup where
toPath ListThingsInThingGroup'{..}
= mconcat
["/thing-groups/", toBS _ltitgThingGroupName,
"/things"]
instance ToQuery ListThingsInThingGroup where
toQuery ListThingsInThingGroup'{..}
= mconcat
["nextToken" =: _ltitgNextToken,
"recursive" =: _ltitgRecursive,
"maxResults" =: _ltitgMaxResults]
data ListThingsInThingGroupResponse = ListThingsInThingGroupResponse'
{ _ltitgrsNextToken :: !(Maybe Text)
, _ltitgrsThings :: !(Maybe [Text])
, _ltitgrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
listThingsInThingGroupResponse
:: Int
-> ListThingsInThingGroupResponse
listThingsInThingGroupResponse pResponseStatus_ =
ListThingsInThingGroupResponse'
{ _ltitgrsNextToken = Nothing
, _ltitgrsThings = Nothing
, _ltitgrsResponseStatus = pResponseStatus_
}
ltitgrsNextToken :: Lens' ListThingsInThingGroupResponse (Maybe Text)
ltitgrsNextToken = lens _ltitgrsNextToken (\ s a -> s{_ltitgrsNextToken = a})
ltitgrsThings :: Lens' ListThingsInThingGroupResponse [Text]
ltitgrsThings = lens _ltitgrsThings (\ s a -> s{_ltitgrsThings = a}) . _Default . _Coerce
ltitgrsResponseStatus :: Lens' ListThingsInThingGroupResponse Int
ltitgrsResponseStatus = lens _ltitgrsResponseStatus (\ s a -> s{_ltitgrsResponseStatus = a})
instance NFData ListThingsInThingGroupResponse where