@defisaver/positions-sdk 0.0.88 → 0.0.90

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 (73) hide show
  1. package/README.md +63 -63
  2. package/cjs/compoundV3/index.js +3 -11
  3. package/cjs/markets/morphoBlue/index.d.ts +7 -1
  4. package/cjs/markets/morphoBlue/index.js +54 -2
  5. package/cjs/morphoAaveV3/index.js +3 -11
  6. package/cjs/spark/index.js +3 -11
  7. package/cjs/types/morphoBlue.d.ts +5 -2
  8. package/cjs/types/morphoBlue.js +4 -1
  9. package/esm/compoundV3/index.js +4 -12
  10. package/esm/markets/morphoBlue/index.d.ts +7 -1
  11. package/esm/markets/morphoBlue/index.js +50 -1
  12. package/esm/morphoAaveV3/index.js +5 -13
  13. package/esm/spark/index.js +5 -13
  14. package/esm/types/morphoBlue.d.ts +5 -2
  15. package/esm/types/morphoBlue.js +4 -1
  16. package/package.json +40 -40
  17. package/src/aaveV2/index.ts +227 -227
  18. package/src/aaveV3/index.ts +558 -558
  19. package/src/assets/index.ts +60 -60
  20. package/src/chickenBonds/index.ts +123 -123
  21. package/src/compoundV2/index.ts +219 -219
  22. package/src/compoundV3/index.ts +266 -274
  23. package/src/config/contracts.js +848 -848
  24. package/src/constants/index.ts +5 -5
  25. package/src/contracts.ts +128 -128
  26. package/src/curveUsd/index.ts +229 -229
  27. package/src/exchange/index.ts +17 -17
  28. package/src/helpers/aaveHelpers/index.ts +134 -134
  29. package/src/helpers/chickenBondsHelpers/index.ts +23 -23
  30. package/src/helpers/compoundHelpers/index.ts +181 -181
  31. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  32. package/src/helpers/index.ts +7 -7
  33. package/src/helpers/llamaLendHelpers/index.ts +45 -45
  34. package/src/helpers/makerHelpers/index.ts +94 -94
  35. package/src/helpers/morphoBlueHelpers/index.ts +56 -56
  36. package/src/helpers/sparkHelpers/index.ts +106 -106
  37. package/src/index.ts +46 -46
  38. package/src/liquity/index.ts +116 -116
  39. package/src/llamaLend/index.ts +268 -268
  40. package/src/maker/index.ts +117 -117
  41. package/src/markets/aave/index.ts +80 -80
  42. package/src/markets/aave/marketAssets.ts +25 -25
  43. package/src/markets/compound/index.ts +142 -142
  44. package/src/markets/compound/marketsAssets.ts +50 -50
  45. package/src/markets/curveUsd/index.ts +69 -69
  46. package/src/markets/index.ts +5 -5
  47. package/src/markets/llamaLend/contractAddresses.ts +95 -95
  48. package/src/markets/llamaLend/index.ts +150 -150
  49. package/src/markets/morphoBlue/index.ts +611 -561
  50. package/src/markets/spark/index.ts +29 -29
  51. package/src/markets/spark/marketAssets.ts +10 -10
  52. package/src/moneymarket/moneymarketCommonService.ts +76 -76
  53. package/src/morphoAaveV2/index.ts +256 -256
  54. package/src/morphoAaveV3/index.ts +612 -620
  55. package/src/morphoBlue/index.ts +162 -162
  56. package/src/multicall/index.ts +22 -22
  57. package/src/services/dsrService.ts +15 -15
  58. package/src/services/priceService.ts +21 -21
  59. package/src/services/utils.ts +51 -51
  60. package/src/setup.ts +8 -8
  61. package/src/spark/index.ts +424 -434
  62. package/src/staking/staking.ts +186 -186
  63. package/src/types/aave.ts +256 -256
  64. package/src/types/chickenBonds.ts +45 -45
  65. package/src/types/common.ts +84 -84
  66. package/src/types/compound.ts +128 -128
  67. package/src/types/curveUsd.ts +118 -118
  68. package/src/types/index.ts +8 -8
  69. package/src/types/liquity.ts +30 -30
  70. package/src/types/llamaLend.ts +143 -143
  71. package/src/types/maker.ts +50 -50
  72. package/src/types/morphoBlue.ts +139 -136
  73. package/src/types/spark.ts +106 -106
