mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2025-01-01 00:18:50 +00:00
Create destination folder
This commit is contained in:
parent
23da151635
commit
368a512722
@ -15,6 +15,7 @@ use crate::data::error::{ExecError, ResultBoxError};
|
|||||||
use crate::data::user::UserID;
|
use crate::data::user::UserID;
|
||||||
use crate::helpers::{account_helper, api_helper, conversations_helper, user_helper};
|
use crate::helpers::{account_helper, api_helper, conversations_helper, user_helper};
|
||||||
use crate::utils::virtual_directories_utils::check_virtual_directory;
|
use crate::utils::virtual_directories_utils::check_virtual_directory;
|
||||||
|
use crate::utils::user_data_utils::prepare_file_creation;
|
||||||
|
|
||||||
/// Http request handler
|
/// Http request handler
|
||||||
///
|
///
|
||||||
@ -278,7 +279,9 @@ impl HttpRequestHandler {
|
|||||||
pub fn save_post_image(&mut self, name: &str, folder: &str, max_w: u32, max_h: u32) -> ResultBoxError<String> {
|
pub fn save_post_image(&mut self, name: &str, folder: &str, max_w: u32, max_h: u32) -> ResultBoxError<String> {
|
||||||
let file = self.post_file(name)?;
|
let file = self.post_file(name)?;
|
||||||
|
|
||||||
Ok(format!("f {} size: {}", file.name, file.buff.len()))
|
let target_user_data_folder = prepare_file_creation(self.user_id()?, folder)?;
|
||||||
|
|
||||||
|
Ok(target_user_data_folder.to_str().unwrap().to_string())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get an integer included in the POST request
|
/// Get an integer included in the POST request
|
||||||
|
@ -3,6 +3,10 @@
|
|||||||
//! @author Pierre Hubert
|
//! @author Pierre Hubert
|
||||||
|
|
||||||
use crate::data::config::conf;
|
use crate::data::config::conf;
|
||||||
|
use crate::data::error::ResultBoxError;
|
||||||
|
use crate::data::user::UserID;
|
||||||
|
use std::path::{Path, PathBuf};
|
||||||
|
use serde_json::to_string;
|
||||||
|
|
||||||
/// Get the full URL to a user data file
|
/// Get the full URL to a user data file
|
||||||
///
|
///
|
||||||
@ -10,3 +14,31 @@ use crate::data::config::conf;
|
|||||||
pub fn user_data_url(uri: &str) -> String {
|
pub fn user_data_url(uri: &str) -> String {
|
||||||
format!("{}{}", conf().storage_url, uri)
|
format!("{}{}", conf().storage_url, uri)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get the system path to a user data file
|
||||||
|
pub fn user_data_path(uri: &Path) -> PathBuf {
|
||||||
|
Path::new(conf().storage_path.as_str()).join(uri)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Prepare the creation of a file (user data file)
|
||||||
|
///
|
||||||
|
/// This function returns the relative folder path in user data directory where the file can be
|
||||||
|
/// created
|
||||||
|
pub fn prepare_file_creation(user_id: UserID, folder: &str) -> ResultBoxError<PathBuf> {
|
||||||
|
let subfolder = match user_id {
|
||||||
|
0 => Path::new(folder).to_path_buf(),
|
||||||
|
id => Path::new(folder).join(to_string(&id)?)
|
||||||
|
};
|
||||||
|
|
||||||
|
let full_path = user_data_path(subfolder.as_path());
|
||||||
|
|
||||||
|
if !full_path.exists() {
|
||||||
|
// Create the directory
|
||||||
|
std::fs::create_dir_all(&full_path)?;
|
||||||
|
|
||||||
|
// Block directory listing
|
||||||
|
std::fs::write(&full_path.join("index.html"), "<b>No listing.</b>")?;
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(subfolder)
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user