Skip to main content

Secure vault files that are easy to use

Project description

Version on Pypi Actions status Docs build status (master) Test coverage (master)

Overview

The easy-vault Python package provides commands for encrypting and decrypting vault files that can be in any format. It provides for programmatic access to encrypted vault files from Python programs, so that the file itself can stay encrypted in the file system but can still be used by the program in clear text.

At first use on a particular vault file, the encryption command prompts for a vault password and stores that in the keyring service of your local system using the keyring package. Subsequent encryption and decryption of the vault file will then use the password from the keyring, avoiding any further password prompts. Programmatic access can also be done with the password from the keyring.

The encryption of the vault files is implemented using the symmetric key functionality of the cryptography package.

One use case for this package is for example the daily work with programs that need the secrets from a vault to access some server or service. For that, the program in question needs to have integrated with this package.

Another use case is testing in CI/CD systems: The encrypted vault file is stored in a repository and the password to access it is put as a secret into the CI/CD system (most CI/CD systems these days support storing secrets in a secure way). The test program uses the vault password from the CI/CD secret to get access to the vault to get to the secrets that are needed to perform the tests. One could have put the vault secrets directly into the CI/CD system, but if the vault file is also used for local work, or if the number of secrets is large or has a complex structure, it is better to have the indirection of the vault file.

The vault files stay encrypted in the file system while they are used, and are only decrypted and re-encrypted in the file system when secrets need to be updated/added/removed.

This package allows putting at rest the habit of having clear text files that contain passwords, API keys and other secrets, and allows transitioning to a secure but still easy to use approach for managing such secrets.

Why a new vault implementation: The ansible-vault command provided the functionality we needed and was originally used (except for the keyring storage which we added). However, Ansible does not support native Windows and that was a requirement. Also, the ansible-vault command requires installing the entire Ansible which is quite large. Searching Pypi for suitable vaults that a) have commands for encrypting and decrypting and b) provide programmatic access to the encrypted file, did not reveal anything suitable.

Documentation and change log

License

The easy-vault package is provided under the Apache Software License 2.0.

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

easy-vault-0.7.0.tar.gz (26.8 kB view details)

Uploaded Source

Built Distribution

easy_vault-0.7.0-py2.py3-none-any.whl (20.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file easy-vault-0.7.0.tar.gz.

File metadata

  • Download URL: easy-vault-0.7.0.tar.gz
  • Upload date:
  • Size: 26.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.7.0 requests/2.25.1 setuptools/44.1.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/2.7.16

File hashes

Hashes for easy-vault-0.7.0.tar.gz
Algorithm Hash digest
SHA256 1748b6d678d6cc57fd750165d0608761c2bf8bbf51bd4574102ad77ec0055454
MD5 83e125213a59a9d2b918db521c4fb3b0
BLAKE2b-256 7e8bbdd0da7d035473fd22eed7eaa15635d61065eb59c6b6874ac0607512314e

See more details on using hashes here.

File details

Details for the file easy_vault-0.7.0-py2.py3-none-any.whl.

File metadata

  • Download URL: easy_vault-0.7.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 20.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.7.0 requests/2.25.1 setuptools/44.1.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/2.7.16

File hashes

Hashes for easy_vault-0.7.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a7f42b208cf37f1e04f20db10ba7b70d3d7b39c4306199987bd6c4a43f1cbb8c
MD5 45dbedd20b0164c62b003e4d2079a7ad
BLAKE2b-256 6b2ff4e68307882b3a4656fd196c48c846c4d8f5d5df42f1240414c8b6e4e892

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