Skip to content

Latest commit

 

History

History
57 lines (38 loc) · 2.11 KB

README.md

File metadata and controls

57 lines (38 loc) · 2.11 KB

Frontier

Frontier is Substrate's Ethereum compatibility layer. It allows you to run unmodified Ethereum dapps.

The goal of Ethereum compatibility layer is to be able to:

  • Run a normal web3 application via the compatibility layer, using local nodes, where an extra bridge binary is acceptable.
  • Be able to import state from Ethereum mainnet.

It consists of the following components:

  • pallet-evm: EVM execution engine for Substrate.
  • pallet-ethereum: Emulation of full Ethereum block processing.
  • rpc-ethereum: Compatibility layer for web3 RPC methods.

Development notes

Frontier is still work-in-progress. Below are some notes about the development.

Runtime

A few notes on the EthereumRuntimeApi's runtime implementation requirements:

  • For supporting author rpc call, the FindAuthor trait must be implemented in an arbitrary struct. This implementation must call the authorities accessor in either Aura or Babe and convert the authority id response to H160 using pallet_evm::HashTruncateConvertAccountId::convert_account_id.

The struct implementing FindAuthor is passed as the FindAuthor associated type's value for pallet_ethereum.

An Aura example for this is available in the template's runtime (EthereumFindAuthor).

  • For supporting chain_id rpc call, a u64 ChainId constant must be defined.

  • For supporting gas_price rpc call, FeeCalculator trait must be implemented in an arbitrary struct. An example FixedGasPrice is available in the template's runtime.

Vendor folder

The vendor folder contains dependencies that contains changes that has not yet been upstreamed. Once the upstreaming process is finished, the corresponding submodule should be removed from vendor folder, and directly use upstream.

The substrate submodule contains a large quantity of dependencies, so they should directly use path directive in dependency declarations. For other dependencies, they should use Cargo's patch feature in workspace declaration.

To install those submodules, from the frontier root folder:

git submodule init
git submodule update