@defisaver/positions-sdk 0.0.97 → 0.0.99

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 (74) hide show
  1. package/README.md +63 -63
  2. package/cjs/config/contracts.d.ts +45 -1
  3. package/cjs/config/contracts.js +3 -3
  4. package/cjs/helpers/morphoBlueHelpers/index.d.ts +9 -2
  5. package/cjs/helpers/morphoBlueHelpers/index.js +66 -1
  6. package/cjs/morphoBlue/index.d.ts +2 -1
  7. package/cjs/morphoBlue/index.js +33 -28
  8. package/cjs/types/contracts/generated/MorphoBlueView.d.ts +61 -0
  9. package/esm/config/contracts.d.ts +45 -1
  10. package/esm/config/contracts.js +3 -3
  11. package/esm/helpers/morphoBlueHelpers/index.d.ts +9 -2
  12. package/esm/helpers/morphoBlueHelpers/index.js +62 -0
  13. package/esm/morphoBlue/index.d.ts +2 -1
  14. package/esm/morphoBlue/index.js +32 -28
  15. package/esm/types/contracts/generated/MorphoBlueView.d.ts +61 -0
  16. package/package.json +40 -40
  17. package/src/aaveV2/index.ts +227 -227
  18. package/src/aaveV3/index.ts +558 -558
  19. package/src/assets/index.ts +60 -60
  20. package/src/chickenBonds/index.ts +123 -123
  21. package/src/compoundV2/index.ts +219 -219
  22. package/src/compoundV3/index.ts +266 -266
  23. package/src/config/contracts.js +848 -848
  24. package/src/constants/index.ts +5 -5
  25. package/src/contracts.ts +128 -128
  26. package/src/curveUsd/index.ts +229 -229
  27. package/src/exchange/index.ts +17 -17
  28. package/src/helpers/aaveHelpers/index.ts +134 -134
  29. package/src/helpers/chickenBondsHelpers/index.ts +23 -23
  30. package/src/helpers/compoundHelpers/index.ts +181 -181
  31. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  32. package/src/helpers/index.ts +7 -7
  33. package/src/helpers/llamaLendHelpers/index.ts +45 -45
  34. package/src/helpers/makerHelpers/index.ts +94 -94
  35. package/src/helpers/morphoBlueHelpers/index.ts +117 -56
  36. package/src/helpers/sparkHelpers/index.ts +106 -106
  37. package/src/index.ts +46 -46
  38. package/src/liquity/index.ts +116 -116
  39. package/src/llamaLend/index.ts +268 -268
  40. package/src/maker/index.ts +117 -117
  41. package/src/markets/aave/index.ts +80 -80
  42. package/src/markets/aave/marketAssets.ts +24 -24
  43. package/src/markets/compound/index.ts +142 -142
  44. package/src/markets/compound/marketsAssets.ts +50 -50
  45. package/src/markets/curveUsd/index.ts +69 -69
  46. package/src/markets/index.ts +5 -5
  47. package/src/markets/llamaLend/contractAddresses.ts +95 -95
  48. package/src/markets/llamaLend/index.ts +150 -150
  49. package/src/markets/morphoBlue/index.ts +611 -611
  50. package/src/markets/spark/index.ts +29 -29
  51. package/src/markets/spark/marketAssets.ts +10 -10
  52. package/src/moneymarket/moneymarketCommonService.ts +76 -76
  53. package/src/morphoAaveV2/index.ts +256 -256
  54. package/src/morphoAaveV3/index.ts +612 -612
  55. package/src/morphoBlue/index.ts +171 -162
  56. package/src/multicall/index.ts +22 -22
  57. package/src/services/dsrService.ts +15 -15
  58. package/src/services/priceService.ts +21 -21
  59. package/src/services/utils.ts +51 -51
  60. package/src/setup.ts +8 -8
  61. package/src/spark/index.ts +424 -424
  62. package/src/staking/staking.ts +187 -187
  63. package/src/types/aave.ts +256 -256
  64. package/src/types/chickenBonds.ts +45 -45
  65. package/src/types/common.ts +84 -84
  66. package/src/types/compound.ts +128 -128
  67. package/src/types/contracts/generated/MorphoBlueView.ts +87 -0
  68. package/src/types/curveUsd.ts +118 -118
  69. package/src/types/index.ts +8 -8
  70. package/src/types/liquity.ts +30 -30
  71. package/src/types/llamaLend.ts +143 -143
  72. package/src/types/maker.ts +50 -50
  73. package/src/types/morphoBlue.ts +139 -139
  74. package/src/types/spark.ts +106 -106
