Skip to content

Latest commit

 

History

History
44 lines (30 loc) · 2.84 KB

README.md

File metadata and controls

44 lines (30 loc) · 2.84 KB

Python script for encrypting secret credentials for version control

This is a simple python script that can be used to encrypt/decrypt secret credentials (API secret keys, HTTP passwords, etc.) using a password to be able to safely put them under version control. It doesn't have any dependancies beyond python standard library.

Why should you use this?

Well, How should I put this? It is more probable that you shouldn't.

It is very likely that other git encryption methods like git-crypt are better for you, I wrote this because I wanted a solution that works well on any platform (Specifically Windows) without having to download cumbersome build tools or going into a dependancy hell. Anyway, feel free to give it a spin.

File structure

This utility will only act on files of the following extension in the same directory

  • *.secret

These are absolutely secret and must not be committed to VCS. They are committed as encrypted files named “*.secret.enc”

  • *.public

These are the public config files, they should be committed to the VCS

  • *.local

These are local override config files, any variable in these files will override values in the other two, they shouldn’t be committed.

How to use

To use this demo

  1. Clone this repo git clone https://github.com/drdrsh/vc-crypt.git
  2. Run python cred.py decrypt and use password dummy_password.
  3. Run python cred.py concat to generate .env file.

To modify secret params, edit your env.secret and run python cred.py encrypt again.

To start from scratch

  1. Download cred.py and .gitignore (or add entries in this .gitignore file to yours).
  2. Create your own *.secret, *.public, *.local files.
  3. Run python cred.py encrypt to be prompted for password, alternatively you can specify the password in the command line by passing arguments --password your_password but this will cause the password to appear in shell history.
  4. Commit your work.
  • To generate .env file run python cred.py concat
  • To decrypt encrypted credentials run python cred.py decrypt and you will be prompted to enter the password, alternatively you can specify the password in the command line by passing arguments --password your_password but this will cause the password to appear in shell history.

Word of caution

This tool attempts to replicate some functionality offered by tools like git-crypt or blackbox with as little dependnacies as possible, it doesn't address the problem of configuration being in plain text on the server or in-memory and as far as I know, these problems are not addressed by git-crypt or blackbox either. If this is a concern to you, look into more secure solution.

License

MIT