Skip to main content

Azure Key Vault source for essentials-configuration.

Project description

Build pypi versions codecov license

essentials-configuration-keyvault

Azure Key Vault source for essentials-configuration.

pip install essentials-configuration-keyvault

essentials-configuration provides a way to handle configuration roots composed of different layers, such as configuration files and environmental variables. Layers are applied in order and can override each others' values, enabling different scenarios like configuration by environment (e.g. DEV, TEST, PROD) and system instance.

essentials-configuration-keyvault provides a solution to add secrets stored in Azure Key Vault into configuration objects.

Example:

from azure.identity import DefaultAzureCredential
from azure.keyvault.secrets import SecretClient
from config.common import ConfigurationBuilder
from config.keyvault import KeyVaultSource

key_vault_name = "example-keyvault-name"

secrets_client = SecretClient(
    vault_url=f"https://{key_vault_name}.vault.azure.net",
    credential=DefaultAzureCredential(),
)

builder = ConfigurationBuilder(KeyVaultSource(secrets_client))

# when the configuration object is built, secrets are fetched from
# the linked key vault and put into the configuration object (e.g.
# database connection strings, API keys for SendGrid, etc.)
config = builder.build()

Refer to the official Key Vault documentation for more information about its Python client library..

How to run the tests using a real Key Vault

The provided tests can either use a mocked SecretClient, or use a real Key Vault. To use a real Key Vault service:

  1. create a Key Vault (ref.)
  2. sign-in using any way supported by azure.identity.DefaultAzureCredential 3 (e.g. VS Code or az login)
  3. run the tests with the following command:
KEYVAULT_NAME="<YOUR_KEYVAULT_NAME>" pytest -s

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

File details

Details for the file essentials_configuration_keyvault-1.0.1.tar.gz.

File metadata

File hashes

Hashes for essentials_configuration_keyvault-1.0.1.tar.gz
Algorithm Hash digest
SHA256 e7d06539ab5d070afca21cd42a7b13ea525a899f1ca189cf516d6826b5f504c9
MD5 05ad87e2268ce9400f92f7e4a5704f82
BLAKE2b-256 13a1c2d8f12a3013453f1c9c8be9de52cd0656858f6f119b72f0dc74ba504cc0

See more details on using hashes here.

File details

Details for the file essentials_configuration_keyvault-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for essentials_configuration_keyvault-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6e355b324d80a20d46cd165b4e31a1f14513e529217cd8d2516459bef736a1c9
MD5 c07cf40630542a629603d206c9729cb6
BLAKE2b-256 3c91bfdc5a952ab7731afa0876f7932ed0588a13f4c19680fe292d8a02f069c3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page