Java
Java
Peoplevox GetReportData
See more Peoplevox Examples
Demonstrates how to export data from a Peoplevox Warehouse Management System (WMS) using a system report template.Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// 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.
//
CkStringBuilder sbSoapXml = new CkStringBuilder();
sbSoapXml.Append("<?xml version=\"1.0\" encoding=\"utf-8\"?>\r\n");
sbSoapXml.Append("<soap:Envelope xmlns:soap=\"http://www.w3.org/2003/05/soap-envelope\" xmlns:peop=\"http://www.peoplevox.net/\">\r\n");
sbSoapXml.Append(" <soap:Header>\r\n");
sbSoapXml.Append(" <peop:UserSessionCredentials>\r\n");
sbSoapXml.Append(" <peop:UserId>PEOPLEVOX_USER_ID</peop:UserId>\r\n");
sbSoapXml.Append(" <peop:ClientId>PEOPLEVOX_CLIENT_ID</peop:ClientId>\r\n");
sbSoapXml.Append(" <peop:SessionId>PEOPLEVOX_SESSION_ID</peop:SessionId>\r\n");
sbSoapXml.Append(" </peop:UserSessionCredentials>\r\n");
sbSoapXml.Append(" </soap:Header>\r\n");
sbSoapXml.Append(" <soap:Body>\r\n");
sbSoapXml.Append(" <peop:GetReportData>\r\n");
sbSoapXml.Append(" <peop:getReportRequest>\r\n");
sbSoapXml.Append(" <peop:TemplateName>Item movement history</peop:TemplateName>\r\n");
sbSoapXml.Append(" <peop:PageNo>1</peop:PageNo>\r\n");
sbSoapXml.Append(" <peop:ItemsPerPage>20</peop:ItemsPerPage>\r\n");
sbSoapXml.Append(" <peop:OrderBy>[Date timestamp]</peop:OrderBy>\r\n");
sbSoapXml.Append(" <peop:Columns>[Item code],[Date timestamp],[From],[To],[Quantity],[Comments]</peop:Columns>\r\n");
sbSoapXml.Append(" <peop:SearchClause>([Date timestamp] > DateTime(2016,01,01,09,00,00))</peop:SearchClause>\r\n");
sbSoapXml.Append(" </peop:getReportRequest>\r\n");
sbSoapXml.Append(" </peop:GetReportData>\r\n");
sbSoapXml.Append(" </soap:Body>\r\n");
sbSoapXml.Append("</soap:Envelope>");
CkHttpRequest req = new CkHttpRequest();
req.put_HttpVerb("POST");
req.put_SendCharset(true);
req.put_Charset("utf-8");
req.AddHeader("Content-Type","text/xml");
req.AddHeader("SOAPAction","http://www.peoplevox.net/GetReportData");
req.put_Path("/PEOPLEVOX_CLIENT_ID/resources/integrationservicev4.asmx");
success = req.LoadBodyFromString(sbSoapXml.getAsString(),"utf-8");
CkHttp http = new CkHttp();
http.put_FollowRedirects(true);
CkHttpResponse resp = new CkHttpResponse();
success = http.HttpSReq("qac.peoplevox.net",443,true,req,resp);
if (success == false) {
System.out.println(http.lastErrorText());
return;
}
// We should expect a 200 response if successful.
if (resp.get_StatusCode() != 200) {
System.out.println("Response StatusCode = " + resp.get_StatusCode());
System.out.println("Response StatusLine: " + resp.statusLine());
System.out.println("Response Header:");
System.out.println(resp.header());
System.out.println(resp.bodyStr());
return;
}
CkXml xmlResponse = new CkXml();
success = xmlResponse.LoadXml(resp.bodyStr());
System.out.println(xmlResponse.getXml());
String detail = xmlResponse.chilkatPath("soap:Body|GetReportDataResponse|GetReportDataResult|Detail|*");
CkCsv csv = new CkCsv();
csv.put_HasColumnNames(true);
csv.LoadFromString(detail);
System.out.println("NumRows = " + csv.get_NumRows());
System.out.println("NumColumns = " + csv.get_NumColumns());
// Iterate over the rows, getting the ItemCode, Name, and Barcode
int i = 0;
int numRows = csv.get_NumRows();
while (i < numRows) {
System.out.println("Item code: " + csv.getCellByName(i,"Item code"));
System.out.println("Date timestamp: " + csv.getCellByName(i,"Date timestamp"));
System.out.println("From: " + csv.getCellByName(i,"From"));
System.out.println("To: " + csv.getCellByName(i,"To"));
System.out.println("Quantity: " + csv.getCellByName(i,"Quantity"));
System.out.println("Comments: " + csv.getCellByName(i,"Comments"));
System.out.println("-");
i = i+1;
}
}
}