@defisaver/automation-sdk 3.3.11 → 3.3.12

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 (54) hide show
  1. package/cjs/automation/private/StrategiesAutomation.d.ts +2 -0
  2. package/cjs/automation/private/StrategiesAutomation.js +10 -1
  3. package/cjs/automation/private/StrategiesAutomation.test.js +25 -0
  4. package/cjs/constants/index.d.ts +1 -0
  5. package/cjs/constants/index.js +62 -1
  6. package/cjs/services/strategiesService.js +104 -0
  7. package/cjs/services/strategySubService.d.ts +6 -0
  8. package/cjs/services/strategySubService.js +30 -1
  9. package/cjs/services/strategySubService.test.js +96 -0
  10. package/cjs/services/subDataService.d.ts +295 -137
  11. package/cjs/services/subDataService.js +639 -393
  12. package/cjs/services/subDataService.test.js +157 -0
  13. package/cjs/services/triggerService.d.ts +29 -0
  14. package/cjs/services/triggerService.js +53 -1
  15. package/cjs/services/triggerService.test.js +84 -0
  16. package/cjs/services/utils.d.ts +1 -1
  17. package/cjs/services/utils.js +10 -2
  18. package/cjs/types/enums.d.ts +17 -3
  19. package/cjs/types/enums.js +14 -0
  20. package/cjs/types/index.d.ts +22 -1
  21. package/esm/automation/private/StrategiesAutomation.d.ts +2 -0
  22. package/esm/automation/private/StrategiesAutomation.js +10 -1
  23. package/esm/automation/private/StrategiesAutomation.test.js +25 -0
  24. package/esm/constants/index.d.ts +1 -0
  25. package/esm/constants/index.js +61 -0
  26. package/esm/services/strategiesService.js +105 -1
  27. package/esm/services/strategySubService.d.ts +6 -0
  28. package/esm/services/strategySubService.js +29 -0
  29. package/esm/services/strategySubService.test.js +97 -1
  30. package/esm/services/subDataService.d.ts +295 -137
  31. package/esm/services/subDataService.js +639 -393
  32. package/esm/services/subDataService.test.js +157 -0
  33. package/esm/services/triggerService.d.ts +29 -0
  34. package/esm/services/triggerService.js +52 -0
  35. package/esm/services/triggerService.test.js +85 -1
  36. package/esm/services/utils.d.ts +1 -1
  37. package/esm/services/utils.js +10 -2
  38. package/esm/types/enums.d.ts +17 -3
  39. package/esm/types/enums.js +14 -0
  40. package/esm/types/index.d.ts +22 -1
  41. package/package.json +2 -2
  42. package/src/automation/private/StrategiesAutomation.test.ts +40 -0
  43. package/src/automation/private/StrategiesAutomation.ts +11 -0
  44. package/src/constants/index.ts +62 -0
  45. package/src/services/strategiesService.ts +119 -1
  46. package/src/services/strategySubService.test.ts +124 -0
  47. package/src/services/strategySubService.ts +118 -0
  48. package/src/services/subDataService.test.ts +172 -0
  49. package/src/services/subDataService.ts +1031 -782
  50. package/src/services/triggerService.test.ts +97 -0
  51. package/src/services/triggerService.ts +74 -1
  52. package/src/services/utils.ts +15 -4
  53. package/src/types/enums.ts +14 -0
  54. package/src/types/index.ts +26 -0
@@ -11,10 +11,82 @@ import {
11
11
  ChainId, CollActionType, DebtActionType, RatioState,
12
12
  } from '../types/enums';
13
13
 
14
- import { AAVE_V3_VARIABLE_BORROW_RATE, ZERO_ADDRESS } from '../constants';
14
+ import { EMPTY_SLOT, ZERO_ADDRESS } from '../constants';
15
15
 
16
16
  import { compareAddresses, ratioPercentageToWei, weiToRatioPercentage } from './utils';
17
17
 
18
+ /**
19
+ _______ _______ .______ .______ _______ ______ ___ .___________. _______ _______
20
+ | \ | ____|| _ \ | _ \ | ____| / | / \ | || ____|| \
21
+ | .--. || |__ | |_) | | |_) | | |__ | ,----' / ^ \ `---| |----`| |__ | .--. |
22
+ | | | || __| | ___/ | / | __| | | / /_\ \ | | | __| | | | |
23
+ | '--' || |____ | | | |\ \----.| |____ | `----./ _____ \ | | | |____ | '--' |
24
+ |_______/ |_______|| _| | _| `._____||_______| \______/__/ \__\ |__| |_______||_______/
25
+ */
26
+ export const morphoAaveV2LeverageManagementSubData = {
27
+ encode(
28
+ triggerRepayRatio: number,
29
+ triggerBoostRatio: number,
30
+ targetBoostRatio: number,
31
+ targetRepayRatio: number,
32
+ boostEnabled: boolean,
33
+ ): SubData {
34
+ return [
35
+ ratioPercentageToWei(triggerRepayRatio),
36
+ ratioPercentageToWei(triggerBoostRatio),
37
+ ratioPercentageToWei(targetBoostRatio),
38
+ ratioPercentageToWei(targetRepayRatio),
39
+ // @ts-ignore
40
+ boostEnabled,
41
+ ];
42
+ },
43
+ decode(subData: SubData): { targetRatio: number } {
44
+ const ratioWei = AbiCoder.decodeParameter('uint128', subData[1]) as any as string;
45
+ const targetRatio = weiToRatioPercentage(ratioWei);
46
+
47
+ return { targetRatio };
48
+ },
49
+ };
50
+ export const cBondsRebondSubData = {
51
+ encode(bondId: number | string): SubData {
52
+ const bondIdEncoded = AbiCoder.encodeParameter('uint256', bondId);
53
+ return [bondIdEncoded];
54
+ },
55
+ decode(subData: SubData): { bondId: string } {
56
+ const bondId = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
57
+ return { bondId };
58
+ },
59
+ };
60
+ export const liquityPaybackUsingChickenBondSubData = {
61
+ /**
62
+ * @param sourceId bondId or subId
63
+ * @param sourceType 0 for bond, 1 for subId
64
+ * @param chainId
65
+ */
66
+ encode: (sourceId: string, sourceType: number, chainId: ChainId = ChainId.Ethereum): SubData => {
67
+ const sourceIdEncoded = AbiCoder.encodeParameter('uint256', sourceId);
68
+ const sourceTypeEncoded = AbiCoder.encodeParameter('uint256', sourceType);
69
+ const lusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('LUSD', chainId).address);
70
+ const bLusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('bLUSD', chainId).address);
71
+
72
+ return [sourceIdEncoded, sourceTypeEncoded, lusdAddressEncoded, bLusdAddressEncoded];
73
+ },
74
+ decode: (subData: SubData) => {
75
+ const sourceId = AbiCoder.decodeParameter('uint256', subData[0])!.toString();
76
+ const sourceType = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
77
+
78
+ return { sourceId, sourceType };
79
+ },
80
+ };
81
+
82
+ /**
83
+ .___ ___. ___ __ ___ _______ .______
84
+ | \/ | / \ | |/ / | ____|| _ \
85
+ | \ / | / ^ \ | ' / | |__ | |_) |
86
+ | |\/| | / /_\ \ | < | __| | /
87
+ | | | | / _____ \ | . \ | |____ | |\ \----.
88
+ |__| |__| /__/ \__\ |__|\__\ |_______|| _| `._____|
89
+ */
18
90
  export const makerRepayFromSavingsSubData = {
19
91
  encode(
20
92
  vaultId: number,
@@ -49,16 +121,6 @@ export const makerRepayFromSavingsSubData = {
49
121
  };
50
122
  },
51
123
  };
52
-
53
- export const liquityRepayFromSavingsSubData = {
54
- decode(subData: SubData): { targetRatio: number } {
55
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
56
- const targetRatio = weiToRatioPercentage(weiRatio);
57
-
58
- return { targetRatio };
59
- },
60
- };
61
-
62
124
  export const makerCloseSubData = {
63
125
  encode(
64
126
  vaultId: number,
@@ -94,7 +156,6 @@ export const makerCloseSubData = {
94
156
  };
95
157
  },
96
158
  };
