mirror of
https://github.com/Instadapp/aave-protocol-v2.git
synced 2024-07-29 21:47:30 +00:00
444 lines
15 KiB
Solidity
444 lines
15 KiB
Solidity
// SPDX-License-Identifier: agpl-3.0
|
|
pragma solidity ^0.6.8;
|
|
|
|
import {LendingPoolAddressesProvider} from '../configuration/LendingPoolAddressesProvider.sol';
|
|
import {ReserveConfiguration} from '../libraries/configuration/ReserveConfiguration.sol';
|
|
pragma experimental ABIEncoderV2;
|
|
|
|
interface ILendingPool {
|
|
/**
|
|
* @dev emitted on deposit
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user
|
|
* @param amount the amount to be deposited
|
|
* @param referral the referral number of the action
|
|
**/
|
|
event Deposit(
|
|
address indexed reserve,
|
|
address user,
|
|
address indexed onBehalfOf,
|
|
uint256 amount,
|
|
uint16 indexed referral
|
|
);
|
|
|
|
/**
|
|
* @dev emitted during a withdraw action.
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user
|
|
* @param amount the amount to be withdrawn
|
|
**/
|
|
event Withdraw(address indexed reserve, address indexed user, uint256 amount);
|
|
|
|
event BorrowAllowanceDelegated(
|
|
address indexed asset,
|
|
address indexed fromUser,
|
|
address indexed toUser,
|
|
uint256 interestRateMode,
|
|
uint256 amount
|
|
);
|
|
/**
|
|
* @dev emitted on borrow
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user
|
|
* @param amount the amount to be deposited
|
|
* @param borrowRateMode the rate mode, can be either 1-stable or 2-variable
|
|
* @param borrowRate the rate at which the user has borrowed
|
|
* @param referral the referral number of the action
|
|
**/
|
|
event Borrow(
|
|
address indexed reserve,
|
|
address user,
|
|
address indexed onBehalfOf,
|
|
uint256 amount,
|
|
uint256 borrowRateMode,
|
|
uint256 borrowRate,
|
|
uint16 indexed referral
|
|
);
|
|
/**
|
|
* @dev emitted on repay
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user for which the repay has been executed
|
|
* @param repayer the address of the user that has performed the repay action
|
|
* @param amount the amount repaid
|
|
**/
|
|
event Repay(
|
|
address indexed reserve,
|
|
address indexed user,
|
|
address indexed repayer,
|
|
uint256 amount
|
|
);
|
|
/**
|
|
* @dev emitted when a user performs a rate swap
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user executing the swap
|
|
**/
|
|
event Swap(address indexed reserve, address indexed user);
|
|
|
|
/**
|
|
* @dev emitted when a user enables a reserve as collateral
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user
|
|
**/
|
|
event ReserveUsedAsCollateralEnabled(address indexed reserve, address indexed user);
|
|
|
|
/**
|
|
* @dev emitted when a user disables a reserve as collateral
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user
|
|
**/
|
|
event ReserveUsedAsCollateralDisabled(address indexed reserve, address indexed user);
|
|
|
|
/**
|
|
* @dev emitted when the stable rate of a user gets rebalanced
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user for which the rebalance has been executed
|
|
**/
|
|
event RebalanceStableBorrowRate(address indexed reserve, address indexed user);
|
|
/**
|
|
* @dev emitted when a flashloan is executed
|
|
* @param target the address of the flashLoanReceiver
|
|
* @param reserve the address of the reserve
|
|
* @param amount the amount requested
|
|
* @param totalPremium the total fee on the amount
|
|
* @param referralCode the referral code of the caller
|
|
**/
|
|
event FlashLoan(
|
|
address indexed target,
|
|
address indexed reserve,
|
|
uint256 amount,
|
|
uint256 totalPremium,
|
|
uint16 referralCode
|
|
);
|
|
/**
|
|
* @dev these events are not emitted directly by the LendingPool
|
|
* but they are declared here as the LendingPoolLiquidationManager
|
|
* is executed using a delegateCall().
|
|
* This allows to have the events in the generated ABI for LendingPool.
|
|
**/
|
|
|
|
/**
|
|
* @dev emitted when a borrower is liquidated
|
|
* @param collateral the address of the collateral being liquidated
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user being liquidated
|
|
* @param purchaseAmount the total amount liquidated
|
|
* @param liquidatedCollateralAmount the amount of collateral being liquidated
|
|
* @param accruedBorrowInterest the amount of interest accrued by the borrower since the last action
|
|
* @param liquidator the address of the liquidator
|
|
* @param receiveAToken true if the liquidator wants to receive aTokens, false otherwise
|
|
**/
|
|
event LiquidationCall(
|
|
address indexed collateral,
|
|
address indexed reserve,
|
|
address indexed user,
|
|
uint256 purchaseAmount,
|
|
uint256 liquidatedCollateralAmount,
|
|
uint256 accruedBorrowInterest,
|
|
address liquidator,
|
|
bool receiveAToken
|
|
);
|
|
/**
|
|
* @dev Emitted when the pause is triggered.
|
|
*/
|
|
event Paused();
|
|
|
|
/**
|
|
* @dev Emitted when the pause is lifted.
|
|
*/
|
|
event Unpaused();
|
|
|
|
/**
|
|
* @dev deposits The underlying asset into the reserve. A corresponding amount of the overlying asset (aTokens)
|
|
* is minted.
|
|
* @param reserve the address of the reserve
|
|
* @param amount the amount to be deposited
|
|
* @param referralCode integrators are assigned a referral code and can potentially receive rewards.
|
|
**/
|
|
function deposit(
|
|
address reserve,
|
|
uint256 amount,
|
|
address onBehalfOf,
|
|
uint16 referralCode
|
|
) external;
|
|
|
|
/**
|
|
* @dev withdraws the assets of user.
|
|
* @param reserve the address of the reserve
|
|
* @param amount the underlying amount to be redeemed
|
|
**/
|
|
function withdraw(address reserve, uint256 amount) external;
|
|
|
|
/**
|
|
* @dev Sets allowance to borrow on a certain type of debt asset for a certain user address
|
|
* @param asset The underlying asset of the debt token
|
|
* @param user The user to give allowance to
|
|
* @param interestRateMode Type of debt: 1 for stable, 2 for variable
|
|
* @param amount Allowance amount to borrow
|
|
**/
|
|
function delegateBorrowAllowance(
|
|
address asset,
|
|
address user,
|
|
uint256 interestRateMode,
|
|
uint256 amount
|
|
) external;
|
|
|
|
function getBorrowAllowance(
|
|
address fromUser,
|
|
address toUser,
|
|
address asset,
|
|
uint256 interestRateMode
|
|
) external view returns (uint256);
|
|
|
|
/**
|
|
* @dev Allows users to borrow a specific amount of the reserve currency, provided that the borrower
|
|
* already deposited enough collateral.
|
|
* @param reserve the address of the reserve
|
|
* @param amount the amount to be borrowed
|
|
* @param interestRateMode the interest rate mode at which the user wants to borrow. Can be 0 (STABLE) or 1 (VARIABLE)
|
|
**/
|
|
function borrow(
|
|
address reserve,
|
|
uint256 amount,
|
|
uint256 interestRateMode,
|
|
uint16 referralCode,
|
|
address onBehalfOf
|
|
) external;
|
|
|
|
/**
|
|
* @notice repays a borrow on the specific reserve, for the specified amount (or for the whole amount, if uint256(-1) is specified).
|
|
* @dev the target user is defined by onBehalfOf. If there is no repayment on behalf of another account,
|
|
* onBehalfOf must be equal to msg.sender.
|
|
* @param reserve the address of the reserve on which the user borrowed
|
|
* @param amount the amount to repay, or uint256(-1) if the user wants to repay everything
|
|
* @param onBehalfOf the address for which msg.sender is repaying.
|
|
**/
|
|
function repay(
|
|
address reserve,
|
|
uint256 amount,
|
|
uint256 rateMode,
|
|
address onBehalfOf
|
|
) external;
|
|
|
|
/**
|
|
* @dev borrowers can user this function to swap between stable and variable borrow rate modes.
|
|
* @param reserve the address of the reserve on which the user borrowed
|
|
* @param rateMode the rate mode that the user wants to swap
|
|
**/
|
|
function swapBorrowRateMode(address reserve, uint256 rateMode) external;
|
|
|
|
/**
|
|
* @dev rebalances the stable interest rate of a user if current liquidity rate > user stable rate.
|
|
* this is regulated by Aave to ensure that the protocol is not abused, and the user is paying a fair
|
|
* rate. Anyone can call this function.
|
|
* @param reserve the address of the reserve
|
|
* @param user the address of the user to be rebalanced
|
|
**/
|
|
function rebalanceStableBorrowRate(address reserve, address user) external;
|
|
|
|
/**
|
|
* @dev allows depositors to enable or disable a specific deposit as collateral.
|
|
* @param reserve the address of the reserve
|
|
* @param useAsCollateral true if the user wants to user the deposit as collateral, false otherwise.
|
|
**/
|
|
function setUserUseReserveAsCollateral(address reserve, bool useAsCollateral) external;
|
|
|
|
/**
|
|
* @dev users can invoke this function to liquidate an undercollateralized position.
|
|
* @param reserve the address of the collateral to liquidated
|
|
* @param reserve the address of the principal reserve
|
|
* @param user the address of the borrower
|
|
* @param purchaseAmount the amount of principal that the liquidator wants to repay
|
|
* @param receiveAToken true if the liquidators wants to receive the aTokens, false if
|
|
* he wants to receive the underlying asset directly
|
|
**/
|
|
function liquidationCall(
|
|
address collateral,
|
|
address reserve,
|
|
address user,
|
|
uint256 purchaseAmount,
|
|
bool receiveAToken
|
|
) external;
|
|
|
|
/**
|
|
* @dev flashes the underlying collateral on an user to swap for the owed asset and repay
|
|
* - Both the owner of the position and other liquidators can execute it
|
|
* - The owner can repay with his collateral at any point, no matter the health factor
|
|
* - Other liquidators can only use this function below 1 HF. To liquidate 50% of the debt > HF 0.98 or the whole below
|
|
* @param collateral The address of the collateral asset
|
|
* @param principal The address of the owed asset
|
|
* @param user Address of the borrower
|
|
* @param principalAmount Amount of the debt to repay. type(uint256).max to repay the maximum possible
|
|
* @param receiver Address of the contract receiving the collateral to swap
|
|
* @param params Variadic bytes param to pass with extra information to the receiver
|
|
**/
|
|
function repayWithCollateral(
|
|
address collateral,
|
|
address principal,
|
|
address user,
|
|
uint256 principalAmount,
|
|
address receiver,
|
|
bytes calldata params
|
|
) external;
|
|
|
|
/**
|
|
* @dev allows smartcontracts to access the liquidity of the pool within one transaction,
|
|
* as long as the amount taken plus a fee is returned. NOTE There are security concerns for developers of flashloan receiver contracts
|
|
* that must be kept into consideration. For further details please visit https://developers.aave.com
|
|
* @param receiver The address of the contract receiving the funds. The receiver should implement the IFlashLoanReceiver interface.
|
|
* @param reserve the address of the principal reserve
|
|
* @param amount the amount requested for this flashloan
|
|
* @param params a bytes array to be sent to the flashloan executor
|
|
* @param referralCode the referral code of the caller
|
|
**/
|
|
function flashLoan(
|
|
address receiver,
|
|
address reserve,
|
|
uint256 amount,
|
|
uint256 debtType,
|
|
bytes calldata params,
|
|
uint16 referralCode
|
|
) external;
|
|
|
|
/**
|
|
* @dev Allows an user to release one of his assets deposited in the protocol, even if it is used as collateral, to swap for another.
|
|
* - It's not possible to release one asset to swap for the same
|
|
* @param receiverAddress The address of the contract receiving the funds. The receiver should implement the ISwapAdapter interface
|
|
* @param fromAsset Asset to swap from
|
|
* @param toAsset Asset to swap to
|
|
* @param params a bytes array to be sent (if needed) to the receiver contract with extra data
|
|
**/
|
|
function swapLiquidity(
|
|
address receiverAddress,
|
|
address fromAsset,
|
|
address toAsset,
|
|
uint256 amountToSwap,
|
|
bytes calldata params
|
|
) external;
|
|
|
|
/**
|
|
* @dev accessory functions to fetch data from the core contract
|
|
**/
|
|
|
|
function getReserveConfigurationData(address reserve)
|
|
external
|
|
view
|
|
returns (
|
|
uint256 decimals,
|
|
uint256 ltv,
|
|
uint256 liquidationThreshold,
|
|
uint256 liquidationBonus,
|
|
uint256 reserveFactor,
|
|
address interestRateStrategyAddress,
|
|
bool usageAsCollateralEnabled,
|
|
bool borrowingEnabled,
|
|
bool stableBorrowRateEnabled,
|
|
bool isActive,
|
|
bool isFreezed
|
|
);
|
|
|
|
function getReserveTokensAddresses(address reserve)
|
|
external
|
|
view
|
|
returns (
|
|
address aTokenAddress,
|
|
address stableDebtTokenAddress,
|
|
address variableDebtTokenAddress
|
|
);
|
|
|
|
function getReserveData(address reserve)
|
|
external
|
|
view
|
|
returns (
|
|
uint256 availableLiquidity,
|
|
uint256 totalStableDebt,
|
|
uint256 totalVariableDebt,
|
|
uint256 liquidityRate,
|
|
uint256 variableBorrowRate,
|
|
uint256 stableBorrowRate,
|
|
uint256 averageStableBorrowRate,
|
|
uint256 liquidityIndex,
|
|
uint256 variableBorrowIndex,
|
|
uint40 lastUpdateTimestamp
|
|
);
|
|
|
|
function getUserAccountData(address user)
|
|
external
|
|
view
|
|
returns (
|
|
uint256 totalCollateralETH,
|
|
uint256 totalBorrowsETH,
|
|
uint256 availableBorrowsETH,
|
|
uint256 currentLiquidationThreshold,
|
|
uint256 ltv,
|
|
uint256 healthFactor
|
|
);
|
|
|
|
function getUserReserveData(address reserve, address user)
|
|
external
|
|
view
|
|
returns (
|
|
uint256 currentATokenBalance,
|
|
uint256 currentStableDebt,
|
|
uint256 currentVariableDebt,
|
|
uint256 principalStableDebt,
|
|
uint256 scaledVariableDebt,
|
|
uint256 stableBorrowRate,
|
|
uint256 liquidityRate,
|
|
uint40 stableRateLastUpdated,
|
|
bool usageAsCollateralEnabled
|
|
);
|
|
|
|
/**
|
|
* @dev initializes a reserve
|
|
* @param reserve the address of the reserve
|
|
* @param aTokenAddress the address of the overlying aToken contract
|
|
* @param interestRateStrategyAddress the address of the interest rate strategy contract
|
|
**/
|
|
function initReserve(
|
|
address reserve,
|
|
address aTokenAddress,
|
|
address stableDebtAddress,
|
|
address variableDebtAddress,
|
|
address interestRateStrategyAddress
|
|
) external;
|
|
|
|
/**
|
|
* @dev updates the address of the interest rate strategy contract
|
|
* @param reserve the address of the reserve
|
|
* @param rateStrategyAddress the address of the interest rate strategy contract
|
|
**/
|
|
|
|
function setReserveInterestRateStrategyAddress(address reserve, address rateStrategyAddress)
|
|
external;
|
|
|
|
function setConfiguration(address reserve, uint256 configuration) external;
|
|
|
|
function getConfiguration(address reserve)
|
|
external
|
|
view
|
|
returns (ReserveConfiguration.Map memory);
|
|
|
|
function getReserveNormalizedIncome(address reserve) external view returns (uint256);
|
|
|
|
function getReserveNormalizedVariableDebt(address reserve) external view returns (uint256);
|
|
|
|
function balanceDecreaseAllowed(
|
|
address reserve,
|
|
address user,
|
|
uint256 amount
|
|
) external view returns (bool);
|
|
|
|
function getReserves() external view returns (address[] memory);
|
|
|
|
/**
|
|
* @dev Set the _pause state
|
|
* @param val the boolean value to set the current pause state of LendingPool
|
|
*/
|
|
function setPause(bool val) external;
|
|
|
|
/**
|
|
* @dev Returns if the LendingPool is paused
|
|
*/
|
|
function paused() external view returns(bool);
|
|
}
|