@defisaver/positions-sdk 2.1.9 → 2.1.11

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 (102) hide show
  1. package/.mocharc.json +4 -4
  2. package/.nvmrc +1 -1
  3. package/README.md +64 -64
  4. package/cjs/helpers/morphoBlueHelpers/index.js +66 -66
  5. package/cjs/helpers/sparkHelpers/index.d.ts +4 -4
  6. package/cjs/helpers/sparkHelpers/index.js +12 -12
  7. package/cjs/markets/aave/marketAssets.js +1 -1
  8. package/cjs/portfolio/index.js +1 -1
  9. package/cjs/spark/index.d.ts +3 -1
  10. package/cjs/spark/index.js +26 -26
  11. package/cjs/staking/staking.js +5 -1
  12. package/cjs/types/spark.d.ts +3 -4
  13. package/esm/helpers/morphoBlueHelpers/index.js +66 -66
  14. package/esm/helpers/sparkHelpers/index.d.ts +4 -4
  15. package/esm/helpers/sparkHelpers/index.js +13 -13
  16. package/esm/markets/aave/marketAssets.js +1 -1
  17. package/esm/portfolio/index.js +1 -1
  18. package/esm/spark/index.d.ts +3 -1
  19. package/esm/spark/index.js +27 -27
  20. package/esm/staking/staking.js +5 -1
  21. package/esm/types/spark.d.ts +3 -4
  22. package/package.json +47 -47
  23. package/src/aaveV2/index.ts +240 -240
  24. package/src/aaveV3/index.ts +614 -614
  25. package/src/aaveV3/merit.ts +97 -97
  26. package/src/aaveV3/merkl.ts +74 -74
  27. package/src/claiming/aaveV3.ts +154 -154
  28. package/src/claiming/compV3.ts +22 -22
  29. package/src/claiming/index.ts +12 -12
  30. package/src/claiming/king.ts +66 -66
  31. package/src/claiming/morphoBlue.ts +118 -118
  32. package/src/claiming/spark.ts +225 -225
  33. package/src/compoundV2/index.ts +244 -244
  34. package/src/compoundV3/index.ts +274 -274
  35. package/src/config/contracts.ts +1251 -1251
  36. package/src/constants/index.ts +10 -10
  37. package/src/contracts.ts +120 -120
  38. package/src/curveUsd/index.ts +254 -254
  39. package/src/eulerV2/index.ts +324 -324
  40. package/src/exchange/index.ts +25 -25
  41. package/src/fluid/index.ts +1668 -1668
  42. package/src/helpers/aaveHelpers/index.ts +187 -187
  43. package/src/helpers/compoundHelpers/index.ts +283 -283
  44. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  45. package/src/helpers/eulerHelpers/index.ts +222 -222
  46. package/src/helpers/fluidHelpers/index.ts +326 -326
  47. package/src/helpers/index.ts +10 -10
  48. package/src/helpers/liquityV2Helpers/index.ts +82 -82
  49. package/src/helpers/llamaLendHelpers/index.ts +53 -53
  50. package/src/helpers/makerHelpers/index.ts +52 -52
  51. package/src/helpers/morphoBlueHelpers/index.ts +396 -396
  52. package/src/helpers/sparkHelpers/index.ts +158 -155
  53. package/src/index.ts +47 -47
  54. package/src/liquity/index.ts +159 -159
  55. package/src/liquityV2/index.ts +657 -657
  56. package/src/llamaLend/index.ts +305 -305
  57. package/src/maker/index.ts +223 -223
  58. package/src/markets/aave/index.ts +116 -116
  59. package/src/markets/aave/marketAssets.ts +54 -54
  60. package/src/markets/compound/index.ts +238 -238
  61. package/src/markets/compound/marketsAssets.ts +97 -97
  62. package/src/markets/curveUsd/index.ts +69 -69
  63. package/src/markets/euler/index.ts +26 -26
  64. package/src/markets/fluid/index.ts +2460 -2460
  65. package/src/markets/index.ts +25 -25
  66. package/src/markets/liquityV2/index.ts +102 -102
  67. package/src/markets/llamaLend/contractAddresses.ts +141 -141
  68. package/src/markets/llamaLend/index.ts +235 -235
  69. package/src/markets/morphoBlue/index.ts +895 -895
  70. package/src/markets/spark/index.ts +29 -29
  71. package/src/markets/spark/marketAssets.ts +12 -12
  72. package/src/moneymarket/moneymarketCommonService.ts +80 -80
  73. package/src/morphoBlue/index.ts +274 -274
  74. package/src/portfolio/index.ts +570 -570
  75. package/src/services/priceService.ts +159 -159
  76. package/src/services/utils.ts +115 -115
  77. package/src/services/viem.ts +34 -34
  78. package/src/setup.ts +8 -8
  79. package/src/spark/index.ts +456 -445
  80. package/src/staking/eligibility.ts +53 -53
  81. package/src/staking/index.ts +1 -1
  82. package/src/staking/staking.ts +172 -170
  83. package/src/types/aave.ts +189 -189
  84. package/src/types/claiming.ts +109 -109
  85. package/src/types/common.ts +107 -107
  86. package/src/types/compound.ts +136 -136
  87. package/src/types/curveUsd.ts +123 -123
  88. package/src/types/euler.ts +175 -175
  89. package/src/types/fluid.ts +452 -452
  90. package/src/types/index.ts +13 -13
  91. package/src/types/liquity.ts +30 -30
  92. package/src/types/liquityV2.ts +126 -126
  93. package/src/types/llamaLend.ts +159 -159
  94. package/src/types/maker.ts +63 -63
  95. package/src/types/merit.ts +1 -1
  96. package/src/types/merkl.ts +70 -70
  97. package/src/types/morphoBlue.ts +194 -194
  98. package/src/types/portfolio.ts +60 -60
  99. package/src/types/spark.ts +133 -135
  100. package/src/umbrella/index.ts +69 -69
  101. package/src/umbrella/umbrellaUtils.ts +29 -29
  102. package/CLAUDE.md +0 -32
