module Network.AWS.StorageGateway.DeleteTapeArchive
    (
    
      deleteTapeArchive
    , DeleteTapeArchive
    
    , dtaTapeARN
    
    , deleteTapeArchiveResponse
    , DeleteTapeArchiveResponse
    
    , dtatrsTapeARN
    , dtatrsStatus
    ) where
import           Network.AWS.Prelude
import           Network.AWS.Request
import           Network.AWS.Response
import           Network.AWS.StorageGateway.Types
import           Network.AWS.StorageGateway.Types.Product
newtype DeleteTapeArchive = DeleteTapeArchive'
    { _dtaTapeARN :: Text
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteTapeArchive
    :: Text 
    -> DeleteTapeArchive
deleteTapeArchive pTapeARN_ =
    DeleteTapeArchive'
    { _dtaTapeARN = pTapeARN_
    }
dtaTapeARN :: Lens' DeleteTapeArchive Text
dtaTapeARN = lens _dtaTapeARN (\ s a -> s{_dtaTapeARN = a});
instance AWSRequest DeleteTapeArchive where
        type Rs DeleteTapeArchive = DeleteTapeArchiveResponse
        request = postJSON storageGateway
        response
          = receiveJSON
              (\ s h x ->
                 DeleteTapeArchiveResponse' <$>
                   (x .?> "TapeARN") <*> (pure (fromEnum s)))
instance ToHeaders DeleteTapeArchive where
        toHeaders
          = const
              (mconcat
                 ["X-Amz-Target" =#
                    ("StorageGateway_20130630.DeleteTapeArchive" ::
                       ByteString),
                  "Content-Type" =#
                    ("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DeleteTapeArchive where
        toJSON DeleteTapeArchive'{..}
          = object
              (catMaybes [Just ("TapeARN" .= _dtaTapeARN)])
instance ToPath DeleteTapeArchive where
        toPath = const "/"
instance ToQuery DeleteTapeArchive where
        toQuery = const mempty
data DeleteTapeArchiveResponse = DeleteTapeArchiveResponse'
    { _dtatrsTapeARN :: !(Maybe Text)
    , _dtatrsStatus  :: !Int
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
deleteTapeArchiveResponse
    :: Int 
    -> DeleteTapeArchiveResponse
deleteTapeArchiveResponse pStatus_ =
    DeleteTapeArchiveResponse'
    { _dtatrsTapeARN = Nothing
    , _dtatrsStatus = pStatus_
    }
dtatrsTapeARN :: Lens' DeleteTapeArchiveResponse (Maybe Text)
dtatrsTapeARN = lens _dtatrsTapeARN (\ s a -> s{_dtatrsTapeARN = a});
dtatrsStatus :: Lens' DeleteTapeArchiveResponse Int
dtatrsStatus = lens _dtatrsStatus (\ s a -> s{_dtatrsStatus = a});