@defisaver/positions-sdk 2.1.40 → 2.1.41

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 (112) 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/savings/morphoVaults/index.js +17 -17
  6. package/cjs/spark/index.js +7 -5
  7. package/cjs/types/spark.d.ts +1 -0
  8. package/esm/helpers/morphoBlueHelpers/index.js +66 -66
  9. package/esm/savings/morphoVaults/index.js +17 -17
  10. package/esm/spark/index.js +7 -5
  11. package/esm/types/spark.d.ts +1 -0
  12. package/package.json +48 -48
  13. package/src/aaveV2/index.ts +240 -240
  14. package/src/aaveV3/index.ts +625 -625
  15. package/src/aaveV3/merit.ts +97 -97
  16. package/src/aaveV3/merkl.ts +74 -74
  17. package/src/claiming/aaveV3.ts +154 -154
  18. package/src/claiming/compV3.ts +22 -22
  19. package/src/claiming/ethena.ts +61 -61
  20. package/src/claiming/index.ts +12 -12
  21. package/src/claiming/king.ts +66 -66
  22. package/src/claiming/morphoBlue.ts +118 -118
  23. package/src/claiming/spark.ts +225 -225
  24. package/src/compoundV2/index.ts +244 -244
  25. package/src/compoundV3/index.ts +274 -274
  26. package/src/config/contracts.ts +1295 -1295
  27. package/src/constants/index.ts +10 -10
  28. package/src/contracts.ts +171 -171
  29. package/src/curveUsd/index.ts +254 -254
  30. package/src/eulerV2/index.ts +324 -324
  31. package/src/exchange/index.ts +25 -25
  32. package/src/fluid/index.ts +1800 -1800
  33. package/src/helpers/aaveHelpers/index.ts +187 -187
  34. package/src/helpers/compoundHelpers/index.ts +283 -283
  35. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  36. package/src/helpers/eulerHelpers/index.ts +222 -222
  37. package/src/helpers/fluidHelpers/index.ts +326 -326
  38. package/src/helpers/index.ts +10 -10
  39. package/src/helpers/liquityV2Helpers/index.ts +82 -82
  40. package/src/helpers/llamaLendHelpers/index.ts +53 -53
  41. package/src/helpers/makerHelpers/index.ts +52 -52
  42. package/src/helpers/morphoBlueHelpers/index.ts +396 -396
  43. package/src/helpers/sparkHelpers/index.ts +158 -158
  44. package/src/index.ts +49 -49
  45. package/src/liquity/index.ts +159 -159
  46. package/src/liquityV2/index.ts +703 -703
  47. package/src/llamaLend/index.ts +305 -305
  48. package/src/maker/index.ts +223 -223
  49. package/src/markets/aave/index.ts +118 -118
  50. package/src/markets/aave/marketAssets.ts +54 -54
  51. package/src/markets/compound/index.ts +243 -243
  52. package/src/markets/compound/marketsAssets.ts +97 -97
  53. package/src/markets/curveUsd/index.ts +69 -69
  54. package/src/markets/euler/index.ts +26 -26
  55. package/src/markets/fluid/index.ts +2900 -2900
  56. package/src/markets/index.ts +25 -25
  57. package/src/markets/liquityV2/index.ts +102 -102
  58. package/src/markets/llamaLend/contractAddresses.ts +141 -141
  59. package/src/markets/llamaLend/index.ts +235 -235
  60. package/src/markets/morphoBlue/index.ts +971 -971
  61. package/src/markets/spark/index.ts +29 -29
  62. package/src/markets/spark/marketAssets.ts +12 -12
  63. package/src/moneymarket/moneymarketCommonService.ts +85 -85
  64. package/src/morphoBlue/index.ts +274 -274
  65. package/src/portfolio/index.ts +598 -598
  66. package/src/savings/index.ts +95 -95
  67. package/src/savings/makerDsr/index.ts +53 -53
  68. package/src/savings/makerDsr/options.ts +9 -9
  69. package/src/savings/morphoVaults/index.ts +80 -80
  70. package/src/savings/morphoVaults/options.ts +193 -193
  71. package/src/savings/skyOptions/index.ts +95 -95
  72. package/src/savings/skyOptions/options.ts +10 -10
  73. package/src/savings/sparkSavingsVaults/index.ts +60 -60
  74. package/src/savings/sparkSavingsVaults/options.ts +35 -35
  75. package/src/savings/yearnV3Vaults/index.ts +61 -61
  76. package/src/savings/yearnV3Vaults/options.ts +55 -55
  77. package/src/savings/yearnVaults/index.ts +73 -73
  78. package/src/savings/yearnVaults/options.ts +32 -32
  79. package/src/services/priceService.ts +278 -278
  80. package/src/services/utils.ts +115 -115
  81. package/src/services/viem.ts +34 -34
  82. package/src/setup.ts +8 -8
  83. package/src/spark/index.ts +458 -456
  84. package/src/staking/eligibility.ts +53 -53
  85. package/src/staking/index.ts +1 -1
  86. package/src/staking/staking.ts +186 -186
  87. package/src/types/aave.ts +196 -196
  88. package/src/types/claiming.ts +114 -114
  89. package/src/types/common.ts +107 -107
  90. package/src/types/compound.ts +144 -144
  91. package/src/types/curveUsd.ts +123 -123
  92. package/src/types/euler.ts +175 -175
  93. package/src/types/fluid.ts +483 -483
  94. package/src/types/index.ts +14 -14
  95. package/src/types/liquity.ts +30 -30
  96. package/src/types/liquityV2.ts +126 -126
  97. package/src/types/llamaLend.ts +159 -159
  98. package/src/types/maker.ts +63 -63
  99. package/src/types/merit.ts +1 -1
  100. package/src/types/merkl.ts +70 -70
  101. package/src/types/morphoBlue.ts +200 -200
  102. package/src/types/portfolio.ts +60 -60
  103. package/src/types/savings/index.ts +23 -23
  104. package/src/types/savings/makerDsr.ts +13 -13
  105. package/src/types/savings/morphoVaults.ts +32 -32
  106. package/src/types/savings/sky.ts +14 -14
  107. package/src/types/savings/sparkSavingsVaults.ts +15 -15
  108. package/src/types/savings/yearnV3Vaults.ts +17 -17
  109. package/src/types/savings/yearnVaults.ts +14 -14
  110. package/src/types/spark.ts +134 -133
  111. package/src/umbrella/index.ts +69 -69
  112. package/src/umbrella/umbrellaUtils.ts +29 -29
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
@@ -54,23 +54,23 @@ const morphoVaultsOptions = __importStar(require("./options"));
54
54
  exports.morphoVaultsOptions = morphoVaultsOptions;