@@ -1,182 +1,182 @@
1
- import Dec from 'decimal.js';
2
- import { getAssetInfoByAddress } from '@defisaver/tokens';
3
- import {
4
- BaseAdditionalAssetData, CompoundAggregatedPositionData, CompoundMarketData, CompoundV2AssetsData, CompoundV2UsedAssets, CompoundV3AssetData, CompoundV3AssetsData, CompoundV3UsedAssets, CompoundVersions,
5
- } from '../../types';
6
- import { getEthAmountForDecimals, handleWbtcLegacy, wethToEth } from '../../services/utils';
7
- import { SECONDS_PER_YEAR } from '../../constants';
8
- import {
9
- aprToApy, calcLeverageLiqPrice, calculateBorrowingAssetLimit, getAssetsTotal, isLeveragedPos,
10
- } from '../../moneymarket';
11
- import { calculateNetApy } from '../../staking';
12
- import { NetworkNumber } from '../../types/common';
13
-
14
- export const formatMarketData = (data: any, network: NetworkNumber, baseAssetPrice: string): CompoundV3AssetData => {
15
- const assetInfo = getAssetInfoByAddress(data.tokenAddr, network);
16
- const isWETH = assetInfo.symbol === 'WETH';
17
- const price = getEthAmountForDecimals(data.price, 8);
18
- return ({
19
- ...data,
20
- priceInBaseAsset: getEthAmountForDecimals(data.price, 8),
21
- price: new Dec(price).mul(baseAssetPrice).toString(),
22
- collateralFactor: getEthAmountForDecimals(data.borrowCollateralFactor, 18),
23
- liquidationRatio: getEthAmountForDecimals(data.liquidateCollateralFactor, 18),
24
- supplyCap: getEthAmountForDecimals(data.supplyCap, assetInfo.decimals),
25
- totalSupply: getEthAmountForDecimals(data.totalSupply, assetInfo.decimals),
26
- symbol: isWETH ? 'ETH' : assetInfo.symbol,
27
- supplyRate: '0',
28
- borrowRate: '0',
29
- canBeBorrowed: false,
30
- canBeSupplied: true,
31
- });
32
- };
33
-
34
- // TODO: maybe not hardcode decimals
35
- export const formatBaseData = (data: any, network: NetworkNumber, baseAssetPrice: string): CompoundV3AssetData & BaseAdditionalAssetData => {
36
- const assetInfo = getAssetInfoByAddress(data.tokenAddr, network);
37
- const totalSupply = getEthAmountForDecimals(new Dec(data.totalSupply).mul(data.supplyIndex).toString(), 15 + assetInfo.decimals);
38
- const totalBorrow = getEthAmountForDecimals(new Dec(data.totalBorrow).mul(data.borrowIndex).toString(), 15 + assetInfo.decimals);
39
- return ({
40
- ...data,
41
- supplyRate: aprToApy(new Dec(data.supplyRate).div(1e18).mul(SECONDS_PER_YEAR).mul(100)
42
- .toString()),
43
- borrowRate: aprToApy(new Dec(data.borrowRate).div(1e18).mul(SECONDS_PER_YEAR).mul(100)
44
- .toString()),
45
- utilization: getEthAmountForDecimals(data.utilization, 16), // utilization is totalSupply/totalBorrow in 1e18, but we need % so when we mul with 100 it's 16 decimals
46
- totalSupply,
47
- totalBorrow,
48
- marketLiquidity: new Dec(totalSupply).minus(totalBorrow).toString(),
49
- symbol: wethToEth(assetInfo.symbol),
50
- priceInBaseAsset: getEthAmountForDecimals(data.price, 8),
51
- price: baseAssetPrice,
52
- collateralFactor: '0',
53
- liquidationRatio: '0',
54
- canBeBorrowed: true,
55
- canBeSupplied: true,
56
- supplyCap: '0',
57
- rewardSupplySpeed: getEthAmountForDecimals(data.baseTrackingSupplyRewardsSpeed, 15),
58
- rewardBorrowSpeed: getEthAmountForDecimals(data.baseTrackingBorrowRewardsSpeed, 15),
59
- minDebt: getEthAmountForDecimals(data.baseBorrowMin, assetInfo.decimals),
60
- isBase: true,
61
- });
62
- };
63
-
64
- export const getIncentiveApys = (
65
- baseData: CompoundV3AssetData & BaseAdditionalAssetData,
66
- compPrice: string,
67
- ): {
68
- incentiveSupplyApy: string,
69
- incentiveBorrowApy: string,
70
- incentiveSupplyToken: string,
71
- incentiveBorrowToken: string,
72
- } => {
73
- const incentiveSupplyApy = aprToApy((100 * SECONDS_PER_YEAR * +baseData.rewardSupplySpeed * +compPrice) / +baseData.price / +baseData.totalSupply).toString();
74
- const incentiveBorrowApy = aprToApy((100 * SECONDS_PER_YEAR * +baseData.rewardBorrowSpeed * +compPrice) / +baseData.price / +baseData.totalBorrow).toString();
75
- return {
76
- incentiveSupplyApy,
77
- incentiveBorrowApy,
78
- incentiveSupplyToken: 'COMP',
79
- incentiveBorrowToken: 'COMP',
80
- };
81
- };
82
-
83
- export const getCompoundV2AggregatedData = ({
84
- usedAssets, assetsData, ...rest
85
- }: { usedAssets: CompoundV2UsedAssets, assetsData: CompoundV2AssetsData }) => {
86
- const payload = {} as CompoundAggregatedPositionData;
87
- payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
88
- payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
89
- payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
90
- payload.borrowLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].collateralFactor));
91
-
92
- const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd).toString();
93
-
94
- payload.leftToBorrowUsd = leftToBorrowUsd;
95
- payload.borrowLimitUsd = new Dec(leftToBorrowUsd).add(payload.borrowedUsd).toString();
96
-
97
- payload.liquidationLimitUsd = payload.borrowLimitUsd;
98
- payload.ratio = payload.borrowedUsd && payload.borrowedUsd !== '0'
99
- ? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString()
100
- : '0';
101
- payload.minRatio = '100';
102
- payload.collRatio = payload.borrowedUsd && payload.borrowedUsd !== '0'
103
- ? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString()
104
- : '0';
105
-
106
- // Calculate borrow limits per asset
107
- Object.values(usedAssets).forEach((item) => {
108
- if (item.isBorrowed) {
109
- // eslint-disable-next-line no-param-reassign
110
- item.limit = calculateBorrowingAssetLimit(item.borrowedUsd, payload.borrowLimitUsd);
111
- }
112
- });
113
-
114
- const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData);
115
- payload.netApy = netApy;
116
- payload.incentiveUsd = incentiveUsd;
117
- payload.totalInterestUsd = totalInterestUsd;
118
-
119
- const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets);
120
- payload.leveragedType = leveragedType;
121
- if (leveragedType !== '') {
122
- payload.leveragedAsset = leveragedAsset;
123
- const assetPrice = assetsData[handleWbtcLegacy(leveragedAsset)].price;
124
- payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
125
- }
126
-
127
- return payload;
128
- };
129
-
130
- export const getCompoundV3AggregatedData = ({
131
- usedAssets, assetsData, network, selectedMarket, ...rest
132
- }: { usedAssets: CompoundV3UsedAssets, assetsData: CompoundV3AssetsData, network: NetworkNumber, selectedMarket: CompoundMarketData }) => {
133
- const payload = {} as CompoundAggregatedPositionData;
134
- payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
135
- payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
136
- payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
137
- payload.borrowLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].collateralFactor));
138
- payload.liquidationLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].liquidationRatio));
139
- payload.debtTooLow = new Dec(usedAssets[selectedMarket.baseAsset]?.borrowed || 0).gt(0) && new Dec(usedAssets[selectedMarket.baseAsset].borrowed).lt(assetsData[selectedMarket.baseAsset].minDebt);
140
- const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd);
141
- payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
142
- payload.ratio = +payload.suppliedUsd ? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
143
- payload.collRatio = +payload.suppliedUsd ? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
144
- const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData);
145
- payload.netApy = netApy;
146
- payload.incentiveUsd = incentiveUsd;
147
- payload.totalInterestUsd = totalInterestUsd;
148
- payload.minRatio = '100';
149
- payload.liqRatio = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).toString();
150
- payload.liqPercent = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).mul(100).toString();
151
- payload.minDebt = assetsData[selectedMarket.baseAsset].minDebt;
152
- const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets, selectedMarket.value === CompoundVersions.CompoundV3ETH ? 0.001 : 5);
153
- payload.leveragedType = leveragedType;
154
- if (leveragedType !== '') {
155
- payload.leveragedAsset = leveragedAsset;
156
- let assetPrice = assetsData[leveragedAsset].price;
157
- if (leveragedType === 'lsd-leverage') {
158
- payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toString();
159
- assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
160
- }
161
- payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
162
- }
163
-
164
- // TO DO: handle strategies
165
- /* const subscribedStrategies = rest.compoundStrategies
166
- ? compoundV3GetSubscribedStrategies({ selectedMarket, compoundStrategies: rest.compoundStrategies })
167
- : []; */
168
-
169
- // TODO possibly move to global helper, since every protocol has the same graphData?
170
- // payload.ratioTooLow = false;
171
- // payload.ratioTooHigh = false;
172
-
173
- // TO DO: handle strategies
174
- /* if (subscribedStrategies.length) {
175
- subscribedStrategies.forEach(({ graphData }) => {
176
- payload.ratioTooLow = parseFloat(payload.ratio) < parseFloat(graphData.minRatio);
177
- payload.ratioTooHigh = graphData.boostEnabled && parseFloat(payload.ratio) > parseFloat(graphData.maxRatio);
178
- });
179
- } */
180
-
181
- return payload;
1
+ import Dec from 'decimal.js';
2
+ import { getAssetInfoByAddress } from '@defisaver/tokens';
3
+ import {
4
+ BaseAdditionalAssetData, CompoundAggregatedPositionData, CompoundMarketData, CompoundV2AssetsData, CompoundV2UsedAssets, CompoundV3AssetData, CompoundV3AssetsData, CompoundV3UsedAssets, CompoundVersions,
5
+ } from '../../types';
6
+ import { getEthAmountForDecimals, handleWbtcLegacy, wethToEth } from '../../services/utils';
7
+ import { SECONDS_PER_YEAR } from '../../constants';
8
+ import {
9
+ aprToApy, calcLeverageLiqPrice, calculateBorrowingAssetLimit, getAssetsTotal, isLeveragedPos,
10
+ } from '../../moneymarket';
11
+ import { calculateNetApy } from '../../staking';
12
+ import { NetworkNumber } from '../../types/common';
13
+
14
+ export const formatMarketData = (data: any, network: NetworkNumber, baseAssetPrice: string): CompoundV3AssetData => {
15
+ const assetInfo = getAssetInfoByAddress(data.tokenAddr, network);
16
+ const isWETH = assetInfo.symbol === 'WETH';
17
+ const price = getEthAmountForDecimals(data.price, 8);
18
+ return ({
19
+ ...data,
20
+ priceInBaseAsset: getEthAmountForDecimals(data.price, 8),
21
+ price: new Dec(price).mul(baseAssetPrice).toString(),
22
+ collateralFactor: getEthAmountForDecimals(data.borrowCollateralFactor, 18),
23
+ liquidationRatio: getEthAmountForDecimals(data.liquidateCollateralFactor, 18),
24
+ supplyCap: getEthAmountForDecimals(data.supplyCap, assetInfo.decimals),
25
+ totalSupply: getEthAmountForDecimals(data.totalSupply, assetInfo.decimals),
26
+ symbol: isWETH ? 'ETH' : assetInfo.symbol,
27
+ supplyRate: '0',
28
+ borrowRate: '0',
29
+ canBeBorrowed: false,
30
+ canBeSupplied: true,
31
+ });
32
+ };
33
+
34
+ // TODO: maybe not hardcode decimals
35
+ export const formatBaseData = (data: any, network: NetworkNumber, baseAssetPrice: string): CompoundV3AssetData & BaseAdditionalAssetData => {
36
+ const assetInfo = getAssetInfoByAddress(data.tokenAddr, network);
37
+ const totalSupply = getEthAmountForDecimals(new Dec(data.totalSupply).mul(data.supplyIndex).toString(), 15 + assetInfo.decimals);
38
+ const totalBorrow = getEthAmountForDecimals(new Dec(data.totalBorrow).mul(data.borrowIndex).toString(), 15 + assetInfo.decimals);
39
+ return ({
40
+ ...data,
41
+ supplyRate: aprToApy(new Dec(data.supplyRate).div(1e18).mul(SECONDS_PER_YEAR).mul(100)
42
+ .toString()),
43
+ borrowRate: aprToApy(new Dec(data.borrowRate).div(1e18).mul(SECONDS_PER_YEAR).mul(100)
44
+ .toString()),
45
+ utilization: getEthAmountForDecimals(data.utilization, 16), // utilization is totalSupply/totalBorrow in 1e18, but we need % so when we mul with 100 it's 16 decimals
46
+ totalSupply,
47
+ totalBorrow,
48
+ marketLiquidity: new Dec(totalSupply).minus(totalBorrow).toString(),
49
+ symbol: wethToEth(assetInfo.symbol),
50
+ priceInBaseAsset: getEthAmountForDecimals(data.price, 8),
51
+ price: baseAssetPrice,
52
+ collateralFactor: '0',
53
+ liquidationRatio: '0',
54
+ canBeBorrowed: true,
55
+ canBeSupplied: true,
56
+ supplyCap: '0',
57
+ rewardSupplySpeed: getEthAmountForDecimals(data.baseTrackingSupplyRewardsSpeed, 15),
58
+ rewardBorrowSpeed: getEthAmountForDecimals(data.baseTrackingBorrowRewardsSpeed, 15),
59
+ minDebt: getEthAmountForDecimals(data.baseBorrowMin, assetInfo.decimals),
60
+ isBase: true,
61
+ });
62
+ };
63
+
64
+ export const getIncentiveApys = (
65
+ baseData: CompoundV3AssetData & BaseAdditionalAssetData,
66
+ compPrice: string,
67
+ ): {
68
+ incentiveSupplyApy: string,
69
+ incentiveBorrowApy: string,
70
+ incentiveSupplyToken: string,
71
+ incentiveBorrowToken: string,
72
+ } => {
73
+ const incentiveSupplyApy = aprToApy((100 * SECONDS_PER_YEAR * +baseData.rewardSupplySpeed * +compPrice) / +baseData.price / +baseData.totalSupply).toString();
74
+ const incentiveBorrowApy = aprToApy((100 * SECONDS_PER_YEAR * +baseData.rewardBorrowSpeed * +compPrice) / +baseData.price / +baseData.totalBorrow).toString();
75
+ return {
76
+ incentiveSupplyApy,
77
+ incentiveBorrowApy,
78
+ incentiveSupplyToken: 'COMP',
79
+ incentiveBorrowToken: 'COMP',
80
+ };
81
+ };
82
+
83
+ export const getCompoundV2AggregatedData = ({
84
+ usedAssets, assetsData, ...rest
85
+ }: { usedAssets: CompoundV2UsedAssets, assetsData: CompoundV2AssetsData }) => {
86
+ const payload = {} as CompoundAggregatedPositionData;
87
+ payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
88
+ payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
89
+ payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
90
+ payload.borrowLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].collateralFactor));
91
+
92
+ const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd).toString();
93
+
94
+ payload.leftToBorrowUsd = leftToBorrowUsd;
95
+ payload.borrowLimitUsd = new Dec(leftToBorrowUsd).add(payload.borrowedUsd).toString();
96
+
97
+ payload.liquidationLimitUsd = payload.borrowLimitUsd;
98
+ payload.ratio = payload.borrowedUsd && payload.borrowedUsd !== '0'
99
+ ? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString()
100
+ : '0';
101
+ payload.minRatio = '100';
102
+ payload.collRatio = payload.borrowedUsd && payload.borrowedUsd !== '0'
103
+ ? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString()
104
+ : '0';
105
+
106
+ // Calculate borrow limits per asset
107
+ Object.values(usedAssets).forEach((item) => {
108
+ if (item.isBorrowed) {
109
+ // eslint-disable-next-line no-param-reassign
110
+ item.limit = calculateBorrowingAssetLimit(item.borrowedUsd, payload.borrowLimitUsd);
111
+ }
112
+ });
113
+
114
+ const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData);
115
+ payload.netApy = netApy;
116
+ payload.incentiveUsd = incentiveUsd;
117
+ payload.totalInterestUsd = totalInterestUsd;
118
+
119
+ const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets);
120
+ payload.leveragedType = leveragedType;
121
+ if (leveragedType !== '') {
122
+ payload.leveragedAsset = leveragedAsset;
123
+ const assetPrice = assetsData[handleWbtcLegacy(leveragedAsset)].price;
124
+ payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
125
+ }
126
+
127
+ return payload;
128
+ };
129
+
130
+ export const getCompoundV3AggregatedData = ({
131
+ usedAssets, assetsData, network, selectedMarket, ...rest
132
+ }: { usedAssets: CompoundV3UsedAssets, assetsData: CompoundV3AssetsData, network: NetworkNumber, selectedMarket: CompoundMarketData }) => {
133
+ const payload = {} as CompoundAggregatedPositionData;
134
+ payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
135
+ payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
136
+ payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
137
+ payload.borrowLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].collateralFactor));
138
+ payload.liquidationLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].liquidationRatio));
139
+ payload.debtTooLow = new Dec(usedAssets[selectedMarket.baseAsset]?.borrowed || 0).gt(0) && new Dec(usedAssets[selectedMarket.baseAsset].borrowed).lt(assetsData[selectedMarket.baseAsset].minDebt);
140
+ const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd);
141
+ payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
142
+ payload.ratio = +payload.suppliedUsd ? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
143
+ payload.collRatio = +payload.suppliedUsd ? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
144
+ const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData);
145
+ payload.netApy = netApy;
146
+ payload.incentiveUsd = incentiveUsd;
147
+ payload.totalInterestUsd = totalInterestUsd;
148
+ payload.minRatio = '100';
149
+ payload.liqRatio = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).toString();
150
+ payload.liqPercent = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).mul(100).toString();
151
+ payload.minDebt = assetsData[selectedMarket.baseAsset].minDebt;
152
+ const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets, selectedMarket.value === CompoundVersions.CompoundV3ETH ? 0.001 : 5);
153
+ payload.leveragedType = leveragedType;
154
+ if (leveragedType !== '') {
155
+ payload.leveragedAsset = leveragedAsset;
156
+ let assetPrice = assetsData[leveragedAsset].price;
157
+ if (leveragedType === 'lsd-leverage') {
158
+ payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toString();
159
+ assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
160
+ }
161
+ payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
162
+ }
163
+
164
+ // TO DO: handle strategies
165
+ /* const subscribedStrategies = rest.compoundStrategies
166
+ ? compoundV3GetSubscribedStrategies({ selectedMarket, compoundStrategies: rest.compoundStrategies })
167
+ : []; */
168
+
169
+ // TODO possibly move to global helper, since every protocol has the same graphData?
170
+ // payload.ratioTooLow = false;
171
+ // payload.ratioTooHigh = false;
172
+
173
+ // TO DO: handle strategies
174
+ /* if (subscribedStrategies.length) {
175
+ subscribedStrategies.forEach(({ graphData }) => {
176
+ payload.ratioTooLow = parseFloat(payload.ratio) < parseFloat(graphData.minRatio);
177
+ payload.ratioTooHigh = graphData.boostEnabled && parseFloat(payload.ratio) > parseFloat(graphData.maxRatio);
178
+ });
179
+ } */
180
+
181
+ return payload;
182
182
  };
