mirror of
https://github.com/Djeeberjr/fw-anwesenheit.git
synced 2026-04-30 18:49:09 +00:00
added static assets on webserver
This commit is contained in:
77
src/webserver/assets.rs
Normal file
77
src/webserver/assets.rs
Normal file
@@ -0,0 +1,77 @@
|
||||
use dir_embed::Embed;
|
||||
use picoserve::response::Content;
|
||||
|
||||
#[derive(Embed)]
|
||||
#[dir = "../../web/dist"]
|
||||
#[mode = "mime"]
|
||||
pub struct Assets;
|
||||
|
||||
impl<State, CurrentPathParameters>
|
||||
picoserve::routing::PathRouterService<State, CurrentPathParameters> for Assets
|
||||
{
|
||||
async fn call_request_handler_service<
|
||||
R: picoserve::io::embedded_io_async::Read,
|
||||
W: picoserve::response::ResponseWriter<Error = R::Error>,
|
||||
>(
|
||||
&self,
|
||||
state: &State,
|
||||
current_path_parameters: CurrentPathParameters,
|
||||
path: picoserve::request::Path<'_>,
|
||||
request: picoserve::request::Request<'_, R>,
|
||||
response_writer: W,
|
||||
) -> Result<picoserve::ResponseSent, W::Error> {
|
||||
let requested_path = path.encoded();
|
||||
|
||||
let requested_file = if requested_path == "/" {
|
||||
Self::get("index.html")
|
||||
} else if let Some(striped_path) = requested_path.strip_prefix("/") {
|
||||
Self::get(striped_path)
|
||||
} else {
|
||||
None
|
||||
};
|
||||
|
||||
match requested_file {
|
||||
Some(content) => {
|
||||
let response = picoserve::response::Response::new(
|
||||
picoserve::response::StatusCode::OK,
|
||||
StaticAsset(content.0, content.1),
|
||||
);
|
||||
|
||||
response_writer
|
||||
.write_response(request.body_connection.finalize().await.unwrap(), response)
|
||||
.await
|
||||
}
|
||||
None => {
|
||||
use picoserve::routing::PathRouter;
|
||||
picoserve::routing::NotFound
|
||||
.call_path_router(
|
||||
state,
|
||||
current_path_parameters,
|
||||
path,
|
||||
request,
|
||||
response_writer,
|
||||
)
|
||||
.await
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
struct StaticAsset(pub &'static [u8], pub &'static str);
|
||||
|
||||
impl Content for StaticAsset {
|
||||
fn content_type(&self) -> &'static str {
|
||||
self.1
|
||||
}
|
||||
|
||||
fn content_length(&self) -> usize {
|
||||
self.0.len()
|
||||
}
|
||||
|
||||
async fn write_content<W: embedded_io_async::Write>(
|
||||
self,
|
||||
mut writer: W,
|
||||
) -> Result<(), W::Error> {
|
||||
writer.write_all(self.0).await
|
||||
}
|
||||
}
|
||||
@@ -4,6 +4,8 @@ use embassy_time::Duration;
|
||||
use picoserve::{AppBuilder, AppRouter, routing::get};
|
||||
use static_cell::make_static;
|
||||
|
||||
mod assets;
|
||||
|
||||
pub fn start_webserver(spawner: &mut Spawner, stack: Stack<'static>) {
|
||||
let app = make_static!(AppProps.build_app());
|
||||
|
||||
@@ -23,7 +25,7 @@ impl AppBuilder for AppProps {
|
||||
type PathRouter = impl picoserve::routing::PathRouter;
|
||||
|
||||
fn build_app(self) -> picoserve::Router<Self::PathRouter> {
|
||||
picoserve::Router::new().route("/", get(|| async move { "Hello World" }))
|
||||
picoserve::Router::from_service(assets::Assets).route("/api/a", get(async move || "Hello"))
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user