{-# 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.DirectoryService.RemoveIPRoutes
(
removeIPRoutes
, RemoveIPRoutes
, rirDirectoryId
, rirCidrIPs
, removeIPRoutesResponse
, RemoveIPRoutesResponse
, rirrsResponseStatus
) where
import Network.AWS.DirectoryService.Types
import Network.AWS.DirectoryService.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data RemoveIPRoutes = RemoveIPRoutes'
{ _rirDirectoryId :: !Text
, _rirCidrIPs :: ![Text]
} deriving (Eq,Read,Show,Data,Typeable,Generic)
removeIPRoutes
:: Text
-> RemoveIPRoutes
removeIPRoutes pDirectoryId_ =
RemoveIPRoutes'
{ _rirDirectoryId = pDirectoryId_
, _rirCidrIPs = mempty
}
rirDirectoryId :: Lens' RemoveIPRoutes Text
rirDirectoryId = lens _rirDirectoryId (\ s a -> s{_rirDirectoryId = a});
rirCidrIPs :: Lens' RemoveIPRoutes [Text]
rirCidrIPs = lens _rirCidrIPs (\ s a -> s{_rirCidrIPs = a}) . _Coerce;
instance AWSRequest RemoveIPRoutes where
type Rs RemoveIPRoutes = RemoveIPRoutesResponse
request = postJSON directoryService
response
= receiveEmpty
(\ s h x ->
RemoveIPRoutesResponse' <$> (pure (fromEnum s)))
instance Hashable RemoveIPRoutes
instance NFData RemoveIPRoutes
instance ToHeaders RemoveIPRoutes where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("DirectoryService_20150416.RemoveIpRoutes" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON RemoveIPRoutes where
toJSON RemoveIPRoutes'{..}
= object
(catMaybes
[Just ("DirectoryId" .= _rirDirectoryId),
Just ("CidrIps" .= _rirCidrIPs)])
instance ToPath RemoveIPRoutes where
toPath = const "/"
instance ToQuery RemoveIPRoutes where
toQuery = const mempty
newtype RemoveIPRoutesResponse = RemoveIPRoutesResponse'
{ _rirrsResponseStatus :: Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
removeIPRoutesResponse
:: Int
-> RemoveIPRoutesResponse
removeIPRoutesResponse pResponseStatus_ =
RemoveIPRoutesResponse'
{ _rirrsResponseStatus = pResponseStatus_
}
rirrsResponseStatus :: Lens' RemoveIPRoutesResponse Int
rirrsResponseStatus = lens _rirrsResponseStatus (\ s a -> s{_rirrsResponseStatus = a});
instance NFData RemoveIPRoutesResponse