mirror of
git://git.proxmox.com/git/proxmox-backup.git
synced 2025-03-07 00:58:32 +03:00
pbs-api-types: add backing-device to DataStoreConfig
Signed-off-by: Hannes Laimer <h.laimer@proxmox.com>
This commit is contained in:
parent
ffc8265e1f
commit
89c650b83e
@ -45,7 +45,7 @@ const_regex! {
|
|||||||
|
|
||||||
pub const CHUNK_DIGEST_FORMAT: ApiStringFormat = ApiStringFormat::Pattern(&SHA256_HEX_REGEX);
|
pub const CHUNK_DIGEST_FORMAT: ApiStringFormat = ApiStringFormat::Pattern(&SHA256_HEX_REGEX);
|
||||||
|
|
||||||
pub const DIR_NAME_SCHEMA: Schema = StringSchema::new("Directory name")
|
pub const DATASTORE_DIR_NAME_SCHEMA: Schema = StringSchema::new("Either the absolute path to the datastore directory, or a relative on-device path for removable datastores.")
|
||||||
.min_length(1)
|
.min_length(1)
|
||||||
.max_length(4096)
|
.max_length(4096)
|
||||||
.schema();
|
.schema();
|
||||||
@ -163,6 +163,9 @@ pub const PRUNE_SCHEMA_KEEP_YEARLY: Schema =
|
|||||||
.minimum(1)
|
.minimum(1)
|
||||||
.schema();
|
.schema();
|
||||||
|
|
||||||
|
/// Base directory where datastores are mounted
|
||||||
|
pub const DATASTORE_MOUNT_DIR: &str = "/mnt/datastore";
|
||||||
|
|
||||||
#[api]
|
#[api]
|
||||||
#[derive(Debug, Default, Copy, Clone, PartialEq, Eq, Serialize, Deserialize)]
|
#[derive(Debug, Default, Copy, Clone, PartialEq, Eq, Serialize, Deserialize)]
|
||||||
#[serde(rename_all = "lowercase")]
|
#[serde(rename_all = "lowercase")]
|
||||||
@ -237,7 +240,7 @@ pub const DATASTORE_TUNING_STRING_SCHEMA: Schema = StringSchema::new("Datastore
|
|||||||
schema: DATASTORE_SCHEMA,
|
schema: DATASTORE_SCHEMA,
|
||||||
},
|
},
|
||||||
path: {
|
path: {
|
||||||
schema: DIR_NAME_SCHEMA,
|
schema: DATASTORE_DIR_NAME_SCHEMA,
|
||||||
},
|
},
|
||||||
"notify-user": {
|
"notify-user": {
|
||||||
optional: true,
|
optional: true,
|
||||||
@ -276,6 +279,12 @@ pub const DATASTORE_TUNING_STRING_SCHEMA: Schema = StringSchema::new("Datastore
|
|||||||
format: &ApiStringFormat::PropertyString(&MaintenanceMode::API_SCHEMA),
|
format: &ApiStringFormat::PropertyString(&MaintenanceMode::API_SCHEMA),
|
||||||
type: String,
|
type: String,
|
||||||
},
|
},
|
||||||
|
"backing-device": {
|
||||||
|
description: "The UUID of the filesystem partition for removable datastores.",
|
||||||
|
optional: true,
|
||||||
|
format: &proxmox_schema::api_types::UUID_FORMAT,
|
||||||
|
type: String,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
)]
|
)]
|
||||||
#[derive(Serialize, Deserialize, Updater, Clone, PartialEq)]
|
#[derive(Serialize, Deserialize, Updater, Clone, PartialEq)]
|
||||||
@ -323,6 +332,11 @@ pub struct DataStoreConfig {
|
|||||||
/// Maintenance mode, type is either 'offline' or 'read-only', message should be enclosed in "
|
/// Maintenance mode, type is either 'offline' or 'read-only', message should be enclosed in "
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
pub maintenance_mode: Option<String>,
|
pub maintenance_mode: Option<String>,
|
||||||
|
|
||||||
|
/// The UUID of the device(for removable datastores)
|
||||||
|
#[updater(skip)]
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub backing_device: Option<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[api]
|
#[api]
|
||||||
@ -357,13 +371,18 @@ impl DataStoreConfig {
|
|||||||
notification_mode: None,
|
notification_mode: None,
|
||||||
tuning: None,
|
tuning: None,
|
||||||
maintenance_mode: None,
|
maintenance_mode: None,
|
||||||
|
backing_device: None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the absolute path to the datastore content.
|
/// Returns the absolute path to the datastore content.
|
||||||
pub fn absolute_path(&self) -> String {
|
pub fn absolute_path(&self) -> String {
|
||||||
|
if self.backing_device.is_some() {
|
||||||
|
format!("{DATASTORE_MOUNT_DIR}/{}", self.name)
|
||||||
|
} else {
|
||||||
self.path.clone()
|
self.path.clone()
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_maintenance_mode(&self) -> Option<MaintenanceMode> {
|
pub fn get_maintenance_mode(&self) -> Option<MaintenanceMode> {
|
||||||
self.maintenance_mode.as_ref().and_then(|str| {
|
self.maintenance_mode.as_ref().and_then(|str| {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user