Go to file
2020-10-24 13:49:57 +02:00
.circleci feat: DebtBridge v1 contracts refactored 2020-10-23 16:46:29 +02:00
.vscode feat: DebtBridge v1 contracts refactored 2020-10-23 16:46:29 +02:00
assets automatic DSR - CDAI rebalance prototype tested 2020-08-24 16:36:07 +02:00
contracts Fix bug, put buffer on the full refinancing 2020-10-24 13:49:57 +02:00
pre-compiles Unit testing new smart contract. 2020-10-23 16:46:29 +02:00
test Add buffer to instaPool borrow, optimize gas cost by removing two extra instamemory write 2020-10-24 13:49:57 +02:00
test_temp feat: clean debt bridge connector and payable fns 2020-10-24 13:49:57 +02:00
.eslintrc.json chore: config linting, formatting and git hooks 2020-10-08 11:36:22 +02:00
.gitattributes Gelato DSA setup tests complete 2020-08-22 15:40:51 +02:00
.gitignore feat: DebtBridge v1 contracts refactored 2020-10-23 16:46:29 +02:00
.prettierignore chore: rebased Full refinancing on new master 2020-10-24 13:49:57 +02:00
.prettierrc.json chore: config linting, formatting and git hooks 2020-10-08 11:36:22 +02:00
.solhint.json feat: DebtBridge v1 contracts refactored 2020-10-23 16:46:29 +02:00
.solhintignore feat: DebtBridge v1 contracts refactored 2020-10-23 16:46:29 +02:00
hardhat.config.js feat: DebtBridge v1 contracts refactored 2020-10-23 16:46:29 +02:00
package.json feat: clean debt bridge connector and payable fns 2020-10-24 13:49:57 +02:00
README.md refactored debt bridge smart contract, added comments and edited readme 2020-10-24 13:49:57 +02:00
yarn.lock feat: clean debt bridge connector and payable fns 2020-10-24 13:49:57 +02:00

gelato-instadapp

gelatodigital

This repo contains smart contracts, mocks and a test suite showcasing how InstaDapp DSAs and Gelato can work together to automate the execution (or casting) of Spells (connectors) based on arbitrary Conditions.

Use Cases

1. Move DAI lending from DSR to Compound

For the first iteration, we started with a simple spell: Move DAI lending from DSR to Compound. This reused two existing deployed InstaDapp Connectors: ConnectMaker.withdrawDai and ConnectCompound.deposit.

Furtheremore the following contracts were added to showcase the automation of the Spell:

  • MockCDAI.sol and MockDSR.sol: to normalize CDAI.supplyRatePerBlock and dsr values to a per second rate in 10**27 precision

  • ConditionCompareUintsFromTwoSource: a generic Gelato Condition that allows you to read and compare data from 2 arbitrary on-chain sources (returndata expected to be uint256 and normalized => hence MockDSR and MockCDAI). This Condition was used to compare DSR to CDAI rates and in the test suite we showcase how a change in the CDAI rate (it going above the DSR) can trigger an automatic rebalancing from DSR to CDAI via DSA Connectors.

  • ProviderModuleDSA: this is needed for any Gelato integration. It tells Gelato how the execution payload should be formatted. In this prototype, it formats the payload for the DSA.cast function.

  • ConnectGelato: this is a Connector needed for the DSA to be able to submit Tasks to Gelato. In the test suite we unlock the DSA MultiSig Master account at 0xfCD22438AD6eD564a1C26151Df73F6B33B817B56, in order to be able to enable this Connector in our mainnet fork running on the local hardhat network instance.

In this example, the DSA simply pre-deposits some ETH on Gelato to repay the executor for the transaction fees incurred from executing the task.

To see for yourself check out the contracts folder and make sure to check out test/mv-DAI-DSR-Compound.test.js, to see an end-to-end test showcasing the prototype.

2. Debt Bridge - Refinance debt position from Maker to Compound based on changes in the ETH / USD price

Debt Bridge is a financial process that aims to make the user position safer. InstaDapp DSA and Gelato together can automate this process.

Full Refinancing from Maker's Vault to Compound.

Based on the debt bridge documentation of Instadapp, we automated this process by adding two connectors ConnectGelatoDebtBridge, ConnectGelatoProviderPayment and a Gelato condition contract.

  • ConditionMakerVaultIsSafe.sol: determine if a specific vault is on an unsafe position.

  • ConnectGelatoDebtBridge.sol: generates the required data which will be assigned to the different inputs needed by ConnectMaker and ConnectCompound by using InstaMemory. Examples are the amount of DAI to pay back or the amount of Ether to withdraw from Maker.

  • ConnectGelatoProviderPayment.sol: makes sure part of the moved collateral is used to pay the Gelato provider for the incurred transaction fee. The Gelato Provider will in turn pay the executor who executed the task.

In this example, the executor will be refunded for the incurred transaction fees by subtracting the estimated gas costs from the collateral which is moved from Maker to Compound. This means the user does not have to pre pay in order to incentivize the execution of the task.

For understanding the entire process of a full refinancing, from the opening of the vault on maker to the execution of the refinancing on InstaDapp, take a look at test/2_Full-Debt-Bridge-Maker-Compound.test.js test.

Known Bugs

Sometimes when running the test/2_Full-Debt-Bridge-Maker-Compound.test.js test, Hardhat will throw the folliwing error: AssertionError: Expected event "LogExecSuccess" to be emitted, but it wasn't. If this happens, just wait a few seconds and re-run the tests, eventually it should work.

Run the tests

  1. Clone this repo
  2. Put your Alchemy ID in .env
  3. yarn install
  4. npx hardhat test