@hyperlane-xyz/core 0.5.3 → 0.5.4-0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/contracts/Call.sol +7 -0
- package/contracts/{AbacusConnectionClient.sol → HyperlaneConnectionClient.sol} +69 -56
- package/contracts/InterchainGasPaymaster.sol +9 -11
- package/contracts/Mailbox.sol +179 -44
- package/contracts/OwnableMulticall.sol +1 -5
- package/contracts/Router.sol +21 -45
- package/contracts/isms/MultisigIsm.sol +340 -0
- package/contracts/libs/Message.sol +107 -66
- package/contracts/libs/MultisigIsmMetadata.sol +187 -0
- package/contracts/middleware/InterchainAccountRouter.sol +9 -6
- package/contracts/middleware/InterchainQueryRouter.sol +15 -9
- package/contracts/middleware/{token-bridge/TokenBridgeRouter.sol → liquidity-layer/LiquidityLayerRouter.sol} +16 -17
- package/contracts/middleware/{token-bridge → liquidity-layer}/adapters/CircleBridgeAdapter.sol +14 -16
- package/contracts/middleware/{token-bridge/interfaces/ITokenBridgeAdapter.sol → liquidity-layer/interfaces/ILiquidityLayerAdapter.sol} +1 -1
- package/contracts/middleware/{token-bridge/interfaces/ITokenBridgeMessageRecipient.sol → liquidity-layer/interfaces/ILiquidityLayerMessageRecipient.sol} +1 -1
- package/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleBridge.sol +0 -0
- package/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleMessageTransmitter.sol +0 -0
- package/contracts/mock/MockCircleBridge.sol +38 -0
- package/contracts/mock/MockCircleMessageTransmitter.sol +43 -0
- package/contracts/mock/MockHyperlaneEnvironment.sol +60 -0
- package/contracts/mock/MockInterchainAccountRouter.sol +98 -0
- package/contracts/mock/MockMailbox.sol +79 -0
- package/contracts/test/TestHyperlaneConnectionClient.sol +14 -0
- package/contracts/test/TestIsm.sol +20 -0
- package/contracts/test/{TestTokenBridgeMessageRecipient.sol → TestLiquidityLayerMessageRecipient.sol} +2 -2
- package/contracts/test/TestMailbox.sol +34 -4
- package/contracts/test/TestMerkle.sol +9 -4
- package/contracts/test/TestMessage.sol +24 -12
- package/contracts/test/TestMultisigIsm.sol +23 -0
- package/contracts/test/TestQuerySender.sol +72 -0
- package/contracts/test/TestSendReceiver.sol +6 -15
- package/contracts/test/TestTokenRecipient.sol +2 -2
- package/dist/contracts/{AbacusConnectionClient.d.ts → HyperlaneConnectionClient.d.ts} +69 -36
- package/dist/contracts/HyperlaneConnectionClient.d.ts.map +1 -0
- package/dist/contracts/HyperlaneConnectionClient.js +4 -0
- package/dist/contracts/HyperlaneConnectionClient.js.map +1 -0
- package/dist/contracts/InterchainGasPaymaster.d.ts +11 -13
- package/dist/contracts/InterchainGasPaymaster.d.ts.map +1 -1
- package/dist/contracts/Mailbox.d.ts +151 -28
- package/dist/contracts/Mailbox.d.ts.map +1 -1
- package/dist/contracts/OwnableSpecifiesISM.d.ts +134 -0
- package/dist/contracts/OwnableSpecifiesISM.d.ts.map +1 -0
- package/dist/contracts/{middleware/token-bridge/TokenBridgeRouter.js → OwnableSpecifiesISM.js} +1 -1
- package/dist/contracts/OwnableSpecifiesISM.js.map +1 -0
- package/dist/contracts/Router.d.ts +65 -32
- package/dist/contracts/Router.d.ts.map +1 -1
- package/dist/contracts/index.d.ts +3 -7
- package/dist/contracts/index.d.ts.map +1 -1
- package/dist/contracts/isms/MultisigIsm.d.ts +235 -0
- package/dist/contracts/isms/MultisigIsm.d.ts.map +1 -0
- package/dist/contracts/{Inbox.js → isms/MultisigIsm.js} +1 -1
- package/dist/contracts/isms/MultisigIsm.js.map +1 -0
- package/dist/contracts/isms/index.d.ts +2 -0
- package/dist/contracts/isms/index.d.ts.map +1 -0
- package/dist/contracts/{middleware/token-bridge/adapters → isms}/index.js +0 -0
- package/dist/contracts/isms/index.js.map +1 -0
- package/dist/contracts/middleware/InterchainAccountRouter.d.ts +71 -38
- package/dist/contracts/middleware/InterchainAccountRouter.d.ts.map +1 -1
- package/dist/contracts/middleware/InterchainQueryRouter.d.ts +72 -39
- package/dist/contracts/middleware/InterchainQueryRouter.d.ts.map +1 -1
- package/dist/contracts/middleware/index.d.ts +2 -2
- package/dist/contracts/middleware/index.d.ts.map +1 -1
- package/dist/contracts/middleware/{token-bridge/TokenBridgeRouter.d.ts → liquidity-layer/LiquidityLayerRouter.d.ts} +103 -70
- package/dist/contracts/middleware/liquidity-layer/LiquidityLayerRouter.d.ts.map +1 -0
- package/dist/contracts/{MerkleTreeManager.js → middleware/liquidity-layer/LiquidityLayerRouter.js} +1 -1
- package/dist/contracts/middleware/liquidity-layer/LiquidityLayerRouter.js.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/adapters/CircleBridgeAdapter.d.ts +78 -45
- package/dist/contracts/middleware/liquidity-layer/adapters/CircleBridgeAdapter.d.ts.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/adapters/CircleBridgeAdapter.js +0 -0
- package/dist/contracts/middleware/liquidity-layer/adapters/CircleBridgeAdapter.js.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/adapters/index.d.ts +0 -0
- package/dist/contracts/middleware/liquidity-layer/adapters/index.d.ts.map +1 -0
- package/dist/contracts/middleware/{token-bridge/interfaces/circle → liquidity-layer/adapters}/index.js +0 -0
- package/dist/contracts/middleware/liquidity-layer/adapters/index.js.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/index.d.ts +1 -1
- package/dist/contracts/middleware/liquidity-layer/index.d.ts.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/index.js +0 -0
- package/dist/contracts/middleware/liquidity-layer/index.js.map +1 -0
- package/dist/contracts/middleware/{token-bridge/interfaces/ITokenBridgeAdapter.d.ts → liquidity-layer/interfaces/ILiquidityLayerAdapter.d.ts} +4 -4
- package/dist/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerAdapter.d.ts.map +1 -0
- package/dist/contracts/{AbacusConnectionClient.js → middleware/liquidity-layer/interfaces/ILiquidityLayerAdapter.js} +1 -1
- package/dist/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerAdapter.js.map +1 -0
- package/dist/contracts/middleware/{token-bridge/interfaces/ITokenBridgeMessageRecipient.d.ts → liquidity-layer/interfaces/ILiquidityLayerMessageRecipient.d.ts} +4 -4
- package/dist/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerMessageRecipient.d.ts.map +1 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerMessageRecipient.js +4 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerMessageRecipient.js.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleBridge.d.ts +0 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/circle/ICircleBridge.d.ts.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleBridge.js +0 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/circle/ICircleBridge.js.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleMessageTransmitter.d.ts +0 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/circle/ICircleMessageTransmitter.d.ts.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleMessageTransmitter.js +0 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/circle/ICircleMessageTransmitter.js.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/index.d.ts +0 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/circle/index.d.ts.map +1 -0
- package/dist/contracts/{validator-manager → middleware/liquidity-layer/interfaces/circle}/index.js +0 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/circle/index.js.map +1 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/index.d.ts +5 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/index.d.ts.map +1 -0
- package/dist/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/index.js +0 -0
- package/dist/contracts/middleware/liquidity-layer/interfaces/index.js.map +1 -0
- package/dist/contracts/mock/MockCircleBridge.d.ts +86 -0
- package/dist/contracts/mock/MockCircleBridge.d.ts.map +1 -0
- package/dist/contracts/mock/MockCircleBridge.js +4 -0
- package/dist/contracts/mock/MockCircleBridge.js.map +1 -0
- package/dist/contracts/mock/MockCircleMessageTransmitter.d.ts +77 -0
- package/dist/contracts/mock/MockCircleMessageTransmitter.d.ts.map +1 -0
- package/dist/contracts/mock/MockCircleMessageTransmitter.js +4 -0
- package/dist/contracts/mock/MockCircleMessageTransmitter.js.map +1 -0
- package/dist/contracts/mock/{MockInbox.d.ts → MockHyperlaneEnvironment.d.ts} +33 -17
- package/dist/contracts/mock/MockHyperlaneEnvironment.d.ts.map +1 -0
- package/dist/contracts/{AbacusConnectionManager.js → mock/MockHyperlaneEnvironment.js} +1 -1
- package/dist/contracts/mock/MockHyperlaneEnvironment.js.map +1 -0
- package/dist/contracts/mock/MockInterchainAccountRouter.d.ts +124 -0
- package/dist/contracts/mock/MockInterchainAccountRouter.d.ts.map +1 -0
- package/dist/contracts/mock/MockInterchainAccountRouter.js +4 -0
- package/dist/contracts/mock/MockInterchainAccountRouter.js.map +1 -0
- package/dist/contracts/mock/MockMailbox.d.ts +185 -0
- package/dist/contracts/mock/MockMailbox.d.ts.map +1 -0
- package/dist/contracts/mock/MockMailbox.js +4 -0
- package/dist/contracts/mock/MockMailbox.js.map +1 -0
- package/dist/contracts/mock/index.d.ts +5 -3
- package/dist/contracts/mock/index.d.ts.map +1 -1
- package/dist/contracts/test/{TestAbacusConnectionClient.d.ts → TestHyperlaneConnectionClient.d.ts} +69 -52
- package/dist/contracts/test/TestHyperlaneConnectionClient.d.ts.map +1 -0
- package/dist/contracts/test/TestHyperlaneConnectionClient.js +4 -0
- package/dist/contracts/test/TestHyperlaneConnectionClient.js.map +1 -0
- package/dist/contracts/test/TestIsm.d.ts +67 -0
- package/dist/contracts/test/TestIsm.d.ts.map +1 -0
- package/dist/contracts/{Outbox.js → test/TestIsm.js} +1 -1
- package/dist/contracts/test/TestIsm.js.map +1 -0
- package/dist/contracts/test/{TestTokenBridgeMessageRecipient.d.ts → TestLiquidityLayerMessageRecipient.d.ts} +4 -4
- package/dist/contracts/test/TestLiquidityLayerMessageRecipient.d.ts.map +1 -0
- package/dist/contracts/test/TestLiquidityLayerMessageRecipient.js +4 -0
- package/dist/contracts/test/TestLiquidityLayerMessageRecipient.js.map +1 -0
- package/dist/contracts/test/TestMailbox.d.ts +164 -33
- package/dist/contracts/test/TestMailbox.d.ts.map +1 -1
- package/dist/contracts/test/TestMessage.d.ts +30 -10
- package/dist/contracts/test/TestMessage.d.ts.map +1 -1
- package/dist/contracts/test/TestMultisigIsm.d.ts +251 -0
- package/dist/contracts/test/TestMultisigIsm.d.ts.map +1 -0
- package/dist/contracts/test/TestMultisigIsm.js +4 -0
- package/dist/contracts/test/TestMultisigIsm.js.map +1 -0
- package/dist/contracts/test/TestQuerySender.d.ts +215 -0
- package/dist/contracts/test/TestQuerySender.d.ts.map +1 -0
- package/dist/contracts/test/TestQuerySender.js +4 -0
- package/dist/contracts/test/TestQuerySender.js.map +1 -0
- package/dist/contracts/test/TestRouter.d.ts +65 -32
- package/dist/contracts/test/TestRouter.d.ts.map +1 -1
- package/dist/contracts/test/index.d.ts +5 -6
- package/dist/contracts/test/index.d.ts.map +1 -1
- package/dist/factories/contracts/{AbacusConnectionClient__factory.d.ts → HyperlaneConnectionClient__factory.d.ts} +5 -5
- package/dist/factories/contracts/HyperlaneConnectionClient__factory.d.ts.map +1 -0
- package/dist/factories/contracts/{AbacusConnectionClient__factory.js → HyperlaneConnectionClient__factory.js} +61 -22
- package/dist/factories/contracts/HyperlaneConnectionClient__factory.js.map +1 -0
- package/dist/factories/contracts/InterchainGasPaymaster__factory.d.ts +1 -1
- package/dist/factories/contracts/InterchainGasPaymaster__factory.d.ts.map +1 -1
- package/dist/factories/contracts/InterchainGasPaymaster__factory.js +7 -18
- package/dist/factories/contracts/InterchainGasPaymaster__factory.js.map +1 -1
- package/dist/factories/contracts/Mailbox__factory.d.ts +29 -13
- package/dist/factories/contracts/Mailbox__factory.d.ts.map +1 -1
- package/dist/factories/contracts/Mailbox__factory.js +239 -11
- package/dist/factories/contracts/Mailbox__factory.js.map +1 -1
- package/dist/factories/contracts/OwnableMulticall__factory.d.ts +1 -1
- package/dist/factories/contracts/OwnableMulticall__factory.js +1 -1
- package/dist/factories/contracts/OwnableSpecifiesISM__factory.d.ts +55 -0
- package/dist/factories/contracts/OwnableSpecifiesISM__factory.d.ts.map +1 -0
- package/dist/factories/contracts/OwnableSpecifiesISM__factory.js +145 -0
- package/dist/factories/contracts/OwnableSpecifiesISM__factory.js.map +1 -0
- package/dist/factories/contracts/Router__factory.d.ts.map +1 -1
- package/dist/factories/contracts/Router__factory.js +65 -26
- package/dist/factories/contracts/Router__factory.js.map +1 -1
- package/dist/factories/contracts/index.d.ts +2 -6
- package/dist/factories/contracts/index.d.ts.map +1 -1
- package/dist/factories/contracts/index.js +4 -12
- package/dist/factories/contracts/index.js.map +1 -1
- package/dist/factories/contracts/isms/MultisigIsm__factory.d.ts +55 -0
- package/dist/factories/contracts/isms/MultisigIsm__factory.d.ts.map +1 -0
- package/dist/factories/contracts/isms/MultisigIsm__factory.js +363 -0
- package/dist/factories/contracts/isms/MultisigIsm__factory.js.map +1 -0
- package/dist/factories/contracts/isms/index.d.ts +2 -0
- package/dist/factories/contracts/isms/index.d.ts.map +1 -0
- package/dist/factories/contracts/isms/index.js +9 -0
- package/dist/factories/contracts/isms/index.js.map +1 -0
- package/dist/factories/contracts/middleware/InterchainAccountRouter__factory.d.ts +1 -12
- package/dist/factories/contracts/middleware/InterchainAccountRouter__factory.d.ts.map +1 -1
- package/dist/factories/contracts/middleware/InterchainAccountRouter__factory.js +78 -33
- package/dist/factories/contracts/middleware/InterchainAccountRouter__factory.js.map +1 -1
- package/dist/factories/contracts/middleware/InterchainQueryRouter__factory.d.ts +1 -12
- package/dist/factories/contracts/middleware/InterchainQueryRouter__factory.d.ts.map +1 -1
- package/dist/factories/contracts/middleware/InterchainQueryRouter__factory.js +81 -30
- package/dist/factories/contracts/middleware/InterchainQueryRouter__factory.js.map +1 -1
- package/dist/factories/contracts/middleware/index.d.ts +1 -1
- package/dist/factories/contracts/middleware/index.d.ts.map +1 -1
- package/dist/factories/contracts/middleware/index.js +2 -2
- package/dist/factories/contracts/middleware/index.js.map +1 -1
- package/dist/factories/contracts/middleware/liquidity-layer/LiquidityLayerRouter__factory.d.ts +48 -0
- package/dist/factories/contracts/middleware/liquidity-layer/LiquidityLayerRouter__factory.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/liquidity-layer/LiquidityLayerRouter__factory.js +419 -0
- package/dist/factories/contracts/middleware/liquidity-layer/LiquidityLayerRouter__factory.js.map +1 -0
- package/dist/factories/contracts/middleware/liquidity-layer/adapters/CircleBridgeAdapter__factory.d.ts +48 -0
- package/dist/factories/contracts/middleware/liquidity-layer/adapters/CircleBridgeAdapter__factory.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/liquidity-layer/adapters/CircleBridgeAdapter__factory.js +623 -0
- package/dist/factories/contracts/middleware/liquidity-layer/adapters/CircleBridgeAdapter__factory.js.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/adapters/index.d.ts +0 -0
- package/dist/factories/contracts/middleware/liquidity-layer/adapters/index.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/adapters/index.js +0 -0
- package/dist/factories/contracts/middleware/liquidity-layer/adapters/index.js.map +1 -0
- package/dist/factories/contracts/middleware/liquidity-layer/index.d.ts +4 -0
- package/dist/factories/contracts/middleware/liquidity-layer/index.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/index.js +3 -3
- package/dist/factories/contracts/middleware/liquidity-layer/index.js.map +1 -0
- package/dist/factories/{interfaces/IAbacusConnectionManager__factory.d.ts → contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerAdapter__factory.d.ts} +5 -5
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerAdapter__factory.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge/interfaces/ITokenBridgeAdapter__factory.js → liquidity-layer/interfaces/ILiquidityLayerAdapter__factory.js} +5 -5
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerAdapter__factory.js.map +1 -0
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerMessageRecipient__factory.d.ts +19 -0
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerMessageRecipient__factory.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge/interfaces/ITokenBridgeMessageRecipient__factory.js → liquidity-layer/interfaces/ILiquidityLayerMessageRecipient__factory.js} +5 -5
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/ILiquidityLayerMessageRecipient__factory.js.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleBridge__factory.d.ts +1 -1
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/circle/ICircleBridge__factory.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleBridge__factory.js +0 -0
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/circle/ICircleBridge__factory.js.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleMessageTransmitter__factory.d.ts +1 -1
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/circle/ICircleMessageTransmitter__factory.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/ICircleMessageTransmitter__factory.js +0 -0
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/circle/ICircleMessageTransmitter__factory.js.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/index.d.ts +0 -0
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/circle/index.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/circle/index.js +0 -0
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/circle/index.js.map +1 -0
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/index.d.ts +4 -0
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/index.d.ts.map +1 -0
- package/dist/factories/contracts/middleware/{token-bridge → liquidity-layer}/interfaces/index.js +5 -5
- package/dist/factories/contracts/middleware/liquidity-layer/interfaces/index.js.map +1 -0
- package/dist/factories/contracts/mock/MockCircleBridge__factory.d.ts +59 -0
- package/dist/factories/contracts/mock/MockCircleBridge__factory.d.ts.map +1 -0
- package/dist/factories/contracts/mock/MockCircleBridge__factory.js +151 -0
- package/dist/factories/contracts/mock/MockCircleBridge__factory.js.map +1 -0
- package/dist/factories/contracts/mock/MockCircleMessageTransmitter__factory.d.ts +45 -0
- package/dist/factories/contracts/mock/MockCircleMessageTransmitter__factory.d.ts.map +1 -0
- package/dist/factories/contracts/mock/MockCircleMessageTransmitter__factory.js +142 -0
- package/dist/factories/contracts/mock/MockCircleMessageTransmitter__factory.js.map +1 -0
- package/dist/factories/contracts/mock/MockHyperlaneEnvironment__factory.d.ts +45 -0
- package/dist/factories/contracts/mock/MockHyperlaneEnvironment__factory.d.ts.map +1 -0
- package/dist/factories/contracts/mock/MockHyperlaneEnvironment__factory.js +109 -0
- package/dist/factories/contracts/mock/MockHyperlaneEnvironment__factory.js.map +1 -0
- package/dist/factories/contracts/mock/MockInterchainAccountRouter__factory.d.ts +69 -0
- package/dist/factories/contracts/mock/MockInterchainAccountRouter__factory.d.ts.map +1 -0
- package/dist/factories/contracts/mock/MockInterchainAccountRouter__factory.js +181 -0
- package/dist/factories/contracts/mock/MockInterchainAccountRouter__factory.js.map +1 -0
- package/dist/factories/contracts/mock/MockMailbox__factory.d.ts +45 -0
- package/dist/factories/contracts/mock/MockMailbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/mock/MockMailbox__factory.js +252 -0
- package/dist/factories/contracts/mock/MockMailbox__factory.js.map +1 -0
- package/dist/factories/contracts/mock/index.d.ts +5 -3
- package/dist/factories/contracts/mock/index.d.ts.map +1 -1
- package/dist/factories/contracts/mock/index.js +11 -7
- package/dist/factories/contracts/mock/index.js.map +1 -1
- package/dist/factories/contracts/test/TestHyperlaneConnectionClient__factory.d.ts +55 -0
- package/dist/factories/contracts/test/TestHyperlaneConnectionClient__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestHyperlaneConnectionClient__factory.js +249 -0
- package/dist/factories/contracts/test/TestHyperlaneConnectionClient__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestIsm__factory.d.ts +35 -0
- package/dist/factories/contracts/test/TestIsm__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestIsm__factory.js +91 -0
- package/dist/factories/contracts/test/TestIsm__factory.js.map +1 -0
- package/dist/factories/contracts/test/{TestTokenBridgeMessageRecipient__factory.d.ts → TestLiquidityLayerMessageRecipient__factory.d.ts} +11 -11
- package/dist/factories/contracts/test/TestLiquidityLayerMessageRecipient__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/{TestTokenBridgeMessageRecipient__factory.js → TestLiquidityLayerMessageRecipient__factory.js} +7 -7
- package/dist/factories/contracts/test/TestLiquidityLayerMessageRecipient__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestMailbox__factory.d.ts +1 -8
- package/dist/factories/contracts/test/TestMailbox__factory.d.ts.map +1 -1
- package/dist/factories/contracts/test/TestMailbox__factory.js +235 -13
- package/dist/factories/contracts/test/TestMailbox__factory.js.map +1 -1
- package/dist/factories/contracts/test/TestMerkle__factory.d.ts +1 -1
- package/dist/factories/contracts/test/TestMerkle__factory.js +1 -1
- package/dist/factories/contracts/test/TestMessage__factory.d.ts +1 -1
- package/dist/factories/contracts/test/TestMessage__factory.d.ts.map +1 -1
- package/dist/factories/contracts/test/TestMessage__factory.js +40 -7
- package/dist/factories/contracts/test/TestMessage__factory.js.map +1 -1
- package/dist/factories/contracts/test/TestMultisigIsm__factory.d.ts +48 -0
- package/dist/factories/contracts/test/TestMultisigIsm__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestMultisigIsm__factory.js +406 -0
- package/dist/factories/contracts/test/TestMultisigIsm__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestQuerySender__factory.d.ts +55 -0
- package/dist/factories/contracts/test/TestQuerySender__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestQuerySender__factory.js +253 -0
- package/dist/factories/contracts/test/TestQuerySender__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestQuery__factory.d.ts +1 -1
- package/dist/factories/contracts/test/TestQuery__factory.d.ts.map +1 -1
- package/dist/factories/contracts/test/TestQuery__factory.js +1 -1
- package/dist/factories/contracts/test/TestQuery__factory.js.map +1 -1
- package/dist/factories/contracts/test/TestRouter__factory.d.ts +1 -1
- package/dist/factories/contracts/test/TestRouter__factory.d.ts.map +1 -1
- package/dist/factories/contracts/test/TestRouter__factory.js +70 -31
- package/dist/factories/contracts/test/TestRouter__factory.js.map +1 -1
- package/dist/factories/contracts/test/TestSendReceiver__factory.d.ts +1 -1
- package/dist/factories/contracts/test/TestSendReceiver__factory.d.ts.map +1 -1
- package/dist/factories/contracts/test/TestSendReceiver__factory.js +2 -2
- package/dist/factories/contracts/test/TestSendReceiver__factory.js.map +1 -1
- package/dist/factories/contracts/test/TestTokenRecipient__factory.d.ts +1 -1
- package/dist/factories/contracts/test/TestTokenRecipient__factory.js +1 -1
- package/dist/factories/contracts/test/index.d.ts +5 -6
- package/dist/factories/contracts/test/index.d.ts.map +1 -1
- package/dist/factories/contracts/test/index.js +11 -13
- package/dist/factories/contracts/test/index.js.map +1 -1
- package/dist/factories/interfaces/IInterchainAccountRouter__factory.d.ts +33 -0
- package/dist/factories/interfaces/IInterchainAccountRouter__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IInterchainAccountRouter__factory.js +78 -0
- package/dist/factories/interfaces/IInterchainAccountRouter__factory.js.map +1 -0
- package/dist/factories/interfaces/IInterchainGasPaymaster__factory.d.ts.map +1 -1
- package/dist/factories/interfaces/IInterchainGasPaymaster__factory.js +3 -8
- package/dist/factories/interfaces/IInterchainGasPaymaster__factory.js.map +1 -1
- package/dist/factories/interfaces/IInterchainQueryRouter__factory.d.ts +33 -0
- package/dist/factories/interfaces/IInterchainQueryRouter__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IInterchainQueryRouter__factory.js +100 -0
- package/dist/factories/interfaces/IInterchainQueryRouter__factory.js.map +1 -0
- package/dist/factories/{contracts/middleware/token-bridge/interfaces/ITokenBridgeAdapter__factory.d.ts → interfaces/IInterchainSecurityModule.sol/IInterchainSecurityModule__factory.d.ts} +5 -5
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/IInterchainSecurityModule__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/IInterchainSecurityModule__factory.js +42 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/IInterchainSecurityModule__factory.js.map +1 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/ISpecifiesInterchainSecurityModule__factory.d.ts +19 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/ISpecifiesInterchainSecurityModule__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/ISpecifiesInterchainSecurityModule__factory.js +31 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/ISpecifiesInterchainSecurityModule__factory.js.map +1 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/index.d.ts +3 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/index.d.ts.map +1 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/index.js +11 -0
- package/dist/factories/interfaces/IInterchainSecurityModule.sol/index.js.map +1 -0
- package/dist/factories/interfaces/IMailbox__factory.d.ts +5 -1
- package/dist/factories/interfaces/IMailbox__factory.d.ts.map +1 -1
- package/dist/factories/interfaces/IMailbox__factory.js +81 -3
- package/dist/factories/interfaces/IMailbox__factory.js.map +1 -1
- package/dist/factories/interfaces/{IOutbox__factory.d.ts → IMultisigIsm__factory.d.ts} +5 -5
- package/dist/factories/interfaces/IMultisigIsm__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/{IInbox__factory.js → IMultisigIsm__factory.js} +55 -41
- package/dist/factories/interfaces/IMultisigIsm__factory.js.map +1 -0
- package/dist/factories/interfaces/index.d.ts +4 -4
- package/dist/factories/interfaces/index.d.ts.map +1 -1
- package/dist/factories/interfaces/index.js +31 -9
- package/dist/factories/interfaces/index.js.map +1 -1
- package/dist/index.d.ts +46 -54
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +45 -53
- package/dist/index.js.map +1 -1
- package/dist/interfaces/IInterchainAccountRouter.d.ts +67 -0
- package/dist/interfaces/IInterchainAccountRouter.d.ts.map +1 -0
- package/dist/interfaces/IInterchainAccountRouter.js +4 -0
- package/dist/interfaces/IInterchainAccountRouter.js.map +1 -0
- package/dist/interfaces/IInterchainGasPaymaster.d.ts +7 -7
- package/dist/interfaces/IInterchainGasPaymaster.d.ts.map +1 -1
- package/dist/interfaces/IInterchainQueryRouter.d.ts +75 -0
- package/dist/interfaces/IInterchainQueryRouter.d.ts.map +1 -0
- package/dist/interfaces/IInterchainQueryRouter.js +4 -0
- package/dist/interfaces/IInterchainQueryRouter.js.map +1 -0
- package/dist/{contracts/mock/MockOutbox.d.ts → interfaces/IInterchainSecurityModule.sol/IInterchainSecurityModule.d.ts} +14 -14
- package/dist/interfaces/IInterchainSecurityModule.sol/IInterchainSecurityModule.d.ts.map +1 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/IInterchainSecurityModule.js +4 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/IInterchainSecurityModule.js.map +1 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/ISpecifiesInterchainSecurityModule.d.ts +43 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/ISpecifiesInterchainSecurityModule.d.ts.map +1 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/ISpecifiesInterchainSecurityModule.js +4 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/ISpecifiesInterchainSecurityModule.js.map +1 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/index.d.ts +3 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/index.d.ts.map +1 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/index.js +3 -0
- package/dist/interfaces/IInterchainSecurityModule.sol/index.js.map +1 -0
- package/dist/interfaces/IMailbox.d.ts +58 -10
- package/dist/interfaces/IMailbox.d.ts.map +1 -1
- package/dist/interfaces/IMultisigIsm.d.ts +75 -0
- package/dist/interfaces/IMultisigIsm.d.ts.map +1 -0
- package/dist/interfaces/IMultisigIsm.js +4 -0
- package/dist/interfaces/IMultisigIsm.js.map +1 -0
- package/dist/interfaces/index.d.ts +5 -4
- package/dist/interfaces/index.d.ts.map +1 -1
- package/dist/interfaces/index.js +1 -0
- package/dist/interfaces/index.js.map +1 -1
- package/interfaces/IInterchainAccountRouter.sol +15 -0
- package/interfaces/IInterchainGasPaymaster.sol +3 -5
- package/interfaces/IInterchainQueryRouter.sol +18 -0
- package/interfaces/IInterchainSecurityModule.sol +16 -0
- package/interfaces/IMailbox.sol +15 -2
- package/interfaces/IMultisigIsm.sol +18 -0
- package/package.json +4 -3
- package/contracts/AbacusConnectionManager.sol +0 -145
- package/contracts/Inbox.sol +0 -148
- package/contracts/MerkleTreeManager.sol +0 -32
- package/contracts/Outbox.sol +0 -191
- package/contracts/mock/MockInbox.sol +0 -52
- package/contracts/mock/MockOutbox.sol +0 -30
- package/contracts/mock/MockTokenBridgeAdapter.sol +0 -46
- package/contracts/test/TestAbacusConnectionClient.sol +0 -23
- package/contracts/test/TestInbox.sol +0 -54
- package/contracts/test/TestMultisigValidatorManager.sol +0 -26
- package/contracts/test/TestOutbox.sol +0 -46
- package/contracts/test/TestValidatorManager.sol +0 -21
- package/contracts/validator-manager/InboxValidatorManager.sol +0 -58
- package/contracts/validator-manager/MultisigValidatorManager.sol +0 -271
- package/contracts/validator-manager/OutboxValidatorManager.sol +0 -244
- package/dist/contracts/AbacusConnectionClient.d.ts.map +0 -1
- package/dist/contracts/AbacusConnectionClient.js.map +0 -1
- package/dist/contracts/AbacusConnectionManager.d.ts +0 -213
- package/dist/contracts/AbacusConnectionManager.d.ts.map +0 -1
- package/dist/contracts/AbacusConnectionManager.js.map +0 -1
- package/dist/contracts/Inbox.d.ts +0 -207
- package/dist/contracts/Inbox.d.ts.map +0 -1
- package/dist/contracts/Inbox.js.map +0 -1
- package/dist/contracts/MerkleTreeManager.d.ts +0 -53
- package/dist/contracts/MerkleTreeManager.d.ts.map +0 -1
- package/dist/contracts/MerkleTreeManager.js.map +0 -1
- package/dist/contracts/Outbox.d.ts +0 -331
- package/dist/contracts/Outbox.d.ts.map +0 -1
- package/dist/contracts/Outbox.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/TokenBridgeRouter.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/TokenBridgeRouter.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/adapters/CircleBridgeAdapter.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/adapters/CircleBridgeAdapter.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/adapters/index.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/adapters/index.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/index.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/index.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/ITokenBridgeAdapter.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/ITokenBridgeAdapter.js +0 -4
- package/dist/contracts/middleware/token-bridge/interfaces/ITokenBridgeAdapter.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/ITokenBridgeMessageRecipient.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/ITokenBridgeMessageRecipient.js +0 -4
- package/dist/contracts/middleware/token-bridge/interfaces/ITokenBridgeMessageRecipient.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/circle/ICircleBridge.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/circle/ICircleBridge.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/circle/ICircleMessageTransmitter.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/circle/ICircleMessageTransmitter.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/circle/index.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/circle/index.js.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/index.d.ts +0 -5
- package/dist/contracts/middleware/token-bridge/interfaces/index.d.ts.map +0 -1
- package/dist/contracts/middleware/token-bridge/interfaces/index.js.map +0 -1
- package/dist/contracts/mock/MockInbox.d.ts.map +0 -1
- package/dist/contracts/mock/MockInbox.js +0 -4
- package/dist/contracts/mock/MockInbox.js.map +0 -1
- package/dist/contracts/mock/MockOutbox.d.ts.map +0 -1
- package/dist/contracts/mock/MockOutbox.js +0 -4
- package/dist/contracts/mock/MockOutbox.js.map +0 -1
- package/dist/contracts/mock/MockTokenBridgeAdapter.d.ts +0 -99
- package/dist/contracts/mock/MockTokenBridgeAdapter.d.ts.map +0 -1
- package/dist/contracts/mock/MockTokenBridgeAdapter.js +0 -4
- package/dist/contracts/mock/MockTokenBridgeAdapter.js.map +0 -1
- package/dist/contracts/test/TestAbacusConnectionClient.d.ts.map +0 -1
- package/dist/contracts/test/TestAbacusConnectionClient.js +0 -4
- package/dist/contracts/test/TestAbacusConnectionClient.js.map +0 -1
- package/dist/contracts/test/TestInbox.d.ts +0 -263
- package/dist/contracts/test/TestInbox.d.ts.map +0 -1
- package/dist/contracts/test/TestInbox.js +0 -4
- package/dist/contracts/test/TestInbox.js.map +0 -1
- package/dist/contracts/test/TestMultisigValidatorManager.d.ts +0 -247
- package/dist/contracts/test/TestMultisigValidatorManager.d.ts.map +0 -1
- package/dist/contracts/test/TestMultisigValidatorManager.js +0 -4
- package/dist/contracts/test/TestMultisigValidatorManager.js.map +0 -1
- package/dist/contracts/test/TestOutbox.d.ts +0 -371
- package/dist/contracts/test/TestOutbox.d.ts.map +0 -1
- package/dist/contracts/test/TestOutbox.js +0 -4
- package/dist/contracts/test/TestOutbox.js.map +0 -1
- package/dist/contracts/test/TestTokenBridgeMessageRecipient.d.ts.map +0 -1
- package/dist/contracts/test/TestTokenBridgeMessageRecipient.js +0 -4
- package/dist/contracts/test/TestTokenBridgeMessageRecipient.js.map +0 -1
- package/dist/contracts/test/TestValidatorManager.d.ts +0 -58
- package/dist/contracts/test/TestValidatorManager.d.ts.map +0 -1
- package/dist/contracts/test/TestValidatorManager.js +0 -4
- package/dist/contracts/test/TestValidatorManager.js.map +0 -1
- package/dist/contracts/validator-manager/InboxValidatorManager.d.ts +0 -263
- package/dist/contracts/validator-manager/InboxValidatorManager.d.ts.map +0 -1
- package/dist/contracts/validator-manager/InboxValidatorManager.js +0 -4
- package/dist/contracts/validator-manager/InboxValidatorManager.js.map +0 -1
- package/dist/contracts/validator-manager/MultisigValidatorManager.d.ts +0 -239
- package/dist/contracts/validator-manager/MultisigValidatorManager.d.ts.map +0 -1
- package/dist/contracts/validator-manager/MultisigValidatorManager.js +0 -4
- package/dist/contracts/validator-manager/MultisigValidatorManager.js.map +0 -1
- package/dist/contracts/validator-manager/OutboxValidatorManager.d.ts +0 -335
- package/dist/contracts/validator-manager/OutboxValidatorManager.d.ts.map +0 -1
- package/dist/contracts/validator-manager/OutboxValidatorManager.js +0 -4
- package/dist/contracts/validator-manager/OutboxValidatorManager.js.map +0 -1
- package/dist/contracts/validator-manager/index.d.ts +0 -4
- package/dist/contracts/validator-manager/index.d.ts.map +0 -1
- package/dist/contracts/validator-manager/index.js.map +0 -1
- package/dist/factories/contracts/AbacusConnectionClient__factory.d.ts.map +0 -1
- package/dist/factories/contracts/AbacusConnectionClient__factory.js.map +0 -1
- package/dist/factories/contracts/AbacusConnectionManager__factory.d.ts +0 -55
- package/dist/factories/contracts/AbacusConnectionManager__factory.d.ts.map +0 -1
- package/dist/factories/contracts/AbacusConnectionManager__factory.js +0 -276
- package/dist/factories/contracts/AbacusConnectionManager__factory.js.map +0 -1
- package/dist/factories/contracts/Inbox__factory.d.ts +0 -59
- package/dist/factories/contracts/Inbox__factory.d.ts.map +0 -1
- package/dist/factories/contracts/Inbox__factory.js +0 -278
- package/dist/factories/contracts/Inbox__factory.js.map +0 -1
- package/dist/factories/contracts/MerkleTreeManager__factory.d.ts +0 -31
- package/dist/factories/contracts/MerkleTreeManager__factory.d.ts.map +0 -1
- package/dist/factories/contracts/MerkleTreeManager__factory.js +0 -67
- package/dist/factories/contracts/MerkleTreeManager__factory.js.map +0 -1
- package/dist/factories/contracts/Outbox__factory.d.ts +0 -59
- package/dist/factories/contracts/Outbox__factory.d.ts.map +0 -1
- package/dist/factories/contracts/Outbox__factory.js +0 -415
- package/dist/factories/contracts/Outbox__factory.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/TokenBridgeRouter__factory.d.ts +0 -48
- package/dist/factories/contracts/middleware/token-bridge/TokenBridgeRouter__factory.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/TokenBridgeRouter__factory.js +0 -380
- package/dist/factories/contracts/middleware/token-bridge/TokenBridgeRouter__factory.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/adapters/CircleBridgeAdapter__factory.d.ts +0 -48
- package/dist/factories/contracts/middleware/token-bridge/adapters/CircleBridgeAdapter__factory.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/adapters/CircleBridgeAdapter__factory.js +0 -584
- package/dist/factories/contracts/middleware/token-bridge/adapters/CircleBridgeAdapter__factory.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/adapters/index.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/adapters/index.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/index.d.ts +0 -4
- package/dist/factories/contracts/middleware/token-bridge/index.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/index.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/ITokenBridgeAdapter__factory.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/ITokenBridgeAdapter__factory.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/ITokenBridgeMessageRecipient__factory.d.ts +0 -19
- package/dist/factories/contracts/middleware/token-bridge/interfaces/ITokenBridgeMessageRecipient__factory.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/ITokenBridgeMessageRecipient__factory.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/circle/ICircleBridge__factory.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/circle/ICircleBridge__factory.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/circle/ICircleMessageTransmitter__factory.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/circle/ICircleMessageTransmitter__factory.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/circle/index.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/circle/index.js.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/index.d.ts +0 -4
- package/dist/factories/contracts/middleware/token-bridge/interfaces/index.d.ts.map +0 -1
- package/dist/factories/contracts/middleware/token-bridge/interfaces/index.js.map +0 -1
- package/dist/factories/contracts/mock/MockInbox__factory.d.ts +0 -31
- package/dist/factories/contracts/mock/MockInbox__factory.d.ts.map +0 -1
- package/dist/factories/contracts/mock/MockInbox__factory.js +0 -76
- package/dist/factories/contracts/mock/MockInbox__factory.js.map +0 -1
- package/dist/factories/contracts/mock/MockOutbox__factory.d.ts +0 -45
- package/dist/factories/contracts/mock/MockOutbox__factory.d.ts.map +0 -1
- package/dist/factories/contracts/mock/MockOutbox__factory.js +0 -86
- package/dist/factories/contracts/mock/MockOutbox__factory.js.map +0 -1
- package/dist/factories/contracts/mock/MockTokenBridgeAdapter__factory.d.ts +0 -45
- package/dist/factories/contracts/mock/MockTokenBridgeAdapter__factory.d.ts.map +0 -1
- package/dist/factories/contracts/mock/MockTokenBridgeAdapter__factory.js +0 -170
- package/dist/factories/contracts/mock/MockTokenBridgeAdapter__factory.js.map +0 -1
- package/dist/factories/contracts/test/TestAbacusConnectionClient__factory.d.ts +0 -48
- package/dist/factories/contracts/test/TestAbacusConnectionClient__factory.d.ts.map +0 -1
- package/dist/factories/contracts/test/TestAbacusConnectionClient__factory.js +0 -242
- package/dist/factories/contracts/test/TestAbacusConnectionClient__factory.js.map +0 -1
- package/dist/factories/contracts/test/TestInbox__factory.d.ts +0 -59
- package/dist/factories/contracts/test/TestInbox__factory.d.ts.map +0 -1
- package/dist/factories/contracts/test/TestInbox__factory.js +0 -371
- package/dist/factories/contracts/test/TestInbox__factory.js.map +0 -1
- package/dist/factories/contracts/test/TestMultisigValidatorManager__factory.d.ts +0 -59
- package/dist/factories/contracts/test/TestMultisigValidatorManager__factory.d.ts.map +0 -1
- package/dist/factories/contracts/test/TestMultisigValidatorManager__factory.js +0 -349
- package/dist/factories/contracts/test/TestMultisigValidatorManager__factory.js.map +0 -1
- package/dist/factories/contracts/test/TestOutbox__factory.d.ts +0 -59
- package/dist/factories/contracts/test/TestOutbox__factory.d.ts.map +0 -1
- package/dist/factories/contracts/test/TestOutbox__factory.js +0 -483
- package/dist/factories/contracts/test/TestOutbox__factory.js.map +0 -1
- package/dist/factories/contracts/test/TestTokenBridgeMessageRecipient__factory.d.ts.map +0 -1
- package/dist/factories/contracts/test/TestTokenBridgeMessageRecipient__factory.js.map +0 -1
- package/dist/factories/contracts/test/TestValidatorManager__factory.d.ts +0 -31
- package/dist/factories/contracts/test/TestValidatorManager__factory.d.ts.map +0 -1
- package/dist/factories/contracts/test/TestValidatorManager__factory.js +0 -79
- package/dist/factories/contracts/test/TestValidatorManager__factory.js.map +0 -1
- package/dist/factories/contracts/validator-manager/InboxValidatorManager__factory.d.ts +0 -59
- package/dist/factories/contracts/validator-manager/InboxValidatorManager__factory.d.ts.map +0 -1
- package/dist/factories/contracts/validator-manager/InboxValidatorManager__factory.js +0 -373
- package/dist/factories/contracts/validator-manager/InboxValidatorManager__factory.js.map +0 -1
- package/dist/factories/contracts/validator-manager/MultisigValidatorManager__factory.d.ts +0 -36
- package/dist/factories/contracts/validator-manager/MultisigValidatorManager__factory.d.ts.map +0 -1
- package/dist/factories/contracts/validator-manager/MultisigValidatorManager__factory.js +0 -286
- package/dist/factories/contracts/validator-manager/MultisigValidatorManager__factory.js.map +0 -1
- package/dist/factories/contracts/validator-manager/OutboxValidatorManager__factory.d.ts +0 -59
- package/dist/factories/contracts/validator-manager/OutboxValidatorManager__factory.d.ts.map +0 -1
- package/dist/factories/contracts/validator-manager/OutboxValidatorManager__factory.js +0 -560
- package/dist/factories/contracts/validator-manager/OutboxValidatorManager__factory.js.map +0 -1
- package/dist/factories/contracts/validator-manager/index.d.ts +0 -4
- package/dist/factories/contracts/validator-manager/index.d.ts.map +0 -1
- package/dist/factories/contracts/validator-manager/index.js +0 -13
- package/dist/factories/contracts/validator-manager/index.js.map +0 -1
- package/dist/factories/interfaces/IAbacusConnectionManager__factory.d.ts.map +0 -1
- package/dist/factories/interfaces/IAbacusConnectionManager__factory.js +0 -63
- package/dist/factories/interfaces/IAbacusConnectionManager__factory.js.map +0 -1
- package/dist/factories/interfaces/IInbox__factory.d.ts +0 -29
- package/dist/factories/interfaces/IInbox__factory.d.ts.map +0 -1
- package/dist/factories/interfaces/IInbox__factory.js.map +0 -1
- package/dist/factories/interfaces/IMultisigValidatorManager__factory.d.ts +0 -19
- package/dist/factories/interfaces/IMultisigValidatorManager__factory.d.ts.map +0 -1
- package/dist/factories/interfaces/IMultisigValidatorManager__factory.js +0 -57
- package/dist/factories/interfaces/IMultisigValidatorManager__factory.js.map +0 -1
- package/dist/factories/interfaces/IOutbox__factory.d.ts.map +0 -1
- package/dist/factories/interfaces/IOutbox__factory.js +0 -155
- package/dist/factories/interfaces/IOutbox__factory.js.map +0 -1
- package/dist/interfaces/IAbacusConnectionManager.d.ts +0 -59
- package/dist/interfaces/IAbacusConnectionManager.d.ts.map +0 -1
- package/dist/interfaces/IAbacusConnectionManager.js +0 -4
- package/dist/interfaces/IAbacusConnectionManager.js.map +0 -1
- package/dist/interfaces/IInbox.d.ts +0 -83
- package/dist/interfaces/IInbox.d.ts.map +0 -1
- package/dist/interfaces/IInbox.js +0 -4
- package/dist/interfaces/IInbox.js.map +0 -1
- package/dist/interfaces/IMultisigValidatorManager.d.ts +0 -59
- package/dist/interfaces/IMultisigValidatorManager.d.ts.map +0 -1
- package/dist/interfaces/IMultisigValidatorManager.js +0 -4
- package/dist/interfaces/IMultisigValidatorManager.js.map +0 -1
- package/dist/interfaces/IOutbox.d.ts +0 -148
- package/dist/interfaces/IOutbox.d.ts.map +0 -1
- package/dist/interfaces/IOutbox.js +0 -4
- package/dist/interfaces/IOutbox.js.map +0 -1
- package/interfaces/IAbacusConnectionManager.sol +0 -12
- package/interfaces/IInbox.sol +0 -16
- package/interfaces/IMultisigValidatorManager.sol +0 -11
- package/interfaces/IOutbox.sol +0 -27
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
+
pragma solidity >=0.6.11;
|
|
3
|
+
|
|
4
|
+
import {Call} from "../contracts/Call.sol";
|
|
5
|
+
|
|
6
|
+
interface IInterchainQueryRouter {
|
|
7
|
+
function query(
|
|
8
|
+
uint32 _destinationDomain,
|
|
9
|
+
Call calldata call,
|
|
10
|
+
bytes calldata callback
|
|
11
|
+
) external returns (bytes32);
|
|
12
|
+
|
|
13
|
+
function query(
|
|
14
|
+
uint32 _destinationDomain,
|
|
15
|
+
Call[] calldata calls,
|
|
16
|
+
bytes[] calldata callbacks
|
|
17
|
+
) external returns (bytes32);
|
|
18
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
+
pragma solidity >=0.6.11;
|
|
3
|
+
|
|
4
|
+
interface IInterchainSecurityModule {
|
|
5
|
+
// Called by the Mailbox to determine whether or not the message should be accepted.
|
|
6
|
+
function verify(bytes calldata _metadata, bytes calldata _message)
|
|
7
|
+
external
|
|
8
|
+
returns (bool);
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
interface ISpecifiesInterchainSecurityModule {
|
|
12
|
+
function interchainSecurityModule()
|
|
13
|
+
external
|
|
14
|
+
view
|
|
15
|
+
returns (IInterchainSecurityModule);
|
|
16
|
+
}
|
package/interfaces/IMailbox.sol
CHANGED
|
@@ -1,8 +1,21 @@
|
|
|
1
1
|
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
-
pragma solidity >=0.
|
|
2
|
+
pragma solidity >=0.8.0;
|
|
3
3
|
|
|
4
4
|
interface IMailbox {
|
|
5
5
|
function localDomain() external view returns (uint32);
|
|
6
6
|
|
|
7
|
-
function
|
|
7
|
+
function dispatch(
|
|
8
|
+
uint32 _destinationDomain,
|
|
9
|
+
bytes32 _recipientAddress,
|
|
10
|
+
bytes calldata _messageBody
|
|
11
|
+
) external returns (bytes32);
|
|
12
|
+
|
|
13
|
+
function process(bytes calldata _metadata, bytes calldata _message)
|
|
14
|
+
external;
|
|
15
|
+
|
|
16
|
+
function count() external view returns (uint32);
|
|
17
|
+
|
|
18
|
+
function root() external view returns (bytes32);
|
|
19
|
+
|
|
20
|
+
function latestCheckpoint() external view returns (bytes32, uint32);
|
|
8
21
|
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
+
pragma solidity >=0.6.0;
|
|
3
|
+
|
|
4
|
+
import {IInterchainSecurityModule} from "./IInterchainSecurityModule.sol";
|
|
5
|
+
|
|
6
|
+
interface IMultisigIsm is IInterchainSecurityModule {
|
|
7
|
+
function isEnrolled(uint32 _domain, address _validator)
|
|
8
|
+
external
|
|
9
|
+
view
|
|
10
|
+
returns (bool);
|
|
11
|
+
|
|
12
|
+
function threshold(uint32 _domain) external view returns (uint256);
|
|
13
|
+
|
|
14
|
+
function validators(uint32 _domain)
|
|
15
|
+
external
|
|
16
|
+
view
|
|
17
|
+
returns (address[] memory);
|
|
18
|
+
}
|
package/package.json
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hyperlane-xyz/core",
|
|
3
3
|
"description": "Core solidity contracts for Hyperlane",
|
|
4
|
-
"version": "0.5.
|
|
4
|
+
"version": "0.5.4-0",
|
|
5
5
|
"dependencies": {
|
|
6
|
-
"@hyperlane-xyz/utils": "0.5.
|
|
6
|
+
"@hyperlane-xyz/utils": "0.5.4-0",
|
|
7
7
|
"@openzeppelin/contracts": "^4.6.0",
|
|
8
8
|
"@openzeppelin/contracts-upgradeable": "^4.6.0"
|
|
9
9
|
},
|
|
@@ -49,5 +49,6 @@
|
|
|
49
49
|
"prettier": "prettier --write ./contracts ./interfaces ./test",
|
|
50
50
|
"test": "hardhat test"
|
|
51
51
|
},
|
|
52
|
-
"types": "dist/index.d.ts"
|
|
52
|
+
"types": "dist/index.d.ts",
|
|
53
|
+
"stableVersion": "0.5.3"
|
|
53
54
|
}
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
-
pragma solidity >=0.8.0;
|
|
3
|
-
pragma abicoder v2;
|
|
4
|
-
|
|
5
|
-
// ============ Internal Imports ============
|
|
6
|
-
import {IOutbox} from "../interfaces/IOutbox.sol";
|
|
7
|
-
import {IAbacusConnectionManager} from "../interfaces/IAbacusConnectionManager.sol";
|
|
8
|
-
|
|
9
|
-
// ============ External Imports ============
|
|
10
|
-
import {Ownable} from "@openzeppelin/contracts/access/Ownable.sol";
|
|
11
|
-
import {Address} from "@openzeppelin/contracts/utils/Address.sol";
|
|
12
|
-
import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* @title AbacusConnectionManager
|
|
16
|
-
* @author Celo Labs Inc.
|
|
17
|
-
* @notice Manages a registry of local Inbox contracts for remote Outbox
|
|
18
|
-
* domains.
|
|
19
|
-
*/
|
|
20
|
-
contract AbacusConnectionManager is IAbacusConnectionManager, Ownable {
|
|
21
|
-
using EnumerableSet for EnumerableSet.AddressSet;
|
|
22
|
-
|
|
23
|
-
// ============ Public Storage ============
|
|
24
|
-
|
|
25
|
-
// Outbox contract
|
|
26
|
-
IOutbox public override outbox;
|
|
27
|
-
// local Inbox address => remote Outbox domain
|
|
28
|
-
mapping(address => uint32) public inboxToDomain;
|
|
29
|
-
// remote Outbox domain => local Inbox addresses
|
|
30
|
-
mapping(uint32 => EnumerableSet.AddressSet) domainToInboxes;
|
|
31
|
-
|
|
32
|
-
// ============ Events ============
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* @notice Emitted when a new Outbox is set.
|
|
36
|
-
* @param outbox the address of the Outbox
|
|
37
|
-
*/
|
|
38
|
-
event OutboxSet(address indexed outbox);
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* @notice Emitted when a new Inbox is enrolled / added
|
|
42
|
-
* @param domain the remote domain of the Outbox contract for the Inbox
|
|
43
|
-
* @param inbox the address of the Inbox
|
|
44
|
-
*/
|
|
45
|
-
event InboxEnrolled(uint32 indexed domain, address inbox);
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* @notice Emitted when a new Inbox is un-enrolled / removed
|
|
49
|
-
* @param domain the remote domain of the Outbox contract for the Inbox
|
|
50
|
-
* @param inbox the address of the Inbox
|
|
51
|
-
*/
|
|
52
|
-
event InboxUnenrolled(uint32 indexed domain, address inbox);
|
|
53
|
-
|
|
54
|
-
// ============ Constructor ============
|
|
55
|
-
|
|
56
|
-
// solhint-disable-next-line no-empty-blocks
|
|
57
|
-
constructor() Ownable() {}
|
|
58
|
-
|
|
59
|
-
// ============ External Functions ============
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* @notice Sets the address of the local Outbox contract.
|
|
63
|
-
* @param _outbox The address of the new local Outbox contract.
|
|
64
|
-
*/
|
|
65
|
-
function setOutbox(address _outbox) external onlyOwner {
|
|
66
|
-
require(Address.isContract(_outbox), "outbox !contract");
|
|
67
|
-
outbox = IOutbox(_outbox);
|
|
68
|
-
emit OutboxSet(_outbox);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* @notice Allow Owner to enroll Inbox contract
|
|
73
|
-
* @param _domain the remote domain of the Outbox contract for the Inbox
|
|
74
|
-
* @param _inbox the address of the Inbox
|
|
75
|
-
*/
|
|
76
|
-
function enrollInbox(uint32 _domain, address _inbox) external onlyOwner {
|
|
77
|
-
require(Address.isContract(_inbox), "inbox !contract");
|
|
78
|
-
require(!isInbox(_inbox), "already inbox");
|
|
79
|
-
// add inbox and domain to two-way mapping
|
|
80
|
-
inboxToDomain[_inbox] = _domain;
|
|
81
|
-
domainToInboxes[_domain].add(_inbox);
|
|
82
|
-
emit InboxEnrolled(_domain, _inbox);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* @notice Allow Owner to un-enroll Inbox contract
|
|
87
|
-
* @param _inbox the address of the Inbox
|
|
88
|
-
*/
|
|
89
|
-
function unenrollInbox(address _inbox) external onlyOwner {
|
|
90
|
-
_unenrollInbox(_inbox);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
/**
|
|
94
|
-
* @notice Query local domain from Outbox
|
|
95
|
-
* @return local domain
|
|
96
|
-
*/
|
|
97
|
-
function localDomain() external view override returns (uint32) {
|
|
98
|
-
return outbox.localDomain();
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
/**
|
|
102
|
-
* @notice Returns the Inbox addresses for a given remote domain
|
|
103
|
-
* @return inboxes An array of addresses of the Inboxes
|
|
104
|
-
*/
|
|
105
|
-
function getInboxes(uint32 remoteDomain)
|
|
106
|
-
external
|
|
107
|
-
view
|
|
108
|
-
returns (address[] memory)
|
|
109
|
-
{
|
|
110
|
-
EnumerableSet.AddressSet storage _inboxes = domainToInboxes[
|
|
111
|
-
remoteDomain
|
|
112
|
-
];
|
|
113
|
-
uint256 length = _inboxes.length();
|
|
114
|
-
address[] memory ret = new address[](length);
|
|
115
|
-
for (uint256 i = 0; i < length; i += 1) {
|
|
116
|
-
ret[i] = _inboxes.at(i);
|
|
117
|
-
}
|
|
118
|
-
return ret;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// ============ Public Functions ============
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* @notice Check whether _inbox is enrolled
|
|
125
|
-
* @param _inbox the inbox to check for enrollment
|
|
126
|
-
* @return TRUE iff _inbox is enrolled
|
|
127
|
-
*/
|
|
128
|
-
function isInbox(address _inbox) public view override returns (bool) {
|
|
129
|
-
return inboxToDomain[_inbox] != 0;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
// ============ Internal Functions ============
|
|
133
|
-
|
|
134
|
-
/**
|
|
135
|
-
* @notice Remove the inbox from the two-way mappings
|
|
136
|
-
* @param _inbox inbox to un-enroll
|
|
137
|
-
*/
|
|
138
|
-
function _unenrollInbox(address _inbox) internal {
|
|
139
|
-
uint32 _currentDomain = inboxToDomain[_inbox];
|
|
140
|
-
require(domainToInboxes[_currentDomain].remove(_inbox), "not enrolled");
|
|
141
|
-
domainToInboxes[_currentDomain].remove(_inbox);
|
|
142
|
-
inboxToDomain[_inbox] = 0;
|
|
143
|
-
emit InboxUnenrolled(_currentDomain, _inbox);
|
|
144
|
-
}
|
|
145
|
-
}
|
package/contracts/Inbox.sol
DELETED
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
-
pragma solidity >=0.8.0;
|
|
3
|
-
|
|
4
|
-
// ============ Internal Imports ============
|
|
5
|
-
import {Versioned} from "./upgrade/Versioned.sol";
|
|
6
|
-
import {Mailbox} from "./Mailbox.sol";
|
|
7
|
-
import {MerkleLib} from "./libs/Merkle.sol";
|
|
8
|
-
import {Message} from "./libs/Message.sol";
|
|
9
|
-
import {TypeCasts} from "./libs/TypeCasts.sol";
|
|
10
|
-
import {IMessageRecipient} from "../interfaces/IMessageRecipient.sol";
|
|
11
|
-
import {IInbox} from "../interfaces/IInbox.sol";
|
|
12
|
-
|
|
13
|
-
// ============ External Imports ============
|
|
14
|
-
import {ReentrancyGuardUpgradeable} from "@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable.sol";
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* @title Inbox
|
|
18
|
-
* @author Celo Labs Inc.
|
|
19
|
-
* @notice Track root updates on Outbox, prove and dispatch messages to end
|
|
20
|
-
* recipients.
|
|
21
|
-
*/
|
|
22
|
-
contract Inbox is IInbox, ReentrancyGuardUpgradeable, Versioned, Mailbox {
|
|
23
|
-
// ============ Libraries ============
|
|
24
|
-
|
|
25
|
-
using MerkleLib for MerkleLib.Tree;
|
|
26
|
-
using Message for bytes;
|
|
27
|
-
using TypeCasts for bytes32;
|
|
28
|
-
|
|
29
|
-
// ============ Enums ============
|
|
30
|
-
|
|
31
|
-
// Status of Message:
|
|
32
|
-
// 0 - None - message has not been processed
|
|
33
|
-
// 1 - Processed - message has been dispatched to recipient
|
|
34
|
-
enum MessageStatus {
|
|
35
|
-
None,
|
|
36
|
-
Processed
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
// ============ Public Storage ============
|
|
40
|
-
|
|
41
|
-
// Domain of outbox chain
|
|
42
|
-
uint32 public override remoteDomain;
|
|
43
|
-
// Mapping of message leaves to MessageStatus
|
|
44
|
-
mapping(bytes32 => MessageStatus) public messages;
|
|
45
|
-
|
|
46
|
-
// ============ Upgrade Gap ============
|
|
47
|
-
|
|
48
|
-
// gap for upgrade safety
|
|
49
|
-
uint256[48] private __GAP;
|
|
50
|
-
|
|
51
|
-
// ============ Events ============
|
|
52
|
-
|
|
53
|
-
/**
|
|
54
|
-
* @notice Emitted when message is processed
|
|
55
|
-
* @dev This event allows watchers to observe the merkle proof they need
|
|
56
|
-
* to prove fraud on the Outbox.
|
|
57
|
-
* @param messageHash Hash of message that was processed.
|
|
58
|
-
*/
|
|
59
|
-
event Process(bytes32 indexed messageHash);
|
|
60
|
-
|
|
61
|
-
// ============ Constructor ============
|
|
62
|
-
|
|
63
|
-
// solhint-disable-next-line no-empty-blocks
|
|
64
|
-
constructor(uint32 _localDomain) Mailbox(_localDomain) {}
|
|
65
|
-
|
|
66
|
-
// ============ Initializer ============
|
|
67
|
-
|
|
68
|
-
function initialize(uint32 _remoteDomain, address _validatorManager)
|
|
69
|
-
external
|
|
70
|
-
initializer
|
|
71
|
-
{
|
|
72
|
-
__ReentrancyGuard_init();
|
|
73
|
-
__Mailbox_initialize(_validatorManager);
|
|
74
|
-
remoteDomain = _remoteDomain;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
// ============ External Functions ============
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* @notice Attempts to process the provided formatted `message`. Performs
|
|
81
|
-
* verification against root of the proof
|
|
82
|
-
* @dev Called by the validator manager, which is responsible for verifying a
|
|
83
|
-
* quorum of validator signatures on the checkpoint.
|
|
84
|
-
* @dev Reverts if verification of the message fails.
|
|
85
|
-
* @param _root The merkle root of the checkpoint used to prove message inclusion.
|
|
86
|
-
* @param _index The index of the checkpoint used to prove message inclusion.
|
|
87
|
-
* @param _message Formatted message (refer to Mailbox.sol Message library)
|
|
88
|
-
* @param _proof Merkle proof of inclusion for message's leaf
|
|
89
|
-
* @param _leafIndex Index of leaf in outbox's merkle tree
|
|
90
|
-
*/
|
|
91
|
-
function process(
|
|
92
|
-
bytes32 _root,
|
|
93
|
-
uint256 _index,
|
|
94
|
-
bytes calldata _message,
|
|
95
|
-
bytes32[32] calldata _proof,
|
|
96
|
-
uint256 _leafIndex
|
|
97
|
-
) external override nonReentrant onlyValidatorManager {
|
|
98
|
-
require(_index >= _leafIndex, "!index");
|
|
99
|
-
bytes32 _messageHash = _message.leaf(_leafIndex);
|
|
100
|
-
// ensure that message has not been processed
|
|
101
|
-
require(
|
|
102
|
-
messages[_messageHash] == MessageStatus.None,
|
|
103
|
-
"!MessageStatus.None"
|
|
104
|
-
);
|
|
105
|
-
// calculate the expected root based on the proof
|
|
106
|
-
bytes32 _calculatedRoot = MerkleLib.branchRoot(
|
|
107
|
-
_messageHash,
|
|
108
|
-
_proof,
|
|
109
|
-
_leafIndex
|
|
110
|
-
);
|
|
111
|
-
// verify the merkle proof
|
|
112
|
-
require(_calculatedRoot == _root, "!proof");
|
|
113
|
-
_process(_message, _messageHash);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
// ============ Internal Functions ============
|
|
117
|
-
|
|
118
|
-
/**
|
|
119
|
-
* @notice Marks a message as processed and calls handle on the recipient
|
|
120
|
-
* @dev Internal function that can be called by contracts like TestInbox
|
|
121
|
-
* @param _message Formatted message (refer to Mailbox.sol Message library)
|
|
122
|
-
* @param _messageHash keccak256 hash of the message
|
|
123
|
-
*/
|
|
124
|
-
function _process(bytes calldata _message, bytes32 _messageHash) internal {
|
|
125
|
-
(
|
|
126
|
-
uint32 origin,
|
|
127
|
-
bytes32 sender,
|
|
128
|
-
uint32 destination,
|
|
129
|
-
bytes32 recipient,
|
|
130
|
-
bytes calldata body
|
|
131
|
-
) = _message.destructure();
|
|
132
|
-
|
|
133
|
-
// ensure message came from the correct domain
|
|
134
|
-
require(origin == remoteDomain, "!origin");
|
|
135
|
-
// ensure message was meant for this domain
|
|
136
|
-
require(destination == localDomain, "!destination");
|
|
137
|
-
|
|
138
|
-
// update message status as processed
|
|
139
|
-
messages[_messageHash] = MessageStatus.Processed;
|
|
140
|
-
|
|
141
|
-
IMessageRecipient(recipient.bytes32ToAddress()).handle(
|
|
142
|
-
origin,
|
|
143
|
-
sender,
|
|
144
|
-
body
|
|
145
|
-
);
|
|
146
|
-
emit Process(_messageHash);
|
|
147
|
-
}
|
|
148
|
-
}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
-
pragma solidity >=0.8.0;
|
|
3
|
-
|
|
4
|
-
// ============ Internal Imports ============
|
|
5
|
-
import {MerkleLib} from "./libs/Merkle.sol";
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* @title MerkleTreeManager
|
|
9
|
-
* @author Celo Labs Inc.
|
|
10
|
-
* @notice Contains a Merkle tree instance and
|
|
11
|
-
* exposes view functions for the tree.
|
|
12
|
-
*/
|
|
13
|
-
contract MerkleTreeManager {
|
|
14
|
-
// ============ Libraries ============
|
|
15
|
-
|
|
16
|
-
using MerkleLib for MerkleLib.Tree;
|
|
17
|
-
MerkleLib.Tree public tree;
|
|
18
|
-
|
|
19
|
-
// ============ Upgrade Gap ============
|
|
20
|
-
|
|
21
|
-
// gap for upgrade safety
|
|
22
|
-
uint256[49] private __GAP;
|
|
23
|
-
|
|
24
|
-
// ============ Public Functions ============
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* @notice Calculates and returns tree's current root
|
|
28
|
-
*/
|
|
29
|
-
function root() public view returns (bytes32) {
|
|
30
|
-
return tree.root();
|
|
31
|
-
}
|
|
32
|
-
}
|
package/contracts/Outbox.sol
DELETED
|
@@ -1,191 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
-
pragma solidity >=0.8.0;
|
|
3
|
-
|
|
4
|
-
// ============ Internal Imports ============
|
|
5
|
-
import {Versioned} from "./upgrade/Versioned.sol";
|
|
6
|
-
import {Mailbox} from "./Mailbox.sol";
|
|
7
|
-
import {MerkleLib} from "./libs/Merkle.sol";
|
|
8
|
-
import {Message} from "./libs/Message.sol";
|
|
9
|
-
import {TypeCasts} from "./libs/TypeCasts.sol";
|
|
10
|
-
import {MerkleTreeManager} from "./MerkleTreeManager.sol";
|
|
11
|
-
import {IOutbox} from "../interfaces/IOutbox.sol";
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* @title Outbox
|
|
15
|
-
* @author Celo Labs Inc.
|
|
16
|
-
* @notice Accepts messages to be dispatched to remote chains,
|
|
17
|
-
* constructs a Merkle tree of the messages,
|
|
18
|
-
* and accepts signatures from a bonded Validator
|
|
19
|
-
* which notarize the Merkle tree roots.
|
|
20
|
-
* Accepts submissions of fraudulent signatures
|
|
21
|
-
* by the Validator and slashes the Validator in this case.
|
|
22
|
-
*/
|
|
23
|
-
contract Outbox is IOutbox, Versioned, MerkleTreeManager, Mailbox {
|
|
24
|
-
// ============ Libraries ============
|
|
25
|
-
|
|
26
|
-
using MerkleLib for MerkleLib.Tree;
|
|
27
|
-
using TypeCasts for address;
|
|
28
|
-
|
|
29
|
-
// ============ Constants ============
|
|
30
|
-
|
|
31
|
-
// Maximum bytes per message = 2 KiB
|
|
32
|
-
// (somewhat arbitrarily set to begin)
|
|
33
|
-
uint256 public constant MAX_MESSAGE_BODY_BYTES = 2 * 2**10;
|
|
34
|
-
|
|
35
|
-
// ============ Enums ============
|
|
36
|
-
|
|
37
|
-
// States:
|
|
38
|
-
// 0 - UnInitialized - before initialize function is called
|
|
39
|
-
// note: the contract is initialized at deploy time, so it should never be in this state
|
|
40
|
-
// 1 - Active - as long as the contract has not become fraudulent
|
|
41
|
-
// 2 - Failed - after a valid fraud proof has been submitted;
|
|
42
|
-
// contract will no longer accept updates or new messages
|
|
43
|
-
enum States {
|
|
44
|
-
UnInitialized,
|
|
45
|
-
Active,
|
|
46
|
-
Failed
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
// ============ Public Storage Variables ============
|
|
50
|
-
|
|
51
|
-
// Cached checkpoints, mapping root => leaf index.
|
|
52
|
-
// Cached checkpoints must have index > 0 as the presence of such
|
|
53
|
-
// a checkpoint cannot be distinguished from its absence.
|
|
54
|
-
mapping(bytes32 => uint256) public cachedCheckpoints;
|
|
55
|
-
// The latest cached root
|
|
56
|
-
bytes32 public latestCachedRoot;
|
|
57
|
-
// Current state of contract
|
|
58
|
-
States public state;
|
|
59
|
-
|
|
60
|
-
// ============ Upgrade Gap ============
|
|
61
|
-
|
|
62
|
-
// gap for upgrade safety
|
|
63
|
-
uint256[47] private __GAP;
|
|
64
|
-
|
|
65
|
-
// ============ Events ============
|
|
66
|
-
|
|
67
|
-
/**
|
|
68
|
-
* @notice Emitted when a checkpoint is cached.
|
|
69
|
-
* @param root Merkle root
|
|
70
|
-
* @param index Leaf index
|
|
71
|
-
*/
|
|
72
|
-
event CheckpointCached(bytes32 indexed root, uint256 indexed index);
|
|
73
|
-
|
|
74
|
-
/**
|
|
75
|
-
* @notice Emitted when a new message is dispatched via Abacus
|
|
76
|
-
* @param leafIndex Index of message's leaf in merkle tree
|
|
77
|
-
* @param message Raw bytes of message
|
|
78
|
-
*/
|
|
79
|
-
event Dispatch(uint256 indexed leafIndex, bytes message);
|
|
80
|
-
|
|
81
|
-
event Fail();
|
|
82
|
-
|
|
83
|
-
// ============ Constructor ============
|
|
84
|
-
|
|
85
|
-
constructor(uint32 _localDomain) Mailbox(_localDomain) {} // solhint-disable-line no-empty-blocks
|
|
86
|
-
|
|
87
|
-
// ============ Initializer ============
|
|
88
|
-
|
|
89
|
-
function initialize(address _validatorManager) external initializer {
|
|
90
|
-
__Mailbox_initialize(_validatorManager);
|
|
91
|
-
state = States.Active;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
// ============ Modifiers ============
|
|
95
|
-
|
|
96
|
-
/**
|
|
97
|
-
* @notice Ensures that contract state != FAILED when the function is called
|
|
98
|
-
*/
|
|
99
|
-
modifier notFailed() {
|
|
100
|
-
require(state != States.Failed, "failed state");
|
|
101
|
-
_;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
// ============ External Functions ============
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
* @notice Dispatch the message it to the destination domain & recipient
|
|
108
|
-
* @dev Format the message, insert its hash into Merkle tree,
|
|
109
|
-
* and emit `Dispatch` event with message information.
|
|
110
|
-
* @param _destinationDomain Domain of destination chain
|
|
111
|
-
* @param _recipientAddress Address of recipient on destination chain as bytes32
|
|
112
|
-
* @param _messageBody Raw bytes content of message
|
|
113
|
-
* @return The leaf index of the dispatched message's hash in the Merkle tree.
|
|
114
|
-
*/
|
|
115
|
-
function dispatch(
|
|
116
|
-
uint32 _destinationDomain,
|
|
117
|
-
bytes32 _recipientAddress,
|
|
118
|
-
bytes calldata _messageBody
|
|
119
|
-
) external override notFailed returns (uint256) {
|
|
120
|
-
require(_messageBody.length <= MAX_MESSAGE_BODY_BYTES, "msg too long");
|
|
121
|
-
// The leaf has not been inserted yet at this point
|
|
122
|
-
uint256 _leafIndex = count();
|
|
123
|
-
// format the message into packed bytes
|
|
124
|
-
bytes memory _message = Message.formatMessage(
|
|
125
|
-
localDomain,
|
|
126
|
-
msg.sender.addressToBytes32(),
|
|
127
|
-
_destinationDomain,
|
|
128
|
-
_recipientAddress,
|
|
129
|
-
_messageBody
|
|
130
|
-
);
|
|
131
|
-
// insert the hashed message into the Merkle tree
|
|
132
|
-
bytes32 _messageHash = keccak256(
|
|
133
|
-
abi.encodePacked(_message, _leafIndex)
|
|
134
|
-
);
|
|
135
|
-
tree.insert(_messageHash);
|
|
136
|
-
emit Dispatch(_leafIndex, _message);
|
|
137
|
-
return _leafIndex;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
/**
|
|
141
|
-
* @notice Caches the current merkle root and index.
|
|
142
|
-
* @dev emits CheckpointCached event
|
|
143
|
-
*/
|
|
144
|
-
function cacheCheckpoint() external override notFailed {
|
|
145
|
-
(bytes32 _root, uint256 _index) = latestCheckpoint();
|
|
146
|
-
require(_index > 0, "!index");
|
|
147
|
-
cachedCheckpoints[_root] = _index;
|
|
148
|
-
latestCachedRoot = _root;
|
|
149
|
-
emit CheckpointCached(_root, _index);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
/**
|
|
153
|
-
* @notice Set contract state to FAILED.
|
|
154
|
-
* @dev Called by the validator manager when fraud is proven.
|
|
155
|
-
*/
|
|
156
|
-
function fail() external override onlyValidatorManager {
|
|
157
|
-
// set contract to FAILED
|
|
158
|
-
state = States.Failed;
|
|
159
|
-
emit Fail();
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
/**
|
|
163
|
-
* @notice Returns the latest entry in the checkpoint cache.
|
|
164
|
-
* @return root Latest cached root
|
|
165
|
-
* @return index Latest cached index
|
|
166
|
-
*/
|
|
167
|
-
function latestCachedCheckpoint()
|
|
168
|
-
external
|
|
169
|
-
view
|
|
170
|
-
returns (bytes32 root, uint256 index)
|
|
171
|
-
{
|
|
172
|
-
root = latestCachedRoot;
|
|
173
|
-
index = cachedCheckpoints[root];
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
/**
|
|
177
|
-
* @notice Returns the number of inserted leaves in the tree
|
|
178
|
-
*/
|
|
179
|
-
function count() public view returns (uint256) {
|
|
180
|
-
return tree.count;
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
/**
|
|
184
|
-
* @notice Returns a checkpoint representing the current merkle tree.
|
|
185
|
-
* @return root The root of the Outbox's merkle tree.
|
|
186
|
-
* @return index The index of the last element in the tree.
|
|
187
|
-
*/
|
|
188
|
-
function latestCheckpoint() public view returns (bytes32, uint256) {
|
|
189
|
-
return (root(), count() - 1);
|
|
190
|
-
}
|
|
191
|
-
}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.0;
|
|
3
|
-
|
|
4
|
-
import {TypeCasts} from "../libs/TypeCasts.sol";
|
|
5
|
-
import {IMessageRecipient} from "../../interfaces/IMessageRecipient.sol";
|
|
6
|
-
|
|
7
|
-
contract MockInbox {
|
|
8
|
-
using TypeCasts for bytes32;
|
|
9
|
-
|
|
10
|
-
struct PendingMessage {
|
|
11
|
-
uint32 originDomain;
|
|
12
|
-
bytes32 sender;
|
|
13
|
-
bytes32 recipient;
|
|
14
|
-
bytes messageBody;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
mapping(uint256 => PendingMessage) pendingMessages;
|
|
18
|
-
uint256 totalMessages = 0;
|
|
19
|
-
uint256 messageProcessed = 0;
|
|
20
|
-
|
|
21
|
-
function addPendingMessage(
|
|
22
|
-
uint32 _originDomain,
|
|
23
|
-
bytes32 _sender,
|
|
24
|
-
bytes32 _recipient,
|
|
25
|
-
bytes memory _messageBody
|
|
26
|
-
) external {
|
|
27
|
-
pendingMessages[totalMessages] = PendingMessage(
|
|
28
|
-
_originDomain,
|
|
29
|
-
_sender,
|
|
30
|
-
_recipient,
|
|
31
|
-
_messageBody
|
|
32
|
-
);
|
|
33
|
-
totalMessages += 1;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
function processNextPendingMessage() public {
|
|
37
|
-
PendingMessage memory pendingMessage = pendingMessages[
|
|
38
|
-
messageProcessed
|
|
39
|
-
];
|
|
40
|
-
|
|
41
|
-
address recipient = pendingMessage.recipient.bytes32ToAddress();
|
|
42
|
-
|
|
43
|
-
IMessageRecipient(recipient).handle(
|
|
44
|
-
// This is completely arbitrary and consumers should not rely
|
|
45
|
-
// on domain handling in the mock mailbox contracts.
|
|
46
|
-
pendingMessage.originDomain,
|
|
47
|
-
pendingMessage.sender,
|
|
48
|
-
pendingMessage.messageBody
|
|
49
|
-
);
|
|
50
|
-
messageProcessed += 1;
|
|
51
|
-
}
|
|
52
|
-
}
|