Sample code for 30+ languages & platforms
Objective-C

Doppler Secrets - List Matching Secrets

See more Secrets Examples

List secrets in the Doppler Secrets matching one or more wildcarded names for app, service, domain, and username.

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

Chilkat Objective-C Downloads

Objective-C
#import <CkoSecrets.h>
#import <CkoJsonObject.h>
#import <NSString.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:

// Doppler Token

// 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: @"doppler_bs"];
[bsId UpdateString: @"service" value: @"Example"];
[bsId UpdateString: @"username" value: @"Joe"];

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

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

// Set wildcarded or exact values for appName, service, domain, and username.
// Omit any members where anything is allowed to match, or alternatively specify "*" to match anything.
CkoJsonObject *jsonMatch = [[CkoJsonObject alloc] init];
[jsonMatch UpdateString: @"appName" value: @"Test*"];
// The following lines can be omitted. Not specifying anything for service, domain, or username is the same as "*".
[jsonMatch UpdateString: @"service" value: @"*"];
[jsonMatch UpdateString: @"domain" value: @"*"];
[jsonMatch UpdateString: @"username" value: @"*"];

// You'll also need to specify your Doppler project and config names for each API call.
[jsonMatch UpdateString: @"project_name" value: @"example-project"];
[jsonMatch UpdateString: @"config_name" value: @"dev"];

CkoJsonObject *results = [[CkoJsonObject alloc] init];
results.EmitCompact = NO;

success = [secrets ListSecrets: jsonMatch jsonOut: results];
if (success == NO) {
    NSLog(@"%@",secrets.LastErrorText);
    return;
}

NSLog(@"%@",[results Emit]);

// Sample output:

// {
//   "secrets": [
//     {
//       "appName": "TEST",
//       "service": "SOMETHING",
//       "domain": "XYZ",
//       "username": "ABC",
//       "dopplerName": "TEST_SOMETHING_XYZ_ABC"
//     },
//     {
//       "appName": "TEST2",
//       "service": "CUSTOM",
//       "domain": "OCEAN",
//       "username": "STARFISH",
//       "dopplerName": "TEST2_CUSTOM_OCEAN_STARFISH"
//     }
//   ]
// }

// ---------------------------------------------------------------------------------------
// Here's sample code for parsing the JSON list of secrets.

NSString *appName = 0;
NSString *service = 0;
NSString *domain = 0;
NSString *username = 0;
NSString *dopplerName = 0;

int i = 0;
int numSecrets = [[results SizeOfArray: @"secrets"] intValue];
while (i < numSecrets) {
    results.I = [NSNumber numberWithInt: i];
    // Note: appName and domain are optional and may not exist in any given secret.
    appName = [results StringOf: @"secrets[i].appName"];
    service = [results StringOf: @"secrets[i].service"];
    domain = [results StringOf: @"secrets[i].domain"];
    username = [results StringOf: @"secrets[i].username"];
    // Information field for the raw Doppler secret name.
    dopplerName = [results StringOf: @"secrets[i].dopplerName"];
    i = i + 1;
}