redfish-codegen 0.3.1

An unopinionated translation of the Redfish specification into Rust.
Documentation
// Generated by redfish-codegen. Do not modify.

use crate::models;

/// The StorageController schema describes a storage controller and its properties.  A storage controller represents a physical or virtual storage device that produces volumes.
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
#[derive(derivative::Derivative)]
#[derivative(Default)]
pub struct StorageController {
    #[serde(rename = "@odata.id")]
    #[serde(skip_deserializing)]
    pub odata_id: models::odata_v4::Id,
    #[serde(rename = "Actions")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub actions: Option<models::storage::v1_13_0::StorageControllerActions>,
    #[serde(rename = "Assembly")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub assembly: Option<models::odata_v4::IdRef>,
    /// The user-assigned asset tag for this storage controller.
    #[serde(rename = "AssetTag")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub asset_tag: Option<String>,
    #[serde(rename = "CacheSummary")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub cache_summary: Option<models::storage::v1_13_0::CacheSummary>,
    #[serde(rename = "Certificates")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub certificates: Option<models::odata_v4::IdRef>,
    #[serde(rename = "ControllerRates")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub controller_rates: Option<models::storage::v1_13_0::Rates>,
    /// The firmware version of this storage controller.
    #[serde(rename = "FirmwareVersion")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub firmware_version: Option<String>,
    /// The durable names for the storage controller.
    #[serde(rename = "Identifiers")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub identifiers: Option<Vec<models::resource::Identifier>>,
    #[serde(rename = "Links")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub links: Option<models::storage::v1_13_0::StorageControllerLinks>,
    #[serde(rename = "Location")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub location: Option<models::resource::Location>,
    /// The manufacturer of this storage controller.
    #[serde(rename = "Manufacturer")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub manufacturer: Option<String>,
    /// An array of DSP0274-defined measurement blocks.
    #[serde(rename = "Measurements")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub measurements: Option<Vec<models::software_inventory::MeasurementBlock>>,
    /// The unique identifier for the member within an array.
    #[serde(rename = "MemberId")]
    pub member_id: String,
    /// The model number for the storage controller.
    #[serde(rename = "Model")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub model: Option<String>,
    /// The name of the storage controller.
    #[serde(rename = "Name")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub name: Option<String>,
    #[serde(rename = "Oem")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub oem: Option<models::resource::Oem>,
    #[serde(rename = "PCIeInterface")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub pcie_interface: Option<models::pcie_device::PCIeInterface>,
    /// The part number for this storage controller.
    #[serde(rename = "PartNumber")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub part_number: Option<String>,
    #[serde(rename = "Ports")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub ports: Option<models::odata_v4::IdRef>,
    /// The SKU for this storage controller.
    #[serde(rename = "SKU")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub sku: Option<String>,
    /// The serial number for this storage controller.
    #[serde(rename = "SerialNumber")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub serial_number: Option<String>,
    /// The maximum speed of the storage controller's device interface.
    #[serde(rename = "SpeedGbps")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub speed_gbps: Option<f64>,
    #[serde(rename = "Status")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub status: Option<models::resource::Status>,
    /// The supported set of protocols for communicating to this storage controller.
    #[serde(rename = "SupportedControllerProtocols")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub supported_controller_protocols: Option<Vec<models::protocol::Protocol>>,
    /// The protocols that the storage controller can use to communicate with attached devices.
    #[serde(rename = "SupportedDeviceProtocols")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub supported_device_protocols: Option<Vec<models::protocol::Protocol>>,
    /// The set of RAID types supported by the storage controller.
    #[serde(rename = "SupportedRAIDTypes")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub supported_raid_types: Option<Vec<models::volume::RAIDType>>,
}

impl crate::Metadata<'static> for StorageController {
    const JSON_SCHEMA: &'static str = "Storage.v1_13_0.json";
}