From b0711983a5f72f9b3236e6cbcef3dae7a424a09c Mon Sep 17 00:00:00 2001 From: alvarius Date: Mon, 23 Sep 2024 13:19:44 +0100 Subject: [PATCH] fix(cli): wait for world init before transferring ownership (#3220) --- .changeset/strong-llamas-learn.md | 5 +++ packages/cli/src/deploy/deployCustomWorld.ts | 37 ++++++++++---------- 2 files changed, 23 insertions(+), 19 deletions(-) create mode 100644 .changeset/strong-llamas-learn.md diff --git a/.changeset/strong-llamas-learn.md b/.changeset/strong-llamas-learn.md new file mode 100644 index 0000000000..a8ef41c9cc --- /dev/null +++ b/.changeset/strong-llamas-learn.md @@ -0,0 +1,5 @@ +--- +"@latticexyz/cli": patch +--- + +If the project is using a custom world, the deployer now waits for the init transaction to be confirmed before transferring ownership of the world. diff --git a/packages/cli/src/deploy/deployCustomWorld.ts b/packages/cli/src/deploy/deployCustomWorld.ts index 8be55baaa7..54016b47c9 100644 --- a/packages/cli/src/deploy/deployCustomWorld.ts +++ b/packages/cli/src/deploy/deployCustomWorld.ts @@ -97,26 +97,25 @@ export async function deployCustomWorld({ const deploy = logsToWorldDeploy(receipt.logs); debug("deployed custom world to", deploy.address, "at block", deploy.deployBlock); - const initTxs = await Promise.all([ - // initialize world via init module - writeContract(client, { - chain: client.chain ?? null, - address: deploy.address, - abi: worldAbi, - functionName: "initialize", - args: [contracts.InitModule.address], - }), - // transfer root namespace to deployer - writeContract(client, { - chain: client.chain ?? null, - address: deploy.address, - abi: worldAbi, - functionName: "transferOwnership", - args: [resourceToHex({ type: "namespace", namespace: "", name: "" }), client.account.address], - }), - ]); + // initialize world via init module + const initTx = await writeContract(client, { + chain: client.chain ?? null, + address: deploy.address, + abi: worldAbi, + functionName: "initialize", + args: [contracts.InitModule.address], + }); + await waitForTransactions({ client, hashes: [initTx], debugLabel: "world init" }); - await waitForTransactions({ client, hashes: initTxs, debugLabel: "world init" }); + // transfer root namespace to deployer after init module is installed so `transferOwnership` method is available + const transferOwnershipTx = await writeContract(client, { + chain: client.chain ?? null, + address: deploy.address, + abi: worldAbi, + functionName: "transferOwnership", + args: [resourceToHex({ type: "namespace", namespace: "", name: "" }), client.account.address], + }); + await waitForTransactions({ client, hashes: [transferOwnershipTx], debugLabel: "world ownership transfer" }); return { ...deploy, stateBlock: deploy.deployBlock }; }