module Network.AWS.AutoScaling.AttachLoadBalancers
(
attachLoadBalancers
, AttachLoadBalancers
, albAutoScalingGroupName
, albLoadBalancerNames
, attachLoadBalancersResponse
, AttachLoadBalancersResponse
, albrsResponseStatus
) where
import Network.AWS.AutoScaling.Types
import Network.AWS.AutoScaling.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data AttachLoadBalancers = AttachLoadBalancers'
{ _albAutoScalingGroupName :: !(Maybe Text)
, _albLoadBalancerNames :: !(Maybe [Text])
} deriving (Eq,Read,Show,Data,Typeable,Generic)
attachLoadBalancers
:: AttachLoadBalancers
attachLoadBalancers =
AttachLoadBalancers'
{ _albAutoScalingGroupName = Nothing
, _albLoadBalancerNames = Nothing
}
albAutoScalingGroupName :: Lens' AttachLoadBalancers (Maybe Text)
albAutoScalingGroupName = lens _albAutoScalingGroupName (\ s a -> s{_albAutoScalingGroupName = a});
albLoadBalancerNames :: Lens' AttachLoadBalancers [Text]
albLoadBalancerNames = lens _albLoadBalancerNames (\ s a -> s{_albLoadBalancerNames = a}) . _Default . _Coerce;
instance AWSRequest AttachLoadBalancers where
type Rs AttachLoadBalancers =
AttachLoadBalancersResponse
request = postQuery autoScaling
response
= receiveXMLWrapper "AttachLoadBalancersResult"
(\ s h x ->
AttachLoadBalancersResponse' <$> (pure (fromEnum s)))
instance Hashable AttachLoadBalancers
instance NFData AttachLoadBalancers
instance ToHeaders AttachLoadBalancers where
toHeaders = const mempty
instance ToPath AttachLoadBalancers where
toPath = const "/"
instance ToQuery AttachLoadBalancers where
toQuery AttachLoadBalancers'{..}
= mconcat
["Action" =: ("AttachLoadBalancers" :: ByteString),
"Version" =: ("2011-01-01" :: ByteString),
"AutoScalingGroupName" =: _albAutoScalingGroupName,
"LoadBalancerNames" =:
toQuery
(toQueryList "member" <$> _albLoadBalancerNames)]
newtype AttachLoadBalancersResponse = AttachLoadBalancersResponse'
{ _albrsResponseStatus :: Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
attachLoadBalancersResponse
:: Int
-> AttachLoadBalancersResponse
attachLoadBalancersResponse pResponseStatus_ =
AttachLoadBalancersResponse'
{ _albrsResponseStatus = pResponseStatus_
}
albrsResponseStatus :: Lens' AttachLoadBalancersResponse Int
albrsResponseStatus = lens _albrsResponseStatus (\ s a -> s{_albrsResponseStatus = a});
instance NFData AttachLoadBalancersResponse