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

    /// List of nodes for which the storage configuration applies.
    #[serde(rename = "nodes", skip_serializing_if = "Option::is_none")]
    pub nodes: Option<String>,

    /// Flag to disable the storage.
    #[serde(rename = "disable", skip_serializing_if = "Option::is_none")]
    pub disable: Option<models::PveBoolean>,

    /// iSCSI portal (IP or DNS name with optional port).
    #[serde(rename = "portal")]
    pub portal: String,

    /// iSCSI target.
    #[serde(rename = "target")]
    pub target: String,

    /// Pool.
    #[serde(rename = "pool")]
    pub pool: String,

    /// ZFS block size
    #[serde(rename = "blocksize")]
    pub blocksize: String,

    /// iscsi provider
    #[serde(rename = "iscsiprovider")]
    pub iscsiprovider: String,

    /// disable write caching on the target
    #[serde(rename = "nowritecache", skip_serializing_if = "Option::is_none")]
    pub nowritecache: Option<models::PveBoolean>,

    /// use sparse volumes
    #[serde(rename = "sparse", skip_serializing_if = "Option::is_none")]
    pub sparse: Option<models::PveBoolean>,

    /// host group for comstar views
    #[serde(rename = "comstar_hg", skip_serializing_if = "Option::is_none")]
    pub comstar_hg: Option<String>,

    /// target group for comstar views
    #[serde(rename = "comstar_tg", skip_serializing_if = "Option::is_none")]
    pub comstar_tg: Option<String>,

    /// target portal group for Linux LIO targets
    #[serde(rename = "lio_tpg", skip_serializing_if = "Option::is_none")]
    pub lio_tpg: 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>,

    /// 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>>,

    /// Base path where to look for the created ZFS block devices. Set automatically during creation if not specified. Usually '/dev/zvol'.
    #[serde(rename = "zfs-base-path", skip_serializing_if = "Option::is_none")]
    pub zfs_base_path: Option<String>,

    #[serde(rename = "type")]
    pub r#type: Type,


}

impl PveStorageZfsConfig {
    pub fn new(portal: String, target: String, pool: String, blocksize: String, iscsiprovider: String, r#type: Type) -> PveStorageZfsConfig {
        PveStorageZfsConfig {
            
            nodes: None,
            
            disable: None,
            
            portal,
            
            target,
            
            pool,
            
            blocksize,
            
            iscsiprovider,
            
            nowritecache: None,
            
            sparse: None,
            
            comstar_hg: None,
            
            comstar_tg: None,
            
            lio_tpg: None,
            
            content: None,
            
            bwlimit: None,
            
            zfs_base_path: None,
            
            r#type,
            
        }
    }
}

/// 
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Type {
    #[serde(rename = "zfs")]
    Zfs,
}

impl Default for Type {
    fn default() -> Type {
        Self::Zfs
    }
}