module Network.AWS.StorageGateway.CancelArchival
    (
    
      cancelArchival
    , CancelArchival
    
    , caGatewayARN
    , caTapeARN
    
    , cancelArchivalResponse
    , CancelArchivalResponse
    
    , carsTapeARN
    , carsStatus
    ) 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 CancelArchival = CancelArchival'
    { _caGatewayARN :: !Text
    , _caTapeARN    :: !Text
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
cancelArchival
    :: Text 
    -> Text 
    -> CancelArchival
cancelArchival pGatewayARN_ pTapeARN_ =
    CancelArchival'
    { _caGatewayARN = pGatewayARN_
    , _caTapeARN = pTapeARN_
    }
caGatewayARN :: Lens' CancelArchival Text
caGatewayARN = lens _caGatewayARN (\ s a -> s{_caGatewayARN = a});
caTapeARN :: Lens' CancelArchival Text
caTapeARN = lens _caTapeARN (\ s a -> s{_caTapeARN = a});
instance AWSRequest CancelArchival where
        type Rs CancelArchival = CancelArchivalResponse
        request = postJSON storageGateway
        response
          = receiveJSON
              (\ s h x ->
                 CancelArchivalResponse' <$>
                   (x .?> "TapeARN") <*> (pure (fromEnum s)))
instance ToHeaders CancelArchival where
        toHeaders
          = const
              (mconcat
                 ["X-Amz-Target" =#
                    ("StorageGateway_20130630.CancelArchival" ::
                       ByteString),
                  "Content-Type" =#
                    ("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON CancelArchival where
        toJSON CancelArchival'{..}
          = object
              (catMaybes
                 [Just ("GatewayARN" .= _caGatewayARN),
                  Just ("TapeARN" .= _caTapeARN)])
instance ToPath CancelArchival where
        toPath = const "/"
instance ToQuery CancelArchival where
        toQuery = const mempty
data CancelArchivalResponse = CancelArchivalResponse'
    { _carsTapeARN :: !(Maybe Text)
    , _carsStatus  :: !Int
    } deriving (Eq,Read,Show,Data,Typeable,Generic)
cancelArchivalResponse
    :: Int 
    -> CancelArchivalResponse
cancelArchivalResponse pStatus_ =
    CancelArchivalResponse'
    { _carsTapeARN = Nothing
    , _carsStatus = pStatus_
    }
carsTapeARN :: Lens' CancelArchivalResponse (Maybe Text)
carsTapeARN = lens _carsTapeARN (\ s a -> s{_carsTapeARN = a});
carsStatus :: Lens' CancelArchivalResponse Int
carsStatus = lens _carsStatus (\ s a -> s{_carsStatus = a});