Sample code for 30+ languages & platforms
Objective-C

Aruba Fatturazione Elettronica CreateTransmissionRequest

See more Aruba Fatturazione Examples

Creation of a new request for the transmission of "Financial Communications" (single file transmission request).

Chilkat Objective-C Downloads

Objective-C
#import <CkoHttp.h>
#import <CkoStringBuilder.h>
#import <CkoJsonObject.h>
#import <CkoHttpResponse.h>
#import <NSString.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://auth.fatturazioneelettronica.aruba.it/services/ClientRequest/CreateTransmissionRequest \
//   -H "Accept: application/json" \
//   -H "Content-Type: application/json;charset=UTF-8" \
//   -d '{
//   "userName" : "ARUBA0000",
//   "password" : "ArubaPwd",
//   "userID" : "ARUBA0000",
//   "comunicationType" : "LI",
//   "dataFile" : "dGVzdA=="
// }'

// 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=="
// }

// The dataFile field must contain an xml document which conforms to the Revenue Agency specifications.
// The document must be Base64 codified and contain a CADES-based electronic signature.
CkoStringBuilder *sbSignedXml = [[CkoStringBuilder alloc] init];
success = [sbSignedXml LoadFile: @"qa_data/aruba/sampleXmlDoc.xml" charset: @"utf-8"];

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: [sbSignedXml GetEncoded: @"base64" charset: @"utf-8"]];

[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/CreateTransmissionRequest" 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": "UICBY9QDLUOXQ72U"
// }

// 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 *errorCode = [jResp StringOf: @"errorCode"];
NSString *errorDescription = [jResp StringOf: @"errorDescription"];
NSString *requestID = [jResp StringOf: @"requestID"];