Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: add code migration guides for v1.3.1 and v1.4.0, update v1.4.0 migration guide #340

Merged
merged 2 commits into from
Jan 10, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
46 changes: 7 additions & 39 deletions docs/developer-guides/migration-guide-1.4.0.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ of the version specified in the compatibility matrix is present in your active d

## Context

This guide describes the process of migrating from Partner Chains SDK v1.3.0 to v1.4.0 for an already
This guide describes the process of migrating from Partner Chains SDK v1.3.1 to v1.4.0 for an already
established chain, avoiding a chain reset.

The biggest change in version v1.4.0 which requires special handling is the update to smart contracts
Expand All @@ -24,59 +24,27 @@ The migration requires multiple detailed steps but to follow them successfuly it
The 1.4.0 version introduces some backwards-incompatible data schemas. This means that a simple runtime upgrade
using `system/setCode` extrinsic would leave the chain in an inconsistent state and unable to produce blocks.
To avoid this issue, the migration involves the following general steps:
1. Upgrade to a transitory version of the runtime 1.3.1, which only introduces a special helper extrinsic `sidechain/upgrade_and_set_addresses`.
2. Establish a brand new Partner Chain on Cardano using the new 1.4.0 version.
3. Use the `sidechain/upgrade_and_set_addresses` to atomically upgrade the runtime to version 1.4.0 and switch the addresses
1. Establish a brand new Partner Chain on Cardano using the new 1.4.0 version.
2. Use the `sidechain/upgrade_and_set_addresses` to atomically upgrade the runtime to version 1.4.0 and switch the addresses
observed for committee selection to the new Partner Chain.

## Migration Steps

### Prerequisites

This guide assumes the following:
1. An already running Partner Chain is present running nodes and runtime of version v1.3.0
1. An already running Partner Chain is present running nodes and runtime build with the Partner Chains SDK v1.3.1
and observing configuration and registrations created using smart contracts of version v6.2.2.
2. The Partner Chain's original chain spec file is available.

### Runtime upgrade to v1.3.1

This patch version extends the Sidechain pallet with a new extrinsic `sidechain/upgrade_and_set_addresses`
which allows the on-chain governance to atomically upgrade the runtime and set the genesis utxo and new main chain
scripts to observe.

1. Update Partner Chains SDK dependencies in your `Cargo.toml` to `v1.3.1`
2. Add the following configuration to your runtime configuration:
```rust
impl pallet_sidechain::Config for Runtime {
// ... other parameters
type MainChainScripts = sp_session_validator_management::MainChainScripts;

fn set_main_chain_scripts(scripts: Self::MainChainScripts) {
pallet_session_validator_management::MainChainScriptsConfiguration::<Runtime>::set(scripts);
}
}
```
This will allow the `upgrade_and_set_addresses` extrinsic to update configuration of the SessionValidatorManagement
pallet together with the Runtime code.

3. Increment the `spec_version` in your runtime configuration.
4. Build the new Runtime WASM (you can do it by running `cargo build --release`)
5. Upgrade the runtime of the chain using the newly built WASM (it can be found in `$CARGO_TARGET_DIR/release/wbuild/<runtime name>/<runtime name>.compressed.wasm`) and the
extrinsic `system/setCode`.

After these steps the chain should be running the runtime using Partner Chains SDK v1.3.1. This version is
fully backwards-compatible and is a preparatory step towards v1.4.0

### Release new version using PC-SDK v1.4.0

This version of the node is backwards-compatible with the runtime in versions 1.3.x. and is needed to support
the runtime in version v1.4.0.

1. Update all Partner Chains SDK dependencies in your `Cargo.toml` file to `v1.4.0`
2. Modify your runtime and node code to be compatible with PC-SDK version v1.4.0. Consult the release notes for v1.4.0
for required changes.
3. Release a new version of your node. This step depends on your release process.
4. Upgrade nodes running the chain to the newly released version. This step depends on your deployment process.
1. Follow [this guide](./sdk-update-v1.3.1-to-v1.4.0.md) to update the code of your project.
2. Release a new version of your node. This step depends on your release process.
3. Upgrade nodes running the chain to the newly released version. This step depends on your deployment process.
Irrespective of the deployment details, the nodes should be run with the same keystores as previously.

After this step, the network should be composed of nodes v1.4.0 but the runtime would remain at v1.3.1,
Expand Down
35 changes: 35 additions & 0 deletions docs/developer-guides/sdk-update-v1.3.0-to-v1.3.1.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
# Migration from v1.3.0 to v1.3.1

