Securing API Keys for AI Service Integrations using Azure Key Vault
PythonSecuring API keys and other secrets is important for maintaining the security and integrity of your application, especially when integrating AI services that often require sensitive access credentials. Azure Key Vault is a cloud service that provides a secure store for secrets, keys, and certificates. By storing sensitive information in the Key Vault, you can manage and control access to these assets securely.
Here's how you can use Pulumi with Azure to create a Key Vault and store an API key:
-
Create an Azure Key Vault: We will create an Azure Key Vault where we'll store the API key securely. The Key Vault will be created within a specific resource group, which we also define. The resource group serves as a logical container for related resources.
-
Add a Secret to the Key Vault: After creating the Key Vault, we will add a secret to it. This secret represents the API key we want to secure.
-
Set Access Policies: We may want to define who can access this Key Vault and what permissions they have. This is done using access policies.
Let's start with the Pulumi program in Python that executes the above steps:
import pulumi from pulumi_azure_native import keyvault, resources # Replace "resource_group_name" and "key_vault_name" with your desired names. resource_group_name = "my-resource-group" key_vault_name = "my-key-vault" # Create an Azure Resource Group resource_group = resources.ResourceGroup(resource_group_name) # Create an Azure Key Vault key_vault = keyvault.Vault( key_vault_name, resource_group_name=resource_group.name, properties=keyvault.VaultPropertiesArgs( sku=keyvault.SkuArgs(name=keyvault.SkuName.STANDARD), tenant_id="your-azure-tenant-id", # Replace with your Azure tenant ID. access_policies=[] # You can define access policies here. ), location="East US" # Choose the location appropriate for you. ) # Add a secret to the Key Vault api_key_secret = keyvault.Secret( "MyAPIKeySecret", properties=keyvault.SecretPropertiesArgs( value="your-api-key-here" # Replace with the API key you want to store securely. ), secret_name="myApiKey", vault_name=key_vault.name, resource_group_name=resource_group.name ) # Export the Key Vault ID and Secret ID pulumi.export("key_vault_id", key_vault.id) pulumi.export("api_key_secret_id", api_key_secret.id)
This program will create an Azure Key Vault, a secure secret (your API key), and set the appropriate properties for each. Remember to replace
your-azure-tenant-id
andyour-api-key-here
with your actual Azure tenant ID and the API key value you wish to secure.The
access_policies
array is empty in this example, but you can add one or moreAccessPolicyEntryArgs
to define who can access the Key Vault and what operations they can perform with it. Properly managing access policies ensures that only authorized applications or users can retrieve the secrets.The
keyvault.Secret
resource is where you store your actual secret value, treated here asyour-api-key-here
. In a production environment, instead of hardcoding the secret in your code, it would be safer to use Pulumi's configuration system or environment variables to keep it out of source control.Lastly, we export the Key Vault's ID and the Secret's ID so you can easily reference them in other parts of your Pulumi application or for use in other applications that may need to access this secret programmatically.
-