Objective-C
Objective-C
Aruba Fatturazione Elettronica CreateTransmissionRequestList
See more Aruba Fatturazione Examples
Creation of "Financial Communications" transmission request in zip format.Chilkat Objective-C Downloads
#import <CkoHttp.h>
#import <CkoZip.h>
#import <CkoBinData.h>
#import <NSString.h>
#import <CkoJsonObject.h>
#import <CkoHttpResponse.h>
#import <CkoStringBuilder.h>
BOOL success = NO;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkoHttp *http = [[CkoHttp alloc] init];
// Implements the following CURL command:
// curl -X POST https://ws.fatturazioneelettronica.aruba.it/services/ClientRequest/CreateTransmissionRequestList \
// -H "Accept: application/json" \
// -H "Content-Type: application/json;charset=UTF-8" \
// -d '{
// "userName" : "ARUBA0000",
// "password" : "ArubaPwd",
// "userID" : "ARUBA0000",
// "comunicationType" : "LI",
// "dataFile" : "dGVzdA=="
// }'
// The dataFile must contain a Zip file, containing xml files which conform to the Revenue Agency specifications.
// The archive file must be Base64 codified and contain a CADES-based electronic signature.
CkoZip *zip = [[CkoZip alloc] init];
// Initialize the zip object. Because we will never actually write a zip file to the filesystem,
// the filepath passed to NewZip does not matter.
[zip NewZip: @"x.zip"];
// Append references to XML files to the zip object in memory.
BOOL recurse = NO;
success = [zip AppendFiles: @"qa_data/aruba/*.xml" recurse: recurse];
if (success == NO) {
NSLog(@"%@",zip.LastErrorText);
return;
}
// Write the zip archive into the bdZip object.
CkoBinData *bdZip = [[CkoBinData alloc] init];
success = [zip WriteBd: bdZip];
if (success == NO) {
NSLog(@"%@",zip.LastErrorText);
return;
}
// Get the zip in base64 format.
NSString *zipAsBase64 = [bdZip GetEncoded: @"base64"];
// Use the following online tool to generate HTTP code from a CURL command
// Convert a cURL Command to HTTP Source Code
// Use this online tool to generate code from sample JSON:
// Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "userName": "ARUBA0000",
// "password": "ArubaPwd",
// "userID": "ARUBA0000",
// "comunicationType": "LI",
// "dataFile": "dGVzdA=="
// }
CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"userName" value: @"ARUBA0000"];
[json UpdateString: @"password" value: @"ArubaPwd"];
[json UpdateString: @"userID" value: @"ARUBA0000"];
[json UpdateString: @"comunicationType" value: @"LI"];
[json UpdateString: @"dataFile" value: zipAsBase64];
[http SetRequestHeader: @"Content-Type" value: @"application/json;charset=UTF-8"];
[http SetRequestHeader: @"Accept" value: @"application/json"];
CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"POST" url: @"https://ws.fatturazioneelettronica.aruba.it/services/ClientRequest/CreateTransmissionRequestList" json: json contentType: @"application/json" response: resp];
if (success == NO) {
NSLog(@"%@",http.LastErrorText);
return;
}
CkoStringBuilder *sbResponseBody = [[CkoStringBuilder alloc] init];
[resp GetBodySb: sbResponseBody];
CkoJsonObject *jResp = [[CkoJsonObject alloc] init];
[jResp LoadSb: sbResponseBody];
jResp.EmitCompact = NO;
NSLog(@"%@",@"Response Body:");
NSLog(@"%@",[jResp Emit]);
int respStatusCode = [resp.StatusCode intValue];
NSLog(@"%@%d",@"Response Status Code = ",respStatusCode);
if (respStatusCode >= 400) {
NSLog(@"%@",@"Response Header:");
NSLog(@"%@",resp.Header);
NSLog(@"%@",@"Failed.");
return;
}
// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)
// {
// "errorCode": "",
// "errorDescription": "",
// "requestID": "C70WC0SIPQ1JISWQ",
// "requestIDList": [
// {
// "fileName": "ITADFSREETDSD_LI_0001.xml",
// "requestID": "TXZWQPVYVFJHRUKN"
// },
// {
// "fileName": "ITADFSREETDSD_LI_0002.xml",
// "requestID": "PRSGFITDHFPTJ8OO"
// },
// {
// "fileName": "ITADFSREETDSD_LI_0003.xml",
// "requestID": "QNJ9E2MWGYGSM22Q"
// }
// ]
// }
// Sample code for parsing the JSON response...
// Use the following online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
NSString *fileName = 0;
NSString *errorCode = [jResp StringOf: @"errorCode"];
NSString *errorDescription = [jResp StringOf: @"errorDescription"];
NSString *requestID = [jResp StringOf: @"requestID"];
int i = 0;
int count_i = [[jResp SizeOfArray: @"requestIDList"] intValue];
while (i < count_i) {
jResp.I = [NSNumber numberWithInt: i];
fileName = [jResp StringOf: @"requestIDList[i].fileName"];
requestID = [jResp StringOf: @"requestIDList[i].requestID"];
i = i + 1;
}