{-# 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.ELBv2.CreateRule
(
createRule
, CreateRule
, crListenerARN
, crConditions
, crPriority
, crActions
, createRuleResponse
, CreateRuleResponse
, crrsRules
, crrsResponseStatus
) where
import Network.AWS.ELBv2.Types
import Network.AWS.ELBv2.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data CreateRule = CreateRule'
{ _crListenerARN :: !Text
, _crConditions :: ![RuleCondition]
, _crPriority :: !Nat
, _crActions :: ![Action]
} deriving (Eq,Read,Show,Data,Typeable,Generic)
createRule
:: Text
-> Natural
-> CreateRule
createRule pListenerARN_ pPriority_ =
CreateRule'
{ _crListenerARN = pListenerARN_
, _crConditions = mempty
, _crPriority = _Nat # pPriority_
, _crActions = mempty
}
crListenerARN :: Lens' CreateRule Text
crListenerARN = lens _crListenerARN (\ s a -> s{_crListenerARN = a});
crConditions :: Lens' CreateRule [RuleCondition]
crConditions = lens _crConditions (\ s a -> s{_crConditions = a}) . _Coerce;
crPriority :: Lens' CreateRule Natural
crPriority = lens _crPriority (\ s a -> s{_crPriority = a}) . _Nat;
crActions :: Lens' CreateRule [Action]
crActions = lens _crActions (\ s a -> s{_crActions = a}) . _Coerce;
instance AWSRequest CreateRule where
type Rs CreateRule = CreateRuleResponse
request = postQuery eLBv2
response
= receiveXMLWrapper "CreateRuleResult"
(\ s h x ->
CreateRuleResponse' <$>
(x .@? "Rules" .!@ mempty >>=
may (parseXMLList "member"))
<*> (pure (fromEnum s)))
instance Hashable CreateRule
instance NFData CreateRule
instance ToHeaders CreateRule where
toHeaders = const mempty
instance ToPath CreateRule where
toPath = const "/"
instance ToQuery CreateRule where
toQuery CreateRule'{..}
= mconcat
["Action" =: ("CreateRule" :: ByteString),
"Version" =: ("2015-12-01" :: ByteString),
"ListenerArn" =: _crListenerARN,
"Conditions" =: toQueryList "member" _crConditions,
"Priority" =: _crPriority,
"Actions" =: toQueryList "member" _crActions]
data CreateRuleResponse = CreateRuleResponse'
{ _crrsRules :: !(Maybe [Rule])
, _crrsResponseStatus :: !Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
createRuleResponse
:: Int
-> CreateRuleResponse
createRuleResponse pResponseStatus_ =
CreateRuleResponse'
{ _crrsRules = Nothing
, _crrsResponseStatus = pResponseStatus_
}
crrsRules :: Lens' CreateRuleResponse [Rule]
crrsRules = lens _crrsRules (\ s a -> s{_crrsRules = a}) . _Default . _Coerce;
crrsResponseStatus :: Lens' CreateRuleResponse Int
crrsResponseStatus = lens _crrsResponseStatus (\ s a -> s{_crrsResponseStatus = a});
instance NFData CreateRuleResponse