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
(AutoIt) eBay -- Download Data using FileTransferServiceDemonstrates how to download a data file using the eBay File Transfer API. Note: This example requires Chilkat v9.5.0.67 or later.
; 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 ..." Local $sAccessToken = "EBAY_ACCESS_TOKEN" $oHttp = ObjCreate("Chilkat.Http") $oReq = ObjCreate("Chilkat.HttpRequest") $oReq.HttpVerb = "POST" $oReq.Path = "/FileTransferService" $oReq.ContentType = "application/xml" ; Build the XML body for the request. $oXml = ObjCreate("Chilkat.Xml") $oXml.Tag = "downloadFileRequest" $oXml.AddAttribute("xmlns","http://www.ebay.com/marketplace/services") $oXml.UpdateChildContent "taskReferenceId","50013004806" $oXml.UpdateChildContent "fileReferenceId","50015579016" $oReq.LoadBodyFromString($oXml.GetXml(),"utf-8") ; The XML body looks like this: ; <?xml version="1.0" encoding="UTF-8"?> ; <downloadFileRequest xmlns="http://www.ebay.com/marketplace/services"> ; <taskReferenceId>50013004806</taskReferenceId> ; <fileReferenceId>50015579016</fileReferenceId> ; </downloadFileRequest> $oReq.AddHeader "X-EBAY-SOA-OPERATION-NAME","downloadFile" $oReq.AddHeader "X-EBAY-SOA-SECURITY-TOKEN",$sAccessToken Local $oResp = $oHttp.SynchronousRequest("storage.sandbox.ebay.com",443,True,$oReq) If ($oHttp.LastMethodSuccess <> True) Then ConsoleWrite($oHttp.LastErrorText & @CRLF) Exit EndIf Local $iStatusCode = $oResp.StatusCode ConsoleWrite("Response status code = " & $iStatusCode & @CRLF) $oResponseBody = ObjCreate("Chilkat.BinData") $oResp.GetBodyBd($oResponseBody) ; We can save the response body to a file for examination if we get an unanticipated response. ; (It's binary, so it won't open well in a text editor.) $oResponseBody.WriteFile("qa_output/response.mime") If ($iStatusCode <> 200) Then ConsoleWrite("Failed." & @CRLF) Exit EndIf ; The response body looks like this: ; --MIMEBoundaryurn_uuid_2B668636C1E17A4D4114925305818684241 ; Content-Type: application/xop+xml; charset=utf-8; type="text/xml" ; Content-Transfer-Encoding: binary ; Content-ID: <0.urn:uuid:2B668636C1E17A4D4114925305818684242> ; ; <?xml version='1.0' encoding='UTF-8'?> ; <downloadFileResponse xmlns="http://www.ebay.com/marketplace/services"> ; <ack>Success</ack> ; <version>1.1.0</version> ; <timestamp>2017-04-18T15:49:41.868Z</timestamp> ; <fileAttachment> ; <Size>587</Size> ; <Data> ; <xop:Include xmlns:xop="http://www.w3.org/2004/08/xop/include" href="cid:urn:uuid:A37C3C73E994C267F11492530585522"/> ; </Data> ; </fileAttachment> ; </downloadFileResponse> ; --MIMEBoundaryurn_uuid_2B668636C1E17A4D4114925305818684241 ; Content-Type: application/zip ; Content-Transfer-Encoding: binary ; Content-ID: <urn:uuid:A37C3C73E994C267F11492530585522> ; ; <the binary bytes of the zip start here...> ; ; Load the binary response into a MIME object. $oMime = ObjCreate("Chilkat.Mime") Local $bSuccess = $oMime.LoadMimeBd($oResponseBody) If ($bSuccess <> True) Then ConsoleWrite($oMime.LastErrorText & @CRLF) Exit EndIf ; Make sure we have 2 sub-parts. The 1st sub-part is the XML response, the 2nd sub-part ; is the zip containing the data. ; Note: The 2nd sub-part can be a "zip" or "gzip". These are two different file formats. ; A zip is indicated with a Content-Type header equal to "application/zip", ; whereas a gzip is indicated with a Content-Type header equal to "application/x-gzip" If ($oMime.NumParts <> 2) Then ConsoleWrite("Expected the MIME to have 2 parts." & @CRLF) ConsoleWrite("NumParts = " & $oMime.NumParts & @CRLF) ConsoleWrite("Failed." & @CRLF) Exit EndIf ; Get the XML from the 1st MIME sub-part. Local $oPart0 = $oMime.GetPart(0) Local $sDownloadResponseXml = $oPart0.GetBodyDecoded() $oXmlResp = ObjCreate("Chilkat.Xml") $oXmlResp.LoadXml($sDownloadResponseXml) ConsoleWrite("Download Response XML:" & @CRLF) ConsoleWrite($oXmlResp.GetXml() & @CRLF) ConsoleWrite("----" & @CRLF) ; Now get the zip from the second part (index=1), unzip, and examine.. Local $oPart1 = $oMime.GetPart(1) $oZipData = ObjCreate("Chilkat.BinData") ; This example requires Chilkat v9.5.0.67 or later. ; The GetBodyBd method was added in v9.5.0.67. $oPart1.GetBodyBd($oZipData) ; Check to see if we have a zip or gzip. $oSbContentType = ObjCreate("Chilkat.StringBuilder") $oSbContentType.Append($oPart1.ContentType) $oXmlFromZip = ObjCreate("Chilkat.Xml") If ($oSbContentType.Contains("gzip",False) = True) Then ; This is a gzip compressed file. $oGzip = ObjCreate("Chilkat.Gzip") ; in-place uncompress the data. ; Note: The UncompressBd method was added in Chilkat v9.5.0.67 $bSuccess = $oGzip.UncompressBd($oZipData) If ($bSuccess <> True) Then ConsoleWrite($oGzip.LastErrorText & @CRLF) Exit EndIf $oXmlFromZip.LoadXml($oZipData.GetString("utf-8")) Else ; This is a zip archive. ; Load the body into a Zip object. $oZip = ObjCreate("Chilkat.Zip") $bSuccess = $oZip.OpenBd($oZipData) If ($bSuccess <> True) Then ConsoleWrite($oZip.LastErrorText & @CRLF) Exit EndIf ; Save the .zip to a file (so we can examine it for debugging if something is not as expected) $oZipData.WriteFile("qa_output/ebay_data.zip") ; The zip should contain a single XML file. If ($oZip.NumEntries <> 1) Then ConsoleWrite("Expected the .zip to have 1 entry." & @CRLF) ConsoleWrite("NumEntries = " & $oZip.NumEntries & @CRLF) ConsoleWrite("Failed." & @CRLF) Exit EndIf Local $oEntry = $oZip.GetEntryByIndex(0) $oXmlFromZip.LoadXml($oEntry.UnzipToString(0,"utf-8")) EndIf ConsoleWrite("XML contained in the zip:" & @CRLF) ConsoleWrite($oXmlFromZip.GetXml() & @CRLF) ConsoleWrite("----" & @CRLF) ConsoleWrite("Success." & @CRLF) |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.