## Project Layout This repository contains several Rust crates that implement the different building blocks of an Ethereum node. The high-level structure of the repository is as follows: Generally reth is composed of a few components, with supporting crates. The main components can be defined as: - [Project Layout](#project-layout) - [Documentation](#documentation) - [Binaries](#binaries) - [Storage](#storage) - [Networking](#networking) - [Common](#common) - [Discovery](#discovery) - [Protocol](#protocol) - [Downloaders](#downloaders) - [Consensus](#consensus) - [Execution](#execution) - [Sync](#sync) - [RPC](#rpc) - [Transports](#transports) - [Common](#common-1) - [Payloads](#payloads) - [Primitives](#primitives) - [Misc](#misc) The supporting crates are split into two categories: [primitives](#primitives) and [miscellaneous](#misc). ### Documentation Contributor documentation is in [`docs`](../../docs) and end-user documentation is in [`book`](../../book). ### Binaries All binaries are stored in [`bin`](../../bin). ### Storage These crates are related to the database. - [`storage/codecs`](../../crates/storage/codecs): Different storage codecs. - [`storage/libmdbx-rs`](../../crates/storage/libmdbx-rs): Rust bindings for [libmdbx](https://libmdbx.dqdkfa.ru). A fork of an earlier Apache-licensed version of [libmdbx-rs][libmdbx-rs]. - [`storage/db`](../../crates/storage/db): Strongly typed Database abstractions (transactions, cursors, tables) over lower level database backends. - Implemented backends: mdbx - [`storage/provider`](../../crates/storage/provider): Traits which provide a higher level api over the database to access the Ethereum state and historical data (transactions, blocks etc.) ### Networking These crates are related to networking (P2P). The networking component mainly lives in [`net/network`](../../crates/net/network), which handles: - Message egress/ingress - Peer management - Session management #### Common - [`net/banlist`](../../crates/net/banlist): A simple peer banlist that can be used to ban peers or IP addresses. - Contains: Peer banlist. - [`net/network-api`](../../crates/net/network-api): Contains traits that define the networking component as a whole. Other components that interface with the network stack only need to depend on this crate for the relevant types. - [`net/nat`](../../crates/net/nat): A small helper crate that resolves the external IP of the running node using various methods (such as a manually provided IP, using UPnP etc.) #### Discovery - [`net/discv4`](../../crates/net/discv4): An implementation of the [discv4][discv4] protocol - [`net/dns`](../../crates/net/dns): An implementation of node discovery via DNS ([EIP-1459][eip-1459]) #### Protocol - [`net/eth-wire`](../../crates/net/eth-wire): Implements the `eth` wire protocol and the ``RLPx`` networking stack. - [`net/ecies`](../../crates/net/ecies): Implementation of the Elliptic Curve Integrated Encryption Scheme used in the ``RLPx`` handshake. #### Downloaders - [`net/downloaders`](../../crates/net/downloaders): Traits defining block body and header downloaders, as well as P2P implementations of both. ### Consensus Different consensus mechanisms. - [`consensus/common`](../../crates/consensus/common): Common consensus functions and traits (e.g. fee calculation) - [`consensus/auto-seal`](../../crates/consensus/auto-seal): A consensus mechanism that auto-seals blocks for local development (also commonly known as "auto-mine") - [`consensus/beacon`](../../crates/consensus/beacon): Consensus mechanism that handles messages from a beacon node ("eth2") ### Execution Crates related to transaction execution. - [`revm`](../../crates/revm): An implementation of an executor using `revm` ### Sync These crates implement the main syncing drivers of reth. - [`blockchain-tree`](../../crates/blockchain-tree): A tree-like structure for handling multiple chains of unfinalized blocks. This is the main component during live sync (i.e. syncing at the tip) - [`stages`](../../crates/stages): A pipelined sync, including implementation of various stages. This is used during initial sync and is faster than the tree-like structure for longer sync ranges. ### RPC Crates related to the RPC component (including IPC transport) The RPC component mainly lives in [`rpc/rpc`](../../crates/rpc/rpc), which implements the following namespaces: - `admin_` - `debug_` (includes Geth-style tracing APIs) - `eth_` - `net_` - `trace_` (OpenEthereum-style tracing APIs) - `txpool_` - `web3_` The engine API ([`engine_`][engine-spec]) lives in [`rpc/rpc-engine-api`](../../crates/rpc/rpc-engine-api) (this is *not* an interface crate despite the confusing name). There is also a crate to easily configure an RPC server: [`rpc/rpc-builder`](../../crates/rpc/rpc-builder). #### Transports The RPC component is based on the `jsonrpsee` crate which provides JSONRPC over WebSockets and HTTP. The IPC transport lives in [`rpc/ipc`](../../crates/rpc/ipc). #### Common - [`rpc/rpc-api`](../../crates/rpc/rpc-api): RPC traits - Supported transports: HTTP, WS, IPC - Supported namespaces: `eth_`, `engine_`, `debug_` - [`rpc/rpc-types`](../../crates/rpc/rpc-types): Types relevant for the RPC endpoints above, grouped by namespace ### Payloads Crates related to building and validating payloads (blocks). - [`transaction-pool`](../../crates/transaction-pool): An in-memory pending transactions pool. - [`payload/builder`](../../crates/payload/builder): Abstractions for payload building and a payload builder service that works with multiple kinds of payload resolvers. - [`payload/basic`](../../crates/payload/basic): A basic payload generator. ### Primitives These crates define primitive types or algorithms. - [`primitives`](../../crates/primitives): Commonly used types in Reth. - [`trie`](../../crates/trie): An implementation of a Merkle Patricia Trie used for various roots (e.g. the state root) in Ethereum. ### Misc Small utility crates. - [`tasks`](../../crates/tasks): An executor-agnostic task abstraction, used to spawn tasks on different async executors. Supports blocking tasks and handles panics gracefully. A tokio implementation is provided by default. - [`metrics/common`](../../crates/metrics/src/common): Common metrics types (e.g. metered channels) - [`metrics/metrics-derive`](../../crates/metrics/metrics-derive): A derive-style API for creating metrics - [`tracing`](../../crates/tracing): A small utility crate to install a uniform [`tracing`][tracing] subscriber [libmdbx-rs]: https://crates.io/crates/libmdbx [discv4]: https://github.com/ethereum/devp2p/blob/master/discv4.md [jsonrpsee]: https://github.com/paritytech/jsonrpsee/ [tracing]: https://crates.io/crates/tracing [eip-1459]: https://eips.ethereum.org/EIPS/eip-1459 [engine-spec]: https://github.com/ethereum/execution-apis/tree/main/src/engine