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
(VBScript) Walmart - Update Inventory for an ItemDemonstrates how to update inventory for an item.
Dim fso, outFile Set fso = CreateObject("Scripting.FileSystemObject") 'Create a Unicode (utf-16) output text file. Set outFile = fso.CreateTextFile("output.txt", True, True) ' --------------------------------------------------------------------------------------------------------- ' Note: This example is deprecated. The Walmart API no longer uses the Signature method of authenticating. ' Walmart now uses OAuth2. ' --------------------------------------------------------------------------------------------------------- ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' Sends the following PUT request: ' PUT https://marketplace.walmartapis.com/v2/inventory?sku={SKU} ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbUrl = CreateObject("Chilkat.StringBuilder") success = sbUrl.Append("https://marketplace.walmartapis.com/v2/inventory?sku={SKU}") numReplaced = sbUrl.Replace("{SKU}","HOPP~904~51041") requestMethod = "PUT" ' First we need to generate a signature for our request. ' The signature needs to be re-generated for each new Walmart HTTP request. ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.AuthUtil") set authUtil = CreateObject("Chilkat.AuthUtil") wmConsumerId = "WALMART_CONSUMER_ID" wmPrivateKey = "WALMART_PRIVATE_KEY" jsonStr = authUtil.WalmartSignature(sbUrl.GetAsString(),wmConsumerId,wmPrivateKey,requestMethod) If (authUtil.LastMethodSuccess <> 1) Then outFile.WriteLine(authUtil.LastErrorText) WScript.Quit End If ' 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 ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set json = CreateObject("Chilkat.JsonObject") success = json.Load(jsonStr) ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Http") set http = CreateObject("Chilkat.Http") http.SetRequestHeader "WM_SVC.NAME","Walmart Marketplace" http.SetRequestHeader "WM_QOS.CORRELATION_ID",json.StringOf("correlation_id") http.SetRequestHeader "WM_SEC.TIMESTAMP",json.StringOf("timestamp") http.SetRequestHeader "WM_SEC.AUTH_SIGNATURE",json.StringOf("signature") http.SetRequestHeader "WM_CONSUMER.ID",wmConsumerId http.Accept = "application/xml" ' Note: Do not explicitly set the "Host" header. Chilkat will set it automatically. ' The body of the PUT request will be XML that looks like this: ' <?xml version="1.0" encoding="utf-8" ?> ' <wm:inventory xmlns:wm="http://walmart.com/"> ' <wm:sku>HOPP~904~51041</wm:sku> ' <wm:quantity> ' <wm:unit>EACH</wm:unit> ' <wm:amount>235</wm:amount> ' </wm:quantity> ' <wm:fulfillmentLagTime>5</wm:fulfillmentLagTime> ' </wm:inventory> ' Build the XML request body: originalAmount = 234 ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Xml") set xmlBody = CreateObject("Chilkat.Xml") xmlBody.Tag = "wm:inventory" success = xmlBody.AddAttribute("xmlns:wm","http://walmart.com/") xmlBody.UpdateChildContent "wm:sku","HOPP~904~51041" xmlBody.UpdateChildContent "wm:quantity|wm:unit","EACH" xmlBody.UpdateChildContentInt "wm:quantity|wm:amount",originalAmount + 1 xmlBody.UpdateChildContent "wm:fulfillmentLagTime","5" outFile.WriteLine("PUT request body:") outFile.WriteLine(xmlBody.GetXml()) outFile.WriteLine("--") ' This is a simple PUT that can be sent w/ the PutText method. xmlStr = http.PutText(sbUrl.GetAsString(),xmlBody.GetXml(),"utf-8","application/xml",0,0) If (http.LastMethodSuccess <> 1) Then outFile.WriteLine(http.LastErrorText) WScript.Quit End If ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Xml") set xml = CreateObject("Chilkat.Xml") success = xml.LoadXml(xmlStr) ' A successful response should have a 200 response status If (http.LastStatus <> 200) Then outFile.WriteLine(xml.GetXml()) outFile.WriteLine("Response Status Code: " & http.LastStatus) outFile.WriteLine("Failed.") WScript.Quit End If ' A sample XML response is shown below.. outFile.WriteLine(xml.GetXml()) outFile.WriteLine("--") outFile.WriteLine("Success!") ' --------------------------------------- ' Sample XML response ' --------------------------------------- ' <?xml version="1.0" encoding="UTF-8" standalone="yes" ?> ' <inventory xmlns="http://walmart.com/"> ' <sku>HOPP~904~51041</sku> ' <quantity> ' <unit>EACH</unit> ' <amount>235</amount> ' </quantity> ' <fulfillmentLagTime>5</fulfillmentLagTime> ' </inventory> outFile.Close |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.