@defisaver/positions-sdk 2.1.27 → 2.1.28
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/makerDSR/options.js +1 -0
- package/cjs/savings/morphoVaults/index.js +17 -17
- package/cjs/savings/morphoVaults/options.js +13 -0
- package/cjs/savings/yearnVaults/options.js +3 -0
- package/cjs/types/savings/makerDsr.d.ts +1 -0
- package/cjs/types/savings/morphoVaults.d.ts +1 -0
- package/cjs/types/savings/yearnVaults.d.ts +1 -0
- package/esm/helpers/morphoBlueHelpers/index.js +66 -66
- package/esm/savings/makerDSR/options.js +1 -0
- package/esm/savings/morphoVaults/index.js +17 -17
- package/esm/savings/morphoVaults/options.js +13 -0
- package/esm/savings/yearnVaults/options.js +3 -0
- package/esm/types/savings/makerDsr.d.ts +1 -0
- package/esm/types/savings/morphoVaults.d.ts +1 -0
- package/esm/types/savings/yearnVaults.d.ts +1 -0
- package/package.json +48 -48
- package/src/aaveV2/index.ts +240 -240
- package/src/aaveV3/index.ts +614 -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 +1281 -1281
- package/src/constants/index.ts +10 -10
- package/src/contracts.ts +142 -142
- 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 +46 -46
- package/src/savings/makerDsr/index.ts +53 -53
- package/src/savings/makerDsr/options.ts +9 -8
- package/src/savings/morphoVaults/index.ts +80 -80
- package/src/savings/morphoVaults/options.ts +135 -122
- package/src/savings/yearnVaults/index.ts +73 -73
- package/src/savings/yearnVaults/options.ts +32 -29
- 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 +17 -17
- package/src/types/savings/makerDsr.ts +13 -12
- package/src/types/savings/morphoVaults.ts +25 -24
- package/src/types/savings/yearnVaults.ts +14 -13
- 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,46 +1,46 @@
|
|
|
1
|
-
import {
|
|
2
|
-
MakerDsrType,
|
|
3
|
-
MorphoVaultType,
|
|
4
|
-
SavingsData,
|
|
5
|
-
YearnVaultType,
|
|
6
|
-
} from '../types';
|
|
7
|
-
import { EthAddress, EthereumProvider, NetworkNumber } from '../types/common';
|
|
8
|
-
import * as morphoVaults from './morphoVaults';
|
|
9
|
-
import * as yearnVaults from './yearnVaults';
|
|
10
|
-
import * as makerDsr from './makerDSR';
|
|
11
|
-
|
|
12
|
-
export {
|
|
13
|
-
morphoVaults,
|
|
14
|
-
yearnVaults,
|
|
15
|
-
makerDsr,
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const getSavingsData = async (
|
|
19
|
-
provider: EthereumProvider,
|
|
20
|
-
network: NetworkNumber,
|
|
21
|
-
accounts: EthAddress[],
|
|
22
|
-
) => {
|
|
23
|
-
const morphoVaultsList = Object.keys(morphoVaults.morphoVaultsOptions.MORPHO_VAULTS) as MorphoVaultType[];
|
|
24
|
-
const yearnVaultsList = Object.keys(yearnVaults.yearnVaultsOptions.YEARN_VAULTS) as YearnVaultType[];
|
|
25
|
-
|
|
26
|
-
const savingsData: SavingsData = {};
|
|
27
|
-
|
|
28
|
-
await Promise.all([
|
|
29
|
-
...morphoVaultsList.map(async (vaultKey) => {
|
|
30
|
-
const vault = morphoVaults.morphoVaultsOptions.getMorphoVault(vaultKey);
|
|
31
|
-
const data = await morphoVaults.getMorphoVaultData(provider, network, vault, accounts);
|
|
32
|
-
savingsData[vaultKey] = data;
|
|
33
|
-
}),
|
|
34
|
-
...yearnVaultsList.map(async (vaultKey) => {
|
|
35
|
-
const vault = yearnVaults.yearnVaultsOptions.getYearnVault(vaultKey);
|
|
36
|
-
const data = await yearnVaults.getYearnVaultData(provider, network, vault, accounts);
|
|
37
|
-
savingsData[vaultKey] = data;
|
|
38
|
-
}),
|
|
39
|
-
(async () => {
|
|
40
|
-
const data = await makerDsr.getMakerDsrData(provider, network, accounts);
|
|
41
|
-
savingsData[MakerDsrType.MakerDsrVault] = data;
|
|
42
|
-
})(),
|
|
43
|
-
]);
|
|
44
|
-
|
|
45
|
-
return savingsData;
|
|
46
|
-
};
|
|
1
|
+
import {
|
|
2
|
+
MakerDsrType,
|
|
3
|
+
MorphoVaultType,
|
|
4
|
+
SavingsData,
|
|
5
|
+
YearnVaultType,
|
|
6
|
+
} from '../types';
|
|
7
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../types/common';
|
|
8
|
+
import * as morphoVaults from './morphoVaults';
|
|
9
|
+
import * as yearnVaults from './yearnVaults';
|
|
10
|
+
import * as makerDsr from './makerDSR';
|
|
11
|
+
|
|
12
|
+
export {
|
|
13
|
+
morphoVaults,
|
|
14
|
+
yearnVaults,
|
|
15
|
+
makerDsr,
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const getSavingsData = async (
|
|
19
|
+
provider: EthereumProvider,
|
|
20
|
+
network: NetworkNumber,
|
|
21
|
+
accounts: EthAddress[],
|
|
22
|
+
) => {
|
|
23
|
+
const morphoVaultsList = Object.keys(morphoVaults.morphoVaultsOptions.MORPHO_VAULTS) as MorphoVaultType[];
|
|
24
|
+
const yearnVaultsList = Object.keys(yearnVaults.yearnVaultsOptions.YEARN_VAULTS) as YearnVaultType[];
|
|
25
|
+
|
|
26
|
+
const savingsData: SavingsData = {};
|
|
27
|
+
|
|
28
|
+
await Promise.all([
|
|
29
|
+
...morphoVaultsList.map(async (vaultKey) => {
|
|
30
|
+
const vault = morphoVaults.morphoVaultsOptions.getMorphoVault(vaultKey);
|
|
31
|
+
const data = await morphoVaults.getMorphoVaultData(provider, network, vault, accounts);
|
|
32
|
+
savingsData[vaultKey] = data;
|
|
33
|
+
}),
|
|
34
|
+
...yearnVaultsList.map(async (vaultKey) => {
|
|
35
|
+
const vault = yearnVaults.yearnVaultsOptions.getYearnVault(vaultKey);
|
|
36
|
+
const data = await yearnVaults.getYearnVaultData(provider, network, vault, accounts);
|
|
37
|
+
savingsData[vaultKey] = data;
|
|
38
|
+
}),
|
|
39
|
+
(async () => {
|
|
40
|
+
const data = await makerDsr.getMakerDsrData(provider, network, accounts);
|
|
41
|
+
savingsData[MakerDsrType.MakerDsrVault] = data;
|
|
42
|
+
})(),
|
|
43
|
+
]);
|
|
44
|
+
|
|
45
|
+
return savingsData;
|
|
46
|
+
};
|
|
@@ -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,9 +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,
|
|
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,
|
|
9
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
|
}
|
|
@@ -1,123 +1,136 @@
|
|
|
1
|
-
import { MorphoVault, MorphoVaultType } from '../../types';
|
|
2
|
-
|
|
3
|
-
export const MORPHO_VAULT_FLAGSHIP_ETH: MorphoVault = {
|
|
4
|
-
type: MorphoVaultType.MorphoVaultFlagshipEth,
|
|
5
|
-
name: 'Flagship ETH',
|
|
6
|
-
address: '0x38989BBA00BDF8181F4082995b3DEAe96163aC5D',
|
|
7
|
-
asset: 'WETH',
|
|
8
|
-
deploymentBlock: 18927491,
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
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
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
};
|
|
74
|
-
|
|
75
|
-
export const
|
|
76
|
-
type: MorphoVaultType.
|
|
77
|
-
name: '
|
|
78
|
-
address: '
|
|
79
|
-
asset: 'USDT',
|
|
80
|
-
deploymentBlock:
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
1
|
+
import { MorphoVault, MorphoVaultType } from '../../types';
|
|
2
|
+
|
|
3
|
+
export const MORPHO_VAULT_FLAGSHIP_ETH: MorphoVault = {
|
|
4
|
+
type: MorphoVaultType.MorphoVaultFlagshipEth,
|
|
5
|
+
name: 'Flagship ETH',
|
|
6
|
+
address: '0x38989BBA00BDF8181F4082995b3DEAe96163aC5D',
|
|
7
|
+
asset: 'WETH',
|
|
8
|
+
deploymentBlock: 18927491,
|
|
9
|
+
isLegacy: true,
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export const MORPHO_VAULT_GAUNTLET_USDC_CORE: MorphoVault = {
|
|
13
|
+
type: MorphoVaultType.MorphoVaultGauntletUSDCCore,
|
|
14
|
+
name: 'Gauntlet USDC Core',
|
|
15
|
+
address: '0x8eB67A509616cd6A7c1B3c8C21D48FF57df3d458',
|
|
16
|
+
asset: 'USDC',
|
|
17
|
+
deploymentBlock: 19777569,
|
|
18
|
+
isLegacy: true,
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export const MORPHO_VAULT_GAUNTLET_USDC_PRIME: MorphoVault = {
|
|
22
|
+
type: MorphoVaultType.MorphoVaultGauntletUSDCPrime,
|
|
23
|
+
name: 'Gauntlet USDC Prime',
|
|
24
|
+
address: '0xdd0f28e19C1780eb6396170735D45153D261490d',
|
|
25
|
+
asset: 'USDC',
|
|
26
|
+
deploymentBlock: 19777569,
|
|
27
|
+
isLegacy: true,
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
export const MORPHO_VAULT_RE7_WETH: MorphoVault = {
|
|
31
|
+
type: MorphoVaultType.MorphoVaultRe7Weth,
|
|
32
|
+
name: 'RE7 WETH',
|
|
33
|
+
address: '0x78Fc2c2eD1A4cDb5402365934aE5648aDAd094d0',
|
|
34
|
+
asset: 'WETH',
|
|
35
|
+
deploymentBlock: 19121118,
|
|
36
|
+
isLegacy: true,
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
export const MORPHO_VAULT_GAUNTLET_WETH_CORE: MorphoVault = {
|
|
40
|
+
type: MorphoVaultType.MorphoVaultGauntletWETHCore,
|
|
41
|
+
name: 'Gauntlet WETH Core',
|
|
42
|
+
address: '0x4881Ef0BF6d2365D3dd6499ccd7532bcdBCE0658',
|
|
43
|
+
asset: 'WETH',
|
|
44
|
+
deploymentBlock: 19541126,
|
|
45
|
+
isLegacy: true,
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
export const MORPHO_VAULT_GAUNTLET_WETH_PRIME: MorphoVault = {
|
|
49
|
+
type: MorphoVaultType.MorphoVaultGauntletWETHPrime,
|
|
50
|
+
name: 'Gauntlet WETH Prime',
|
|
51
|
+
address: '0x2371e134e3455e0593363cBF89d3b6cf53740618',
|
|
52
|
+
asset: 'WETH',
|
|
53
|
+
deploymentBlock: 19372149,
|
|
54
|
+
isLegacy: true,
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
export const MORPHO_VAULT_BOOSTED_USDC: MorphoVault = {
|
|
58
|
+
type: MorphoVaultType.MorphoVaultBoostedUSDC,
|
|
59
|
+
name: 'Boosted USDC',
|
|
60
|
+
address: '0xd63070114470f685b75B74D60EEc7c1113d33a3D',
|
|
61
|
+
asset: 'USDC',
|
|
62
|
+
deploymentBlock: 20377233,
|
|
63
|
+
isLegacy: true,
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
export const MORPHO_VAULT_STEAKHOUSE_PYUSD: MorphoVault = {
|
|
67
|
+
type: MorphoVaultType.MorphoVaultSteakhousePYUSD,
|
|
68
|
+
name: 'Steakhouse PYUSD',
|
|
69
|
+
address: '0xbEEF02e5E13584ab96848af90261f0C8Ee04722a',
|
|
70
|
+
asset: 'PYUSD',
|
|
71
|
+
deploymentBlock: 19043398,
|
|
72
|
+
isLegacy: false,
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
export const MORPHO_VAULT_FLAGSHIP_USDT: MorphoVault = {
|
|
76
|
+
type: MorphoVaultType.MorphoVaultFlagshipUSDT,
|
|
77
|
+
name: 'Flagship USDT',
|
|
78
|
+
address: '0x2C25f6C25770fFEC5959D34B94Bf898865e5D6b1',
|
|
79
|
+
asset: 'USDT',
|
|
80
|
+
deploymentBlock: 19127039,
|
|
81
|
+
isLegacy: true,
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
export const MORPHO_VAULT_STEAKHOUSE_USDT: MorphoVault = {
|
|
85
|
+
type: MorphoVaultType.MorphoVaultSteakhouseUSDT,
|
|
86
|
+
name: 'Steakhouse USDT',
|
|
87
|
+
address: '0xbEef047a543E45807105E51A8BBEFCc5950fcfBa',
|
|
88
|
+
asset: 'USDT',
|
|
89
|
+
deploymentBlock: 19043398,
|
|
90
|
+
isLegacy: false,
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
export const MORPHO_VAULT_GAUNTLET_USDA_CORE: MorphoVault = {
|
|
94
|
+
type: MorphoVaultType.MorphoVaultGauntletUSDACore,
|
|
95
|
+
name: 'Gauntlet USDA Core',
|
|
96
|
+
address: '0x125D41A6e5dbf455cD9Df8F80BCC6fd172D52Cc6',
|
|
97
|
+
asset: 'USDA',
|
|
98
|
+
deploymentBlock: 19633608,
|
|
99
|
+
isLegacy: true,
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
export const MORPHO_VAULT_GAUNTLET_USDT_PRIME: MorphoVault = {
|
|
103
|
+
type: MorphoVaultType.MorphoVaultGauntletUSDTPrime,
|
|
104
|
+
name: 'Gauntlet USDT Prime',
|
|
105
|
+
address: '0x8CB3649114051cA5119141a34C200D65dc0Faa73',
|
|
106
|
+
asset: 'USDT',
|
|
107
|
+
deploymentBlock: 19486541,
|
|
108
|
+
isLegacy: true,
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
export const MORPHO_VAULT_GAUNTLET_RESOLV_USDC: MorphoVault = {
|
|
112
|
+
type: MorphoVaultType.MorphoVaultGauntletResolvUSDC,
|
|
113
|
+
name: 'Gauntlet Resolv USDC',
|
|
114
|
+
address: '0x132E6C9C33A62D7727cd359b1f51e5B566E485Eb',
|
|
115
|
+
asset: 'USDC',
|
|
116
|
+
deploymentBlock: 21487882,
|
|
117
|
+
isLegacy: true,
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
export const MORPHO_VAULTS: Record<MorphoVaultType, MorphoVault> = {
|
|
121
|
+
[MorphoVaultType.MorphoVaultFlagshipEth]: MORPHO_VAULT_FLAGSHIP_ETH,
|
|
122
|
+
[MorphoVaultType.MorphoVaultGauntletUSDCCore]: MORPHO_VAULT_GAUNTLET_USDC_CORE,
|
|
123
|
+
[MorphoVaultType.MorphoVaultGauntletUSDCPrime]: MORPHO_VAULT_GAUNTLET_USDC_PRIME,
|
|
124
|
+
[MorphoVaultType.MorphoVaultRe7Weth]: MORPHO_VAULT_RE7_WETH,
|
|
125
|
+
[MorphoVaultType.MorphoVaultGauntletWETHCore]: MORPHO_VAULT_GAUNTLET_WETH_CORE,
|
|
126
|
+
[MorphoVaultType.MorphoVaultGauntletWETHPrime]: MORPHO_VAULT_GAUNTLET_WETH_PRIME,
|
|
127
|
+
[MorphoVaultType.MorphoVaultBoostedUSDC]: MORPHO_VAULT_BOOSTED_USDC,
|
|
128
|
+
[MorphoVaultType.MorphoVaultSteakhousePYUSD]: MORPHO_VAULT_STEAKHOUSE_PYUSD,
|
|
129
|
+
[MorphoVaultType.MorphoVaultFlagshipUSDT]: MORPHO_VAULT_FLAGSHIP_USDT,
|
|
130
|
+
[MorphoVaultType.MorphoVaultSteakhouseUSDT]: MORPHO_VAULT_STEAKHOUSE_USDT,
|
|
131
|
+
[MorphoVaultType.MorphoVaultGauntletUSDACore]: MORPHO_VAULT_GAUNTLET_USDA_CORE,
|
|
132
|
+
[MorphoVaultType.MorphoVaultGauntletUSDTPrime]: MORPHO_VAULT_GAUNTLET_USDT_PRIME,
|
|
133
|
+
[MorphoVaultType.MorphoVaultGauntletResolvUSDC]: MORPHO_VAULT_GAUNTLET_RESOLV_USDC,
|
|
134
|
+
};
|
|
135
|
+
|
|
123
136
|
export const getMorphoVault = (type: MorphoVaultType): MorphoVault => MORPHO_VAULTS[type];
|