HomeDisk/server/src/auth/register.rs

70 lines
2.0 KiB
Rust
Raw Normal View History

use std::fs;
use axum::{extract::rejection::JsonRejection, Extension, Json};
use homedisk_database::{Database, User};
use homedisk_types::{
auth::login::{Request, Response},
2022-06-08 19:16:12 +00:00
config::Config,
errors::{AuthError, ServerError},
2022-04-19 13:14:17 +00:00
};
use crate::middleware::{create_token, validate_json};
2022-06-08 19:16:12 +00:00
/// Handle `/auth/register` 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-04-30 19:56:06 +00:00
// username must contain at least 4 characters
if request.username.len() < 4 {
return Err(ServerError::AuthError(AuthError::UsernameTooShort));
}
// username must be less than 25 characters
if request.username.len() > 25 {
2022-04-30 19:56:06 +00:00
return Err(ServerError::AuthError(AuthError::UsernameTooLong));
}
// password must contain at least 8 characters
if request.password.len() < 8 {
return Err(ServerError::AuthError(AuthError::PasswordTooShort));
}
2022-04-19 13:14:17 +00:00
let user = User::new(&request.username, &request.password);
let response = match db.create_user(&user).await {
Ok(_) => {
let token = create_token(&user, config.jwt.secret.as_bytes(), config.jwt.expires)?;
2022-04-19 13:14:17 +00:00
Response::LoggedIn {
access_token: token,
2022-04-19 13:14:17 +00:00
}
}
2022-06-11 08:19:47 +00:00
// error while searching for a user
Err(err) => {
// user already exists
if err.to_string().contains("UNIQUE constraint failed") {
return Err(ServerError::AuthError(AuthError::UserAlreadyExists));
}
2022-06-11 08:19:47 +00:00
// other error
return Err(ServerError::AuthError(AuthError::Other(err.to_string())));
}
};
// create directory for user files
let user_dir = format!(
"{storage}/{username}",
storage = config.storage.path,
username = user.username,
);
fs::create_dir_all(&user_dir).unwrap();
Ok(Json(response))
}