mirror of
https://git.asonix.dog/asonix/pict-rs.git
synced 2025-01-06 01:28:45 +00:00
Cleanup temporary directory on launch by default
This commit is contained in:
parent
34b9919428
commit
793d3c0c70
6 changed files with 42 additions and 9 deletions
|
@ -4,6 +4,7 @@ read_only = false
|
||||||
danger_dummy_mode = false
|
danger_dummy_mode = false
|
||||||
max_file_count = 1
|
max_file_count = 1
|
||||||
temporary_directory = "/tmp"
|
temporary_directory = "/tmp"
|
||||||
|
cleanup_temporary_directory = true
|
||||||
|
|
||||||
[client]
|
[client]
|
||||||
timeout = 30
|
timeout = 30
|
||||||
|
@ -46,7 +47,7 @@ proxy = "7d"
|
||||||
[media.magick]
|
[media.magick]
|
||||||
max_width = 10000
|
max_width = 10000
|
||||||
max_height = 10000
|
max_height = 10000
|
||||||
max_area = 40000000
|
max_area = 20000
|
||||||
memory = 256
|
memory = 256
|
||||||
map = 512
|
map = 512
|
||||||
disk = 1024
|
disk = 1024
|
||||||
|
|
|
@ -55,6 +55,7 @@ impl Args {
|
||||||
address,
|
address,
|
||||||
api_key,
|
api_key,
|
||||||
temporary_directory,
|
temporary_directory,
|
||||||
|
no_cleanup_temporary_directory,
|
||||||
certificate,
|
certificate,
|
||||||
private_key,
|
private_key,
|
||||||
client_timeout,
|
client_timeout,
|
||||||
|
@ -122,6 +123,7 @@ impl Args {
|
||||||
danger_dummy_mode,
|
danger_dummy_mode,
|
||||||
max_file_count,
|
max_file_count,
|
||||||
temporary_directory,
|
temporary_directory,
|
||||||
|
cleanup_temporary_directory: !no_cleanup_temporary_directory,
|
||||||
certificate,
|
certificate,
|
||||||
private_key,
|
private_key,
|
||||||
};
|
};
|
||||||
|
@ -541,6 +543,7 @@ struct Server {
|
||||||
max_file_count: Option<u32>,
|
max_file_count: Option<u32>,
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
temporary_directory: Option<PathBuf>,
|
temporary_directory: Option<PathBuf>,
|
||||||
|
cleanup_temporary_directory: bool,
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
certificate: Option<PathBuf>,
|
certificate: Option<PathBuf>,
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
@ -973,6 +976,10 @@ struct Run {
|
||||||
#[arg(long)]
|
#[arg(long)]
|
||||||
temporary_directory: Option<PathBuf>,
|
temporary_directory: Option<PathBuf>,
|
||||||
|
|
||||||
|
/// Whether to attempt to clean files left behind from a previous run of pict-rs
|
||||||
|
#[arg(long)]
|
||||||
|
no_cleanup_temporary_directory: bool,
|
||||||
|
|
||||||
/// The path to the TLS certificate. Both the certificate and the private_key must be specified
|
/// The path to the TLS certificate. Both the certificate and the private_key must be specified
|
||||||
/// to enable TLS
|
/// to enable TLS
|
||||||
#[arg(long)]
|
#[arg(long)]
|
||||||
|
|
|
@ -24,6 +24,7 @@ struct ServerDefaults {
|
||||||
danger_dummy_mode: bool,
|
danger_dummy_mode: bool,
|
||||||
max_file_count: u32,
|
max_file_count: u32,
|
||||||
temporary_directory: PathBuf,
|
temporary_directory: PathBuf,
|
||||||
|
cleanup_temporary_directory: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Serialize)]
|
||||||
|
@ -211,6 +212,7 @@ impl Default for ServerDefaults {
|
||||||
danger_dummy_mode: false,
|
danger_dummy_mode: false,
|
||||||
max_file_count: 1,
|
max_file_count: 1,
|
||||||
temporary_directory: std::env::temp_dir(),
|
temporary_directory: std::env::temp_dir(),
|
||||||
|
cleanup_temporary_directory: true,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -119,6 +119,8 @@ pub(crate) struct Server {
|
||||||
|
|
||||||
pub(crate) temporary_directory: PathBuf,
|
pub(crate) temporary_directory: PathBuf,
|
||||||
|
|
||||||
|
pub(crate) cleanup_temporary_directory: bool,
|
||||||
|
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
pub(crate) certificate: Option<PathBuf>,
|
pub(crate) certificate: Option<PathBuf>,
|
||||||
|
|
||||||
|
|
|
@ -1924,7 +1924,11 @@ impl PictRsConfiguration {
|
||||||
// describe all the metrics pict-rs produces
|
// describe all the metrics pict-rs produces
|
||||||
init_metrics::init_metrics();
|
init_metrics::init_metrics();
|
||||||
|
|
||||||
let tmp_dir = TmpDir::init(&config.server.temporary_directory).await?;
|
let tmp_dir = TmpDir::init(
|
||||||
|
&config.server.temporary_directory,
|
||||||
|
config.server.cleanup_temporary_directory,
|
||||||
|
)
|
||||||
|
.await?;
|
||||||
let policy_dir = magick::write_magick_policy(&config.media, &tmp_dir).await?;
|
let policy_dir = magick::write_magick_policy(&config.media, &tmp_dir).await?;
|
||||||
|
|
||||||
let client = build_client()?;
|
let client = build_client()?;
|
||||||
|
|
|
@ -16,9 +16,17 @@ pub(crate) struct TmpDir {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TmpDir {
|
impl TmpDir {
|
||||||
pub(crate) async fn init<P: AsRef<Path>>(path: P) -> std::io::Result<Arc<Self>> {
|
pub(crate) async fn init<P: AsRef<Path>>(path: P, cleanup: bool) -> std::io::Result<Arc<Self>> {
|
||||||
let path = path.as_ref().join(Uuid::now_v7().to_string());
|
let base_path = path.as_ref().join("pict-rs");
|
||||||
tokio::fs::create_dir(&path).await?;
|
|
||||||
|
if cleanup && tokio::fs::metadata(&base_path).await.is_ok() {
|
||||||
|
tokio::fs::remove_dir_all(&base_path).await?;
|
||||||
|
}
|
||||||
|
|
||||||
|
let path = base_path.join(Uuid::now_v7().to_string());
|
||||||
|
|
||||||
|
tokio::fs::create_dir_all(&path).await?;
|
||||||
|
|
||||||
Ok(Arc::new(TmpDir { path: Some(path) }))
|
Ok(Arc::new(TmpDir { path: Some(path) }))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,8 +55,13 @@ impl TmpDir {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) async fn cleanup(self: Arc<Self>) -> std::io::Result<()> {
|
pub(crate) async fn cleanup(self: Arc<Self>) -> std::io::Result<()> {
|
||||||
if let Some(path) = Arc::into_inner(self).and_then(|mut this| this.path.take()) {
|
if let Some(mut path) = Arc::into_inner(self).and_then(|mut this| this.path.take()) {
|
||||||
tokio::fs::remove_dir_all(path).await?;
|
tokio::fs::remove_dir_all(&path).await?;
|
||||||
|
|
||||||
|
if path.pop() {
|
||||||
|
// attempt to remove parent directory if it is empty
|
||||||
|
let _ = tokio::fs::remove_dir(path).await;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -57,9 +70,13 @@ impl TmpDir {
|
||||||
|
|
||||||
impl Drop for TmpDir {
|
impl Drop for TmpDir {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
if let Some(path) = self.path.take() {
|
if let Some(mut path) = self.path.take() {
|
||||||
tracing::warn!("TmpDir - Blocking remove of {path:?}");
|
tracing::warn!("TmpDir - Blocking remove of {path:?}");
|
||||||
std::fs::remove_dir_all(path).expect("Removed directory");
|
std::fs::remove_dir_all(&path).expect("Removed directory");
|
||||||
|
if path.pop() {
|
||||||
|
// attempt to remove parent directory if it is empty
|
||||||
|
let _ = std::fs::remove_dir(path);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue