Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Tcl) Amazon SP-API Upload FeedSee more Amazon SP-API ExamplesUpload a feed document to the feed previously created. For more information, see https://developer-docs.amazon.com/sp-api/docs/feeds-api-v2021-06-30-use-case-guide#step-2-construct-a-feed
load ./chilkat.dll # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. # Load your own feed data file. set sbRequestBody [new_CkStringBuilder] set success [CkStringBuilder_LoadFile $sbRequestBody "C:/AAWorkarea/test-despatch-upload.txt" "utf-8"] if {$success == 0} then { puts "Failed to load test-despatch-upload.txt." delete_CkStringBuilder $sbRequestBody exit } # The SP-API Create Feed example returned JSON such as this. # { # "feedDocumentId": "amzn1.tortuga.4.eu.8fb6f9c4-XXXX-4e7f-824f-XXXXXXXXXXXXX.ZZZZZZZZZZZZZZ", # "url": "https://tortuga-prod-eu.s3-eu-west-1.amazonaws.com/%2FNinetyDays/amzn1.tortuga.4.eu.8fb6f9c4-XXXX-4e7f-824f-XXXXXXXXXXXXX.ZZZZZZZZZZZZZZ?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20230222T014944Z&X-Amz-SignedHeaders=content-type%3Bhost&X-Amz-Expires=300&X-Amz-Credential=XXXXXXXXXXXXXXXXX%2F20230222%2Feu-west-1%2Fs3%2Faws4_request&X-Amz-Signature=XXXXXXXXXXXXXXXXXXXXXXXXXXXX" # } # Load the JSON feed file created by this example: SP-API Create Feed set jsonFeedInfo [new_CkJsonObject] set success [CkJsonObject_LoadFile $jsonFeedInfo "qa_data/json/sp_api_feed_upload_info.json"] if {$success == 0} then { puts [CkJsonObject_lastErrorText $jsonFeedInfo] delete_CkStringBuilder $sbRequestBody delete_CkJsonObject $jsonFeedInfo exit } # Get the pre-signed URL set url [CkJsonObject_stringOf $jsonFeedInfo "url"] # We can use the Chilkat HTTP object because the URL is pre-signed. # We don't need to add our own AWS authentication because it's already in the pre-signed URL, # which is only valid for short amount of time. set http [new_CkHttp] # NOTE: The string "text/tab-separated-values; charset=UTF-8" must match exactly the contentType specified when creating the feed. # resp is a CkHttpResponse set resp [CkHttp_PTextSb $http "PUT" $url $sbRequestBody "utf-8" "text/tab-separated-values; charset=UTF-8" 0 0] if {[CkHttp_get_LastMethodSuccess $http] == 0} then { puts [CkHttp_lastErrorText $http] delete_CkStringBuilder $sbRequestBody delete_CkJsonObject $jsonFeedInfo delete_CkHttp $http exit } puts "status code = [CkHttpResponse_get_StatusCode $resp]" puts "status text = [CkHttpResponse_statusText $resp]" puts "response body:" puts [CkHttpResponse_bodyStr $resp] delete_CkHttpResponse $resp delete_CkStringBuilder $sbRequestBody delete_CkJsonObject $jsonFeedInfo delete_CkHttp $http |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.