module Network.AWS.DirectoryService.UpdateConditionalForwarder
(
updateConditionalForwarder
, UpdateConditionalForwarder
, ucfDirectoryId
, ucfRemoteDomainName
, ucfDNSIPAddrs
, updateConditionalForwarderResponse
, UpdateConditionalForwarderResponse
, ucfrsResponseStatus
) 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 UpdateConditionalForwarder = UpdateConditionalForwarder'
{ _ucfDirectoryId :: !Text
, _ucfRemoteDomainName :: !Text
, _ucfDNSIPAddrs :: ![Text]
} deriving (Eq,Read,Show,Data,Typeable,Generic)
updateConditionalForwarder
:: Text
-> Text
-> UpdateConditionalForwarder
updateConditionalForwarder pDirectoryId_ pRemoteDomainName_ =
UpdateConditionalForwarder'
{ _ucfDirectoryId = pDirectoryId_
, _ucfRemoteDomainName = pRemoteDomainName_
, _ucfDNSIPAddrs = mempty
}
ucfDirectoryId :: Lens' UpdateConditionalForwarder Text
ucfDirectoryId = lens _ucfDirectoryId (\ s a -> s{_ucfDirectoryId = a});
ucfRemoteDomainName :: Lens' UpdateConditionalForwarder Text
ucfRemoteDomainName = lens _ucfRemoteDomainName (\ s a -> s{_ucfRemoteDomainName = a});
ucfDNSIPAddrs :: Lens' UpdateConditionalForwarder [Text]
ucfDNSIPAddrs = lens _ucfDNSIPAddrs (\ s a -> s{_ucfDNSIPAddrs = a}) . _Coerce;
instance AWSRequest UpdateConditionalForwarder where
type Rs UpdateConditionalForwarder =
UpdateConditionalForwarderResponse
request = postJSON directoryService
response
= receiveEmpty
(\ s h x ->
UpdateConditionalForwarderResponse' <$>
(pure (fromEnum s)))
instance Hashable UpdateConditionalForwarder
instance NFData UpdateConditionalForwarder
instance ToHeaders UpdateConditionalForwarder where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("DirectoryService_20150416.UpdateConditionalForwarder"
:: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON UpdateConditionalForwarder where
toJSON UpdateConditionalForwarder'{..}
= object
(catMaybes
[Just ("DirectoryId" .= _ucfDirectoryId),
Just ("RemoteDomainName" .= _ucfRemoteDomainName),
Just ("DnsIpAddrs" .= _ucfDNSIPAddrs)])
instance ToPath UpdateConditionalForwarder where
toPath = const "/"
instance ToQuery UpdateConditionalForwarder where
toQuery = const mempty
newtype UpdateConditionalForwarderResponse = UpdateConditionalForwarderResponse'
{ _ucfrsResponseStatus :: Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
updateConditionalForwarderResponse
:: Int
-> UpdateConditionalForwarderResponse
updateConditionalForwarderResponse pResponseStatus_ =
UpdateConditionalForwarderResponse'
{ _ucfrsResponseStatus = pResponseStatus_
}
ucfrsResponseStatus :: Lens' UpdateConditionalForwarderResponse Int
ucfrsResponseStatus = lens _ucfrsResponseStatus (\ s a -> s{_ucfrsResponseStatus = a});
instance NFData UpdateConditionalForwarderResponse