@defisaver/positions-sdk 0.0.68 → 0.0.69

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