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

/// LinkCarrierAccountRequest : The request schema for verify and add the merchant's account with a certain carrier.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct LinkCarrierAccountRequest {
    /// Object to pass additional information about the MCI Integrator shipperType: List of ClientReferenceDetail
    #[serde(rename = "clientReferenceDetails", skip_serializing_if = "Option::is_none")]
    pub client_reference_details: Option<Vec<models::shipping_v2::ClientReferenceDetail>>,
    /// CarrierAccountType  associated with account.
    #[serde(rename = "carrierAccountType")]
    pub carrier_account_type: String,
    /// A list of all attributes required by the carrier in order to successfully link the merchant's account
    #[serde(rename = "carrierAccountAttributes")]
    pub carrier_account_attributes: Vec<models::shipping_v2::CarrierAccountAttribute>,
    /// A list of all attributes required by the carrier in order to successfully link the merchant's account
    #[serde(rename = "encryptedCarrierAccountAttributes", skip_serializing_if = "Option::is_none")]
    pub encrypted_carrier_account_attributes: Option<Vec<models::shipping_v2::CarrierAccountAttribute>>,
}

impl LinkCarrierAccountRequest {
    /// The request schema for verify and add the merchant's account with a certain carrier.
    pub fn new(carrier_account_type: String, carrier_account_attributes: Vec<models::shipping_v2::CarrierAccountAttribute>) -> LinkCarrierAccountRequest {
        LinkCarrierAccountRequest {
            client_reference_details: None,
            carrier_account_type,
            carrier_account_attributes,
            encrypted_carrier_account_attributes: None,
        }
    }
}