-
Notifications
You must be signed in to change notification settings - Fork 91
/
Copy pathLibCreditNftRedemptionCalculator.sol
41 lines (36 loc) · 1.53 KB
/
LibCreditNftRedemptionCalculator.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// SPDX-License-Identifier: MIT
pragma solidity 0.8.19;
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
import "abdk/ABDKMathQuad.sol";
import {CreditNft} from "../../dollar/core/CreditNft.sol";
import {LibAppStorage, AppStorage} from "./LibAppStorage.sol";
/// @notice Library for calculating amount of Credit NFTs to mint on Dollars burn
library LibCreditNftRedemptionCalculator {
using ABDKMathQuad for uint256;
using ABDKMathQuad for bytes16;
/**
* @notice Returns Credit NFT amount minted for `dollarsToBurn` amount of Dollars to burn
* @param dollarsToBurn Amount of Dollars to burn
* @return Amount of Credit NFTs to mint
*/
function getCreditNftAmount(
uint256 dollarsToBurn
) internal view returns (uint256) {
AppStorage storage store = LibAppStorage.appStorage();
address creditNftAddress = store.creditNftAddress;
CreditNft cNFT = CreditNft(creditNftAddress);
require(
cNFT.getTotalOutstandingDebt() <
IERC20(store.dollarTokenAddress).totalSupply(),
"CreditNft to Dollar: DEBT_TOO_HIGH"
);
bytes16 one = uint256(1).fromUInt();
bytes16 totalDebt = cNFT.getTotalOutstandingDebt().fromUInt();
bytes16 r = totalDebt.div(
IERC20(store.dollarTokenAddress).totalSupply().fromUInt()
);
bytes16 oneMinusRAllSquared = (one.sub(r)).mul(one.sub(r));
bytes16 res = one.div(oneMinusRAllSquared);
return res.mul(dollarsToBurn.fromUInt()).toUInt();
}
}