Go to file
Kirill Fedoseev b5952ce02a Correct dependency building. Moved building tss in separate job 2019-10-23 19:12:27 +03:00
.circleci Correct dependency building. Moved building tss in separate job 2019-10-23 19:12:27 +03:00
demo Added more initialization of environment 2019-10-21 21:43:31 +03:00
src Correct dependency building. Moved building tss in separate job 2019-10-23 19:12:27 +03:00
tests Correct dependency building. Moved building tss in separate job 2019-10-23 19:12:27 +03:00
.gitattributes highlight Solidity code in GitHub browser 2019-08-23 20:49:33 +03:00
.gitignore Separate queue for exchange messages. Moved nonce, rangeStart, rangeSize to bridge contract 2019-10-18 13:38:42 +03:00
.gitmodules Demo of ETH-to-BNC bridge 2019-07-07 22:58:35 +03:00
DEMO.md Updated DEMO.md voting section 2019-10-06 14:41:39 +03:00
README.md finished instruction for demo and splitted the document on two parts 2019-08-23 20:37:06 +03:00

README.md

Ethereum to Binance Chain bridge

This repository contains a proof-of-concept for ERC20-to-BEP2 bridge.

https://forum.poa.network/t/ethereum-to-binance-chain-bridge/2696

The bridge is able to transfer an ERC20 tokens on an EVM-based chain to BEP2 to the Binance Chain and vice versa.

It includes the following components:

  1. The bridge contract on an EVM-based chain that is responsible to receive and release ERC20 tokens
  2. The orchestration contract on an EVM-based chain that participate in MPC (multy-party computations) to generate a threshold signature.
  3. The oracle that monitors the chains and the send transactions. One oracle represents one bridge validator (one private key).

The idea of the bridge is similar to the token bridge produced by POA.Network:

  • every oracle sends its confirmation as soon as a user sends the token relay request in one chain.
  • when enough confirmations collected the requested amount of tokens is unlocked in another chain.

Collecting confirmations for the Binance Chain is made in form of mutlisig wallet - the validator's confirmation is participation in the transaction signature gneration with usage of Threshold Signature Scheme (TSS) implemented for ECDSA by KZen Research team.

At this version the tool for TSS is used as is. It is assumed that later part of TSS orchestration will be moved to the orchestration contract. So far, the orchestration contract is used as a database to keep data required by TSS parties during the signature generation.

Read an instruction how to run a demo for the bridge.