use std::fs; use crate::fs::validate_path; use axum::extract::Query; use axum::Extension; use axum_auth::AuthBearer; use homedisk_database::Database; use homedisk_types::fs::upload::Pagination; use homedisk_types::{config::Config, errors::ServerError}; use crate::middleware::{find_user, validate_jwt}; /// Handle `/fs/download` requests pub async fn handle( Extension(db): Extension, Extension(config): Extension, AuthBearer(token): AuthBearer, query: Query, ) -> Result, ServerError> { // validate user token let token = validate_jwt(config.jwt.secret.as_bytes(), &token)?; // validate the `path` can be used validate_path(&query.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 = query.path ); // read file content let content = fs::read(path).unwrap(); // send file content in Response Ok(content) }