{-# 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.CreateDefaultSubnet
(
createDefaultSubnet
, CreateDefaultSubnet
, cdsDryRun
, cdsAvailabilityZone
, createDefaultSubnetResponse
, CreateDefaultSubnetResponse
, cdsrsSubnet
, cdsrsResponseStatus
) 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 CreateDefaultSubnet = CreateDefaultSubnet'
{ _cdsDryRun :: !(Maybe Bool)
, _cdsAvailabilityZone :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
createDefaultSubnet
:: Text
-> CreateDefaultSubnet
createDefaultSubnet pAvailabilityZone_ =
CreateDefaultSubnet'
{_cdsDryRun = Nothing, _cdsAvailabilityZone = pAvailabilityZone_}
cdsDryRun :: Lens' CreateDefaultSubnet (Maybe Bool)
cdsDryRun = lens _cdsDryRun (\ s a -> s{_cdsDryRun = a})
cdsAvailabilityZone :: Lens' CreateDefaultSubnet Text
cdsAvailabilityZone = lens _cdsAvailabilityZone (\ s a -> s{_cdsAvailabilityZone = a})
instance AWSRequest CreateDefaultSubnet where
type Rs CreateDefaultSubnet =
CreateDefaultSubnetResponse
request = postQuery ec2
response
= receiveXML
(\ s h x ->
CreateDefaultSubnetResponse' <$>
(x .@? "subnet") <*> (pure (fromEnum s)))
instance Hashable CreateDefaultSubnet where
instance NFData CreateDefaultSubnet where
instance ToHeaders CreateDefaultSubnet where
toHeaders = const mempty
instance ToPath CreateDefaultSubnet where
toPath = const "/"
instance ToQuery CreateDefaultSubnet where
toQuery CreateDefaultSubnet'{..}
= mconcat
["Action" =: ("CreateDefaultSubnet" :: ByteString),
"Version" =: ("2016-11-15" :: ByteString),
"DryRun" =: _cdsDryRun,
"AvailabilityZone" =: _cdsAvailabilityZone]
data CreateDefaultSubnetResponse = CreateDefaultSubnetResponse'
{ _cdsrsSubnet :: !(Maybe Subnet)
, _cdsrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
createDefaultSubnetResponse
:: Int
-> CreateDefaultSubnetResponse
createDefaultSubnetResponse pResponseStatus_ =
CreateDefaultSubnetResponse'
{_cdsrsSubnet = Nothing, _cdsrsResponseStatus = pResponseStatus_}
cdsrsSubnet :: Lens' CreateDefaultSubnetResponse (Maybe Subnet)
cdsrsSubnet = lens _cdsrsSubnet (\ s a -> s{_cdsrsSubnet = a})
cdsrsResponseStatus :: Lens' CreateDefaultSubnetResponse Int
cdsrsResponseStatus = lens _cdsrsResponseStatus (\ s a -> s{_cdsrsResponseStatus = a})
instance NFData CreateDefaultSubnetResponse where