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 PveErasureCodingConfig {

    /// CRUSH device class. Will create an erasure coded pool plus a replicated pool for metadata.
    #[serde(rename = "device-class", skip_serializing_if = "Option::is_none")]
    pub device_class: Option<String>,

    /// CRUSH failure domain. Default is 'host'. Will create an erasure coded pool plus a replicated pool for metadata.
    #[serde(rename = "failure-domain", skip_serializing_if = "Option::is_none")]
    pub failure_domain: Option<String>,

    /// Number of data chunks. Will create an erasure coded pool plus a replicated pool for metadata.
    #[serde(rename = "k")]
    pub k: i64,

    /// Number of coding chunks. Will create an erasure coded pool plus a replicated pool for metadata.
    #[serde(rename = "m")]
    pub m: i64,

    /// Override the erasure code (EC) profile to use. Will create an erasure coded pool plus a replicated pool for metadata.
    #[serde(rename = "profile", skip_serializing_if = "Option::is_none")]
    pub profile: Option<String>,


}

impl PveErasureCodingConfig {
    pub fn new(k: i64, m: i64) -> PveErasureCodingConfig {
        PveErasureCodingConfig {
            
            device_class: None,
            
            failure_domain: None,
            
            k,
            
            m,
            
            profile: None,
            
        }
    }
}


impl PveErasureCodingConfig {
    /// Serialise this PveErasureCodingConfig into Proxmox's CLI-style shorthand
    /// string (`key=value,…`). The property marked `x-pve-default-key`
    /// is emitted positionally without a `key=` prefix; aliases collapse
    /// multiple property names to the same wire key.
    ///
    /// Example: `PveErasureCodingConfig `
    /// → `"virtio,bridge=vmbr0"`
    pub fn to_shorthand(&self) -> String {
        let mut parts: Vec<String> = Vec::new();
        
        
        
        if let Some(ref v) = self.device_class {
            parts.push(format!("device-class={}", v));
        }
        
        
        if let Some(ref v) = self.failure_domain {
            parts.push(format!("failure-domain={}", v));
        }
        
        
        parts.push(format!("k={}", self.k));
        
        
        
        parts.push(format!("m={}", self.m));
        
        
        
        if let Some(ref v) = self.profile {
            parts.push(format!("profile={}", v));
        }
        
        parts.join(",")
    }
}