Skip to content

nagyesta/lowkey-vault-example-python

Repository files navigation

LowkeyVault

GitHub license Python package Lowkey secure

Lowkey Vault - Example Python

This is an example for Lowkey Vault. It demonstrates a basic scenario where a key is used for encrypt/decrypt operations and database connection specific credentials as well as getting a PKCS12 store with a certificate and matching private key inside.

Points of interest

Usage

  1. Start Lowkey Vault and Assumed Identity
    1. Either by following the steps here and here.
    2. Or running docker-compose up -d
  2. Set REQUESTS_CA_BUNDLE environment variable to reference lowkeyvault.pem
  3. If you are not using the default 169.254.169.254:80 address for Assumed Identity (because for example you are running it in the cloud)
    1. Set AZURE_POD_IDENTITY_AUTHORITY_HOST environment variable to point to the Assumed Identity base URL e.g., http://localhost:8080
    2. Set IMDS_ENDPOINT environment variable to point to the Assumed Identity base URL e.g., http://localhost:8080
    3. Set IDENTITY_ENDPOINT environment variable to point to the /metadata/identity/oauth2/token path of Assumed Identity e.g., http://localhost:8080/metadata/identity/oauth2/token
    4. Create an empty file named /var/opt/azcmagent/tokens/assumed-identity.key to let the client think that you are using Azure Arc for Managed Identity
  4. Run the tests

Note

In order to better understand what is needed in general to make similar examples work, please find a generic overview here.

Tip

Since v2.4.2, Lowkey Vault is providing the same token endpoint on the 8080 port by default. Therefore, you don't need to start another container.

Note

To be able to use Azure Identity 1.18.0+ you must use Lowkey Vault 2.5.0+ as earlier versions don't provide the necessary headers in the token response.

About

POC example for using Lowkey Vault in your Python project.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages