/*
* 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};
/// PromotionCode : The promotion code is a token that reduces the price at POST booking time OR Token that reduces the price at POST trip-offer-collection time OR Token to receive offers that are not available without it.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
pub struct PromotionCode {
/// The code issued by the issuer
#[serde(rename = "code")]
pub code: String,
/// The party that issues the promotion code, in case of a railway it's its RICS code
#[serde(rename = "issuer", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub issuer: Option<Option<String>>,
}
impl PromotionCode {
/// The promotion code is a token that reduces the price at POST booking time OR Token that reduces the price at POST trip-offer-collection time OR Token to receive offers that are not available without it.
pub fn new(code: String) -> PromotionCode {
PromotionCode {
code,
issuer: None,
}
}
}