@defisaver/positions-sdk 2.1.52-aave-v4 → 2.1.52-dev-2

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 (199) hide show
  1. package/.mocharc.json +4 -4
  2. package/.nvmrc +1 -1
  3. package/README.md +64 -64
  4. package/cjs/config/contracts.d.ts +0 -1277
  5. package/cjs/config/contracts.js +0 -9
  6. package/cjs/contracts.d.ts +0 -23120
  7. package/cjs/contracts.js +1 -2
  8. package/cjs/fluid/index.d.ts +3 -3
  9. package/cjs/helpers/aaveHelpers/index.d.ts +2 -2
  10. package/cjs/helpers/aaveHelpers/index.js +18 -2
  11. package/cjs/helpers/compoundHelpers/index.js +1 -1
  12. package/cjs/helpers/eulerHelpers/index.d.ts +2 -2
  13. package/cjs/helpers/eulerHelpers/index.js +6 -5
  14. package/cjs/helpers/fluidHelpers/index.js +2 -1
  15. package/cjs/helpers/index.d.ts +0 -1
  16. package/cjs/helpers/index.js +1 -2
  17. package/cjs/helpers/morphoBlueHelpers/index.js +67 -67
  18. package/cjs/helpers/sparkHelpers/index.js +1 -1
  19. package/cjs/index.d.ts +1 -2
  20. package/cjs/index.js +1 -3
  21. package/cjs/markets/index.d.ts +0 -1
  22. package/cjs/markets/index.js +1 -3
  23. package/cjs/moneymarket/moneymarketCommonService.d.ts +3 -3
  24. package/cjs/moneymarket/moneymarketCommonService.js +14 -6
  25. package/cjs/portfolio/index.js +0 -20
  26. package/cjs/savings/morphoVaults/index.js +17 -17
  27. package/cjs/types/aave.d.ts +3 -2
  28. package/cjs/types/common.d.ts +8 -0
  29. package/cjs/types/common.js +10 -1
  30. package/cjs/types/compound.d.ts +2 -2
  31. package/cjs/types/curveUsd.d.ts +2 -2
  32. package/cjs/types/euler.d.ts +2 -2
  33. package/cjs/types/fluid.d.ts +2 -2
  34. package/cjs/types/index.d.ts +0 -1
  35. package/cjs/types/index.js +0 -1
  36. package/cjs/types/liquityV2.d.ts +3 -3
  37. package/cjs/types/llamaLend.d.ts +2 -2
  38. package/cjs/types/morphoBlue.d.ts +3 -3
  39. package/cjs/types/portfolio.d.ts +0 -4
  40. package/cjs/types/spark.d.ts +2 -2
  41. package/esm/config/contracts.d.ts +0 -1277
  42. package/esm/config/contracts.js +0 -8
  43. package/esm/contracts.d.ts +0 -23120
  44. package/esm/contracts.js +0 -1
  45. package/esm/fluid/index.d.ts +3 -3
  46. package/esm/helpers/aaveHelpers/index.d.ts +2 -2
  47. package/esm/helpers/aaveHelpers/index.js +18 -2
  48. package/esm/helpers/compoundHelpers/index.js +2 -2
  49. package/esm/helpers/eulerHelpers/index.d.ts +2 -2
  50. package/esm/helpers/eulerHelpers/index.js +6 -5
  51. package/esm/helpers/fluidHelpers/index.js +2 -1
  52. package/esm/helpers/index.d.ts +0 -1
  53. package/esm/helpers/index.js +0 -1
  54. package/esm/helpers/morphoBlueHelpers/index.js +68 -68
  55. package/esm/helpers/sparkHelpers/index.js +2 -2
  56. package/esm/index.d.ts +1 -2
  57. package/esm/index.js +1 -2
  58. package/esm/markets/index.d.ts +0 -1
  59. package/esm/markets/index.js +0 -1
  60. package/esm/moneymarket/moneymarketCommonService.d.ts +3 -3
  61. package/esm/moneymarket/moneymarketCommonService.js +14 -6
  62. package/esm/portfolio/index.js +1 -21
  63. package/esm/savings/morphoVaults/index.js +17 -17
  64. package/esm/types/aave.d.ts +3 -2
  65. package/esm/types/common.d.ts +8 -0
  66. package/esm/types/common.js +9 -0
  67. package/esm/types/compound.d.ts +2 -2
  68. package/esm/types/curveUsd.d.ts +2 -2
  69. package/esm/types/euler.d.ts +2 -2
  70. package/esm/types/fluid.d.ts +2 -2
  71. package/esm/types/fluid.js +1 -1
  72. package/esm/types/index.d.ts +0 -1
  73. package/esm/types/index.js +0 -1
  74. package/esm/types/liquityV2.d.ts +3 -3
  75. package/esm/types/llamaLend.d.ts +2 -2
  76. package/esm/types/morphoBlue.d.ts +3 -3
  77. package/esm/types/portfolio.d.ts +0 -4
  78. package/esm/types/spark.d.ts +2 -2
  79. package/package.json +48 -48
  80. package/src/aaveV2/index.ts +240 -240
  81. package/src/aaveV3/index.ts +635 -635
  82. package/src/aaveV3/merit.ts +97 -97
  83. package/src/aaveV3/merkl.ts +74 -74
  84. package/src/claiming/aaveV3.ts +154 -154
  85. package/src/claiming/compV3.ts +22 -22
  86. package/src/claiming/ethena.ts +61 -61
  87. package/src/claiming/index.ts +12 -12
  88. package/src/claiming/king.ts +66 -66
  89. package/src/claiming/morphoBlue.ts +118 -118
  90. package/src/claiming/spark.ts +225 -225
  91. package/src/compoundV2/index.ts +244 -244
  92. package/src/compoundV3/index.ts +274 -274
  93. package/src/config/contracts.ts +1320 -1328
  94. package/src/constants/index.ts +10 -10
  95. package/src/contracts.ts +172 -174
  96. package/src/curveUsd/index.ts +254 -254
  97. package/src/eulerV2/index.ts +324 -324
  98. package/src/exchange/index.ts +25 -25
  99. package/src/fluid/index.ts +1800 -1800
  100. package/src/helpers/aaveHelpers/index.ts +207 -191
  101. package/src/helpers/compoundHelpers/index.ts +283 -283
  102. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  103. package/src/helpers/eulerHelpers/index.ts +222 -222
  104. package/src/helpers/fluidHelpers/index.ts +326 -326
  105. package/src/helpers/index.ts +10 -11
  106. package/src/helpers/liquityV2Helpers/index.ts +82 -82
  107. package/src/helpers/llamaLendHelpers/index.ts +53 -53
  108. package/src/helpers/makerHelpers/index.ts +52 -52
  109. package/src/helpers/morphoBlueHelpers/index.ts +396 -396
  110. package/src/helpers/sparkHelpers/index.ts +160 -158
  111. package/src/index.ts +49 -51
  112. package/src/liquity/index.ts +159 -159
  113. package/src/liquityV2/index.ts +703 -703
  114. package/src/llamaLend/index.ts +305 -305
  115. package/src/maker/index.ts +223 -223
  116. package/src/markets/aave/index.ts +118 -118
  117. package/src/markets/aave/marketAssets.ts +54 -54
  118. package/src/markets/compound/index.ts +243 -243
  119. package/src/markets/compound/marketsAssets.ts +97 -97
  120. package/src/markets/curveUsd/index.ts +69 -69
  121. package/src/markets/euler/index.ts +26 -26
  122. package/src/markets/fluid/index.ts +2900 -2900
  123. package/src/markets/index.ts +25 -26
  124. package/src/markets/liquityV2/index.ts +102 -102
  125. package/src/markets/llamaLend/contractAddresses.ts +141 -141
  126. package/src/markets/llamaLend/index.ts +235 -235
  127. package/src/markets/morphoBlue/index.ts +988 -988
  128. package/src/markets/spark/index.ts +29 -29
  129. package/src/markets/spark/marketAssets.ts +12 -12
  130. package/src/moneymarket/moneymarketCommonService.ts +92 -85
  131. package/src/morphoBlue/index.ts +274 -274
  132. package/src/portfolio/index.ts +586 -606
  133. package/src/savings/index.ts +95 -95
  134. package/src/savings/makerDsr/index.ts +53 -53
  135. package/src/savings/makerDsr/options.ts +9 -9
  136. package/src/savings/morphoVaults/index.ts +80 -80
  137. package/src/savings/morphoVaults/options.ts +193 -193
  138. package/src/savings/skyOptions/index.ts +95 -95
  139. package/src/savings/skyOptions/options.ts +10 -10
  140. package/src/savings/sparkSavingsVaults/index.ts +60 -60
  141. package/src/savings/sparkSavingsVaults/options.ts +35 -35
  142. package/src/savings/yearnV3Vaults/index.ts +61 -61
  143. package/src/savings/yearnV3Vaults/options.ts +55 -55
  144. package/src/savings/yearnVaults/index.ts +73 -73
  145. package/src/savings/yearnVaults/options.ts +32 -32
  146. package/src/services/priceService.ts +278 -278
  147. package/src/services/utils.ts +115 -115
  148. package/src/services/viem.ts +57 -57
  149. package/src/setup.ts +8 -8
  150. package/src/spark/index.ts +459 -459
  151. package/src/staking/eligibility.ts +53 -53
  152. package/src/staking/index.ts +1 -1
  153. package/src/staking/staking.ts +192 -192
  154. package/src/types/aave.ts +200 -198
  155. package/src/types/claiming.ts +114 -114
  156. package/src/types/common.ts +116 -107
  157. package/src/types/compound.ts +145 -144
  158. package/src/types/curveUsd.ts +123 -123
  159. package/src/types/euler.ts +176 -175
  160. package/src/types/fluid.ts +485 -483
  161. package/src/types/index.ts +15 -16
  162. package/src/types/liquity.ts +30 -30
  163. package/src/types/liquityV2.ts +128 -126
  164. package/src/types/llamaLend.ts +161 -159
  165. package/src/types/maker.ts +63 -63
  166. package/src/types/merit.ts +1 -1
  167. package/src/types/merkl.ts +70 -70
  168. package/src/types/morphoBlue.ts +202 -202
  169. package/src/types/portfolio.ts +60 -64
  170. package/src/types/savings/index.ts +23 -23
  171. package/src/types/savings/makerDsr.ts +13 -13
  172. package/src/types/savings/morphoVaults.ts +32 -32
  173. package/src/types/savings/sky.ts +14 -14
  174. package/src/types/savings/sparkSavingsVaults.ts +15 -15
  175. package/src/types/savings/yearnV3Vaults.ts +17 -17
  176. package/src/types/savings/yearnVaults.ts +14 -14
  177. package/src/types/spark.ts +135 -134
  178. package/src/umbrella/index.ts +69 -69
  179. package/src/umbrella/umbrellaUtils.ts +29 -29
  180. package/cjs/aaveV4/index.d.ts +0 -7
  181. package/cjs/aaveV4/index.js +0 -174
  182. package/cjs/helpers/aaveV4Helpers/index.d.ts +0 -13
  183. package/cjs/helpers/aaveV4Helpers/index.js +0 -109
  184. package/cjs/markets/aaveV4/index.d.ts +0 -13
  185. package/cjs/markets/aaveV4/index.js +0 -39
  186. package/cjs/types/aaveV4.d.ts +0 -137
  187. package/cjs/types/aaveV4.js +0 -11
  188. package/esm/aaveV4/index.d.ts +0 -7
  189. package/esm/aaveV4/index.js +0 -165
  190. package/esm/helpers/aaveV4Helpers/index.d.ts +0 -13
  191. package/esm/helpers/aaveV4Helpers/index.js +0 -100
  192. package/esm/markets/aaveV4/index.d.ts +0 -13
  193. package/esm/markets/aaveV4/index.js +0 -29
  194. package/esm/types/aaveV4.d.ts +0 -137
  195. package/esm/types/aaveV4.js +0 -8
  196. package/src/aaveV4/index.ts +0 -176
  197. package/src/helpers/aaveV4Helpers/index.ts +0 -121
  198. package/src/markets/aaveV4/index.ts +0 -42
  199. package/src/types/aaveV4.ts +0 -151
