Sample code for 30+ languages & platforms
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

Java
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;
        }
  }
}