# frozen_string_literal: true require "peddler/api" module Peddler class << self def uploads_2020_11_01(...) APIs::Uploads20201101.new(...) end end module APIs # Selling Partner API for Uploads # # The Uploads API lets you upload files that you can programmatically access using other Selling Partner APIs, such # as the A+ Content API and the Messaging API. class Uploads20201101 < API # Creates an upload destination, returning the information required to upload a file to the destination and to # programmatically access the file. # # @param marketplace_ids [Array] A list of marketplace identifiers. This specifies the marketplaces where # the upload will be available. Only one marketplace can be specified. # @param content_md5 [String] An MD5 hash of the content to be submitted to the upload destination. This value is # used to determine if the data has been corrupted or tampered with during transit. # @param resource [String] The resource for the upload destination that you are creating. For example, if you are # creating an upload destination for the createLegalDisclosure operation of the Messaging API, the `{resource}` # would be `/messaging/v1/orders/{amazonOrderId}/messages/legalDisclosure`, and the entire path would be # `/uploads/2020-11-01/uploadDestinations/messaging/v1/orders/{amazonOrderId}/messages/legalDisclosure`. If you # are creating an upload destination for an Aplus content document, the `{resource}` would be # `aplus/2020-11-01/contentDocuments` and the path would be # `/uploads/v1/uploadDestinations/aplus/2020-11-01/contentDocuments`. # @param content_type [String] The content type of the file to be uploaded. # @param rate_limit [Float] Requests per second # @param tries [Integer] Total request attempts, including retries # @return [Peddler::Response] The API response def create_upload_destination_for_resource(marketplace_ids, content_md5, resource, content_type: nil, rate_limit: 10.0, tries: 2) cannot_sandbox! path = "/uploads/2020-11-01/uploadDestinations/#{resource}" params = { "marketplaceIds" => marketplace_ids, "contentMD5" => content_md5, "contentType" => content_type, }.compact meter(rate_limit, tries:).post(path, params:) end end end end