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) Azure Key Vault - Create or Update a Binary SecretSee more Secrets ExamplesDemonstrates how to create or update a binary secret stored in the Azure Key Vault. 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> #include <C_CkHttp.h> #include <C_CkBinData.h> void ChilkatSample(void) { HCkSecrets bootstrap; HCkJsonObject bsId; HCkSecrets secrets; BOOL success; HCkJsonObject json; const char *url; HCkHttp http; HCkBinData bd; // 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: // Azure Tenant ID // Azure Client ID // Azure Client Secret // 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 bootstrap = CkSecrets_Create(); // 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. // --------------------------------------------------------------------------------------------- CkSecrets_putLocation(bootstrap,"local_manager"); // Specify the bootstrap secret to be used. bsId = CkJsonObject_Create(); CkJsonObject_UpdateString(bsId,"appName","azure_bs"); CkJsonObject_UpdateString(bsId,"service","Example"); CkJsonObject_UpdateString(bsId,"username","Joe"); // ---------------------------------------------------- secrets = CkSecrets_Create(); CkSecrets_putLocation(secrets,"azure_key_vault"); success = CkSecrets_SetBootstrapSecret(secrets,bsId,bootstrap); if (success == FALSE) { printf("%s\n",CkSecrets_lastErrorText(secrets)); CkSecrets_Dispose(bootstrap); CkJsonObject_Dispose(bsId); CkSecrets_Dispose(secrets); return; } // Specify the name of the secret to be created or updated. // service and username are required. // appName and domain are optional. // Note: The values are arbitrary and can be anything you want. json = CkJsonObject_Create(); CkJsonObject_UpdateString(json,"appName","Test2"); CkJsonObject_UpdateString(json,"service","Custom"); CkJsonObject_UpdateString(json,"domain","Ocean"); CkJsonObject_UpdateString(json,"username","Starfish"); // For Azure Key Vault, we also need to specify the name of the vault where the secret is to be stored. // Replace "kvChilkat" with the name of your key vault. CkJsonObject_UpdateString(json,"vaultName","kvChilkat"); // The purpose of this example is to show how arbitrary binary data // can be stored as a secret. // We'll use a small JPG image that is approximately 6KB in size. // You can test using this same JPG at this URL: url = "https://chilkatdownload.com/sample_data/starfish.jpg"; http = CkHttp_Create(); bd = CkBinData_Create(); success = CkHttp_DownloadBd(http,url,bd); if (success == FALSE) { printf("%s\n",CkHttp_lastErrorText(http)); CkSecrets_Dispose(bootstrap); CkJsonObject_Dispose(bsId); CkSecrets_Dispose(secrets); CkJsonObject_Dispose(json); CkHttp_Dispose(http); CkBinData_Dispose(bd); return; } // Create or update the binary secret. success = CkSecrets_UpdateSecretBd(secrets,json,bd); if (success == FALSE) { printf("%s\n",CkSecrets_lastErrorText(secrets)); CkSecrets_Dispose(bootstrap); CkJsonObject_Dispose(bsId); CkSecrets_Dispose(secrets); CkJsonObject_Dispose(json); CkHttp_Dispose(http); CkBinData_Dispose(bd); return; } printf("Success.\n"); // Here you can see the secret that was created in the Azure Key Vault: // CkSecrets_Dispose(bootstrap); CkJsonObject_Dispose(bsId); CkSecrets_Dispose(secrets); CkJsonObject_Dispose(json); CkHttp_Dispose(http); CkBinData_Dispose(bd); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.