mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-12 04:11:07 +00:00
Provide overview about project components (#121)
* Add descriptions for folder structure + node * Beef up descriptions of project components * Fix list formatting * Add note about nightly Rust * Update README.md Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com> * Update README.md Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com> * Reword Tomek's currency-exchange suggestion * Add link to Substrate's installation guide Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com>
This commit is contained in:
committed by
Bastian Köcher
parent
7294ea44e1
commit
592409d740
+152
-2
@@ -2,7 +2,157 @@
|
||||
|
||||
This is a collection of components for building bridges.
|
||||
|
||||
The main components that will be constructed here will be bridge modules/runtimes
|
||||
and bridge relays.
|
||||
These components include runtime modules to help you construct your bridge's runtime, as well as
|
||||
bridge relays for cross-chain communication.
|
||||
|
||||
A bridge node is also available. The node can be used to run a test network which has support for bridging Ethereum
|
||||
PoA chains to Substrate. We're working on expanding this functionality in the future.
|
||||
|
||||
🚧 The bridges are currently under construction - a hardhat is recommended beyond this point 🚧
|
||||
|
||||
## Contents
|
||||
- [Installation](#installation)
|
||||
- [Project Layout](#project-layout)
|
||||
- [Bridge Node Runtime](#bridge-node-runtime)
|
||||
- [Ethereum Node](#ethereum-node)
|
||||
- [Bridge Relay](#bridge-relay)
|
||||
- [Running the Bridge](#running-the-bridge)
|
||||
|
||||
## Installation
|
||||
To get up and running you need both stable and nightly Rust. Rust nightly is used to build the Web
|
||||
Assembly (WASM) runtime for the node. You can configure the WASM support as so:
|
||||
|
||||
```
|
||||
rustup install nightly
|
||||
rustup target add wasm32-unknown-unknown --toolchain nightly
|
||||
```
|
||||
|
||||
Once this is configured you can build and test the repo as follows:
|
||||
|
||||
```
|
||||
git clone https://github.com/paritytech/parity-bridges-common.git
|
||||
cd parity-bridges-common
|
||||
cargo build --all
|
||||
cargo test --all
|
||||
```
|
||||
|
||||
If you need more information about setting up your development environment Substrate's
|
||||
[Getting Started](https://substrate.dev/docs/en/knowledgebase/getting-started/) page is a good
|
||||
resource.
|
||||
|
||||
## Project Layout
|
||||
Here's an overview of how the project is laid out. The main bits are the `node`, which is the actual
|
||||
"blockchain", the `modules` which are used to build the blockchain's logic (a.k.a the runtime) and
|
||||
the `relays` which are used to pass messages between chains.
|
||||
|
||||
```
|
||||
├── bin
|
||||
│ └── node // Bridge ready chain implementation
|
||||
├── modules // Runtime Modules
|
||||
│ ├── ethereum // Manage Ethereum PoA chain info
|
||||
│ ├── ethereum-contract // Ethereum built-in for validating Substrate block info
|
||||
│ ├── currency-exchange // Cross-chain fund transfers
|
||||
│ └── substrate // Manage Substrate chain info
|
||||
├── primitives // Shared runtime and node code
|
||||
│ └── ethereum-poa // Helpers for Ethereum PoA
|
||||
├── relays // Cross-chain communication
|
||||
│ ├── ethereum // Sync and communicate between Ethereum PoA + Substrate chains
|
||||
│ └── substrate // 🚧 WIP 🚧
|
||||
```
|
||||
|
||||
## Bridge Node Runtime
|
||||
The node runtime consists of several runtime modules, however not all of them are used at the same
|
||||
time. When running an Ethereum PoA to Substrate bridge the modules required are the Ethereum module
|
||||
and the currency exchange module. When running a Substrate to Substrate bridge the Substrate and
|
||||
currency exchange modules are required.
|
||||
|
||||
Below is a brief description of each of the runtime modules.
|
||||
|
||||
### Ethereum Bridge Runtime Module
|
||||
The main job of this runtime module is to keep track of useful information an Ethereum PoA chain
|
||||
which has been submitted by a bridge relayer. This includes:
|
||||
|
||||
- Ethereum headers and their status (e.g are they the best header, are they finalized, etc.)
|
||||
- Current validator set, and upcoming validator sets
|
||||
|
||||
This runtime module has more responsibilties than simply storing headers and validator sets. It is
|
||||
able to perform checks on the incoming headers to verify their general integrity, as well as whether
|
||||
or not they've been finalized by the authorities on the PoA chain.
|
||||
|
||||
This module is laid out as so:
|
||||
|
||||
```
|
||||
├── ethereum
|
||||
│ └── src
|
||||
│ ├── error.rs // Runtime error handling
|
||||
│ ├── finality.rs // Manage finality operations
|
||||
│ ├── import.rs // Import new Ethereum headers
|
||||
│ ├── lib.rs // Store headers and validator set info
|
||||
│ ├── validators.rs // Track current and future PoA validator sets
|
||||
│ └── verification.rs // Verify validity of incoming Ethereum headers
|
||||
```
|
||||
|
||||
### Currency Exchange Runtime Module
|
||||
The currency exchange module is used to faciliate cross-chain funds transfers. It works by accepting
|
||||
a transaction which proves that funds were locked on one chain, and releases a corresponding amount
|
||||
of funds on the recieving chain.
|
||||
|
||||
For example: Alice would like to send funds from chain A to chain B. What she would do is send a
|
||||
transaction to chain A indicating that she would like to send funds to an address on chain B. This
|
||||
transaction would contain the amount of funds she would like to send, as well as the address of the
|
||||
recipient on chain B. These funds would now be locked on chain A. Once the block containing this
|
||||
"locked-funds" transaction is finalized it can be relayed to chain B. Chain B will verify that this
|
||||
transaction was included in a finalized block on chain A, and if successful deposit funds into the
|
||||
recipient account on chain B.
|
||||
|
||||
Chain B would need a way to convert from a foreign currency to its local currency. How this is done
|
||||
is left to the runtime developer for chain B.
|
||||
|
||||
This module is one example of how an on-chain light client can be used to prove a particular action
|
||||
was taken on a foreign chain. In particular it enables transfers of the foreign chain's native
|
||||
currency, but more sophisticated modules such as ERC20 token transfers or arbitrary message transfers
|
||||
are being worked on as well.
|
||||
|
||||
### Substrate Bridge Runtime Module
|
||||
👷 Under Construction 👷♀️
|
||||
|
||||
## Ethereum Node
|
||||
On the Ethereum side of things, we require two things. First, a Solidity smart contract to track the
|
||||
Substrate headers which have been submitted to the bridge (by the relay), and a built-in contract to
|
||||
be able to verify that headers have been finalized by the Grandpa finality gadget. Together this
|
||||
allows the Ethereum PoA chain to verify the integrity and finality of incoming Substrate headers.
|
||||
|
||||
The Solidity smart contract is not part of this repo, but can be found
|
||||
[here](https://github.com/svyatonik/substrate-bridge-sol/blob/master/substrate-bridge.sol) if you're
|
||||
curious. We have the contract ABI in the `ethereum/relays/res` directory.
|
||||
|
||||
## Bridge Relay
|
||||
The bridge relay is responsible for syncing the chains which are being bridged, and passing messages
|
||||
between them. The current implementation of the relay supportings syncing and interacting with
|
||||
Ethereum PoA and Substrate chains.
|
||||
|
||||
The folder structure of the bridge relay is as follows:
|
||||
|
||||
```
|
||||
├── relays
|
||||
│ ├── ethereum
|
||||
│ │ ├── res
|
||||
│ │ │ └── ...
|
||||
│ │ └── src
|
||||
│ │ ├── ethereum_client.rs // Interface for Ethereum RPC
|
||||
│ │ ├── ethereum_deploy_contract.rs // Utility for deploying bridge contract to Ethereum
|
||||
│ │ ├── ethereum_sync_loop.rs // Sync headers from Ethereum, submit to Substrate
|
||||
│ │ ├── ethereum_types.rs // Useful Ethereum types
|
||||
│ │ ├── headers.rs // Track synced and incoming block headers
|
||||
│ │ ├── main.rs // Entry point to binary
|
||||
│ │ ├── substrate_client.rs // Interface for Substrate RPC
|
||||
│ │ ├── substrate_sync_loop.rs // Sync headers from Substrate, submit to Ethereum
|
||||
│ │ ├── substrate_types.rs // Useful Ethereum types
|
||||
│ │ ├── sync.rs // Sync configuration and helpers
|
||||
│ │ ├── sync_loop.rs // Header synchronization between source and target chains
|
||||
│ │ ├── sync_types.rs // Useful sync types
|
||||
│ │ └── utils.rs // General utilities
|
||||
```
|
||||
|
||||
## Running the Bridge
|
||||
👷 Under Construction 👷♀️
|
||||
|
||||
Reference in New Issue
Block a user