Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual Basic 6.0) 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 Long ' 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 ChilkatStringBuilder 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 New ChilkatHttpRequest req.HttpVerb = "POST" req.SendCharset = 1 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 ChilkatHttp http.FollowRedirects = 1 Dim resp As ChilkatHttpResponse Set resp = http.SynchronousRequest("qac.peoplevox.net",443,1,req) If (http.LastMethodSuccess <> 1) 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 New ChilkatXml success = xmlResponse.LoadXml(resp.BodyStr) Debug.Print xmlResponse.GetXml() Dim detail As String detail = xmlResponse.ChilkatPath("soap:Body|GetReportDataResponse|GetReportDataResult|Detail|*") Dim csv As New ChilkatCsv csv.HasColumnNames = 1 success = csv.LoadFromString(detail) Debug.Print "NumRows = " & csv.NumRows Debug.Print "NumColumns = " & csv.NumColumns ' Iterate over the rows, getting the ItemCode, Name, and Barcode Dim i As Long i = 0 Dim numRows As Long 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-2024 Chilkat Software, Inc. All Rights Reserved.