@defisaver/positions-sdk 0.0.66 → 0.0.67

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