tape: implement option changer-drive-id

This commit is contained in:
Dietmar Maurer
2020-12-10 09:09:06 +01:00
parent a3c709ef21
commit f70d8091d3
5 changed files with 56 additions and 14 deletions

View File

@ -10,6 +10,7 @@ use crate::{
PROXMOX_CONFIG_DIGEST_SCHEMA,
DRIVE_ID_SCHEMA,
CHANGER_ID_SCHEMA,
CHANGER_DRIVE_ID_SCHEMA,
LINUX_DRIVE_PATH_SCHEMA,
DriveListEntry,
LinuxTapeDrive,
@ -36,6 +37,10 @@ use crate::{
schema: CHANGER_ID_SCHEMA,
optional: true,
},
"changer-drive-id": {
schema: CHANGER_DRIVE_ID_SCHEMA,
optional: true,
},
},
},
)]
@ -142,10 +147,13 @@ pub fn list_drives(
#[api()]
#[derive(Serialize, Deserialize)]
#[allow(non_camel_case_types)]
#[serde(rename_all = "kebab-case")]
/// Deletable property name
pub enum DeletableProperty {
/// Delete the changer property.
changer,
/// Delete the changer-drive-id property.
changer_drive_id,
}
#[api(
@ -163,6 +171,10 @@ pub enum DeletableProperty {
schema: CHANGER_ID_SCHEMA,
optional: true,
},
"changer-drive-id": {
schema: CHANGER_DRIVE_ID_SCHEMA,
optional: true,
},
delete: {
description: "List of properties to delete.",
type: Array,
@ -183,6 +195,7 @@ pub fn update_drive(
name: String,
path: Option<String>,
changer: Option<String>,
changer_drive_id: Option<u64>,
delete: Option<Vec<DeletableProperty>>,
digest: Option<String>,
_param: Value,
@ -202,7 +215,11 @@ pub fn update_drive(
if let Some(delete) = delete {
for delete_prop in delete {
match delete_prop {
DeletableProperty::changer => { data.changer = None; },
DeletableProperty::changer => {
data.changer = None;
data.changer_drive_id = None;
},
DeletableProperty::changer_drive_id => { data.changer_drive_id = None; },
}
}
}
@ -218,6 +235,17 @@ pub fn update_drive(
data.changer = Some(changer);
}
if let Some(changer_drive_id) = changer_drive_id {
if changer_drive_id == 0 {
data.changer_drive_id = None;
} else {
if data.changer.is_none() {
bail!("Option 'changer-drive-id' requires option 'changer'.");
}
data.changer_drive_id = Some(changer_drive_id);
}
}
config.set_data(&name, "linux", &data)?;
config::drive::save_config(&config)?;