Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jamshedvesuna/cronos

Python module for safely and cleanly using sensitive data in code
https://github.com/jamshedvesuna/cronos

Last synced: 3 months ago
JSON representation

Python module for safely and cleanly using sensitive data in code

Awesome Lists containing this project

README

        

cronos
======

Python module for safely and cleanly using sensitive data in shared code.

Cronos uses a secure encryption method, [AES256](http://en.wikipedia.org/wiki/Advanced_Encryption_Standard), to store passwords and sensitive values locally. Simple (and unsecure) [Caesar Ciphers](http://en.wikipedia.org/wiki/Caesar_cipher) are used to create obfuscated keys in the cronos datastore. This means keys are simply human-unreadable and values are securely encrypted with a password file (defaults to your ssh private key).

Install
-------
Supports Linux and OS X.

* Python Pip: `pip install cronos`

Usage
-----
While global keys are stored in your code (such as the plaintext `API_KEY` in the examples below), Cronos uses the single interface `get` to *initially* prompt the user for the value at runtime. Cronos stores the encrypted value in a keystore called `db.cronos`. Upon a second call to `get`, Cronos performs a lookup and decryption.

You may want to add `*.cronos` to your `.gitignore`.

Using your ssh private key (`id_rsa`) as the default encryption key:
```python
from cronos import cronos
c = cronos.Cronos()
myKey = c.get("API_KEY") # Prompt user for API_KEY if not already stored
```

Using `mypassword.txt` as the encryption key and `/tmp/db.chronos` as the db file:
```python
from cronos import cronos
c = cronos.Cronos(passFile='mypassword.txt', storeFile='/tmp/db.chronos')
myKey = c.get("API_KEY") # Prompt user for API_KEY if not already stored
```

Requirements
------------
* [getpass](https://docs.python.org/2/library/getpass.html)
* [os](https://docs.python.org/2/library/os.html)
* [pickle](https://docs.python.org/2/library/pickle.htmlpassword)
* [simplecrypt](https://pypi.python.org/pypi/simple-crypt)
* [sys](https://docs.python.org/2/library/sys.html)