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,233 @@
|
|
1
|
+
import {
|
2
|
+
bytesToHex as bufferToHex,
|
3
|
+
isValidAddress,
|
4
|
+
toBytes,
|
5
|
+
} from "@nomicfoundation/ethereumjs-util";
|
6
|
+
import * as t from "io-ts";
|
7
|
+
|
8
|
+
import * as BigIntUtils from "../../../util/bigint";
|
9
|
+
import { assertHardhatInvariant, HardhatError } from "../../errors";
|
10
|
+
import { ERRORS } from "../../errors-list";
|
11
|
+
|
12
|
+
const ADDRESS_LENGTH_BYTES = 20;
|
13
|
+
const HASH_LENGTH_BYTES = 32;
|
14
|
+
|
15
|
+
export const rpcQuantity = new t.Type<bigint>(
|
16
|
+
"QUANTITY",
|
17
|
+
BigIntUtils.isBigInt,
|
18
|
+
(u, c) => (isRpcQuantityString(u) ? t.success(BigInt(u)) : t.failure(u, c)),
|
19
|
+
t.identity
|
20
|
+
);
|
21
|
+
|
22
|
+
export const rpcData = new t.Type<Buffer>(
|
23
|
+
"DATA",
|
24
|
+
Buffer.isBuffer,
|
25
|
+
(u, c) =>
|
26
|
+
isRpcDataString(u) ? t.success(Buffer.from(toBytes(u))) : t.failure(u, c),
|
27
|
+
t.identity
|
28
|
+
);
|
29
|
+
|
30
|
+
export const rpcHash = new t.Type<Buffer>(
|
31
|
+
"HASH",
|
32
|
+
(v): v is Buffer => Buffer.isBuffer(v) && v.length === HASH_LENGTH_BYTES,
|
33
|
+
(u, c) =>
|
34
|
+
isRpcHashString(u) ? t.success(Buffer.from(toBytes(u))) : t.failure(u, c),
|
35
|
+
t.identity
|
36
|
+
);
|
37
|
+
|
38
|
+
export const rpcStorageSlot = new t.Type<bigint>(
|
39
|
+
"Storage slot",
|
40
|
+
BigIntUtils.isBigInt,
|
41
|
+
validateStorageSlot,
|
42
|
+
t.identity
|
43
|
+
);
|
44
|
+
|
45
|
+
// This type is necessary because objects' keys need to be either strings or numbers to be properly handled by the 'io-ts' module.
|
46
|
+
// If they are not defined as strings or numbers, the type definition will result in an empty object without the required properties.
|
47
|
+
// For example, instead of displaying { ke1: value1 }, it will display {}
|
48
|
+
export const rpcStorageSlotHexString = new t.Type<string>(
|
49
|
+
"Storage slot hex string",
|
50
|
+
(x): x is string => typeof x === "string",
|
51
|
+
(u, c) =>
|
52
|
+
validateRpcStorageSlotHexString(u) ? t.success(u) : t.failure(u, c),
|
53
|
+
t.identity
|
54
|
+
);
|
55
|
+
|
56
|
+
function validateStorageSlot(u: unknown, c: t.Context): t.Validation<bigint> {
|
57
|
+
if (typeof u !== "string") {
|
58
|
+
return t.failure(
|
59
|
+
u,
|
60
|
+
c,
|
61
|
+
`Storage slot argument must be a string, got '${u as any}'`
|
62
|
+
);
|
63
|
+
}
|
64
|
+
|
65
|
+
if (u === "") {
|
66
|
+
return t.failure(u, c, "Storage slot argument cannot be an empty string");
|
67
|
+
}
|
68
|
+
|
69
|
+
if (u.startsWith("0x")) {
|
70
|
+
if (u.length > 66) {
|
71
|
+
return t.failure(
|
72
|
+
u,
|
73
|
+
c,
|
74
|
+
`Storage slot argument must have a length of at most 66 ("0x" + 32 bytes), but '${u}' has a length of ${u.length}`
|
75
|
+
);
|
76
|
+
}
|
77
|
+
} else {
|
78
|
+
if (u.length > 64) {
|
79
|
+
return t.failure(
|
80
|
+
u,
|
81
|
+
c,
|
82
|
+
`Storage slot argument must have a length of at most 64 (32 bytes), but '${u}' has a length of ${u.length}`
|
83
|
+
);
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
if (u.match(/^(0x)?([0-9a-fA-F]){0,64}$/) === null) {
|
88
|
+
return t.failure(
|
89
|
+
u,
|
90
|
+
c,
|
91
|
+
`Storage slot argument must be a valid hexadecimal, got '${u}'`
|
92
|
+
);
|
93
|
+
}
|
94
|
+
|
95
|
+
return t.success(u === "0x" ? 0n : BigInt(u.startsWith("0x") ? u : `0x${u}`));
|
96
|
+
}
|
97
|
+
|
98
|
+
export const rpcAddress = new t.Type<Buffer>(
|
99
|
+
"ADDRESS",
|
100
|
+
(v): v is Buffer => Buffer.isBuffer(v) && v.length === ADDRESS_LENGTH_BYTES,
|
101
|
+
(u, c) =>
|
102
|
+
isRpcAddressString(u)
|
103
|
+
? t.success(Buffer.from(toBytes(u)))
|
104
|
+
: t.failure(u, c),
|
105
|
+
t.identity
|
106
|
+
);
|
107
|
+
|
108
|
+
export const rpcUnsignedInteger = new t.Type<number>(
|
109
|
+
"Unsigned integer",
|
110
|
+
isInteger,
|
111
|
+
(u, c) => (isInteger(u) && u >= 0 ? t.success(u) : t.failure(u, c)),
|
112
|
+
t.identity
|
113
|
+
);
|
114
|
+
|
115
|
+
export const rpcQuantityAsNumber = new t.Type<bigint>(
|
116
|
+
"Integer",
|
117
|
+
BigIntUtils.isBigInt,
|
118
|
+
(u, c) => (isInteger(u) ? t.success(BigInt(u)) : t.failure(u, c)),
|
119
|
+
t.identity
|
120
|
+
);
|
121
|
+
|
122
|
+
export const rpcFloat = new t.Type<number>(
|
123
|
+
"Float number",
|
124
|
+
isNumber,
|
125
|
+
(u, c) => (typeof u === "number" ? t.success(u) : t.failure(u, c)),
|
126
|
+
t.identity
|
127
|
+
);
|
128
|
+
|
129
|
+
// Conversion functions
|
130
|
+
|
131
|
+
/**
|
132
|
+
* Transforms a QUANTITY into a number. It should only be used if you are 100% sure that the value
|
133
|
+
* fits in a number.
|
134
|
+
*/
|
135
|
+
export function rpcQuantityToNumber(quantity: string): number {
|
136
|
+
return Number(rpcQuantityToBigInt(quantity));
|
137
|
+
}
|
138
|
+
|
139
|
+
export function rpcQuantityToBigInt(quantity: string): bigint {
|
140
|
+
// We validate it in case a value gets here through a cast or any
|
141
|
+
if (!isRpcQuantityString(quantity)) {
|
142
|
+
throw new HardhatError(ERRORS.NETWORK.INVALID_RPC_QUANTITY_VALUE, {
|
143
|
+
value: quantity,
|
144
|
+
});
|
145
|
+
}
|
146
|
+
|
147
|
+
return BigInt(quantity);
|
148
|
+
}
|
149
|
+
|
150
|
+
export function numberToRpcQuantity(n: number | bigint): string {
|
151
|
+
assertHardhatInvariant(
|
152
|
+
typeof n === "number" || typeof n === "bigint",
|
153
|
+
"Expected number"
|
154
|
+
);
|
155
|
+
|
156
|
+
return `0x${n.toString(16)}`;
|
157
|
+
}
|
158
|
+
|
159
|
+
export function numberToRpcStorageSlot(n: number | bigint): string {
|
160
|
+
assertHardhatInvariant(
|
161
|
+
typeof n === "number" || typeof n === "bigint",
|
162
|
+
"Expected number"
|
163
|
+
);
|
164
|
+
|
165
|
+
return `0x${BigIntUtils.toEvmWord(n)}`;
|
166
|
+
}
|
167
|
+
|
168
|
+
/**
|
169
|
+
* Transforms a DATA into a number. It should only be used if you are 100% sure that the data
|
170
|
+
* represents a value fits in a number.
|
171
|
+
*/
|
172
|
+
export function rpcDataToNumber(data: string): number {
|
173
|
+
return Number(rpcDataToBigInt(data));
|
174
|
+
}
|
175
|
+
|
176
|
+
export function rpcDataToBigInt(data: string): bigint {
|
177
|
+
return data === "0x" ? 0n : BigInt(data);
|
178
|
+
}
|
179
|
+
|
180
|
+
export function bufferToRpcData(
|
181
|
+
buffer: Uint8Array,
|
182
|
+
padToBytes: number = 0
|
183
|
+
): string {
|
184
|
+
let s = bufferToHex(buffer);
|
185
|
+
if (padToBytes > 0 && s.length < padToBytes * 2 + 2) {
|
186
|
+
s = `0x${"0".repeat(padToBytes * 2 + 2 - s.length)}${s.slice(2)}`;
|
187
|
+
}
|
188
|
+
return s;
|
189
|
+
}
|
190
|
+
|
191
|
+
export function rpcDataToBuffer(data: string): Buffer {
|
192
|
+
// We validate it in case a value gets here through a cast or any
|
193
|
+
if (!isRpcDataString(data)) {
|
194
|
+
throw new HardhatError(ERRORS.NETWORK.INVALID_RPC_DATA_VALUE, {
|
195
|
+
value: data,
|
196
|
+
});
|
197
|
+
}
|
198
|
+
|
199
|
+
return Buffer.from(toBytes(data));
|
200
|
+
}
|
201
|
+
|
202
|
+
// Type guards
|
203
|
+
|
204
|
+
function validateRpcStorageSlotHexString(u: unknown): u is string {
|
205
|
+
return typeof u === "string" && /^0x([0-9a-fA-F]){64}$/.test(u);
|
206
|
+
}
|
207
|
+
|
208
|
+
function isRpcQuantityString(u: unknown): u is string {
|
209
|
+
return (
|
210
|
+
typeof u === "string" &&
|
211
|
+
u.match(/^0x(?:0|(?:[1-9a-fA-F][0-9a-fA-F]*))$/) !== null
|
212
|
+
);
|
213
|
+
}
|
214
|
+
|
215
|
+
function isRpcDataString(u: unknown): u is string {
|
216
|
+
return typeof u === "string" && u.match(/^0x(?:[0-9a-fA-F]{2})*$/) !== null;
|
217
|
+
}
|
218
|
+
|
219
|
+
function isRpcHashString(u: unknown): u is string {
|
220
|
+
return typeof u === "string" && u.length === 66 && isRpcDataString(u);
|
221
|
+
}
|
222
|
+
|
223
|
+
function isRpcAddressString(u: unknown): u is string {
|
224
|
+
return typeof u === "string" && isValidAddress(u);
|
225
|
+
}
|
226
|
+
|
227
|
+
function isInteger(num: unknown): num is number {
|
228
|
+
return Number.isInteger(num);
|
229
|
+
}
|
230
|
+
|
231
|
+
function isNumber(num: unknown): num is number {
|
232
|
+
return typeof num === "number";
|
233
|
+
}
|
@@ -0,0 +1,44 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { optionalOrNullable } from "../../../../util/io-ts";
|
4
|
+
import { rpcData, rpcQuantity } from "../base-types";
|
5
|
+
|
6
|
+
export const rpcNewBlockTagObjectWithNumber = t.type({
|
7
|
+
blockNumber: rpcQuantity,
|
8
|
+
});
|
9
|
+
|
10
|
+
export const rpcNewBlockTagObjectWithHash = t.type({
|
11
|
+
blockHash: rpcData,
|
12
|
+
requireCanonical: optionalOrNullable(t.boolean),
|
13
|
+
});
|
14
|
+
|
15
|
+
export const rpcBlockTagName = t.keyof({
|
16
|
+
earliest: null,
|
17
|
+
latest: null,
|
18
|
+
pending: null,
|
19
|
+
safe: null,
|
20
|
+
finalized: null,
|
21
|
+
});
|
22
|
+
|
23
|
+
// This is the new kind of block tag as defined by https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1898.md
|
24
|
+
export const rpcNewBlockTag = t.union([
|
25
|
+
rpcQuantity,
|
26
|
+
rpcNewBlockTagObjectWithNumber,
|
27
|
+
rpcNewBlockTagObjectWithHash,
|
28
|
+
rpcBlockTagName,
|
29
|
+
]);
|
30
|
+
|
31
|
+
export type RpcNewBlockTag = t.TypeOf<typeof rpcNewBlockTag>;
|
32
|
+
|
33
|
+
export const optionalRpcNewBlockTag = optionalOrNullable(rpcNewBlockTag);
|
34
|
+
|
35
|
+
export type OptionalRpcNewBlockTag = t.TypeOf<typeof optionalRpcNewBlockTag>;
|
36
|
+
|
37
|
+
// This is the old kind of block tag which is described in the ethereum wiki
|
38
|
+
export const rpcOldBlockTag = t.union([rpcQuantity, rpcBlockTagName]);
|
39
|
+
|
40
|
+
export type RpcOldBlockTag = t.TypeOf<typeof rpcOldBlockTag>;
|
41
|
+
|
42
|
+
export const optionalRpcOldBlockTag = optionalOrNullable(rpcOldBlockTag);
|
43
|
+
|
44
|
+
export type OptionalRpcOldBlockTag = t.TypeOf<typeof optionalRpcOldBlockTag>;
|
@@ -0,0 +1,60 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { optionalOrNullable } from "../../../../util/io-ts";
|
4
|
+
import { rpcAccessList } from "../access-list";
|
5
|
+
import {
|
6
|
+
rpcAddress,
|
7
|
+
rpcData,
|
8
|
+
rpcHash,
|
9
|
+
rpcQuantity,
|
10
|
+
rpcStorageSlot,
|
11
|
+
rpcStorageSlotHexString,
|
12
|
+
} from "../base-types";
|
13
|
+
import { address } from "../../../config/config-validation";
|
14
|
+
|
15
|
+
// Type used by eth_call and eth_estimateGas
|
16
|
+
export const rpcCallRequest = t.type(
|
17
|
+
{
|
18
|
+
from: optionalOrNullable(rpcAddress),
|
19
|
+
to: optionalOrNullable(rpcAddress),
|
20
|
+
gas: optionalOrNullable(rpcQuantity),
|
21
|
+
gasPrice: optionalOrNullable(rpcQuantity),
|
22
|
+
value: optionalOrNullable(rpcQuantity),
|
23
|
+
data: optionalOrNullable(rpcData),
|
24
|
+
accessList: optionalOrNullable(rpcAccessList),
|
25
|
+
maxFeePerGas: optionalOrNullable(rpcQuantity),
|
26
|
+
maxPriorityFeePerGas: optionalOrNullable(rpcQuantity),
|
27
|
+
blobs: optionalOrNullable(t.array(rpcData)),
|
28
|
+
blobVersionedHashes: optionalOrNullable(t.array(rpcHash)),
|
29
|
+
},
|
30
|
+
"RpcCallRequest"
|
31
|
+
);
|
32
|
+
|
33
|
+
export type RpcCallRequest = t.TypeOf<typeof rpcCallRequest>;
|
34
|
+
|
35
|
+
// Types used by eth_call to configure the state override set
|
36
|
+
export const stateProperties = t.record(
|
37
|
+
rpcStorageSlotHexString,
|
38
|
+
rpcStorageSlot
|
39
|
+
);
|
40
|
+
|
41
|
+
export const stateOverrideOptions = t.type(
|
42
|
+
{
|
43
|
+
balance: optionalOrNullable(rpcQuantity),
|
44
|
+
nonce: optionalOrNullable(rpcQuantity),
|
45
|
+
code: optionalOrNullable(rpcData),
|
46
|
+
state: optionalOrNullable(stateProperties),
|
47
|
+
stateDiff: optionalOrNullable(stateProperties),
|
48
|
+
},
|
49
|
+
"stateOverrideOptions"
|
50
|
+
);
|
51
|
+
|
52
|
+
export const stateOverrideSet = t.record(address, stateOverrideOptions);
|
53
|
+
export const optionalStateOverrideSet = optionalOrNullable(stateOverrideSet);
|
54
|
+
|
55
|
+
export type StateProperties = t.TypeOf<typeof stateProperties>;
|
56
|
+
export type StateOverrideOptions = t.TypeOf<typeof stateOverrideOptions>;
|
57
|
+
export type StateOverrideSet = t.TypeOf<typeof stateOverrideSet>;
|
58
|
+
export type OptionalStateOverrideSet = t.TypeOf<
|
59
|
+
typeof optionalStateOverrideSet
|
60
|
+
>;
|
@@ -0,0 +1,17 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { optionalOrNullable } from "../../../../util/io-ts";
|
4
|
+
|
5
|
+
export const rpcDebugTracingConfig = optionalOrNullable(
|
6
|
+
t.type(
|
7
|
+
{
|
8
|
+
tracer: optionalOrNullable(t.string),
|
9
|
+
disableStorage: optionalOrNullable(t.boolean),
|
10
|
+
disableMemory: optionalOrNullable(t.boolean),
|
11
|
+
disableStack: optionalOrNullable(t.boolean),
|
12
|
+
},
|
13
|
+
"RpcDebugTracingConfig"
|
14
|
+
)
|
15
|
+
);
|
16
|
+
|
17
|
+
export type RpcDebugTracingConfig = t.TypeOf<typeof rpcDebugTracingConfig>;
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { optionalOrNullable } from "../../../../util/io-ts";
|
4
|
+
import { rpcHash } from "../base-types";
|
5
|
+
|
6
|
+
import { optionalRpcOldBlockTag } from "./blockTag";
|
7
|
+
import { optionalRpcLogAddress } from "./logAddress";
|
8
|
+
import { optionalRpcLogTopics } from "./logTopics";
|
9
|
+
|
10
|
+
export const rpcFilterRequest = t.type(
|
11
|
+
{
|
12
|
+
fromBlock: optionalRpcOldBlockTag,
|
13
|
+
toBlock: optionalRpcOldBlockTag,
|
14
|
+
address: optionalRpcLogAddress,
|
15
|
+
topics: optionalRpcLogTopics,
|
16
|
+
blockHash: optionalOrNullable(rpcHash),
|
17
|
+
},
|
18
|
+
"RpcFilterRequest"
|
19
|
+
);
|
20
|
+
|
21
|
+
export type RpcFilterRequest = t.TypeOf<typeof rpcFilterRequest>;
|
22
|
+
|
23
|
+
export const optionalRpcFilterRequest = optionalOrNullable(rpcFilterRequest);
|
24
|
+
|
25
|
+
export type OptionalRpcFilterRequest = t.TypeOf<
|
26
|
+
typeof optionalRpcFilterRequest
|
27
|
+
>;
|
@@ -0,0 +1,54 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { optional } from "../../../../util/io-ts";
|
4
|
+
import { rpcUnsignedInteger } from "../base-types";
|
5
|
+
|
6
|
+
export const rpcForkConfig = optional(
|
7
|
+
t.type(
|
8
|
+
{
|
9
|
+
jsonRpcUrl: t.string,
|
10
|
+
blockNumber: optional(t.number),
|
11
|
+
httpHeaders: optional(t.record(t.string, t.string, "httpHeaders")),
|
12
|
+
},
|
13
|
+
"RpcForkConfig"
|
14
|
+
)
|
15
|
+
);
|
16
|
+
|
17
|
+
export type RpcForkConfig = t.TypeOf<typeof rpcForkConfig>;
|
18
|
+
|
19
|
+
export const rpcHardhatNetworkConfig = t.type(
|
20
|
+
{
|
21
|
+
forking: optional(rpcForkConfig),
|
22
|
+
},
|
23
|
+
"HardhatNetworkConfig"
|
24
|
+
);
|
25
|
+
|
26
|
+
export type RpcHardhatNetworkConfig = t.TypeOf<typeof rpcHardhatNetworkConfig>;
|
27
|
+
|
28
|
+
export const optionalRpcHardhatNetworkConfig = optional(
|
29
|
+
rpcHardhatNetworkConfig
|
30
|
+
);
|
31
|
+
|
32
|
+
const isNumberPair = (x: unknown): x is [number, number] =>
|
33
|
+
Array.isArray(x) &&
|
34
|
+
x.length === 2 &&
|
35
|
+
Number.isInteger(x[0]) &&
|
36
|
+
Number.isInteger(x[1]);
|
37
|
+
|
38
|
+
// TODO: This can be simplified
|
39
|
+
const rpcIntervalMiningRange = new t.Type<[number, number]>(
|
40
|
+
"Interval mining range",
|
41
|
+
isNumberPair,
|
42
|
+
(u, c) =>
|
43
|
+
isNumberPair(u) && u[0] >= 0 && u[1] >= u[0]
|
44
|
+
? t.success(u)
|
45
|
+
: t.failure(u, c),
|
46
|
+
t.identity
|
47
|
+
);
|
48
|
+
|
49
|
+
export const rpcIntervalMining = t.union([
|
50
|
+
rpcUnsignedInteger,
|
51
|
+
rpcIntervalMiningRange,
|
52
|
+
]);
|
53
|
+
|
54
|
+
export type RpcIntervalMining = t.TypeOf<typeof rpcIntervalMining>;
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { optionalOrNullable } from "../../../../util/io-ts";
|
4
|
+
import { rpcAddress } from "../base-types";
|
5
|
+
|
6
|
+
export const rpcLogAddress = t.union([rpcAddress, t.array(rpcAddress)]);
|
7
|
+
|
8
|
+
export type RpcLogAddress = t.TypeOf<typeof rpcLogAddress>;
|
9
|
+
|
10
|
+
export const optionalRpcLogAddress = optionalOrNullable(rpcLogAddress);
|
11
|
+
|
12
|
+
export type OptionalRpcLogAddress = t.TypeOf<typeof optionalRpcLogAddress>;
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { optionalOrNullable } from "../../../../util/io-ts";
|
4
|
+
import { rpcHash } from "../base-types";
|
5
|
+
|
6
|
+
export const rpcLogTopics = t.array(
|
7
|
+
t.union([t.null, rpcHash, t.array(t.union([t.null, rpcHash]))])
|
8
|
+
);
|
9
|
+
|
10
|
+
export type RpcLogTopics = t.TypeOf<typeof rpcLogTopics>;
|
11
|
+
|
12
|
+
export const optionalRpcLogTopics = optionalOrNullable(rpcLogTopics);
|
13
|
+
|
14
|
+
export type OptionalRpcLogTopics = t.TypeOf<typeof optionalRpcLogTopics>;
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
export const rpcCompilerInput = t.type(
|
4
|
+
{
|
5
|
+
language: t.string,
|
6
|
+
sources: t.any,
|
7
|
+
settings: t.any,
|
8
|
+
},
|
9
|
+
"RpcCompilerInput"
|
10
|
+
);
|
11
|
+
|
12
|
+
export type RpcCompilerInput = t.TypeOf<typeof rpcCompilerInput>;
|
13
|
+
|
14
|
+
export const rpcCompilerOutput = t.type(
|
15
|
+
{
|
16
|
+
sources: t.any,
|
17
|
+
contracts: t.any,
|
18
|
+
},
|
19
|
+
"RpcCompilerOutput"
|
20
|
+
);
|
21
|
+
|
22
|
+
export type RpcCompilerOutput = t.TypeOf<typeof rpcCompilerOutput>;
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { RpcFilterRequest } from "./filterRequest";
|
4
|
+
|
5
|
+
// TODO: This types are incorrect. See: https://geth.ethereum.org/docs/rpc/pubsub
|
6
|
+
// Actually, the logs filter is not of the same type as eth_newFilter
|
7
|
+
|
8
|
+
export interface RpcSubscribe {
|
9
|
+
request: RpcFilterRequest;
|
10
|
+
}
|
11
|
+
|
12
|
+
export type RpcSubscribeRequest = t.TypeOf<typeof rpcSubscribeRequest>;
|
13
|
+
|
14
|
+
export const rpcSubscribeRequest = t.keyof(
|
15
|
+
{
|
16
|
+
newHeads: null,
|
17
|
+
newPendingTransactions: null,
|
18
|
+
logs: null,
|
19
|
+
},
|
20
|
+
"RpcSubscribe"
|
21
|
+
);
|
@@ -0,0 +1,47 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
|
3
|
+
import { optionalOrNullable } from "../../../../util/io-ts";
|
4
|
+
import { rpcAccessList } from "../access-list";
|
5
|
+
import { rpcAddress, rpcData, rpcHash, rpcQuantity } from "../base-types";
|
6
|
+
|
7
|
+
// Type used by eth_sendTransaction
|
8
|
+
export const rpcTransactionRequest = t.type(
|
9
|
+
{
|
10
|
+
from: rpcAddress,
|
11
|
+
to: optionalOrNullable(rpcAddress),
|
12
|
+
gas: optionalOrNullable(rpcQuantity),
|
13
|
+
gasPrice: optionalOrNullable(rpcQuantity),
|
14
|
+
value: optionalOrNullable(rpcQuantity),
|
15
|
+
nonce: optionalOrNullable(rpcQuantity),
|
16
|
+
data: optionalOrNullable(rpcData),
|
17
|
+
accessList: optionalOrNullable(rpcAccessList),
|
18
|
+
chainId: optionalOrNullable(rpcQuantity),
|
19
|
+
maxFeePerGas: optionalOrNullable(rpcQuantity),
|
20
|
+
maxPriorityFeePerGas: optionalOrNullable(rpcQuantity),
|
21
|
+
blobs: optionalOrNullable(t.array(rpcData)),
|
22
|
+
blobVersionedHashes: optionalOrNullable(t.array(rpcHash)),
|
23
|
+
},
|
24
|
+
"RpcTransactionRequest"
|
25
|
+
);
|
26
|
+
|
27
|
+
// This type represents possibly valid inputs to rpcTransactionRequest.
|
28
|
+
// TODO: It can probably be inferred by io-ts.
|
29
|
+
export interface RpcTransactionRequestInput {
|
30
|
+
from: string;
|
31
|
+
to?: string;
|
32
|
+
gas?: string;
|
33
|
+
gasPrice?: string;
|
34
|
+
value?: string;
|
35
|
+
nonce?: string;
|
36
|
+
data?: string;
|
37
|
+
accessList?: Array<{
|
38
|
+
address: string;
|
39
|
+
storageKeys: string[];
|
40
|
+
}>;
|
41
|
+
maxFeePerGas?: string;
|
42
|
+
maxPriorityFeePerGas?: string;
|
43
|
+
blobs?: string[];
|
44
|
+
blobVersionedHashes?: string[];
|
45
|
+
}
|
46
|
+
|
47
|
+
export type RpcTransactionRequest = t.TypeOf<typeof rpcTransactionRequest>;
|
@@ -0,0 +1,75 @@
|
|
1
|
+
import * as t from "io-ts";
|
2
|
+
import { PathReporter } from "io-ts/lib/PathReporter";
|
3
|
+
|
4
|
+
import { InvalidArgumentsError } from "../../../providers/errors";
|
5
|
+
|
6
|
+
/* eslint-disable @nomicfoundation/hardhat-internal-rules/only-hardhat-error */
|
7
|
+
|
8
|
+
/**
|
9
|
+
* This function validates a list of params, throwing InvalidArgumentsError
|
10
|
+
* if the validation fails, and returning their already-parsed types if
|
11
|
+
* the validation succeeds.
|
12
|
+
*
|
13
|
+
* TODO: The type can probably be improved, removing the anys
|
14
|
+
*/
|
15
|
+
export function validateParams<
|
16
|
+
TypesT extends ReadonlyArray<t.Type<any, any, any>>
|
17
|
+
>(
|
18
|
+
params: any[],
|
19
|
+
...types: TypesT
|
20
|
+
): {
|
21
|
+
[i in keyof TypesT]: TypesT[i] extends t.Type<infer TypeT, any, any>
|
22
|
+
? TypeT
|
23
|
+
: never;
|
24
|
+
} {
|
25
|
+
if (types === undefined && params.length > 0) {
|
26
|
+
throw new InvalidArgumentsError(
|
27
|
+
`No argument was expected and got ${params.length}`
|
28
|
+
);
|
29
|
+
}
|
30
|
+
|
31
|
+
let optionalParams = 0;
|
32
|
+
for (let i = types.length - 1; i >= 0; i--) {
|
33
|
+
if (types[i].is(undefined)) {
|
34
|
+
optionalParams += 1;
|
35
|
+
} else {
|
36
|
+
break;
|
37
|
+
}
|
38
|
+
}
|
39
|
+
|
40
|
+
if (optionalParams === 0) {
|
41
|
+
if (params.length !== types.length) {
|
42
|
+
throw new InvalidArgumentsError(
|
43
|
+
`Expected exactly ${types.length} arguments and got ${params.length}`
|
44
|
+
);
|
45
|
+
}
|
46
|
+
} else {
|
47
|
+
if (
|
48
|
+
params.length > types.length ||
|
49
|
+
params.length < types.length - optionalParams
|
50
|
+
) {
|
51
|
+
throw new InvalidArgumentsError(
|
52
|
+
`Expected between ${types.length - optionalParams} and ${
|
53
|
+
types.length
|
54
|
+
} arguments and got ${params.length}`
|
55
|
+
);
|
56
|
+
}
|
57
|
+
}
|
58
|
+
|
59
|
+
const decoded: any[] = [];
|
60
|
+
for (let i = 0; i < types.length; i++) {
|
61
|
+
const result = types[i].decode(params[i]);
|
62
|
+
|
63
|
+
if (result.isLeft()) {
|
64
|
+
throw new InvalidArgumentsError(
|
65
|
+
`Errors encountered in param ${i}: ${PathReporter.report(result).join(
|
66
|
+
", "
|
67
|
+
)}`
|
68
|
+
);
|
69
|
+
}
|
70
|
+
|
71
|
+
decoded.push(result.value);
|
72
|
+
}
|
73
|
+
|
74
|
+
return decoded as any;
|
75
|
+
}
|