@defisaver/positions-sdk 2.1.52-aave-v4 → 2.1.52-aave-v4-1-dev

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.
Files changed (86) hide show
  1. package/cjs/fluid/index.d.ts +6 -6
  2. package/cjs/helpers/aaveHelpers/index.d.ts +2 -2
  3. package/cjs/helpers/aaveHelpers/index.js +16 -5
  4. package/cjs/helpers/aaveV4Helpers/index.d.ts +2 -2
  5. package/cjs/helpers/aaveV4Helpers/index.js +22 -14
  6. package/cjs/helpers/compoundHelpers/index.js +15 -18
  7. package/cjs/helpers/eulerHelpers/index.d.ts +2 -2
  8. package/cjs/helpers/eulerHelpers/index.js +21 -13
  9. package/cjs/helpers/fluidHelpers/index.js +16 -5
  10. package/cjs/helpers/morphoBlueHelpers/index.js +15 -5
  11. package/cjs/helpers/sparkHelpers/index.d.ts +2 -2
  12. package/cjs/helpers/sparkHelpers/index.js +15 -5
  13. package/cjs/markets/aaveV4/index.d.ts +10 -7
  14. package/cjs/markets/aaveV4/index.js +41 -21
  15. package/cjs/moneymarket/moneymarketCommonService.d.ts +3 -3
  16. package/cjs/moneymarket/moneymarketCommonService.js +9 -9
  17. package/cjs/types/aave.d.ts +3 -3
  18. package/cjs/types/aaveV4.d.ts +7 -5
  19. package/cjs/types/aaveV4.js +2 -0
  20. package/cjs/types/common.d.ts +7 -0
  21. package/cjs/types/common.js +9 -1
  22. package/cjs/types/compound.d.ts +3 -3
  23. package/cjs/types/curveUsd.d.ts +2 -2
  24. package/cjs/types/euler.d.ts +3 -3
  25. package/cjs/types/fluid.d.ts +3 -3
  26. package/cjs/types/index.d.ts +1 -0
  27. package/cjs/types/index.js +1 -0
  28. package/cjs/types/liquityV2.d.ts +3 -3
  29. package/cjs/types/llamaLend.d.ts +2 -2
  30. package/cjs/types/morphoBlue.d.ts +5 -5
  31. package/cjs/types/spark.d.ts +3 -3
  32. package/esm/fluid/index.d.ts +6 -6
  33. package/esm/helpers/aaveHelpers/index.d.ts +2 -2
  34. package/esm/helpers/aaveHelpers/index.js +16 -5
  35. package/esm/helpers/aaveV4Helpers/index.d.ts +2 -2
  36. package/esm/helpers/aaveV4Helpers/index.js +22 -14
  37. package/esm/helpers/compoundHelpers/index.js +16 -19
  38. package/esm/helpers/eulerHelpers/index.d.ts +2 -2
  39. package/esm/helpers/eulerHelpers/index.js +21 -13
  40. package/esm/helpers/fluidHelpers/index.js +16 -5
  41. package/esm/helpers/morphoBlueHelpers/index.js +16 -6
  42. package/esm/helpers/sparkHelpers/index.d.ts +2 -2
  43. package/esm/helpers/sparkHelpers/index.js +16 -6
  44. package/esm/markets/aaveV4/index.d.ts +10 -7
  45. package/esm/markets/aaveV4/index.js +33 -15
  46. package/esm/moneymarket/moneymarketCommonService.d.ts +3 -3
  47. package/esm/moneymarket/moneymarketCommonService.js +9 -9
  48. package/esm/types/aave.d.ts +3 -3
  49. package/esm/types/aaveV4.d.ts +7 -5
  50. package/esm/types/aaveV4.js +2 -0
  51. package/esm/types/common.d.ts +7 -0
  52. package/esm/types/common.js +8 -0
  53. package/esm/types/compound.d.ts +3 -3
  54. package/esm/types/curveUsd.d.ts +2 -2
  55. package/esm/types/euler.d.ts +3 -3
  56. package/esm/types/fluid.d.ts +3 -3
  57. package/esm/types/fluid.js +1 -1
  58. package/esm/types/index.d.ts +1 -0
  59. package/esm/types/index.js +1 -0
  60. package/esm/types/liquityV2.d.ts +3 -3
  61. package/esm/types/llamaLend.d.ts +2 -2
  62. package/esm/types/morphoBlue.d.ts +5 -5
  63. package/esm/types/spark.d.ts +3 -3
  64. package/package.json +1 -1
  65. package/src/helpers/aaveHelpers/index.ts +18 -7
  66. package/src/helpers/aaveV4Helpers/index.ts +21 -14
  67. package/src/helpers/compoundHelpers/index.ts +16 -23
  68. package/src/helpers/eulerHelpers/index.ts +21 -14
  69. package/src/helpers/fluidHelpers/index.ts +15 -6
  70. package/src/helpers/morphoBlueHelpers/index.ts +15 -6
  71. package/src/helpers/sparkHelpers/index.ts +18 -7
  72. package/src/markets/aaveV4/index.ts +46 -20
  73. package/src/markets/index.ts +5 -1
  74. package/src/moneymarket/moneymarketCommonService.ts +10 -11
  75. package/src/types/aave.ts +3 -2
  76. package/src/types/aaveV4.ts +7 -3
  77. package/src/types/common.ts +8 -0
  78. package/src/types/compound.ts +3 -2
  79. package/src/types/curveUsd.ts +2 -2
  80. package/src/types/euler.ts +3 -2
  81. package/src/types/fluid.ts +5 -3
  82. package/src/types/index.ts +1 -0
  83. package/src/types/liquityV2.ts +5 -3
  84. package/src/types/llamaLend.ts +4 -2
  85. package/src/types/morphoBlue.ts +5 -5
  86. package/src/types/spark.ts +3 -2
