@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,43 +1,43 @@
|
|
|
1
1
|
import { DomainRoutingHook, OPStackHook, ProtocolFee } from '@hyperlane-xyz/core';
|
|
2
|
-
import { HyperlaneContracts } from '../contracts/types';
|
|
3
|
-
import { CoreAddresses } from '../core/contracts';
|
|
4
|
-
import { HyperlaneDeployer } from '../deploy/HyperlaneDeployer';
|
|
5
|
-
import { ContractVerifier } from '../deploy/verify/ContractVerifier';
|
|
6
|
-
import { HyperlaneIgpDeployer } from '../gas/HyperlaneIgpDeployer';
|
|
7
|
-
import { IgpFactories } from '../gas/contracts';
|
|
8
|
-
import { HyperlaneIsmFactory } from '../ism/HyperlaneIsmFactory';
|
|
9
|
-
import { MultiProvider } from '../providers/MultiProvider';
|
|
10
|
-
import { ChainMap, ChainName } from '../types';
|
|
11
|
-
import { HookFactories } from './contracts';
|
|
12
|
-
import { AggregationHookConfig, DomainRoutingHookConfig, FallbackRoutingHookConfig, HookConfig, IgpHookConfig, OpStackHookConfig, ProtocolFeeHookConfig } from './types';
|
|
2
|
+
import { HyperlaneContracts } from '../contracts/types.js';
|
|
3
|
+
import { CoreAddresses } from '../core/contracts.js';
|
|
4
|
+
import { HyperlaneDeployer } from '../deploy/HyperlaneDeployer.js';
|
|
5
|
+
import { ContractVerifier } from '../deploy/verify/ContractVerifier.js';
|
|
6
|
+
import { HyperlaneIgpDeployer } from '../gas/HyperlaneIgpDeployer.js';
|
|
7
|
+
import { IgpFactories } from '../gas/contracts.js';
|
|
8
|
+
import { HyperlaneIsmFactory } from '../ism/HyperlaneIsmFactory.js';
|
|
9
|
+
import { MultiProvider } from '../providers/MultiProvider.js';
|
|
10
|
+
import { ChainMap, ChainName } from '../types.js';
|
|
11
|
+
import { HookFactories } from './contracts.js';
|
|
12
|
+
import { AggregationHookConfig, DomainRoutingHookConfig, FallbackRoutingHookConfig, HookConfig, IgpHookConfig, OpStackHookConfig, ProtocolFeeHookConfig } from './types.js';
|
|
13
13
|
export declare class HyperlaneHookDeployer extends HyperlaneDeployer<HookConfig, HookFactories> {
|
|
14
14
|
readonly core: ChainMap<Partial<CoreAddresses>>;
|
|
15
15
|
readonly ismFactory: HyperlaneIsmFactory;
|
|
16
16
|
readonly igpDeployer: HyperlaneIgpDeployer;
|
|
17
17
|
constructor(multiProvider: MultiProvider, core: ChainMap<Partial<CoreAddresses>>, ismFactory: HyperlaneIsmFactory, contractVerifier?: ContractVerifier, igpDeployer?: HyperlaneIgpDeployer);
|
|
18
18
|
cacheAddressesMap(addressesMap: ChainMap<CoreAddresses>): void;
|
|
19
|
-
deployContracts(chain: ChainName, config: HookConfig, coreAddresses?: Partial<import("../contracts/types").HyperlaneAddresses<{
|
|
19
|
+
deployContracts(chain: ChainName, config: HookConfig, coreAddresses?: Partial<import("../contracts/types.js").HyperlaneAddresses<{
|
|
20
20
|
validatorAnnounce: import("@hyperlane-xyz/core").ValidatorAnnounce__factory;
|
|
21
21
|
proxyAdmin: import("@hyperlane-xyz/core").ProxyAdmin__factory;
|
|
22
22
|
mailbox: import("@hyperlane-xyz/core").Mailbox__factory;
|
|
23
23
|
}>>): Promise<HyperlaneContracts<HookFactories>>;
|
|
24
24
|
deployProtocolFee(chain: ChainName, config: ProtocolFeeHookConfig): Promise<ProtocolFee>;
|
|
25
|
-
deployIgp(chain: ChainName, config: IgpHookConfig, coreAddresses?: Partial<import("../contracts/types").HyperlaneAddresses<{
|
|
25
|
+
deployIgp(chain: ChainName, config: IgpHookConfig, coreAddresses?: Partial<import("../contracts/types.js").HyperlaneAddresses<{
|
|
26
26
|
validatorAnnounce: import("@hyperlane-xyz/core").ValidatorAnnounce__factory;
|
|
27
27
|
proxyAdmin: import("@hyperlane-xyz/core").ProxyAdmin__factory;
|
|
28
28
|
mailbox: import("@hyperlane-xyz/core").Mailbox__factory;
|
|
29
29
|
}>>): Promise<HyperlaneContracts<IgpFactories>>;
|
|
30
|
-
deployAggregation(chain: ChainName, config: AggregationHookConfig, coreAddresses?: Partial<import("../contracts/types").HyperlaneAddresses<{
|
|
30
|
+
deployAggregation(chain: ChainName, config: AggregationHookConfig, coreAddresses?: Partial<import("../contracts/types.js").HyperlaneAddresses<{
|
|
31
31
|
validatorAnnounce: import("@hyperlane-xyz/core").ValidatorAnnounce__factory;
|
|
32
32
|
proxyAdmin: import("@hyperlane-xyz/core").ProxyAdmin__factory;
|
|
33
33
|
mailbox: import("@hyperlane-xyz/core").Mailbox__factory;
|
|
34
34
|
}>>): Promise<HyperlaneContracts<HookFactories>>;
|
|
35
|
-
deployOpStack(chain: ChainName, config: OpStackHookConfig, coreAddresses?: Partial<import("../contracts/types").HyperlaneAddresses<{
|
|
35
|
+
deployOpStack(chain: ChainName, config: OpStackHookConfig, coreAddresses?: Partial<import("../contracts/types.js").HyperlaneAddresses<{
|
|
36
36
|
validatorAnnounce: import("@hyperlane-xyz/core").ValidatorAnnounce__factory;
|
|
37
37
|
proxyAdmin: import("@hyperlane-xyz/core").ProxyAdmin__factory;
|
|
38
38
|
mailbox: import("@hyperlane-xyz/core").Mailbox__factory;
|
|
39
39
|
}>>): Promise<OPStackHook>;
|
|
40
|
-
deployRouting(chain: ChainName, config: DomainRoutingHookConfig | FallbackRoutingHookConfig, coreAddresses?: Partial<import("../contracts/types").HyperlaneAddresses<{
|
|
40
|
+
deployRouting(chain: ChainName, config: DomainRoutingHookConfig | FallbackRoutingHookConfig, coreAddresses?: Partial<import("../contracts/types.js").HyperlaneAddresses<{
|
|
41
41
|
validatorAnnounce: import("@hyperlane-xyz/core").ValidatorAnnounce__factory;
|
|
42
42
|
proxyAdmin: import("@hyperlane-xyz/core").ProxyAdmin__factory;
|
|
43
43
|
mailbox: import("@hyperlane-xyz/core").Mailbox__factory;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneHookDeployer.d.ts","sourceRoot":"","sources":["../../src/hook/HyperlaneHookDeployer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"HyperlaneHookDeployer.d.ts","sourceRoot":"","sources":["../../src/hook/HyperlaneHookDeployer.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,iBAAiB,EAGjB,WAAW,EAEX,WAAW,EAEZ,MAAM,qBAAqB,CAAC;AAI7B,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AACtE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAEpE,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAElD,OAAO,EAAgB,aAAa,EAAiB,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EACL,qBAAqB,EACrB,uBAAuB,EACvB,yBAAyB,EACzB,UAAU,EAEV,aAAa,EACb,iBAAiB,EACjB,qBAAqB,EACtB,MAAM,YAAY,CAAC;AAEpB,qBAAa,qBAAsB,SAAQ,iBAAiB,CAC1D,UAAU,EACV,aAAa,CACd;IAGG,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IAC/C,QAAQ,CAAC,UAAU,EAAE,mBAAmB;IAExC,QAAQ,CAAC,WAAW;gBAJpB,aAAa,EAAE,aAAa,EACnB,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,EACtC,UAAU,EAAE,mBAAmB,EACxC,gBAAgB,CAAC,EAAE,gBAAgB,EAC1B,WAAW,uBAGnB;IAQH,iBAAiB,CAAC,YAAY,EAAE,QAAQ,CAAC,aAAa,CAAC,GAAG,IAAI;IAKxD,eAAe,CACnB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,UAAU,EAClB,aAAa;;;;OAAmB,GAC/B,OAAO,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC;IA2CvC,iBAAiB,CACrB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,qBAAqB,GAC5B,OAAO,CAAC,WAAW,CAAC;IAUjB,SAAS,CACb,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,aAAa,EACrB,aAAa;;;;OAAmB,GAC/B,OAAO,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;IAmBtC,iBAAiB,CACrB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,qBAAqB,EAC7B,aAAa;;;;OAAmB,GAC/B,OAAO,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC;IA8BvC,aAAa,CACjB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,iBAAiB,EACzB,aAAa;;;;OAAmB,GAC/B,OAAO,CAAC,WAAW,CAAC;IAqEjB,aAAa,CACjB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,uBAAuB,GAAG,yBAAyB,EAC3D,aAAa;;;;OAAmB,GAC/B,OAAO,CAAC,iBAAiB,CAAC;CA0E9B"}
|
|
@@ -1,23 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
18
|
-
constructor(multiProvider, core, ismFactory, contractVerifier, igpDeployer = new HyperlaneIgpDeployer_1.HyperlaneIgpDeployer(multiProvider, contractVerifier)) {
|
|
19
|
-
super(multiProvider, contracts_1.hookFactories, {
|
|
20
|
-
logger: (0, debug_1.default)('hyperlane:HookDeployer'),
|
|
1
|
+
import { ethers } from 'ethers';
|
|
2
|
+
import { IL1CrossDomainMessenger__factory, StaticAggregationHook__factory, } from '@hyperlane-xyz/core';
|
|
3
|
+
import { addressToBytes32, rootLogger } from '@hyperlane-xyz/utils';
|
|
4
|
+
import { chainMetadata } from '../consts/chainMetadata.js';
|
|
5
|
+
import { HyperlaneDeployer } from '../deploy/HyperlaneDeployer.js';
|
|
6
|
+
import { HyperlaneIgpDeployer } from '../gas/HyperlaneIgpDeployer.js';
|
|
7
|
+
import { IsmType } from '../ism/types.js';
|
|
8
|
+
import { hookFactories } from './contracts.js';
|
|
9
|
+
import { HookType, } from './types.js';
|
|
10
|
+
export class HyperlaneHookDeployer extends HyperlaneDeployer {
|
|
11
|
+
core;
|
|
12
|
+
ismFactory;
|
|
13
|
+
igpDeployer;
|
|
14
|
+
constructor(multiProvider, core, ismFactory, contractVerifier, igpDeployer = new HyperlaneIgpDeployer(multiProvider, contractVerifier)) {
|
|
15
|
+
super(multiProvider, hookFactories, {
|
|
16
|
+
logger: rootLogger.child({ module: 'HookDeployer' }),
|
|
21
17
|
contractVerifier,
|
|
22
18
|
});
|
|
23
19
|
this.core = core;
|
|
@@ -30,34 +26,34 @@ class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
30
26
|
}
|
|
31
27
|
async deployContracts(chain, config, coreAddresses = this.core[chain]) {
|
|
32
28
|
let hook;
|
|
33
|
-
if (config.type ===
|
|
29
|
+
if (config.type === HookType.MERKLE_TREE) {
|
|
34
30
|
const mailbox = coreAddresses.mailbox;
|
|
35
31
|
if (!mailbox) {
|
|
36
32
|
throw new Error(`Mailbox address is required for ${config.type}`);
|
|
37
33
|
}
|
|
38
34
|
hook = await this.deployContract(chain, config.type, [mailbox]);
|
|
39
35
|
}
|
|
40
|
-
else if (config.type ===
|
|
36
|
+
else if (config.type === HookType.INTERCHAIN_GAS_PAYMASTER) {
|
|
41
37
|
const { interchainGasPaymaster } = await this.deployIgp(chain, config, coreAddresses);
|
|
42
38
|
hook = interchainGasPaymaster;
|
|
43
39
|
}
|
|
44
|
-
else if (config.type ===
|
|
40
|
+
else if (config.type === HookType.AGGREGATION) {
|
|
45
41
|
hook = (await this.deployAggregation(chain, config, coreAddresses))
|
|
46
42
|
.aggregationHook; // deploy from factory
|
|
47
43
|
}
|
|
48
|
-
else if (config.type ===
|
|
44
|
+
else if (config.type === HookType.PROTOCOL_FEE) {
|
|
49
45
|
hook = await this.deployProtocolFee(chain, config);
|
|
50
46
|
}
|
|
51
|
-
else if (config.type ===
|
|
47
|
+
else if (config.type === HookType.OP_STACK) {
|
|
52
48
|
hook = await this.deployOpStack(chain, config, coreAddresses);
|
|
53
49
|
}
|
|
54
|
-
else if (config.type ===
|
|
55
|
-
config.type ===
|
|
50
|
+
else if (config.type === HookType.ROUTING ||
|
|
51
|
+
config.type === HookType.FALLBACK_ROUTING) {
|
|
56
52
|
hook = await this.deployRouting(chain, config, coreAddresses);
|
|
57
53
|
}
|
|
58
|
-
else if (config.type ===
|
|
54
|
+
else if (config.type === HookType.PAUSABLE) {
|
|
59
55
|
hook = await this.deployContract(chain, config.type, []);
|
|
60
|
-
await this.transferOwnershipOfContracts(chain, config, { [
|
|
56
|
+
await this.transferOwnershipOfContracts(chain, config, { [HookType.PAUSABLE]: hook });
|
|
61
57
|
}
|
|
62
58
|
else {
|
|
63
59
|
throw new Error(`Unsupported hook config: ${config}`);
|
|
@@ -67,16 +63,16 @@ class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
67
63
|
return deployedContracts;
|
|
68
64
|
}
|
|
69
65
|
async deployProtocolFee(chain, config) {
|
|
70
|
-
this.logger('Deploying ProtocolFeeHook for %s', chain);
|
|
71
|
-
return this.deployContract(chain,
|
|
66
|
+
this.logger.debug('Deploying ProtocolFeeHook for %s', chain);
|
|
67
|
+
return this.deployContract(chain, HookType.PROTOCOL_FEE, [
|
|
72
68
|
config.maxProtocolFee,
|
|
73
69
|
config.protocolFee,
|
|
74
70
|
config.beneficiary,
|
|
75
|
-
config.owner,
|
|
71
|
+
await this.resolveInterchainAccountAsOwner(chain, config.owner),
|
|
76
72
|
]);
|
|
77
73
|
}
|
|
78
74
|
async deployIgp(chain, config, coreAddresses = this.core[chain]) {
|
|
79
|
-
this.logger('Deploying IGP as hook for %s', chain);
|
|
75
|
+
this.logger.debug('Deploying IGP as hook for %s', chain);
|
|
80
76
|
if (coreAddresses.proxyAdmin) {
|
|
81
77
|
this.igpDeployer.writeCache(chain, 'proxyAdmin', coreAddresses.proxyAdmin);
|
|
82
78
|
}
|
|
@@ -86,7 +82,7 @@ class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
86
82
|
return igpContracts;
|
|
87
83
|
}
|
|
88
84
|
async deployAggregation(chain, config, coreAddresses = this.core[chain]) {
|
|
89
|
-
this.logger('Deploying AggregationHook for %s', chain);
|
|
85
|
+
this.logger.debug('Deploying AggregationHook for %s', chain);
|
|
90
86
|
const aggregatedHooks = [];
|
|
91
87
|
let hooks = {};
|
|
92
88
|
for (const hookConfig of config.hooks) {
|
|
@@ -94,24 +90,24 @@ class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
94
90
|
aggregatedHooks.push(subhooks[hookConfig.type].address);
|
|
95
91
|
hooks = { ...hooks, ...subhooks };
|
|
96
92
|
}
|
|
97
|
-
this.logger(`Deploying aggregation hook of ${config.hooks.map((h) => h.type)}`);
|
|
93
|
+
this.logger.debug(`Deploying aggregation hook of ${config.hooks.map((h) => h.type)}`);
|
|
98
94
|
const address = await this.ismFactory.deployStaticAddressSet(chain, this.ismFactory.getContracts(chain).staticAggregationHookFactory, aggregatedHooks, this.logger);
|
|
99
|
-
hooks[
|
|
95
|
+
hooks[HookType.AGGREGATION] = StaticAggregationHook__factory.connect(address, this.multiProvider.getSignerOrProvider(chain));
|
|
100
96
|
this.addDeployedContracts(chain, hooks);
|
|
101
97
|
return hooks;
|
|
102
98
|
}
|
|
103
99
|
async deployOpStack(chain, config, coreAddresses = this.core[chain]) {
|
|
104
|
-
this.logger('Deploying OPStackHook for %s to %s', chain, config.destinationChain);
|
|
100
|
+
this.logger.debug('Deploying OPStackHook for %s to %s', chain, config.destinationChain);
|
|
105
101
|
const mailbox = coreAddresses.mailbox;
|
|
106
102
|
if (!mailbox) {
|
|
107
103
|
throw new Error(`Mailbox address is required for ${config.type}`);
|
|
108
104
|
}
|
|
109
105
|
// fetch l2 messenger address from l1 messenger
|
|
110
|
-
const l1Messenger =
|
|
106
|
+
const l1Messenger = IL1CrossDomainMessenger__factory.connect(config.nativeBridge, this.multiProvider.getSignerOrProvider(chain));
|
|
111
107
|
const l2Messenger = await l1Messenger.OTHER_MESSENGER();
|
|
112
108
|
// deploy opstack ism
|
|
113
109
|
const ismConfig = {
|
|
114
|
-
type:
|
|
110
|
+
type: IsmType.OP_STACK,
|
|
115
111
|
origin: chain,
|
|
116
112
|
nativeBridge: l2Messenger,
|
|
117
113
|
};
|
|
@@ -121,26 +117,26 @@ class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
121
117
|
origin: chain,
|
|
122
118
|
}));
|
|
123
119
|
// deploy opstack hook
|
|
124
|
-
const hook = await this.deployContract(chain,
|
|
120
|
+
const hook = await this.deployContract(chain, HookType.OP_STACK, [
|
|
125
121
|
mailbox,
|
|
126
122
|
this.multiProvider.getDomainId(config.destinationChain),
|
|
127
|
-
|
|
123
|
+
addressToBytes32(opstackIsm.address),
|
|
128
124
|
config.nativeBridge,
|
|
129
125
|
]);
|
|
130
126
|
const overrides = this.multiProvider.getTransactionOverrides(chain);
|
|
131
127
|
// set authorized hook on opstack ism
|
|
132
128
|
const authorizedHook = await opstackIsm.authorizedHook();
|
|
133
|
-
if (authorizedHook ===
|
|
134
|
-
this.logger('Authorized hook already set on ism %s', opstackIsm.address);
|
|
129
|
+
if (authorizedHook === addressToBytes32(hook.address)) {
|
|
130
|
+
this.logger.debug('Authorized hook already set on ism %s', opstackIsm.address);
|
|
135
131
|
return hook;
|
|
136
132
|
}
|
|
137
|
-
else if (authorizedHook !==
|
|
138
|
-
this.logger('Authorized hook mismatch on ism %s, expected %s, got %s', opstackIsm.address,
|
|
133
|
+
else if (authorizedHook !== addressToBytes32(ethers.constants.AddressZero)) {
|
|
134
|
+
this.logger.debug('Authorized hook mismatch on ism %s, expected %s, got %s', opstackIsm.address, addressToBytes32(hook.address), authorizedHook);
|
|
139
135
|
throw new Error('Authorized hook mismatch');
|
|
140
136
|
}
|
|
141
137
|
// check if mismatch and redeploy hook
|
|
142
|
-
this.logger('Setting authorized hook %s on ism % on destination %s', hook.address, opstackIsm.address, config.destinationChain);
|
|
143
|
-
await this.multiProvider.handleTx(config.destinationChain, opstackIsm.setAuthorizedHook(
|
|
138
|
+
this.logger.debug('Setting authorized hook %s on ism % on destination %s', hook.address, opstackIsm.address, config.destinationChain);
|
|
139
|
+
await this.multiProvider.handleTx(config.destinationChain, opstackIsm.setAuthorizedHook(addressToBytes32(hook.address), overrides));
|
|
144
140
|
return hook;
|
|
145
141
|
}
|
|
146
142
|
async deployRouting(chain, config, coreAddresses = this.core[chain]) {
|
|
@@ -148,21 +144,23 @@ class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
148
144
|
if (!mailbox) {
|
|
149
145
|
throw new Error(`Mailbox address is required for ${config.type}`);
|
|
150
146
|
}
|
|
147
|
+
// we don't config owner as config.owner because there're post-deploy steps like
|
|
148
|
+
// enrolling routing hooks which need ownership, and therefore we transferOwnership at the end
|
|
151
149
|
const deployer = await this.multiProvider.getSigner(chain).getAddress();
|
|
152
150
|
let routingHook;
|
|
153
151
|
switch (config.type) {
|
|
154
|
-
case
|
|
155
|
-
this.logger('Deploying DomainRoutingHook for %s', chain);
|
|
156
|
-
routingHook = await this.deployContract(chain,
|
|
152
|
+
case HookType.ROUTING: {
|
|
153
|
+
this.logger.debug('Deploying DomainRoutingHook for %s', chain);
|
|
154
|
+
routingHook = await this.deployContract(chain, HookType.ROUTING, [
|
|
157
155
|
mailbox,
|
|
158
156
|
deployer,
|
|
159
157
|
]);
|
|
160
158
|
break;
|
|
161
159
|
}
|
|
162
|
-
case
|
|
163
|
-
this.logger('Deploying FallbackDomainRoutingHook for %s', chain);
|
|
160
|
+
case HookType.FALLBACK_ROUTING: {
|
|
161
|
+
this.logger.debug('Deploying FallbackDomainRoutingHook for %s', chain);
|
|
164
162
|
const fallbackHook = await this.deployContracts(chain, config.fallback, coreAddresses);
|
|
165
|
-
routingHook = await this.deployContract(chain,
|
|
163
|
+
routingHook = await this.deployContract(chain, HookType.FALLBACK_ROUTING, [mailbox, deployer, fallbackHook[config.fallback.type].address]);
|
|
166
164
|
break;
|
|
167
165
|
}
|
|
168
166
|
default:
|
|
@@ -170,7 +168,7 @@ class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
170
168
|
}
|
|
171
169
|
const routingConfigs = [];
|
|
172
170
|
for (const [dest, hookConfig] of Object.entries(config.domains)) {
|
|
173
|
-
const destDomain =
|
|
171
|
+
const destDomain = chainMetadata[dest]?.domainId ?? this.multiProvider.getDomainId(dest);
|
|
174
172
|
if (typeof hookConfig === 'string') {
|
|
175
173
|
routingConfigs.push({
|
|
176
174
|
destination: destDomain,
|
|
@@ -193,5 +191,4 @@ class HyperlaneHookDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
193
191
|
return routingHook;
|
|
194
192
|
}
|
|
195
193
|
}
|
|
196
|
-
exports.HyperlaneHookDeployer = HyperlaneHookDeployer;
|
|
197
194
|
//# sourceMappingURL=HyperlaneHookDeployer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneHookDeployer.js","sourceRoot":"","sources":["../../src/hook/HyperlaneHookDeployer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"HyperlaneHookDeployer.js","sourceRoot":"","sources":["../../src/hook/HyperlaneHookDeployer.ts"],"names":[],"mappings":"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"}
|
package/dist/hook/contracts.js
CHANGED
|
@@ -1,16 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
[
|
|
8
|
-
[
|
|
9
|
-
[
|
|
10
|
-
[
|
|
11
|
-
[
|
|
12
|
-
[types_1.HookType.ROUTING]: new core_1.DomainRoutingHook__factory(),
|
|
13
|
-
[types_1.HookType.FALLBACK_ROUTING]: new core_1.FallbackDomainRoutingHook__factory(),
|
|
14
|
-
[types_1.HookType.PAUSABLE]: new core_1.PausableHook__factory(),
|
|
1
|
+
import { DomainRoutingHook__factory, FallbackDomainRoutingHook__factory, InterchainGasPaymaster__factory, MerkleTreeHook__factory, OPStackHook__factory, PausableHook__factory, ProtocolFee__factory, StaticAggregationHook__factory, } from '@hyperlane-xyz/core';
|
|
2
|
+
import { HookType } from './types.js';
|
|
3
|
+
export const hookFactories = {
|
|
4
|
+
[HookType.MERKLE_TREE]: new MerkleTreeHook__factory(),
|
|
5
|
+
[HookType.PROTOCOL_FEE]: new ProtocolFee__factory(),
|
|
6
|
+
[HookType.INTERCHAIN_GAS_PAYMASTER]: new InterchainGasPaymaster__factory(), // unused
|
|
7
|
+
[HookType.AGGREGATION]: new StaticAggregationHook__factory(), // unused
|
|
8
|
+
[HookType.OP_STACK]: new OPStackHook__factory(),
|
|
9
|
+
[HookType.ROUTING]: new DomainRoutingHook__factory(),
|
|
10
|
+
[HookType.FALLBACK_ROUTING]: new FallbackDomainRoutingHook__factory(),
|
|
11
|
+
[HookType.PAUSABLE]: new PausableHook__factory(),
|
|
15
12
|
};
|
|
16
13
|
//# sourceMappingURL=contracts.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contracts.js","sourceRoot":"","sources":["../../src/hook/contracts.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"contracts.js","sourceRoot":"","sources":["../../src/hook/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,0BAA0B,EAC1B,kCAAkC,EAClC,+BAA+B,EAC/B,uBAAuB,EACvB,oBAAoB,EACpB,qBAAqB,EACrB,oBAAoB,EACpB,8BAA8B,GAC/B,MAAM,qBAAqB,CAAC;AAG7B,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,IAAI,uBAAuB,EAAE;IACrD,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,IAAI,oBAAoB,EAAE;IACnD,CAAC,QAAQ,CAAC,wBAAwB,CAAC,EAAE,IAAI,+BAA+B,EAAE,EAAE,SAAS;IACrF,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,IAAI,8BAA8B,EAAE,EAAE,SAAS;IACvE,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,IAAI,oBAAoB,EAAE;IAC/C,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,IAAI,0BAA0B,EAAE;IACpD,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,IAAI,kCAAkC,EAAE;IACrE,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,IAAI,qBAAqB,EAAE;CACjD,CAAC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { providers } from 'ethers';
|
|
2
|
+
import { Address, WithAddress } from '@hyperlane-xyz/utils';
|
|
3
|
+
import { MultiProvider } from '../providers/MultiProvider.js';
|
|
4
|
+
import { ChainName } from '../types.js';
|
|
5
|
+
import { AggregationHookConfig, DomainRoutingHookConfig, FallbackRoutingHookConfig, HookConfig, IgpHookConfig, MerkleTreeHookConfig, OpStackHookConfig, PausableHookConfig, ProtocolFeeHookConfig } from './types.js';
|
|
6
|
+
interface HookReader {
|
|
7
|
+
deriveHookConfig(address: Address): Promise<WithAddress<HookConfig>>;
|
|
8
|
+
deriveMerkleTreeConfig(address: Address): Promise<WithAddress<MerkleTreeHookConfig>>;
|
|
9
|
+
deriveAggregationConfig(address: Address): Promise<WithAddress<AggregationHookConfig>>;
|
|
10
|
+
deriveIgpConfig(address: Address): Promise<WithAddress<IgpHookConfig>>;
|
|
11
|
+
deriveProtocolFeeConfig(address: Address): Promise<WithAddress<ProtocolFeeHookConfig>>;
|
|
12
|
+
deriveOpStackConfig(address: Address): Promise<WithAddress<OpStackHookConfig>>;
|
|
13
|
+
deriveDomainRoutingConfig(address: Address): Promise<WithAddress<DomainRoutingHookConfig>>;
|
|
14
|
+
deriveFallbackRoutingConfig(address: Address): Promise<WithAddress<FallbackRoutingHookConfig>>;
|
|
15
|
+
derivePausableConfig(address: Address): Promise<WithAddress<PausableHookConfig>>;
|
|
16
|
+
}
|
|
17
|
+
export declare class EvmHookReader implements HookReader {
|
|
18
|
+
protected readonly multiProvider: MultiProvider;
|
|
19
|
+
protected readonly chain: ChainName;
|
|
20
|
+
protected readonly concurrency: number;
|
|
21
|
+
protected readonly provider: providers.Provider;
|
|
22
|
+
protected readonly logger: import("pino").default.Logger<never>;
|
|
23
|
+
constructor(multiProvider: MultiProvider, chain: ChainName, concurrency?: number);
|
|
24
|
+
deriveHookConfig(address: Address): Promise<WithAddress<HookConfig>>;
|
|
25
|
+
deriveMerkleTreeConfig(address: Address): Promise<WithAddress<MerkleTreeHookConfig>>;
|
|
26
|
+
deriveAggregationConfig(address: Address): Promise<WithAddress<AggregationHookConfig>>;
|
|
27
|
+
deriveIgpConfig(address: Address): Promise<WithAddress<IgpHookConfig>>;
|
|
28
|
+
deriveProtocolFeeConfig(address: Address): Promise<WithAddress<ProtocolFeeHookConfig>>;
|
|
29
|
+
deriveOpStackConfig(address: Address): Promise<WithAddress<OpStackHookConfig>>;
|
|
30
|
+
deriveDomainRoutingConfig(address: Address): Promise<WithAddress<DomainRoutingHookConfig>>;
|
|
31
|
+
deriveFallbackRoutingConfig(address: Address): Promise<WithAddress<FallbackRoutingHookConfig>>;
|
|
32
|
+
private fetchDomainHooks;
|
|
33
|
+
derivePausableConfig(address: Address): Promise<WithAddress<PausableHookConfig>>;
|
|
34
|
+
}
|
|
35
|
+
export {};
|
|
36
|
+
//# sourceMappingURL=read.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"read.d.ts","sourceRoot":"","sources":["../../src/hook/read.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { assert } from 'console';
|
|
2
|
+
import { ethers } from 'ethers';
|
|
3
|
+
import { DomainRoutingHook__factory, FallbackDomainRoutingHook__factory, IPostDispatchHook__factory, InterchainGasPaymaster__factory, MerkleTreeHook__factory, OPStackHook__factory, PausableHook__factory, ProtocolFee__factory, StaticAggregationHook__factory, StorageGasOracle__factory, } from '@hyperlane-xyz/core';
|
|
4
|
+
import { concurrentMap, eqAddress, rootLogger, } from '@hyperlane-xyz/utils';
|
|
5
|
+
import { DEFAULT_CONTRACT_READ_CONCURRENCY } from '../consts/crud.js';
|
|
6
|
+
import { HookType, OnchainHookType, } from './types.js';
|
|
7
|
+
export class EvmHookReader {
|
|
8
|
+
multiProvider;
|
|
9
|
+
chain;
|
|
10
|
+
concurrency;
|
|
11
|
+
provider;
|
|
12
|
+
logger = rootLogger.child({ module: 'EvmHookReader' });
|
|
13
|
+
constructor(multiProvider, chain, concurrency = DEFAULT_CONTRACT_READ_CONCURRENCY) {
|
|
14
|
+
this.multiProvider = multiProvider;
|
|
15
|
+
this.chain = chain;
|
|
16
|
+
this.concurrency = concurrency;
|
|
17
|
+
this.provider = this.multiProvider.getProvider(chain);
|
|
18
|
+
}
|
|
19
|
+
async deriveHookConfig(address) {
|
|
20
|
+
const hook = IPostDispatchHook__factory.connect(address, this.provider);
|
|
21
|
+
const onchainHookType = await hook.hookType();
|
|
22
|
+
switch (onchainHookType) {
|
|
23
|
+
case OnchainHookType.ROUTING:
|
|
24
|
+
return this.deriveDomainRoutingConfig(address);
|
|
25
|
+
case OnchainHookType.AGGREGATION:
|
|
26
|
+
return this.deriveAggregationConfig(address);
|
|
27
|
+
case OnchainHookType.MERKLE_TREE:
|
|
28
|
+
return this.deriveMerkleTreeConfig(address);
|
|
29
|
+
case OnchainHookType.INTERCHAIN_GAS_PAYMASTER:
|
|
30
|
+
return this.deriveIgpConfig(address);
|
|
31
|
+
case OnchainHookType.FALLBACK_ROUTING:
|
|
32
|
+
return this.deriveFallbackRoutingConfig(address);
|
|
33
|
+
case OnchainHookType.PAUSABLE:
|
|
34
|
+
return this.derivePausableConfig(address);
|
|
35
|
+
case OnchainHookType.PROTOCOL_FEE:
|
|
36
|
+
return this.deriveProtocolFeeConfig(address);
|
|
37
|
+
// ID_AUTH_ISM could be OPStackHook, ERC5164Hook or LayerZeroV2Hook
|
|
38
|
+
// For now assume it's OP_STACK
|
|
39
|
+
case OnchainHookType.ID_AUTH_ISM:
|
|
40
|
+
return this.deriveOpStackConfig(address);
|
|
41
|
+
default:
|
|
42
|
+
throw new Error(`Unsupported HookType: ${OnchainHookType[onchainHookType]}`);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
async deriveMerkleTreeConfig(address) {
|
|
46
|
+
const hook = MerkleTreeHook__factory.connect(address, this.provider);
|
|
47
|
+
assert((await hook.hookType()) === OnchainHookType.MERKLE_TREE);
|
|
48
|
+
return {
|
|
49
|
+
address,
|
|
50
|
+
type: HookType.MERKLE_TREE,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
async deriveAggregationConfig(address) {
|
|
54
|
+
const hook = StaticAggregationHook__factory.connect(address, this.provider);
|
|
55
|
+
assert((await hook.hookType()) === OnchainHookType.AGGREGATION);
|
|
56
|
+
const hooks = await hook.hooks(ethers.constants.AddressZero);
|
|
57
|
+
const hookConfigs = await concurrentMap(this.concurrency, hooks, async (hook) => this.deriveHookConfig(hook));
|
|
58
|
+
return {
|
|
59
|
+
address,
|
|
60
|
+
type: HookType.AGGREGATION,
|
|
61
|
+
hooks: hookConfigs,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
async deriveIgpConfig(address) {
|
|
65
|
+
const hook = InterchainGasPaymaster__factory.connect(address, this.provider);
|
|
66
|
+
assert((await hook.hookType()) === OnchainHookType.INTERCHAIN_GAS_PAYMASTER);
|
|
67
|
+
const owner = await hook.owner();
|
|
68
|
+
const beneficiary = await hook.beneficiary();
|
|
69
|
+
const overhead = {};
|
|
70
|
+
const oracleConfig = {};
|
|
71
|
+
let oracleKey;
|
|
72
|
+
const domainIds = this.multiProvider.getKnownDomainIds();
|
|
73
|
+
const allKeys = await concurrentMap(this.concurrency, domainIds, async (domainId) => {
|
|
74
|
+
const chainName = this.multiProvider.getChainName(domainId);
|
|
75
|
+
try {
|
|
76
|
+
const { tokenExchangeRate, gasPrice } = await hook.getExchangeRateAndGasPrice(domainId);
|
|
77
|
+
const domainGasOverhead = await hook.destinationGasLimit(domainId, 0);
|
|
78
|
+
overhead[chainName] = domainGasOverhead.toNumber();
|
|
79
|
+
oracleConfig[chainName] = { tokenExchangeRate, gasPrice };
|
|
80
|
+
const { gasOracle } = await hook.destinationGasConfigs(domainId);
|
|
81
|
+
const oracle = StorageGasOracle__factory.connect(gasOracle, this.provider);
|
|
82
|
+
return oracle.owner();
|
|
83
|
+
}
|
|
84
|
+
catch (error) {
|
|
85
|
+
this.logger.debug('Domain not configured on IGP Hook', domainId, chainName);
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
const resolvedOracleKeys = allKeys.filter((key) => key !== null);
|
|
90
|
+
if (resolvedOracleKeys.length > 0) {
|
|
91
|
+
const allKeysMatch = resolvedOracleKeys.every((key) => eqAddress(resolvedOracleKeys[0], key));
|
|
92
|
+
assert(allKeysMatch, 'Not all oracle keys match');
|
|
93
|
+
oracleKey = resolvedOracleKeys[0];
|
|
94
|
+
}
|
|
95
|
+
return {
|
|
96
|
+
owner,
|
|
97
|
+
address,
|
|
98
|
+
type: HookType.INTERCHAIN_GAS_PAYMASTER,
|
|
99
|
+
beneficiary,
|
|
100
|
+
oracleKey: oracleKey ?? owner,
|
|
101
|
+
overhead,
|
|
102
|
+
oracleConfig,
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
async deriveProtocolFeeConfig(address) {
|
|
106
|
+
const hook = ProtocolFee__factory.connect(address, this.provider);
|
|
107
|
+
assert((await hook.hookType()) === OnchainHookType.PROTOCOL_FEE);
|
|
108
|
+
const owner = await hook.owner();
|
|
109
|
+
const maxProtocolFee = await hook.MAX_PROTOCOL_FEE();
|
|
110
|
+
const protocolFee = await hook.protocolFee();
|
|
111
|
+
const beneficiary = await hook.beneficiary();
|
|
112
|
+
return {
|
|
113
|
+
owner,
|
|
114
|
+
address,
|
|
115
|
+
type: HookType.PROTOCOL_FEE,
|
|
116
|
+
maxProtocolFee: maxProtocolFee.toString(),
|
|
117
|
+
protocolFee: protocolFee.toString(),
|
|
118
|
+
beneficiary,
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
async deriveOpStackConfig(address) {
|
|
122
|
+
const hook = OPStackHook__factory.connect(address, this.provider);
|
|
123
|
+
const owner = await hook.owner();
|
|
124
|
+
assert((await hook.hookType()) === OnchainHookType.ID_AUTH_ISM);
|
|
125
|
+
const messengerContract = await hook.l1Messenger();
|
|
126
|
+
const destinationDomain = await hook.destinationDomain();
|
|
127
|
+
const destinationChainName = this.multiProvider.getChainName(destinationDomain);
|
|
128
|
+
return {
|
|
129
|
+
owner,
|
|
130
|
+
address,
|
|
131
|
+
type: HookType.OP_STACK,
|
|
132
|
+
nativeBridge: messengerContract,
|
|
133
|
+
destinationChain: destinationChainName,
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
async deriveDomainRoutingConfig(address) {
|
|
137
|
+
const hook = DomainRoutingHook__factory.connect(address, this.provider);
|
|
138
|
+
assert((await hook.hookType()) === OnchainHookType.ROUTING);
|
|
139
|
+
const owner = await hook.owner();
|
|
140
|
+
const domainHooks = await this.fetchDomainHooks(hook);
|
|
141
|
+
return {
|
|
142
|
+
owner,
|
|
143
|
+
address,
|
|
144
|
+
type: HookType.ROUTING,
|
|
145
|
+
domains: domainHooks,
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
async deriveFallbackRoutingConfig(address) {
|
|
149
|
+
const hook = FallbackDomainRoutingHook__factory.connect(address, this.provider);
|
|
150
|
+
assert((await hook.hookType()) === OnchainHookType.FALLBACK_ROUTING);
|
|
151
|
+
const owner = await hook.owner();
|
|
152
|
+
const domainHooks = await this.fetchDomainHooks(hook);
|
|
153
|
+
const fallbackHook = await hook.fallbackHook();
|
|
154
|
+
const fallbackHookConfig = await this.deriveHookConfig(fallbackHook);
|
|
155
|
+
return {
|
|
156
|
+
owner,
|
|
157
|
+
address,
|
|
158
|
+
type: HookType.FALLBACK_ROUTING,
|
|
159
|
+
domains: domainHooks,
|
|
160
|
+
fallback: fallbackHookConfig,
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
async fetchDomainHooks(hook) {
|
|
164
|
+
const domainIds = this.multiProvider.getKnownDomainIds();
|
|
165
|
+
const domainHooks = {};
|
|
166
|
+
await concurrentMap(this.concurrency, domainIds, async (domainId) => {
|
|
167
|
+
const chainName = this.multiProvider.getChainName(domainId);
|
|
168
|
+
try {
|
|
169
|
+
const domainHook = await hook.hooks(domainId);
|
|
170
|
+
if (domainHook !== ethers.constants.AddressZero) {
|
|
171
|
+
domainHooks[chainName] = await this.deriveHookConfig(domainHook);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
catch (error) {
|
|
175
|
+
this.logger.debug(`Domain not configured on ${hook.constructor.name}`, domainId, chainName);
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
return domainHooks;
|
|
179
|
+
}
|
|
180
|
+
async derivePausableConfig(address) {
|
|
181
|
+
const hook = PausableHook__factory.connect(address, this.provider);
|
|
182
|
+
assert((await hook.hookType()) === OnchainHookType.PAUSABLE);
|
|
183
|
+
const owner = await hook.owner();
|
|
184
|
+
return {
|
|
185
|
+
owner,
|
|
186
|
+
address,
|
|
187
|
+
type: HookType.PAUSABLE,
|
|
188
|
+
};
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
//# sourceMappingURL=read.js.map
|