tape: implement option changer-drive-id
This commit is contained in:
@ -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)?;
|
||||
|
Reference in New Issue
Block a user