Cleanup temporary directory on launch by default

This commit is contained in:
asonix 2024-03-23 18:41:59 -05:00
parent 34b9919428
commit 793d3c0c70
6 changed files with 42 additions and 9 deletions

View file

@ -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

View file

@ -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)]

View file

@ -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,
} }
} }
} }

View file

@ -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>,

View file

@ -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()?;

View file

@ -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);
}
} }
} }
} }