Sample code for 30+ languages & platforms
Visual Basic 6.0

Peoplevox GetReportData

See more Peoplevox Examples

Demonstrates how to export data from a Peoplevox Warehouse Management System (WMS) using a system report template.

Chilkat Visual Basic 6.0 Downloads

Visual Basic 6.0
Dim success As Long
success = 0

' 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 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 New ChilkatHttpResponse
success = http.HttpSReq("qac.peoplevox.net",443,1,req,resp)
If (success = 0) 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