From 089702313dea71b8e21df2d3d358e18dcec4ef40 Mon Sep 17 00:00:00 2001 From: Jeff Smale <6363749+jeffsmale90@users.noreply.github.com> Date: Wed, 11 Jan 2023 18:20:32 +1300 Subject: [PATCH] Add evm_transactionSimulation end point for experimental purposes --- src/chains/ethereum/ethereum/src/api.ts | 29 +++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/src/chains/ethereum/ethereum/src/api.ts b/src/chains/ethereum/ethereum/src/api.ts index c314523b67..cfbc0e2333 100644 --- a/src/chains/ethereum/ethereum/src/api.ts +++ b/src/chains/ethereum/ethereum/src/api.ts @@ -15,6 +15,7 @@ import { BaseFeeHeader, Block, RuntimeBlock } from "@ganache/ethereum-block"; import { Transaction, TransactionFactory, + calculateIntrinsicGas, TypedTransaction } from "@ganache/ethereum-transaction"; import { @@ -1914,6 +1915,34 @@ export default class EthereumApi implements Api { return null; } + async evm_simulateTransaction( + transaction: Ethereum.Transaction + ): Promise { + const data = Data.from(transaction.data); + const intrinsicGas = calculateIntrinsicGas( + data, + true, + this.#blockchain.common + ); + console.time("eth_simulateTransaction"); + const blockchain = this.#blockchain; + const minerOptions = this.#options.miner; + + const fromAddress = Address.from(transaction.from); + const toAddress = Address.from(transaction.to); + const code = await blockchain.accounts.getCode(toAddress); + const latest = blockchain.blocks.latest; + + const result = await blockchain.vm.evm.runCode({ + code: code.toBuffer(), + gasLimit: minerOptions.callGasLimit.toBigInt(), + caller: fromAddress, + address: toAddress, + data: data.toBuffer() + }); + console.timeEnd("eth_simulateTransaction"); + return Quantity.from(result.executionGasUsed + intrinsicGas); + } /** * Creates new message call transaction or a contract creation, if the data field contains code. *