Skip to content

papercliplabs/compound-v3-subgraph

Repository files navigation

Compound V3 Community Subgraphs

Subgraphs

Compound V3 Community Subgraphs are the most comprehensive data source for developers looking to integrate Compound v3 protocol data into their decentralized applications (dApps)

Deployments

Mainnets

Blockchain Network Deployment (The Graph Decentralized Network)
Ethereum mainnet Subgraph
Polygon Subgraph
Arbitrum Subgraph
Base Subgraph
Optimism Subgraph
Scroll Subgraph

Testnets

Blockchain Network Subgraph
Sepolia Subgraph
Base Sepolia Subgraph

API Key

You will need an API Key from The Graph to query these subgraphs. They provide a generous free plan. You can read the docs on how to set this up here: https://thegraph.com/docs/en/subgraphs/querying/introduction/

Usage Notes

  • All percentages are represented as decimals in [0.0, 1.0]
  • baseTransfer will not emit any events if all value changed is on the borrow side. For this reason, it it possible that positions that did baseTransfers may be out of date until interaction happens involving that position do another interaction with the market. There is an issue open in Compound's comet repo here to add this event: compound-finance/comet#816
  • All interactions to the comet contract emit a specific event except for except for baseTransfer (see above^). Also, the Transfer event gets omitted anytime the cToken balances change, for this reason we update accounting on a Transfer event (which is generally redundant, except for the special case described above). For this reason, we don't explicitly track this interaction for usage as this would result in duplicate counting.
  • USD balances are as of the last time an entity got updated. If there are no entity updates for a long period the "current" values will not be very accurate and should be instead constructed using the token balance and the current token price pulled from elsewhere.

Compound v3 Contract Block Diagram Overview

erDiagram
		GOVERNOR_BRAVO ||--|| TIMELOCK : "ProposalCreated|VoteCase|ProposalCanceled|ProposalQueued|ProposalExecuted"
		TIMELOCK ||--|| CONFIGURATOR_PROXY : "QueueTransaction|CancelTranscation|ExecuteTransaction"
		CONFIGURATOR_PROXY ||--|| CONFIGURATOR : ""
		CONFIGURATOR ||--o{ COMET_FACTORY : "SetFactory"
		COMET_FACTORY ||--o{ COMET : ""
		CONFIGURATOR ||--o{ COMET_PROXY : "CometDeployed|SetConfiguration|AddAsset|..."
		COMET_REWARDS }|--|{ COMET_PROXY : ""
		COMET_PROXY ||--|| COMET : ""
		LENDER_OR_BORROWER }|--|{ COMET_PROXY : "Supply|Transfer|Withdraw|Approve"
		LENDER_OR_BORROWER }|--|{ COMET_REWARDS : "RewardClaimed"
		GOVERNANCE_PARTICIPANT }|--|| GOVERNOR_BRAVO : "Create|Vote|Cancel|Queue|Execute"
		LIQUIDATOR }|--|{ COMET_PROXY : "Absorb|BuyCollatoral"
		COMET }|--|{ PRICE_FEED : ""
Loading

Subgraph Development

In the below commands, replace with one of [mainnet, polygon, arbitrum-one, base, goerli]

Install dependencies:

yarn

Copy .env.example to .env and populate it

cp .env.example .env

Run code generation

yarn codegen

Build

yarn build:<network> 

Deploy to the subgraph studio

yarn deploy-studio:<network>

Codegen, build and deploy in one command

yarn auto-deploy:<network> v<version (X.Y.Z)>

# Example
yarn auto-deploy:mainnet v0.0.1

Validation

Validation is summarized in this spreadsheet

Helpers used to derive the data for validation can be found in:

  • Jupyter notebook query.ipynb: used to query subgraph and plot data
  • The script directContract.ts: used to read comet contracts at specified blocks to compare with the subgraph

to run directContract.ts

cd validation
yarn install
ts-node directContract.ts

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published