From fbec62d424273acd9e3dac9a04ab971195c7e535 Mon Sep 17 00:00:00 2001 From: Michael Moldoveanu Date: Fri, 11 Aug 2023 10:02:10 -0700 Subject: [PATCH] fix: send transaction clobbers fee (fixes #67) (#78) --- packages/core/src/provider/base.ts | 26 ++++++++++++++++++-------- 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/packages/core/src/provider/base.ts b/packages/core/src/provider/base.ts index 3b2e32e613..5cfb11fea1 100644 --- a/packages/core/src/provider/base.ts +++ b/packages/core/src/provider/base.ts @@ -159,16 +159,21 @@ export class SmartAccountProvider< throw new Error("transaction is missing to address"); } + const overrides: UserOperationOverrides = {}; + if (request.maxFeePerGas) { + overrides.maxFeePerGas = request.maxFeePerGas; + } + if (request.maxPriorityFeePerGas) { + overrides.maxPriorityFeePerGas = request.maxPriorityFeePerGas; + } + const { hash } = await this.sendUserOperation( { target: request.to, data: request.data ?? "0x", value: request.value ? fromHex(request.value, "bigint") : 0n, }, - { - maxFeePerGas: request.maxFeePerGas, - maxPriorityFeePerGas: request.maxPriorityFeePerGas, - } + overrides ); return await this.waitForUserOperationTransaction(hash as Hash); @@ -239,11 +244,16 @@ export class SmartAccountProvider< .filter((x) => x.maxPriorityFeePerGas != null) .map((x) => fromHex(x.maxPriorityFeePerGas!, "bigint")) ); + const overrides: UserOperationOverrides = {}; + if (maxFeePerGas != null) { + overrides.maxFeePerGas = maxFeePerGas; + } - const { hash } = await this.sendUserOperation(batch, { - maxFeePerGas, - maxPriorityFeePerGas, - }); + if (maxPriorityFeePerGas != null) { + overrides.maxPriorityFeePerGas = maxPriorityFeePerGas; + } + + const { hash } = await this.sendUserOperation(batch, overrides); return await this.waitForUserOperationTransaction(hash as Hash); };