@defisaver/automation-sdk 3.3.10 → 3.3.11-aave-v4-1-dev
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 +72 -1
- package/cjs/services/ethereumService.test.js +2 -0
- package/cjs/services/strategiesService.js +129 -0
- package/cjs/services/strategySubService.d.ts +19 -0
- package/cjs/services/strategySubService.js +37 -1
- package/cjs/services/strategySubService.test.js +229 -0
- package/cjs/services/subDataService.d.ts +298 -129
- package/cjs/services/subDataService.js +639 -369
- package/cjs/services/subDataService.test.js +214 -0
- package/cjs/services/triggerService.d.ts +38 -0
- package/cjs/services/triggerService.js +68 -1
- package/cjs/services/triggerService.test.js +130 -0
- package/cjs/services/utils.d.ts +1 -1
- package/cjs/services/utils.js +10 -2
- package/cjs/types/enums.d.ts +19 -3
- package/cjs/types/enums.js +16 -0
- package/cjs/types/index.d.ts +33 -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 +71 -0
- package/esm/services/ethereumService.test.js +2 -0
- package/esm/services/strategiesService.js +130 -1
- package/esm/services/strategySubService.d.ts +19 -0
- package/esm/services/strategySubService.js +36 -0
- package/esm/services/strategySubService.test.js +230 -1
- package/esm/services/subDataService.d.ts +298 -129
- package/esm/services/subDataService.js +639 -369
- package/esm/services/subDataService.test.js +214 -0
- package/esm/services/triggerService.d.ts +38 -0
- package/esm/services/triggerService.js +67 -0
- package/esm/services/triggerService.test.js +131 -1
- package/esm/services/utils.d.ts +1 -1
- package/esm/services/utils.js +10 -2
- package/esm/types/enums.d.ts +19 -3
- package/esm/types/enums.js +16 -0
- package/esm/types/index.d.ts +33 -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 +72 -0
- package/src/services/ethereumService.test.ts +2 -0
- package/src/services/strategiesService.ts +150 -2
- package/src/services/strategySubService.test.ts +286 -0
- package/src/services/strategySubService.ts +140 -0
- package/src/services/subDataService.test.ts +239 -0
- package/src/services/subDataService.ts +1072 -784
- package/src/services/triggerService.test.ts +148 -0
- package/src/services/triggerService.ts +97 -1
- package/src/services/utils.ts +15 -4
- package/src/types/enums.ts +16 -0
- package/src/types/index.ts +40 -1
|
@@ -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,371 +504,244 @@ 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');
|
|
535
|
+
user: EthereumAddress,
|
|
536
|
+
isGeneric: boolean,
|
|
537
|
+
): SubData {
|
|
538
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
539
|
+
const encodedRatioState = AbiCoder.encodeParameter('uint8', ratioState);
|
|
496
540
|
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
541
|
+
if (isGeneric) {
|
|
542
|
+
const encodedMarket = AbiCoder.encodeParameter('address', market);
|
|
543
|
+
const encodedUser = AbiCoder.encodeParameter('address', user);
|
|
544
|
+
return [encodedTargetRatio, encodedRatioState, encodedMarket, encodedUser];
|
|
545
|
+
}
|
|
546
|
+
const encodedUseDefaultMarket = AbiCoder.encodeParameter('bool', true);
|
|
547
|
+
const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', false);
|
|
548
|
+
return [encodedTargetRatio, encodedRatioState, encodedUseDefaultMarket, encodedUseOnBehalf];
|
|
549
|
+
},
|
|
550
|
+
decode(subData: SubData): { targetRatio: number, ratioState: RatioState } {
|
|
551
|
+
const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[0]) as any as string);
|
|
552
|
+
const ratioState = AbiCoder.decodeParameter('uint8', subData[1]) as any as RatioState;
|
|
502
553
|
|
|
503
|
-
return { targetRatio };
|
|
554
|
+
return { targetRatio, ratioState };
|
|
504
555
|
},
|
|
505
556
|
};
|
|
506
|
-
|
|
507
|
-
export const morphoAaveV2LeverageManagementSubData = {
|
|
557
|
+
export const aaveV3LeverageManagementOnPriceGeneric = {
|
|
508
558
|
encode(
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
559
|
+
collAsset: EthereumAddress,
|
|
560
|
+
collAssetId: number,
|
|
561
|
+
debtAsset: EthereumAddress,
|
|
562
|
+
debtAssetId: number,
|
|
563
|
+
marketAddr: EthereumAddress,
|
|
564
|
+
targetRatio: number,
|
|
565
|
+
user: EthereumAddress,
|
|
514
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);
|
|
574
|
+
|
|
515
575
|
return [
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
576
|
+
encodedColl,
|
|
577
|
+
encodedCollId,
|
|
578
|
+
encodedDebt,
|
|
579
|
+
encodedDebtId,
|
|
580
|
+
encodedMarket,
|
|
581
|
+
encodedTargetRatio,
|
|
582
|
+
userEncoded,
|
|
522
583
|
];
|
|
523
584
|
},
|
|
524
|
-
decode(subData: SubData): {
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
const
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
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();
|
|
585
|
+
decode(subData: SubData): {
|
|
586
|
+
collAsset: EthereumAddress,
|
|
587
|
+
collAssetId: number,
|
|
588
|
+
debtAsset: EthereumAddress,
|
|
589
|
+
debtAssetId: number,
|
|
590
|
+
marketAddr: EthereumAddress,
|
|
591
|
+
targetRatio: number,
|
|
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;
|
|
560
599
|
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
};
|
|
600
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as unknown as string;
|
|
601
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
564
602
|
|
|
565
|
-
|
|
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);
|
|
603
|
+
const owner = AbiCoder.decodeParameter('address', subData[6]) as unknown as EthereumAddress;
|
|
571
604
|
|
|
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
605
|
return {
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
606
|
+
collAsset,
|
|
607
|
+
collAssetId,
|
|
608
|
+
debtAsset,
|
|
609
|
+
debtAssetId,
|
|
610
|
+
marketAddr,
|
|
611
|
+
targetRatio,
|
|
612
|
+
owner,
|
|
584
613
|
};
|
|
585
614
|
},
|
|
586
615
|
};
|
|
616
|
+
export const aaveV3CloseGenericSubData = {
|
|
617
|
+
encode(
|
|
618
|
+
collAsset: EthereumAddress,
|
|
619
|
+
collAssetId: number,
|
|
620
|
+
debtAsset: EthereumAddress,
|
|
621
|
+
debtAssetId: number,
|
|
622
|
+
closeType: CloseStrategyType,
|
|
623
|
+
marketAddr: EthereumAddress,
|
|
624
|
+
user: EthereumAddress,
|
|
625
|
+
): SubData {
|
|
626
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
627
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
628
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
629
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
630
|
+
const encodedCloseType = AbiCoder.encodeParameter('uint8', closeType);
|
|
631
|
+
const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
|
|
632
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
587
633
|
|
|
588
|
-
export const exchangeLimitOrderSubData = {
|
|
589
|
-
encode(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, targetPrice: string, goodUntil: string | number, orderType: OrderType) : SubData {
|
|
590
634
|
return [
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
635
|
+
encodedColl,
|
|
636
|
+
encodedCollId,
|
|
637
|
+
encodedDebt,
|
|
638
|
+
encodedDebtId,
|
|
639
|
+
encodedCloseType,
|
|
640
|
+
encodedMarket,
|
|
641
|
+
userEncoded,
|
|
597
642
|
];
|
|
598
643
|
},
|
|
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
644
|
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
645
|
+
decode(subData: SubData): {
|
|
646
|
+
collAsset: EthereumAddress,
|
|
647
|
+
collAssetId: number,
|
|
648
|
+
debtAsset: EthereumAddress,
|
|
649
|
+
debtAssetId: number,
|
|
650
|
+
closeType: CloseStrategyType,
|
|
651
|
+
marketAddr: EthereumAddress,
|
|
652
|
+
owner: EthereumAddress,
|
|
653
|
+
} {
|
|
654
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
655
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
656
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
657
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
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;
|
|
611
661
|
|
|
612
|
-
return {
|
|
662
|
+
return {
|
|
663
|
+
collAsset, collAssetId, debtAsset, debtAssetId, closeType, marketAddr, owner,
|
|
664
|
+
};
|
|
613
665
|
},
|
|
614
666
|
};
|
|
615
|
-
export const
|
|
667
|
+
export const aaveV3CollateralSwitchSubData = {
|
|
616
668
|
encode(
|
|
617
|
-
|
|
618
|
-
|
|
669
|
+
fromAsset: EthereumAddress,
|
|
670
|
+
fromAssetId: number,
|
|
671
|
+
toAsset: EthereumAddress,
|
|
672
|
+
toAssetId: number,
|
|
673
|
+
marketAddr: EthereumAddress,
|
|
674
|
+
amountToSwitch: string,
|
|
675
|
+
useOnBehalf: boolean = false,
|
|
619
676
|
): SubData {
|
|
620
|
-
const
|
|
621
|
-
const
|
|
622
|
-
|
|
623
|
-
const
|
|
624
|
-
const
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
decode(subData: SubData): { targetRatio: number, ratioState: RatioState } {
|
|
628
|
-
const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[0]) as any as string);
|
|
629
|
-
const ratioState = AbiCoder.decodeParameter('uint8', subData[1]) as any as RatioState;
|
|
630
|
-
|
|
631
|
-
return { targetRatio, ratioState };
|
|
632
|
-
},
|
|
633
|
-
};
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
export const liquityDsrPaybackSubData = {
|
|
637
|
-
encode: (targetRatio: number) => {
|
|
638
|
-
const daiAddress = getAssetInfo('DAI').address;
|
|
639
|
-
const lusdAddress = getAssetInfo('LUSD').address;
|
|
640
|
-
|
|
641
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
|
|
642
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
643
|
-
const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
|
|
644
|
-
const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
|
|
645
|
-
|
|
646
|
-
return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, lusdAddressEncoded];
|
|
647
|
-
},
|
|
648
|
-
decode: (subData: SubData) => {
|
|
649
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
650
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
651
|
-
return { targetRatio };
|
|
652
|
-
},
|
|
653
|
-
};
|
|
654
|
-
|
|
655
|
-
export const liquityDsrSupplySubData = {
|
|
656
|
-
encode: (targetRatio: number) => {
|
|
657
|
-
const daiAddress = getAssetInfo('DAI').address;
|
|
658
|
-
const wethAddress = getAssetInfo('WETH').address;
|
|
659
|
-
|
|
660
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
|
|
661
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
662
|
-
const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
|
|
663
|
-
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
664
|
-
|
|
665
|
-
return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, wethAddressEncoded];
|
|
666
|
-
},
|
|
667
|
-
decode: (subData: SubData) => {
|
|
668
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
669
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
670
|
-
return { targetRatio };
|
|
671
|
-
},
|
|
672
|
-
};
|
|
673
|
-
|
|
674
|
-
export const liquityDebtInFrontRepaySubData = {
|
|
675
|
-
encode: (targetRatioIncrease: number) => {
|
|
676
|
-
const wethAddress = getAssetInfo('WETH').address;
|
|
677
|
-
const lusdAddress = getAssetInfo('LUSD').address;
|
|
678
|
-
|
|
679
|
-
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
680
|
-
const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
|
|
681
|
-
const targetRatioIncreaseEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatioIncrease));
|
|
682
|
-
const withdrawIdEncoded = AbiCoder.encodeParameter('uint8', 1); // withdraw - 1
|
|
683
|
-
const paybackIdEncoded = AbiCoder.encodeParameter('uint8', 0); // payback - 0
|
|
684
|
-
|
|
685
|
-
return [wethAddressEncoded, lusdAddressEncoded, targetRatioIncreaseEncoded, withdrawIdEncoded, paybackIdEncoded];
|
|
686
|
-
},
|
|
687
|
-
decode: (subData: SubData) => {
|
|
688
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
|
|
689
|
-
const targetRatioIncrease = weiToRatioPercentage(weiRatio);
|
|
690
|
-
return { targetRatioIncrease };
|
|
691
|
-
},
|
|
692
|
-
};
|
|
693
|
-
|
|
694
|
-
export const crvUSDLeverageManagementSubData = {
|
|
695
|
-
encode: (
|
|
696
|
-
controllerAddr: EthereumAddress,
|
|
697
|
-
ratioState: RatioState,
|
|
698
|
-
targetRatio: number,
|
|
699
|
-
collTokenAddr: EthereumAddress,
|
|
700
|
-
crvUSDAddr: EthereumAddress,
|
|
701
|
-
) => {
|
|
702
|
-
const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
|
|
703
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
704
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
705
|
-
const collTokenAddrEncoded = AbiCoder.encodeParameter('address', collTokenAddr);
|
|
706
|
-
const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
|
|
707
|
-
return [controllerAddrEncoded, ratioStateEncoded, targetRatioEncoded, collTokenAddrEncoded, crvUSDAddrEncoded];
|
|
708
|
-
},
|
|
709
|
-
decode: (subData: SubData) => {
|
|
710
|
-
const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
711
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
|
|
712
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
713
|
-
|
|
714
|
-
return { controller, targetRatio };
|
|
715
|
-
},
|
|
716
|
-
};
|
|
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);
|
|
717
684
|
|
|
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
685
|
return [
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
686
|
+
encodedFromAsset,
|
|
687
|
+
encodedFromAssetId,
|
|
688
|
+
encodedToAsset,
|
|
689
|
+
encodedToAssetId,
|
|
690
|
+
encodedMarketAddr,
|
|
691
|
+
encodedAmountToSwitch,
|
|
692
|
+
encodedUseOnBehalf,
|
|
737
693
|
];
|
|
738
694
|
},
|
|
739
|
-
decode
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
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;
|
|
709
|
+
|
|
745
710
|
return {
|
|
746
|
-
|
|
747
|
-
addressToPullTokensFrom,
|
|
748
|
-
positionOwner,
|
|
749
|
-
paybackAmount,
|
|
711
|
+
fromAsset, fromAssetId, toAsset, toAssetId, marketAddr, amountToSwitch,
|
|
750
712
|
};
|
|
751
713
|
},
|
|
752
714
|
};
|
|
715
|
+
export const aaveV3QuotePriceSubData = {
|
|
716
|
+
encode(
|
|
717
|
+
collAsset: EthereumAddress,
|
|
718
|
+
collAssetId: number,
|
|
719
|
+
debtAsset: EthereumAddress,
|
|
720
|
+
debtAssetId: number,
|
|
721
|
+
nullAddress: EthereumAddress = ZERO_ADDRESS,
|
|
722
|
+
): SubData {
|
|
723
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
724
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
753
725
|
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
lltv: string,
|
|
761
|
-
ratioState: RatioState,
|
|
762
|
-
targetRatio: number,
|
|
763
|
-
user: EthereumAddress,
|
|
764
|
-
isEOA: boolean,
|
|
765
|
-
) => {
|
|
766
|
-
const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
|
|
767
|
-
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
768
|
-
const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
|
|
769
|
-
const irmEncoded = AbiCoder.encodeParameter('address', irm);
|
|
770
|
-
const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
|
|
771
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
772
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
773
|
-
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
774
|
-
const isEOAEncoded = AbiCoder.encodeParameter('bool', isEOA);
|
|
775
|
-
return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, ratioStateEncoded, targetRatioEncoded, userEncoded, isEOAEncoded];
|
|
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];
|
|
776
732
|
},
|
|
777
|
-
decode
|
|
778
|
-
const
|
|
779
|
-
const
|
|
780
|
-
|
|
781
|
-
const
|
|
782
|
-
const
|
|
783
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[6]) as any as EthereumAddress;
|
|
784
|
-
const user = AbiCoder.decodeParameter('address', subData[7]) as any as EthereumAddress;
|
|
785
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
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]));
|
|
786
739
|
|
|
787
740
|
return {
|
|
788
|
-
|
|
789
|
-
collToken,
|
|
790
|
-
oracle,
|
|
791
|
-
irm,
|
|
792
|
-
lltv,
|
|
793
|
-
user,
|
|
794
|
-
targetRatio,
|
|
741
|
+
collAsset, collAssetId, debtAsset, debtAssetId,
|
|
795
742
|
};
|
|
796
743
|
},
|
|
797
744
|
};
|
|
798
|
-
|
|
799
745
|
export const aaveV3LeverageManagementOnPriceSubData = {
|
|
800
746
|
encode(
|
|
801
747
|
collAsset: EthereumAddress,
|
|
@@ -846,273 +792,284 @@ export const aaveV3LeverageManagementOnPriceSubData = {
|
|
|
846
792
|
},
|
|
847
793
|
};
|
|
848
794
|
|
|
849
|
-
|
|
795
|
+
/**
|
|
796
|
+
* ___ ___ ____ ____ _______ ____ ____ _ _
|
|
797
|
+
/ \ / \ \ \ / / | ____| \ \ / / | || |
|
|
798
|
+
/ ^ \ / ^ \ \ \/ / | |__ \ \/ / | || |_
|
|
799
|
+
/ /_\ \ / /_\ \ \ / | __| \ / |__ _|
|
|
800
|
+
/ _____ \ / _____ \ \ / | |____ \ / | |
|
|
801
|
+
/__/ \__\ /__/ \__\ \__/ |_______| \__/ |_|
|
|
802
|
+
*/
|
|
803
|
+
export const aaveV4LeverageManagementSubData = {
|
|
850
804
|
encode: (
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
collToken: EthereumAddress,
|
|
854
|
-
boldToken: EthereumAddress,
|
|
805
|
+
spoke: EthereumAddress,
|
|
806
|
+
owner: EthereumAddress,
|
|
855
807
|
ratioState: RatioState,
|
|
856
808
|
targetRatio: number,
|
|
857
|
-
) => {
|
|
858
|
-
const
|
|
859
|
-
const
|
|
860
|
-
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
861
|
-
const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
|
|
862
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
863
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
864
|
-
|
|
865
|
-
const isRepay = ratioState === RatioState.UNDER;
|
|
866
|
-
const collActionType = isRepay ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
|
|
867
|
-
const debtActionType = isRepay ? DebtActionType.PAYBACK : DebtActionType.BORROW;
|
|
868
|
-
|
|
869
|
-
const collActionTypeEncoded = AbiCoder.encodeParameter('uint8', collActionType);
|
|
870
|
-
const debtActionTypeEncoded = AbiCoder.encodeParameter('uint8', debtActionType);
|
|
871
|
-
|
|
872
|
-
return [
|
|
873
|
-
marketEncoded,
|
|
874
|
-
troveIdEncoded,
|
|
875
|
-
collTokenEncoded,
|
|
876
|
-
boldTokenEncoded,
|
|
877
|
-
ratioStateEncoded,
|
|
878
|
-
targetRatioEncoded,
|
|
879
|
-
collActionTypeEncoded,
|
|
880
|
-
debtActionTypeEncoded,
|
|
881
|
-
];
|
|
882
|
-
},
|
|
883
|
-
decode: (subData: SubData) => {
|
|
884
|
-
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
885
|
-
const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
886
|
-
const collToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
887
|
-
const boldToken = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
888
|
-
const ratioState = AbiCoder.decodeParameter('uint8', subData[4]) as any as RatioState;
|
|
889
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
|
|
890
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
891
|
-
|
|
892
|
-
return {
|
|
893
|
-
market, troveId, collToken, boldToken, ratioState, targetRatio,
|
|
894
|
-
};
|
|
895
|
-
},
|
|
896
|
-
};
|
|
897
|
-
|
|
898
|
-
export const liquityV2CloseSubData = {
|
|
899
|
-
encode(
|
|
900
|
-
market: EthereumAddress,
|
|
901
|
-
troveId: string,
|
|
902
|
-
collToken: EthereumAddress,
|
|
903
|
-
boldToken: EthereumAddress,
|
|
904
|
-
closeType: CloseStrategyType,
|
|
905
|
-
): SubData {
|
|
906
|
-
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
907
|
-
const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
|
|
908
|
-
const collAddrEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
909
|
-
const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
|
|
910
|
-
const wethAddress = getAssetInfo('WETH').address;
|
|
911
|
-
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
912
|
-
const gasCompensation = new Dec('0.0375').mul(1e18).toString();
|
|
913
|
-
const gasCompensationEncoded = AbiCoder.encodeParameter('uint256', gasCompensation);
|
|
914
|
-
const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
|
|
915
|
-
|
|
916
|
-
return [
|
|
917
|
-
marketEncoded,
|
|
918
|
-
troveIdEncoded,
|
|
919
|
-
collAddrEncoded,
|
|
920
|
-
boldTokenEncoded,
|
|
921
|
-
wethAddressEncoded,
|
|
922
|
-
gasCompensationEncoded,
|
|
923
|
-
closeTypeEncoded,
|
|
924
|
-
];
|
|
925
|
-
},
|
|
926
|
-
decode(subData: SubData): {
|
|
927
|
-
market: EthereumAddress,
|
|
928
|
-
troveId: string,
|
|
929
|
-
collToken: EthereumAddress,
|
|
930
|
-
boldToken: EthereumAddress,
|
|
931
|
-
closeType: CloseStrategyType,
|
|
932
|
-
} {
|
|
933
|
-
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
934
|
-
const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
935
|
-
const collToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
936
|
-
const boldToken = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
937
|
-
// skip wethAddress and gasCompensation
|
|
938
|
-
const closeType = AbiCoder.decodeParameter('uint8', subData[6]) as any as CloseStrategyType;
|
|
939
|
-
|
|
940
|
-
return {
|
|
941
|
-
market, troveId, collToken, boldToken, closeType,
|
|
942
|
-
};
|
|
943
|
-
},
|
|
944
|
-
};
|
|
945
|
-
|
|
946
|
-
export const liquityV2LeverageManagementOnPriceSubData = {
|
|
947
|
-
encode(
|
|
948
|
-
market: EthereumAddress,
|
|
949
|
-
troveId: string,
|
|
950
|
-
collToken: EthereumAddress,
|
|
951
|
-
boldToken: EthereumAddress,
|
|
952
|
-
targetRatio: number,
|
|
953
|
-
isRepayOnPrice: boolean,
|
|
954
|
-
): SubData {
|
|
955
|
-
const encodedMarket = AbiCoder.encodeParameter('address', market);
|
|
956
|
-
const encodedTroveId = AbiCoder.encodeParameter('uint256', troveId);
|
|
957
|
-
const encodedCollToken = AbiCoder.encodeParameter('address', collToken);
|
|
958
|
-
const encodedBoldToken = AbiCoder.encodeParameter('address', boldToken);
|
|
959
|
-
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);
|
|
966
|
-
|
|
967
|
-
return [
|
|
968
|
-
encodedMarket,
|
|
969
|
-
encodedTroveId,
|
|
970
|
-
encodedCollToken,
|
|
971
|
-
encodedBoldToken,
|
|
972
|
-
encodedTargetRatio,
|
|
973
|
-
encodedCollActionType,
|
|
974
|
-
encodedDebtActionType,
|
|
975
|
-
];
|
|
976
|
-
},
|
|
977
|
-
decode(subData: SubData): {
|
|
978
|
-
market: EthereumAddress,
|
|
979
|
-
troveId: string,
|
|
980
|
-
collToken: EthereumAddress,
|
|
981
|
-
boldToken: EthereumAddress,
|
|
982
|
-
targetRatio: number,
|
|
983
|
-
} {
|
|
984
|
-
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
985
|
-
const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
986
|
-
const collToken = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
987
|
-
const boldToken = AbiCoder.decodeParameter('address', subData[3]) as unknown as EthereumAddress;
|
|
988
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[4]) as any as string;
|
|
989
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
990
|
-
|
|
991
|
-
return {
|
|
992
|
-
market, troveId, collToken, boldToken, targetRatio,
|
|
993
|
-
};
|
|
994
|
-
},
|
|
995
|
-
};
|
|
996
|
-
export const morphoBlueLeverageManagementOnPriceSubData = {
|
|
997
|
-
encode(
|
|
998
|
-
loanToken: EthereumAddress,
|
|
999
|
-
collToken: EthereumAddress,
|
|
1000
|
-
oracle: EthereumAddress,
|
|
1001
|
-
irm: EthereumAddress,
|
|
1002
|
-
lltv: string,
|
|
1003
|
-
targetRatio: number,
|
|
1004
|
-
user: EthereumAddress,
|
|
1005
|
-
): SubData {
|
|
1006
|
-
const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
|
|
1007
|
-
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
1008
|
-
const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
|
|
1009
|
-
const irmEncoded = AbiCoder.encodeParameter('address', irm);
|
|
1010
|
-
const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
|
|
1011
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
1012
|
-
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1013
|
-
return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, targetRatioEncoded, userEncoded];
|
|
1014
|
-
},
|
|
1015
|
-
decode(subData: SubData) {
|
|
1016
|
-
const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1017
|
-
const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
1018
|
-
const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
1019
|
-
const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
1020
|
-
const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
|
|
1021
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as EthereumAddress;
|
|
1022
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1023
|
-
const user = AbiCoder.decodeParameter('address', subData[6]) as any as EthereumAddress;
|
|
1024
|
-
|
|
1025
|
-
return {
|
|
1026
|
-
loanToken,
|
|
1027
|
-
collToken,
|
|
1028
|
-
oracle,
|
|
1029
|
-
irm,
|
|
1030
|
-
lltv,
|
|
1031
|
-
targetRatio,
|
|
1032
|
-
user,
|
|
1033
|
-
};
|
|
1034
|
-
},
|
|
1035
|
-
};
|
|
1036
|
-
|
|
1037
|
-
export const liquityV2PaybackSubData = {
|
|
1038
|
-
encode: (
|
|
1039
|
-
market: EthereumAddress,
|
|
1040
|
-
troveId: string,
|
|
1041
|
-
boldToken: EthereumAddress,
|
|
1042
|
-
targetRatio: number,
|
|
1043
|
-
ratioState: RatioState,
|
|
1044
|
-
) => {
|
|
1045
|
-
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
1046
|
-
const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
|
|
1047
|
-
const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
|
|
1048
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
809
|
+
) => {
|
|
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,
|
|
@@ -1168,39 +1124,123 @@ export const compoundV3CloseSubData = {
|
|
|
1168
1124
|
closeType: CloseStrategyType,
|
|
1169
1125
|
user: EthereumAddress,
|
|
1170
1126
|
): SubData {
|
|
1171
|
-
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
1172
|
-
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
1173
|
-
const baseTokenEncoded = AbiCoder.encodeParameter('address', baseToken);
|
|
1174
|
-
const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
|
|
1175
|
-
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1127
|
+
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
1128
|
+
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
1129
|
+
const baseTokenEncoded = AbiCoder.encodeParameter('address', baseToken);
|
|
1130
|
+
const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
|
|
1131
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1132
|
+
|
|
1133
|
+
return [
|
|
1134
|
+
marketEncoded,
|
|
1135
|
+
collTokenEncoded,
|
|
1136
|
+
baseTokenEncoded,
|
|
1137
|
+
closeTypeEncoded,
|
|
1138
|
+
userEncoded,
|
|
1139
|
+
];
|
|
1140
|
+
},
|
|
1141
|
+
decode(subData: SubData): {
|
|
1142
|
+
market: EthereumAddress,
|
|
1143
|
+
collToken: EthereumAddress,
|
|
1144
|
+
baseToken: EthereumAddress,
|
|
1145
|
+
closeType: CloseStrategyType,
|
|
1146
|
+
owner: EthereumAddress,
|
|
1147
|
+
} {
|
|
1148
|
+
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1149
|
+
const collToken = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
1150
|
+
const baseToken = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
1151
|
+
const closeType = Number(AbiCoder.decodeParameter('uint8', subData[3])) as CloseStrategyType;
|
|
1152
|
+
const owner = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
1153
|
+
|
|
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);
|
|
1176
1232
|
|
|
1177
|
-
|
|
1178
|
-
|
|
1179
|
-
|
|
1180
|
-
baseTokenEncoded,
|
|
1181
|
-
closeTypeEncoded,
|
|
1182
|
-
userEncoded,
|
|
1183
|
-
];
|
|
1233
|
+
const encodedUseDefaultMarket = AbiCoder.encodeParameter('bool', true);
|
|
1234
|
+
const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', false);
|
|
1235
|
+
return [encodedTargetRatio, encodedRatioState, encodedUseDefaultMarket, encodedUseOnBehalf];
|
|
1184
1236
|
},
|
|
1185
|
-
decode(subData: SubData): {
|
|
1186
|
-
|
|
1187
|
-
|
|
1188
|
-
baseToken: EthereumAddress,
|
|
1189
|
-
closeType: CloseStrategyType,
|
|
1190
|
-
owner: EthereumAddress,
|
|
1191
|
-
} {
|
|
1192
|
-
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1193
|
-
const collToken = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
1194
|
-
const baseToken = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
1195
|
-
const closeType = Number(AbiCoder.decodeParameter('uint8', subData[3])) as CloseStrategyType;
|
|
1196
|
-
const owner = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
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;
|
|
1197
1240
|
|
|
1198
|
-
return {
|
|
1199
|
-
market, collToken, baseToken, closeType, owner,
|
|
1200
|
-
};
|
|
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,
|
|
@@ -1292,3 +1529,54 @@ export const morphoBlueCloseOnPriceSubData = {
|
|
|
1292
1529
|
};
|
|
1293
1530
|
},
|
|
1294
1531
|
};
|
|
1532
|
+
|
|
1533
|
+
/**
|
|
1534
|
+
_______ __ __ __ __ _______
|
|
1535
|
+
| ____|| | | | | | | | | \
|
|
1536
|
+
| |__ | | | | | | | | | .--. |
|
|
1537
|
+
| __| | | | | | | | | | | | |
|
|
1538
|
+
| | | `----.| `--' | | | | '--' |
|
|
1539
|
+
|__| |_______| \______/ |__| |_______/
|
|
1540
|
+
*/
|
|
1541
|
+
export const fluidLeverageManagementSubData = {
|
|
1542
|
+
encode: (
|
|
1543
|
+
nftId: string,
|
|
1544
|
+
vault: EthereumAddress,
|
|
1545
|
+
ratioState: RatioState,
|
|
1546
|
+
targetRatio: number,
|
|
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
|
+
];
|
|
1570
|
+
},
|
|
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;
|
|
1576
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1577
|
+
|
|
1578
|
+
return {
|
|
1579
|
+
nftId, vault, ratioState, targetRatio,
|
|
1580
|
+
};
|
|
1581
|
+
},
|
|
1582
|
+
};
|