Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(MFC) Peoplevox GetReportDataDemonstrates how to export data from a Peoplevox Warehouse Management System (WMS) using a system report template.
#include <CkStringBuilder.h> #include <CkHttpRequest.h> #include <CkHttp.h> #include <CkHttpResponse.h> #include <CkXml.h> #include <CkCsv.h> void ChilkatSample(void) { CkString strOut; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. bool success; // 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; 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; 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; http.put_FollowRedirects(true); CkHttpResponse *resp = http.SynchronousRequest("qac.peoplevox.net",443,true,req); if (http.get_LastMethodSuccess() != true) { strOut.append(http.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // We should expect a 200 response if successful. if (resp->get_StatusCode() != 200) { strOut.append("Response StatusCode = "); strOut.appendInt(resp->get_StatusCode()); strOut.append("\r\n"); strOut.append("Response StatusLine: "); strOut.append(resp->statusLine()); strOut.append("\r\n"); strOut.append("Response Header:"); strOut.append("\r\n"); strOut.append(resp->header()); strOut.append("\r\n"); strOut.append(resp->bodyStr()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } CkXml xmlResponse; success = xmlResponse.LoadXml(resp->bodyStr()); strOut.append(xmlResponse.getXml()); strOut.append("\r\n"); delete resp; const char *detail = xmlResponse.chilkatPath("soap:Body|GetReportDataResponse|GetReportDataResult|Detail|*"); CkCsv csv; csv.put_HasColumnNames(true); csv.LoadFromString(detail); strOut.append("NumRows = "); strOut.appendInt(csv.get_NumRows()); strOut.append("\r\n"); strOut.append("NumColumns = "); strOut.appendInt(csv.get_NumColumns()); strOut.append("\r\n"); // Iterate over the rows, getting the ItemCode, Name, and Barcode int i = 0; int numRows = csv.get_NumRows(); while (i < numRows) { strOut.append("Item code: "); strOut.append(csv.getCellByName(i,"Item code")); strOut.append("\r\n"); strOut.append("Date timestamp: "); strOut.append(csv.getCellByName(i,"Date timestamp")); strOut.append("\r\n"); strOut.append("From: "); strOut.append(csv.getCellByName(i,"From")); strOut.append("\r\n"); strOut.append("To: "); strOut.append(csv.getCellByName(i,"To")); strOut.append("\r\n"); strOut.append("Quantity: "); strOut.append(csv.getCellByName(i,"Quantity")); strOut.append("\r\n"); strOut.append("Comments: "); strOut.append(csv.getCellByName(i,"Comments")); strOut.append("\r\n"); strOut.append("-"); strOut.append("\r\n"); i = i + 1; } SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.