From b949b30f24b9f4f08387f292a9ffd69f87709b36 Mon Sep 17 00:00:00 2001 From: Nathan Sobo Date: Sat, 25 Dec 2021 11:57:37 -0700 Subject: [PATCH] Add delete user endpoint --- crates/server/src/api.rs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/crates/server/src/api.rs b/crates/server/src/api.rs index 9510c2fc103d0e23d2bfa8c149da561595dd9a96..a4e24083a3f63fdd47263920c03b813dae259c17 100644 --- a/crates/server/src/api.rs +++ b/crates/server/src/api.rs @@ -9,6 +9,7 @@ pub fn add_routes(app: &mut tide::Server>) { app.at("/users").get(get_users); app.at("/users").post(create_user); app.at("/users/:id").put(update_user); + app.at("/users/:id").delete(delete_user); app.at("/users/:github_login").get(get_user); app.at("/users/:github_login/access_tokens") .post(create_access_token); @@ -88,6 +89,20 @@ async fn update_user(mut request: Request) -> tide::Result { Ok(tide::Response::builder(StatusCode::Ok).build()) } +async fn delete_user(request: Request) -> tide::Result { + request.require_token().await?; + let user_id = UserId( + request + .param("id")? + .parse::() + .map_err(|error| surf::Error::from_str(StatusCode::BadRequest, error.to_string()))?, + ); + + request.db().delete_user(user_id).await?; + + Ok(tide::Response::builder(StatusCode::Ok).build()) +} + async fn create_access_token(request: Request) -> tide::Result { request.require_token().await?;