standardized maker and erc20

This commit is contained in:
Islarky Overlord 2021-06-16 07:23:37 +08:00
parent 899b78c8dd
commit 162a110323
7 changed files with 386 additions and 1 deletions

1
.gitignore vendored
View File

@ -63,6 +63,7 @@ build/contracts
# buidler
artifacts
cache
bin
node_modules

View File

@ -28,7 +28,7 @@ contract Resolver {
tokensBal[i] = Balances({
flusher: flushers[i],
balance: bals,
isDeployed: isContractDeployed(flushers[i]);
isDeployed: isContractDeployed(flushers[i])
});
}
return tokensBal;

View File

@ -0,0 +1,10 @@
pragma solidity ^0.6.10;
pragma experimental ABIEncoderV2;
interface TokenInterface {
function balanceOf(address) external view returns (uint);
function allowance(address owner, address spender) external view returns (uint256);
function decimals() external view returns (uint);
function name() external view returns (string memory);
function symbol() external view returns (string memory);
}

View File

@ -0,0 +1,90 @@
pragma solidity ^0.6.10;
pragma experimental ABIEncoderV2;
import {TokenInterface} from "./interface.sol";
contract Resolver {
struct TokenData {
bool isToken;
string name;
string symbol;
uint256 decimals;
}
function getTokenDetails(address[] memory tknAddress)
public
view
returns (TokenData[] memory)
{
TokenData[] memory tokenDatas = new TokenData[](tknAddress.length);
for (uint256 i = 0; i < tknAddress.length; i++) {
if (tknAddress[i] == 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE) {
tokenDatas[i] = TokenData(true, "ETHER", "ETH", 18);
} else {
TokenInterface token = TokenInterface(tknAddress[i]);
bool isToken = true;
try token.symbol() {} catch {
isToken = false;
continue;
}
try token.name() {} catch {
isToken = false;
continue;
}
try token.decimals() {} catch {
isToken = false;
continue;
}
tokenDatas[i] = TokenData(
true,
token.name(),
token.symbol(),
token.decimals()
);
}
}
return tokenDatas;
}
function getBalances(address owner, address[] memory tknAddress)
public
view
returns (uint256[] memory)
{
uint256[] memory tokensBal = new uint256[](tknAddress.length);
for (uint256 i = 0; i < tknAddress.length; i++) {
if (tknAddress[i] == 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE) {
tokensBal[i] = owner.balance;
} else {
TokenInterface token = TokenInterface(tknAddress[i]);
tokensBal[i] = token.balanceOf(owner);
}
}
return tokensBal;
}
function getAllowances(
address owner,
address spender,
address[] memory tknAddress
) public view returns (uint256[] memory) {
uint256[] memory tokenAllowances = new uint256[](tknAddress.length);
for (uint256 i = 0; i < tknAddress.length; i++) {
if (tknAddress[i] == 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE) {
tokenAllowances[i] = 0;
} else {
TokenInterface token = TokenInterface(tknAddress[i]);
tokenAllowances[i] = token.allowance(owner, spender);
}
}
return tokenAllowances;
}
}
contract InstaERC20Resolver is Resolver {
string public constant name = "ERC20-Resolver-v1.1";
}

View File

