From 5a05b47dcd05e711de4e8a6eb23f9a96d2abe17f Mon Sep 17 00:00:00 2001 From: CAst Date: Mon, 11 Dec 2023 15:44:19 +0500 Subject: [PATCH] Gas margin 10% (#45) * [defence-for-gas-limit] gas margin 10% * [defence-for-gas-limit] add comment --- src/contracts/vaultMulticall.ts | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/contracts/vaultMulticall.ts b/src/contracts/vaultMulticall.ts index fc681de6..c2bfff94 100644 --- a/src/contracts/vaultMulticall.ts +++ b/src/contracts/vaultMulticall.ts @@ -104,14 +104,25 @@ const vaultMulticall = async (values: VaultMulticallInput): P } as T } + // Even though ethers tries to find the best price for gas, sometimes it's + // not enough and the transaction breaks down and users lose money for gas. + // Adding 10% to the gas limit + if (isSoloCall) { const { method, args } = params[0] // @ts-ignore: no types to describe - return contract[method](...args) + const estimatedGas = await contract[method].estimateGas(...args) + const gasLimit = estimatedGas * 110n / 100n + + // @ts-ignore: no types to describe + return contract[method](...args, { gasLimit }) } - return contract.multicall(calls) as T + const estimatedGas = await contract.multicall.estimateGas(calls) + const gasLimit = estimatedGas * 110n / 100n + + return contract.multicall(calls, { gasLimit }) as T }