- Added `bcrypt`, `jsonwebtoken`, and `once_cell` dependencies to manage password hashing and JWT handling. - Created `Claims` struct for JWT claims and implemented token generation in the login route. - Implemented user registration and authentication logic in the `auth` module. - Updated error handling to include validation errors. - Created new routes for user registration and login, and integrated them into the main router. - Added tests for the authentication flow, including registration and login scenarios. - Updated user model to include a password hash field. - Refactored user creation logic to include password validation. - Adjusted feed and user routes to utilize JWT for authentication.
42 lines
1.4 KiB
Rust
42 lines
1.4 KiB
Rust
use axum::{extract::rejection::JsonRejection, http::StatusCode};
|
|
use sea_orm::DbErr;
|
|
|
|
use app::error::UserError;
|
|
|
|
use super::traits::HTTPError;
|
|
|
|
impl HTTPError for JsonRejection {
|
|
fn to_status_code(&self) -> StatusCode {
|
|
match self {
|
|
JsonRejection::JsonSyntaxError(_) => StatusCode::BAD_REQUEST,
|
|
_ => StatusCode::BAD_REQUEST,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl HTTPError for DbErr {
|
|
fn to_status_code(&self) -> StatusCode {
|
|
match self {
|
|
DbErr::ConnectionAcquire(_) => StatusCode::INTERNAL_SERVER_ERROR,
|
|
DbErr::UnpackInsertId => StatusCode::CONFLICT,
|
|
DbErr::RecordNotFound(_) => StatusCode::NOT_FOUND,
|
|
DbErr::Custom(s) if s == "Users cannot follow themselves" => StatusCode::BAD_REQUEST,
|
|
_ => StatusCode::INTERNAL_SERVER_ERROR, // TODO:: more granularity
|
|
}
|
|
}
|
|
}
|
|
|
|
impl HTTPError for UserError {
|
|
fn to_status_code(&self) -> StatusCode {
|
|
match self {
|
|
UserError::NotFound => StatusCode::NOT_FOUND,
|
|
UserError::NotFollowing => StatusCode::NOT_FOUND,
|
|
UserError::Forbidden => StatusCode::FORBIDDEN,
|
|
UserError::UsernameTaken => StatusCode::BAD_REQUEST,
|
|
UserError::AlreadyFollowing => StatusCode::BAD_REQUEST,
|
|
UserError::Validation(_) => StatusCode::UNPROCESSABLE_ENTITY,
|
|
UserError::Internal(_) => StatusCode::INTERNAL_SERVER_ERROR,
|
|
}
|
|
}
|
|
}
|