@ -0,0 +1,107 @@
pragma solidity ^0.6.0;
import {DSMath} from "../../common/math.sol";
import {VatLike, SpotLike, JugLike, InstaMcdAddress} from "./interface.sol";
contract Helpers is DSMath {
/**
* @dev get MakerDAO MCD Address contract
*/
function getMcdAddresses() public pure returns (address) {
return 0xF23196DF1C440345DE07feFbe556a5eF0dcD29F0;
}
struct VaultData {
uint id;
address owner;
string colType;
uint collateral;
uint art;
uint debt;
uint liquidatedCol;
uint borrowRate;
uint colPrice;
uint liquidationRatio;
address vaultAddress;
}
struct ColInfo {
uint borrowRate;
uint price;
uint liquidationRatio;
uint vaultDebtCelling;
uint vaultDebtFloor;
uint vaultTotalDebt;
uint totalDebtCelling;
uint TotalDebt;
}
/**
* @dev Convert String to bytes32.
*/
function stringToBytes32(string memory str) internal pure returns (bytes32 result) {
require(bytes(str).length != 0, "String-Empty");
// solium-disable-next-line security/no-inline-assembly
assembly {
result := mload(add(str, 32))
}
}
/**
* @dev Convert bytes32 to String.
*/
function bytes32ToString(bytes32 _bytes32) internal pure returns (string memory) {
bytes32 _temp;
uint count;
for (uint256 i; i < 32; i++) {
_temp = _bytes32[i];
if( _temp != bytes32(0)) {
count += 1;
}
}
bytes memory bytesArray = new bytes(count);
for (uint256 i; i < count; i++) {
bytesArray[i] = (_bytes32[i]);
}
return (string(bytesArray));
}
function getFee(bytes32 ilk) internal view returns (uint fee) {
address jug = InstaMcdAddress(getMcdAddresses()).jug();
(uint duty,) = JugLike(jug).ilks(ilk);
uint base = JugLike(jug).base();
fee = add(duty, base);
}
function getColPrice(bytes32 ilk) internal view returns (uint price) {
address spot = InstaMcdAddress(getMcdAddresses()).spot();
address vat = InstaMcdAddress(getMcdAddresses()).vat();
(, uint mat) = SpotLike(spot).ilks(ilk);
(,,uint spotPrice,,) = VatLike(vat).ilks(ilk);
price = rmul(mat, spotPrice);
}
function getColRatio(bytes32 ilk) internal view returns (uint ratio) {
address spot = InstaMcdAddress(getMcdAddresses()).spot();
(, ratio) = SpotLike(spot).ilks(ilk);
}
function getDebtFloorAndCeiling(bytes32 ilk) internal view returns (uint, uint, uint, uint, uint) {
address vat = InstaMcdAddress(getMcdAddresses()).vat();
(uint totalArt,uint rate,, uint vaultDebtCellingRad, uint vaultDebtFloor) = VatLike(vat).ilks(ilk);
uint vaultDebtCelling = vaultDebtCellingRad / 10 ** 45;
uint vaultTotalDebt = rmul(totalArt, rate);
uint totalDebtCelling = VatLike(vat).Line();
uint totalDebt = VatLike(vat).debt();
return (
vaultDebtCelling,
vaultTotalDebt,
vaultDebtFloor,
totalDebtCelling,
totalDebt
);
}
}

View File

@ -0,0 +1,50 @@
pragma solidity ^0.6.0;
pragma experimental ABIEncoderV2;
interface ManagerLike {
function ilks(uint) external view returns (bytes32);
function owns(uint) external view returns (address);
function urns(uint) external view returns (address);
function vat() external view returns (address);
}
interface CdpsLike {
function getCdpsAsc(address, address) external view returns (uint[] memory, address[] memory, bytes32[] memory);
}
interface VatLike {
function ilks(bytes32) external view returns (uint, uint, uint, uint, uint);
function dai(address) external view returns (uint);
function urns(bytes32, address) external view returns (uint, uint);
function gem(bytes32, address) external view returns (uint);
function debt() external view returns (uint);
function Line() external view returns (uint);
}
interface JugLike {
function ilks(bytes32) external view returns (uint, uint);
function base() external view returns (uint);
}
interface PotLike {
function dsr() external view returns (uint);
function pie(address) external view returns (uint);
function chi() external view returns (uint);
}
interface SpotLike {
function ilks(bytes32) external view returns (PipLike, uint);
}
interface PipLike {
function peek() external view returns (bytes32, bool);
}
interface InstaMcdAddress {
function manager() external view returns (address);
function vat() external view returns (address);
function jug() external view returns (address);
function spot() external view returns (address);
function pot() external view returns (address);
function getCdps() external view returns (address);
}