package/.mocharc.json CHANGED
@@ -1,4 +1,4 @@
1
- {
2
- "require": "ts-node/register",
3
- "extension": ["ts"]
4
- }
1
+ {
2
+ "require": "ts-node/register",
3
+ "extension": ["ts"]
4
+ }
package/.nvmrc CHANGED
@@ -1 +1 @@
1
- v20.17.0
1
+ v20.17.0
package/README.md CHANGED
@@ -1,64 +1,64 @@
1
- # DeFi Saver Positions SDK
2
-
3
- Supported protocols:
4
- - [Maker](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/maker)
5
- - [Spark](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/spark)
6
- - [CrvUSD](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/curveUsd)
7
- - [Aave V2](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/aaveV2)
8
- - [Aave V3](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/aaveV3)
9
- - [Compound V2](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/compoundV2)
10
- - [Compound V3](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/compoundV3)
11
- - [Liquity](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/liquity)
12
-
13
- ## Setup
14
- Supported Node version is v10.
15
-
16
- - run `npm install` (first time)
17
- - run `npm run build`
18
-
19
- `build` command will generate contracts and build ejs and esm folders
20
-
21
- ## How to use
22
- [All available imports](https://github.com/defisaver/defisaver-positions-sdk/blob/main/src/index.ts)
23
-
24
- This is a Compound V3 example, and every other protocol is similar
25
- ```js
26
- import { compoundV3 } from '@defisaver/positions-sdk';
27
-
28
-
29
- // every protocol has market data and user data getters
30
- const {
31
- getCompoundV3MarketsData,
32
- getCompoundV3AccountData,
33
- } = compoundV3;
34
-
35
- const provider = 'Your RPC provider';
36
-
37
- const user = '0x123...';
38
-
39
- const { assetsData } = await getCompoundV3MarketsData(
40
- provider, // rpc for the network you are using (note: can be tenderly or any other testnet rpc)
41
- 1, // network
42
- selectedMarket, // market object like in /src/markets/compound/index.ts
43
- provider, // this must be mainnet rpc - used for getting prices onchain and calculating apys
44
- );
45
-
46
- const userData = await getCompoundV3AccountData(
47
- provider,
48
- 1, // network
49
- userAddress, // EOA or DSProxy
50
- '', // proxy address of the user, or just empty string if checking for EOA
51
- {
52
- selectedMarket, // market object as in /src/markets/compound/index.ts
53
- assetsData,
54
- }
55
- );
56
- ```
57
-
58
- More examples found [here](https://github.com/defisaver/defisaver-positions-sdk/tree/main/tests)
59
-
60
- ## Testing
61
-
62
- `npm run test` - Run all tests
63
-
64
- `npm run test-single --name=your_test_name` - Run single test for specified name e.g. for MyTest.js test name is MyTest
1
+ # DeFi Saver Positions SDK
2
+
3
+ Supported protocols:
4
+ - [Maker](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/maker)
5
+ - [Spark](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/spark)
6
+ - [CrvUSD](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/curveUsd)
7
+ - [Aave V2](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/aaveV2)
8
+ - [Aave V3](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/aaveV3)
9
+ - [Compound V2](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/compoundV2)
10
+ - [Compound V3](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/compoundV3)
11
+ - [Liquity](https://github.com/defisaver/defisaver-positions-sdk/tree/main/src/liquity)
12
+
13
+ ## Setup
14
+ Supported Node version is v10.
15
+
16
+ - run `npm install` (first time)
17
+ - run `npm run build`
18
+
19
+ `build` command will generate contracts and build ejs and esm folders
20
+
21
+ ## How to use
22
+ [All available imports](https://github.com/defisaver/defisaver-positions-sdk/blob/main/src/index.ts)
23
+
24
+ This is a Compound V3 example, and every other protocol is similar
25
+ ```js
26
+ import { compoundV3 } from '@defisaver/positions-sdk';
27
+
28
+
29
+ // every protocol has market data and user data getters
30
+ const {
31
+ getCompoundV3MarketsData,
32
+ getCompoundV3AccountData,
33
+ } = compoundV3;
34
+
35
+ const provider = 'Your RPC provider';
36
+
37
+ const user = '0x123...';
38
+
39
+ const { assetsData } = await getCompoundV3MarketsData(
40
+ provider, // rpc for the network you are using (note: can be tenderly or any other testnet rpc)
41
+ 1, // network
42
+ selectedMarket, // market object like in /src/markets/compound/index.ts
43
+ provider, // this must be mainnet rpc - used for getting prices onchain and calculating apys
44
+ );
45
+
46
+ const userData = await getCompoundV3AccountData(
47
+ provider,
48
+ 1, // network
49
+ userAddress, // EOA or DSProxy
50
+ '', // proxy address of the user, or just empty string if checking for EOA
51
+ {
52
+ selectedMarket, // market object as in /src/markets/compound/index.ts
53
+ assetsData,
54
+ }
55
+ );
56
+ ```
57
+
58
+ More examples found [here](https://github.com/defisaver/defisaver-positions-sdk/tree/main/tests)
59
+
60
+ ## Testing
61
+
62
+ `npm run test` - Run all tests
63
+
64
+ `npm run test-single --name=your_test_name` - Run single test for specified name e.g. for MyTest.js test name is MyTest
@@ -128,73 +128,73 @@ const getApyAfterValuesEstimation = (selectedMarket, actions, provider, network)
128
128
  });
129
129
  exports.getApyAfterValuesEstimation = getApyAfterValuesEstimation;
130
130
  const API_URL = 'https://blue-api.morpho.org/graphql';
131
- const MARKET_QUERY = `
132
- query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
133
- marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
134
- reallocatableLiquidityAssets
135
- targetBorrowUtilization
136
- loanAsset {
137
- address
138
- decimals
139
- priceUsd
140
- }
141
- state {
142
- liquidityAssets
143
- borrowAssets
144
- supplyAssets
145
- }
146
- publicAllocatorSharedLiquidity {
147
- assets
148
- vault {
149
- address
150
- name
151
- }
152
- allocationMarket {
153
- uniqueKey
154
- loanAsset {
155
- address
156
- }
157
- collateralAsset {
158
- address
159
- }
160
- irmAddress
161
- oracle {
162
- address
163
- }
164
- lltv
165
- }
166
- }
167
- loanAsset {
168
- address
169
- }
170
- collateralAsset {
171
- address
172
- }
173
- oracle {
174
- address
175
- }
176
- irmAddress
177
- lltv
178
- }
179
- }
131
+ const MARKET_QUERY = `
132
+ query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
133
+ marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
134
+ reallocatableLiquidityAssets
135
+ targetBorrowUtilization
136
+ loanAsset {
137
+ address
138
+ decimals
139
+ priceUsd
140
+ }
141
+ state {
142
+ liquidityAssets
143
+ borrowAssets
144
+ supplyAssets
145
+ }
146
+ publicAllocatorSharedLiquidity {
147
+ assets
148
+ vault {
149
+ address
150
+ name
151
+ }
152
+ allocationMarket {
153
+ uniqueKey
154
+ loanAsset {
155
+ address
156
+ }
157
+ collateralAsset {
158
+ address
159
+ }
160
+ irmAddress
161
+ oracle {
162
+ address
163
+ }
164
+ lltv
165
+ }
166
+ }
167
+ loanAsset {
168
+ address
169
+ }
170
+ collateralAsset {
171
+ address
172
+ }
173
+ oracle {
174
+ address
175
+ }
176
+ irmAddress
177
+ lltv
178
+ }
179
+ }
180
180
  `;
181
- const REWARDS_QUERY = `
182
- query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
183
- marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
184
- uniqueKey
185
- state {
186
- rewards {
187
- amountPerSuppliedToken
188
- supplyApr
189
- amountPerBorrowedToken
190
- borrowApr
191
- asset {
192
- address
193
- }
194
- }
195
- }
196
- }
197
- }
181
+ const REWARDS_QUERY = `
182
+ query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
183
+ marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
184
+ uniqueKey
185
+ state {
186
+ rewards {
187
+ amountPerSuppliedToken
188
+ supplyApr
189
+ amountPerBorrowedToken
190
+ borrowApr
191
+ asset {
192
+ address
193
+ }
194
+ }
195
+ }
196
+ }
197
+ }
198
198
  `;
