This repository contains several Rust crates that implement the different building blocks of an Conflux node. The high-level structure of the repository is as follows:
- bins: All binary crates located in this folder
- crates: All crates library
- internal_contract: Internal contracts's abi and interface
- tests: The python integration tests
- run: Node run misc, include default config file and start scripts
- dev-support: Dev support scripts
- docs: Documentation
- changelogs: Changelogs, especially for the JSON-RPC APIs
The bins directory contains some binary crates:
- conflux: The conflux binary program, which serves as both the node's startup program and a CLI tool. It can be used for account management, calling RPC interfaces, etc.
- cfx_store: A tool for managing accounts.
- cfx_key: A conflux account key generation tool.
- pos-genesis-tool: A tool for generating PoS genesis data.
- cfx_bytes: Provides some general byte manipulation functions.
- cfx_types:Provides some commonly used type definitions in blockchain, such as Address, U256, H256, etc.
- cfx_addr: Conflux base32 address encoding/decoding.
The primitives crate contains the core data structures used in the Conflux system. For example, block, transaction, and receipt. This crate forms the foundational data structures of the entire Conflux system.
The Conflux Protocol's core code located at cfxcore directory. Including consensus
, EVM machine
etc.
The dbs directory contains the database crates.
The network directory contains the network crate.
The client crate contains the client startup logic and the Core Space RPC implementation.
Conflux provides a standard JSON-RPC 2.0 interface to allow external ecosystems (SDKs, wallets, etc.) to interact with the blockchain. Conflux includes two spaces: Core Space and eSpace, each with its own RPC.
The RPC implementation for eSpace is mainly located in the crates/rpc directory and is developed using the jsonrpsee RPC framework. It includes multiple crates:
- rpc-primitives: Definitions of the raw types for RPC.
- rpc-cfx-types: RPC type definitions for Core Space.
- rpc-eth-types: RPC type definitions for eSpace.
- rpc-eth-api: RPC interface definitions for eSpace, organized by namespace.
- rpc-eth-impl: RPC interface implementation for eSpace.
- rpc-cfx-impl: RPC interface implementation for Core Space.
- rpc-builder: Logic for RPC interface registration and service startup.
- rpc-utils: Implementation of common utilities, such as error code definitions.
The RPC implementation for Core Space is located in the crates/client crate, developed using jsonrpc-coree. The core code is in the src/rpc directory.
Conflux uses the industry-standard Stratum protocol
for implementing PoW mining. The protocol implementation code is primarily located in the crates/stratum and crates/blockgen directories. Additionally, there is some related code in the crates/cfxcore/core/src/pow/mod.rs
file.
The util directory contains some general utility crates.