@@ -1,41 +1,41 @@
1
- import Dec from 'decimal.js';
2
- import { CrvUSDAggregatedPositionData, CrvUSDMarketData, CrvUSDUsedAssets } from '../../types';
3
- import { MMUsedAssets, NetworkNumber } from '../../types/common';
4
- import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
5
- import { mapRange } from '../../services/utils';
6
-
7
- export const getCrvUsdAggregatedData = ({
8
- loanExists, usedAssets, network, selectedMarket, numOfBands, ...rest
9
- }:{
10
- loanExists: boolean, usedAssets: CrvUSDUsedAssets, network: NetworkNumber, selectedMarket: CrvUSDMarketData, numOfBands: number | string
11
- }): CrvUSDAggregatedPositionData => {
12
- const payload = {} as CrvUSDAggregatedPositionData;
13
- payload.supplied = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ supplied }: { supplied: string }) => supplied); // this is wrong if we are in soft-liquidations
14
- payload.borrowed = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowed }: { borrowed: string }) => borrowed);
15
- payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
16
- payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
17
-
18
- payload.ratio = loanExists
19
- ? new Dec(payload.suppliedUsd)
20
- .dividedBy(payload.borrowedUsd)
21
- .times(100)
22
- .toString()
23
- : '0';
24
-
25
- // this is all approximation
26
- payload.minAllowedRatio = mapRange(numOfBands, 4, 50, 115, 140); // collateral ratio
27
- payload.collFactor = new Dec(1).div(payload.minAllowedRatio).mul(100).toString(); // collateral factor = 1 / collateral ratio
28
- // only take in consideration collAsset
29
- payload.borrowLimitUsd = usedAssets?.[selectedMarket.collAsset]?.isSupplied
30
- ? new Dec(usedAssets[selectedMarket.collAsset].suppliedUsd).mul(payload.collFactor).toString()
31
- : '0';
32
-
33
- const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets as unknown as MMUsedAssets);
34
- payload.leveragedType = leveragedType;
35
- if (leveragedType !== '') {
36
- payload.leveragedAsset = leveragedAsset;
37
- payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, usedAssets[selectedMarket.collAsset].price, payload.borrowedUsd, payload.borrowLimitUsd);
38
- }
39
-
40
- return payload;
1
+ import Dec from 'decimal.js';
2
+ import { CrvUSDAggregatedPositionData, CrvUSDMarketData, CrvUSDUsedAssets } from '../../types';
3
+ import { MMUsedAssets, NetworkNumber } from '../../types/common';
4
+ import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
5
+ import { mapRange } from '../../services/utils';
6
+
7
+ export const getCrvUsdAggregatedData = ({
8
+ loanExists, usedAssets, network, selectedMarket, numOfBands, ...rest
9
+ }:{
10
+ loanExists: boolean, usedAssets: CrvUSDUsedAssets, network: NetworkNumber, selectedMarket: CrvUSDMarketData, numOfBands: number | string
11
+ }): CrvUSDAggregatedPositionData => {
12
+ const payload = {} as CrvUSDAggregatedPositionData;
13
+ payload.supplied = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ supplied }: { supplied: string }) => supplied); // this is wrong if we are in soft-liquidations
14
+ payload.borrowed = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowed }: { borrowed: string }) => borrowed);
15
+ payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
16
+ payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
17
+
18
+ payload.ratio = loanExists
19
+ ? new Dec(payload.suppliedUsd)
20
+ .dividedBy(payload.borrowedUsd)
21
+ .times(100)
22
+ .toString()
23
+ : '0';
24
+
25
+ // this is all approximation
26
+ payload.minAllowedRatio = mapRange(numOfBands, 4, 50, 115, 140); // collateral ratio
27
+ payload.collFactor = new Dec(1).div(payload.minAllowedRatio).mul(100).toString(); // collateral factor = 1 / collateral ratio
28
+ // only take in consideration collAsset
29
+ payload.borrowLimitUsd = usedAssets?.[selectedMarket.collAsset]?.isSupplied
30
+ ? new Dec(usedAssets[selectedMarket.collAsset].suppliedUsd).mul(payload.collFactor).toString()
31
+ : '0';
32
+
33
+ const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets as unknown as MMUsedAssets);
34
+ payload.leveragedType = leveragedType;
35
+ if (leveragedType !== '') {
36
+ payload.leveragedAsset = leveragedAsset;
37
+ payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, usedAssets[selectedMarket.collAsset].price, payload.borrowedUsd, payload.borrowLimitUsd);
38
+ }
39
+
40
+ return payload;
41
41
  };