199
199
  /**
200
200
  * Get reallocatable liquidity to a given market and target borrow utilization
@@ -7,19 +7,19 @@ export declare const sparkIsInIsolationMode: ({ usedAssets, assetsData }: {
7
7
  export declare const sparkGetCollSuppliedAssets: ({ usedAssets }: {
8
8
  usedAssets: SparkUsedAssets;
9
9
  }) => import("../../types").SparkUsedAsset[];
10
- export declare const sparkGetSuppliableAssets: ({ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest }: SparkHelperCommon) => {
10
+ export declare const sparkGetSuppliableAssets: ({ usedAssets, eModeCategory, assetsData, selectedMarket, network, ...rest }: SparkHelperCommon) => {
11
11
  symbol: string;
12
12
  canBeCollateral: boolean;
13
13
  }[];
14
- export declare const sparkGetSuppliableAsCollAssets: ({ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest }: SparkHelperCommon) => {
14
+ export declare const sparkGetSuppliableAsCollAssets: ({ usedAssets, eModeCategory, assetsData, selectedMarket, network, ...rest }: SparkHelperCommon) => {
15
15
  symbol: string;
16
16
  canBeCollateral: boolean;
17
17
  }[];
18
- export declare const sparkGetEmodeMutableProps: ({ eModeCategory, assetsData, }: SparkHelperCommon, _asset: string) => {
18
+ export declare const sparkGetEmodeMutableProps: ({ eModeCategory, eModeCategoriesData, assetsData, }: SparkHelperCommon, _asset: string) => {
19
19
  liquidationRatio: string;
20
20
  collateralFactor: string;
21
21
  };
22
- export declare const sparkGetAggregatedPositionData: ({ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest }: SparkHelperCommon) => SparkAggregatedPositionData;
22
+ export declare const sparkGetAggregatedPositionData: ({ usedAssets, eModeCategory, eModeCategoriesData, assetsData, selectedMarket, network, ...rest }: SparkHelperCommon) => SparkAggregatedPositionData;
23
23
  export declare const getApyAfterValuesEstimation: (selectedMarket: SparkMarketData, actions: [{
24
24
  action: string;
25
25
  amount: string;
@@ -38,8 +38,8 @@ exports.sparkIsInIsolationMode = sparkIsInIsolationMode;
38
38
  const sparkGetCollSuppliedAssets = ({ usedAssets }) => Object.values(usedAssets).filter(({ isSupplied, collateral }) => isSupplied && collateral);
39
39
  exports.sparkGetCollSuppliedAssets = sparkGetCollSuppliedAssets;
40
40
  const sparkGetSuppliableAssets = (_a) => {
41
- var { usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network } = _a, rest = __rest(_a, ["usedAssets", "eModeCategory", "eModeCategories", "assetsData", "selectedMarket", "network"]);
42
- const data = Object.assign({ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network }, rest);
41
+ var { usedAssets, eModeCategory, assetsData, selectedMarket, network } = _a, rest = __rest(_a, ["usedAssets", "eModeCategory", "assetsData", "selectedMarket", "network"]);
42
+ const data = Object.assign({ usedAssets, eModeCategory, assetsData, selectedMarket, network }, rest);
43
43
  const collAccountAssets = (0, exports.sparkGetCollSuppliedAssets)(data);
44
44
  const marketAssets = Object.values(assetsData);
45
45
  if ((0, exports.sparkIsInIsolationMode)(data)) {
@@ -50,27 +50,27 @@ const sparkGetSuppliableAssets = (_a) => {
50
50
  };
51
51
  exports.sparkGetSuppliableAssets = sparkGetSuppliableAssets;
52
52
  const sparkGetSuppliableAsCollAssets = (_a) => {
53
- var { usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network } = _a, rest = __rest(_a, ["usedAssets", "eModeCategory", "eModeCategories", "assetsData", "selectedMarket", "network"]);
54
- return (0, exports.sparkGetSuppliableAssets)(Object.assign({ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network }, rest)).filter(({ canBeCollateral }) => canBeCollateral);
53
+ var { usedAssets, eModeCategory, assetsData, selectedMarket, network } = _a, rest = __rest(_a, ["usedAssets", "eModeCategory", "assetsData", "selectedMarket", "network"]);
54
+ return (0, exports.sparkGetSuppliableAssets)(Object.assign({ usedAssets, eModeCategory, assetsData, selectedMarket, network }, rest)).filter(({ canBeCollateral }) => canBeCollateral);
55
55
  };
56
56
  exports.sparkGetSuppliableAsCollAssets = sparkGetSuppliableAsCollAssets;
57
- const sparkGetEmodeMutableProps = ({ eModeCategory, assetsData, }, _asset) => {
58
- var _a;
59
- const asset = (0, utils_1.wethToEth)(_asset);
57
+ const sparkGetEmodeMutableProps = ({ eModeCategory, eModeCategoriesData, assetsData, }, _asset) => {
58
+ const asset = (0, utils_1.getNativeAssetFromWrapped)(_asset);
60
59
  const assetData = assetsData[asset];
60
+ const eModeCategoryData = (eModeCategoriesData === null || eModeCategoriesData === void 0 ? void 0 : eModeCategoriesData[eModeCategory]) || { collateralAssets: [], collateralFactor: '0', liquidationRatio: '0' };
61
61
  if (eModeCategory === 0
62
- || assetData.eModeCategory !== eModeCategory
63
- || new decimal_js_1.default(((_a = assetData === null || assetData === void 0 ? void 0 : assetData.eModeCategoryData) === null || _a === void 0 ? void 0 : _a.collateralFactor) || 0).eq(0)) {
62
+ || !eModeCategoryData.collateralAssets.includes(asset)
63
+ || new decimal_js_1.default(eModeCategoryData.collateralFactor || 0).eq(0)) {
64
64
  const { liquidationRatio, collateralFactor } = assetData;
65
65
  return ({ liquidationRatio, collateralFactor });
66
66
  }
67
- const { liquidationRatio, collateralFactor } = assetData.eModeCategoryData;
67
+ const { liquidationRatio, collateralFactor } = eModeCategoryData;
68
68
  return ({ liquidationRatio, collateralFactor });
69
69
  };
70
70
  exports.sparkGetEmodeMutableProps = sparkGetEmodeMutableProps;
71
71
  const sparkGetAggregatedPositionData = (_a) => {
72
- var { usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network } = _a, rest = __rest(_a, ["usedAssets", "eModeCategory", "eModeCategories", "assetsData", "selectedMarket", "network"]);
73
- const data = Object.assign({ usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network }, rest);
72
+ var { usedAssets, eModeCategory, eModeCategoriesData, assetsData, selectedMarket, network } = _a, rest = __rest(_a, ["usedAssets", "eModeCategory", "eModeCategoriesData", "assetsData", "selectedMarket", "network"]);
73
+ const data = Object.assign({ usedAssets, eModeCategory, eModeCategoriesData, assetsData, selectedMarket, network }, rest);
74
74
  const payload = {};
75
75
  payload.suppliedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied }) => isSupplied, ({ suppliedUsd }) => suppliedUsd);
76
76
  payload.suppliedCollateralUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied, collateral }) => isSupplied && collateral, ({ suppliedUsd }) => suppliedUsd);
@@ -18,7 +18,7 @@ exports.aaveV3AssetsDefaultMarketOpt = [
18
18
  exports.aaveV3AssetsDefaultMarketArb = ['DAI', 'LINK', 'USDC.e', 'WBTC', 'ETH', 'USDT', 'AAVE', 'EURS', 'wstETH', 'MAI', 'rETH', 'LUSD', 'USDC', 'FRAX', 'ARB', 'weETH', 'GHO', 'ezETH', 'rsETH', 'tBTC'];
19
19
  exports.aaveV3AssetsDefaultMarketBase = ['ETH', 'cbETH', 'USDbC', 'wstETH', 'USDC', 'weETH', 'cbBTC', 'ezETH', 'GHO', 'wrsETH', 'LBTC', 'EURC', 'AAVE', 'tBTC'];
20
20
  exports.aaveV3AssetsDefaultMarketLinea = ['ETH', 'USDC', 'weETH', 'ezETH', 'USDT', 'wstETH', 'wrsETH', 'WBTC'];
21
- exports.aaveV3AssetsDefaultMarketPlasma = ['ETH', 'USDT', 'sUSDe', 'USDe', 'weETH', 'XAUt'];
21
+ exports.aaveV3AssetsDefaultMarketPlasma = ['ETH', 'USDT', 'sUSDe', 'USDe', 'weETH', 'XAUt', 'PT USDe Jan', 'PT sUSDe Jan', 'wrsETH', 'wstETH'];
22
22
  // @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
23
23
  exports.aaveV3AssetsDefaultMarket = {
24
24
  [common_1.NetworkNumber.Eth]: exports.aaveV3AssetsDefaultMarketEth,
@@ -452,7 +452,7 @@ function getPortfolioData(provider, network, defaultProvider, addresses, summerF
452
452
  }))).flat(),
453
453
  ...sparkMarkets.map((market) => allAddresses.map((address) => __awaiter(this, void 0, void 0, function* () {
454
454
  try {
455
- const accData = yield (0, spark_1._getSparkAccountData)(client, network, address, { selectedMarket: market, assetsData: sparkMarketsData[market.value].assetsData });
455
+ const accData = yield (0, spark_1._getSparkAccountData)(client, network, address, { selectedMarket: market, assetsData: sparkMarketsData[market.value].assetsData, eModeCategoriesData: sparkMarketsData[market.value].eModeCategoriesData });
456
456
  if (new decimal_js_1.default(accData.suppliedUsd).gt(0))
457
457
  positions[address.toLowerCase()].spark[market.value] = { error: '', data: accData };
458
458
  }
@@ -1,6 +1,6 @@
1
1
  import { Client } from 'viem';
2
2
  import { Blockish, EthAddress, EthereumProvider, NetworkNumber, PositionBalances } from '../types/common';
3
- import { SparkEModeCategoryDataMapping, SparkAssetsData, SparkMarketData, SparkMarketsData, SparkPositionData, SparkUsedAssets } from '../types';
3
+ import { SparkEModeCategoryDataMapping, SparkAssetsData, SparkMarketData, SparkMarketsData, SparkPositionData, SparkUsedAssets, EModeCategoriesData } from '../types';
4
4
  export declare const sparkEmodeCategoriesMapping: (extractedState: {
5
5
  assetsData: SparkAssetsData;
6
6
  }, usedAssets: SparkUsedAssets) => {
@@ -32,9 +32,11 @@ export declare const getSparkAccountBalances: (provider: EthereumProvider, netwo
32
32
  export declare const _getSparkAccountData: (provider: Client, network: NetworkNumber, address: EthAddress, extractedState: {
33
33
  selectedMarket: SparkMarketData;
34
34
  assetsData: SparkAssetsData;
35
+ eModeCategoriesData: EModeCategoriesData;
35
36
  }) => Promise<SparkPositionData>;
36
37
  export declare const getSparkAccountData: (provider: EthereumProvider, network: NetworkNumber, address: EthAddress, extractedState: {
37
38
  selectedMarket: SparkMarketData;
38
39
  assetsData: SparkAssetsData;
40
+ eModeCategoriesData: EModeCategoriesData;
39
41
  }) => Promise<SparkPositionData>;
40
42
  export declare const getSparkFullPositionData: (provider: EthereumProvider, network: NetworkNumber, address: EthAddress, market: SparkMarketData) => Promise<SparkPositionData>;
@@ -28,7 +28,6 @@ const sparkEmodeCategoriesMapping = (extractedState, usedAssets) => {
28
28
  const usedAssetsValues = Object.values(usedAssets);
29
29
  const categoriesMapping = {};
30
30
  Object.values(assetsData).forEach((a) => {
31
- var _a;
32
31
  const borrowingOnlyFromCategory = a.eModeCategory === 0
33
32
  ? true
34
33
  : !usedAssetsValues.filter(u => u.isBorrowed && u.eModeCategory !== a.eModeCategory).length;
@@ -39,8 +38,6 @@ const sparkEmodeCategoriesMapping = (extractedState, usedAssets) => {
39
38
  enteringTerms,
40
39
  canEnterCategory: !enteringTerms.includes(false),
41
40
  id: a.eModeCategory,
42
- data: a.eModeCategoryData,
43
- assets: a.eModeCategory === 0 ? [] : [...(((_a = categoriesMapping[a.eModeCategory]) === null || _a === void 0 ? void 0 : _a.assets) || []), a.symbol],
44
41
  enabledData: {
45
42
  ratio: afterEnteringCategory.ratio,
46
43
  liqRatio: afterEnteringCategory.liqRatio,
@@ -56,18 +53,17 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
56
53
  const marketAddress = selectedMarket.providerAddress;
57
54
  const loanInfoContract = (0, contracts_1.SparkViewContractViem)(provider, network);
58
55
  const sparkIncentivesContract = (0, contracts_1.SparkIncentiveDataProviderContractViem)(provider, network);
59
- const [loanInfo, _rewardInfo] = yield Promise.all([
56
+ // eslint-disable-next-line prefer-const
57
+ let [loanInfo, rewardInfo] = yield Promise.all([
60
58
  loanInfoContract.read.getFullTokensInfo([marketAddress, selectedMarket.assets.map(a => (0, tokens_1.getAssetInfo)((0, utils_1.ethToWeth)(a)).address)]),
61
- network === common_1.NetworkNumber.Opt ? sparkIncentivesContract.read.getReservesIncentivesData([marketAddress]) : [],
59
+ sparkIncentivesContract.read.getReservesIncentivesData([marketAddress]),
62
60
  ]);
63
- let rewardInfo = [];
64
- if (network === common_1.NetworkNumber.Opt) {
65
- rewardInfo = rewardInfo.reduce((all, market) => {
66
- // eslint-disable-next-line no-param-reassign
67
- all[market.underlyingAsset] = market;
68
- return all;
69
- }, {});
70
- }
61
+ rewardInfo = rewardInfo.reduce((all, market) => {
62
+ // eslint-disable-next-line no-param-reassign
63
+ all[market.underlyingAsset] = market;
64
+ return all;
65
+ }, {});
66
+ const eModeCategoriesData = {};
71
67
  const assetsData = yield Promise.all(loanInfo
72
68
  .map((market, i) => __awaiter(void 0, void 0, void 0, function* () {
73
69
  const symbol = selectedMarket.assets[i];
@@ -82,6 +78,15 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
82
78
  if (new decimal_js_1.default(marketLiquidity).lt(0)) {
83
79
  marketLiquidity = '0';
84
80
  }
81
+ eModeCategoriesData[+market.emodeCategory.toString()] = {
82
+ id: +market.emodeCategory.toString(),
83
+ label: market.label,
84
+ liquidationBonus: new decimal_js_1.default(market.liquidationBonus).div(10000).toString(),
85
+ liquidationRatio: new decimal_js_1.default(market.liquidationThreshold).div(10000).toString(),
86
+ collateralFactor: new decimal_js_1.default(market.ltv).div(10000).toString(),
87
+ collateralAssets: eModeCategoriesData[+market.emodeCategory.toString()] ? [...eModeCategoriesData[+market.emodeCategory.toString()].collateralAssets, selectedMarket.assets[i]] : [selectedMarket.assets[i]],
88
+ borrowAssets: eModeCategoriesData[+market.emodeCategory.toString()] ? [...eModeCategoriesData[+market.emodeCategory.toString()].borrowAssets, selectedMarket.assets[i]] : [selectedMarket.assets[i]],
89
+ };
85
90
  return ({
86
91
  symbol: selectedMarket.assets[i],
87
92
  isIsolated: new decimal_js_1.default(market.debtCeilingForIsolationMode.toString()).gt(0),
@@ -116,13 +121,6 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
116
121
  isolationModeBorrowingEnabled: market.isolationModeBorrowingEnabled,
117
122
  isFlashLoanEnabled: market.isFlashLoanEnabled,
118
123
  aTokenAddress: market.aTokenAddress,
119
- eModeCategoryData: {
120
- label: market.label,
121
- liquidationBonus: new decimal_js_1.default(market.liquidationBonus).div(10000).toString(),
122
- liquidationRatio: new decimal_js_1.default(market.liquidationThreshold).div(10000).toString(),
123
- collateralFactor: new decimal_js_1.default(market.ltv).div(10000).toString(),
124
- priceSource: market.priceSource,
125
- },
126
124
  supplyIncentives: [],
127
125
  borrowIncentives: [],
128
126
  });
@@ -154,7 +152,7 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
154
152
  return;
155
153
  rewardForMarket.aIncentiveData.rewardsTokenInformation.forEach(supplyRewardData => {
156
154
  if (supplyRewardData) {
157
- if (supplyRewardData.emissionEndTimestamp * 1000 < Date.now())
155
+ if (+(supplyRewardData.emissionEndTimestamp.toString()) * 1000 < Date.now())
158
156
  return;
159
157
  const supplyEmissionPerSecond = supplyRewardData.emissionPerSecond;
160
158
  const supplyRewardPrice = new decimal_js_1.default(supplyRewardData.rewardPriceFeed).div(Math.pow(10, supplyRewardData.priceFeedDecimals))
@@ -175,7 +173,7 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
175
173
  });
176
174
  rewardForMarket.vIncentiveData.rewardsTokenInformation.forEach(borrowRewardData => {
177
175
  if (borrowRewardData) {
178
- if (borrowRewardData.emissionEndTimestamp * 1000 < Date.now())
176
+ if (+(borrowRewardData.emissionEndTimestamp.toString()) * 1000 < Date.now())
179
177
  return;
180
178
  const supplyEmissionPerSecond = borrowRewardData.emissionPerSecond;
181
179
  const supplyRewardPrice = new decimal_js_1.default(borrowRewardData.rewardPriceFeed).div(Math.pow(10, borrowRewardData.priceFeedDecimals))
@@ -196,7 +194,7 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
196
194
  });
197
195
  /* eslint-enable no-param-reassign */
