.circleci | ||
.vscode | ||
assets | ||
contracts | ||
pre-compiles | ||
test | ||
test_temp | ||
.eslintrc.json | ||
.gitattributes | ||
.gitignore | ||
.prettierignore | ||
.prettierrc.json | ||
.solhint.json | ||
.solhintignore | ||
ConnectGelatoDebtBridge.sol | ||
hardhat.config.js | ||
package.json | ||
README.md | ||
yarn.lock |
gelato-instadapp
This repo contains smart contract prototypes and mocks and a test suite showcasing how the InstaDapp DSA could use Gelato to automate the execution (or casting) of its Spells (connectors) based on arbitrary Conditions.
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
andMockDSR.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 theDSA.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.
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. To do so follow the steps below:
Debt Bridge
Debt Bridge is a finance process that aim to make the user position safer. InstaDapp DSA could use Gelato to 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
: use Instamemory to assign values to the differents inputs needed byConnectMaker
andConnectCompound
like the amount of DAI to pay back, the amount of Ether to withdraw from Maker etc... -
ConnectGelatoProviderPayment.sol
: will pay the Gelato provider (the Ethereum account paying the transaction).
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-Refinance-External-Provider.test.js
test.
- Clone this repo
- Put your Alchemy ID in .env
- yarn install
- npx hardhat test