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 EndpointGroup schema describes group of endpoints that are managed as a unit.
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
#[derive(derivative::Derivative)]
#[derivative(Default)]
pub struct EndpointGroup {
    #[serde(rename = "@odata.context")]
    #[serde(skip_deserializing)]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub odata_context: Option<models::odata_v4::Context>,
    #[serde(rename = "@odata.etag")]
    #[serde(skip_deserializing)]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub odata_etag: Option<models::odata_v4::Etag>,
    #[serde(rename = "@odata.id")]
    #[serde(skip_deserializing)]
    pub odata_id: models::odata_v4::Id,
    #[serde(rename = "@odata.type")]
    #[serde(skip_deserializing)]
    #[derivative(Default(value = "models::odata_v4::Type(\"#EndpointGroup.v1_3_2.EndpointGroup\".to_string())"))]
    pub odata_type: models::odata_v4::Type,
    #[serde(rename = "AccessState")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub access_state: Option<models::endpoint_group::AccessState>,
    #[serde(rename = "Actions")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub actions: Option<models::endpoint_group::v1_3_2::Actions>,
    #[serde(rename = "Description")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub description: Option<models::resource::Description>,
    /// The endpoints in this endpoint group.
    #[serde(rename = "Endpoints")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub endpoints: Option<Vec<models::odata_v4::IdRef>>,
    #[serde(rename = "Endpoints@odata.count")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub endpoints_odata_count: Option<models::odata_v4::Count>,
    #[serde(rename = "GroupType")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub group_type: Option<models::endpoint_group::v1_3_2::GroupType>,
    #[serde(rename = "Id")]
    #[serde(skip_deserializing)]
    pub id: models::resource::Id,
    #[serde(rename = "Identifier")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub identifier: Option<models::resource::Identifier>,
    #[serde(rename = "Links")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub links: Option<models::endpoint_group::v1_3_2::Links>,
    #[serde(rename = "Name")]
    #[serde(skip_deserializing)]
    pub name: models::resource::Name,
    #[serde(rename = "Oem")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub oem: Option<models::resource::Oem>,
    /// An indication if access to the resources through the endpoint group is preferred.
    #[serde(rename = "Preferred")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub preferred: Option<bool>,
    /// The SCSI-defined identifier for this group.
    #[serde(rename = "TargetEndpointGroupIdentifier")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub target_endpoint_group_identifier: Option<i64>,
}

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