Sample code for 30+ languages & platforms
Objective-C

Aruba Fatturazione Elettronica ppd

See more Aruba Fatturazione Examples

If pddAvailable is true then this method retrieves the Preservation package as a Zip file of financial messages, specifying its request ID (requestID). If however pddAvailable is false, in other words, the Preservation package is not available, the HTTP status code 404 is returned.

Chilkat Objective-C Downloads

Objective-C
#import <CkoHttp.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://ws.fatturazioneelettronica.aruba.it/services/ClientRequest/pdd \
//   -H "Accept: application/json" \
//   -H "Content-Type: application/json;charset=UTF-8" \
//   -d '{
//   "userName" : "ARUBA0000",
//   "password" : "ArubaPwd",
//   "requestID" : "XZLA9SZ9ZW"
// }'

// 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",
//   "requestID": "XZLA9SZ9ZW"
// }

CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"userName" value: @"ARUBA0000"];
[json UpdateString: @"password" value: @"ArubaPwd"];
[json UpdateString: @"requestID" value: @"XZLA9SZ9ZW"];

[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/pdd" json: json contentType: @"application/json" response: resp];
if (success == NO) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

// Returns a response that looks like this:

// HTTP/1.1 200 OK
// Content-Disposition: attachment; filename="IT01879020517_LI_0001.conservazione.zip"
// Content-Type: application/zip
// Accept-Ranges: bytes
// Content-Length: 8
// 
// <binary>

if ([resp.StatusCode intValue] != 200) {
    NSLog(@"%@%d",@"response status code = ",[resp.StatusCode intValue]);
    NSLog(@"%@",resp.BodyStr);
    return;
}

// If we get here, the response contains a .zip.
// Save to the filename specified in the Content-Disposition.
NSString *zipFilename = [resp GetHeaderFieldAttr: @"Content-Disposition" attrName: @"filename"];
success = [resp SaveBodyBinary: zipFilename];

NSLog(@"%@",@"Success.");