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 TaskService schema describes a task service that enables management of long-duration operations, includes the properties for the task service itself, and has links to the resource collection of tasks.
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
#[derive(derivative::Derivative)]
#[derivative(Default)]
pub struct TaskService {
    #[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(\"#TaskService.v1_2_0.TaskService\".to_string())"))]
    pub odata_type: models::odata_v4::Type,
    #[serde(rename = "Actions")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub actions: Option<models::task_service::v1_2_0::Actions>,
    #[serde(rename = "CompletedTaskOverWritePolicy")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub completed_task_over_write_policy: Option<models::task_service::v1_2_0::OverWritePolicy>,
    /// The current date and time, with UTC offset, setting that the task service uses.
    #[serde(rename = "DateTime")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub date_time: Option<String>,
    #[serde(rename = "Description")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub description: Option<models::resource::Description>,
    #[serde(rename = "Id")]
    #[serde(skip_deserializing)]
    pub id: models::resource::Id,
    /// An indication of whether a task state change sends an event.
    #[serde(rename = "LifeCycleEventOnTaskStateChange")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub life_cycle_event_on_task_state_change: Option<bool>,
    #[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 of whether this service is enabled.
    #[serde(rename = "ServiceEnabled")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub service_enabled: Option<bool>,
    #[serde(rename = "Status")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub status: Option<models::resource::Status>,
    /// The number of minutes after which a completed task is deleted by the service.
    #[serde(rename = "TaskAutoDeleteTimeoutMinutes")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub task_auto_delete_timeout_minutes: Option<i64>,
    #[serde(rename = "Tasks")]
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub tasks: Option<models::odata_v4::IdRef>,
}

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