55
55
  const viem_1 = require("../../services/viem");
56
56
  const contracts_1 = require("../../contracts");
57
- const vaultDataQuery = (vaultAddress) => `query vaultByAddress {
58
- vaultByAddress(chainId: 1, address: "${vaultAddress}") {
59
- id,
60
- dailyApy,
61
- dailyApys {
62
- apy, netApy
63
- },
64
- monthlyApys {
65
- apy, netApy
66
- },
67
- liquidity {
68
- underlying, usd,
69
- },
70
- asset {
71
- priceUsd
72
- }
73
- }
57
+ const vaultDataQuery = (vaultAddress) => `query vaultByAddress {
58
+ vaultByAddress(chainId: 1, address: "${vaultAddress}") {
59
+ id,
60
+ dailyApy,
61
+ dailyApys {
62
+ apy, netApy
63
+ },
64
+ monthlyApys {
65
+ apy, netApy
66
+ },
67
+ liquidity {
68
+ underlying, usd,
69
+ },
70
+ asset {
71
+ priceUsd
72
+ }
73
+ }
74
74
  }`;
75
75
  const MORPHO_BLUE_API = 'https://blue-api.morpho.org/graphql';
76
76
  const _getMorphoVaultData = (provider, network, morphoVault, accounts) => __awaiter(void 0, void 0, void 0, function* () {
@@ -78,21 +78,22 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
78
78
  if (new decimal_js_1.default(marketLiquidity).lt(0)) {
79
79
  marketLiquidity = '0';
80
80
  }
81
- eModeCategoriesData[+market.emodeCategory.toString()] = {
82
- id: +market.emodeCategory.toString(),
81
+ const emodeCategoryId = +market.emodeCategory.toString();
82
+ eModeCategoriesData[emodeCategoryId] = {
83
+ id: emodeCategoryId,
83
84
  label: market.label,
84
85
  liquidationBonus: new decimal_js_1.default(market.liquidationBonus).div(10000).toString(),
85
86
  liquidationRatio: new decimal_js_1.default(market.liquidationThreshold).div(10000).toString(),
86
87
  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]],
88
+ collateralAssets: eModeCategoriesData[emodeCategoryId] ? [...eModeCategoriesData[emodeCategoryId].collateralAssets, selectedMarket.assets[i]] : [selectedMarket.assets[i]],
89
+ borrowAssets: eModeCategoriesData[emodeCategoryId] ? [...eModeCategoriesData[emodeCategoryId].borrowAssets, selectedMarket.assets[i]] : [selectedMarket.assets[i]],
89
90
  };
90
91
  return ({
91
92
  symbol: selectedMarket.assets[i],
92
93
  isIsolated: new decimal_js_1.default(market.debtCeilingForIsolationMode.toString()).gt(0),
93
94
  debtCeilingForIsolationMode: new decimal_js_1.default(market.debtCeilingForIsolationMode.toString()).div(100).toString(),
94
95
  isSiloed: market.isSiloedForBorrowing,
95
- eModeCategory: +market.emodeCategory.toString(),
96
+ eModeCategory: emodeCategoryId,
96
97
  isolationModeTotalDebt: new decimal_js_1.default(market.isolationModeTotalDebt.toString()).div(100).toString(),
97
98
  assetId: Number(market.assetId),
98
99
  underlyingTokenAddress: market.underlyingTokenAddress,
@@ -100,6 +101,7 @@ const _getSparkMarketsData = (provider, network, selectedMarket) => __awaiter(vo
100
101
  borrowRate: (0, moneymarket_1.aprToApy)(new decimal_js_1.default(market.borrowRateVariable.toString()).div(1e25).toString()),
101
102
  borrowRateStable: (0, moneymarket_1.aprToApy)(new decimal_js_1.default(market.borrowRateStable.toString()).div(1e25).toString()),
102
103
  collateralFactor: new decimal_js_1.default(market.collateralFactor.toString()).div(10000).toString(),
104
+ liquidationBonus: eModeCategoriesData[emodeCategoryId].liquidationBonus,
103
105
  liquidationRatio: new decimal_js_1.default(market.liquidationRatio.toString()).div(10000).toString(),
104
106
  marketLiquidity,
105
107
  utilization: new decimal_js_1.default(market.totalBorrow.toString()).times(100).div(new decimal_js_1.default(market.totalSupply.toString())).toString(),
@@ -44,6 +44,7 @@ export interface SparkAssetData extends MMAssetData {
44
44
  usageAsCollateralEnabled: boolean;
45
45
  isIsolated: boolean;
46
46
  eModeCategory: number;
47
+ liquidationBonus: string;
47
48
  liquidationRatio: string;
48
49
  }
49
50
  export interface SparkAssetsData {
@@ -118,73 +118,73 @@ export const getApyAfterValuesEstimation = (selectedMarket, actions, provider, n
118
118
  return { borrowRate, supplyRate };
119
119
  });
120
120
  const API_URL = 'https://blue-api.morpho.org/graphql';
121
- const MARKET_QUERY = `
122
- query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
123
- marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
124
- reallocatableLiquidityAssets
125
- targetBorrowUtilization
126
- loanAsset {
127
- address
128
- decimals
129
- priceUsd
130
- }
131
- state {
132
- liquidityAssets
133
- borrowAssets
134
- supplyAssets
135
- }
136
- publicAllocatorSharedLiquidity {
137
- assets
138
- vault {
139
- address
140
- name
141
- }
142
- allocationMarket {
143
- uniqueKey
144
- loanAsset {
145
- address
146
- }
147
- collateralAsset {
148
- address
149
- }
150
- irmAddress
151
- oracle {
152
- address
153
- }
154
- lltv
155
- }
156
- }
157
- loanAsset {
158
- address
159
- }
160
- collateralAsset {
161
- address
162
- }
163
- oracle {
164
- address
165
- }
166
- irmAddress
167
- lltv
168
- }
169
- }
121
+ const MARKET_QUERY = `
122
+ query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
123
+ marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
124
+ reallocatableLiquidityAssets
125
+ targetBorrowUtilization
126
+ loanAsset {
127
+ address
128
+ decimals
129
+ priceUsd
130
+ }
131
+ state {
132
+ liquidityAssets
133
+ borrowAssets
134
+ supplyAssets
135
+ }
136
+ publicAllocatorSharedLiquidity {
137
+ assets
138
+ vault {
139
+ address
140
+ name
141
+ }
142
+ allocationMarket {
143
+ uniqueKey
144
+ loanAsset {
145
+ address
146
+ }
147
+ collateralAsset {
148
+ address
149
+ }
150
+ irmAddress
151
+ oracle {
152
+ address
153
+ }
154
+ lltv
155
+ }
156
+ }
157
+ loanAsset {
158
+ address
159
+ }
160
+ collateralAsset {
161
+ address
162
+ }
163
+ oracle {
164
+ address
165
+ }
166
+ irmAddress
167
+ lltv
168
+ }
169
+ }
170
170
  `;
