@hyperlane-xyz/sdk 3.9.0 → 3.10.1-beta0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -3
- package/dist/app/HyperlaneApp.d.ts +6 -7
- package/dist/app/HyperlaneApp.d.ts.map +1 -1
- package/dist/app/HyperlaneApp.js +10 -15
- package/dist/app/HyperlaneApp.js.map +1 -1
- package/dist/app/MultiProtocolApp.d.ts +10 -11
- package/dist/app/MultiProtocolApp.d.ts.map +1 -1
- package/dist/app/MultiProtocolApp.js +25 -43
- package/dist/app/MultiProtocolApp.js.map +1 -1
- package/dist/app/MultiProtocolApp.test.js +15 -17
- package/dist/app/MultiProtocolApp.test.js.map +1 -1
- package/dist/consts/bytecode.d.ts +8 -8
- package/dist/consts/bytecode.d.ts.map +1 -1
- package/dist/consts/bytecode.js +2 -5
- package/dist/consts/bytecode.js.map +1 -1
- package/dist/consts/chainMetadata.d.ts +5 -3
- package/dist/consts/chainMetadata.d.ts.map +1 -1
- package/dist/consts/chainMetadata.js +295 -239
- package/dist/consts/chainMetadata.js.map +1 -1
- package/dist/consts/chains.d.ts +3 -1
- package/dist/consts/chains.d.ts.map +1 -1
- package/dist/consts/chains.js +19 -18
- package/dist/consts/chains.js.map +1 -1
- package/dist/consts/crud.d.ts +2 -0
- package/dist/consts/crud.d.ts.map +1 -0
- package/dist/consts/crud.js +2 -0
- package/dist/consts/crud.js.map +1 -0
- package/dist/consts/environments/index.d.ts +290 -236
- package/dist/consts/environments/index.d.ts.map +1 -1
- package/dist/consts/environments/index.js +5 -11
- package/dist/consts/environments/index.js.map +1 -1
- package/dist/consts/environments/mainnet.json +295 -243
- package/dist/consts/environments/testnet.json +49 -47
- package/dist/consts/igp.js +1 -4
- package/dist/consts/igp.js.map +1 -1
- package/dist/consts/mailbox.js +1 -4
- package/dist/consts/mailbox.js.map +1 -1
- package/dist/consts/multisigIsm.d.ts +2 -2
- package/dist/consts/multisigIsm.d.ts.map +1 -1
- package/dist/consts/multisigIsm.js +59 -54
- package/dist/consts/multisigIsm.js.map +1 -1
- package/dist/consts/sealevel.js +1 -4
- package/dist/consts/sealevel.js.map +1 -1
- package/dist/contracts/contracts.d.ts +4 -4
- package/dist/contracts/contracts.d.ts.map +1 -1
- package/dist/contracts/contracts.js +33 -48
- package/dist/contracts/contracts.js.map +1 -1
- package/dist/contracts/types.d.ts +1 -1
- package/dist/contracts/types.d.ts.map +1 -1
- package/dist/contracts/types.js +1 -2
- package/dist/core/CoreDeployer.hardhat-test.js +83 -50
- package/dist/core/CoreDeployer.hardhat-test.js.map +1 -1
- package/dist/core/HyperlaneCore.d.ts +15 -9
- package/dist/core/HyperlaneCore.d.ts.map +1 -1
- package/dist/core/HyperlaneCore.js +80 -38
- package/dist/core/HyperlaneCore.js.map +1 -1
- package/dist/core/HyperlaneCore.test.js +6 -8
- package/dist/core/HyperlaneCore.test.js.map +1 -1
- package/dist/core/HyperlaneCoreChecker.d.ts +6 -6
- package/dist/core/HyperlaneCoreChecker.d.ts.map +1 -1
- package/dist/core/HyperlaneCoreChecker.js +25 -28
- package/dist/core/HyperlaneCoreChecker.js.map +1 -1
- package/dist/core/HyperlaneCoreDeployer.d.ts +12 -12
- package/dist/core/HyperlaneCoreDeployer.d.ts.map +1 -1
- package/dist/core/HyperlaneCoreDeployer.js +26 -27
- package/dist/core/HyperlaneCoreDeployer.js.map +1 -1
- package/dist/core/MultiProtocolCore.d.ts +9 -10
- package/dist/core/MultiProtocolCore.d.ts.map +1 -1
- package/dist/core/MultiProtocolCore.js +18 -23
- package/dist/core/MultiProtocolCore.js.map +1 -1
- package/dist/core/MultiProtocolCore.test.js +30 -32
- package/dist/core/MultiProtocolCore.test.js.map +1 -1
- package/dist/core/TestCoreApp.d.ts +3 -3
- package/dist/core/TestCoreApp.d.ts.map +1 -1
- package/dist/core/TestCoreApp.js +11 -14
- package/dist/core/TestCoreApp.js.map +1 -1
- package/dist/core/TestCoreDeployer.d.ts +5 -5
- package/dist/core/TestCoreDeployer.d.ts.map +1 -1
- package/dist/core/TestCoreDeployer.js +7 -11
- package/dist/core/TestCoreDeployer.js.map +1 -1
- package/dist/core/TestRecipientDeployer.d.ts +5 -5
- package/dist/core/TestRecipientDeployer.d.ts.map +1 -1
- package/dist/core/TestRecipientDeployer.js +11 -18
- package/dist/core/TestRecipientDeployer.js.map +1 -1
- package/dist/core/adapters/CosmWasmCoreAdapter.d.ts +6 -6
- package/dist/core/adapters/CosmWasmCoreAdapter.d.ts.map +1 -1
- package/dist/core/adapters/CosmWasmCoreAdapter.js +12 -13
- package/dist/core/adapters/CosmWasmCoreAdapter.js.map +1 -1
- package/dist/core/adapters/CosmWasmCoreAdapter.test.js +11 -13
- package/dist/core/adapters/CosmWasmCoreAdapter.test.js.map +1 -1
- package/dist/core/adapters/CosmWasmIgpAdapter.d.ts +4 -4
- package/dist/core/adapters/CosmWasmIgpAdapter.d.ts.map +1 -1
- package/dist/core/adapters/CosmWasmIgpAdapter.js +5 -6
- package/dist/core/adapters/CosmWasmIgpAdapter.js.map +1 -1
- package/dist/core/adapters/EvmCoreAdapter.d.ts +6 -6
- package/dist/core/adapters/EvmCoreAdapter.d.ts.map +1 -1
- package/dist/core/adapters/EvmCoreAdapter.js +12 -12
- package/dist/core/adapters/EvmCoreAdapter.js.map +1 -1
- package/dist/core/adapters/SealevelCoreAdapter.d.ts +5 -5
- package/dist/core/adapters/SealevelCoreAdapter.d.ts.map +1 -1
- package/dist/core/adapters/SealevelCoreAdapter.js +14 -15
- package/dist/core/adapters/SealevelCoreAdapter.js.map +1 -1
- package/dist/core/adapters/SealevelCoreAdapter.test.js +5 -7
- package/dist/core/adapters/SealevelCoreAdapter.test.js.map +1 -1
- package/dist/core/adapters/types.d.ts +3 -3
- package/dist/core/adapters/types.d.ts.map +1 -1
- package/dist/core/adapters/types.js +1 -2
- package/dist/core/contracts.d.ts +1 -1
- package/dist/core/contracts.d.ts.map +1 -1
- package/dist/core/contracts.js +5 -8
- package/dist/core/contracts.js.map +1 -1
- package/dist/core/events.d.ts +1 -1
- package/dist/core/events.d.ts.map +1 -1
- package/dist/core/events.js +1 -2
- package/dist/core/read.d.ts +28 -0
- package/dist/core/read.d.ts.map +1 -0
- package/dist/core/read.js +44 -0
- package/dist/core/read.js.map +1 -0
- package/dist/core/testHyperlaneDeploy.hardhat-test.js +29 -31
- package/dist/core/testHyperlaneDeploy.hardhat-test.js.map +1 -1
- package/dist/core/types.d.ts +6 -6
- package/dist/core/types.d.ts.map +1 -1
- package/dist/core/types.js +4 -7
- package/dist/core/types.js.map +1 -1
- package/dist/cw-types/Cw20Base.types.js +1 -2
- package/dist/cw-types/Cw20Base.types.js.map +1 -1
- package/dist/cw-types/HookAggregate.types.js +1 -2
- package/dist/cw-types/HookAggregate.types.js.map +1 -1
- package/dist/cw-types/HookMerkle.types.js +1 -2
- package/dist/cw-types/HookMerkle.types.js.map +1 -1
- package/dist/cw-types/HookPausable.types.js +1 -2
- package/dist/cw-types/HookPausable.types.js.map +1 -1
- package/dist/cw-types/HookRouting.types.js +1 -2
- package/dist/cw-types/HookRouting.types.js.map +1 -1
- package/dist/cw-types/HookRoutingCustom.types.js +1 -2
- package/dist/cw-types/HookRoutingCustom.types.js.map +1 -1
- package/dist/cw-types/HookRoutingFallback.types.js +1 -2
- package/dist/cw-types/HookRoutingFallback.types.js.map +1 -1
- package/dist/cw-types/Igp.types.js +1 -2
- package/dist/cw-types/Igp.types.js.map +1 -1
- package/dist/cw-types/IgpOracle.types.js +1 -2
- package/dist/cw-types/IgpOracle.types.js.map +1 -1
- package/dist/cw-types/IsmAggregate.types.js +1 -2
- package/dist/cw-types/IsmAggregate.types.js.map +1 -1
- package/dist/cw-types/IsmMultisig.types.js +1 -2
- package/dist/cw-types/IsmMultisig.types.js.map +1 -1
- package/dist/cw-types/IsmRouting.types.js +1 -2
- package/dist/cw-types/IsmRouting.types.js.map +1 -1
- package/dist/cw-types/Mailbox.types.js +1 -2
- package/dist/cw-types/Mailbox.types.js.map +1 -1
- package/dist/cw-types/ValidatorAnnounce.types.js +1 -2
- package/dist/cw-types/ValidatorAnnounce.types.js.map +1 -1
- package/dist/cw-types/WarpCw20.types.js +1 -2
- package/dist/cw-types/WarpCw20.types.js.map +1 -1
- package/dist/cw-types/WarpNative.types.js +1 -2
- package/dist/cw-types/WarpNative.types.js.map +1 -1
- package/dist/deploy/HyperlaneAppChecker.d.ts +6 -6
- package/dist/deploy/HyperlaneAppChecker.d.ts.map +1 -1
- package/dist/deploy/HyperlaneAppChecker.js +39 -36
- package/dist/deploy/HyperlaneAppChecker.js.map +1 -1
- package/dist/deploy/HyperlaneDeployer.d.ts +34 -16
- package/dist/deploy/HyperlaneDeployer.d.ts.map +1 -1
- package/dist/deploy/HyperlaneDeployer.js +112 -79
- package/dist/deploy/HyperlaneDeployer.js.map +1 -1
- package/dist/deploy/HyperlaneProxyFactoryDeployer.d.ts +6 -6
- package/dist/deploy/HyperlaneProxyFactoryDeployer.d.ts.map +1 -1
- package/dist/deploy/HyperlaneProxyFactoryDeployer.js +7 -14
- package/dist/deploy/HyperlaneProxyFactoryDeployer.js.map +1 -1
- package/dist/deploy/contracts.js +8 -11
- package/dist/deploy/contracts.js.map +1 -1
- package/dist/deploy/proxy.js +9 -16
- package/dist/deploy/proxy.js.map +1 -1
- package/dist/deploy/schemas.d.ts +70 -0
- package/dist/deploy/schemas.d.ts.map +1 -0
- package/dist/deploy/schemas.js +7 -0
- package/dist/deploy/schemas.js.map +1 -0
- package/dist/deploy/types.d.ts +17 -4
- package/dist/deploy/types.d.ts.map +1 -1
- package/dist/deploy/types.js +17 -7
- package/dist/deploy/types.js.map +1 -1
- package/dist/deploy/verify/ContractVerifier.d.ts +8 -7
- package/dist/deploy/verify/ContractVerifier.d.ts.map +1 -1
- package/dist/deploy/verify/ContractVerifier.js +52 -56
- package/dist/deploy/verify/ContractVerifier.js.map +1 -1
- package/dist/deploy/verify/PostDeploymentContractVerifier.d.ts +6 -7
- package/dist/deploy/verify/PostDeploymentContractVerifier.d.ts.map +1 -1
- package/dist/deploy/verify/PostDeploymentContractVerifier.js +14 -14
- package/dist/deploy/verify/PostDeploymentContractVerifier.js.map +1 -1
- package/dist/deploy/verify/types.js +7 -10
- package/dist/deploy/verify/types.js.map +1 -1
- package/dist/deploy/verify/utils.d.ts +1 -1
- package/dist/deploy/verify/utils.d.ts.map +1 -1
- package/dist/deploy/verify/utils.js +4 -11
- package/dist/deploy/verify/utils.js.map +1 -1
- package/dist/gas/HyperlaneIgp.d.ts +6 -6
- package/dist/gas/HyperlaneIgp.d.ts.map +1 -1
- package/dist/gas/HyperlaneIgp.js +9 -13
- package/dist/gas/HyperlaneIgp.js.map +1 -1
- package/dist/gas/HyperlaneIgpChecker.d.ts +4 -4
- package/dist/gas/HyperlaneIgpChecker.d.ts.map +1 -1
- package/dist/gas/HyperlaneIgpChecker.js +21 -25
- package/dist/gas/HyperlaneIgpChecker.js.map +1 -1
- package/dist/gas/HyperlaneIgpDeployer.d.ts +7 -7
- package/dist/gas/HyperlaneIgpDeployer.d.ts.map +1 -1
- package/dist/gas/HyperlaneIgpDeployer.js +16 -25
- package/dist/gas/HyperlaneIgpDeployer.js.map +1 -1
- package/dist/gas/adapters/SealevelIgpAdapter.d.ts +4 -4
- package/dist/gas/adapters/SealevelIgpAdapter.d.ts.map +1 -1
- package/dist/gas/adapters/SealevelIgpAdapter.js +11 -12
- package/dist/gas/adapters/SealevelIgpAdapter.js.map +1 -1
- package/dist/gas/adapters/serialization.js +33 -19
- package/dist/gas/adapters/serialization.js.map +1 -1
- package/dist/gas/contracts.js +5 -8
- package/dist/gas/contracts.js.map +1 -1
- package/dist/gas/oracle/configure-gas-oracles.hardhat-test.js +14 -15
- package/dist/gas/oracle/configure-gas-oracles.hardhat-test.js.map +1 -1
- package/dist/gas/oracle/types.js +9 -14
- package/dist/gas/oracle/types.js.map +1 -1
- package/dist/gas/token-prices.d.ts +2 -2
- package/dist/gas/token-prices.d.ts.map +1 -1
- package/dist/gas/token-prices.js +17 -17
- package/dist/gas/token-prices.js.map +1 -1
- package/dist/gas/token-prices.test.js +10 -12
- package/dist/gas/token-prices.test.js.map +1 -1
- package/dist/gas/types.d.ts +4 -4
- package/dist/gas/types.d.ts.map +1 -1
- package/dist/gas/types.js +2 -5
- package/dist/gas/types.js.map +1 -1
- package/dist/hook/HyperlaneHookDeployer.d.ts +16 -16
- package/dist/hook/HyperlaneHookDeployer.d.ts.map +1 -1
- package/dist/hook/HyperlaneHookDeployer.js +52 -55
- package/dist/hook/HyperlaneHookDeployer.js.map +1 -1
- package/dist/hook/contracts.js +11 -14
- package/dist/hook/contracts.js.map +1 -1
- package/dist/hook/read.d.ts +36 -0
- package/dist/hook/read.d.ts.map +1 -0
- package/dist/hook/read.js +191 -0
- package/dist/hook/read.js.map +1 -0
- package/dist/hook/read.test.d.ts +2 -0
- package/dist/hook/read.test.d.ts.map +1 -0
- package/dist/hook/read.test.js +151 -0
- package/dist/hook/read.test.js.map +1 -0
- package/dist/hook/types.d.ts +17 -6
- package/dist/hook/types.d.ts.map +1 -1
- package/dist/hook/types.js +16 -5
- package/dist/hook/types.js.map +1 -1
- package/dist/index.d.ts +116 -105
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +106 -320
- package/dist/index.js.map +1 -1
- package/dist/ism/HyperlaneIsmFactory.d.ts +13 -13
- package/dist/ism/HyperlaneIsmFactory.d.ts.map +1 -1
- package/dist/ism/HyperlaneIsmFactory.hardhat-test.js +104 -80
- package/dist/ism/HyperlaneIsmFactory.hardhat-test.js.map +1 -1
- package/dist/ism/HyperlaneIsmFactory.js +70 -74
- package/dist/ism/HyperlaneIsmFactory.js.map +1 -1
- package/dist/ism/adapters/CosmWasmMultisigAdapter.d.ts +5 -5
- package/dist/ism/adapters/CosmWasmMultisigAdapter.d.ts.map +1 -1
- package/dist/ism/adapters/CosmWasmMultisigAdapter.js +9 -10
- package/dist/ism/adapters/CosmWasmMultisigAdapter.js.map +1 -1
- package/dist/ism/multisig.d.ts +2 -2
- package/dist/ism/multisig.d.ts.map +1 -1
- package/dist/ism/multisig.js +9 -14
- package/dist/ism/multisig.js.map +1 -1
- package/dist/ism/read.d.ts +29 -0
- package/dist/ism/read.d.ts.map +1 -0
- package/dist/ism/read.js +152 -0
- package/dist/ism/read.js.map +1 -0
- package/dist/ism/read.test.d.ts +2 -0
- package/dist/ism/read.test.d.ts.map +1 -0
- package/dist/ism/read.test.js +125 -0
- package/dist/ism/read.test.js.map +1 -0
- package/dist/ism/schemas.d.ts +177 -0
- package/dist/ism/schemas.d.ts.map +1 -0
- package/dist/ism/schemas.js +59 -0
- package/dist/ism/schemas.js.map +1 -0
- package/dist/ism/schemas.test.d.ts +2 -0
- package/dist/ism/schemas.test.d.ts.map +1 -0
- package/dist/ism/schemas.test.js +18 -0
- package/dist/ism/schemas.test.js.map +1 -0
- package/dist/ism/types.d.ts +14 -7
- package/dist/ism/types.d.ts.map +1 -1
- package/dist/ism/types.js +9 -12
- package/dist/ism/types.js.map +1 -1
- package/dist/ism/utils.d.ts +5 -5
- package/dist/ism/utils.d.ts.map +1 -1
- package/dist/ism/utils.js +85 -82
- package/dist/ism/utils.js.map +1 -1
- package/dist/metadata/ChainMetadataManager.d.ts +5 -5
- package/dist/metadata/ChainMetadataManager.d.ts.map +1 -1
- package/dist/metadata/ChainMetadataManager.js +23 -23
- package/dist/metadata/ChainMetadataManager.js.map +1 -1
- package/dist/metadata/agentConfig.d.ts +340 -340
- package/dist/metadata/agentConfig.d.ts.map +1 -1
- package/dist/metadata/agentConfig.js +100 -104
- package/dist/metadata/agentConfig.js.map +1 -1
- package/dist/metadata/agentConfig.test.js +12 -14
- package/dist/metadata/agentConfig.test.js.map +1 -1
- package/dist/metadata/blockExplorer.d.ts +1 -1
- package/dist/metadata/blockExplorer.d.ts.map +1 -1
- package/dist/metadata/blockExplorer.js +12 -20
- package/dist/metadata/blockExplorer.js.map +1 -1
- package/dist/metadata/chainMetadata.test.js +22 -24
- package/dist/metadata/chainMetadata.test.js.map +1 -1
- package/dist/metadata/chainMetadataTypes.d.ts +233 -1
- package/dist/metadata/chainMetadataTypes.d.ts.map +1 -1
- package/dist/metadata/chainMetadataTypes.js +91 -79
- package/dist/metadata/chainMetadataTypes.js.map +1 -1
- package/dist/metadata/customZodTypes.js +6 -9
- package/dist/metadata/customZodTypes.js.map +1 -1
- package/dist/metadata/deploymentArtifacts.js +8 -11
- package/dist/metadata/deploymentArtifacts.js.map +1 -1
- package/dist/metadata/health.d.ts +2 -2
- package/dist/metadata/health.d.ts.map +1 -1
- package/dist/metadata/health.js +44 -52
- package/dist/metadata/health.js.map +1 -1
- package/dist/metadata/matchingList.js +9 -12
- package/dist/metadata/matchingList.js.map +1 -1
- package/dist/metadata/warpRouteConfig.d.ts +2 -2
- package/dist/metadata/warpRouteConfig.d.ts.map +1 -1
- package/dist/metadata/warpRouteConfig.js +18 -21
- package/dist/metadata/warpRouteConfig.js.map +1 -1
- package/dist/middleware/account/InterchainAccount.d.ts +15 -5
- package/dist/middleware/account/InterchainAccount.d.ts.map +1 -1
- package/dist/middleware/account/InterchainAccount.js +71 -13
- package/dist/middleware/account/InterchainAccount.js.map +1 -1
- package/dist/middleware/account/InterchainAccountChecker.d.ts +6 -6
- package/dist/middleware/account/InterchainAccountChecker.d.ts.map +1 -1
- package/dist/middleware/account/InterchainAccountChecker.js +4 -8
- package/dist/middleware/account/InterchainAccountChecker.js.map +1 -1
- package/dist/middleware/account/InterchainAccountDeployer.d.ts +14 -11
- package/dist/middleware/account/InterchainAccountDeployer.d.ts.map +1 -1
- package/dist/middleware/account/InterchainAccountDeployer.js +16 -12
- package/dist/middleware/account/InterchainAccountDeployer.js.map +1 -1
- package/dist/middleware/account/accounts.hardhat-test.js +44 -30
- package/dist/middleware/account/accounts.hardhat-test.js.map +1 -1
- package/dist/middleware/account/contracts.js +6 -9
- package/dist/middleware/account/contracts.js.map +1 -1
- package/dist/middleware/account/schemas.d.ts +21 -0
- package/dist/middleware/account/schemas.d.ts.map +1 -0
- package/dist/middleware/account/schemas.js +11 -0
- package/dist/middleware/account/schemas.js.map +1 -0
- package/dist/middleware/account/types.d.ts +10 -0
- package/dist/middleware/account/types.d.ts.map +1 -0
- package/dist/middleware/account/types.js +2 -0
- package/dist/middleware/account/types.js.map +1 -0
- package/dist/middleware/liquidity-layer/LiquidityLayerApp.d.ts +6 -6
- package/dist/middleware/liquidity-layer/LiquidityLayerApp.d.ts.map +1 -1
- package/dist/middleware/liquidity-layer/LiquidityLayerApp.js +23 -24
- package/dist/middleware/liquidity-layer/LiquidityLayerApp.js.map +1 -1
- package/dist/middleware/liquidity-layer/LiquidityLayerRouterDeployer.d.ts +14 -12
- package/dist/middleware/liquidity-layer/LiquidityLayerRouterDeployer.d.ts.map +1 -1
- package/dist/middleware/liquidity-layer/LiquidityLayerRouterDeployer.js +32 -28
- package/dist/middleware/liquidity-layer/LiquidityLayerRouterDeployer.js.map +1 -1
- package/dist/middleware/liquidity-layer/contracts.js +7 -10
- package/dist/middleware/liquidity-layer/contracts.js.map +1 -1
- package/dist/middleware/liquidity-layer/liquidity-layer.hardhat-test.js +36 -38
- package/dist/middleware/liquidity-layer/liquidity-layer.hardhat-test.js.map +1 -1
- package/dist/middleware/query/InterchainQuery.d.ts +5 -5
- package/dist/middleware/query/InterchainQuery.d.ts.map +1 -1
- package/dist/middleware/query/InterchainQuery.js +7 -11
- package/dist/middleware/query/InterchainQuery.js.map +1 -1
- package/dist/middleware/query/InterchainQueryChecker.d.ts +4 -4
- package/dist/middleware/query/InterchainQueryChecker.d.ts.map +1 -1
- package/dist/middleware/query/InterchainQueryChecker.js +2 -6
- package/dist/middleware/query/InterchainQueryChecker.js.map +1 -1
- package/dist/middleware/query/InterchainQueryDeployer.d.ts +13 -9
- package/dist/middleware/query/InterchainQueryDeployer.d.ts.map +1 -1
- package/dist/middleware/query/InterchainQueryDeployer.js +16 -12
- package/dist/middleware/query/InterchainQueryDeployer.js.map +1 -1
- package/dist/middleware/query/contracts.js +5 -8
- package/dist/middleware/query/contracts.js.map +1 -1
- package/dist/middleware/query/queries.hardhat-test.js +32 -34
- package/dist/middleware/query/queries.hardhat-test.js.map +1 -1
- package/dist/providers/MultiProtocolProvider.d.ts +10 -10
- package/dist/providers/MultiProtocolProvider.d.ts.map +1 -1
- package/dist/providers/MultiProtocolProvider.js +37 -35
- package/dist/providers/MultiProtocolProvider.js.map +1 -1
- package/dist/providers/MultiProtocolProvider.test.js +12 -14
- package/dist/providers/MultiProtocolProvider.test.js.map +1 -1
- package/dist/providers/MultiProvider.d.ts +7 -7
- package/dist/providers/MultiProvider.d.ts.map +1 -1
- package/dist/providers/MultiProvider.js +30 -25
- package/dist/providers/MultiProvider.js.map +1 -1
- package/dist/providers/ProviderType.js +8 -11
- package/dist/providers/ProviderType.js.map +1 -1
- package/dist/providers/SmartProvider/HyperlaneEtherscanProvider.d.ts +3 -4
- package/dist/providers/SmartProvider/HyperlaneEtherscanProvider.d.ts.map +1 -1
- package/dist/providers/SmartProvider/HyperlaneEtherscanProvider.js +19 -25
- package/dist/providers/SmartProvider/HyperlaneEtherscanProvider.js.map +1 -1
- package/dist/providers/SmartProvider/HyperlaneJsonRpcProvider.d.ts +3 -4
- package/dist/providers/SmartProvider/HyperlaneJsonRpcProvider.d.ts.map +1 -1
- package/dist/providers/SmartProvider/HyperlaneJsonRpcProvider.js +32 -38
- package/dist/providers/SmartProvider/HyperlaneJsonRpcProvider.js.map +1 -1
- package/dist/providers/SmartProvider/ProviderMethods.js +5 -9
- package/dist/providers/SmartProvider/ProviderMethods.js.map +1 -1
- package/dist/providers/SmartProvider/SmartProvider.d.ts +7 -7
- package/dist/providers/SmartProvider/SmartProvider.d.ts.map +1 -1
- package/dist/providers/SmartProvider/SmartProvider.foundry-test.js +22 -24
- package/dist/providers/SmartProvider/SmartProvider.foundry-test.js.map +1 -1
- package/dist/providers/SmartProvider/SmartProvider.js +45 -45
- package/dist/providers/SmartProvider/SmartProvider.js.map +1 -1
- package/dist/providers/SmartProvider/SmartProvider.test.js +45 -47
- package/dist/providers/SmartProvider/SmartProvider.test.js.map +1 -1
- package/dist/providers/SmartProvider/types.d.ts +1 -1
- package/dist/providers/SmartProvider/types.d.ts.map +1 -1
- package/dist/providers/SmartProvider/types.js +2 -5
- package/dist/providers/SmartProvider/types.js.map +1 -1
- package/dist/providers/providerBuilders.d.ts +3 -3
- package/dist/providers/providerBuilders.d.ts.map +1 -1
- package/dist/providers/providerBuilders.js +38 -48
- package/dist/providers/providerBuilders.js.map +1 -1
- package/dist/providers/transactionFeeEstimators.d.ts +2 -2
- package/dist/providers/transactionFeeEstimators.d.ts.map +1 -1
- package/dist/providers/transactionFeeEstimators.js +40 -50
- package/dist/providers/transactionFeeEstimators.js.map +1 -1
- package/dist/router/GasRouterDeployer.d.ts +5 -5
- package/dist/router/GasRouterDeployer.d.ts.map +1 -1
- package/dist/router/GasRouterDeployer.js +4 -8
- package/dist/router/GasRouterDeployer.js.map +1 -1
- package/dist/router/HyperlaneRouterChecker.d.ts +7 -7
- package/dist/router/HyperlaneRouterChecker.d.ts.map +1 -1
- package/dist/router/HyperlaneRouterChecker.js +24 -26
- package/dist/router/HyperlaneRouterChecker.js.map +1 -1
- package/dist/router/HyperlaneRouterDeployer.d.ts +4 -4
- package/dist/router/HyperlaneRouterDeployer.d.ts.map +1 -1
- package/dist/router/HyperlaneRouterDeployer.js +14 -18
- package/dist/router/HyperlaneRouterDeployer.js.map +1 -1
- package/dist/router/MultiProtocolRouterApps.d.ts +4 -5
- package/dist/router/MultiProtocolRouterApps.d.ts.map +1 -1
- package/dist/router/MultiProtocolRouterApps.js +14 -19
- package/dist/router/MultiProtocolRouterApps.js.map +1 -1
- package/dist/router/MultiProtocolRouterApps.test.js +13 -15
- package/dist/router/MultiProtocolRouterApps.test.js.map +1 -1
- package/dist/router/ProxiedRouterChecker.d.ts +4 -4
- package/dist/router/ProxiedRouterChecker.d.ts.map +1 -1
- package/dist/router/ProxiedRouterChecker.js +2 -6
- package/dist/router/ProxiedRouterChecker.js.map +1 -1
- package/dist/router/ProxiedRouterDeployer.d.ts +28 -9
- package/dist/router/ProxiedRouterDeployer.d.ts.map +1 -1
- package/dist/router/ProxiedRouterDeployer.js +13 -19
- package/dist/router/ProxiedRouterDeployer.js.map +1 -1
- package/dist/router/RouterApps.d.ts +7 -8
- package/dist/router/RouterApps.d.ts.map +1 -1
- package/dist/router/RouterApps.js +19 -17
- package/dist/router/RouterApps.js.map +1 -1
- package/dist/router/adapters/EvmRouterAdapter.d.ts +4 -4
- package/dist/router/adapters/EvmRouterAdapter.d.ts.map +1 -1
- package/dist/router/adapters/EvmRouterAdapter.js +11 -13
- package/dist/router/adapters/EvmRouterAdapter.js.map +1 -1
- package/dist/router/adapters/SealevelRouterAdapter.d.ts +4 -4
- package/dist/router/adapters/SealevelRouterAdapter.d.ts.map +1 -1
- package/dist/router/adapters/SealevelRouterAdapter.js +6 -8
- package/dist/router/adapters/SealevelRouterAdapter.js.map +1 -1
- package/dist/router/adapters/types.d.ts +2 -2
- package/dist/router/adapters/types.d.ts.map +1 -1
- package/dist/router/adapters/types.js +1 -2
- package/dist/router/schemas.d.ts +71 -0
- package/dist/router/schemas.d.ts.map +1 -0
- package/dist/router/schemas.js +16 -0
- package/dist/router/schemas.js.map +1 -0
- package/dist/router/types.d.ts +8 -15
- package/dist/router/types.d.ts.map +1 -1
- package/dist/router/types.js +8 -11
- package/dist/router/types.js.map +1 -1
- package/dist/test/metadata-check.js +17 -20
- package/dist/test/metadata-check.js.map +1 -1
- package/dist/test/testUtils.d.ts +8 -8
- package/dist/test/testUtils.d.ts.map +1 -1
- package/dist/test/testUtils.js +29 -34
- package/dist/test/testUtils.js.map +1 -1
- package/dist/token/IToken.d.ts +21 -21
- package/dist/token/IToken.d.ts.map +1 -1
- package/dist/token/IToken.js +18 -21
- package/dist/token/IToken.js.map +1 -1
- package/dist/token/Token.d.ts +7 -7
- package/dist/token/Token.d.ts.map +1 -1
- package/dist/token/Token.js +77 -80
- package/dist/token/Token.js.map +1 -1
- package/dist/token/Token.test.js +68 -70
- package/dist/token/Token.test.js.map +1 -1
- package/dist/token/TokenAmount.d.ts +1 -1
- package/dist/token/TokenAmount.d.ts.map +1 -1
- package/dist/token/TokenAmount.js +5 -7
- package/dist/token/TokenAmount.js.map +1 -1
- package/dist/token/TokenAmount.test.js +22 -24
- package/dist/token/TokenAmount.test.js.map +1 -1
- package/dist/token/TokenConnection.d.ts +2 -2
- package/dist/token/TokenConnection.d.ts.map +1 -1
- package/dist/token/TokenConnection.js +26 -31
- package/dist/token/TokenConnection.js.map +1 -1
- package/dist/token/TokenStandard.d.ts +2 -2
- package/dist/token/TokenStandard.d.ts.map +1 -1
- package/dist/token/TokenStandard.js +54 -57
- package/dist/token/TokenStandard.js.map +1 -1
- package/dist/token/adapters/CosmWasmTokenAdapter.d.ts +9 -9
- package/dist/token/adapters/CosmWasmTokenAdapter.d.ts.map +1 -1
- package/dist/token/adapters/CosmWasmTokenAdapter.js +28 -19
- package/dist/token/adapters/CosmWasmTokenAdapter.js.map +1 -1
- package/dist/token/adapters/CosmWasmTokenAdapter.test.js +39 -47
- package/dist/token/adapters/CosmWasmTokenAdapter.test.js.map +1 -1
- package/dist/token/adapters/CosmosTokenAdapter.d.ts +6 -6
- package/dist/token/adapters/CosmosTokenAdapter.d.ts.map +1 -1
- package/dist/token/adapters/CosmosTokenAdapter.js +22 -19
- package/dist/token/adapters/CosmosTokenAdapter.js.map +1 -1
- package/dist/token/adapters/EvmTokenAdapter.d.ts +6 -6
- package/dist/token/adapters/EvmTokenAdapter.d.ts.map +1 -1
- package/dist/token/adapters/EvmTokenAdapter.js +36 -28
- package/dist/token/adapters/EvmTokenAdapter.js.map +1 -1
- package/dist/token/adapters/ITokenAdapter.d.ts +2 -2
- package/dist/token/adapters/ITokenAdapter.d.ts.map +1 -1
- package/dist/token/adapters/ITokenAdapter.js +1 -2
- package/dist/token/adapters/SealevelTokenAdapter.d.ts +7 -7
- package/dist/token/adapters/SealevelTokenAdapter.d.ts.map +1 -1
- package/dist/token/adapters/SealevelTokenAdapter.js +68 -61
- package/dist/token/adapters/SealevelTokenAdapter.js.map +1 -1
- package/dist/token/adapters/serialization.d.ts +1 -1
- package/dist/token/adapters/serialization.d.ts.map +1 -1
- package/dist/token/adapters/serialization.js +58 -28
- package/dist/token/adapters/serialization.js.map +1 -1
- package/dist/token/app.d.ts +11 -0
- package/dist/token/app.d.ts.map +1 -0
- package/dist/token/app.js +22 -0
- package/dist/token/app.js.map +1 -0
- package/dist/token/checker.d.ts +10 -0
- package/dist/token/checker.d.ts.map +1 -0
- package/dist/token/checker.js +73 -0
- package/dist/token/checker.js.map +1 -0
- package/dist/token/config.d.ts +11 -5
- package/dist/token/config.d.ts.map +1 -1
- package/dist/token/config.js +10 -19
- package/dist/token/config.js.map +1 -1
- package/dist/token/contracts.d.ts +30 -0
- package/dist/token/contracts.d.ts.map +1 -1
- package/dist/token/contracts.js +36 -18
- package/dist/token/contracts.js.map +1 -1
- package/dist/token/deploy.d.ts +26 -19
- package/dist/token/deploy.d.ts.map +1 -1
- package/dist/token/deploy.hardhat-test.js +16 -18
- package/dist/token/deploy.hardhat-test.js.map +1 -1
- package/dist/token/deploy.js +147 -113
- package/dist/token/deploy.js.map +1 -1
- package/dist/token/schemas.d.ts +375 -0
- package/dist/token/schemas.d.ts.map +1 -0
- package/dist/token/schemas.js +48 -0
- package/dist/token/schemas.js.map +1 -0
- package/dist/token/schemas.test.d.ts +2 -0
- package/dist/token/schemas.test.d.ts.map +1 -0
- package/dist/token/schemas.test.js +85 -0
- package/dist/token/schemas.test.js.map +1 -0
- package/dist/token/types.d.ts +5 -0
- package/dist/token/types.d.ts.map +1 -0
- package/dist/token/types.js +2 -0
- package/dist/token/types.js.map +1 -0
- package/dist/types.js +1 -2
- package/dist/utils/MultiGeneric.d.ts +2 -2
- package/dist/utils/MultiGeneric.d.ts.map +1 -1
- package/dist/utils/MultiGeneric.js +5 -8
- package/dist/utils/MultiGeneric.js.map +1 -1
- package/dist/utils/fetch.js +3 -10
- package/dist/utils/fetch.js.map +1 -1
- package/dist/utils/filter.d.ts +1 -1
- package/dist/utils/filter.d.ts.map +1 -1
- package/dist/utils/filter.js +1 -5
- package/dist/utils/filter.js.map +1 -1
- package/dist/utils/fork.d.ts +38 -0
- package/dist/utils/fork.d.ts.map +1 -0
- package/dist/utils/fork.js +89 -0
- package/dist/utils/fork.js.map +1 -0
- package/dist/utils/ism.js +5 -12
- package/dist/utils/ism.js.map +1 -1
- package/dist/utils/sealevelSerialization.js +10 -9
- package/dist/utils/sealevelSerialization.js.map +1 -1
- package/dist/utils/wagmi.d.ts +2 -2
- package/dist/utils/wagmi.d.ts.map +1 -1
- package/dist/utils/wagmi.js +7 -11
- package/dist/utils/wagmi.js.map +1 -1
- package/dist/warp/WarpCore.d.ts +10 -10
- package/dist/warp/WarpCore.d.ts.map +1 -1
- package/dist/warp/WarpCore.js +53 -51
- package/dist/warp/WarpCore.js.map +1 -1
- package/dist/warp/WarpCore.test.js +67 -73
- package/dist/warp/WarpCore.test.js.map +1 -1
- package/dist/warp/types.d.ts +29 -29
- package/dist/warp/types.d.ts.map +1 -1
- package/dist/warp/types.js +17 -20
- package/dist/warp/types.js.map +1 -1
- package/package.json +22 -14
- package/dist/logger.d.ts +0 -3
- package/dist/logger.d.ts.map +0 -1
- package/dist/logger.js +0 -11
- package/dist/logger.js.map +0 -1
|
@@ -1,16 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.HyperlaneProxyFactoryDeployer = void 0;
|
|
7
|
-
const debug_1 = __importDefault(require("debug"));
|
|
8
|
-
const HyperlaneDeployer_1 = require("./HyperlaneDeployer");
|
|
9
|
-
const contracts_1 = require("./contracts");
|
|
10
|
-
class HyperlaneProxyFactoryDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
1
|
+
import { rootLogger } from '@hyperlane-xyz/utils';
|
|
2
|
+
import { HyperlaneDeployer } from './HyperlaneDeployer.js';
|
|
3
|
+
import { proxyFactoryFactories, proxyFactoryImplementations, } from './contracts.js';
|
|
4
|
+
export class HyperlaneProxyFactoryDeployer extends HyperlaneDeployer {
|
|
11
5
|
constructor(multiProvider, contractVerifier) {
|
|
12
|
-
super(multiProvider,
|
|
13
|
-
logger: (
|
|
6
|
+
super(multiProvider, proxyFactoryFactories, {
|
|
7
|
+
logger: rootLogger.child({ module: 'IsmFactoryDeployer' }),
|
|
14
8
|
contractVerifier,
|
|
15
9
|
});
|
|
16
10
|
}
|
|
@@ -20,7 +14,7 @@ class HyperlaneProxyFactoryDeployer extends HyperlaneDeployer_1.HyperlaneDeploye
|
|
|
20
14
|
const factory = await this.deployContract(chain, factoryName, []);
|
|
21
15
|
this.addVerificationArtifacts(chain, [
|
|
22
16
|
{
|
|
23
|
-
name:
|
|
17
|
+
name: proxyFactoryImplementations[factoryName],
|
|
24
18
|
address: await factory.implementation(),
|
|
25
19
|
constructorArguments: '',
|
|
26
20
|
isProxy: true,
|
|
@@ -31,5 +25,4 @@ class HyperlaneProxyFactoryDeployer extends HyperlaneDeployer_1.HyperlaneDeploye
|
|
|
31
25
|
return contracts;
|
|
32
26
|
}
|
|
33
27
|
}
|
|
34
|
-
exports.HyperlaneProxyFactoryDeployer = HyperlaneProxyFactoryDeployer;
|
|
35
28
|
//# sourceMappingURL=HyperlaneProxyFactoryDeployer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneProxyFactoryDeployer.js","sourceRoot":"","sources":["../../src/deploy/HyperlaneProxyFactoryDeployer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"HyperlaneProxyFactoryDeployer.js","sourceRoot":"","sources":["../../src/deploy/HyperlaneProxyFactoryDeployer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAMlD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAEL,qBAAqB,EACrB,2BAA2B,GAC5B,MAAM,gBAAgB,CAAC;AAGxB,MAAM,OAAO,6BAA8B,SAAQ,iBAGlD;IACC,YACE,aAA4B,EAC5B,gBAAmC;QAEnC,KAAK,CAAC,aAAa,EAAE,qBAAqB,EAAE;YAC1C,MAAM,EAAE,UAAU,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,oBAAoB,EAAE,CAAC;YAC1D,gBAAgB;SACjB,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,KAAgB;QAEhB,MAAM,SAAS,GAAQ,EAAE,CAAC;QAC1B,KAAK,MAAM,WAAW,IAAI,MAAM,CAAC,IAAI,CACnC,IAAI,CAAC,SAAS,CACoB,EAAE,CAAC;YACrC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,WAAW,EAAE,EAAE,CAAC,CAAC;YAClE,IAAI,CAAC,wBAAwB,CAAC,KAAK,EAAE;gBACnC;oBACE,IAAI,EAAE,2BAA2B,CAAC,WAAW,CAAC;oBAC9C,OAAO,EAAE,MAAM,OAAO,CAAC,cAAc,EAAE;oBACvC,oBAAoB,EAAE,EAAE;oBACxB,OAAO,EAAE,IAAI;iBACd;aACF,CAAC,CAAC;YACH,SAAS,CAAC,WAAW,CAAC,GAAG,OAAO,CAAC;QACnC,CAAC;QACD,OAAO,SAAsD,CAAC;IAChE,CAAC;CACF"}
|
package/dist/deploy/contracts.js
CHANGED
|
@@ -1,18 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.proxyFactoryImplementations = exports.proxyFactoryFactories = void 0;
|
|
4
|
-
const core_1 = require("@hyperlane-xyz/core");
|
|
1
|
+
import { DomainRoutingIsmFactory__factory, StaticAggregationHookFactory__factory, StaticAggregationIsmFactory__factory, StaticMerkleRootMultisigIsmFactory__factory, StaticMessageIdMultisigIsmFactory__factory, } from '@hyperlane-xyz/core';
|
|
5
2
|
// Any name changes here should also be reflected in the example artifacts.
|
|
6
3
|
// E.g. typescript/cli/examples/contract-artifacts.yaml
|
|
7
|
-
|
|
8
|
-
staticMerkleRootMultisigIsmFactory: new
|
|
9
|
-
staticMessageIdMultisigIsmFactory: new
|
|
10
|
-
staticAggregationIsmFactory: new
|
|
11
|
-
staticAggregationHookFactory: new
|
|
12
|
-
domainRoutingIsmFactory: new
|
|
4
|
+
export const proxyFactoryFactories = {
|
|
5
|
+
staticMerkleRootMultisigIsmFactory: new StaticMerkleRootMultisigIsmFactory__factory(),
|
|
6
|
+
staticMessageIdMultisigIsmFactory: new StaticMessageIdMultisigIsmFactory__factory(),
|
|
7
|
+
staticAggregationIsmFactory: new StaticAggregationIsmFactory__factory(),
|
|
8
|
+
staticAggregationHookFactory: new StaticAggregationHookFactory__factory(),
|
|
9
|
+
domainRoutingIsmFactory: new DomainRoutingIsmFactory__factory(),
|
|
13
10
|
};
|
|
14
11
|
// must match contract names for verification
|
|
15
|
-
|
|
12
|
+
export const proxyFactoryImplementations = {
|
|
16
13
|
staticMerkleRootMultisigIsmFactory: 'StaticMerkleRootMultisigIsm',
|
|
17
14
|
staticMessageIdMultisigIsmFactory: 'StaticMessageIdMultisigIsm',
|
|
18
15
|
staticAggregationIsmFactory: 'StaticAggregationIsm',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contracts.js","sourceRoot":"","sources":["../../src/deploy/contracts.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"contracts.js","sourceRoot":"","sources":["../../src/deploy/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gCAAgC,EAChC,qCAAqC,EACrC,oCAAoC,EACpC,2CAA2C,EAC3C,0CAA0C,GAC3C,MAAM,qBAAqB,CAAC;AAE7B,2EAA2E;AAC3E,uDAAuD;AACvD,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACnC,kCAAkC,EAChC,IAAI,2CAA2C,EAAE;IACnD,iCAAiC,EAC/B,IAAI,0CAA0C,EAAE;IAClD,2BAA2B,EAAE,IAAI,oCAAoC,EAAE;IACvE,4BAA4B,EAAE,IAAI,qCAAqC,EAAE;IACzE,uBAAuB,EAAE,IAAI,gCAAgC,EAAE;CAChE,CAAC;AAMF,6CAA6C;AAC7C,MAAM,CAAC,MAAM,2BAA2B,GAAgC;IACtE,kCAAkC,EAAE,6BAA6B;IACjE,iCAAiC,EAAE,4BAA4B;IAC/D,2BAA2B,EAAE,sBAAsB;IACnD,4BAA4B,EAAE,uBAAuB;IACrD,uBAAuB,EAAE,mBAAmB;CAC7C,CAAC"}
|
package/dist/deploy/proxy.js
CHANGED
|
@@ -1,30 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const ethers_1 = require("ethers");
|
|
5
|
-
const utils_1 = require("@hyperlane-xyz/utils");
|
|
6
|
-
async function proxyImplementation(provider, proxy) {
|
|
1
|
+
import { ethers } from 'ethers';
|
|
2
|
+
import { eqAddress } from '@hyperlane-xyz/utils';
|
|
3
|
+
export async function proxyImplementation(provider, proxy) {
|
|
7
4
|
// Hardcoded storage slot for implementation per EIP-1967
|
|
8
5
|
const storageValue = await provider.getStorageAt(proxy, '0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc');
|
|
9
|
-
return
|
|
6
|
+
return ethers.utils.getAddress(storageValue.slice(26));
|
|
10
7
|
}
|
|
11
|
-
|
|
12
|
-
async function proxyAdmin(provider, proxy) {
|
|
8
|
+
export async function proxyAdmin(provider, proxy) {
|
|
13
9
|
// Hardcoded storage slot for admin per EIP-1967
|
|
14
10
|
const storageValue = await provider.getStorageAt(proxy, '0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103');
|
|
15
|
-
return
|
|
11
|
+
return ethers.utils.getAddress(storageValue.slice(26));
|
|
16
12
|
}
|
|
17
|
-
|
|
18
|
-
function proxyConstructorArgs(implementation, proxyAdmin, initializeArgs) {
|
|
13
|
+
export function proxyConstructorArgs(implementation, proxyAdmin, initializeArgs) {
|
|
19
14
|
const initData = initializeArgs
|
|
20
15
|
? implementation.interface.encodeFunctionData('initialize', initializeArgs)
|
|
21
16
|
: '0x';
|
|
22
17
|
return [implementation.address, proxyAdmin, initData];
|
|
23
18
|
}
|
|
24
|
-
|
|
25
|
-
async function isProxy(provider, proxy) {
|
|
19
|
+
export async function isProxy(provider, proxy) {
|
|
26
20
|
const admin = await proxyAdmin(provider, proxy);
|
|
27
|
-
return !
|
|
21
|
+
return !eqAddress(admin, ethers.constants.AddressZero);
|
|
28
22
|
}
|
|
29
|
-
exports.isProxy = isProxy;
|
|
30
23
|
//# sourceMappingURL=proxy.js.map
|
package/dist/deploy/proxy.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"proxy.js","sourceRoot":"","sources":["../../src/deploy/proxy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"proxy.js","sourceRoot":"","sources":["../../src/deploy/proxy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEhC,OAAO,EAAW,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAa1D,MAAM,CAAC,KAAK,UAAU,mBAAmB,CACvC,QAAmC,EACnC,KAAc;IAEd,yDAAyD;IACzD,MAAM,YAAY,GAAG,MAAM,QAAQ,CAAC,YAAY,CAC9C,KAAK,EACL,oEAAoE,CACrE,CAAC;IACF,OAAO,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,QAAmC,EACnC,KAAc;IAEd,gDAAgD;IAChD,MAAM,YAAY,GAAG,MAAM,QAAQ,CAAC,YAAY,CAC9C,KAAK,EACL,oEAAoE,CACrE,CAAC;IACF,OAAO,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,cAAiB,EACjB,UAAkB,EAClB,cAA4C;IAE5C,MAAM,QAAQ,GAAG,cAAc;QAC7B,CAAC,CAAC,cAAc,CAAC,SAAS,CAAC,kBAAkB,CAAC,YAAY,EAAE,cAAc,CAAC;QAC3E,CAAC,CAAC,IAAI,CAAC;IACT,OAAO,CAAC,cAAc,CAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,OAAO,CAC3B,QAAmC,EACnC,KAAc;IAEd,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IAChD,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;AACzD,CAAC"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
export declare const OwnerSchema: z.ZodUnion<[z.ZodString, z.ZodObject<{
|
|
3
|
+
origin: z.ZodString;
|
|
4
|
+
owner: z.ZodString;
|
|
5
|
+
localRouter: z.ZodOptional<z.ZodString>;
|
|
6
|
+
routerOverride: z.ZodOptional<z.ZodString>;
|
|
7
|
+
ismOverride: z.ZodOptional<z.ZodString>;
|
|
8
|
+
}, "strip", z.ZodTypeAny, {
|
|
9
|
+
owner: string;
|
|
10
|
+
origin: string;
|
|
11
|
+
localRouter?: string | undefined;
|
|
12
|
+
routerOverride?: string | undefined;
|
|
13
|
+
ismOverride?: string | undefined;
|
|
14
|
+
}, {
|
|
15
|
+
owner: string;
|
|
16
|
+
origin: string;
|
|
17
|
+
localRouter?: string | undefined;
|
|
18
|
+
routerOverride?: string | undefined;
|
|
19
|
+
ismOverride?: string | undefined;
|
|
20
|
+
}>]>;
|
|
21
|
+
export declare const OwnableConfigSchema: z.ZodObject<{
|
|
22
|
+
owner: z.ZodUnion<[z.ZodString, z.ZodObject<{
|
|
23
|
+
origin: z.ZodString;
|
|
24
|
+
owner: z.ZodString;
|
|
25
|
+
localRouter: z.ZodOptional<z.ZodString>;
|
|
26
|
+
routerOverride: z.ZodOptional<z.ZodString>;
|
|
27
|
+
ismOverride: z.ZodOptional<z.ZodString>;
|
|
28
|
+
}, "strip", z.ZodTypeAny, {
|
|
29
|
+
owner: string;
|
|
30
|
+
origin: string;
|
|
31
|
+
localRouter?: string | undefined;
|
|
32
|
+
routerOverride?: string | undefined;
|
|
33
|
+
ismOverride?: string | undefined;
|
|
34
|
+
}, {
|
|
35
|
+
owner: string;
|
|
36
|
+
origin: string;
|
|
37
|
+
localRouter?: string | undefined;
|
|
38
|
+
routerOverride?: string | undefined;
|
|
39
|
+
ismOverride?: string | undefined;
|
|
40
|
+
}>]>;
|
|
41
|
+
}, "strip", z.ZodTypeAny, {
|
|
42
|
+
owner: (string | {
|
|
43
|
+
owner: string;
|
|
44
|
+
origin: string;
|
|
45
|
+
localRouter?: string | undefined;
|
|
46
|
+
routerOverride?: string | undefined;
|
|
47
|
+
ismOverride?: string | undefined;
|
|
48
|
+
}) & (string | {
|
|
49
|
+
owner: string;
|
|
50
|
+
origin: string;
|
|
51
|
+
localRouter?: string | undefined;
|
|
52
|
+
routerOverride?: string | undefined;
|
|
53
|
+
ismOverride?: string | undefined;
|
|
54
|
+
} | undefined);
|
|
55
|
+
}, {
|
|
56
|
+
owner: (string | {
|
|
57
|
+
owner: string;
|
|
58
|
+
origin: string;
|
|
59
|
+
localRouter?: string | undefined;
|
|
60
|
+
routerOverride?: string | undefined;
|
|
61
|
+
ismOverride?: string | undefined;
|
|
62
|
+
}) & (string | {
|
|
63
|
+
owner: string;
|
|
64
|
+
origin: string;
|
|
65
|
+
localRouter?: string | undefined;
|
|
66
|
+
routerOverride?: string | undefined;
|
|
67
|
+
ismOverride?: string | undefined;
|
|
68
|
+
} | undefined);
|
|
69
|
+
}>;
|
|
70
|
+
//# sourceMappingURL=schemas.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schemas.d.ts","sourceRoot":"","sources":["../../src/deploy/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAIxB,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;IAA6C,CAAC;AAEtE,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAE9B,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { AccountConfigSchema } from '../middleware/account/schemas.js';
|
|
3
|
+
export const OwnerSchema = z.union([z.string(), AccountConfigSchema]);
|
|
4
|
+
export const OwnableConfigSchema = z.object({
|
|
5
|
+
owner: OwnerSchema,
|
|
6
|
+
});
|
|
7
|
+
//# sourceMappingURL=schemas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schemas.js","sourceRoot":"","sources":["../../src/deploy/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AAEvE,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,mBAAmB,CAAC,CAAC,CAAC;AAEtE,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,KAAK,EAAE,WAAW;CACnB,CAAC,CAAC"}
|
package/dist/deploy/types.d.ts
CHANGED
|
@@ -1,11 +1,20 @@
|
|
|
1
1
|
import type { Contract } from 'ethers';
|
|
2
|
+
import { z } from 'zod';
|
|
2
3
|
import type { AccessControl, Ownable, TimelockController } from '@hyperlane-xyz/core';
|
|
3
4
|
import { Address } from '@hyperlane-xyz/utils';
|
|
4
|
-
import
|
|
5
|
-
|
|
6
|
-
|
|
5
|
+
import { AccountConfig } from '../middleware/account/types.js';
|
|
6
|
+
import { MultiProvider } from '../providers/MultiProvider.js';
|
|
7
|
+
import type { ChainName } from '../types.js';
|
|
8
|
+
import { OwnableConfigSchema } from './schemas.js';
|
|
9
|
+
export type Owner = Address | AccountConfig;
|
|
10
|
+
/**
|
|
11
|
+
* @remarks ownerOverrides is added outside of the Schema because zod handle generics in a weird way (uses functions)
|
|
12
|
+
* @see https://stackoverflow.com/questions/74907523/creating-zod-schema-for-generic-interface
|
|
13
|
+
*/
|
|
14
|
+
export type OwnableConfig<Keys extends PropertyKey = PropertyKey> = z.infer<typeof OwnableConfigSchema> & {
|
|
7
15
|
ownerOverrides?: Partial<Record<Keys, Address>>;
|
|
8
16
|
};
|
|
17
|
+
export declare function resolveOrDeployAccountOwner(multiProvider: MultiProvider, chain: ChainName, owner: Owner): Promise<Address>;
|
|
9
18
|
export declare function isOwnableConfig(config: object): config is OwnableConfig;
|
|
10
19
|
export interface CheckerViolation {
|
|
11
20
|
chain: ChainName;
|
|
@@ -20,7 +29,8 @@ export declare enum ViolationType {
|
|
|
20
29
|
BytecodeMismatch = "BytecodeMismatch",
|
|
21
30
|
ProxyAdmin = "ProxyAdmin",
|
|
22
31
|
TimelockController = "TimelockController",
|
|
23
|
-
AccessControl = "AccessControl"
|
|
32
|
+
AccessControl = "AccessControl",
|
|
33
|
+
TokenMismatch = "TokenMismatch"
|
|
24
34
|
}
|
|
25
35
|
export interface OwnerViolation extends CheckerViolation {
|
|
26
36
|
type: ViolationType.Owner;
|
|
@@ -54,4 +64,7 @@ export interface BytecodeMismatchViolation extends CheckerViolation {
|
|
|
54
64
|
type: ViolationType.BytecodeMismatch;
|
|
55
65
|
name: string;
|
|
56
66
|
}
|
|
67
|
+
export interface TokenMismatchViolation extends CheckerViolation {
|
|
68
|
+
tokenAddress: Address;
|
|
69
|
+
}
|
|
57
70
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/deploy/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/deploy/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AACvC,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EACV,aAAa,EACb,OAAO,EACP,kBAAkB,EACnB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAG/C,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAE7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD,MAAM,MAAM,KAAK,GAAG,OAAO,GAAG,aAAa,CAAC;AAE5C;;;GAGG;AACH,MAAM,MAAM,aAAa,CAAC,IAAI,SAAS,WAAW,GAAG,WAAW,IAAI,CAAC,CAAC,KAAK,CACzE,OAAO,mBAAmB,CAC3B,GAAG;IACF,cAAc,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;CACjD,CAAC;AAEF,wBAAsB,2BAA2B,CAC/C,aAAa,EAAE,aAAa,EAC5B,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,KAAK,GACX,OAAO,CAAC,OAAO,CAAC,CAUlB;AAED,wBAAgB,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,IAAI,aAAa,CAEvE;AAED,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,SAAS,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,GAAG,CAAC;IACd,MAAM,EAAE,GAAG,CAAC;IACZ,QAAQ,CAAC,EAAE,QAAQ,CAAC;CACrB;AAED,oBAAY,aAAa;IACvB,KAAK,UAAU;IACf,WAAW,gBAAgB;IAC3B,gBAAgB,qBAAqB;IACrC,UAAU,eAAe;IACzB,kBAAkB,uBAAuB;IACzC,aAAa,kBAAkB;IAC/B,aAAa,kBAAkB;CAChC;AAED,MAAM,WAAW,cAAe,SAAQ,gBAAgB;IACtD,IAAI,EAAE,aAAa,CAAC,KAAK,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,mBAAoB,SAAQ,gBAAgB;IAC3D,IAAI,EAAE,aAAa,CAAC,UAAU,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,2BAA4B,SAAQ,gBAAgB;IACnE,IAAI,EAAE,aAAa,CAAC,kBAAkB,CAAC;IACvC,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,kBAAkB,CAAC;CAC9B;AAED,MAAM,WAAW,sBAAuB,SAAQ,gBAAgB;IAC9D,IAAI,EAAE,aAAa,CAAC,aAAa,CAAC;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,EAAE,aAAa,CAAC;CACzB;AAED,MAAM,WAAW,oBAAqB,SAAQ,gBAAgB;IAC5D,IAAI,EAAE,aAAa,CAAC,WAAW,CAAC;CACjC;AAED,MAAM,WAAW,yBAA0B,SAAQ,gBAAgB;IACjE,IAAI,EAAE,aAAa,CAAC,gBAAgB,CAAC;IACrC,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,sBAAuB,SAAQ,gBAAgB;IAC9D,YAAY,EAAE,OAAO,CAAC;CACvB"}
|
package/dist/deploy/types.js
CHANGED
|
@@ -1,11 +1,20 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { deployInterchainAccount } from '../middleware/account/InterchainAccount.js';
|
|
2
|
+
export async function resolveOrDeployAccountOwner(multiProvider, chain, owner) {
|
|
3
|
+
if (typeof owner === 'string') {
|
|
4
|
+
return owner;
|
|
5
|
+
}
|
|
6
|
+
else {
|
|
7
|
+
if (!owner.localRouter) {
|
|
8
|
+
throw new Error('localRouter is required for AccountConfig');
|
|
9
|
+
}
|
|
10
|
+
// submits a transaction to deploy an interchain account if the owner is an AccountConfig and the ICA isn't not deployed yet
|
|
11
|
+
return await deployInterchainAccount(multiProvider, chain, owner);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export function isOwnableConfig(config) {
|
|
5
15
|
return 'owner' in config;
|
|
6
16
|
}
|
|
7
|
-
|
|
8
|
-
var ViolationType;
|
|
17
|
+
export var ViolationType;
|
|
9
18
|
(function (ViolationType) {
|
|
10
19
|
ViolationType["Owner"] = "Owner";
|
|
11
20
|
ViolationType["NotDeployed"] = "NotDeployed";
|
|
@@ -13,5 +22,6 @@ var ViolationType;
|
|
|
13
22
|
ViolationType["ProxyAdmin"] = "ProxyAdmin";
|
|
14
23
|
ViolationType["TimelockController"] = "TimelockController";
|
|
15
24
|
ViolationType["AccessControl"] = "AccessControl";
|
|
16
|
-
|
|
25
|
+
ViolationType["TokenMismatch"] = "TokenMismatch";
|
|
26
|
+
})(ViolationType || (ViolationType = {}));
|
|
17
27
|
//# sourceMappingURL=types.js.map
|
package/dist/deploy/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/deploy/types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/deploy/types.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AAmBrF,MAAM,CAAC,KAAK,UAAU,2BAA2B,CAC/C,aAA4B,EAC5B,KAAgB,EAChB,KAAY;IAEZ,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,KAAK,CAAC;IACf,CAAC;SAAM,CAAC;QACN,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;YACvB,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;QAC/D,CAAC;QACD,4HAA4H;QAC5H,OAAO,MAAM,uBAAuB,CAAC,aAAa,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IACpE,CAAC;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,MAAc;IAC5C,OAAO,OAAO,IAAI,MAAM,CAAC;AAC3B,CAAC;AAUD,MAAM,CAAN,IAAY,aAQX;AARD,WAAY,aAAa;IACvB,gCAAe,CAAA;IACf,4CAA2B,CAAA;IAC3B,sDAAqC,CAAA;IACrC,0CAAyB,CAAA;IACzB,0DAAyC,CAAA;IACzC,gDAA+B,CAAA;IAC/B,gDAA+B,CAAA;AACjC,CAAC,EARW,aAAa,KAAb,aAAa,QAQxB"}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { BuildArtifact, CompilerOptions, ContractVerificationInput } from './types';
|
|
1
|
+
import { MultiProvider } from '../../providers/MultiProvider.js';
|
|
2
|
+
import { ChainMap, ChainName } from '../../types.js';
|
|
3
|
+
import { BuildArtifact, CompilerOptions, ContractVerificationInput } from './types.js';
|
|
5
4
|
export declare class ContractVerifier {
|
|
6
5
|
protected readonly multiProvider: MultiProvider;
|
|
7
6
|
protected readonly apiKeys: ChainMap<string>;
|
|
8
|
-
|
|
9
|
-
|
|
7
|
+
protected logger: import("pino").default.Logger<never>;
|
|
8
|
+
protected contractSourceMap: {
|
|
9
|
+
[contractName: string]: string;
|
|
10
|
+
};
|
|
10
11
|
protected readonly standardInputJson: string;
|
|
11
12
|
protected readonly compilerOptions: CompilerOptions;
|
|
12
13
|
constructor(multiProvider: MultiProvider, apiKeys: ChainMap<string>, buildArtifact: BuildArtifact, licenseType: CompilerOptions['licenseType']);
|
|
@@ -14,6 +15,6 @@ export declare class ContractVerifier {
|
|
|
14
15
|
private isAlreadyVerified;
|
|
15
16
|
private verifyProxy;
|
|
16
17
|
private verifyImplementation;
|
|
17
|
-
verifyContract(chain: ChainName, input: ContractVerificationInput, logger?:
|
|
18
|
+
verifyContract(chain: ChainName, input: ContractVerificationInput, logger?: import("pino").default.Logger<never>): Promise<void>;
|
|
18
19
|
}
|
|
19
20
|
//# sourceMappingURL=ContractVerifier.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ContractVerifier.d.ts","sourceRoot":"","sources":["../../../src/deploy/verify/ContractVerifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ContractVerifier.d.ts","sourceRoot":"","sources":["../../../src/deploy/verify/ContractVerifier.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAErD,OAAO,EACL,aAAa,EACb,eAAe,EACf,yBAAyB,EAK1B,MAAM,YAAY,CAAC;AAEpB,qBAAa,gBAAgB;IASzB,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,aAAa;IAC/C,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC;IAT9C,SAAS,CAAC,MAAM,uCAAoD;IAEpE,SAAS,CAAC,iBAAiB,EAAE;QAAE,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAM;IAErE,SAAS,CAAC,QAAQ,CAAC,iBAAiB,EAAE,MAAM,CAAC;IAC7C,SAAS,CAAC,QAAQ,CAAC,eAAe,EAAE,eAAe,CAAC;gBAG/B,aAAa,EAAE,aAAa,EAC5B,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,EAC5C,aAAa,EAAE,aAAa,EAC5B,WAAW,EAAE,eAAe,CAAC,aAAa,CAAC;YAqC/B,UAAU;YAiGV,iBAAiB;YAuBjB,WAAW;YAuCX,oBAAoB;IA4C5B,cAAc,CAClB,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,yBAAyB,EAChC,MAAM,uCAAc,GACnB,OAAO,CAAC,IAAI,CAAC;CAiDjB"}
|
|
@@ -1,21 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
class ContractVerifier {
|
|
1
|
+
import fetch from 'cross-fetch';
|
|
2
|
+
import { ethers } from 'ethers';
|
|
3
|
+
import { rootLogger, sleep, strip0x } from '@hyperlane-xyz/utils';
|
|
4
|
+
import { ExplorerFamily } from '../../metadata/chainMetadataTypes.js';
|
|
5
|
+
import { EXPLORER_GET_ACTIONS, ExplorerApiActions, ExplorerApiErrors, } from './types.js';
|
|
6
|
+
export class ContractVerifier {
|
|
7
|
+
multiProvider;
|
|
8
|
+
apiKeys;
|
|
9
|
+
logger = rootLogger.child({ module: 'ContractVerifier' });
|
|
10
|
+
contractSourceMap = {};
|
|
11
|
+
standardInputJson;
|
|
12
|
+
compilerOptions;
|
|
14
13
|
constructor(multiProvider, apiKeys, buildArtifact, licenseType) {
|
|
15
14
|
this.multiProvider = multiProvider;
|
|
16
15
|
this.apiKeys = apiKeys;
|
|
17
|
-
this.logger = (0, debug_1.debug)(`hyperlane:ContractVerifier`);
|
|
18
|
-
this.contractSourceMap = {};
|
|
19
16
|
// Extract the standard input json and compiler version from the build artifact
|
|
20
17
|
this.standardInputJson = JSON.stringify(buildArtifact.input);
|
|
21
18
|
const compilerversion = `v${buildArtifact.solcLongVersion}`;
|
|
@@ -46,7 +43,7 @@ class ContractVerifier {
|
|
|
46
43
|
});
|
|
47
44
|
}
|
|
48
45
|
async submitForm(chain, action, verificationLogger, options) {
|
|
49
|
-
const { apiUrl, family } = this.multiProvider.getExplorerApi(chain);
|
|
46
|
+
const { apiUrl, family, apiKey = this.apiKeys[chain], } = this.multiProvider.getExplorerApi(chain);
|
|
50
47
|
const params = new URLSearchParams();
|
|
51
48
|
params.set('module', 'contract');
|
|
52
49
|
params.set('action', action);
|
|
@@ -55,27 +52,27 @@ class ContractVerifier {
|
|
|
55
52
|
params.set(key, value);
|
|
56
53
|
}
|
|
57
54
|
// only include apikey if provided & not blockscout
|
|
58
|
-
if (family !==
|
|
59
|
-
params.set('apikey',
|
|
55
|
+
if (family !== ExplorerFamily.Blockscout && apiKey) {
|
|
56
|
+
params.set('apikey', apiKey);
|
|
60
57
|
}
|
|
61
58
|
const url = new URL(apiUrl);
|
|
62
|
-
const isGetRequest =
|
|
59
|
+
const isGetRequest = EXPLORER_GET_ACTIONS.includes(action);
|
|
63
60
|
if (isGetRequest) {
|
|
64
61
|
url.search = params.toString();
|
|
65
62
|
}
|
|
66
|
-
else if (family ===
|
|
63
|
+
else if (family === ExplorerFamily.Blockscout) {
|
|
67
64
|
// Blockscout requires module and action to be query params
|
|
68
65
|
url.searchParams.set('module', 'contract');
|
|
69
66
|
url.searchParams.set('action', action);
|
|
70
67
|
}
|
|
71
68
|
let response;
|
|
72
69
|
if (isGetRequest) {
|
|
73
|
-
response = await (
|
|
70
|
+
response = await fetch(url.toString(), {
|
|
74
71
|
method: 'GET',
|
|
75
72
|
});
|
|
76
73
|
}
|
|
77
74
|
else {
|
|
78
|
-
response = await (
|
|
75
|
+
response = await fetch(url.toString(), {
|
|
79
76
|
method: 'POST',
|
|
80
77
|
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
|
|
81
78
|
body: params,
|
|
@@ -86,16 +83,16 @@ class ContractVerifier {
|
|
|
86
83
|
if (result.message !== 'OK') {
|
|
87
84
|
let errorMessage;
|
|
88
85
|
switch (result.result) {
|
|
89
|
-
case
|
|
90
|
-
await
|
|
86
|
+
case ExplorerApiErrors.VERIFICATION_PENDING:
|
|
87
|
+
await sleep(5000); // wait 5 seconds
|
|
91
88
|
return this.submitForm(chain, action, verificationLogger, options);
|
|
92
|
-
case
|
|
93
|
-
case
|
|
89
|
+
case ExplorerApiErrors.ALREADY_VERIFIED:
|
|
90
|
+
case ExplorerApiErrors.ALREADY_VERIFIED_ALT:
|
|
94
91
|
return;
|
|
95
|
-
case
|
|
92
|
+
case ExplorerApiErrors.PROXY_FAILED:
|
|
96
93
|
errorMessage = 'Proxy verification failed, try manually?';
|
|
97
94
|
break;
|
|
98
|
-
case
|
|
95
|
+
case ExplorerApiErrors.BYTECODE_MISMATCH:
|
|
99
96
|
errorMessage =
|
|
100
97
|
'Compiled bytecode does not match deployed bytecode, check constructor arguments?';
|
|
101
98
|
break;
|
|
@@ -104,30 +101,30 @@ class ContractVerifier {
|
|
|
104
101
|
break;
|
|
105
102
|
}
|
|
106
103
|
if (errorMessage) {
|
|
107
|
-
verificationLogger(errorMessage);
|
|
104
|
+
verificationLogger.debug(errorMessage);
|
|
108
105
|
throw new Error(`[${chain}] ${errorMessage}`);
|
|
109
106
|
}
|
|
110
107
|
}
|
|
111
|
-
if (result.result ===
|
|
112
|
-
await
|
|
108
|
+
if (result.result === ExplorerApiErrors.UNKNOWN_UID) {
|
|
109
|
+
await sleep(1000); // wait 1 second
|
|
113
110
|
return this.submitForm(chain, action, verificationLogger, options);
|
|
114
111
|
}
|
|
115
|
-
if (result.result ===
|
|
112
|
+
if (result.result === ExplorerApiErrors.UNABLE_TO_VERIFY) {
|
|
116
113
|
const errorMessage = `Verification failed. ${result.result ?? response.statusText}`;
|
|
117
|
-
verificationLogger(errorMessage);
|
|
114
|
+
verificationLogger.debug(errorMessage);
|
|
118
115
|
throw new Error(`[${chain}] ${errorMessage}`);
|
|
119
116
|
}
|
|
120
117
|
return result.result;
|
|
121
118
|
}
|
|
122
119
|
async isAlreadyVerified(chain, input, verificationLogger) {
|
|
123
120
|
try {
|
|
124
|
-
const result = await this.submitForm(chain,
|
|
121
|
+
const result = await this.submitForm(chain, ExplorerApiActions.GETSOURCECODE, verificationLogger, {
|
|
125
122
|
address: input.address,
|
|
126
123
|
});
|
|
127
124
|
return !!result[0]?.SourceCode;
|
|
128
125
|
}
|
|
129
126
|
catch (error) {
|
|
130
|
-
verificationLogger(`Error checking if contract is already verified: ${error}`);
|
|
127
|
+
verificationLogger.debug(`Error checking if contract is already verified: ${error}`);
|
|
131
128
|
return false;
|
|
132
129
|
}
|
|
133
130
|
}
|
|
@@ -135,26 +132,26 @@ class ContractVerifier {
|
|
|
135
132
|
if (!input.isProxy)
|
|
136
133
|
return;
|
|
137
134
|
try {
|
|
138
|
-
const proxyGuid = await this.submitForm(chain,
|
|
135
|
+
const proxyGuid = await this.submitForm(chain, ExplorerApiActions.MARK_PROXY, verificationLogger, { address: input.address });
|
|
139
136
|
if (!proxyGuid)
|
|
140
137
|
return;
|
|
141
|
-
await this.submitForm(chain,
|
|
138
|
+
await this.submitForm(chain, ExplorerApiActions.CHECK_PROXY_STATUS, verificationLogger, {
|
|
142
139
|
guid: proxyGuid,
|
|
143
140
|
});
|
|
144
141
|
const addressUrl = await this.multiProvider.tryGetExplorerAddressUrl(chain, input.address);
|
|
145
|
-
verificationLogger(`Successfully verified proxy ${addressUrl}#readProxyContract`);
|
|
142
|
+
verificationLogger.debug(`Successfully verified proxy ${addressUrl}#readProxyContract`);
|
|
146
143
|
}
|
|
147
144
|
catch (error) {
|
|
148
|
-
verificationLogger(`Verification of proxy at ${input.address} failed: ${error}`);
|
|
145
|
+
verificationLogger.debug(`Verification of proxy at ${input.address} failed: ${error}`);
|
|
149
146
|
throw error;
|
|
150
147
|
}
|
|
151
148
|
}
|
|
152
149
|
async verifyImplementation(chain, input, verificationLogger) {
|
|
153
|
-
verificationLogger(`Verifying implementation at ${input.address}`);
|
|
150
|
+
verificationLogger.debug(`Verifying implementation at ${input.address}`);
|
|
154
151
|
const sourceName = this.contractSourceMap[input.name];
|
|
155
152
|
if (!sourceName) {
|
|
156
153
|
const errorMessage = `Contract '${input.name}' not found in provided build artifact`;
|
|
157
|
-
verificationLogger(errorMessage);
|
|
154
|
+
verificationLogger.error(errorMessage);
|
|
158
155
|
throw new Error(`[${chain}] ${errorMessage}`);
|
|
159
156
|
}
|
|
160
157
|
const data = {
|
|
@@ -162,52 +159,51 @@ class ContractVerifier {
|
|
|
162
159
|
contractname: `${sourceName}:${input.name}`,
|
|
163
160
|
contractaddress: input.address,
|
|
164
161
|
// TYPO IS ENFORCED BY API
|
|
165
|
-
constructorArguements:
|
|
162
|
+
constructorArguements: strip0x(input.constructorArguments ?? ''),
|
|
166
163
|
...this.compilerOptions,
|
|
167
164
|
};
|
|
168
|
-
const guid = await this.submitForm(chain,
|
|
165
|
+
const guid = await this.submitForm(chain, ExplorerApiActions.VERIFY_IMPLEMENTATION, verificationLogger, data);
|
|
169
166
|
if (!guid)
|
|
170
167
|
return;
|
|
171
|
-
await this.submitForm(chain,
|
|
168
|
+
await this.submitForm(chain, ExplorerApiActions.CHECK_STATUS, verificationLogger, { guid });
|
|
172
169
|
const addressUrl = await this.multiProvider.tryGetExplorerAddressUrl(chain, input.address);
|
|
173
|
-
verificationLogger(`Successfully verified ${addressUrl}#code`);
|
|
170
|
+
verificationLogger.debug(`Successfully verified ${addressUrl}#code`);
|
|
174
171
|
}
|
|
175
172
|
async verifyContract(chain, input, logger = this.logger) {
|
|
176
|
-
const verificationLogger = logger.
|
|
173
|
+
const verificationLogger = logger.child({ chain, name: input.name });
|
|
177
174
|
const metadata = this.multiProvider.tryGetChainMetadata(chain);
|
|
178
175
|
const rpcUrl = metadata?.rpcUrls[0].http ?? '';
|
|
179
176
|
if (rpcUrl.includes('localhost') || rpcUrl.includes('127.0.0.1')) {
|
|
180
|
-
verificationLogger('Skipping verification for local endpoints');
|
|
177
|
+
verificationLogger.debug('Skipping verification for local endpoints');
|
|
181
178
|
return;
|
|
182
179
|
}
|
|
183
180
|
const explorerApi = this.multiProvider.tryGetExplorerApi(chain);
|
|
184
181
|
if (!explorerApi) {
|
|
185
|
-
verificationLogger('No explorer API set, skipping');
|
|
182
|
+
verificationLogger.debug('No explorer API set, skipping');
|
|
186
183
|
return;
|
|
187
184
|
}
|
|
188
185
|
if (!explorerApi.family) {
|
|
189
|
-
verificationLogger(`No explorer family set, skipping`);
|
|
186
|
+
verificationLogger.debug(`No explorer family set, skipping`);
|
|
190
187
|
return;
|
|
191
188
|
}
|
|
192
|
-
if (explorerApi.family ===
|
|
193
|
-
verificationLogger(`Unsupported explorer family, skipping`);
|
|
189
|
+
if (explorerApi.family === ExplorerFamily.Other) {
|
|
190
|
+
verificationLogger.debug(`Unsupported explorer family, skipping`);
|
|
194
191
|
return;
|
|
195
192
|
}
|
|
196
|
-
if (input.address ===
|
|
193
|
+
if (input.address === ethers.constants.AddressZero)
|
|
197
194
|
return;
|
|
198
195
|
if (Array.isArray(input.constructorArguments)) {
|
|
199
|
-
verificationLogger('Constructor arguments in legacy format, skipping');
|
|
196
|
+
verificationLogger.debug('Constructor arguments in legacy format, skipping');
|
|
200
197
|
return;
|
|
201
198
|
}
|
|
202
199
|
if (await this.isAlreadyVerified(chain, input, verificationLogger)) {
|
|
203
200
|
const addressUrl = await this.multiProvider.tryGetExplorerAddressUrl(chain, input.address);
|
|
204
|
-
verificationLogger(`Contract already verified at ${addressUrl}#code`);
|
|
205
|
-
await
|
|
201
|
+
verificationLogger.debug(`Contract already verified at ${addressUrl}#code`);
|
|
202
|
+
await sleep(200); // There is a rate limit of 5 requests per second
|
|
206
203
|
return;
|
|
207
204
|
}
|
|
208
205
|
await this.verifyImplementation(chain, input, verificationLogger);
|
|
209
206
|
await this.verifyProxy(chain, input, verificationLogger);
|
|
210
207
|
}
|
|
211
208
|
}
|
|
212
|
-
exports.ContractVerifier = ContractVerifier;
|
|
213
209
|
//# sourceMappingURL=ContractVerifier.js.map
|