HomeDisk/server/src/auth/login.rs

48 lines
1.5 KiB
Rust
Raw Normal View History

use axum::{extract::rejection::JsonRejection, Extension, Json};
use homedisk_database::{Database, Error, User};
use homedisk_types::{
2022-04-18 12:17:30 +00:00
auth::login::{Request, Response},
2022-06-08 19:16:12 +00:00
config::Config,
errors::{AuthError, ServerError},
};
use crate::middleware::{create_token, validate_json};
2022-06-08 17:08:06 +00:00
/// Handle `/auth/login` requests
pub async fn handle(
2022-05-01 18:34:28 +00:00
Extension(db): Extension<Database>,
Extension(config): Extension<Config>,
request: Result<Json<Request>, JsonRejection>,
) -> Result<Json<Response>, ServerError> {
2022-06-07 20:36:26 +00:00
// validate json request
let request = validate_json::<Request>(request)?;
2022-06-08 17:08:06 +00:00
// create `User` type
let user = User::new(&request.username, &request.password);
2022-06-08 17:08:06 +00:00
// search for a user in database
let response = match db.find_user(&user.username, &user.password).await {
Ok(user) => {
2022-06-08 17:08:06 +00:00
// create user token
let token = create_token(&user, config.jwt.secret.as_bytes(), config.jwt.expires)?;
2022-06-11 08:19:47 +00:00
// Reponse user token
Response::LoggedIn {
access_token: token,
}
}
2022-06-11 08:19:47 +00:00
// error while searching for a user
2022-05-01 18:34:28 +00:00
Err(err) => {
return match err {
2022-06-11 08:19:47 +00:00
// user not found
2022-05-01 18:34:28 +00:00
Error::UserNotFound => Err(ServerError::AuthError(AuthError::UserNotFound)),
2022-06-11 08:19:47 +00:00
// other error
_ => Err(ServerError::AuthError(AuthError::Other(err.to_string()))),
};
2022-05-01 18:34:28 +00:00
}
};
Ok(Json(response))
}