From fa74b9bcc2059e69ede856f7f11c90c40b1dac75 Mon Sep 17 00:00:00 2001 From: ahramy Date: Sun, 10 Nov 2024 20:01:57 -0800 Subject: [PATCH] updated --- .changeset/hungry-seahorses-tap.md | 5 +++++ contracts/InterchainTokenService.sol | 6 ++++-- 2 files changed, 9 insertions(+), 2 deletions(-) create mode 100644 .changeset/hungry-seahorses-tap.md diff --git a/.changeset/hungry-seahorses-tap.md b/.changeset/hungry-seahorses-tap.md new file mode 100644 index 00000000..97bba477 --- /dev/null +++ b/.changeset/hungry-seahorses-tap.md @@ -0,0 +1,5 @@ +--- +'@axelar-network/interchain-token-service': patch +--- + +Prevent the deployment of the token manager on its hub. Now, require registering the trusted address for the self chain if it is connected to the ITS hub, to ensure this check is applied correctly. Note: This deploy token manager restriction is temporary for chains connected via the Hub. Once the ITS hub adds support for it, the restriction will be removed. diff --git a/contracts/InterchainTokenService.sol b/contracts/InterchainTokenService.sol index 1b763651..aed216a7 100644 --- a/contracts/InterchainTokenService.sol +++ b/contracts/InterchainTokenService.sol @@ -283,6 +283,8 @@ contract InterchainTokenService is * @notice Used to deploy remote custom TokenManagers. * @dev At least the `gasValue` amount of native token must be passed to the function call. `gasValue` exists because this function can be * part of a multicall involving multiple functions that could make remote contract calls. + * Restricted on ITS contracts deployed to Amplifier chains until ITS Hub adds support. Only the factory contract can call + * `deployTokenManager` for canonical token registration. This should still work fine for consensus deployments. * @param salt The salt to be used during deployment. * @param destinationChain The name of the chain to deploy the TokenManager and standardized token to. * @param tokenManagerType The type of token manager to be deployed. Cannot be NATIVE_INTERCHAIN_TOKEN. @@ -305,8 +307,8 @@ contract InterchainTokenService is if (deployer == interchainTokenFactory) { deployer = TOKEN_FACTORY_DEPLOYER; } else if (bytes(destinationChain).length == 0) { - string memory destinationAddress = trustedAddress(chainName()); - if (keccak256(abi.encodePacked(destinationAddress)) == ITS_HUB_ROUTING_IDENTIFIER_HASH) { + // Restricted on ITS contracts deployed to Amplifier chains until ITS Hub adds support. + if (trustedAddressHash(chainName()) == ITS_HUB_ROUTING_IDENTIFIER_HASH) { revert NotSupported(); } }