-
Notifications
You must be signed in to change notification settings - Fork 107
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into ron/transact-from-eth-to-sub
- Loading branch information
Showing
13 changed files
with
273 additions
and
22 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,33 @@ | ||
// SPDX-License-Identifier: Apache-2.0 | ||
// SPDX-FileCopyrightText: 2023 Snowfork <[email protected]> | ||
pragma solidity 0.8.23; | ||
|
||
import {AgentExecutor} from "./AgentExecutor.sol"; | ||
import {Gateway} from "./Gateway.sol"; | ||
import {ParaID} from "./Types.sol"; | ||
import {Script} from "forge-std/Script.sol"; | ||
import {stdJson} from "forge-std/StdJson.sol"; | ||
|
||
contract DeployGatewayLogic is Script { | ||
using stdJson for string; | ||
|
||
function setUp() public {} | ||
|
||
function run() public { | ||
uint256 privateKey = vm.envUint("PRIVATE_KEY"); | ||
address deployer = vm.rememberKey(privateKey); | ||
vm.startBroadcast(deployer); | ||
|
||
address beefyClient = vm.envAddress("BEEFY_CLIENT_CONTRACT_ADDRESS"); | ||
|
||
ParaID bridgeHubParaID = ParaID.wrap(uint32(vm.envUint("BRIDGE_HUB_PARAID"))); | ||
bytes32 bridgeHubAgentID = vm.envBytes32("BRIDGE_HUB_AGENT_ID"); | ||
|
||
uint8 foreignTokenDecimals = uint8(vm.envUint("FOREIGN_TOKEN_DECIMALS")); | ||
|
||
AgentExecutor executor = new AgentExecutor(); | ||
new Gateway(address(beefyClient), address(executor), bridgeHubParaID, bridgeHubAgentID, foreignTokenDecimals); | ||
|
||
vm.stopBroadcast(); | ||
} | ||
} |
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
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
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
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,27 @@ | ||
--- | ||
description: >- | ||
In a case of an emergency (e.g. a exploitable vulnerability found), the bridge | ||
needs to be halted so that no messages can be processed. | ||
--- | ||
|
||
# Halt Bridge in Case of Emergency | ||
|
||
### Halting Mechanism | ||
|
||
The bridge is halted through a storage item in each Snowbridge pallet called `OperatingMode` . | ||
|
||
Possible operating mode states are: | ||
|
||
* `Normal` | ||
* `Halted` (`RejectingOutboundMessages` for the `system` pallet) | ||
|
||
If the operating mode is set to [`Halted`](https://github.com/Snowfork/polkadot-sdk/blob/2536e780bf6af052e1d9e85a8b2648aae91ec6d7/bridges/snowbridge/primitives/core/src/operating\_mode.rs#L12), no bridge messages will be processed. Each pallet needs to be disabled individually. Here are the pallets that need to be disabled, with the call hash to do so: | ||
|
||
* Ethereum client pallet: `0x520301` | ||
* Inbound queue pallet: `0x500101` | ||
* Outbound queue pallet: `0x510001` | ||
* Ethereum system pallet: `0x530101` | ||
|
||
These extrinsics should be done from the relay chain, descending to the BridgeHub parachain origin, similar to the [force beacon checkpoint call](https://app.gitbook.com/o/bDGMcdShFBeGc3v6VzHf/s/tC80IPpnYgEJmgOYIpqZ/\~/changes/72/runbooks/initialize-ethereum-light-client-with-forced-checkpoint). | ||
|
||
If the bridge was halted, no messages will be processed. When the operating mode is changed to `normal` messages will be continue being processed. |
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,85 @@ | ||
--- | ||
description: >- | ||
How to upgrade the Ethereum gateway controlling the bridge on the Ethereum | ||
side. | ||
--- | ||
|
||
# Initial Deployment of Gateway Contracts | ||
|
||
### Build and Deploy Contracts | ||
|
||
To build and deploy the new contracts, follow these steps from inside the [Snowbridge repository](https://github.com/snowfork/snowbridge): | ||
|
||
#### Generate BEEFY State | ||
|
||
Set the following in .env file: | ||
|
||
```bash | ||
export RELAYCHAIN_ENDPOINT= <relay chain endpoint> | ||
export BEEFY_START_BLOCK= # default is 1 | ||
``` | ||
|
||
The BEEFY start block can be selected from a recent block that has a BEEFY commitment. | ||
|
||
Run `scripts/generate-beefy-checkoutpoint.sh`. This will leave the beefy state in the contracts folder. | ||
|
||
#### Deploy Contracts | ||
|
||
Set the following in .env file: | ||
|
||
```bash | ||
# Secret | ||
export INFURA_PROJECT_ID=<secret> | ||
export ETHERSCAN_API_KEY=<secret> | ||
export DEPLOYER_ETH_KEY=<secret> | ||
|
||
# Chain | ||
export ETH_NETWORK=< sepolia /mainnet > | ||
export ETH_NETWORK_ID=< 11155111 /1 > | ||
|
||
# Endpoints | ||
export RELAYCHAIN_ENDPOINT=wss://rococo-rpc.polkadot.io | ||
export ETH_RPC_ENDPOINT=https://sepolia.infura.io/v3 | ||
export ETH_WS_ENDPOINT=wss://sepolia.infura.io/ws/v3 | ||
export BEACON_HTTP_ENDPOINT=https://lodestar-sepolia.chainsafe.io | ||
|
||
# Beefy | ||
export BEEFY_START_BLOCK=8592280 # Default value | ||
export MINIMUM_REQUIRED_SIGNATURES=16 | ||
export ETH_RANDAO_DELAY=128 # 4 epochs=128 slots=25.6mins | ||
export ETH_RANDAO_EXP=6 # 6 slots before expired | ||
|
||
# Channels and Agents | ||
export BRIDGE_HUB_PARAID=1013 | ||
export BRIDGE_HUB_AGENT_ID=0x03170a2e7597b7b7e3d84c05391d139a62b157e78786d8c082f29dcf4c111314 | ||
export ASSET_HUB_PARAID=1000 | ||
export ASSET_HUB_AGENT_ID=0x81c5ab2571199e3188135178f3c2c8e2d268be1313d029b30f534fa579b69b79 | ||
export REJECT_OUTBOUND_MESSAGES=false | ||
|
||
# Fees | ||
export CREATE_ASSET_FEE=10000000000 | ||
export DELIVERY_COST=10000000000 | ||
export EXCHANGE_RATE=25000000000000 | ||
export REGISTER_TOKEN_FEE=5000000000000000000 | ||
export RESERVE_TRANSFER_FEE=10000000000 | ||
|
||
export FOREIGN_TOKEN_DECIMALS=12 | ||
|
||
# Initial agents deposits. Set low on purpose as they can be topped up manually | ||
export ETH_BRIDGE_HUB_INITIAL_DEPOSIT=1000000 | ||
``` | ||
|
||
Run `scripts/deploy-contracts.sh` | ||
|
||
Back up `contracts.json` and contract artifacts to s3: [https://s3.console.aws.amazon.com/s3/buckets/snowbridge-rococo-demo?region=eu-central-1\&bucketType=general\&tab=objects](https://s3.console.aws.amazon.com/s3/buckets/snowbridge-rococo-demo?region=eu-central-1\&bucketType=general\&tab=objects) | ||
|
||
Confirm settings with the team and get ETH for the deployment.  | ||
|
||
Add contracts to tenderly | ||
|
||
### Update the EthereumGatewayAddress on BridgeHub | ||
|
||
To update the `EthereumGateway` [contract address](https://github.com/Snowfork/polkadot-sdk/blob/snowbridge/bridges/snowbridge/pallets/inbound-queue/src/lib.rs#L112), a set storage call is executed: | ||
|
||
* Example call hash: `0xff00630003000100d50f03082f000006020700c817a804824f1200a400040440aed97c7854d601808b98ae43079dafb3505b4909ce6ca82d2ce23bd46738953c7959e710cd` | ||
* Link to pre-populate on Rococo: [https://polkadot.js.org/apps/?rpc=wss%3A%2F%2Frococo-rpc.polkadot.io#/extrinsics/decode/0xff00630003000100d50f03082f000006020700c817a804824f1200a400040440aed97c7854d601808b98ae43079dafb3505b4909ce6ca82d2ce23bd46738953c7959e710cd](https://polkadot.js.org/apps/?rpc=wss%3A%2F%2Frococo-rpc.polkadot.io#/extrinsics/decode/0xff00630003000100d50f03082f000006020700c817a804824f1200a400040440aed97c7854d601808b98ae43079dafb3505b4909ce6ca82d2ce23bd46738953c7959e710cd\)) |
33 changes: 33 additions & 0 deletions
33
docs/runbooks/initialize-ethereum-light-client-with-forced-checkpoint.md
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,33 @@ | ||
--- | ||
description: >- | ||
Generate a beacon checkpoint to sync the Ethereum client from. This is done on | ||
bridge initialization or forced sync reset. | ||
--- | ||
|
||
# Initialize Ethereum light client with Forced Checkpoint | ||
|
||
## Generate Checkpoint Data | ||
|
||
On the server where the relayer is deployed, run the following command: | ||
|
||
``` | ||
relayer/build/snowbridge-relay generate-beacon-checkpoint --url http://127.0.0.1:9596 | ||
``` | ||
|
||
The command will output the beacon checkpoint data in hex form. Prepend `0x5200` to the resulting hex (the [Ethereum client pallet index](https://github.com/Snowfork/polkadot-sdk/blob/snowbridge/cumulus/parachains/runtimes/bridge-hubs/bridge-hub-rococo/src/lib.rs#L730) and the `force_checkpoint` [call index](https://github.com/Snowfork/polkadot-sdk/blob/snowbridge/bridges/snowbridge/pallets/ethereum-client/src/lib.rs#L216) combined). | ||
|
||
### Call Force Checkpoint from Relay Chain | ||
|
||
Use the resulting call data to make the Transact call to set the beacon checkpoint. | ||
|
||
* call hash: `0xff00630003000100d50f03082f00000602070008d6e82982ee3600a5025200821017d7c8b03a2a182824cfe569187a28faa718368a0ace36e2b1b8b6dbd7f8093c0594aa8a9c557dabac173fac324158e77fb5840738a1a541f633cbec8884c6a601c567d2b376a05392000000000000000002101851a76c1adff357d59b36327d02cfb7f718368a0ace36e2b1b8b6dbd7f8093c0594aa8a9c557dabac173fac324158e77fb5840738a1a541f633cbec8884c6a601c567d2b376a05392000000000000000000` | ||
* link to pre-populate on Rococo: [https://polkadot.js.org/apps/?rpc=wss%3A%2F%2Frococo-rpc.polkadot.io#/extrinsics/decode/0xff00630003000100d50f03082f00000602070008d6e82982ee3600a5025200821017d7c8b03a2a182824cfe569187a28faa718368a0ace36e2b1b8b6dbd7f8093c0594aa8a9c557dabac173fac324158e77fb5840738a1a541f633cbec8884c6a601c567d2b376a05392000000000000000002101851a76c1adff357d59b36327d02cfb7f718368a0ace36e2b1b8b6dbd7f8093c0594aa8a9c557dabac173fac324158e77fb5840738a1a541f633cbec8884c6a601c567d2b376a05392000000000000000000](https://polkadot.js.org/apps/?rpc=wss%3A%2F%2Frococo-rpc.polkadot.io#/extrinsics/decode/0xff00630003000100d50f03082f00000602070008d6e82982ee3600a5025200821017d7c8b03a2a182824cfe569187a28faa718368a0ace36e2b1b8b6dbd7f8093c0594aa8a9c557dabac173fac324158e77fb5840738a1a541f633cbec8884c6a601c567d2b376a05392000000000000000002101851a76c1adff357d59b36327d02cfb7f718368a0ace36e2b1b8b6dbd7f8093c0594aa8a9c557dabac173fac324158e77fb5840738a1a541f633cbec8884c6a601c567d2b376a05392000000000000000000) | ||
|
||
Replace the encoded call bytes highlighted in the screenshot below with the checkpoint data generated in the previous step: | ||
|
||
<figure><img src="../.gitbook/assets/Screenshot 2024-02-16 at 11.21.53.png" alt=""><figcaption><p>Replace encoded call bytes with hex generated in the first step.</p></figcaption></figure> | ||
|
||
|
||
|
||
|
||
|
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