Skip to content

apoorvlathey/PrivaSwap

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PrivaSwap

PrivaSwap allows the bitcoin users to transition into Ethereum by not hindering their privacy.

Users can swap their Bitcoins to tBTC tokens on Ethereum powered by Keep Network. These tokens are then transferred to a totally new Stealth Address via Umbra Protocol maintaining the Privacy of the User.

VIDEO DEMO:

LIVE DEMO: https://apoorvlathey.com/projects/PrivaSwap

Benefit of using Umbra Protocol with tBTC

Umbra offers a ton of benefits as compared to Tornado Cash:

  • Valid for any arbitrary amount of Tokens (Not dependent on Slot Sizes)
  • No Waiting time as instant and direct transfer
  • Less Gas Fee per transaction as just simple transfers.
  • DIRECT tBTC transfers (No need to convert to other supported tokens by tornado cash)

How does the Dapp Work?

  1. Setup Account. A random Public-Private Key Pair is generated. The Private key is encrypted by our password and gets stored into the browser's local storage. Copy and Send the Public Key to the Sender.

  2. Send. Switch onto the send tab. You would see your tBTC balance. If it's zero then head over to https://dapp.test.tbtc.network/ to convert BTC to tBTC. Input the Public Key of Receiver and enter any arbitary amount of tBTC you want to send (after approving the contract). Click "Send tBTC".

The sender uses the provided Public Key and Mulitplies it with a Random Number to generate a fresh Stealth Address. The tokens are transferred to this address and an Event is emitted by our Smart Contract containing this Random Number encrypted by the receiver Public Key ensuring that only the receiver can decrypt the Random Number from Event Logs history of the entire contract.

  1. Withdraw. On entering the password, Private key is unlocked from browser's local storage. The Dapp checks to decrypt all the events emitted, using this Private Key. On successfully finding the corresponding event, we get the Random Number. Using this Random Number and our Private Key, the Private Key of Stealth Address is generated.

This generated Private Key can be directly imported into Metamask:

And there you have your Tokens:

Transaction Overview for third party

In our transaction only the sender and receiver are aware of receiver's identity. For an outsider looking at the transaction, Umbra makes the link between sending and receiving address meaningless! Everyone knows the address funds were sent to, but they don't know who controls that address.

Umbra Logo
Image via @IoTeX hackernoon.

What's in for the Future of PrivaSwap?

  • To use tbtc.js to mint tBTC which get directly transferred to the Stealth Address via our Smart Contract.
  • Integrate GSN to allow sending of tokens from Stealth Address to any other address.

Setup the Project

  1. Clone the repo
  2. npm i and npm run start
  3. Switch Metamask to Ropsten and head over to localhost:3000

About

Swap BTC to tBTC and transfer to ETH address anonymously.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published