{-# 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.DescribeDHCPOptions
(
describeDHCPOptions
, DescribeDHCPOptions
, ddoFilters
, ddoDHCPOptionsIds
, ddoDryRun
, describeDHCPOptionsResponse
, DescribeDHCPOptionsResponse
, ddorsDHCPOptions
, ddorsResponseStatus
) 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 DescribeDHCPOptions = DescribeDHCPOptions'
{ _ddoFilters :: !(Maybe [Filter])
, _ddoDHCPOptionsIds :: !(Maybe [Text])
, _ddoDryRun :: !(Maybe Bool)
} deriving (Eq,Read,Show,Data,Typeable,Generic)
describeDHCPOptions
:: DescribeDHCPOptions
describeDHCPOptions =
DescribeDHCPOptions'
{ _ddoFilters = Nothing
, _ddoDHCPOptionsIds = Nothing
, _ddoDryRun = Nothing
}
ddoFilters :: Lens' DescribeDHCPOptions [Filter]
ddoFilters = lens _ddoFilters (\ s a -> s{_ddoFilters = a}) . _Default . _Coerce;
ddoDHCPOptionsIds :: Lens' DescribeDHCPOptions [Text]
ddoDHCPOptionsIds = lens _ddoDHCPOptionsIds (\ s a -> s{_ddoDHCPOptionsIds = a}) . _Default . _Coerce;
ddoDryRun :: Lens' DescribeDHCPOptions (Maybe Bool)
ddoDryRun = lens _ddoDryRun (\ s a -> s{_ddoDryRun = a});
instance AWSRequest DescribeDHCPOptions where
type Rs DescribeDHCPOptions =
DescribeDHCPOptionsResponse
request = postQuery ec2
response
= receiveXML
(\ s h x ->
DescribeDHCPOptionsResponse' <$>
(x .@? "dhcpOptionsSet" .!@ mempty >>=
may (parseXMLList "item"))
<*> (pure (fromEnum s)))
instance Hashable DescribeDHCPOptions
instance NFData DescribeDHCPOptions
instance ToHeaders DescribeDHCPOptions where
toHeaders = const mempty
instance ToPath DescribeDHCPOptions where
toPath = const "/"
instance ToQuery DescribeDHCPOptions where
toQuery DescribeDHCPOptions'{..}
= mconcat
["Action" =: ("DescribeDhcpOptions" :: ByteString),
"Version" =: ("2016-04-01" :: ByteString),
toQuery (toQueryList "Filter" <$> _ddoFilters),
toQuery
(toQueryList "DhcpOptionsId" <$> _ddoDHCPOptionsIds),
"DryRun" =: _ddoDryRun]
data DescribeDHCPOptionsResponse = DescribeDHCPOptionsResponse'
{ _ddorsDHCPOptions :: !(Maybe [DHCPOptions])
, _ddorsResponseStatus :: !Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
describeDHCPOptionsResponse
:: Int
-> DescribeDHCPOptionsResponse
describeDHCPOptionsResponse pResponseStatus_ =
DescribeDHCPOptionsResponse'
{ _ddorsDHCPOptions = Nothing
, _ddorsResponseStatus = pResponseStatus_
}
ddorsDHCPOptions :: Lens' DescribeDHCPOptionsResponse [DHCPOptions]
ddorsDHCPOptions = lens _ddorsDHCPOptions (\ s a -> s{_ddorsDHCPOptions = a}) . _Default . _Coerce;
ddorsResponseStatus :: Lens' DescribeDHCPOptionsResponse Int
ddorsResponseStatus = lens _ddorsResponseStatus (\ s a -> s{_ddorsResponseStatus = a});
instance NFData DescribeDHCPOptionsResponse