Skip to content

Latest commit

 

History

History
42 lines (34 loc) · 1.8 KB

README.md

File metadata and controls

42 lines (34 loc) · 1.8 KB

erasure.py

Python client for the erasure protocol

Tests

Erasure Protocol version: 1.2.0

Setup:

  1. Create & activate virtulenv (python 3.6+)
  2. Install the library using pypi. pip install erasure

Usage:

The client is built to replicate the usage here.

  1. Update the settings by configuring the appropriate enviornment variables.
  2. Initialize a client:
    erasure_client = ErasureClient(w3, mode, version)
    
  3. Create a feed:
    feed = Feed(erasure_client=erasure_client, feed_address=FEED_ADDRESS)
    
  4. Submit a post:
    receipt = feed.create_post(raw_data, key=key)
    
    Note: The encryption keys, and data for this post will be saved in ERASURE_KEY_STORE/<proof_hash>
  5. Reveal a post:
    key_cid, data_cid = post.reveal()
    

Development:

  1. Clone & enter the repo. git clone https://github.com/ankitchiplunkar/erasure.py.git
  2. Install required libraries. pip install -r requirements.txt

Testing:

  1. Launch a local version of erasure protocol via ganache
  2. Install, initlalize and run the ipfs daemon locally ipfs daemon
  3. Run the tests locally pytest -vv tests/