1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
* Proxmox Virtual Environment API
*
* Generated from apidoc.js. NOT an official Proxmox specification. See https://pve.proxmox.com/pve-docs/api-viewer/ for the upstream documentation.
*
* The version of the OpenAPI document: 9.x
*
* Generated by: https://openapi-generator.tech
*/
use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct PveStorageLvmConfig {
/// Volume group name.
#[serde(rename = "vgname")]
pub vgname: String,
/// List of nodes for which the storage configuration applies.
#[serde(rename = "nodes", skip_serializing_if = "Option::is_none")]
pub nodes: Option<String>,
/// Indicate that this is a single storage with the same contents on all nodes (or all listed in the 'nodes' option). It will not make the contents of a local storage automatically accessible to other nodes, it just marks an already shared storage as such!
#[serde(rename = "shared", skip_serializing_if = "Option::is_none")]
pub shared: Option<models::PveBoolean>,
/// Flag to disable the storage.
#[serde(rename = "disable", skip_serializing_if = "Option::is_none")]
pub disable: Option<models::PveBoolean>,
/// Zero-out data when removing LVs.
#[serde(rename = "saferemove", skip_serializing_if = "Option::is_none")]
pub saferemove: Option<models::PveBoolean>,
/// Wipe step size in MiB. It will be capped to the maximum supported by the storage.
#[serde(rename = "saferemove-stepsize", skip_serializing_if = "Option::is_none")]
pub saferemove_stepsize: Option<models::PveSaferemoveStepsizeEnum>,
/// Wipe throughput (cstream -t parameter value).
#[serde(rename = "saferemove_throughput", skip_serializing_if = "Option::is_none")]
pub saferemove_throughput: Option<String>,
/// Allowed content types. NOTE: the value 'rootdir' is used for Containers, and value 'images' for VMs.
#[serde(rename = "content", skip_serializing_if = "Option::is_none")]
pub content: Option<String>,
/// Base volume. This volume is automatically activated.
#[serde(rename = "base", skip_serializing_if = "Option::is_none")]
pub base: Option<String>,
/// Only list logical volumes tagged with 'pve-vm-ID'.
#[serde(rename = "tagged_only", skip_serializing_if = "Option::is_none")]
pub tagged_only: Option<models::PveBoolean>,
/// Set I/O bandwidth limit for various operations (in KiB/s).
#[serde(rename = "bwlimit", skip_serializing_if = "Option::is_none")]
pub bwlimit: Option<Box<models::PveBwlimitField>>,
/// Enable support for creating storage-vendor agnostic snapshot through volume backing-chains.
#[serde(rename = "snapshot-as-volume-chain", skip_serializing_if = "Option::is_none")]
pub snapshot_as_volume_chain: Option<models::PveBoolean>,
#[serde(rename = "type")]
pub r#type: Type,
}
impl PveStorageLvmConfig {
pub fn new(vgname: String, r#type: Type) -> PveStorageLvmConfig {
PveStorageLvmConfig {
vgname,
nodes: None,
shared: None,
disable: None,
saferemove: None,
saferemove_stepsize: None,
saferemove_throughput: None,
content: None,
base: None,
tagged_only: None,
bwlimit: None,
snapshot_as_volume_chain: None,
r#type,
}
}
}
///
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Type {
#[serde(rename = "lvm")]
Lvm,
}
impl Default for Type {
fn default() -> Type {
Self::Lvm
}
}