summaryrefslogtreecommitdiffstats
path: root/src/server/routes/users/get_user.rs
diff options
context:
space:
mode:
authorrtkay123 <dev@kanjala.com>2025-07-17 14:00:40 +0200
committerrtkay123 <dev@kanjala.com>2025-07-17 14:00:40 +0200
commit69fe55ad54468948c13af520a498ed4aeac194ed (patch)
treec7db25aa7cf615480e9b386064f232d2bec6ccc3 /src/server/routes/users/get_user.rs
parent5fdb24b6a2cef7964a049e789ed90f883221d657 (diff)
downloadsellershut-69fe55ad54468948c13af520a498ed4aeac194ed.tar.bz2
sellershut-69fe55ad54468948c13af520a498ed4aeac194ed.zip
chore: convert to workspace
Diffstat (limited to 'src/server/routes/users/get_user.rs')
-rw-r--r--src/server/routes/users/get_user.rs100
1 files changed, 0 insertions, 100 deletions
diff --git a/src/server/routes/users/get_user.rs b/src/server/routes/users/get_user.rs
deleted file mode 100644
index fc2803e..0000000
--- a/src/server/routes/users/get_user.rs
+++ /dev/null
@@ -1,100 +0,0 @@
-use activitypub_federation::{
- axum::json::FederationJson, config::Data, protocol::context::WithContext, traits::Object,
-};
-use axum::{debug_handler, extract::Path, http::StatusCode, response::IntoResponse};
-use tracing::trace;
-
-use crate::{error::AppError, state::AppHandle};
-
-#[debug_handler]
-pub async fn http_get_user(
- Path(name): Path<String>,
- data: Data<AppHandle>,
-) -> Result<impl IntoResponse, AppError> {
- if let Some(a) = read_user(&name, &data).await? {
- let json_user = a.into_json(&data).await?;
- Ok((
- StatusCode::OK,
- FederationJson(WithContext::new_default(json_user)),
- )
- .into_response())
- } else {
- Ok((StatusCode::NOT_FOUND, "").into_response())
- }
-}
-
-pub async fn read_user(
- name: &str,
- data: &Data<AppHandle>,
-) -> Result<Option<crate::entity::user::User>, AppError> {
- trace!(username = name, "getting user");
- let read = sqlx::query_as!(
- crate::entity::user::DbUser,
- "select * from account where username = $1 and local = $2",
- name,
- true
- )
- .fetch_optional(&data.services.postgres)
- .await?;
-
- let user = read.into_iter().find(|value| value.username.eq(&name));
- let user = match user {
- Some(user) => Some(crate::entity::user::User::try_from(user)?),
- None => None,
- };
- Ok(user)
-}
-
-#[cfg(test)]
-mod tests {
- use axum::{
- body::Body,
- http::{Request, StatusCode},
- };
- use sqlx::PgPool;
- use stack_up::Services;
- use tower::ServiceExt;
-
- use crate::{
- server::{self, test_config},
- state::AppState,
- };
-
- #[sqlx::test]
- async fn get_user(pool: PgPool) {
- let services = Services { postgres: pool };
- let state = AppState::create(services, &test_config()).await.unwrap();
- let app = server::router(state);
-
- let response = app
- .oneshot(
- Request::builder()
- .uri("/users/sellershut")
- .body(Body::empty())
- .unwrap(),
- )
- .await
- .unwrap();
-
- assert_eq!(response.status(), StatusCode::OK);
- }
-
- #[sqlx::test]
- async fn get_user_not_found(pool: PgPool) {
- let services = Services { postgres: pool };
- let state = AppState::create(services, &test_config()).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);
- }
-}