@defisaver/positions-sdk 2.1.35 → 2.1.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.mocharc.json +4 -4
- package/.nvmrc +1 -1
- package/README.md +64 -64
- package/cjs/helpers/morphoBlueHelpers/index.js +66 -66
- package/cjs/savings/morphoVaults/index.js +17 -17
- package/cjs/savings/skyOptions/options.js +1 -0
- package/cjs/types/savings/sky.d.ts +1 -0
- package/esm/helpers/morphoBlueHelpers/index.js +66 -66
- package/esm/savings/morphoVaults/index.js +17 -17
- package/esm/savings/skyOptions/options.js +1 -0
- package/esm/types/savings/sky.d.ts +1 -0
- package/package.json +48 -48
- package/src/aaveV2/index.ts +240 -240
- package/src/aaveV3/index.ts +625 -625
- package/src/aaveV3/merit.ts +97 -97
- package/src/aaveV3/merkl.ts +74 -74
- package/src/claiming/aaveV3.ts +154 -154
- package/src/claiming/compV3.ts +22 -22
- package/src/claiming/ethena.ts +61 -61
- package/src/claiming/index.ts +12 -12
- package/src/claiming/king.ts +66 -66
- package/src/claiming/morphoBlue.ts +118 -118
- package/src/claiming/spark.ts +225 -225
- package/src/compoundV2/index.ts +244 -244
- package/src/compoundV3/index.ts +274 -274
- package/src/config/contracts.ts +1292 -1292
- package/src/constants/index.ts +10 -10
- package/src/contracts.ts +162 -162
- package/src/curveUsd/index.ts +254 -254
- package/src/eulerV2/index.ts +324 -324
- package/src/exchange/index.ts +25 -25
- package/src/fluid/index.ts +1800 -1800
- package/src/helpers/aaveHelpers/index.ts +187 -187
- package/src/helpers/compoundHelpers/index.ts +283 -283
- package/src/helpers/curveUsdHelpers/index.ts +40 -40
- package/src/helpers/eulerHelpers/index.ts +222 -222
- package/src/helpers/fluidHelpers/index.ts +326 -326
- package/src/helpers/index.ts +10 -10
- package/src/helpers/liquityV2Helpers/index.ts +82 -82
- package/src/helpers/llamaLendHelpers/index.ts +53 -53
- package/src/helpers/makerHelpers/index.ts +52 -52
- package/src/helpers/morphoBlueHelpers/index.ts +396 -396
- package/src/helpers/sparkHelpers/index.ts +158 -158
- package/src/index.ts +49 -49
- package/src/liquity/index.ts +159 -159
- package/src/liquityV2/index.ts +703 -703
- package/src/llamaLend/index.ts +305 -305
- package/src/maker/index.ts +223 -223
- package/src/markets/aave/index.ts +118 -118
- package/src/markets/aave/marketAssets.ts +54 -54
- package/src/markets/compound/index.ts +243 -243
- package/src/markets/compound/marketsAssets.ts +97 -97
- package/src/markets/curveUsd/index.ts +69 -69
- package/src/markets/euler/index.ts +26 -26
- package/src/markets/fluid/index.ts +2900 -2900
- package/src/markets/index.ts +25 -25
- package/src/markets/liquityV2/index.ts +102 -102
- package/src/markets/llamaLend/contractAddresses.ts +141 -141
- package/src/markets/llamaLend/index.ts +235 -235
- package/src/markets/morphoBlue/index.ts +971 -971
- package/src/markets/spark/index.ts +29 -29
- package/src/markets/spark/marketAssets.ts +12 -12
- package/src/moneymarket/moneymarketCommonService.ts +85 -85
- package/src/morphoBlue/index.ts +274 -274
- package/src/portfolio/index.ts +598 -598
- package/src/savings/index.ts +82 -82
- package/src/savings/makerDsr/index.ts +53 -53
- package/src/savings/makerDsr/options.ts +9 -9
- package/src/savings/morphoVaults/index.ts +80 -80
- package/src/savings/morphoVaults/options.ts +203 -203
- package/src/savings/skyOptions/index.ts +95 -95
- package/src/savings/skyOptions/options.ts +10 -9
- package/src/savings/sparkSavingsVaults/index.ts +60 -60
- package/src/savings/sparkSavingsVaults/options.ts +35 -35
- package/src/savings/yearnVaults/index.ts +73 -73
- package/src/savings/yearnVaults/options.ts +32 -32
- package/src/services/priceService.ts +278 -278
- package/src/services/utils.ts +115 -115
- package/src/services/viem.ts +34 -34
- package/src/setup.ts +8 -8
- package/src/spark/index.ts +456 -456
- package/src/staking/eligibility.ts +53 -53
- package/src/staking/index.ts +1 -1
- package/src/staking/staking.ts +186 -186
- package/src/types/aave.ts +196 -196
- package/src/types/claiming.ts +114 -114
- package/src/types/common.ts +107 -107
- package/src/types/compound.ts +144 -144
- package/src/types/curveUsd.ts +123 -123
- package/src/types/euler.ts +175 -175
- package/src/types/fluid.ts +483 -483
- package/src/types/index.ts +14 -14
- package/src/types/liquity.ts +30 -30
- package/src/types/liquityV2.ts +126 -126
- package/src/types/llamaLend.ts +159 -159
- package/src/types/maker.ts +63 -63
- package/src/types/merit.ts +1 -1
- package/src/types/merkl.ts +70 -70
- package/src/types/morphoBlue.ts +200 -200
- package/src/types/portfolio.ts +60 -60
- package/src/types/savings/index.ts +21 -21
- package/src/types/savings/makerDsr.ts +13 -13
- package/src/types/savings/morphoVaults.ts +33 -33
- package/src/types/savings/sky.ts +14 -13
- package/src/types/savings/sparkSavingsVaults.ts +15 -15
- package/src/types/savings/yearnVaults.ts +14 -14
- package/src/types/spark.ts +133 -133
- package/src/umbrella/index.ts +69 -69
- package/src/umbrella/umbrellaUtils.ts +29 -29
|
@@ -1,61 +1,61 @@
|
|
|
1
|
-
import { Client } from 'viem';
|
|
2
|
-
import Dec from 'decimal.js';
|
|
3
|
-
import { assetAmountInEth, getAssetInfo } from '@defisaver/tokens';
|
|
4
|
-
import { SavingsVaultData, SparkSavingsVault } from '../../types';
|
|
5
|
-
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
6
|
-
import * as sparkSavingsVaultsOptions from './options';
|
|
7
|
-
import { getViemProvider } from '../../services/viem';
|
|
8
|
-
import { getErc20ContractViem, getSparkSavingsVaultContractViem } from '../../contracts';
|
|
9
|
-
|
|
10
|
-
export {
|
|
11
|
-
sparkSavingsVaultsOptions,
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
export const _getSparkSavingsVaultData = async (provider: Client, network: NetworkNumber, sparkSavingsVault: SparkSavingsVault, accounts: EthAddress[]): Promise<SavingsVaultData> => {
|
|
15
|
-
const sparkSavingsVaultContract = getSparkSavingsVaultContractViem(provider, sparkSavingsVault.address);
|
|
16
|
-
const underlyingAssetContract = getErc20ContractViem(provider, getAssetInfo(sparkSavingsVault.asset, network).address as EthAddress);
|
|
17
|
-
|
|
18
|
-
const shares: Record<EthAddress, bigint> = {};
|
|
19
|
-
|
|
20
|
-
const [totalAssets, decimals, nowChi, RAY, liquidityWei] = await Promise.all([
|
|
21
|
-
sparkSavingsVaultContract.read.totalAssets(),
|
|
22
|
-
sparkSavingsVaultContract.read.decimals(),
|
|
23
|
-
sparkSavingsVaultContract.read.nowChi(),
|
|
24
|
-
sparkSavingsVaultContract.read.RAY(),
|
|
25
|
-
underlyingAssetContract.read.balanceOf([sparkSavingsVault.address]),
|
|
26
|
-
...accounts.map(async (account) => {
|
|
27
|
-
const share = await sparkSavingsVaultContract.read.balanceOf([account]);
|
|
28
|
-
shares[account] = share;
|
|
29
|
-
}),
|
|
30
|
-
]);
|
|
31
|
-
|
|
32
|
-
const poolSize = assetAmountInEth(totalAssets.toString(), sparkSavingsVault.asset);
|
|
33
|
-
const liquidity = assetAmountInEth(liquidityWei.toString(), sparkSavingsVault.asset);
|
|
34
|
-
|
|
35
|
-
const supplied: Record<EthAddress, string> = {};
|
|
36
|
-
accounts.forEach((account) => {
|
|
37
|
-
const share = shares[account] || BigInt(0);
|
|
38
|
-
supplied[account.toLowerCase() as EthAddress] = assetAmountInEth(
|
|
39
|
-
new Dec(share).mul(nowChi).div(RAY).toFixed(0)
|
|
40
|
-
.toString(), sparkSavingsVault.asset,
|
|
41
|
-
);
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
return {
|
|
45
|
-
poolSize,
|
|
46
|
-
supplied,
|
|
47
|
-
liquidity,
|
|
48
|
-
asset: sparkSavingsVault.asset,
|
|
49
|
-
optionType: sparkSavingsVault.type,
|
|
50
|
-
};
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
export async function getSparkSavingsVaultData(provider: EthereumProvider, network: NetworkNumber, sparkSavingsVault: SparkSavingsVault, accounts: EthAddress[]): Promise<SavingsVaultData> {
|
|
54
|
-
return _getSparkSavingsVaultData(getViemProvider(provider, network, {
|
|
55
|
-
batch: {
|
|
56
|
-
multicall: {
|
|
57
|
-
batchSize: 2500000,
|
|
58
|
-
},
|
|
59
|
-
},
|
|
60
|
-
}), network, sparkSavingsVault, accounts);
|
|
1
|
+
import { Client } from 'viem';
|
|
2
|
+
import Dec from 'decimal.js';
|
|
3
|
+
import { assetAmountInEth, getAssetInfo } from '@defisaver/tokens';
|
|
4
|
+
import { SavingsVaultData, SparkSavingsVault } from '../../types';
|
|
5
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
6
|
+
import * as sparkSavingsVaultsOptions from './options';
|
|
7
|
+
import { getViemProvider } from '../../services/viem';
|
|
8
|
+
import { getErc20ContractViem, getSparkSavingsVaultContractViem } from '../../contracts';
|
|
9
|
+
|
|
10
|
+
export {
|
|
11
|
+
sparkSavingsVaultsOptions,
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export const _getSparkSavingsVaultData = async (provider: Client, network: NetworkNumber, sparkSavingsVault: SparkSavingsVault, accounts: EthAddress[]): Promise<SavingsVaultData> => {
|
|
15
|
+
const sparkSavingsVaultContract = getSparkSavingsVaultContractViem(provider, sparkSavingsVault.address);
|
|
16
|
+
const underlyingAssetContract = getErc20ContractViem(provider, getAssetInfo(sparkSavingsVault.asset, network).address as EthAddress);
|
|
17
|
+
|
|
18
|
+
const shares: Record<EthAddress, bigint> = {};
|
|
19
|
+
|
|
20
|
+
const [totalAssets, decimals, nowChi, RAY, liquidityWei] = await Promise.all([
|
|
21
|
+
sparkSavingsVaultContract.read.totalAssets(),
|
|
22
|
+
sparkSavingsVaultContract.read.decimals(),
|
|
23
|
+
sparkSavingsVaultContract.read.nowChi(),
|
|
24
|
+
sparkSavingsVaultContract.read.RAY(),
|
|
25
|
+
underlyingAssetContract.read.balanceOf([sparkSavingsVault.address]),
|
|
26
|
+
...accounts.map(async (account) => {
|
|
27
|
+
const share = await sparkSavingsVaultContract.read.balanceOf([account]);
|
|
28
|
+
shares[account] = share;
|
|
29
|
+
}),
|
|
30
|
+
]);
|
|
31
|
+
|
|
32
|
+
const poolSize = assetAmountInEth(totalAssets.toString(), sparkSavingsVault.asset);
|
|
33
|
+
const liquidity = assetAmountInEth(liquidityWei.toString(), sparkSavingsVault.asset);
|
|
34
|
+
|
|
35
|
+
const supplied: Record<EthAddress, string> = {};
|
|
36
|
+
accounts.forEach((account) => {
|
|
37
|
+
const share = shares[account] || BigInt(0);
|
|
38
|
+
supplied[account.toLowerCase() as EthAddress] = assetAmountInEth(
|
|
39
|
+
new Dec(share).mul(nowChi).div(RAY).toFixed(0)
|
|
40
|
+
.toString(), sparkSavingsVault.asset,
|
|
41
|
+
);
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
return {
|
|
45
|
+
poolSize,
|
|
46
|
+
supplied,
|
|
47
|
+
liquidity,
|
|
48
|
+
asset: sparkSavingsVault.asset,
|
|
49
|
+
optionType: sparkSavingsVault.type,
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
export async function getSparkSavingsVaultData(provider: EthereumProvider, network: NetworkNumber, sparkSavingsVault: SparkSavingsVault, accounts: EthAddress[]): Promise<SavingsVaultData> {
|
|
54
|
+
return _getSparkSavingsVaultData(getViemProvider(provider, network, {
|
|
55
|
+
batch: {
|
|
56
|
+
multicall: {
|
|
57
|
+
batchSize: 2500000,
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
}), network, sparkSavingsVault, accounts);
|
|
61
61
|
}
|
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
import { SparkSavingsVault, SparkSavingsVaultType } from '../../types';
|
|
2
|
-
|
|
3
|
-
export const SPARK_SAVINGS_VAULT_USDC: SparkSavingsVault = {
|
|
4
|
-
type: SparkSavingsVaultType.SparkSavingsUSDC,
|
|
5
|
-
name: 'Spark Savings USDC',
|
|
6
|
-
address: '0x28B3a8fb53B741A8Fd78c0fb9A6B2393d896a43d',
|
|
7
|
-
asset: 'USDC',
|
|
8
|
-
deploymentBlock: 23484422,
|
|
9
|
-
isLegacy: false,
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
export const SPARK_SAVINGS_VAULT_USDT: SparkSavingsVault = {
|
|
13
|
-
type: SparkSavingsVaultType.SparkSavingsUSDT,
|
|
14
|
-
name: 'Spark Savings USDT',
|
|
15
|
-
address: '0xe2e7a17dFf93280dec073C995595155283e3C372',
|
|
16
|
-
asset: 'USDT',
|
|
17
|
-
deploymentBlock: 23484439,
|
|
18
|
-
isLegacy: false,
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
export const SPARK_SAVINGS_VAULT_WETH: SparkSavingsVault = {
|
|
22
|
-
type: SparkSavingsVaultType.SparkSavingsETH,
|
|
23
|
-
name: 'Spark Savings WETH',
|
|
24
|
-
address: '0xfE6eb3b609a7C8352A241f7F3A21CEA4e9209B8f',
|
|
25
|
-
asset: 'WETH',
|
|
26
|
-
deploymentBlock: 23484474,
|
|
27
|
-
isLegacy: false,
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
export const SPARK_SAVINGS_VAULTS: Record<SparkSavingsVaultType, SparkSavingsVault> = {
|
|
31
|
-
[SparkSavingsVaultType.SparkSavingsUSDC]: SPARK_SAVINGS_VAULT_USDC,
|
|
32
|
-
[SparkSavingsVaultType.SparkSavingsUSDT]: SPARK_SAVINGS_VAULT_USDT,
|
|
33
|
-
[SparkSavingsVaultType.SparkSavingsETH]: SPARK_SAVINGS_VAULT_WETH,
|
|
34
|
-
};
|
|
35
|
-
|
|
1
|
+
import { SparkSavingsVault, SparkSavingsVaultType } from '../../types';
|
|
2
|
+
|
|
3
|
+
export const SPARK_SAVINGS_VAULT_USDC: SparkSavingsVault = {
|
|
4
|
+
type: SparkSavingsVaultType.SparkSavingsUSDC,
|
|
5
|
+
name: 'Spark Savings USDC',
|
|
6
|
+
address: '0x28B3a8fb53B741A8Fd78c0fb9A6B2393d896a43d',
|
|
7
|
+
asset: 'USDC',
|
|
8
|
+
deploymentBlock: 23484422,
|
|
9
|
+
isLegacy: false,
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export const SPARK_SAVINGS_VAULT_USDT: SparkSavingsVault = {
|
|
13
|
+
type: SparkSavingsVaultType.SparkSavingsUSDT,
|
|
14
|
+
name: 'Spark Savings USDT',
|
|
15
|
+
address: '0xe2e7a17dFf93280dec073C995595155283e3C372',
|
|
16
|
+
asset: 'USDT',
|
|
17
|
+
deploymentBlock: 23484439,
|
|
18
|
+
isLegacy: false,
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export const SPARK_SAVINGS_VAULT_WETH: SparkSavingsVault = {
|
|
22
|
+
type: SparkSavingsVaultType.SparkSavingsETH,
|
|
23
|
+
name: 'Spark Savings WETH',
|
|
24
|
+
address: '0xfE6eb3b609a7C8352A241f7F3A21CEA4e9209B8f',
|
|
25
|
+
asset: 'WETH',
|
|
26
|
+
deploymentBlock: 23484474,
|
|
27
|
+
isLegacy: false,
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
export const SPARK_SAVINGS_VAULTS: Record<SparkSavingsVaultType, SparkSavingsVault> = {
|
|
31
|
+
[SparkSavingsVaultType.SparkSavingsUSDC]: SPARK_SAVINGS_VAULT_USDC,
|
|
32
|
+
[SparkSavingsVaultType.SparkSavingsUSDT]: SPARK_SAVINGS_VAULT_USDT,
|
|
33
|
+
[SparkSavingsVaultType.SparkSavingsETH]: SPARK_SAVINGS_VAULT_WETH,
|
|
34
|
+
};
|
|
35
|
+
|
|
36
36
|
export const getSparkSavingsVault = (type: SparkSavingsVaultType): SparkSavingsVault => SPARK_SAVINGS_VAULTS[type];
|
|
@@ -1,74 +1,74 @@
|
|
|
1
|
-
import Dec from 'decimal.js';
|
|
2
|
-
import { Client } from 'viem';
|
|
3
|
-
import { assetAmountInEth } from '@defisaver/tokens';
|
|
4
|
-
import { getViemProvider } from '../../services/viem';
|
|
5
|
-
import { SavingsVaultData, YearnVault } from '../../types';
|
|
6
|
-
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
7
|
-
import * as yearnVaultsOptions from './options';
|
|
8
|
-
import { getYearnVaultContractViem, YearnViewContractViem } from '../../contracts';
|
|
9
|
-
|
|
10
|
-
export {
|
|
11
|
-
yearnVaultsOptions,
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
export const _getYearnVaultData = async (provider: Client, network: NetworkNumber, yearnVault: YearnVault, accounts: EthAddress[]): Promise<SavingsVaultData> => {
|
|
15
|
-
const yearnVaultContract = getYearnVaultContractViem(provider, yearnVault.address);
|
|
16
|
-
const viewContract = YearnViewContractViem(provider, network);
|
|
17
|
-
|
|
18
|
-
const yvAmountsWei: Record<EthAddress, bigint> = {};
|
|
19
|
-
|
|
20
|
-
const [tokenSupply, underlyingSupply, poolLiquidity] = await Promise.all([
|
|
21
|
-
yearnVaultContract.read.totalSupply(),
|
|
22
|
-
yearnVaultContract.read.totalAssets(),
|
|
23
|
-
viewContract.read.getPoolLiquidity([yearnVault.address]),
|
|
24
|
-
...accounts.map(async (account) => {
|
|
25
|
-
const yvAmount = await yearnVaultContract.read.balanceOf([account]);
|
|
26
|
-
yvAmountsWei[account] = yvAmount;
|
|
27
|
-
}),
|
|
28
|
-
]);
|
|
29
|
-
|
|
30
|
-
const exchangeRate = new Dec(underlyingSupply).div(tokenSupply).toString();
|
|
31
|
-
const poolSize = assetAmountInEth(underlyingSupply.toString(), yearnVault.asset);
|
|
32
|
-
const liquidity = assetAmountInEth(poolLiquidity.toString(), yearnVault.asset);
|
|
33
|
-
|
|
34
|
-
const supplied: Record<EthAddress, string> = {};
|
|
35
|
-
accounts.forEach((account) => {
|
|
36
|
-
const yvAmountWei = yvAmountsWei[account] || BigInt(0);
|
|
37
|
-
const underlyingAmountWei = new Dec(yvAmountWei).mul(exchangeRate).toString();
|
|
38
|
-
supplied[account.toLowerCase() as EthAddress] = assetAmountInEth(underlyingAmountWei, yearnVault.asset);
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
return {
|
|
42
|
-
poolSize,
|
|
43
|
-
liquidity,
|
|
44
|
-
supplied,
|
|
45
|
-
asset: yearnVault.asset,
|
|
46
|
-
optionType: yearnVault.type,
|
|
47
|
-
};
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
export async function getYearnVaultData(provider: EthereumProvider, network: NetworkNumber, yearnVault: YearnVault, accounts: EthAddress[]): Promise<SavingsVaultData> {
|
|
51
|
-
return _getYearnVaultData(getViemProvider(provider, network, {
|
|
52
|
-
batch: {
|
|
53
|
-
multicall: {
|
|
54
|
-
batchSize: 2500000,
|
|
55
|
-
},
|
|
56
|
-
},
|
|
57
|
-
}), network, yearnVault, accounts);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
export const _getYearnVaultExchangeRate = async (provider: Client, yearnVault: YearnVault): Promise<string> => {
|
|
61
|
-
const yearnVaultContract = getYearnVaultContractViem(provider, yearnVault.address);
|
|
62
|
-
|
|
63
|
-
const [tokenSupply, underlyingSupply] = await Promise.all([
|
|
64
|
-
yearnVaultContract.read.totalSupply(),
|
|
65
|
-
yearnVaultContract.read.totalAssets(),
|
|
66
|
-
]);
|
|
67
|
-
|
|
68
|
-
const exchangeRate = new Dec(underlyingSupply).div(tokenSupply).toString();
|
|
69
|
-
return exchangeRate;
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
export async function getYearnVaultExchangeRate(provider: EthereumProvider, network: NetworkNumber, yearnVault: YearnVault): Promise<string> {
|
|
73
|
-
return _getYearnVaultExchangeRate(getViemProvider(provider, network), yearnVault);
|
|
1
|
+
import Dec from 'decimal.js';
|
|
2
|
+
import { Client } from 'viem';
|
|
3
|
+
import { assetAmountInEth } from '@defisaver/tokens';
|
|
4
|
+
import { getViemProvider } from '../../services/viem';
|
|
5
|
+
import { SavingsVaultData, YearnVault } from '../../types';
|
|
6
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
7
|
+
import * as yearnVaultsOptions from './options';
|
|
8
|
+
import { getYearnVaultContractViem, YearnViewContractViem } from '../../contracts';
|
|
9
|
+
|
|
10
|
+
export {
|
|
11
|
+
yearnVaultsOptions,
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export const _getYearnVaultData = async (provider: Client, network: NetworkNumber, yearnVault: YearnVault, accounts: EthAddress[]): Promise<SavingsVaultData> => {
|
|
15
|
+
const yearnVaultContract = getYearnVaultContractViem(provider, yearnVault.address);
|
|
16
|
+
const viewContract = YearnViewContractViem(provider, network);
|
|
17
|
+
|
|
18
|
+
const yvAmountsWei: Record<EthAddress, bigint> = {};
|
|
19
|
+
|
|
20
|
+
const [tokenSupply, underlyingSupply, poolLiquidity] = await Promise.all([
|
|
21
|
+
yearnVaultContract.read.totalSupply(),
|
|
22
|
+
yearnVaultContract.read.totalAssets(),
|
|
23
|
+
viewContract.read.getPoolLiquidity([yearnVault.address]),
|
|
24
|
+
...accounts.map(async (account) => {
|
|
25
|
+
const yvAmount = await yearnVaultContract.read.balanceOf([account]);
|
|
26
|
+
yvAmountsWei[account] = yvAmount;
|
|
27
|
+
}),
|
|
28
|
+
]);
|
|
29
|
+
|
|
30
|
+
const exchangeRate = new Dec(underlyingSupply).div(tokenSupply).toString();
|
|
31
|
+
const poolSize = assetAmountInEth(underlyingSupply.toString(), yearnVault.asset);
|
|
32
|
+
const liquidity = assetAmountInEth(poolLiquidity.toString(), yearnVault.asset);
|
|
33
|
+
|
|
34
|
+
const supplied: Record<EthAddress, string> = {};
|
|
35
|
+
accounts.forEach((account) => {
|
|
36
|
+
const yvAmountWei = yvAmountsWei[account] || BigInt(0);
|
|
37
|
+
const underlyingAmountWei = new Dec(yvAmountWei).mul(exchangeRate).toString();
|
|
38
|
+
supplied[account.toLowerCase() as EthAddress] = assetAmountInEth(underlyingAmountWei, yearnVault.asset);
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
return {
|
|
42
|
+
poolSize,
|
|
43
|
+
liquidity,
|
|
44
|
+
supplied,
|
|
45
|
+
asset: yearnVault.asset,
|
|
46
|
+
optionType: yearnVault.type,
|
|
47
|
+
};
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
export async function getYearnVaultData(provider: EthereumProvider, network: NetworkNumber, yearnVault: YearnVault, accounts: EthAddress[]): Promise<SavingsVaultData> {
|
|
51
|
+
return _getYearnVaultData(getViemProvider(provider, network, {
|
|
52
|
+
batch: {
|
|
53
|
+
multicall: {
|
|
54
|
+
batchSize: 2500000,
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
}), network, yearnVault, accounts);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
export const _getYearnVaultExchangeRate = async (provider: Client, yearnVault: YearnVault): Promise<string> => {
|
|
61
|
+
const yearnVaultContract = getYearnVaultContractViem(provider, yearnVault.address);
|
|
62
|
+
|
|
63
|
+
const [tokenSupply, underlyingSupply] = await Promise.all([
|
|
64
|
+
yearnVaultContract.read.totalSupply(),
|
|
65
|
+
yearnVaultContract.read.totalAssets(),
|
|
66
|
+
]);
|
|
67
|
+
|
|
68
|
+
const exchangeRate = new Dec(underlyingSupply).div(tokenSupply).toString();
|
|
69
|
+
return exchangeRate;
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
export async function getYearnVaultExchangeRate(provider: EthereumProvider, network: NetworkNumber, yearnVault: YearnVault): Promise<string> {
|
|
73
|
+
return _getYearnVaultExchangeRate(getViemProvider(provider, network), yearnVault);
|
|
74
74
|
}
|
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
import { YearnVault, YearnVaultType } from '../../types/savings/yearnVaults';
|
|
2
|
-
|
|
3
|
-
export const YEARN_VAULT_DAI: YearnVault = {
|
|
4
|
-
type: YearnVaultType.YearnVaultDAI,
|
|
5
|
-
address: '0xdA816459F1AB5631232FE5e97a05BBBb94970c95',
|
|
6
|
-
asset: 'DAI',
|
|
7
|
-
deploymentBlock: 12796965,
|
|
8
|
-
isLegacy: false,
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
export const YEARN_VAULT_USDC: YearnVault = {
|
|
12
|
-
type: YearnVaultType.YearnVaultUSDC,
|
|
13
|
-
address: '0xa354F35829Ae975e850e23e9615b11Da1B3dC4DE',
|
|
14
|
-
asset: 'USDC',
|
|
15
|
-
deploymentBlock: 13513457,
|
|
16
|
-
isLegacy: false,
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
export const YEARN_VAULT_USDT: YearnVault = {
|
|
20
|
-
type: YearnVaultType.YearnVaultUSDT,
|
|
21
|
-
address: '0x3B27F92C0e212C671EA351827EDF93DB27cc0c65',
|
|
22
|
-
asset: 'USDT',
|
|
23
|
-
deploymentBlock: 14980240,
|
|
24
|
-
isLegacy: false,
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
export const YEARN_VAULTS: Record<YearnVaultType, YearnVault> = {
|
|
28
|
-
[YearnVaultType.YearnVaultDAI]: YEARN_VAULT_DAI,
|
|
29
|
-
[YearnVaultType.YearnVaultUSDC]: YEARN_VAULT_USDC,
|
|
30
|
-
[YearnVaultType.YearnVaultUSDT]: YEARN_VAULT_USDT,
|
|
31
|
-
};
|
|
32
|
-
|
|
1
|
+
import { YearnVault, YearnVaultType } from '../../types/savings/yearnVaults';
|
|
2
|
+
|
|
3
|
+
export const YEARN_VAULT_DAI: YearnVault = {
|
|
4
|
+
type: YearnVaultType.YearnVaultDAI,
|
|
5
|
+
address: '0xdA816459F1AB5631232FE5e97a05BBBb94970c95',
|
|
6
|
+
asset: 'DAI',
|
|
7
|
+
deploymentBlock: 12796965,
|
|
8
|
+
isLegacy: false,
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export const YEARN_VAULT_USDC: YearnVault = {
|
|
12
|
+
type: YearnVaultType.YearnVaultUSDC,
|
|
13
|
+
address: '0xa354F35829Ae975e850e23e9615b11Da1B3dC4DE',
|
|
14
|
+
asset: 'USDC',
|
|
15
|
+
deploymentBlock: 13513457,
|
|
16
|
+
isLegacy: false,
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
export const YEARN_VAULT_USDT: YearnVault = {
|
|
20
|
+
type: YearnVaultType.YearnVaultUSDT,
|
|
21
|
+
address: '0x3B27F92C0e212C671EA351827EDF93DB27cc0c65',
|
|
22
|
+
asset: 'USDT',
|
|
23
|
+
deploymentBlock: 14980240,
|
|
24
|
+
isLegacy: false,
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export const YEARN_VAULTS: Record<YearnVaultType, YearnVault> = {
|
|
28
|
+
[YearnVaultType.YearnVaultDAI]: YEARN_VAULT_DAI,
|
|
29
|
+
[YearnVaultType.YearnVaultUSDC]: YEARN_VAULT_USDC,
|
|
30
|
+
[YearnVaultType.YearnVaultUSDT]: YEARN_VAULT_USDT,
|
|
31
|
+
};
|
|
32
|
+
|
|
33
33
|
export const getYearnVault = (type: YearnVaultType): YearnVault => YEARN_VAULTS[type];
|