97
-
98
159
  export const makerLeverageManagementSubData = {
99
160
  decode: (subData:SubData) => {
100
161
  const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!.toString();
@@ -103,7 +164,6 @@ export const makerLeverageManagementSubData = {
103
164
  return { vaultId, targetRatio };
104
165
  },
105
166
  };
106
-
107
167
  export const makerLeverageManagementWithoutSubProxy = {
108
168
  encode(
109
169
  vaultId: number,
@@ -124,6 +184,22 @@ export const makerLeverageManagementWithoutSubProxy = {
124
184
  },
125
185
  };
126
186
 
187
+ /**
188
+ __ __ ______ __ __ __ .___________.____ ____ ____ ____ __
189
+ | | | | / __ \ | | | | | | | |\ \ / / \ \ / / /_ |
190
+ | | | | | | | | | | | | | | `---| |----` \ \/ / \ \/ / | |
191
+ | | | | | | | | | | | | | | | | \_ _/ \ / | |
192
+ | `----.| | | `--' '--.| `--' | | | | | | | \ / | |
193
+ |_______||__| \_____\_____\\______/ |__| |__| |__| \__/ |_|
194
+ */
195
+ export const liquityRepayFromSavingsSubData = {
196
+ decode(subData: SubData): { targetRatio: number } {
197
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
198
+ const targetRatio = weiToRatioPercentage(weiRatio);
199
+
200
+ return { targetRatio };
201
+ },
202
+ };
127
203
  export const liquityLeverageManagementSubData = {
128
204
  decode: (subData:SubData) => {
129
205
  const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
@@ -131,7 +207,6 @@ export const liquityLeverageManagementSubData = {
131
207
  return { targetRatio };
132
208
  },
133
209
  };
134
-
135
210
  export const liquityCloseSubData = {
136
211
  encode(
137
212
  closeToAssetAddr: EthereumAddress,
@@ -158,262 +233,260 @@ export const liquityCloseSubData = {
158
233
  return { closeToAssetAddr, debtAddr };
159
234
  },
160
235
  };
236
+ export const liquityDsrPaybackSubData = {
237
+ encode: (targetRatio: number) => {
238
+ const daiAddress = getAssetInfo('DAI').address;
239
+ const lusdAddress = getAssetInfo('LUSD').address;
161
240
 
162
- export const aaveV2LeverageManagementSubData = {
163
- encode(
164
- triggerRepayRatio: number,
165
- triggerBoostRatio: number,
166
- targetBoostRatio: number,
167
- targetRepayRatio: number,
168
- boostEnabled: boolean,
169
- ): SubData {
170
- return [
171
- new Dec(triggerRepayRatio).mul(1e16).toString(),
172
- new Dec(triggerBoostRatio).mul(1e16).toString(),
173
- new Dec(targetBoostRatio).mul(1e16).toString(),
174
- new Dec(targetRepayRatio).mul(1e16).toString(),
175
- // @ts-ignore // TODO
176
- boostEnabled,
177
- ];
178
- },
179
- decode(subData: SubData): { targetRatio: number } {
180
- const ratioWei = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
181
- const targetRatio = weiToRatioPercentage(ratioWei);
241
+ const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
242
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
243
+ const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
244
+ const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
182
245
 
246
+ return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, lusdAddressEncoded];
247
+ },
248
+ decode: (subData: SubData) => {
249
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
250
+ const targetRatio = weiToRatioPercentage(weiRatio);
183
251
  return { targetRatio };
184
252
  },
185
253
  };
254
+ export const liquityDsrSupplySubData = {
255
+ encode: (targetRatio: number) => {
256
+ const daiAddress = getAssetInfo('DAI').address;
257
+ const wethAddress = getAssetInfo('WETH').address;
186
258
 
187
- export const aaveV3LeverageManagementSubData = {
188
- decode(subData: SubData): { targetRatio: number } {
189
- const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
190
- const targetRatio = weiToRatioPercentage(ratioWei);
259
+ const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
260
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
261
+ const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
262
+ const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
191
263
 
264
+ return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, wethAddressEncoded];
265
+ },
266
+ decode: (subData: SubData) => {
267
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
268
+ const targetRatio = weiToRatioPercentage(weiRatio);
192
269
  return { targetRatio };
193
270
  },
194
271
  };
272
+ export const liquityDebtInFrontRepaySubData = {
273
+ encode: (targetRatioIncrease: number) => {
274
+ const wethAddress = getAssetInfo('WETH').address;
275
+ const lusdAddress = getAssetInfo('LUSD').address;
195
276
 
196
- export const aaveV3LeverageManagementSubDataWithoutSubProxy = {
197
- encode(
198
- targetRatio: number,
199
- ratioState: RatioState,
200
- market: EthereumAddress,
201
- user: EthereumAddress,
202
- isGeneric: boolean,
203
- ): SubData {
204
- const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
205
- const encodedRatioState = AbiCoder.encodeParameter('uint8', ratioState);
277
+ const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
278
+ const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
279
+ const targetRatioIncreaseEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatioIncrease));
280
+ const withdrawIdEncoded = AbiCoder.encodeParameter('uint8', 1); // withdraw - 1
281
+ const paybackIdEncoded = AbiCoder.encodeParameter('uint8', 0); // payback - 0
206
282
 
207
- if (isGeneric) {
208
- const encodedMarket = AbiCoder.encodeParameter('address', market);
209
- const encodedUser = AbiCoder.encodeParameter('address', user);
210
- return [encodedTargetRatio, encodedRatioState, encodedMarket, encodedUser];
211
- }
212
- const encodedUseDefaultMarket = AbiCoder.encodeParameter('bool', true);
213
- const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', false);
214
- return [encodedTargetRatio, encodedRatioState, encodedUseDefaultMarket, encodedUseOnBehalf];
283
+ return [wethAddressEncoded, lusdAddressEncoded, targetRatioIncreaseEncoded, withdrawIdEncoded, paybackIdEncoded];
215
284
  },
216
- decode(subData: SubData): { targetRatio: number, ratioState: RatioState } {
217
- const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[0]) as any as string);
218
- const ratioState = AbiCoder.decodeParameter('uint8', subData[1]) as any as RatioState;
219
-
220
- return { targetRatio, ratioState };
285
+ decode: (subData: SubData) => {
286
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
287
+ const targetRatioIncrease = weiToRatioPercentage(weiRatio);
288
+ return { targetRatioIncrease };
221
289
  },
222
290
  };
223
291
 
224
- export const aaveV3LeverageManagementOnPriceGeneric = {
225
- encode(
226
- collAsset: EthereumAddress,
227
- collAssetId: number,
228
- debtAsset: EthereumAddress,
229
- debtAssetId: number,
230
- marketAddr: EthereumAddress,
292
+ /**
293
+ * __ __ ______ __ __ __ .___________.____ ____ ____ ____ ___
294
+ | | | | / __ \ | | | | | | | |\ \ / / \ \ / / |__ \
295
+ | | | | | | | | | | | | | | `---| |----` \ \/ / \ \/ / ) |
296
+ | | | | | | | | | | | | | | | | \_ _/ \ / / /
297
+ | `----.| | | `--' '--.| `--' | | | | | | | \ / / /_
298
+ |_______||__| \_____\_____\\______/ |__| |__| |__| \__/ |____|
299
+ */
300
+ export const liquityV2LeverageManagementSubData = {
301
+ encode: (
302
+ market: EthereumAddress,
303
+ troveId: string,
304
+ collToken: EthereumAddress,
305
+ boldToken: EthereumAddress,
306
+ ratioState: RatioState,
231
307
  targetRatio: number,
232
- user: EthereumAddress,
233
- ): SubData {
234
- const encodedColl = AbiCoder.encodeParameter('address', collAsset);
235
- const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
236
- const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
237
- const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
238
- const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
239
- const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
240
- const userEncoded = AbiCoder.encodeParameter('address', user);
308
+ ) => {
309
+ const marketEncoded = AbiCoder.encodeParameter('address', market);
310
+ const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
311
+ const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
312
+ const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
313
+ const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
314
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
315
+
316
+ const isRepay = ratioState === RatioState.UNDER;
317
+ const collActionType = isRepay ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
318
+ const debtActionType = isRepay ? DebtActionType.PAYBACK : DebtActionType.BORROW;
319
+
320
+ const collActionTypeEncoded = AbiCoder.encodeParameter('uint8', collActionType);
321
+ const debtActionTypeEncoded = AbiCoder.encodeParameter('uint8', debtActionType);
241
322
 
242
323
  return [
243
- encodedColl,
244
- encodedCollId,
245
- encodedDebt,
246
- encodedDebtId,
247
- encodedMarket,
248
- encodedTargetRatio,
249
- userEncoded,
324
+ marketEncoded,
325
+ troveIdEncoded,
326
+ collTokenEncoded,
327
+ boldTokenEncoded,
328
+ ratioStateEncoded,
329
+ targetRatioEncoded,
330
+ collActionTypeEncoded,
331
+ debtActionTypeEncoded,
250
332
  ];
251
333
  },
252
- decode(subData: SubData): {
253
- collAsset: EthereumAddress,
254
- collAssetId: number,
255
- debtAsset: EthereumAddress,
256
- debtAssetId: number,
257
- marketAddr: EthereumAddress,
258
- targetRatio: number,
259
- owner: EthereumAddress,
260
- } {
261
- const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
262
- const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
263
- const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
264
- const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
265
- const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
266
-
267
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as unknown as string;
334
+ decode: (subData: SubData) => {
335
+ const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
336
+ const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
337
+ const collToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
338
+ const boldToken = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
339
+ const ratioState = AbiCoder.decodeParameter('uint8', subData[4]) as any as RatioState;
340
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
268
341
  const targetRatio = weiToRatioPercentage(weiRatio);
269
342
 
270
- const owner = AbiCoder.decodeParameter('address', subData[6]) as unknown as EthereumAddress;
271
-
272
343
  return {
273
- collAsset,
274
- collAssetId,
275
- debtAsset,
276
- debtAssetId,
277
- marketAddr,
278
- targetRatio,
279
- owner,
344
+ market, troveId, collToken, boldToken, ratioState, targetRatio,
280
345
  };
281
346
  },
282
347
  };
283
-
284
- export const aaveV3CloseGenericSubData = {
348
+ export const liquityV2CloseSubData = {
285
349
  encode(
286
- collAsset: EthereumAddress,
287
- collAssetId: number,
288
- debtAsset: EthereumAddress,
289
- debtAssetId: number,
350
+ market: EthereumAddress,
351
+ troveId: string,
352
+ collToken: EthereumAddress,
353
+ boldToken: EthereumAddress,
290
354
  closeType: CloseStrategyType,
291
- marketAddr: EthereumAddress,
292
- user: EthereumAddress,
293
355
  ): SubData {
294
- const encodedColl = AbiCoder.encodeParameter('address', collAsset);
295
- const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
296
- const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
297
- const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
298
- const encodedCloseType = AbiCoder.encodeParameter('uint8', closeType);
299
- const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
300
- const userEncoded = AbiCoder.encodeParameter('address', user);
356
+ const marketEncoded = AbiCoder.encodeParameter('address', market);
357
+ const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
358
+ const collAddrEncoded = AbiCoder.encodeParameter('address', collToken);
359
+ const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
360
+ const wethAddress = getAssetInfo('WETH').address;
361
+ const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
362
+ const gasCompensation = new Dec('0.0375').mul(1e18).toString();
363
+ const gasCompensationEncoded = AbiCoder.encodeParameter('uint256', gasCompensation);
364
+ const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
301
365
 
302
366
  return [
303
- encodedColl,
304
- encodedCollId,
305
- encodedDebt,
306
- encodedDebtId,
307
- encodedCloseType,
308
- encodedMarket,
309
- userEncoded,
367
+ marketEncoded,
368
+ troveIdEncoded,
369
+ collAddrEncoded,
370
+ boldTokenEncoded,
371
+ wethAddressEncoded,
372
+ gasCompensationEncoded,
373
+ closeTypeEncoded,
310
374
  ];
311
375
  },
312
-
313
376
  decode(subData: SubData): {
314
- collAsset: EthereumAddress,
315
- collAssetId: number,
316
- debtAsset: EthereumAddress,
317
- debtAssetId: number,
377
+ market: EthereumAddress,
378
+ troveId: string,
379
+ collToken: EthereumAddress,
380
+ boldToken: EthereumAddress,
318
381
  closeType: CloseStrategyType,
319
- marketAddr: EthereumAddress,
320
- owner: EthereumAddress,
321
382
  } {
322
- const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
323
- const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
324
- const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
325
- const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
326
- const closeType = Number(AbiCoder.decodeParameter('uint8', subData[4])) as CloseStrategyType;
327
- const marketAddr = AbiCoder.decodeParameter('address', subData[5]) as unknown as EthereumAddress;
328
- const owner = AbiCoder.decodeParameter('address', subData[6]) as unknown as EthereumAddress;
383
+ const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
384
+ const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
385
+ const collToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
386
+ const boldToken = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
387
+ // skip wethAddress and gasCompensation
388
+ const closeType = AbiCoder.decodeParameter('uint8', subData[6]) as any as CloseStrategyType;
329
389
 
330
390
  return {
331
- collAsset, collAssetId, debtAsset, debtAssetId, closeType, marketAddr, owner,
391
+ market, troveId, collToken, boldToken, closeType,
332
392
  };
333
393
  },
334
394
  };
335
-
336
- export const aaveV3CollateralSwitchSubData = {
395
+ export const liquityV2LeverageManagementOnPriceSubData = {
337
396
  encode(
338
- fromAsset: EthereumAddress,
339
- fromAssetId: number,
340
- toAsset: EthereumAddress,
341
- toAssetId: number,
342
- marketAddr: EthereumAddress,
343
- amountToSwitch: string,
344
- useOnBehalf: boolean = false,
397
+ market: EthereumAddress,
398
+ troveId: string,
399
+ collToken: EthereumAddress,
400
+ boldToken: EthereumAddress,
401
+ targetRatio: number,
402
+ isRepayOnPrice: boolean,
345
403
  ): SubData {
346
- const encodedFromAsset = AbiCoder.encodeParameter('address', fromAsset);
347
- const encodedFromAssetId = AbiCoder.encodeParameter('uint8', fromAssetId);
348
- const encodedToAsset = AbiCoder.encodeParameter('address', toAsset);
349
- const encodedToAssetId = AbiCoder.encodeParameter('uint8', toAssetId);
350
- const encodedMarketAddr = AbiCoder.encodeParameter('address', marketAddr);
351
- const encodedAmountToSwitch = AbiCoder.encodeParameter('uint256', amountToSwitch);
352
- const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', useOnBehalf);
404
+ const encodedMarket = AbiCoder.encodeParameter('address', market);
405
+ const encodedTroveId = AbiCoder.encodeParameter('uint256', troveId);
406
+ const encodedCollToken = AbiCoder.encodeParameter('address', collToken);
407
+ const encodedBoldToken = AbiCoder.encodeParameter('address', boldToken);
408
+ const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
409
+
410
+ const collActionType = isRepayOnPrice ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
411
+ const debtActionType = isRepayOnPrice ? DebtActionType.PAYBACK : DebtActionType.BORROW;
412
+
413
+ const encodedCollActionType = AbiCoder.encodeParameter('uint8', collActionType);
414
+ const encodedDebtActionType = AbiCoder.encodeParameter('uint8', debtActionType);
353
415
 
354
416
  return [
355
- encodedFromAsset,
356
- encodedFromAssetId,
357
- encodedToAsset,
358
- encodedToAssetId,
359
- encodedMarketAddr,
360
- encodedAmountToSwitch,
361
- encodedUseOnBehalf,
417
+ encodedMarket,
418
+ encodedTroveId,
419
+ encodedCollToken,
420
+ encodedBoldToken,
421
+ encodedTargetRatio,
422
+ encodedCollActionType,
423
+ encodedDebtActionType,
362
424
  ];
363
425
  },
364
426
  decode(subData: SubData): {
365
- fromAsset: EthereumAddress,
366
- fromAssetId: number,
367
- toAsset: EthereumAddress,
368
- toAssetId: number,
369
- marketAddr: EthereumAddress,
370
- amountToSwitch: string,
427
+ market: EthereumAddress,
428
+ troveId: string,
429
+ collToken: EthereumAddress,
430
+ boldToken: EthereumAddress,
431
+ targetRatio: number,
371
432
  } {
372
- const fromAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
373
- const fromAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
374
- const toAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
375
- const toAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
376
- const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
377
- const amountToSwitch = AbiCoder.decodeParameter('uint256', subData[5]) as unknown as string;
433
+ const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
434
+ const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
435
+ const collToken = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
436
+ const boldToken = AbiCoder.decodeParameter('address', subData[3]) as unknown as EthereumAddress;
437
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[4]) as any as string;
438
+ const targetRatio = weiToRatioPercentage(weiRatio);
378
439
 
379
440
  return {
380
- fromAsset, fromAssetId, toAsset, toAssetId, marketAddr, amountToSwitch,
441
+ market, troveId, collToken, boldToken, targetRatio,
381
442
  };
382
443
  },
383
444
  };
445
+ export const liquityV2PaybackSubData = {
446
+ encode: (
447
+ market: EthereumAddress,
448
+ troveId: string,
449
+ boldToken: EthereumAddress,
450
+ targetRatio: number,
451
+ ratioState: RatioState,
452
+ ) => {
453
+ const marketEncoded = AbiCoder.encodeParameter('address', market);
454
+ const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
455
+ const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
456
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
457
+ const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
384
458
 
385
- export const aaveV3QuotePriceSubData = {
386
- encode(
387
- collAsset: EthereumAddress,
388
- collAssetId: number,
389
- debtAsset: EthereumAddress,
390
- debtAssetId: number,
391
- nullAddress: EthereumAddress = ZERO_ADDRESS,
392
- ): SubData {
393
- const encodedColl = AbiCoder.encodeParameter('address', collAsset);
394
- const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
395
-
396
- const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
397
- const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
398
-
399
- const encodedNullAddress = AbiCoder.encodeParameter('address', nullAddress);
400
-
401
- return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedNullAddress];
459
+ return [
460
+ marketEncoded,
461
+ troveIdEncoded,
462
+ boldTokenEncoded,
463
+ targetRatioEncoded,
464
+ ratioStateEncoded,
465
+ ];
402
466
  },
403
- decode(subData: SubData): { collAsset: EthereumAddress, collAssetId: number, debtAsset: EthereumAddress, debtAssetId: number } {
404
- const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
405
- const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
406
-
407
- const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
408
- const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
467
+ decode: (subData: SubData) => {
468
+ const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
469
+ const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
470
+ const boldToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
471
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
472
+ const ratioState = AbiCoder.decodeParameter('uint8', subData[4]) as any as RatioState;
473
+ const targetRatio = weiToRatioPercentage(weiRatio);
409
474
 
410
475
  return {
411
- collAsset, collAssetId, debtAsset, debtAssetId,
476
+ market, troveId, boldToken, ratioState, targetRatio,
412
477
  };
413
478
  },
414
479
  };
415
480
 
416
- export const compoundV2LeverageManagementSubData = {
481
+ /**
482
+ ___ ___ ____ ____ _______ ____ ____ ___
483
+ / \ / \ \ \ / / | ____| \ \ / / |__ \
484
+ / ^ \ / ^ \ \ \/ / | |__ \ \/ / ) |
485
+ / /_\ \ / /_\ \ \ / | __| \ / / /
486
+ / _____ \ / _____ \ \ / | |____ \ / / /_
487
+ /__/ \__\ /__/ \__\ \__/ |_______| \__/ |____|
488
+ */
489
+ export const aaveV2LeverageManagementSubData = {
417
490
  encode(
418
491
  triggerRepayRatio: number,
419
492
  triggerBoostRatio: number,
@@ -431,195 +504,45 @@ export const compoundV2LeverageManagementSubData = {
431
504
  ];
432
505
  },
433
506
  decode(subData: SubData): { targetRatio: number } {
434
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
435
- const targetRatio = weiToRatioPercentage(weiRatio);
507
+ const ratioWei = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
508
+ const targetRatio = weiToRatioPercentage(ratioWei);
436
509
 
437
510
  return { targetRatio };
438
511
  },
439
512
  };
440
513
 
441
- export const compoundV3LeverageManagementSubData = {
442
- encode(
443
- market: EthereumAddress,
444
- baseToken: EthereumAddress,
445
- triggerRepayRatio: number,
446
- triggerBoostRatio: number,
447
- targetBoostRatio: number,
448
- targetRepayRatio: number,
449
- boostEnabled: boolean,
450
- isEOA: boolean,
451
- ): SubData {
452
- return [
453
- market,
454
- baseToken,
455
- new Dec(triggerRepayRatio).mul(1e16).toString(),
456
- new Dec(triggerBoostRatio).mul(1e16).toString(),
457
- new Dec(targetBoostRatio).mul(1e16).toString(),
458
- new Dec(targetRepayRatio).mul(1e16).toString(),
459
- // @ts-ignore // TODO
460
- boostEnabled, isEOA,
461
- ];
462
- },
514
+ /**
515
+ ___ ___ ____ ____ _______ ____ ____ ____
516
+ / \ / \ \ \ / / | ____| \ \ / / |___ \
517
+ / ^ \ / ^ \ \ \/ / | |__ \ \/ / __) |
518
+ / /_\ \ / /_\ \ \ / | __| \ / |__ <
519
+ / _____ \ / _____ \ \ / | |____ \ / ___) |
520
+ /__/ \__\ /__/ \__\ \__/ |_______| \__/ |____/
521
+ */
522
+ export const aaveV3LeverageManagementSubData = {
463
523
  decode(subData: SubData): { targetRatio: number } {
464
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
465
- const targetRatio = weiToRatioPercentage(weiRatio);
524
+ const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
525
+ const targetRatio = weiToRatioPercentage(ratioWei);
466
526
 
467
527
  return { targetRatio };
468
528
  },
469
529
  };
470
-
471
- export const compoundV3L2LeverageManagementSubData = {
530
+ export const aaveV3LeverageManagementSubDataWithoutSubProxy = {
472
531
  encode(
532
+ targetRatio: number,
533
+ ratioState: RatioState,
473
534
  market: EthereumAddress,
474
- baseToken: EthereumAddress,
475
- triggerRepayRatio: number,
476
- triggerBoostRatio: number,
477
- targetBoostRatio: number,
478
- targetRepayRatio: number,
479
- boostEnabled: boolean,
480
- isEOA: boolean,
481
- ): string {
482
- let subInput = '0x';
483
-
484
- subInput = subInput.concat(market.slice(2));
485
- subInput = subInput.concat(baseToken.slice(2));
486
- subInput = subInput.concat(new Dec(triggerRepayRatio).mul(1e16).toHex().slice(2)
487
- .padStart(32, '0'));
488
- subInput = subInput.concat(new Dec(triggerBoostRatio).mul(1e16).toHex().slice(2)
489
- .padStart(32, '0'));
490
- subInput = subInput.concat(new Dec(targetBoostRatio).mul(1e16).toHex().slice(2)
491
- .padStart(32, '0'));
492
- subInput = subInput.concat(new Dec(targetRepayRatio).mul(1e16).toHex().slice(2)
493
- .padStart(32, '0'));
494
- subInput = subInput.concat(boostEnabled ? '01' : '00');
495
- subInput = subInput.concat(isEOA ? '01' : '00');
496
-
497
- return subInput;
498
- },
499
- decode(subData: SubData): { targetRatio: number } {
500
- const ratioWei = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
501
- const targetRatio = weiToRatioPercentage(ratioWei);
502
-
503
- return { targetRatio };
504
- },
505
- };
506
-
507
- export const morphoAaveV2LeverageManagementSubData = {
508
- encode(
509
- triggerRepayRatio: number,
510
- triggerBoostRatio: number,
511
- targetBoostRatio: number,
512
- targetRepayRatio: number,
513
- boostEnabled: boolean,
514
- ): SubData {
515
- return [
516
- ratioPercentageToWei(triggerRepayRatio),
517
- ratioPercentageToWei(triggerBoostRatio),
518
- ratioPercentageToWei(targetBoostRatio),
519
- ratioPercentageToWei(targetRepayRatio),
520
- // @ts-ignore
521
- boostEnabled,
522
- ];
523
- },
524
- decode(subData: SubData): { targetRatio: number } {
525
- const ratioWei = AbiCoder.decodeParameter('uint128', subData[1]) as any as string;
526
- const targetRatio = weiToRatioPercentage(ratioWei);
527
-
528
- return { targetRatio };
529
- },
530
- };
531
-
532
- export const cBondsRebondSubData = {
533
- encode(bondId: number | string): SubData {
534
- const bondIdEncoded = AbiCoder.encodeParameter('uint256', bondId);
535
- return [bondIdEncoded];
536
- },
537
- decode(subData: SubData): { bondId: string } {
538
- const bondId = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
539
- return { bondId };
540
- },
541
- };
542
-
543
- export const liquityPaybackUsingChickenBondSubData = {
544
- /**
545
- * @param sourceId bondId or subId
546
- * @param sourceType 0 for bond, 1 for subId
547
- * @param chainId
548
- */
549
- encode: (sourceId: string, sourceType: number, chainId: ChainId = ChainId.Ethereum): SubData => {
550
- const sourceIdEncoded = AbiCoder.encodeParameter('uint256', sourceId);
551
- const sourceTypeEncoded = AbiCoder.encodeParameter('uint256', sourceType);
552
- const lusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('LUSD', chainId).address);
553
- const bLusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('bLUSD', chainId).address);
554
-
555
- return [sourceIdEncoded, sourceTypeEncoded, lusdAddressEncoded, bLusdAddressEncoded];
556
- },
557
- decode: (subData: SubData) => {
558
- const sourceId = AbiCoder.decodeParameter('uint256', subData[0])!.toString();
559
- const sourceType = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
560
-
561
- return { sourceId, sourceType };
562
- },
563
- };
564
-
565
- export const exchangeDcaSubData = {
566
- encode: (fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, interval: number) : SubData => {
567
- const sellTokenEncoded = AbiCoder.encodeParameter('address', fromToken);
568
- const buyTokenEncoded = AbiCoder.encodeParameter('address', toToken);
569
- const amountEncoded = AbiCoder.encodeParameter('uint256', amount);
570
- const intervalEncoded = AbiCoder.encodeParameter('uint256', interval);
571
-
572
- return [sellTokenEncoded, buyTokenEncoded, amountEncoded, intervalEncoded];
573
- },
574
- decode: (subData: SubData, chainId: ChainId) => {
575
- const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
576
- const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
577
- const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
578
- const interval = AbiCoder.decodeParameter('uint256', subData[3])!.toString();
579
- return {
580
- fromToken,
581
- toToken,
582
- amount,
583
- interval,
584
- };
585
- },
586
- };
587
-
588
- export const exchangeLimitOrderSubData = {
589
- encode(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, targetPrice: string, goodUntil: string | number, orderType: OrderType) : SubData {
590
- return [
591
- fromToken,
592
- toToken,
593
- amount,
594
- targetPrice,
595
- new Dec(goodUntil).toString(),
596
- new Dec(orderType).toString(),
597
- ];
598
- },
599
- decode: (subData: SubData, chainId: ChainId) => {
600
- const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
601
- const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
602
- const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
603
- return { fromToken, toToken, amount };
604
- },
605
- };
606
-
607
- export const sparkLeverageManagementSubData = { // TODO encode?
608
- decode(subData: SubData): { targetRatio: number } {
609
- const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
610
- const targetRatio = weiToRatioPercentage(ratioWei);
611
-
612
- return { targetRatio };
613
- },
614
- };
615
- export const sparkLeverageManagementSubDataWithoutSubProxy = {
616
- encode(
617
- targetRatio: number,
618
- ratioState: RatioState,
619
- ): SubData {
620
- const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
621
- const encodedRatioState = AbiCoder.encodeParameter('uint8', ratioState);
535
+ user: EthereumAddress,
536
+ isGeneric: boolean,
537
+ ): SubData {
538
+ const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
539
+ const encodedRatioState = AbiCoder.encodeParameter('uint8', ratioState);
622
540
 
541
+ if (isGeneric) {
542
+ const encodedMarket = AbiCoder.encodeParameter('address', market);
543
+ const encodedUser = AbiCoder.encodeParameter('address', user);
544
+ return [encodedTargetRatio, encodedRatioState, encodedMarket, encodedUser];
545
+ }
623
546
  const encodedUseDefaultMarket = AbiCoder.encodeParameter('bool', true);
624
547
  const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', false);
625
548
  return [encodedTargetRatio, encodedRatioState, encodedUseDefaultMarket, encodedUseOnBehalf];
@@ -631,488 +554,522 @@ export const sparkLeverageManagementSubDataWithoutSubProxy = {
631
554
  return { targetRatio, ratioState };
632
555
  },
633
556
  };
634
-
635
-
636
- export const liquityDsrPaybackSubData = {
637
- encode: (targetRatio: number) => {
638
- const daiAddress = getAssetInfo('DAI').address;
639
- const lusdAddress = getAssetInfo('LUSD').address;
640
-
641
- const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
642
- const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
643
- const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
644
- const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
645
-
646
- return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, lusdAddressEncoded];
647
- },
648
- decode: (subData: SubData) => {
649
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
650
- const targetRatio = weiToRatioPercentage(weiRatio);
651
- return { targetRatio };
652
- },
653
- };
654
-
655
- export const liquityDsrSupplySubData = {
656
- encode: (targetRatio: number) => {
657
- const daiAddress = getAssetInfo('DAI').address;
658
- const wethAddress = getAssetInfo('WETH').address;
659
-
660
- const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
661
- const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
662
- const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
663
- const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
664
-
665
- return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, wethAddressEncoded];
666
- },
667
- decode: (subData: SubData) => {
668
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
669
- const targetRatio = weiToRatioPercentage(weiRatio);
670
- return { targetRatio };
671
- },
672
- };
673
-
674
- export const liquityDebtInFrontRepaySubData = {
675
- encode: (targetRatioIncrease: number) => {
676
- const wethAddress = getAssetInfo('WETH').address;
677
- const lusdAddress = getAssetInfo('LUSD').address;
678
-
679
- const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
680
- const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
681
- const targetRatioIncreaseEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatioIncrease));
682
- const withdrawIdEncoded = AbiCoder.encodeParameter('uint8', 1); // withdraw - 1
683
- const paybackIdEncoded = AbiCoder.encodeParameter('uint8', 0); // payback - 0
684
-
685
- return [wethAddressEncoded, lusdAddressEncoded, targetRatioIncreaseEncoded, withdrawIdEncoded, paybackIdEncoded];
686
- },
687
- decode: (subData: SubData) => {
688
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
689
- const targetRatioIncrease = weiToRatioPercentage(weiRatio);
690
- return { targetRatioIncrease };
691
- },
692
- };
693
-
694
- export const crvUSDLeverageManagementSubData = {
695
- encode: (
696
- controllerAddr: EthereumAddress,
697
- ratioState: RatioState,
557
+ export const aaveV3LeverageManagementOnPriceGeneric = {
558
+ encode(
559
+ collAsset: EthereumAddress,
560
+ collAssetId: number,
561
+ debtAsset: EthereumAddress,
562
+ debtAssetId: number,
563
+ marketAddr: EthereumAddress,
698
564
  targetRatio: number,
699
- collTokenAddr: EthereumAddress,
700
- crvUSDAddr: EthereumAddress,
701
- ) => {
702
- const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
703
- const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
704
- const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
705
- const collTokenAddrEncoded = AbiCoder.encodeParameter('address', collTokenAddr);
706
- const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
707
- return [controllerAddrEncoded, ratioStateEncoded, targetRatioEncoded, collTokenAddrEncoded, crvUSDAddrEncoded];
708
- },
709
- decode: (subData: SubData) => {
710
- const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
711
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
712
- const targetRatio = weiToRatioPercentage(weiRatio);
713
-
714
- return { controller, targetRatio };
715
- },
716
- };
565
+ user: EthereumAddress,
566
+ ): SubData {
567
+ const encodedColl = AbiCoder.encodeParameter('address', collAsset);
568
+ const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
569
+ const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
570
+ const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
571
+ const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
572
+ const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
573
+ const userEncoded = AbiCoder.encodeParameter('address', user);
717
574
 
718
- export const crvUSDPaybackSubData = {
719
- encode: (
720
- controllerAddr: EthereumAddress,
721
- addressToPullTokensFrom: EthereumAddress,
722
- positionOwner: EthereumAddress,
723
- paybackAmount: string,
724
- crvUSDAddr: EthereumAddress,
725
- ) => {
726
- const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
727
- const addressToPullTokensFromEncoded = AbiCoder.encodeParameter('address', addressToPullTokensFrom);
728
- const positionOwnerEncoded = AbiCoder.encodeParameter('address', positionOwner);
729
- const paybackAmountEncoded = AbiCoder.encodeParameter('uint256', toWei(paybackAmount, 'ether'));
730
- const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
731
575
  return [
732
- controllerAddrEncoded,
733
- addressToPullTokensFromEncoded,
734
- positionOwnerEncoded,
735
- paybackAmountEncoded,
736
- crvUSDAddrEncoded,
576
+ encodedColl,
577
+ encodedCollId,
578
+ encodedDebt,
579
+ encodedDebtId,
580
+ encodedMarket,
581
+ encodedTargetRatio,
582
+ userEncoded,
737
583
  ];
738
584
  },
739
- decode: (subData: SubData) => {
740
- const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
741
- const addressToPullTokensFrom = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
742
- const positionOwner = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
743
- const weiPaybackAmount = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
744
- const paybackAmount = fromWei(weiPaybackAmount, 'ether');
745
- return {
746
- controller,
747
- addressToPullTokensFrom,
748
- positionOwner,
749
- paybackAmount,
750
- };
751
- },
752
- };
753
-
754
- export const morphoBlueLeverageManagementSubData = {
755
- encode: (
756
- loanToken: EthereumAddress,
757
- collToken: EthereumAddress,
758
- oracle: EthereumAddress,
759
- irm: EthereumAddress,
760
- lltv: string,
761
- ratioState: RatioState,
585
+ decode(subData: SubData): {
586
+ collAsset: EthereumAddress,
587
+ collAssetId: number,
588
+ debtAsset: EthereumAddress,
589
+ debtAssetId: number,
590
+ marketAddr: EthereumAddress,
762
591
  targetRatio: number,
763
- user: EthereumAddress,
764
- isEOA: boolean,
765
- ) => {
766
- const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
767
- const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
768
- const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
769
- const irmEncoded = AbiCoder.encodeParameter('address', irm);
770
- const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
771
- const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
772
- const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
773
- const userEncoded = AbiCoder.encodeParameter('address', user);
774
- const isEOAEncoded = AbiCoder.encodeParameter('bool', isEOA);
775
- return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, ratioStateEncoded, targetRatioEncoded, userEncoded, isEOAEncoded];
776
- },
777
- decode: (subData: SubData) => {
778
- const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
779
- const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
780
- const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
781
- const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
782
- const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
783
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[6]) as any as EthereumAddress;
784
- const user = AbiCoder.decodeParameter('address', subData[7]) as any as EthereumAddress;
592
+ owner: EthereumAddress,
593
+ } {
594
+ const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
595
+ const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
596
+ const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
597
+ const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
598
+ const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
599
+
600
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as unknown as string;
785
601
  const targetRatio = weiToRatioPercentage(weiRatio);
786
602
 
603
+ const owner = AbiCoder.decodeParameter('address', subData[6]) as unknown as EthereumAddress;
604
+
787
605
  return {
788
- loanToken,
789
- collToken,
790
- oracle,
791
- irm,
792
- lltv,
793
- user,
606
+ collAsset,
607
+ collAssetId,
608
+ debtAsset,
609
+ debtAssetId,
610
+ marketAddr,
794
611
  targetRatio,
612
+ owner,
795
613
  };
796
614
  },
797
- };
798
-
799
- export const aaveV3LeverageManagementOnPriceSubData = {
615
+ };
616
+ export const aaveV3CloseGenericSubData = {
800
617
  encode(
801
618
  collAsset: EthereumAddress,
802
619
  collAssetId: number,
803
620
  debtAsset: EthereumAddress,
804
621
  debtAssetId: number,
622
+ closeType: CloseStrategyType,
805
623
  marketAddr: EthereumAddress,
806
- targetRatio: number,
624
+ user: EthereumAddress,
807
625
  ): SubData {
808
626
  const encodedColl = AbiCoder.encodeParameter('address', collAsset);
809
627
  const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
810
628
  const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
811
629
  const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
630
+ const encodedCloseType = AbiCoder.encodeParameter('uint8', closeType);
812
631
  const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
813
- const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
814
- const useOnBehalfEncoded = AbiCoder.encodeParameter('bool', false);
632
+ const userEncoded = AbiCoder.encodeParameter('address', user);
815
633
 
816
634
  return [
817
635
  encodedColl,
818
636
  encodedCollId,
819
637
  encodedDebt,
820
638
  encodedDebtId,
639
+ encodedCloseType,
821
640
  encodedMarket,
822
- encodedTargetRatio,
823
- useOnBehalfEncoded,
641
+ userEncoded,
824
642
  ];
825
643
  },
644
+
826
645
  decode(subData: SubData): {
827
646
  collAsset: EthereumAddress,
828
647
  collAssetId: number,
829
648
  debtAsset: EthereumAddress,
830
649
  debtAssetId: number,
650
+ closeType: CloseStrategyType,
831
651
  marketAddr: EthereumAddress,
832
- targetRatio: number,
652
+ owner: EthereumAddress,
833
653
  } {
834
654
  const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
835
655
  const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
836
656
  const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
837
657
  const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
838
- const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
839
-
840
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
841
- const targetRatio = weiToRatioPercentage(weiRatio);
658
+ const closeType = Number(AbiCoder.decodeParameter('uint8', subData[4])) as CloseStrategyType;
659
+ const marketAddr = AbiCoder.decodeParameter('address', subData[5]) as unknown as EthereumAddress;
660
+ const owner = AbiCoder.decodeParameter('address', subData[6]) as unknown as EthereumAddress;
842
661
 
843
662
  return {
844
- collAsset, collAssetId, debtAsset, debtAssetId, marketAddr, targetRatio,
663
+ collAsset, collAssetId, debtAsset, debtAssetId, closeType, marketAddr, owner,
845
664
  };
846
665
  },
847
666
  };
848
-
849
- export const liquityV2LeverageManagementSubData = {
850
- encode: (
851
- market: EthereumAddress,
852
- troveId: string,
853
- collToken: EthereumAddress,
854
- boldToken: EthereumAddress,
855
- ratioState: RatioState,
856
- targetRatio: number,
857
- ) => {
858
- const marketEncoded = AbiCoder.encodeParameter('address', market);
859
- const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
860
- const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
861
- const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
862
- const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
863
- const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
864
-
865
- const isRepay = ratioState === RatioState.UNDER;
866
- const collActionType = isRepay ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
867
- const debtActionType = isRepay ? DebtActionType.PAYBACK : DebtActionType.BORROW;
868
-
869
- const collActionTypeEncoded = AbiCoder.encodeParameter('uint8', collActionType);
870
- const debtActionTypeEncoded = AbiCoder.encodeParameter('uint8', debtActionType);
667
+ export const aaveV3CollateralSwitchSubData = {
668
+ encode(
669
+ fromAsset: EthereumAddress,
670
+ fromAssetId: number,
671
+ toAsset: EthereumAddress,
672
+ toAssetId: number,
673
+ marketAddr: EthereumAddress,
674
+ amountToSwitch: string,
675
+ useOnBehalf: boolean = false,
676
+ ): SubData {
677
+ const encodedFromAsset = AbiCoder.encodeParameter('address', fromAsset);
678
+ const encodedFromAssetId = AbiCoder.encodeParameter('uint8', fromAssetId);
679
+ const encodedToAsset = AbiCoder.encodeParameter('address', toAsset);
680
+ const encodedToAssetId = AbiCoder.encodeParameter('uint8', toAssetId);
681
+ const encodedMarketAddr = AbiCoder.encodeParameter('address', marketAddr);
682
+ const encodedAmountToSwitch = AbiCoder.encodeParameter('uint256', amountToSwitch);
683
+ const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', useOnBehalf);
871
684
 
872
685
  return [
873
- marketEncoded,
874
- troveIdEncoded,
875
- collTokenEncoded,
876
- boldTokenEncoded,
877
- ratioStateEncoded,
878
- targetRatioEncoded,
879
- collActionTypeEncoded,
880
- debtActionTypeEncoded,
686
+ encodedFromAsset,
687
+ encodedFromAssetId,
688
+ encodedToAsset,
689
+ encodedToAssetId,
690
+ encodedMarketAddr,
691
+ encodedAmountToSwitch,
692
+ encodedUseOnBehalf,
881
693
  ];
882
694
  },
883
- decode: (subData: SubData) => {
884
- const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
885
- const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
886
- const collToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
887
- const boldToken = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
888
- const ratioState = AbiCoder.decodeParameter('uint8', subData[4]) as any as RatioState;
889
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
890
- const targetRatio = weiToRatioPercentage(weiRatio);
695
+ decode(subData: SubData): {
696
+ fromAsset: EthereumAddress,
697
+ fromAssetId: number,
698
+ toAsset: EthereumAddress,
699
+ toAssetId: number,
700
+ marketAddr: EthereumAddress,
701
+ amountToSwitch: string,
702
+ } {
703
+ const fromAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
704
+ const fromAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
705
+ const toAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
706
+ const toAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
707
+ const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
708
+ const amountToSwitch = AbiCoder.decodeParameter('uint256', subData[5]) as unknown as string;
891
709
 
892
710
  return {
893
- market, troveId, collToken, boldToken, ratioState, targetRatio,
711
+ fromAsset, fromAssetId, toAsset, toAssetId, marketAddr, amountToSwitch,
894
712
  };
895
713
  },
896
714
  };
897
-
898
- export const liquityV2CloseSubData = {
715
+ export const aaveV3QuotePriceSubData = {
899
716
  encode(
900
- market: EthereumAddress,
901
- troveId: string,
902
- collToken: EthereumAddress,
903
- boldToken: EthereumAddress,
904
- closeType: CloseStrategyType,
717
+ collAsset: EthereumAddress,
718
+ collAssetId: number,
719
+ debtAsset: EthereumAddress,
720
+ debtAssetId: number,
721
+ nullAddress: EthereumAddress = ZERO_ADDRESS,
905
722
  ): SubData {
906
- const marketEncoded = AbiCoder.encodeParameter('address', market);
907
- const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
908
- const collAddrEncoded = AbiCoder.encodeParameter('address', collToken);
909
- const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
910
- const wethAddress = getAssetInfo('WETH').address;
911
- const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
912
- const gasCompensation = new Dec('0.0375').mul(1e18).toString();
913
- const gasCompensationEncoded = AbiCoder.encodeParameter('uint256', gasCompensation);
914
- const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
723
+ const encodedColl = AbiCoder.encodeParameter('address', collAsset);
724
+ const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
915
725
 
916
- return [
917
- marketEncoded,
918
- troveIdEncoded,
919
- collAddrEncoded,
920
- boldTokenEncoded,
921
- wethAddressEncoded,
922
- gasCompensationEncoded,
923
- closeTypeEncoded,
924
- ];
726
+ const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
727
+ const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
728
+
729
+ const encodedNullAddress = AbiCoder.encodeParameter('address', nullAddress);
730
+
731
+ return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedNullAddress];
925
732
  },
926
- decode(subData: SubData): {
927
- market: EthereumAddress,
928
- troveId: string,
929
- collToken: EthereumAddress,
930
- boldToken: EthereumAddress,
931
- closeType: CloseStrategyType,
932
- } {
933
- const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
934
- const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
935
- const collToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
936
- const boldToken = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
937
- // skip wethAddress and gasCompensation
938
- const closeType = AbiCoder.decodeParameter('uint8', subData[6]) as any as CloseStrategyType;
733
+ decode(subData: SubData): { collAsset: EthereumAddress, collAssetId: number, debtAsset: EthereumAddress, debtAssetId: number } {
734
+ const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
735
+ const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
736
+
737
+ const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
738
+ const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
939
739
 
940
740
  return {
941
- market, troveId, collToken, boldToken, closeType,
741
+ collAsset, collAssetId, debtAsset, debtAssetId,
942
742
  };
943
743
  },
944
744
  };
945
-
946
- export const liquityV2LeverageManagementOnPriceSubData = {
745
+ export const aaveV3LeverageManagementOnPriceSubData = {
947
746
  encode(
948
- market: EthereumAddress,
949
- troveId: string,
950
- collToken: EthereumAddress,
951
- boldToken: EthereumAddress,
747
+ collAsset: EthereumAddress,
748
+ collAssetId: number,
749
+ debtAsset: EthereumAddress,
750
+ debtAssetId: number,
751
+ marketAddr: EthereumAddress,
952
752
  targetRatio: number,
953
- isRepayOnPrice: boolean,
954
753
  ): SubData {
955
- const encodedMarket = AbiCoder.encodeParameter('address', market);
956
- const encodedTroveId = AbiCoder.encodeParameter('uint256', troveId);
957
- const encodedCollToken = AbiCoder.encodeParameter('address', collToken);
958
- const encodedBoldToken = AbiCoder.encodeParameter('address', boldToken);
754
+ const encodedColl = AbiCoder.encodeParameter('address', collAsset);
755
+ const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
756
+ const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
757
+ const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
758
+ const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
959
759
  const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
960
-
961
- const collActionType = isRepayOnPrice ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
962
- const debtActionType = isRepayOnPrice ? DebtActionType.PAYBACK : DebtActionType.BORROW;
963
-
964
- const encodedCollActionType = AbiCoder.encodeParameter('uint8', collActionType);
965
- const encodedDebtActionType = AbiCoder.encodeParameter('uint8', debtActionType);
760
+ const useOnBehalfEncoded = AbiCoder.encodeParameter('bool', false);
966
761
 
967
762
  return [
763
+ encodedColl,
764
+ encodedCollId,
765
+ encodedDebt,
766
+ encodedDebtId,
968
767
  encodedMarket,
969
- encodedTroveId,
970
- encodedCollToken,
971
- encodedBoldToken,
972
768
  encodedTargetRatio,
973
- encodedCollActionType,
974
- encodedDebtActionType,
769
+ useOnBehalfEncoded,
975
770
  ];
976
771
  },
977
772
  decode(subData: SubData): {
978
- market: EthereumAddress,
979
- troveId: string,
980
- collToken: EthereumAddress,
981
- boldToken: EthereumAddress,
773
+ collAsset: EthereumAddress,
774
+ collAssetId: number,
775
+ debtAsset: EthereumAddress,
776
+ debtAssetId: number,
777
+ marketAddr: EthereumAddress,
982
778
  targetRatio: number,
983
779
  } {
984
- const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
985
- const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
986
- const collToken = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
987
- const boldToken = AbiCoder.decodeParameter('address', subData[3]) as unknown as EthereumAddress;
988
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[4]) as any as string;
989
- const targetRatio = weiToRatioPercentage(weiRatio);
780
+ const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
781
+ const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
782
+ const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
783
+ const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
784
+ const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
990
785
 
991
- return {
992
- market, troveId, collToken, boldToken, targetRatio,
993
- };
994
- },
995
- };
996
- export const morphoBlueLeverageManagementOnPriceSubData = {
997
- encode(
998
- loanToken: EthereumAddress,
999
- collToken: EthereumAddress,
1000
- oracle: EthereumAddress,
1001
- irm: EthereumAddress,
1002
- lltv: string,
1003
- targetRatio: number,
1004
- user: EthereumAddress,
1005
- ): SubData {
1006
- const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
1007
- const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
1008
- const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
1009
- const irmEncoded = AbiCoder.encodeParameter('address', irm);
1010
- const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
1011
- const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1012
- const userEncoded = AbiCoder.encodeParameter('address', user);
1013
- return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, targetRatioEncoded, userEncoded];
1014
- },
1015
- decode(subData: SubData) {
1016
- const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
1017
- const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
1018
- const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
1019
- const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
1020
- const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
1021
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as EthereumAddress;
786
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
1022
787
  const targetRatio = weiToRatioPercentage(weiRatio);
1023
- const user = AbiCoder.decodeParameter('address', subData[6]) as any as EthereumAddress;
1024
788
 
1025
789
  return {
1026
- loanToken,
1027
- collToken,
1028
- oracle,
1029
- irm,
1030
- lltv,
1031
- targetRatio,
1032
- user,
790
+ collAsset, collAssetId, debtAsset, debtAssetId, marketAddr, targetRatio,
1033
791
  };
1034
792
  },
1035
793
  };
1036
794
 
1037
- export const liquityV2PaybackSubData = {
795
+ /**
796
+ * ___ ___ ____ ____ _______ ____ ____ _ _
797
+ / \ / \ \ \ / / | ____| \ \ / / | || |
798
+ / ^ \ / ^ \ \ \/ / | |__ \ \/ / | || |_
799
+ / /_\ \ / /_\ \ \ / | __| \ / |__ _|
800
+ / _____ \ / _____ \ \ / | |____ \ / | |
801
+ /__/ \__\ /__/ \__\ \__/ |_______| \__/ |_|
802
+ */
803
+ export const aaveV4LeverageManagementSubData = {
1038
804
  encode: (
1039
- market: EthereumAddress,
1040
- troveId: string,
1041
- boldToken: EthereumAddress,
1042
- targetRatio: number,
805
+ spoke: EthereumAddress,
806
+ owner: EthereumAddress,
1043
807
  ratioState: RatioState,
808
+ targetRatio: number,
1044
809
  ) => {
1045
- const marketEncoded = AbiCoder.encodeParameter('address', market);
1046
- const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
1047
- const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
1048
- const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
810
+ const spokeEncoded = AbiCoder.encodeParameter('address', spoke);
811
+ const ownerEncoded = AbiCoder.encodeParameter('address', owner);
1049
812
  const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
1050
-
813
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
814
+ // Add two empty slots for future addons (e.g tsi or slippage settings)
1051
815
  return [
1052
- marketEncoded,
1053
- troveIdEncoded,
1054
- boldTokenEncoded,
1055
- targetRatioEncoded,
816
+ spokeEncoded,
817
+ ownerEncoded,
1056
818
  ratioStateEncoded,
819
+ targetRatioEncoded,
820
+ EMPTY_SLOT,
821
+ EMPTY_SLOT,
1057
822
  ];
1058
823
  },
1059
824
  decode: (subData: SubData) => {
1060
- const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
1061
- const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
1062
- const boldToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
1063
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
1064
- const ratioState = AbiCoder.decodeParameter('uint8', subData[4]) as any as RatioState;
1065
- const targetRatio = weiToRatioPercentage(weiRatio);
1066
-
825
+ const spoke = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
826
+ const owner = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
827
+ const ratioState = Number(AbiCoder.decodeParameter('uint8', subData[2])) as RatioState;
828
+ const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[3]) as any as string);
1067
829
  return {
1068
- market, troveId, boldToken, ratioState, targetRatio,
830
+ spoke, owner, ratioState, targetRatio,
1069
831
  };
1070
832
  },
1071
833
  };
1072
-
1073
- export const fluidLeverageManagementSubData = {
834
+ export const aaveV4LeverageManagementOnPriceSubData = {
1074
835
  encode: (
1075
- nftId: string,
1076
- vault: EthereumAddress,
836
+ spoke: EthereumAddress,
837
+ owner: EthereumAddress,
838
+ collAsset: EthereumAddress,
839
+ collAssetId: number,
840
+ debtAsset: EthereumAddress,
841
+ debtAssetId: number,
1077
842
  ratioState: RatioState,
1078
843
  targetRatio: number,
1079
844
  ) => {
1080
- const nftIdEncoded = AbiCoder.encodeParameter('uint256', nftId);
1081
- const vaultEncoded = AbiCoder.encodeParameter('address', vault);
845
+ const spokeEncoded = AbiCoder.encodeParameter('address', spoke);
846
+ const ownerEncoded = AbiCoder.encodeParameter('address', owner);
847
+ const collAssetEncoded = AbiCoder.encodeParameter('address', collAsset);
848
+ const collAssetIdEncoded = AbiCoder.encodeParameter('uint256', collAssetId);
849
+ const debtAssetEncoded = AbiCoder.encodeParameter('address', debtAsset);
850
+ const debtAssetIdEncoded = AbiCoder.encodeParameter('uint256', debtAssetId);
1082
851
  const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
1083
852
  const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1084
- const wrapEthEncoded = AbiCoder.encodeParameter('bool', true);
1085
-
1086
- const isRepay = ratioState === RatioState.UNDER;
1087
- const collActionType = isRepay ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
1088
- const debtActionType = isRepay ? DebtActionType.PAYBACK : DebtActionType.BORROW;
1089
-
1090
- const collActionTypeEncoded = AbiCoder.encodeParameter('uint8', collActionType);
1091
- const debtActionTypeEncoded = AbiCoder.encodeParameter('uint8', debtActionType);
1092
-
853
+ // Add two empty slots for future addons (e.g tsi or slippage settings)
1093
854
  return [
1094
- nftIdEncoded,
1095
- vaultEncoded,
855
+ spokeEncoded,
856
+ ownerEncoded,
857
+ collAssetEncoded,
858
+ collAssetIdEncoded,
859
+ debtAssetEncoded,
860
+ debtAssetIdEncoded,
1096
861
  ratioStateEncoded,
1097
862
  targetRatioEncoded,
1098
- wrapEthEncoded,
1099
- collActionTypeEncoded,
1100
- debtActionTypeEncoded,
863
+ EMPTY_SLOT,
864
+ EMPTY_SLOT,
1101
865
  ];
1102
866
  },
1103
867
  decode: (subData: SubData) => {
1104
- const nftId = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
1105
- const vault = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
1106
- const ratioState = AbiCoder.decodeParameter('uint8', subData[2]) as any as RatioState;
868
+ const spoke = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
869
+ const owner = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
870
+ const collAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
871
+ const collAssetId = Number(AbiCoder.decodeParameter('uint256', subData[3]));
872
+ const debtAsset = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
873
+ const debtAssetId = Number(AbiCoder.decodeParameter('uint256', subData[5]));
874
+ const ratioState = Number(AbiCoder.decodeParameter('uint8', subData[6])) as RatioState;
875
+ const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[7]) as any as string);
876
+ return {
877
+ spoke, owner, collAsset, collAssetId, debtAsset, debtAssetId, ratioState, targetRatio,
878
+ };
879
+ },
880
+ };
881
+ export const aaveV4CloseSubData = {
882
+ encode: (
883
+ spoke: EthereumAddress,
884
+ owner: EthereumAddress,
885
+ collAsset: EthereumAddress,
886
+ collAssetId: number,
887
+ debtAsset: EthereumAddress,
888
+ debtAssetId: number,
889
+ closeType: CloseStrategyType,
890
+ ) => {
891
+ const spokeEncoded = AbiCoder.encodeParameter('address', spoke);
892
+ const ownerEncoded = AbiCoder.encodeParameter('address', owner);
893
+ const collAssetEncoded = AbiCoder.encodeParameter('address', collAsset);
894
+ const collAssetIdEncoded = AbiCoder.encodeParameter('uint256', collAssetId);
895
+ const debtAssetEncoded = AbiCoder.encodeParameter('address', debtAsset);
896
+ const debtAssetIdEncoded = AbiCoder.encodeParameter('uint256', debtAssetId);
897
+ const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
898
+ // Add two empty slots for future addons (e.g tsi or slippage settings)
899
+ return [
900
+ spokeEncoded,
901
+ ownerEncoded,
902
+ collAssetEncoded,
903
+ collAssetIdEncoded,
904
+ debtAssetEncoded,
905
+ debtAssetIdEncoded,
906
+ closeTypeEncoded,
907
+ EMPTY_SLOT,
908
+ EMPTY_SLOT,
909
+ ];
910
+ },
911
+ decode: (subData: SubData) => {
912
+ const spoke = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
913
+ const owner = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
914
+ const collAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
915
+ const collAssetId = Number(AbiCoder.decodeParameter('uint256', subData[3]));
916
+ const debtAsset = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
917
+ const debtAssetId = Number(AbiCoder.decodeParameter('uint256', subData[5]));
918
+ const closeType = Number(AbiCoder.decodeParameter('uint8', subData[6])) as CloseStrategyType;
919
+ return {
920
+ spoke, owner, collAsset, collAssetId, debtAsset, debtAssetId, closeType,
921
+ };
922
+ },
923
+ };
924
+ export const aaveV4CollateralSwitchSubData = {
925
+ encode: (
926
+ spoke: EthereumAddress,
927
+ owner: EthereumAddress,
928
+ fromAsset: EthereumAddress,
929
+ fromAssetId: number,
930
+ toAsset: EthereumAddress,
931
+ toAssetId: number,
932
+ amountToSwitch: string,
933
+ ) => {
934
+ const spokeEncoded = AbiCoder.encodeParameter('address', spoke);
935
+ const ownerEncoded = AbiCoder.encodeParameter('address', owner);
936
+ const fromAssetEncoded = AbiCoder.encodeParameter('address', fromAsset);
937
+ const fromAssetIdEncoded = AbiCoder.encodeParameter('uint256', fromAssetId);
938
+ const toAssetEncoded = AbiCoder.encodeParameter('address', toAsset);
939
+ const toAssetIdEncoded = AbiCoder.encodeParameter('uint256', toAssetId);
940
+ const amountToSwitchEncoded = AbiCoder.encodeParameter('uint256', amountToSwitch);
941
+ // Add two empty slots for future addons (e.g tsi or slippage settings)
942
+ return [
943
+ spokeEncoded,
944
+ ownerEncoded,
945
+ fromAssetEncoded,
946
+ fromAssetIdEncoded,
947
+ toAssetEncoded,
948
+ toAssetIdEncoded,
949
+ amountToSwitchEncoded,
950
+ EMPTY_SLOT,
951
+ EMPTY_SLOT,
952
+ ];
953
+ },
954
+ decode: (subData: SubData) => {
955
+ const spoke = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
956
+ const owner = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
957
+ const fromAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
958
+ const fromAssetId = Number(AbiCoder.decodeParameter('uint256', subData[3]));
959
+ const toAsset = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
960
+ const toAssetId = Number(AbiCoder.decodeParameter('uint256', subData[5]));
961
+ const amountToSwitch = AbiCoder.decodeParameter('uint256', subData[6]) as any as string;
962
+ return {
963
+ spoke, owner, fromAsset, fromAssetId, toAsset, toAssetId, amountToSwitch,
964
+ };
965
+ },
966
+ };
967
+
968
+ /**
969
+ ______ ______ .___ ___. .______ ____ ____ ___
970
+ / | / __ \ | \/ | | _ \ \ \ / / |__ \
971
+ | ,----'| | | | | \ / | | |_) | \ \/ / ) |
972
+ | | | | | | | |\/| | | ___/ \ / / /
973
+ | `----.| `--' | | | | | | | \ / / /_
974
+ \______| \______/ |__| |__| | _| \__/ |____|
975
+ */
976
+ export const compoundV2LeverageManagementSubData = {
977
+ encode(
978
+ triggerRepayRatio: number,
979
+ triggerBoostRatio: number,
980
+ targetBoostRatio: number,
981
+ targetRepayRatio: number,
982
+ boostEnabled: boolean,
983
+ ): SubData {
984
+ return [
985
+ new Dec(triggerRepayRatio).mul(1e16).toString(),
986
+ new Dec(triggerBoostRatio).mul(1e16).toString(),
987
+ new Dec(targetBoostRatio).mul(1e16).toString(),
988
+ new Dec(targetRepayRatio).mul(1e16).toString(),
989
+ // @ts-ignore // TODO
990
+ boostEnabled,
991
+ ];
992
+ },
993
+ decode(subData: SubData): { targetRatio: number } {
994
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
995
+ const targetRatio = weiToRatioPercentage(weiRatio);
996
+
997
+ return { targetRatio };
998
+ },
999
+ };
1000
+
1001
+ /**
1002
+ ______ ______ .___ ___. .______ ____ ____ ____
1003
+ / | / __ \ | \/ | | _ \ \ \ / / |___ \
1004
+ | ,----'| | | | | \ / | | |_) | \ \/ / __) |
1005
+ | | | | | | | |\/| | | ___/ \ / |__ <
1006
+ | `----.| `--' | | | | | | | \ / ___) |
1007
+ \______| \______/ |__| |__| | _| \__/ |____/
1008
+ */
1009
+ export const compoundV3LeverageManagementSubData = {
1010
+ encode(
1011
+ market: EthereumAddress,
1012
+ baseToken: EthereumAddress,
1013
+ triggerRepayRatio: number,
1014
+ triggerBoostRatio: number,
1015
+ targetBoostRatio: number,
1016
+ targetRepayRatio: number,
1017
+ boostEnabled: boolean,
1018
+ isEOA: boolean,
1019
+ ): SubData {
1020
+ return [
1021
+ market,
1022
+ baseToken,
1023
+ new Dec(triggerRepayRatio).mul(1e16).toString(),
1024
+ new Dec(triggerBoostRatio).mul(1e16).toString(),
1025
+ new Dec(targetBoostRatio).mul(1e16).toString(),
1026
+ new Dec(targetRepayRatio).mul(1e16).toString(),
1027
+ // @ts-ignore // TODO
1028
+ boostEnabled, isEOA,
1029
+ ];
1030
+ },
1031
+ decode(subData: SubData): { targetRatio: number } {
1107
1032
  const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
1108
1033
  const targetRatio = weiToRatioPercentage(weiRatio);
1109
1034
 
1110
- return {
1111
- nftId, vault, ratioState, targetRatio,
1112
- };
1035
+ return { targetRatio };
1113
1036
  },
1114
1037
  };
1038
+ export const compoundV3L2LeverageManagementSubData = {
1039
+ encode(
1040
+ market: EthereumAddress,
1041
+ baseToken: EthereumAddress,
1042
+ triggerRepayRatio: number,
1043
+ triggerBoostRatio: number,
1044
+ targetBoostRatio: number,
1045
+ targetRepayRatio: number,
1046
+ boostEnabled: boolean,
1047
+ isEOA: boolean,
1048
+ ): string {
1049
+ let subInput = '0x';
1050
+
1051
+ subInput = subInput.concat(market.slice(2));
1052
+ subInput = subInput.concat(baseToken.slice(2));
1053
+ subInput = subInput.concat(new Dec(triggerRepayRatio).mul(1e16).toHex().slice(2)
1054
+ .padStart(32, '0'));
1055
+ subInput = subInput.concat(new Dec(triggerBoostRatio).mul(1e16).toHex().slice(2)
1056
+ .padStart(32, '0'));
1057
+ subInput = subInput.concat(new Dec(targetBoostRatio).mul(1e16).toHex().slice(2)
1058
+ .padStart(32, '0'));
1059
+ subInput = subInput.concat(new Dec(targetRepayRatio).mul(1e16).toHex().slice(2)
1060
+ .padStart(32, '0'));
1061
+ subInput = subInput.concat(boostEnabled ? '01' : '00');
1062
+ subInput = subInput.concat(isEOA ? '01' : '00');
1063
+
1064
+ return subInput;
1065
+ },
1066
+ decode(subData: SubData): { targetRatio: number } {
1067
+ const ratioWei = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
1068
+ const targetRatio = weiToRatioPercentage(ratioWei);
1115
1069
 
1070
+ return { targetRatio };
1071
+ },
1072
+ };
1116
1073
  export const compoundV3LeverageManagementOnPriceSubData = {
1117
1074
  encode(
1118
1075
  market: EthereumAddress,
@@ -1159,7 +1116,6 @@ export const compoundV3LeverageManagementOnPriceSubData = {
1159
1116
  };
1160
1117
  },
1161
1118
  };
1162
-
1163
1119
  export const compoundV3CloseSubData = {
1164
1120
  encode(
1165
1121
  market: EthereumAddress,
@@ -1195,12 +1151,96 @@ export const compoundV3CloseSubData = {
1195
1151
  const closeType = Number(AbiCoder.decodeParameter('uint8', subData[3])) as CloseStrategyType;
1196
1152
  const owner = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
1197
1153
 
1198
- return {
1199
- market, collToken, baseToken, closeType, owner,
1200
- };
1154
+ return {
1155
+ market, collToken, baseToken, closeType, owner,
1156
+ };
1157
+ },
1158
+ };
1159
+
1160
+ /**
1161
+ __________ ___ ______ __ __ ___ .__ __. _______ _______
1162
+ | ____\ \ / / / || | | | / \ | \ | | / _____|| ____|
1163
+ | |__ \ V / | ,----'| |__| | / ^ \ | \| | | | __ | |__
1164
+ | __| > < | | | __ | / /_\ \ | . ` | | | |_ | | __|
1165
+ | |____ / . \ | `----.| | | | / _____ \ | |\ | | |__| | | |____
1166
+ |_______/__/ \__\ \______||__| |__| /__/ \__\ |__| \__| \______| |_______|
1167
+ */
1168
+ export const exchangeDcaSubData = {
1169
+ encode: (fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, interval: number) : SubData => {
1170
+ const sellTokenEncoded = AbiCoder.encodeParameter('address', fromToken);
1171
+ const buyTokenEncoded = AbiCoder.encodeParameter('address', toToken);
1172
+ const amountEncoded = AbiCoder.encodeParameter('uint256', amount);
1173
+ const intervalEncoded = AbiCoder.encodeParameter('uint256', interval);
1174
+
1175
+ return [sellTokenEncoded, buyTokenEncoded, amountEncoded, intervalEncoded];
1176
+ },
1177
+ decode: (subData: SubData, chainId: ChainId) => {
1178
+ const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
1179
+ const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
1180
+ const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
1181
+ const interval = AbiCoder.decodeParameter('uint256', subData[3])!.toString();
1182
+ return {
1183
+ fromToken,
1184
+ toToken,
1185
+ amount,
1186
+ interval,
1187
+ };
1188
+ },
1189
+ };
1190
+ export const exchangeLimitOrderSubData = {
1191
+ encode(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, targetPrice: string, goodUntil: string | number, orderType: OrderType) : SubData {
1192
+ return [
1193
+ fromToken,
1194
+ toToken,
1195
+ amount,
1196
+ targetPrice,
1197
+ new Dec(goodUntil).toString(),
1198
+ new Dec(orderType).toString(),
1199
+ ];
1200
+ },
1201
+ decode: (subData: SubData, chainId: ChainId) => {
1202
+ const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
1203
+ const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
1204
+ const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
1205
+ return { fromToken, toToken, amount };
1206
+ },
1207
+ };
1208
+
1209
+ /**
1210
+ _______..______ ___ .______ __ ___
1211
+ / || _ \ / \ | _ \ | |/ /
1212
+ | (----`| |_) | / ^ \ | |_) | | ' /
1213
+ \ \ | ___/ / /_\ \ | / | <
1214
+ .----) | | | / _____ \ | |\ \----.| . \
1215
+ |_______/ | _| /__/ \__\ | _| `._____||__|\__\
1216
+ */
1217
+ export const sparkLeverageManagementSubData = {
1218
+ decode(subData: SubData): { targetRatio: number } {
1219
+ const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
1220
+ const targetRatio = weiToRatioPercentage(ratioWei);
1221
+
1222
+ return { targetRatio };
1223
+ },
1224
+ };
1225
+ export const sparkLeverageManagementSubDataWithoutSubProxy = {
1226
+ encode(
1227
+ targetRatio: number,
1228
+ ratioState: RatioState,
1229
+ ): SubData {
1230
+ const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1231
+ const encodedRatioState = AbiCoder.encodeParameter('uint8', ratioState);
1232
+
1233
+ const encodedUseDefaultMarket = AbiCoder.encodeParameter('bool', true);
1234
+ const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', false);
1235
+ return [encodedTargetRatio, encodedRatioState, encodedUseDefaultMarket, encodedUseOnBehalf];
1236
+ },
1237
+ decode(subData: SubData): { targetRatio: number, ratioState: RatioState } {
1238
+ const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[0]) as any as string);
1239
+ const ratioState = AbiCoder.decodeParameter('uint8', subData[1]) as any as RatioState;
1240
+
1241
+ return { targetRatio, ratioState };
1201
1242
  },
1202
1243
  };
1203
-
1204
1244
  export const sparkCloseGenericSubData = {
1205
1245
  encode(
1206
1246
  collAsset: EthereumAddress,
@@ -1252,7 +1292,204 @@ export const sparkCloseGenericSubData = {
1252
1292
  };
1253
1293
  },
1254
1294
  };
1295
+ export const sparkLeverageManagementOnPriceSubData = {
1296
+ encode(
1297
+ collAsset: EthereumAddress,
1298
+ collAssetId: number,
1299
+ debtAsset: EthereumAddress,
1300
+ debtAssetId: number,
1301
+ marketAddr: EthereumAddress,
1302
+ targetRatio: number,
1303
+ ): SubData {
1304
+ const encodedColl = AbiCoder.encodeParameter('address', collAsset);
1305
+ const encodedCollId = AbiCoder.encodeParameter('uint16', collAssetId);
1306
+ const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
1307
+ const encodedDebtId = AbiCoder.encodeParameter('uint16', debtAssetId);
1308
+ const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
1309
+ const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1310
+ const useOnBehalfEncoded = AbiCoder.encodeParameter('bool', false);
1311
+ return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedMarket, encodedTargetRatio, useOnBehalfEncoded];
1312
+ },
1313
+ decode(subData: SubData): {
1314
+ collAsset: EthereumAddress,
1315
+ collAssetId: number,
1316
+ debtAsset: EthereumAddress,
1317
+ debtAssetId: number,
1318
+ marketAddr: EthereumAddress,
1319
+ targetRatio: number,
1320
+ } {
1321
+ const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
1322
+ const collAssetId = Number(AbiCoder.decodeParameter('uint16', subData[1]));
1323
+ const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
1324
+ const debtAssetId = Number(AbiCoder.decodeParameter('uint16', subData[3]));
1325
+ const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
1326
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
1327
+ const targetRatio = weiToRatioPercentage(weiRatio);
1328
+ return {
1329
+ collAsset, collAssetId, debtAsset, debtAssetId, marketAddr, targetRatio,
1330
+ };
1331
+ },
1332
+ };
1333
+
1334
+ /**
1335
+ ______ .______ ____ ____ __ __ _______. _______
1336
+ / || _ \ \ \ / / | | | | / || \
1337
+ | ,----'| |_) | \ \/ / | | | | | (----`| .--. |
1338
+ | | | / \ / | | | | \ \ | | | |
1339
+ | `----.| |\ \----. \ / | `--' | .----) | | '--' |
1340
+ \______|| _| `._____| \__/ \______/ |_______/ |_______/
1341
+ */
1342
+ export const crvUSDLeverageManagementSubData = {
1343
+ encode: (
1344
+ controllerAddr: EthereumAddress,
1345
+ ratioState: RatioState,
1346
+ targetRatio: number,
1347
+ collTokenAddr: EthereumAddress,
1348
+ crvUSDAddr: EthereumAddress,
1349
+ ) => {
1350
+ const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
1351
+ const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
1352
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1353
+ const collTokenAddrEncoded = AbiCoder.encodeParameter('address', collTokenAddr);
1354
+ const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
1355
+ return [controllerAddrEncoded, ratioStateEncoded, targetRatioEncoded, collTokenAddrEncoded, crvUSDAddrEncoded];
1356
+ },
1357
+ decode: (subData: SubData) => {
1358
+ const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
1359
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
1360
+ const targetRatio = weiToRatioPercentage(weiRatio);
1361
+
1362
+ return { controller, targetRatio };
1363
+ },
1364
+ };
1365
+ export const crvUSDPaybackSubData = {
1366
+ encode: (
1367
+ controllerAddr: EthereumAddress,
1368
+ addressToPullTokensFrom: EthereumAddress,
1369
+ positionOwner: EthereumAddress,
1370
+ paybackAmount: string,
1371
+ crvUSDAddr: EthereumAddress,
1372
+ ) => {
1373
+ const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
1374
+ const addressToPullTokensFromEncoded = AbiCoder.encodeParameter('address', addressToPullTokensFrom);
1375
+ const positionOwnerEncoded = AbiCoder.encodeParameter('address', positionOwner);
1376
+ const paybackAmountEncoded = AbiCoder.encodeParameter('uint256', toWei(paybackAmount, 'ether'));
1377
+ const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
1378
+ return [
1379
+ controllerAddrEncoded,
1380
+ addressToPullTokensFromEncoded,
1381
+ positionOwnerEncoded,
1382
+ paybackAmountEncoded,
1383
+ crvUSDAddrEncoded,
1384
+ ];
1385
+ },
1386
+ decode: (subData: SubData) => {
1387
+ const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
1388
+ const addressToPullTokensFrom = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
1389
+ const positionOwner = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
1390
+ const weiPaybackAmount = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
1391
+ const paybackAmount = fromWei(weiPaybackAmount, 'ether');
1392
+ return {
1393
+ controller,
1394
+ addressToPullTokensFrom,
1395
+ positionOwner,
1396
+ paybackAmount,
1397
+ };
1398
+ },
1399
+ };
1400
+
1401
+ /**
1402
+ .___ ___. ______ .______ .______ __ __ ______
1403
+ | \/ | / __ \ | _ \ | _ \ | | | | / __ \
1404
+ | \ / | | | | | | |_) | | |_) | | |__| | | | | |
1405
+ | |\/| | | | | | | / | ___/ | __ | | | | |
1406
+ | | | | | `--' | | |\ \----.| | | | | | | `--' |
1407
+ |__| |__| \______/ | _| `._____|| _| |__| |__| \______/
1408
+ */
1409
+ export const morphoBlueLeverageManagementSubData = {
1410
+ encode: (
1411
+ loanToken: EthereumAddress,
1412
+ collToken: EthereumAddress,
1413
+ oracle: EthereumAddress,
1414
+ irm: EthereumAddress,
1415
+ lltv: string,
1416
+ ratioState: RatioState,
1417
+ targetRatio: number,
1418
+ user: EthereumAddress,
1419
+ isEOA: boolean,
1420
+ ) => {
1421
+ const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
1422
+ const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
1423
+ const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
1424
+ const irmEncoded = AbiCoder.encodeParameter('address', irm);
1425
+ const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
1426
+ const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
1427
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1428
+ const userEncoded = AbiCoder.encodeParameter('address', user);
1429
+ const isEOAEncoded = AbiCoder.encodeParameter('bool', isEOA);
1430
+ return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, ratioStateEncoded, targetRatioEncoded, userEncoded, isEOAEncoded];
1431
+ },
1432
+ decode: (subData: SubData) => {
1433
+ const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
1434
+ const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
1435
+ const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
1436
+ const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
1437
+ const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
1438
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[6]) as any as EthereumAddress;
1439
+ const user = AbiCoder.decodeParameter('address', subData[7]) as any as EthereumAddress;
1440
+ const targetRatio = weiToRatioPercentage(weiRatio);
1441
+
1442
+ return {
1443
+ loanToken,
1444
+ collToken,
1445
+ oracle,
1446
+ irm,
1447
+ lltv,
1448
+ user,
1449
+ targetRatio,
1450
+ };
1451
+ },
1452
+ };
1453
+ export const morphoBlueLeverageManagementOnPriceSubData = {
1454
+ encode(
1455
+ loanToken: EthereumAddress,
1456
+ collToken: EthereumAddress,
1457
+ oracle: EthereumAddress,
1458
+ irm: EthereumAddress,
1459
+ lltv: string,
1460
+ targetRatio: number,
1461
+ user: EthereumAddress,
1462
+ ): SubData {
1463
+ const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
1464
+ const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
1465
+ const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
1466
+ const irmEncoded = AbiCoder.encodeParameter('address', irm);
1467
+ const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
1468
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1469
+ const userEncoded = AbiCoder.encodeParameter('address', user);
1470
+ return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, targetRatioEncoded, userEncoded];
1471
+ },
1472
+ decode(subData: SubData) {
1473
+ const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
1474
+ const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
1475
+ const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
1476
+ const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
1477
+ const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
1478
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as EthereumAddress;
1479
+ const targetRatio = weiToRatioPercentage(weiRatio);
1480
+ const user = AbiCoder.decodeParameter('address', subData[6]) as any as EthereumAddress;
1255
1481
 
1482
+ return {
1483
+ loanToken,
1484
+ collToken,
1485
+ oracle,
1486
+ irm,
1487
+ lltv,
1488
+ targetRatio,
1489
+ user,
1490
+ };
1491
+ },
1492
+ };
1256
1493
  export const morphoBlueCloseOnPriceSubData = {
1257
1494
  encode(
1258
1495
  loanToken: EthereumAddress,
@@ -1293,41 +1530,53 @@ export const morphoBlueCloseOnPriceSubData = {
1293
1530
  },
1294
1531
  };
1295
1532
 
1296
- export const sparkLeverageManagementOnPriceSubData = {
1297
- encode(
1298
- collAsset: EthereumAddress,
1299
- collAssetId: number,
1300
- debtAsset: EthereumAddress,
1301
- debtAssetId: number,
1302
- marketAddr: EthereumAddress,
1533
+ /**
1534
+ _______ __ __ __ __ _______
1535
+ | ____|| | | | | | | | | \
1536
+ | |__ | | | | | | | | | .--. |
1537
+ | __| | | | | | | | | | | | |
1538
+ | | | `----.| `--' | | | | '--' |
1539
+ |__| |_______| \______/ |__| |_______/
1540
+ */
1541
+ export const fluidLeverageManagementSubData = {
1542
+ encode: (
1543
+ nftId: string,
1544
+ vault: EthereumAddress,
1545
+ ratioState: RatioState,
1303
1546
  targetRatio: number,
1304
- ): SubData {
1305
- const encodedColl = AbiCoder.encodeParameter('address', collAsset);
1306
- const encodedCollId = AbiCoder.encodeParameter('uint16', collAssetId);
1307
- const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
1308
- const encodedDebtId = AbiCoder.encodeParameter('uint16', debtAssetId);
1309
- const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
1310
- const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1311
- const useOnBehalfEncoded = AbiCoder.encodeParameter('bool', false);
1312
- return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedMarket, encodedTargetRatio, useOnBehalfEncoded];
1547
+ ) => {
1548
+ const nftIdEncoded = AbiCoder.encodeParameter('uint256', nftId);
1549
+ const vaultEncoded = AbiCoder.encodeParameter('address', vault);
1550
+ const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
1551
+ const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
1552
+ const wrapEthEncoded = AbiCoder.encodeParameter('bool', true);
1553
+
1554
+ const isRepay = ratioState === RatioState.UNDER;
1555
+ const collActionType = isRepay ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
1556
+ const debtActionType = isRepay ? DebtActionType.PAYBACK : DebtActionType.BORROW;
1557
+
1558
+ const collActionTypeEncoded = AbiCoder.encodeParameter('uint8', collActionType);
1559
+ const debtActionTypeEncoded = AbiCoder.encodeParameter('uint8', debtActionType);
1560
+
1561
+ return [
1562
+ nftIdEncoded,
1563
+ vaultEncoded,
1564
+ ratioStateEncoded,
1565
+ targetRatioEncoded,
1566
+ wrapEthEncoded,
1567
+ collActionTypeEncoded,
1568
+ debtActionTypeEncoded,
1569
+ ];
1313
1570
  },
1314
- decode(subData: SubData): {
1315
- collAsset: EthereumAddress,
1316
- collAssetId: number,
1317
- debtAsset: EthereumAddress,
1318
- debtAssetId: number,
1319
- marketAddr: EthereumAddress,
1320
- targetRatio: number,
1321
- } {
1322
- const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
1323
- const collAssetId = Number(AbiCoder.decodeParameter('uint16', subData[1]));
1324
- const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
1325
- const debtAssetId = Number(AbiCoder.decodeParameter('uint16', subData[3]));
1326
- const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
1327
- const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
1571
+ decode: (subData: SubData) => {
1572
+ const nftId = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
1573
+ const vault = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
1574
+ const ratioState = AbiCoder.decodeParameter('uint8', subData[2]) as any as RatioState;
1575
+ const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
1328
1576
  const targetRatio = weiToRatioPercentage(weiRatio);
1577
+
1329
1578
  return {
1330
- collAsset, collAssetId, debtAsset, debtAssetId, marketAddr, targetRatio,
1579
+ nftId, vault, ratioState, targetRatio,
1331
1580
  };
1332
1581
  },
1333
1582
  };