Objective-C
Objective-C
Yousign Procedure Creation Basic Mode Upload File
See more Yousign Examples
Demonstrates the 1st step of Yousign procedure creation, which is to upload a PDF file.Chilkat Objective-C Downloads
#import <CkoHttp.h>
#import <CkoBinData.h>
#import <CkoJsonObject.h>
#import <CkoHttpResponse.h>
#import <CkoStringBuilder.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 --location --request POST 'https://staging-api.yousign.com/files' \
// --header 'Authorization: Bearer YOUR_API_KEY' \
// --header 'Content-Type: application/json' \
// --data-raw '{
// "name": "The best name for my file.pdf",
// "content": "JVBERi0..." }'
// Load a PDF file to be uploaded.
CkoBinData *pdfData = [[CkoBinData alloc] init];
success = [pdfData LoadFile: @"qa_data/pdf/helloWorld.pdf"];
if (success == NO) {
NSLog(@"%@",@"Failed to load PDF local file.");
return;
}
// 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.
// {
// "name": "The best name for my file.pdf",
// "content": "JVBERi0..."
// }
CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"name" value: @"helloWorld.pdf"];
[json UpdateString: @"content" value: [pdfData GetEncoded: @"base64"]];
// Adds the "Authorization: Bearer YOUR_API_KEY" header.
http.AuthToken = @"YOUR_API_KEY";
CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"POST" url: @"https://staging-api.yousign.com/files" 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)
// {
// "id": "/files/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX",
// "name": "The best name for my file.pdf",
// "type": "signable",
// "contentType": "application/pdf",
// "description": null,
// "createdAt": "2018-12-01T11:36:20+01:00",
// "updatedAt": "2018-12-01T11:36:20+01:00",
// "sha256": "bb57ae2b2ca6ad0133a699350d1a6f6c8cdfde3cf872cf526585d306e4675cc2",
// "metadata": [
// ],
// "workspace": "/workspaces/XXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX",
// "creator": null,
// "protected": false,
// "position": 0,
// "parent": null
// }
// 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 *id = [jResp StringOf: @"id"];
NSString *name = [jResp StringOf: @"name"];
NSString *v_type = [jResp StringOf: @"type"];
NSString *contentType = [jResp StringOf: @"contentType"];
NSString *description = [jResp StringOf: @"description"];
NSString *createdAt = [jResp StringOf: @"createdAt"];
NSString *updatedAt = [jResp StringOf: @"updatedAt"];
NSString *sha256 = [jResp StringOf: @"sha256"];
NSString *workspace = [jResp StringOf: @"workspace"];
NSString *creator = [jResp StringOf: @"creator"];
BOOL v_protected = [jResp BoolOf: @"protected"];
int position = [[jResp IntOf: @"position"] intValue];
NSString *parent = [jResp StringOf: @"parent"];
int i = 0;
int count_i = [[jResp SizeOfArray: @"metadata"] intValue];
while (i < count_i) {
jResp.I = [NSNumber numberWithInt: i];
i = i + 1;
}