Parcel is a decentralized crypto payroll service with built-in end-to-end data encryption using Filecoin, IPFS, Textile’s Powergate and Sablier for money streaming.
This project enable organisations to run crypto payroll seamlessly using mass payouts for multiple tokens and money streaming in one single transaction with the help of transactions batching.
It also ensures end to end encryption for organisation data on IPFS and Filecoin and the encryption key is calculated deterministically though signatures using ethereum private key.
Moreover, Parcel is built to empower people to receive payments in real time and employers to run payroll and manage organisation documents without any hassle.
Components
The idea of mass payouts is inspired from the initial version of Parcel which was built at Hack Money Hackathon. However, the code for the mass payouts in this version is different from what is being used in initial version.
Repo Link :- https://github.com/ParcelHQ/parcel-contracts/tree/massPayouts Hack Money Project Link :- https://hack.ethglobal.co/showcase/parcel-recUVCg0viNysWQAs
Parcel UI : It contains the code for user interface for the application built with Reactjs. Repo Link : https://github.com/ParcelHQ/parcel-ui
Parcel SDK : It includes all the methods to interact with IPFS gateway via end to end encryption and this component is being used on the client side with Parcel UI. Repo Link : https://github.com/ParcelHQ/parcel-sdk
Parcel Filecoin Archiving: It includes the code for getting the ipfs hashes from smart contracts and fetch the data from IPFS and archive it on Filecoin using Textile's Powergate. The main purpose of this component is to make sure data is persisted on Filecoin. In case of unavailability of data on IPFS, it can retrieve the data from filecoin and push it back to IPFS .
We have also tested the archiving with filecoin testnet hosted nodes by Textile team.
Repo Link : https://github.com/ParcelHQ/parcel-filecoin-archiving
Steps to run the mass payroll and streaming in live demo. 1.Create an organisation with the name 2. Go to Payroll section and add departments. 3. Go to People section and multiple employees and put the salary and currency you want them to get paid. 4. Select people checkbox and press Pay or Stream.
To see your live streams and balances make sure you add the correct dai and usdc addresses in metamask.
Usdc : 0x472d88e5246d9bF2AB925615fc580336430679Ae Dai : 0xc3dbf84Abb494ce5199D5d4D815b10EC29529ff8
Technology Stack includes
Sablier Protocol for money streaming.
Uniswap for token swapping
IPFS for encrypted data storage.
Fleek for website hosting.
Textile's Powegate for encrypted data archiving on Filecoin.
Ethereum signature for generating encryption keys deterministically.
Metamask for wallet management.
Let's understand the workflow for adding, getting and updating user's data and documents on IPFS and Smart contracts.
Adding Data:-
Generate encryption keys by signing a deterministic string using Ethereum private keys and then hash it with the hashing algorithm.
Encrypt data with the generated key.
Calculate the master hash from IPFS for the particular section e.g "Documents" in an organisation and attach encrypted data to this master hash and then store it in a smart contract by doing a transaction and map it to index.
Getting data:
Generate encryption keys by signing a deterministic string using Ethereum private keys and then hash it with the hashing algorithm.
Fetch the IPFS hashes from the smart contract.
Get the encrypted data from the IPFS.
Decryption the data locally with the generated key.
Updating data:
Generate encryption keys by signing a deterministic string using Ethereum private keys and then hash it with the hashing algorithm.
Fetch the IPFS hashes from the smart contract.
Get the encrypted data from the IPFS.
Decryption the data locally with the generated key.
Encrypt the updated data with the generated key.
Calculate the master hash for the updated encrypted data from IPFS and then store it in a smart contract by doing a transaction and map it to same index.