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
(SQL Server) Azure Key Vault - Create or Update a JSON SecretSee more Secrets ExamplesDemonstrates how to create or update a JSON 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/
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- 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 DECLARE @bootstrap int -- Use "Chilkat_9_5_0.Secrets" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Secrets', @bootstrap OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- 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. -- --------------------------------------------------------------------------------------------- EXEC sp_OASetProperty @bootstrap, 'Location', 'local_manager' -- Specify the bootstrap secret to be used. DECLARE @bsId int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @bsId OUT DECLARE @success int EXEC sp_OAMethod @bsId, 'UpdateString', @success OUT, 'appName', 'azure_bs' EXEC sp_OAMethod @bsId, 'UpdateString', @success OUT, 'service', 'Example' EXEC sp_OAMethod @bsId, 'UpdateString', @success OUT, 'username', 'Joe' -- ---------------------------------------------------- DECLARE @secrets int -- Use "Chilkat_9_5_0.Secrets" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Secrets', @secrets OUT EXEC sp_OASetProperty @secrets, 'Location', 'azure_key_vault' DECLARE @success int EXEC sp_OAMethod @secrets, 'SetBootstrapSecret', @success OUT, @bsId, @bootstrap IF @success = 0 BEGIN EXEC sp_OAGetProperty @secrets, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @bootstrap EXEC @hr = sp_OADestroy @bsId EXEC @hr = sp_OADestroy @secrets RETURN END -- ---- -- Specify the name of the secret. -- service and username are required. -- appName and domain are optional. -- Note: The values are arbitrary and can be anything you want. DECLARE @json int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'appName', 'MyApp' EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'service', 'OAuth2' EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'domain', 'onedrive' EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'username', 'matt' -- 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. EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'vaultName', 'kvChilkat' -- Get the secret to be stored. DECLARE @jsonSecret int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @jsonSecret OUT EXEC sp_OAMethod @jsonSecret, 'LoadFile', @success OUT, 'qa_data/tokens/oneDrive.json' IF @success = 0 BEGIN EXEC sp_OAGetProperty @jsonSecret, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @bootstrap EXEC @hr = sp_OADestroy @bsId EXEC @hr = sp_OADestroy @secrets EXEC @hr = sp_OADestroy @json EXEC @hr = sp_OADestroy @jsonSecret RETURN END -- Create or update the secret. EXEC sp_OAMethod @secrets, 'UpdateSecretJson', @success OUT, @json, @jsonSecret IF @success = 0 BEGIN EXEC sp_OAGetProperty @secrets, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @bootstrap EXEC @hr = sp_OADestroy @bsId EXEC @hr = sp_OADestroy @secrets EXEC @hr = sp_OADestroy @json EXEC @hr = sp_OADestroy @jsonSecret RETURN END PRINT 'Success.' -- Here you can see the secret that was created: -- EXEC @hr = sp_OADestroy @bootstrap EXEC @hr = sp_OADestroy @bsId EXEC @hr = sp_OADestroy @secrets EXEC @hr = sp_OADestroy @json EXEC @hr = sp_OADestroy @jsonSecret END GO |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.