mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
updated with new connectors & updates
This commit is contained in:
parent
994fb1dd31
commit
9d2a61e40f
|
|
@ -82,6 +82,7 @@ contract BasicResolver is AaveHelpers {
|
||||||
event LogWithdraw(address indexed token, uint256 tokenAmt, uint256 getId, uint256 setId);
|
event LogWithdraw(address indexed token, uint256 tokenAmt, uint256 getId, uint256 setId);
|
||||||
event LogBorrow(address indexed token, uint256 tokenAmt, uint256 getId, uint256 setId);
|
event LogBorrow(address indexed token, uint256 tokenAmt, uint256 getId, uint256 setId);
|
||||||
event LogPayback(address indexed token, uint256 tokenAmt, uint256 getId, uint256 setId);
|
event LogPayback(address indexed token, uint256 tokenAmt, uint256 getId, uint256 setId);
|
||||||
|
event LogEnableCollateral(address[] tokens);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Deposit ETH/ERC20_Token.
|
* @dev Deposit ETH/ERC20_Token.
|
||||||
|
|
@ -111,9 +112,6 @@ contract BasicResolver is AaveHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogDeposit(token, _amt, getId, setId);
|
emit LogDeposit(token, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogDeposit(address,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(token, _amt, getId, setId);
|
|
||||||
emitEvent(_eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -137,9 +135,6 @@ contract BasicResolver is AaveHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogWithdraw(token, _amt, getId, setId);
|
emit LogWithdraw(token, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogWithdraw(address,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(token, _amt, getId, setId);
|
|
||||||
emitEvent(_eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -156,9 +151,6 @@ contract BasicResolver is AaveHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogBorrow(token, _amt, getId, setId);
|
emit LogBorrow(token, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogBorrow(address,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(token, _amt, getId, setId);
|
|
||||||
emitEvent(_eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -189,12 +181,29 @@ contract BasicResolver is AaveHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogPayback(token, _amt, getId, setId);
|
emit LogPayback(token, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogPayback(address,uint256,uint256,uint256)");
|
}
|
||||||
bytes memory _eventParam = abi.encode(token, _amt, getId, setId);
|
|
||||||
emitEvent(_eventCode, _eventParam);
|
/**
|
||||||
|
* @dev Enable collateral
|
||||||
|
* @param tokens Array of tokens to enable collateral
|
||||||
|
*/
|
||||||
|
function enableCollateral(address[] calldata tokens) external payable {
|
||||||
|
uint _length = tokens.length;
|
||||||
|
require(_length > 0, "0-tokens-not-allowed");
|
||||||
|
|
||||||
|
AaveInterface aave = AaveInterface(getAaveProvider().getLendingPool());
|
||||||
|
|
||||||
|
for (uint i = 0; i < _length; i++) {
|
||||||
|
address token = tokens[i];
|
||||||
|
if (getWithdrawBalance(token) > 0 && !getIsColl(aave, token)) {
|
||||||
|
aave.setUserUseReserveAsCollateral(token, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
emit LogEnableCollateral(tokens);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
contract ConnectAave is BasicResolver {
|
contract ConnectAave is BasicResolver {
|
||||||
string public name = "Aave-v1";
|
string public name = "Aave-v1.1";
|
||||||
}
|
}
|
||||||
266
contracts/connectors_old/aave_v2.sol
Normal file
266
contracts/connectors_old/aave_v2.sol
Normal file
|
|
@ -0,0 +1,266 @@
|
||||||
|
pragma solidity ^0.6.0;
|
||||||
|
pragma experimental ABIEncoderV2;
|
||||||
|
|
||||||
|
// import files from common directory
|
||||||
|
import { TokenInterface , MemoryInterface} from "../common/interfaces.sol";
|
||||||
|
import { Stores } from "../common/stores.sol";
|
||||||
|
import { DSMath } from "../common/math.sol";
|
||||||
|
|
||||||
|
interface AaveInterface {
|
||||||
|
function deposit(address _asset, uint256 _amount, address _onBehalfOf, uint16 _referralCode) external;
|
||||||
|
function withdraw(address _asset, uint256 _amount, address _to) external;
|
||||||
|
function borrow(
|
||||||
|
address _asset,
|
||||||
|
uint256 _amount,
|
||||||
|
uint256 _interestRateMode,
|
||||||
|
uint16 _referralCode,
|
||||||
|
address _onBehalfOf
|
||||||
|
) external;
|
||||||
|
function repay(address _asset, uint256 _amount, uint256 _rateMode, address _onBehalfOf) external;
|
||||||
|
function setUserUseReserveAsCollateral(address _asset, bool _useAsCollateral) external;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface AaveLendingPoolProviderInterface {
|
||||||
|
function getLendingPool() external view returns (address);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Aave Protocol Data Provider
|
||||||
|
interface AaveDataProviderInterface {
|
||||||
|
function getReserveTokensAddresses(address _asset) external view returns (
|
||||||
|
address aTokenAddress,
|
||||||
|
address stableDebtTokenAddress,
|
||||||
|
address variableDebtTokenAddress
|
||||||
|
);
|
||||||
|
function getUserReserveData(address _asset, address _user) external view returns (
|
||||||
|
uint256 currentATokenBalance,
|
||||||
|
uint256 currentStableDebt,
|
||||||
|
uint256 currentVariableDebt,
|
||||||
|
uint256 principalStableDebt,
|
||||||
|
uint256 scaledVariableDebt,
|
||||||
|
uint256 stableBorrowRate,
|
||||||
|
uint256 liquidityRate,
|
||||||
|
uint40 stableRateLastUpdated,
|
||||||
|
bool usageAsCollateralEnabled
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
interface AaveAddressProviderRegistryInterface {
|
||||||
|
function getAddressesProvidersList() external view returns (address[] memory);
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ATokenInterface {
|
||||||
|
function balanceOf(address _user) external view returns(uint256);
|
||||||
|
}
|
||||||
|
|
||||||
|
contract AaveHelpers is DSMath, Stores {
|
||||||
|
/**
|
||||||
|
* @dev get Aave Lending Pool Provider
|
||||||
|
*/
|
||||||
|
function getAaveProvider() internal pure returns (AaveLendingPoolProviderInterface) {
|
||||||
|
return AaveLendingPoolProviderInterface(0xB53C1a33016B2DC2fF3653530bfF1848a515c8c5); //mainnet
|
||||||
|
// return AaveLendingPoolProviderInterface(0x652B2937Efd0B5beA1c8d54293FC1289672AFC6b); //kovan
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev get Aave Protocol Data Provider
|
||||||
|
*/
|
||||||
|
function getAaveDataProvider() internal pure returns (AaveDataProviderInterface) {
|
||||||
|
return AaveDataProviderInterface(0x057835Ad21a177dbdd3090bB1CAE03EaCF78Fc6d); //mainnet
|
||||||
|
// return AaveDataProviderInterface(0x744C1aaA95232EeF8A9994C4E0b3a89659D9AB79); //kovan
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Return Weth address
|
||||||
|
*/
|
||||||
|
function getWethAddr() internal pure returns (address) {
|
||||||
|
return 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2; // Mainnet WETH Address
|
||||||
|
// return 0xd0A1E359811322d97991E03f863a0C30C2cF029C; // Kovan WETH Address
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev get Referral Code
|
||||||
|
*/
|
||||||
|
function getReferralCode() internal pure returns (uint16) {
|
||||||
|
return 3228;
|
||||||
|
}
|
||||||
|
|
||||||
|
function getIsColl(AaveDataProviderInterface aaveData, address token, address user) internal view returns (bool isCol) {
|
||||||
|
(, , , , , , , , isCol) = aaveData.getUserReserveData(token, user);
|
||||||
|
}
|
||||||
|
|
||||||
|
function convertEthToWeth(bool isEth, TokenInterface token, uint amount) internal {
|
||||||
|
if(isEth) token.deposit.value(amount)();
|
||||||
|
}
|
||||||
|
|
||||||
|
function convertWethToEth(bool isEth, TokenInterface token, uint amount) internal {
|
||||||
|
if(isEth) {
|
||||||
|
token.approve(address(token), amount);
|
||||||
|
token.withdraw(amount);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function getPaybackBalance(AaveDataProviderInterface aaveData, address token, uint rateMode) internal view returns (uint) {
|
||||||
|
(, uint stableDebt, uint variableDebt, , , , , , ) = aaveData.getUserReserveData(token, address(this));
|
||||||
|
return rateMode == 1 ? stableDebt : variableDebt;
|
||||||
|
}
|
||||||
|
|
||||||
|
function getCollateralBalance(AaveDataProviderInterface aaveData, address token) internal view returns (uint bal) {
|
||||||
|
(bal, , , , , , , ,) = aaveData.getUserReserveData(token, address(this));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
contract BasicResolver is AaveHelpers {
|
||||||
|
event LogDeposit(address indexed token, uint256 tokenAmt, uint256 getId, uint256 setId);
|
||||||
|
event LogWithdraw(address indexed token, uint256 tokenAmt, uint256 getId, uint256 setId);
|
||||||
|
event LogBorrow(address indexed token, uint256 tokenAmt, uint256 indexed rateMode, uint256 getId, uint256 setId);
|
||||||
|
event LogPayback(address indexed token, uint256 tokenAmt, uint256 indexed rateMode, uint256 getId, uint256 setId);
|
||||||
|
event LogEnableCollateral(address[] tokens);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Deposit ETH/ERC20_Token.
|
||||||
|
* @param token token address to deposit.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
||||||
|
* @param amt token amount to deposit.
|
||||||
|
* @param getId Get token amount at this ID from `InstaMemory` Contract.
|
||||||
|
* @param setId Set token amount at this ID in `InstaMemory` Contract.
|
||||||
|
*/
|
||||||
|
function deposit(address token, uint amt, uint getId, uint setId) external payable {
|
||||||
|
uint _amt = getUint(getId, amt);
|
||||||
|
|
||||||
|
AaveInterface aave = AaveInterface(getAaveProvider().getLendingPool());
|
||||||
|
AaveDataProviderInterface aaveData = getAaveDataProvider();
|
||||||
|
|
||||||
|
bool isEth = token == getEthAddr();
|
||||||
|
address _token = isEth ? getWethAddr() : token;
|
||||||
|
|
||||||
|
TokenInterface tokenContract = TokenInterface(_token);
|
||||||
|
|
||||||
|
if (isEth) {
|
||||||
|
_amt = _amt == uint(-1) ? address(this).balance : _amt;
|
||||||
|
convertEthToWeth(isEth, tokenContract, _amt);
|
||||||
|
} else {
|
||||||
|
_amt = _amt == uint(-1) ? tokenContract.balanceOf(address(this)) : _amt;
|
||||||
|
}
|
||||||
|
|
||||||
|
tokenContract.approve(address(aave), _amt);
|
||||||
|
|
||||||
|
aave.deposit(_token, _amt, address(this), getReferralCode());
|
||||||
|
|
||||||
|
if (!getIsColl(aaveData, _token, address(this))) {
|
||||||
|
aave.setUserUseReserveAsCollateral(_token, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
setUint(setId, _amt);
|
||||||
|
|
||||||
|
emit LogDeposit(token, _amt, getId, setId);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Withdraw ETH/ERC20_Token.
|
||||||
|
* @param token token address to withdraw.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
||||||
|
* @param amt token amount to withdraw.
|
||||||
|
* @param getId Get token amount at this ID from `InstaMemory` Contract.
|
||||||
|
* @param setId Set token amount at this ID in `InstaMemory` Contract.
|
||||||
|
*/
|
||||||
|
function withdraw(address token, uint amt, uint getId, uint setId) external payable {
|
||||||
|
uint _amt = getUint(getId, amt);
|
||||||
|
|
||||||
|
AaveInterface aave = AaveInterface(getAaveProvider().getLendingPool());
|
||||||
|
bool isEth = token == getEthAddr();
|
||||||
|
address _token = isEth ? getWethAddr() : token;
|
||||||
|
|
||||||
|
TokenInterface tokenContract = TokenInterface(_token);
|
||||||
|
|
||||||
|
uint initialBal = tokenContract.balanceOf(address(this));
|
||||||
|
aave.withdraw(_token, _amt, address(this));
|
||||||
|
uint finalBal = tokenContract.balanceOf(address(this));
|
||||||
|
|
||||||
|
_amt = sub(finalBal, initialBal);
|
||||||
|
|
||||||
|
convertWethToEth(isEth, tokenContract, _amt);
|
||||||
|
|
||||||
|
setUint(setId, _amt);
|
||||||
|
|
||||||
|
emit LogWithdraw(token, _amt, getId, setId);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Borrow ETH/ERC20_Token.
|
||||||
|
* @param token token address to borrow.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
||||||
|
* @param amt token amount to borrow.
|
||||||
|
* @param rateMode type of borrow debt.(For Stable: 1, Variable: 2)
|
||||||
|
* @param getId Get token amount at this ID from `InstaMemory` Contract.
|
||||||
|
* @param setId Set token amount at this ID in `InstaMemory` Contract.
|
||||||
|
*/
|
||||||
|
function borrow(address token, uint amt, uint rateMode, uint getId, uint setId) external payable {
|
||||||
|
uint _amt = getUint(getId, amt);
|
||||||
|
|
||||||
|
AaveInterface aave = AaveInterface(getAaveProvider().getLendingPool());
|
||||||
|
|
||||||
|
bool isEth = token == getEthAddr();
|
||||||
|
address _token = isEth ? getWethAddr() : token;
|
||||||
|
|
||||||
|
aave.borrow(_token, _amt, rateMode, getReferralCode(), address(this));
|
||||||
|
convertWethToEth(isEth, TokenInterface(_token), _amt);
|
||||||
|
|
||||||
|
setUint(setId, _amt);
|
||||||
|
|
||||||
|
emit LogBorrow(token, _amt, rateMode, getId, setId);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Payback borrowed ETH/ERC20_Token.
|
||||||
|
* @param token token address to payback.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
||||||
|
* @param amt token amount to payback.
|
||||||
|
* @param rateMode type of borrow debt.(For Stable: 1, Variable: 2)
|
||||||
|
* @param getId Get token amount at this ID from `InstaMemory` Contract.
|
||||||
|
* @param setId Set token amount at this ID in `InstaMemory` Contract.
|
||||||
|
*/
|
||||||
|
function payback(address token, uint amt, uint rateMode, uint getId, uint setId) external payable {
|
||||||
|
uint _amt = getUint(getId, amt);
|
||||||
|
|
||||||
|
AaveInterface aave = AaveInterface(getAaveProvider().getLendingPool());
|
||||||
|
AaveDataProviderInterface aaveData = getAaveDataProvider();
|
||||||
|
|
||||||
|
bool isEth = token == getEthAddr();
|
||||||
|
address _token = isEth ? getWethAddr() : token;
|
||||||
|
|
||||||
|
TokenInterface tokenContract = TokenInterface(_token);
|
||||||
|
|
||||||
|
_amt = _amt == uint(-1) ? getPaybackBalance(aaveData, _token, rateMode) : _amt;
|
||||||
|
|
||||||
|
if (isEth) convertEthToWeth(isEth, tokenContract, _amt);
|
||||||
|
|
||||||
|
tokenContract.approve(address(aave), _amt);
|
||||||
|
|
||||||
|
aave.repay(_token, _amt, rateMode, address(this));
|
||||||
|
|
||||||
|
setUint(setId, _amt);
|
||||||
|
|
||||||
|
emit LogPayback(token, _amt, rateMode, getId, setId);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Enable collateral
|
||||||
|
* @param tokens Array of tokens to enable collateral
|
||||||
|
*/
|
||||||
|
function enableCollateral(address[] calldata tokens) external payable {
|
||||||
|
uint _length = tokens.length;
|
||||||
|
require(_length > 0, "0-tokens-not-allowed");
|
||||||
|
|
||||||
|
AaveInterface aave = AaveInterface(getAaveProvider().getLendingPool());
|
||||||
|
AaveDataProviderInterface aaveData = getAaveDataProvider();
|
||||||
|
|
||||||
|
for (uint i = 0; i < _length; i++) {
|
||||||
|
address token = tokens[i];
|
||||||
|
if (getCollateralBalance(aaveData, token) > 0 && !getIsColl(aaveData, token, address(this))) {
|
||||||
|
aave.setUserUseReserveAsCollateral(token, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
emit LogEnableCollateral(tokens);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
contract ConnectAaveV2 is BasicResolver {
|
||||||
|
string public name = "AaveV2-v1.1";
|
||||||
|
}
|
||||||
|
|
@ -63,7 +63,7 @@ contract BasicResolver is Stores {
|
||||||
uint getId,
|
uint getId,
|
||||||
uint setId
|
uint setId
|
||||||
) public payable {
|
) public payable {
|
||||||
require(AccountInterface(address(this)).isAuth(to), "invalid-to-address");
|
// require(AccountInterface(address(this)).isAuth(to), "invalid-to-address");
|
||||||
uint amt = getUint(getId, tokenAmt);
|
uint amt = getUint(getId, tokenAmt);
|
||||||
if (erc20 == getEthAddr()) {
|
if (erc20 == getEthAddr()) {
|
||||||
amt = amt == uint(-1) ? address(this).balance : amt;
|
amt = amt == uint(-1) ? address(this).balance : amt;
|
||||||
|
|
|
||||||
|
|
@ -47,10 +47,6 @@ interface MemoryInterface {
|
||||||
function setUint(uint _id, uint _val) external;
|
function setUint(uint _id, uint _val) external;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface EventInterface {
|
|
||||||
function emitEvent(uint _connectorType, uint _connectorID, bytes32 _eventCode, bytes calldata _eventData) external;
|
|
||||||
}
|
|
||||||
|
|
||||||
contract DSMath {
|
contract DSMath {
|
||||||
|
|
||||||
function add(uint x, uint y) internal pure returns (uint z) {
|
function add(uint x, uint y) internal pure returns (uint z) {
|
||||||
|
|
@ -93,12 +89,12 @@ contract Helpers is DSMath {
|
||||||
return 0x8a5419CfC711B2343c17a6ABf4B2bAFaBb06957F; // InstaMemory Address
|
return 0x8a5419CfC711B2343c17a6ABf4B2bAFaBb06957F; // InstaMemory Address
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
// /**
|
||||||
* @dev Return InstaEvent Address.
|
// * @dev Return InstaEvent Address.
|
||||||
*/
|
// */
|
||||||
function getEventAddr() internal pure returns (address) {
|
// function getEventAddr() internal pure returns (address) {
|
||||||
return 0x2af7ea6Cb911035f3eb1ED895Cb6692C39ecbA97; // InstaEvent Address
|
// return 0x2af7ea6Cb911035f3eb1ED895Cb6692C39ecbA97; // InstaEvent Address
|
||||||
}
|
// }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Get Uint value from InstaMemory Contract.
|
* @dev Get Uint value from InstaMemory Contract.
|
||||||
|
|
@ -118,7 +114,7 @@ contract Helpers is DSMath {
|
||||||
* @dev Connector Details
|
* @dev Connector Details
|
||||||
*/
|
*/
|
||||||
function connectorID() public pure returns(uint _type, uint _id) {
|
function connectorID() public pure returns(uint _type, uint _id) {
|
||||||
(_type, _id) = (1, 24);
|
(_type, _id) = (1, 57);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -190,15 +186,11 @@ contract BasicResolver is CompoundHelpers {
|
||||||
TokenInterface tokenContract = TokenInterface(token);
|
TokenInterface tokenContract = TokenInterface(token);
|
||||||
_amt = _amt == uint(-1) ? tokenContract.balanceOf(address(this)) : _amt;
|
_amt = _amt == uint(-1) ? tokenContract.balanceOf(address(this)) : _amt;
|
||||||
tokenContract.approve(cToken, _amt);
|
tokenContract.approve(cToken, _amt);
|
||||||
require(CTokenInterface(cToken).mint(_amt) == 0, "borrow-failed");
|
require(CTokenInterface(cToken).mint(_amt) == 0, "deposit-failed");
|
||||||
}
|
}
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogDeposit(token, cToken, _amt, getId, setId);
|
emit LogDeposit(token, cToken, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogDeposit(address,address,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(token, cToken, _amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -224,10 +216,6 @@ contract BasicResolver is CompoundHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogWithdraw(token, cToken, _amt, getId, setId);
|
emit LogWithdraw(token, cToken, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogWithdraw(address,address,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(token, cToken, _amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -245,10 +233,6 @@ contract BasicResolver is CompoundHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogBorrow(token, cToken, _amt, getId, setId);
|
emit LogBorrow(token, cToken, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogBorrow(address,address,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(token, cToken, _amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -276,17 +260,13 @@ contract BasicResolver is CompoundHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogPayback(token, cToken, _amt, getId, setId);
|
emit LogPayback(token, cToken, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogPayback(address,address,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(token, cToken, _amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
contract ExtraResolver is BasicResolver {
|
contract ExtraResolver is BasicResolver {
|
||||||
event LogClaimedComp(uint256 compAmt, uint256 setId);
|
event LogClaimedComp(uint256 compAmt, uint256 setId);
|
||||||
event LogDepositCToken(address indexed token, address cToken, uint256 tokenAmt, uint256 cTokenAmt,uint256 getId, uint256 setId);
|
event LogDepositCToken(address indexed token, address cToken, uint256 tokenAmt, uint256 cTokenAmt,uint256 getId, uint256 setId);
|
||||||
event LogWithdrawCToken(address indexed token, address cToken, uint256 cTokenAmt, uint256 getId, uint256 setId);
|
event LogWithdrawCToken(address indexed token, address cToken, uint256 tokenAmt, uint256 cTokenAmt, uint256 getId, uint256 setId);
|
||||||
event LogLiquidate(
|
event LogLiquidate(
|
||||||
address indexed borrower,
|
address indexed borrower,
|
||||||
address indexed tokenToPay,
|
address indexed tokenToPay,
|
||||||
|
|
@ -296,26 +276,6 @@ contract ExtraResolver is BasicResolver {
|
||||||
uint256 setId
|
uint256 setId
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
|
||||||
* @dev Claim Accrued COMP Token.
|
|
||||||
* @param setId Set ctoken amount at this ID in `InstaMemory` Contract.
|
|
||||||
*/
|
|
||||||
function ClaimComp(uint setId) external payable {
|
|
||||||
TokenInterface compToken = TokenInterface(getCompTokenAddress());
|
|
||||||
uint intialBal = compToken.balanceOf(address(this));
|
|
||||||
ComptrollerInterface(getComptrollerAddress()).claimComp(address(this));
|
|
||||||
uint finalBal = compToken.balanceOf(address(this));
|
|
||||||
uint amt = sub(finalBal, intialBal);
|
|
||||||
|
|
||||||
setUint(setId, amt);
|
|
||||||
|
|
||||||
emit LogClaimedComp(amt, setId);
|
|
||||||
bytes32 _eventCode = keccak256("LogClaimedComp(uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(amt, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Deposit ETH/ERC20_Token.
|
* @dev Deposit ETH/ERC20_Token.
|
||||||
* @param token token address to depositCToken.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
* @param token token address to depositCToken.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
||||||
|
|
@ -346,10 +306,6 @@ contract ExtraResolver is BasicResolver {
|
||||||
setUint(setId, _cAmt);
|
setUint(setId, _cAmt);
|
||||||
|
|
||||||
emit LogDepositCToken(token, cToken, _amt, _cAmt, getId, setId);
|
emit LogDepositCToken(token, cToken, _amt, _cAmt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogDepositCToken(address,address,uint256,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(token, cToken, _amt, _cAmt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -357,22 +313,23 @@ contract ExtraResolver is BasicResolver {
|
||||||
* @param token token address to withdraw CToken.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
* @param token token address to withdraw CToken.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
||||||
* @param cTokenAmt ctoken amount to withdrawCToken.
|
* @param cTokenAmt ctoken amount to withdrawCToken.
|
||||||
* @param getId Get ctoken amount at this ID from `InstaMemory` Contract.
|
* @param getId Get ctoken amount at this ID from `InstaMemory` Contract.
|
||||||
* @param setId Set ctoken amount at this ID in `InstaMemory` Contract.
|
* @param setId Set token amount at this ID in `InstaMemory` Contract.
|
||||||
*/
|
*/
|
||||||
function withdrawCToken(address token, uint cTokenAmt, uint getId, uint setId) external payable {
|
function withdrawCToken(address token, uint cTokenAmt, uint getId, uint setId) external payable {
|
||||||
uint _amt = getUint(getId, cTokenAmt);
|
uint _cAmt = getUint(getId, cTokenAmt);
|
||||||
address cToken = InstaMapping(getMappingAddr()).cTokenMapping(token);
|
address cToken = InstaMapping(getMappingAddr()).cTokenMapping(token);
|
||||||
CTokenInterface cTokenContract = CTokenInterface(cToken);
|
CTokenInterface cTokenContract = CTokenInterface(cToken);
|
||||||
_amt = _amt == uint(-1) ? cTokenContract.balanceOf(address(this)) : _amt;
|
TokenInterface tokenContract = TokenInterface(token);
|
||||||
require(cTokenContract.redeem(_amt) == 0, "redeem-failed");
|
_cAmt = _cAmt == uint(-1) ? cTokenContract.balanceOf(address(this)) : _cAmt;
|
||||||
setUint(setId, _amt);
|
|
||||||
|
|
||||||
emit LogWithdrawCToken(token, cToken, _amt, getId, setId);
|
uint initialBal = token != getAddressETH() ? tokenContract.balanceOf(address(this)) : address(this).balance;
|
||||||
bytes32 _eventCode = keccak256("LogWithdrawCToken(address,address,uint256,uint256,uint256)");
|
require(cTokenContract.redeem(_cAmt) == 0, "redeem-failed");
|
||||||
bytes memory _eventParam = abi.encode(token, cToken, _amt, getId, setId);
|
uint finalBal = token != getAddressETH() ? tokenContract.balanceOf(address(this)) : address(this).balance;
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
|
|
||||||
|
uint withdrawAmt = sub(finalBal, initialBal);
|
||||||
|
setUint(setId, withdrawAmt);
|
||||||
|
|
||||||
|
emit LogWithdrawCToken(token, cToken, withdrawAmt, _cAmt, getId, setId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -421,22 +378,10 @@ contract ExtraResolver is BasicResolver {
|
||||||
getId,
|
getId,
|
||||||
setId
|
setId
|
||||||
);
|
);
|
||||||
bytes32 _eventCode = keccak256("LogLiquidate(address,address,address,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(
|
|
||||||
address(this),
|
|
||||||
tokenToPay,
|
|
||||||
tokenInReturn,
|
|
||||||
_amt,
|
|
||||||
getId,
|
|
||||||
setId
|
|
||||||
);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
contract ConnectCompound is ExtraResolver {
|
contract ConnectCompound is ExtraResolver {
|
||||||
string public name = "Compound-v1.2";
|
string public name = "Compound-v1.3";
|
||||||
}
|
}
|
||||||
78
contracts/connectors_old/fee.sol
Normal file
78
contracts/connectors_old/fee.sol
Normal file
|
|
@ -0,0 +1,78 @@
|
||||||
|
pragma solidity ^0.6.0;
|
||||||
|
pragma experimental ABIEncoderV2;
|
||||||
|
|
||||||
|
interface MemoryInterface {
|
||||||
|
function getUint(uint _id) external returns (uint _num);
|
||||||
|
function setUint(uint _id, uint _val) external;
|
||||||
|
}
|
||||||
|
|
||||||
|
contract DSMath {
|
||||||
|
uint256 constant WAD = 10 ** 18;
|
||||||
|
|
||||||
|
function add(uint x, uint y) internal pure returns (uint z) {
|
||||||
|
require((z = x + y) >= x, "math-not-safe");
|
||||||
|
}
|
||||||
|
|
||||||
|
function mul(uint x, uint y) internal pure returns (uint z) {
|
||||||
|
require(y == 0 || (z = x * y) / y == x, "math-not-safe");
|
||||||
|
}
|
||||||
|
|
||||||
|
function wmul(uint x, uint y) internal pure returns (uint z) {
|
||||||
|
z = add(mul(x, y), WAD / 2) / WAD;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
contract Setup is DSMath {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Return InstAaMemory Address.
|
||||||
|
*/
|
||||||
|
function getMemoryAddr() internal pure returns (address) {
|
||||||
|
return 0x8a5419CfC711B2343c17a6ABf4B2bAFaBb06957F;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Get Uint value from InstaMemory Contract.
|
||||||
|
*/
|
||||||
|
function getUint(uint getId, uint val) internal returns (uint returnVal) {
|
||||||
|
returnVal = getId == 0 ? val : MemoryInterface(getMemoryAddr()).getUint(getId);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Set Uint value in InstaMemory Contract.
|
||||||
|
*/
|
||||||
|
function setUint(uint setId, uint val) internal {
|
||||||
|
if (setId != 0) MemoryInterface(getMemoryAddr()).setUint(setId, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Connector ID and Type. TODO: change.
|
||||||
|
*/
|
||||||
|
function connectorID() public pure returns(uint _type, uint _id) {
|
||||||
|
(_type, _id) = (1, 37);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
contract FeeResolver is Setup {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Calculate fee
|
||||||
|
*/
|
||||||
|
function calculateFee(uint amount, uint fee, uint getId, uint setId, uint setIdFee) external payable {
|
||||||
|
uint _amt = getUint(getId, amount);
|
||||||
|
|
||||||
|
uint feeAmt = wmul(_amt, fee);
|
||||||
|
|
||||||
|
uint totalAmt = add(_amt, feeAmt);
|
||||||
|
|
||||||
|
setUint(setId, totalAmt);
|
||||||
|
setUint(setIdFee, feeAmt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
contract ConnectFee is FeeResolver {
|
||||||
|
string public constant name = "Fee-v1";
|
||||||
|
}
|
||||||
|
|
@ -3,7 +3,6 @@ pragma solidity ^0.6.0;
|
||||||
interface TokenInterface {
|
interface TokenInterface {
|
||||||
function approve(address, uint) external;
|
function approve(address, uint) external;
|
||||||
function transfer(address, uint) external;
|
function transfer(address, uint) external;
|
||||||
function transferFrom(address, address, uint) external;
|
|
||||||
function deposit() external payable;
|
function deposit() external payable;
|
||||||
function withdraw(uint) external;
|
function withdraw(uint) external;
|
||||||
function balanceOf(address) external view returns (uint);
|
function balanceOf(address) external view returns (uint);
|
||||||
|
|
@ -40,7 +39,6 @@ interface VatLike {
|
||||||
function hope(address) external;
|
function hope(address) external;
|
||||||
function move(address, address, uint) external;
|
function move(address, address, uint) external;
|
||||||
function gem(bytes32, address) external view returns (uint);
|
function gem(bytes32, address) external view returns (uint);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
interface TokenJoinInterface {
|
interface TokenJoinInterface {
|
||||||
|
|
@ -184,7 +182,7 @@ contract Helpers is DSMath {
|
||||||
* @dev Connector Details
|
* @dev Connector Details
|
||||||
*/
|
*/
|
||||||
function connectorID() public pure returns(uint _type, uint _id) {
|
function connectorID() public pure returns(uint _type, uint _id) {
|
||||||
(_type, _id) = (1, 40);
|
(_type, _id) = (1, 61);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -333,7 +331,7 @@ contract MakerHelpers is MakerMCDAddresses {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
contract EventHelper is MakerHelpers {
|
contract BasicResolver is MakerHelpers {
|
||||||
event LogOpen(uint256 indexed vault, bytes32 indexed ilk);
|
event LogOpen(uint256 indexed vault, bytes32 indexed ilk);
|
||||||
event LogClose(uint256 indexed vault, bytes32 indexed ilk);
|
event LogClose(uint256 indexed vault, bytes32 indexed ilk);
|
||||||
event LogTransfer(uint256 indexed vault, bytes32 indexed ilk, address newOwner);
|
event LogTransfer(uint256 indexed vault, bytes32 indexed ilk, address newOwner);
|
||||||
|
|
@ -342,24 +340,6 @@ contract EventHelper is MakerHelpers {
|
||||||
event LogBorrow(uint256 indexed vault, bytes32 indexed ilk, uint256 tokenAmt, uint256 getId, uint256 setId);
|
event LogBorrow(uint256 indexed vault, bytes32 indexed ilk, uint256 tokenAmt, uint256 getId, uint256 setId);
|
||||||
event LogPayback(uint256 indexed vault, bytes32 indexed ilk, uint256 tokenAmt, uint256 getId, uint256 setId);
|
event LogPayback(uint256 indexed vault, bytes32 indexed ilk, uint256 tokenAmt, uint256 getId, uint256 setId);
|
||||||
|
|
||||||
function emitLogDeposit(uint256 vault, bytes32 ilk, uint256 tokenAmt, uint256 getId, uint256 setId) internal {
|
|
||||||
emit LogDeposit(vault, ilk, tokenAmt, getId, setId);
|
|
||||||
bytes32 _eventCode = keccak256("LogDeposit(uint256,bytes32,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(vault, ilk, tokenAmt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
|
||||||
|
|
||||||
function emitLogBorrow(uint256 vault, bytes32 ilk, uint256 tokenAmt, uint256 getId, uint256 setId) internal {
|
|
||||||
emit LogBorrow(vault, ilk, tokenAmt, getId, setId);
|
|
||||||
bytes32 _eventCode = keccak256("LogBorrow(uint256,bytes32,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(vault, ilk, tokenAmt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
contract BasicResolver is EventHelper {
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Open Vault
|
* @dev Open Vault
|
||||||
|
|
@ -371,10 +351,6 @@ contract BasicResolver is EventHelper {
|
||||||
vault = ManagerLike(getMcdManager()).open(ilk, address(this));
|
vault = ManagerLike(getMcdManager()).open(ilk, address(this));
|
||||||
|
|
||||||
emit LogOpen(vault, ilk);
|
emit LogOpen(vault, ilk);
|
||||||
bytes32 _eventCode = keccak256("LogOpen(uint256,bytes32)");
|
|
||||||
bytes memory _eventParam = abi.encode(vault, ilk);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -394,10 +370,6 @@ contract BasicResolver is EventHelper {
|
||||||
managerContract.give(_vault, getGiveAddress());
|
managerContract.give(_vault, getGiveAddress());
|
||||||
|
|
||||||
emit LogClose(_vault, ilk);
|
emit LogClose(_vault, ilk);
|
||||||
bytes32 _eventCode = keccak256("LogClose(uint256,bytes32)");
|
|
||||||
bytes memory _eventParam = abi.encode(_vault, ilk);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -445,7 +417,7 @@ contract BasicResolver is EventHelper {
|
||||||
|
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emitLogDeposit(_vault, ilk, _amt, getId, setId);
|
emit LogDeposit(vault, ilk, _amt, getId, setId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -502,10 +474,6 @@ contract BasicResolver is EventHelper {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogWithdraw(_vault, ilk, _amt, getId, setId);
|
emit LogWithdraw(_vault, ilk, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogWithdraw(uint256,bytes32,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(_vault, ilk, _amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -556,7 +524,7 @@ contract BasicResolver is EventHelper {
|
||||||
|
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emitLogBorrow(_vault, ilk, _amt, getId, setId);
|
emit LogBorrow(vault, ilk, _amt, getId, setId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -603,10 +571,6 @@ contract BasicResolver is EventHelper {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogPayback(_vault, ilk, _amt, getId, setId);
|
emit LogPayback(_vault, ilk, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogPayback(uint256,bytes32,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(_vault, ilk, _amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -640,7 +604,7 @@ contract BasicExtraResolver is BasicResolver {
|
||||||
uint _amt18;
|
uint _amt18;
|
||||||
if (_amt == uint(-1)) {
|
if (_amt == uint(-1)) {
|
||||||
_amt18 = VatLike(managerContract.vat()).gem(ilk, urn);
|
_amt18 = VatLike(managerContract.vat()).gem(ilk, urn);
|
||||||
_amt = convert18ToDec(tokenJoinContract.dec(), _amt);
|
_amt = convert18ToDec(tokenJoinContract.dec(), _amt18);
|
||||||
} else {
|
} else {
|
||||||
_amt18 = convertTo18(tokenJoinContract.dec(), _amt);
|
_amt18 = convertTo18(tokenJoinContract.dec(), _amt);
|
||||||
}
|
}
|
||||||
|
|
@ -660,10 +624,6 @@ contract BasicExtraResolver is BasicResolver {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogWithdrawLiquidated(vault, ilk, _amt, getId, setId);
|
emit LogWithdrawLiquidated(vault, ilk, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogWithdrawLiquidated(uint256,bytes32,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(vault, ilk, _amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
struct MakerData {
|
struct MakerData {
|
||||||
|
|
@ -745,9 +705,9 @@ contract BasicExtraResolver is BasicResolver {
|
||||||
setUint(setIdDeposit, _amtDeposit);
|
setUint(setIdDeposit, _amtDeposit);
|
||||||
setUint(setIdBorrow, _amtBorrow);
|
setUint(setIdBorrow, _amtBorrow);
|
||||||
|
|
||||||
emitLogDeposit(makerData._vault, ilk, _amtDeposit, getIdDeposit, setIdDeposit);
|
emit LogDeposit(makerData._vault, ilk, _amtDeposit, getIdDeposit, setIdDeposit);
|
||||||
|
|
||||||
emitLogBorrow(makerData._vault, ilk, _amtBorrow, getIdBorrow, setIdBorrow);
|
emit LogBorrow(makerData._vault, ilk, _amtBorrow, getIdBorrow, setIdBorrow);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -792,10 +752,6 @@ contract BasicExtraResolver is BasicResolver {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogExitDai(_vault, ilk, _amt, getId, setId);
|
emit LogExitDai(_vault, ilk, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogExitDai(uint256,bytes32,uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(_vault, ilk, _amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -838,10 +794,6 @@ contract DsrResolver is BasicExtraResolver {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogDepositDai(_amt, getId, setId);
|
emit LogDepositDai(_amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogDepositDai(uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(_amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -886,13 +838,9 @@ contract DsrResolver is BasicExtraResolver {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogWithdrawDai(_amt, getId, setId);
|
emit LogWithdrawDai(_amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogWithdrawDai(uint256,uint256,uint256)");
|
|
||||||
bytes memory _eventParam = abi.encode(_amt, getId, setId);
|
|
||||||
(uint _type, uint _id) = connectorID();
|
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
contract ConnectMaker is DsrResolver {
|
contract ConnectMaker is DsrResolver {
|
||||||
string public constant name = "MakerDao-v1.3";
|
string public constant name = "MakerDao-v1.4";
|
||||||
}
|
}
|
||||||
Loading…
Reference in New Issue
Block a user