2022-04-23 21:48:20 +00:00
|
|
|
use axum::{Extension, Json};
|
|
|
|
use axum_auth::AuthBearer;
|
|
|
|
use homedisk_database::{Database, Error};
|
|
|
|
use homedisk_types::{
|
|
|
|
auth::whoami::Response,
|
|
|
|
config::types::Config,
|
|
|
|
errors::{AuthError, ServerError},
|
|
|
|
};
|
|
|
|
|
|
|
|
use crate::middleware::validate_jwt;
|
|
|
|
|
|
|
|
pub async fn handle(
|
|
|
|
db: Extension<Database>,
|
|
|
|
config: Extension<Config>,
|
|
|
|
AuthBearer(token): AuthBearer,
|
|
|
|
) -> Result<Json<Response>, ServerError> {
|
2022-06-07 20:36:26 +00:00
|
|
|
// validate user token
|
2022-04-23 21:48:20 +00:00
|
|
|
let token = validate_jwt(config.jwt.secret.as_bytes(), &token)?;
|
|
|
|
|
|
|
|
let response = match db.find_user_by_id(token.claims.sub).await {
|
|
|
|
Ok(res) => Response {
|
|
|
|
username: res.username,
|
|
|
|
},
|
|
|
|
|
|
|
|
Err(err) => match err {
|
|
|
|
Error::UserNotFound => return Err(ServerError::AuthError(AuthError::UserNotFound)),
|
|
|
|
_ => {
|
2022-05-01 20:44:28 +00:00
|
|
|
return Err(ServerError::AuthError(AuthError::UnknownError(
|
2022-04-23 21:48:20 +00:00
|
|
|
err.to_string(),
|
|
|
|
)))
|
|
|
|
}
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
Ok(Json(response))
|
|
|
|
}
|