use std::fs; use axum::{extract::rejection::JsonRejection, Extension, Json}; use axum_auth::AuthBearer; use homedisk_database::Database; use homedisk_types::{ config::Config, errors::{FsError, ServerError}, fs::create_dir::Request, }; use crate::middleware::{find_user, validate_json, validate_jwt, validate_path}; pub async fn handle( Extension(db): Extension, Extension(config): Extension, AuthBearer(token): AuthBearer, request: Result, JsonRejection>, ) -> Result<(), ServerError> { // validate json request let Json(request) = validate_json(request)?; // validate user token let token = validate_jwt(config.jwt.secret.as_bytes(), &token)?; // validate the `path` can be used validate_path(&request.path)?; // search for a user by UUID from a token let user = find_user(&db, &token.claims.sub).await?; // directory where the file will be placed let path = format!( "{user_dir}/{req_dir}", user_dir = user.user_dir(&config.storage.path), req_dir = request.path ); // create directories fs::create_dir_all(path) .map_err(|err| ServerError::FsError(FsError::CreateDirectory(err.to_string())))?; // send an empty response Ok(()) }