From 4a6c7b17d3c6731a0bfe1945829cecbee3ca0335 Mon Sep 17 00:00:00 2001 From: Wodann Date: Wed, 18 Dec 2024 11:21:47 +0000 Subject: [PATCH 1/2] feat: specify genesis state for L1 --- .../network-manager/edr/edr-provider.ts | 42 ++++++++++++++++--- 1 file changed, 36 insertions(+), 6 deletions(-) diff --git a/v-next/hardhat/src/internal/builtin-plugins/network-manager/edr/edr-provider.ts b/v-next/hardhat/src/internal/builtin-plugins/network-manager/edr/edr-provider.ts index ef03ab6a77..94790b4e18 100644 --- a/v-next/hardhat/src/internal/builtin-plugins/network-manager/edr/edr-provider.ts +++ b/v-next/hardhat/src/internal/builtin-plugins/network-manager/edr/edr-provider.ts @@ -32,11 +32,14 @@ import EventEmitter from "node:events"; import util from "node:util"; import { + Account, EdrContext, createModelsAndDecodeBytecodes, initializeVmTraceDecoder, SolidityTracer, VmTracer, + BEACON_ROOTS_ADDRESS, + BEACON_ROOTS_BYTECODE, GENERIC_CHAIN_TYPE, OPTIMISM_CHAIN_TYPE, genericChainProviderFactory, @@ -69,6 +72,7 @@ import { } from "./utils/convert-to-edr.js"; import { getHardforkName } from "./utils/hardfork.js"; import { printLine, replaceLastLine } from "./utils/logger.js"; +import { HardforkName } from "./types/hardfork.js"; const log = debug("hardhat:core:hardhat-network:provider"); @@ -100,6 +104,24 @@ interface EdrProviderConfig { jsonRpcRequestWrapper?: JsonRpcRequestWrapperFunction; } +function localL1GenesisState(hardfork: HardforkName): Account[] { + if (hardfork < HardforkName.CANCUN) { + return []; + } + + return [ + { + address: Uint8Array.from( + Buffer.from(BEACON_ROOTS_ADDRESS.slice(2), "hex"), + ), + balance: 0n, + nonce: 0n, + code: Uint8Array.from(Buffer.from(BEACON_ROOTS_BYTECODE.slice(2), "hex")), + storage: [], + }, + ]; +} + export class EdrProvider extends EventEmitter implements EthereumProvider { readonly #provider: Provider; readonly #vmTraceDecoder: VmTraceDecoder; @@ -159,6 +181,13 @@ export class EdrProvider extends EventEmitter implements EthereumProvider { const hardforkName = getHardforkName(networkConfig.hardfork); + const genesisState = + fork !== undefined + ? [] + : networkConfig.chainType === "optimism" + ? [] // TODO: Add local Optimism genesis state + : localL1GenesisState(hardforkName); + const context = await getGlobalEdrContext(); const provider = await context.createProvider( networkConfig.chainType === "optimism" @@ -178,12 +207,7 @@ export class EdrProvider extends EventEmitter implements EthereumProvider { enableRip7212: networkConfig.enableRip7212, fork, hardfork: ethereumsjsHardforkToEdrSpecId(hardforkName), - genesisAccounts: networkConfig.genesisAccounts.map((account) => { - return { - secretKey: account.privateKey, - balance: BigInt(account.balance), - }; - }), + genesisState, initialDate, initialBaseFeePerGas: networkConfig.initialBaseFeePerGas !== undefined @@ -202,6 +226,12 @@ export class EdrProvider extends EventEmitter implements EthereumProvider { }, }, networkId: BigInt(networkConfig.networkId), + ownedAccounts: networkConfig.genesisAccounts.map((account) => { + return { + secretKey: account.privateKey, + balance: BigInt(account.balance), + }; + }), }, { enable: loggerConfig.enabled, From b074a621f9282dbf85314e4766ce5e21c888bb61 Mon Sep 17 00:00:00 2001 From: Wodann Date: Fri, 20 Dec 2024 12:42:57 +0000 Subject: [PATCH 2/2] WIP: feat: specify Optimism l1 genesis state --- .../network-manager/edr/edr-provider.ts | 32 ++++--------------- 1 file changed, 7 insertions(+), 25 deletions(-) diff --git a/v-next/hardhat/src/internal/builtin-plugins/network-manager/edr/edr-provider.ts b/v-next/hardhat/src/internal/builtin-plugins/network-manager/edr/edr-provider.ts index 94790b4e18..cbfc2af370 100644 --- a/v-next/hardhat/src/internal/builtin-plugins/network-manager/edr/edr-provider.ts +++ b/v-next/hardhat/src/internal/builtin-plugins/network-manager/edr/edr-provider.ts @@ -32,18 +32,19 @@ import EventEmitter from "node:events"; import util from "node:util"; import { - Account, EdrContext, createModelsAndDecodeBytecodes, initializeVmTraceDecoder, SolidityTracer, VmTracer, - BEACON_ROOTS_ADDRESS, - BEACON_ROOTS_BYTECODE, GENERIC_CHAIN_TYPE, OPTIMISM_CHAIN_TYPE, genericChainProviderFactory, optimismProviderFactory, + optimismGenesisState, + optimismHardforkFromString, + l1GenesisState, + l1HardforkFromString, } from "@ignored/edr-optimism"; import { ensureError } from "@ignored/hardhat-vnext-utils/error"; import chalk from "chalk"; @@ -72,7 +73,6 @@ import { } from "./utils/convert-to-edr.js"; import { getHardforkName } from "./utils/hardfork.js"; import { printLine, replaceLastLine } from "./utils/logger.js"; -import { HardforkName } from "./types/hardfork.js"; const log = debug("hardhat:core:hardhat-network:provider"); @@ -104,24 +104,6 @@ interface EdrProviderConfig { jsonRpcRequestWrapper?: JsonRpcRequestWrapperFunction; } -function localL1GenesisState(hardfork: HardforkName): Account[] { - if (hardfork < HardforkName.CANCUN) { - return []; - } - - return [ - { - address: Uint8Array.from( - Buffer.from(BEACON_ROOTS_ADDRESS.slice(2), "hex"), - ), - balance: 0n, - nonce: 0n, - code: Uint8Array.from(Buffer.from(BEACON_ROOTS_BYTECODE.slice(2), "hex")), - storage: [], - }, - ]; -} - export class EdrProvider extends EventEmitter implements EthereumProvider { readonly #provider: Provider; readonly #vmTraceDecoder: VmTraceDecoder; @@ -183,10 +165,10 @@ export class EdrProvider extends EventEmitter implements EthereumProvider { const genesisState = fork !== undefined - ? [] + ? [] // TODO: Add support for overriding remote fork state when the local fork is different : networkConfig.chainType === "optimism" - ? [] // TODO: Add local Optimism genesis state - : localL1GenesisState(hardforkName); + ? optimismGenesisState(optimismHardforkFromString(hardforkName)) + : l1GenesisState(l1HardforkFromString(hardforkName)); const context = await getGlobalEdrContext(); const provider = await context.createProvider(