From 4d1ad64d0072fbf2c2c0bc4846322c45afea9510 Mon Sep 17 00:00:00 2001 From: impelcrypto <92044428+impelcrypto@users.noreply.github.com> Date: Tue, 2 Jan 2024 21:37:43 +0800 Subject: [PATCH] fix: removed estimatedGas from sendEvmTransaction (#1107) --- src/v2/services/implementations/MetamaskWalletService.ts | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/v2/services/implementations/MetamaskWalletService.ts b/src/v2/services/implementations/MetamaskWalletService.ts index cbdd561dd..d9249e1be 100644 --- a/src/v2/services/implementations/MetamaskWalletService.ts +++ b/src/v2/services/implementations/MetamaskWalletService.ts @@ -124,9 +124,12 @@ export class MetamaskWalletService extends WalletService implements IWalletServi try { const web3 = new Web3(this.provider as any); const rawTx = await getRawEvmTransaction(web3, from, to, data, value); + + // Memo: passing this variable (estimatedGas) to `sendTransaction({gas: estimatedGas})` causes an error when sending `withdrawal` transactions. + // the function goes the catch statement if something goes wrong while getting the estimatedGas. This way, the UI prevents sending invalid transactions which could cause loss of assets. const estimatedGas = await web3.eth.estimateGas(rawTx); const transactionHash = await web3.eth - .sendTransaction({ ...rawTx, gas: estimatedGas }) + .sendTransaction({ ...rawTx }) .once('transactionHash', (transactionHash) => { this.eventAggregator.publish(new BusyMessage(true)); })