@@ -1,95 +1,95 @@
1
- import Web3 from 'web3';
2
- import Dec from 'decimal.js';
3
- import { Blockish, NetworkNumber } from '../../types/common';
4
- import {
5
- McdDogContract, McdJugContract, McdSpotterContract, McdVatContract,
6
- } from '../../contracts';
7
- import { multicall } from '../../multicall';
8
- import { SECONDS_PER_YEAR } from '../../constants';
9
- import { bytesToString } from '../../services/utils';
10
- import { IlkInfo } from '../../types';
11
-
12
- export const getUnclaimedCollateral = async (web3: Web3, network: NetworkNumber, urn: string, ilk: string) => {
13
- const vatContract = McdVatContract(web3, network);
14
- const coll = await vatContract.methods.gem(ilk, urn).call();
15
- return coll;
16
- };
17
-
18
- export const getCollateralInfo = async (ilk: string, web3: Web3, network: NetworkNumber, block: Blockish = 'latest'): Promise<IlkInfo> => {
19
- const spotterContract = McdSpotterContract(web3, network);
20
- const vatContract = McdVatContract(web3, network);
21
- const dogContract = McdDogContract(web3, network);
22
- const jugContract = McdJugContract(web3, network);
23
-
24
- const multicallData = [
25
- {
26
- target: spotterContract.options.address,
27
- abiItem: spotterContract.options.jsonInterface.find(({ name }) => name === 'par'),
28
- params: [],
29
- },
30
- {
31
- target: spotterContract.options.address,
32
- abiItem: spotterContract.options.jsonInterface.find(({ name }) => name === 'ilks'),
33
- params: [ilk],
34
- },
35
- {
36
- target: vatContract.options.address,
37
- abiItem: vatContract.options.jsonInterface.find(({ name }) => name === 'ilks'),
38
- params: [ilk],
39
- },
40
- {
41
- target: jugContract.options.address,
42
- abiItem: jugContract.options.jsonInterface.find(({ name }) => name === 'ilks'),
43
- params: [ilk],
44
- },
45
- {
46
- target: jugContract.options.address,
47
- abiItem: jugContract.options.jsonInterface.find(({ name }) => name === 'drip'),
48
- params: [ilk],
49
- },
50
- {
51
- target: dogContract.options.address,
52
- abiItem: dogContract.options.jsonInterface.find(({ name }) => name === 'chop'),
53
- params: [ilk],
54
- },
55
- ];
56
-
57
- const multiRes = await multicall(multicallData, web3, network, block);
58
-
59
- const par = new Dec(multiRes[0][0].toString()).div(1e27).toString();
60
- const mat = new Dec(multiRes[1][1].toString()).div(1e27).toString();
61
- const art = new Dec(multiRes[2][0].toString()).toString();
62
- const rate = new Dec(multiRes[2][1].toString()).toString();
63
- const spot = new Dec(multiRes[2][2].toString()).div(1e27).toString();
64
- const line = new Dec(multiRes[2][3].toString()).div(1e45).toString();
65
- const dust = new Dec(multiRes[2][1].toString()).div(1e45).toString();
66
- const duty = new Dec(multiRes[3][0].toString()).toString();
67
- const futureRate = new Dec(multiRes[4][0].toString()).toString();
68
- const chop = new Dec(multiRes[5][0].toString()).div(1e18).toString();
69
-
70
- const stabilityFee = new Dec(duty.toString())
71
- .div(1e27)
72
- .pow(SECONDS_PER_YEAR)
73
- .minus(1)
74
- .mul(100)
75
- .toNumber();
76
- const liquidationFee = new Dec(chop).mul(100).sub(100).toString();
77
- const globalDebtCurrent = new Dec(art).div(1e18).mul(new Dec(futureRate).div(1e27)).toString();
78
- const globalDebtCeiling = line;
79
- const creatableDebt = new Dec(globalDebtCeiling).sub(globalDebtCurrent).toString();
80
-
81
- return {
82
- ilkLabel: bytesToString(ilk),
83
- currentRate: rate,
84
- futureRate,
85
- minDebt: dust,
86
- globalDebtCurrent,
87
- globalDebtCeiling,
88
- assetPrice: new Dec(spot).times(par).times(mat).toString(),
89
- liqRatio: mat,
90
- liqPercent: +mat * 100,
91
- stabilityFee,
92
- liquidationFee: new Dec(liquidationFee).lt(0) ? '0' : liquidationFee,
93
- creatableDebt,
94
- };
1
+ import Web3 from 'web3';
2
+ import Dec from 'decimal.js';
3
+ import { Blockish, NetworkNumber } from '../../types/common';
4
+ import {
5
+ McdDogContract, McdJugContract, McdSpotterContract, McdVatContract,
6
+ } from '../../contracts';
7
+ import { multicall } from '../../multicall';
8
+ import { SECONDS_PER_YEAR } from '../../constants';
9
+ import { bytesToString } from '../../services/utils';
10
+ import { IlkInfo } from '../../types';
11
+
12
+ export const getUnclaimedCollateral = async (web3: Web3, network: NetworkNumber, urn: string, ilk: string) => {
13
+ const vatContract = McdVatContract(web3, network);
14
+ const coll = await vatContract.methods.gem(ilk, urn).call();
15
+ return coll;
16
+ };
17
+
18
+ export const getCollateralInfo = async (ilk: string, web3: Web3, network: NetworkNumber, block: Blockish = 'latest'): Promise<IlkInfo> => {
19
+ const spotterContract = McdSpotterContract(web3, network);
20
+ const vatContract = McdVatContract(web3, network);
21
+ const dogContract = McdDogContract(web3, network);
22
+ const jugContract = McdJugContract(web3, network);
23
+
24
+ const multicallData = [
25
+ {
26
+ target: spotterContract.options.address,
27
+ abiItem: spotterContract.options.jsonInterface.find(({ name }) => name === 'par'),
28
+ params: [],
29
+ },
30
+ {
31
+ target: spotterContract.options.address,
32
+ abiItem: spotterContract.options.jsonInterface.find(({ name }) => name === 'ilks'),
33
+ params: [ilk],
34
+ },
35
+ {
36
+ target: vatContract.options.address,
37
+ abiItem: vatContract.options.jsonInterface.find(({ name }) => name === 'ilks'),
38
+ params: [ilk],
39
+ },
40
+ {
41
+ target: jugContract.options.address,
42
+ abiItem: jugContract.options.jsonInterface.find(({ name }) => name === 'ilks'),
43
+ params: [ilk],
44
+ },
45
+ {
46
+ target: jugContract.options.address,
47
+ abiItem: jugContract.options.jsonInterface.find(({ name }) => name === 'drip'),
48
+ params: [ilk],
49
+ },
50
+ {
51
+ target: dogContract.options.address,
52
+ abiItem: dogContract.options.jsonInterface.find(({ name }) => name === 'chop'),
53
+ params: [ilk],
54
+ },
55
+ ];
56
+
57
+ const multiRes = await multicall(multicallData, web3, network, block);
58
+
59
+ const par = new Dec(multiRes[0][0].toString()).div(1e27).toString();
60
+ const mat = new Dec(multiRes[1][1].toString()).div(1e27).toString();
61
+ const art = new Dec(multiRes[2][0].toString()).toString();
62
+ const rate = new Dec(multiRes[2][1].toString()).toString();
63
+ const spot = new Dec(multiRes[2][2].toString()).div(1e27).toString();
64
+ const line = new Dec(multiRes[2][3].toString()).div(1e45).toString();
65
+ const dust = new Dec(multiRes[2][1].toString()).div(1e45).toString();
66
+ const duty = new Dec(multiRes[3][0].toString()).toString();
67
+ const futureRate = new Dec(multiRes[4][0].toString()).toString();
68
+ const chop = new Dec(multiRes[5][0].toString()).div(1e18).toString();
69
+
70
+ const stabilityFee = new Dec(duty.toString())
71
+ .div(1e27)
72
+ .pow(SECONDS_PER_YEAR)
73
+ .minus(1)
74
+ .mul(100)
75
+ .toNumber();
76
+ const liquidationFee = new Dec(chop).mul(100).sub(100).toString();
77
+ const globalDebtCurrent = new Dec(art).div(1e18).mul(new Dec(futureRate).div(1e27)).toString();
78
+ const globalDebtCeiling = line;
79
+ const creatableDebt = new Dec(globalDebtCeiling).sub(globalDebtCurrent).toString();
80
+
81
+ return {
82
+ ilkLabel: bytesToString(ilk),
83
+ currentRate: rate,
84
+ futureRate,
85
+ minDebt: dust,
86
+ globalDebtCurrent,
87
+ globalDebtCeiling,
88
+ assetPrice: new Dec(spot).times(par).times(mat).toString(),
89
+ liqRatio: mat,
90
+ liqPercent: +mat * 100,
91
+ stabilityFee,
92
+ liquidationFee: new Dec(liquidationFee).lt(0) ? '0' : liquidationFee,
93
+ creatableDebt,
94
+ };
95
95
  };
@@ -1,57 +1,118 @@
1
- import Dec from 'decimal.js';
2
- import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
3
- import { calculateNetApy } from '../../staking';
4
- import { MMUsedAssets } from '../../types/common';
5
- import { MorphoBlueAggregatedPositionData, MorphoBlueAssetsData, MorphoBlueMarketInfo } from '../../types';
6
-
7
- export const getMorphoBlueAggregatedPositionData = ({ usedAssets, assetsData, marketInfo }: { usedAssets: MMUsedAssets, assetsData: MorphoBlueAssetsData, marketInfo: MorphoBlueMarketInfo }): MorphoBlueAggregatedPositionData => {
8
- const payload = {} as MorphoBlueAggregatedPositionData;
9
- payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
10
- payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: string }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
11
- payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
12
-
13
- const {
14
- lltv, oracle, collateralToken, loanToken,
15
- } = marketInfo;
16
-
17
- payload.borrowLimitUsd = getAssetsTotal(
18
- usedAssets,
19
- ({ isSupplied, collateral }: { isSupplied: boolean, collateral: string }) => isSupplied && collateral,
20
- ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => {
21
- const suppliedUsdAmount = suppliedUsd;
22
-
23
- return new Dec(suppliedUsdAmount).mul(lltv);
24
- },
25
- );
26
- payload.liquidationLimitUsd = payload.borrowLimitUsd;
27
- const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd);
28
- payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
29
-
30
- payload.leftToBorrow = new Dec(usedAssets[collateralToken]?.supplied || 0).mul(oracle).mul(lltv).sub(usedAssets[loanToken]?.borrowed || 0)
31
- .toString();
32
-
33
- const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData as any);
34
- payload.netApy = netApy;
35
- payload.incentiveUsd = incentiveUsd;
36
- payload.totalInterestUsd = totalInterestUsd;
37
-
38
- payload.ltv = new Dec(payload.borrowedUsd).div(payload.suppliedCollateralUsd).toString();
39
- payload.ltv = new Dec(usedAssets[loanToken]?.borrowed || 0).div(oracle).div(usedAssets[collateralToken]?.supplied || 1).toString(); // default to 1 because can't div 0
40
- payload.ratio = new Dec(usedAssets[collateralToken]?.supplied || 0).mul(oracle).div(usedAssets[loanToken]?.borrowed || 1).mul(100)
41
- .toString();
42
-
43
- const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets);
44
- payload.leveragedType = leveragedType;
45
- if (leveragedType !== '') {
46
- payload.leveragedAsset = leveragedAsset;
47
- let assetPrice = assetsData[leveragedAsset].price;
48
- if (leveragedType === 'lsd-leverage') {
49
- // Treat ETH like a stablecoin in a long stETH position
50
- payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
51
- assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
52
- }
53
- payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
54
- }
55
-
56
- return payload;
1
+ import Dec from 'decimal.js';
2
+ import { assetAmountInWei } from '@defisaver/tokens';
3
+ import Web3 from 'web3';
4
+ import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
5
+ import { calculateNetApy } from '../../staking';
6
+ import { MMUsedAssets, NetworkNumber } from '../../types/common';
7
+ import {
8
+ MorphoBlueAggregatedPositionData, MorphoBlueAssetsData, MorphoBlueMarketData, MorphoBlueMarketInfo,
9
+ } from '../../types';
10
+ import { SECONDS_PER_YEAR, WAD } from '../../constants';
11
+ import { MorphoBlueViewContract } from '../../contracts';
12
+ import { MarketParamsStruct } from '../../types/contracts/generated/MorphoBlueView';
13
+
14
+ export const getMorphoBlueAggregatedPositionData = ({ usedAssets, assetsData, marketInfo }: { usedAssets: MMUsedAssets, assetsData: MorphoBlueAssetsData, marketInfo: MorphoBlueMarketInfo }): MorphoBlueAggregatedPositionData => {
15
+ const payload = {} as MorphoBlueAggregatedPositionData;
16
+ payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
17
+ payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: string }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
18
+ payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
19
+
20
+ const {
21
+ lltv, oracle, collateralToken, loanToken,
22
+ } = marketInfo;
23
+
24
+ payload.borrowLimitUsd = getAssetsTotal(
25
+ usedAssets,
26
+ ({ isSupplied, collateral }: { isSupplied: boolean, collateral: string }) => isSupplied && collateral,
27
+ ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => {
28
+ const suppliedUsdAmount = suppliedUsd;
29
+
30
+ return new Dec(suppliedUsdAmount).mul(lltv);
31
+ },
32
+ );
33
+ payload.liquidationLimitUsd = payload.borrowLimitUsd;
34
+ const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd);
35
+ payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
36
+
37
+ payload.leftToBorrow = new Dec(usedAssets[collateralToken]?.supplied || 0).mul(oracle).mul(lltv).sub(usedAssets[loanToken]?.borrowed || 0)
38
+ .toString();
39
+
40
+ const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData as any);
41
+ payload.netApy = netApy;
42
+ payload.incentiveUsd = incentiveUsd;
43
+ payload.totalInterestUsd = totalInterestUsd;
44
+
45
+ payload.ltv = new Dec(payload.borrowedUsd).div(payload.suppliedCollateralUsd).toString();
46
+ payload.ltv = new Dec(usedAssets[loanToken]?.borrowed || 0).div(oracle).div(usedAssets[collateralToken]?.supplied || 1).toString(); // default to 1 because can't div 0
47
+ payload.ratio = new Dec(usedAssets[collateralToken]?.supplied || 0).mul(oracle).div(usedAssets[loanToken]?.borrowed || 1).mul(100)
48
+ .toString();
49
+
50
+ const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets);
51
+ payload.leveragedType = leveragedType;
52
+ if (leveragedType !== '') {
53
+ payload.leveragedAsset = leveragedAsset;
54
+ let assetPrice = assetsData[leveragedAsset].price;
55
+ if (leveragedType === 'lsd-leverage') {
56
+ // Treat ETH like a stablecoin in a long stETH position
57
+ payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
58
+ assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
59
+ }
60
+ payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
61
+ }
62
+
63
+ return payload;
64
+ };
65
+
66
+ const compound = (ratePerSeconds: string) => {
67
+ const compounding = new Dec(ratePerSeconds).mul(SECONDS_PER_YEAR).toString();
68
+ const apyNumber = Math.expm1(new Dec(compounding).div(WAD).toNumber());
69
+ return new Dec(apyNumber).mul(WAD).floor().toString();
70
+ };
71
+
72
+ export const getSupplyRate = (totalSupplyAssets: string, totalBorrowAssets: string, borrowRate: string, fee: string) => {
73
+ if (totalBorrowAssets === '0' || totalSupplyAssets === '0') {
74
+ return '0';
75
+ }
76
+ const utillization = new Dec(totalBorrowAssets).mul(WAD).div(totalSupplyAssets).ceil()
77
+ .toString();
78
+ const supplyRate = new Dec(utillization).mul(borrowRate).div(WAD).ceil()
79
+ .toString();
80
+ const ratePerSecond = new Dec(supplyRate).mul(new Dec(WAD).minus(fee)).div(WAD).ceil()
81
+ .toString();
82
+ return new Dec(compound(ratePerSecond)).div(1e18).mul(100).toString();
83
+ };
84
+
85
+ export const getBorrowRate = (borrowRate: string, totalBorrowShares: string) => {
86
+ if (totalBorrowShares === '0') {
87
+ return '0';
88
+ }
89
+ return new Dec(compound(borrowRate)).div(1e18).mul(100).toString();
90
+ };
91
+
92
+ const borrowOperations = ['borrow', 'payback'];
93
+
94
+ export const getApyAfterValuesEstimation = async (selectedMarket: MorphoBlueMarketData, action: string, amount: string, asset: string, web3: Web3, network: NetworkNumber) => {
95
+ const morphoBlueViewContract = MorphoBlueViewContract(web3, network);
96
+ const lltvInWei = assetAmountInWei(selectedMarket.lltv, 'ETH');
97
+ const marketData: MarketParamsStruct = [selectedMarket.loanToken, selectedMarket.collateralToken, selectedMarket.oracle, selectedMarket.irm, lltvInWei];
98
+ const isBorrowOperation = borrowOperations.includes(action);
99
+ const amountInWei = assetAmountInWei(amount, asset);
100
+ let liquidityAdded;
101
+ let liquidityRemoved;
102
+ if (isBorrowOperation) {
103
+ liquidityAdded = action === 'payback' ? amountInWei : '0';
104
+ liquidityRemoved = action === 'borrow' ? amountInWei : '0';
105
+ } else {
106
+ liquidityAdded = action === 'collateral' ? amountInWei : '0';
107
+ liquidityRemoved = action === 'withdraw' ? amountInWei : '0';
108
+ }
109
+ const data = await morphoBlueViewContract.methods.getApyAfterValuesEstimation([
110
+ marketData,
111
+ isBorrowOperation,
112
+ liquidityAdded,
113
+ liquidityRemoved,
114
+ ]).call();
115
+ const borrowRate = getBorrowRate(data.borrowRate, data.market.totalBorrowShares);
116
+ const supplyRate = getSupplyRate(data.market.totalSupplyAssets, data.market.totalBorrowAssets, data.borrowRate, data.market.fee);
117
+ return { borrowRate, supplyRate };
57
118
  };
