From: MegaBrutal Date: Sun, 27 Nov 2022 01:45:00 +0000 (+0100) Subject: Create macro to make HTTP response of image X-Git-Url: http://git.megabrutal.com/?a=commitdiff_plain;h=5e6838bf2c50c8b93ffc1ed0b7ab101961d909a4;p=litoprism.git Create macro to make HTTP response of image --- diff --git a/src/main.rs b/src/main.rs index 0405e22..854f2c0 100644 --- a/src/main.rs +++ b/src/main.rs @@ -22,6 +22,14 @@ use actix_web::cookie::time::OffsetDateTime; const TIMEAVATAR_SIZE_U32: u32 = 6; const TIMEAVATAR_SIZE_I64: i64 = TIMEAVATAR_SIZE_U32 as i64; +macro_rules! response_image { + ($cursor:expr) => { + HttpResponse::build(StatusCode::OK) + .content_type("image/png") + .body($cursor.into_inner()) + } +} + #[derive(Debug)] struct ImageError(image::ImageError); @@ -243,9 +251,7 @@ fn image_to_cursor(img: RgbImage, scale: u32) -> Result>, ImageEr async fn img_gen0(req: HttpRequest) -> Result { let data = req.uri().path().split('/').nth(3).unwrap(); let cursor = make_png(32, 32, 16, percent_decode_str(data).into_iter().borrow_mut())?; - Ok(HttpResponse::build(StatusCode::OK) - .content_type("image/png") - .body(cursor.into_inner())) + Ok(response_image!(cursor)) } #[get("/gen/1/{dim_x}/{dim_y}/{scale}/{data}")] @@ -253,9 +259,7 @@ async fn img_gen1(req: HttpRequest, path: web::Path<(u32, u32, u32)>) -> Result< let (dim_x, dim_y, scale) = path.into_inner(); let data = req.uri().path().split('/').nth(6).unwrap(); let cursor = make_png(dim_x, dim_y, scale, percent_decode_str(data).into_iter().borrow_mut())?; - Ok(HttpResponse::build(StatusCode::OK) - .content_type("image/png") - .body(cursor.into_inner())) + Ok(response_image!(cursor)) } #[get("/gen/2/{dim_x}/{dim_y}/{scale}")] @@ -266,9 +270,7 @@ async fn img_gen2(req: HttpRequest, path: web::Path<(u32, u32, u32)>) -> Result< _ => "" }; let cursor = make_png(dim_x, dim_y, scale, &mut data.bytes())?; - Ok(HttpResponse::build(StatusCode::OK) - .content_type("image/png") - .body(cursor.into_inner())) + Ok(response_image!(cursor)) } #[get("/gen/3/{scale}")] @@ -284,9 +286,7 @@ async fn img_gen3(req: HttpRequest, path: web::Path) -> Result>>) -> Ok(apply_to_canvas( |c, d| to_canvasresult(rgb_encode_to_canvas(c, d)), &mut canvas_option.0, None, data)?.img.clone()) } as Result)?; let cursor = image_to_cursor(img, scale)?; - Ok(HttpResponse::build(StatusCode::OK) - .content_type("image/png") - .body(cursor.into_inner())) + Ok(response_image!(cursor)) } #[get("/pgen/1/{dim_x}/{dim_y}/{scale}/{data}")] @@ -312,9 +310,7 @@ async fn img_pgen1(req: HttpRequest, path: web::Path<(u32, u32, u32)>, canvas1: Ok(apply_to_canvas( |c, d| to_canvasresult(rgb_encode_to_canvas(c, d)), &mut canvas_option.0, Some((dim_x, dim_y)), data)?.img.clone()) } as Result)?; let cursor = image_to_cursor(img, scale)?; - Ok(HttpResponse::build(StatusCode::OK) - .content_type("image/png") - .body(cursor.into_inner())) + Ok(response_image!(cursor)) } #[get("/pgen/2/{dim_x}/{dim_y}/{scale}")] @@ -329,9 +325,7 @@ async fn img_pgen2(req: HttpRequest, path: web::Path<(u32, u32, u32)>, canvas1: Ok(apply_to_canvas( |c, d| to_canvasresult(rgb_encode_to_canvas(c, d)), &mut canvas_option.0, Some((dim_x, dim_y)), data)?.img.clone()) } as Result)?; let cursor = image_to_cursor(img, scale)?; - Ok(HttpResponse::build(StatusCode::OK) - .content_type("image/png") - .body(cursor.into_inner())) + Ok(response_image!(cursor)) } #[get("/pgen/3/{scale}")] @@ -354,9 +348,7 @@ async fn img_pgen3(req: HttpRequest, path: web::Path, canvas2: web::Data)?; let cursor = image_to_cursor(resimg, scale)?; - Ok(HttpResponse::build(StatusCode::OK) - .content_type("image/png") - .body(cursor.into_inner())) + Ok(response_image!(cursor)) } #[get("/pdrop/{canvas_id}")]