@defisaver/positions-sdk 2.1.34 → 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/config/contracts.d.ts +91 -0
- package/cjs/config/contracts.js +9 -1
- package/cjs/contracts.d.ts +629 -0
- package/cjs/contracts.js +2 -1
- package/cjs/helpers/morphoBlueHelpers/index.js +66 -66
- package/cjs/savings/index.d.ts +4 -3
- package/cjs/savings/index.js +43 -12
- package/cjs/savings/morphoVaults/index.js +17 -17
- package/cjs/savings/skyOptions/index.d.ts +7 -0
- package/cjs/savings/skyOptions/index.js +122 -0
- package/cjs/savings/skyOptions/options.d.ts +2 -0
- package/cjs/savings/skyOptions/options.js +12 -0
- package/cjs/types/savings/index.d.ts +3 -1
- package/cjs/types/savings/index.js +1 -0
- package/cjs/types/savings/sky.d.ts +12 -0
- package/cjs/types/savings/sky.js +7 -0
- package/esm/config/contracts.d.ts +91 -0
- package/esm/config/contracts.js +8 -0
- package/esm/contracts.d.ts +629 -0
- package/esm/contracts.js +1 -0
- package/esm/helpers/morphoBlueHelpers/index.js +66 -66
- package/esm/savings/index.d.ts +4 -3
- package/esm/savings/index.js +43 -13
- package/esm/savings/morphoVaults/index.js +17 -17
- package/esm/savings/skyOptions/index.d.ts +7 -0
- package/esm/savings/skyOptions/index.js +81 -0
- package/esm/savings/skyOptions/options.d.ts +2 -0
- package/esm/savings/skyOptions/options.js +9 -0
- package/esm/types/savings/index.d.ts +3 -1
- package/esm/types/savings/index.js +1 -0
- package/esm/types/savings/sky.d.ts +12 -0
- package/esm/types/savings/sky.js +4 -0
- package/package.json +48 -48
- package/src/aaveV2/index.ts +240 -240
- package/src/aaveV3/index.ts +625 -614
- 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 -1284
- package/src/constants/index.ts +10 -10
- package/src/contracts.ts +163 -161
- 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 -55
- 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 -0
- package/src/savings/skyOptions/options.ts +10 -0
- 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 +22 -20
- package/src/types/savings/makerDsr.ts +13 -13
- package/src/types/savings/morphoVaults.ts +33 -33
- package/src/types/savings/sky.ts +14 -0
- 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
package/src/savings/index.ts
CHANGED
|
@@ -1,55 +1,82 @@
|
|
|
1
|
-
import {
|
|
2
|
-
MakerDsrType,
|
|
3
|
-
MorphoVaultType,
|
|
4
|
-
SavingsData,
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
import
|
|
10
|
-
import * as
|
|
11
|
-
import * as
|
|
12
|
-
import * as
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
const
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
1
|
+
import {
|
|
2
|
+
MakerDsrType,
|
|
3
|
+
MorphoVaultType,
|
|
4
|
+
SavingsData,
|
|
5
|
+
SkySavingsType,
|
|
6
|
+
SparkSavingsVaultType,
|
|
7
|
+
YearnVaultType,
|
|
8
|
+
} from '../types';
|
|
9
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../types/common';
|
|
10
|
+
import * as morphoVaults from './morphoVaults';
|
|
11
|
+
import * as yearnVaults from './yearnVaults';
|
|
12
|
+
import * as makerDsr from './makerDsr';
|
|
13
|
+
import * as skyOptions from './skyOptions';
|
|
14
|
+
import * as sparkSavingsVaults from './sparkSavingsVaults';
|
|
15
|
+
|
|
16
|
+
export {
|
|
17
|
+
morphoVaults,
|
|
18
|
+
yearnVaults,
|
|
19
|
+
makerDsr,
|
|
20
|
+
skyOptions,
|
|
21
|
+
sparkSavingsVaults,
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export const getSavingsData = async (
|
|
25
|
+
provider: EthereumProvider,
|
|
26
|
+
network: NetworkNumber,
|
|
27
|
+
accounts: EthAddress[],
|
|
28
|
+
) => {
|
|
29
|
+
const morphoVaultsList = Object.keys(morphoVaults.morphoVaultsOptions.MORPHO_VAULTS) as MorphoVaultType[];
|
|
30
|
+
const yearnVaultsList = Object.keys(yearnVaults.yearnVaultsOptions.YEARN_VAULTS) as YearnVaultType[];
|
|
31
|
+
const sparkSavingsVaultsList = Object.keys(sparkSavingsVaults.sparkSavingsVaultsOptions.SPARK_SAVINGS_VAULTS) as SparkSavingsVaultType[];
|
|
32
|
+
|
|
33
|
+
const savingsData: SavingsData = {};
|
|
34
|
+
|
|
35
|
+
await Promise.all([
|
|
36
|
+
...morphoVaultsList.map(async (vaultKey) => {
|
|
37
|
+
try {
|
|
38
|
+
const vault = morphoVaults.morphoVaultsOptions.getMorphoVault(vaultKey);
|
|
39
|
+
const data = await morphoVaults.getMorphoVaultData(provider, network, vault, accounts);
|
|
40
|
+
savingsData[vaultKey] = data;
|
|
41
|
+
} catch (err) {
|
|
42
|
+
console.error(`[getSavingsData] Error fetching morpho vault ${vaultKey}:`, err);
|
|
43
|
+
}
|
|
44
|
+
}),
|
|
45
|
+
...yearnVaultsList.map(async (vaultKey) => {
|
|
46
|
+
try {
|
|
47
|
+
const vault = yearnVaults.yearnVaultsOptions.getYearnVault(vaultKey);
|
|
48
|
+
const data = await yearnVaults.getYearnVaultData(provider, network, vault, accounts);
|
|
49
|
+
savingsData[vaultKey] = data;
|
|
50
|
+
} catch (err) {
|
|
51
|
+
console.error(`[getSavingsData] Error fetching yearn vault ${vaultKey}:`, err);
|
|
52
|
+
}
|
|
53
|
+
}),
|
|
54
|
+
...sparkSavingsVaultsList.map(async (vaultKey) => {
|
|
55
|
+
try {
|
|
56
|
+
const vault = sparkSavingsVaults.sparkSavingsVaultsOptions.getSparkSavingsVault(vaultKey);
|
|
57
|
+
const data = await sparkSavingsVaults.getSparkSavingsVaultData(provider, network, vault, accounts);
|
|
58
|
+
savingsData[vaultKey] = data;
|
|
59
|
+
} catch (err) {
|
|
60
|
+
console.error(`[getSavingsData] Error fetching yearn vault ${vaultKey}:`, err);
|
|
61
|
+
}
|
|
62
|
+
}),
|
|
63
|
+
(async () => {
|
|
64
|
+
try {
|
|
65
|
+
const data = await makerDsr.getMakerDsrData(provider, network, accounts);
|
|
66
|
+
savingsData[MakerDsrType.MakerDsrVault] = data;
|
|
67
|
+
} catch (err) {
|
|
68
|
+
console.error('[getSavingsData] Error fetching maker DSR data:', err);
|
|
69
|
+
}
|
|
70
|
+
})(),
|
|
71
|
+
(async () => {
|
|
72
|
+
try {
|
|
73
|
+
const data = await skyOptions.getSkyOptionData(provider, network, accounts);
|
|
74
|
+
savingsData[SkySavingsType.SkySavings] = data;
|
|
75
|
+
} catch (err) {
|
|
76
|
+
console.error('[getSavingsData] Error fetching Sky savings data:', err);
|
|
77
|
+
}
|
|
78
|
+
})(),
|
|
79
|
+
]);
|
|
80
|
+
|
|
81
|
+
return savingsData;
|
|
82
|
+
};
|
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
import { Client } from 'viem';
|
|
2
|
-
import Dec from 'decimal.js';
|
|
3
|
-
import { getViemProvider } from '../../services/viem';
|
|
4
|
-
import { MakerDsrType, SavingsVaultData } from '../../types';
|
|
5
|
-
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
6
|
-
import * as makerDsrOptions from './options';
|
|
7
|
-
import { MakerDsrContractViem } from '../../contracts';
|
|
8
|
-
|
|
9
|
-
export {
|
|
10
|
-
makerDsrOptions,
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
export const _getMakerDsrData = async (provider: Client, network: NetworkNumber, accounts: EthAddress[]): Promise<SavingsVaultData> => {
|
|
14
|
-
const contract = MakerDsrContractViem(provider, network);
|
|
15
|
-
|
|
16
|
-
const pieAmounts: Record<EthAddress, bigint> = {};
|
|
17
|
-
|
|
18
|
-
const [Pie, chi] = await Promise.all([
|
|
19
|
-
contract.read.Pie(),
|
|
20
|
-
contract.read.chi(),
|
|
21
|
-
...accounts.map(async (account) => {
|
|
22
|
-
const pieAmount = await contract.read.pie([account]) as bigint;
|
|
23
|
-
pieAmounts[account] = pieAmount;
|
|
24
|
-
}),
|
|
25
|
-
]);
|
|
26
|
-
|
|
27
|
-
const totalSupplyRad = new Dec(Pie as bigint).mul(chi as bigint).toString();
|
|
28
|
-
const poolSize = new Dec(totalSupplyRad).div(1e45).toString();
|
|
29
|
-
|
|
30
|
-
const supplied: Record<EthAddress, string> = {};
|
|
31
|
-
accounts.forEach((account) => {
|
|
32
|
-
const pie = pieAmounts[account] || BigInt(0);
|
|
33
|
-
const radAmount = new Dec(pie).mul(chi as bigint).toString();
|
|
34
|
-
supplied[account.toLowerCase() as EthAddress] = new Dec(radAmount).div(1e45).toString();
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
return {
|
|
38
|
-
poolSize,
|
|
39
|
-
liquidity: poolSize,
|
|
40
|
-
supplied,
|
|
41
|
-
asset: 'DAI',
|
|
42
|
-
optionType: MakerDsrType.MakerDsrVault,
|
|
43
|
-
};
|
|
44
|
-
};
|
|
45
|
-
|
|
46
|
-
export async function getMakerDsrData(provider: EthereumProvider, network: NetworkNumber, accounts: EthAddress[]): Promise<SavingsVaultData> {
|
|
47
|
-
return _getMakerDsrData(getViemProvider(provider, network, {
|
|
48
|
-
batch: {
|
|
49
|
-
multicall: {
|
|
50
|
-
batchSize: 2500000,
|
|
51
|
-
},
|
|
52
|
-
},
|
|
53
|
-
}), network, accounts);
|
|
1
|
+
import { Client } from 'viem';
|
|
2
|
+
import Dec from 'decimal.js';
|
|
3
|
+
import { getViemProvider } from '../../services/viem';
|
|
4
|
+
import { MakerDsrType, SavingsVaultData } from '../../types';
|
|
5
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
6
|
+
import * as makerDsrOptions from './options';
|
|
7
|
+
import { MakerDsrContractViem } from '../../contracts';
|
|
8
|
+
|
|
9
|
+
export {
|
|
10
|
+
makerDsrOptions,
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const _getMakerDsrData = async (provider: Client, network: NetworkNumber, accounts: EthAddress[]): Promise<SavingsVaultData> => {
|
|
14
|
+
const contract = MakerDsrContractViem(provider, network);
|
|
15
|
+
|
|
16
|
+
const pieAmounts: Record<EthAddress, bigint> = {};
|
|
17
|
+
|
|
18
|
+
const [Pie, chi] = await Promise.all([
|
|
19
|
+
contract.read.Pie(),
|
|
20
|
+
contract.read.chi(),
|
|
21
|
+
...accounts.map(async (account) => {
|
|
22
|
+
const pieAmount = await contract.read.pie([account]) as bigint;
|
|
23
|
+
pieAmounts[account] = pieAmount;
|
|
24
|
+
}),
|
|
25
|
+
]);
|
|
26
|
+
|
|
27
|
+
const totalSupplyRad = new Dec(Pie as bigint).mul(chi as bigint).toString();
|
|
28
|
+
const poolSize = new Dec(totalSupplyRad).div(1e45).toString();
|
|
29
|
+
|
|
30
|
+
const supplied: Record<EthAddress, string> = {};
|
|
31
|
+
accounts.forEach((account) => {
|
|
32
|
+
const pie = pieAmounts[account] || BigInt(0);
|
|
33
|
+
const radAmount = new Dec(pie).mul(chi as bigint).toString();
|
|
34
|
+
supplied[account.toLowerCase() as EthAddress] = new Dec(radAmount).div(1e45).toString();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
return {
|
|
38
|
+
poolSize,
|
|
39
|
+
liquidity: poolSize,
|
|
40
|
+
supplied,
|
|
41
|
+
asset: 'DAI',
|
|
42
|
+
optionType: MakerDsrType.MakerDsrVault,
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
export async function getMakerDsrData(provider: EthereumProvider, network: NetworkNumber, accounts: EthAddress[]): Promise<SavingsVaultData> {
|
|
47
|
+
return _getMakerDsrData(getViemProvider(provider, network, {
|
|
48
|
+
batch: {
|
|
49
|
+
multicall: {
|
|
50
|
+
batchSize: 2500000,
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
}), network, accounts);
|
|
54
54
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { MakerDsrType, MakerDsrVault } from '../../types';
|
|
2
|
-
|
|
3
|
-
export const MAKER_DSR_VAULT: MakerDsrVault = {
|
|
4
|
-
type: MakerDsrType.MakerDsrVault,
|
|
5
|
-
name: 'Maker DSR',
|
|
6
|
-
address: '0x197e90f9fad81970ba7976f33cbd77088e5d7cf7',
|
|
7
|
-
asset: 'DAI',
|
|
8
|
-
deploymentBlock: 8928160,
|
|
9
|
-
isLegacy: true,
|
|
1
|
+
import { MakerDsrType, MakerDsrVault } from '../../types';
|
|
2
|
+
|
|
3
|
+
export const MAKER_DSR_VAULT: MakerDsrVault = {
|
|
4
|
+
type: MakerDsrType.MakerDsrVault,
|
|
5
|
+
name: 'Maker DSR',
|
|
6
|
+
address: '0x197e90f9fad81970ba7976f33cbd77088e5d7cf7',
|
|
7
|
+
asset: 'DAI',
|
|
8
|
+
deploymentBlock: 8928160,
|
|
9
|
+
isLegacy: true,
|
|
10
10
|
};
|
|
@@ -1,81 +1,81 @@
|
|
|
1
|
-
import { Client } from 'viem';
|
|
2
|
-
import Dec from 'decimal.js';
|
|
3
|
-
import { request as graphqlRequest } from 'graphql-request';
|
|
4
|
-
import { assetAmountInEth } from '@defisaver/tokens';
|
|
5
|
-
import * as morphoVaultsOptions from './options';
|
|
6
|
-
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
7
|
-
import { getViemProvider } from '../../services/viem';
|
|
8
|
-
import { getMorphoVaultContractViem } from '../../contracts';
|
|
9
|
-
import { MorphoVault, SavingsVaultData } from '../../types';
|
|
10
|
-
|
|
11
|
-
export {
|
|
12
|
-
morphoVaultsOptions,
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
const vaultDataQuery = (vaultAddress: EthAddress) => `query vaultByAddress {
|
|
16
|
-
vaultByAddress(chainId: 1, address: "${vaultAddress}") {
|
|
17
|
-
id,
|
|
18
|
-
dailyApy,
|
|
19
|
-
dailyApys {
|
|
20
|
-
apy, netApy
|
|
21
|
-
},
|
|
22
|
-
monthlyApys {
|
|
23
|
-
apy, netApy
|
|
24
|
-
},
|
|
25
|
-
liquidity {
|
|
26
|
-
underlying, usd,
|
|
27
|
-
},
|
|
28
|
-
asset {
|
|
29
|
-
priceUsd
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}`;
|
|
33
|
-
|
|
34
|
-
const MORPHO_BLUE_API = 'https://blue-api.morpho.org/graphql';
|
|
35
|
-
|
|
36
|
-
export const _getMorphoVaultData = async (provider: Client, network: NetworkNumber, morphoVault: MorphoVault, accounts: EthAddress[]): Promise<SavingsVaultData> => {
|
|
37
|
-
const morphoVaultContract = getMorphoVaultContractViem(provider, morphoVault.address);
|
|
38
|
-
|
|
39
|
-
const shares: Record<EthAddress, bigint> = {};
|
|
40
|
-
|
|
41
|
-
const [totalAssets, totalSupply, decimals, decimalsOffset, vaultData] = await Promise.all([
|
|
42
|
-
morphoVaultContract.read.totalAssets(),
|
|
43
|
-
morphoVaultContract.read.totalSupply(),
|
|
44
|
-
morphoVaultContract.read.decimals(),
|
|
45
|
-
morphoVaultContract.read.DECIMALS_OFFSET(),
|
|
46
|
-
graphqlRequest(MORPHO_BLUE_API, vaultDataQuery(morphoVault.address)),
|
|
47
|
-
...accounts.map(async (account) => {
|
|
48
|
-
const share = await morphoVaultContract.read.balanceOf([account]);
|
|
49
|
-
shares[account] = share;
|
|
50
|
-
}),
|
|
51
|
-
]);
|
|
52
|
-
|
|
53
|
-
const poolSize = assetAmountInEth(totalAssets.toString(), morphoVault.asset);
|
|
54
|
-
const liquidity = assetAmountInEth((vaultData as any).vaultByAddress.liquidity.underlying, morphoVault.asset);
|
|
55
|
-
|
|
56
|
-
const supplied: Record<EthAddress, string> = {};
|
|
57
|
-
accounts.forEach((account) => {
|
|
58
|
-
const share = shares[account] || BigInt(0);
|
|
59
|
-
supplied[account.toLowerCase() as EthAddress] = new Dec(new Dec(share.toString()).mul(new Dec(totalAssets.toString()).add(1)).div(new Dec(totalSupply.toString()).add(10 ** decimalsOffset)).div(10 ** 18)
|
|
60
|
-
.toFixed(decimals)).mul(10 ** decimalsOffset)
|
|
61
|
-
.toString();
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
return {
|
|
65
|
-
poolSize,
|
|
66
|
-
supplied,
|
|
67
|
-
liquidity,
|
|
68
|
-
asset: morphoVault.asset,
|
|
69
|
-
optionType: morphoVault.type,
|
|
70
|
-
};
|
|
71
|
-
};
|
|
72
|
-
|
|
73
|
-
export async function getMorphoVaultData(provider: EthereumProvider, network: NetworkNumber, morphoVault: MorphoVault, accounts: EthAddress[]): Promise<SavingsVaultData> {
|
|
74
|
-
return _getMorphoVaultData(getViemProvider(provider, network, {
|
|
75
|
-
batch: {
|
|
76
|
-
multicall: {
|
|
77
|
-
batchSize: 2500000,
|
|
78
|
-
},
|
|
79
|
-
},
|
|
80
|
-
}), network, morphoVault, accounts);
|
|
1
|
+
import { Client } from 'viem';
|
|
2
|
+
import Dec from 'decimal.js';
|
|
3
|
+
import { request as graphqlRequest } from 'graphql-request';
|
|
4
|
+
import { assetAmountInEth } from '@defisaver/tokens';
|
|
5
|
+
import * as morphoVaultsOptions from './options';
|
|
6
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
7
|
+
import { getViemProvider } from '../../services/viem';
|
|
8
|
+
import { getMorphoVaultContractViem } from '../../contracts';
|
|
9
|
+
import { MorphoVault, SavingsVaultData } from '../../types';
|
|
10
|
+
|
|
11
|
+
export {
|
|
12
|
+
morphoVaultsOptions,
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
const vaultDataQuery = (vaultAddress: EthAddress) => `query vaultByAddress {
|
|
16
|
+
vaultByAddress(chainId: 1, address: "${vaultAddress}") {
|
|
17
|
+
id,
|
|
18
|
+
dailyApy,
|
|
19
|
+
dailyApys {
|
|
20
|
+
apy, netApy
|
|
21
|
+
},
|
|
22
|
+
monthlyApys {
|
|
23
|
+
apy, netApy
|
|
24
|
+
},
|
|
25
|
+
liquidity {
|
|
26
|
+
underlying, usd,
|
|
27
|
+
},
|
|
28
|
+
asset {
|
|
29
|
+
priceUsd
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}`;
|
|
33
|
+
|
|
34
|
+
const MORPHO_BLUE_API = 'https://blue-api.morpho.org/graphql';
|
|
35
|
+
|
|
36
|
+
export const _getMorphoVaultData = async (provider: Client, network: NetworkNumber, morphoVault: MorphoVault, accounts: EthAddress[]): Promise<SavingsVaultData> => {
|
|
37
|
+
const morphoVaultContract = getMorphoVaultContractViem(provider, morphoVault.address);
|
|
38
|
+
|
|
39
|
+
const shares: Record<EthAddress, bigint> = {};
|
|
40
|
+
|
|
41
|
+
const [totalAssets, totalSupply, decimals, decimalsOffset, vaultData] = await Promise.all([
|
|
42
|
+
morphoVaultContract.read.totalAssets(),
|
|
43
|
+
morphoVaultContract.read.totalSupply(),
|
|
44
|
+
morphoVaultContract.read.decimals(),
|
|
45
|
+
morphoVaultContract.read.DECIMALS_OFFSET(),
|
|
46
|
+
graphqlRequest(MORPHO_BLUE_API, vaultDataQuery(morphoVault.address)),
|
|
47
|
+
...accounts.map(async (account) => {
|
|
48
|
+
const share = await morphoVaultContract.read.balanceOf([account]);
|
|
49
|
+
shares[account] = share;
|
|
50
|
+
}),
|
|
51
|
+
]);
|
|
52
|
+
|
|
53
|
+
const poolSize = assetAmountInEth(totalAssets.toString(), morphoVault.asset);
|
|
54
|
+
const liquidity = assetAmountInEth((vaultData as any).vaultByAddress.liquidity.underlying, morphoVault.asset);
|
|
55
|
+
|
|
56
|
+
const supplied: Record<EthAddress, string> = {};
|
|
57
|
+
accounts.forEach((account) => {
|
|
58
|
+
const share = shares[account] || BigInt(0);
|
|
59
|
+
supplied[account.toLowerCase() as EthAddress] = new Dec(new Dec(share.toString()).mul(new Dec(totalAssets.toString()).add(1)).div(new Dec(totalSupply.toString()).add(10 ** decimalsOffset)).div(10 ** 18)
|
|
60
|
+
.toFixed(decimals)).mul(10 ** decimalsOffset)
|
|
61
|
+
.toString();
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
return {
|
|
65
|
+
poolSize,
|
|
66
|
+
supplied,
|
|
67
|
+
liquidity,
|
|
68
|
+
asset: morphoVault.asset,
|
|
69
|
+
optionType: morphoVault.type,
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
export async function getMorphoVaultData(provider: EthereumProvider, network: NetworkNumber, morphoVault: MorphoVault, accounts: EthAddress[]): Promise<SavingsVaultData> {
|
|
74
|
+
return _getMorphoVaultData(getViemProvider(provider, network, {
|
|
75
|
+
batch: {
|
|
76
|
+
multicall: {
|
|
77
|
+
batchSize: 2500000,
|
|
78
|
+
},
|
|
79
|
+
},
|
|
80
|
+
}), network, morphoVault, accounts);
|
|
81
81
|
}
|