Sample code for 30+ languages & platforms
Objective-C

AWS Setup Bootstrap Secret in Memory

See more Secrets Examples

Accessing a cloud-based secrets manager requires authentication credentials, which cannot be stored within the secrets manager itself.

This example shows how to set up an in-memory bootstrap secret with authentication credentials which will be used in other examples to access the AWS Secrets Manager.

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.

CkoSecrets *bootstrap = [[CkoSecrets alloc] init];

// This secret will reside in memory.
bootstrap.Location = @"memory";

// Specify the name of the bootstrap 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: @"AWS"];
[json UpdateString: @"service" value: @"Example"];
[json UpdateString: @"username" value: @"Joe"];

// The bootstrap secret for the AWS Secrets Manager will contain
// the AWS region, access key, and secret key, like this:
CkoJsonObject *jsonSecret = [[CkoJsonObject alloc] init];
// Modify if necessary to use your region..
[jsonSecret UpdateString: @"awsRegion" value: @"us-east-1"];
[jsonSecret UpdateString: @"awsAccessKey" value: @"YOUR_ACCESS_KEY"];
[jsonSecret UpdateString: @"awsSecretKey" value: @"YOUR_SECRET_KEY"];

// Create or update the bootstrap secret (in memory).
// The secret is stored encrypted in memory, and is available to be used
// regardless of the lifetime of the "bootstrap" object.
success = [bootstrap UpdateSecretJson: json secret: jsonSecret];
if (success == NO) {
    NSLog(@"%@",bootstrap.LastErrorText);
    return;
}

NSLog(@"%@",@"The AWS bootstrap secret has been stored in memory.");