Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Objective-C) Retrieve User Account DataSee more DocuSign ExamplesTo make an API call to the DocuSign platform, your application needs both an access token (which you obtained in the previous step), and base URI that is unique to the user on whose behalf your application is making the API call. To get the base URI, call the/oauth/userinfoendpoint, supplying your application’s access token as a header. For more information, see https://developers.docusign.com/esign-rest-api/guides/authentication/oauth2-jsonwebtoken
#import <CkoHttp.h> #import <CkoJsonObject.h> #import <CkoStringBuilder.h> #import <NSString.h> // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoHttp *http = [[CkoHttp alloc] init]; BOOL success; // Implements the following CURL command: // curl --header "Authorization: Bearer eyJ0eXAi.....UE8Kl_V8KroQ" https://account-d.docusign.com/oauth/userinfo // Use the following online tool to generate HTTP code from a CURL command // Convert a cURL Command to HTTP Source Code // Adds the "Authorization: Bearer eyJ0eXAi.....UE8Kl_V8KroQ" header. CkoJsonObject *jsonToken = [[CkoJsonObject alloc] init]; // Load a previously obtained OAuth2 access token. success = [jsonToken LoadFile: @"qa_data/tokens/docusign.json"]; if (success == NO) { NSLog(@"%@",jsonToken.LastErrorText); return; } http.AuthToken = [jsonToken StringOf: @"access_token"]; CkoStringBuilder *sbResponseBody = [[CkoStringBuilder alloc] init]; success = [http QuickGetSb: @"https://account-d.docusign.com/oauth/userinfo" sbContent: sbResponseBody]; if (success == NO) { NSLog(@"%@",http.LastErrorText); return; } CkoJsonObject *jResp = [[CkoJsonObject alloc] init]; [jResp LoadSb: sbResponseBody]; jResp.EmitCompact = NO; NSLog(@"%@",@"Response Body:"); NSLog(@"%@",[jResp Emit]); int respStatusCode = [http.LastStatus intValue]; NSLog(@"%@%d",@"Response Status Code = ",respStatusCode); if (respStatusCode >= 400) { NSLog(@"%@",@"Response Header:"); NSLog(@"%@",http.LastHeader); NSLog(@"%@",@"Failed."); return; } // Sample JSON response: // (Sample code for parsing the JSON response is shown below) // { // "sub": "564f7988-xxxx-xxxx-xxxx-781ee556ab7a", // "name": "Example J Smith", // "given_name": "Example", // "family_name": "Smith", // "created": "2018-04-13T22:03:03.45", // "email": "Example.Smith@exampledomain.com", // "accounts": [ // { // "account_id": "18b4799a-xxxx-xxxx-xxxx-b5b4b8a97604", // "is_default": true, // "account_name": "ExampleAccount", // "base_uri": "https://demo.docusign.net" // } // ] // } // 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 *account_id = 0; BOOL is_default; NSString *account_name = 0; NSString *base_uri = 0; NSString *sub = [jResp StringOf: @"sub"]; NSString *name = [jResp StringOf: @"name"]; NSString *given_name = [jResp StringOf: @"given_name"]; NSString *family_name = [jResp StringOf: @"family_name"]; NSString *created = [jResp StringOf: @"created"]; NSString *email = [jResp StringOf: @"email"]; int i = 0; int count_i = [[jResp SizeOfArray: @"accounts"] intValue]; while (i < count_i) { jResp.I = [NSNumber numberWithInt: i]; account_id = [jResp StringOf: @"accounts[i].account_id"]; is_default = [jResp BoolOf: @"accounts[i].is_default"]; account_name = [jResp StringOf: @"accounts[i].account_name"]; base_uri = [jResp StringOf: @"accounts[i].base_uri"]; i = i + 1; } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.