@@ -1,8 +1,8 @@
1
- export * as aaveHelpers from './aaveHelpers';
2
- export * as compoundHelpers from './compoundHelpers';
3
- export * as sparkHelpers from './sparkHelpers';
4
- export * as curveUsdHelpers from './curveUsdHelpers';
5
- export * as makerHelpers from './makerHelpers';
6
- export * as chickenBondsHelpers from './chickenBondsHelpers';
7
- export * as morphoBlueHelpers from './morphoBlueHelpers';
1
+ export * as aaveHelpers from './aaveHelpers';
2
+ export * as compoundHelpers from './compoundHelpers';
3
+ export * as sparkHelpers from './sparkHelpers';
4
+ export * as curveUsdHelpers from './curveUsdHelpers';
5
+ export * as makerHelpers from './makerHelpers';
6
+ export * as chickenBondsHelpers from './chickenBondsHelpers';
7
+ export * as morphoBlueHelpers from './morphoBlueHelpers';
8
8
  export * as llamaLendHelpers from './llamaLendHelpers';
@@ -1,45 +1,45 @@
1
- import Dec from 'decimal.js';
2
- import { LlamaLendAggregatedPositionData, LlamaLendMarketData, LlamaLendUsedAssets } from '../../types';
3
- import { MMUsedAssets, NetworkNumber } from '../../types/common';
4
- import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
5
- import { mapRange } from '../../services/utils';
6
-
7
- export const getLlamaLendAggregatedData = ({
8
- loanExists, usedAssets, network, selectedMarket, numOfBands, ...rest
9
- }:{
10
- loanExists: boolean, usedAssets: LlamaLendUsedAssets, network: NetworkNumber, selectedMarket: LlamaLendMarketData, numOfBands: number | string
11
- }): LlamaLendAggregatedPositionData => {
12
- const collAsset = selectedMarket.collAsset;
13
- const debtAsset = selectedMarket.baseAsset;
14
- const payload = {} as LlamaLendAggregatedPositionData;
15
-
16
- // payload.supplied = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ supplied }: { supplied: string }) => supplied);
17
- // payload.borrowed = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowed }: { borrowed: string }) => borrowed);
18
- payload.suppliedUsd = getAssetsTotal(usedAssets, ({ collateral }: { collateral: boolean }) => collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
19
- payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
20
- payload.suppliedForYieldUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedForYield }: { suppliedForYield?: string }) => suppliedForYield || '0');
21
-
22
- payload.ratio = loanExists
23
- ? new Dec(payload.suppliedUsd)
24
- .dividedBy(payload.borrowedUsd)
25
- .times(100)
26
- .toString()
27
- : '0';
28
-
29
- // this is all approximation
30
- payload.minAllowedRatio = mapRange(numOfBands, 4, 50, 115, 140); // collateral ratio
31
- payload.collFactor = new Dec(1).div(payload.minAllowedRatio).mul(100).toString(); // collateral factor = 1 / collateral ratio
32
- // only take in consideration collAsset
33
- payload.borrowLimitUsd = usedAssets?.[collAsset]?.isSupplied
34
- ? new Dec(usedAssets[collAsset].suppliedUsd).mul(payload.collFactor).toString()
35
- : '0';
36
-
37
- const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets as unknown as MMUsedAssets);
38
- payload.leveragedType = leveragedType;
39
- if (leveragedType !== '') {
40
- payload.leveragedAsset = leveragedAsset;
41
- payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, usedAssets[collAsset].price, payload.borrowedUsd, payload.borrowLimitUsd);
42
- }
43
-
44
- return payload;
45
- };
1
+ import Dec from 'decimal.js';
2
+ import { LlamaLendAggregatedPositionData, LlamaLendMarketData, LlamaLendUsedAssets } from '../../types';
3
+ import { MMUsedAssets, NetworkNumber } from '../../types/common';
4
+ import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
5
+ import { mapRange } from '../../services/utils';
6
+
7
+ export const getLlamaLendAggregatedData = ({
8
+ loanExists, usedAssets, network, selectedMarket, numOfBands, ...rest
9
+ }:{
10
+ loanExists: boolean, usedAssets: LlamaLendUsedAssets, network: NetworkNumber, selectedMarket: LlamaLendMarketData, numOfBands: number | string
11
+ }): LlamaLendAggregatedPositionData => {
12
+ const collAsset = selectedMarket.collAsset;
13
+ const debtAsset = selectedMarket.baseAsset;
14
+ const payload = {} as LlamaLendAggregatedPositionData;
15
+
16
+ // payload.supplied = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ supplied }: { supplied: string }) => supplied);
17
+ // payload.borrowed = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowed }: { borrowed: string }) => borrowed);
18
+ payload.suppliedUsd = getAssetsTotal(usedAssets, ({ collateral }: { collateral: boolean }) => collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
19
+ payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
20
+ payload.suppliedForYieldUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedForYield }: { suppliedForYield?: string }) => suppliedForYield || '0');
21
+
22
+ payload.ratio = loanExists
23
+ ? new Dec(payload.suppliedUsd)
24
+ .dividedBy(payload.borrowedUsd)
25
+ .times(100)
26
+ .toString()
27
+ : '0';
28
+
29
+ // this is all approximation
30
+ payload.minAllowedRatio = mapRange(numOfBands, 4, 50, 115, 140); // collateral ratio
31
+ payload.collFactor = new Dec(1).div(payload.minAllowedRatio).mul(100).toString(); // collateral factor = 1 / collateral ratio
32
+ // only take in consideration collAsset
33
+ payload.borrowLimitUsd = usedAssets?.[collAsset]?.isSupplied
34
+ ? new Dec(usedAssets[collAsset].suppliedUsd).mul(payload.collFactor).toString()
35
+ : '0';
36
+
37
+ const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets as unknown as MMUsedAssets);
38
+ payload.leveragedType = leveragedType;
39
+ if (leveragedType !== '') {
40
+ payload.leveragedAsset = leveragedAsset;
41
+ payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, usedAssets[collAsset].price, payload.borrowedUsd, payload.borrowLimitUsd);
42
+ }
43
+
44
+ return payload;
45
+ };