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) Walmart - Send Shipping NotificationSee Shipping notifications/updates for more information about this call. Note: This example requires Chilkat v9.5.0.67 or greater. 
 ' 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/v3/orders/{purchaseOrderId}/shipping Dim sbUrl As Chilkat.StringBuilder Set sbUrl = Chilkat.NewStringBuilder success = sbUrl.Append("https://marketplace.walmartapis.com/v3/orders/{purchaseOrderId}/shipping") numReplaced = sbUrl.Replace("{purchaseOrderId}","1111691995111") requestMethod = "POST" ' First we need to generate a signature for our request. ' The signature needs to be re-generated for each new Walmart HTTP request. Dim authUtil As Chilkat.AuthUtil Set authUtil = Chilkat.NewAuthUtil wmConsumerId = "WALMART_CONSUMER_ID" wmPrivateKey = "WALMART_PRIVATE_KEY" jsonStr = authUtil.WalmartSignature(sbUrl.GetAsString(),wmConsumerId,wmPrivateKey,requestMethod) If (authUtil.LastMethodSuccess <> True) Then Debug.Print authUtil.LastErrorText Exit Sub 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 Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject success = json.Load(jsonStr) Dim http As Chilkat.Http Set http = Chilkat.NewHttp 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.SetRequestHeader "WM_CONSUMER.CHANNEL.TYPE","WALMART_CHANNEL_TYPE" http.Accept = "application/xml" ' Note: Do not explicitly set the "Host" header. Chilkat will set it automatically. ' The body of the POST request will be XML that looks something like this: ' <?xml version="1.0" encoding="UTF-8" standalone="yes"?> ' <ns2:orderShipment ' xmlns:ns2="http://walmart.com/mp/v3/orders" ' xmlns:ns3="http://walmart.com/"> ' <ns2:orderLines> ' <ns2:orderLine> ' <ns2:lineNumber>2</ns2:lineNumber> ' <ns2:orderLineStatuses> ' <ns2:orderLineStatus> ' <ns2:status>Shipped</ns2:status> ' <ns2:statusQuantity> ' <ns2:unitOfMeasurement>Each</ns2:unitOfMeasurement> ' <ns2:amount>1</ns2:amount> ' </ns2:statusQuantity> ' <ns2:trackingInfo> ' <ns2:shipDateTime>2016-06-27T05:30:15.000Z</ns2:shipDateTime> ' <ns2:carrierName> ' <ns2:carrier>FedEx</ns2:carrier> ' </ns2:carrierName> ' <ns2:methodCode>Standard</ns2:methodCode> ' <ns2:trackingNumber>12333634122</ns2:trackingNumber> ' </ns2:trackingInfo> ' </ns2:orderLineStatus> ' </ns2:orderLineStatuses> ' </ns2:orderLine> ' </ns2:orderLines> ' </ns2:orderShipment> ' Build the XML request body: lineNumber = 1 shippingStatus = "Shipped" quantity = 1 carrier = "USPS" shippingMethod = "Standard" trackingNumber = "9999869903501929298999" Dim dtNow As Chilkat.CkDateTime Set dtNow = Chilkat.NewCkDateTime success = dtNow.SetFromCurrentSystemTime() shipDateTime = dtNow.GetAsTimestamp(False) Dim xmlBody As Chilkat.Xml Set xmlBody = Chilkat.NewXml xmlBody.Tag = "ns2:orderShipment" success = xmlBody.AddAttribute("xmlns:ns2","http://walmart.com/mp/v3/orders") success = xmlBody.AddAttribute("xmlns:ns3","http://walmart.com/") xmlBody.UpdateChildContentInt "ns2:orderLines|ns2:orderLine|ns2:lineNumber",lineNumber Set orderLine = xmlBody.GetChildWithTag("ns2:orderLines|ns2:orderLine") orderLine.UpdateChildContent "ns2:orderLineStatuses|ns2:orderLineStatus|ns2:status",shippingStatus Set orderLineStatus = orderLine.GetChildWithTag("ns2:orderLineStatuses|ns2:orderLineStatus") orderLineStatus.UpdateChildContent "ns2:statusQuantity|ns2:unitOfMeasurement","Each" orderLineStatus.UpdateChildContentInt "ns2:statusQuantity|ns2:amount",quantity orderLineStatus.UpdateChildContent "ns2:trackingInfo|ns2:shipDateTime",shipDateTime orderLineStatus.UpdateChildContent "ns2:trackingInfo|ns2:carrierName|ns2:carrier",carrier orderLineStatus.UpdateChildContent "ns2:trackingInfo|ns2:methodCode",shippingMethod orderLineStatus.UpdateChildContent "ns2:trackingInfo|ns2:trackingNumber",trackingNumber Debug.Print "POST request body:" Debug.Print xmlBody.GetXml() Debug.Print "--" ' This is a simple POST that can be sent w/ the PostXml method. ' Explicitly set the Content-Type header, otherwise "text/xml" will be used. http.SetRequestHeader "Content-Type","application/xml" Set resp = http.PostXml(sbUrl.GetAsString(),xmlBody.GetXml(),"utf-8") If (http.LastMethodSuccess <> True) Then Debug.Print http.LastErrorText Exit Sub End If Dim xml As Chilkat.Xml Set xml = Chilkat.NewXml success = xml.LoadXml(resp.BodyStr) ' A successful response should have a 200 response status If (resp.StatusCode <> 200) Then Debug.Print xml.GetXml() Debug.Print "Response Status Code: "; resp.StatusCode Debug.Print "Failed." Exit Sub End If ' Show the XML response.. Debug.Print xml.GetXml() Debug.Print "--" Debug.Print "Success!"  | 
  ||||
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.