aave-protocol-v2/contracts/protocol/tokenization/VariableDebtToken.sol

143 lines
4.4 KiB
Solidity
Raw Normal View History

// SPDX-License-Identifier: agpl-3.0
2020-11-20 10:45:20 +00:00
pragma solidity 0.6.12;
2020-06-30 12:09:28 +00:00
import {IVariableDebtToken} from '../../interfaces/IVariableDebtToken.sol';
2020-08-20 07:51:21 +00:00
import {WadRayMath} from '../libraries/math/WadRayMath.sol';
2020-09-30 15:40:47 +00:00
import {Errors} from '../libraries/helpers/Errors.sol';
import {DebtTokenBase} from './base/DebtTokenBase.sol';
2020-06-30 12:09:28 +00:00
/**
* @title VariableDebtToken
* @notice Implements a variable debt token to track the borrowing positions of users
* at variable rate mode
2020-07-13 08:54:08 +00:00
* @author Aave
**/
2020-06-30 12:09:28 +00:00
contract VariableDebtToken is DebtTokenBase, IVariableDebtToken {
using WadRayMath for uint256;
uint256 public constant DEBT_TOKEN_REVISION = 0x2;
2020-08-17 19:28:50 +00:00
2020-08-18 09:39:34 +00:00
constructor(
address pool,
address underlyingAsset,
string memory name,
2020-09-15 13:53:20 +00:00
string memory symbol,
address incentivesController
) public DebtTokenBase(pool, underlyingAsset, name, symbol, incentivesController) {}
2020-08-17 19:28:50 +00:00
/**
* @dev Gets the revision of the stable debt token implementation
* @return The debt token implementation revision
2020-08-17 19:28:50 +00:00
**/
function getRevision() internal pure virtual override returns (uint256) {
2020-08-17 19:28:50 +00:00
return DEBT_TOKEN_REVISION;
}
/**
* @dev Calculates the accumulated debt balance of the user
* @return The debt balance of the user
2020-07-13 08:54:08 +00:00
**/
function balanceOf(address user) public view virtual override returns (uint256) {
2020-09-14 13:09:16 +00:00
uint256 scaledBalance = super.balanceOf(user);
2020-09-10 09:25:45 +00:00
if (scaledBalance == 0) {
2020-06-30 12:09:28 +00:00
return 0;
}
return scaledBalance.rayMul(POOL.getReserveNormalizedVariableDebt(UNDERLYING_ASSET_ADDRESS));
2020-06-30 12:09:28 +00:00
}
2020-07-03 21:20:02 +00:00
/**
* @dev Mints debt token to the `onBehalfOf` address
* - Only callable by the LendingPool
* @param user The address receiving the borrowed underlying, being the delegatee in case
* of credit delegate, or same as `onBehalfOf` otherwise
* @param onBehalfOf The address receiving the debt tokens
* @param amount The amount of debt being minted
* @param index The variable debt index of the reserve
* @return `true` if the the previous balance of the user is 0
2020-07-13 08:54:08 +00:00
**/
function mint(
address user,
2020-11-03 18:47:57 +00:00
address onBehalfOf,
uint256 amount,
uint256 index
2020-10-15 12:13:46 +00:00
) external override onlyLendingPool returns (bool) {
2020-11-03 18:47:57 +00:00
if (user != onBehalfOf) {
_decreaseBorrowAllowance(onBehalfOf, user, amount);
}
uint256 previousBalance = super.balanceOf(onBehalfOf);
2020-09-30 15:40:47 +00:00
uint256 amountScaled = amount.rayDiv(index);
2020-11-12 12:54:23 +00:00
require(amountScaled != 0, Errors.CT_INVALID_MINT_AMOUNT);
2020-09-30 15:40:47 +00:00
2020-11-03 18:47:57 +00:00
_mint(onBehalfOf, amountScaled);
2020-07-03 21:20:02 +00:00
2020-11-03 18:47:57 +00:00
emit Transfer(address(0), onBehalfOf, amount);
emit Mint(user, onBehalfOf, amount, index);
2020-10-15 12:13:46 +00:00
return previousBalance == 0;
2020-06-30 12:09:28 +00:00
}
/**
* @dev Burns user variable debt
* - Only callable by the LendingPool
* @param user The user whose debt is getting burned
* @param amount The amount getting burned
* @param index The variable debt index of the reserve
2020-07-13 08:54:08 +00:00
**/
function burn(
address user,
uint256 amount,
uint256 index
) external override onlyLendingPool {
2020-09-30 15:40:47 +00:00
uint256 amountScaled = amount.rayDiv(index);
2020-11-12 12:54:23 +00:00
require(amountScaled != 0, Errors.CT_INVALID_BURN_AMOUNT);
2020-09-30 15:40:47 +00:00
_burn(user, amountScaled);
2020-07-03 21:20:02 +00:00
2020-09-15 13:20:32 +00:00
emit Transfer(user, address(0), amount);
2020-09-21 15:41:38 +00:00
emit Burn(user, amount, index);
2020-06-30 12:09:28 +00:00
}
2020-09-10 10:51:52 +00:00
2020-09-10 11:05:02 +00:00
/**
* @dev Returns the principal debt balance of the user from
* @return The debt balance of the user since the last burn/mint action
**/
function scaledBalanceOf(address user) public view virtual override returns (uint256) {
2020-09-10 11:05:02 +00:00
return super.balanceOf(user);
}
/**
* @dev Returns the total supply of the variable debt token. Represents the total debt accrued by the users
* @return The total supply
**/
function totalSupply() public view virtual override returns (uint256) {
return
super.totalSupply().rayMul(POOL.getReserveNormalizedVariableDebt(UNDERLYING_ASSET_ADDRESS));
2020-09-10 11:05:02 +00:00
}
/**
* @dev Returns the scaled total supply of the variable debt token. Represents sum(debt/index)
* @return the scaled total supply
**/
function scaledTotalSupply() public view virtual override returns (uint256) {
return super.totalSupply();
}
2020-09-21 15:41:38 +00:00
2020-10-08 13:41:48 +00:00
/**
2020-11-26 13:58:42 +00:00
* @dev Returns the principal balance of the user and principal total supply.
* @param user The address of the user
* @return The principal balance of the user
* @return The principal total supply
2020-09-21 15:41:38 +00:00
**/
2020-10-08 13:41:48 +00:00
function getScaledUserBalanceAndSupply(address user)
external
view
override
2020-10-08 13:41:48 +00:00
returns (uint256, uint256)
{
2020-09-21 15:41:38 +00:00
return (super.balanceOf(user), super.totalSupply());
2020-06-30 12:09:28 +00:00
}
}