From 66f4e6a8091d74712bd15925636f8d10501839d7 Mon Sep 17 00:00:00 2001 From: Dominik Csapak Date: Mon, 28 Sep 2020 15:32:05 +0200 Subject: [PATCH] server/worker_task: refactor locking of the task list also add the functionality of having a 'shared' (read) lock for the list we will need this later Signed-off-by: Dominik Csapak --- src/server/worker_task.rs | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/src/server/worker_task.rs b/src/server/worker_task.rs index a24e59b4..34d31f99 100644 --- a/src/server/worker_task.rs +++ b/src/server/worker_task.rs @@ -325,6 +325,15 @@ pub struct TaskListInfo { pub state: Option, // endtime, status } +fn lock_task_list_files(exclusive: bool) -> Result { + let backup_user = crate::backup::backup_user()?; + + let lock = open_file_locked(PROXMOX_BACKUP_TASK_LOCK_FN, std::time::Duration::new(10, 0), exclusive)?; + nix::unistd::chown(PROXMOX_BACKUP_TASK_LOCK_FN, Some(backup_user.uid), Some(backup_user.gid))?; + + Ok(lock) +} + // atomically read/update the task list, update status of finished tasks // new_upid is added to the list when specified. // Returns a sorted list of known tasks, @@ -332,8 +341,7 @@ fn update_active_workers(new_upid: Option<&UPID>) -> Result, E let backup_user = crate::backup::backup_user()?; - let lock = open_file_locked(PROXMOX_BACKUP_TASK_LOCK_FN, std::time::Duration::new(10, 0), true)?; - nix::unistd::chown(PROXMOX_BACKUP_TASK_LOCK_FN, Some(backup_user.uid), Some(backup_user.gid))?; + let lock = lock_task_list_files(true)?; let reader = match File::open(PROXMOX_BACKUP_ACTIVE_TASK_FN) { Ok(f) => Some(BufReader::new(f)),