DEPRECATED: This package has been replaced by @rtoken/utils
and the rToken Subgraph
in the β‘οΈ rtoken-monorepo
This library provides tools for getting rDAI and rToken data into your dapp.
Feature | Status | Notes |
---|---|---|
Get rDAI data in your dapp | β | Currently in Beta |
Subgraph for rDAI on mainnet | β | Deployed subgraph |
Roll-your-own rToken | β | docs |
What else do you need? | ? |
yarn add rtoken-analytics
import RTokenAnalytics from 'rtoken-analytics';
const MyComponent = () => {
const from = "0x9492510bbcb93b6992d8b7bb67888558e12dcac4"
const to = "0x8605e554111d8ea3295e69addaf8b2abf60d68a3"
const rTokenAnalytics = new RTokenAnalytics();
const interestSent = await rTokenAnalytics.getInterestSent(from, to);
}
If you are using your own rToken subgraph, you will need to provide this info in the arguments.
const options = {
subgraphURL: "some other url",
rdaiSubgraphId: "some other id",
};
const rTokenAnalytics = new RTokenAnalytics(options);
Arguments | Default value |
---|---|
subgraphURL |
https://api.thegraph.com/subgraphs/id/ |
rdaiSubgraphId |
QmfUZ16H2GBxQ4eULAELDJjjVZcZ36TcDkwhoZ9cjF2WNc |
Get all loans where interest is being sent to another address
Returns array of active loans. Example:
[
{
amount: "0.50000000058207661",
hat: { id: "11" },
recipient: { id: "0x358f6260f1f90cd11a10e251ce16ea526f131b02" },
},
{
amount: "24.49999999941792339",
// ...
},
];
Get all loans where interest is being received from another address
Returns array of active loans (same schema as above)
Get the total amount of interest sent
Returns: value in DAI
What other features do you want? Let us know by making an issue.
If you deploy your own token, and you wish to use this SDK, you will need to deploy you own subgraph. As long as you didn't modify the rToken contracts too much, you can just deploy the subgraph in the /subgraph
folder. Be sure to modify subgraph.yaml
with the correct address
and startBlock
.
β οΈ You probably don't need to do this! If your rToken is deployed toMainnet
orRopsten
, and you are using the standard rToken contracts, then you should use the hosted servers provided by The Graph.
The rToken team uses a local subgraph deployment to enable rapid development and testing of the tools provided here. In this section we will do the following:
- Deploy the
rtoken-analytics
subgraph to a local docker container on your machine. - Deploy the rToken contracts to a local Ganache instance.
- Check that your setup is correct by running some tests
If you've previously performed the setup process, you should skip down to the Testing and restarting section.
If you get stuck during setup, see additional instructions from The Graph docs here.
First install the dependencies
sudo apt install docker docker-compose
yarn global add truffle ganache-cli @graphprotocol/graph-cli
Download the graph-node
Docker instance.
git clone https://github.com/graphprotocol/graph-node/
cd graph-node/docker
If on Linux, run the following script. Note I had problems here, so you may need to troubleshoot by first running docker-compose create
or docker-compose up
. If you get a "version" error, update your docker-compose with these instructions. If you get an error like ERROR: could not find an available, non-overlapping IPv4 address...
then take off your tin-foil hat and stop running OpenVPN, or follow this tutorial.
sudo apt install jq # if necessary
./setup.sh
Now lets start our subgraph Docker instance.
docker-compose up
# leave running
In a new terminal, switch back to the rtoken-analytics
repo, and start running ganache-cli.
yarn start_ganache
# leave running
In a new terminal, we can fetch the latest contracts from the rtoken-contracts
repo, and deploy them to ganache.
yarn fetch_contracts
yarn deploy_contracts
The address in rtoken-analytics/subgraph/subgraph.yaml
should be automatically updated during the previous step. Before proceeding, check that the deployed rToken address printed at the start of the deployment process matches the one shown in the .yaml file.
We are now ready to deploy our subgraph.
cd subgraph
yarn create-local # Only needs to be run the first time
yarn deploy-local
Great job! Now let's make sure things are working properly by doing a sanity check using Postman, or other API tool.
Property | value |
---|---|
URL | http://localhost:8000/subgraphs/name/rtoken-project/rtoken-analytics |
Request type | POST |
body | GraphQL |
query {
users(first: 5) {
id
sentAddressList
receivedAddressList
}
}
You should get a response like this
{
"data": {
"users": [
{
"id": "0x1eeee046f7722b0c7f04ecc457dc5cf69f4fba99",
"receivedAddressList": [
"0xbf44e907c4b6583d2cd3d0a0c403403bb44c4a3c",
"0xbf44e907c4b6583d2cd3d0a0c403403bb44c4a3c",
"0xbf44e907c4b6583d2cd3d0a0c403403bb44c4a3c"
],
"sentAddressList": []
},
...
π Congrats! if you were successful with the initial setup, you can move to the next section to enable automatic redeployments of the subgraph upon changes.
Here are the current steps to fully automate β‘ subgraph re-deployment and testing upon changes to the subraph.
In the repo graph-node/docker
, stop your docker instance, and restart it.
sudo rm -rf data && docker-compose up
Open a new terminal, at the root directory of this repository.
yarn start_ganache
# leave running
In a new terminal, deploy the contracts. This will also re-deploy the new subgraph, whenever subgraph.yaml is changed.
yarn start_subgraph
# leave running
In a new terminal, start the test suite
nodemon -x yarn test_local
# leave running
This is one method for obtaining the Compound interest rate in your dapp.
import axios from "axios";
const COMPOUND_URL = "https://api.compound.finance/api/v2/ctoken?addresses[]=";
const daiCompoundAddress = "0x5d3a536E4D6DbD6114cc1Ead35777bAB948E3643";
const getCompoundRate = async () => {
const res = await axios.get(`${COMPOUND_URL}${daiCompoundAddress}`);
const compoundRate = res.data.cToken[0].supply_rate.value;
const compoundRateFormatted = Math.round(compoundRate * 10000) / 100;
return {
compoundRate,
compoundRateFormatted,
};
};
Then use it like this
const { compoundRate, compoundRateFormatted } = await getCompoundRate();
console.log(`Compound Rate: ${compoundRateFormatted}%`);
// > Compound Rate: 4.56%
// Recommend you save the rate for quick reference, as the API can be slow.
if (typeof window !== "undefined") {
localStorage.setItem("compoundRate", compoundRate);
}
Contributions, suggestions, and issues are welcome. At the moment, there are no strict guidelines to follow.