diff options
Diffstat (limited to 'atuin-server/src/handlers/user.rs')
| -rw-r--r-- | atuin-server/src/handlers/user.rs | 25 |
1 files changed, 19 insertions, 6 deletions
diff --git a/atuin-server/src/handlers/user.rs b/atuin-server/src/handlers/user.rs index 1bcfce2f..42e4aa33 100644 --- a/atuin-server/src/handlers/user.rs +++ b/atuin-server/src/handlers/user.rs @@ -32,10 +32,15 @@ pub async fn get( ) -> Result<Json<UserResponse>, ErrorResponseStatus<'static>> { let user = match db.get_user(username.as_ref()).await { Ok(user) => user, - Err(e) => { - debug!("user not found: {}", e); + Err(sqlx::Error::RowNotFound) => { + debug!("user not found: {}", username); return Err(ErrorResponse::reply("user not found").with_status(StatusCode::NOT_FOUND)); } + Err(err) => { + error!("database error: {}", err); + return Err(ErrorResponse::reply("database error") + .with_status(StatusCode::INTERNAL_SERVER_ERROR)); + } }; Ok(Json(UserResponse { @@ -96,20 +101,28 @@ pub async fn login( ) -> Result<Json<LoginResponse>, ErrorResponseStatus<'static>> { let user = match db.get_user(login.username.borrow()).await { Ok(u) => u, + Err(sqlx::Error::RowNotFound) => { + return Err(ErrorResponse::reply("user not found").with_status(StatusCode::NOT_FOUND)); + } Err(e) => { error!("failed to get user {}: {}", login.username.clone(), e); - return Err(ErrorResponse::reply("user not found").with_status(StatusCode::NOT_FOUND)); + return Err(ErrorResponse::reply("database error") + .with_status(StatusCode::INTERNAL_SERVER_ERROR)); } }; let session = match db.get_user_session(&user).await { Ok(u) => u, - Err(e) => { - error!("failed to get session for {}: {}", login.username, e); - + Err(sqlx::Error::RowNotFound) => { + debug!("user session not found for user id={}", user.id); return Err(ErrorResponse::reply("user not found").with_status(StatusCode::NOT_FOUND)); } + Err(err) => { + error!("database error for user {}: {}", login.username, err); + return Err(ErrorResponse::reply("database error") + .with_status(StatusCode::INTERNAL_SERVER_ERROR)); + } }; let verified = verify_str(user.password.as_str(), login.password.borrow()); |