@@ -1,160 +1,160 @@
1
- import Dec from 'decimal.js';
2
- import { assetAmountInEth, getAssetInfo } from '@defisaver/tokens';
3
- import { Client } from 'viem';
4
- import {
5
- Blockish, EthAddress, EthereumProvider, NetworkNumber, PositionBalances,
6
- } from '../types/common';
7
- import {
8
- LiquityActivePoolContractViem,
9
- LiquityCollSurplusPoolContractViem,
10
- LiquityLQTYStakingViem,
11
- LiquityPriceFeedContractViem,
12
- LiquityStabilityPoolViem,
13
- LiquityTroveManagerContractViem,
14
- LiquityViewContractViem,
15
- } from '../contracts';
16
- import { LIQUITY_TROVE_STATUS_ENUM, LiquityTroveInfo } from '../types';
17
- import { ZERO_ADDRESS } from '../constants';
18
- import { getViemProvider, setViemBlockNumber } from '../services/viem';
19
- import { getEthAmountForDecimals } from '../services/utils';
20
-
21
- export const LIQUITY_NORMAL_MODE_RATIO = 110; // MCR
22
- export const LIQUITY_RECOVERY_MODE_RATIO = 150; // CCR
23
-
24
- export const _getLiquityAccountBalances = async (provider: Client, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress): Promise<PositionBalances> => {
25
- let balances: PositionBalances = {
26
- collateral: {},
27
- debt: {},
28
- };
29
-
30
- if (!address) {
31
- return balances;
32
- }
33
-
34
- const viewContract = LiquityViewContractViem(provider, network, block);
35
- const troveInfo = await viewContract.read.getTroveInfo([address], setViemBlockNumber(block));
36
-
37
- balances = {
38
- collateral: {
39
- [addressMapping ? getAssetInfo('ETH', network).address.toLowerCase() : 'ETH']: troveInfo[1].toString(),
40
- },
41
- debt: {
42
- [addressMapping ? getAssetInfo('LUSD', network).address.toLowerCase() : 'LUSD']: troveInfo[2].toString(),
43
- },
44
- };
45
-
46
- return balances;
47
- };
48
-
49
- export const getLiquityAccountBalances = async (provider: EthereumProvider, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress): Promise<PositionBalances> => _getLiquityAccountBalances(getViemProvider(provider, network), network, block, addressMapping, address);
50
-
51
- const _getDebtInFront = async (viewContract: any, address: EthAddress, accumulatedSum = '0', iterations = 2000): Promise<string> => {
52
- const res = await viewContract.read.getDebtInFront([address, accumulatedSum, iterations]);
53
- const debt = res[1].toString();
54
- const next = res[0];
55
- if (next === ZERO_ADDRESS) return assetAmountInEth(debt, 'LUSD');
56
- return _getDebtInFront(viewContract, next, debt, iterations);
57
- };
58
-
59
- export const getDebtInFront = async (provider: EthereumProvider, address: EthAddress): Promise<string> => {
60
- const client = getViemProvider(provider, NetworkNumber.Eth);
61
- const viewContract = LiquityViewContractViem(client, NetworkNumber.Eth);
62
- return _getDebtInFront(viewContract, address);
63
- };
64
-
65
- export const _getLiquityTroveInfo = async (provider: Client, network: NetworkNumber, address: EthAddress): Promise<LiquityTroveInfo> => {
66
- const viewContract = LiquityViewContractViem(provider, network);
67
- const collSurplusPoolContract = LiquityCollSurplusPoolContractViem(provider, network);
68
- const troveManagerContract = LiquityTroveManagerContractViem(provider, network);
69
- const priceFeedContract = LiquityPriceFeedContractViem(provider, network);
70
- const activePoolContract = LiquityActivePoolContractViem(provider, network);
71
-
72
- const [
73
- troveInfo,
74
- collSurplusInfo,
75
- borrowingRateWithDecay,
76
- assetPrice,
77
- totalETH,
78
- totalLUSD,
79
- debtInFront,
80
- ] = await Promise.all([
81
- viewContract.read.getTroveInfo([address]),
82
- collSurplusPoolContract.read.getCollateral([address]),
83
- troveManagerContract.read.getBorrowingRateWithDecay(),
84
- priceFeedContract.read.fetchPrice(),
85
- activePoolContract.read.getETH(),
86
- activePoolContract.read.getLUSDDebt(),
87
- _getDebtInFront(viewContract, address),
88
- ]);
89
-
90
- const recoveryMode = troveInfo[6];
91
-
92
- const payload = {
93
- troveStatus: LIQUITY_TROVE_STATUS_ENUM[+(troveInfo[0].toString())],
94
- collateral: assetAmountInEth(troveInfo[1].toString()),
95
- debtInAsset: assetAmountInEth(troveInfo[2].toString()),
96
- TCRatio: assetAmountInEth(troveInfo[4].toString()),
97
- recoveryMode,
98
- claimableCollateral: assetAmountInEth(collSurplusInfo.toString()),
99
- borrowingRateWithDecay: assetAmountInEth(borrowingRateWithDecay.toString()),
100
- assetPrice: assetAmountInEth(assetPrice.toString()),
101
- totalETH: totalETH.toString(),
102
- totalLUSD: totalLUSD.toString(),
103
- debtInFront: debtInFront.toString(),
104
- minCollateralRatio: recoveryMode ? LIQUITY_RECOVERY_MODE_RATIO : LIQUITY_NORMAL_MODE_RATIO,
105
- priceForRecovery: new Dec(recoveryMode ? LIQUITY_RECOVERY_MODE_RATIO : LIQUITY_NORMAL_MODE_RATIO).mul(totalLUSD).div(totalETH).div(100)
106
- .toString(),
107
- };
108
-
109
- return payload;
110
- };
111
-
112
- export const getLiquityTroveInfo = async (provider: EthereumProvider, network: NetworkNumber, address: EthAddress): Promise<LiquityTroveInfo> => _getLiquityTroveInfo(getViemProvider(provider, network, { batch: { multicall: true } }), network, address);
113
-
114
- export const getLiquityStakingData = async (provider: Client, network: NetworkNumber, address: EthAddress) => {
115
- const lqtyStakingView = LiquityLQTYStakingViem(provider, network);
116
- const stabilityPoolView = LiquityStabilityPoolViem(provider, network);
117
- const [
118
- stakes,
119
- pendingETHGain,
120
- pendingLUSDGain,
121
- totalLQTYStakes,
122
- stabilityPoolETHGain,
123
- stabilityPoolLQTYGain,
124
- compoundedLUSDDeposit,
125
- totalLUSDDeposits,
126
- ] = await Promise.all([
127
- lqtyStakingView.read.stakes([address]),
128
- lqtyStakingView.read.getPendingETHGain([address]),
129
- lqtyStakingView.read.getPendingLUSDGain([address]),
130
- lqtyStakingView.read.totalLQTYStaked(),
131
- stabilityPoolView.read.getDepositorETHGain([address]),
132
- stabilityPoolView.read.getDepositorLQTYGain([address]),
133
- stabilityPoolView.read.getCompoundedLUSDDeposit([address]),
134
- stabilityPoolView.read.getTotalLUSDDeposits(),
135
- ]);
136
- const totalLUSDDeposited = getEthAmountForDecimals(totalLUSDDeposits as string, 18);
137
- const totalLQTYStaked = getEthAmountForDecimals(totalLQTYStakes as string, 18);
138
- const stakedLQTY = getEthAmountForDecimals(stakes as string, 18);
139
- const stakedLUSDBalance = getEthAmountForDecimals(compoundedLUSDDeposit as string, 18);
140
- const rewardETH = getEthAmountForDecimals(pendingETHGain as string, 18);
141
- const rewardLUSD = getEthAmountForDecimals(pendingLUSDGain as string, 18);
142
- const stabilityRewardETH = getEthAmountForDecimals(stabilityPoolETHGain as string, 18);
143
- const stabilityRewardLQTY = getEthAmountForDecimals(stabilityPoolLQTYGain as string, 18);
144
-
145
- const showStakingBalances = !!(+stakedLQTY || +stakedLUSDBalance
146
- || +rewardETH || +rewardLUSD
147
- || +stabilityRewardETH || +stabilityRewardLQTY);
148
-
149
- return {
150
- totalLUSDDeposited,
151
- totalLQTYStaked,
152
- stakedLQTY,
153
- stakedLUSDBalance,
154
- rewardETH,
155
- rewardLUSD,
156
- stabilityRewardETH,
157
- stabilityRewardLQTY,
158
- showStakingBalances,
159
- };
1
+ import Dec from 'decimal.js';
2
+ import { assetAmountInEth, getAssetInfo } from '@defisaver/tokens';
3
+ import { Client } from 'viem';
4
+ import {
5
+ Blockish, EthAddress, EthereumProvider, NetworkNumber, PositionBalances,
6
+ } from '../types/common';
7
+ import {
8
+ LiquityActivePoolContractViem,
9
+ LiquityCollSurplusPoolContractViem,
10
+ LiquityLQTYStakingViem,
11
+ LiquityPriceFeedContractViem,
12
+ LiquityStabilityPoolViem,
13
+ LiquityTroveManagerContractViem,
14
+ LiquityViewContractViem,
15
+ } from '../contracts';
16
+ import { LIQUITY_TROVE_STATUS_ENUM, LiquityTroveInfo } from '../types';
17
+ import { ZERO_ADDRESS } from '../constants';
18
+ import { getViemProvider, setViemBlockNumber } from '../services/viem';
19
+ import { getEthAmountForDecimals } from '../services/utils';
20
+
21
+ export const LIQUITY_NORMAL_MODE_RATIO = 110; // MCR
22
+ export const LIQUITY_RECOVERY_MODE_RATIO = 150; // CCR
23
+
24
+ export const _getLiquityAccountBalances = async (provider: Client, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress): Promise<PositionBalances> => {
25
+ let balances: PositionBalances = {
26
+ collateral: {},
27
+ debt: {},
28
+ };
29
+
30
+ if (!address) {
31
+ return balances;
32
+ }
33
+
34
+ const viewContract = LiquityViewContractViem(provider, network, block);
35
+ const troveInfo = await viewContract.read.getTroveInfo([address], setViemBlockNumber(block));
36
+
37
+ balances = {
38
+ collateral: {
39
+ [addressMapping ? getAssetInfo('ETH', network).address.toLowerCase() : 'ETH']: troveInfo[1].toString(),
40
+ },
41
+ debt: {
42
+ [addressMapping ? getAssetInfo('LUSD', network).address.toLowerCase() : 'LUSD']: troveInfo[2].toString(),
43
+ },
44
+ };
45
+
46
+ return balances;
47
+ };
48
+
49
+ export const getLiquityAccountBalances = async (provider: EthereumProvider, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress): Promise<PositionBalances> => _getLiquityAccountBalances(getViemProvider(provider, network), network, block, addressMapping, address);
50
+
51
+ const _getDebtInFront = async (viewContract: any, address: EthAddress, accumulatedSum = '0', iterations = 2000): Promise<string> => {
52
+ const res = await viewContract.read.getDebtInFront([address, accumulatedSum, iterations]);
53
+ const debt = res[1].toString();
54
+ const next = res[0];
55
+ if (next === ZERO_ADDRESS) return assetAmountInEth(debt, 'LUSD');
56
+ return _getDebtInFront(viewContract, next, debt, iterations);
57
+ };
58
+
59
+ export const getDebtInFront = async (provider: EthereumProvider, address: EthAddress): Promise<string> => {
60
+ const client = getViemProvider(provider, NetworkNumber.Eth);
61
+ const viewContract = LiquityViewContractViem(client, NetworkNumber.Eth);
62
+ return _getDebtInFront(viewContract, address);
63
+ };
64
+
65
+ export const _getLiquityTroveInfo = async (provider: Client, network: NetworkNumber, address: EthAddress): Promise<LiquityTroveInfo> => {
66
+ const viewContract = LiquityViewContractViem(provider, network);
67
+ const collSurplusPoolContract = LiquityCollSurplusPoolContractViem(provider, network);
68
+ const troveManagerContract = LiquityTroveManagerContractViem(provider, network);
69
+ const priceFeedContract = LiquityPriceFeedContractViem(provider, network);
70
+ const activePoolContract = LiquityActivePoolContractViem(provider, network);
71
+
72
+ const [
73
+ troveInfo,
74
+ collSurplusInfo,
75
+ borrowingRateWithDecay,
76
+ assetPrice,
77
+ totalETH,
78
+ totalLUSD,
79
+ debtInFront,
80
+ ] = await Promise.all([
81
+ viewContract.read.getTroveInfo([address]),
82
+ collSurplusPoolContract.read.getCollateral([address]),
83
+ troveManagerContract.read.getBorrowingRateWithDecay(),
84
+ priceFeedContract.read.fetchPrice(),
85
+ activePoolContract.read.getETH(),
86
+ activePoolContract.read.getLUSDDebt(),
87
+ _getDebtInFront(viewContract, address),
88
+ ]);
89
+
90
+ const recoveryMode = troveInfo[6];
91
+
92
+ const payload = {
93
+ troveStatus: LIQUITY_TROVE_STATUS_ENUM[+(troveInfo[0].toString())],
94
+ collateral: assetAmountInEth(troveInfo[1].toString()),
95
+ debtInAsset: assetAmountInEth(troveInfo[2].toString()),
96
+ TCRatio: assetAmountInEth(troveInfo[4].toString()),
97
+ recoveryMode,
98
+ claimableCollateral: assetAmountInEth(collSurplusInfo.toString()),
99
+ borrowingRateWithDecay: assetAmountInEth(borrowingRateWithDecay.toString()),
100
+ assetPrice: assetAmountInEth(assetPrice.toString()),
101
+ totalETH: totalETH.toString(),
102
+ totalLUSD: totalLUSD.toString(),
103
+ debtInFront: debtInFront.toString(),
104
+ minCollateralRatio: recoveryMode ? LIQUITY_RECOVERY_MODE_RATIO : LIQUITY_NORMAL_MODE_RATIO,
105
+ priceForRecovery: new Dec(recoveryMode ? LIQUITY_RECOVERY_MODE_RATIO : LIQUITY_NORMAL_MODE_RATIO).mul(totalLUSD).div(totalETH).div(100)
106
+ .toString(),
107
+ };
108
+
109
+ return payload;
110
+ };
111
+
112
+ export const getLiquityTroveInfo = async (provider: EthereumProvider, network: NetworkNumber, address: EthAddress): Promise<LiquityTroveInfo> => _getLiquityTroveInfo(getViemProvider(provider, network, { batch: { multicall: true } }), network, address);
113
+
114
+ export const getLiquityStakingData = async (provider: Client, network: NetworkNumber, address: EthAddress) => {
115
+ const lqtyStakingView = LiquityLQTYStakingViem(provider, network);
116
+ const stabilityPoolView = LiquityStabilityPoolViem(provider, network);
117
+ const [
118
+ stakes,
119
+ pendingETHGain,
120
+ pendingLUSDGain,
121
+ totalLQTYStakes,
122
+ stabilityPoolETHGain,
123
+ stabilityPoolLQTYGain,
124
+ compoundedLUSDDeposit,
125
+ totalLUSDDeposits,
126
+ ] = await Promise.all([
127
+ lqtyStakingView.read.stakes([address]),
128
+ lqtyStakingView.read.getPendingETHGain([address]),
129
+ lqtyStakingView.read.getPendingLUSDGain([address]),
130
+ lqtyStakingView.read.totalLQTYStaked(),
131
+ stabilityPoolView.read.getDepositorETHGain([address]),
132
+ stabilityPoolView.read.getDepositorLQTYGain([address]),
133
+ stabilityPoolView.read.getCompoundedLUSDDeposit([address]),
134
+ stabilityPoolView.read.getTotalLUSDDeposits(),
135
+ ]);
136
+ const totalLUSDDeposited = getEthAmountForDecimals(totalLUSDDeposits as string, 18);
137
+ const totalLQTYStaked = getEthAmountForDecimals(totalLQTYStakes as string, 18);
138
+ const stakedLQTY = getEthAmountForDecimals(stakes as string, 18);
139
+ const stakedLUSDBalance = getEthAmountForDecimals(compoundedLUSDDeposit as string, 18);
140
+ const rewardETH = getEthAmountForDecimals(pendingETHGain as string, 18);
141
+ const rewardLUSD = getEthAmountForDecimals(pendingLUSDGain as string, 18);
142
+ const stabilityRewardETH = getEthAmountForDecimals(stabilityPoolETHGain as string, 18);
143
+ const stabilityRewardLQTY = getEthAmountForDecimals(stabilityPoolLQTYGain as string, 18);
144
+
145
+ const showStakingBalances = !!(+stakedLQTY || +stakedLUSDBalance
146
+ || +rewardETH || +rewardLUSD
147
+ || +stabilityRewardETH || +stabilityRewardLQTY);
148
+
149
+ return {
150
+ totalLUSDDeposited,
151
+ totalLQTYStaked,
152
+ stakedLQTY,
153
+ stakedLUSDBalance,
154
+ rewardETH,
155
+ rewardLUSD,
156
+ stabilityRewardETH,
157
+ stabilityRewardLQTY,
158
+ showStakingBalances,
159
+ };
160
160
  };