@defisaver/positions-sdk 2.1.2 → 2.1.4

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 (100) hide show
  1. package/.mocharc.json +4 -4
  2. package/.nvmrc +1 -1
  3. package/README.md +64 -64
  4. package/cjs/helpers/aaveHelpers/index.js +8 -7
  5. package/cjs/helpers/morphoBlueHelpers/index.js +66 -66
  6. package/cjs/staking/eligibility.d.ts +4 -2
  7. package/cjs/staking/eligibility.js +3 -4
  8. package/cjs/staking/staking.d.ts +2 -1
  9. package/cjs/staking/staking.js +5 -4
  10. package/cjs/types/common.d.ts +1 -1
  11. package/cjs/types/common.js +1 -1
  12. package/esm/helpers/aaveHelpers/index.js +8 -7
  13. package/esm/helpers/morphoBlueHelpers/index.js +66 -66
  14. package/esm/staking/eligibility.d.ts +4 -2
  15. package/esm/staking/eligibility.js +3 -4
  16. package/esm/staking/staking.d.ts +2 -1
  17. package/esm/staking/staking.js +5 -4
  18. package/esm/types/common.d.ts +1 -1
  19. package/esm/types/common.js +1 -1
  20. package/package.json +47 -47
  21. package/src/aaveV2/index.ts +240 -240
  22. package/src/aaveV3/index.ts +614 -614
  23. package/src/aaveV3/merit.ts +94 -94
  24. package/src/aaveV3/merkl.ts +74 -74
  25. package/src/claiming/aaveV3.ts +154 -154
  26. package/src/claiming/compV3.ts +22 -22
  27. package/src/claiming/index.ts +12 -12
  28. package/src/claiming/king.ts +66 -66
  29. package/src/claiming/morphoBlue.ts +118 -118
  30. package/src/claiming/spark.ts +225 -225
  31. package/src/compoundV2/index.ts +244 -244
  32. package/src/compoundV3/index.ts +274 -274
  33. package/src/config/contracts.ts +1228 -1228
  34. package/src/constants/index.ts +10 -10
  35. package/src/contracts.ts +120 -120
  36. package/src/curveUsd/index.ts +250 -250
  37. package/src/eulerV2/index.ts +324 -324
  38. package/src/exchange/index.ts +25 -25
  39. package/src/fluid/index.ts +1638 -1638
  40. package/src/helpers/aaveHelpers/index.ts +185 -183
  41. package/src/helpers/compoundHelpers/index.ts +283 -283
  42. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  43. package/src/helpers/eulerHelpers/index.ts +222 -222
  44. package/src/helpers/fluidHelpers/index.ts +326 -326
  45. package/src/helpers/index.ts +10 -10
  46. package/src/helpers/liquityV2Helpers/index.ts +82 -82
  47. package/src/helpers/llamaLendHelpers/index.ts +53 -53
  48. package/src/helpers/makerHelpers/index.ts +52 -52
  49. package/src/helpers/morphoBlueHelpers/index.ts +396 -396
  50. package/src/helpers/sparkHelpers/index.ts +155 -155
  51. package/src/index.ts +47 -47
  52. package/src/liquity/index.ts +159 -159
  53. package/src/liquityV2/index.ts +657 -657
  54. package/src/llamaLend/index.ts +305 -305
  55. package/src/maker/index.ts +223 -223
  56. package/src/markets/aave/index.ts +116 -116
  57. package/src/markets/aave/marketAssets.ts +49 -49
  58. package/src/markets/compound/index.ts +227 -227
  59. package/src/markets/compound/marketsAssets.ts +90 -90
  60. package/src/markets/curveUsd/index.ts +69 -69
  61. package/src/markets/euler/index.ts +26 -26
  62. package/src/markets/fluid/index.ts +2456 -2456
  63. package/src/markets/index.ts +25 -25
  64. package/src/markets/liquityV2/index.ts +102 -102
  65. package/src/markets/llamaLend/contractAddresses.ts +141 -141
  66. package/src/markets/llamaLend/index.ts +235 -235
  67. package/src/markets/morphoBlue/index.ts +895 -895
  68. package/src/markets/spark/index.ts +29 -29
  69. package/src/markets/spark/marketAssets.ts +11 -11
  70. package/src/moneymarket/moneymarketCommonService.ts +80 -80
  71. package/src/morphoBlue/index.ts +274 -274
  72. package/src/portfolio/index.ts +570 -570
  73. package/src/services/priceService.ts +159 -159
  74. package/src/services/utils.ts +99 -99
  75. package/src/services/viem.ts +32 -32
  76. package/src/setup.ts +8 -8
  77. package/src/spark/index.ts +445 -445
  78. package/src/staking/eligibility.ts +59 -60
  79. package/src/staking/index.ts +1 -1
  80. package/src/staking/staking.ts +170 -170
  81. package/src/types/aave.ts +189 -189
  82. package/src/types/claiming.ts +109 -109
  83. package/src/types/common.ts +105 -105
  84. package/src/types/compound.ts +136 -136
  85. package/src/types/curveUsd.ts +121 -121
  86. package/src/types/euler.ts +175 -175
  87. package/src/types/fluid.ts +448 -448
  88. package/src/types/index.ts +13 -13
  89. package/src/types/liquity.ts +30 -30
  90. package/src/types/liquityV2.ts +126 -126
  91. package/src/types/llamaLend.ts +159 -159
  92. package/src/types/maker.ts +63 -63
  93. package/src/types/merit.ts +1 -1
  94. package/src/types/merkl.ts +70 -70
  95. package/src/types/morphoBlue.ts +194 -194
  96. package/src/types/portfolio.ts +60 -60
  97. package/src/types/spark.ts +135 -135
  98. package/src/umbrella/index.ts +69 -69
  99. package/src/umbrella/umbrellaUtils.ts +29 -29
  100. package/CLAUDE.md +0 -32
@@ -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
  };