2022-05-09 21:04:46 +00:00
|
|
|
use std::fs;
|
2022-05-07 13:19:36 +00:00
|
|
|
|
|
|
|
use crate::fs::validate_path;
|
|
|
|
use axum::extract::Query;
|
2022-05-09 21:04:46 +00:00
|
|
|
use axum::Extension;
|
2022-05-07 13:19:36 +00:00
|
|
|
use axum_auth::AuthBearer;
|
|
|
|
use homedisk_database::Database;
|
|
|
|
use homedisk_types::fs::upload::Pagination;
|
2022-05-27 13:58:16 +00:00
|
|
|
use homedisk_types::{config::types::Config, errors::ServerError};
|
2022-05-07 13:19:36 +00:00
|
|
|
|
2022-05-09 21:04:46 +00:00
|
|
|
use crate::middleware::{find_user, validate_jwt};
|
2022-05-07 13:19:36 +00:00
|
|
|
|
|
|
|
pub async fn handle(
|
|
|
|
Extension(db): Extension<Database>,
|
|
|
|
Extension(config): Extension<Config>,
|
|
|
|
AuthBearer(token): AuthBearer,
|
|
|
|
query: Query<Pagination>,
|
|
|
|
) -> Result<Vec<u8>, ServerError> {
|
|
|
|
// validate 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();
|
|
|
|
|
|
|
|
Ok(content)
|
|
|
|
}
|