View File

@ -0,0 +1,127 @@
pragma solidity ^0.6.0;
pragma experimental ABIEncoderV2;
import {Helpers} from "./helpers.sol";
import {InstaMcdAddress, VatLike, CdpsLike, ManagerLike, PotLike} from "./interface.sol";
contract VaultResolver is Helpers {
function getVaults(address owner)
external
view
returns (VaultData[] memory)
{
address manager = InstaMcdAddress(getMcdAddresses()).manager();
address cdpManger = InstaMcdAddress(getMcdAddresses()).getCdps();
(uint256[] memory ids, address[] memory urns, bytes32[] memory ilks) =
CdpsLike(cdpManger).getCdpsAsc(manager, owner);
VaultData[] memory vaults = new VaultData[](ids.length);
for (uint256 i = 0; i < ids.length; i++) {
(uint256 ink, uint256 art) =
VatLike(ManagerLike(manager).vat()).urns(ilks[i], urns[i]);
(, uint256 rate, uint256 priceMargin, , ) =
VatLike(ManagerLike(manager).vat()).ilks(ilks[i]);
uint256 mat = getColRatio(ilks[i]);
vaults[i] = VaultData(
ids[i],
owner,
bytes32ToString(ilks[i]),
ink,
art,
rmul(art, rate),
VatLike(ManagerLike(manager).vat()).gem(ilks[i], urns[i]),
getFee(ilks[i]),
rmul(priceMargin, mat),
mat,
urns[i]
);
}
return vaults;
}
function getVaultById(uint256 id) external view returns (VaultData memory) {
address manager = InstaMcdAddress(getMcdAddresses()).manager();
address urn = ManagerLike(manager).urns(id);
bytes32 ilk = ManagerLike(manager).ilks(id);
(uint256 ink, uint256 art) =
VatLike(ManagerLike(manager).vat()).urns(ilk, urn);
(, uint256 rate, uint256 priceMargin, , ) =
VatLike(ManagerLike(manager).vat()).ilks(ilk);
uint256 mat = getColRatio(ilk);
uint256 feeRate = getFee(ilk);
VaultData memory vault =
VaultData(
id,
ManagerLike(manager).owns(id),
bytes32ToString(ilk),
ink,
art,
rmul(art, rate),
VatLike(ManagerLike(manager).vat()).gem(ilk, urn),
feeRate,
rmul(priceMargin, mat),
mat,
urn
);
return vault;
}
function getColInfo(string[] memory name)
public
view
returns (ColInfo[] memory)
{
ColInfo[] memory colInfo = new ColInfo[](name.length);
for (uint256 i = 0; i < name.length; i++) {
bytes32 ilk = stringToBytes32(name[i]);
(
uint256 vaultDebtCelling,
uint256 vaultDebtFloor,
uint256 vaultTotalDebt,
uint256 totalDebtCelling,
uint256 totalDebt
) = getDebtFloorAndCeiling(ilk);
colInfo[i] = ColInfo(
getFee(ilk),
getColPrice(ilk),
getColRatio(ilk),
vaultDebtCelling,
vaultTotalDebt,
vaultDebtFloor,
totalDebtCelling,
totalDebt
);
}
return colInfo;
}
}
contract DSRResolver is VaultResolver {
function getDsrRate() public view returns (uint256 dsr) {
address pot = InstaMcdAddress(getMcdAddresses()).pot();
dsr = PotLike(pot).dsr();
}
function getDaiPosition(address owner)
external
view
returns (uint256 amt, uint256 dsr)
{
address pot = InstaMcdAddress(getMcdAddresses()).pot();
uint256 chi = PotLike(pot).chi();
uint256 pie = PotLike(pot).pie(owner);
amt = rmul(pie, chi);
dsr = getDsrRate();
}
}
contract InstaMakerResolver is DSRResolver {
string public constant name = "Maker-Resolver-v1.4";
}