Deploy Hyperlane
Deploy Hyperlane to any smart contract environment of your choice.
Hyperlane is designed to be deployed to new chains by anyone, at any time.
This tutorial is intended for users who want to deploy Hyperlane to a new EVM chain.
By the end of this guide you will have deployed and configured the Hyperlane Messaging API, allowing developers to send interchain messages to and from your chain.
At a high level, deploying Hyperlane requires the following actions:
#1.-setup-keys that you will use to deploy contracts and run validators and relayers
#2.-deploy-contracts to the local chain and to every remote chain with which the local chain will be able to send and receive messages.
#3.-run-validators on your local chain, to provide the signatures needed for the Interchain security modules you deployed in step (2)
#4.-run-relayer to send and receive messages between chains set up in the #2.-deploy-contracts step.
#5.-send-test-messages to confirm that your relayer is able to deliver messages from and to each pair of chains
1. Setup keys
In order to complete this guide, you first need to set up the following:
Key Type | Description | Needs Funding? |
---|---|---|
Contract Deployer | 32 byte hexadecimal private key | Yes, on all the chains on which we need to deploy contracts. |
Validator Accounts | A list of validator addresses for your local chain are needed to configure the Multisig ISMs. The configuration is a list of | Yes, a small amount to do announce the location of the validator signatures (could be done by a different key in production) |
Relayer Accounts | The relayer client(s) use one account on the local chain and an additional account for each of the remote chains. | Yes. Each relayer instance must be configured with a key that has a balance on all the other chains. Use the chains' faucet to get tokens if they are testnets, for the core chains, you can find a list of faucets under Token sources & faucets. |
When testing out this guide, you can use the same hexadecimal key for all three roles for simplicity.
For instructions on how to generate keys, see Agent keys. Your deployer key must be a hexadecimal key, while validator and relayer keys can be hexadecimal or AWS KMS.
If deploying on a local network using Foundry's Anvil, use the following command to fund your newly-generated account. It uses one of the pre-funded private keys to transfer 1 ETH to the address in the $YOUR_PUBLIC_KEY
variable.
Do not proceed to the next section until you have set up deployer, validator, and relayer keys.
2. Deploy contracts
Overview
In this step we will be deploying Hyperlane smart contracts to the local and remote chains.
On the local chain, we will deploy:
The core contracts, including a Mailbox that can be used to send and receive messages
On all chains, we will deploy:
A Multisig ISM that can be used to verify inbound messages
A InterchainGasPaymasters, which can be used to pay our relayer for delivering interchain messages
A
TestRecipient
, which we will send messages to, in order to test that everything is working correctly
Setup
If you have not yet set up your deployer, validator, and relayer keys, see #1.-setup-keys
First, set up the hyperlane-deploy
repo. This repo contain scripts to deploy Hyperlane contracts. You will need to install yarn
if you haven't already.
Next, add a ChainMetadata
entry for your local chain to hyperlane-deploy/config/chains.ts
. An example has been populated for you for anvil
.
Any chains that already have Hyperlane deployments do not need to be configured here (see chainMetadata.ts for a list of chains for which metadata has already been provided).
Finally, add the MultisigIsmConfig
entry for your local chain to hyperlane-deploy/config/multisig_ism.ts
. An example with a single validator has been populated for you for anvil
.
Any chains that already have Hyperlane deployments do not need to be configured here (see multisigIsm.ts for a list of chains for which ISM configs have already been provided).
Deploy
You can then run yarn ts-node scripts/deploy-hyperlane.ts
to deploy the Hyperlane contracts. You will need to provide the following arguments:
local
: The local chain on which Hyperlane is being deployedremotes
: The chains with which 'local' will be able to send and receive messageskey
: A hexadecimal private key for transaction signing
An example deployment command to anvil
that supports communication with goerli
and sepolia
is shown below:
The deploy script will only accept chains for which configuration has been provided. If you do not see your desired chain in the list of choices, you may be missing config in chains.ts
or multisig_ism.ts
Verify
If everything ran successfully, congrats! You should see contract addresses written to artifacts/addresses.json
, and agent config written to artifacts/agent_config.json
3. Run validators
Follow the Validators guide to run validators for the Mailboxon your local chain. These validators will provide the security for messages sent from your chain to remote chains.
Include the agent config from the #2.-deploy-contracts step in CONFIG_FILES
. If you're using Docker, you will need to mount the file into the container.
You should have already set up your validator keys in step #1.-setup-keys, so you can skip that part of the Validators guide.
Make sure these validators match the addresses you provided when in your MultisigIsmConfig
. Otherwise, the Multisig ISMs you deployed in the previous step will not be able to verify messages sent from your chain.
4. Run relayer
Follow the Relayers guide to run a relayer that will deliver interchain messages sent between the local and remote chains.
Remember to set --relayChains
or HYP_BASE_RELAYCHAINS
appropriately.
Include the agent config from the #2.-deploy-contracts step in CONFIG_FILES
. If you're using Docker, you will need to mount the file into the container.
You should have already set up your relayer keys in step #1.-setup-keys, so you can skip that part of the Relayers guide.
Relayers5. Send test messages
You can check everything is working correctly by sending a test message between each pair of chains.
You can run yarn ts-node scripts/test-messages.ts
to send test messages. You will need to provide the following arguments:
chains
: Test messages will be sent between each pair of these chainskey
: A hexadecimal private key for transaction signing
An example command that tests that messages can be sent between any pair of anvil
, goerli
, and sepolia
is shown below:
If everything ran successfully, congrats! You should something similar to the following output:
If you've waited a while and messages still aren't being delivered, take a look at the origin chain relayer logs and reach out on discord.
Last updated