Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C) Windows Credentials Manager / Apple Keychain - List Matching SecretsSee more Secrets ExamplesList secrets matching one or more wildcarded names for app, service, domain, and username. Note: This example requires Chilkat v10.1.0 or later. For more information, see https://cknotes.com/chilkat-secrets-class-added-in-version-10-1-0/
#include <C_CkSecrets.h> #include <C_CkJsonObject.h> void ChilkatSample(void) { HCkSecrets secrets; HCkJsonObject jsonMatch; HCkJsonObject results; BOOL success; const char *appName; const char *service; const char *domain; const char *username; const char *targetName; const char *keyChainService; const char *keyChainAccount; int i; int count_i; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. secrets = CkSecrets_Create(); // On Windows, this is the Windows Credentials Manager // On MacOS/iOS, it is the Apple Keychain CkSecrets_putLocation(secrets,"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 = CkJsonObject_Create(); CkJsonObject_UpdateString(jsonMatch,"appName","Test*"); CkJsonObject_UpdateString(jsonMatch,"service","*"); CkJsonObject_UpdateString(jsonMatch,"domain","*"); CkJsonObject_UpdateString(jsonMatch,"username","Starfish*"); results = CkJsonObject_Create(); CkJsonObject_putEmitCompact(results,FALSE); success = CkSecrets_ListSecrets(secrets,jsonMatch,results); if (success == FALSE) { printf("%s\n",CkSecrets_lastErrorText(secrets)); CkSecrets_Dispose(secrets); CkJsonObject_Dispose(jsonMatch); CkJsonObject_Dispose(results); return; } printf("%s\n",CkJsonObject_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 = CkJsonObject_SizeOfArray(results,"secrets"); while (i < count_i) { CkJsonObject_putI(results,i); appName = CkJsonObject_stringOf(results,"secrets[i].appName"); service = CkJsonObject_stringOf(results,"secrets[i].service"); domain = CkJsonObject_stringOf(results,"secrets[i].domain"); username = CkJsonObject_stringOf(results,"secrets[i].username"); // Information field for Windows Credentials Manager. targetName = CkJsonObject_stringOf(results,"secrets[i].targetName"); // Informational fields if on MacOS using the Apple Keychain. keyChainService = CkJsonObject_stringOf(results,"secrets[i].keyChainService"); keyChainAccount = CkJsonObject_stringOf(results,"secrets[i].keyChainAccount"); i = i + 1; } CkSecrets_Dispose(secrets); CkJsonObject_Dispose(jsonMatch); CkJsonObject_Dispose(results); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.