diff options
| author | metamuffin <metamuffin@disroot.org> | 2023-02-11 10:47:25 +0100 | 
|---|---|---|
| committer | metamuffin <metamuffin@disroot.org> | 2023-02-11 10:47:25 +0100 | 
| commit | 389caf52b7a247301af71a61cc6a1259147efff3 (patch) | |
| tree | bde68f65cfc73eabb9a7e9dd8735fd5a85a84702 /server | |
| parent | 9dfc929b709d4187dc307f68a42fa058eda7a4c1 (diff) | |
| download | keks-meet-389caf52b7a247301af71a61cc6a1259147efff3.tar keks-meet-389caf52b7a247301af71a61cc6a1259147efff3.tar.bz2 keks-meet-389caf52b7a247301af71a61cc6a1259147efff3.tar.zst | |
fix standalone version (and avoid a compiler crash)
Diffstat (limited to 'server')
| -rw-r--r-- | server/src/assets.rs | 23 | ||||
| -rw-r--r-- | server/src/main.rs | 6 | 
2 files changed, 21 insertions, 8 deletions
| diff --git a/server/src/assets.rs b/server/src/assets.rs index 068bc0c..bdd7ef9 100644 --- a/server/src/assets.rs +++ b/server/src/assets.rs @@ -1,7 +1,7 @@  #[cfg(not(feature = "standalone"))]  #[macro_export]  macro_rules! s_file { -    ($path: literal) => { +    ($path: literal, $content_type: literal) => {          warp::fs::file($path)      };  } @@ -17,8 +17,14 @@ macro_rules! s_asset_dir {  #[cfg(feature = "standalone")]  #[macro_export]  macro_rules! s_file { -    ($path: literal) => { -        warp::get().map(|| include_str!(concat!("../../", $path))) +    ($path: literal, $content_type: literal) => { +        warp::any().map(|| { +            warp::reply::with_header( +                include_str!(concat!("../../", $path)), +                "content-type", +                $content_type, +            ) +        })      };  } @@ -29,8 +35,15 @@ macro_rules! s_asset_dir {          use include_dir::{include_dir, Dir};          const DIR: Dir = include_dir!("$CARGO_MANIFEST_DIR/../client-web/public/assets");          warp::path::tail().and_then(|t: warp::path::Tail| async move { -            DIR.get_file(t.as_str()) -                .map(|f| f.contents_utf8().unwrap()) +            let path = t.as_str(); +            let content_type = match &path { +                _ if path.ends_with(".wasm") => "application/wasm", +                _ if path.ends_with(".js") => "application/javascript", +                _ if path.ends_with(".css") => "text/css", +                _ => "application/octet-stream", +            }; +            DIR.get_file(path) +                .map(|f| warp::reply::with_header(f.contents(), "content-type", content_type))                  .ok_or(warp::reject::not_found())          })      }}; diff --git a/server/src/main.rs b/server/src/main.rs index 518ea99..c818eb5 100644 --- a/server/src/main.rs +++ b/server/src/main.rs @@ -42,10 +42,10 @@ async fn run() {          .and(warp::ws())          .map(signaling_connect); -    let index: _ = warp::path!().and(s_file!("client-web/public/start.html")); -    let room: _ = warp::path!("room").and(s_file!("client-web/public/app.html")); +    let index: _ = warp::path!().and(s_file!("client-web/public/start.html", "text/html")); +    let room: _ = warp::path!("room").and(s_file!("client-web/public/app.html", "text/html"));      let assets: _ = warp::path("assets").and(s_asset_dir!()); -    let sw_script: _ = warp::path("sw.js").and(s_file!("client-web/public/assets/sw.js")); +    let sw_script: _ = warp::path("sw.js").and(s_file!("client-web/public/assets/sw.js", "application/javascript"));      let favicon: _ = warp::path!("favicon.ico").map(|| "");      let old_format_redirect: _ = warp::path!("room" / String).map(|rsecret| {          reply::with_header( | 
