clientapi-pve 2026.5.24

Generated from apidoc.js. NOT an official Proxmox specification. See https://pve.proxmox.com/pve-docs/api-viewer/ for the upstream documentation.
Documentation
/*
 * 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
    }
}