171
- const REWARDS_QUERY = `
172
- query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
173
- marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
174
- uniqueKey
175
- state {
176
- rewards {
177
- amountPerSuppliedToken
178
- supplyApr
179
- amountPerBorrowedToken
180
- borrowApr
181
- asset {
182
- address
183
- }
184
- }
185
- }
186
- }
187
- }
171
+ const REWARDS_QUERY = `
172
+ query MarketByUniqueKey($uniqueKey: String!, $chainId: Int!) {
173
+ marketByUniqueKey(uniqueKey: $uniqueKey, chainId: $chainId) {
174
+ uniqueKey
175
+ state {
176
+ rewards {
177
+ amountPerSuppliedToken
178
+ supplyApr
179
+ amountPerBorrowedToken
180
+ borrowApr
181
+ asset {
182
+ address
183
+ }
184
+ }
185
+ }
186
+ }
187
+ }
188
188
  `;
189
189
  /**
190
190
  * Get reallocatable liquidity to a given market and target borrow utilization
@@ -14,23 +14,23 @@ import * as morphoVaultsOptions from './options';
14
14
  import { getViemProvider } from '../../services/viem';
15
15
  import { getMorphoVaultContractViem } from '../../contracts';
16
16
  export { morphoVaultsOptions, };
17
- const vaultDataQuery = (vaultAddress) => `query vaultByAddress {
18
- vaultByAddress(chainId: 1, address: "${vaultAddress}") {
19
- id,
20
- dailyApy,
21
- dailyApys {
22
- apy, netApy
23
- },
24
- monthlyApys {
25
- apy, netApy
26
- },
27
- liquidity {
28
- underlying, usd,
29
- },
30
- asset {
31
- priceUsd
32
- }
33
- }
17
+ const vaultDataQuery = (vaultAddress) => `query vaultByAddress {
18
+ vaultByAddress(chainId: 1, address: "${vaultAddress}") {
19
+ id,
20
+ dailyApy,
21
+ dailyApys {
22
+ apy, netApy
23
+ },
24
+ monthlyApys {
25
+ apy, netApy
26
+ },
27
+ liquidity {
28
+ underlying, usd,
29
+ },
30
+ asset {
31
+ priceUsd
32
+ }
33
+ }
34
34
  }`;
35
35
  const MORPHO_BLUE_API = 'https://blue-api.morpho.org/graphql';
36
36
  export const _getMorphoVaultData = (provider, network, morphoVault, accounts) => __awaiter(void 0, void 0, void 0, function* () {
@@ -71,21 +71,22 @@ export const _getSparkMarketsData = (provider, network, selectedMarket) => __awa
71
71
  if (new Dec(marketLiquidity).lt(0)) {
72
72
  marketLiquidity = '0';
73
73
  }
74
- eModeCategoriesData[+market.emodeCategory.toString()] = {
75
- id: +market.emodeCategory.toString(),
74
+ const emodeCategoryId = +market.emodeCategory.toString();
75
+ eModeCategoriesData[emodeCategoryId] = {
76
+ id: emodeCategoryId,
76
77
  label: market.label,
77
78
  liquidationBonus: new Dec(market.liquidationBonus).div(10000).toString(),
78
79
  liquidationRatio: new Dec(market.liquidationThreshold).div(10000).toString(),
79
80
  collateralFactor: new Dec(market.ltv).div(10000).toString(),
80
- collateralAssets: eModeCategoriesData[+market.emodeCategory.toString()] ? [...eModeCategoriesData[+market.emodeCategory.toString()].collateralAssets, selectedMarket.assets[i]] : [selectedMarket.assets[i]],
81
- borrowAssets: eModeCategoriesData[+market.emodeCategory.toString()] ? [...eModeCategoriesData[+market.emodeCategory.toString()].borrowAssets, selectedMarket.assets[i]] : [selectedMarket.assets[i]],
81
+ collateralAssets: eModeCategoriesData[emodeCategoryId] ? [...eModeCategoriesData[emodeCategoryId].collateralAssets, selectedMarket.assets[i]] : [selectedMarket.assets[i]],
82
+ borrowAssets: eModeCategoriesData[emodeCategoryId] ? [...eModeCategoriesData[emodeCategoryId].borrowAssets, selectedMarket.assets[i]] : [selectedMarket.assets[i]],
82
83
  };
83
84
  return ({
84
85
  symbol: selectedMarket.assets[i],
85
86
  isIsolated: new Dec(market.debtCeilingForIsolationMode.toString()).gt(0),
86
87
  debtCeilingForIsolationMode: new Dec(market.debtCeilingForIsolationMode.toString()).div(100).toString(),
87
88
  isSiloed: market.isSiloedForBorrowing,
88
- eModeCategory: +market.emodeCategory.toString(),
89
+ eModeCategory: emodeCategoryId,
89
90
  isolationModeTotalDebt: new Dec(market.isolationModeTotalDebt.toString()).div(100).toString(),
90
91
  assetId: Number(market.assetId),
91
92
  underlyingTokenAddress: market.underlyingTokenAddress,
@@ -93,6 +94,7 @@ export const _getSparkMarketsData = (provider, network, selectedMarket) => __awa
93
94
  borrowRate: aprToApy(new Dec(market.borrowRateVariable.toString()).div(1e25).toString()),
94
95
  borrowRateStable: aprToApy(new Dec(market.borrowRateStable.toString()).div(1e25).toString()),
95
96
  collateralFactor: new Dec(market.collateralFactor.toString()).div(10000).toString(),
97
+ liquidationBonus: eModeCategoriesData[emodeCategoryId].liquidationBonus,
96
98
  liquidationRatio: new Dec(market.liquidationRatio.toString()).div(10000).toString(),
97
99
  marketLiquidity,
98
100
  utilization: new Dec(market.totalBorrow.toString()).times(100).div(new Dec(market.totalSupply.toString())).toString(),
@@ -44,6 +44,7 @@ export interface SparkAssetData extends MMAssetData {
44
44
  usageAsCollateralEnabled: boolean;
45
45
  isIsolated: boolean;
46
46
  eModeCategory: number;
47
+ liquidationBonus: string;
47
48
  liquidationRatio: string;
48
49
  }
49
50
  export interface SparkAssetsData {