2022-04-21 18:54:53 +00:00
|
|
|
use axum::{Extension, Json};
|
2022-04-18 12:13:15 +00:00
|
|
|
use homedisk_types::{
|
2022-04-18 12:17:30 +00:00
|
|
|
auth::login::{Request, Response},
|
2022-04-21 18:54:53 +00:00
|
|
|
config::types::Config,
|
2022-04-18 12:13:15 +00:00
|
|
|
errors::{AuthError, ServerError},
|
2022-04-21 18:54:53 +00:00
|
|
|
token::{Claims, Token},
|
2022-04-18 12:13:15 +00:00
|
|
|
};
|
2022-04-21 18:54:53 +00:00
|
|
|
use homedisk_utils::database::{Database, User};
|
2022-04-18 12:13:15 +00:00
|
|
|
|
2022-04-21 18:54:53 +00:00
|
|
|
pub async fn handle(
|
|
|
|
db: Extension<Database>,
|
|
|
|
config: Extension<Config>,
|
|
|
|
Json(request): Json<Request>,
|
|
|
|
) -> Result<Json<Response>, ServerError> {
|
|
|
|
let user = User::new(&request.username, &request.password);
|
|
|
|
|
|
|
|
let response = match db.find_user(&user.username, &user.password).await {
|
|
|
|
Ok(res) => {
|
|
|
|
let token = Token::new(config.jwt.secret.as_bytes(), Claims::new(res.id)).unwrap();
|
|
|
|
|
|
|
|
Response::LoggedIn {
|
|
|
|
access_token: token.encoded,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Err(e) => {
|
|
|
|
use homedisk_utils::database::Error;
|
|
|
|
match e {
|
|
|
|
Error::UserNotFound => return Err(ServerError::AuthError(AuthError::UserNotFound)),
|
|
|
|
_ => {
|
|
|
|
return Err(ServerError::AuthError(AuthError::UnknowError(
|
|
|
|
e.to_string(),
|
|
|
|
)))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Ok(Json(response))
|
2022-04-18 12:13:15 +00:00
|
|
|
}
|