AutoIt
AutoIt
MWS RequestReport (Amazon Marketplace Web Service)
See more Amazon MWS Examples
Creates a report request and submits the request to Amazon MWS.See Amazon MWS RequestReport for more information.
Chilkat AutoIt Downloads
Local $bSuccess = False
; This example requires the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.
$oRest = ObjCreate("Chilkat.Rest")
; Connect to the Amazon MWS REST server.
;
; Make sure to connect to the correct Amazon MWS Endpoint, otherwise
; you'll get an HTTP 401 response code.
;
; The possible servers are:
;
; North America (NA) https://mws.amazonservices.com
; Europe (EU) https://mws-eu.amazonservices.com
; India (IN) https://mws.amazonservices.in
; China (CN) https://mws.amazonservices.com.cn
; Japan (JP) https://mws.amazonservices.jp
;
Local $bTls = True
Local $iPort = 443
Local $bAutoReconnect = True
$bSuccess = $oRest.Connect("mws.amazonservices.com",$iPort,$bTls,$bAutoReconnect)
If ($bSuccess <> True) Then
ConsoleWrite("ConnectFailReason: " & $oRest.ConnectFailReason & @CRLF)
ConsoleWrite($oRest.LastErrorText & @CRLF)
Exit
EndIf
$oRest.Host = "mws.amazonservices.com"
$oRest.AddQueryParam("AWSAccessKeyId","0PB842EXAMPLE7N4ZTR2")
$oRest.AddQueryParam("Action","RequestReport")
$oRest.AddQueryParam("EndDate","2008-06-26T18:12:21")
$oRest.AddQueryParam("MWSAuthToken","amzn.mws.4ea38b7b-f563-7709-4bae-87aeaEXAMPLE")
$oRest.AddQueryParam("Marketplace","ATVPDKIKX0DER")
$oRest.AddQueryParam("ReportType","_GET_MERCHANT_LISTINGS_DATA_")
$oRest.AddQueryParam("SellerId","A1XEXAMPLE5E6")
$oRest.AddQueryParam("SignatureMethod","HmacSHA256")
$oRest.AddQueryParam("SignatureVersion","2")
$oRest.AddQueryParam("StartDate","2009-01-03T18:12:21")
$oRest.AddQueryParam("Version","2009-01-01")
; Add the MWS Signature param. (Also adds the Timestamp parameter using the curent system date/time.)
; The AddMwsSignature method adds the Timestamp and Signature query params.
$oRest.AddMwsSignature("POST","/Reports/2009-01-01","mws.amazonservices.com","MWS_SECRET_KEY")
Local $sResponseXml = $oRest.FullRequestFormUrlEncoded("POST","/Reports/2009-01-01")
If ($oRest.LastMethodSuccess <> True) Then
ConsoleWrite($oRest.LastErrorText & @CRLF)
Exit
EndIf
If ($oRest.ResponseStatusCode <> 200) Then
; Examine the request/response to see what happened.
ConsoleWrite("response status code = " & $oRest.ResponseStatusCode & @CRLF)
ConsoleWrite("response status text = " & $oRest.ResponseStatusText & @CRLF)
ConsoleWrite("response header: " & $oRest.ResponseHeader & @CRLF)
ConsoleWrite("response body: " & $sResponseXml & @CRLF)
ConsoleWrite("---" & @CRLF)
ConsoleWrite("LastRequestStartLine: " & $oRest.LastRequestStartLine & @CRLF)
ConsoleWrite("LastRequestHeader: " & $oRest.LastRequestHeader & @CRLF)
EndIf
; Examine the XML returned in the response body.
ConsoleWrite($sResponseXml & @CRLF)
ConsoleWrite("----" & @CRLF)
ConsoleWrite("Success." & @CRLF)
; Sample Response
; Use this online tool to generate parsing code from sample XML:
; Generate Parsing Code from XML
; <?xml version="1.0"?>
; <RequestReportResponse
; xmlns="http://mws.amazonaws.com/doc/2009-01-01/">
; <RequestReportResult>
; <ReportRequestInfo>
; <ReportRequestId>2291326454</ReportRequestId>
; <ReportType>_GET_MERCHANT_LISTINGS_DATA_</ReportType>
; <StartDate>2009-01-21T02:10:39+00:00</StartDate>
; <EndDate>2009-02-13T02:10:39+00:00</EndDate>
; <Scheduled>false</Scheduled>
; <SubmittedDate>2009-02-20T02:10:39+00:00</SubmittedDate>
; <ReportProcessingStatus>_SUBMITTED_</ReportProcessingStatus>
; </ReportRequestInfo>
; </RequestReportResult>
; <ResponseMetadata>
; <RequestId>88faca76-b600-46d2-b53c-0c8c4533e43a</RequestId>
; </ResponseMetadata>
; </RequestReportResponse>
$oXml = ObjCreate("Chilkat.Xml")
$oXml.LoadXml($sResponseXml)
Local $sRequestReportResponse_xmlns = $oXml.GetAttrValue("xmlns")
Local $sReportRequestId = $oXml.GetChildContent("RequestReportResult|ReportRequestInfo|ReportRequestId")
Local $sReportType = $oXml.GetChildContent("RequestReportResult|ReportRequestInfo|ReportType")
Local $sStartDate = $oXml.GetChildContent("RequestReportResult|ReportRequestInfo|StartDate")
Local $sEndDate = $oXml.GetChildContent("RequestReportResult|ReportRequestInfo|EndDate")
Local $sScheduled = $oXml.GetChildContent("RequestReportResult|ReportRequestInfo|Scheduled")
Local $sSubmittedDate = $oXml.GetChildContent("RequestReportResult|ReportRequestInfo|SubmittedDate")
Local $sReportProcessingStatus = $oXml.GetChildContent("RequestReportResult|ReportRequestInfo|ReportProcessingStatus")
Local $sRequestId = $oXml.GetChildContent("ResponseMetadata|RequestId")