amazon-spapi 2.0.3

A Rust client library for Amazon Selling Partner API (SP-API)
Documentation
/*
 * Selling Partner API for Easy Ship
 *
 * Use the Selling Partner API for Easy Ship to build applications for sellers to manage and ship Amazon Easy Ship orders. With this API, you can get available time slots, schedule and reschedule Easy Ship orders, and print shipping labels, invoices, and warranties. To review the differences in Easy Ship operations by marketplace, refer to [Marketplace support](https://developer-docs.amazon.com/sp-api/docs/easyship-api-v2022-03-23-use-case-guide#marketplace-support).
 *
 * The version of the OpenAPI document: 2022-03-23
 * 
 * Generated by: https://openapi-generator.tech
 */

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

/// PackageDetails : Package details. Includes `packageItems`, `packageTimeSlot`, and `packageIdentifier`.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct PackageDetails {
    /// A list of items contained in the package.
    #[serde(rename = "packageItems", skip_serializing_if = "Option::is_none")]
    pub package_items: Option<Vec<models::easy_ship_2022_03_23::Item>>,
    #[serde(rename = "packageTimeSlot")]
    pub package_time_slot: Box<models::easy_ship_2022_03_23::TimeSlot>,
    /// Optional seller-created identifier that is printed on the shipping label to help the seller identify the package.
    #[serde(rename = "packageIdentifier", skip_serializing_if = "Option::is_none")]
    pub package_identifier: Option<String>,
}

impl PackageDetails {
    /// Package details. Includes `packageItems`, `packageTimeSlot`, and `packageIdentifier`.
    pub fn new(package_time_slot: models::easy_ship_2022_03_23::TimeSlot) -> PackageDetails {
        PackageDetails {
            package_items: None,
            package_time_slot: Box::new(package_time_slot),
            package_identifier: None,
        }
    }
}