@defisaver/positions-sdk 0.0.80 → 0.0.81

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 (64) hide show
  1. package/README.md +63 -63
  2. package/cjs/aaveV3/index.js +4 -7
  3. package/cjs/spark/index.js +57 -48
  4. package/esm/aaveV3/index.js +4 -7
  5. package/esm/spark/index.js +58 -49
  6. package/package.json +41 -41
  7. package/src/aaveV2/index.ts +227 -227
  8. package/src/aaveV3/index.ts +559 -562
  9. package/src/assets/index.ts +60 -60
  10. package/src/chickenBonds/index.ts +123 -123
  11. package/src/compoundV2/index.ts +219 -219
  12. package/src/compoundV3/index.ts +273 -273
  13. package/src/config/contracts.js +848 -848
  14. package/src/constants/index.ts +5 -5
  15. package/src/contracts.ts +128 -128
  16. package/src/curveUsd/index.ts +229 -229
  17. package/src/exchange/index.ts +17 -17
  18. package/src/helpers/aaveHelpers/index.ts +134 -134
  19. package/src/helpers/chickenBondsHelpers/index.ts +23 -23
  20. package/src/helpers/compoundHelpers/index.ts +181 -181
  21. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  22. package/src/helpers/index.ts +7 -7
  23. package/src/helpers/llamaLendHelpers/index.ts +45 -45
  24. package/src/helpers/makerHelpers/index.ts +94 -94
  25. package/src/helpers/morphoBlueHelpers/index.ts +56 -56
  26. package/src/helpers/sparkHelpers/index.ts +106 -106
  27. package/src/index.ts +46 -46
  28. package/src/liquity/index.ts +116 -116
  29. package/src/llamaLend/index.ts +268 -268
  30. package/src/maker/index.ts +117 -117
  31. package/src/markets/aave/index.ts +80 -80
  32. package/src/markets/aave/marketAssets.ts +25 -25
  33. package/src/markets/compound/index.ts +142 -142
  34. package/src/markets/compound/marketsAssets.ts +50 -50
  35. package/src/markets/curveUsd/index.ts +69 -69
  36. package/src/markets/index.ts +5 -5
  37. package/src/markets/llamaLend/contractAddresses.ts +95 -95
  38. package/src/markets/llamaLend/index.ts +150 -150
  39. package/src/markets/morphoBlue/index.ts +462 -462
  40. package/src/markets/spark/index.ts +29 -29
  41. package/src/markets/spark/marketAssets.ts +10 -10
  42. package/src/moneymarket/moneymarketCommonService.ts +75 -75
  43. package/src/morphoAaveV2/index.ts +256 -256
  44. package/src/morphoAaveV3/index.ts +619 -619
  45. package/src/morphoBlue/index.ts +162 -162
  46. package/src/multicall/index.ts +22 -22
  47. package/src/services/dsrService.ts +15 -15
  48. package/src/services/priceService.ts +21 -21
  49. package/src/services/utils.ts +51 -51
  50. package/src/setup.ts +8 -8
  51. package/src/spark/index.ts +433 -422
  52. package/src/staking/staking.ts +198 -198
  53. package/src/types/aave.ts +256 -256
  54. package/src/types/chickenBonds.ts +45 -45
  55. package/src/types/common.ts +84 -84
  56. package/src/types/compound.ts +128 -128
  57. package/src/types/curveUsd.ts +118 -118
  58. package/src/types/index.ts +8 -8
  59. package/src/types/liquity.ts +30 -30
  60. package/src/types/llamaLend.ts +143 -143
  61. package/src/types/maker.ts +50 -50
  62. package/src/types/morphoBlue.ts +129 -129
  63. package/src/types/spark.ts +106 -106
  64. package/yarn-error.log +0 -64
@@ -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
+ };