From fee3bafbb38b4587cd349ce0aed665e278a57490 Mon Sep 17 00:00:00 2001 From: Jun Kim <64379343+junkim012@users.noreply.github.com> Date: Fri, 20 Dec 2024 13:55:32 -0500 Subject: [PATCH] fix: M-03 add hook to dispatch and L-03 make quote and dispatch consistent --- ...ltiChainHyperlaneTellerWithMultiAssetSupport.sol | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/src/base/Roles/CrossChain/MultiChainHyperlaneTellerWithMultiAssetSupport.sol b/src/base/Roles/CrossChain/MultiChainHyperlaneTellerWithMultiAssetSupport.sol index 7089c4a..4a92e22 100644 --- a/src/base/Roles/CrossChain/MultiChainHyperlaneTellerWithMultiAssetSupport.sol +++ b/src/base/Roles/CrossChain/MultiChainHyperlaneTellerWithMultiAssetSupport.sol @@ -87,11 +87,14 @@ contract MultiChainHyperlaneTellerWithMultiAssetSupport is MultiChainTellerBase * @param data Bridge data */ function _quote(uint256 shareAmount, BridgeData calldata data) internal view override returns (uint256) { - bytes memory _payload = abi.encode(shareAmount, data.destinationChainReceiver); + bytes32 messageId = keccak256(abi.encodePacked(++nonce, address(this), block.chainid)); + + bytes memory _payload = abi.encode(shareAmount, data.destinationChainReceiver, messageId); + bytes32 msgRecipient = _addressToBytes32(selectorToChains[data.chainSelector].targetTeller); return mailbox.quoteDispatch( - data.chainSelector, msgRecipient, _payload, StandardHookMetadata.overrideGasLimit(data.messageGas) + data.chainSelector, msgRecipient, _payload, StandardHookMetadata.overrideGasLimit(data.messageGas), hook ); } @@ -172,9 +175,9 @@ contract MultiChainHyperlaneTellerWithMultiAssetSupport is MultiChainTellerBase data.chainSelector, // must be `destinationDomain` on hyperlane msgRecipient, // must be the teller address left-padded to bytes32 _payload, - StandardHookMetadata.overrideGasLimit(data.messageGas) // Sets the refund address to msg.sender, sets - // `_msgValue` - // to zero + StandardHookMetadata.overrideGasLimit(data.messageGas), // Sets the refund address to msg.sender, sets + // `_msgValue` to zero + hook ); }