![]() |
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
(AutoIt) Walmart - Update bulk inventoryNote: This example uses classes, properties, or methods discontinued in Chilkat v11.0.0 or greater. See Update bulk inventory for more information about this call.
; This example requires the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. ; Sends the following POST request: ; POST https://marketplace.walmartapis.com/v2/feeds?feedType=inventory Local $bSuccess Local $sUrl = "https://marketplace.walmartapis.com/v2/feeds?feedType=inventory" Local $sRequestMethod = "POST" ; First we need to generate a signature for our request. ; The signature needs to be re-generated for each new Walmart HTTP request. $oAuthUtil = ObjCreate("Chilkat.AuthUtil") Local $sWmConsumerId = "WALMART_CONSUMER_ID" Local $sWmPrivateKey = "WALMART_PRIVATE_KEY" Local $sJsonStr = $oAuthUtil.WalmartSignature($sUrl,$sWmConsumerId,$sWmPrivateKey,$sRequestMethod) If ($oAuthUtil.LastMethodSuccess <> True) Then ConsoleWrite($oAuthUtil.LastErrorText & @CRLF) Exit EndIf ; Build the HTTP POST request. $oReq = ObjCreate("Chilkat.HttpRequest") $oReq.HttpVerb = "POST" $oReq.ContentType = "multipart/form-data" $oReq.Path = "/v2/feeds?feedType=inventory" $oReq.AddHeader "Accept","application/xml" ; The JSON returned by WalmartSignature contains the values to be used in the following ; header fields: WM_SEC.AUTH_SIGNATURE, WM_SEC.TIMESTAMP, and WM_QOS.CORRELATION_ID $oJson = ObjCreate("Chilkat.JsonObject") $oJson.Load($sJsonStr) $oReq.AddHeader "WM_SVC.NAME","Walmart Marketplace" $oReq.AddHeader "WM_QOS.CORRELATION_ID",$oJson.StringOf("correlation_id") $oReq.AddHeader "WM_SEC.TIMESTAMP",$oJson.StringOf("timestamp") $oReq.AddHeader "WM_SEC.AUTH_SIGNATURE",$oJson.StringOf("signature") $oReq.AddHeader "WM_CONSUMER.ID",$sWmConsumerId ; Note: Make sure to replace "WALMART_CHANNEL_TYPE" with the actual value for your seller account... $oReq.AddHeader "WM_CONSUMER.CHANNEL.TYPE","WALMART_CHANNEL_TYPE" ; The body of the POST will contain XML. In this example, we'll load the XML ; from a file. The XML contains inventory data that looks something like this: ; <InventoryFeed xmlns="http://walmart.com/"> ; <InventoryHeader> ; <version>1.4</version> ; </InventoryHeader> ; <inventory> ; <sku>1068155</sku> ; <quantity> ; <unit>EACH</unit> ; <amount>10</amount> ; </quantity> ; <fulfillmentLagTime>1</fulfillmentLagTime> ; </inventory> ; <inventory> ; <sku>10210321</sku> ; <quantity> ; <unit>EACH</unit> ; <amount>20</amount> ; </quantity> ; <fulfillmentLagTime>3</fulfillmentLagTime> ; </inventory> ; </InventoryFeed> $bSuccess = $oReq.AddFileForUpload2("inventory","qa_data/walmart/inventory.xml","application/xml") If ($bSuccess <> True) Then ConsoleWrite($oReq.LastErrorText & @CRLF) Exit EndIf $oHttp = ObjCreate("Chilkat.Http") Local $oResp = $oHttp.SynchronousRequest("marketplace.walmartapis.com",443,True,$oReq) If ($oHttp.LastMethodSuccess <> True) Then ConsoleWrite($oHttp.LastErrorText & @CRLF) Exit EndIf $oXml = ObjCreate("Chilkat.Xml") $oXml.LoadXml($oResp.BodyStr) ; A successful response should have a 200 response status If ($oResp.StatusCode <> 200) Then ConsoleWrite($oXml.GetXml() & @CRLF) ConsoleWrite("Response Status Code: " & $oResp.StatusCode & @CRLF) ConsoleWrite("Failed." & @CRLF) Exit EndIf ; Show the XML response.. ConsoleWrite($oXml.GetXml() & @CRLF) ConsoleWrite("--" & @CRLF) ConsoleWrite("Success!" & @CRLF) |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.