Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) 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
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. -- Load your own feed data file. DECLARE @sbRequestBody int -- Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbRequestBody OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @success int EXEC sp_OAMethod @sbRequestBody, 'LoadFile', @success OUT, 'C:/AAWorkarea/test-despatch-upload.txt', 'utf-8' IF @success = 0 BEGIN PRINT 'Failed to load test-despatch-upload.txt.' EXEC @hr = sp_OADestroy @sbRequestBody RETURN END -- 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 DECLARE @jsonFeedInfo int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @jsonFeedInfo OUT EXEC sp_OAMethod @jsonFeedInfo, 'LoadFile', @success OUT, 'qa_data/json/sp_api_feed_upload_info.json' IF @success = 0 BEGIN EXEC sp_OAGetProperty @jsonFeedInfo, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @sbRequestBody EXEC @hr = sp_OADestroy @jsonFeedInfo RETURN END -- Get the pre-signed URL DECLARE @url nvarchar(4000) EXEC sp_OAMethod @jsonFeedInfo, 'StringOf', @url OUT, '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. DECLARE @http int -- Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT -- NOTE: The string "text/tab-separated-values; charset=UTF-8" must match exactly the contentType specified when creating the feed. DECLARE @resp int EXEC sp_OAMethod @http, 'PTextSb', @resp OUT, 'PUT', @url, @sbRequestBody, 'utf-8', 'text/tab-separated-values; charset=UTF-8', 0, 0 EXEC sp_OAGetProperty @http, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 = 0 BEGIN EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @sbRequestBody EXEC @hr = sp_OADestroy @jsonFeedInfo EXEC @hr = sp_OADestroy @http RETURN END EXEC sp_OAGetProperty @resp, 'StatusCode', @iTmp0 OUT PRINT 'status code = ' + @iTmp0 EXEC sp_OAGetProperty @resp, 'StatusText', @sTmp0 OUT PRINT 'status text = ' + @sTmp0 PRINT 'response body:' EXEC sp_OAGetProperty @resp, 'BodyStr', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @resp EXEC @hr = sp_OADestroy @sbRequestBody EXEC @hr = sp_OADestroy @jsonFeedInfo EXEC @hr = sp_OADestroy @http END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.