Browse Source

Refactor `EmbeddedFileExt` to use combinators and ?

This allows for the "happy-path" to stay on the same indentation-level,
which makes the code easier to read.
fix-bad-api-calls
Thomas Eizinger 3 years ago
parent
commit
d326533170
No known key found for this signature in database GPG Key ID: 651AC83A6C6C8B96
  1. 24
      daemon/src/routes.rs

24
daemon/src/routes.rs

@ -1,7 +1,6 @@
use rocket::http::{ContentType, Status};
use rust_embed::EmbeddedFile;
use std::borrow::Cow;
use std::ffi::OsStr;
use std::path::PathBuf;
pub trait EmbeddedFileExt {
@ -10,18 +9,15 @@ pub trait EmbeddedFileExt {
impl EmbeddedFileExt for Option<EmbeddedFile> {
fn into_response(self, file: PathBuf) -> Result<(ContentType, Cow<'static, [u8]>), Status> {
match self {
None => Err(Status::NotFound),
Some(embedded_file) => {
let ext = file
.as_path()
.extension()
.and_then(OsStr::to_str)
.ok_or_else(|| Status::new(400))?;
let content_type =
ContentType::from_extension(ext).ok_or_else(|| Status::new(400))?;
Ok::<(ContentType, Cow<[u8]>), Status>((content_type, embedded_file.data))
}
}
let embedded_file = self.ok_or(Status::NotFound)?;
let ext = file
.as_path()
.extension()
.ok_or(Status::BadRequest)?
.to_str()
.ok_or(Status::InternalServerError)?;
let content_type = ContentType::from_extension(ext).ok_or(Status::InternalServerError)?;
Ok((content_type, embedded_file.data))
}
}

Loading…
Cancel
Save