amazon-spapi 2.0.3

A Rust client library for Amazon Selling Partner API (SP-API)
Documentation
/*
 * Selling Partner API for Merchant Fulfillment
 *
 * With the Selling Partner API for Merchant Fulfillment, you can build applications that sellers can use to purchase shipping for non-Prime and Prime orders using Amazon's Buy Shipping Services.
 *
 * The version of the OpenAPI document: v0
 * 
 * Generated by: https://openapi-generator.tech
 */

use crate::models;
use serde::{Deserialize, Serialize};

/// CreateShipmentRequest : Request schema.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct CreateShipmentRequest {
    #[serde(rename = "ShipmentRequestDetails")]
    pub shipment_request_details: Box<models::merchant_fulfillment_v0::ShipmentRequestDetails>,
    /// An Amazon-defined shipping service identifier.
    #[serde(rename = "ShippingServiceId")]
    pub shipping_service_id: String,
    /// Identifies a shipping service order made by a carrier.
    #[serde(rename = "ShippingServiceOfferId", skip_serializing_if = "Option::is_none")]
    pub shipping_service_offer_id: Option<String>,
    #[serde(rename = "HazmatType", skip_serializing_if = "Option::is_none")]
    pub hazmat_type: Option<models::merchant_fulfillment_v0::HazmatType>,
    #[serde(rename = "LabelFormatOption", skip_serializing_if = "Option::is_none")]
    pub label_format_option: Option<Box<models::merchant_fulfillment_v0::LabelFormatOptionRequest>>,
    /// A list of additional seller input pairs required to purchase shipping.
    #[serde(rename = "ShipmentLevelSellerInputsList", skip_serializing_if = "Option::is_none")]
    pub shipment_level_seller_inputs_list: Option<Vec<models::merchant_fulfillment_v0::AdditionalSellerInputs>>,
}

impl CreateShipmentRequest {
    /// Request schema.
    pub fn new(shipment_request_details: models::merchant_fulfillment_v0::ShipmentRequestDetails, shipping_service_id: String) -> CreateShipmentRequest {
        CreateShipmentRequest {
            shipment_request_details: Box::new(shipment_request_details),
            shipping_service_id,
            shipping_service_offer_id: None,
            hazmat_type: None,
            label_format_option: None,
            shipment_level_seller_inputs_list: None,
        }
    }
}