Chilkat Examples

ChilkatHOMEAndroid™Classic ASPCC++C#Mono C#.NET Core C#C# UWP/WinRTDataFlexDelphi ActiveXDelphi DLLVisual FoxProJavaLianjaMFCObjective-CPerlPHP ActiveXPHP ExtensionPowerBuilderPowerShellPureBasicCkPythonChilkat2-PythonRubySQL ServerSwift 2Swift 3/4TclUnicode CUnicode C++Visual Basic 6.0VB.NETVB.NET UWP/WinRTVBScriptXojo PluginNode.jsExcelGo

Objective-C Web API Examples

Primary Categories

AWS Translate
Activix CRM
Adyen
Amazon MWS
Azure Maps
Azure Monitor
Azure OAuth2
Azure Storage Accounts
Bluzone
CardConnect
ClickBank
Clickatell
Cloudfare
DocuSign
ETrade
Etsy
Facebook
GeoOp
GetHarvest
Jira
MYOB

Magento
Microsoft Calendar
Microsoft Group
Microsoft Tasks and Plans
Okta OAuth/OIDC
OneLogin OIDC
PayPal
Peoplevox
Populi
QuickBooks
SOAP finkok.com
Shippo
Shopify
Stripe
SugarCRM
Trello
Twitter
VoiceBase
Vonage
Walmart
Walmart v3
Xero
eBay
effectconnect

 

 

 

(Objective-C) Peoplevox WMS Export Data

Demonstrates how to export data from a Peoplevox Warehouse Management System (WMS) using the GetData. It can return up to 1000 records for each call. The page number and number of items per page parameters are used to repeat the same method to return pages of information.

Chilkat Objective-C Library Downloads

MAC OS X (Cocoa) Libs

iOS Libs

#import <CkoStringBuilder.h>
#import <CkoHttpRequest.h>
#import <CkoHttp.h>
#import <CkoHttpResponse.h>
#import <CkoXml.h>
#import <NSString.h>
#import <CkoCsv.h>

// 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/GetData
// 	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:GetData>
// 	         <peop:getRequest>
// 	            <peop:TemplateName>Item Types</peop:TemplateName>
// 	            <peop:PageNo>1</peop:PageNo>
// 	            <peop:ItemsPerPage>10</peop:ItemsPerPage>
// 	            <peop:SearchClause>Name.Contains("T")</peop:SearchClause>
// 	         </peop:getRequest>
// 	      </peop:GetData>
// 	   </soap:Body>
// 	</soap:Envelope>
// 

