Sample code for 30+ languages & platforms
Objective-C

Oracle Cloud Secrets - Create or Update a JSON Secret

See more Secrets Examples

Demonstrates how to create or update a JSON secret stored in the Oracle Cloud Secrets.

Note: This example requires Chilkat v10.1.0 or later.

Chilkat Objective-C Downloads

Objective-C
#import <CkoSecrets.h>
#import <CkoJsonObject.h>

BOOL success = NO;

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

// The bootstrap secret will contain the following information:

// Private Key PEM

// See following examples for setting up a bootstrap secret in memory, 
// or in the local manager (Windows Credentials Manager or Apple Keychain)
// Setup Bootstrap Secret in Local Manager
// Setup Bootstrap Secret in Memory
CkoSecrets *bootstrap = [[CkoSecrets alloc] init];

// Set the location of the bootstrap secret.
// Can be "local_manager" or "memory", depending on how you setup the bootstrap secret.
// ---------------------------------------------------------------------------------------------
// If your operating system is NOT Windows or MacOS/iOS, then change "local_manager" to "memory"
// You can also, if desired, use "memory" on Windows and MacOS/iOS if your bootstrap secret was previously setup in memory.
// ---------------------------------------------------------------------------------------------
bootstrap.Location = @"local_manager";

// Specify the bootstrap secret to be used.
CkoJsonObject *bsId = [[CkoJsonObject alloc] init];
[bsId UpdateString: @"appName" value: @"oracle_bs"];
[bsId UpdateString: @"service" value: @"Example"];
[bsId UpdateString: @"username" value: @"Joe"];

// ----------------------------------------------------
CkoSecrets *secrets = [[CkoSecrets alloc] init];

// Setup for the Oracle Cloud Secrets
secrets.Location = @"oracle_cloud";
success = [secrets SetBootstrapSecret: bsId secretContent: bootstrap];
if (success == NO) {
    NSLog(@"%@",secrets.LastErrorText);
    return;
}

// ----
// Specify the name of the secret.
// service and username are required.
// appName and domain are optional.
// Note: The values are arbitrary and can be anything you want.
CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"appName" value: @"MyApp"];
[json UpdateString: @"service" value: @"OAuth2"];
[json UpdateString: @"domain" value: @"onedrive"];
[json UpdateString: @"username" value: @"matt"];

// Oracle Cloud Secrets requires a lot of additional information for each API call.
// You'll need to replace the following with your values.
// Note: To learn how to find these values, go to an AI such as ChatGPT and ask (for example) "In Oracle Cloud, where do I find my master key OCID?"
[json UpdateString: @"vault_name" value: @"ocid1.vault.oc1.us-chicago-1.ijttzlz7aadxo.abxxeljt4gv6tgrar66i5ugffincjmp52oveht3y2zn74rgo6raz6h72qtia"];
[json UpdateString: @"region" value: @"us-chicago-1"];
[json UpdateString: @"tenancy_ocid" value: @"ocid1.tenancy.oc1..aaaaaaaaov6vd3xdybgvwblezx2kmgjmo3dvsuljbwpf2m27mk47kkxsa5aa"];
[json UpdateString: @"user_ocid" value: @"ocid1.user.oc1..aaaaaaaarsn42gwcl5rvahcmt5r6aheek65z54k5nbd6gtclmqn6emkqxajq"];
[json UpdateString: @"master_key_ocid" value: @"ocid1.key.oc1.us-chicago-1.ijttzlz7aadxo.abxyeljtfbqhl5h2velmojmm6ls77lskmc7ardpekjgw264my6fuyxmhm6xa"];

// Get the secret to be stored.
CkoJsonObject *jsonSecret = [[CkoJsonObject alloc] init];
success = [jsonSecret LoadFile: @"qa_data/tokens/oneDrive.json"];
if (success == NO) {
    NSLog(@"%@",jsonSecret.LastErrorText);
    return;
}

// Create or update the secret.
success = [secrets UpdateSecretJson: json secret: jsonSecret];
if (success == NO) {
    NSLog(@"%@",secrets.LastErrorText);
    return;
}

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

// Here you can see the secret that was created:

// image