Version v0.24.1
Added
- #1786: Regenesis now includes off-chain tables.
- #1716: Added support of WASM state transition along with upgradable execution that works with native(std) and WASM(non-std) executors. The
fuel-corenow requires awasm32-unknown-unknowntarget to build. - #1770: Add the new L1 event type for forced transactions.
- #1767: Added consensus parameters version and state transition version to the
ApplicationHeaderto describe what was used to produce this block. - #1760: Added tests to verify that the network operates with a custom chain id and base asset id.
- #1752: Add
ProducerGasPricetrait that theProducerdepends on to get the gas price for the block. - #1747: The DA block height is now included in the genesis state.
- #1740: Remove optional fields from genesis configs
- #1737: Remove temporary tables for calculating roots during genesis.
- #1731: Expose
schema.sdlfromfuel-core-client.
Changed
Breaking
-
#1771: Contract 'states' and 'balances' brought back into
ContractConfig. Parquet now writes a file per table. -
1779: Modify Relayer service to order Events from L1 by block index
-
#1783: The PR upgrade
fuel-vmto0.48.0release. Because of some breaking changes, we also adapted our codebase to follow them:- Implementation of
Defaultfor configs was moved under thetest-helpersfeature. Thefuel-corebinary uses testnet configuration instead ofDefault::default(for cases whenChainConfigwas not provided by the user). - All parameter types are enums now and require corresponding modifications across the codebase(we need to use getters and setters). The GraphQL API remains the same for simplicity, but each parameter now has one more field -
version, that can be used to decide how to deserialize. - The
UtxoIdtype now is 34 bytes instead of 33. It affects hex representation and requires adding00. - The
block_gas_limitwas moved toConsensusParametersfromChainConfig. It means the block producer doesn't specify the block gas limit anymore, and we don't need to propagate this information. - The
bytecodeLengthfield is removed from theCreatetransaction. - Removed
ConsensusParametersfrom executor config becauseConsensusParameters::defaultis not available anymore. Instead, executors fetchConsensusParametersfrom the database.
- Implementation of
-
#1769: Include new field on header for the merkle root of imported events. Rename other message root field.
-
#1768: Moved
ContractsInfotable to the off-chain database. Removedsaltfield from theContractConfig. -
#1761: Adjustments to the upcoming testnet configs:
- Decreased the max size of the contract/predicate/script to be 100KB.
- Decreased the max size of the transaction to be 110KB.
- Decreased the max number of storage slots to be 1760(110KB / 64).
- Removed fake coins from the genesis state.
- Renamed folders to be "testnet" and "dev-testnet".
- The name of the networks are "Upgradable Testnet" and "Upgradable Dev Testnet".
-
#1694: The change moves the database transaction logic from the
fuel-coreto thefuel-core-storagelevel. The corresponding issue described the reason behind it.Technical details of implementation
-
The change splits the
KeyValueStoreintoKeyValueInspectandKeyValueMutate, as well theBlueprintintoBlueprintInspectandBlueprintMutate. It allows requiring less restricted constraints for any read-related operations. -
One of the main ideas of the change is to allow for the actual storage only to implement
KeyValueInspectandModifiablewithout theKeyValueMutate. It simplifies work with the databases and provides a safe way of interacting with them (Modification into the database can only go through theModifiable::commit_changes). This feature is used to track the height of each database during commits and even limit how commits are done, providing additional safety. This part of the change was done as a separate commit. -
The
StorageTransactionis aStructuredStoragethat usesInMemoryTransactioninside to accumulate modifications. OnlyInMemoryTransactionhas a real implementation of theKeyValueMutate(Other types only implement it in tests). -
The implementation of the
Modifiablefor theDatabasecontains a business logic that provides additional safety but limits the usage of the database. TheDatabasenow tracks its height and is responsible for its updates. In thecommit_changesfunction, it analyzes the changes that were done and tries to find a new height(For example, in the case of theOnChaindatabase, we are looking for a newBlockin theFuelBlockstable). -
As was planned in the issue, now the executor has full control over how commits to the storage are done.
-
All mutation methods now require
&mut self- exclusive ownership over the object to be able to write into it. It almost negates the chance of concurrent modification of the storage, but it is still possible since theDatabaseimplements theClonetrait. To be sure that we don't corrupt the state of the database, thecommit_changesfunction implements additional safety checks to be sure that we commit updates per each height only once time. -
Side changes:
- The
dropfunction was moved fromDatabasetoRocksDBas a preparation for the state rewind since the read view should also keep the drop function until it is destroyed. - The
StatisticTabletable lives in the off-chain worker. - Removed duplication of the
Databasefrom thedap::ConcreteStoragesince it is already available from the VM. - The executor return only produced
Changesinstead of the storage transaction, which simplifies the interaction between modules and port definition. - The logic related to the iteration over the storage is moved to the
fuel-core-storagecrate and is now reusable. It provides aninteratormethod that duplicates the logic fromMemoryStoreon iterating over theBTreeMapand methods likeiter_all,iter_all_by_prefix, etc. It was done in a separate revivable commit. - The
MemoryTransactionViewis fully replaced by theStorageTransactionInner. - Removed
flushmethod from theDatabasesince it is not needed after #1664.
- The
-
-
#1693: The change separates the initial chain state from the chain config and stores them in separate files when generating a snapshot. The state snapshot can be generated in a new format where parquet is used for compression and indexing while postcard is used for encoding. This enables importing in a stream like fashion which reduces memory requirements. Json encoding is still supported to enable easy manual setup. However, parquet is prefered for large state files.
Snapshot command
The CLI was expanded to allow customizing the used encoding. Snapshots are now generated along with a metadata file describing the encoding used. The metadata file contains encoding details as well as the location of additional files inside the snapshot directory containing the actual data. The chain config is always generated in the JSON format.
The snapshot command now has the '--output-directory' for specifying where to save the snapshot.
Run command
The run command now includes the 'db_prune' flag which when provided will prune the existing db and start genesis from the provided snapshot metadata file or the local testnet configuration.
The snapshot metadata file contains paths to the chain config file and files containing chain state items (coins, messages, contracts, contract states, and balances), which are loaded via streaming.
Each item group in the genesis process is handled by a separate worker, allowing for parallel loading. Workers stream file contents in batches.
A database transaction is committed every time an item group is succesfully loaded. Resumability is achieved by recording the last loaded group index within the same db tx. If loading is aborted, the remaining workers are shutdown. Upon restart, workers resume from the last processed group.
Contract States and Balances
Using uniform-sized batches may result in batches containing items from multiple contracts. Optimal performance can presumably be achieved by selecting a batch size that typically encompasses an entire contract's state or balance, allowing for immediate initialization of relevant Merkle trees.
Removed
- #1757: Removed
protobuffrom everywhere sincelibp2pusesquick-protobuf.
What's Changed
- Expose
schema.sdladd some helper types and traits by @Dentosal in #1731 - Regenesis support by @MujkicA in #1693
- Remove genesis temp tables by @MujkicA in #1737
- Remove optional fields from configs by @MujkicA in #1740
- Weekly
cargo updateby @github-actions in #1745 - Regenesis should also store da block height by @xgreenx in #1747
- Duplicating blacklisting feature for TxPool from
0.22.4by @xgreenx in #1748 - Moved
StorageTransactionto thefuel-core-storagecrate by @xgreenx in #1694 - Prepare the codebase to use base gas price during block production #1642 by @MitchTurner in #1752
- Removed
protobuffrom everywhere sincelibp2pusesquick-protobufby @xgreenx in #1757 - Weekly
cargo updateby @github-actions in #1758 - Added tests to verify that the network operates with a custom chain id and base asset id by @xgreenx in #1760
- Adjustments to the upcoming testnet configs by @xgreenx in #1761
- Added consensus parameters version and state transition version to the
ApplicationHeaderby @xgreenx in #1767 - Moved
ContractsInfotable to the off-chain database by @xgreenx in #1768 - Keep record of events from L1 in Block Header by @MitchTurner in #1769
- Feature/new fti event by @Voxelot in #1770
- Forkless state transition with upgradable WASM executor by @xgreenx in #1716
- Removed the usage of the
lazy_staticfrom teh codebase by @xgreenx in #1781 - Patch to use
fuel-vm 0.48.0by @xgreenx in #1783 - Modify Relayer service to order Events from L1 by block index by @MitchTurner in #1779
- refactor: Prepare (re)genesis for off chain tables by @segfault-magnet in #1771
- feat: Add some off chain tables to regenesis by @segfault-magnet in #1786
- Release v0.24.0 by @xgreenx in #1791
- Moved chain specification into
fuel-core-bincrate by @xgreenx in #1792 - Release v0.24.1 by @xgreenx in #1793
Full Changelog: v0.23.0...v0.24.1