hardhat 2.23.0-dev.3 → 2.23.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -1
- package/builtin-tasks/compile.js +8 -8
- package/builtin-tasks/compile.js.map +1 -1
- package/builtin-tasks/flatten.js +13 -6
- package/builtin-tasks/flatten.js.map +1 -1
- package/builtin-tasks/node.js +7 -7
- package/builtin-tasks/node.js.map +1 -1
- package/builtin-tasks/test.js +2 -2
- package/builtin-tasks/test.js.map +1 -1
- package/builtin-tasks/utils/watch.js +2 -2
- package/builtin-tasks/utils/watch.js.map +1 -1
- package/common/bigInt.d.ts +1 -1
- package/common/bigInt.d.ts.map +1 -1
- package/console.sol +1 -1
- package/internal/cli/autocomplete.js +1 -1
- package/internal/cli/autocomplete.js.map +1 -1
- package/internal/cli/banner-manager.d.ts +12 -0
- package/internal/cli/banner-manager.d.ts.map +1 -0
- package/internal/cli/banner-manager.js +126 -0
- package/internal/cli/banner-manager.js.map +1 -0
- package/internal/cli/bootstrap.js +4 -5
- package/internal/cli/bootstrap.js.map +1 -1
- package/internal/cli/cli.js +14 -9
- package/internal/cli/cli.js.map +1 -1
- package/internal/cli/constants.d.ts.map +1 -1
- package/internal/cli/constants.js +1 -1
- package/internal/cli/constants.js.map +1 -1
- package/internal/cli/is-node-version-to-warn-on.d.ts +13 -0
- package/internal/cli/is-node-version-to-warn-on.d.ts.map +1 -0
- package/internal/cli/is-node-version-to-warn-on.js +46 -0
- package/internal/cli/is-node-version-to-warn-on.js.map +1 -0
- package/internal/cli/project-creation.d.ts +1 -1
- package/internal/cli/project-creation.d.ts.map +1 -1
- package/internal/cli/project-creation.js +31 -21
- package/internal/cli/project-creation.js.map +1 -1
- package/internal/cli/vars.js +10 -10
- package/internal/cli/vars.js.map +1 -1
- package/internal/cli/version-notifier.js +2 -2
- package/internal/cli/version-notifier.js.map +1 -1
- package/internal/constants.d.ts.map +1 -1
- package/internal/constants.js +1 -0
- package/internal/constants.js.map +1 -1
- package/internal/context.d.ts +1 -2
- package/internal/context.d.ts.map +1 -1
- package/internal/context.js +0 -3
- package/internal/context.js.map +1 -1
- package/internal/core/config/config-env.d.ts +1 -2
- package/internal/core/config/config-env.d.ts.map +1 -1
- package/internal/core/config/config-env.js +1 -8
- package/internal/core/config/config-env.js.map +1 -1
- package/internal/core/config/config-loading.d.ts +1 -1
- package/internal/core/config/config-loading.d.ts.map +1 -1
- package/internal/core/config/config-loading.js +14 -8
- package/internal/core/config/config-loading.js.map +1 -1
- package/internal/core/config/config-validation.js +1 -1
- package/internal/core/config/config-validation.js.map +1 -1
- package/internal/core/config/default-config.d.ts.map +1 -1
- package/internal/core/config/default-config.js +57 -32
- package/internal/core/config/default-config.js.map +1 -1
- package/internal/core/errors-list.d.ts +14 -0
- package/internal/core/errors-list.d.ts.map +1 -1
- package/internal/core/errors-list.js +18 -1
- package/internal/core/errors-list.js.map +1 -1
- package/internal/core/jsonrpc/types/authorization-list.d.ts +21 -0
- package/internal/core/jsonrpc/types/authorization-list.d.ts.map +1 -0
- package/internal/{hardhat-network/provider/PoolState.js → core/jsonrpc/types/authorization-list.js} +12 -15
- package/internal/core/jsonrpc/types/authorization-list.js.map +1 -0
- package/internal/core/jsonrpc/types/base-types.d.ts +2 -0
- package/internal/core/jsonrpc/types/base-types.d.ts.map +1 -1
- package/internal/core/jsonrpc/types/base-types.js +12 -8
- package/internal/core/jsonrpc/types/base-types.js.map +1 -1
- package/internal/core/jsonrpc/types/input/logAddress.d.ts +1 -0
- package/internal/core/jsonrpc/types/input/logAddress.d.ts.map +1 -1
- package/internal/core/jsonrpc/types/input/logTopics.d.ts +1 -0
- package/internal/core/jsonrpc/types/input/logTopics.d.ts.map +1 -1
- package/internal/core/jsonrpc/types/input/transactionRequest.d.ts +23 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.d.ts.map +1 -1
- package/internal/core/jsonrpc/types/input/transactionRequest.js +2 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.js.map +1 -1
- package/internal/core/jsonrpc/types/output/block.d.ts +2 -2
- package/internal/core/jsonrpc/types/output/block.d.ts.map +1 -1
- package/internal/core/jsonrpc/types/output/block.js +2 -1
- package/internal/core/jsonrpc/types/output/block.js.map +1 -1
- package/internal/core/project-structure.js +8 -8
- package/internal/core/project-structure.js.map +1 -1
- package/internal/core/providers/accounts.d.ts.map +1 -1
- package/internal/core/providers/accounts.js +76 -34
- package/internal/core/providers/accounts.js.map +1 -1
- package/internal/core/providers/construction.d.ts +2 -2
- package/internal/core/providers/construction.d.ts.map +1 -1
- package/internal/core/providers/construction.js +2 -2
- package/internal/core/providers/construction.js.map +1 -1
- package/internal/core/providers/http.d.ts.map +1 -1
- package/internal/core/providers/http.js +7 -0
- package/internal/core/providers/http.js.map +1 -1
- package/internal/core/providers/lazy-initialization.d.ts.map +1 -1
- package/internal/core/providers/lazy-initialization.js +10 -10
- package/internal/core/providers/lazy-initialization.js.map +1 -1
- package/internal/core/providers/util.d.ts +1 -0
- package/internal/core/providers/util.d.ts.map +1 -1
- package/internal/core/providers/util.js +1 -1
- package/internal/core/providers/util.js.map +1 -1
- package/internal/core/runtime-environment.d.ts +2 -2
- package/internal/core/runtime-environment.d.ts.map +1 -1
- package/internal/core/runtime-environment.js +2 -2
- package/internal/core/runtime-environment.js.map +1 -1
- package/internal/core/typescript-support.d.ts +1 -1
- package/internal/core/typescript-support.js +1 -1
- package/internal/hardhat-network/jsonrpc/client.d.ts +2 -1
- package/internal/hardhat-network/jsonrpc/client.d.ts.map +1 -1
- package/internal/hardhat-network/jsonrpc/client.js +10 -10
- package/internal/hardhat-network/jsonrpc/client.js.map +1 -1
- package/internal/hardhat-network/jsonrpc/handler.d.ts.map +1 -1
- package/internal/hardhat-network/jsonrpc/handler.js +2 -1
- package/internal/hardhat-network/jsonrpc/handler.js.map +1 -1
- package/internal/hardhat-network/provider/node-types.d.ts +0 -52
- package/internal/hardhat-network/provider/node-types.d.ts.map +1 -1
- package/internal/hardhat-network/provider/output.d.ts +12 -1
- package/internal/hardhat-network/provider/output.d.ts.map +1 -1
- package/internal/hardhat-network/provider/provider.d.ts +5 -20
- package/internal/hardhat-network/provider/provider.d.ts.map +1 -1
- package/internal/hardhat-network/provider/provider.js +47 -171
- package/internal/hardhat-network/provider/provider.js.map +1 -1
- package/internal/hardhat-network/provider/return-data.d.ts +2 -15
- package/internal/hardhat-network/provider/return-data.d.ts.map +1 -1
- package/internal/hardhat-network/provider/return-data.js +2 -50
- package/internal/hardhat-network/provider/return-data.js.map +1 -1
- package/internal/hardhat-network/provider/utils/convertToEdr.d.ts.map +1 -1
- package/internal/hardhat-network/provider/utils/convertToEdr.js +10 -7
- package/internal/hardhat-network/provider/utils/convertToEdr.js.map +1 -1
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.js +2 -2
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.js.map +1 -1
- package/internal/hardhat-network/provider/utils/makeAccount.d.ts +1 -1
- package/internal/hardhat-network/provider/utils/makeAccount.d.ts.map +1 -1
- package/internal/hardhat-network/provider/utils/makeAccount.js +4 -4
- package/internal/hardhat-network/provider/utils/makeAccount.js.map +1 -1
- package/internal/hardhat-network/provider/utils/makeForkClient.js +2 -2
- package/internal/hardhat-network/provider/utils/makeForkClient.js.map +1 -1
- package/internal/hardhat-network/provider/utils/random.d.ts +4 -3
- package/internal/hardhat-network/provider/utils/random.d.ts.map +1 -1
- package/internal/hardhat-network/provider/utils/random.js +3 -3
- package/internal/hardhat-network/provider/utils/random.js.map +1 -1
- package/internal/hardhat-network/provider/vm/exit.d.ts +2 -21
- package/internal/hardhat-network/provider/vm/exit.d.ts.map +1 -1
- package/internal/hardhat-network/provider/vm/exit.js +3 -93
- package/internal/hardhat-network/provider/vm/exit.js.map +1 -1
- package/internal/hardhat-network/provider/vm/minimal-vm.d.ts +3 -2
- package/internal/hardhat-network/provider/vm/minimal-vm.d.ts.map +1 -1
- package/internal/hardhat-network/provider/vm/minimal-vm.js +10 -4
- package/internal/hardhat-network/provider/vm/minimal-vm.js.map +1 -1
- package/internal/hardhat-network/provider/vm/types.d.ts +2 -1
- package/internal/hardhat-network/provider/vm/types.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/consoleLogger.d.ts +17 -16
- package/internal/hardhat-network/stack-traces/consoleLogger.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/consoleLogger.js +68 -102
- package/internal/hardhat-network/stack-traces/consoleLogger.js.map +1 -1
- package/internal/hardhat-network/stack-traces/constants.d.ts +1 -2
- package/internal/hardhat-network/stack-traces/constants.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/constants.js +2 -3
- package/internal/hardhat-network/stack-traces/constants.js.map +1 -1
- package/internal/hardhat-network/stack-traces/library-utils.d.ts +2 -11
- package/internal/hardhat-network/stack-traces/library-utils.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/library-utils.js +3 -61
- package/internal/hardhat-network/stack-traces/library-utils.js.map +1 -1
- package/internal/hardhat-network/stack-traces/logger.d.ts +2 -598
- package/internal/hardhat-network/stack-traces/logger.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/logger.js +379 -601
- package/internal/hardhat-network/stack-traces/logger.js.map +1 -1
- package/internal/hardhat-network/stack-traces/solidity-errors.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/solidity-errors.js +61 -56
- package/internal/hardhat-network/stack-traces/solidity-errors.js.map +1 -1
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.d.ts +4 -155
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.d.ts.map +1 -1
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.js +12 -37
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.js.map +1 -1
- package/internal/lib/hardhat-lib.d.ts.map +1 -1
- package/internal/lib/hardhat-lib.js +1 -1
- package/internal/lib/hardhat-lib.js.map +1 -1
- package/internal/sentry/anonymizer.d.ts +1 -1
- package/internal/sentry/anonymizer.d.ts.map +1 -1
- package/internal/sentry/anonymizer.js +1 -1
- package/internal/sentry/anonymizer.js.map +1 -1
- package/internal/solidity/compiler/downloader.js +1 -1
- package/internal/solidity/compiler/downloader.js.map +1 -1
- package/internal/solidity/compiler/solc-info.d.ts.map +1 -1
- package/internal/solidity/compiler/solc-info.js +4 -0
- package/internal/solidity/compiler/solc-info.js.map +1 -1
- package/internal/util/caller-package.js +1 -1
- package/internal/util/caller-package.js.map +1 -1
- package/internal/util/glob.d.ts +1 -1
- package/internal/util/glob.d.ts.map +1 -1
- package/internal/util/glob.js +2 -7
- package/internal/util/glob.js.map +1 -1
- package/internal/util/hardforks.d.ts +2 -1
- package/internal/util/hardforks.d.ts.map +1 -1
- package/internal/util/hardforks.js +2 -0
- package/internal/util/hardforks.js.map +1 -1
- package/internal/util/hash.d.ts +1 -0
- package/internal/util/hash.d.ts.map +1 -1
- package/internal/util/keys-derivation.d.ts +1 -0
- package/internal/util/keys-derivation.d.ts.map +1 -1
- package/internal/util/packageInfo.d.ts +1 -1
- package/internal/util/packageInfo.d.ts.map +1 -1
- package/internal/util/packageInfo.js +3 -3
- package/internal/util/packageInfo.js.map +1 -1
- package/internal/util/request.d.ts +2 -0
- package/internal/util/request.d.ts.map +1 -0
- package/internal/util/request.js +70 -0
- package/internal/util/request.js.map +1 -0
- package/package.json +12 -17
- package/register.js +1 -1
- package/register.js.map +1 -1
- package/sample-projects/javascript/contracts/Lock.sol +1 -1
- package/sample-projects/javascript/hardhat.config.js +1 -1
- package/sample-projects/javascript/ignition/modules/Lock.js +3 -0
- package/sample-projects/javascript-esm/contracts/Lock.sol +1 -1
- package/sample-projects/javascript-esm/hardhat.config.cjs +1 -1
- package/sample-projects/javascript-esm/ignition/modules/Lock.js +3 -0
- package/sample-projects/typescript/contracts/Lock.sol +1 -1
- package/sample-projects/typescript/hardhat.config.ts +1 -1
- package/sample-projects/typescript/ignition/modules/Lock.ts +3 -0
- package/sample-projects/typescript-viem/contracts/Lock.sol +1 -1
- package/sample-projects/typescript-viem/hardhat.config.ts +1 -1
- package/sample-projects/typescript-viem/ignition/modules/Lock.ts +3 -0
- package/src/builtin-tasks/compile.ts +12 -8
- package/src/builtin-tasks/flatten.ts +59 -41
- package/src/builtin-tasks/node.ts +8 -8
- package/src/builtin-tasks/test.ts +2 -2
- package/src/builtin-tasks/utils/watch.ts +2 -2
- package/src/common/bigInt.ts +1 -1
- package/src/internal/cli/autocomplete.ts +1 -1
- package/src/internal/cli/banner-manager.ts +182 -0
- package/src/internal/cli/bootstrap.ts +5 -5
- package/src/internal/cli/cli.ts +24 -15
- package/src/internal/cli/constants.ts +1 -1
- package/src/internal/cli/is-node-version-to-warn-on.ts +54 -0
- package/src/internal/cli/project-creation.ts +48 -22
- package/src/internal/cli/vars.ts +10 -10
- package/src/internal/cli/version-notifier.ts +3 -3
- package/src/internal/constants.ts +1 -0
- package/src/internal/context.ts +0 -5
- package/src/internal/core/config/config-env.ts +0 -10
- package/src/internal/core/config/config-loading.ts +15 -8
- package/src/internal/core/config/config-validation.ts +1 -1
- package/src/internal/core/config/default-config.ts +57 -32
- package/src/internal/core/errors-list.ts +19 -1
- package/src/internal/core/jsonrpc/types/authorization-list.ts +20 -0
- package/src/internal/core/jsonrpc/types/base-types.ts +13 -1
- package/src/internal/core/jsonrpc/types/input/transactionRequest.ts +10 -0
- package/src/internal/core/jsonrpc/types/output/block.ts +2 -1
- package/src/internal/core/project-structure.ts +8 -8
- package/src/internal/core/providers/accounts.ts +95 -50
- package/src/internal/core/providers/construction.ts +1 -3
- package/src/internal/core/providers/http.ts +11 -0
- package/src/internal/core/providers/lazy-initialization.ts +13 -13
- package/src/internal/core/providers/util.ts +1 -1
- package/src/internal/core/runtime-environment.ts +0 -8
- package/src/internal/core/typescript-support.ts +1 -1
- package/src/internal/hardhat-network/jsonrpc/client.ts +1 -4
- package/src/internal/hardhat-network/jsonrpc/handler.ts +2 -1
- package/src/internal/hardhat-network/provider/node-types.ts +0 -70
- package/src/internal/hardhat-network/provider/output.ts +16 -1
- package/src/internal/hardhat-network/provider/provider.ts +57 -236
- package/src/internal/hardhat-network/provider/return-data.ts +5 -73
- package/src/internal/hardhat-network/provider/utils/convertToEdr.ts +6 -3
- package/src/internal/hardhat-network/provider/utils/fork-recomendations-banner.ts +2 -2
- package/src/internal/hardhat-network/provider/utils/makeAccount.ts +1 -6
- package/src/internal/hardhat-network/provider/utils/makeForkClient.ts +2 -2
- package/src/internal/hardhat-network/provider/utils/random.ts +4 -5
- package/src/internal/hardhat-network/provider/vm/exit.ts +4 -112
- package/src/internal/hardhat-network/provider/vm/minimal-vm.ts +8 -3
- package/src/internal/hardhat-network/provider/vm/types.ts +1 -1
- package/src/internal/hardhat-network/stack-traces/consoleLogger.ts +34 -95
- package/src/internal/hardhat-network/stack-traces/constants.ts +1 -2
- package/src/internal/hardhat-network/stack-traces/library-utils.ts +5 -90
- package/src/internal/hardhat-network/stack-traces/logger.ts +378 -600
- package/src/internal/hardhat-network/stack-traces/solidity-errors.ts +17 -16
- package/src/internal/hardhat-network/stack-traces/solidity-stack-trace.ts +83 -186
- package/src/internal/lib/hardhat-lib.ts +0 -1
- package/src/internal/sentry/anonymizer.ts +2 -2
- package/src/internal/solidity/compiler/downloader.ts +1 -1
- package/src/internal/solidity/compiler/solc-info.ts +4 -0
- package/src/internal/util/caller-package.ts +2 -2
- package/src/internal/util/glob.ts +6 -6
- package/src/internal/util/hardforks.ts +2 -0
- package/src/internal/util/packageInfo.ts +4 -4
- package/src/internal/util/request.ts +51 -0
- package/src/register.ts +0 -1
- package/src/types/config.ts +2 -0
- package/src/types/index.ts +0 -1
- package/types/config.d.ts +2 -0
- package/types/config.d.ts.map +1 -1
- package/types/index.d.ts +0 -1
- package/types/index.d.ts.map +1 -1
- package/types/index.js +0 -1
- package/types/index.js.map +1 -1
- package/internal/hardhat-network/provider/BlockchainBase.d.ts +0 -29
- package/internal/hardhat-network/provider/BlockchainBase.d.ts.map +0 -1
- package/internal/hardhat-network/provider/BlockchainBase.js +0 -144
- package/internal/hardhat-network/provider/BlockchainBase.js.map +0 -1
- package/internal/hardhat-network/provider/BlockchainData.d.ts +0 -58
- package/internal/hardhat-network/provider/BlockchainData.d.ts.map +0 -1
- package/internal/hardhat-network/provider/BlockchainData.js +0 -178
- package/internal/hardhat-network/provider/BlockchainData.js.map +0 -1
- package/internal/hardhat-network/provider/HardhatBlockchain.d.ts +0 -24
- package/internal/hardhat-network/provider/HardhatBlockchain.d.ts.map +0 -1
- package/internal/hardhat-network/provider/HardhatBlockchain.js +0 -73
- package/internal/hardhat-network/provider/HardhatBlockchain.js.map +0 -1
- package/internal/hardhat-network/provider/MiningTimer.d.ts +0 -28
- package/internal/hardhat-network/provider/MiningTimer.d.ts.map +0 -1
- package/internal/hardhat-network/provider/MiningTimer.js +0 -96
- package/internal/hardhat-network/provider/MiningTimer.js.map +0 -1
- package/internal/hardhat-network/provider/PoolState.d.ts +0 -26
- package/internal/hardhat-network/provider/PoolState.d.ts.map +0 -1
- package/internal/hardhat-network/provider/PoolState.js.map +0 -1
- package/internal/hardhat-network/provider/TransactionQueue.d.ts +0 -32
- package/internal/hardhat-network/provider/TransactionQueue.d.ts.map +0 -1
- package/internal/hardhat-network/provider/TransactionQueue.js +0 -130
- package/internal/hardhat-network/provider/TransactionQueue.js.map +0 -1
- package/internal/hardhat-network/provider/TxPool.d.ts +0 -83
- package/internal/hardhat-network/provider/TxPool.d.ts.map +0 -1
- package/internal/hardhat-network/provider/TxPool.js +0 -470
- package/internal/hardhat-network/provider/TxPool.js.map +0 -1
- package/internal/hardhat-network/provider/ethereumjs-workarounds.d.ts +0 -2
- package/internal/hardhat-network/provider/ethereumjs-workarounds.d.ts.map +0 -1
- package/internal/hardhat-network/provider/ethereumjs-workarounds.js +0 -15
- package/internal/hardhat-network/provider/ethereumjs-workarounds.js.map +0 -1
- package/internal/hardhat-network/provider/filter.d.ts +0 -29
- package/internal/hardhat-network/provider/filter.d.ts.map +0 -1
- package/internal/hardhat-network/provider/filter.js +0 -97
- package/internal/hardhat-network/provider/filter.js.map +0 -1
- package/internal/hardhat-network/provider/fork/ForkBlockchain.d.ts +0 -33
- package/internal/hardhat-network/provider/fork/ForkBlockchain.d.ts.map +0 -1
- package/internal/hardhat-network/provider/fork/ForkBlockchain.js +0 -272
- package/internal/hardhat-network/provider/fork/ForkBlockchain.js.map +0 -1
- package/internal/hardhat-network/provider/fork/ForkStateManager.d.ts +0 -51
- package/internal/hardhat-network/provider/fork/ForkStateManager.d.ts.map +0 -1
- package/internal/hardhat-network/provider/fork/ForkStateManager.js +0 -300
- package/internal/hardhat-network/provider/fork/ForkStateManager.js.map +0 -1
- package/internal/hardhat-network/provider/fork/rpcToBlockData.d.ts +0 -4
- package/internal/hardhat-network/provider/fork/rpcToBlockData.d.ts.map +0 -1
- package/internal/hardhat-network/provider/fork/rpcToBlockData.js +0 -32
- package/internal/hardhat-network/provider/fork/rpcToBlockData.js.map +0 -1
- package/internal/hardhat-network/provider/fork/rpcToTxData.d.ts +0 -10
- package/internal/hardhat-network/provider/fork/rpcToTxData.d.ts.map +0 -1
- package/internal/hardhat-network/provider/fork/rpcToTxData.js +0 -29
- package/internal/hardhat-network/provider/fork/rpcToTxData.js.map +0 -1
- package/internal/hardhat-network/provider/modules/base.d.ts +0 -17
- package/internal/hardhat-network/provider/modules/base.d.ts.map +0 -1
- package/internal/hardhat-network/provider/modules/base.js +0 -127
- package/internal/hardhat-network/provider/modules/base.js.map +0 -1
- package/internal/hardhat-network/provider/modules/debug.d.ts +0 -12
- package/internal/hardhat-network/provider/modules/debug.d.ts.map +0 -1
- package/internal/hardhat-network/provider/modules/debug.js +0 -52
- package/internal/hardhat-network/provider/modules/debug.js.map +0 -1
- package/internal/hardhat-network/provider/modules/eth.d.ts +0 -107
- package/internal/hardhat-network/provider/modules/eth.d.ts.map +0 -1
- package/internal/hardhat-network/provider/modules/eth.js +0 -1034
- package/internal/hardhat-network/provider/modules/eth.js.map +0 -1
- package/internal/hardhat-network/provider/modules/evm.d.ts +0 -32
- package/internal/hardhat-network/provider/modules/evm.d.ts.map +0 -1
- package/internal/hardhat-network/provider/modules/evm.js +0 -180
- package/internal/hardhat-network/provider/modules/evm.js.map +0 -1
- package/internal/hardhat-network/provider/modules/hardhat.d.ts +0 -54
- package/internal/hardhat-network/provider/modules/hardhat.d.ts.map +0 -1
- package/internal/hardhat-network/provider/modules/hardhat.js +0 -309
- package/internal/hardhat-network/provider/modules/hardhat.js.map +0 -1
- package/internal/hardhat-network/provider/modules/net.d.ts +0 -13
- package/internal/hardhat-network/provider/modules/net.d.ts.map +0 -1
- package/internal/hardhat-network/provider/modules/net.js +0 -47
- package/internal/hardhat-network/provider/modules/net.js.map +0 -1
- package/internal/hardhat-network/provider/modules/personal.d.ts +0 -9
- package/internal/hardhat-network/provider/modules/personal.d.ts.map +0 -1
- package/internal/hardhat-network/provider/modules/personal.js +0 -31
- package/internal/hardhat-network/provider/modules/personal.js.map +0 -1
- package/internal/hardhat-network/provider/modules/web3.d.ts +0 -11
- package/internal/hardhat-network/provider/modules/web3.d.ts.map +0 -1
- package/internal/hardhat-network/provider/modules/web3.js +0 -38
- package/internal/hardhat-network/provider/modules/web3.js.map +0 -1
- package/internal/hardhat-network/provider/node.d.ts +0 -197
- package/internal/hardhat-network/provider/node.d.ts.map +0 -1
- package/internal/hardhat-network/provider/node.js +0 -1866
- package/internal/hardhat-network/provider/node.js.map +0 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderAccessListEIP2930Transaction.d.ts +0 -29
- package/internal/hardhat-network/provider/transactions/FakeSenderAccessListEIP2930Transaction.d.ts.map +0 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderAccessListEIP2930Transaction.js +0 -137
- package/internal/hardhat-network/provider/transactions/FakeSenderAccessListEIP2930Transaction.js.map +0 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderEIP1559Transaction.d.ts +0 -27
- package/internal/hardhat-network/provider/transactions/FakeSenderEIP1559Transaction.d.ts.map +0 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderEIP1559Transaction.js +0 -137
- package/internal/hardhat-network/provider/transactions/FakeSenderEIP1559Transaction.js.map +0 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderTransaction.d.ts +0 -33
- package/internal/hardhat-network/provider/transactions/FakeSenderTransaction.d.ts.map +0 -1
- package/internal/hardhat-network/provider/transactions/FakeSenderTransaction.js +0 -141
- package/internal/hardhat-network/provider/transactions/FakeSenderTransaction.js.map +0 -1
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidEIP1559Transaction.d.ts +0 -30
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidEIP1559Transaction.d.ts.map +0 -1
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidEIP1559Transaction.js +0 -97
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidEIP1559Transaction.js.map +0 -1
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidEIP2930Transaction.d.ts +0 -30
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidEIP2930Transaction.d.ts.map +0 -1
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidEIP2930Transaction.js +0 -98
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidEIP2930Transaction.js.map +0 -1
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidTransaction.d.ts +0 -40
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidTransaction.d.ts.map +0 -1
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidTransaction.js +0 -91
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidTransaction.js.map +0 -1
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidUnknownTypeTransaction.d.ts +0 -32
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidUnknownTypeTransaction.d.ts.map +0 -1
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidUnknownTypeTransaction.js +0 -87
- package/internal/hardhat-network/provider/transactions/ReadOnlyValidUnknownTypeTransaction.js.map +0 -1
- package/internal/hardhat-network/provider/types/HardhatBlockchainInterface.d.ts +0 -17
- package/internal/hardhat-network/provider/types/HardhatBlockchainInterface.d.ts.map +0 -1
- package/internal/hardhat-network/provider/types/HardhatBlockchainInterface.js +0 -3
- package/internal/hardhat-network/provider/types/HardhatBlockchainInterface.js.map +0 -1
- package/internal/hardhat-network/provider/utils/makeCommon.d.ts +0 -4
- package/internal/hardhat-network/provider/utils/makeCommon.d.ts.map +0 -1
- package/internal/hardhat-network/provider/utils/makeCommon.js +0 -17
- package/internal/hardhat-network/provider/utils/makeCommon.js.map +0 -1
- package/internal/hardhat-network/provider/utils/makeFakeSignature.d.ts +0 -7
- package/internal/hardhat-network/provider/utils/makeFakeSignature.d.ts.map +0 -1
- package/internal/hardhat-network/provider/utils/makeFakeSignature.js +0 -31
- package/internal/hardhat-network/provider/utils/makeFakeSignature.js.map +0 -1
- package/internal/hardhat-network/provider/utils/makeStateTrie.d.ts +0 -4
- package/internal/hardhat-network/provider/utils/makeStateTrie.d.ts.map +0 -1
- package/internal/hardhat-network/provider/utils/makeStateTrie.js +0 -20
- package/internal/hardhat-network/provider/utils/makeStateTrie.js.map +0 -1
- package/internal/hardhat-network/provider/utils/putGenesisBlock.d.ts +0 -8
- package/internal/hardhat-network/provider/utils/putGenesisBlock.d.ts.map +0 -1
- package/internal/hardhat-network/provider/utils/putGenesisBlock.js +0 -37
- package/internal/hardhat-network/provider/utils/putGenesisBlock.js.map +0 -1
- package/internal/hardhat-network/provider/utils/reorganizeTransactionsLists.d.ts +0 -12
- package/internal/hardhat-network/provider/utils/reorganizeTransactionsLists.d.ts.map +0 -1
- package/internal/hardhat-network/provider/utils/reorganizeTransactionsLists.js +0 -62
- package/internal/hardhat-network/provider/utils/reorganizeTransactionsLists.js.map +0 -1
- package/internal/hardhat-network/provider/utils/txMapToArray.d.ts +0 -3
- package/internal/hardhat-network/provider/utils/txMapToArray.d.ts.map +0 -1
- package/internal/hardhat-network/provider/utils/txMapToArray.js +0 -12
- package/internal/hardhat-network/provider/utils/txMapToArray.js.map +0 -1
- package/internal/hardhat-network/stack-traces/compiler-to-model.d.ts +0 -4
- package/internal/hardhat-network/stack-traces/compiler-to-model.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/compiler-to-model.js +0 -356
- package/internal/hardhat-network/stack-traces/compiler-to-model.js.map +0 -1
- package/internal/hardhat-network/stack-traces/contracts-identifier.d.ts +0 -15
- package/internal/hardhat-network/stack-traces/contracts-identifier.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/contracts-identifier.js +0 -166
- package/internal/hardhat-network/stack-traces/contracts-identifier.js.map +0 -1
- package/internal/hardhat-network/stack-traces/debug.d.ts +0 -8
- package/internal/hardhat-network/stack-traces/debug.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/debug.js +0 -148
- package/internal/hardhat-network/stack-traces/debug.js.map +0 -1
- package/internal/hardhat-network/stack-traces/error-inferrer.d.ts +0 -85
- package/internal/hardhat-network/stack-traces/error-inferrer.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/error-inferrer.js +0 -1168
- package/internal/hardhat-network/stack-traces/error-inferrer.js.map +0 -1
- package/internal/hardhat-network/stack-traces/mapped-inlined-internal-functions-heuristics.d.ts +0 -24
- package/internal/hardhat-network/stack-traces/mapped-inlined-internal-functions-heuristics.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/mapped-inlined-internal-functions-heuristics.js +0 -116
- package/internal/hardhat-network/stack-traces/mapped-inlined-internal-functions-heuristics.js.map +0 -1
- package/internal/hardhat-network/stack-traces/message-trace.d.ts +0 -55
- package/internal/hardhat-network/stack-traces/message-trace.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/message-trace.js +0 -49
- package/internal/hardhat-network/stack-traces/message-trace.js.map +0 -1
- package/internal/hardhat-network/stack-traces/model.d.ts +0 -140
- package/internal/hardhat-network/stack-traces/model.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/model.js +0 -328
- package/internal/hardhat-network/stack-traces/model.js.map +0 -1
- package/internal/hardhat-network/stack-traces/opcodes.d.ts +0 -266
- package/internal/hardhat-network/stack-traces/opcodes.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/opcodes.js +0 -320
- package/internal/hardhat-network/stack-traces/opcodes.js.map +0 -1
- package/internal/hardhat-network/stack-traces/solidityTracer.d.ts +0 -14
- package/internal/hardhat-network/stack-traces/solidityTracer.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/solidityTracer.js +0 -167
- package/internal/hardhat-network/stack-traces/solidityTracer.js.map +0 -1
- package/internal/hardhat-network/stack-traces/source-maps.d.ts +0 -13
- package/internal/hardhat-network/stack-traces/source-maps.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/source-maps.js +0 -106
- package/internal/hardhat-network/stack-traces/source-maps.js.map +0 -1
- package/internal/hardhat-network/stack-traces/vm-debug-tracer.d.ts +0 -46
- package/internal/hardhat-network/stack-traces/vm-debug-tracer.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/vm-debug-tracer.js +0 -421
- package/internal/hardhat-network/stack-traces/vm-debug-tracer.js.map +0 -1
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.d.ts +0 -17
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.js +0 -91
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.js.map +0 -1
- package/internal/hardhat-network/stack-traces/vm-tracer.d.ts +0 -19
- package/internal/hardhat-network/stack-traces/vm-tracer.d.ts.map +0 -1
- package/internal/hardhat-network/stack-traces/vm-tracer.js +0 -170
- package/internal/hardhat-network/stack-traces/vm-tracer.js.map +0 -1
- package/src/internal/hardhat-network/provider/utils/makeCommon.ts +0 -20
- package/src/internal/hardhat-network/stack-traces/compiler-to-model.ts +0 -699
- package/src/internal/hardhat-network/stack-traces/contracts-identifier.ts +0 -235
- package/src/internal/hardhat-network/stack-traces/debug.ts +0 -220
- package/src/internal/hardhat-network/stack-traces/error-inferrer.ts +0 -1845
- package/src/internal/hardhat-network/stack-traces/mapped-inlined-internal-functions-heuristics.ts +0 -163
- package/src/internal/hardhat-network/stack-traces/message-trace.ts +0 -131
- package/src/internal/hardhat-network/stack-traces/model.ts +0 -409
- package/src/internal/hardhat-network/stack-traces/opcodes.ts +0 -344
- package/src/internal/hardhat-network/stack-traces/solidityTracer.ts +0 -255
- package/src/internal/hardhat-network/stack-traces/source-maps.ts +0 -167
- package/src/internal/hardhat-network/stack-traces/vm-trace-decoder.ts +0 -135
- package/src/internal/hardhat-network/stack-traces/vm-tracer.ts +0 -221
- package/src/types/experimental.ts +0 -18
- package/types/experimental.d.ts +0 -5
- package/types/experimental.d.ts.map +0 -1
- package/types/experimental.js +0 -3
- package/types/experimental.js.map +0 -1
|
@@ -1,470 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.TxPool = exports.deserializeTransaction = exports.serializeTransaction = void 0;
|
|
27
|
-
const ethereumjs_tx_1 = require("@nomicfoundation/ethereumjs-tx");
|
|
28
|
-
const ethereumjs_util_1 = require("@nomicfoundation/ethereumjs-util");
|
|
29
|
-
const immutable_1 = require("immutable");
|
|
30
|
-
const errors_1 = require("../../core/providers/errors");
|
|
31
|
-
const BigIntUtils = __importStar(require("../../util/bigint"));
|
|
32
|
-
const PoolState_1 = require("./PoolState");
|
|
33
|
-
const FakeSenderAccessListEIP2930Transaction_1 = require("./transactions/FakeSenderAccessListEIP2930Transaction");
|
|
34
|
-
const FakeSenderTransaction_1 = require("./transactions/FakeSenderTransaction");
|
|
35
|
-
const reorganizeTransactionsLists_1 = require("./utils/reorganizeTransactionsLists");
|
|
36
|
-
const FakeSenderEIP1559Transaction_1 = require("./transactions/FakeSenderEIP1559Transaction");
|
|
37
|
-
/* eslint-disable @nomicfoundation/hardhat-internal-rules/only-hardhat-error */
|
|
38
|
-
function serializeTransaction(tx) {
|
|
39
|
-
const rlpSerialization = (0, ethereumjs_util_1.bufferToHex)(tx.data.serialize());
|
|
40
|
-
const isFake = tx.data instanceof FakeSenderTransaction_1.FakeSenderTransaction ||
|
|
41
|
-
tx.data instanceof FakeSenderAccessListEIP2930Transaction_1.FakeSenderAccessListEIP2930Transaction ||
|
|
42
|
-
tx.data instanceof FakeSenderEIP1559Transaction_1.FakeSenderEIP1559Transaction;
|
|
43
|
-
return (0, PoolState_1.makeSerializedTransaction)({
|
|
44
|
-
orderId: tx.orderId,
|
|
45
|
-
fakeFrom: isFake ? tx.data.getSenderAddress().toString() : undefined,
|
|
46
|
-
data: rlpSerialization,
|
|
47
|
-
txType: tx.data.type,
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
exports.serializeTransaction = serializeTransaction;
|
|
51
|
-
function deserializeTransaction(tx, common) {
|
|
52
|
-
const rlpSerialization = tx.get("data");
|
|
53
|
-
const fakeFrom = tx.get("fakeFrom");
|
|
54
|
-
let data;
|
|
55
|
-
if (fakeFrom !== undefined) {
|
|
56
|
-
const sender = ethereumjs_util_1.Address.fromString(fakeFrom);
|
|
57
|
-
const serialization = (0, ethereumjs_util_1.toBuffer)(rlpSerialization);
|
|
58
|
-
if (tx.get("txType") === 1) {
|
|
59
|
-
data =
|
|
60
|
-
FakeSenderAccessListEIP2930Transaction_1.FakeSenderAccessListEIP2930Transaction.fromSenderAndRlpSerializedTx(sender, serialization, { common });
|
|
61
|
-
}
|
|
62
|
-
else if (tx.get("txType") === 2) {
|
|
63
|
-
data = FakeSenderEIP1559Transaction_1.FakeSenderEIP1559Transaction.fromSenderAndRlpSerializedTx(sender, serialization, { common });
|
|
64
|
-
}
|
|
65
|
-
else {
|
|
66
|
-
data = FakeSenderTransaction_1.FakeSenderTransaction.fromSenderAndRlpSerializedTx(sender, serialization, { common });
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
data = ethereumjs_tx_1.TransactionFactory.fromSerializedData((0, ethereumjs_util_1.toBuffer)(rlpSerialization), {
|
|
71
|
-
common,
|
|
72
|
-
disableMaxInitCodeSizeCheck: true,
|
|
73
|
-
});
|
|
74
|
-
}
|
|
75
|
-
return {
|
|
76
|
-
orderId: tx.get("orderId"),
|
|
77
|
-
data,
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
exports.deserializeTransaction = deserializeTransaction;
|
|
81
|
-
class TxPool {
|
|
82
|
-
constructor(_stateManager, blockGasLimit, common) {
|
|
83
|
-
this._stateManager = _stateManager;
|
|
84
|
-
this._snapshotIdToState = new Map();
|
|
85
|
-
this._nextSnapshotId = 0;
|
|
86
|
-
this._nextOrderId = 0;
|
|
87
|
-
this._state = (0, PoolState_1.makePoolState)({
|
|
88
|
-
blockGasLimit: BigIntUtils.toHex(blockGasLimit),
|
|
89
|
-
});
|
|
90
|
-
this._deserializeTransaction = (tx) => deserializeTransaction(tx, common);
|
|
91
|
-
}
|
|
92
|
-
async addTransaction(tx) {
|
|
93
|
-
const senderAddress = this._getSenderAddress(tx);
|
|
94
|
-
const nextConfirmedNonce = await this._getNextConfirmedNonce(senderAddress);
|
|
95
|
-
const nextPendingNonce = await this.getNextPendingNonce(senderAddress);
|
|
96
|
-
await this._validateTransaction(tx, senderAddress, nextConfirmedNonce);
|
|
97
|
-
const txNonce = tx.nonce;
|
|
98
|
-
if (txNonce > nextPendingNonce) {
|
|
99
|
-
this._addQueuedTransaction(tx);
|
|
100
|
-
}
|
|
101
|
-
else {
|
|
102
|
-
this._addPendingTransaction(tx);
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* Remove transaction with the given hash from the mempool. Returns true
|
|
107
|
-
* if a transaction was removed, false otherwise.
|
|
108
|
-
*/
|
|
109
|
-
removeTransaction(txHash) {
|
|
110
|
-
const tx = this.getTransactionByHash(txHash);
|
|
111
|
-
if (tx === undefined) {
|
|
112
|
-
// transaction doesn't exist in the mempool
|
|
113
|
-
return false;
|
|
114
|
-
}
|
|
115
|
-
this._deleteTransactionByHash(txHash);
|
|
116
|
-
const serializedTx = serializeTransaction(tx);
|
|
117
|
-
const senderAddress = this._getSenderAddress(tx.data).toString();
|
|
118
|
-
const pendingForAddress = this._getPendingForAddress(senderAddress) ??
|
|
119
|
-
(0, immutable_1.List)();
|
|
120
|
-
const queuedForAddress = this._getQueuedForAddress(senderAddress) ??
|
|
121
|
-
(0, immutable_1.List)();
|
|
122
|
-
// if the tx to remove is in the pending state, remove it
|
|
123
|
-
// and move the following transactions to the queued list
|
|
124
|
-
const indexOfPendingTx = pendingForAddress.indexOf(serializedTx);
|
|
125
|
-
if (indexOfPendingTx !== -1) {
|
|
126
|
-
const newPendingForAddress = pendingForAddress.splice(indexOfPendingTx, pendingForAddress.size);
|
|
127
|
-
const newQueuedForAddress = queuedForAddress.concat(pendingForAddress.slice(indexOfPendingTx + 1));
|
|
128
|
-
this._setPendingForAddress(senderAddress, newPendingForAddress);
|
|
129
|
-
this._setQueuedForAddress(senderAddress, newQueuedForAddress);
|
|
130
|
-
return true;
|
|
131
|
-
}
|
|
132
|
-
// if the tx is in the queued state, we just remove it
|
|
133
|
-
const indexOfQueuedTx = queuedForAddress.indexOf(serializedTx);
|
|
134
|
-
if (indexOfQueuedTx !== -1) {
|
|
135
|
-
const newQueuedForAddress = queuedForAddress.splice(indexOfQueuedTx, 1);
|
|
136
|
-
this._setQueuedForAddress(senderAddress, newQueuedForAddress);
|
|
137
|
-
return true;
|
|
138
|
-
}
|
|
139
|
-
throw new Error("Tx should have existed in the pending or queued lists");
|
|
140
|
-
}
|
|
141
|
-
snapshot() {
|
|
142
|
-
const id = this._nextSnapshotId++;
|
|
143
|
-
this._snapshotIdToState.set(id, this._state);
|
|
144
|
-
return id;
|
|
145
|
-
}
|
|
146
|
-
revert(snapshotId) {
|
|
147
|
-
const state = this._snapshotIdToState.get(snapshotId);
|
|
148
|
-
if (state === undefined) {
|
|
149
|
-
throw new Error("There's no snapshot with such ID");
|
|
150
|
-
}
|
|
151
|
-
this._state = state;
|
|
152
|
-
this._removeSnapshotsAfter(snapshotId);
|
|
153
|
-
}
|
|
154
|
-
getTransactionByHash(hash) {
|
|
155
|
-
const tx = this._getTransactionsByHash().get((0, ethereumjs_util_1.bufferToHex)(hash));
|
|
156
|
-
if (tx !== undefined) {
|
|
157
|
-
return this._deserializeTransaction(tx);
|
|
158
|
-
}
|
|
159
|
-
return undefined;
|
|
160
|
-
}
|
|
161
|
-
hasPendingTransactions() {
|
|
162
|
-
const pendingMap = this._getPending();
|
|
163
|
-
return pendingMap.some((senderPendingTxs) => !senderPendingTxs.isEmpty());
|
|
164
|
-
}
|
|
165
|
-
hasQueuedTransactions() {
|
|
166
|
-
const queuedMap = this._getQueued();
|
|
167
|
-
return queuedMap.some((senderQueuedTxs) => !senderQueuedTxs.isEmpty());
|
|
168
|
-
}
|
|
169
|
-
isEmpty() {
|
|
170
|
-
return !(this.hasPendingTransactions() || this.hasQueuedTransactions());
|
|
171
|
-
}
|
|
172
|
-
getPendingTransactions() {
|
|
173
|
-
const deserializedImmutableMap = this._getPending()
|
|
174
|
-
.filter((txs) => txs.size > 0)
|
|
175
|
-
.map((txs) => txs.map(this._deserializeTransaction).toJS());
|
|
176
|
-
return new Map(deserializedImmutableMap.entries());
|
|
177
|
-
}
|
|
178
|
-
getQueuedTransactions() {
|
|
179
|
-
const deserializedImmutableMap = this._getQueued()
|
|
180
|
-
.filter((txs) => txs.size > 0)
|
|
181
|
-
.map((txs) => txs.map(this._deserializeTransaction).toJS());
|
|
182
|
-
return new Map(deserializedImmutableMap.entries());
|
|
183
|
-
}
|
|
184
|
-
/**
|
|
185
|
-
* Returns the next available nonce for an address, taking into account
|
|
186
|
-
* its pending transactions.
|
|
187
|
-
*/
|
|
188
|
-
async getNextPendingNonce(accountAddress) {
|
|
189
|
-
const pendingTxs = this._getPendingForAddress(accountAddress.toString());
|
|
190
|
-
const lastPendingTx = pendingTxs?.last(undefined);
|
|
191
|
-
if (lastPendingTx === undefined) {
|
|
192
|
-
return this._getNextConfirmedNonce(accountAddress);
|
|
193
|
-
}
|
|
194
|
-
const lastPendingTxNonce = this._deserializeTransaction(lastPendingTx).data.nonce;
|
|
195
|
-
return lastPendingTxNonce + 1n;
|
|
196
|
-
}
|
|
197
|
-
getBlockGasLimit() {
|
|
198
|
-
return BigInt(this._state.get("blockGasLimit"));
|
|
199
|
-
}
|
|
200
|
-
setBlockGasLimit(newLimit) {
|
|
201
|
-
if (typeof newLimit === "number") {
|
|
202
|
-
newLimit = BigInt(newLimit);
|
|
203
|
-
}
|
|
204
|
-
this._setBlockGasLimit(newLimit);
|
|
205
|
-
}
|
|
206
|
-
/**
|
|
207
|
-
* Updates the pending and queued list of all addresses
|
|
208
|
-
*/
|
|
209
|
-
async updatePendingAndQueued() {
|
|
210
|
-
let newPending = this._getPending();
|
|
211
|
-
// update pending transactions
|
|
212
|
-
for (const [address, txs] of newPending) {
|
|
213
|
-
const senderAccount = await this._stateManager.getAccount(ethereumjs_util_1.Address.fromString(address));
|
|
214
|
-
const senderNonce = senderAccount.nonce;
|
|
215
|
-
const senderBalance = senderAccount.balance;
|
|
216
|
-
let moveToQueued = false;
|
|
217
|
-
for (const tx of txs) {
|
|
218
|
-
const deserializedTx = this._deserializeTransaction(tx);
|
|
219
|
-
if (moveToQueued) {
|
|
220
|
-
newPending = this._removeTx(newPending, address, deserializedTx);
|
|
221
|
-
const queued = this._getQueuedForAddress(address) ?? (0, immutable_1.List)();
|
|
222
|
-
this._setQueuedForAddress(address, queued.push(tx));
|
|
223
|
-
continue;
|
|
224
|
-
}
|
|
225
|
-
const txNonce = deserializedTx.data.nonce;
|
|
226
|
-
if (!this._isTxValid(deserializedTx, txNonce, senderNonce, senderBalance)) {
|
|
227
|
-
newPending = this._removeTx(newPending, address, deserializedTx);
|
|
228
|
-
// if we are dropping a pending transaction with a valid nonce,
|
|
229
|
-
// then we move all the following txs to the queued list
|
|
230
|
-
if (txNonce >= senderNonce) {
|
|
231
|
-
moveToQueued = true;
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
this._setPending(newPending);
|
|
237
|
-
// update queued addresses
|
|
238
|
-
let newQueued = this._getQueued();
|
|
239
|
-
for (const [address, txs] of newQueued) {
|
|
240
|
-
const senderAccount = await this._stateManager.getAccount(ethereumjs_util_1.Address.fromString(address));
|
|
241
|
-
const senderNonce = senderAccount.nonce;
|
|
242
|
-
const senderBalance = senderAccount.balance;
|
|
243
|
-
for (const tx of txs) {
|
|
244
|
-
const deserializedTx = this._deserializeTransaction(tx);
|
|
245
|
-
const txNonce = deserializedTx.data.nonce;
|
|
246
|
-
if (!this._isTxValid(deserializedTx, txNonce, senderNonce, senderBalance)) {
|
|
247
|
-
newQueued = this._removeTx(newQueued, address, deserializedTx);
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
this._setQueued(newQueued);
|
|
252
|
-
}
|
|
253
|
-
_getSenderAddress(tx) {
|
|
254
|
-
try {
|
|
255
|
-
return tx.getSenderAddress(); // verifies signature
|
|
256
|
-
}
|
|
257
|
-
catch (e) {
|
|
258
|
-
if (!tx.isSigned()) {
|
|
259
|
-
throw new errors_1.InvalidInputError("Invalid Signature");
|
|
260
|
-
}
|
|
261
|
-
throw new errors_1.InvalidInputError(e.message);
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
_removeSnapshotsAfter(snapshotId) {
|
|
265
|
-
const snapshotIds = [...this._snapshotIdToState.keys()].filter((x) => x >= snapshotId);
|
|
266
|
-
for (const id of snapshotIds) {
|
|
267
|
-
this._snapshotIdToState.delete(id);
|
|
268
|
-
}
|
|
269
|
-
}
|
|
270
|
-
_removeTx(map, address, deserializedTX) {
|
|
271
|
-
const accountTxs = map.get(address);
|
|
272
|
-
if (accountTxs === undefined) {
|
|
273
|
-
throw new Error("Trying to remove a transaction from list that doesn't exist, this should never happen");
|
|
274
|
-
}
|
|
275
|
-
this._deleteTransactionByHash(deserializedTX.data.hash());
|
|
276
|
-
const indexOfTx = accountTxs.indexOf(serializeTransaction(deserializedTX));
|
|
277
|
-
return map.set(address, accountTxs.remove(indexOfTx));
|
|
278
|
-
}
|
|
279
|
-
_addPendingTransaction(tx) {
|
|
280
|
-
const orderedTx = {
|
|
281
|
-
orderId: this._nextOrderId++,
|
|
282
|
-
data: tx,
|
|
283
|
-
};
|
|
284
|
-
const serializedTx = serializeTransaction(orderedTx);
|
|
285
|
-
const hexSenderAddress = tx.getSenderAddress().toString();
|
|
286
|
-
const accountTransactions = this._getPendingForAddress(hexSenderAddress) ?? (0, immutable_1.List)();
|
|
287
|
-
const replaced = this._replacePendingTx(hexSenderAddress, orderedTx);
|
|
288
|
-
if (!replaced) {
|
|
289
|
-
const { newPending, newQueued } = (0, reorganizeTransactionsLists_1.reorganizeTransactionsLists)(accountTransactions.push(serializedTx), this._getQueuedForAddress(hexSenderAddress) ?? (0, immutable_1.List)(), (stx) => this._deserializeTransaction(stx).data.nonce);
|
|
290
|
-
this._setPendingForAddress(hexSenderAddress, newPending);
|
|
291
|
-
this._setQueuedForAddress(hexSenderAddress, newQueued);
|
|
292
|
-
}
|
|
293
|
-
this._setTransactionByHash((0, ethereumjs_util_1.bufferToHex)(tx.hash()), serializedTx);
|
|
294
|
-
}
|
|
295
|
-
_addQueuedTransaction(tx) {
|
|
296
|
-
const orderedTx = {
|
|
297
|
-
orderId: this._nextOrderId++,
|
|
298
|
-
data: tx,
|
|
299
|
-
};
|
|
300
|
-
const serializedTx = serializeTransaction(orderedTx);
|
|
301
|
-
const hexSenderAddress = tx.getSenderAddress().toString();
|
|
302
|
-
const accountTransactions = this._getQueuedForAddress(hexSenderAddress) ?? (0, immutable_1.List)();
|
|
303
|
-
const replaced = this._replaceQueuedTx(hexSenderAddress, orderedTx);
|
|
304
|
-
if (!replaced) {
|
|
305
|
-
this._setQueuedForAddress(hexSenderAddress, accountTransactions.push(serializedTx));
|
|
306
|
-
}
|
|
307
|
-
this._setTransactionByHash((0, ethereumjs_util_1.bufferToHex)(tx.hash()), serializedTx);
|
|
308
|
-
}
|
|
309
|
-
async _validateTransaction(tx, senderAddress, senderNonce) {
|
|
310
|
-
if (this._knownTransaction(tx)) {
|
|
311
|
-
throw new errors_1.InvalidInputError(`Known transaction: ${(0, ethereumjs_util_1.bufferToHex)(tx.hash())}`);
|
|
312
|
-
}
|
|
313
|
-
const txNonce = tx.nonce;
|
|
314
|
-
// Geth returns this error if trying to create a contract and no data is provided
|
|
315
|
-
if (tx.to === undefined && tx.data.length === 0) {
|
|
316
|
-
throw new errors_1.InvalidInputError("contract creation without any data provided");
|
|
317
|
-
}
|
|
318
|
-
const senderAccount = await this._stateManager.getAccount(senderAddress);
|
|
319
|
-
const senderBalance = senderAccount.balance;
|
|
320
|
-
const maxFee = "gasPrice" in tx ? tx.gasPrice : tx.maxFeePerGas;
|
|
321
|
-
const txMaxUpfrontCost = tx.gasLimit * maxFee + tx.value;
|
|
322
|
-
if (txMaxUpfrontCost > senderBalance) {
|
|
323
|
-
throw new errors_1.InvalidInputError(`sender doesn't have enough funds to send tx. The max upfront cost is: ${txMaxUpfrontCost.toString()}` +
|
|
324
|
-
` and the sender's account only has: ${senderBalance.toString()}`);
|
|
325
|
-
}
|
|
326
|
-
if (txNonce < senderNonce) {
|
|
327
|
-
throw new errors_1.InvalidInputError(`Nonce too low. Expected nonce to be at least ${senderNonce.toString()} but got ${txNonce.toString()}.`);
|
|
328
|
-
}
|
|
329
|
-
const gasLimit = tx.gasLimit;
|
|
330
|
-
const baseFee = tx.getBaseFee();
|
|
331
|
-
if (gasLimit < baseFee) {
|
|
332
|
-
throw new errors_1.InvalidInputError(`Transaction requires at least ${baseFee.toString()} gas but got ${gasLimit.toString()}`);
|
|
333
|
-
}
|
|
334
|
-
const blockGasLimit = this.getBlockGasLimit();
|
|
335
|
-
if (gasLimit > blockGasLimit) {
|
|
336
|
-
throw new errors_1.InvalidInputError(`Transaction gas limit is ${gasLimit.toString()} and exceeds block gas limit of ${blockGasLimit.toString()}`);
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
_knownTransaction(tx) {
|
|
340
|
-
const senderAddress = tx.getSenderAddress().toString();
|
|
341
|
-
return (this._transactionExists(tx, this._getPendingForAddress(senderAddress)) ||
|
|
342
|
-
this._transactionExists(tx, this._getQueuedForAddress(senderAddress)));
|
|
343
|
-
}
|
|
344
|
-
_transactionExists(tx, txList) {
|
|
345
|
-
const existingTx = txList?.find((etx) => this._deserializeTransaction(etx).data.hash().equals(tx.hash()));
|
|
346
|
-
return existingTx !== undefined;
|
|
347
|
-
}
|
|
348
|
-
_getTransactionsByHash() {
|
|
349
|
-
return this._state.get("hashToTransaction");
|
|
350
|
-
}
|
|
351
|
-
_getPending() {
|
|
352
|
-
return this._state.get("pendingTransactions");
|
|
353
|
-
}
|
|
354
|
-
_getQueued() {
|
|
355
|
-
return this._state.get("queuedTransactions");
|
|
356
|
-
}
|
|
357
|
-
_getPendingForAddress(address) {
|
|
358
|
-
return this._getPending().get(address);
|
|
359
|
-
}
|
|
360
|
-
_getQueuedForAddress(address) {
|
|
361
|
-
return this._getQueued().get(address);
|
|
362
|
-
}
|
|
363
|
-
_setTransactionByHash(hash, transaction) {
|
|
364
|
-
this._state = this._state.set("hashToTransaction", this._getTransactionsByHash().set(hash, transaction));
|
|
365
|
-
}
|
|
366
|
-
_setPending(transactions) {
|
|
367
|
-
this._state = this._state.set("pendingTransactions", transactions);
|
|
368
|
-
}
|
|
369
|
-
_setQueued(transactions) {
|
|
370
|
-
this._state = this._state.set("queuedTransactions", transactions);
|
|
371
|
-
}
|
|
372
|
-
_setPendingForAddress(address, transactions) {
|
|
373
|
-
this._state = this._state.set("pendingTransactions", this._getPending().set(address, transactions));
|
|
374
|
-
}
|
|
375
|
-
_setQueuedForAddress(address, transactions) {
|
|
376
|
-
this._state = this._state.set("queuedTransactions", this._getQueued().set(address, transactions));
|
|
377
|
-
}
|
|
378
|
-
_setBlockGasLimit(newLimit) {
|
|
379
|
-
this._state = this._state.set("blockGasLimit", BigIntUtils.toHex(newLimit));
|
|
380
|
-
}
|
|
381
|
-
_deleteTransactionByHash(hash) {
|
|
382
|
-
this._state = this._state.set("hashToTransaction", this._getTransactionsByHash().delete((0, ethereumjs_util_1.bufferToHex)(hash)));
|
|
383
|
-
}
|
|
384
|
-
_isTxValid(tx, txNonce, senderNonce, senderBalance) {
|
|
385
|
-
const txGasLimit = tx.data.gasLimit;
|
|
386
|
-
return (txGasLimit <= this.getBlockGasLimit() &&
|
|
387
|
-
txNonce >= senderNonce &&
|
|
388
|
-
tx.data.getUpfrontCost() <= senderBalance);
|
|
389
|
-
}
|
|
390
|
-
/**
|
|
391
|
-
* Returns the next available nonce for an address, ignoring its
|
|
392
|
-
* pending transactions.
|
|
393
|
-
*/
|
|
394
|
-
async _getNextConfirmedNonce(accountAddress) {
|
|
395
|
-
const account = await this._stateManager.getAccount(accountAddress);
|
|
396
|
-
return account.nonce;
|
|
397
|
-
}
|
|
398
|
-
/**
|
|
399
|
-
* Checks if some pending tx with the same nonce as `newTx` exists.
|
|
400
|
-
* If it exists, it replaces it with `newTx` and returns true.
|
|
401
|
-
* Otherwise returns false.
|
|
402
|
-
*/
|
|
403
|
-
_replacePendingTx(accountAddress, newTx) {
|
|
404
|
-
const pendingTxs = this._getPendingForAddress(accountAddress);
|
|
405
|
-
const newPendingTxs = this._replaceTx(pendingTxs, newTx);
|
|
406
|
-
if (newPendingTxs !== undefined) {
|
|
407
|
-
this._setPendingForAddress(accountAddress, newPendingTxs);
|
|
408
|
-
return true;
|
|
409
|
-
}
|
|
410
|
-
return false;
|
|
411
|
-
}
|
|
412
|
-
/**
|
|
413
|
-
* Checks if some queued tx with the same nonce as `newTx` exists.
|
|
414
|
-
* If it exists, it replaces it with `newTx` and returns true.
|
|
415
|
-
* Otherwise returns false.
|
|
416
|
-
*/
|
|
417
|
-
_replaceQueuedTx(accountAddress, newTx) {
|
|
418
|
-
const queuedTxs = this._getQueuedForAddress(accountAddress);
|
|
419
|
-
const newQueuedTxs = this._replaceTx(queuedTxs, newTx);
|
|
420
|
-
if (newQueuedTxs !== undefined) {
|
|
421
|
-
this._setQueuedForAddress(accountAddress, newQueuedTxs);
|
|
422
|
-
return true;
|
|
423
|
-
}
|
|
424
|
-
return false;
|
|
425
|
-
}
|
|
426
|
-
_replaceTx(txs, newTx) {
|
|
427
|
-
if (txs === undefined) {
|
|
428
|
-
return;
|
|
429
|
-
}
|
|
430
|
-
const existingTxEntry = txs.findEntry((tx) => this._deserializeTransaction(tx).data.nonce === newTx.data.nonce);
|
|
431
|
-
if (existingTxEntry === undefined) {
|
|
432
|
-
return;
|
|
433
|
-
}
|
|
434
|
-
const [existingTxIndex, existingTx] = existingTxEntry;
|
|
435
|
-
const deserializedExistingTx = this._deserializeTransaction(existingTx);
|
|
436
|
-
const currentMaxFeePerGas = "gasPrice" in deserializedExistingTx.data
|
|
437
|
-
? deserializedExistingTx.data.gasPrice
|
|
438
|
-
: deserializedExistingTx.data.maxFeePerGas;
|
|
439
|
-
const currentPriorityFeePerGas = "gasPrice" in deserializedExistingTx.data
|
|
440
|
-
? deserializedExistingTx.data.gasPrice
|
|
441
|
-
: deserializedExistingTx.data.maxPriorityFeePerGas;
|
|
442
|
-
const newMaxFeePerGas = "gasPrice" in newTx.data ? newTx.data.gasPrice : newTx.data.maxFeePerGas;
|
|
443
|
-
const newPriorityFeePerGas = "gasPrice" in newTx.data
|
|
444
|
-
? newTx.data.gasPrice
|
|
445
|
-
: newTx.data.maxPriorityFeePerGas;
|
|
446
|
-
const minNewMaxFeePerGas = this._getMinNewFeePrice(currentMaxFeePerGas);
|
|
447
|
-
const minNewPriorityFeePerGas = this._getMinNewFeePrice(currentPriorityFeePerGas);
|
|
448
|
-
if (newMaxFeePerGas < minNewMaxFeePerGas) {
|
|
449
|
-
throw new errors_1.InvalidInputError(`Replacement transaction underpriced. A gasPrice/maxFeePerGas of at least ${minNewMaxFeePerGas.toString()} is necessary to replace the existing transaction with nonce ${newTx.data.nonce.toString()}.`);
|
|
450
|
-
}
|
|
451
|
-
if (newPriorityFeePerGas < minNewPriorityFeePerGas) {
|
|
452
|
-
throw new errors_1.InvalidInputError(`Replacement transaction underpriced. A gasPrice/maxPriorityFeePerGas of at least ${minNewPriorityFeePerGas.toString()} is necessary to replace the existing transaction with nonce ${newTx.data.nonce.toString()}.`);
|
|
453
|
-
}
|
|
454
|
-
const newTxs = txs.set(existingTxIndex, serializeTransaction(newTx));
|
|
455
|
-
this._deleteTransactionByHash(deserializedExistingTx.data.hash());
|
|
456
|
-
return newTxs;
|
|
457
|
-
}
|
|
458
|
-
_getMinNewFeePrice(feePrice) {
|
|
459
|
-
let minNewPriorityFee = feePrice * 110n;
|
|
460
|
-
if (minNewPriorityFee % 100n === 0n) {
|
|
461
|
-
minNewPriorityFee = minNewPriorityFee / 100n;
|
|
462
|
-
}
|
|
463
|
-
else {
|
|
464
|
-
minNewPriorityFee = minNewPriorityFee / 100n + 1n;
|
|
465
|
-
}
|
|
466
|
-
return minNewPriorityFee;
|
|
467
|
-
}
|
|
468
|
-
}
|
|
469
|
-
exports.TxPool = TxPool;
|
|
470
|
-
//# sourceMappingURL=TxPool.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"TxPool.js","sourceRoot":"","sources":["../../../src/internal/hardhat-network/provider/TxPool.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ethereumjs-workarounds.d.ts","sourceRoot":"","sources":["../../../src/internal/hardhat-network/provider/ethereumjs-workarounds.ts"],"names":[],"mappings":""}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const ethereumjs_tx_1 = require("@nomicfoundation/ethereumjs-tx");
|
|
4
|
-
const baseTransaction_1 = require("@nomicfoundation/ethereumjs-tx/dist/baseTransaction");
|
|
5
|
-
// This is a hack to prevent Block.fromBlockData from recreating our
|
|
6
|
-
// transactions and changing their types. Note fromBlockData is used
|
|
7
|
-
// by the BlockBuilder to update block it's building.
|
|
8
|
-
const previousFromTxData = ethereumjs_tx_1.TransactionFactory.fromTxData;
|
|
9
|
-
ethereumjs_tx_1.TransactionFactory.fromTxData = function (txData, txOptions) {
|
|
10
|
-
if (txData instanceof baseTransaction_1.BaseTransaction) {
|
|
11
|
-
return txData;
|
|
12
|
-
}
|
|
13
|
-
return previousFromTxData.call(this, txData, txOptions);
|
|
14
|
-
};
|
|
15
|
-
//# sourceMappingURL=ethereumjs-workarounds.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ethereumjs-workarounds.js","sourceRoot":"","sources":["../../../src/internal/hardhat-network/provider/ethereumjs-workarounds.ts"],"names":[],"mappings":";;AAAA,kEAAoE;AACpE,yFAAsF;AAOtF,oEAAoE;AACpE,oEAAoE;AACpE,qDAAqD;AACrD,MAAM,kBAAkB,GAAG,kCAAkB,CAAC,UAAU,CAAC;AACxD,kCAA0B,CAAC,UAAU,GAAG,UACvC,MAAwC,EACxC,SAAqB;IAErB,IAAI,MAAM,YAAY,iCAAe,EAAE;QACrC,OAAO,MAAM,CAAC;KACf;IAED,OAAO,kBAAkB,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;AAC1D,CAAC,CAAC"}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { Bloom } from "@nomicfoundation/ethereumjs-vm";
|
|
3
|
-
import { RpcLogOutput } from "./output";
|
|
4
|
-
export declare const LATEST_BLOCK = -1n;
|
|
5
|
-
export declare enum Type {
|
|
6
|
-
LOGS_SUBSCRIPTION = 0,
|
|
7
|
-
PENDING_TRANSACTION_SUBSCRIPTION = 1,
|
|
8
|
-
BLOCK_SUBSCRIPTION = 2
|
|
9
|
-
}
|
|
10
|
-
export interface FilterCriteria {
|
|
11
|
-
fromBlock: bigint;
|
|
12
|
-
toBlock: bigint;
|
|
13
|
-
addresses: Buffer[];
|
|
14
|
-
normalizedTopics: Array<Array<Buffer | null> | null>;
|
|
15
|
-
}
|
|
16
|
-
export interface Filter {
|
|
17
|
-
id: bigint;
|
|
18
|
-
type: Type;
|
|
19
|
-
criteria?: FilterCriteria;
|
|
20
|
-
deadline: Date;
|
|
21
|
-
hashes: string[];
|
|
22
|
-
logs: RpcLogOutput[];
|
|
23
|
-
subscription: boolean;
|
|
24
|
-
}
|
|
25
|
-
export declare function bloomFilter(bloom: Bloom, addresses: Buffer[], normalizedTopics: Array<Array<Buffer | null> | null>): boolean;
|
|
26
|
-
export declare function filterLogs(logs: RpcLogOutput[], criteria: FilterCriteria): RpcLogOutput[];
|
|
27
|
-
export declare function includes(addresses: Buffer[], a: Buffer): boolean;
|
|
28
|
-
export declare function topicMatched(normalizedTopics: Array<Array<Buffer | null> | null>, logTopics: string[]): boolean;
|
|
29
|
-
//# sourceMappingURL=filter.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../../src/internal/hardhat-network/provider/filter.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,eAAO,MAAM,YAAY,MAAM,CAAC;AAEhC,oBAAY,IAAI;IACd,iBAAiB,IAAI;IACrB,gCAAgC,IAAI;IACpC,kBAAkB,IAAI;CACvB;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,gBAAgB,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;CACtD;AAED,MAAM,WAAW,MAAM;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,IAAI,CAAC;IACX,QAAQ,CAAC,EAAE,cAAc,CAAC;IAC1B,QAAQ,EAAE,IAAI,CAAC;IACf,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,IAAI,EAAE,YAAY,EAAE,CAAC;IACrB,YAAY,EAAE,OAAO,CAAC;CACvB;AAED,wBAAgB,WAAW,CACzB,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,MAAM,EAAE,EACnB,gBAAgB,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC,GACnD,OAAO,CAiCT;AAED,wBAAgB,UAAU,CACxB,IAAI,EAAE,YAAY,EAAE,EACpB,QAAQ,EAAE,cAAc,GACvB,YAAY,EAAE,CA2BhB;AAED,wBAAgB,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAQhE;AAED,wBAAgB,YAAY,CAC1B,gBAAgB,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC,EACpD,SAAS,EAAE,MAAM,EAAE,GAClB,OAAO,CAwBT"}
|
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.topicMatched = exports.includes = exports.filterLogs = exports.bloomFilter = exports.Type = exports.LATEST_BLOCK = void 0;
|
|
4
|
-
const ethereumjs_util_1 = require("@nomicfoundation/ethereumjs-util");
|
|
5
|
-
exports.LATEST_BLOCK = -1n;
|
|
6
|
-
var Type;
|
|
7
|
-
(function (Type) {
|
|
8
|
-
Type[Type["LOGS_SUBSCRIPTION"] = 0] = "LOGS_SUBSCRIPTION";
|
|
9
|
-
Type[Type["PENDING_TRANSACTION_SUBSCRIPTION"] = 1] = "PENDING_TRANSACTION_SUBSCRIPTION";
|
|
10
|
-
Type[Type["BLOCK_SUBSCRIPTION"] = 2] = "BLOCK_SUBSCRIPTION";
|
|
11
|
-
})(Type = exports.Type || (exports.Type = {}));
|
|
12
|
-
function bloomFilter(bloom, addresses, normalizedTopics) {
|
|
13
|
-
if (addresses.length > 0) {
|
|
14
|
-
let included = false;
|
|
15
|
-
for (const address of addresses) {
|
|
16
|
-
if (bloom.check(address)) {
|
|
17
|
-
included = true;
|
|
18
|
-
break;
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
if (!included) {
|
|
22
|
-
return false;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
for (const sub of normalizedTopics) {
|
|
26
|
-
if (sub === null || sub.length === 0) {
|
|
27
|
-
continue;
|
|
28
|
-
}
|
|
29
|
-
let included = false;
|
|
30
|
-
for (const topic of sub) {
|
|
31
|
-
if (topic !== null && bloom.check(topic)) {
|
|
32
|
-
included = true;
|
|
33
|
-
break;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
if (!included) {
|
|
37
|
-
return false;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
return true;
|
|
41
|
-
}
|
|
42
|
-
exports.bloomFilter = bloomFilter;
|
|
43
|
-
function filterLogs(logs, criteria) {
|
|
44
|
-
const filteredLogs = [];
|
|
45
|
-
for (const log of logs) {
|
|
46
|
-
const blockNumber = BigInt(log.blockNumber);
|
|
47
|
-
if (blockNumber < criteria.fromBlock) {
|
|
48
|
-
continue;
|
|
49
|
-
}
|
|
50
|
-
if (criteria.toBlock !== exports.LATEST_BLOCK && blockNumber > criteria.toBlock) {
|
|
51
|
-
continue;
|
|
52
|
-
}
|
|
53
|
-
if (criteria.addresses.length !== 0 &&
|
|
54
|
-
!includes(criteria.addresses, (0, ethereumjs_util_1.toBuffer)(log.address))) {
|
|
55
|
-
continue;
|
|
56
|
-
}
|
|
57
|
-
if (!topicMatched(criteria.normalizedTopics, log.topics)) {
|
|
58
|
-
continue;
|
|
59
|
-
}
|
|
60
|
-
filteredLogs.push(log);
|
|
61
|
-
}
|
|
62
|
-
return filteredLogs;
|
|
63
|
-
}
|
|
64
|
-
exports.filterLogs = filterLogs;
|
|
65
|
-
function includes(addresses, a) {
|
|
66
|
-
for (const address of addresses) {
|
|
67
|
-
if (Buffer.compare(address, a) === 0) {
|
|
68
|
-
return true;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
return false;
|
|
72
|
-
}
|
|
73
|
-
exports.includes = includes;
|
|
74
|
-
function topicMatched(normalizedTopics, logTopics) {
|
|
75
|
-
for (let i = 0; i < normalizedTopics.length; i++) {
|
|
76
|
-
if (normalizedTopics.length > logTopics.length) {
|
|
77
|
-
return false;
|
|
78
|
-
}
|
|
79
|
-
const sub = normalizedTopics[i];
|
|
80
|
-
if (sub === null || sub.length === 0) {
|
|
81
|
-
continue;
|
|
82
|
-
}
|
|
83
|
-
let match = false;
|
|
84
|
-
for (const topic of sub) {
|
|
85
|
-
if (topic === null || logTopics[i] === (0, ethereumjs_util_1.bufferToHex)(topic)) {
|
|
86
|
-
match = true;
|
|
87
|
-
break;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
if (!match) {
|
|
91
|
-
return false;
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
return true;
|
|
95
|
-
}
|
|
96
|
-
exports.topicMatched = topicMatched;
|
|
97
|
-
//# sourceMappingURL=filter.js.map
|