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) Peoplevox GetReportDataDemonstrates how to export data from a Peoplevox Warehouse Management System (WMS) using a system report template.
' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' Sends a POST that looks like this: ' POST /PEOPLEVOX_CLIENT_ID/resources/integrationservicev4.asmx HTTP/1.1 ' Content-Type: text/xml;charset=UTF-8 ' SOAPAction: http://www.peoplevox.net/GetReportData ' Content-Length: (automatically computed and added by Chilkat) ' Host: qac.peoplevox.net ' ' <soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:peop="http://www.peoplevox.net/"> ' <soap:Header> ' <peop:UserSessionCredentials> ' <peop:UserId>PEOPLEVOX_USER_ID</peop:UserId> ' <peop:ClientId>PEOPLEVOX_CLIENT_ID</peop:ClientId> ' <peop:SessionId>PEOPLEVOX_SESSION_ID</peop:SessionId> ' </peop:UserSessionCredentials> ' </soap:Header> ' <soap:Body> ' <peop:GetReportData> ' <peop:getReportRequest> ' <peop:TemplateName>Item movement history</peop:TemplateName> ' <peop:PageNo>1</peop:PageNo> ' <peop:ItemsPerPage>20</peop:ItemsPerPage> ' <peop:OrderBy>[Date timestamp]</peop:OrderBy> ' <peop:Columns>[Item code],[Date timestamp],[From],[To],[Quantity],[Comments]</peop:Columns> ' <peop:SearchClause>([Date timestamp] > DateTime(2016,01,01,09,00,00))</peop:SearchClause> ' </peop:getReportRequest> ' </peop:GetReportData> ' </soap:Body> ' </soap:Envelope> ' ' Notice that a UserId is needed here. This is different than the username required for Peoplevox authentication. ' The UserId for the admin account is 1. ' Dim sbSoapXml As Chilkat.StringBuilder Set sbSoapXml = Chilkat.NewStringBuilder success = sbSoapXml.Append("<?xml version=""1.0"" encoding=""utf-8""?>" & vbCrLf) success = sbSoapXml.Append("<soap:Envelope xmlns:soap=""http://www.w3.org/2003/05/soap-envelope"" xmlns:peop=""http://www.peoplevox.net/"">" & vbCrLf) success = sbSoapXml.Append(" <soap:Header>" & vbCrLf) success = sbSoapXml.Append(" <peop:UserSessionCredentials>" & vbCrLf) success = sbSoapXml.Append(" <peop:UserId>PEOPLEVOX_USER_ID</peop:UserId>" & vbCrLf) success = sbSoapXml.Append(" <peop:ClientId>PEOPLEVOX_CLIENT_ID</peop:ClientId>" & vbCrLf) success = sbSoapXml.Append(" <peop:SessionId>PEOPLEVOX_SESSION_ID</peop:SessionId>" & vbCrLf) success = sbSoapXml.Append(" </peop:UserSessionCredentials>" & vbCrLf) success = sbSoapXml.Append(" </soap:Header>" & vbCrLf) success = sbSoapXml.Append(" <soap:Body>" & vbCrLf) success = sbSoapXml.Append(" <peop:GetReportData>" & vbCrLf) success = sbSoapXml.Append(" <peop:getReportRequest>" & vbCrLf) success = sbSoapXml.Append(" <peop:TemplateName>Item movement history</peop:TemplateName>" & vbCrLf) success = sbSoapXml.Append(" <peop:PageNo>1</peop:PageNo>" & vbCrLf) success = sbSoapXml.Append(" <peop:ItemsPerPage>20</peop:ItemsPerPage>" & vbCrLf) success = sbSoapXml.Append(" <peop:OrderBy>[Date timestamp]</peop:OrderBy>" & vbCrLf) success = sbSoapXml.Append(" <peop:Columns>[Item code],[Date timestamp],[From],[To],[Quantity],[Comments]</peop:Columns>" & vbCrLf) success = sbSoapXml.Append(" <peop:SearchClause>([Date timestamp] > DateTime(2016,01,01,09,00,00))</peop:SearchClause>" & vbCrLf) success = sbSoapXml.Append(" </peop:getReportRequest>" & vbCrLf) success = sbSoapXml.Append(" </peop:GetReportData>" & vbCrLf) success = sbSoapXml.Append(" </soap:Body>" & vbCrLf) success = sbSoapXml.Append("</soap:Envelope>") Dim req As Chilkat.HttpRequest Set req = Chilkat.NewHttpRequest req.HttpVerb = "POST" req.SendCharset = True req.Charset = "utf-8" req.AddHeader "Content-Type","text/xml" req.AddHeader "SOAPAction","http://www.peoplevox.net/GetReportData" req.Path = "/PEOPLEVOX_CLIENT_ID/resources/integrationservicev4.asmx" success = req.LoadBodyFromString(sbSoapXml.GetAsString(),"utf-8") Dim http As Chilkat.Http Set http = Chilkat.NewHttp http.FollowRedirects = True Set resp = http.SynchronousRequest("qac.peoplevox.net",443,True,req) If (http.LastMethodSuccess <> True) Then Debug.Print http.LastErrorText Exit Sub End If ' We should expect a 200 response if successful. If (resp.StatusCode <> 200) Then Debug.Print "Response StatusCode = "; resp.StatusCode Debug.Print "Response StatusLine: "; resp.StatusLine Debug.Print "Response Header:" Debug.Print resp.Header Debug.Print resp.BodyStr Exit Sub End If Dim xmlResponse As Chilkat.Xml Set xmlResponse = Chilkat.NewXml success = xmlResponse.LoadXml(resp.BodyStr) Debug.Print xmlResponse.GetXml() detail = xmlResponse.ChilkatPath("soap:Body|GetReportDataResponse|GetReportDataResult|Detail|*") Dim csv As Chilkat.Csv Set csv = Chilkat.NewCsv csv.HasColumnNames = True success = csv.LoadFromString(detail) Debug.Print "NumRows = "; csv.NumRows Debug.Print "NumColumns = "; csv.NumColumns ' Iterate over the rows, getting the ItemCode, Name, and Barcode i = 0 numRows = csv.NumRows Do While i < numRows Debug.Print "Item code: "; csv.GetCellByName(i,"Item code") Debug.Print "Date timestamp: "; csv.GetCellByName(i,"Date timestamp") Debug.Print "From: "; csv.GetCellByName(i,"From") Debug.Print "To: "; csv.GetCellByName(i,"To") Debug.Print "Quantity: "; csv.GetCellByName(i,"Quantity") Debug.Print "Comments: "; csv.GetCellByName(i,"Comments") Debug.Print "-" i = i + 1 Loop |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.