module Network.AWS.OpsWorks.UpdateVolume
(
updateVolume
, UpdateVolume
, uName
, uMountPoint
, uVolumeId
, updateVolumeResponse
, UpdateVolumeResponse
) where
import Network.AWS.Lens
import Network.AWS.OpsWorks.Types
import Network.AWS.OpsWorks.Types.Product
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data UpdateVolume = UpdateVolume'
{ _uName :: !(Maybe Text)
, _uMountPoint :: !(Maybe Text)
, _uVolumeId :: !Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
updateVolume
:: Text
-> UpdateVolume
updateVolume pVolumeId_ =
UpdateVolume'
{ _uName = Nothing
, _uMountPoint = Nothing
, _uVolumeId = pVolumeId_
}
uName :: Lens' UpdateVolume (Maybe Text)
uName = lens _uName (\ s a -> s{_uName = a});
uMountPoint :: Lens' UpdateVolume (Maybe Text)
uMountPoint = lens _uMountPoint (\ s a -> s{_uMountPoint = a});
uVolumeId :: Lens' UpdateVolume Text
uVolumeId = lens _uVolumeId (\ s a -> s{_uVolumeId = a});
instance AWSRequest UpdateVolume where
type Rs UpdateVolume = UpdateVolumeResponse
request = postJSON opsWorks
response = receiveNull UpdateVolumeResponse'
instance Hashable UpdateVolume
instance NFData UpdateVolume
instance ToHeaders UpdateVolume where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("OpsWorks_20130218.UpdateVolume" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON UpdateVolume where
toJSON UpdateVolume'{..}
= object
(catMaybes
[("Name" .=) <$> _uName,
("MountPoint" .=) <$> _uMountPoint,
Just ("VolumeId" .= _uVolumeId)])
instance ToPath UpdateVolume where
toPath = const "/"
instance ToQuery UpdateVolume where
toQuery = const mempty
data UpdateVolumeResponse =
UpdateVolumeResponse'
deriving (Eq,Read,Show,Data,Typeable,Generic)
updateVolumeResponse
:: UpdateVolumeResponse
updateVolumeResponse = UpdateVolumeResponse'
instance NFData UpdateVolumeResponse