@@ -1,107 +1,107 @@
1
- import Dec from 'decimal.js';
2
- import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
3
- import {
4
- SparkAggregatedPositionData,
5
- SparkAssetsData, SparkHelperCommon, SparkUsedAssets,
6
- } from '../../types';
7
- import { calculateNetApy } from '../../staking';
8
- import { wethToEth } from '../../services/utils';
9
-
10
- export const sparkIsInIsolationMode = ({ usedAssets, assetsData }: { usedAssets: SparkUsedAssets, assetsData: SparkAssetsData }) => Object.values(usedAssets).some(({ symbol, collateral }) => collateral && assetsData[symbol].isIsolated);
11
-
12
- export const sparkGetCollSuppliedAssets = ({ usedAssets }: { usedAssets: SparkUsedAssets }) => Object.values(usedAssets).filter(({ isSupplied, collateral }) => isSupplied && collateral);
13
-
14
- export const sparkGetSuppliableAssets = ({
15
- usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest
16
- }: SparkHelperCommon) => {
17
- const data = {
18
- usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
19
- };
20
-
21
- const collAccountAssets = sparkGetCollSuppliedAssets(data);
22
- const marketAssets = Object.values(assetsData);
23
-
24
- if (sparkIsInIsolationMode(data)) {
25
- const collAsset = collAccountAssets[0].symbol;
26
- return marketAssets.filter(d => d.canBeSupplied).map(({ symbol }) => ({ symbol, canBeCollateral: symbol === collAsset }));
27
- }
28
-
29
- return marketAssets.filter(d => d.canBeSupplied).map(({ symbol, isIsolated }) => ({ symbol, canBeCollateral: !isIsolated }));
30
- };
31
-
32
- export const sparkGetSuppliableAsCollAssets = ({
33
- usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest
34
- }: SparkHelperCommon) => sparkGetSuppliableAssets({
35
- usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
36
- }).filter(({ canBeCollateral }) => canBeCollateral);
37
-
38
- export const sparkGetEmodeMutableProps = ({
39
- eModeCategory,
40
- assetsData,
41
- }: SparkHelperCommon,
42
- _asset: string) => {
43
- const asset = wethToEth(_asset);
44
-
45
- const assetData = assetsData[asset];
46
- if (
47
- eModeCategory === 0
48
- || assetData.eModeCategory !== eModeCategory
49
- || new Dec(assetData?.eModeCategoryData?.collateralFactor || 0).eq(0)
50
- ) {
51
- const { liquidationRatio, collateralFactor } = assetData;
52
- return ({ liquidationRatio, collateralFactor });
53
- }
54
- const { liquidationRatio, collateralFactor } = assetData.eModeCategoryData;
55
- return ({ liquidationRatio, collateralFactor });
56
- };
57
-
58
- export const sparkGetAggregatedPositionData = ({
59
- usedAssets,
60
- eModeCategory,
61
- eModeCategories,
62
- assetsData,
63
- selectedMarket,
64
- network,
65
- ...rest
66
- }: SparkHelperCommon): SparkAggregatedPositionData => {
67
- const data = {
68
- usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
69
- };
70
- const payload = {} as SparkAggregatedPositionData;
71
- payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
72
- payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
73
- payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
74
- payload.borrowLimitUsd = getAssetsTotal(
75
- usedAssets,
76
- ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral,
77
- ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(sparkGetEmodeMutableProps(data, symbol).collateralFactor),
78
- );
79
- payload.liquidationLimitUsd = getAssetsTotal(
80
- usedAssets,
81
- ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral,
82
- ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(sparkGetEmodeMutableProps(data, symbol).liquidationRatio),
83
- );
84
- const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd);
85
- payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
86
- payload.ratio = +payload.suppliedUsd ? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
87
- payload.collRatio = +payload.suppliedUsd ? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
88
- const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData);
89
- payload.netApy = netApy;
90
- payload.incentiveUsd = incentiveUsd;
91
- payload.totalInterestUsd = totalInterestUsd;
92
- payload.liqRatio = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).toString();
93
- payload.liqPercent = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).mul(100).toString();
94
- const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets);
95
- payload.leveragedType = leveragedType;
96
- if (leveragedType !== '') {
97
- payload.leveragedAsset = leveragedAsset;
98
- let assetPrice = data.assetsData[leveragedAsset].price; // TODO sparkPrice or price??
99
- if (leveragedType === 'lsd-leverage') {
100
- // Treat ETH like a stablecoin in a long stETH position
101
- payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
102
- assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
103
- }
104
- payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
105
- }
106
- return payload;
1
+ import Dec from 'decimal.js';
2
+ import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
3
+ import {
4
+ SparkAggregatedPositionData,
5
+ SparkAssetsData, SparkHelperCommon, SparkUsedAssets,
6
+ } from '../../types';
7
+ import { calculateNetApy } from '../../staking';
8
+ import { wethToEth } from '../../services/utils';
9
+
10
+ export const sparkIsInIsolationMode = ({ usedAssets, assetsData }: { usedAssets: SparkUsedAssets, assetsData: SparkAssetsData }) => Object.values(usedAssets).some(({ symbol, collateral }) => collateral && assetsData[symbol].isIsolated);
11
+
12
+ export const sparkGetCollSuppliedAssets = ({ usedAssets }: { usedAssets: SparkUsedAssets }) => Object.values(usedAssets).filter(({ isSupplied, collateral }) => isSupplied && collateral);
13
+
14
+ export const sparkGetSuppliableAssets = ({
15
+ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest
16
+ }: SparkHelperCommon) => {
17
+ const data = {
18
+ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
19
+ };
20
+
21
+ const collAccountAssets = sparkGetCollSuppliedAssets(data);
22
+ const marketAssets = Object.values(assetsData);
23
+
24
+ if (sparkIsInIsolationMode(data)) {
25
+ const collAsset = collAccountAssets[0].symbol;
26
+ return marketAssets.filter(d => d.canBeSupplied).map(({ symbol }) => ({ symbol, canBeCollateral: symbol === collAsset }));
27
+ }
28
+
29
+ return marketAssets.filter(d => d.canBeSupplied).map(({ symbol, isIsolated }) => ({ symbol, canBeCollateral: !isIsolated }));
30
+ };
31
+
32
+ export const sparkGetSuppliableAsCollAssets = ({
33
+ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest
34
+ }: SparkHelperCommon) => sparkGetSuppliableAssets({
35
+ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
36
+ }).filter(({ canBeCollateral }) => canBeCollateral);
37
+
38
+ export const sparkGetEmodeMutableProps = ({
39
+ eModeCategory,
40
+ assetsData,
41
+ }: SparkHelperCommon,
42
+ _asset: string) => {
43
+ const asset = wethToEth(_asset);
44
+
45
+ const assetData = assetsData[asset];
46
+ if (
47
+ eModeCategory === 0
48
+ || assetData.eModeCategory !== eModeCategory
49
+ || new Dec(assetData?.eModeCategoryData?.collateralFactor || 0).eq(0)
50
+ ) {
51
+ const { liquidationRatio, collateralFactor } = assetData;
52
+ return ({ liquidationRatio, collateralFactor });
53
+ }
54
+ const { liquidationRatio, collateralFactor } = assetData.eModeCategoryData;
55
+ return ({ liquidationRatio, collateralFactor });
56
+ };
57
+
58
+ export const sparkGetAggregatedPositionData = ({
59
+ usedAssets,
60
+ eModeCategory,
61
+ eModeCategories,
62
+ assetsData,
63
+ selectedMarket,
64
+ network,
65
+ ...rest
66
+ }: SparkHelperCommon): SparkAggregatedPositionData => {
67
+ const data = {
68
+ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
69
+ };
70
+ const payload = {} as SparkAggregatedPositionData;
71
+ payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
72
+ payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
73
+ payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
74
+ payload.borrowLimitUsd = getAssetsTotal(
75
+ usedAssets,
76
+ ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral,
77
+ ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(sparkGetEmodeMutableProps(data, symbol).collateralFactor),
78
+ );
79
+ payload.liquidationLimitUsd = getAssetsTotal(
80
+ usedAssets,
81
+ ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral,
82
+ ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(sparkGetEmodeMutableProps(data, symbol).liquidationRatio),
83
+ );
84
+ const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd);
85
+ payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
86
+ payload.ratio = +payload.suppliedUsd ? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
87
+ payload.collRatio = +payload.suppliedUsd ? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
88
+ const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData);
89
+ payload.netApy = netApy;
90
+ payload.incentiveUsd = incentiveUsd;
91
+ payload.totalInterestUsd = totalInterestUsd;
92
+ payload.liqRatio = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).toString();
93
+ payload.liqPercent = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).mul(100).toString();
94
+ const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets);
95
+ payload.leveragedType = leveragedType;
96
+ if (leveragedType !== '') {
97
+ payload.leveragedAsset = leveragedAsset;
98
+ let assetPrice = data.assetsData[leveragedAsset].price; // TODO sparkPrice or price??
99
+ if (leveragedType === 'lsd-leverage') {
100
+ // Treat ETH like a stablecoin in a long stETH position
101
+ payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
102
+ assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
103
+ }
104
+ payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
105
+ }
106
+ return payload;
107
107
  };