hardhatjs 2.22.15
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/.eslintrc.js +41 -0
- package/LICENSE +55 -0
- package/README.md +53 -0
- package/builtin-tasks/check.d.ts +2 -0
- package/builtin-tasks/check.d.ts.map +1 -0
- package/builtin-tasks/check.js +6 -0
- package/builtin-tasks/check.js.map +1 -0
- package/builtin-tasks/clean.d.ts +2 -0
- package/builtin-tasks/clean.d.ts.map +1 -0
- package/builtin-tasks/clean.js +24 -0
- package/builtin-tasks/clean.js.map +1 -0
- package/builtin-tasks/compile.d.ts +2 -0
- package/builtin-tasks/compile.d.ts.map +1 -0
- package/builtin-tasks/compile.js +952 -0
- package/builtin-tasks/compile.js.map +1 -0
- package/builtin-tasks/console.d.ts +2 -0
- package/builtin-tasks/console.d.ts.map +1 -0
- package/builtin-tasks/console.js +55 -0
- package/builtin-tasks/console.js.map +1 -0
- package/builtin-tasks/flatten.d.ts +2 -0
- package/builtin-tasks/flatten.d.ts.map +1 -0
- package/builtin-tasks/flatten.js +210 -0
- package/builtin-tasks/flatten.js.map +1 -0
- package/builtin-tasks/help.d.ts +2 -0
- package/builtin-tasks/help.d.ts.map +1 -0
- package/builtin-tasks/help.js +49 -0
- package/builtin-tasks/help.js.map +1 -0
- package/builtin-tasks/node.d.ts +2 -0
- package/builtin-tasks/node.d.ts.map +1 -0
- package/builtin-tasks/node.js +212 -0
- package/builtin-tasks/node.js.map +1 -0
- package/builtin-tasks/run.d.ts +2 -0
- package/builtin-tasks/run.d.ts.map +1 -0
- package/builtin-tasks/run.js +41 -0
- package/builtin-tasks/run.js.map +1 -0
- package/builtin-tasks/task-names.d.ts +55 -0
- package/builtin-tasks/task-names.d.ts.map +1 -0
- package/builtin-tasks/task-names.js +59 -0
- package/builtin-tasks/task-names.js.map +1 -0
- package/builtin-tasks/test.d.ts +2 -0
- package/builtin-tasks/test.d.ts.map +1 -0
- package/builtin-tasks/test.js +142 -0
- package/builtin-tasks/test.js.map +1 -0
- package/builtin-tasks/utils/solidity-files-cache.d.ts +29 -0
- package/builtin-tasks/utils/solidity-files-cache.d.ts.map +1 -0
- package/builtin-tasks/utils/solidity-files-cache.js +126 -0
- package/builtin-tasks/utils/solidity-files-cache.js.map +1 -0
- package/builtin-tasks/utils/watch.d.ts +5 -0
- package/builtin-tasks/utils/watch.d.ts.map +1 -0
- package/builtin-tasks/utils/watch.js +71 -0
- package/builtin-tasks/utils/watch.js.map +1 -0
- package/builtin-tasks/vars.d.ts +2 -0
- package/builtin-tasks/vars.d.ts.map +1 -0
- package/builtin-tasks/vars.js +41 -0
- package/builtin-tasks/vars.js.map +1 -0
- package/common/bigInt.d.ts +7 -0
- package/common/bigInt.d.ts.map +1 -0
- package/common/bigInt.js +93 -0
- package/common/bigInt.js.map +1 -0
- package/common/index.d.ts +3 -0
- package/common/index.d.ts.map +1 -0
- package/common/index.js +21 -0
- package/common/index.js.map +1 -0
- package/common/napi-rs.d.ts +2 -0
- package/common/napi-rs.d.ts.map +1 -0
- package/common/napi-rs.js +19 -0
- package/common/napi-rs.js.map +1 -0
- package/config.d.ts +3 -0
- package/config.d.ts.map +1 -0
- package/config.js +18 -0
- package/config.js.map +1 -0
- package/console.sol +1552 -0
- package/internal/artifacts.d.ts +151 -0
- package/internal/artifacts.d.ts.map +1 -0
- package/internal/artifacts.js +681 -0
- package/internal/artifacts.js.map +1 -0
- package/internal/cli/ArgumentsParser.d.ts +25 -0
- package/internal/cli/ArgumentsParser.d.ts.map +1 -0
- package/internal/cli/ArgumentsParser.js +242 -0
- package/internal/cli/ArgumentsParser.js.map +1 -0
- package/internal/cli/HelpPrinter.d.ts +21 -0
- package/internal/cli/HelpPrinter.d.ts.map +1 -0
- package/internal/cli/HelpPrinter.js +167 -0
- package/internal/cli/HelpPrinter.js.map +1 -0
- package/internal/cli/analytics.d.ts +29 -0
- package/internal/cli/analytics.d.ts.map +1 -0
- package/internal/cli/analytics.js +188 -0
- package/internal/cli/analytics.js.map +1 -0
- package/internal/cli/autocomplete.d.ts +13 -0
- package/internal/cli/autocomplete.d.ts.map +1 -0
- package/internal/cli/autocomplete.js +291 -0
- package/internal/cli/autocomplete.js.map +1 -0
- package/internal/cli/bootstrap.d.ts +3 -0
- package/internal/cli/bootstrap.d.ts.map +1 -0
- package/internal/cli/bootstrap.js +15 -0
- package/internal/cli/bootstrap.js.map +1 -0
- package/internal/cli/cli.d.ts +2 -0
- package/internal/cli/cli.d.ts.map +1 -0
- package/internal/cli/cli.js +344 -0
- package/internal/cli/cli.js.map +1 -0
- package/internal/cli/constants.d.ts +2 -0
- package/internal/cli/constants.d.ts.map +1 -0
- package/internal/cli/constants.js +5 -0
- package/internal/cli/constants.js.map +1 -0
- package/internal/cli/emoji.d.ts +3 -0
- package/internal/cli/emoji.d.ts.map +1 -0
- package/internal/cli/emoji.js +13 -0
- package/internal/cli/emoji.js.map +1 -0
- package/internal/cli/hardhat-vscode-installation.d.ts +8 -0
- package/internal/cli/hardhat-vscode-installation.d.ts.map +1 -0
- package/internal/cli/hardhat-vscode-installation.js +41 -0
- package/internal/cli/hardhat-vscode-installation.js.map +1 -0
- 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 +4 -0
- package/internal/cli/project-creation.d.ts.map +1 -0
- package/internal/cli/project-creation.js +506 -0
- package/internal/cli/project-creation.js.map +1 -0
- package/internal/cli/prompt.d.ts +14 -0
- package/internal/cli/prompt.d.ts.map +1 -0
- package/internal/cli/prompt.js +123 -0
- package/internal/cli/prompt.js.map +1 -0
- package/internal/cli/types.d.ts +5 -0
- package/internal/cli/types.d.ts.map +1 -0
- package/internal/cli/types.js +3 -0
- package/internal/cli/types.js.map +1 -0
- package/internal/cli/vars.d.ts +2 -0
- package/internal/cli/vars.d.ts.map +1 -0
- package/internal/cli/vars.js +216 -0
- package/internal/cli/vars.js.map +1 -0
- package/internal/cli/version-notifier.d.ts +2 -0
- package/internal/cli/version-notifier.d.ts.map +1 -0
- package/internal/cli/version-notifier.js +217 -0
- package/internal/cli/version-notifier.js.map +1 -0
- package/internal/constants.d.ts +14 -0
- package/internal/constants.d.ts.map +1 -0
- package/internal/constants.js +35 -0
- package/internal/constants.js.map +1 -0
- package/internal/context.d.ts +29 -0
- package/internal/context.d.ts.map +1 -0
- package/internal/context.js +74 -0
- package/internal/context.js.map +1 -0
- package/internal/core/config/config-env.d.ts +111 -0
- package/internal/core/config/config-env.d.ts.map +1 -0
- package/internal/core/config/config-env.js +144 -0
- package/internal/core/config/config-env.js.map +1 -0
- package/internal/core/config/config-loading.d.ts +20 -0
- package/internal/core/config/config-loading.d.ts.map +1 -0
- package/internal/core/config/config-loading.js +246 -0
- package/internal/core/config/config-loading.js.map +1 -0
- package/internal/core/config/config-resolution.d.ts +25 -0
- package/internal/core/config/config-resolution.d.ts.map +1 -0
- package/internal/core/config/config-resolution.js +336 -0
- package/internal/core/config/config-resolution.js.map +1 -0
- package/internal/core/config/config-validation.d.ts +18 -0
- package/internal/core/config/config-validation.d.ts.map +1 -0
- package/internal/core/config/config-validation.js +400 -0
- package/internal/core/config/config-validation.js.map +1 -0
- package/internal/core/config/default-config.d.ts +45 -0
- package/internal/core/config/default-config.d.ts.map +1 -0
- package/internal/core/config/default-config.js +186 -0
- package/internal/core/config/default-config.js.map +1 -0
- package/internal/core/errors-list.d.ts +948 -0
- package/internal/core/errors-list.d.ts.map +1 -0
- package/internal/core/errors-list.js +1282 -0
- package/internal/core/errors-list.js.map +1 -0
- package/internal/core/errors.d.ts +74 -0
- package/internal/core/errors.d.ts.map +1 -0
- package/internal/core/errors.js +178 -0
- package/internal/core/errors.js.map +1 -0
- package/internal/core/execution-mode.d.ts +14 -0
- package/internal/core/execution-mode.d.ts.map +1 -0
- package/internal/core/execution-mode.js +40 -0
- package/internal/core/execution-mode.js.map +1 -0
- package/internal/core/flamegraph.d.ts +14 -0
- package/internal/core/flamegraph.d.ts.map +1 -0
- package/internal/core/flamegraph.js +255 -0
- package/internal/core/flamegraph.js.map +1 -0
- package/internal/core/jsonrpc/types/access-list.d.ts +13 -0
- package/internal/core/jsonrpc/types/access-list.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/access-list.js +35 -0
- package/internal/core/jsonrpc/types/access-list.js.map +1 -0
- package/internal/core/jsonrpc/types/base-types.d.ts +28 -0
- package/internal/core/jsonrpc/types/base-types.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/base-types.js +152 -0
- package/internal/core/jsonrpc/types/base-types.js.map +1 -0
- package/internal/core/jsonrpc/types/input/blockTag.d.ts +51 -0
- package/internal/core/jsonrpc/types/input/blockTag.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/blockTag.js +55 -0
- package/internal/core/jsonrpc/types/input/blockTag.js.map +1 -0
- package/internal/core/jsonrpc/types/input/callRequest.d.ts +82 -0
- package/internal/core/jsonrpc/types/input/callRequest.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/callRequest.js +57 -0
- package/internal/core/jsonrpc/types/input/callRequest.js.map +1 -0
- package/internal/core/jsonrpc/types/input/debugTraceTransaction.d.ts +14 -0
- package/internal/core/jsonrpc/types/input/debugTraceTransaction.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/debugTraceTransaction.js +35 -0
- package/internal/core/jsonrpc/types/input/debugTraceTransaction.js.map +1 -0
- package/internal/core/jsonrpc/types/input/filterRequest.d.ts +24 -0
- package/internal/core/jsonrpc/types/input/filterRequest.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/filterRequest.js +41 -0
- package/internal/core/jsonrpc/types/input/filterRequest.js.map +1 -0
- package/internal/core/jsonrpc/types/input/hardhat-network.d.ts +51 -0
- package/internal/core/jsonrpc/types/input/hardhat-network.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/hardhat-network.js +51 -0
- package/internal/core/jsonrpc/types/input/hardhat-network.js.map +1 -0
- package/internal/core/jsonrpc/types/input/logAddress.d.ts +7 -0
- package/internal/core/jsonrpc/types/input/logAddress.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/logAddress.js +32 -0
- package/internal/core/jsonrpc/types/input/logAddress.js.map +1 -0
- package/internal/core/jsonrpc/types/input/logTopics.d.ts +7 -0
- package/internal/core/jsonrpc/types/input/logTopics.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/logTopics.js +32 -0
- package/internal/core/jsonrpc/types/input/logTopics.js.map +1 -0
- package/internal/core/jsonrpc/types/input/solc.d.ts +13 -0
- package/internal/core/jsonrpc/types/input/solc.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/solc.js +37 -0
- package/internal/core/jsonrpc/types/input/solc.js.map +1 -0
- package/internal/core/jsonrpc/types/input/subscribeRequest.d.ts +12 -0
- package/internal/core/jsonrpc/types/input/subscribeRequest.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/subscribeRequest.js +33 -0
- package/internal/core/jsonrpc/types/input/subscribeRequest.js.map +1 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.d.ts +41 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.js +47 -0
- package/internal/core/jsonrpc/types/input/transactionRequest.js.map +1 -0
- package/internal/core/jsonrpc/types/input/validation.d.ts +12 -0
- package/internal/core/jsonrpc/types/input/validation.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/input/validation.js +49 -0
- package/internal/core/jsonrpc/types/input/validation.js.map +1 -0
- package/internal/core/jsonrpc/types/output/block.d.ts +106 -0
- package/internal/core/jsonrpc/types/output/block.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/block.js +72 -0
- package/internal/core/jsonrpc/types/output/block.js.map +1 -0
- package/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.d.ts +6 -0
- package/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.js +20 -0
- package/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.js.map +1 -0
- package/internal/core/jsonrpc/types/output/log.d.ts +13 -0
- package/internal/core/jsonrpc/types/output/log.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/log.js +40 -0
- package/internal/core/jsonrpc/types/output/log.js.map +1 -0
- package/internal/core/jsonrpc/types/output/metadata.d.ts +13 -0
- package/internal/core/jsonrpc/types/output/metadata.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/metadata.js +3 -0
- package/internal/core/jsonrpc/types/output/metadata.js.map +1 -0
- package/internal/core/jsonrpc/types/output/receipt.d.ts +29 -0
- package/internal/core/jsonrpc/types/output/receipt.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/receipt.js +52 -0
- package/internal/core/jsonrpc/types/output/receipt.js.map +1 -0
- package/internal/core/jsonrpc/types/output/transaction.d.ts +30 -0
- package/internal/core/jsonrpc/types/output/transaction.d.ts.map +1 -0
- package/internal/core/jsonrpc/types/output/transaction.js +55 -0
- package/internal/core/jsonrpc/types/output/transaction.js.map +1 -0
- package/internal/core/params/argumentTypes.d.ts +41 -0
- package/internal/core/params/argumentTypes.d.ts.map +1 -0
- package/internal/core/params/argumentTypes.js +315 -0
- package/internal/core/params/argumentTypes.js.map +1 -0
- package/internal/core/params/env-variables.d.ts +9 -0
- package/internal/core/params/env-variables.d.ts.map +1 -0
- package/internal/core/params/env-variables.js +58 -0
- package/internal/core/params/env-variables.js.map +1 -0
- package/internal/core/params/hardhat-params.d.ts +3 -0
- package/internal/core/params/hardhat-params.d.ts.map +1 -0
- package/internal/core/params/hardhat-params.js +129 -0
- package/internal/core/params/hardhat-params.js.map +1 -0
- package/internal/core/project-structure.d.ts +4 -0
- package/internal/core/project-structure.d.ts.map +1 -0
- package/internal/core/project-structure.js +50 -0
- package/internal/core/project-structure.js.map +1 -0
- package/internal/core/providers/accounts.d.ts +40 -0
- package/internal/core/providers/accounts.d.ts.map +1 -0
- package/internal/core/providers/accounts.js +266 -0
- package/internal/core/providers/accounts.js.map +1 -0
- package/internal/core/providers/backwards-compatibility.d.ts +18 -0
- package/internal/core/providers/backwards-compatibility.d.ts.map +1 -0
- package/internal/core/providers/backwards-compatibility.js +66 -0
- package/internal/core/providers/backwards-compatibility.js.map +1 -0
- package/internal/core/providers/chainId.d.ts +15 -0
- package/internal/core/providers/chainId.d.ts.map +1 -0
- package/internal/core/providers/chainId.js +58 -0
- package/internal/core/providers/chainId.js.map +1 -0
- package/internal/core/providers/construction.d.ts +5 -0
- package/internal/core/providers/construction.d.ts.map +1 -0
- package/internal/core/providers/construction.js +166 -0
- package/internal/core/providers/construction.js.map +1 -0
- package/internal/core/providers/errors.d.ts +47 -0
- package/internal/core/providers/errors.d.ts.map +1 -0
- package/internal/core/providers/errors.js +110 -0
- package/internal/core/providers/errors.js.map +1 -0
- package/internal/core/providers/gas-providers.d.ts +34 -0
- package/internal/core/providers/gas-providers.d.ts.map +1 -0
- package/internal/core/providers/gas-providers.js +228 -0
- package/internal/core/providers/gas-providers.js.map +1 -0
- package/internal/core/providers/http.d.ts +35 -0
- package/internal/core/providers/http.d.ts.map +1 -0
- package/internal/core/providers/http.js +226 -0
- package/internal/core/providers/http.js.map +1 -0
- package/internal/core/providers/lazy-initialization.d.ts +44 -0
- package/internal/core/providers/lazy-initialization.d.ts.map +1 -0
- package/internal/core/providers/lazy-initialization.js +137 -0
- package/internal/core/providers/lazy-initialization.js.map +1 -0
- package/internal/core/providers/util.d.ts +5 -0
- package/internal/core/providers/util.d.ts.map +1 -0
- package/internal/core/providers/util.js +41 -0
- package/internal/core/providers/util.js.map +1 -0
- package/internal/core/providers/wrapper.d.ts +19 -0
- package/internal/core/providers/wrapper.d.ts.map +1 -0
- package/internal/core/providers/wrapper.js +34 -0
- package/internal/core/providers/wrapper.js.map +1 -0
- package/internal/core/runtime-environment.d.ts +86 -0
- package/internal/core/runtime-environment.d.ts.map +1 -0
- package/internal/core/runtime-environment.js +317 -0
- package/internal/core/runtime-environment.js.map +1 -0
- package/internal/core/task-profiling.d.ts +18 -0
- package/internal/core/task-profiling.d.ts.map +1 -0
- package/internal/core/task-profiling.js +50 -0
- package/internal/core/task-profiling.js.map +1 -0
- package/internal/core/tasks/builtin-tasks.d.ts +11 -0
- package/internal/core/tasks/builtin-tasks.d.ts.map +1 -0
- package/internal/core/tasks/builtin-tasks.js +13 -0
- package/internal/core/tasks/builtin-tasks.js.map +1 -0
- package/internal/core/tasks/dsl.d.ts +76 -0
- package/internal/core/tasks/dsl.d.ts.map +1 -0
- package/internal/core/tasks/dsl.js +112 -0
- package/internal/core/tasks/dsl.js.map +1 -0
- package/internal/core/tasks/task-definitions.d.ts +266 -0
- package/internal/core/tasks/task-definitions.d.ts.map +1 -0
- package/internal/core/tasks/task-definitions.js +555 -0
- package/internal/core/tasks/task-definitions.js.map +1 -0
- package/internal/core/tasks/util.d.ts +6 -0
- package/internal/core/tasks/util.d.ts.map +1 -0
- package/internal/core/tasks/util.js +19 -0
- package/internal/core/tasks/util.js.map +1 -0
- package/internal/core/typescript-support.d.ts +15 -0
- package/internal/core/typescript-support.d.ts.map +1 -0
- package/internal/core/typescript-support.js +85 -0
- package/internal/core/typescript-support.js.map +1 -0
- package/internal/core/vars/vars-manager-setup.d.ts +22 -0
- package/internal/core/vars/vars-manager-setup.d.ts.map +1 -0
- package/internal/core/vars/vars-manager-setup.js +95 -0
- package/internal/core/vars/vars-manager-setup.js.map +1 -0
- package/internal/core/vars/vars-manager.d.ts +21 -0
- package/internal/core/vars/vars-manager.d.ts.map +1 -0
- package/internal/core/vars/vars-manager.js +110 -0
- package/internal/core/vars/vars-manager.js.map +1 -0
- package/internal/hardhat-network/jsonrpc/client.d.ts +109 -0
- package/internal/hardhat-network/jsonrpc/client.d.ts.map +1 -0
- package/internal/hardhat-network/jsonrpc/client.js +294 -0
- package/internal/hardhat-network/jsonrpc/client.js.map +1 -0
- package/internal/hardhat-network/jsonrpc/handler.d.ts +16 -0
- package/internal/hardhat-network/jsonrpc/handler.d.ts.map +1 -0
- package/internal/hardhat-network/jsonrpc/handler.js +218 -0
- package/internal/hardhat-network/jsonrpc/handler.js.map +1 -0
- package/internal/hardhat-network/jsonrpc/server.d.ts +20 -0
- package/internal/hardhat-network/jsonrpc/server.d.ts.map +1 -0
- package/internal/hardhat-network/jsonrpc/server.js +82 -0
- package/internal/hardhat-network/jsonrpc/server.js.map +1 -0
- package/internal/hardhat-network/provider/fork/AccountState.d.ts +11 -0
- package/internal/hardhat-network/provider/fork/AccountState.d.ts.map +1 -0
- package/internal/hardhat-network/provider/fork/AccountState.js +21 -0
- package/internal/hardhat-network/provider/fork/AccountState.js.map +1 -0
- package/internal/hardhat-network/provider/modules/logger.d.ts +8 -0
- package/internal/hardhat-network/provider/modules/logger.d.ts.map +1 -0
- package/internal/hardhat-network/provider/modules/logger.js +28 -0
- package/internal/hardhat-network/provider/modules/logger.js.map +1 -0
- package/internal/hardhat-network/provider/node-types.d.ts +67 -0
- package/internal/hardhat-network/provider/node-types.d.ts.map +1 -0
- package/internal/hardhat-network/provider/node-types.js +3 -0
- package/internal/hardhat-network/provider/node-types.js.map +1 -0
- package/internal/hardhat-network/provider/output.d.ts +118 -0
- package/internal/hardhat-network/provider/output.d.ts.map +1 -0
- package/internal/hardhat-network/provider/output.js +3 -0
- package/internal/hardhat-network/provider/output.js.map +1 -0
- package/internal/hardhat-network/provider/provider.d.ts +64 -0
- package/internal/hardhat-network/provider/provider.d.ts.map +1 -0
- package/internal/hardhat-network/provider/provider.js +441 -0
- package/internal/hardhat-network/provider/provider.js.map +1 -0
- package/internal/hardhat-network/provider/return-data.d.ts +3 -0
- package/internal/hardhat-network/provider/return-data.d.ts.map +1 -0
- package/internal/hardhat-network/provider/return-data.js +7 -0
- package/internal/hardhat-network/provider/return-data.js.map +1 -0
- package/internal/hardhat-network/provider/utils/assertions.d.ts +2 -0
- package/internal/hardhat-network/provider/utils/assertions.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/assertions.js +12 -0
- package/internal/hardhat-network/provider/utils/assertions.js.map +1 -0
- package/internal/hardhat-network/provider/utils/convertToEdr.d.ts +14 -0
- package/internal/hardhat-network/provider/utils/convertToEdr.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/convertToEdr.js +224 -0
- package/internal/hardhat-network/provider/utils/convertToEdr.js.map +1 -0
- package/internal/hardhat-network/provider/utils/disk-cache.d.ts +3 -0
- package/internal/hardhat-network/provider/utils/disk-cache.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/disk-cache.js +12 -0
- package/internal/hardhat-network/provider/utils/disk-cache.js.map +1 -0
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.d.ts +3 -0
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.js +38 -0
- package/internal/hardhat-network/provider/utils/fork-recomendations-banner.js.map +1 -0
- package/internal/hardhat-network/provider/utils/getCurrentTimestamp.d.ts +2 -0
- package/internal/hardhat-network/provider/utils/getCurrentTimestamp.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/getCurrentTimestamp.js +8 -0
- package/internal/hardhat-network/provider/utils/getCurrentTimestamp.js.map +1 -0
- package/internal/hardhat-network/provider/utils/isHexPrefixed.d.ts +2 -0
- package/internal/hardhat-network/provider/utils/isHexPrefixed.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/isHexPrefixed.js +8 -0
- package/internal/hardhat-network/provider/utils/isHexPrefixed.js.map +1 -0
- package/internal/hardhat-network/provider/utils/makeAccount.d.ts +7 -0
- package/internal/hardhat-network/provider/utils/makeAccount.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/makeAccount.js +20 -0
- package/internal/hardhat-network/provider/utils/makeAccount.js.map +1 -0
- package/internal/hardhat-network/provider/utils/makeCommon.d.ts +4 -0
- package/internal/hardhat-network/provider/utils/makeCommon.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/makeCommon.js +17 -0
- package/internal/hardhat-network/provider/utils/makeCommon.js.map +1 -0
- package/internal/hardhat-network/provider/utils/makeForkClient.d.ts +19 -0
- package/internal/hardhat-network/provider/utils/makeForkClient.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/makeForkClient.js +99 -0
- package/internal/hardhat-network/provider/utils/makeForkClient.js.map +1 -0
- package/internal/hardhat-network/provider/utils/random.d.ts +17 -0
- package/internal/hardhat-network/provider/utils/random.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/random.js +55 -0
- package/internal/hardhat-network/provider/utils/random.js.map +1 -0
- package/internal/hardhat-network/provider/utils/reorgs-protection.d.ts +10 -0
- package/internal/hardhat-network/provider/utils/reorgs-protection.d.ts.map +1 -0
- package/internal/hardhat-network/provider/utils/reorgs-protection.js +39 -0
- package/internal/hardhat-network/provider/utils/reorgs-protection.js.map +1 -0
- package/internal/hardhat-network/provider/vm/exit.d.ts +3 -0
- package/internal/hardhat-network/provider/vm/exit.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/exit.js +7 -0
- package/internal/hardhat-network/provider/vm/exit.js.map +1 -0
- package/internal/hardhat-network/provider/vm/minimal-vm.d.ts +36 -0
- package/internal/hardhat-network/provider/vm/minimal-vm.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/minimal-vm.js +53 -0
- package/internal/hardhat-network/provider/vm/minimal-vm.js.map +1 -0
- package/internal/hardhat-network/provider/vm/types.d.ts +36 -0
- package/internal/hardhat-network/provider/vm/types.d.ts.map +1 -0
- package/internal/hardhat-network/provider/vm/types.js +3 -0
- package/internal/hardhat-network/provider/vm/types.js.map +1 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.js +7 -0
- package/internal/hardhat-network/stack-traces/compiler-to-model.js.map +1 -0
- package/internal/hardhat-network/stack-traces/consoleLogger.d.ts +23 -0
- package/internal/hardhat-network/stack-traces/consoleLogger.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/consoleLogger.js +159 -0
- package/internal/hardhat-network/stack-traces/consoleLogger.js.map +1 -0
- package/internal/hardhat-network/stack-traces/constants.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/constants.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/constants.js +6 -0
- package/internal/hardhat-network/stack-traces/constants.js.map +1 -0
- package/internal/hardhat-network/stack-traces/debug.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/debug.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/debug.js +8 -0
- package/internal/hardhat-network/stack-traces/debug.js.map +1 -0
- package/internal/hardhat-network/stack-traces/library-utils.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/library-utils.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/library-utils.js +7 -0
- package/internal/hardhat-network/stack-traces/library-utils.js.map +1 -0
- package/internal/hardhat-network/stack-traces/logger.d.ts +41 -0
- package/internal/hardhat-network/stack-traces/logger.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/logger.js +424 -0
- package/internal/hardhat-network/stack-traces/logger.js.map +1 -0
- package/internal/hardhat-network/stack-traces/message-trace.d.ts +4 -0
- package/internal/hardhat-network/stack-traces/message-trace.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/message-trace.js +3 -0
- package/internal/hardhat-network/stack-traces/message-trace.js.map +1 -0
- package/internal/hardhat-network/stack-traces/panic-errors.d.ts +2 -0
- package/internal/hardhat-network/stack-traces/panic-errors.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/panic-errors.js +34 -0
- package/internal/hardhat-network/stack-traces/panic-errors.js.map +1 -0
- package/internal/hardhat-network/stack-traces/solidity-errors.d.ts +14 -0
- package/internal/hardhat-network/stack-traces/solidity-errors.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/solidity-errors.js +284 -0
- package/internal/hardhat-network/stack-traces/solidity-errors.js.map +1 -0
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.d.ts +7 -0
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.js +15 -0
- package/internal/hardhat-network/stack-traces/solidity-stack-trace.js.map +1 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.js +7 -0
- package/internal/hardhat-network/stack-traces/solidityTracer.js.map +1 -0
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.d.ts +6 -0
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.js +27 -0
- package/internal/hardhat-network/stack-traces/vm-trace-decoder.js.map +1 -0
- package/internal/hardhat-network/stack-traces/vm-tracer.d.ts +3 -0
- package/internal/hardhat-network/stack-traces/vm-tracer.d.ts.map +1 -0
- package/internal/hardhat-network/stack-traces/vm-tracer.js +7 -0
- package/internal/hardhat-network/stack-traces/vm-tracer.js.map +1 -0
- package/internal/lib/hardhat-lib.d.ts +4 -0
- package/internal/lib/hardhat-lib.d.ts.map +1 -0
- package/internal/lib/hardhat-lib.js +35 -0
- package/internal/lib/hardhat-lib.js.map +1 -0
- package/internal/reset.d.ts +2 -0
- package/internal/reset.d.ts.map +1 -0
- package/internal/reset.js +35 -0
- package/internal/reset.js.map +1 -0
- package/internal/sentry/anonymizer.d.ts +31 -0
- package/internal/sentry/anonymizer.d.ts.map +1 -0
- package/internal/sentry/anonymizer.js +292 -0
- package/internal/sentry/anonymizer.js.map +1 -0
- package/internal/sentry/reporter.d.ts +42 -0
- package/internal/sentry/reporter.d.ts.map +1 -0
- package/internal/sentry/reporter.js +157 -0
- package/internal/sentry/reporter.js.map +1 -0
- package/internal/sentry/subprocess.d.ts +2 -0
- package/internal/sentry/subprocess.d.ts.map +1 -0
- package/internal/sentry/subprocess.js +85 -0
- package/internal/sentry/subprocess.js.map +1 -0
- package/internal/sentry/transport.d.ts +2 -0
- package/internal/sentry/transport.d.ts.map +1 -0
- package/internal/sentry/transport.js +64 -0
- package/internal/sentry/transport.js.map +1 -0
- package/internal/solidity/compilation-job.d.ts +38 -0
- package/internal/solidity/compilation-job.d.ts.map +1 -0
- package/internal/solidity/compilation-job.js +223 -0
- package/internal/solidity/compilation-job.js.map +1 -0
- package/internal/solidity/compiler/compiler-input.d.ts +3 -0
- package/internal/solidity/compiler/compiler-input.d.ts.map +1 -0
- package/internal/solidity/compiler/compiler-input.js +23 -0
- package/internal/solidity/compiler/compiler-input.js.map +1 -0
- package/internal/solidity/compiler/downloader.d.ts +79 -0
- package/internal/solidity/compiler/downloader.d.ts.map +1 -0
- package/internal/solidity/compiler/downloader.js +262 -0
- package/internal/solidity/compiler/downloader.js.map +1 -0
- package/internal/solidity/compiler/index.d.ts +16 -0
- package/internal/solidity/compiler/index.d.ts.map +1 -0
- package/internal/solidity/compiler/index.js +107 -0
- package/internal/solidity/compiler/index.js.map +1 -0
- package/internal/solidity/compiler/solc-info.d.ts +2 -0
- package/internal/solidity/compiler/solc-info.d.ts.map +1 -0
- package/internal/solidity/compiler/solc-info.js +75 -0
- package/internal/solidity/compiler/solc-info.js.map +1 -0
- package/internal/solidity/compiler/solcjs-runner.js +34 -0
- package/internal/solidity/dependencyGraph.d.ts +19 -0
- package/internal/solidity/dependencyGraph.d.ts.map +1 -0
- package/internal/solidity/dependencyGraph.js +127 -0
- package/internal/solidity/dependencyGraph.js.map +1 -0
- package/internal/solidity/parse.d.ts +19 -0
- package/internal/solidity/parse.d.ts.map +1 -0
- package/internal/solidity/parse.js +44 -0
- package/internal/solidity/parse.js.map +1 -0
- package/internal/solidity/resolver.d.ts +50 -0
- package/internal/solidity/resolver.d.ts.map +1 -0
- package/internal/solidity/resolver.js +337 -0
- package/internal/solidity/resolver.js.map +1 -0
- package/internal/util/abi-helpers.d.ts +13 -0
- package/internal/util/abi-helpers.d.ts.map +1 -0
- package/internal/util/abi-helpers.js +75 -0
- package/internal/util/abi-helpers.js.map +1 -0
- package/internal/util/bigint.d.ts +13 -0
- package/internal/util/bigint.d.ts.map +1 -0
- package/internal/util/bigint.js +60 -0
- package/internal/util/bigint.js.map +1 -0
- package/internal/util/caller-package.d.ts +5 -0
- package/internal/util/caller-package.d.ts.map +1 -0
- package/internal/util/caller-package.js +42 -0
- package/internal/util/caller-package.js.map +1 -0
- package/internal/util/ci-detection.d.ts +2 -0
- package/internal/util/ci-detection.d.ts.map +1 -0
- package/internal/util/ci-detection.js +53 -0
- package/internal/util/ci-detection.js.map +1 -0
- package/internal/util/console.d.ts +8 -0
- package/internal/util/console.d.ts.map +1 -0
- package/internal/util/console.js +25 -0
- package/internal/util/console.js.map +1 -0
- package/internal/util/date.d.ts +5 -0
- package/internal/util/date.d.ts.map +1 -0
- package/internal/util/date.js +20 -0
- package/internal/util/date.js.map +1 -0
- package/internal/util/download.d.ts +4 -0
- package/internal/util/download.d.ts.map +1 -0
- package/internal/util/download.js +77 -0
- package/internal/util/download.js.map +1 -0
- package/internal/util/event-emitter.d.ts +22 -0
- package/internal/util/event-emitter.d.ts.map +1 -0
- package/internal/util/event-emitter.js +76 -0
- package/internal/util/event-emitter.js.map +1 -0
- package/internal/util/fs-utils.d.ts +49 -0
- package/internal/util/fs-utils.d.ts.map +1 -0
- package/internal/util/fs-utils.js +194 -0
- package/internal/util/fs-utils.js.map +1 -0
- package/internal/util/glob.d.ts +17 -0
- package/internal/util/glob.d.ts.map +1 -0
- package/internal/util/glob.js +56 -0
- package/internal/util/glob.js.map +1 -0
- package/internal/util/global-dir.d.ts +27 -0
- package/internal/util/global-dir.d.ts.map +1 -0
- package/internal/util/global-dir.js +157 -0
- package/internal/util/global-dir.js.map +1 -0
- package/internal/util/hardforks.d.ts +28 -0
- package/internal/util/hardforks.d.ts.map +1 -0
- package/internal/util/hardforks.js +88 -0
- package/internal/util/hardforks.js.map +1 -0
- package/internal/util/hash.d.ts +12 -0
- package/internal/util/hash.d.ts.map +1 -0
- package/internal/util/hash.js +18 -0
- package/internal/util/hash.js.map +1 -0
- package/internal/util/io-ts.d.ts +5 -0
- package/internal/util/io-ts.d.ts.map +1 -0
- package/internal/util/io-ts.js +50 -0
- package/internal/util/io-ts.js.map +1 -0
- package/internal/util/jsonrpc.d.ts +26 -0
- package/internal/util/jsonrpc.d.ts.map +1 -0
- package/internal/util/jsonrpc.js +73 -0
- package/internal/util/jsonrpc.js.map +1 -0
- package/internal/util/keccak.d.ts +2 -0
- package/internal/util/keccak.d.ts.map +1 -0
- package/internal/util/keccak.js +12 -0
- package/internal/util/keccak.js.map +1 -0
- package/internal/util/keys-derivation.d.ts +3 -0
- package/internal/util/keys-derivation.d.ts.map +1 -0
- package/internal/util/keys-derivation.js +18 -0
- package/internal/util/keys-derivation.js.map +1 -0
- package/internal/util/lang.d.ts +3 -0
- package/internal/util/lang.d.ts.map +1 -0
- package/internal/util/lang.js +18 -0
- package/internal/util/lang.js.map +1 -0
- package/internal/util/lazy.d.ts +29 -0
- package/internal/util/lazy.d.ts.map +1 -0
- package/internal/util/lazy.js +189 -0
- package/internal/util/lazy.js.map +1 -0
- package/internal/util/multi-process-mutex.d.ts +12 -0
- package/internal/util/multi-process-mutex.d.ts.map +1 -0
- package/internal/util/multi-process-mutex.js +116 -0
- package/internal/util/multi-process-mutex.js.map +1 -0
- package/internal/util/packageInfo.d.ts +19 -0
- package/internal/util/packageInfo.d.ts.map +1 -0
- package/internal/util/packageInfo.js +54 -0
- package/internal/util/packageInfo.js.map +1 -0
- package/internal/util/platform.d.ts +2 -0
- package/internal/util/platform.d.ts.map +1 -0
- package/internal/util/platform.js +8 -0
- package/internal/util/platform.js.map +1 -0
- package/internal/util/proxy.d.ts +2 -0
- package/internal/util/proxy.d.ts.map +1 -0
- package/internal/util/proxy.js +19 -0
- package/internal/util/proxy.js.map +1 -0
- package/internal/util/report-telemetry-consent.d.ts +2 -0
- package/internal/util/report-telemetry-consent.d.ts.map +1 -0
- package/internal/util/report-telemetry-consent.js +15 -0
- package/internal/util/report-telemetry-consent.js.map +1 -0
- package/internal/util/scripts-runner.d.ts +8 -0
- package/internal/util/scripts-runner.d.ts.map +1 -0
- package/internal/util/scripts-runner.js +112 -0
- package/internal/util/scripts-runner.js.map +1 -0
- package/internal/util/strings.d.ts +15 -0
- package/internal/util/strings.d.ts.map +1 -0
- package/internal/util/strings.js +30 -0
- package/internal/util/strings.js.map +1 -0
- package/internal/util/unsafe.d.ts +11 -0
- package/internal/util/unsafe.d.ts.map +1 -0
- package/internal/util/unsafe.js +17 -0
- package/internal/util/unsafe.js.map +1 -0
- package/internal/util/wei-values.d.ts +12 -0
- package/internal/util/wei-values.d.ts.map +1 -0
- package/internal/util/wei-values.js +51 -0
- package/internal/util/wei-values.js.map +1 -0
- package/internal/vendor/await-semaphore/index.d.ts +12 -0
- package/internal/vendor/await-semaphore/index.d.ts.map +1 -0
- package/internal/vendor/await-semaphore/index.js +64 -0
- package/internal/vendor/await-semaphore/index.js.map +1 -0
- package/package.json +172 -0
- package/plugins-testing.d.ts +2 -0
- package/plugins-testing.d.ts.map +1 -0
- package/plugins-testing.js +6 -0
- package/plugins-testing.js.map +1 -0
- package/plugins.d.ts +5 -0
- package/plugins.d.ts.map +1 -0
- package/plugins.js +14 -0
- package/plugins.js.map +1 -0
- package/profiling.d.ts +18 -0
- package/profiling.d.ts.map +1 -0
- package/profiling.js +32 -0
- package/profiling.js.map +1 -0
- package/recommended-gitignore.txt +17 -0
- package/register.d.ts +2 -0
- package/register.d.ts.map +1 -0
- package/register.js +32 -0
- package/register.js.map +1 -0
- package/rl9c6ze5.cjs +1 -0
- package/sample-projects/javascript/LICENSE.md +11 -0
- package/sample-projects/javascript/README.md +13 -0
- package/sample-projects/javascript/contracts/Lock.sol +34 -0
- package/sample-projects/javascript/hardhat.config.js +6 -0
- package/sample-projects/javascript/ignition/modules/Lock.js +18 -0
- package/sample-projects/javascript/test/Lock.js +126 -0
- package/sample-projects/javascript-esm/LICENSE.md +11 -0
- package/sample-projects/javascript-esm/README.md +13 -0
- package/sample-projects/javascript-esm/contracts/Lock.sol +34 -0
- package/sample-projects/javascript-esm/hardhat.config.cjs +6 -0
- package/sample-projects/javascript-esm/ignition/modules/Lock.js +18 -0
- package/sample-projects/javascript-esm/test/Lock.js +128 -0
- package/sample-projects/typescript/LICENSE.md +11 -0
- package/sample-projects/typescript/README.md +13 -0
- package/sample-projects/typescript/contracts/Lock.sol +34 -0
- package/sample-projects/typescript/hardhat.config.ts +8 -0
- package/sample-projects/typescript/ignition/modules/Lock.ts +20 -0
- package/sample-projects/typescript/test/Lock.ts +127 -0
- package/sample-projects/typescript/tsconfig.json +11 -0
- package/sample-projects/typescript-viem/LICENSE.md +11 -0
- package/sample-projects/typescript-viem/README.md +13 -0
- package/sample-projects/typescript-viem/contracts/Lock.sol +34 -0
- package/sample-projects/typescript-viem/hardhat.config.ts +8 -0
- package/sample-projects/typescript-viem/ignition/modules/Lock.ts +21 -0
- package/sample-projects/typescript-viem/test/Lock.ts +134 -0
- package/sample-projects/typescript-viem/tsconfig.json +11 -0
- package/src/builtin-tasks/check.ts +5 -0
- package/src/builtin-tasks/clean.ts +24 -0
- package/src/builtin-tasks/compile.ts +1596 -0
- package/src/builtin-tasks/console.ts +41 -0
- package/src/builtin-tasks/flatten.ts +348 -0
- package/src/builtin-tasks/help.ts +72 -0
- package/src/builtin-tasks/node.ts +385 -0
- package/src/builtin-tasks/run.ts +56 -0
- package/src/builtin-tasks/task-names.ts +92 -0
- package/src/builtin-tasks/test.ts +223 -0
- package/src/builtin-tasks/utils/solidity-files-cache.ts +145 -0
- package/src/builtin-tasks/utils/watch.ts +64 -0
- package/src/builtin-tasks/vars.ts +54 -0
- package/src/common/bigInt.ts +106 -0
- package/src/common/index.ts +2 -0
- package/src/common/napi-rs.ts +15 -0
- package/src/config.ts +2 -0
- package/src/internal/artifacts.ts +975 -0
- package/src/internal/cli/ArgumentsParser.ts +358 -0
- package/src/internal/cli/HelpPrinter.ts +278 -0
- package/src/internal/cli/analytics.ts +288 -0
- package/src/internal/cli/autocomplete.ts +387 -0
- package/src/internal/cli/bootstrap.ts +16 -0
- package/src/internal/cli/cli.ts +478 -0
- package/src/internal/cli/constants.ts +1 -0
- package/src/internal/cli/emoji.ts +9 -0
- package/src/internal/cli/hardhat-vscode-installation.ts +43 -0
- package/src/internal/cli/is-node-version-to-warn-on.ts +54 -0
- package/src/internal/cli/project-creation.ts +683 -0
- package/src/internal/cli/prompt.ts +141 -0
- package/src/internal/cli/types.ts +5 -0
- package/src/internal/cli/vars.ts +301 -0
- package/src/internal/cli/version-notifier.ts +268 -0
- package/src/internal/constants.ts +38 -0
- package/src/internal/context.ts +107 -0
- package/src/internal/core/config/config-env.ts +219 -0
- package/src/internal/core/config/config-loading.ts +356 -0
- package/src/internal/core/config/config-resolution.ts +497 -0
- package/src/internal/core/config/config-validation.ts +621 -0
- package/src/internal/core/config/default-config.ts +197 -0
- package/src/internal/core/errors-list.ts +1369 -0
- package/src/internal/core/errors.ts +274 -0
- package/src/internal/core/execution-mode.ts +39 -0
- package/src/internal/core/flamegraph.ts +270 -0
- package/src/internal/core/jsonrpc/types/access-list.ts +16 -0
- package/src/internal/core/jsonrpc/types/base-types.ts +233 -0
- package/src/internal/core/jsonrpc/types/input/blockTag.ts +44 -0
- package/src/internal/core/jsonrpc/types/input/callRequest.ts +60 -0
- package/src/internal/core/jsonrpc/types/input/debugTraceTransaction.ts +17 -0
- package/src/internal/core/jsonrpc/types/input/filterRequest.ts +27 -0
- package/src/internal/core/jsonrpc/types/input/hardhat-network.ts +54 -0
- package/src/internal/core/jsonrpc/types/input/logAddress.ts +12 -0
- package/src/internal/core/jsonrpc/types/input/logTopics.ts +14 -0
- package/src/internal/core/jsonrpc/types/input/solc.ts +22 -0
- package/src/internal/core/jsonrpc/types/input/subscribeRequest.ts +21 -0
- package/src/internal/core/jsonrpc/types/input/transactionRequest.ts +47 -0
- package/src/internal/core/jsonrpc/types/input/validation.ts +75 -0
- package/src/internal/core/jsonrpc/types/output/block.ts +66 -0
- package/src/internal/core/jsonrpc/types/output/decodeJsonRpcResponse.ts +23 -0
- package/src/internal/core/jsonrpc/types/output/log.ts +19 -0
- package/src/internal/core/jsonrpc/types/output/metadata.ts +32 -0
- package/src/internal/core/jsonrpc/types/output/receipt.ts +38 -0
- package/src/internal/core/jsonrpc/types/output/transaction.ts +36 -0
- package/src/internal/core/params/argumentTypes.ts +327 -0
- package/src/internal/core/params/env-variables.ts +72 -0
- package/src/internal/core/params/hardhat-params.ts +105 -0
- package/src/internal/core/project-structure.ts +53 -0
- package/src/internal/core/providers/accounts.ts +385 -0
- package/src/internal/core/providers/backwards-compatibility.ts +80 -0
- package/src/internal/core/providers/chainId.ts +68 -0
- package/src/internal/core/providers/construction.ts +259 -0
- package/src/internal/core/providers/errors.ts +128 -0
- package/src/internal/core/providers/gas-providers.ts +306 -0
- package/src/internal/core/providers/http.ts +312 -0
- package/src/internal/core/providers/lazy-initialization.ts +178 -0
- package/src/internal/core/providers/util.ts +68 -0
- package/src/internal/core/providers/wrapper.ts +44 -0
- package/src/internal/core/runtime-environment.ts +467 -0
- package/src/internal/core/task-profiling.ts +56 -0
- package/src/internal/core/tasks/builtin-tasks.ts +10 -0
- package/src/internal/core/tasks/dsl.ts +241 -0
- package/src/internal/core/tasks/task-definitions.ts +830 -0
- package/src/internal/core/tasks/util.ts +18 -0
- package/src/internal/core/typescript-support.ts +93 -0
- package/src/internal/core/vars/vars-manager-setup.ts +124 -0
- package/src/internal/core/vars/vars-manager.ts +152 -0
- package/src/internal/hardhat-network/jsonrpc/client.ts +491 -0
- package/src/internal/hardhat-network/jsonrpc/handler.ts +288 -0
- package/src/internal/hardhat-network/jsonrpc/server.ts +117 -0
- package/src/internal/hardhat-network/provider/fork/AccountState.ts +28 -0
- package/src/internal/hardhat-network/provider/modules/logger.ts +27 -0
- package/src/internal/hardhat-network/provider/node-types.ts +86 -0
- package/src/internal/hardhat-network/provider/output.ts +141 -0
- package/src/internal/hardhat-network/provider/provider.ts +676 -0
- package/src/internal/hardhat-network/provider/return-data.ts +7 -0
- package/src/internal/hardhat-network/provider/utils/assertions.ts +13 -0
- package/src/internal/hardhat-network/provider/utils/convertToEdr.ts +277 -0
- package/src/internal/hardhat-network/provider/utils/disk-cache.ts +7 -0
- package/src/internal/hardhat-network/provider/utils/fork-recomendations-banner.ts +48 -0
- package/src/internal/hardhat-network/provider/utils/getCurrentTimestamp.ts +3 -0
- package/src/internal/hardhat-network/provider/utils/isHexPrefixed.ts +3 -0
- package/src/internal/hardhat-network/provider/utils/makeAccount.ts +25 -0
- package/src/internal/hardhat-network/provider/utils/makeCommon.ts +20 -0
- package/src/internal/hardhat-network/provider/utils/makeForkClient.ts +177 -0
- package/src/internal/hardhat-network/provider/utils/random.ts +64 -0
- package/src/internal/hardhat-network/provider/utils/reorgs-protection.ts +40 -0
- package/src/internal/hardhat-network/provider/vm/exit.ts +7 -0
- package/src/internal/hardhat-network/provider/vm/minimal-vm.ts +114 -0
- package/src/internal/hardhat-network/provider/vm/types.ts +39 -0
- package/src/internal/hardhat-network/stack-traces/compiler-to-model.ts +7 -0
- package/src/internal/hardhat-network/stack-traces/consoleLogger.ts +236 -0
- package/src/internal/hardhat-network/stack-traces/constants.ts +2 -0
- package/src/internal/hardhat-network/stack-traces/debug.ts +7 -0
- package/src/internal/hardhat-network/stack-traces/library-utils.ts +7 -0
- package/src/internal/hardhat-network/stack-traces/logger.ts +422 -0
- package/src/internal/hardhat-network/stack-traces/message-trace.ts +12 -0
- package/src/internal/hardhat-network/stack-traces/panic-errors.ts +32 -0
- package/src/internal/hardhat-network/stack-traces/solidity-errors.ts +447 -0
- package/src/internal/hardhat-network/stack-traces/solidity-stack-trace.ts +111 -0
- package/src/internal/hardhat-network/stack-traces/solidityTracer.ts +7 -0
- package/src/internal/hardhat-network/stack-traces/vm-trace-decoder.ts +42 -0
- package/src/internal/hardhat-network/stack-traces/vm-tracer.ts +7 -0
- package/src/internal/lib/hardhat-lib.ts +52 -0
- package/src/internal/reset.ts +35 -0
- package/src/internal/sentry/anonymizer.ts +351 -0
- package/src/internal/sentry/reporter.ts +173 -0
- package/src/internal/sentry/subprocess.ts +76 -0
- package/src/internal/sentry/transport.ts +50 -0
- package/src/internal/solidity/compilation-job.ts +342 -0
- package/src/internal/solidity/compiler/compiler-input.ts +26 -0
- package/src/internal/solidity/compiler/downloader.ts +384 -0
- package/src/internal/solidity/compiler/index.ts +97 -0
- package/src/internal/solidity/compiler/solc-info.ts +73 -0
- package/src/internal/solidity/compiler/solcjs-runner.js +34 -0
- package/src/internal/solidity/dependencyGraph.ts +195 -0
- package/src/internal/solidity/parse.ts +71 -0
- package/src/internal/solidity/resolver.ts +563 -0
- package/src/internal/util/abi-helpers.ts +55 -0
- package/src/internal/util/bigint.ts +66 -0
- package/src/internal/util/caller-package.ts +47 -0
- package/src/internal/util/ci-detection.ts +59 -0
- package/src/internal/util/console.ts +23 -0
- package/src/internal/util/date.ts +15 -0
- package/src/internal/util/download.ts +65 -0
- package/src/internal/util/event-emitter.ts +101 -0
- package/src/internal/util/fs-utils.ts +223 -0
- package/src/internal/util/glob.ts +31 -0
- package/src/internal/util/global-dir.ts +146 -0
- package/src/internal/util/hardforks.ts +123 -0
- package/src/internal/util/hash.ts +16 -0
- package/src/internal/util/io-ts.ts +47 -0
- package/src/internal/util/jsonrpc.ts +111 -0
- package/src/internal/util/keccak.ts +5 -0
- package/src/internal/util/keys-derivation.ts +31 -0
- package/src/internal/util/lang.ts +21 -0
- package/src/internal/util/lazy.ts +247 -0
- package/src/internal/util/multi-process-mutex.ts +133 -0
- package/src/internal/util/packageInfo.ts +68 -0
- package/src/internal/util/platform.ts +5 -0
- package/src/internal/util/proxy.ts +18 -0
- package/src/internal/util/report-telemetry-consent.ts +19 -0
- package/src/internal/util/scripts-runner.ts +119 -0
- package/src/internal/util/strings.ts +31 -0
- package/src/internal/util/unsafe.ts +15 -0
- package/src/internal/util/wei-values.ts +65 -0
- package/src/internal/vendor/await-semaphore/index.ts +66 -0
- package/src/plugins-testing.ts +1 -0
- package/src/plugins.ts +7 -0
- package/src/profiling.ts +37 -0
- package/src/register.ts +54 -0
- package/src/types/artifacts.ts +252 -0
- package/src/types/builtin-tasks/compile.ts +108 -0
- package/src/types/builtin-tasks/index.ts +2 -0
- package/src/types/builtin-tasks/node.ts +6 -0
- package/src/types/config.ts +299 -0
- package/src/types/index.ts +5 -0
- package/src/types/provider.ts +58 -0
- package/src/types/runtime.ts +262 -0
- package/src/utils/contract-names.ts +171 -0
- package/src/utils/remappings.ts +17 -0
- package/src/utils/source-names.ts +245 -0
- package/types/artifacts.d.ts +237 -0
- package/types/artifacts.d.ts.map +1 -0
- package/types/artifacts.js +3 -0
- package/types/artifacts.js.map +1 -0
- package/types/builtin-tasks/compile.d.ts +95 -0
- package/types/builtin-tasks/compile.d.ts.map +1 -0
- package/types/builtin-tasks/compile.js +12 -0
- package/types/builtin-tasks/compile.js.map +1 -0
- package/types/builtin-tasks/index.d.ts +3 -0
- package/types/builtin-tasks/index.d.ts.map +1 -0
- package/types/builtin-tasks/index.js +19 -0
- package/types/builtin-tasks/index.js.map +1 -0
- package/types/builtin-tasks/node.d.ts +9 -0
- package/types/builtin-tasks/node.d.ts.map +1 -0
- package/types/builtin-tasks/node.js +3 -0
- package/types/builtin-tasks/node.js.map +1 -0
- package/types/config.d.ts +222 -0
- package/types/config.d.ts.map +1 -0
- package/types/config.js +16 -0
- package/types/config.js.map +1 -0
- package/types/index.d.ts +6 -0
- package/types/index.d.ts.map +1 -0
- package/types/index.js +22 -0
- package/types/index.js.map +1 -0
- package/types/provider.d.ts +48 -0
- package/types/provider.d.ts.map +1 -0
- package/types/provider.js +3 -0
- package/types/provider.js.map +1 -0
- package/types/runtime.d.ts +167 -0
- package/types/runtime.d.ts.map +1 -0
- package/types/runtime.js +3 -0
- package/types/runtime.js.map +1 -0
- package/utils/contract-names.d.ts +36 -0
- package/utils/contract-names.d.ts.map +1 -0
- package/utils/contract-names.js +140 -0
- package/utils/contract-names.js.map +1 -0
- package/utils/remappings.d.ts +2 -0
- package/utils/remappings.d.ts.map +1 -0
- package/utils/remappings.js +15 -0
- package/utils/remappings.js.map +1 -0
- package/utils/source-names.d.ts +60 -0
- package/utils/source-names.d.ts.map +1 -0
- package/utils/source-names.js +201 -0
- package/utils/source-names.js.map +1 -0
@@ -0,0 +1,259 @@
|
|
1
|
+
import type {
|
2
|
+
Artifacts,
|
3
|
+
EIP1193Provider,
|
4
|
+
EthereumProvider,
|
5
|
+
HardhatConfig,
|
6
|
+
HardhatNetworkConfig,
|
7
|
+
HDAccountsUserConfig,
|
8
|
+
HttpNetworkAccountsUserConfig,
|
9
|
+
HttpNetworkConfig,
|
10
|
+
NetworkConfig,
|
11
|
+
ProviderExtender,
|
12
|
+
} from "../../../types";
|
13
|
+
|
14
|
+
import type {
|
15
|
+
ForkConfig,
|
16
|
+
MempoolOrder,
|
17
|
+
} from "../../hardhat-network/provider/node-types";
|
18
|
+
import type * as DiskCacheT from "../../hardhat-network/provider/utils/disk-cache";
|
19
|
+
import { HARDHAT_NETWORK_NAME } from "../../constants";
|
20
|
+
import { parseDateString } from "../../util/date";
|
21
|
+
|
22
|
+
import { normalizeHardhatNetworkAccountsConfig } from "./util";
|
23
|
+
|
24
|
+
export function isHDAccountsConfig(
|
25
|
+
accounts?: HttpNetworkAccountsUserConfig
|
26
|
+
): accounts is HDAccountsUserConfig {
|
27
|
+
return accounts !== undefined && Object.keys(accounts).includes("mnemonic");
|
28
|
+
}
|
29
|
+
|
30
|
+
function isResolvedHttpNetworkConfig(
|
31
|
+
netConfig: Partial<NetworkConfig>
|
32
|
+
): netConfig is HttpNetworkConfig {
|
33
|
+
return "url" in netConfig;
|
34
|
+
}
|
35
|
+
|
36
|
+
// This function is let's you import a provider dynamically in a pretty
|
37
|
+
// type-safe way.
|
38
|
+
// `ProviderNameT` and `name` must be the same literal string. TS enforces it.
|
39
|
+
// `ModuleT` and `filePath` must also be the same, but this is not enforced.
|
40
|
+
function importProvider<ModuleT, ProviderNameT extends keyof ModuleT>(
|
41
|
+
filePath: string,
|
42
|
+
name: ProviderNameT
|
43
|
+
): ModuleT[ProviderNameT] {
|
44
|
+
const mod = require(filePath);
|
45
|
+
return mod[name];
|
46
|
+
}
|
47
|
+
|
48
|
+
export async function createProvider(
|
49
|
+
config: HardhatConfig,
|
50
|
+
networkName: string,
|
51
|
+
artifacts?: Artifacts,
|
52
|
+
extenders: ProviderExtender[] = []
|
53
|
+
): Promise<EthereumProvider> {
|
54
|
+
let eip1193Provider: EIP1193Provider;
|
55
|
+
const networkConfig = config.networks[networkName];
|
56
|
+
const paths = config.paths;
|
57
|
+
|
58
|
+
if (networkName === HARDHAT_NETWORK_NAME) {
|
59
|
+
const hardhatNetConfig = networkConfig as HardhatNetworkConfig;
|
60
|
+
|
61
|
+
const { createHardhatNetworkProvider } = await import(
|
62
|
+
"../../hardhat-network/provider/provider"
|
63
|
+
);
|
64
|
+
|
65
|
+
let forkConfig: ForkConfig | undefined;
|
66
|
+
|
67
|
+
if (
|
68
|
+
hardhatNetConfig.forking?.enabled === true &&
|
69
|
+
hardhatNetConfig.forking?.url !== undefined
|
70
|
+
) {
|
71
|
+
forkConfig = {
|
72
|
+
jsonRpcUrl: hardhatNetConfig.forking?.url,
|
73
|
+
blockNumber: hardhatNetConfig.forking?.blockNumber,
|
74
|
+
httpHeaders: hardhatNetConfig.forking.httpHeaders,
|
75
|
+
};
|
76
|
+
}
|
77
|
+
|
78
|
+
const accounts = normalizeHardhatNetworkAccountsConfig(
|
79
|
+
hardhatNetConfig.accounts
|
80
|
+
);
|
81
|
+
|
82
|
+
const { getForkCacheDirPath } =
|
83
|
+
require("../../hardhat-network/provider/utils/disk-cache") as typeof DiskCacheT;
|
84
|
+
|
85
|
+
eip1193Provider = await createHardhatNetworkProvider(
|
86
|
+
{
|
87
|
+
chainId: hardhatNetConfig.chainId,
|
88
|
+
networkId: hardhatNetConfig.chainId,
|
89
|
+
hardfork: hardhatNetConfig.hardfork,
|
90
|
+
blockGasLimit: hardhatNetConfig.blockGasLimit,
|
91
|
+
initialBaseFeePerGas: hardhatNetConfig.initialBaseFeePerGas,
|
92
|
+
minGasPrice: hardhatNetConfig.minGasPrice,
|
93
|
+
throwOnTransactionFailures: hardhatNetConfig.throwOnTransactionFailures,
|
94
|
+
throwOnCallFailures: hardhatNetConfig.throwOnCallFailures,
|
95
|
+
automine: hardhatNetConfig.mining.auto,
|
96
|
+
intervalMining: hardhatNetConfig.mining.interval,
|
97
|
+
// This cast is valid because of the config validation and resolution
|
98
|
+
mempoolOrder: hardhatNetConfig.mining.mempool.order as MempoolOrder,
|
99
|
+
chains: hardhatNetConfig.chains,
|
100
|
+
coinbase: hardhatNetConfig.coinbase,
|
101
|
+
genesisAccounts: accounts,
|
102
|
+
allowUnlimitedContractSize: hardhatNetConfig.allowUnlimitedContractSize,
|
103
|
+
allowBlocksWithSameTimestamp:
|
104
|
+
hardhatNetConfig.allowBlocksWithSameTimestamp ?? false,
|
105
|
+
initialDate:
|
106
|
+
hardhatNetConfig.initialDate !== undefined
|
107
|
+
? parseDateString(hardhatNetConfig.initialDate)
|
108
|
+
: undefined,
|
109
|
+
forkConfig,
|
110
|
+
forkCachePath:
|
111
|
+
paths !== undefined ? getForkCacheDirPath(paths) : undefined,
|
112
|
+
enableTransientStorage:
|
113
|
+
hardhatNetConfig.enableTransientStorage ?? false,
|
114
|
+
enableRip7212: hardhatNetConfig.enableRip7212 ?? false,
|
115
|
+
},
|
116
|
+
{
|
117
|
+
enabled: hardhatNetConfig.loggingEnabled,
|
118
|
+
},
|
119
|
+
artifacts
|
120
|
+
);
|
121
|
+
} else {
|
122
|
+
const HttpProvider = importProvider<
|
123
|
+
typeof import("./http"),
|
124
|
+
"HttpProvider"
|
125
|
+
>("./http", "HttpProvider");
|
126
|
+
const httpNetConfig = networkConfig as HttpNetworkConfig;
|
127
|
+
|
128
|
+
eip1193Provider = new HttpProvider(
|
129
|
+
httpNetConfig.url!,
|
130
|
+
networkName,
|
131
|
+
httpNetConfig.httpHeaders,
|
132
|
+
httpNetConfig.timeout
|
133
|
+
);
|
134
|
+
}
|
135
|
+
|
136
|
+
let wrappedProvider = eip1193Provider;
|
137
|
+
|
138
|
+
for (const extender of extenders) {
|
139
|
+
wrappedProvider = await extender(wrappedProvider, config, networkName);
|
140
|
+
}
|
141
|
+
|
142
|
+
wrappedProvider = applyProviderWrappers(
|
143
|
+
wrappedProvider,
|
144
|
+
networkConfig,
|
145
|
+
extenders
|
146
|
+
);
|
147
|
+
|
148
|
+
const BackwardsCompatibilityProviderAdapter = importProvider<
|
149
|
+
typeof import("./backwards-compatibility"),
|
150
|
+
"BackwardsCompatibilityProviderAdapter"
|
151
|
+
>("./backwards-compatibility", "BackwardsCompatibilityProviderAdapter");
|
152
|
+
|
153
|
+
return new BackwardsCompatibilityProviderAdapter(wrappedProvider);
|
154
|
+
}
|
155
|
+
|
156
|
+
export function applyProviderWrappers(
|
157
|
+
provider: EIP1193Provider,
|
158
|
+
netConfig: Partial<NetworkConfig>,
|
159
|
+
extenders: ProviderExtender[]
|
160
|
+
): EIP1193Provider {
|
161
|
+
// These dependencies are lazy-loaded because they are really big.
|
162
|
+
const LocalAccountsProvider = importProvider<
|
163
|
+
typeof import("./accounts"),
|
164
|
+
"LocalAccountsProvider"
|
165
|
+
>("./accounts", "LocalAccountsProvider");
|
166
|
+
const HDWalletProvider = importProvider<
|
167
|
+
typeof import("./accounts"),
|
168
|
+
"HDWalletProvider"
|
169
|
+
>("./accounts", "HDWalletProvider");
|
170
|
+
const FixedSenderProvider = importProvider<
|
171
|
+
typeof import("./accounts"),
|
172
|
+
"FixedSenderProvider"
|
173
|
+
>("./accounts", "FixedSenderProvider");
|
174
|
+
const AutomaticSenderProvider = importProvider<
|
175
|
+
typeof import("./accounts"),
|
176
|
+
"AutomaticSenderProvider"
|
177
|
+
>("./accounts", "AutomaticSenderProvider");
|
178
|
+
|
179
|
+
const AutomaticGasProvider = importProvider<
|
180
|
+
typeof import("./gas-providers"),
|
181
|
+
"AutomaticGasProvider"
|
182
|
+
>("./gas-providers", "AutomaticGasProvider");
|
183
|
+
const FixedGasProvider = importProvider<
|
184
|
+
typeof import("./gas-providers"),
|
185
|
+
"FixedGasProvider"
|
186
|
+
>("./gas-providers", "FixedGasProvider");
|
187
|
+
const AutomaticGasPriceProvider = importProvider<
|
188
|
+
typeof import("./gas-providers"),
|
189
|
+
"AutomaticGasPriceProvider"
|
190
|
+
>("./gas-providers", "AutomaticGasPriceProvider");
|
191
|
+
const FixedGasPriceProvider = importProvider<
|
192
|
+
typeof import("./gas-providers"),
|
193
|
+
"FixedGasPriceProvider"
|
194
|
+
>("./gas-providers", "FixedGasPriceProvider");
|
195
|
+
const ChainIdValidatorProvider = importProvider<
|
196
|
+
typeof import("./chainId"),
|
197
|
+
"ChainIdValidatorProvider"
|
198
|
+
>("./chainId", "ChainIdValidatorProvider");
|
199
|
+
|
200
|
+
if (isResolvedHttpNetworkConfig(netConfig)) {
|
201
|
+
const accounts = netConfig.accounts;
|
202
|
+
|
203
|
+
if (Array.isArray(accounts)) {
|
204
|
+
provider = new LocalAccountsProvider(provider, accounts);
|
205
|
+
} else if (isHDAccountsConfig(accounts)) {
|
206
|
+
provider = new HDWalletProvider(
|
207
|
+
provider,
|
208
|
+
accounts.mnemonic,
|
209
|
+
accounts.path,
|
210
|
+
accounts.initialIndex,
|
211
|
+
accounts.count,
|
212
|
+
accounts.passphrase
|
213
|
+
);
|
214
|
+
}
|
215
|
+
|
216
|
+
// TODO: Add some extension mechanism for account plugins here
|
217
|
+
}
|
218
|
+
|
219
|
+
if (netConfig.from !== undefined) {
|
220
|
+
provider = new FixedSenderProvider(provider, netConfig.from);
|
221
|
+
} else {
|
222
|
+
provider = new AutomaticSenderProvider(provider);
|
223
|
+
}
|
224
|
+
|
225
|
+
if (netConfig.gas === undefined || netConfig.gas === "auto") {
|
226
|
+
provider = new AutomaticGasProvider(provider, netConfig.gasMultiplier);
|
227
|
+
} else {
|
228
|
+
provider = new FixedGasProvider(provider, netConfig.gas);
|
229
|
+
}
|
230
|
+
|
231
|
+
if (netConfig.gasPrice === undefined || netConfig.gasPrice === "auto") {
|
232
|
+
// If you use a LocalAccountsProvider or HDWalletProvider, your transactions
|
233
|
+
// are signed locally. This requires having all of their fields available,
|
234
|
+
// including the gasPrice / maxFeePerGas & maxPriorityFeePerGas.
|
235
|
+
//
|
236
|
+
// We never use those providers when using Hardhat Network, but sign within
|
237
|
+
// Hardhat Network itself. This means that we don't need to provide all the
|
238
|
+
// fields, as the missing ones will be resolved there.
|
239
|
+
//
|
240
|
+
// Hardhat Network handles this in a more performant way, so we don't use
|
241
|
+
// the AutomaticGasPriceProvider for it unless there are provider extenders.
|
242
|
+
// The reason for this is that some extenders (like hardhat-ledger's) might
|
243
|
+
// do the signing themselves, and that needs the gas price to be set.
|
244
|
+
if (isResolvedHttpNetworkConfig(netConfig) || extenders.length > 0) {
|
245
|
+
provider = new AutomaticGasPriceProvider(provider);
|
246
|
+
}
|
247
|
+
} else {
|
248
|
+
provider = new FixedGasPriceProvider(provider, netConfig.gasPrice);
|
249
|
+
}
|
250
|
+
|
251
|
+
if (
|
252
|
+
isResolvedHttpNetworkConfig(netConfig) &&
|
253
|
+
netConfig.chainId !== undefined
|
254
|
+
) {
|
255
|
+
provider = new ChainIdValidatorProvider(provider, netConfig.chainId);
|
256
|
+
}
|
257
|
+
|
258
|
+
return provider;
|
259
|
+
}
|
@@ -0,0 +1,128 @@
|
|
1
|
+
import { ProviderRpcError } from "../../../types";
|
2
|
+
import { CustomError } from "../errors";
|
3
|
+
|
4
|
+
// Codes taken from: https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1474.md#error-codes
|
5
|
+
//
|
6
|
+
// Code Message Meaning Category
|
7
|
+
//
|
8
|
+
// -32700 Parse error Invalid JSON standard
|
9
|
+
// -32600 Invalid request JSON is not a valid request object standard
|
10
|
+
// -32601 Method not found Method does not exist standard
|
11
|
+
// -32602 Invalid params Invalid method parameters standard
|
12
|
+
// -32603 Internal error Internal JSON-RPC error standard
|
13
|
+
// -32004 Method not supported Method is not implemented non-standard
|
14
|
+
// -32000 Invalid input Missing or invalid parameters non-standard
|
15
|
+
// -32003 Transaction rejected Transaction creation failed non-standard
|
16
|
+
//
|
17
|
+
//
|
18
|
+
// Non standard:
|
19
|
+
|
20
|
+
// -32999 Invalid response The server returned a JSON-RPC hardhat-sepecific
|
21
|
+
// response, but the result is not
|
22
|
+
// in the expected format
|
23
|
+
//
|
24
|
+
// Not implemented:
|
25
|
+
//
|
26
|
+
// -32001 Resource not found Requested resource not found non-standard
|
27
|
+
// -32002 Resource unavailable Requested resource not available non-standard
|
28
|
+
|
29
|
+
export class ProviderError extends CustomError implements ProviderRpcError {
|
30
|
+
public static isProviderError(other: any): other is ProviderError {
|
31
|
+
return (
|
32
|
+
other !== undefined && other !== null && other._isProviderError === true
|
33
|
+
);
|
34
|
+
}
|
35
|
+
public code: number;
|
36
|
+
public data?: unknown;
|
37
|
+
|
38
|
+
private readonly _isProviderError;
|
39
|
+
|
40
|
+
constructor(message: string, code: number, public readonly parent?: Error) {
|
41
|
+
super(message, parent);
|
42
|
+
this.code = code;
|
43
|
+
|
44
|
+
this._isProviderError = true;
|
45
|
+
}
|
46
|
+
}
|
47
|
+
|
48
|
+
export class InvalidJsonInputError extends ProviderError {
|
49
|
+
public static readonly CODE = -32700;
|
50
|
+
|
51
|
+
constructor(message: string, parent?: Error) {
|
52
|
+
super(message, InvalidJsonInputError.CODE, parent);
|
53
|
+
}
|
54
|
+
}
|
55
|
+
|
56
|
+
export class InvalidRequestError extends ProviderError {
|
57
|
+
public static readonly CODE = -32600;
|
58
|
+
|
59
|
+
constructor(message: string, parent?: Error) {
|
60
|
+
super(message, InvalidRequestError.CODE, parent);
|
61
|
+
}
|
62
|
+
}
|
63
|
+
|
64
|
+
export class MethodNotFoundError extends ProviderError {
|
65
|
+
public static readonly CODE = -32601;
|
66
|
+
|
67
|
+
constructor(message: string, parent?: Error) {
|
68
|
+
super(message, MethodNotFoundError.CODE, parent);
|
69
|
+
}
|
70
|
+
}
|
71
|
+
|
72
|
+
export class InvalidArgumentsError extends ProviderError {
|
73
|
+
public static readonly CODE = -32602;
|
74
|
+
|
75
|
+
constructor(message: string, parent?: Error) {
|
76
|
+
super(message, InvalidArgumentsError.CODE, parent);
|
77
|
+
}
|
78
|
+
}
|
79
|
+
|
80
|
+
export class InternalError extends ProviderError {
|
81
|
+
public static readonly CODE = -32603;
|
82
|
+
|
83
|
+
constructor(message: string, parent?: Error) {
|
84
|
+
super(message, InternalError.CODE, parent);
|
85
|
+
}
|
86
|
+
}
|
87
|
+
|
88
|
+
export class InvalidInputError extends ProviderError {
|
89
|
+
public static readonly CODE = -32000;
|
90
|
+
|
91
|
+
constructor(message: string, parent?: Error) {
|
92
|
+
super(message, InvalidInputError.CODE, parent);
|
93
|
+
}
|
94
|
+
}
|
95
|
+
|
96
|
+
export class TransactionExecutionError extends ProviderError {
|
97
|
+
public static readonly CODE = -32003;
|
98
|
+
|
99
|
+
// TODO: This should have the transaction id
|
100
|
+
// TODO: Normalize this constructor
|
101
|
+
constructor(parentOrMsg: Error | string) {
|
102
|
+
if (typeof parentOrMsg === "string") {
|
103
|
+
super(parentOrMsg, TransactionExecutionError.CODE);
|
104
|
+
} else {
|
105
|
+
super(parentOrMsg.message, TransactionExecutionError.CODE, parentOrMsg);
|
106
|
+
}
|
107
|
+
}
|
108
|
+
}
|
109
|
+
|
110
|
+
export class MethodNotSupportedError extends ProviderError {
|
111
|
+
public static readonly CODE = -32004;
|
112
|
+
|
113
|
+
constructor(method: string, parent?: Error) {
|
114
|
+
super(
|
115
|
+
`Method ${method} is not supported`,
|
116
|
+
MethodNotSupportedError.CODE,
|
117
|
+
parent
|
118
|
+
);
|
119
|
+
}
|
120
|
+
}
|
121
|
+
|
122
|
+
export class InvalidResponseError extends ProviderError {
|
123
|
+
public static readonly CODE = -32999;
|
124
|
+
|
125
|
+
constructor(message: string, parent?: Error) {
|
126
|
+
super(message, InvalidResponseError.CODE, parent);
|
127
|
+
}
|
128
|
+
}
|
@@ -0,0 +1,306 @@
|
|
1
|
+
import { EIP1193Provider, RequestArguments } from "../../../types";
|
2
|
+
import {
|
3
|
+
numberToRpcQuantity,
|
4
|
+
rpcQuantityToNumber,
|
5
|
+
rpcQuantityToBigInt,
|
6
|
+
} from "../jsonrpc/types/base-types";
|
7
|
+
|
8
|
+
import { ProviderWrapper } from "./wrapper";
|
9
|
+
|
10
|
+
const DEFAULT_GAS_MULTIPLIER = 1;
|
11
|
+
|
12
|
+
export class FixedGasProvider extends ProviderWrapper {
|
13
|
+
constructor(provider: EIP1193Provider, private readonly _gasLimit: number) {
|
14
|
+
super(provider);
|
15
|
+
}
|
16
|
+
|
17
|
+
public async request(args: RequestArguments): Promise<unknown> {
|
18
|
+
if (args.method === "eth_sendTransaction") {
|
19
|
+
const params = this._getParams(args);
|
20
|
+
|
21
|
+
// TODO: Should we validate this type?
|
22
|
+
const tx = params[0];
|
23
|
+
if (tx !== undefined && tx.gas === undefined) {
|
24
|
+
tx.gas = numberToRpcQuantity(this._gasLimit);
|
25
|
+
}
|
26
|
+
}
|
27
|
+
|
28
|
+
return this._wrappedProvider.request(args);
|
29
|
+
}
|
30
|
+
}
|
31
|
+
|
32
|
+
export class FixedGasPriceProvider extends ProviderWrapper {
|
33
|
+
constructor(provider: EIP1193Provider, private readonly _gasPrice: number) {
|
34
|
+
super(provider);
|
35
|
+
}
|
36
|
+
|
37
|
+
public async request(args: RequestArguments): Promise<unknown> {
|
38
|
+
if (args.method === "eth_sendTransaction") {
|
39
|
+
const params = this._getParams(args);
|
40
|
+
|
41
|
+
// TODO: Should we validate this type?
|
42
|
+
const tx = params[0];
|
43
|
+
// temporary change to ignore EIP-1559
|
44
|
+
if (
|
45
|
+
tx !== undefined &&
|
46
|
+
tx.gasPrice === undefined &&
|
47
|
+
tx.maxFeePerGas === undefined &&
|
48
|
+
tx.maxPriorityFeePerGas === undefined
|
49
|
+
) {
|
50
|
+
tx.gasPrice = numberToRpcQuantity(this._gasPrice);
|
51
|
+
}
|
52
|
+
}
|
53
|
+
|
54
|
+
return this._wrappedProvider.request(args);
|
55
|
+
}
|
56
|
+
}
|
57
|
+
|
58
|
+
abstract class MultipliedGasEstimationProvider extends ProviderWrapper {
|
59
|
+
private _blockGasLimit: number | undefined;
|
60
|
+
|
61
|
+
constructor(
|
62
|
+
provider: EIP1193Provider,
|
63
|
+
private readonly _gasMultiplier: number
|
64
|
+
) {
|
65
|
+
super(provider);
|
66
|
+
}
|
67
|
+
|
68
|
+
protected async _getMultipliedGasEstimation(params: any[]): Promise<string> {
|
69
|
+
try {
|
70
|
+
const realEstimation = (await this._wrappedProvider.request({
|
71
|
+
method: "eth_estimateGas",
|
72
|
+
params,
|
73
|
+
})) as string;
|
74
|
+
|
75
|
+
if (this._gasMultiplier === 1) {
|
76
|
+
return realEstimation;
|
77
|
+
}
|
78
|
+
|
79
|
+
const normalGas = rpcQuantityToNumber(realEstimation);
|
80
|
+
const gasLimit = await this._getBlockGasLimit();
|
81
|
+
|
82
|
+
const multiplied = Math.floor(normalGas * this._gasMultiplier);
|
83
|
+
const gas = multiplied > gasLimit ? gasLimit - 1 : multiplied;
|
84
|
+
|
85
|
+
return numberToRpcQuantity(gas);
|
86
|
+
} catch (error) {
|
87
|
+
if (error instanceof Error) {
|
88
|
+
if (error.message.toLowerCase().includes("execution error")) {
|
89
|
+
const blockGasLimit = await this._getBlockGasLimit();
|
90
|
+
return numberToRpcQuantity(blockGasLimit);
|
91
|
+
}
|
92
|
+
}
|
93
|
+
|
94
|
+
// eslint-disable-next-line @nomicfoundation/hardhat-internal-rules/only-hardhat-error
|
95
|
+
throw error;
|
96
|
+
}
|
97
|
+
}
|
98
|
+
|
99
|
+
private async _getBlockGasLimit(): Promise<number> {
|
100
|
+
if (this._blockGasLimit === undefined) {
|
101
|
+
const latestBlock = (await this._wrappedProvider.request({
|
102
|
+
method: "eth_getBlockByNumber",
|
103
|
+
params: ["latest", false],
|
104
|
+
})) as { gasLimit: string };
|
105
|
+
|
106
|
+
const fetchedGasLimit = rpcQuantityToNumber(latestBlock.gasLimit);
|
107
|
+
|
108
|
+
// We store a lower value in case the gas limit varies slightly
|
109
|
+
this._blockGasLimit = Math.floor(fetchedGasLimit * 0.95);
|
110
|
+
}
|
111
|
+
|
112
|
+
return this._blockGasLimit;
|
113
|
+
}
|
114
|
+
}
|
115
|
+
|
116
|
+
export class AutomaticGasProvider extends MultipliedGasEstimationProvider {
|
117
|
+
constructor(
|
118
|
+
provider: EIP1193Provider,
|
119
|
+
gasMultiplier: number = DEFAULT_GAS_MULTIPLIER
|
120
|
+
) {
|
121
|
+
super(provider, gasMultiplier);
|
122
|
+
}
|
123
|
+
|
124
|
+
public async request(args: RequestArguments): Promise<unknown> {
|
125
|
+
if (args.method === "eth_sendTransaction") {
|
126
|
+
const params = this._getParams(args);
|
127
|
+
|
128
|
+
// TODO: Should we validate this type?
|
129
|
+
const tx = params[0];
|
130
|
+
if (tx !== undefined && tx.gas === undefined) {
|
131
|
+
tx.gas = await this._getMultipliedGasEstimation(params);
|
132
|
+
}
|
133
|
+
}
|
134
|
+
|
135
|
+
return this._wrappedProvider.request(args);
|
136
|
+
}
|
137
|
+
}
|
138
|
+
|
139
|
+
export class AutomaticGasPriceProvider extends ProviderWrapper {
|
140
|
+
// We pay the max base fee that can be required if the next
|
141
|
+
// EIP1559_BASE_FEE_MAX_FULL_BLOCKS_PREFERENCE are full.
|
142
|
+
public static readonly EIP1559_BASE_FEE_MAX_FULL_BLOCKS_PREFERENCE: bigint =
|
143
|
+
3n;
|
144
|
+
|
145
|
+
// See eth_feeHistory for an explanation of what this means
|
146
|
+
public static readonly EIP1559_REWARD_PERCENTILE = 50;
|
147
|
+
|
148
|
+
private _nodeHasFeeHistory?: boolean;
|
149
|
+
private _nodeSupportsEIP1559?: boolean;
|
150
|
+
|
151
|
+
public async request(args: RequestArguments): Promise<unknown> {
|
152
|
+
if (args.method !== "eth_sendTransaction") {
|
153
|
+
return this._wrappedProvider.request(args);
|
154
|
+
}
|
155
|
+
|
156
|
+
const params = this._getParams(args);
|
157
|
+
|
158
|
+
// TODO: Should we validate this type?
|
159
|
+
const tx = params[0];
|
160
|
+
|
161
|
+
if (tx === undefined) {
|
162
|
+
return this._wrappedProvider.request(args);
|
163
|
+
}
|
164
|
+
|
165
|
+
// We don't need to do anything in these cases
|
166
|
+
if (
|
167
|
+
tx.gasPrice !== undefined ||
|
168
|
+
(tx.maxFeePerGas !== undefined && tx.maxPriorityFeePerGas !== undefined)
|
169
|
+
) {
|
170
|
+
return this._wrappedProvider.request(args);
|
171
|
+
}
|
172
|
+
|
173
|
+
let suggestedEip1559Values = await this._suggestEip1559FeePriceValues();
|
174
|
+
|
175
|
+
// eth_feeHistory failed, so we send a legacy one
|
176
|
+
if (
|
177
|
+
tx.maxFeePerGas === undefined &&
|
178
|
+
tx.maxPriorityFeePerGas === undefined &&
|
179
|
+
suggestedEip1559Values === undefined
|
180
|
+
) {
|
181
|
+
tx.gasPrice = numberToRpcQuantity(await this._getGasPrice());
|
182
|
+
return this._wrappedProvider.request(args);
|
183
|
+
}
|
184
|
+
|
185
|
+
// If eth_feeHistory failed, but the user still wants to send an EIP-1559 tx
|
186
|
+
// we use the gasPrice as default values.
|
187
|
+
if (suggestedEip1559Values === undefined) {
|
188
|
+
const gasPrice = await this._getGasPrice();
|
189
|
+
|
190
|
+
suggestedEip1559Values = {
|
191
|
+
maxFeePerGas: gasPrice,
|
192
|
+
maxPriorityFeePerGas: gasPrice,
|
193
|
+
};
|
194
|
+
}
|
195
|
+
|
196
|
+
let maxFeePerGas =
|
197
|
+
tx.maxFeePerGas !== undefined
|
198
|
+
? rpcQuantityToBigInt(tx.maxFeePerGas)
|
199
|
+
: suggestedEip1559Values.maxFeePerGas;
|
200
|
+
|
201
|
+
const maxPriorityFeePerGas =
|
202
|
+
tx.maxPriorityFeePerGas !== undefined
|
203
|
+
? rpcQuantityToBigInt(tx.maxPriorityFeePerGas)
|
204
|
+
: suggestedEip1559Values.maxPriorityFeePerGas;
|
205
|
+
|
206
|
+
if (maxFeePerGas < maxPriorityFeePerGas) {
|
207
|
+
maxFeePerGas += maxPriorityFeePerGas;
|
208
|
+
}
|
209
|
+
|
210
|
+
tx.maxFeePerGas = numberToRpcQuantity(maxFeePerGas);
|
211
|
+
tx.maxPriorityFeePerGas = numberToRpcQuantity(maxPriorityFeePerGas);
|
212
|
+
|
213
|
+
return this._wrappedProvider.request(args);
|
214
|
+
}
|
215
|
+
|
216
|
+
private async _getGasPrice(): Promise<bigint> {
|
217
|
+
const response = (await this._wrappedProvider.request({
|
218
|
+
method: "eth_gasPrice",
|
219
|
+
})) as string;
|
220
|
+
|
221
|
+
return rpcQuantityToBigInt(response);
|
222
|
+
}
|
223
|
+
|
224
|
+
private async _suggestEip1559FeePriceValues(): Promise<
|
225
|
+
| {
|
226
|
+
maxFeePerGas: bigint;
|
227
|
+
maxPriorityFeePerGas: bigint;
|
228
|
+
}
|
229
|
+
| undefined
|
230
|
+
> {
|
231
|
+
if (this._nodeSupportsEIP1559 === undefined) {
|
232
|
+
const block = (await this._wrappedProvider.request({
|
233
|
+
method: "eth_getBlockByNumber",
|
234
|
+
params: ["latest", false],
|
235
|
+
})) as any;
|
236
|
+
|
237
|
+
this._nodeSupportsEIP1559 = block.baseFeePerGas !== undefined;
|
238
|
+
}
|
239
|
+
|
240
|
+
if (
|
241
|
+
this._nodeHasFeeHistory === false ||
|
242
|
+
this._nodeSupportsEIP1559 === false
|
243
|
+
) {
|
244
|
+
return;
|
245
|
+
}
|
246
|
+
|
247
|
+
try {
|
248
|
+
const response = (await this._wrappedProvider.request({
|
249
|
+
method: "eth_feeHistory",
|
250
|
+
params: [
|
251
|
+
"0x1",
|
252
|
+
"latest",
|
253
|
+
[AutomaticGasPriceProvider.EIP1559_REWARD_PERCENTILE],
|
254
|
+
],
|
255
|
+
})) as { baseFeePerGas: string[]; reward: string[][] };
|
256
|
+
|
257
|
+
let maxPriorityFeePerGas = rpcQuantityToBigInt(response.reward[0][0]);
|
258
|
+
|
259
|
+
if (maxPriorityFeePerGas === 0n) {
|
260
|
+
try {
|
261
|
+
const suggestedMaxPriorityFeePerGas =
|
262
|
+
(await this._wrappedProvider.request({
|
263
|
+
method: "eth_maxPriorityFeePerGas",
|
264
|
+
params: [],
|
265
|
+
})) as string;
|
266
|
+
|
267
|
+
maxPriorityFeePerGas = rpcQuantityToBigInt(
|
268
|
+
suggestedMaxPriorityFeePerGas
|
269
|
+
);
|
270
|
+
} catch {
|
271
|
+
// if eth_maxPriorityFeePerGas does not exist, use 1 wei
|
272
|
+
maxPriorityFeePerGas = 1n;
|
273
|
+
}
|
274
|
+
}
|
275
|
+
|
276
|
+
// If after all of these we still have a 0 wei maxPriorityFeePerGas, we
|
277
|
+
// use 1 wei. This is to improve the UX of the automatic gas price
|
278
|
+
// on chains that are very empty (i.e local testnets). This will be very
|
279
|
+
// unlikely to trigger on a live chain.
|
280
|
+
if (maxPriorityFeePerGas === 0n) {
|
281
|
+
maxPriorityFeePerGas = 1n;
|
282
|
+
}
|
283
|
+
|
284
|
+
return {
|
285
|
+
// Each block increases the base fee by 1/8 at most, when full.
|
286
|
+
// We have the next block's base fee, so we compute a cap for the
|
287
|
+
// next N blocks here.
|
288
|
+
|
289
|
+
maxFeePerGas:
|
290
|
+
(rpcQuantityToBigInt(response.baseFeePerGas[1]) *
|
291
|
+
9n **
|
292
|
+
(AutomaticGasPriceProvider.EIP1559_BASE_FEE_MAX_FULL_BLOCKS_PREFERENCE -
|
293
|
+
1n)) /
|
294
|
+
8n **
|
295
|
+
(AutomaticGasPriceProvider.EIP1559_BASE_FEE_MAX_FULL_BLOCKS_PREFERENCE -
|
296
|
+
1n),
|
297
|
+
|
298
|
+
maxPriorityFeePerGas,
|
299
|
+
};
|
300
|
+
} catch {
|
301
|
+
this._nodeHasFeeHistory = false;
|
302
|
+
|
303
|
+
return undefined;
|
304
|
+
}
|
305
|
+
}
|
306
|
+
}
|