{-# 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.CloudHSMv2.DeleteCluster
(
deleteCluster
, DeleteCluster
, dcClusterId
, deleteClusterResponse
, DeleteClusterResponse
, drsCluster
, drsResponseStatus
) where
import Network.AWS.CloudHSMv2.Types
import Network.AWS.CloudHSMv2.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
newtype DeleteCluster = DeleteCluster'
{ _dcClusterId :: Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
deleteCluster
:: Text
-> DeleteCluster
deleteCluster pClusterId_ = DeleteCluster' {_dcClusterId = pClusterId_}
dcClusterId :: Lens' DeleteCluster Text
dcClusterId = lens _dcClusterId (\ s a -> s{_dcClusterId = a})
instance AWSRequest DeleteCluster where
type Rs DeleteCluster = DeleteClusterResponse
request = postJSON cloudHSMv2
response
= receiveJSON
(\ s h x ->
DeleteClusterResponse' <$>
(x .?> "Cluster") <*> (pure (fromEnum s)))
instance Hashable DeleteCluster where
instance NFData DeleteCluster where
instance ToHeaders DeleteCluster where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("BaldrApiService.DeleteCluster" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DeleteCluster where
toJSON DeleteCluster'{..}
= object
(catMaybes [Just ("ClusterId" .= _dcClusterId)])
instance ToPath DeleteCluster where
toPath = const "/"
instance ToQuery DeleteCluster where
toQuery = const mempty
data DeleteClusterResponse = DeleteClusterResponse'
{ _drsCluster :: !(Maybe Cluster)
, _drsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
deleteClusterResponse
:: Int
-> DeleteClusterResponse
deleteClusterResponse pResponseStatus_ =
DeleteClusterResponse'
{_drsCluster = Nothing, _drsResponseStatus = pResponseStatus_}
drsCluster :: Lens' DeleteClusterResponse (Maybe Cluster)
drsCluster = lens _drsCluster (\ s a -> s{_drsCluster = a})
drsResponseStatus :: Lens' DeleteClusterResponse Int
drsResponseStatus = lens _drsResponseStatus (\ s a -> s{_drsResponseStatus = a})
instance NFData DeleteClusterResponse where