tape: add MediaPool::lock_unassigned_media_pool() helper
This commit is contained in:
parent
54fcb7f5d8
commit
2ab2ca9c24
@ -441,9 +441,7 @@ impl MediaPool {
|
|||||||
println!("no expired media in pool, try to find unassigned/free media");
|
println!("no expired media in pool, try to find unassigned/free media");
|
||||||
|
|
||||||
// try unassigned media
|
// try unassigned media
|
||||||
|
let _lock = Self::lock_unassigned_media_pool(&self.state_path)?;
|
||||||
// lock artificial "__UNASSIGNED__" pool to avoid races
|
|
||||||
let _lock = MediaPool::lock(&self.state_path, "__UNASSIGNED__")?;
|
|
||||||
|
|
||||||
self.inventory.reload()?;
|
self.inventory.reload()?;
|
||||||
|
|
||||||
@ -574,6 +572,12 @@ impl MediaPool {
|
|||||||
|
|
||||||
Ok(MediaPoolLockGuard(lock))
|
Ok(MediaPoolLockGuard(lock))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Lock for media not assigned to any pool
|
||||||
|
pub fn lock_unassigned_media_pool(base_path: &Path) -> Result<MediaPoolLockGuard, Error> {
|
||||||
|
// lock artificial "__UNASSIGNED__" pool to avoid races
|
||||||
|
MediaPool::lock(base_path, "__UNASSIGNED__")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Backup media
|
/// Backup media
|
||||||
|
Loading…
Reference in New Issue
Block a user