{-# 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.ResourceGroups.UpdateGroupQuery
(
updateGroupQuery
, UpdateGroupQuery
, ugqGroupName
, ugqResourceQuery
, updateGroupQueryResponse
, UpdateGroupQueryResponse
, ugqrsGroupQuery
, ugqrsResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.ResourceGroups.Types
import Network.AWS.ResourceGroups.Types.Product
import Network.AWS.Response
data UpdateGroupQuery = UpdateGroupQuery'
{ _ugqGroupName :: !Text
, _ugqResourceQuery :: !ResourceQuery
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updateGroupQuery
:: Text
-> ResourceQuery
-> UpdateGroupQuery
updateGroupQuery pGroupName_ pResourceQuery_ =
UpdateGroupQuery'
{_ugqGroupName = pGroupName_, _ugqResourceQuery = pResourceQuery_}
ugqGroupName :: Lens' UpdateGroupQuery Text
ugqGroupName = lens _ugqGroupName (\ s a -> s{_ugqGroupName = a})
ugqResourceQuery :: Lens' UpdateGroupQuery ResourceQuery
ugqResourceQuery = lens _ugqResourceQuery (\ s a -> s{_ugqResourceQuery = a})
instance AWSRequest UpdateGroupQuery where
type Rs UpdateGroupQuery = UpdateGroupQueryResponse
request = putJSON resourceGroups
response
= receiveJSON
(\ s h x ->
UpdateGroupQueryResponse' <$>
(x .?> "GroupQuery") <*> (pure (fromEnum s)))
instance Hashable UpdateGroupQuery where
instance NFData UpdateGroupQuery where
instance ToHeaders UpdateGroupQuery where
toHeaders = const mempty
instance ToJSON UpdateGroupQuery where
toJSON UpdateGroupQuery'{..}
= object
(catMaybes
[Just ("ResourceQuery" .= _ugqResourceQuery)])
instance ToPath UpdateGroupQuery where
toPath UpdateGroupQuery'{..}
= mconcat ["/groups/", toBS _ugqGroupName, "/query"]
instance ToQuery UpdateGroupQuery where
toQuery = const mempty
data UpdateGroupQueryResponse = UpdateGroupQueryResponse'
{ _ugqrsGroupQuery :: !(Maybe GroupQuery)
, _ugqrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updateGroupQueryResponse
:: Int
-> UpdateGroupQueryResponse
updateGroupQueryResponse pResponseStatus_ =
UpdateGroupQueryResponse'
{_ugqrsGroupQuery = Nothing, _ugqrsResponseStatus = pResponseStatus_}
ugqrsGroupQuery :: Lens' UpdateGroupQueryResponse (Maybe GroupQuery)
ugqrsGroupQuery = lens _ugqrsGroupQuery (\ s a -> s{_ugqrsGroupQuery = a})
ugqrsResponseStatus :: Lens' UpdateGroupQueryResponse Int
ugqrsResponseStatus = lens _ugqrsResponseStatus (\ s a -> s{_ugqrsResponseStatus = a})
instance NFData UpdateGroupQueryResponse where