From aef35f2a0b919efa2194fe6cce682878cfe96232 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Arma=C3=ABl=20Gu=C3=A9neau?= Date: Thu, 2 Jan 2025 12:13:27 +0100 Subject: [PATCH] slightly improve error handling in handlers --- src/main.rs | 31 ++++++++++++++++++++----------- 1 file changed, 20 insertions(+), 11 deletions(-) diff --git a/src/main.rs b/src/main.rs index ef3b814..cf5a660 100644 --- a/src/main.rs +++ b/src/main.rs @@ -4,8 +4,7 @@ use axum::{ http::{header, StatusCode}, response::{Html, IntoResponse}, routing::get, - Form, - Router, + Form, Router, }; use forgejo_api::{Auth, Forgejo}; use lazy_static::lazy_static; @@ -299,7 +298,7 @@ async fn get_index( State(data): State>, Query(q): Query, OriginalUri(uri): OriginalUri, -) -> Html { +) -> Result, AppError> { eprintln!("GET {}", uri); let db = &data.db; @@ -355,9 +354,9 @@ async fn get_index( ); context.insert("total_users_count", &users_count); eprintln!("rendering template..."); - let page = TEMPLATES.render("index.html", &context).unwrap(); + let page = TEMPLATES.render("index.html", &context)?; eprintln!("done"); - Html::from(page) + Ok(Html::from(page)) } async fn post_classified( @@ -387,7 +386,11 @@ async fn post_classified( eprintln!("done"); - Ok((StatusCode::SEE_OTHER, [(header::LOCATION, uri.to_string())], ())) + Ok(( + StatusCode::SEE_OTHER, + [(header::LOCATION, uri.to_string())], + (), + )) } async fn post_classified_index( @@ -409,7 +412,7 @@ async fn post_classified_edit( async fn get_classified( State(data): State>, OriginalUri(uri): OriginalUri, -) -> Html { +) -> Result, AppError> { eprintln!("GET {}", uri); let db = &data.db; @@ -431,14 +434,17 @@ async fn get_classified( context.insert("forge_url", &data.config.forge_url.to_string()); context.insert("users", &users); eprintln!("rendering template..."); - let page = TEMPLATES.render("classified.html", &context).unwrap(); + let page = TEMPLATES.render("classified.html", &context)?; eprintln!("done"); - Html::from(page) + Ok(Html::from(page)) } const STATIC_DIR: include_dir::Dir = include_dir::include_dir!("static"); -async fn get_static_(Path(filename): Path, OriginalUri(uri): OriginalUri) -> impl IntoResponse { +async fn get_static_( + Path(filename): Path, + OriginalUri(uri): OriginalUri, +) -> impl IntoResponse { eprintln!("GET {}", uri); match STATIC_DIR.get_file(filename) { @@ -498,7 +504,10 @@ async fn main() -> anyhow::Result<()> { let app = Router::new() .route("/", get(get_index).post(post_classified_index)) - .route("/classified", get(get_classified).post(post_classified_edit)) + .route( + "/classified", + get(get_classified).post(post_classified_edit), + ) .route("/static/{*filename}", get(get_static_)) .with_state(shared_state);