osdm-sys 0.1.0-alpha.3

Specifications for the OSDM API standard. The OSDM specification supports two modes of operation: Retailer Mode and Distributor Mode. The API works identically in both modes, except that in distributor mode the API also returns fare information. The following resources are key to get started: - [Processes](https://osdm.io/spec/processes/) - [Models](https://osdm.io/spec/models/) - [Getting started](https://osdm.io/spec/getting-started/)
Documentation
/*
 * UIC 90918-10 - OSDM
 *
 * Specifications for the OSDM API standard. The OSDM specification supports two modes of operation: Retailer Mode and Distributor Mode. The API works identically in both modes, except that in distributor mode the API also returns fare information.  The following resources are key to get started:    -  [Processes](https://osdm.io/spec/processes/)   -  [Models](https://osdm.io/spec/models/)   -  [Getting started](https://osdm.io/spec/getting-started/) 
 *
 * The version of the OpenAPI document: 3.7.0
 * Contact: osdm@uic.org
 * Generated by: https://openapi-generator.tech
 */

use crate::models;
use serde::{Deserialize, Serialize};

/// TransferLeg : A leg which links other legs of a trip where a transfer between different places is required. Provided by OJP. 
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
pub struct TransferLeg {
    /// Types of modes that run at any time without a timetable. Provided by OJP. 
    #[serde(rename = "continuousMode", skip_serializing_if = "Option::is_none")]
    pub continuous_mode: Option<String>,
    /// Modes dedicated to perform transfers. Provided by OJP. 
    #[serde(rename = "transferMode", skip_serializing_if = "Option::is_none")]
    pub transfer_mode: Option<String>,
    #[serde(rename = "start")]
    pub start: Box<models::PlaceRef>,
    #[serde(rename = "end")]
    pub end: Box<models::PlaceRef>,
    /// Time at which window begins. 
    #[serde(rename = "timeWindowStart", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
    pub time_window_start: Option<Option<String>>,
    /// Time at which window ends. 
    #[serde(rename = "timeWindowEnd", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
    pub time_window_end: Option<Option<String>>,
    /// Overall duration of this interchange. 
    #[serde(rename = "duration", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
    pub duration: Option<Option<String>>,
    #[serde(rename = "situationFullRefs", skip_serializing_if = "Option::is_none")]
    pub situation_full_refs: Option<Vec<String>>,
    #[serde(rename = "co2Emission", skip_serializing_if = "Option::is_none")]
    pub co2_emission: Option<Box<models::Quantity>>,
}

impl TransferLeg {
    /// A leg which links other legs of a trip where a transfer between different places is required. Provided by OJP. 
    pub fn new(start: models::PlaceRef, end: models::PlaceRef) -> TransferLeg {
        TransferLeg {
            continuous_mode: None,
            transfer_mode: None,
            start: Box::new(start),
            end: Box::new(end),
            time_window_start: None,
            time_window_end: None,
            duration: None,
            situation_full_refs: None,
            co2_emission: None,
        }
    }
}