From dbaa2e1455a9fc923263d09b8e6636b3176adc1f Mon Sep 17 00:00:00 2001 From: Mauro Piazza Date: Wed, 6 Nov 2024 11:54:08 +0100 Subject: [PATCH] fix(solidity): Adapter's swap native condition (#37) --- solidity/src/contracts/Adapter.sol | 9 +++++++-- solidity/test/forge/Adapter.t.sol | 1 + solidity/test/forge/Helper.sol | 1 + solidity/test/hardhat/Adapter.test.js | 1 + .../hardhat/forked-environment/ptoken-upgrade.test.js | 4 +++- 5 files changed, 13 insertions(+), 3 deletions(-) diff --git a/solidity/src/contracts/Adapter.sol b/solidity/src/contracts/Adapter.sol index 96b04ad7..64e81d10 100644 --- a/solidity/src/contracts/Adapter.sol +++ b/solidity/src/contracts/Adapter.sol @@ -30,14 +30,19 @@ contract Adapter is IAdapter, Ownable, ReentrancyGuard { address public pam; uint256 public minFee; mapping(bytes32 => bool) public pastEvents; + bool public isNative; constructor( address xerc20_, address erc20_, + bool isNative_, address feesManager_, address pam_ ) Ownable(msg.sender) { - erc20 = erc20_; + isNative = isNative_; + if (!isNative) { + erc20 = erc20_; + } xerc20 = xerc20_; feesManager = feesManager_; pam = pam_; @@ -124,7 +129,7 @@ contract Adapter is IAdapter, Ownable, ReentrancyGuard { string memory recipient, bytes memory data ) external payable { - if (erc20 == address(0)) { + if (erc20 == address(0) && isNative) { _swapNative(destinationChainId, recipient, data); } else { _swapToken(token, amount, destinationChainId, recipient, data); diff --git a/solidity/test/forge/Adapter.t.sol b/solidity/test/forge/Adapter.t.sol index 3555c1d5..f67e470a 100644 --- a/solidity/test/forge/Adapter.t.sol +++ b/solidity/test/forge/Adapter.t.sol @@ -43,6 +43,7 @@ contract AdapterTest is Test, Helper { adapter = new Adapter( address(xerc20), address(erc20), + notNative, address(feesManager), address(pam) ); diff --git a/solidity/test/forge/Helper.sol b/solidity/test/forge/Helper.sol index 0ec53bf7..a0bf85b5 100644 --- a/solidity/test/forge/Helper.sol +++ b/solidity/test/forge/Helper.sol @@ -105,6 +105,7 @@ abstract contract Helper is Test, DeployHelper { adapter = new Adapter( address(xerc20), address(erc20), + notNative, address(feesManager), address(pam) ); diff --git a/solidity/test/hardhat/Adapter.test.js b/solidity/test/hardhat/Adapter.test.js index 7322ebbf..0caa0f36 100644 --- a/solidity/test/hardhat/Adapter.test.js +++ b/solidity/test/hardhat/Adapter.test.js @@ -82,6 +82,7 @@ const deployERC1820 = () => setCode(ERC1820, ERC1820BYTES) const adapter = await deploy(hre, 'Adapter', [ pTokenV2.target, erc20.target, + _isNative, feesManager, PAM, ]) diff --git a/solidity/test/hardhat/forked-environment/ptoken-upgrade.test.js b/solidity/test/hardhat/forked-environment/ptoken-upgrade.test.js index 231d4ecb..bfbb106e 100644 --- a/solidity/test/hardhat/forked-environment/ptoken-upgrade.test.js +++ b/solidity/test/hardhat/forked-environment/ptoken-upgrade.test.js @@ -45,6 +45,7 @@ conditionalDescribe( const burningLimit = hre.ethers.parseEther('500000') const swapAmount = hre.ethers.parseEther('10000') const userdata = '0x' + const isNative = false let erc20, adapterEth, @@ -93,6 +94,7 @@ conditionalDescribe( adapterBsc = await deploy(hre, 'Adapter', [ ptoken.target, ADDRESS_ERC20_TOKEN, + isNative, feesManagerBsc, pamBsc, ]) @@ -179,7 +181,6 @@ conditionalDescribe( const name = `p${await erc20.name()}` const symbol = `p${await erc20.symbol()}` - const isNative = false const factory = await deploy(hre, 'XERC20Factory', []) xerc20 = await deployXERC20(hre, factory, name, symbol) @@ -204,6 +205,7 @@ conditionalDescribe( adapterEth = await deploy(hre, 'Adapter', [ xerc20.target, ADDRESS_ERC20_TOKEN, + isNative, feesManagerEth, pamEth, ])