-
Notifications
You must be signed in to change notification settings - Fork 66
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
6716b95
commit 9c41744
Showing
2 changed files
with
118 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,117 @@ | ||
<!-- markdownlint-disable MD028 --> | ||
# Upgrade guide for Cartesi Rollups Node `v1.5` | ||
|
||
Release `v1.5` brings a change in the way the Cartesi Rollups Node calculate epochs. | ||
They are now calculated based on block numbers intead of timestamps. | ||
|
||
> [!WARNING] | ||
> This release contains a **BREAKING CHANGE** that fixes issue [#432](https://github.com/cartesi/rollups-node/issues/432), where epochs may be closed wrongly between restarts of the Cartesi Rollups Node, eventually triggering a `ClaimMismatch` error, which causes the Cartesi Rollups Node to abrubtly shut down. | ||
> [!IMPORTANT] | ||
> It's highly recommended that application owners upgrade their instances of the Cartesi Rollups Node to `v1.5`, had their applications being affected by the issue above or not. | ||
## What has changed | ||
|
||
The way the Cartesi Rollups Node calculates epochs has changed starting on version 1.5. | ||
This procedure is now based on the `CARTESI_EPOCH_LENGTH` environment variable instead of `CARTESI_EPOCH_DURATION`. | ||
|
||
The value of `CARTESI_EPOCH_LENGTH` (blocks) may be derived from `CARTESI_EPOCH_DURATION` (seconds) as follows: | ||
|
||
`CARTESI_EPOCH_LENGTH = CARTESI_EPOCH_DURATION/BLOCK_TIME` | ||
|
||
Where `BLOCK_TIME` corresponds to the duration it takes to generate a block in the target network. | ||
|
||
> [!TIP] | ||
> Suppose a block is created every `12` seconds and `CARTESI_EPOCH_DURATION` is set to `86400` seconds (24 hours). | ||
> | ||
> So, `CARTESI_EPOCH_LENGTH = 86400/12 = 7200` | ||
Check the [`CHANGELOG`](./CHANGELOG.md) and the [configuration](./docs/config.md) for more details. | ||
|
||
## How to upgrade | ||
|
||
Application owners may decide to redeploy their applications, upgrading their instances of the Cartesi Rollups Node to release `v.1.5`. | ||
This is the simplest way to perform the upgrade. | ||
|
||
In order to do so, just update the application configuration considering [what has changed](#what-has-changed) and upgrade the version of the Cartesi Rollups Node as usual. | ||
|
||
> [!CAUTION] | ||
> A redeployment will create a new instance of the application from scratch. | ||
> All previous inputs, outputs and claims will remain associated to the previous application address, funds included. | ||
Alternatively, if the application owner wants to keep the application inputs, they may choose to replace the _History_ being used by the application's _Authority_ instead. | ||
This process is a little bit more involved and is described in the next section. | ||
|
||
## Steps to replace an Application's _History_ | ||
|
||
> [!CAUTION] | ||
> Instances of the [History](https://github.com/cartesi/rollups-contracts/blob/v1.4.0/onchain/rollups/contracts/history/History.sol) contract from [rollups-contracts v.1.4.0](https://github.com/cartesi/rollups-contracts/releases/tag/v1.4.0) may be used simultaneously by several applications through their associated _Authority_ instance. | ||
> Application owners must consider that and exercise care when performing the steps listed below. | ||
To keep the application inputs, before performing the upgrade to version `v1.5.`, proceed as described in the sub-sections below. | ||
|
||
### 1. Instantiate a new _History_ | ||
|
||
This is a two-step process. | ||
First, the address of the new _History_ instance should be calculated. | ||
|
||
> [!NOTE] | ||
> It's recommended to use the deterministic functions available in the Rollups Contracts. | ||
> [!IMPORTANT] | ||
> The commands below assumes that the following environment variables have been previous defined: | ||
> | ||
> - `CONTRACT_OWNER_ADDRESS`: address of the wallet used by the application owner | ||
> - `SALT`: salt to be used by the deterministic deployment functions | ||
> - `RPC_URL`: the RPC endpoint to be used | ||
> - `MNEMONIC`: mnemonic phrase for the application owner's wallet (other wallet options may be used) | ||
> - `HISTORY_FACTORY_ADDRESS`: address of a valid _History Factory_ instance | ||
> - `AUTHORITY_ADDRESS`: address of the _Authority_ instance being used by the application | ||
In order to calculate the new address, the owner may call function [`calculateHistoryAddress(address, bytes32)`](https://github.com/cartesi/rollups-contracts/blob/e8a2d82bc51167086e7928b9a6aced0d62c96cf8/onchain/rollups/contracts/history/HistoryFactory.sol#L35-L38). | ||
This can be done with the the help of Foundry's [cast](https://book.getfoundry.sh/reference/cast/) as follows: | ||
|
||
```shell | ||
cast call \ | ||
--trace --verbose \ | ||
$HISTORY_FACTORY_ADDRESS \ | ||
"calculateHistoryAddress(address,bytes32)(address)" \ | ||
$CONTRACT_OWNER_ADDRESS \ | ||
$SALT \ | ||
--rpc-url "$RPC_URL" | ||
``` | ||
|
||
Assuming the command execution is successfull, set the resulting address as a new environment variable `NEW_HISTORY_ADDRESS`, to be used later on. | ||
|
||
After that, the new instance of _History_ may be created by calling function [`newHistory(address, bytes32)`](https://github.com/cartesi/rollups-contracts/blob/e8a2d82bc51167086e7928b9a6aced0d62c96cf8/onchain/rollups/contracts/history/HistoryFactory.sol#L24-L27) as follows: | ||
|
||
```shell | ||
cast send \ | ||
--json \ | ||
--mnemonic "$MNEMONIC" \ | ||
$HISTORY_FACTORY_ADDRESS \ | ||
"newHistory(address,bytes32)(History)" \ | ||
$CONTRACT_OWNER_ADDRESS \ | ||
$SALT \ | ||
--rpc-url "$RPC_URL" | ||
``` | ||
|
||
### 2. Replace the _History_ | ||
|
||
> [!IMPORTANT] | ||
> The command below assumes that the environment variables set in the previous step are available, as well as `NEW_HISTORY_ADDRESS`, which must contain the address of the new _History_. | ||
To replace the _History_ used by the _Authority_, call [`setHistory(_history)`](https://github.com/cartesi/rollups-contracts/blob/e8a2d82bc51167086e7928b9a6aced0d62c96cf8/onchain/rollups/contracts/consensus/authority/Authority.sol#L65) as follows: | ||
|
||
```shell | ||
cast send \ | ||
--json \ | ||
--mnemonic "$MNEMONIC" \ | ||
"$AUTHORITY_ADDRESS" \ | ||
"setHistory(address)" \ | ||
"$NEW_HISTORY_ADDRESS" \ | ||
"$SALT" \ | ||
--rpc-url "$RPC_URL" | ||
``` | ||
|
||
After the _History_ replacement is complete, one must update `CARTESI_CONTRACTS_HISTORY_ADDRESS` with the new _History_ address in the application configuration and proceed with the upgrade of the Cartesi Rollups Node as usual. |