From 29fb2156bf854ecfc2db9c106701b88f5288610a Mon Sep 17 00:00:00 2001 From: Tobias de Bruijn Date: Mon, 22 Jul 2024 17:54:51 +0200 Subject: [PATCH] Fix: Unneeded branching around a continue statement; Fix: Return correct Retry-After on ratelimit --- frontend/src/components/UploadPhotoDialog.vue | 5 ++--- server/chroma/src/routes/v1/photo/create.rs | 17 ++++++++--------- 2 files changed, 10 insertions(+), 12 deletions(-) diff --git a/frontend/src/components/UploadPhotoDialog.vue b/frontend/src/components/UploadPhotoDialog.vue index 643f7be..105f1fb 100644 --- a/frontend/src/components/UploadPhotoDialog.vue +++ b/frontend/src/components/UploadPhotoDialog.vue @@ -83,10 +83,9 @@ export default Vue.extend({ if(e instanceof TooManyRequests) { console.log(`Got HTTP 429. Waiting ${e.retryAfter} seconds`); await new Promise(resolve => setTimeout(resolve, e.retryAfter)); - continue; - } else { - continue; } + + continue; } if(result === true) { diff --git a/server/chroma/src/routes/v1/photo/create.rs b/server/chroma/src/routes/v1/photo/create.rs index bec7723..d2b109d 100644 --- a/server/chroma/src/routes/v1/photo/create.rs +++ b/server/chroma/src/routes/v1/photo/create.rs @@ -5,6 +5,7 @@ use actix_multiresponse::Payload; use dal::database::{Album, Database, Photo, PhotoQuality}; use dal::storage_engine::Storage; use exif::{In, Tag}; +use governor::clock::Clock; use image::imageops::FilterType; use image::io::Reader; use image::{DynamicImage, GenericImageView}; @@ -47,7 +48,7 @@ pub async fn create( } // TODO Update actix-multiresponse to support moving out the payload, avoids another clone - let photo_id = image_pipeline(&data, payload.photo_data.clone(), &album, &data.db).await?; + let photo_id = image_pipeline(&data, payload.photo_data.clone(), &album).await?; Ok(Payload(CreatePhotoResponse { photo_id })) } @@ -58,16 +59,13 @@ pub async fn create( /// /// If any step in the pipeline fails #[instrument(skip(data, image))] -async fn image_pipeline( - data: &WebData, - image: Vec, - album: &Album, - db: &Database, -) -> WebResult { +async fn image_pipeline(data: &WebData, image: Vec, album: &Album) -> WebResult { // Make sure we don't run into AWS ratelimits here if let Err(e) = data.ratelimits.photo_create.check() { return Err(Error::Ratelimit { - retry_after: e.wait_time_from(e.earliest_possible()).as_secs(), + retry_after: e + .wait_time_from(governor::clock::DefaultClock::default().now()) + .as_secs(), }); } @@ -226,7 +224,8 @@ fn resize_and_save( }; // Fetch the photo - let ok = reqwest::Client::new().get(url) + let ok = reqwest::Client::new() + .get(url) .send() .await .map(|resp| resp.error_for_status().is_ok())