Skip to content

Axon r01

Compare
Choose a tag to compare
@raulk raulk released this 16 Jul 15:01
· 16 commits to main since this release
2bccfb4

Introducing Axon

It's early days for IPC! We are starting to enact a proper versioning and changelog practices. The framework will evolve rapidly in the next quarters, and it'll do so in major architectural milestones. With high probability, backwards compatibility between these milestones will not be preserved, requiring a manual migration to upgrade from one to the next. To cite a few such expected milestones: IPC modularization, consensus pluggability, Wasm-based client kernel.

We introduce the notion of "product generations" to represent the lifetime of IPC under each of these major architectural iterations. Product generations are named alphabetically A-Z (we certainly don't expect more than 26 generations...) We've kept the naming universe deliberately broad: entities/concepts found in biological, mathematical, or computing networks.

The first product generation is called Axon!

image

Find more background on these choices / implications here: #1012.

Axon r01

This is the baseline release of the IPC framework. A variation of this release is powering the networks of Fluence and Basin. Throughout the Axon generation, we do not expect to release crates and therefore we're staying away from adopting semver, resorting instead to simple sequential revision numbers. We're aiming to cut/tag revisions and publish changelogs on a weekly basis, with some flexibility to account for work in progress landing smoothly.

Axon r01 supports these major features (not a comprehensive list):

  • CometBFT/Ignite-based consensus (currently on v0.37 but with plans to upgrade to v0.38 / v1).
  • Wasm- and IPLD-based Filecoin Virtual Machine as an execution layer, supporting custom built-in Wasm actors, custom syscalls, custom gas price lists, and more.
  • Ethereum-compatible runtime and JSON-RPC API (quasi-Dencun level, missing MCOPY support).
  • Validator membership: federated (proof of authority) and collateral-driven (basis for proof of stake).
  • Configurable supply source for subnets: either inheriting the parent root coin, or adopting an ERC20-compatible token for circulating supply / gas.
  • L2 subnet creation, with L3+ behind a feature flag until we harden message propagation, response paths, and fault scenarios.
  • Asynchronous general message passing across the IPC hierarchy, with result and return data delivery back to the caller.
  • Cross-linked security: checkpointing on the parent via the relayer, and committing parent's finality in the subnet.
  • Ability to permission and restrict contract deployment in subnets.
  • Upgradability: framework actors can be upgraded through contract upgrades, and subnet hard forks can be run with the UpgradeScheduler.
  • Validator management through the parent network.
  • Automatic chain snapshots, with ability to bootstrap from them.
  • Compatibility with the BlockScount explorer and Ethereum wallets out of the box.
  • ... and a lot more.

Join the conversation!

Come ask your questions or give us feedback in the #ipc channel on Filecoin Slack.