/*
* 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};
/// ModeFilter : List of public transport modes to include or exclude. Provided by OJP.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
pub struct ModeFilter {
/// Whether modes in list are to include or exclude from search.
#[serde(rename = "exclude", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub exclude: Option<Option<bool>>,
/// List of Transport modes to include/exclude.
#[serde(rename = "transportModes", skip_serializing_if = "Option::is_none")]
pub transport_modes: Option<Vec<models::Mode>>,
}
impl ModeFilter {
/// List of public transport modes to include or exclude. Provided by OJP.
pub fn new() -> ModeFilter {
ModeFilter {
exclude: None,
transport_modes: None,
}
}
}