osdm-sys 0.1.0-alpha.2

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};

/// ContinuousLeg : A leg of a journey that is not bound to a timetable. Provided by OJP. 
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
pub struct ContinuousLeg {
    #[serde(rename = "start")]
    pub start: Box<models::Place>,
    #[serde(rename = "end")]
    pub end: Box<models::Place>,
    #[serde(rename = "service")]
    pub service: Box<models::ContinuousService>,
    /// 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>>,
    /// Duration of this leg according to user preferences like walk speed. 
    #[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 ContinuousLeg {
    /// A leg of a journey that is not bound to a timetable. Provided by OJP. 
    pub fn new(start: models::Place, end: models::Place, service: models::ContinuousService) -> ContinuousLeg {
        ContinuousLeg {
            start: Box::new(start),
            end: Box::new(end),
            service: Box::new(service),
            time_window_start: None,
            time_window_end: None,
            duration: None,
            situation_full_refs: None,
            co2_emission: None,
        }
    }
}