api2/config/{drive, changer}: prevent adding same device multiple times
this check is not perfect since there are often multiple device nodes per drive/changer, but from the scan api we should return always the same, so for an api user this should be enough Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
This commit is contained in:
parent
cef4654ff4
commit
b03ec281bf
@ -59,10 +59,18 @@ pub fn create_changer(
|
||||
|
||||
check_drive_path(&linux_changers, &path)?;
|
||||
|
||||
if config.sections.get(&name).is_some() {
|
||||
let existing: Vec<ScsiTapeChanger> = config.convert_to_typed_array("changer")?;
|
||||
|
||||
for changer in existing {
|
||||
if changer.name == name {
|
||||
bail!("Entry '{}' already exists", name);
|
||||
}
|
||||
|
||||
if changer.path == path {
|
||||
bail!("Path '{}' already in use by '{}'", path, changer.name);
|
||||
}
|
||||
}
|
||||
|
||||
let item = ScsiTapeChanger {
|
||||
name: name.clone(),
|
||||
path,
|
||||
|
@ -56,9 +56,16 @@ pub fn create_drive(param: Value) -> Result<(), Error> {
|
||||
|
||||
check_drive_path(&linux_drives, &item.path)?;
|
||||
|
||||
if config.sections.get(&item.name).is_some() {
|
||||
let existing: Vec<LinuxTapeDrive> = config.convert_to_typed_array("linux")?;
|
||||
|
||||
for drive in existing {
|
||||
if drive.name == item.name {
|
||||
bail!("Entry '{}' already exists", item.name);
|
||||
}
|
||||
if drive.path == item.path {
|
||||
bail!("Path '{}' already used in drive '{}'", item.path, drive.name);
|
||||
}
|
||||
}
|
||||
|
||||
config.set_data(&item.name, "linux", &item)?;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user