From 9268fc1f2fb9e3e2596e3772443c7e03ac87978c Mon Sep 17 00:00:00 2001 From: Alex Gherghisan Date: Tue, 3 Dec 2024 21:26:54 +0000 Subject: [PATCH] fix: publicly register class --- yarn-project/aztec.js/src/contract/deploy_method.ts | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/yarn-project/aztec.js/src/contract/deploy_method.ts b/yarn-project/aztec.js/src/contract/deploy_method.ts index 909c6b46bb5..262406f004b 100644 --- a/yarn-project/aztec.js/src/contract/deploy_method.ts +++ b/yarn-project/aztec.js/src/contract/deploy_method.ts @@ -89,6 +89,11 @@ export class DeployMethod extends Bas * it returns a promise for an array instead of a function call directly. */ public async request(options: DeployOptions = {}): Promise { + const deployment = await this.getDeploymentFunctionCalls(options); + + // NOTE: MEGA HACK. Remove with #10007 + // register the contract after generating deployment function calls in order to publicly register the class and (optioanlly) emit its bytecode + // // TODO: Should we add the contracts to the DB here, or once the tx has been sent or mined? // Note that we need to run this registerContract here so it's available when computeFeeOptionsFromEstimatedGas // runs, since it needs the contract to have been registered in order to estimate gas for its initialization, @@ -97,7 +102,6 @@ export class DeployMethod extends Bas // once this tx has gone through. await this.wallet.registerContract({ artifact: this.artifact, instance: this.getInstance(options) }); - const deployment = await this.getDeploymentFunctionCalls(options); const bootstrap = await this.getInitializeFunctionCalls(options); if (deployment.calls.length + bootstrap.calls.length === 0) {