From 18f598952a461e05ade980d8aa319216df0141ce Mon Sep 17 00:00:00 2001 From: Wim Looman Date: Mon, 17 Oct 2022 19:44:58 +0200 Subject: [PATCH] Serve json source files as source pages instead of raw --- src/web/source.rs | 30 ++++++++++++++++++++++++++++-- 1 file changed, 28 insertions(+), 2 deletions(-) diff --git a/src/web/source.rs b/src/web/source.rs index a08983a92..5541d637f 100644 --- a/src/web/source.rs +++ b/src/web/source.rs @@ -273,10 +273,11 @@ pub fn source_browser_handler(req: &mut Request) -> IronResult { }; let (file, file_content) = if let Some(blob) = blob { + let is_text = blob.mime.starts_with("text") || blob.mime == "application/json"; // serve the file with DatabaseFileHandler if file isn't text and not empty - if !blob.mime.starts_with("text") && !blob.is_empty() { + if !is_text && !blob.is_empty() { return Ok(DbFile(blob).serve()); - } else if blob.mime.starts_with("text") && !blob.is_empty() { + } else if is_text && !blob.is_empty() { let path = blob .path .rsplit_once('/') @@ -478,4 +479,29 @@ mod tests { Ok(()) }); } + + #[test] + fn json_is_served_as_rendered_html() { + wrapper(|env| { + env.fake_release() + .name("fake") + .version("0.1.0") + .source_file("config.json", b"{}") + .create()?; + + let web = env.frontend(); + + let response = web.get("/crate/fake/0.1.0/source/config.json").send()?; + assert!(response + .headers() + .get("content-type") + .unwrap() + .to_str() + .unwrap() + .starts_with("text/html")); + assert!(response.text()?.starts_with(r#""#)); + + Ok(()) + }); + } }