From 7e084bcf82e10b7836e96dcc383ae6d81eae0942 Mon Sep 17 00:00:00 2001 From: MegaBrutal Date: Sun, 26 Jun 2022 02:20:00 +0200 Subject: [PATCH] Enforce maximum image size --- src/main.rs | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/src/main.rs b/src/main.rs index c9c48b8..96cb1b3 100644 --- a/src/main.rs +++ b/src/main.rs @@ -17,6 +17,12 @@ use image::error::{LimitError, LimitErrorKind}; #[derive(Debug)] struct ImageError(image::ImageError); +impl ImageError { + fn dimension_error() -> ImageError { + ImageError(image::ImageError::Limits(LimitError::from_kind(LimitErrorKind::DimensionError))) + } +} + impl Display for ImageError { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", &self.0) @@ -71,11 +77,16 @@ async fn greet(name: web::Path, req: HttpRequest) -> impl Responder { } fn make_png(dim_x: u32, dim_y: u32, scale: u32, data: &mut dyn Iterator) -> Result>, ImageError> { + // Image must not be larger than 1 megapixel + if dim_x * dim_y * scale > 1048576 { + return Err(ImageError::dimension_error()) + } + let mut img: RgbImage = ImageBuffer::new(dim_x, dim_y); let mut pixels = img.pixels_mut(); for sp in ToRgbIter::new(data) { - let mut dp = pixels.next().ok_or(ImageError(image::ImageError::Limits(LimitError::from_kind(LimitErrorKind::DimensionError))))?; + let mut dp = pixels.next().ok_or(ImageError::dimension_error())?; println!("{:?}", sp); dp.0 = sp.0; } -- 2.34.1