Skip to content

Latest commit

 

History

History
55 lines (44 loc) · 1.72 KB

README.md

File metadata and controls

55 lines (44 loc) · 1.72 KB

Example: use RLNjs in browser

The example go through the following steps:

  1. Deploy the necessary contracts: verifier (the mock proof verifier since it's not yet generated), ERC20 token, and the RLN contract
  2. Create a RLN instance rln, and demonstrate how to register, createProof, verifyProof, withdraw, and releaseWithdrawal.
  3. Create a RLN instance rlnAnother and demonstrate how to slash a spammer. rlnAnother simply register and send more proofs than they should. rln can detect the spam by examine the output from saveProof. If the status of the output is BREACH, the secret is leaked. rln can use the recovered secret to slash the spammer by calling slash.

To install and run the example, follow the steps below.

  1. Install the project
$ npm install
  1. Run a local testing RPC Here we use a hardhat node. If the RPC is not listening http://localhost:8545, you need to change the url in config.ts.

In a new terminal, run:

$ npx hardhat node
  1. Run the example in a browser "Try npm run clean if you've made changes to the code but the web page is not updated"
$ npm run browser

...
Available on:
  http://127.0.0.1:8080
  http://192.168.50.66:8080
Hit CTRL-C to stop the server

Open the web page at http://localhost:8080. You should see the following output in the browser console.

Connecting to endpoint at http://localhost:8545
Deploying contracts...

...

Successfully breached rlnAnother's secret=xxx
Successfully slashed rlnAnother
  1. Run the example in NodeJS
$ npm run node

...
Connecting to endpoint at http://localhost:8545
Deploying contracts...
...
Successfully breached rlnAnother's secret=xxx
Successfully slashed rlnAnother