Unicode C
Unicode C
Windows Credentials Manager / Apple Keychain - List Matching Secrets
See more Secrets Examples
List secrets matching one or more wildcarded names for app, service, domain, and username.Note: This example requires Chilkat v10.1.0 or later.
Chilkat Unicode C Downloads
#include <C_CkSecretsW.h>
#include <C_CkJsonObjectW.h>
void ChilkatSample(void)
{
BOOL success;
HCkSecretsW secrets;
HCkJsonObjectW jsonMatch;
HCkJsonObjectW results;
const wchar_t *appName;
const wchar_t *service;
const wchar_t *domain;
const wchar_t *username;
const wchar_t *targetName;
const wchar_t *keyChainService;
const wchar_t *keyChainAccount;
int i;
int count_i;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
secrets = CkSecretsW_Create();
// On Windows, this is the Windows Credentials Manager
// On MacOS/iOS, it is the Apple Keychain
CkSecretsW_putLocation(secrets,L"local_manager");
// 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.
jsonMatch = CkJsonObjectW_Create();
CkJsonObjectW_UpdateString(jsonMatch,L"appName",L"Test*");
CkJsonObjectW_UpdateString(jsonMatch,L"service",L"*");
CkJsonObjectW_UpdateString(jsonMatch,L"domain",L"*");
CkJsonObjectW_UpdateString(jsonMatch,L"username",L"Starfish*");
results = CkJsonObjectW_Create();
CkJsonObjectW_putEmitCompact(results,FALSE);
success = CkSecretsW_ListSecrets(secrets,jsonMatch,results);
if (success == FALSE) {
wprintf(L"%s\n",CkSecretsW_lastErrorText(secrets));
CkSecretsW_Dispose(secrets);
CkJsonObjectW_Dispose(jsonMatch);
CkJsonObjectW_Dispose(results);
return;
}
wprintf(L"%s\n",CkJsonObjectW_emit(results));
// Sample output on Windows.
// The "targetName" is purely informational and indicates the raw TargetName of the secret (i.e. Credential) stored in the Credentials Manager.
// {
// "secrets": [
// {
// "appName": "Test2",
// "service": "Custom",
// "domain": "Ocean",
// "username": "Starfish20",
// "targetName": "Test2/Custom/Ocean/Starfish20"
// },
// {
// "appName": "Test2",
// "service": "Custom",
// "domain": "Ocean",
// "username": "Starfish",
// "targetName": "Test2/Custom/Ocean/Starfish"
// }
// ]
// }
// ---------------------------------------------------------------------------------------
// Here's sample code for parsing the JSON list of secrets.
i = 0;
count_i = CkJsonObjectW_SizeOfArray(results,L"secrets");
while (i < count_i) {
CkJsonObjectW_putI(results,i);
appName = CkJsonObjectW_stringOf(results,L"secrets[i].appName");
service = CkJsonObjectW_stringOf(results,L"secrets[i].service");
domain = CkJsonObjectW_stringOf(results,L"secrets[i].domain");
username = CkJsonObjectW_stringOf(results,L"secrets[i].username");
// Information field for Windows Credentials Manager.
targetName = CkJsonObjectW_stringOf(results,L"secrets[i].targetName");
// Informational fields if on MacOS using the Apple Keychain.
keyChainService = CkJsonObjectW_stringOf(results,L"secrets[i].keyChainService");
keyChainAccount = CkJsonObjectW_stringOf(results,L"secrets[i].keyChainAccount");
i = i + 1;
}
CkSecretsW_Dispose(secrets);
CkJsonObjectW_Dispose(jsonMatch);
CkJsonObjectW_Dispose(results);
}