@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.
- package/cjs/automation/private/StrategiesAutomation.d.ts +2 -0
- package/cjs/automation/private/StrategiesAutomation.js +10 -1
- package/cjs/automation/private/StrategiesAutomation.test.js +25 -0
- package/cjs/constants/index.d.ts +1 -0
- package/cjs/constants/index.js +62 -1
- package/cjs/services/strategiesService.js +104 -0
- package/cjs/services/strategySubService.d.ts +6 -0
- package/cjs/services/strategySubService.js +30 -1
- package/cjs/services/strategySubService.test.js +96 -0
- package/cjs/services/subDataService.d.ts +295 -137
- package/cjs/services/subDataService.js +639 -393
- package/cjs/services/subDataService.test.js +157 -0
- package/cjs/services/triggerService.d.ts +29 -0
- package/cjs/services/triggerService.js +53 -1
- package/cjs/services/triggerService.test.js +84 -0
- package/cjs/services/utils.d.ts +1 -1
- package/cjs/services/utils.js +10 -2
- package/cjs/types/enums.d.ts +17 -3
- package/cjs/types/enums.js +14 -0
- package/cjs/types/index.d.ts +22 -1
- package/esm/automation/private/StrategiesAutomation.d.ts +2 -0
- package/esm/automation/private/StrategiesAutomation.js +10 -1
- package/esm/automation/private/StrategiesAutomation.test.js +25 -0
- package/esm/constants/index.d.ts +1 -0
- package/esm/constants/index.js +61 -0
- package/esm/services/strategiesService.js +105 -1
- package/esm/services/strategySubService.d.ts +6 -0
- package/esm/services/strategySubService.js +29 -0
- package/esm/services/strategySubService.test.js +97 -1
- package/esm/services/subDataService.d.ts +295 -137
- package/esm/services/subDataService.js +639 -393
- package/esm/services/subDataService.test.js +157 -0
- package/esm/services/triggerService.d.ts +29 -0
- package/esm/services/triggerService.js +52 -0
- package/esm/services/triggerService.test.js +85 -1
- package/esm/services/utils.d.ts +1 -1
- package/esm/services/utils.js +10 -2
- package/esm/types/enums.d.ts +17 -3
- package/esm/types/enums.js +14 -0
- package/esm/types/index.d.ts +22 -1
- package/package.json +2 -2
- package/src/automation/private/StrategiesAutomation.test.ts +40 -0
- package/src/automation/private/StrategiesAutomation.ts +11 -0
- package/src/constants/index.ts +62 -0
- package/src/services/strategiesService.ts +119 -1
- package/src/services/strategySubService.test.ts +124 -0
- package/src/services/strategySubService.ts +118 -0
- package/src/services/subDataService.test.ts +172 -0
- package/src/services/subDataService.ts +1031 -782
- package/src/services/triggerService.test.ts +97 -0
- package/src/services/triggerService.ts +74 -1
- package/src/services/utils.ts +15 -4
- package/src/types/enums.ts +14 -0
- 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 {
|
|
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
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
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
|
-
|
|
188
|
-
|
|
189
|
-
const
|
|
190
|
-
const
|
|
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
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
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
|
-
|
|
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)
|
|
217
|
-
const
|
|
218
|
-
const
|
|
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
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
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
|
-
|
|
233
|
-
|
|
234
|
-
const
|
|
235
|
-
const
|
|
236
|
-
const
|
|
237
|
-
const
|
|
238
|
-
const
|
|
239
|
-
|
|
240
|
-
const
|
|
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
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
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
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
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
|
-
|
|
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
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
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
|
|
295
|
-
const
|
|
296
|
-
const
|
|
297
|
-
const
|
|
298
|
-
const
|
|
299
|
-
const
|
|
300
|
-
const
|
|
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
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
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
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
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
|
|
323
|
-
const
|
|
324
|
-
const
|
|
325
|
-
const
|
|
326
|
-
|
|
327
|
-
const
|
|
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
|
-
|
|
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
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
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
|
|
347
|
-
const
|
|
348
|
-
const
|
|
349
|
-
const
|
|
350
|
-
const
|
|
351
|
-
|
|
352
|
-
const
|
|
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
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
417
|
+
encodedMarket,
|
|
418
|
+
encodedTroveId,
|
|
419
|
+
encodedCollToken,
|
|
420
|
+
encodedBoldToken,
|
|
421
|
+
encodedTargetRatio,
|
|
422
|
+
encodedCollActionType,
|
|
423
|
+
encodedDebtActionType,
|
|
362
424
|
];
|
|
363
425
|
},
|
|
364
426
|
decode(subData: SubData): {
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
amountToSwitch: string,
|
|
427
|
+
market: EthereumAddress,
|
|
428
|
+
troveId: string,
|
|
429
|
+
collToken: EthereumAddress,
|
|
430
|
+
boldToken: EthereumAddress,
|
|
431
|
+
targetRatio: number,
|
|
371
432
|
} {
|
|
372
|
-
const
|
|
373
|
-
const
|
|
374
|
-
const
|
|
375
|
-
const
|
|
376
|
-
const
|
|
377
|
-
const
|
|
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
|
-
|
|
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
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
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)
|
|
404
|
-
const
|
|
405
|
-
const
|
|
406
|
-
|
|
407
|
-
const
|
|
408
|
-
const
|
|
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
|
-
|
|
476
|
+
market, troveId, boldToken, ratioState, targetRatio,
|
|
412
477
|
};
|
|
413
478
|
},
|
|
414
479
|
};
|
|
415
480
|
|
|
416
|
-
|
|
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
|
|
435
|
-
const targetRatio = weiToRatioPercentage(
|
|
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
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
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
|
|
465
|
-
const targetRatio = weiToRatioPercentage(
|
|
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
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
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
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
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
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
const
|
|
703
|
-
const
|
|
704
|
-
const
|
|
705
|
-
const
|
|
706
|
-
const
|
|
707
|
-
|
|
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
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
576
|
+
encodedColl,
|
|
577
|
+
encodedCollId,
|
|
578
|
+
encodedDebt,
|
|
579
|
+
encodedDebtId,
|
|
580
|
+
encodedMarket,
|
|
581
|
+
encodedTargetRatio,
|
|
582
|
+
userEncoded,
|
|
737
583
|
];
|
|
738
584
|
},
|
|
739
|
-
decode
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
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
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
const
|
|
767
|
-
const
|
|
768
|
-
const
|
|
769
|
-
const
|
|
770
|
-
|
|
771
|
-
const
|
|
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
|
-
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
839
|
-
|
|
840
|
-
const
|
|
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,
|
|
663
|
+
collAsset, collAssetId, debtAsset, debtAssetId, closeType, marketAddr, owner,
|
|
845
664
|
};
|
|
846
665
|
},
|
|
847
666
|
};
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
)
|
|
858
|
-
const
|
|
859
|
-
const
|
|
860
|
-
const
|
|
861
|
-
const
|
|
862
|
-
const
|
|
863
|
-
const
|
|
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
|
-
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
debtActionTypeEncoded,
|
|
686
|
+
encodedFromAsset,
|
|
687
|
+
encodedFromAssetId,
|
|
688
|
+
encodedToAsset,
|
|
689
|
+
encodedToAssetId,
|
|
690
|
+
encodedMarketAddr,
|
|
691
|
+
encodedAmountToSwitch,
|
|
692
|
+
encodedUseOnBehalf,
|
|
881
693
|
];
|
|
882
694
|
},
|
|
883
|
-
decode
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
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
|
-
|
|
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
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
|
|
904
|
-
|
|
717
|
+
collAsset: EthereumAddress,
|
|
718
|
+
collAssetId: number,
|
|
719
|
+
debtAsset: EthereumAddress,
|
|
720
|
+
debtAssetId: number,
|
|
721
|
+
nullAddress: EthereumAddress = ZERO_ADDRESS,
|
|
905
722
|
): SubData {
|
|
906
|
-
const
|
|
907
|
-
const
|
|
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
|
-
|
|
917
|
-
|
|
918
|
-
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
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
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
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
|
-
|
|
741
|
+
collAsset, collAssetId, debtAsset, debtAssetId,
|
|
942
742
|
};
|
|
943
743
|
},
|
|
944
744
|
};
|
|
945
|
-
|
|
946
|
-
export const liquityV2LeverageManagementOnPriceSubData = {
|
|
745
|
+
export const aaveV3LeverageManagementOnPriceSubData = {
|
|
947
746
|
encode(
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
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
|
|
956
|
-
const
|
|
957
|
-
const
|
|
958
|
-
const
|
|
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
|
-
|
|
974
|
-
encodedDebtActionType,
|
|
769
|
+
useOnBehalfEncoded,
|
|
975
770
|
];
|
|
976
771
|
},
|
|
977
772
|
decode(subData: SubData): {
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
|
|
773
|
+
collAsset: EthereumAddress,
|
|
774
|
+
collAssetId: number,
|
|
775
|
+
debtAsset: EthereumAddress,
|
|
776
|
+
debtAssetId: number,
|
|
777
|
+
marketAddr: EthereumAddress,
|
|
982
778
|
targetRatio: number,
|
|
983
779
|
} {
|
|
984
|
-
const
|
|
985
|
-
const
|
|
986
|
-
const
|
|
987
|
-
const
|
|
988
|
-
const
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
795
|
+
/**
|
|
796
|
+
* ___ ___ ____ ____ _______ ____ ____ _ _
|
|
797
|
+
/ \ / \ \ \ / / | ____| \ \ / / | || |
|
|
798
|
+
/ ^ \ / ^ \ \ \/ / | |__ \ \/ / | || |_
|
|
799
|
+
/ /_\ \ / /_\ \ \ / | __| \ / |__ _|
|
|
800
|
+
/ _____ \ / _____ \ \ / | |____ \ / | |
|
|
801
|
+
/__/ \__\ /__/ \__\ \__/ |_______| \__/ |_|
|
|
802
|
+
*/
|
|
803
|
+
export const aaveV4LeverageManagementSubData = {
|
|
1038
804
|
encode: (
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
boldToken: EthereumAddress,
|
|
1042
|
-
targetRatio: number,
|
|
805
|
+
spoke: EthereumAddress,
|
|
806
|
+
owner: EthereumAddress,
|
|
1043
807
|
ratioState: RatioState,
|
|
808
|
+
targetRatio: number,
|
|
1044
809
|
) => {
|
|
1045
|
-
const
|
|
1046
|
-
const
|
|
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
|
-
|
|
1053
|
-
|
|
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
|
|
1061
|
-
const
|
|
1062
|
-
const
|
|
1063
|
-
const
|
|
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
|
-
|
|
830
|
+
spoke, owner, ratioState, targetRatio,
|
|
1069
831
|
};
|
|
1070
832
|
},
|
|
1071
833
|
};
|
|
1072
|
-
|
|
1073
|
-
export const fluidLeverageManagementSubData = {
|
|
834
|
+
export const aaveV4LeverageManagementOnPriceSubData = {
|
|
1074
835
|
encode: (
|
|
1075
|
-
|
|
1076
|
-
|
|
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
|
|
1081
|
-
const
|
|
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
|
-
|
|
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
|
-
|
|
1095
|
-
|
|
855
|
+
spokeEncoded,
|
|
856
|
+
ownerEncoded,
|
|
857
|
+
collAssetEncoded,
|
|
858
|
+
collAssetIdEncoded,
|
|
859
|
+
debtAssetEncoded,
|
|
860
|
+
debtAssetIdEncoded,
|
|
1096
861
|
ratioStateEncoded,
|
|
1097
862
|
targetRatioEncoded,
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
debtActionTypeEncoded,
|
|
863
|
+
EMPTY_SLOT,
|
|
864
|
+
EMPTY_SLOT,
|
|
1101
865
|
];
|
|
1102
866
|
},
|
|
1103
867
|
decode: (subData: SubData) => {
|
|
1104
|
-
const
|
|
1105
|
-
const
|
|
1106
|
-
const
|
|
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
|
-
|
|
1297
|
-
|
|
1298
|
-
|
|
1299
|
-
|
|
1300
|
-
|
|
1301
|
-
|
|
1302
|
-
|
|
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
|
-
)
|
|
1305
|
-
const
|
|
1306
|
-
const
|
|
1307
|
-
const
|
|
1308
|
-
const
|
|
1309
|
-
const
|
|
1310
|
-
|
|
1311
|
-
const
|
|
1312
|
-
|
|
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
|
-
|
|
1316
|
-
|
|
1317
|
-
|
|
1318
|
-
|
|
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
|
-
|
|
1579
|
+
nftId, vault, ratioState, targetRatio,
|
|
1331
1580
|
};
|
|
1332
1581
|
},
|
|
1333
1582
|
};
|