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

/// FulfillmentPart : Fulfillment items to be integrated in to tickets, e.g. visual security elements, additional bar codes, control keys. 
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
pub struct FulfillmentPart {
    /// list of fulfillment media where this item applies 
    #[serde(rename = "fulfillmentMedia", skip_serializing_if = "Option::is_none")]
    pub fulfillment_media: Option<Vec<String>>,
    /// reference to a passenger 
    #[serde(rename = "passengerRef", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
    pub passenger_ref: Option<Option<String>>,
    #[serde(rename = "controlId", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
    pub control_id: Option<Option<String>>,
    /// 'visual elements, bar codes' 
    #[serde(rename = "securityFeatures", skip_serializing_if = "Option::is_none")]
    pub security_features: Option<Vec<models::FulfillmentItemSecurityFeature>>,
    #[serde(rename = "securityFeatureLinks", skip_serializing_if = "Option::is_none")]
    pub security_feature_links: Option<Vec<models::FulfillmentItemSecurityFeatureLinks>>,
    #[serde(rename = "fulfillmentInformationTexts", skip_serializing_if = "Option::is_none")]
    pub fulfillment_information_texts: Option<Vec<models::TextElement>>,
    /// The use of the provided features is mandatory. 
    #[serde(rename = "isMandatory", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
    pub is_mandatory: Option<Option<bool>>,
    /// The security feature must be used on secure paper. 
    #[serde(rename = "securePaperOnly", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
    pub secure_paper_only: Option<Option<bool>>,
}

impl FulfillmentPart {
    /// Fulfillment items to be integrated in to tickets, e.g. visual security elements, additional bar codes, control keys. 
    pub fn new() -> FulfillmentPart {
        FulfillmentPart {
            fulfillment_media: None,
            passenger_ref: None,
            control_id: None,
            security_features: None,
            security_feature_links: None,
            fulfillment_information_texts: None,
            is_mandatory: None,
            secure_paper_only: None,
        }
    }
}