198
196
  })));
199
- const payload = {};
197
+ const filteredAssetsData = {};
200
198
  // Sort by market size
201
199
  assetsData
202
200
  .sort((a, b) => {
@@ -205,9 +203,11 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
205
203
  return new decimal_js_1.default(bMarket).minus(aMarket).toNumber();
206
204
  })
207
205
  .forEach((assetData, i) => {
208
- payload[assetData.symbol] = Object.assign(Object.assign({}, assetData), { sortIndex: i });
206
+ filteredAssetsData[assetData.symbol] = Object.assign(Object.assign({}, assetData), { sortIndex: i });
209
207
  });
210
- return { assetsData: payload };
208
+ eModeCategoriesData[0].collateralAssets = Object.values(filteredAssetsData).map(a => a.symbol);
209
+ eModeCategoriesData[0].borrowAssets = Object.values(filteredAssetsData).map(a => a.symbol);
210
+ return { assetsData: filteredAssetsData, eModeCategoriesData };
211
211
  });
212
212
  exports._getSparkMarketsData = _getSparkMarketsData;
213
213
  const getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(void 0, void 0, void 0, function* () { return (0, exports._getSparkMarketsData)((0, viem_1.getViemProvider)(provider, network), network, selectedMarket); });
@@ -349,7 +349,7 @@ const getSparkAccountData = (provider, network, address, extractedState) => __aw
349
349
  exports.getSparkAccountData = getSparkAccountData;
