@metamask-private/defi-adapters
v0.15.0
Published
Defi adapters for MMI Dashboard - simplify and standardise fetching data from various DeFi protocols
Readme
Welcome to our DeFi Adapter Library! 🚀
This library is designed to simplify and standardise the process of fetching data and interacting with various DeFi protocols, which often have unique interfaces and data structures. Our adapters 1) fetch and transform underlying protocol data into a standardised format that can be easily used by portfolio dashboards and 2) generate transaction params to create and update protocol positions.
Note: Please note that in this library, adapters must query on-chain data to ensure accuracy and reliability, we do not accept centralised APIs to get positions or rewards.
How to create a Read Adapter
Setup steps
Watch the setup video for a detailed guide.
- Install:
nvm useto select the environmentnpm ito install dependenciesnpm run buildto build the CLI
- Run project:
npm run devto run the project
Continue watching videos for the following steps or, alternatively, find a written version in Steps to create a read adapter
Build adapter steps
Watch the build adapter video for a detailed guide.
- Use CLI:
npm run new-adapterthis launches our interactive CLI that will prompt you with a series of questions
Inspect your automatically created adapter file and implement unfinished methods
Watch the inspect your adapter video for a detailed guide.
Build Smart Contract Classes from ABIs
Watch the build contract classes from ABIs video for a detailed guide.
- Save a json file with your abi and add it to your ${protocolName}/contracts/abis/ folder
- Run:
npm run build-typesto generate your smart contract classes
Build your DeFi asset metadata
Watch the build your DeFi asset metadata video for a detailed guide.
- Implement the
getProtocolTokenmethod in your adapter and make sure it is decorated with@CacheToDb.
- If the adapter requires additional metadata. The
AdditionalMetadatatype should be updated accordingly, otherwise it should be deleted. - You can add any data that is serializable as JSON (including BigInt) as additional metadata.
- There are four protected fields that, if added, must adhere to stricter types. Those are:
{
underlyingTokens?: Erc20ExtendedMetadata[]
rewardTokens?: Erc20ExtendedMetadata[]
extraRewardTokens?: Erc20ExtendedMetadata[]
tokenId?: string
}- Run:
npm run build-metadata-db -- -p <protocol-id> -pd <product-id>to create your metadata files
Build your Snapshot tests
Watch the build your snapshot tests video for a detailed guide.
- Populate your test cases file.
- Run:
npm run build-snapshots -- -p <protocol-id>to build your snapshot tests
