Mokhtar Naamani f0bc38390c giza: update readme, changelog some setup instructions and small fix to yarn.lock | 3 years ago | |
---|---|---|
.. | ||
src | 3 years ago | |
CHANGELOG.md | 3 years ago | |
Cargo.toml | 3 years ago | |
README.md | 4 years ago | |
build.rs | 3 years ago | |
runtime-banner.svg | 4 years ago |
The runtime is the code that defines the consensus rules of the Joystream protocol. It is compiled to WASM and lives on chain. Joystream node execute the code's logic to validate transactions and blocks on the blockchain.
When building joystream-node as described in ../node/README.md, in addition to the joystream-node binary being built the WASM blob artifact is produced in:
./target/release/wbuild/joystream-node-runtime/joystream_node_runtime.compact.wasm
Deploying the compiled runtime on a live system can be done in one of two ways:
By creating a proposal for upgrading the Joystream runtime, which will then be voted on by the council. If the proposal is approved, the upgrade will go through after a grace period. When the Joystream platform is live, this will be the only way to upgrade the chain's runtime code.
By creating an extrinsic (transaction) signed with the sudo key invoking system::setCode()
. This can be done either from the Pioneer extrinsics tab, or directly with an admin script. This way of upgrading the runtime code is intended for development and testnet phases only.
Versioning of the runtime is set in runtime/src/lib.rs
For detailed information about how to set correct version numbers when developing a new runtime, see this