From f83375a244ed1bee61efc1a083eaff01ac1e55c3 Mon Sep 17 00:00:00 2001 From: cdamian <17934949+cdamian@users.noreply.github.com> Date: Tue, 12 Sep 2023 13:52:53 +0300 Subject: [PATCH] routers: Drop LP contract call from Axelar message --- .../routers/src/routers/axelar_evm.rs | 42 ++++--------------- 1 file changed, 7 insertions(+), 35 deletions(-) diff --git a/pallets/liquidity-pools-gateway/routers/src/routers/axelar_evm.rs b/pallets/liquidity-pools-gateway/routers/src/routers/axelar_evm.rs index 137160536f..20bb127f0c 100644 --- a/pallets/liquidity-pools-gateway/routers/src/routers/axelar_evm.rs +++ b/pallets/liquidity-pools-gateway/routers/src/routers/axelar_evm.rs @@ -24,7 +24,7 @@ use sp_std::{collections::btree_map::BTreeMap, marker::PhantomData, vec, vec::Ve use crate::{ AccountIdOf, EVMRouter, MessageOf, AXELAR_DESTINATION_CHAIN_PARAM, AXELAR_DESTINATION_CONTRACT_ADDRESS_PARAM, AXELAR_FUNCTION_NAME, AXELAR_PAYLOAD_PARAM, - FUNCTION_NAME, MAX_AXELAR_EVM_CHAIN_SIZE, MESSAGE_PARAM, + MAX_AXELAR_EVM_CHAIN_SIZE, }; /// The router used for executing the LiquidityPools contract via Axelar. @@ -74,8 +74,8 @@ where } /// Encodes the provided message into the format required for submitting it -/// to the Axelar contract which in turn submits it to the LiquidityPools -/// contract. +/// to the Axelar contract which in turn calls the LiquidityPools +/// contract with the serialized LP message a payload. /// /// Axelar contract call: /// @@ -87,36 +87,6 @@ pub(crate) fn get_axelar_encoded_msg( target_chain: Vec, target_contract: H160, ) -> Result, &'static str> { - let target_chain_string = - String::from_utf8(target_chain).map_err(|_| "target chain conversion error")?; - - #[allow(deprecated)] - let encoded_liquidity_pools_contract = Contract { - constructor: None, - functions: BTreeMap::>::from([( - FUNCTION_NAME.to_string(), - vec![Function { - name: FUNCTION_NAME.into(), - inputs: vec![Param { - name: MESSAGE_PARAM.into(), - kind: ParamType::Bytes, - internal_type: None, - }], - outputs: vec![], - constant: false, - state_mutability: Default::default(), - }], - )]), - events: Default::default(), - errors: Default::default(), - receive: false, - fallback: false, - } - .function(FUNCTION_NAME) - .map_err(|_| "cannot retrieve LiquidityPools contract function")? - .encode_input(&[Token::Bytes(serialized_msg)]) - .map_err(|_| "cannot encode input for LiquidityPools contract function")?; - #[allow(deprecated)] let encoded_axelar_contract = Contract { constructor: None, @@ -154,9 +124,11 @@ pub(crate) fn get_axelar_encoded_msg( .function(AXELAR_FUNCTION_NAME) .map_err(|_| "cannot retrieve Axelar contract function")? .encode_input(&[ - Token::String(target_chain_string), + Token::String( + String::from_utf8(target_chain).map_err(|_| "target chain conversion error")?, + ), Token::String(target_contract.to_string()), - Token::Bytes(encoded_liquidity_pools_contract), + Token::Bytes(serialized_msg), ]) .map_err(|_| "cannot encode input for Axelar contract function")?;