Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) eBay -- Upload Bulk Data using FileTransferServiceDemonstrates how to upload your data file using the eBay File Transfer API.
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' Use a previously obtained access token. The token should look something like this: ' "AgAAAA**AQA ..." accessToken = "EBAY_ACCESS_TOKEN" Dim http As Chilkat.Http Set http = Chilkat.NewHttp apiCall = "uploadFile" fileAttachmentUuid = "<urn:uuid:bb47b86a237311e793ae92361f002671>" xmlUuid = "<urn:uuid:bb47b766237311e793ae92361f002671>" Dim req As Chilkat.HttpRequest Set req = Chilkat.NewHttpRequest req.HttpVerb = "POST" req.Path = "/FileTransferService" Dim sbContentType As Chilkat.StringBuilder Set sbContentType = Chilkat.NewStringBuilder Dim success As Boolean success = sbContentType.Append("multipart/related; type=""application/xop+xml""; start=""XMLUUID""; start-info=""text/xml""") replaceCount = sbContentType.Replace("XMLUUID",xmlUuid) req.ContentType = sbContentType.GetAsString() req.AddHeader "X-EBAY-SOA-SERVICE-NAME","FileTransferService" req.AddHeader "X-EBAY-SOA-OPERATION-NAME",apiCall req.AddHeader "X-EBAY-SOA-SECURITY-TOKEN",accessToken req.AddHeader "X-EBAY-SOA-REQUEST-DATA-FORMAT","XML" req.AddHeader "X-EBAY-SOA-RESPONSE-DATA-FORMAT","XML" req.AddHeader "User-Agent","AnythingYouWant" pathToFileOnDisk1 = "qa_data/ebay/uploadFileRequest.xml" success = req.AddFileForUpload("uploadFileRequest.xml",pathToFileOnDisk1) If (success <> True) Then Debug.Print req.LastErrorText Exit Sub End If pathToFileOnDisk2 = "qa_data/ebay/BulkDataExchangeRequests.gz" success = req.AddFileForUpload("BulkDataExchangeRequests.gz",pathToFileOnDisk2) If (success <> True) Then Debug.Print req.LastErrorText Exit Sub End If ' Add sub-headers for each file in the request. success = req.AddSubHeader(0,"Content-Type","application/xop+xml; charset=UTF-8; type=""text/xml""") success = req.AddSubHeader(0,"Content-Transfer-Encoding","binary") success = req.AddSubHeader(0,"Content-ID",xmlUuid) success = req.AddSubHeader(1,"Content-Type","application/octet-stream") success = req.AddSubHeader(1,"Content-Transfer-Encoding","binary") success = req.AddSubHeader(1,"Content-ID",fileAttachmentUuid) Set resp = http.SynchronousRequest("storage.sandbox.ebay.com",443,True,req) If (http.LastMethodSuccess <> True) Then Debug.Print http.LastErrorText Exit Sub End If Debug.Print "Response status code = "; resp.StatusCode Dim xml As Chilkat.Xml Set xml = Chilkat.NewXml success = xml.LoadXml(resp.BodyStr) If (resp.StatusCode <> 200) Then Debug.Print xml.GetXml() Debug.Print "Failed." Exit Sub End If ' We still may have a failure. The XML needs to be checked. ' A failed response might look like this: ' <?xml version="1.0" encoding="UTF-8" ?> ' <uploadFileResponse xmlns="http://www.ebay.com/marketplace/services"> ' <ack>Failure</ack> ' <errorMessage> ' <error> ' <errorId>1</errorId> ' <domain>Marketplace</domain> ' <severity>Error</severity> ' <category>Application</category> ' <message>Task Reference Id is invalid</message> ' <subdomain>FileTransfer</subdomain> ' </error> ' </errorMessage> ' <version>1.1.0</version> ' <timestamp>2017-04-18T01:05:27.475Z</timestamp> ' </uploadFileResponse> ' A successful response looks like this: ' <?xml version="1.0" encoding="UTF-8" ?> ' <uploadFileResponse xmlns="http://www.ebay.com/marketplace/services"> ' <ack>Success</ack> ' <version>1.1.0</version> ' <timestamp>2017-04-18T01:22:47.853Z</timestamp> ' </uploadFileResponse> Debug.Print xml.GetXml() ' Get the "ack" to see if it's "Failure" or "Success" If (xml.ChildContentMatches("ack","Success",False)) Then Debug.Print "Success." Else Debug.Print "Failure." End If |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.