This guide present steps required to migrate you project from Partner Chains SDK v1.3.0 to v1.3.1.

## Update SDK dependency

In your cargo.toml files, update the `partner-chains` dependency from `v1.3.0` to `v1.3.1`.

## Update Runtime

In your Runtime crate find where instance of `RuntimeVersion` is created and increase the `spec_version`,
because runtime code update is required.

In your Rutime find `impl pallet_sidechain::Config` for your runtime,
and add following code to it:
```rust
type MainChainScripts = sp_session_validator_management::MainChainScripts;

fn set_main_chain_scripts(scripts: Self::MainChainScripts) {
pallet_session_validator_management::MainChainScriptsConfiguration::<Runtime>::set(scripts);
}
```

If you have any Runtime test, is will be necessary to update mock as well:
```rust
type MainChainScripts = ();

fn set_main_chain_scripts(scripts: Self::MainChainScripts) {}
```

## Update the on-chain runtime code

Perform regular runtime code update procedure:
* update nodes to version build with Partner Chains SDK v1.3.1
* use `system/setCode` extrinsic to update runtime code build with Partner Chains SDK v1.3.1
91 changes: 91 additions & 0 deletions docs/developer-guides/sdk-update-v1.3.1-to-v1.4.0.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
# Migration from v1.3.1 to v1.4.0

This guide present steps required to migrate your project from partner-chains v1.3.0 to v1.3.1.

The most notable change in v1.4.0 is removal of the SidechainParams.
Sections about Node and Runtime update will explain how to deal with this removal.

## Update SDK dependency

Most probably your code depended on `chain-params` crate from `partner-chains`.
Please remove this dependency from your `Cargo.toml` files.

In your cargo.toml files, update the `partner-chains` dependency from `v1.3.1` to `v1.4.0`.

### Repository reorganization

Between v1.3 and v1.4 there was a major reorganization of the repository.

Reference runtime implementation crate `sidechain-runtime` has been moved to `node/runtime`,
and reference node implementation crate `partner-chains-node` has been moved to `node/node`.

All other crates have been moved to `toolkit` directory.

Crates names have not been changed.

## Update Runtime crate

In your Runtime crate find where instance of `RuntimeVersion` is created and increase the `spec_version`,
because runtime code update is required.

In you Runtime find `impl pallet_session_validator_management::Config` for your runtime type,
and replace
```rust
select_authorities(Sidechain::sidechain_params(), input, sidechain_epoch)
```
with
```rust
select_authorities(Sidechain::genesis_utxo(), input, sidechain_epoch)
```
because SidechainParameters were removed and the genesis UTXO is now the sole idenfier of the chain.

Find `impl pallet_sidechain::Config` and remove following code from it:
```rust
type SidechainParams = chain_params::SidechainParams;
```

In `impl_runtime_apis!` please replace:
```rust
impl sp_sidechain::GetSidechainParams<Block, SidechainParams> for Runtime {
fn sidechain_params() -> SidechainParams {
Sidechain::sidechain_params()
}
}
```
with
```rust
impl sp_sidechain::GetGenesisUtxo<Block> for Runtime {
fn genesis_utxo() -> UtxoId {
Sidechain::genesis_utxo()
}
}
```

In `impl authority_selection_inherents::filter_invalid_candidates::CandidateValidationApi` please replace:
```rust
authority_selection_inherents::filter_invalid_candidates::validate_registration_data(mainchain_pub_key, registration_data, &Sidechain::sidechain_params()).err()
```
with
```rust
authority_selection_inherents::filter_invalid_candidates::validate_registration_data(mainchain_pub_key, registration_data, Sidechain::genesis_utxo()).err()
```

If your have any Runtime test, is will be necessary to them by replacing mock SidechainParams with a mock UtxoId.

## Update Node crate

Replace `sp_sidechain::GetSidechainParams<Block, SidechainParams>` with `sp_sidechain::GetSidechainParams<Block>` in RPC implementation.

In the code used to build a chain spec, please update `sidechain: SidechainConfig` creation.
The `param` field is replaced with `genesis_utxo`.
To keep reading this value from environment, please use: `sp_sidechain::read_genesis_utxo_from_env_with_defaults`.

Example:
```rust
sidechain: SidechainConfig {
genesis_utxo: sp_sidechain::read_genesis_utxo_from_env_with_defaults()?,
..Default::default()
}
```

If your code has any tests in the node crate, please replace creation of mock `SidechainParams` with a mock `UtxoId`.
Loading