EnvCloak was originally built to secure .env files, but it can encrypt and decrypt any file type.
Use it for .json, .yaml, .txt, binary files, or any sensitive data.
The name may be misleading, but the tool is far more versatile than it suggests!
"Because Your Secrets Deserve Better Than Plaintext!"
Welcome to EnvCloak, the ultimate sidekick for developers, ops folks, and anyone whoโs ever accidentally committed an API key to version control. (Yes, I knowโฆ it happens to the best of us. ๐ ) EnvCloak takes the stress out of managing environment variables by wrapping them in the cozy blanket of encryption, so you can focus on building awesome thingsโwithout the lingering fear of a security breach.
If you find EnvCloak useful, please โญ the repository. It helps others discover this project! - thank you!
In order to install envcloak
simply run:
pip install envcloak
or if you want dev
tools too ๐:
pip install envcloak[dev]
๐ There are also self-contained binaries for
Windows
,Linux
andMacOS
, don't have to use python at all! ๐ฅณ
โน๏ธ More examples are present in examples section.
# With password and salt
envcloak generate-key-from-password --password "YourTopSecretPassword" \
--salt "e3a1c8b0d4f6e2c7a5b9d6f0cr2ad1a2" --output secretkey.key
# With password without salt (we will add random salt then)
envcloak generate-key-from-password --password "YourTopSecretPassword" --output secretkey.key
# From random password and salt
envcloak generate-key --output secretkey.key
What it does: generates your private key used to encrypt and decrypt files. Appends (or creates if needed) .gitignore as well as super-hero should! ๐
โ If someone knows your password and salt (option 1) can recreate same
key
- keep those variables safe askey
itself โ
โ ๏ธ This tool allows to encrypt more.env
is just an example! ๐
envcloak encrypt --input .env --output .env.enc --key-file mykey.key
What it does: Encrypts your
.env
file with a specified key, outputting a sparkling.env.enc
file.
envcloak decrypt --input .env.enc --output .env --key-file mykey.key
What it does: Decrypts the
.env.enc
file back to.env
using the same key. Voilร !
or you may want to use it ...
from envcloak import load_encrypted_env
load_encrypted_env('.env.enc', key_file='mykey.key').to_os_env()
# Now os.environ contains the decrypted variables
What it does: Loads decrypted variables directly into
os.environ
. Secrets delivered, stress-free.
๐ Encryption Algorithm
- Powered by AES-256-GCM for speed and security.
- Provides
sha3
validation of files and content.
๐๏ธ Key Storage
- Local key files with strict permissions.
- Secure environment variables for CI/CD systems.
๐๏ธ File Handling
- Works with individual files.
- Works with directories using
--directory
instead of--input
onencrypt
anddecrypt
.
โน๏ธ EnvCloak process files in batch one-by-one.
- Can recursively encrypt or decrypt directories.
- Can list files in directory that will be encrypted using
--preview
flag (โน๏ธ only for directories and it does not commit the operation!).
๐ฆ Error Handling
- Clear, friendly error messages for any hiccups.
- Gracefully handles missing keys or corrupted files.
โ Compatibility of pipelines and systems
- k8s / OKD / OCP deployments
- Jenkins pipelines
- Azure Pipelines
- Github Workflows
- Gitlab CI/CD Pipelines
Because you deserve peace of mind. EnvCloak wraps your environment variables in layers of encryption goodness, protecting them from prying eyes and accidental slips. Whether youโre a solo dev or part of a big team, this tool is here to make managing secrets simple, secure, and downright pleasant.
So go aheadโsecure your .env
like a boss. And remember, EnvCloak isnโt just a tool; itโs your secret-keeping partner in crime. (But the good kind of crime. ๐)
Tool | Strengths | Weaknesses |
---|---|---|
EnvCloak | Lightweight, Python-native, simple to integrate with CI/CD workflows. | Limited ecosystem compared to established tools. |
Sops | Integrates with cloud providers, supports partial file encryption. | More complex to configure for beginners. |
BlackBox | Simple file-based encryption for Git repos. | Limited to GPG, lacks flexibility. |
Vault | Robust, enterprise-grade with dynamic secrets. | High complexity, overkill for small projects. |
Confidant | AWS IAM integration, designed for secure CI/CD workflows. | Requires AWS, limited to its ecosystem. |
Doppler | Centralized secret management with CI/CD integration. | Paid plans for advanced features, cloud-reliant. |
Key Differentiator for EnvCloak: Focused specifically on Python developers and lightweight CI/CD needs, making it ideal for small to medium projects.
Weโd love to hear your thoughts about EnvCloak! Open an issue or join the conversation in Discussions.
A huge thanks to all our amazing contributors! ๐
Donโt let your API keys end up in the wrong hands (or on Twitter). Grab EnvCloak now and start encrypting like a pro.
Happy env
(an many other file types) Cloaking! ๐ต๏ธโโ๏ธ