{-# 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.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 where
instance NFData UpdateConditionalForwarder where
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
where