// A few helpful notes about this request:
// 1) 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.
// 2) The sample data contains a TEST product with SKU/Code= "TEST". Search key is set to "T".
//     
CkoStringBuilder *sbSoapXml = [[CkoStringBuilder alloc] init];
[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:GetData>\r\n"];
[sbSoapXml Append: @"         <peop:getRequest>\r\n"];
[sbSoapXml Append: @"            <peop:TemplateName>Item Types</peop:TemplateName>\r\n"];
[sbSoapXml Append: @"            <peop:PageNo>1</peop:PageNo>\r\n"];
[sbSoapXml Append: @"            <peop:ItemsPerPage>10</peop:ItemsPerPage>\r\n"];
[sbSoapXml Append: @"            <peop:SearchClause>Name.Contains(\"T\")</peop:SearchClause>\r\n"];
[sbSoapXml Append: @"         </peop:getRequest>\r\n"];
[sbSoapXml Append: @"      </peop:GetData>\r\n"];
[sbSoapXml Append: @"   </soap:Body>\r\n"];
[sbSoapXml Append: @"</soap:Envelope>"];

CkoHttpRequest *req = [[CkoHttpRequest alloc] init];
req.HttpVerb = @"POST";
req.SendCharset = YES;
req.Charset = @"utf-8";
[req AddHeader: @"Content-Type" value: @"text/xml"];
[req AddHeader: @"SOAPAction" value: @"http://www.peoplevox.net/GetData"];
req.Path = @"/PEOPLEVOX_CLIENT_ID/resources/integrationservicev4.asmx";
success = [req LoadBodyFromString: [sbSoapXml GetAsString] charset: @"utf-8"];

CkoHttp *http = [[CkoHttp alloc] init];
http.FollowRedirects = YES;

CkoHttpResponse *resp = [http SynchronousRequest: @"qac.peoplevox.net" port: [NSNumber numberWithInt: 443] ssl: YES req: req];
if (http.LastMethodSuccess != YES) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

// We should expect a 200 response if successful.
if ([resp.StatusCode intValue] != 200) {
    NSLog(@"%@%d",@"Response StatusCode = ",[resp.StatusCode intValue]);
    NSLog(@"%@%@",@"Response StatusLine: ",resp.StatusLine);
    NSLog(@"%@",@"Response Header:");
    NSLog(@"%@",resp.Header);
    NSLog(@"%@",resp.BodyStr);
    return;
}

CkoXml *xmlResponse = [[CkoXml alloc] init];
success = [xmlResponse LoadXml: resp.BodyStr];
NSLog(@"%@",[xmlResponse GetXml]);

// A sample response is shown below.  The following code loads the CSV into a Chilkat CSV object, and then demonstrates how to access the data from the CSV API.
NSString *detail = [xmlResponse ChilkatPath: @"soap:Body|GetDataResponse|GetDataResult|Detail|*"];

CkoCsv *csv = [[CkoCsv alloc] init];
csv.HasColumnNames = YES;
[csv LoadFromString: detail];

NSLog(@"%@%d",@"NumRows = ",[csv.NumRows intValue]);
NSLog(@"%@%d",@"NumColumns = ",[csv.NumColumns intValue]);

// Iterate over the rows, getting the ItemCode, Name, and Barcode
int i = 0;
int numRows = [csv.NumRows intValue];
while (i < numRows) {
    NSLog(@"%@%@",@"ItemCode: ",[csv GetCellByName: [NSNumber numberWithInt: i] columnName: @"ItemCode"]);
    NSLog(@"%@%@",@"Name: ",[csv GetCellByName: [NSNumber numberWithInt: i] columnName: @"Name"]);
    NSLog(@"%@%@",@"Barcode: ",[csv GetCellByName: [NSNumber numberWithInt: i] columnName: @"Barcode"]);
    NSLog(@"%@",@"-");
    i = i + 1;
}

// <?xml version="1.0" encoding="utf-8" ?>
// <soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
//     <soap:Body>
//         <GetDataResponse xmlns="http://www.peoplevox.net/">
//             <GetDataResult>
//                 <ResponseId>0</ResponseId>
//                 <TotalCount>7</TotalCount>
//                 <Detail>"ItemCode","Name","Barcode","Description","ItemGroup","UnitOfMeasure","DefaultEconomicOrderQuantity","DefaultLeadTime","DefaultSuppliersPartNumber","HasSerialNumbers","UseManufacturersSerialNumber","ReorderPoint","PickPolicy","Traceability","ShelfLife","DefaultNumberItemsPerContainer","DefaultContainerType","DefaultNumberItemsPerOuterCase","DefaultNumberItemsPerInnerCase","BuyPrice","WholesalePrice","RetailPrice","Weight","WeightMeasure","Height","Width","Depth","DimensionMeasure","Tags","Attribute1","Attribute2","Attribute3","Attribute4","Attribute5","Attribute6","Attribute7","Attribute8","Attribute9","Attribute10","Attribute11","Attribute12","Attribute13","Attribute14","Attribute15","OnHand","Allocated","Available","POQuantityOutstanding","MinimumPickLocationQuantity","DefaultReplenishmentQuantity"
// "B246","48 PACK TENNIS BALLS","503147002876","","Item group","EA","","","","False","False","0","","False","","288","Container","","","0","0","0","0.00","EA","0.00","0.00","0.00","cm","","","","","","","","","","","","","","","","","9995","520","9475","0","0","0"
// "BGG1411","Scan testing product","503147011937","","Group1","EA","","","","False","False","0","","False","","288","Container","","","0","0","0","0.00","EA","0.00","0.00","0.00","cm","","","","","","","","","","","","","","","","","0","0","0","0","0","0"
// "OLOO15","TENT PEG REMOVER","503147006613","","Group1","EA","","","","False","False","0","","False","","80","Container","","","0","0","0","0.00","EA","0.00","0.00","0.00","cm","","","","","","","","","","","","","","","","","10000","15","9985","0","0","0"
// "TEST","testing product","123456789","testing product
// line 2","Group1","EA","","","","False","False","0","","False","","70","Pallet","20","10","0","0","0","10.00","kg","120.00","10.00","12.00","cm","","","","","","","","","","","","","","","","","0","0","0","0","0","0"
// "TY3120","PLASTIC COATED PLAYING CARDS","503147001942","","Item group","EA","","","","False","False","0","","False","","255","Container","","","0","0","0","0.00","EA","0.00","0.00","0.00","cm","","","","","","","","","","","","","","","","","10000","213","9787","0","0","0"
// "TY5263","WATER ARROWS","503147007813","","Item group","EA","","","","False","False","0","","False","","144","Container","","","0","0","0","0.00","EA","0.00","0.00","0.00","cm","","","","","","","","","","","","","","","","","10000","576","9424","0","0","0"
// "TY5281","QUOITS SET","503147007851","","Item group","EA","","","","False","False","0","","False","","48","Container","","","0","0","0","0.00","EA","0.00","0.00","0.00","cm","","","","","","","","","","","","","","","","","10000","0","10000","0","0","0"</Detail>
//                 <Statuses />
//                 <ImportingQueueId>0</ImportingQueueId>
//                 <SalesOrdersToDespatchIds />
//             </GetDataResult>
//         </GetDataResponse>
//     </soap:Body>
// </soap:Envelope>
 

© 2000-2019 Chilkat Software, Inc. All Rights Reserved.