@hyperlane-xyz/core 0.5.0-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 +14 -0
- package/contracts/AbacusConnectionManager.sol +168 -0
- package/contracts/Inbox.sol +148 -0
- package/contracts/InterchainGasPaymaster.sol +67 -0
- package/contracts/Mailbox.sol +93 -0
- package/contracts/MerkleTreeManager.sol +32 -0
- package/contracts/Outbox.sol +191 -0
- package/contracts/libs/Merkle.sol +208 -0
- package/contracts/libs/Message.sol +122 -0
- package/contracts/libs/TypeCasts.sol +34 -0
- package/contracts/mock/MockInbox.sol +49 -0
- package/contracts/mock/MockOutbox.sol +26 -0
- package/contracts/test/MysteryMath.sol +21 -0
- package/contracts/test/MysteryMathV1.sol +22 -0
- package/contracts/test/MysteryMathV2.sol +22 -0
- package/contracts/test/TestInbox.sol +54 -0
- package/contracts/test/TestMailbox.sol +12 -0
- package/contracts/test/TestMerkle.sol +30 -0
- package/contracts/test/TestMessage.sol +64 -0
- package/contracts/test/TestMultisigValidatorManager.sol +26 -0
- package/contracts/test/TestOutbox.sol +46 -0
- package/contracts/test/TestRecipient.sol +18 -0
- package/contracts/test/TestSendReceiver.sol +65 -0
- package/contracts/test/TestValidatorManager.sol +21 -0
- package/contracts/test/bad-recipient/BadRecipient1.sol +16 -0
- package/contracts/test/bad-recipient/BadRecipient2.sol +6 -0
- package/contracts/test/bad-recipient/BadRecipient3.sol +17 -0
- package/contracts/test/bad-recipient/BadRecipient5.sol +14 -0
- package/contracts/test/bad-recipient/BadRecipient6.sol +14 -0
- package/contracts/upgrade/UpgradeBeacon.sol +98 -0
- package/contracts/upgrade/UpgradeBeaconController.sol +48 -0
- package/contracts/upgrade/UpgradeBeaconProxy.sol +176 -0
- package/contracts/upgrade/Versioned.sol +10 -0
- package/contracts/validator-manager/InboxValidatorManager.sol +58 -0
- package/contracts/validator-manager/MultisigValidatorManager.sol +271 -0
- package/contracts/validator-manager/OutboxValidatorManager.sol +244 -0
- package/dist/@openzeppelin/contracts/access/Ownable.d.ts +90 -0
- package/dist/@openzeppelin/contracts/access/Ownable.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts/access/Ownable.js +4 -0
- package/dist/@openzeppelin/contracts/access/Ownable.js.map +1 -0
- package/dist/@openzeppelin/contracts/access/index.d.ts +2 -0
- package/dist/@openzeppelin/contracts/access/index.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts/access/index.js +3 -0
- package/dist/@openzeppelin/contracts/access/index.js.map +1 -0
- package/dist/@openzeppelin/contracts/index.d.ts +3 -0
- package/dist/@openzeppelin/contracts/index.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts/index.js +4 -0
- package/dist/@openzeppelin/contracts/index.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.d.ts +99 -0
- package/dist/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.js +4 -0
- package/dist/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/access/index.d.ts +2 -0
- package/dist/@openzeppelin/contracts-upgradeable/access/index.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/access/index.js +3 -0
- package/dist/@openzeppelin/contracts-upgradeable/access/index.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/index.d.ts +9 -0
- package/dist/@openzeppelin/contracts-upgradeable/index.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/index.js +4 -0
- package/dist/@openzeppelin/contracts-upgradeable/index.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/index.d.ts +3 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/index.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/index.js +4 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/index.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.d.ts +40 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.js +4 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/utils/index.d.ts +2 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/utils/index.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/utils/index.js +3 -0
- package/dist/@openzeppelin/contracts-upgradeable/proxy/utils/index.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable.d.ts +40 -0
- package/dist/@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable.js +4 -0
- package/dist/@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/security/index.d.ts +2 -0
- package/dist/@openzeppelin/contracts-upgradeable/security/index.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/security/index.js +3 -0
- package/dist/@openzeppelin/contracts-upgradeable/security/index.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable.d.ts +40 -0
- package/dist/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable.js +4 -0
- package/dist/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable.js.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/utils/index.d.ts +2 -0
- package/dist/@openzeppelin/contracts-upgradeable/utils/index.d.ts.map +1 -0
- package/dist/@openzeppelin/contracts-upgradeable/utils/index.js +3 -0
- package/dist/@openzeppelin/contracts-upgradeable/utils/index.js.map +1 -0
- package/dist/@openzeppelin/index.d.ts +5 -0
- package/dist/@openzeppelin/index.d.ts.map +1 -0
- package/dist/@openzeppelin/index.js +4 -0
- package/dist/@openzeppelin/index.js.map +1 -0
- package/dist/common.d.ts +22 -0
- package/dist/common.d.ts.map +1 -0
- package/dist/common.js +4 -0
- package/dist/common.js.map +1 -0
- package/dist/contracts/AbacusConnectionManager.d.ts +221 -0
- package/dist/contracts/AbacusConnectionManager.d.ts.map +1 -0
- package/dist/contracts/AbacusConnectionManager.js +4 -0
- package/dist/contracts/AbacusConnectionManager.js.map +1 -0
- package/dist/contracts/Inbox.d.ts +207 -0
- package/dist/contracts/Inbox.d.ts.map +1 -0
- package/dist/contracts/Inbox.js +4 -0
- package/dist/contracts/Inbox.js.map +1 -0
- package/dist/contracts/InterchainGasPaymaster.d.ts +162 -0
- package/dist/contracts/InterchainGasPaymaster.d.ts.map +1 -0
- package/dist/contracts/InterchainGasPaymaster.js +4 -0
- package/dist/contracts/InterchainGasPaymaster.js.map +1 -0
- package/dist/contracts/Mailbox.d.ts +142 -0
- package/dist/contracts/Mailbox.d.ts.map +1 -0
- package/dist/contracts/Mailbox.js +4 -0
- package/dist/contracts/Mailbox.js.map +1 -0
- package/dist/contracts/MerkleTreeManager.d.ts +53 -0
- package/dist/contracts/MerkleTreeManager.d.ts.map +1 -0
- package/dist/contracts/MerkleTreeManager.js +4 -0
- package/dist/contracts/MerkleTreeManager.js.map +1 -0
- package/dist/contracts/Outbox.d.ts +331 -0
- package/dist/contracts/Outbox.d.ts.map +1 -0
- package/dist/contracts/Outbox.js +4 -0
- package/dist/contracts/Outbox.js.map +1 -0
- package/dist/contracts/index.d.ts +15 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +4 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/mock/MockInbox.d.ts +67 -0
- package/dist/contracts/mock/MockInbox.d.ts.map +1 -0
- package/dist/contracts/mock/MockInbox.js +4 -0
- package/dist/contracts/mock/MockInbox.js.map +1 -0
- package/dist/contracts/mock/MockOutbox.d.ts +51 -0
- package/dist/contracts/mock/MockOutbox.d.ts.map +1 -0
- package/dist/contracts/mock/MockOutbox.js +4 -0
- package/dist/contracts/mock/MockOutbox.js.map +1 -0
- package/dist/contracts/mock/index.d.ts +3 -0
- package/dist/contracts/mock/index.d.ts.map +1 -0
- package/dist/contracts/mock/index.js +3 -0
- package/dist/contracts/mock/index.js.map +1 -0
- package/dist/contracts/test/MysteryMath.d.ts +77 -0
- package/dist/contracts/test/MysteryMath.d.ts.map +1 -0
- package/dist/contracts/test/MysteryMath.js +4 -0
- package/dist/contracts/test/MysteryMath.js.map +1 -0
- package/dist/contracts/test/MysteryMathV1.d.ts +85 -0
- package/dist/contracts/test/MysteryMathV1.d.ts.map +1 -0
- package/dist/contracts/test/MysteryMathV1.js +4 -0
- package/dist/contracts/test/MysteryMathV1.js.map +1 -0
- package/dist/contracts/test/MysteryMathV2.d.ts +85 -0
- package/dist/contracts/test/MysteryMathV2.d.ts.map +1 -0
- package/dist/contracts/test/MysteryMathV2.js +4 -0
- package/dist/contracts/test/MysteryMathV2.js.map +1 -0
- package/dist/contracts/test/TestInbox.d.ts +263 -0
- package/dist/contracts/test/TestInbox.d.ts.map +1 -0
- package/dist/contracts/test/TestInbox.js +4 -0
- package/dist/contracts/test/TestInbox.js.map +1 -0
- package/dist/contracts/test/TestMailbox.d.ts +158 -0
- package/dist/contracts/test/TestMailbox.d.ts.map +1 -0
- package/dist/contracts/test/TestMailbox.js +4 -0
- package/dist/contracts/test/TestMailbox.js.map +1 -0
- package/dist/contracts/test/TestMerkle.d.ts +87 -0
- package/dist/contracts/test/TestMerkle.d.ts.map +1 -0
- package/dist/contracts/test/TestMerkle.js +4 -0
- package/dist/contracts/test/TestMerkle.js.map +1 -0
- package/dist/contracts/test/TestMessage.d.ts +103 -0
- package/dist/contracts/test/TestMessage.d.ts.map +1 -0
- package/dist/contracts/test/TestMessage.js +4 -0
- package/dist/contracts/test/TestMessage.js.map +1 -0
- package/dist/contracts/test/TestMultisigValidatorManager.d.ts +247 -0
- package/dist/contracts/test/TestMultisigValidatorManager.d.ts.map +1 -0
- package/dist/contracts/test/TestMultisigValidatorManager.js +4 -0
- package/dist/contracts/test/TestMultisigValidatorManager.js.map +1 -0
- package/dist/contracts/test/TestOutbox.d.ts +371 -0
- package/dist/contracts/test/TestOutbox.d.ts.map +1 -0
- package/dist/contracts/test/TestOutbox.js +4 -0
- package/dist/contracts/test/TestOutbox.js.map +1 -0
- package/dist/contracts/test/TestRecipient.d.ts +67 -0
- package/dist/contracts/test/TestRecipient.d.ts.map +1 -0
- package/dist/contracts/test/TestRecipient.js +4 -0
- package/dist/contracts/test/TestRecipient.js.map +1 -0
- package/dist/contracts/test/TestSendReceiver.d.ts +78 -0
- package/dist/contracts/test/TestSendReceiver.d.ts.map +1 -0
- package/dist/contracts/test/TestSendReceiver.js +4 -0
- package/dist/contracts/test/TestSendReceiver.js.map +1 -0
- package/dist/contracts/test/TestValidatorManager.d.ts +58 -0
- package/dist/contracts/test/TestValidatorManager.d.ts.map +1 -0
- package/dist/contracts/test/TestValidatorManager.js +4 -0
- package/dist/contracts/test/TestValidatorManager.js.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient1.d.ts +43 -0
- package/dist/contracts/test/bad-recipient/BadRecipient1.d.ts.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient1.js +4 -0
- package/dist/contracts/test/bad-recipient/BadRecipient1.js.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient2.d.ts +43 -0
- package/dist/contracts/test/bad-recipient/BadRecipient2.d.ts.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient2.js +4 -0
- package/dist/contracts/test/bad-recipient/BadRecipient2.js.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient3.d.ts +43 -0
- package/dist/contracts/test/bad-recipient/BadRecipient3.d.ts.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient3.js +4 -0
- package/dist/contracts/test/bad-recipient/BadRecipient3.js.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient5.d.ts +43 -0
- package/dist/contracts/test/bad-recipient/BadRecipient5.d.ts.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient5.js +4 -0
- package/dist/contracts/test/bad-recipient/BadRecipient5.js.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient6.d.ts +43 -0
- package/dist/contracts/test/bad-recipient/BadRecipient6.d.ts.map +1 -0
- package/dist/contracts/test/bad-recipient/BadRecipient6.js +4 -0
- package/dist/contracts/test/bad-recipient/BadRecipient6.js.map +1 -0
- package/dist/contracts/test/bad-recipient/index.d.ts +6 -0
- package/dist/contracts/test/bad-recipient/index.d.ts.map +1 -0
- package/dist/contracts/test/bad-recipient/index.js +3 -0
- package/dist/contracts/test/bad-recipient/index.js.map +1 -0
- package/dist/contracts/test/index.d.ts +15 -0
- package/dist/contracts/test/index.d.ts.map +1 -0
- package/dist/contracts/test/index.js +4 -0
- package/dist/contracts/test/index.js.map +1 -0
- package/dist/contracts/upgrade/UpgradeBeacon.d.ts +40 -0
- package/dist/contracts/upgrade/UpgradeBeacon.d.ts.map +1 -0
- package/dist/contracts/upgrade/UpgradeBeacon.js +4 -0
- package/dist/contracts/upgrade/UpgradeBeacon.js.map +1 -0
- package/dist/contracts/upgrade/UpgradeBeaconController.d.ts +119 -0
- package/dist/contracts/upgrade/UpgradeBeaconController.d.ts.map +1 -0
- package/dist/contracts/upgrade/UpgradeBeaconController.js +4 -0
- package/dist/contracts/upgrade/UpgradeBeaconController.js.map +1 -0
- package/dist/contracts/upgrade/UpgradeBeaconProxy.d.ts +28 -0
- package/dist/contracts/upgrade/UpgradeBeaconProxy.d.ts.map +1 -0
- package/dist/contracts/upgrade/UpgradeBeaconProxy.js +4 -0
- package/dist/contracts/upgrade/UpgradeBeaconProxy.js.map +1 -0
- package/dist/contracts/upgrade/Versioned.d.ts +43 -0
- package/dist/contracts/upgrade/Versioned.d.ts.map +1 -0
- package/dist/contracts/upgrade/Versioned.js +4 -0
- package/dist/contracts/upgrade/Versioned.js.map +1 -0
- package/dist/contracts/upgrade/index.d.ts +5 -0
- package/dist/contracts/upgrade/index.d.ts.map +1 -0
- package/dist/contracts/upgrade/index.js +3 -0
- package/dist/contracts/upgrade/index.js.map +1 -0
- package/dist/contracts/validator-manager/InboxValidatorManager.d.ts +263 -0
- package/dist/contracts/validator-manager/InboxValidatorManager.d.ts.map +1 -0
- package/dist/contracts/validator-manager/InboxValidatorManager.js +4 -0
- package/dist/contracts/validator-manager/InboxValidatorManager.js.map +1 -0
- package/dist/contracts/validator-manager/MultisigValidatorManager.d.ts +239 -0
- package/dist/contracts/validator-manager/MultisigValidatorManager.d.ts.map +1 -0
- package/dist/contracts/validator-manager/MultisigValidatorManager.js +4 -0
- package/dist/contracts/validator-manager/MultisigValidatorManager.js.map +1 -0
- package/dist/contracts/validator-manager/OutboxValidatorManager.d.ts +335 -0
- package/dist/contracts/validator-manager/OutboxValidatorManager.d.ts.map +1 -0
- package/dist/contracts/validator-manager/OutboxValidatorManager.js +4 -0
- package/dist/contracts/validator-manager/OutboxValidatorManager.js.map +1 -0
- package/dist/contracts/validator-manager/index.d.ts +4 -0
- package/dist/contracts/validator-manager/index.d.ts.map +1 -0
- package/dist/contracts/validator-manager/index.js +3 -0
- package/dist/contracts/validator-manager/index.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts/access/Ownable__factory.d.ts +43 -0
- package/dist/factories/@openzeppelin/contracts/access/Ownable__factory.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts/access/Ownable__factory.js +70 -0
- package/dist/factories/@openzeppelin/contracts/access/Ownable__factory.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts/access/index.d.ts +2 -0
- package/dist/factories/@openzeppelin/contracts/access/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts/access/index.js +9 -0
- package/dist/factories/@openzeppelin/contracts/access/index.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts/index.d.ts +2 -0
- package/dist/factories/@openzeppelin/contracts/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts/index.js +31 -0
- package/dist/factories/@openzeppelin/contracts/index.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable__factory.d.ts +43 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable__factory.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable__factory.js +83 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable__factory.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/access/index.d.ts +2 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/access/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/access/index.js +9 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/access/index.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/index.d.ts +5 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/index.js +34 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/index.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/index.d.ts +2 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/index.js +31 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/index.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable__factory.d.ts +19 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable__factory.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable__factory.js +31 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable__factory.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/utils/index.d.ts +2 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/utils/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/utils/index.js +9 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/proxy/utils/index.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable__factory.d.ts +19 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable__factory.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable__factory.js +31 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/security/ReentrancyGuardUpgradeable__factory.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/security/index.d.ts +2 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/security/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/security/index.js +9 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/security/index.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable__factory.d.ts +19 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable__factory.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable__factory.js +31 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable__factory.js.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/utils/index.d.ts +2 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/utils/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/utils/index.js +9 -0
- package/dist/factories/@openzeppelin/contracts-upgradeable/utils/index.js.map +1 -0
- package/dist/factories/@openzeppelin/index.d.ts +3 -0
- package/dist/factories/@openzeppelin/index.d.ts.map +1 -0
- package/dist/factories/@openzeppelin/index.js +32 -0
- package/dist/factories/@openzeppelin/index.js.map +1 -0
- package/dist/factories/contracts/AbacusConnectionManager__factory.d.ts +55 -0
- package/dist/factories/contracts/AbacusConnectionManager__factory.d.ts.map +1 -0
- package/dist/factories/contracts/AbacusConnectionManager__factory.js +295 -0
- package/dist/factories/contracts/AbacusConnectionManager__factory.js.map +1 -0
- package/dist/factories/contracts/Inbox__factory.d.ts +59 -0
- package/dist/factories/contracts/Inbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/Inbox__factory.js +278 -0
- package/dist/factories/contracts/Inbox__factory.js.map +1 -0
- package/dist/factories/contracts/InterchainGasPaymaster__factory.d.ts +62 -0
- package/dist/factories/contracts/InterchainGasPaymaster__factory.d.ts.map +1 -0
- package/dist/factories/contracts/InterchainGasPaymaster__factory.js +173 -0
- package/dist/factories/contracts/InterchainGasPaymaster__factory.js.map +1 -0
- package/dist/factories/contracts/Mailbox__factory.d.ts +43 -0
- package/dist/factories/contracts/Mailbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/Mailbox__factory.js +135 -0
- package/dist/factories/contracts/Mailbox__factory.js.map +1 -0
- package/dist/factories/contracts/MerkleTreeManager__factory.d.ts +31 -0
- package/dist/factories/contracts/MerkleTreeManager__factory.d.ts.map +1 -0
- package/dist/factories/contracts/MerkleTreeManager__factory.js +67 -0
- package/dist/factories/contracts/MerkleTreeManager__factory.js.map +1 -0
- package/dist/factories/contracts/Outbox__factory.d.ts +59 -0
- package/dist/factories/contracts/Outbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/Outbox__factory.js +415 -0
- package/dist/factories/contracts/Outbox__factory.js.map +1 -0
- package/dist/factories/contracts/index.d.ts +11 -0
- package/dist/factories/contracts/index.d.ts.map +1 -0
- package/dist/factories/contracts/index.js +46 -0
- package/dist/factories/contracts/index.js.map +1 -0
- package/dist/factories/contracts/mock/MockInbox__factory.d.ts +31 -0
- package/dist/factories/contracts/mock/MockInbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/mock/MockInbox__factory.js +71 -0
- package/dist/factories/contracts/mock/MockInbox__factory.js.map +1 -0
- package/dist/factories/contracts/mock/MockOutbox__factory.d.ts +41 -0
- package/dist/factories/contracts/mock/MockOutbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/mock/MockOutbox__factory.js +75 -0
- package/dist/factories/contracts/mock/MockOutbox__factory.js.map +1 -0
- package/dist/factories/contracts/mock/index.d.ts +3 -0
- package/dist/factories/contracts/mock/index.d.ts.map +1 -0
- package/dist/factories/contracts/mock/index.js +11 -0
- package/dist/factories/contracts/mock/index.js.map +1 -0
- package/dist/factories/contracts/test/MysteryMathV1__factory.d.ts +41 -0
- package/dist/factories/contracts/test/MysteryMathV1__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/MysteryMathV1__factory.js +122 -0
- package/dist/factories/contracts/test/MysteryMathV1__factory.js.map +1 -0
- package/dist/factories/contracts/test/MysteryMathV2__factory.d.ts +41 -0
- package/dist/factories/contracts/test/MysteryMathV2__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/MysteryMathV2__factory.js +122 -0
- package/dist/factories/contracts/test/MysteryMathV2__factory.js.map +1 -0
- package/dist/factories/contracts/test/MysteryMath__factory.d.ts +23 -0
- package/dist/factories/contracts/test/MysteryMath__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/MysteryMath__factory.js +81 -0
- package/dist/factories/contracts/test/MysteryMath__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestInbox__factory.d.ts +59 -0
- package/dist/factories/contracts/test/TestInbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestInbox__factory.js +371 -0
- package/dist/factories/contracts/test/TestInbox__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestMailbox__factory.d.ts +66 -0
- package/dist/factories/contracts/test/TestMailbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestMailbox__factory.js +182 -0
- package/dist/factories/contracts/test/TestMailbox__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestMerkle__factory.d.ts +41 -0
- package/dist/factories/contracts/test/TestMerkle__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestMerkle__factory.js +127 -0
- package/dist/factories/contracts/test/TestMerkle__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestMessage__factory.d.ts +35 -0
- package/dist/factories/contracts/test/TestMessage__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestMessage__factory.js +179 -0
- package/dist/factories/contracts/test/TestMessage__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestMultisigValidatorManager__factory.d.ts +59 -0
- package/dist/factories/contracts/test/TestMultisigValidatorManager__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestMultisigValidatorManager__factory.js +349 -0
- package/dist/factories/contracts/test/TestMultisigValidatorManager__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestOutbox__factory.d.ts +59 -0
- package/dist/factories/contracts/test/TestOutbox__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestOutbox__factory.js +483 -0
- package/dist/factories/contracts/test/TestOutbox__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestRecipient__factory.d.ts +41 -0
- package/dist/factories/contracts/test/TestRecipient__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestRecipient__factory.js +90 -0
- package/dist/factories/contracts/test/TestRecipient__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestSendReceiver__factory.d.ts +44 -0
- package/dist/factories/contracts/test/TestSendReceiver__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestSendReceiver__factory.js +105 -0
- package/dist/factories/contracts/test/TestSendReceiver__factory.js.map +1 -0
- package/dist/factories/contracts/test/TestValidatorManager__factory.d.ts +31 -0
- package/dist/factories/contracts/test/TestValidatorManager__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/TestValidatorManager__factory.js +79 -0
- package/dist/factories/contracts/test/TestValidatorManager__factory.js.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient1__factory.d.ts +31 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient1__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient1__factory.js +64 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient1__factory.js.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient2__factory.d.ts +31 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient2__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient2__factory.js +59 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient2__factory.js.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient3__factory.d.ts +31 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient3__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient3__factory.js +64 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient3__factory.js.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient5__factory.d.ts +31 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient5__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient5__factory.js +64 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient5__factory.js.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient6__factory.d.ts +31 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient6__factory.d.ts.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient6__factory.js +64 -0
- package/dist/factories/contracts/test/bad-recipient/BadRecipient6__factory.js.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/index.d.ts +6 -0
- package/dist/factories/contracts/test/bad-recipient/index.d.ts.map +1 -0
- package/dist/factories/contracts/test/bad-recipient/index.js +17 -0
- package/dist/factories/contracts/test/bad-recipient/index.js.map +1 -0
- package/dist/factories/contracts/test/index.d.ts +14 -0
- package/dist/factories/contracts/test/index.d.ts.map +1 -0
- package/dist/factories/contracts/test/index.js +55 -0
- package/dist/factories/contracts/test/index.js.map +1 -0
- package/dist/factories/contracts/upgrade/UpgradeBeaconController__factory.d.ts +55 -0
- package/dist/factories/contracts/upgrade/UpgradeBeaconController__factory.d.ts.map +1 -0
- package/dist/factories/contracts/upgrade/UpgradeBeaconController__factory.js +130 -0
- package/dist/factories/contracts/upgrade/UpgradeBeaconController__factory.js.map +1 -0
- package/dist/factories/contracts/upgrade/UpgradeBeaconProxy__factory.d.ts +33 -0
- package/dist/factories/contracts/upgrade/UpgradeBeaconProxy__factory.d.ts.map +1 -0
- package/dist/factories/contracts/upgrade/UpgradeBeaconProxy__factory.js +65 -0
- package/dist/factories/contracts/upgrade/UpgradeBeaconProxy__factory.js.map +1 -0
- package/dist/factories/contracts/upgrade/UpgradeBeacon__factory.d.ts +48 -0
- package/dist/factories/contracts/upgrade/UpgradeBeacon__factory.d.ts.map +1 -0
- package/dist/factories/contracts/upgrade/UpgradeBeacon__factory.js +74 -0
- package/dist/factories/contracts/upgrade/UpgradeBeacon__factory.js.map +1 -0
- package/dist/factories/contracts/upgrade/Versioned__factory.d.ts +31 -0
- package/dist/factories/contracts/upgrade/Versioned__factory.d.ts.map +1 -0
- package/dist/factories/contracts/upgrade/Versioned__factory.js +54 -0
- package/dist/factories/contracts/upgrade/Versioned__factory.js.map +1 -0
- package/dist/factories/contracts/upgrade/index.d.ts +5 -0
- package/dist/factories/contracts/upgrade/index.d.ts.map +1 -0
- package/dist/factories/contracts/upgrade/index.js +15 -0
- package/dist/factories/contracts/upgrade/index.js.map +1 -0
- package/dist/factories/contracts/validator-manager/InboxValidatorManager__factory.d.ts +59 -0
- package/dist/factories/contracts/validator-manager/InboxValidatorManager__factory.d.ts.map +1 -0
- package/dist/factories/contracts/validator-manager/InboxValidatorManager__factory.js +373 -0
- package/dist/factories/contracts/validator-manager/InboxValidatorManager__factory.js.map +1 -0
- package/dist/factories/contracts/validator-manager/MultisigValidatorManager__factory.d.ts +36 -0
- package/dist/factories/contracts/validator-manager/MultisigValidatorManager__factory.d.ts.map +1 -0
- package/dist/factories/contracts/validator-manager/MultisigValidatorManager__factory.js +286 -0
- package/dist/factories/contracts/validator-manager/MultisigValidatorManager__factory.js.map +1 -0
- package/dist/factories/contracts/validator-manager/OutboxValidatorManager__factory.d.ts +59 -0
- package/dist/factories/contracts/validator-manager/OutboxValidatorManager__factory.d.ts.map +1 -0
- package/dist/factories/contracts/validator-manager/OutboxValidatorManager__factory.js +560 -0
- package/dist/factories/contracts/validator-manager/OutboxValidatorManager__factory.js.map +1 -0
- package/dist/factories/contracts/validator-manager/index.d.ts +4 -0
- package/dist/factories/contracts/validator-manager/index.d.ts.map +1 -0
- package/dist/factories/contracts/validator-manager/index.js +13 -0
- package/dist/factories/contracts/validator-manager/index.js.map +1 -0
- package/dist/factories/index.d.ts +4 -0
- package/dist/factories/index.d.ts.map +1 -0
- package/dist/factories/index.js +33 -0
- package/dist/factories/index.js.map +1 -0
- package/dist/factories/interfaces/IAbacusConnectionManager__factory.d.ts +23 -0
- package/dist/factories/interfaces/IAbacusConnectionManager__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IAbacusConnectionManager__factory.js +63 -0
- package/dist/factories/interfaces/IAbacusConnectionManager__factory.js.map +1 -0
- package/dist/factories/interfaces/IInbox__factory.d.ts +29 -0
- package/dist/factories/interfaces/IInbox__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IInbox__factory.js +90 -0
- package/dist/factories/interfaces/IInbox__factory.js.map +1 -0
- package/dist/factories/interfaces/IInterchainGasPaymaster__factory.d.ts +19 -0
- package/dist/factories/interfaces/IInterchainGasPaymaster__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IInterchainGasPaymaster__factory.js +41 -0
- package/dist/factories/interfaces/IInterchainGasPaymaster__factory.js.map +1 -0
- package/dist/factories/interfaces/IMailbox__factory.d.ts +19 -0
- package/dist/factories/interfaces/IMailbox__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IMailbox__factory.js +44 -0
- package/dist/factories/interfaces/IMailbox__factory.js.map +1 -0
- package/dist/factories/interfaces/IMessageRecipient__factory.d.ts +19 -0
- package/dist/factories/interfaces/IMessageRecipient__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IMessageRecipient__factory.js +41 -0
- package/dist/factories/interfaces/IMessageRecipient__factory.js.map +1 -0
- package/dist/factories/interfaces/IMultisigValidatorManager__factory.d.ts +19 -0
- package/dist/factories/interfaces/IMultisigValidatorManager__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IMultisigValidatorManager__factory.js +57 -0
- package/dist/factories/interfaces/IMultisigValidatorManager__factory.js.map +1 -0
- package/dist/factories/interfaces/IOutbox__factory.d.ts +23 -0
- package/dist/factories/interfaces/IOutbox__factory.d.ts.map +1 -0
- package/dist/factories/interfaces/IOutbox__factory.js +155 -0
- package/dist/factories/interfaces/IOutbox__factory.js.map +1 -0
- package/dist/factories/interfaces/index.d.ts +8 -0
- package/dist/factories/interfaces/index.d.ts.map +1 -0
- package/dist/factories/interfaces/index.js +21 -0
- package/dist/factories/interfaces/index.js.map +1 -0
- package/dist/index.d.ts +96 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +117 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/IAbacusConnectionManager.d.ts +59 -0
- package/dist/interfaces/IAbacusConnectionManager.d.ts.map +1 -0
- package/dist/interfaces/IAbacusConnectionManager.js +4 -0
- package/dist/interfaces/IAbacusConnectionManager.js.map +1 -0
- package/dist/interfaces/IInbox.d.ts +83 -0
- package/dist/interfaces/IInbox.d.ts.map +1 -0
- package/dist/interfaces/IInbox.js +4 -0
- package/dist/interfaces/IInbox.js.map +1 -0
- package/dist/interfaces/IInterchainGasPaymaster.d.ts +51 -0
- package/dist/interfaces/IInterchainGasPaymaster.d.ts.map +1 -0
- package/dist/interfaces/IInterchainGasPaymaster.js +4 -0
- package/dist/interfaces/IInterchainGasPaymaster.js.map +1 -0
- package/dist/interfaces/IMailbox.d.ts +51 -0
- package/dist/interfaces/IMailbox.d.ts.map +1 -0
- package/dist/interfaces/IMailbox.js +4 -0
- package/dist/interfaces/IMailbox.js.map +1 -0
- package/dist/interfaces/IMessageRecipient.d.ts +51 -0
- package/dist/interfaces/IMessageRecipient.d.ts.map +1 -0
- package/dist/interfaces/IMessageRecipient.js +4 -0
- package/dist/interfaces/IMessageRecipient.js.map +1 -0
- package/dist/interfaces/IMultisigValidatorManager.d.ts +59 -0
- package/dist/interfaces/IMultisigValidatorManager.d.ts.map +1 -0
- package/dist/interfaces/IMultisigValidatorManager.js +4 -0
- package/dist/interfaces/IMultisigValidatorManager.js.map +1 -0
- package/dist/interfaces/IOutbox.d.ts +148 -0
- package/dist/interfaces/IOutbox.d.ts.map +1 -0
- package/dist/interfaces/IOutbox.js +4 -0
- package/dist/interfaces/IOutbox.js.map +1 -0
- package/dist/interfaces/index.d.ts +8 -0
- package/dist/interfaces/index.d.ts.map +1 -0
- package/dist/interfaces/index.js +3 -0
- package/dist/interfaces/index.js.map +1 -0
- package/interfaces/IAbacusConnectionManager.sol +12 -0
- package/interfaces/IInbox.sol +16 -0
- package/interfaces/IInterchainGasPaymaster.sol +15 -0
- package/interfaces/IMailbox.sol +8 -0
- package/interfaces/IMessageRecipient.sol +10 -0
- package/interfaces/IMultisigValidatorManager.sol +11 -0
- package/interfaces/IOutbox.sol +27 -0
- package/package.json +54 -0
package/README.md
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
## Hyperlane Solidity
|
|
2
|
+
|
|
3
|
+
On-chain implementations of Hyperlane in Solidity.
|
|
4
|
+
|
|
5
|
+
### Setup
|
|
6
|
+
|
|
7
|
+
- `npm install --dev`
|
|
8
|
+
- `brew install jq` OR `sudo apt-get install jq`
|
|
9
|
+
- `npm install -g solhint`, check it is installed using `solhint --version`
|
|
10
|
+
|
|
11
|
+
### Build
|
|
12
|
+
|
|
13
|
+
- `npm run compile`
|
|
14
|
+
- `npm run test`
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
+
pragma solidity >=0.8.0;
|
|
3
|
+
|
|
4
|
+
// ============ Internal Imports ============
|
|
5
|
+
import {IOutbox} from "../interfaces/IOutbox.sol";
|
|
6
|
+
import {IInbox} from "../interfaces/IInbox.sol";
|
|
7
|
+
import {IAbacusConnectionManager} from "../interfaces/IAbacusConnectionManager.sol";
|
|
8
|
+
import {IMultisigValidatorManager} from "../interfaces/IMultisigValidatorManager.sol";
|
|
9
|
+
|
|
10
|
+
// ============ External Imports ============
|
|
11
|
+
import {Ownable} from "@openzeppelin/contracts/access/Ownable.sol";
|
|
12
|
+
import {Address} from "@openzeppelin/contracts/utils/Address.sol";
|
|
13
|
+
import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* @title AbacusConnectionManager
|
|
17
|
+
* @author Celo Labs Inc.
|
|
18
|
+
* @notice Manages a registry of local Inbox contracts for remote Outbox
|
|
19
|
+
* domains.
|
|
20
|
+
*/
|
|
21
|
+
contract AbacusConnectionManager is IAbacusConnectionManager, Ownable {
|
|
22
|
+
using EnumerableSet for EnumerableSet.AddressSet;
|
|
23
|
+
using EnumerableSet for EnumerableSet.Bytes32Set;
|
|
24
|
+
|
|
25
|
+
// ============ Public Storage ============
|
|
26
|
+
|
|
27
|
+
// Outbox contract
|
|
28
|
+
IOutbox public override outbox;
|
|
29
|
+
// local Inbox address => remote Outbox domain
|
|
30
|
+
mapping(address => uint32) public inboxToDomain;
|
|
31
|
+
// remote Outbox domain => local Inbox addresses
|
|
32
|
+
mapping(uint32 => EnumerableSet.AddressSet) internal domainToInboxes;
|
|
33
|
+
// complete history of enrolled inbox domain hashes, even if unenrolled
|
|
34
|
+
EnumerableSet.Bytes32Set domainHashes;
|
|
35
|
+
|
|
36
|
+
// ============ Events ============
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* @notice Emitted when a new Outbox is set.
|
|
40
|
+
* @param outbox the address of the Outbox
|
|
41
|
+
*/
|
|
42
|
+
event OutboxSet(address indexed outbox);
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* @notice Emitted when a new Inbox is enrolled / added
|
|
46
|
+
* @param domain the remote domain of the Outbox contract for the Inbox
|
|
47
|
+
* @param inbox the address of the Inbox
|
|
48
|
+
*/
|
|
49
|
+
event InboxEnrolled(uint32 indexed domain, address inbox);
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* @notice Emitted when a new Inbox is un-enrolled / removed
|
|
53
|
+
* @param domain the remote domain of the Outbox contract for the Inbox
|
|
54
|
+
* @param inbox the address of the Inbox
|
|
55
|
+
*/
|
|
56
|
+
event InboxUnenrolled(uint32 indexed domain, address inbox);
|
|
57
|
+
|
|
58
|
+
// ============ Constructor ============
|
|
59
|
+
|
|
60
|
+
// solhint-disable-next-line no-empty-blocks
|
|
61
|
+
constructor() Ownable() {}
|
|
62
|
+
|
|
63
|
+
// ============ External Functions ============
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* @notice Sets the address of the local Outbox contract.
|
|
67
|
+
* @param _outbox The address of the new local Outbox contract.
|
|
68
|
+
*/
|
|
69
|
+
function setOutbox(address _outbox) external onlyOwner {
|
|
70
|
+
require(Address.isContract(_outbox), "outbox !contract");
|
|
71
|
+
outbox = IOutbox(_outbox);
|
|
72
|
+
emit OutboxSet(_outbox);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* @notice Allow Owner to enroll Inbox contract
|
|
77
|
+
* @param _domain the remote domain of the Outbox contract for the Inbox
|
|
78
|
+
* @param _inbox the address of the Inbox
|
|
79
|
+
*/
|
|
80
|
+
function enrollInbox(uint32 _domain, address _inbox) external onlyOwner {
|
|
81
|
+
require(Address.isContract(_inbox), "inbox !contract");
|
|
82
|
+
require(!isInbox(_inbox), "already inbox");
|
|
83
|
+
|
|
84
|
+
// prevent enrolling an inbox that matches any previously enrolled domain hash
|
|
85
|
+
bytes32 domainHash = getDomainHash(_inbox);
|
|
86
|
+
require(
|
|
87
|
+
!domainHashes.contains(domainHash),
|
|
88
|
+
"domain hash previously enrolled"
|
|
89
|
+
);
|
|
90
|
+
domainHashes.add(domainHash);
|
|
91
|
+
|
|
92
|
+
// add inbox and domain to two-way mapping
|
|
93
|
+
inboxToDomain[_inbox] = _domain;
|
|
94
|
+
require(domainToInboxes[_domain].add(_inbox), "already enrolled");
|
|
95
|
+
emit InboxEnrolled(_domain, _inbox);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* @notice Allow Owner to un-enroll Inbox contract
|
|
100
|
+
* @param _inbox the address of the Inbox
|
|
101
|
+
*/
|
|
102
|
+
function unenrollInbox(address _inbox) external onlyOwner {
|
|
103
|
+
_unenrollInbox(_inbox);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* @notice Query local domain from Outbox
|
|
108
|
+
* @return local domain
|
|
109
|
+
*/
|
|
110
|
+
function localDomain() external view override returns (uint32) {
|
|
111
|
+
return outbox.localDomain();
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* @notice Returns the Inbox addresses for a given remote domain
|
|
116
|
+
* @return inboxes An array of addresses of the Inboxes
|
|
117
|
+
*/
|
|
118
|
+
function getInboxes(uint32 remoteDomain)
|
|
119
|
+
external
|
|
120
|
+
view
|
|
121
|
+
returns (address[] memory)
|
|
122
|
+
{
|
|
123
|
+
EnumerableSet.AddressSet storage _inboxes = domainToInboxes[
|
|
124
|
+
remoteDomain
|
|
125
|
+
];
|
|
126
|
+
uint256 length = _inboxes.length();
|
|
127
|
+
address[] memory ret = new address[](length);
|
|
128
|
+
for (uint256 i = 0; i < length; i += 1) {
|
|
129
|
+
ret[i] = _inboxes.at(i);
|
|
130
|
+
}
|
|
131
|
+
return ret;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
// ============ Public Functions ============
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* @notice Check whether _inbox is enrolled
|
|
138
|
+
* @param _inbox the inbox to check for enrollment
|
|
139
|
+
* @return TRUE iff _inbox is enrolled
|
|
140
|
+
*/
|
|
141
|
+
function isInbox(address _inbox) public view override returns (bool) {
|
|
142
|
+
return inboxToDomain[_inbox] != 0;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
/**
|
|
146
|
+
* @notice Check whether _inbox is enrolled
|
|
147
|
+
* @param _inbox the inbox to check for enrollment
|
|
148
|
+
* @return TRUE iff _inbox is enrolled
|
|
149
|
+
*/
|
|
150
|
+
function getDomainHash(address _inbox) public view returns (bytes32) {
|
|
151
|
+
IInbox inbox = IInbox(_inbox);
|
|
152
|
+
address vm = inbox.validatorManager();
|
|
153
|
+
return IMultisigValidatorManager(vm).domainHash();
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
// ============ Internal Functions ============
|
|
157
|
+
|
|
158
|
+
/**
|
|
159
|
+
* @notice Remove the inbox from the two-way mappings
|
|
160
|
+
* @param _inbox inbox to un-enroll
|
|
161
|
+
*/
|
|
162
|
+
function _unenrollInbox(address _inbox) internal {
|
|
163
|
+
uint32 _currentDomain = inboxToDomain[_inbox];
|
|
164
|
+
require(domainToInboxes[_currentDomain].remove(_inbox), "not enrolled");
|
|
165
|
+
inboxToDomain[_inbox] = 0;
|
|
166
|
+
emit InboxUnenrolled(_currentDomain, _inbox);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
@@ -0,0 +1,148 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
+
pragma solidity >=0.8.0;
|
|
3
|
+
|
|
4
|
+
// ============ Internal Imports ============
|
|
5
|
+
import {IInterchainGasPaymaster} from "../interfaces/IInterchainGasPaymaster.sol";
|
|
6
|
+
// ============ External Imports ============
|
|
7
|
+
import {OwnableUpgradeable} from "@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.sol";
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* @title InterchainGasPaymaster
|
|
11
|
+
* @notice Manages payments on a source chain to cover gas costs of relaying
|
|
12
|
+
* messages to destination chains.
|
|
13
|
+
*/
|
|
14
|
+
contract InterchainGasPaymaster is IInterchainGasPaymaster, OwnableUpgradeable {
|
|
15
|
+
// ============ Events ============
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* @notice Emitted when a payment is made for a message's gas costs.
|
|
19
|
+
* @param outbox The address of the Outbox contract.
|
|
20
|
+
* @param leafIndex The index of the message in the Outbox merkle tree.
|
|
21
|
+
* @param amount The amount of native tokens paid.
|
|
22
|
+
*/
|
|
23
|
+
event GasPayment(address indexed outbox, uint256 leafIndex, uint256 amount);
|
|
24
|
+
|
|
25
|
+
// ============ Constructor ============
|
|
26
|
+
|
|
27
|
+
// solhint-disable-next-line no-empty-blocks
|
|
28
|
+
constructor() {
|
|
29
|
+
initialize(); // allows contract to be used without proxying
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// ============ External Functions ============
|
|
33
|
+
|
|
34
|
+
function initialize() public initializer {
|
|
35
|
+
__Ownable_init();
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* @notice Deposits msg.value as a payment for the relaying of a message
|
|
40
|
+
* to its destination chain.
|
|
41
|
+
* @param _outbox The address of the Outbox contract.
|
|
42
|
+
* @param _leafIndex The index of the message in the Outbox merkle tree.
|
|
43
|
+
* @param _destinationDomain The domain of the message's destination chain.
|
|
44
|
+
*/
|
|
45
|
+
function payGasFor(
|
|
46
|
+
address _outbox,
|
|
47
|
+
uint256 _leafIndex,
|
|
48
|
+
uint32 _destinationDomain
|
|
49
|
+
) external payable override {
|
|
50
|
+
// Silence compiler warning. The NatSpec @param requires the parameter to be named.
|
|
51
|
+
// While not used at the moment, future versions of the paymaster may conditionally
|
|
52
|
+
// forward payments depending on the destination domain.
|
|
53
|
+
_destinationDomain;
|
|
54
|
+
|
|
55
|
+
emit GasPayment(_outbox, _leafIndex, msg.value);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* @notice Transfers the entire native token balance to the owner of the contract.
|
|
60
|
+
* @dev The owner must be able to receive native tokens.
|
|
61
|
+
*/
|
|
62
|
+
function claim() external {
|
|
63
|
+
// Transfer the entire balance to owner.
|
|
64
|
+
(bool success, ) = owner().call{value: address(this).balance}("");
|
|
65
|
+
require(success, "!transfer");
|
|
66
|
+
}
|
|
67
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
+
pragma solidity >=0.8.0;
|
|
3
|
+
|
|
4
|
+
// ============ Internal Imports ============
|
|
5
|
+
import {IMailbox} from "../interfaces/IMailbox.sol";
|
|
6
|
+
// ============ External Imports ============
|
|
7
|
+
import {OwnableUpgradeable} from "@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.sol";
|
|
8
|
+
import {Address} from "@openzeppelin/contracts/utils/Address.sol";
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* @title Mailbox
|
|
12
|
+
* @author Celo Labs Inc.
|
|
13
|
+
* @notice Shared utilities between Outbox and Inbox.
|
|
14
|
+
*/
|
|
15
|
+
abstract contract Mailbox is IMailbox, OwnableUpgradeable {
|
|
16
|
+
// ============ Immutable Variables ============
|
|
17
|
+
|
|
18
|
+
// Domain of chain on which the contract is deployed
|
|
19
|
+
uint32 public immutable override localDomain;
|
|
20
|
+
|
|
21
|
+
// ============ Public Variables ============
|
|
22
|
+
|
|
23
|
+
// Address of the validator manager contract.
|
|
24
|
+
address public validatorManager;
|
|
25
|
+
|
|
26
|
+
// ============ Upgrade Gap ============
|
|
27
|
+
|
|
28
|
+
// gap for upgrade safety
|
|
29
|
+
uint256[49] private __GAP;
|
|
30
|
+
|
|
31
|
+
// ============ Events ============
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* @notice Emitted when the validator manager contract is changed
|
|
35
|
+
* @param validatorManager The address of the new validatorManager
|
|
36
|
+
*/
|
|
37
|
+
event ValidatorManagerSet(address validatorManager);
|
|
38
|
+
|
|
39
|
+
// ============ Modifiers ============
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* @notice Ensures that a function is called by the validator manager contract.
|
|
43
|
+
*/
|
|
44
|
+
modifier onlyValidatorManager() {
|
|
45
|
+
require(msg.sender == validatorManager, "!validatorManager");
|
|
46
|
+
_;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// ============ Constructor ============
|
|
50
|
+
|
|
51
|
+
constructor(uint32 _localDomain) {
|
|
52
|
+
localDomain = _localDomain;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// ============ Initializer ============
|
|
56
|
+
|
|
57
|
+
function __Mailbox_initialize(address _validatorManager)
|
|
58
|
+
internal
|
|
59
|
+
onlyInitializing
|
|
60
|
+
{
|
|
61
|
+
// initialize owner
|
|
62
|
+
__Ownable_init();
|
|
63
|
+
_setValidatorManager(_validatorManager);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// ============ External Functions ============
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* @notice Set a new validator manager contract
|
|
70
|
+
* @dev Mailbox(es) will initially be initialized using a trusted validator manager contract;
|
|
71
|
+
* we will progressively decentralize by swapping the trusted contract with a new implementation
|
|
72
|
+
* that implements Validator bonding & slashing, and rules for Validator selection & rotation
|
|
73
|
+
* @param _validatorManager the new validator manager contract
|
|
74
|
+
*/
|
|
75
|
+
function setValidatorManager(address _validatorManager) external onlyOwner {
|
|
76
|
+
_setValidatorManager(_validatorManager);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// ============ Internal Functions ============
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* @notice Set the validator manager
|
|
83
|
+
* @param _validatorManager Address of the validator manager
|
|
84
|
+
*/
|
|
85
|
+
function _setValidatorManager(address _validatorManager) internal {
|
|
86
|
+
require(
|
|
87
|
+
Address.isContract(_validatorManager),
|
|
88
|
+
"!contract validatorManager"
|
|
89
|
+
);
|
|
90
|
+
validatorManager = _validatorManager;
|
|
91
|
+
emit ValidatorManagerSet(_validatorManager);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
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
|
+
}
|