2018-02-16 20:47:38 +00:00
|
|
|
.. role:: bash(code)
|
|
|
|
:language: bash
|
|
|
|
|
|
|
|
|
2018-02-16 19:27:36 +00:00
|
|
|
pyUmbral
|
|
|
|
========
|
2018-02-16 20:47:38 +00:00
|
|
|
|
2018-02-16 19:31:41 +00:00
|
|
|
.. image:: https://travis-ci.org/nucypher/pyUmbral.svg?branch=master
|
|
|
|
:target: https://travis-ci.org/nucypher/pyUmbral
|
2018-02-16 19:27:36 +00:00
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
pyUmbral is a 100% python implementation of Umbral using OpenSSL and Cryptography.io,
|
|
|
|
enabling users to perform public key encryption and split key proxy-rencryption
|
|
|
|
in a straightforward and usable manner.
|
2018-02-16 19:27:36 +00:00
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
**Alice encrypts data for herself**
|
2018-02-16 19:27:36 +00:00
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
.. code-block:: python
|
2018-02-16 19:27:36 +00:00
|
|
|
|
|
|
|
from umbral import umbral, keys
|
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
# Generate a key pair for Alice
|
|
|
|
alices_private_key = keys.UmbralPrivateKey.gen_key()
|
|
|
|
alices_public_key = private_key.get_pubkey()
|
2018-02-16 19:27:36 +00:00
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
# Encrypt data with bob's public key
|
2018-02-16 19:27:36 +00:00
|
|
|
plaintext = b'Proxy Re-encryption is cool!'
|
2018-02-16 20:47:38 +00:00
|
|
|
ciphertext, capsule = umbral.encrypt(alices_public_key, plaintext)
|
|
|
|
|
|
|
|
# Decrypt data with Bob's keys
|
|
|
|
cleartext = umbral.decrypt(capsule, alices_private_key, ciphertext, alices_public_key)
|
|
|
|
|
|
|
|
**Ursula Re-encrypts for Bob**
|
|
|
|
|
|
|
|
.. code-block:: python
|
2018-02-16 19:27:36 +00:00
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
# Generate a key pair for Bob
|
|
|
|
bobs_private_key = keys.UmbralPrivateKey.gen_key()
|
|
|
|
bobs_public_key = private_key.get_pubkey()
|
|
|
|
|
|
|
|
# Bob receives the capsule through a side channel (S3, ipfs, Google Cloud, etc.)
|
|
|
|
capsule = capsule
|
|
|
|
|
|
|
|
# Generate split re-encryption keys with "M of N"
|
|
|
|
# Minimum threshold of 10 ("M") - and 20 total shares ("N").
|
|
|
|
kfrags, _ = umbral.split_rekey(alices_private_key, bobs_public_key, 10, 20)
|
|
|
|
|
|
|
|
# Ursula re-encrypts the shares and bob attaches them to the capsule
|
|
|
|
for kfrag in kfrags:
|
|
|
|
cfrag = umbral.reencrypt(kfrag, umbral_capsule)
|
|
|
|
bob_capsule.attach_cfrag(cfrag)
|
|
|
|
|
|
|
|
# Bob opens the capsule and decrypts the re-encrypted ciphertext
|
|
|
|
plaintext = umbral.decrypt(capsule, bobs_private_key, ciphertext, alices_public_key)
|
2018-02-16 19:27:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
Features
|
|
|
|
--------
|
2018-02-16 20:47:38 +00:00
|
|
|
- Proxy re-encryption
|
2018-02-16 19:27:36 +00:00
|
|
|
- Asymmetric key pair generation
|
2018-02-16 20:47:38 +00:00
|
|
|
- Public key encryption
|
|
|
|
- Key Encapsulation
|
2018-02-16 19:27:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
Installation
|
|
|
|
------------
|
|
|
|
|
|
|
|
The NuCypher team uses pipenv for managing pyUmbral's dependencies.
|
2018-02-16 20:47:38 +00:00
|
|
|
The recommended installation procedure is as follows...
|
|
|
|
|
|
|
|
.. code-block:: bash
|
2018-02-16 19:27:36 +00:00
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
$ sudo pip3 install pipenv
|
|
|
|
$ pipenv install
|
2018-02-16 19:27:36 +00:00
|
|
|
|
|
|
|
Post-installation, you can activate the project virtual enviorment
|
2018-02-16 20:47:38 +00:00
|
|
|
in your current terminal session by running :bash:`pipenv shell`.
|
2018-02-16 19:27:36 +00:00
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
For more information on pipenv, find the official documentation here: `https://docs.pipenv.org/`_.
|
2018-02-16 19:27:36 +00:00
|
|
|
|
|
|
|
Support & Contribute
|
2018-02-16 20:47:38 +00:00
|
|
|
---------------------
|
2018-02-16 19:27:36 +00:00
|
|
|
|
2018-02-16 20:47:38 +00:00
|
|
|
- Issue Tracker: `github.com/nucypher/pyUmbral/issues`_
|
|
|
|
- Source Code: `github.com/nucypher/pyUmbral`_
|