module Network.AWS.StorageGateway.DeleteTape
    (
    
      deleteTape
    , DeleteTape
    
    , dttGatewayARN
    , dttTapeARN
    
    , deleteTapeResponse
    , DeleteTapeResponse
    
    , dtrsTapeARN
    , dtrsStatus
    ) where
import           Network.AWS.Prelude
import           Network.AWS.Request
import           Network.AWS.Response
import           Network.AWS.StorageGateway.Types
import           Network.AWS.StorageGateway.Types.Product
data DeleteTape = DeleteTape'
    { _dttGatewayARN :: !Text
    , _dttTapeARN    :: !Text
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteTape
    :: Text 
    -> Text 
    -> DeleteTape
deleteTape pGatewayARN_ pTapeARN_ =
    DeleteTape'
    { _dttGatewayARN = pGatewayARN_
    , _dttTapeARN = pTapeARN_
    }
dttGatewayARN :: Lens' DeleteTape Text
dttGatewayARN = lens _dttGatewayARN (\ s a -> s{_dttGatewayARN = a});
dttTapeARN :: Lens' DeleteTape Text
dttTapeARN = lens _dttTapeARN (\ s a -> s{_dttTapeARN = a});
instance AWSRequest DeleteTape where
        type Rs DeleteTape = DeleteTapeResponse
        request = postJSON storageGateway
        response
          = receiveJSON
              (\ s h x ->
                 DeleteTapeResponse' <$>
                   (x .?> "TapeARN") <*> (pure (fromEnum s)))
instance ToHeaders DeleteTape where
        toHeaders
          = const
              (mconcat
                 ["X-Amz-Target" =#
                    ("StorageGateway_20130630.DeleteTape" :: ByteString),
                  "Content-Type" =#
                    ("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DeleteTape where
        toJSON DeleteTape'{..}
          = object
              (catMaybes
                 [Just ("GatewayARN" .= _dttGatewayARN),
                  Just ("TapeARN" .= _dttTapeARN)])
instance ToPath DeleteTape where
        toPath = const "/"
instance ToQuery DeleteTape where
        toQuery = const mempty
data DeleteTapeResponse = DeleteTapeResponse'
    { _dtrsTapeARN :: !(Maybe Text)
    , _dtrsStatus  :: !Int
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteTapeResponse
    :: Int 
    -> DeleteTapeResponse
deleteTapeResponse pStatus_ =
    DeleteTapeResponse'
    { _dtrsTapeARN = Nothing
    , _dtrsStatus = pStatus_
    }
dtrsTapeARN :: Lens' DeleteTapeResponse (Maybe Text)
dtrsTapeARN = lens _dtrsTapeARN (\ s a -> s{_dtrsTapeARN = a});
dtrsStatus :: Lens' DeleteTapeResponse Int
dtrsStatus = lens _dtrsStatus (\ s a -> s{_dtrsStatus = a});