fuel-core
Fuel Client
Fuel client implementation.
Contributing
If you are interested in contributing to Fuel, see our CONTRIBUTING.md guidelines for coding standards and review process.
Before pushing any changes or creating pull request please run
.
Building
System Requirements
There are several system requirements including clang.
MacOS
brew updatebrew install cmake
Debian
apt updateapt install -y cmake pkg-config build-essential git clang libclang-dev
Arch
pacman -Syu --needed --noconfirm cmake gcc pkgconf git clang
Rust setup
You'll need
target installed.
rustup target add wasm32-unknown-unknown
Compiling
We recommend using
to build fuel-core:
cargo xtask build
This will run
as well as any other custom build processes we have such as re-generating a GraphQL schema for the client.
Testing
The ci_checks.sh script file can be used to run all CI checks, including the running of tests.
source ci_checks.sh
The script requires pre-installed tools. For more information run:
cat ci_checks.sh
Running
The service can be launched by executing
. The list of options for running can be accessed via the
option:
$ ./target/debug/fuel-core run --help
USAGE: fuel-core run [OPTIONS]
OPTIONS: --snapshot <SNAPSHOT> Snapshot from which to do (re)genesis. Defaults to local testnet configuration
[env: SNAPSHOT=] ...
For many development purposes it is useful to have a state that won't persist and the
option can be set to
as in the following example.
Example
$ ./target/debug/fuel-core run --db-type in-memory2023-06-13T12:45:22.860536Z INFO fuel_core::cli::run: 230: Block production mode: Instant2023-06-13T12:38:47.059783Z INFO fuel_core::cli::run: 310: Fuel Core version v0.18.12023-06-13T12:38:47.078969Z INFO new{name=fuel-core}:_commit_result{block_id=b1807ca9f2eec7e459b866ecf69b68679fc6b205a9a85c16bd4943d1bfc6fb2a height=0 tx_status=[]}: fuel_core_importer::importer: 231: Committed block2023-06-13T12:38:47.097777Z INFO new{name=fuel-core}: fuel_core::graphql_api::service: 208: Binding GraphQL provider to 127.0.0.1:4000
To disable block production on your local node, set
Example
$ ./target/debug/fuel-core run --poa-instant=false2023-06-13T12:44:12.857763Z INFO fuel_core::cli::run: 232: Block production disabled
Running a Ignition node
If you want to participate in the Ignition network with your own node you can launch it following these simple commands.
Install the latest fuelup :
curl -fsSL https://install.fuel.network/ | shfuelup toolchain install latest
Clone the chain configuration folder :
git clone https://github.com/FuelLabs/chain-configuration
Generate a keypair for your node:
fuel-core-keygen new --key-type peering
and copy the secret key displayed.
Run your node (change all variable with
to your own personal variables):
fuel-core run \--enable-relayer \--service-name fuel-ignition-node \--keypair {KEYGEN_SECRET_KEY} \--relayer {ETHEREUM_RPC_ENDPOINT} \--ip=0.0.0.0 --port 4000 --peering-port 30333 \--db-path ~/.fuel-ignition \--snapshot {PATH_TO_CHAIN_CONFIGURATION_FOLDER}/ignition \--utxo-validation --poa-instant false --enable-p2p \--bootstrap-nodes /dnsaddr/mainnet.fuel.network \--sync-header-batch-size 100 \--relayer-v2-listening-contracts=0xAEB0c00D0125A8a788956ade4f4F12Ead9f65DDf \--relayer-da-deploy-height=20620434 \--relayer-log-page-size=100 \--sync-block-stream-buffer-size 30
Instead of directly placing your personal values on the command we advise you to use, for example, environment variables.
Troubleshooting
Publishing
We use
action for automatic publishing of all crates.
If you have problems with publishing, you can troubleshoot it locally with
.
act release -s GITHUB_TOKEN=<YOUR_GITHUB_TOKEN> -j publish-crates-check --container-architecture linux/amd64 --reuse
It requires GitHubToken to do request to the GitHub. You can create it with this instruction.
Outdated database
If you encounter an error such as
thread 'main' panicked at 'unable to open database: DatabaseError(Error { message: "Invalid argument: Column families not opened: column-11, column-10, column-9, column-8, column-7, column-6, column-5, column-4, column-3, column-2, column-1, column-0" })', fuel-core/src/main.rs:23:66
Clear your local database using:
File descriptor limits
On some macOS versions the default file descriptor limit is quite low, which can lead to IO errors with messages like
or even
when RocksDB encounters these issues. Use the following command to increase the open file limit. Note that this only affects the current shell session, so consider adding it to
.
ulimit -n 10240
Log level
The service relies on the environment variable
. For more information, check the EnvFilter examples crate.
Human logging can be disabled with the environment variable
Debugging
See the guide on debugging for an overview on running a debug build of a local node.
Docker & Kubernetes
# Create Docker Imagedocker build -t fuel-core . -f deployment/Dockerfile
# Delete Docker Imagedocker image rm fuel-core
# Create Kubernetes Volume, Deployment & Servicekubectl create -f deployment/fuel-core.yml
# Delete Kubernetes Volume, Deployment & Servicekubectl delete -f deployment/fuel-core.yml
GraphQL service
The client functionality is available through a service endpoint that expect GraphQL queries.
Transaction executor
The transaction executor currently performs instant block production. Changes are persisted to RocksDB by default.
- Service endpoint: /v1/graphql
- Schema (available after building): crates/client/assets/schema.sdl
The service expects a mutation defined as
that receives a Transaction in hex encoded binary format, as specified here.
cURL example
This example will execute a script that represents the following sequence of ASM:
ADDI(0x10, RegId::ZERO, 0xca),ADDI(0x11, RegId::ZERO, 0xba),LOG(0x10, 0x11, RegId::ZERO, RegId::ZERO),RET(RegId::ONE),
$ cargo run --bin fuel-core-client -- transaction submit \"{\"Script\":{ \"body\":{ \"script_gas_limit\":1000000, \"receipts_root\":\"0000000000000000000000000000000000000000000000000000000000000000\", \"script\":[80,64,0,202,80,68,0,186,51,65,16,0,36,4,0,0], \"script_data\":[] }, \"policies\":{ \"bits\":\"Maturity | MaxFee\", \"values\":[0,0,0,0]}, \"inputs\":[{ \"CoinSigned\":{ \"utxo_id\":{ \"tx_id\":\"c49d65de61cf04588a764b557d25cc6c6b4bc0d7429227e2a21e61c213b3a3e2\", \"output_index\":33298 }, \"owner\":\"f1e92c42b90934aa6372e30bc568a326f6e66a1a0288595e6e3fbd392a4f3e6e\", \"amount\":4294967295, \"asset_id\":\"0000000000000000000000000000000000000000000000000000000000000000\", \"tx_pointer\":{ \"block_height\":0, \"tx_index\":0 }, \"witness_index\":0, \"predicate_gas_used\":null, \"predicate\":null, \"predicate_data\":null}}], \"outputs\":[], \"witnesses\":[{ \"data\":[167,184,58,243,113,131,73,255,233,187,213,245,147,97,92,200,55,162,35,88,241,0,222,151,44,66,30,244,186,138,146,161,73,250,79,15,67,105,225,4,79,142,222,72,74,1,221,173,88,143,201,96,229,4,170,19,75,126,67,159,133,151,149,51]} ]}}"
You may meet the error
due to the UTXO validation. The UTXO validation can be turned off by adding the
flag.
$ ./target/debug/fuel-core run --db-type in-memory --debug