@morpho-org/blue-sdk-ethers
v3.0.0
Published
Ethers-based augmentation of `@morpho-org/blue-sdk` that exports (and optionally injects) ethers-based fetch methods.
Keywords
Readme
@morpho-org/blue-sdk-ethers
Ethers-based augmentation of @morpho-org/blue-sdk that exports (and optionally injects) ethers-based fetch methods.
Installation
npm install @morpho-org/blue-sdk-ethersyarn add @morpho-org/blue-sdk-ethersGetting Started
Augment blue-sdk entity classes with fetchers
Opt in classes augmentation to easily fetch an entire entity of the Morpho Blue & MetaMorpho ecosystem using ethers:
// Granular, opt-in, per-entity class augmentation:
import "@morpho-org/blue-sdk-ethers/lib/augment/AccrualPosition";
import "@morpho-org/blue-sdk-ethers/lib/augment/Holding";
import "@morpho-org/blue-sdk-ethers/lib/augment/Market";
import "@morpho-org/blue-sdk-ethers/lib/augment/MarketParams";
import "@morpho-org/blue-sdk-ethers/lib/augment/Position";
import "@morpho-org/blue-sdk-ethers/lib/augment/Token";
import "@morpho-org/blue-sdk-ethers/lib/augment/VaultConfig";
import "@morpho-org/blue-sdk-ethers/lib/augment/Vault";
import "@morpho-org/blue-sdk-ethers/lib/augment/VaultUser";
import "@morpho-org/blue-sdk-ethers/lib/augment/VaultMarketAllocation";
import "@morpho-org/blue-sdk-ethers/lib/augment/VaultMarketConfig";
import "@morpho-org/blue-sdk-ethers/lib/augment/VaultMarketPublicAllocatorConfig";
// Or full, opt-in class augmentation:
import "@morpho-org/blue-sdk-ethers/lib/augment";Fetch the config of a specific market
Leverage the MarketParams class to fetch information on a given market's immutable configuration:
import { MarketId } from "@morpho-org/blue-sdk";
// /!\ Import MarketParams from the augmentation file (or simply import the file)
import { MarketParams } from "@morpho-org/blue-sdk-ethers/lib/augment/MarketParams";
const config = await MarketParams.fetch(
"0xb323495f7e4148be5643a4ea4a8221eef163e4bccfdedc2a6f4696baacbc86cc" as MarketId,
provider // Ethers provider.
);
config.collateralToken; // e.g. 0x7f39C581F595B53c5cb19bD0b3f8dA6c935E2Ca0.Fetch data of a specific market
Leverage the Market class to fetch information on a specific market:
import { Time } from "@morpho-org/morpho-ts";
import { MarketId } from "@morpho-org/blue-sdk";
// /!\ Import Market from the augmentation file (or simply import the file)
import { Market } from "@morpho-org/blue-sdk-ethers/lib/augment/Market";
const market = await Market.fetch(
"0xb323495f7e4148be5643a4ea4a8221eef163e4bccfdedc2a6f4696baacbc86cc" as MarketId,
provider // Ethers provider.
);
// Or from a config, to fetch faster (skips fetching the config):
// const market = Market.fetchFromConfig(
// config,
// provider // Ethers provider.
// );
market.utilization; // e.g. 92% (scaled by WAD).
market.liquidity; // e.g. 23_000000n (in loan assets).
const accruedMarket = market.accrueInterest(Time.timestamp()); // Accrue interest to the latest's timestamp.
accruedMarket.toSupplyAssets(shares); // Convert supply shares to assets.
accruedMarket.apyAtTarget; // e.g. 3% (scaled by WAD).
accruedMarket.borrowApy; // e.g. 8% (scaled by WAD).Fetch data on the position of a specific user on a specific market
Leverage the Position class to fetch the position of a user on a given market:
import { Time } from "@morpho-org/morpho-ts";
import { MarketId } from "@morpho-org/blue-sdk";
// /!\ Import AccrualPosition from the augmentation file (or simply import the file)
import { AccrualPosition } from "@morpho-org/blue-sdk-ethers/lib/augment/Position";
const position = await AccrualPosition.fetch(
"0x7f65e7326F22963e2039734dDfF61958D5d284Ca",
"0xb323495f7e4148be5643a4ea4a8221eef163e4bccfdedc2a6f4696baacbc86cc" as MarketId,
provider // Ethers provider.
);
// Or from a config, to fetch faster:
// const position = AccrualPosition.fetchFromConfig(
// "0x7f65e7326F22963e2039734dDfF61958D5d284Ca",
// config,
// provider // Ethers provider.
// );
position.borrowAssets; // e.g. 23_000000n (in loan assets).
position.isHealthy; // e.g. true.
position.maxBorrowableAssets; // e.g. 2100_000000n (in loan assets).
const accruedPosition = position.accrueInterest(Time.timestamp()); // Accrue interest to the latest's timestamp.
position.borrowAssets; // e.g. 23_500000n (in loan assets).