{-# 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.WorkSpaces.DisassociateIPGroups
(
disassociateIPGroups
, DisassociateIPGroups
, digDirectoryId
, digGroupIds
, disassociateIPGroupsResponse
, DisassociateIPGroupsResponse
, digrsResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
import Network.AWS.WorkSpaces.Types
import Network.AWS.WorkSpaces.Types.Product
data DisassociateIPGroups = DisassociateIPGroups'
{ _digDirectoryId :: !Text
, _digGroupIds :: ![Text]
} deriving (Eq, Read, Show, Data, Typeable, Generic)
disassociateIPGroups
:: Text
-> DisassociateIPGroups
disassociateIPGroups pDirectoryId_ =
DisassociateIPGroups' {_digDirectoryId = pDirectoryId_, _digGroupIds = mempty}
digDirectoryId :: Lens' DisassociateIPGroups Text
digDirectoryId = lens _digDirectoryId (\ s a -> s{_digDirectoryId = a})
digGroupIds :: Lens' DisassociateIPGroups [Text]
digGroupIds = lens _digGroupIds (\ s a -> s{_digGroupIds = a}) . _Coerce
instance AWSRequest DisassociateIPGroups where
type Rs DisassociateIPGroups =
DisassociateIPGroupsResponse
request = postJSON workSpaces
response
= receiveEmpty
(\ s h x ->
DisassociateIPGroupsResponse' <$>
(pure (fromEnum s)))
instance Hashable DisassociateIPGroups where
instance NFData DisassociateIPGroups where
instance ToHeaders DisassociateIPGroups where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("WorkspacesService.DisassociateIpGroups" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DisassociateIPGroups where
toJSON DisassociateIPGroups'{..}
= object
(catMaybes
[Just ("DirectoryId" .= _digDirectoryId),
Just ("GroupIds" .= _digGroupIds)])
instance ToPath DisassociateIPGroups where
toPath = const "/"
instance ToQuery DisassociateIPGroups where
toQuery = const mempty
newtype DisassociateIPGroupsResponse = DisassociateIPGroupsResponse'
{ _digrsResponseStatus :: Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
disassociateIPGroupsResponse
:: Int
-> DisassociateIPGroupsResponse
disassociateIPGroupsResponse pResponseStatus_ =
DisassociateIPGroupsResponse' {_digrsResponseStatus = pResponseStatus_}
digrsResponseStatus :: Lens' DisassociateIPGroupsResponse Int
digrsResponseStatus = lens _digrsResponseStatus (\ s a -> s{_digrsResponseStatus = a})
instance NFData DisassociateIPGroupsResponse where