{-# 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.EnableVolumeIO
(
enableVolumeIO
, EnableVolumeIO
, evioDryRun
, evioVolumeId
, enableVolumeIOResponse
, EnableVolumeIOResponse
) 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 EnableVolumeIO = EnableVolumeIO'
{ _evioDryRun :: !(Maybe Bool)
, _evioVolumeId :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
enableVolumeIO
:: Text
-> EnableVolumeIO
enableVolumeIO pVolumeId_ =
EnableVolumeIO' {_evioDryRun = Nothing, _evioVolumeId = pVolumeId_}
evioDryRun :: Lens' EnableVolumeIO (Maybe Bool)
evioDryRun = lens _evioDryRun (\ s a -> s{_evioDryRun = a})
evioVolumeId :: Lens' EnableVolumeIO Text
evioVolumeId = lens _evioVolumeId (\ s a -> s{_evioVolumeId = a})
instance AWSRequest EnableVolumeIO where
type Rs EnableVolumeIO = EnableVolumeIOResponse
request = postQuery ec2
response = receiveNull EnableVolumeIOResponse'
instance Hashable EnableVolumeIO where
instance NFData EnableVolumeIO where
instance ToHeaders EnableVolumeIO where
toHeaders = const mempty
instance ToPath EnableVolumeIO where
toPath = const "/"
instance ToQuery EnableVolumeIO where
toQuery EnableVolumeIO'{..}
= mconcat
["Action" =: ("EnableVolumeIO" :: ByteString),
"Version" =: ("2016-11-15" :: ByteString),
"DryRun" =: _evioDryRun, "VolumeId" =: _evioVolumeId]
data EnableVolumeIOResponse =
EnableVolumeIOResponse'
deriving (Eq, Read, Show, Data, Typeable, Generic)
enableVolumeIOResponse
:: EnableVolumeIOResponse
enableVolumeIOResponse = EnableVolumeIOResponse'
instance NFData EnableVolumeIOResponse where