Add chains to the client
In this tutorial you modify a template application to use a public blockchain instead of anvil
(opens in a new tab).
Note that this is not required if you are going to use Lattice chains, redstone (opens in a new tab) and garnet (opens in a new tab)
Setup
Create a new MUD application from the template. Use the vanilla template.
pnpm create mud@latest --name tutorial --template vanilla
cd tutorial
pnpm install
pnpm dev
You can also use the react-ecs
or threejs
templates without any changes to the tutorial.
If you wish to use the react
template you'll need to modify a bit to account for the use of Zustand instead of RECs.
File changes
You need to edit supportedChains.ts
, and possibly also setupNetwork.ts
.
-
Edit the file
packages/client/src/mud/supportedChains.ts
to add the chain definition from Viem. You can see the list of chains supported by Viem (opens in a new tab). If you need a different chain you can usedefineChain
(opens in a new tab).supportedChains.tsimport { MUDChain, mudFoundry, redstone, garnet } from "@latticexyz/common/chains"; import { holesky } from "viem/chains"; export const supportedChains: MUDChain[] = [mudFoundry, redstone, garnet, holesky];
-
If the chain object in Viem doesn't have a webSocket endpoint, only an HTTP one, you need to edit
packages/client/src/mud/setupNetwork.ts
(opens in a new tab) to only use a webSocket endpoint when one is defined. You might also wish to deal with the possibility you only have a webSocket endpoint defined, depending on the chains you support.
Use the application
When you run the client, set two parameters:
chainId
, the chain ID. You can set this information in the URL, or in the vite environment asVITE_CHAIN_ID
.initialBlockNumber
, the block number where theWorld
contract was first deployed. Without this value, the client will try to synchronize from the beginning of the blockchain, which could take a long time. You can set this value either in the URL, or theworlds.json
file (asblockNumber
).
For example, to connect to the Holesky World
at address 0x78900cc99939b24a95b2892961ad0c701df97993
(opens in a new tab), which contains the standard contract code, you use this URL:
http://localhost:3000/?chainid=17000
And this file in packages/contracts/worlds.json
:
{
"31337": {
"address": "0x8d8b6b8414e1e3dcfd4168561b9be6bd3bf6ec4b"
},
"17000": {
"address": "0x78900cc99939b24a95b2892961ad0c701df97993",
"blockNumber": 1844083
}
}