Skip to main content

Scan, encrypt, and manage secrets in your project with key file or passphrase-based encryption.

Project description

envveil

envveil is a Python library and CLI tool for scanning, encrypting, and managing sensitive secrets (like API keys, tokens, and passwords) in your project. It helps you keep secrets out of your codebase, supports both key file and passphrase-based encryption, and provides audit logging and .gitignore management for maximum security.


Author


Features

  • Scan for sensitive keys in .env, settings.py, JSON, and other files
  • Encrypt secrets using either a key file or a user-supplied passphrase (no key file needed)
  • Decrypt secrets easily for local use
  • Rotate encryption keys or passphrases and re-encrypt secrets
  • Retrofit protection for already-pushed repositories
  • Audit logging for all secret access and key rotation events
  • Automatic .gitignore management and warnings for unsafe key handling
  • Language-specific .gitignore template fetcher

Installation

From PyPI

pip install envveil

From Source

pip install -r requirements.txt
# (Clone or copy envveil into your project directory)

Usage Summary Table

Step Command Example What Happens
Scan scan --env .env Finds secrets in file
Encrypt encrypt --env .env --passphrase "your_passphrase" Encrypts secrets with passphrase, stores salt+data
Decrypt decrypt --passphrase "your_passphrase" Decrypts and prints secrets
Rotate Key rotate-key --old-passphrase "old" --new-passphrase "new" Changes passphrase, re-encrypts secrets
Audit Log (automatic) Logs all decrypt/rotate events
.gitignore (automatic) Ensures secret files are ignored by git

Security Notes

  • Passphrase mode: No key file is stored. The passphrase is never saved; if you forget it, secrets are unrecoverable.
  • Key file mode: Always ensure .envveil.key is in your .gitignore. envveil will warn you if not.
  • Audit log: All decryption and key rotation events are logged in envveil_audit.log.
  • .env.encrypted and key files are always added to .gitignore automatically.

License

MIT License


Disclaimer

envveil is a developer tool for secret management and does not guarantee absolute security. Always follow best practices for secret storage and access control in production environments.

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

envveil-0.1.0.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

envveil-0.1.0-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file envveil-0.1.0.tar.gz.

File metadata

  • Download URL: envveil-0.1.0.tar.gz
  • Upload date:
  • Size: 6.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for envveil-0.1.0.tar.gz
Algorithm Hash digest
SHA256 53339803eb3b67ca87ff30b295ec51760ac5ab909c7805aad24db40c25161944
MD5 202ec2823237f5aeb60cc22f30ccdf83
BLAKE2b-256 dc698e91ad65eb99315cd9114cb3ea8facce5f6bb2e7c4bbc167a4f294234110

See more details on using hashes here.

File details

Details for the file envveil-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: envveil-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for envveil-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b9df7dba6b90df7adb73e042a5b580a4cc461d9645e2ff88e0b15f604c10614b
MD5 efac633f6a800a939160e0f618904c98
BLAKE2b-256 15815c30dab5b07617c2deff7f3d0903bde7793bfdc97142ca94c00bf9a509e9

See more details on using hashes here.

Supported by

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