{-# 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.EC2.DescribeAvailabilityZones
(
describeAvailabilityZones
, DescribeAvailabilityZones
, dazZoneNames
, dazFilters
, dazDryRun
, describeAvailabilityZonesResponse
, DescribeAvailabilityZonesResponse
, dazrsAvailabilityZones
, dazrsResponseStatus
) where
import Network.AWS.EC2.Types
import Network.AWS.EC2.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data DescribeAvailabilityZones = DescribeAvailabilityZones'
{ _dazZoneNames :: !(Maybe [Text])
, _dazFilters :: !(Maybe [Filter])
, _dazDryRun :: !(Maybe Bool)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeAvailabilityZones
:: DescribeAvailabilityZones
describeAvailabilityZones =
DescribeAvailabilityZones'
{_dazZoneNames = Nothing, _dazFilters = Nothing, _dazDryRun = Nothing}
dazZoneNames :: Lens' DescribeAvailabilityZones [Text]
dazZoneNames = lens _dazZoneNames (\ s a -> s{_dazZoneNames = a}) . _Default . _Coerce
dazFilters :: Lens' DescribeAvailabilityZones [Filter]
dazFilters = lens _dazFilters (\ s a -> s{_dazFilters = a}) . _Default . _Coerce
dazDryRun :: Lens' DescribeAvailabilityZones (Maybe Bool)
dazDryRun = lens _dazDryRun (\ s a -> s{_dazDryRun = a})
instance AWSRequest DescribeAvailabilityZones where
type Rs DescribeAvailabilityZones =
DescribeAvailabilityZonesResponse
request = postQuery ec2
response
= receiveXML
(\ s h x ->
DescribeAvailabilityZonesResponse' <$>
(x .@? "availabilityZoneInfo" .!@ mempty >>=
may (parseXMLList "item"))
<*> (pure (fromEnum s)))
instance Hashable DescribeAvailabilityZones where
instance NFData DescribeAvailabilityZones where
instance ToHeaders DescribeAvailabilityZones where
toHeaders = const mempty
instance ToPath DescribeAvailabilityZones where
toPath = const "/"
instance ToQuery DescribeAvailabilityZones where
toQuery DescribeAvailabilityZones'{..}
= mconcat
["Action" =:
("DescribeAvailabilityZones" :: ByteString),
"Version" =: ("2016-11-15" :: ByteString),
toQuery (toQueryList "ZoneName" <$> _dazZoneNames),
toQuery (toQueryList "Filter" <$> _dazFilters),
"DryRun" =: _dazDryRun]
data DescribeAvailabilityZonesResponse = DescribeAvailabilityZonesResponse'
{ _dazrsAvailabilityZones :: !(Maybe [AvailabilityZone])
, _dazrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeAvailabilityZonesResponse
:: Int
-> DescribeAvailabilityZonesResponse
describeAvailabilityZonesResponse pResponseStatus_ =
DescribeAvailabilityZonesResponse'
{_dazrsAvailabilityZones = Nothing, _dazrsResponseStatus = pResponseStatus_}
dazrsAvailabilityZones :: Lens' DescribeAvailabilityZonesResponse [AvailabilityZone]
dazrsAvailabilityZones = lens _dazrsAvailabilityZones (\ s a -> s{_dazrsAvailabilityZones = a}) . _Default . _Coerce
dazrsResponseStatus :: Lens' DescribeAvailabilityZonesResponse Int
dazrsResponseStatus = lens _dazrsResponseStatus (\ s a -> s{_dazrsResponseStatus = a})
instance NFData DescribeAvailabilityZonesResponse
where