mirror of
https://github.com/Instadapp/dsa-connectors-old.git
synced 2024-07-29 22:47:46 +00:00
Merge pull request #20 from InstaDApp/Maker-connector-update
Maker connector update
This commit is contained in:
commit
20df1625de
|
@ -184,7 +184,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, 26);
|
(_type, _id) = (1, 40);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -333,8 +333,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);
|
||||||
|
@ -343,6 +342,25 @@ contract BasicResolver 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
|
||||||
* @param colType Type of Collateral.(eg: 'ETH-A')
|
* @param colType Type of Collateral.(eg: 'ETH-A')
|
||||||
|
@ -428,10 +446,6 @@ contract BasicResolver is MakerHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emitLogDeposit(_vault, ilk, _amt, getId, setId);
|
emitLogDeposit(_vault, ilk, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogDeposit(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);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -543,10 +557,6 @@ contract BasicResolver is MakerHelpers {
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emitLogBorrow(_vault, ilk, _amt, getId, setId);
|
emitLogBorrow(_vault, ilk, _amt, getId, setId);
|
||||||
bytes32 _eventCode = keccak256("LogBorrow(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);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -656,6 +666,90 @@ contract BasicExtraResolver is BasicResolver {
|
||||||
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
EventInterface(getEventAddr()).emitEvent(_type, _id, _eventCode, _eventParam);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct MakerData {
|
||||||
|
uint _vault;
|
||||||
|
address colAddr;
|
||||||
|
address daiJoin;
|
||||||
|
TokenJoinInterface tokenJoinContract;
|
||||||
|
VatLike vatContract;
|
||||||
|
TokenInterface tokenContract;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @dev Deposit ETH/ERC20_Token Collateral and Borrow DAI.
|
||||||
|
* @param vault Vault ID.
|
||||||
|
* @param depositAmt token deposit amount to Withdraw.
|
||||||
|
* @param borrowAmt token borrow amount to Withdraw.
|
||||||
|
* @param getIdDeposit Get deposit token amount at this ID from `InstaMemory` Contract.
|
||||||
|
* @param getIdBorrow Get borrow token amount at this ID from `InstaMemory` Contract.
|
||||||
|
* @param setIdDeposit Set deposit token amount at this ID in `InstaMemory` Contract.
|
||||||
|
* @param setIdBorrow Set borrow token amount at this ID in `InstaMemory` Contract.
|
||||||
|
*/
|
||||||
|
function depositAndBorrow(
|
||||||
|
uint vault,
|
||||||
|
uint depositAmt,
|
||||||
|
uint borrowAmt,
|
||||||
|
uint getIdDeposit,
|
||||||
|
uint getIdBorrow,
|
||||||
|
uint setIdDeposit,
|
||||||
|
uint setIdBorrow
|
||||||
|
) external payable
|
||||||
|
{
|
||||||
|
ManagerLike managerContract = ManagerLike(getMcdManager());
|
||||||
|
MakerData memory makerData;
|
||||||
|
uint _amtDeposit = getUint(getIdDeposit, depositAmt);
|
||||||
|
uint _amtBorrow = getUint(getIdBorrow, borrowAmt);
|
||||||
|
|
||||||
|
makerData._vault = getVault(managerContract, vault);
|
||||||
|
(bytes32 ilk, address urn) = getVaultData(managerContract, makerData._vault);
|
||||||
|
|
||||||
|
makerData.colAddr = InstaMapping(getMappingAddr()).gemJoinMapping(ilk);
|
||||||
|
makerData.tokenJoinContract = TokenJoinInterface(makerData.colAddr);
|
||||||
|
makerData.vatContract = VatLike(managerContract.vat());
|
||||||
|
makerData.daiJoin = getMcdDaiJoin();
|
||||||
|
|
||||||
|
makerData.tokenContract = makerData.tokenJoinContract.gem();
|
||||||
|
|
||||||
|
if (isEth(address(makerData.tokenContract))) {
|
||||||
|
_amtDeposit = _amtDeposit == uint(-1) ? address(this).balance : _amtDeposit;
|
||||||
|
makerData.tokenContract.deposit.value(_amtDeposit)();
|
||||||
|
} else {
|
||||||
|
_amtDeposit = _amtDeposit == uint(-1) ? makerData.tokenContract.balanceOf(address(this)) : _amtDeposit;
|
||||||
|
}
|
||||||
|
|
||||||
|
makerData.tokenContract.approve(address(makerData.colAddr), _amtDeposit);
|
||||||
|
makerData.tokenJoinContract.join(urn, _amtDeposit);
|
||||||
|
|
||||||
|
managerContract.frob(
|
||||||
|
makerData._vault,
|
||||||
|
toInt(convertTo18(makerData.tokenJoinContract.dec(), _amtDeposit)),
|
||||||
|
_getBorrowAmt(
|
||||||
|
address(makerData.vatContract),
|
||||||
|
urn,
|
||||||
|
ilk,
|
||||||
|
_amtBorrow
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
managerContract.move(
|
||||||
|
makerData._vault,
|
||||||
|
address(this),
|
||||||
|
toRad(_amtBorrow)
|
||||||
|
);
|
||||||
|
|
||||||
|
if (makerData.vatContract.can(address(this), address(makerData.daiJoin)) == 0) {
|
||||||
|
makerData.vatContract.hope(makerData.daiJoin);
|
||||||
|
}
|
||||||
|
|
||||||
|
DaiJoinInterface(makerData.daiJoin).exit(address(this), _amtBorrow);
|
||||||
|
|
||||||
|
setUint(setIdDeposit, _amtDeposit);
|
||||||
|
setUint(setIdBorrow, _amtBorrow);
|
||||||
|
|
||||||
|
emitLogDeposit(makerData._vault, ilk, _amtDeposit, getIdDeposit, setIdDeposit);
|
||||||
|
|
||||||
|
emitLogBorrow(makerData._vault, ilk, _amtBorrow, getIdBorrow, setIdBorrow);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Exit DAI from urn.
|
* @dev Exit DAI from urn.
|
||||||
* @param vault Vault ID.
|
* @param vault Vault ID.
|
||||||
|
@ -800,5 +894,5 @@ contract DsrResolver is BasicExtraResolver {
|
||||||
}
|
}
|
||||||
|
|
||||||
contract ConnectMaker is DsrResolver {
|
contract ConnectMaker is DsrResolver {
|
||||||
string public constant name = "MakerDao-v1.2";
|
string public constant name = "MakerDao-v1.3";
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user