@@ -130,10 +130,10 @@ export declare const _getUserPositions: (provider: PublicClient, network: Networ
130
130
  collRatio: string;
131
131
  minRatio: string;
132
132
  totalInterestUsd: string;
133
- leveragedType?: string;
133
+ leveragedType?: import("../types").LeverageType;
134
134
  leveragedAsset?: string;
135
135
  liquidationPrice?: string;
136
- leveragedLsdAssetRatio?: string;
136
+ currentVolatilePairRatio?: string;
137
137
  minCollRatio?: string;
138
138
  collLiquidationRatio?: string;
139
139
  owner: string;
@@ -161,10 +161,10 @@ export declare const getUserPositions: (provider: EthereumProvider, network: Net
161
161
  collRatio: string;
162
162
  minRatio: string;
163
163
  totalInterestUsd: string;
164
- leveragedType?: string;
164
+ leveragedType?: import("../types").LeverageType;
165
165
  leveragedAsset?: string;
166
166
  liquidationPrice?: string;
167
- leveragedLsdAssetRatio?: string;
167
+ currentVolatilePairRatio?: string;
168
168
  minCollRatio?: string;
169
169
  collLiquidationRatio?: string;
170
170
  owner: string;
@@ -192,10 +192,10 @@ export declare const _getUserPositionsPortfolio: (provider: PublicClient, networ
192
192
  collRatio: string;
193
193
  minRatio: string;
194
194
  totalInterestUsd: string;
195
- leveragedType?: string;
195
+ leveragedType?: import("../types").LeverageType;
196
196
  leveragedAsset?: string;
197
197
  liquidationPrice?: string;
198
- leveragedLsdAssetRatio?: string;
198
+ currentVolatilePairRatio?: string;
199
199
  minCollRatio?: string;
200
200
  collLiquidationRatio?: string;
201
201
  owner: string;
@@ -1,4 +1,4 @@
1
- import { AaveHelperCommon, AaveMarketInfo, AaveV3AggregatedPositionData, AaveV3AssetsData, AaveV3UsedAssets, AaveVersions } from '../../types';
1
+ import { AaveHelperCommon, AaveMarketInfo, AaveV3AggregatedPositionData, AaveV3AssetsData, AaveV3UsedAsset, 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
- }) => import("../../types").AaveV3UsedAsset[];
20
+ }) => AaveV3UsedAsset[];
21
21
  export declare const aaveAnyGetSuppliableAssets: ({ usedAssets, eModeCategory, assetsData, selectedMarket, network, ...rest }: AaveHelperCommon) => {
22
22
  symbol: string;
23
23
  canBeCollateral: boolean;
@@ -31,6 +31,7 @@ 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");
34
35
  const contracts_1 = require("../../contracts");
35
36
  const viem_1 = require("../../services/viem");
36
37
  exports.AAVE_V3_MARKETS = [types_1.AaveVersions.AaveV3, types_1.AaveVersions.AaveV3Lido, types_1.AaveVersions.AaveV3Etherfi];
@@ -103,12 +104,22 @@ const aaveAnyGetAggregatedPositionData = (_a) => {
103
104
  payload.liquidationPrice = '';
104
105
  if (leveragedType !== '') {
105
106
  let assetPrice = data.assetsData[leveragedAsset].price;
106
- if (leveragedType === 'lsd-leverage') {
107
- // Treat ETH like a stablecoin in a long stETH position
108
- payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
109
- assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
107
+ if (leveragedType === common_1.LeverageType.VolatilePair) {
108
+ const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
109
+ const borrowedAssetPrice = data.assetsData[borrowedAsset.symbol].price;
110
+ const leveragedAssetPrice = data.assetsData[leveragedAsset].price;
111
+ const isReverse = new decimal_js_1.default(leveragedAssetPrice).lt(borrowedAssetPrice);
112
+ if (isReverse) {
113
+ payload.leveragedType = common_1.LeverageType.VolatilePairReverse;
114
+ payload.currentVolatilePairRatio = new decimal_js_1.default(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
115
+ assetPrice = new decimal_js_1.default(borrowedAssetPrice).div(assetPrice).toString();
116
+ }
117
+ else {
118
+ assetPrice = new decimal_js_1.default(assetPrice).div(borrowedAssetPrice).toString();
119
+ payload.currentVolatilePairRatio = new decimal_js_1.default(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
120
+ }
110
121
  }
111
- payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
122
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
112
123
  }
113
124
  payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
114
125
  payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
@@ -1,8 +1,8 @@
1
1
  import { AaveV4AggregatedPositionData, AaveV4AssetsData, AaveV4ReserveAssetData, AaveV4UsedReserveAsset, AaveV4UsedReserveAssets } from '../../types';
2
- import { NetworkNumber } from '../../types/common';
2
+ import { LeverageType, NetworkNumber } from '../../types/common';
3
3
  export declare const aaveV4GetCollateralFactor: (assetData: AaveV4ReserveAssetData, usedAssetData: AaveV4UsedReserveAsset, useUserCollateralFactor?: boolean) => number;
4
4
  export declare const isLeveragedPosAaveV4: (usedAssets: AaveV4UsedReserveAssets, dustLimit?: number) => {
5
- leveragedType: string;
5
+ leveragedType: LeverageType;
6
6
  leveragedAsset: string;
7
7
  };
8
8
  export declare const aaveV4GetAggregatedPositionData: ({ usedAssets, assetsData, network, useUserCollateralFactor, }: {
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.aaveV4GetAggregatedPositionData = exports.isLeveragedPosAaveV4 = exports.aaveV4GetCollateralFactor = void 0;
7
7
  const decimal_js_1 = __importDefault(require("decimal.js"));
8
8
  const moneymarket_1 = require("../../moneymarket");
9
+ const common_1 = require("../../types/common");
9
10
  const aaveV4GetCollateralFactor = (assetData, usedAssetData, useUserCollateralFactor = false) => (useUserCollateralFactor ? usedAssetData.collateralFactor : assetData.collateralFactor);
10
11
  exports.aaveV4GetCollateralFactor = aaveV4GetCollateralFactor;
11
12
  const isLeveragedPosAaveV4 = (usedAssets, dustLimit = 5) => {
@@ -34,34 +35,32 @@ const isLeveragedPosAaveV4 = (usedAssets, dustLimit = 5) => {
34
35
  });
35
36
  const isLong = borrowStable > 0 && borrowUnstable === 0 && supplyUnstable === 1 && supplyStable === 0;
36
37
  const isShort = supplyStable > 0 && supplyUnstable === 0 && borrowUnstable === 1 && borrowStable === 0;
37
- // lsd -> liquid staking derivative
38
- const isLsdLeveraged = supplyUnstable === 1 && borrowUnstable === 1 && shortAsset === 'ETH' && ['stETH', 'wstETH', 'cbETH', 'rETH', 'ezETH', 'weETH'].includes(longAsset);
38
+ const isVolatilePair = supplyUnstable === 1 && borrowUnstable === 1 && supplyStable === 0 && borrowStable === 0;
39
39
  if (isLong) {
40
40
  return {
41
- leveragedType: 'long',
41
+ leveragedType: common_1.LeverageType.Long,
42
42
  leveragedAsset: longAsset,
43
43
  };
44
44
  }
45
45
  if (isShort) {
46
46
  return {
47
- leveragedType: 'short',
47
+ leveragedType: common_1.LeverageType.Short,
48
48
  leveragedAsset: shortAsset,
49
49
  };
50
50
  }
51
- if (isLsdLeveraged) {
51
+ if (isVolatilePair) {
52
52
  return {
53
- leveragedType: 'lsd-leverage',
53
+ leveragedType: common_1.LeverageType.VolatilePair,
54
54
  leveragedAsset: longAsset,
55
55
  };
56
56
  }
57
57
  return {
58
- leveragedType: '',
58
+ leveragedType: common_1.LeverageType.None,
59
59
  leveragedAsset: '',
60
60
  };
61
61
  };
62
62
  exports.isLeveragedPosAaveV4 = isLeveragedPosAaveV4;
63
63
  const aaveV4GetAggregatedPositionData = ({ usedAssets, assetsData, network, useUserCollateralFactor = false, }) => {
64
- var _a;
65
64
  const payload = {};
66
65
  payload.suppliedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied }) => isSupplied, ({ suppliedUsd }) => suppliedUsd);
67
66
  payload.suppliedCollateralUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied, collateral }) => isSupplied && collateral, ({ suppliedUsd }) => suppliedUsd);
@@ -83,13 +82,22 @@ const aaveV4GetAggregatedPositionData = ({ usedAssets, assetsData, network, useU
83
82
  if (leveragedType !== '') {
84
83
  const leveragedAssetData = assetsData[leveragedAsset];
85
84
  let assetPrice = (leveragedAssetData === null || leveragedAssetData === void 0 ? void 0 : leveragedAssetData.price) || '0';
86
- if (leveragedType === 'lsd-leverage') {
87
- // Treat ETH like a stablecoin in a long stETH position
88
- const ethPrice = ((_a = Object.values(assetsData).find((asset) => asset.symbol === 'ETH')) === null || _a === void 0 ? void 0 : _a.price) || '0';
89
- payload.leveragedLsdAssetRatio = new decimal_js_1.default((leveragedAssetData === null || leveragedAssetData === void 0 ? void 0 : leveragedAssetData.price) || '0').div(ethPrice).toDP(18).toString();
90
- assetPrice = new decimal_js_1.default(assetPrice).div(ethPrice).toString();
85
+ if (leveragedType === common_1.LeverageType.VolatilePair) {
86
+ const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
87
+ const borrowedAssetPrice = assetsData[`${borrowedAsset.symbol}-${borrowedAsset.reserveId}`].price;
88
+ const leveragedAssetPrice = assetsData[leveragedAsset].price;
89
+ const isReverse = new decimal_js_1.default(leveragedAssetPrice).lt(borrowedAssetPrice);
90
+ if (isReverse) {
91
+ payload.leveragedType = common_1.LeverageType.VolatilePairReverse;
92
+ payload.currentVolatilePairRatio = new decimal_js_1.default(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
93
+ assetPrice = new decimal_js_1.default(borrowedAssetPrice).div(assetPrice).toString();
94
+ }
95
+ else {
96
+ assetPrice = new decimal_js_1.default(assetPrice).div(borrowedAssetPrice).toString();
97
+ payload.currentVolatilePairRatio = new decimal_js_1.default(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
98
+ }
91
99
  }
92
- payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
100
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
93
101
  }
94
102
  payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
95
103
  payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
@@ -150,28 +150,25 @@ const getCompoundV3AggregatedData = (_a) => {
150
150
  if (leveragedType !== '') {
151
151
  payload.leveragedAsset = leveragedAsset;
152
152
  let assetPrice = assetsData[leveragedAsset].price;
153
- if (leveragedType === 'lsd-leverage') {
154
- payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toString();
155
- assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
153
+ if (leveragedType === common_1.LeverageType.VolatilePair) {
154
+ const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
155
+ const borrowedAssetPrice = assetsData[borrowedAsset.symbol].price;
156
+ const leveragedAssetPrice = assetsData[leveragedAsset].price;
157
+ const isReverse = new decimal_js_1.default(leveragedAssetPrice).lt(borrowedAssetPrice);
158
+ if (isReverse) {
159
+ payload.leveragedType = common_1.LeverageType.VolatilePairReverse;
160
+ payload.currentVolatilePairRatio = new decimal_js_1.default(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
161
+ assetPrice = new decimal_js_1.default(borrowedAssetPrice).div(assetPrice).toString();
162
+ }
163
+ else {
164
+ assetPrice = new decimal_js_1.default(assetPrice).div(borrowedAssetPrice).toString();
165
+ payload.currentVolatilePairRatio = new decimal_js_1.default(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
166
+ }
156
167
  }
157
- payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
168
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
158
169
  }
159
170
  payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
160
171
  payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
161
- // TO DO: handle strategies
162
- /* const subscribedStrategies = rest.compoundStrategies
163
- ? compoundV3GetSubscribedStrategies({ selectedMarket, compoundStrategies: rest.compoundStrategies })
164
- : []; */
165
- // TODO possibly move to global helper, since every protocol has the same graphData?
166
- // payload.ratioTooLow = false;
167
- // payload.ratioTooHigh = false;
168
- // TO DO: handle strategies
169
- /* if (subscribedStrategies.length) {
170
- subscribedStrategies.forEach(({ graphData }) => {
171
- payload.ratioTooLow = parseFloat(payload.ratio) < parseFloat(graphData.minRatio);
172
- payload.ratioTooHigh = graphData.boostEnabled && parseFloat(payload.ratio) > parseFloat(graphData.maxRatio);
173
- });
174
- } */
175
172
  return payload;
176
173
  };
177
174
  exports.getCompoundV3AggregatedData = getCompoundV3AggregatedData;
@@ -1,7 +1,7 @@
1
- import { EthAddress, EthereumProvider, NetworkNumber } from '../../types/common';
1
+ import { EthAddress, EthereumProvider, LeverageType, NetworkNumber } from '../../types/common';
2
2
  import { EulerV2AggregatedPositionData, EulerV2AssetsData, EulerV2UsedAssets } from '../../types';
3
3
  export declare const isLeveragedPos: (usedAssets: EulerV2UsedAssets, dustLimit?: number) => {
4
- leveragedType: string;
4
+ leveragedType: LeverageType;
5
5
  leveragedAsset: string;
6
6
  leveragedVault: string;
7
7
  };
@@ -26,6 +26,7 @@ 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");
29
30
  const moneymarket_1 = require("../../moneymarket");
30
31
  const staking_1 = require("../../staking");
31
32
  const contracts_1 = require("../../contracts");
@@ -59,31 +60,30 @@ const isLeveragedPos = (usedAssets, dustLimit = 5) => {
59
60
  });
60
61
  const isLong = borrowStable > 0 && borrowUnstable === 0 && supplyUnstable === 1 && supplyStable === 0;
61
62
  const isShort = supplyStable > 0 && supplyUnstable === 0 && borrowUnstable === 1 && borrowStable === 0;
62
- // lsd -> liquid staking derivative
63
- const isLsdLeveraged = supplyUnstable === 1 && borrowUnstable === 1 && shortAsset === 'ETH' && ['stETH', 'wstETH', 'cbETH', 'rETH'].includes(longAsset);
63
+ const isVolatilePair = supplyUnstable === 1 && borrowUnstable === 1 && supplyStable === 0 && borrowStable === 0;
64
64
  if (isLong) {
65
65
  return {
66
- leveragedType: 'long',
66
+ leveragedType: common_1.LeverageType.Long,
67
67
  leveragedAsset: longAsset,
68
68
  leveragedVault: leverageAssetVault,
69
69
  };
70
70
  }
71
71
  if (isShort) {
72
72
  return {
73
- leveragedType: 'short',
73
+ leveragedType: common_1.LeverageType.Short,
74
74
  leveragedAsset: shortAsset,
75
75
  leveragedVault: leverageAssetVault,
76
76
  };
77
77
  }
78
- if (isLsdLeveraged) {
78
+ if (isVolatilePair) {
79
79
  return {
80
- leveragedType: 'lsd-leverage',
80
+ leveragedType: common_1.LeverageType.VolatilePair,
81
81
  leveragedAsset: longAsset,
82
82
  leveragedVault: leverageAssetVault,
83
83
  };
84
84
  }
85
85
  return {
86
- leveragedType: '',
86
+ leveragedType: common_1.LeverageType.None,
87
87
  leveragedAsset: '',
88
88
  leveragedVault: '',
89
89
  };
@@ -113,14 +113,22 @@ const getEulerV2AggregatedData = (_a) => {
113
113
  if (leveragedType !== '') {
114
114
  payload.leveragedAsset = leveragedAsset;
115
115
  let assetPrice = assetsData[leveragedVault.toLowerCase()].price;
116
- if (leveragedType === 'lsd-leverage') {
117
- const ethAsset = Object.values(assetsData).find((asset) => ['WETH', 'ETH'].includes(asset.symbol));
118
- if (ethAsset) {
119
- payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedVault.toLowerCase()].price).div(ethAsset.price).toString();
120
- assetPrice = new decimal_js_1.default(assetPrice).div(ethAsset.price).toString();
116
+ if (leveragedType === common_1.LeverageType.VolatilePair) {
117
+ const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
118
+ const borrowedAssetPrice = assetsData[borrowedAsset.vaultAddress.toLowerCase()].price;
119
+ const leveragedAssetPrice = assetsData[leveragedVault.toLowerCase()].price;
120
+ const isReverse = new decimal_js_1.default(leveragedAssetPrice).lt(borrowedAssetPrice);
121
+ if (isReverse) {
122
+ payload.leveragedType = common_1.LeverageType.VolatilePairReverse;
123
+ payload.currentVolatilePairRatio = new decimal_js_1.default(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
124
+ assetPrice = new decimal_js_1.default(borrowedAssetPrice).div(assetPrice).toString();
125
+ }
126
+ else {
127
+ assetPrice = new decimal_js_1.default(assetPrice).div(borrowedAssetPrice).toString();
128
+ payload.currentVolatilePairRatio = new decimal_js_1.default(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
121
129
  }
122
130
  }
123
- payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
131
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
124
132
  }
125
133
  payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
126
134
  payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
@@ -9,6 +9,7 @@ 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");
12
13
  const utils_1 = require("../../services/utils");
13
14
  const calculateNetApyDex = ({ marketData, suppliedUsd, borrowedUsd }) => {
14
15
  const { borrowRate, supplyRate, incentiveBorrowRate, incentiveSupplyRate, tradingBorrowRate, tradingSupplyRate, } = marketData;
@@ -55,12 +56,22 @@ const getFluidAggregatedData = ({ usedAssets, assetsData, marketData, }, supplyS
55
56
  if (leveragedType !== '') {
56
57
  payload.leveragedAsset = leveragedAsset;
57
58
  let assetPrice = assetsData[leveragedAsset].price;
58
- if (leveragedType === 'lsd-leverage') {
59
- // Treat ETH like a stablecoin in a long stETH position
60
- payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
61
- assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
59
+ if (leveragedType === common_1.LeverageType.VolatilePair) {
60
+ const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
61
+ const borrowedAssetPrice = assetsData[borrowedAsset.symbol].price;
62
+ const leveragedAssetPrice = assetsData[leveragedAsset].price;
63
+ const isReverse = new decimal_js_1.default(leveragedAssetPrice).lt(borrowedAssetPrice);
64
+ if (isReverse) {
65
+ payload.leveragedType = common_1.LeverageType.VolatilePairReverse;
66
+ payload.currentVolatilePairRatio = new decimal_js_1.default(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
67
+ assetPrice = new decimal_js_1.default(borrowedAssetPrice).div(assetPrice).toString();
68
+ }
69
+ else {
70
+ assetPrice = new decimal_js_1.default(assetPrice).div(borrowedAssetPrice).toString();
71
+ payload.currentVolatilePairRatio = new decimal_js_1.default(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
72
+ }
62
73
  }
63
- payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
74
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
64
75
  }
65
76
  payload.minCollRatio = new decimal_js_1.default(payload.suppliedUsd).div(payload.borrowLimitUsd).mul(100).toString();
66
77
  payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedUsd).div(payload.liquidationLimitUsd).mul(100).toString();
@@ -51,12 +51,22 @@ const getMorphoBlueAggregatedPositionData = ({ usedAssets, assetsData, marketInf
51
51
  if (leveragedType !== '') {
52
52
  payload.leveragedAsset = leveragedAsset;
53
53
  let assetPrice = assetsData[leveragedAsset].price;
54
- if (leveragedType === 'lsd-leverage') {
55
- // Treat ETH like a stablecoin in a long stETH position
56
- payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
57
- assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
54
+ if (leveragedType === common_1.LeverageType.VolatilePair) {
55
+ const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
56
+ const borrowedAssetPrice = assetsData[borrowedAsset.symbol].price;
57
+ const leveragedAssetPrice = assetsData[leveragedAsset].price;
58
+ const isReverse = new decimal_js_1.default(leveragedAssetPrice).lt(borrowedAssetPrice);
59
+ if (isReverse) {
60
+ payload.leveragedType = common_1.LeverageType.VolatilePairReverse;
61
+ payload.currentVolatilePairRatio = new decimal_js_1.default(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
62
+ assetPrice = new decimal_js_1.default(borrowedAssetPrice).div(assetPrice).toString();
63
+ }
64
+ else {
65
+ assetPrice = new decimal_js_1.default(assetPrice).div(borrowedAssetPrice).toString();
66
+ payload.currentVolatilePairRatio = new decimal_js_1.default(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
67
+ }
58
68
  }
59
- payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
69
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
60
70
  }
61
71
  payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
62
72
  payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
@@ -1,4 +1,4 @@
1
- import { SparkAggregatedPositionData, SparkAssetsData, SparkHelperCommon, SparkMarketData, SparkUsedAssets } from '../../types';
1
+ import { SparkAggregatedPositionData, SparkAssetsData, SparkHelperCommon, SparkMarketData, SparkUsedAsset, SparkUsedAssets } from '../../types';
2
2
  import { EthereumProvider } from '../../types/common';
3
3
  export declare const sparkIsInIsolationMode: ({ usedAssets, assetsData }: {
4
4
  usedAssets: SparkUsedAssets;
@@ -6,7 +6,7 @@ export declare const sparkIsInIsolationMode: ({ usedAssets, assetsData }: {
6
6
  }) => boolean;
7
7
  export declare const sparkGetCollSuppliedAssets: ({ usedAssets }: {
8
8
  usedAssets: SparkUsedAssets;
9
- }) => import("../../types").SparkUsedAsset[];
9
+ }) => SparkUsedAsset[];
10
10
  export declare const sparkGetSuppliableAssets: ({ usedAssets, eModeCategory, assetsData, selectedMarket, network, ...rest }: SparkHelperCommon) => {
11
11
  symbol: string;
12
12
  canBeCollateral: boolean;
@@ -92,12 +92,22 @@ 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 === 'lsd-leverage') {
96
- // Treat ETH like a stablecoin in a long stETH position
97
- payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
98
- assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
95
+ if (leveragedType === common_1.LeverageType.VolatilePair) {
96
+ const borrowedAsset = Object.values(usedAssets).find(({ borrowedUsd }) => +borrowedUsd > 0);
97
+ const borrowedAssetPrice = data.assetsData[borrowedAsset.symbol].price;
98
+ const leveragedAssetPrice = data.assetsData[leveragedAsset].price;
99
+ const isReverse = new decimal_js_1.default(leveragedAssetPrice).lt(borrowedAssetPrice);
100
+ if (isReverse) {
101
+ payload.leveragedType = common_1.LeverageType.VolatilePairReverse;
102
+ payload.currentVolatilePairRatio = new decimal_js_1.default(borrowedAssetPrice).div(leveragedAssetPrice).toDP(18).toString();
103
+ assetPrice = new decimal_js_1.default(borrowedAssetPrice).div(assetPrice).toString();
104
+ }
105
+ else {
106
+ assetPrice = new decimal_js_1.default(assetPrice).div(borrowedAssetPrice).toString();
107
+ payload.currentVolatilePairRatio = new decimal_js_1.default(leveragedAssetPrice).div(borrowedAssetPrice).toDP(18).toString();
108
+ }
99
109
  }
100
- payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
110
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(payload.leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
101
111
  }
102
112
  payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
103
113
  payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
@@ -1,13 +1,16 @@
1
- import { AaveV4HubInfo, AaveV4HubsType, AaveV4SpokeInfo, AaveV4SpokesType } from '../../types';
2
- import { NetworkNumber } from '../../types/common';
3
- export declare const AAVE_V4_CORE_SPOKE: (networkId: NetworkNumber) => AaveV4SpokeInfo;
4
- export declare const AaveV4Spokes: (networkId: NetworkNumber) => {
5
- readonly aave_v4_core_spoke: AaveV4SpokeInfo;
6
- };
7
- export declare const getAaveV4SpokeTypeInfo: (type: AaveV4SpokesType, network?: NetworkNumber) => AaveV4SpokeInfo;
1
+ import { AaveV4HubInfo, AaveV4HubsType, AaveV4SpokeInfo, AaveV4SpokesType, NetworkNumber } from '../../types';
8
2
  export declare const AAVE_V4_CORE_HUB: (networkId: NetworkNumber) => AaveV4HubInfo;
3
+ export declare const AAVE_V4_YIELD_SEEKING_HUB: (networkId: NetworkNumber) => AaveV4HubInfo;
9
4
  export declare const AaveV4Hubs: (networkId: NetworkNumber) => {
10
5
  readonly aave_v4_core_hub: AaveV4HubInfo;
6
+ readonly aave_v4_yield_seeking_hub: AaveV4HubInfo;
11
7
  };
12
8
  export declare const getAaveV4HubTypeInfo: (type: AaveV4HubsType, network?: NetworkNumber) => AaveV4HubInfo;
13
9
  export declare const getAaveV4HubByAddress: (networkId: NetworkNumber, address: string) => AaveV4HubInfo | undefined;
10
+ export declare const AAVE_V4_CORE_SPOKE: (networkId: NetworkNumber) => AaveV4SpokeInfo;
11
+ export declare const AAVE_V4_YIELD_SEEKING_SPOKE: (networkId: NetworkNumber) => AaveV4SpokeInfo;
12
+ export declare const AaveV4Spokes: (networkId: NetworkNumber) => {
13
+ readonly aave_v4_core_spoke: AaveV4SpokeInfo;
14
+ readonly aave_v4_yield_seeking_spoke: AaveV4SpokeInfo;
15
+ };
16
+ export declare const getAaveV4SpokeTypeInfo: (type: AaveV4SpokesType, network?: NetworkNumber) => AaveV4SpokeInfo;
@@ -1,39 +1,59 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getAaveV4HubByAddress = exports.getAaveV4HubTypeInfo = exports.AaveV4Hubs = exports.AAVE_V4_CORE_HUB = exports.getAaveV4SpokeTypeInfo = exports.AaveV4Spokes = exports.AAVE_V4_CORE_SPOKE = void 0;
3
+ exports.getAaveV4SpokeTypeInfo = exports.AaveV4Spokes = exports.AAVE_V4_YIELD_SEEKING_SPOKE = exports.AAVE_V4_CORE_SPOKE = exports.getAaveV4HubByAddress = exports.getAaveV4HubTypeInfo = exports.AaveV4Hubs = exports.AAVE_V4_YIELD_SEEKING_HUB = exports.AAVE_V4_CORE_HUB = void 0;
4
4
  const types_1 = require("../../types");
5
- const common_1 = require("../../types/common");
5
+ // HUBS
6
+ const AAVE_V4_CORE_HUB = (networkId) => ({
7
+ chainIds: [types_1.NetworkNumber.Eth],
8
+ label: 'Core Hub',
9
+ value: types_1.AaveV4HubsType.AaveV4CoreHub,
10
+ address: '0xaD905aD5EA5B98cD50AE40Cfe368344686a21366',
11
+ });
12
+ exports.AAVE_V4_CORE_HUB = AAVE_V4_CORE_HUB;
13
+ const AAVE_V4_YIELD_SEEKING_HUB = (networkId) => ({
14
+ chainIds: [types_1.NetworkNumber.Eth],
15
+ label: 'Yield Seeking Hub',
16
+ value: types_1.AaveV4HubsType.AaveV4YieldSeekingHub,
17
+ address: '0x86F37ba3b480c5fE22A7eb1ba2B2D49c94089FBB',
18
+ });
19
+ exports.AAVE_V4_YIELD_SEEKING_HUB = AAVE_V4_YIELD_SEEKING_HUB;
20
+ const AaveV4Hubs = (networkId) => ({
21
+ [types_1.AaveV4HubsType.AaveV4CoreHub]: (0, exports.AAVE_V4_CORE_HUB)(networkId),
22
+ [types_1.AaveV4HubsType.AaveV4YieldSeekingHub]: (0, exports.AAVE_V4_YIELD_SEEKING_HUB)(networkId),
23
+ });
24
+ exports.AaveV4Hubs = AaveV4Hubs;
25
+ const getAaveV4HubTypeInfo = (type, network) => (Object.assign({}, (0, exports.AaveV4Hubs)(network !== null && network !== void 0 ? network : types_1.NetworkNumber.Eth))[type]);
26
+ exports.getAaveV4HubTypeInfo = getAaveV4HubTypeInfo;
27
+ const getAaveV4HubByAddress = (networkId, address) => Object.values((0, exports.AaveV4Hubs)(networkId)).find(hub => hub.address.toLowerCase() === address.toLowerCase());
28
+ exports.getAaveV4HubByAddress = getAaveV4HubByAddress;
6
29
  // SPOKES
7
30
  const AAVE_V4_CORE_SPOKE = (networkId) => ({
8
- chainIds: [common_1.NetworkNumber.Eth],
31
+ chainIds: [types_1.NetworkNumber.Eth],
9
32
  label: 'Core Spoke',
10
33
  value: types_1.AaveV4SpokesType.AaveV4CoreSpoke,
11
34
  url: 'core',
12
35
  address: '0xBa97c5E52cd5BC3D7950Ae70779F8FfE92d40CdC',
13
36
  hubs: [
14
- '0xaD905aD5EA5B98cD50AE40Cfe368344686a21366',
37
+ (0, exports.AAVE_V4_CORE_HUB)(types_1.NetworkNumber.Eth).address,
15
38
  ],
16
39
  });
17
40
  exports.AAVE_V4_CORE_SPOKE = AAVE_V4_CORE_SPOKE;
41
+ const AAVE_V4_YIELD_SEEKING_SPOKE = (networkId) => ({
42
+ chainIds: [types_1.NetworkNumber.Eth],
43
+ label: 'Yield Seeking Spoke',
44
+ value: types_1.AaveV4SpokesType.AaveV4YieldSeekingSpoke,
45
+ url: 'yield-seeking',
46
+ address: '0x2559e4e04f2ca7180e5f20c2872d22ec89601b56',
47
+ hubs: [
48
+ (0, exports.AAVE_V4_CORE_HUB)(types_1.NetworkNumber.Eth).address,
49
+ (0, exports.AAVE_V4_YIELD_SEEKING_HUB)(types_1.NetworkNumber.Eth).address,
50
+ ],
51
+ });
52
+ exports.AAVE_V4_YIELD_SEEKING_SPOKE = AAVE_V4_YIELD_SEEKING_SPOKE;
18
53
  const AaveV4Spokes = (networkId) => ({
19
54
  [types_1.AaveV4SpokesType.AaveV4CoreSpoke]: (0, exports.AAVE_V4_CORE_SPOKE)(networkId),
55
+ [types_1.AaveV4SpokesType.AaveV4YieldSeekingSpoke]: (0, exports.AAVE_V4_YIELD_SEEKING_SPOKE)(networkId),
20
56
  });
21
57
  exports.AaveV4Spokes = AaveV4Spokes;
22
- const getAaveV4SpokeTypeInfo = (type, network) => (Object.assign({}, (0, exports.AaveV4Spokes)(network !== null && network !== void 0 ? network : common_1.NetworkNumber.Eth))[type]);
58
+ const getAaveV4SpokeTypeInfo = (type, network) => (Object.assign({}, (0, exports.AaveV4Spokes)(network !== null && network !== void 0 ? network : types_1.NetworkNumber.Eth))[type]);
23
59
  exports.getAaveV4SpokeTypeInfo = getAaveV4SpokeTypeInfo;
24
- // HUBS
25
- const AAVE_V4_CORE_HUB = (networkId) => ({
26
- chainIds: [common_1.NetworkNumber.Eth],
27
- label: 'Core Hub',
28
- value: types_1.AaveV4HubsType.AaveV4CoreHub,
29
- address: '0xaD905aD5EA5B98cD50AE40Cfe368344686a21366',
30
- });
31
- exports.AAVE_V4_CORE_HUB = AAVE_V4_CORE_HUB;
32
- const AaveV4Hubs = (networkId) => ({
33
- [types_1.AaveV4HubsType.AaveV4CoreHub]: (0, exports.AAVE_V4_CORE_HUB)(networkId),
34
- });
35
- exports.AaveV4Hubs = AaveV4Hubs;
36
- const getAaveV4HubTypeInfo = (type, network) => (Object.assign({}, (0, exports.AaveV4Hubs)(network !== null && network !== void 0 ? network : common_1.NetworkNumber.Eth))[type]);
37
- exports.getAaveV4HubTypeInfo = getAaveV4HubTypeInfo;
38
- const getAaveV4HubByAddress = (networkId, address) => Object.values((0, exports.AaveV4Hubs)(networkId)).find(hub => hub.address.toLowerCase() === address.toLowerCase());
39
- exports.getAaveV4HubByAddress = getAaveV4HubByAddress;
@@ -1,12 +1,12 @@
1
- import { MMUsedAssets } from '../types/common';
1
+ import { LeverageType, 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: string, assetPrice: string, borrowedUsd: string, borrowLimitUsd: string) => string;
5
+ export declare const calcLeverageLiqPrice: (leverageType: LeverageType, 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: string;
9
+ leveragedType: LeverageType;
10
10
  leveragedAsset: string;
11
11
  };
12
12
  export declare const aprToApy: (interest: string | number, frequency?: number) => string;
@@ -6,6 +6,7 @@ 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");
9
10
  const getAssetsTotal = (assets, filter, transform) => Object.values(assets)
10
11
  .filter(filter)
11
12
  .map(transform)
@@ -17,9 +18,9 @@ exports.calcLongLiqPrice = calcLongLiqPrice;
17
18
  const calcShortLiqPrice = (assetPrice, borrowedUsd, borrowLimitUsd) => new decimal_js_1.default(assetPrice).div(borrowedUsd).mul(borrowLimitUsd).toString();
18
19
  exports.calcShortLiqPrice = calcShortLiqPrice;
19
20
  const calcLeverageLiqPrice = (leverageType, assetPrice, borrowedUsd, borrowLimitUsd) => {
20
- if (leverageType === 'short')
21
+ if (leverageType === common_1.LeverageType.Short || leverageType === common_1.LeverageType.VolatilePairReverse)
21
22
  return (0, exports.calcShortLiqPrice)(assetPrice, borrowedUsd, borrowLimitUsd);
22
- if (leverageType === 'long' || leverageType === 'lsd-leverage')
23
+ if (leverageType === common_1.LeverageType.Long || leverageType === common_1.LeverageType.VolatilePair)
23
24
  return (0, exports.calcLongLiqPrice)(assetPrice, borrowedUsd, borrowLimitUsd);
24
25
  console.error('invalid leverageType', leverageType);
25
26
  return '0';
@@ -58,28 +59,27 @@ const isLeveragedPos = (usedAssets, dustLimit = 5) => {
58
59
  });
59
60
  const isLong = borrowStable > 0 && borrowUnstable === 0 && supplyUnstable === 1 && supplyStable === 0;
60
61
  const isShort = supplyStable > 0 && supplyUnstable === 0 && borrowUnstable === 1 && borrowStable === 0;
61
- // lsd -> liquid staking derivative
62
- const isLsdLeveraged = supplyUnstable === 1 && borrowUnstable === 1 && shortAsset === 'ETH' && ['stETH', 'wstETH', 'cbETH', 'rETH', 'ezETH', 'weETH'].includes(longAsset);
62
+ const isVolatilePair = supplyUnstable === 1 && borrowUnstable === 1 && supplyStable === 0 && borrowStable === 0;
63
63
  if (isLong) {
64
64
  return {
65
- leveragedType: 'long',
65
+ leveragedType: common_1.LeverageType.Long,
66
66
  leveragedAsset: longAsset,
67
67
  };
68
68
  }
69
69
  if (isShort) {
70
70
  return {
71
- leveragedType: 'short',
71
+ leveragedType: common_1.LeverageType.Short,
72
72
  leveragedAsset: shortAsset,
73
73
  };
74
74
  }
75
- if (isLsdLeveraged) {
75
+ if (isVolatilePair) {
76
76
  return {
77
- leveragedType: 'lsd-leverage',
77
+ leveragedType: common_1.LeverageType.VolatilePair,
78
78
  leveragedAsset: longAsset,
79
79
  };
80
80
  }
81
81
  return {
82
- leveragedType: '',
82
+ leveragedType: common_1.LeverageType.None,
83
83
  leveragedAsset: '',
84
84
  };
85
85
  };