From 42dfc27ecfbdc248870741ae0fcbc3470dd30515 Mon Sep 17 00:00:00 2001 From: HeDui <1628652790@qq.com> Date: Thu, 10 Aug 2023 23:58:08 +0800 Subject: [PATCH] fix: return the panel index.html file by default (#193) It fixes #192 --- crates/panel/src/handlers/panel.rs | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/crates/panel/src/handlers/panel.rs b/crates/panel/src/handlers/panel.rs index d90bb243..cb6dbf5b 100644 --- a/crates/panel/src/handlers/panel.rs +++ b/crates/panel/src/handlers/panel.rs @@ -12,19 +12,30 @@ use rust_embed::RustEmbed; #[folder = "client/dist/"] struct Asset; -/// Find the static assets of the administration panel #[actix_web::get("/_panel{_:.*}")] pub async fn handle_static_panel(path: web::Path) -> impl Responder { - let path = if path.len() == 0 { + let path = if path.is_empty() { "index.html" } else { path.as_str().strip_prefix('/').unwrap() }; - match Asset::get(path) { - Some(content) => HttpResponse::Ok() - .content_type(from_path(path).first_or_octet_stream().as_ref()) - .body(content.data.into_owned()), - None => HttpResponse::NotFound().body("404 Not Found"), - } + let (content_type, content_data) = Asset::get(path) + .map(|content| { + ( + from_path(path).first_or_octet_stream().to_string(), + content.data.into_owned(), + ) + }) + .unwrap_or_else(|| { + let default_content = Asset::get("index.html").unwrap(); + ( + "text/html; charset=utf-8".to_string(), + default_content.data.into_owned(), + ) + }); + + HttpResponse::Ok() + .content_type(content_type) + .body(content_data) }