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 Endpoint schema contains the properties of an endpoint resource that represents the properties of an entity that sends or receives protocol-defined messages over a transport.
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
#[derive(derivative::Derivative)]
#[derivative(Default)]
pub struct Endpoint {
    #[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(\"#Endpoint.v1_8_0.Endpoint\".to_string())"))]
    pub odata_type: models::odata_v4::Type,
    #[serde(rename = "Actions")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub actions: Option<models::endpoint::v1_8_0::Actions>,
    /// All the entities connected to this endpoint.
    #[serde(rename = "ConnectedEntities")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub connected_entities: Option<Vec<models::endpoint::v1_8_0::ConnectedEntity>>,
    #[serde(rename = "Description")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub description: Option<models::resource::Description>,
    #[serde(rename = "EndpointProtocol")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub endpoint_protocol: Option<models::protocol::Protocol>,
    /// The amount of memory in bytes that the host should allocate to connect to this endpoint.
    #[serde(rename = "HostReservationMemoryBytes")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub host_reservation_memory_bytes: Option<i64>,
    /// An array of details for each IP transport supported by this endpoint.  The array structure can model multiple IP addresses for this endpoint.
    #[serde(rename = "IPTransportDetails")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub ip_transport_details: Option<Vec<models::endpoint::v1_8_0::IPTransportDetails>>,
    #[serde(rename = "Id")]
    #[serde(skip_deserializing)]
    pub id: models::resource::Id,
    /// Identifiers for this endpoint.
    #[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::endpoint::v1_8_0::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>,
    #[serde(rename = "PciId")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub pci_id: Option<models::endpoint::v1_8_0::PciId>,
    /// Redundancy information for the lower-level endpoints supporting this endpoint.
    #[serde(rename = "Redundancy")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub redundancy: Option<Vec<models::redundancy::Redundancy>>,
    #[serde(rename = "Redundancy@odata.count")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub redundancy_odata_count: Option<models::odata_v4::Count>,
    #[serde(rename = "Status")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub status: Option<models::resource::Status>,
}

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