mirror of
https://github.com/Instadapp/aave-protocol-v2.git
synced 2024-07-29 21:47:30 +00:00
Update adapters to use the new flashloan interface
This commit is contained in:
parent
723e3f82a6
commit
96e74cf707
|
@ -28,18 +28,18 @@ contract UniswapLiquiditySwapAdapter is BaseUniswapAdapter, IFlashLoanReceiver {
|
||||||
* The received funds from the swap are then deposited into the protocol on behalf of the user.
|
* The received funds from the swap are then deposited into the protocol on behalf of the user.
|
||||||
* The user should give this contract allowance to pull the ATokens in order to withdraw the underlying asset and
|
* The user should give this contract allowance to pull the ATokens in order to withdraw the underlying asset and
|
||||||
* repay the flash loan.
|
* repay the flash loan.
|
||||||
* @param reserve Address to be swapped
|
* @param assets Address to be swapped
|
||||||
* @param amount Amount of the reserve to be swapped
|
* @param amounts Amount of the reserve to be swapped
|
||||||
* @param fee Fee of the flash loan
|
* @param premiums Fee of the flash loan
|
||||||
* @param params Additional variadic field to include extra params. Expected parameters:
|
* @param params Additional variadic field to include extra params. Expected parameters:
|
||||||
* address assetToSwapTo Address of the reserve to be swapped to and deposited
|
* address assetToSwapTo Address of the reserve to be swapped to and deposited
|
||||||
* address user The address of the user
|
* address user The address of the user
|
||||||
* uint256 slippage The max slippage percentage allowed for the swap
|
* uint256 slippage The max slippage percentage allowed for the swap
|
||||||
*/
|
*/
|
||||||
function executeOperation(
|
function executeOperation(
|
||||||
address reserve,
|
address[] calldata assets,
|
||||||
uint256 amount,
|
uint256[] calldata amounts,
|
||||||
uint256 fee,
|
uint256[] calldata premiums,
|
||||||
bytes calldata params
|
bytes calldata params
|
||||||
) external override returns (bool) {
|
) external override returns (bool) {
|
||||||
(
|
(
|
||||||
|
@ -49,14 +49,14 @@ contract UniswapLiquiditySwapAdapter is BaseUniswapAdapter, IFlashLoanReceiver {
|
||||||
) = abi.decode(params, (address, address, uint256));
|
) = abi.decode(params, (address, address, uint256));
|
||||||
require(slippage < MAX_SLIPPAGE_PERCENT && slippage >= MIN_SLIPPAGE_PERCENT, 'SLIPPAGE_OUT_OF_RANGE');
|
require(slippage < MAX_SLIPPAGE_PERCENT && slippage >= MIN_SLIPPAGE_PERCENT, 'SLIPPAGE_OUT_OF_RANGE');
|
||||||
|
|
||||||
uint256 receivedAmount = swapExactTokensForTokens(reserve, assetToSwapTo, amount, slippage);
|
uint256 receivedAmount = swapExactTokensForTokens(assets[0], assetToSwapTo, amounts[0], slippage);
|
||||||
|
|
||||||
// Deposit new reserve
|
// Deposit new reserve
|
||||||
IERC20(assetToSwapTo).approve(address(pool), receivedAmount);
|
IERC20(assetToSwapTo).approve(address(pool), receivedAmount);
|
||||||
pool.deposit(assetToSwapTo, receivedAmount, user, 0);
|
pool.deposit(assetToSwapTo, receivedAmount, user, 0);
|
||||||
|
|
||||||
uint256 flashLoanDebt = amount.add(fee);
|
uint256 flashLoanDebt = amounts[0].add(premiums[0]);
|
||||||
pullATokenAndRepayFlashLoan(reserve, user, flashLoanDebt);
|
pullATokenAndRepayFlashLoan(assets[0], user, flashLoanDebt);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,9 +28,9 @@ contract UniswapRepayAdapter is BaseUniswapAdapter, IFlashLoanReceiver {
|
||||||
* then used to repay a debt on the protocol on behalf of the user.
|
* then used to repay a debt on the protocol on behalf of the user.
|
||||||
* The user should give this contract allowance to pull the ATokens in order to withdraw the underlying asset and
|
* The user should give this contract allowance to pull the ATokens in order to withdraw the underlying asset and
|
||||||
* repay the flash loan.
|
* repay the flash loan.
|
||||||
* @param reserve Address to be swapped
|
* @param assets Address to be swapped
|
||||||
* @param amount Amount of the reserve to be swapped
|
* @param amounts Amount of the reserve to be swapped
|
||||||
* @param fee Fee of the flash loan
|
* @param premiums Fee of the flash loan
|
||||||
* @param params Additional variadic field to include extra params. Expected parameters:
|
* @param params Additional variadic field to include extra params. Expected parameters:
|
||||||
* address assetToSwapTo Address of the reserve to be swapped to and deposited
|
* address assetToSwapTo Address of the reserve to be swapped to and deposited
|
||||||
* address user The address of the user
|
* address user The address of the user
|
||||||
|
@ -41,9 +41,9 @@ contract UniswapRepayAdapter is BaseUniswapAdapter, IFlashLoanReceiver {
|
||||||
* uint256 rateMode The rate modes of the debt to be repaid
|
* uint256 rateMode The rate modes of the debt to be repaid
|
||||||
*/
|
*/
|
||||||
function executeOperation(
|
function executeOperation(
|
||||||
address reserve,
|
address[] calldata assets,
|
||||||
uint256 amount,
|
uint256[] calldata amounts,
|
||||||
uint256 fee,
|
uint256[] calldata premiums,
|
||||||
bytes calldata params
|
bytes calldata params
|
||||||
) external override returns (bool) {
|
) external override returns (bool) {
|
||||||
(
|
(
|
||||||
|
@ -54,17 +54,17 @@ contract UniswapRepayAdapter is BaseUniswapAdapter, IFlashLoanReceiver {
|
||||||
uint256 rateMode
|
uint256 rateMode
|
||||||
) = abi.decode(params, (address, address, uint256, uint256, uint256));
|
) = abi.decode(params, (address, address, uint256, uint256, uint256));
|
||||||
|
|
||||||
swapTokensForExactTokens(reserve, assetToSwapTo, amount, repayAmount);
|
swapTokensForExactTokens(assets[0], assetToSwapTo, amounts[0], repayAmount);
|
||||||
|
|
||||||
// Repay debt
|
// Repay debt
|
||||||
IERC20(assetToSwapTo).approve(address(pool), repayAmount);
|
IERC20(assetToSwapTo).approve(address(pool), repayAmount);
|
||||||
pool.repay(assetToSwapTo, repayAmount, rateMode, user);
|
pool.repay(assetToSwapTo, repayAmount, rateMode, user);
|
||||||
|
|
||||||
uint256 flashLoanDebt = amount.add(fee);
|
uint256 flashLoanDebt = amounts[0].add(premiums[0]);
|
||||||
pullATokenAndRepayFlashLoan(reserve, user, flashLoanDebt);
|
pullATokenAndRepayFlashLoan(assets[0], user, flashLoanDebt);
|
||||||
|
|
||||||
// Take care of reserve leftover from the swap
|
// Take care of reserve leftover from the swap
|
||||||
sendLeftOver(reserve, flashLoanDebt, leftOverAction, user);
|
sendLeftOver(assets[0], flashLoanDebt, leftOverAction, user);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,8 +101,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapLiquiditySwapAdapter.address,
|
uniswapLiquiditySwapAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -194,8 +194,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapLiquiditySwapAdapter.address,
|
uniswapLiquiditySwapAdapter.address,
|
||||||
usdc.address,
|
[usdc.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -259,8 +259,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapLiquiditySwapAdapter.address,
|
uniswapLiquiditySwapAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params1,
|
params1,
|
||||||
0
|
0
|
||||||
|
@ -271,8 +271,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapLiquiditySwapAdapter.address,
|
uniswapLiquiditySwapAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params2,
|
params2,
|
||||||
0
|
0
|
||||||
|
@ -319,8 +319,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapLiquiditySwapAdapter.address,
|
uniswapLiquiditySwapAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -415,8 +415,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapRepayAdapter.address,
|
uniswapRepayAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -459,7 +459,6 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
|
|
||||||
const liquidityToSwap = amountWETHtoSwap;
|
const liquidityToSwap = amountWETHtoSwap;
|
||||||
await aEth.connect(user).approve(uniswapRepayAdapter.address, liquidityToSwap);
|
await aEth.connect(user).approve(uniswapRepayAdapter.address, liquidityToSwap);
|
||||||
const userAEthBalanceBefore = await aEth.balanceOf(userAddress);
|
|
||||||
|
|
||||||
// Subtract the FL fee from the amount to be swapped 0,09%
|
// Subtract the FL fee from the amount to be swapped 0,09%
|
||||||
const flashloanAmount = new BigNumber(liquidityToSwap.toString()).div(1.0009).toFixed(0);
|
const flashloanAmount = new BigNumber(liquidityToSwap.toString()).div(1.0009).toFixed(0);
|
||||||
|
@ -477,8 +476,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapRepayAdapter.address,
|
uniswapRepayAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -504,7 +503,6 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
|
|
||||||
const liquidityToSwap = amountWETHtoSwap;
|
const liquidityToSwap = amountWETHtoSwap;
|
||||||
await aEth.connect(user).approve(uniswapRepayAdapter.address, liquidityToSwap);
|
await aEth.connect(user).approve(uniswapRepayAdapter.address, liquidityToSwap);
|
||||||
const userAEthBalanceBefore = await aEth.balanceOf(userAddress);
|
|
||||||
|
|
||||||
// Subtract the FL fee from the amount to be swapped 0,09%
|
// Subtract the FL fee from the amount to be swapped 0,09%
|
||||||
const flashloanAmount = new BigNumber(liquidityToSwap.toString()).div(1.0009).toFixed(0);
|
const flashloanAmount = new BigNumber(liquidityToSwap.toString()).div(1.0009).toFixed(0);
|
||||||
|
@ -522,8 +520,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapRepayAdapter.address,
|
uniswapRepayAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -532,7 +530,7 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should revert when the received amount is less than expected', async () => {
|
it('should revert when the received amount is less than expected', async () => {
|
||||||
const {users, pool, weth, oracle, dai, aEth, uniswapRepayAdapter, deployer} = testEnv;
|
const {users, pool, weth, oracle, dai, aEth, uniswapRepayAdapter} = testEnv;
|
||||||
const user = users[0].signer;
|
const user = users[0].signer;
|
||||||
const userAddress = users[0].address;
|
const userAddress = users[0].address;
|
||||||
|
|
||||||
|
@ -570,8 +568,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapRepayAdapter.address,
|
uniswapRepayAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -595,8 +593,7 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
// Open user Debt
|
// Open user Debt
|
||||||
await pool.connect(user).borrow(dai.address, expectedDaiAmount, 1, 0, userAddress);
|
await pool.connect(user).borrow(dai.address, expectedDaiAmount, 1, 0, userAddress);
|
||||||
|
|
||||||
const liquidityToSwap = amountWETHtoSwap;
|
await aEth.connect(user).approve(uniswapRepayAdapter.address, amountWETHtoSwap);
|
||||||
await aEth.connect(user).approve(uniswapRepayAdapter.address, liquidityToSwap);
|
|
||||||
|
|
||||||
// Subtract the FL fee from the amount to be swapped 0,09%
|
// Subtract the FL fee from the amount to be swapped 0,09%
|
||||||
const bigMaxAmountToSwap = amountWETHtoSwap.mul(2);
|
const bigMaxAmountToSwap = amountWETHtoSwap.mul(2);
|
||||||
|
@ -615,8 +612,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapRepayAdapter.address,
|
uniswapRepayAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -686,8 +683,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapRepayAdapter.address,
|
uniswapRepayAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
@ -776,8 +773,8 @@ makeSuite('Uniswap adapters', (testEnv: TestEnv) => {
|
||||||
.connect(user)
|
.connect(user)
|
||||||
.flashLoan(
|
.flashLoan(
|
||||||
uniswapRepayAdapter.address,
|
uniswapRepayAdapter.address,
|
||||||
weth.address,
|
[weth.address],
|
||||||
flashloanAmount.toString(),
|
[flashloanAmount.toString()],
|
||||||
0,
|
0,
|
||||||
params,
|
params,
|
||||||
0
|
0
|
||||||
|
|
Loading…
Reference in New Issue
Block a user