DSA Connectors
Go to file
Thrilok kumar cce38fec6d
Added new connectors
Connector Name: "B-COMPOUND-A"
Connector Address: 0xa3EeFDc2de9DFA59968bEcff3E15b53E6162460f

Connector Name: "B-MAKERDAO-A"
Connector Address: 0xB0A1f10FeEfECf25064CE7cdF0a65042F7dE7bF0

Connector Name: "B-LIQUITY-A"
Connector Address: 0x19574E5Dfb40bbD63A4F3bdcF27ed662b329b2ff

Connector Name: "UNISWAP-V3-A"
Connector Address: 0x25B0c76dE86C3457b9B8b9ee3775F5a7b8D4c475
2021-08-29 23:03:05 +05:30
.github/workflows Checker for solidity code (#32) 2021-05-07 22:06:52 +05:30
.husky Checker for solidity code (#32) 2021-05-07 22:06:52 +05:30
contracts Merge pull request #68 from Instadapp/feat/uniswap-v3-connector 2021-08-29 22:19:26 +05:30
deployements/mainnet Added basic compound testcases 2021-05-15 00:46:54 +05:30
docs Added new connectors 2021-08-29 23:03:05 +05:30
scripts Merge branch 'main' into dep/compound-mapping-update 2021-08-06 00:57:35 +05:30
status-checks check if public function is payable 2021-07-26 18:59:54 +03:00
test Merge pull request #68 from Instadapp/feat/uniswap-v3-connector 2021-08-29 22:19:26 +05:30
.env.example Add deployment script 2021-03-15 17:56:22 +05:30
.gitignore basic setup 2020-11-20 23:41:19 +11:00
hardhat.config.js Reverted commit 2021-08-20 03:53:48 +05:30
LICENSE Initial commit 2020-11-20 22:30:23 +11:00
package-lock.json Updated hardhat package 2021-08-12 00:39:38 +05:30
package.json Updated hardhat package 2021-08-12 00:39:38 +05:30
README.md Update README.md 2021-08-26 22:11:14 +05:30
yarn.lock Updated hardhat package 2021-08-12 00:39:38 +05:30

DSA connectors

Connectors are standard proxy logics contract that let DeFi Smart Account (DSA) interact with various smart contracts, and make the important actions accessible like cross protocol interoperability.

DSAs are powerful because they can easily be extended with connectors. Every new connector that is added is immediately usable by any developer building on top of DSAs. Connectors can either be base connectors to protocols, auth connectors, higher level connectors with more specific use cases like optimized lending, or connectors to native liquidity pools.

You can create a PR to request a support for specific protocol or external contracts. The process to add a new connector is explained below.

List of all the mainnet connector for referrence is here

How to add a new connector

You can create a new PR to add a new connector. To get the PR merged, certain requirements needs to be met which will be explained here.

New connector should follow the current directory structure

Common files for all connectors are in contracts/common directory.

  • math.sol has methods for mathematical operations (DSMath)
  • interfaces.sol contains the common interfaces
    • TokenInterface for ERC-20 interface including WETH
  • stores.sol contains the global constants as well as methods getId & setId (Stores)
  • basic.sol inherits DSMath & Stores contracts. This contains few details explained below
    • Wrapping & unwrapping ETH (convertEthToWeth & convertWethToEth)
    • Getting token & ETH balance of DSA

Connectors are under contracts/connectors directory, and should be formatted as follows:

  • Connector events should be in a separate contract: events.sol
  • Interfaces should be defined in a seperate file: interface.sol
  • If the connector has helper methods & constants (including interface instances), this should be defined in a separate file: helpers.sol
    • Helpers contract should inherit Basic contract from common directory
    • If the connector doesn't have any helper methods, the main contract should inherit Basic contract
  • The main logic of the contract should be under main.sol, and the contract should inherit Helpers (if exists, otherwise Basic) & Events

Few things to consider while writing the connector:

  • Connector should have a public constant string declared name, which will be the name of the connector. This will be versioned. Ex: Compound-v1
  • Contract name should start with ConnectV2 appended with protocol name. Eg: ConnectV2Compound
  • User interacting methods (external methods) will not be emitting events, rather the methods will be returning 2 variables:
    • _eventName of string type: This will be the event signture defined in the Events contract. Ex: LogDeposit(address,address,uint256,uint256,uint256)
    • _eventParam of bytes type: This will be the abi encoded event parameters
  • The contracts should not have selfdestruct()
  • The contracts should not have delegatecall()
  • Use uint(-1) of type(uint256).max for maximum amount everywhere
  • Use ethAddr (declared in Stores) to denote Ethereum (non-ERC20)
  • Use address(this) instead of msg.sender for fetching balance on-chain, etc
  • Only approve() (declared in Basic) limited amount while giving ERC20 allowance, which strictly needs to be 0 by the end of the spell.
  • User interacting functions should have natspec comments(@dev, @notice, @param).
  • Use getUint() (declared in Stores) for getting value that saved from previous spell
  • Use setUint() (declared in Stores) for setting value to save for the future spell

Support

If you can't find something you're looking for or have any questions, ask them at our developers community on Discord or simply send an Email.