From a8ef9c834a7d6c4e2f2e6b2c778f4ea8bc253736 Mon Sep 17 00:00:00 2001 From: Rob klein Gunnewiek Date: Fri, 1 Nov 2019 16:58:48 +0100 Subject: [PATCH] error handling for the GCS implementation of RETR (#80) this solves issue https://github.com/bolcom/libunftp/issues/63 --- src/storage/cloud_storage.rs | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/src/storage/cloud_storage.rs b/src/storage/cloud_storage.rs index 3d0b767e..2829afc1 100644 --- a/src/storage/cloud_storage.rs +++ b/src/storage/cloud_storage.rs @@ -319,8 +319,28 @@ impl StorageBackend for CloudStorage { client .request(request) .map_err(|_| Error::from(ErrorKind::PermanentFileNotAvailable)) - .and_then(|response| response.into_body().map_err(|_| Error::from(ErrorKind::PermanentFileNotAvailable)).concat2()) - .and_then(move |body| future::ok(Object::new(body.to_vec()))) + .and_then(|response| { + let status = response.status(); + response + .into_body() + .map_err(|_| Error::from(ErrorKind::PermanentFileNotAvailable)) + .concat2() + .and_then(move |body| { + match status { + // These are the GCS error variants as per https://cloud.google.com/storage/docs/json_api/v1/status-codes + StatusCode::UNAUTHORIZED => future::err(Error::from(ErrorKind::PermanentFileNotAvailable)), + StatusCode::FORBIDDEN => future::err(Error::from(ErrorKind::PermissionDenied)), + StatusCode::NOT_FOUND => future::err(Error::from(ErrorKind::PermanentFileNotAvailable)), + _ => { + if status.is_success() { + future::ok(Object::new(body.to_vec())) + } else { + future::err(Error::from(ErrorKind::LocalError)) + } + } + } + }) + }) }); Box::new(result) }