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

/// ProductCategory : Product category based on NeTEx/SIRI. A product category is a classification for vehicle journeys to express some common properties of journeys for marketing and fare products. Provided by OJP. 
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
pub struct ProductCategory {
    /// Full name of this product category, e.g. 'TGV Lyria' in Switzerland and France. UIC: Long name of Service Brand 
    #[serde(rename = "name")]
    pub name: String,
    /// Short name or acronym of the product category, likely to be published, e.g. 'TGV' UIC: Abbreviation of Service Brand 
    #[serde(rename = "shortName")]
    pub short_name: String,
    /// Reference to a product category. Product categories should be defined once and used uniformly in all channels (e.g. NeTEx, SIRI, OJP). Provided by OJP. 
    #[serde(rename = "productCategoryRef", deserialize_with = "Option::deserialize")]
    pub product_category_ref: Option<String>,
}

impl ProductCategory {
    /// Product category based on NeTEx/SIRI. A product category is a classification for vehicle journeys to express some common properties of journeys for marketing and fare products. Provided by OJP. 
    pub fn new(name: String, short_name: String, product_category_ref: Option<String>) -> ProductCategory {
        ProductCategory {
            name,
            short_name,
            product_category_ref,
        }
    }
}