amazon-spapi 2.0.3

A Rust client library for Amazon Selling Partner API (SP-API)
Documentation
/*
 * Amazon Shipping API
 *
 * The Amazon Shipping API is designed to support outbound shipping use cases both for orders originating on Amazon-owned marketplaces as well as external channels/marketplaces. With these APIs, you can request shipping rates, create shipments, cancel shipments, and track shipments.
 *
 * The version of the OpenAPI document: v2
 * Contact: swa-api-core@amazon.com
 * Generated by: https://openapi-generator.tech
 */

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

/// CreateClaimRequest : The request schema for the CreateClaim operation
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct CreateClaimRequest {
    /// The carrier generated identifier for a package in a purchased shipment.
    #[serde(rename = "trackingId")]
    pub tracking_id: String,
    #[serde(rename = "declaredValue", skip_serializing_if = "Option::is_none")]
    pub declared_value: Option<Box<models::shipping_v2::Currency>>,
    #[serde(rename = "claimReason")]
    pub claim_reason: models::shipping_v2::ClaimReason,
    /// Applicable for only On Amazon shipments to identify if replacement was sent
    #[serde(rename = "isReplacementPackageSent", skip_serializing_if = "Option::is_none")]
    pub is_replacement_package_sent: Option<bool>,
    /// A list of proof URLs for a claim. Basic URL validation will happen for each URLs present in the list
    #[serde(rename = "proofs", skip_serializing_if = "Option::is_none")]
    pub proofs: Option<Vec<String>>,
    #[serde(rename = "settlementType")]
    pub settlement_type: models::shipping_v2::SettlementType,
}

impl CreateClaimRequest {
    /// The request schema for the CreateClaim operation
    pub fn new(tracking_id: String, claim_reason: models::shipping_v2::ClaimReason, settlement_type: models::shipping_v2::SettlementType) -> CreateClaimRequest {
        CreateClaimRequest {
            tracking_id,
            declared_value: None,
            claim_reason,
            is_replacement_package_sent: None,
            proofs: None,
            settlement_type,
        }
    }
}