From 23d86c84e108757951e997d444145b570b72ae62 Mon Sep 17 00:00:00 2001 From: rtkay123 Date: Sat, 12 Jul 2025 17:01:31 +0200 Subject: feat: webfinger --- src/server/routes/users/get_user.rs | 32 ++++++++++++++++++++++++++------ 1 file changed, 26 insertions(+), 6 deletions(-) (limited to 'src/server/routes/users/get_user.rs') diff --git a/src/server/routes/users/get_user.rs b/src/server/routes/users/get_user.rs index 8020923..d86cc26 100644 --- a/src/server/routes/users/get_user.rs +++ b/src/server/routes/users/get_user.rs @@ -10,12 +10,7 @@ pub async fn http_get_user( Path(name): Path, data: Data, ) -> Result { - let read = data.users.read().await; - if let Some(a) = read - .iter() - .find(|value| value.username.eq(&name)) - .map(ToOwned::to_owned) - { + if let Some(a) = read_user(&name, &data).await { let json_user = a.into_json(&data).await?; Ok(( StatusCode::OK, @@ -27,6 +22,13 @@ pub async fn http_get_user( } } +pub async fn read_user(name: &str, data: &Data) -> Option { + let read = data.users.read().await; + read.iter() + .find(|value| value.username.eq(&name)) + .map(ToOwned::to_owned) +} + #[cfg(test)] mod tests { use axum::{ @@ -54,4 +56,22 @@ mod tests { assert_eq!(response.status(), StatusCode::OK); } + + #[tokio::test] + async fn get_user_not_found() { + let state = AppState::new().await.unwrap(); + let app = server::router(state); + + let response = app + .oneshot( + Request::builder() + .uri("/users/selut") + .body(Body::empty()) + .unwrap(), + ) + .await + .unwrap(); + + assert_eq!(response.status(), StatusCode::NOT_FOUND); + } } -- cgit v1.2.3