# frozen_string_literal: true
require "peddler/api"
module Peddler
class << self
def shipping_v1(...)
APIs::ShippingV1.new(...)
end
end
module APIs
# Selling Partner API for Shipping
#
# Provides programmatic access to Amazon Shipping APIs. **Note:** If you are new to the Amazon Shipping API, refer
# to the latest version of Amazon Shipping API
# (v2) on the Amazon Shipping Developer
# Documentation site.
class ShippingV1 < API
# Create a new shipment.
#
# @note This operation can make a static sandbox call.
# @param body [Hash]
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def create_shipment(body, rate_limit: 5.0, tries: 2)
path = "/shipping/v1/shipments"
meter(rate_limit, tries:).post(path, body:)
end
# Return the entire shipment object for the shipmentId.
#
# @note This operation can make a static sandbox call.
# @param shipment_id [String]
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def get_shipment(shipment_id, rate_limit: 5.0, tries: 2)
path = "/shipping/v1/shipments/#{shipment_id}"
meter(rate_limit, tries:).get(path)
end
# Cancel a shipment by the given shipmentId.
#
# @note This operation can make a static sandbox call.
# @param shipment_id [String]
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def cancel_shipment(shipment_id, rate_limit: 5.0, tries: 2)
path = "/shipping/v1/shipments/#{shipment_id}/cancel"
meter(rate_limit, tries:).post(path)
end
# Purchase shipping labels based on a given rate.
#
# @note This operation can make a static sandbox call.
# @param shipment_id [String]
# @param body [Hash]
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def purchase_labels(shipment_id, body, rate_limit: 5.0, tries: 2)
path = "/shipping/v1/shipments/#{shipment_id}/purchaseLabels"
meter(rate_limit, tries:).post(path, body:)
end
# Retrieve shipping label based on the shipment id and tracking id.
#
# @note This operation can make a static sandbox call.
# @param shipment_id [String]
# @param tracking_id [String]
# @param body [Hash]
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def retrieve_shipping_label(shipment_id, tracking_id, body, rate_limit: 5.0, tries: 2)
path = "/shipping/v1/shipments/#{shipment_id}/containers/#{tracking_id}/label"
meter(rate_limit, tries:).post(path, body:)
end
# Purchase shipping labels.
#
# @note This operation can make a static sandbox call.
# @param body [Hash]
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def purchase_shipment(body, rate_limit: 5.0, tries: 2)
path = "/shipping/v1/purchaseShipment"
meter(rate_limit, tries:).post(path, body:)
end
# Get service rates.
#
# @note This operation can make a static sandbox call.
# @param body [Hash]
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def get_rates(body, rate_limit: 5.0, tries: 2)
path = "/shipping/v1/rates"
meter(rate_limit, tries:).post(path, body:)
end
# Verify if the current account is valid.
#
# @note This operation can make a static sandbox call.
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def get_account(rate_limit: 5.0, tries: 2)
path = "/shipping/v1/account"
meter(rate_limit, tries:).get(path)
end
# Return the tracking information of a shipment.
#
# @note This operation can make a static sandbox call.
# @param tracking_id [String]
# @param rate_limit [Float] Requests per second
# @param tries [Integer] Total request attempts, including retries
# @return [Peddler::Response] The API response
def get_tracking_information(tracking_id, rate_limit: 1.0, tries: 2)
path = "/shipping/v1/tracking/#{tracking_id}"
meter(rate_limit, tries:).get(path)
end
end
end
end