Ethereum/RSK Bridge that allows to move ERC20 tokens from one chain to the other.
Cross chain events are very important in the future of crypto. Exchanging tokens between networks allows the token holders to use them in their favorite chain without beeing restricted to the contract owner network choice. Moreover this also allows layer 2 solutions to use the same tokens on different chains, this concept together with stable coins creates a great way of payment with low volatility across networks.
The smart contract on each network are connected by bridges, a bridge on one chain would receive and lock the ERC20 tokens, this action emits an event that will be served to the bridge on the other chain. This interoperability is achieved using a Federation that sends the event from one contract to the other, once the bridge on the other chain receives the event from the Federation, it mints the tokens on the mirror ERC20 contract. See the FAQ to know more about how it works!
The bridges on each contract are upgradeable, this would enable a smooth transition to a more decentralized bridge in the future. Here's is a link to the first POC of the trustless decentralized bridge
You can use the 'Token Bridge Dapp' together with Nifty Wallet or Metamask with custom network to move tokens between networks. This is the Dapp guide if you don't know how to use it. Or you can use a wallet with the abi of the contracts. See the 'interaction guide using MyCrypto' for more information on how to use the bridge.
Here are the 'addresses' of the deployed contracts in the different networks.
To report a vulnerability, please use the vulnerability reporting guideline for details on how to do it.
The smart contracts used by the bridge and the instructions to deploy them are in the 'bridge folder'. The ABI to interact with the contracts are in the 'abis folder'
The dapp of the token bridge can be found in the 'UI Folder'
A federation sends notification of events happening in the bridge of one chain to another chain. The federation is composed of oracles listening to the events created in one chain and sending it to the other chain. When a majority of the federators votes on an event, the bridge accepts the event as valid and releases the tokens on the other chain. See the 'federator' for more information about federations.
An integration test is prepared for contracts and federators. To properly run integration test, you need check network config in the truffle-config.js
and package.json
in bridge
folder with your test chains' configuration before run npm run deployIntegrationTest
.
- Check
mnemonic.key
inbridge
- Check
infura.key
inbridge
- Check
federator.key
infederator/config
- Check
config.js
infederator/config
Then
- run
npm run deployIntegrationTest
inbridge
- run
npm run integrationTest
infederator