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
(VB.NET UWP/WinRT) 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. Dim success As Boolean ' 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 New Chilkat.StringBuilder sbSoapXml.Append("<?xml version=""1.0"" encoding=""utf-8""?>" & vbCrLf) sbSoapXml.Append("<soap:Envelope xmlns:soap=""http://www.w3.org/2003/05/soap-envelope"" xmlns:peop=""http://www.peoplevox.net/"">" & vbCrLf) sbSoapXml.Append(" <soap:Header>" & vbCrLf) sbSoapXml.Append(" <peop:UserSessionCredentials>" & vbCrLf) sbSoapXml.Append(" <peop:UserId>PEOPLEVOX_USER_ID</peop:UserId>" & vbCrLf) sbSoapXml.Append(" <peop:ClientId>PEOPLEVOX_CLIENT_ID</peop:ClientId>" & vbCrLf) sbSoapXml.Append(" <peop:SessionId>PEOPLEVOX_SESSION_ID</peop:SessionId>" & vbCrLf) sbSoapXml.Append(" </peop:UserSessionCredentials>" & vbCrLf) sbSoapXml.Append(" </soap:Header>" & vbCrLf) sbSoapXml.Append(" <soap:Body>" & vbCrLf) sbSoapXml.Append(" <peop:GetReportData>" & vbCrLf) sbSoapXml.Append(" <peop:getReportRequest>" & vbCrLf) sbSoapXml.Append(" <peop:TemplateName>Item movement history</peop:TemplateName>" & vbCrLf) sbSoapXml.Append(" <peop:PageNo>1</peop:PageNo>" & vbCrLf) sbSoapXml.Append(" <peop:ItemsPerPage>20</peop:ItemsPerPage>" & vbCrLf) sbSoapXml.Append(" <peop:OrderBy>[Date timestamp]</peop:OrderBy>" & vbCrLf) sbSoapXml.Append(" <peop:Columns>[Item code],[Date timestamp],[From],[To],[Quantity],[Comments]</peop:Columns>" & vbCrLf) sbSoapXml.Append(" <peop:SearchClause>([Date timestamp] > DateTime(2016,01,01,09,00,00))</peop:SearchClause>" & vbCrLf) sbSoapXml.Append(" </peop:getReportRequest>" & vbCrLf) sbSoapXml.Append(" </peop:GetReportData>" & vbCrLf) sbSoapXml.Append(" </soap:Body>" & vbCrLf) sbSoapXml.Append("</soap:Envelope>") Dim req As New Chilkat.HttpRequest 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 New Chilkat.Http http.FollowRedirects = True Dim resp As Chilkat.HttpResponse = Await http.SynchronousRequestAsync("qac.peoplevox.net",443,True,req) If (http.LastMethodSuccess <> True) Then Debug.WriteLine(http.LastErrorText) Exit Sub End If ' We should expect a 200 response if successful. If (resp.StatusCode <> 200) Then Debug.WriteLine("Response StatusCode = " & resp.StatusCode) Debug.WriteLine("Response StatusLine: " & resp.StatusLine) Debug.WriteLine("Response Header:") Debug.WriteLine(resp.Header) Debug.WriteLine(resp.BodyStr) Exit Sub End If Dim xmlResponse As New Chilkat.Xml success = xmlResponse.LoadXml(resp.BodyStr) Debug.WriteLine(xmlResponse.GetXml()) Dim detail As String = xmlResponse.ChilkatPath("soap:Body|GetReportDataResponse|GetReportDataResult|Detail|*") Dim csv As New Chilkat.Csv csv.HasColumnNames = True csv.LoadFromString(detail) Debug.WriteLine("NumRows = " & csv.NumRows) Debug.WriteLine("NumColumns = " & csv.NumColumns) ' Iterate over the rows, getting the ItemCode, Name, and Barcode Dim i As Integer = 0 Dim numRows As Integer = csv.NumRows While i < numRows Debug.WriteLine("Item code: " & csv.GetCellByName(i,"Item code")) Debug.WriteLine("Date timestamp: " & csv.GetCellByName(i,"Date timestamp")) Debug.WriteLine("From: " & csv.GetCellByName(i,"From")) Debug.WriteLine("To: " & csv.GetCellByName(i,"To")) Debug.WriteLine("Quantity: " & csv.GetCellByName(i,"Quantity")) Debug.WriteLine("Comments: " & csv.GetCellByName(i,"Comments")) Debug.WriteLine("-") i = i + 1 End While |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.