@defisaver/positions-sdk 2.1.52-dev-2 → 2.1.52
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/cjs/fluid/index.d.ts +3 -3
- package/cjs/helpers/aaveHelpers/index.d.ts +2 -2
- package/cjs/helpers/aaveHelpers/index.js +2 -18
- package/cjs/helpers/compoundHelpers/index.js +1 -1
- package/cjs/helpers/eulerHelpers/index.d.ts +2 -2
- package/cjs/helpers/eulerHelpers/index.js +5 -6
- package/cjs/helpers/fluidHelpers/index.js +1 -2
- package/cjs/helpers/morphoBlueHelpers/index.js +1 -1
- package/cjs/helpers/sparkHelpers/index.js +1 -1
- package/cjs/moneymarket/moneymarketCommonService.d.ts +3 -3
- package/cjs/moneymarket/moneymarketCommonService.js +6 -14
- package/cjs/types/aave.d.ts +2 -3
- package/cjs/types/common.d.ts +0 -8
- package/cjs/types/common.js +1 -10
- package/cjs/types/compound.d.ts +2 -2
- package/cjs/types/curveUsd.d.ts +2 -2
- package/cjs/types/euler.d.ts +2 -2
- package/cjs/types/fluid.d.ts +2 -2
- package/cjs/types/liquityV2.d.ts +3 -3
- package/cjs/types/llamaLend.d.ts +2 -2
- package/cjs/types/morphoBlue.d.ts +3 -3
- package/cjs/types/spark.d.ts +2 -2
- package/esm/fluid/index.d.ts +3 -3
- package/esm/helpers/aaveHelpers/index.d.ts +2 -2
- package/esm/helpers/aaveHelpers/index.js +2 -18
- package/esm/helpers/compoundHelpers/index.js +2 -2
- package/esm/helpers/eulerHelpers/index.d.ts +2 -2
- package/esm/helpers/eulerHelpers/index.js +5 -6
- package/esm/helpers/fluidHelpers/index.js +1 -2
- package/esm/helpers/morphoBlueHelpers/index.js +2 -2
- package/esm/helpers/sparkHelpers/index.js +2 -2
- package/esm/moneymarket/moneymarketCommonService.d.ts +3 -3
- package/esm/moneymarket/moneymarketCommonService.js +6 -14
- package/esm/types/aave.d.ts +2 -3
- package/esm/types/common.d.ts +0 -8
- package/esm/types/common.js +0 -9
- package/esm/types/compound.d.ts +2 -2
- package/esm/types/curveUsd.d.ts +2 -2
- package/esm/types/euler.d.ts +2 -2
- package/esm/types/fluid.d.ts +2 -2
- package/esm/types/fluid.js +1 -1
- package/esm/types/liquityV2.d.ts +3 -3
- package/esm/types/llamaLend.d.ts +2 -2
- package/esm/types/morphoBlue.d.ts +3 -3
- package/esm/types/spark.d.ts +2 -2
- package/package.json +2 -2
- package/src/helpers/aaveHelpers/index.ts +4 -20
- package/src/helpers/compoundHelpers/index.ts +2 -2
- package/src/helpers/eulerHelpers/index.ts +6 -6
- package/src/helpers/fluidHelpers/index.ts +2 -2
- package/src/helpers/morphoBlueHelpers/index.ts +2 -2
- package/src/helpers/sparkHelpers/index.ts +2 -4
- package/src/moneymarket/moneymarketCommonService.ts +8 -15
- package/src/types/aave.ts +1 -3
- package/src/types/common.ts +0 -9
- package/src/types/compound.ts +1 -2
- package/src/types/curveUsd.ts +2 -2
- package/src/types/euler.ts +1 -2
- package/src/types/fluid.ts +2 -4
- package/src/types/liquityV2.ts +3 -5
- package/src/types/llamaLend.ts +2 -4
- package/src/types/morphoBlue.ts +3 -3
- package/src/types/spark.ts +1 -2
package/cjs/fluid/index.d.ts
CHANGED
|
@@ -130,7 +130,7 @@ export declare const _getUserPositions: (provider: PublicClient, network: Networ
|
|
|
130
130
|
collRatio: string;
|
|
131
131
|
minRatio: string;
|
|
132
132
|
totalInterestUsd: string;
|
|
133
|
-
leveragedType?:
|
|
133
|
+
leveragedType?: string;
|
|
134
134
|
leveragedAsset?: string;
|
|
135
135
|
liquidationPrice?: string;
|
|
136
136
|
leveragedLsdAssetRatio?: string;
|
|
@@ -161,7 +161,7 @@ export declare const getUserPositions: (provider: EthereumProvider, network: Net
|
|
|
161
161
|
collRatio: string;
|
|
162
162
|
minRatio: string;
|
|
163
163
|
totalInterestUsd: string;
|
|
164
|
-
leveragedType?:
|
|
164
|
+
leveragedType?: string;
|
|
165
165
|
leveragedAsset?: string;
|
|
166
166
|
liquidationPrice?: string;
|
|
167
167
|
leveragedLsdAssetRatio?: string;
|
|
@@ -192,7 +192,7 @@ export declare const _getUserPositionsPortfolio: (provider: PublicClient, networ
|
|
|
192
192
|
collRatio: string;
|
|
193
193
|
minRatio: string;
|
|
194
194
|
totalInterestUsd: string;
|
|
195
|
-
leveragedType?:
|
|
195
|
+
leveragedType?: string;
|
|
196
196
|
leveragedAsset?: string;
|
|
197
197
|
liquidationPrice?: string;
|
|
198
198
|
leveragedLsdAssetRatio?: string;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AaveHelperCommon, AaveMarketInfo, AaveV3AggregatedPositionData, AaveV3AssetsData,
|
|
1
|
+
import { AaveHelperCommon, AaveMarketInfo, AaveV3AggregatedPositionData, AaveV3AssetsData, AaveV3UsedAssets, AaveVersions } from '../../types';
|
|
2
2
|
import { EthereumProvider, NetworkNumber } from '../../types/common';
|
|
3
3
|
export declare const AAVE_V3_MARKETS: AaveVersions[];
|
|
4
4
|
export declare const isAaveV2: ({ selectedMarket }: {
|
|
@@ -17,7 +17,7 @@ export declare const aaveV3IsInSiloedMode: ({ usedAssets, assetsData }: {
|
|
|
17
17
|
}) => boolean;
|
|
18
18
|
export declare const aaveAnyGetCollSuppliedAssets: ({ usedAssets }: {
|
|
19
19
|
usedAssets: AaveV3UsedAssets;
|
|
20
|
-
}) => AaveV3UsedAsset[];
|
|
20
|
+
}) => import("../../types").AaveV3UsedAsset[];
|
|
21
21
|
export declare const aaveAnyGetSuppliableAssets: ({ usedAssets, eModeCategory, assetsData, selectedMarket, network, ...rest }: AaveHelperCommon) => {
|
|
22
22
|
symbol: string;
|
|
23
23
|
canBeCollateral: boolean;
|
|
@@ -31,7 +31,6 @@ const utils_1 = require("../../services/utils");
|
|
|
31
31
|
const moneymarket_1 = require("../../moneymarket");
|
|
32
32
|
const staking_1 = require("../../staking");
|
|
33
33
|
const constants_1 = require("../../constants");
|
|
34
|
-
const common_1 = require("../../types/common");
|
|
35
34
|
const contracts_1 = require("../../contracts");
|
|
36
35
|
const viem_1 = require("../../services/viem");
|
|
37
36
|
exports.AAVE_V3_MARKETS = [types_1.AaveVersions.AaveV3, types_1.AaveVersions.AaveV3Lido, types_1.AaveVersions.AaveV3Etherfi];
|
|
@@ -104,27 +103,12 @@ const aaveAnyGetAggregatedPositionData = (_a) => {
|
|
|
104
103
|
payload.liquidationPrice = '';
|
|
105
104
|
if (leveragedType !== '') {
|
|
106
105
|
let assetPrice = data.assetsData[leveragedAsset].price;
|
|
107
|
-
if (leveragedType ===
|
|
106
|
+
if (leveragedType === 'lsd-leverage') {
|
|
108
107
|
// Treat ETH like a stablecoin in a long stETH position
|
|
109
108
|
payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
|
|
110
109
|
assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
|
|
111
110
|
}
|
|
112
|
-
|
|
113
|
-
const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
|
|
114
|
-
const borrowedAssetPrice = data.assetsData[borrowedAsset.symbol].price;
|
|
115
|
-
const leveragedAssetPrice = data.assetsData[leveragedAsset].price;
|
|
116
|
-
const isReverse = new decimal_js_1.default(leveragedAssetPrice).lt(borrowedAssetPrice);
|
|
117
|
-
if (isReverse) {
|
|
118
|
-
payload.leveragedType = common_1.LeverageType.VolatilePairReverse;
|
|
119
|
-
payload.currentVolatilePairRatio = new decimal_js_1.default(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
|
|
120
|
-
assetPrice = new decimal_js_1.default(borrowedAssetPrice).div(assetPrice).toString();
|
|
121
|
-
}
|
|
122
|
-
else {
|
|
123
|
-
assetPrice = new decimal_js_1.default(assetPrice).div(borrowedAssetPrice).toString();
|
|
124
|
-
payload.currentVolatilePairRatio = new decimal_js_1.default(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
|
|
111
|
+
payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
|
|
128
112
|
}
|
|
129
113
|
payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
|
|
130
114
|
payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
|
|
@@ -150,7 +150,7 @@ const getCompoundV3AggregatedData = (_a) => {
|
|
|
150
150
|
if (leveragedType !== '') {
|
|
151
151
|
payload.leveragedAsset = leveragedAsset;
|
|
152
152
|
let assetPrice = assetsData[leveragedAsset].price;
|
|
153
|
-
if (leveragedType ===
|
|
153
|
+
if (leveragedType === 'lsd-leverage') {
|
|
154
154
|
payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toString();
|
|
155
155
|
assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
|
|
156
156
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { EthAddress, EthereumProvider,
|
|
1
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
2
2
|
import { EulerV2AggregatedPositionData, EulerV2AssetsData, EulerV2UsedAssets } from '../../types';
|
|
3
3
|
export declare const isLeveragedPos: (usedAssets: EulerV2UsedAssets, dustLimit?: number) => {
|
|
4
|
-
leveragedType:
|
|
4
|
+
leveragedType: string;
|
|
5
5
|
leveragedAsset: string;
|
|
6
6
|
leveragedVault: string;
|
|
7
7
|
};
|
|
@@ -26,7 +26,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
26
26
|
exports.getEulerV2SubAccounts = exports.getApyAfterValuesEstimationEulerV2 = exports.getEulerV2SupplyRate = exports.getUtilizationRate = exports.getEulerV2BorrowRate = exports.getEulerV2AggregatedData = exports.isLeveragedPos = void 0;
|
|
27
27
|
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
28
28
|
const tokens_1 = require("@defisaver/tokens");
|
|
29
|
-
const common_1 = require("../../types/common");
|
|
30
29
|
const moneymarket_1 = require("../../moneymarket");
|
|
31
30
|
const staking_1 = require("../../staking");
|
|
32
31
|
const contracts_1 = require("../../contracts");
|
|
@@ -64,27 +63,27 @@ const isLeveragedPos = (usedAssets, dustLimit = 5) => {
|
|
|
64
63
|
const isLsdLeveraged = supplyUnstable === 1 && borrowUnstable === 1 && shortAsset === 'ETH' && ['stETH', 'wstETH', 'cbETH', 'rETH'].includes(longAsset);
|
|
65
64
|
if (isLong) {
|
|
66
65
|
return {
|
|
67
|
-
leveragedType:
|
|
66
|
+
leveragedType: 'long',
|
|
68
67
|
leveragedAsset: longAsset,
|
|
69
68
|
leveragedVault: leverageAssetVault,
|
|
70
69
|
};
|
|
71
70
|
}
|
|
72
71
|
if (isShort) {
|
|
73
72
|
return {
|
|
74
|
-
leveragedType:
|
|
73
|
+
leveragedType: 'short',
|
|
75
74
|
leveragedAsset: shortAsset,
|
|
76
75
|
leveragedVault: leverageAssetVault,
|
|
77
76
|
};
|
|
78
77
|
}
|
|
79
78
|
if (isLsdLeveraged) {
|
|
80
79
|
return {
|
|
81
|
-
leveragedType:
|
|
80
|
+
leveragedType: 'lsd-leverage',
|
|
82
81
|
leveragedAsset: longAsset,
|
|
83
82
|
leveragedVault: leverageAssetVault,
|
|
84
83
|
};
|
|
85
84
|
}
|
|
86
85
|
return {
|
|
87
|
-
leveragedType:
|
|
86
|
+
leveragedType: '',
|
|
88
87
|
leveragedAsset: '',
|
|
89
88
|
leveragedVault: '',
|
|
90
89
|
};
|
|
@@ -114,7 +113,7 @@ const getEulerV2AggregatedData = (_a) => {
|
|
|
114
113
|
if (leveragedType !== '') {
|
|
115
114
|
payload.leveragedAsset = leveragedAsset;
|
|
116
115
|
let assetPrice = assetsData[leveragedVault.toLowerCase()].price;
|
|
117
|
-
if (leveragedType ===
|
|
116
|
+
if (leveragedType === 'lsd-leverage') {
|
|
118
117
|
const ethAsset = Object.values(assetsData).find((asset) => ['WETH', 'ETH'].includes(asset.symbol));
|
|
119
118
|
if (ethAsset) {
|
|
120
119
|
payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedVault.toLowerCase()].price).div(ethAsset.price).toString();
|
|
@@ -9,7 +9,6 @@ const tokens_1 = require("@defisaver/tokens");
|
|
|
9
9
|
const types_1 = require("../../types");
|
|
10
10
|
const moneymarket_1 = require("../../moneymarket");
|
|
11
11
|
const staking_1 = require("../../staking");
|
|
12
|
-
const common_1 = require("../../types/common");
|
|
13
12
|
const utils_1 = require("../../services/utils");
|
|
14
13
|
const calculateNetApyDex = ({ marketData, suppliedUsd, borrowedUsd }) => {
|
|
15
14
|
const { borrowRate, supplyRate, incentiveBorrowRate, incentiveSupplyRate, tradingBorrowRate, tradingSupplyRate, } = marketData;
|
|
@@ -56,7 +55,7 @@ const getFluidAggregatedData = ({ usedAssets, assetsData, marketData, }, supplyS
|
|
|
56
55
|
if (leveragedType !== '') {
|
|
57
56
|
payload.leveragedAsset = leveragedAsset;
|
|
58
57
|
let assetPrice = assetsData[leveragedAsset].price;
|
|
59
|
-
if (leveragedType ===
|
|
58
|
+
if (leveragedType === 'lsd-leverage') {
|
|
60
59
|
// Treat ETH like a stablecoin in a long stETH position
|
|
61
60
|
payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
|
|
62
61
|
assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
|
|
@@ -51,7 +51,7 @@ const getMorphoBlueAggregatedPositionData = ({ usedAssets, assetsData, marketInf
|
|
|
51
51
|
if (leveragedType !== '') {
|
|
52
52
|
payload.leveragedAsset = leveragedAsset;
|
|
53
53
|
let assetPrice = assetsData[leveragedAsset].price;
|
|
54
|
-
if (leveragedType ===
|
|
54
|
+
if (leveragedType === 'lsd-leverage') {
|
|
55
55
|
// Treat ETH like a stablecoin in a long stETH position
|
|
56
56
|
payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
|
|
57
57
|
assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
|
|
@@ -92,7 +92,7 @@ const sparkGetAggregatedPositionData = (_a) => {
|
|
|
92
92
|
if (leveragedType !== '') {
|
|
93
93
|
payload.leveragedAsset = leveragedAsset;
|
|
94
94
|
let assetPrice = data.assetsData[leveragedAsset].price; // TODO sparkPrice or price??
|
|
95
|
-
if (leveragedType ===
|
|
95
|
+
if (leveragedType === 'lsd-leverage') {
|
|
96
96
|
// Treat ETH like a stablecoin in a long stETH position
|
|
97
97
|
payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
|
|
98
98
|
assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { MMUsedAssets } from '../types/common';
|
|
2
2
|
export declare const getAssetsTotal: (assets: object, filter: any, transform: any) => any;
|
|
3
3
|
export declare const calcLongLiqPrice: (assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => string;
|
|
4
4
|
export declare const calcShortLiqPrice: (assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => string;
|
|
5
|
-
export declare const calcLeverageLiqPrice: (leverageType:
|
|
5
|
+
export declare const calcLeverageLiqPrice: (leverageType: string, assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => string;
|
|
6
6
|
export declare const calculateBorrowingAssetLimit: (assetBorrowedUsd: string, borrowLimitUsd: string) => string;
|
|
7
7
|
export declare const STABLE_ASSETS: string[];
|
|
8
8
|
export declare const isLeveragedPos: (usedAssets: MMUsedAssets, dustLimit?: number) => {
|
|
9
|
-
leveragedType:
|
|
9
|
+
leveragedType: string;
|
|
10
10
|
leveragedAsset: string;
|
|
11
11
|
};
|
|
12
12
|
export declare const aprToApy: (interest: string | number, frequency?: number) => string;
|
|
@@ -6,7 +6,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.aprToApy = exports.isLeveragedPos = exports.STABLE_ASSETS = exports.calculateBorrowingAssetLimit = exports.calcLeverageLiqPrice = exports.calcShortLiqPrice = exports.calcLongLiqPrice = exports.getAssetsTotal = void 0;
|
|
7
7
|
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
8
8
|
const constants_1 = require("../constants");
|
|
9
|
-
const common_1 = require("../types/common");
|
|
10
9
|
const getAssetsTotal = (assets, filter, transform) => Object.values(assets)
|
|
11
10
|
.filter(filter)
|
|
12
11
|
.map(transform)
|
|
@@ -18,9 +17,9 @@ exports.calcLongLiqPrice = calcLongLiqPrice;
|
|
|
18
17
|
const calcShortLiqPrice = (assetPrice, borrowedUsd, borrowLimitUsd) => new decimal_js_1.default(assetPrice).div(borrowedUsd).mul(borrowLimitUsd).toString();
|
|
19
18
|
exports.calcShortLiqPrice = calcShortLiqPrice;
|
|
20
19
|
const calcLeverageLiqPrice = (leverageType, assetPrice, borrowedUsd, borrowLimitUsd) => {
|
|
21
|
-
if (leverageType ===
|
|
20
|
+
if (leverageType === 'short')
|
|
22
21
|
return (0, exports.calcShortLiqPrice)(assetPrice, borrowedUsd, borrowLimitUsd);
|
|
23
|
-
if (leverageType ===
|
|
22
|
+
if (leverageType === 'long' || leverageType === 'lsd-leverage')
|
|
24
23
|
return (0, exports.calcLongLiqPrice)(assetPrice, borrowedUsd, borrowLimitUsd);
|
|
25
24
|
console.error('invalid leverageType', leverageType);
|
|
26
25
|
return '0';
|
|
@@ -61,33 +60,26 @@ const isLeveragedPos = (usedAssets, dustLimit = 5) => {
|
|
|
61
60
|
const isShort = supplyStable > 0 && supplyUnstable === 0 && borrowUnstable === 1 && borrowStable === 0;
|
|
62
61
|
// lsd -> liquid staking derivative
|
|
63
62
|
const isLsdLeveraged = supplyUnstable === 1 && borrowUnstable === 1 && shortAsset === 'ETH' && ['stETH', 'wstETH', 'cbETH', 'rETH', 'ezETH', 'weETH'].includes(longAsset);
|
|
64
|
-
const isVolatilePair = supplyUnstable === 1 && borrowUnstable === 1 && supplyStable === 0 && borrowStable === 0;
|
|
65
63
|
if (isLong) {
|
|
66
64
|
return {
|
|
67
|
-
leveragedType:
|
|
65
|
+
leveragedType: 'long',
|
|
68
66
|
leveragedAsset: longAsset,
|
|
69
67
|
};
|
|
70
68
|
}
|
|
71
69
|
if (isShort) {
|
|
72
70
|
return {
|
|
73
|
-
leveragedType:
|
|
71
|
+
leveragedType: 'short',
|
|
74
72
|
leveragedAsset: shortAsset,
|
|
75
73
|
};
|
|
76
74
|
}
|
|
77
75
|
if (isLsdLeveraged) {
|
|
78
76
|
return {
|
|
79
|
-
leveragedType:
|
|
80
|
-
leveragedAsset: longAsset,
|
|
81
|
-
};
|
|
82
|
-
}
|
|
83
|
-
if (isVolatilePair) {
|
|
84
|
-
return {
|
|
85
|
-
leveragedType: common_1.LeverageType.VolatilePair,
|
|
77
|
+
leveragedType: 'lsd-leverage',
|
|
86
78
|
leveragedAsset: longAsset,
|
|
87
79
|
};
|
|
88
80
|
}
|
|
89
81
|
return {
|
|
90
|
-
leveragedType:
|
|
82
|
+
leveragedType: '',
|
|
91
83
|
leveragedAsset: '',
|
|
92
84
|
};
|
|
93
85
|
};
|
package/cjs/types/aave.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IncentiveData,
|
|
1
|
+
import { IncentiveData, MMAssetData, MMPositionData, MMUsedAsset, NetworkNumber } from './common';
|
|
2
2
|
export declare enum AaveVersions {
|
|
3
3
|
AaveV1 = "v1",
|
|
4
4
|
AaveV2 = "v2default",
|
|
@@ -161,7 +161,7 @@ export interface AaveV3AggregatedPositionData {
|
|
|
161
161
|
totalInterestUsd: string;
|
|
162
162
|
liqRatio: string;
|
|
163
163
|
liqPercent: string;
|
|
164
|
-
leveragedType:
|
|
164
|
+
leveragedType: string;
|
|
165
165
|
leveragedAsset?: string;
|
|
166
166
|
leveragedLsdAssetRatio?: string;
|
|
167
167
|
liquidationPrice?: string;
|
|
@@ -169,7 +169,6 @@ export interface AaveV3AggregatedPositionData {
|
|
|
169
169
|
collLiquidationRatio?: string;
|
|
170
170
|
healthRatio?: string;
|
|
171
171
|
minHealthRatio?: string;
|
|
172
|
-
currentVolatilePairRatio?: string;
|
|
173
172
|
}
|
|
174
173
|
export interface AaveHelperCommon {
|
|
175
174
|
usedAssets: any;
|
package/cjs/types/common.d.ts
CHANGED
|
@@ -8,14 +8,6 @@ export declare enum IncentiveEligibilityId {
|
|
|
8
8
|
AaveV3ArbitrumETHLSBorrow = "0x0c84331e39d6658Cd6e6b9ba04736cC4c4734351",
|
|
9
9
|
AaveV3EthenaLiquidLeveragePlasma = "0x67264783f1e9a2af8627a235853057a6fc975bd2BORROW_BL"
|
|
10
10
|
}
|
|
11
|
-
export declare enum LeverageType {
|
|
12
|
-
Long = "long",
|
|
13
|
-
Short = "short",
|
|
14
|
-
LsdLeverage = "lsd-leverage",
|
|
15
|
-
VolatilePair = "volatile-pair",
|
|
16
|
-
VolatilePairReverse = "volatile-pair-reverse",
|
|
17
|
-
None = ""
|
|
18
|
-
}
|
|
19
11
|
export interface IncentiveData {
|
|
20
12
|
token: string;
|
|
21
13
|
apy: string;
|
package/cjs/types/common.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NetworkNumber = exports.
|
|
3
|
+
exports.NetworkNumber = exports.IncentiveEligibilityId = exports.IncentiveKind = void 0;
|
|
4
4
|
var IncentiveKind;
|
|
5
5
|
(function (IncentiveKind) {
|
|
6
6
|
IncentiveKind["Staking"] = "staking";
|
|
@@ -13,15 +13,6 @@ var IncentiveEligibilityId;
|
|
|
13
13
|
IncentiveEligibilityId["AaveV3ArbitrumETHLSBorrow"] = "0x0c84331e39d6658Cd6e6b9ba04736cC4c4734351";
|
|
14
14
|
IncentiveEligibilityId["AaveV3EthenaLiquidLeveragePlasma"] = "0x67264783f1e9a2af8627a235853057a6fc975bd2BORROW_BL";
|
|
15
15
|
})(IncentiveEligibilityId || (exports.IncentiveEligibilityId = IncentiveEligibilityId = {}));
|
|
16
|
-
var LeverageType;
|
|
17
|
-
(function (LeverageType) {
|
|
18
|
-
LeverageType["Long"] = "long";
|
|
19
|
-
LeverageType["Short"] = "short";
|
|
20
|
-
LeverageType["LsdLeverage"] = "lsd-leverage";
|
|
21
|
-
LeverageType["VolatilePair"] = "volatile-pair";
|
|
22
|
-
LeverageType["VolatilePairReverse"] = "volatile-pair-reverse";
|
|
23
|
-
LeverageType["None"] = "";
|
|
24
|
-
})(LeverageType || (exports.LeverageType = LeverageType = {}));
|
|
25
16
|
var NetworkNumber;
|
|
26
17
|
(function (NetworkNumber) {
|
|
27
18
|
NetworkNumber[NetworkNumber["Eth"] = 1] = "Eth";
|
package/cjs/types/compound.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EthAddress,
|
|
1
|
+
import { EthAddress, MMAssetData, MMPositionData, MMUsedAsset, NetworkNumber } from './common';
|
|
2
2
|
export declare enum CompoundVersions {
|
|
3
3
|
'CompoundV2' = "v2",
|
|
4
4
|
'CompoundV3USDC' = "v3-USDC",
|
|
@@ -94,7 +94,7 @@ export interface CompoundAggregatedPositionData {
|
|
|
94
94
|
totalInterestUsd: string;
|
|
95
95
|
liqRatio: string;
|
|
96
96
|
liqPercent: string;
|
|
97
|
-
leveragedType:
|
|
97
|
+
leveragedType: string;
|
|
98
98
|
leveragedAsset?: string;
|
|
99
99
|
leveragedLsdAssetRatio?: string;
|
|
100
100
|
liquidationPrice?: string;
|
package/cjs/types/curveUsd.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EthAddress,
|
|
1
|
+
import { EthAddress, NetworkNumber } from './common';
|
|
2
2
|
export declare enum CrvUSDVersions {
|
|
3
3
|
'crvUSDwstETH' = "wstETH",
|
|
4
4
|
'crvUSDWBTC' = "WBTC",
|
|
@@ -71,7 +71,7 @@ export interface CrvUSDAggregatedPositionData {
|
|
|
71
71
|
borrowLimitUsd: string;
|
|
72
72
|
minAllowedRatio: number;
|
|
73
73
|
collFactor: string;
|
|
74
|
-
leveragedType:
|
|
74
|
+
leveragedType: string;
|
|
75
75
|
leveragedAsset?: string;
|
|
76
76
|
liquidationPrice?: string;
|
|
77
77
|
}
|
package/cjs/types/euler.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EthAddress, IncentiveData,
|
|
1
|
+
import { EthAddress, IncentiveData, MMPositionData, NetworkNumber } from './common';
|
|
2
2
|
export declare enum EulerV2Versions {
|
|
3
3
|
eUSDC2 = "eUSDC-2",
|
|
4
4
|
eWETH2 = "eWETH-2"
|
|
@@ -141,7 +141,7 @@ export interface EulerV2AggregatedPositionData {
|
|
|
141
141
|
totalInterestUsd: string;
|
|
142
142
|
liqRatio: string;
|
|
143
143
|
liqPercent: string;
|
|
144
|
-
leveragedType:
|
|
144
|
+
leveragedType: string;
|
|
145
145
|
leveragedAsset?: string;
|
|
146
146
|
leveragedLsdAssetRatio?: string;
|
|
147
147
|
liquidationPrice?: string;
|
package/cjs/types/fluid.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EthAddress, IncentiveData,
|
|
1
|
+
import { EthAddress, IncentiveData, NetworkNumber } from './common';
|
|
2
2
|
export interface FluidMarketInfo {
|
|
3
3
|
chainIds: number[];
|
|
4
4
|
label: string;
|
|
@@ -323,7 +323,7 @@ export interface FluidAggregatedVaultData {
|
|
|
323
323
|
collRatio: string;
|
|
324
324
|
minRatio: string;
|
|
325
325
|
totalInterestUsd: string;
|
|
326
|
-
leveragedType?:
|
|
326
|
+
leveragedType?: string;
|
|
327
327
|
leveragedAsset?: string;
|
|
328
328
|
liquidationPrice?: string;
|
|
329
329
|
leveragedLsdAssetRatio?: string;
|
package/cjs/types/liquityV2.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EthAddress, IncentiveData,
|
|
1
|
+
import { EthAddress, IncentiveData, NetworkNumber } from './common';
|
|
2
2
|
export declare enum LiquityV2Versions {
|
|
3
3
|
LiquityV2Eth = "liquityv2eth",
|
|
4
4
|
LiquityV2WstEth = "liquityv2wsteth",
|
|
@@ -88,7 +88,7 @@ export interface LiquityV2AggregatedTroveData {
|
|
|
88
88
|
netApy: string;
|
|
89
89
|
incentiveUsd: string;
|
|
90
90
|
totalInterestUsd: string;
|
|
91
|
-
leveragedType:
|
|
91
|
+
leveragedType: string;
|
|
92
92
|
leveragedAsset: string;
|
|
93
93
|
liquidationPrice: string;
|
|
94
94
|
ratio: string;
|
|
@@ -110,7 +110,7 @@ export interface LiquityV2TroveData {
|
|
|
110
110
|
totalInterestUsd: string;
|
|
111
111
|
interestBatchManager: EthAddress;
|
|
112
112
|
troveStatus: string;
|
|
113
|
-
leveragedType:
|
|
113
|
+
leveragedType: string;
|
|
114
114
|
leveragedAsset: string;
|
|
115
115
|
liquidationPrice: string;
|
|
116
116
|
debtInFront: string;
|
package/cjs/types/llamaLend.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EthAddress, IncentiveData,
|
|
1
|
+
import { EthAddress, IncentiveData, NetworkNumber } from './common';
|
|
2
2
|
import { BandData, UserBandData } from './curveUsd';
|
|
3
3
|
export declare enum LLVersionsEth {
|
|
4
4
|
LLWstethCrvusd = "llamaLendwstETHcrvUSD",
|
|
@@ -112,7 +112,7 @@ export interface LlamaLendAggregatedPositionData {
|
|
|
112
112
|
borrowLimitUsd: string;
|
|
113
113
|
minAllowedRatio: number;
|
|
114
114
|
collFactor: string;
|
|
115
|
-
leveragedType:
|
|
115
|
+
leveragedType: string;
|
|
116
116
|
leveragedAsset?: string;
|
|
117
117
|
liquidationPrice?: string;
|
|
118
118
|
netApy: string;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EthAddress, IncentiveData,
|
|
1
|
+
import { EthAddress, IncentiveData, MMUsedAssets, NetworkNumber } from './common';
|
|
2
2
|
export declare enum MorphoBlueVersions {
|
|
3
3
|
MorphoBlueWstEthUSDC = "morphobluewstethusdc",// wstETH/USDC
|
|
4
4
|
MorphoBlueSDAIUSDC = "morphobluesdaiusdc",// sDAI/USDC
|
|
@@ -121,7 +121,7 @@ export interface MorphoBlueAggregatedPositionData {
|
|
|
121
121
|
totalInterestUsd: string;
|
|
122
122
|
ltv: string;
|
|
123
123
|
ratio: string;
|
|
124
|
-
leveragedType:
|
|
124
|
+
leveragedType: string;
|
|
125
125
|
leveragedAsset?: string;
|
|
126
126
|
leveragedLsdAssetRatio?: string;
|
|
127
127
|
liquidationPrice?: string;
|
|
@@ -142,7 +142,7 @@ export interface MorphoBluePositionData {
|
|
|
142
142
|
totalInterestUsd: string;
|
|
143
143
|
ltv: string;
|
|
144
144
|
ratio: string;
|
|
145
|
-
leveragedType:
|
|
145
|
+
leveragedType: string;
|
|
146
146
|
leveragedAsset?: string;
|
|
147
147
|
leveragedLsdAssetRatio?: string;
|
|
148
148
|
liquidationPrice?: string;
|
package/cjs/types/spark.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { EModeCategoriesData } from './aave';
|
|
2
|
-
import { EthAddress,
|
|
2
|
+
import { EthAddress, MMAssetData, MMPositionData, MMUsedAsset, NetworkNumber } from './common';
|
|
3
3
|
export declare enum SparkVersions {
|
|
4
4
|
SparkV1 = "v1default"
|
|
5
5
|
}
|
|
@@ -90,7 +90,7 @@ export interface SparkAggregatedPositionData {
|
|
|
90
90
|
totalInterestUsd: string;
|
|
91
91
|
liqRatio: string;
|
|
92
92
|
liqPercent: string;
|
|
93
|
-
leveragedType:
|
|
93
|
+
leveragedType: string;
|
|
94
94
|
leveragedAsset?: string;
|
|
95
95
|
leveragedLsdAssetRatio?: string;
|
|
96
96
|
liquidationPrice?: string;
|
package/esm/fluid/index.d.ts
CHANGED
|
@@ -130,7 +130,7 @@ export declare const _getUserPositions: (provider: PublicClient, network: Networ
|
|
|
130
130
|
collRatio: string;
|
|
131
131
|
minRatio: string;
|
|
132
132
|
totalInterestUsd: string;
|
|
133
|
-
leveragedType?:
|
|
133
|
+
leveragedType?: string;
|
|
134
134
|
leveragedAsset?: string;
|
|
135
135
|
liquidationPrice?: string;
|
|
136
136
|
leveragedLsdAssetRatio?: string;
|
|
@@ -161,7 +161,7 @@ export declare const getUserPositions: (provider: EthereumProvider, network: Net
|
|
|
161
161
|
collRatio: string;
|
|
162
162
|
minRatio: string;
|
|
163
163
|
totalInterestUsd: string;
|
|
164
|
-
leveragedType?:
|
|
164
|
+
leveragedType?: string;
|
|
165
165
|
leveragedAsset?: string;
|
|
166
166
|
liquidationPrice?: string;
|
|
167
167
|
leveragedLsdAssetRatio?: string;
|
|
@@ -192,7 +192,7 @@ export declare const _getUserPositionsPortfolio: (provider: PublicClient, networ
|
|
|
192
192
|
collRatio: string;
|
|
193
193
|
minRatio: string;
|
|
194
194
|
totalInterestUsd: string;
|
|
195
|
-
leveragedType?:
|
|
195
|
+
leveragedType?: string;
|
|
196
196
|
leveragedAsset?: string;
|
|
197
197
|
liquidationPrice?: string;
|
|
198
198
|
leveragedLsdAssetRatio?: string;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AaveHelperCommon, AaveMarketInfo, AaveV3AggregatedPositionData, AaveV3AssetsData,
|
|
1
|
+
import { AaveHelperCommon, AaveMarketInfo, AaveV3AggregatedPositionData, AaveV3AssetsData, AaveV3UsedAssets, AaveVersions } from '../../types';
|
|
2
2
|
import { EthereumProvider, NetworkNumber } from '../../types/common';
|
|
3
3
|
export declare const AAVE_V3_MARKETS: AaveVersions[];
|
|
4
4
|
export declare const isAaveV2: ({ selectedMarket }: {
|
|
@@ -17,7 +17,7 @@ export declare const aaveV3IsInSiloedMode: ({ usedAssets, assetsData }: {
|
|
|
17
17
|
}) => boolean;
|
|
18
18
|
export declare const aaveAnyGetCollSuppliedAssets: ({ usedAssets }: {
|
|
19
19
|
usedAssets: AaveV3UsedAssets;
|
|
20
|
-
}) => AaveV3UsedAsset[];
|
|
20
|
+
}) => import("../../types").AaveV3UsedAsset[];
|
|
21
21
|
export declare const aaveAnyGetSuppliableAssets: ({ usedAssets, eModeCategory, assetsData, selectedMarket, network, ...rest }: AaveHelperCommon) => {
|
|
22
22
|
symbol: string;
|
|
23
23
|
canBeCollateral: boolean;
|
|
@@ -25,7 +25,6 @@ import { getNativeAssetFromWrapped, getWrappedNativeAssetFromUnwrapped } from '.
|
|
|
25
25
|
import { aprToApy, calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos, } from '../../moneymarket';
|
|
26
26
|
import { calculateNetApy } from '../../staking';
|
|
27
27
|
import { borrowOperations } from '../../constants';
|
|
28
|
-
import { LeverageType, } from '../../types/common';
|
|
29
28
|
import { AaveLoanInfoV2ContractViem, AaveV3ViewContractViem } from '../../contracts';
|
|
30
29
|
import { getViemProvider } from '../../services/viem';
|
|
31
30
|
export const AAVE_V3_MARKETS = [AaveVersions.AaveV3, AaveVersions.AaveV3Lido, AaveVersions.AaveV3Etherfi];
|
|
@@ -90,27 +89,12 @@ export const aaveAnyGetAggregatedPositionData = (_a) => {
|
|
|
90
89
|
payload.liquidationPrice = '';
|
|
91
90
|
if (leveragedType !== '') {
|
|
92
91
|
let assetPrice = data.assetsData[leveragedAsset].price;
|
|
93
|
-
if (leveragedType ===
|
|
92
|
+
if (leveragedType === 'lsd-leverage') {
|
|
94
93
|
// Treat ETH like a stablecoin in a long stETH position
|
|
95
94
|
payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
|
|
96
95
|
assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
|
|
97
96
|
}
|
|
98
|
-
|
|
99
|
-
const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
|
|
100
|
-
const borrowedAssetPrice = data.assetsData[borrowedAsset.symbol].price;
|
|
101
|
-
const leveragedAssetPrice = data.assetsData[leveragedAsset].price;
|
|
102
|
-
const isReverse = new Dec(leveragedAssetPrice).lt(borrowedAssetPrice);
|
|
103
|
-
if (isReverse) {
|
|
104
|
-
payload.leveragedType = LeverageType.VolatilePairReverse;
|
|
105
|
-
payload.currentVolatilePairRatio = new Dec(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
|
|
106
|
-
assetPrice = new Dec(borrowedAssetPrice).div(assetPrice).toString();
|
|
107
|
-
}
|
|
108
|
-
else {
|
|
109
|
-
assetPrice = new Dec(assetPrice).div(borrowedAssetPrice).toString();
|
|
110
|
-
payload.currentVolatilePairRatio = new Dec(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
payload.liquidationPrice = calcLeverageLiqPrice(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
|
|
97
|
+
payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
|
|
114
98
|
}
|
|
115
99
|
payload.minCollRatio = new Dec(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
|
|
116
100
|
payload.collLiquidationRatio = new Dec(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
|
|
@@ -25,7 +25,7 @@ import { addToArrayIf, getEthAmountForDecimals, handleWbtcLegacy, wethToEth, } f
|
|
|
25
25
|
import { BLOCKS_IN_A_YEAR, borrowOperations, SECONDS_PER_YEAR } from '../../constants';
|
|
26
26
|
import { aprToApy, calcLeverageLiqPrice, calculateBorrowingAssetLimit, getAssetsTotal, isLeveragedPos, } from '../../moneymarket';
|
|
27
27
|
import { calculateNetApy, getStakingApy, STAKING_ASSETS } from '../../staking';
|
|
28
|
-
import { IncentiveKind,
|
|
28
|
+
import { IncentiveKind, NetworkNumber, } from '../../types/common';
|
|
29
29
|
import { CompoundLoanInfoContractViem, CompV3ViewContractViem } from '../../contracts';
|
|
30
30
|
import { getViemProvider } from '../../services/viem';
|
|
31
31
|
export const formatMarketData = (data, network, baseAssetPrice) => {
|
|
@@ -140,7 +140,7 @@ export const getCompoundV3AggregatedData = (_a) => {
|
|
|
140
140
|
if (leveragedType !== '') {
|
|
141
141
|
payload.leveragedAsset = leveragedAsset;
|
|
142
142
|
let assetPrice = assetsData[leveragedAsset].price;
|
|
143
|
-
if (leveragedType ===
|
|
143
|
+
if (leveragedType === 'lsd-leverage') {
|
|
144
144
|
payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toString();
|
|
145
145
|
assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
|
|
146
146
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { EthAddress, EthereumProvider,
|
|
1
|
+
import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
|
|
2
2
|
import { EulerV2AggregatedPositionData, EulerV2AssetsData, EulerV2UsedAssets } from '../../types';
|
|
3
3
|
export declare const isLeveragedPos: (usedAssets: EulerV2UsedAssets, dustLimit?: number) => {
|
|
4
|
-
leveragedType:
|
|
4
|
+
leveragedType: string;
|
|
5
5
|
leveragedAsset: string;
|
|
6
6
|
leveragedVault: string;
|
|
7
7
|
};
|
|
@@ -20,7 +20,6 @@ var __rest = (this && this.__rest) || function (s, e) {
|
|
|
20
20
|
};
|
|
21
21
|
import Dec from 'decimal.js';
|
|
22
22
|
import { assetAmountInWei } from '@defisaver/tokens';
|
|
23
|
-
import { LeverageType, } from '../../types/common';
|
|
24
23
|
import { calcLeverageLiqPrice, getAssetsTotal, STABLE_ASSETS, } from '../../moneymarket';
|
|
25
24
|
import { calculateNetApy } from '../../staking';
|
|
26
25
|
import { EulerV2ViewContractViem } from '../../contracts';
|
|
@@ -58,27 +57,27 @@ export const isLeveragedPos = (usedAssets, dustLimit = 5) => {
|
|
|
58
57
|
const isLsdLeveraged = supplyUnstable === 1 && borrowUnstable === 1 && shortAsset === 'ETH' && ['stETH', 'wstETH', 'cbETH', 'rETH'].includes(longAsset);
|
|
59
58
|
if (isLong) {
|
|
60
59
|
return {
|
|
61
|
-
leveragedType:
|
|
60
|
+
leveragedType: 'long',
|
|
62
61
|
leveragedAsset: longAsset,
|
|
63
62
|
leveragedVault: leverageAssetVault,
|
|
64
63
|
};
|
|
65
64
|
}
|
|
66
65
|
if (isShort) {
|
|
67
66
|
return {
|
|
68
|
-
leveragedType:
|
|
67
|
+
leveragedType: 'short',
|
|
69
68
|
leveragedAsset: shortAsset,
|
|
70
69
|
leveragedVault: leverageAssetVault,
|
|
71
70
|
};
|
|
72
71
|
}
|
|
73
72
|
if (isLsdLeveraged) {
|
|
74
73
|
return {
|
|
75
|
-
leveragedType:
|
|
74
|
+
leveragedType: 'lsd-leverage',
|
|
76
75
|
leveragedAsset: longAsset,
|
|
77
76
|
leveragedVault: leverageAssetVault,
|
|
78
77
|
};
|
|
79
78
|
}
|
|
80
79
|
return {
|
|
81
|
-
leveragedType:
|
|
80
|
+
leveragedType: '',
|
|
82
81
|
leveragedAsset: '',
|
|
83
82
|
leveragedVault: '',
|
|
84
83
|
};
|
|
@@ -107,7 +106,7 @@ export const getEulerV2AggregatedData = (_a) => {
|
|
|
107
106
|
if (leveragedType !== '') {
|
|
108
107
|
payload.leveragedAsset = leveragedAsset;
|
|
109
108
|
let assetPrice = assetsData[leveragedVault.toLowerCase()].price;
|
|
110
|
-
if (leveragedType ===
|
|
109
|
+
if (leveragedType === 'lsd-leverage') {
|
|
111
110
|
const ethAsset = Object.values(assetsData).find((asset) => ['WETH', 'ETH'].includes(asset.symbol));
|
|
112
111
|
if (ethAsset) {
|
|
113
112
|
payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedVault.toLowerCase()].price).div(ethAsset.price).toString();
|