350
350
  const getSparkFullPositionData = (provider, network, address, market) => __awaiter(void 0, void 0, void 0, function* () {
351
351
  const marketData = yield (0, exports.getSparkMarketsData)(provider, network, market);
352
- const positionData = yield (0, exports.getSparkAccountData)(provider, network, address, { assetsData: marketData.assetsData, selectedMarket: market });
352
+ const positionData = yield (0, exports.getSparkAccountData)(provider, network, address, { assetsData: marketData.assetsData, selectedMarket: market, eModeCategoriesData: marketData.eModeCategoriesData });
353
353
  return positionData;
354
354
  });
355
355
  exports.getSparkFullPositionData = getSparkFullPositionData;
@@ -67,7 +67,7 @@ const getApyFromDfsApi = (asset) => __awaiter(void 0, void 0, void 0, function*
67
67
  return '0';
68
68
  }
69
69
  });
70
- exports.STAKING_ASSETS = ['cbETH', 'wstETH', 'cbETH', 'rETH', 'sDAI', 'weETH', 'sUSDe', 'osETH', 'ezETH', 'ETHx', 'rsETH', 'pufETH', 'wrsETH', 'wsuperOETHb', 'sUSDS', 'tETH', 'PT sUSDe Sep', 'PT USDe Sep', 'PT sUSDe Nov', 'PT USDe Nov'];
70
+ exports.STAKING_ASSETS = ['cbETH', 'wstETH', 'cbETH', 'rETH', 'sDAI', 'weETH', 'sUSDe', 'osETH', 'ezETH', 'ETHx', 'rsETH', 'pufETH', 'wrsETH', 'wsuperOETHb', 'sUSDS', 'tETH', 'PT sUSDe Sep', 'PT USDe Sep', 'PT sUSDe Nov', 'PT USDe Nov', 'PT USDe Jan', 'PT sUSDe Jan', 'wrsETH', 'wstETH'];
71
71
  exports.getStakingApy = (0, memoizee_1.default)((asset) => __awaiter(void 0, void 0, void 0, function* () {
72
72
  try {
73
73
  if (asset === 'stETH' || asset === 'wstETH')
@@ -116,6 +116,10 @@ exports.getStakingApy = (0, memoizee_1.default)((asset) => __awaiter(void 0, voi
116
116
  return yield getApyFromDfsApi('PT sUSDe Nov');
117
117
  if (asset === 'PT USDe Nov')
118
118
  return yield getApyFromDfsApi('PT USDe Nov');
119
+ if (asset === 'PT USDe Jan')
120
+ return yield getApyFromDfsApi('PT USDe Jan');
121
+ if (asset === 'PT sUSDe Jan')
122
+ return yield getApyFromDfsApi('PT sUSDe Jan');
119
123
  }
120
124
  catch (e) {
121
125
  console.error(`Failed to fetch APY for ${asset}`);
@@ -1,3 +1,4 @@
1
+ import { EModeCategoriesData } from './aave';
1
2
  import { EthAddress, MMAssetData, MMPositionData, MMUsedAsset, NetworkNumber } from './common';
2
3
  export declare enum SparkVersions {
3
4
  SparkV1 = "v1default"
@@ -13,8 +14,6 @@ export interface SparkEModeCategoryDataMapping {
13
14
  enteringTerms: boolean[];
14
15
  canEnterCategory: boolean;
15
16
  id: number;
16
- data: SparkEModeCategoryData;
17
- assets: string[];
18
17
  enabledData: {
19
18
  ratio: string;
20
19
  liqRatio: string;
@@ -45,7 +44,6 @@ export interface SparkAssetData extends MMAssetData {
45
44
  usageAsCollateralEnabled: boolean;
46
45
  isIsolated: boolean;
47
46
  eModeCategory: number;
48
- eModeCategoryData: SparkEModeCategoryData;
49
47
  liquidationRatio: string;
50
48
  }
51
49
  export interface SparkAssetsData {
@@ -53,6 +51,7 @@ export interface SparkAssetsData {
53
51
  }
54
52
  export type SparkMarketsData = {
55
53
  assetsData: SparkAssetsData;
54
+ eModeCategoriesData: EModeCategoriesData;
56
55
  };
57
56
  export interface SparkUsedAsset extends MMUsedAsset {
58
57
  stableBorrowRate: string;
@@ -71,7 +70,7 @@ export interface SparkUsedAssets {
71
70
  export interface SparkHelperCommon {
72
71
  usedAssets: SparkUsedAssets;
73
72
  eModeCategory: number;
74
- eModeCategories?: object;
73
+ eModeCategoriesData?: EModeCategoriesData;
75
74
  assetsData: SparkAssetsData;
76
75
  selectedMarket?: SparkMarketData;
77
76
  network?: NetworkNumber;