C#
C#
Peoplevox GetReportData
See more Peoplevox Examples
Demonstrates how to export data from a Peoplevox Warehouse Management System (WMS) using a system report template.Chilkat C# Downloads
bool 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.
//
Chilkat.StringBuilder sbSoapXml = new Chilkat.StringBuilder();
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>");
Chilkat.HttpRequest req = 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");
Chilkat.Http http = new Chilkat.Http();
http.FollowRedirects = true;
Chilkat.HttpResponse resp = new Chilkat.HttpResponse();
success = http.HttpSReq("qac.peoplevox.net",443,true,req,resp);
if (success == false) {
Debug.WriteLine(http.LastErrorText);
return;
}
// We should expect a 200 response if successful.
if (resp.StatusCode != 200) {
Debug.WriteLine("Response StatusCode = " + Convert.ToString(resp.StatusCode));
Debug.WriteLine("Response StatusLine: " + resp.StatusLine);
Debug.WriteLine("Response Header:");
Debug.WriteLine(resp.Header);
Debug.WriteLine(resp.BodyStr);
return;
}
Chilkat.Xml xmlResponse = new Chilkat.Xml();
success = xmlResponse.LoadXml(resp.BodyStr);
Debug.WriteLine(xmlResponse.GetXml());
string detail = xmlResponse.ChilkatPath("soap:Body|GetReportDataResponse|GetReportDataResult|Detail|*");
Chilkat.Csv csv = new Chilkat.Csv();
csv.HasColumnNames = true;
csv.LoadFromString(detail);
Debug.WriteLine("NumRows = " + Convert.ToString(csv.NumRows));
Debug.WriteLine("NumColumns = " + Convert.ToString(csv.NumColumns));
// Iterate over the rows, getting the ItemCode, Name, and Barcode
int i = 0;
int numRows = 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;
}