amazon-spapi 2.0.3

A Rust client library for Amazon Selling Partner API (SP-API)
Documentation
/*
 * Selling Partner APIs for Fulfillment Outbound
 *
 * The Selling Partner API for Fulfillment Outbound lets you create applications that help a seller fulfill Multi-Channel Fulfillment orders using their inventory in Amazon's fulfillment network. You can get information on both potential and existing fulfillment orders.
 *
 * The version of the OpenAPI document: 2020-07-01
 * 
 * Generated by: https://openapi-generator.tech
 */

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

/// PackageTrackingDetails : Tracking details of package
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct PackageTrackingDetails {
    /// The package identifier.
    #[serde(rename = "packageNumber")]
    pub package_number: i32,
    /// The tracking number for the package.
    #[serde(rename = "trackingNumber", skip_serializing_if = "Option::is_none")]
    pub tracking_number: Option<String>,
    /// Link on swiship.com that allows customers to track the package.
    #[serde(rename = "customerTrackingLink", skip_serializing_if = "Option::is_none")]
    pub customer_tracking_link: Option<String>,
    /// The name of the carrier.
    #[serde(rename = "carrierCode", skip_serializing_if = "Option::is_none")]
    pub carrier_code: Option<String>,
    /// The phone number of the carrier.
    #[serde(rename = "carrierPhoneNumber", skip_serializing_if = "Option::is_none")]
    pub carrier_phone_number: Option<String>,
    /// The URL of the carrier's website.
    #[serde(rename = "carrierURL", skip_serializing_if = "Option::is_none")]
    pub carrier_url: Option<String>,
    /// Date timestamp
    #[serde(rename = "shipDate", skip_serializing_if = "Option::is_none")]
    pub ship_date: Option<String>,
    /// Date timestamp
    #[serde(rename = "estimatedArrivalDate", skip_serializing_if = "Option::is_none")]
    pub estimated_arrival_date: Option<String>,
    #[serde(rename = "shipToAddress", skip_serializing_if = "Option::is_none")]
    pub ship_to_address: Option<Box<models::fulfillment_outbound_2020_07_01::TrackingAddress>>,
    #[serde(rename = "currentStatus", skip_serializing_if = "Option::is_none")]
    pub current_status: Option<models::fulfillment_outbound_2020_07_01::CurrentStatus>,
    /// Description corresponding to the CurrentStatus value.
    #[serde(rename = "currentStatusDescription", skip_serializing_if = "Option::is_none")]
    pub current_status_description: Option<String>,
    #[serde(rename = "deliveryWindow", skip_serializing_if = "Option::is_none")]
    pub delivery_window: Option<Box<models::fulfillment_outbound_2020_07_01::DateRange>>,
    /// The name of the person who signed for the package.
    #[serde(rename = "signedForBy", skip_serializing_if = "Option::is_none")]
    pub signed_for_by: Option<String>,
    #[serde(rename = "additionalLocationInfo", skip_serializing_if = "Option::is_none")]
    pub additional_location_info: Option<models::fulfillment_outbound_2020_07_01::AdditionalLocationInfo>,
    /// An array of tracking event information.
    #[serde(rename = "trackingEvents", skip_serializing_if = "Option::is_none")]
    pub tracking_events: Option<Vec<models::fulfillment_outbound_2020_07_01::TrackingEvent>>,
}

impl PackageTrackingDetails {
    /// Tracking details of package
    pub fn new(package_number: i32) -> PackageTrackingDetails {
        PackageTrackingDetails {
            package_number,
            tracking_number: None,
            customer_tracking_link: None,
            carrier_code: None,
            carrier_phone_number: None,
            carrier_url: None,
            ship_date: None,
            estimated_arrival_date: None,
            ship_to_address: None,
            current_status: None,
            current_status_description: None,
            delivery_window: None,
            signed_for_by: None,
            additional_location_info: None,
            tracking_events: None,
        }
    }
}