mirror of
https://github.com/Instadapp/dsa-connectors-old.git
synced 2024-07-29 22:47:46 +00:00
Added depositAndBorrow function in makerDao
This commit is contained in:
parent
8ce92dcb1d
commit
0e014b4126
|
@ -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')
|
||||||
|
@ -427,11 +445,7 @@ contract BasicResolver is MakerHelpers {
|
||||||
|
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogDeposit(_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);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -542,11 +556,7 @@ contract BasicResolver is MakerHelpers {
|
||||||
|
|
||||||
setUint(setId, _amt);
|
setUint(setId, _amt);
|
||||||
|
|
||||||
emit LogBorrow(_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(address(this), _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.
|
||||||
|
|
Loading…
Reference in New Issue
Block a user