@defisaver/automation-sdk 3.1.3 → 3.2.0
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/.babelrc +3 -3
- package/.editorconfig +9 -9
- package/.env +5 -0
- package/.env.dev +4 -4
- package/.eslintignore +6 -6
- package/.eslintrc.js +39 -39
- package/.mocharc.json +4 -4
- package/.nvmrc +1 -1
- package/README.md +46 -46
- package/cjs/abis/Erc20.json +223 -223
- package/cjs/abis/SubStorage.json +21 -21
- package/cjs/abis/UniMulticall.json +17 -17
- package/cjs/abis/index.d.ts +9 -9
- package/cjs/abis/index.js +30 -30
- package/cjs/abis/legacy_AaveV2Subscriptions.json +8 -8
- package/cjs/abis/legacy_AuthCheck.json +8 -8
- package/cjs/abis/legacy_CompoundV2Subscriptions.json +9 -9
- package/cjs/abis/legacy_MakerSubscriptions.json +9 -9
- package/cjs/automation/private/Automation.d.ts +12 -12
- package/cjs/automation/private/Automation.js +42 -42
- package/cjs/automation/private/LegacyAutomation.d.ts +25 -25
- package/cjs/automation/private/LegacyAutomation.js +118 -118
- package/cjs/automation/private/LegacyProtocol.d.ts +22 -22
- package/cjs/automation/private/LegacyProtocol.js +41 -41
- package/cjs/automation/private/LegacyProtocol.test.d.ts +1 -1
- package/cjs/automation/private/LegacyProtocol.test.js +25 -25
- package/cjs/automation/private/Protocol.d.ts +22 -22
- package/cjs/automation/private/Protocol.js +41 -41
- package/cjs/automation/private/Protocol.test.d.ts +1 -1
- package/cjs/automation/private/Protocol.test.js +25 -25
- package/cjs/automation/private/StrategiesAutomation.d.ts +33 -33
- package/cjs/automation/private/StrategiesAutomation.js +190 -181
- package/cjs/automation/private/StrategiesAutomation.test.d.ts +1 -1
- package/cjs/automation/private/StrategiesAutomation.test.js +671 -671
- package/cjs/automation/public/ArbitrumStrategies.d.ts +5 -5
- package/cjs/automation/public/ArbitrumStrategies.js +13 -13
- package/cjs/automation/public/BaseStrategies.d.ts +5 -5
- package/cjs/automation/public/BaseStrategies.js +13 -13
- package/cjs/automation/public/EthereumStrategies.d.ts +5 -5
- package/cjs/automation/public/EthereumStrategies.js +13 -13
- package/cjs/automation/public/OptimismStrategies.d.ts +5 -5
- package/cjs/automation/public/OptimismStrategies.js +13 -13
- package/cjs/automation/public/Strategies.test.d.ts +1 -0
- package/cjs/automation/public/Strategies.test.js +61 -0
- package/cjs/automation/public/legacy/LegacyAaveAutomation.d.ts +6 -6
- package/cjs/automation/public/legacy/LegacyAaveAutomation.js +20 -20
- package/cjs/automation/public/legacy/LegacyCompoundAutomation.d.ts +6 -6
- package/cjs/automation/public/legacy/LegacyCompoundAutomation.js +20 -20
- package/cjs/automation/public/legacy/LegacyMakerAutomation.d.ts +6 -6
- package/cjs/automation/public/legacy/LegacyMakerAutomation.js +20 -20
- package/cjs/configuration.d.ts +1 -1
- package/cjs/configuration.js +12 -12
- package/cjs/constants/index.d.ts +28 -28
- package/cjs/constants/index.js +494 -489
- package/cjs/index.d.ts +23 -23
- package/cjs/index.js +65 -65
- package/cjs/services/contractService.d.ts +12 -12
- package/cjs/services/contractService.js +54 -54
- package/cjs/services/ethereumService.d.ts +7 -7
- package/cjs/services/ethereumService.js +49 -49
- package/cjs/services/ethereumService.test.d.ts +1 -1
- package/cjs/services/ethereumService.test.js +242 -242
- package/cjs/services/strategiesService.d.ts +2 -2
- package/cjs/services/strategiesService.js +724 -723
- package/cjs/services/strategiesService.test.d.ts +1 -1
- package/cjs/services/strategiesService.test.js +110 -110
- package/cjs/services/strategySubService.d.ts +100 -100
- package/cjs/services/strategySubService.js +267 -267
- package/cjs/services/strategySubService.test.d.ts +1 -1
- package/cjs/services/strategySubService.test.js +936 -936
- package/cjs/services/subDataService.d.ts +192 -192
- package/cjs/services/subDataService.js +475 -475
- package/cjs/services/subDataService.test.d.ts +1 -1
- package/cjs/services/subDataService.test.js +1282 -1282
- package/cjs/services/triggerService.d.ts +191 -191
- package/cjs/services/triggerService.js +367 -367
- package/cjs/services/triggerService.test.d.ts +1 -1
- package/cjs/services/triggerService.test.js +926 -926
- package/cjs/services/utils.d.ts +25 -25
- package/cjs/services/utils.js +131 -131
- package/cjs/services/utils.test.d.ts +1 -1
- package/cjs/services/utils.test.js +376 -376
- package/cjs/types/contracts/generated/Erc20.d.ts +53 -53
- package/cjs/types/contracts/generated/Erc20.js +5 -5
- package/cjs/types/contracts/generated/Legacy_AaveV2Subscriptions.d.ts +129 -129
- package/cjs/types/contracts/generated/Legacy_AaveV2Subscriptions.js +5 -5
- package/cjs/types/contracts/generated/Legacy_AuthCheck.d.ts +20 -20
- package/cjs/types/contracts/generated/Legacy_AuthCheck.js +5 -5
- package/cjs/types/contracts/generated/Legacy_CompoundV2Subscriptions.d.ts +128 -128
- package/cjs/types/contracts/generated/Legacy_CompoundV2Subscriptions.js +5 -5
- package/cjs/types/contracts/generated/Legacy_MakerSubscriptions.d.ts +246 -246
- package/cjs/types/contracts/generated/Legacy_MakerSubscriptions.js +5 -5
- package/cjs/types/contracts/generated/SubStorage.d.ts +110 -114
- package/cjs/types/contracts/generated/SubStorage.js +5 -5
- package/cjs/types/contracts/generated/UniMulticall.d.ts +55 -55
- package/cjs/types/contracts/generated/UniMulticall.js +5 -5
- package/cjs/types/contracts/generated/index.d.ts +7 -7
- package/cjs/types/contracts/generated/index.js +2 -2
- package/cjs/types/contracts/generated/types.d.ts +54 -54
- package/cjs/types/contracts/generated/types.js +2 -2
- package/cjs/types/enums.d.ts +186 -184
- package/cjs/types/enums.js +208 -206
- package/cjs/types/index.d.ts +224 -224
- package/cjs/types/index.js +2 -2
- package/esm/abis/Erc20.json +223 -223
- package/esm/abis/SubStorage.json +21 -21
- package/esm/abis/UniMulticall.json +17 -17
- package/esm/abis/index.d.ts +9 -9
- package/esm/abis/index.js +18 -18
- package/esm/abis/legacy_AaveV2Subscriptions.json +8 -8
- package/esm/abis/legacy_AuthCheck.json +8 -8
- package/esm/abis/legacy_CompoundV2Subscriptions.json +9 -9
- package/esm/abis/legacy_MakerSubscriptions.json +9 -9
- package/esm/automation/private/Automation.d.ts +12 -12
- package/esm/automation/private/Automation.js +39 -39
- package/esm/automation/private/LegacyAutomation.d.ts +25 -25
- package/esm/automation/private/LegacyAutomation.js +112 -112
- package/esm/automation/private/LegacyProtocol.d.ts +22 -22
- package/esm/automation/private/LegacyProtocol.js +38 -38
- package/esm/automation/private/LegacyProtocol.test.d.ts +1 -1
- package/esm/automation/private/LegacyProtocol.test.js +20 -20
- package/esm/automation/private/Protocol.d.ts +22 -22
- package/esm/automation/private/Protocol.js +38 -38
- package/esm/automation/private/Protocol.test.d.ts +1 -1
- package/esm/automation/private/Protocol.test.js +20 -20
- package/esm/automation/private/StrategiesAutomation.d.ts +33 -33
- package/esm/automation/private/StrategiesAutomation.js +184 -175
- package/esm/automation/private/StrategiesAutomation.test.d.ts +1 -1
- package/esm/automation/private/StrategiesAutomation.test.js +666 -666
- package/esm/automation/public/ArbitrumStrategies.d.ts +5 -5
- package/esm/automation/public/ArbitrumStrategies.js +7 -7
- package/esm/automation/public/BaseStrategies.d.ts +5 -5
- package/esm/automation/public/BaseStrategies.js +7 -7
- package/esm/automation/public/EthereumStrategies.d.ts +5 -5
- package/esm/automation/public/EthereumStrategies.js +7 -7
- package/esm/automation/public/OptimismStrategies.d.ts +5 -5
- package/esm/automation/public/OptimismStrategies.js +7 -7
- package/esm/automation/public/Strategies.test.d.ts +1 -0
- package/esm/automation/public/Strategies.test.js +56 -0
- package/esm/automation/public/legacy/LegacyAaveAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyAaveAutomation.js +14 -14
- package/esm/automation/public/legacy/LegacyCompoundAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyCompoundAutomation.js +14 -14
- package/esm/automation/public/legacy/LegacyMakerAutomation.d.ts +6 -6
- package/esm/automation/public/legacy/LegacyMakerAutomation.js +14 -14
- package/esm/configuration.d.ts +1 -1
- package/esm/configuration.js +7 -7
- package/esm/constants/index.d.ts +28 -28
- package/esm/constants/index.js +488 -483
- package/esm/index.d.ts +23 -23
- package/esm/index.js +23 -23
- package/esm/services/contractService.d.ts +12 -12
- package/esm/services/contractService.js +45 -45
- package/esm/services/ethereumService.d.ts +7 -7
- package/esm/services/ethereumService.js +41 -41
- package/esm/services/ethereumService.test.d.ts +1 -1
- package/esm/services/ethereumService.test.js +237 -237
- package/esm/services/strategiesService.d.ts +2 -2
- package/esm/services/strategiesService.js +697 -696
- package/esm/services/strategiesService.test.d.ts +1 -1
- package/esm/services/strategiesService.test.js +108 -108
- package/esm/services/strategySubService.d.ts +100 -100
- package/esm/services/strategySubService.js +238 -238
- package/esm/services/strategySubService.test.d.ts +1 -1
- package/esm/services/strategySubService.test.js +908 -908
- package/esm/services/subDataService.d.ts +192 -192
- package/esm/services/subDataService.js +469 -469
- package/esm/services/subDataService.test.d.ts +1 -1
- package/esm/services/subDataService.test.js +1254 -1254
- package/esm/services/triggerService.d.ts +191 -191
- package/esm/services/triggerService.js +338 -338
- package/esm/services/triggerService.test.d.ts +1 -1
- package/esm/services/triggerService.test.js +901 -901
- package/esm/services/utils.d.ts +25 -25
- package/esm/services/utils.js +82 -82
- package/esm/services/utils.test.d.ts +1 -1
- package/esm/services/utils.test.js +348 -348
- package/esm/types/contracts/generated/Erc20.d.ts +53 -53
- package/esm/types/contracts/generated/Erc20.js +4 -4
- package/esm/types/contracts/generated/Legacy_AaveV2Subscriptions.d.ts +129 -129
- package/esm/types/contracts/generated/Legacy_AaveV2Subscriptions.js +4 -4
- package/esm/types/contracts/generated/Legacy_AuthCheck.d.ts +20 -20
- package/esm/types/contracts/generated/Legacy_AuthCheck.js +4 -4
- package/esm/types/contracts/generated/Legacy_CompoundV2Subscriptions.d.ts +128 -128
- package/esm/types/contracts/generated/Legacy_CompoundV2Subscriptions.js +4 -4
- package/esm/types/contracts/generated/Legacy_MakerSubscriptions.d.ts +246 -246
- package/esm/types/contracts/generated/Legacy_MakerSubscriptions.js +4 -4
- package/esm/types/contracts/generated/SubStorage.d.ts +110 -114
- package/esm/types/contracts/generated/SubStorage.js +4 -4
- package/esm/types/contracts/generated/UniMulticall.d.ts +55 -55
- package/esm/types/contracts/generated/UniMulticall.js +4 -4
- package/esm/types/contracts/generated/index.d.ts +7 -7
- package/esm/types/contracts/generated/index.js +1 -1
- package/esm/types/contracts/generated/types.d.ts +54 -54
- package/esm/types/contracts/generated/types.js +1 -1
- package/esm/types/enums.d.ts +186 -184
- package/esm/types/enums.js +205 -203
- package/esm/types/index.d.ts +224 -224
- package/esm/types/index.js +1 -1
- package/package.json +62 -61
- package/scripts/generateContractTypes.js +39 -39
- package/src/abis/Erc20.json +222 -222
- package/src/abis/SubStorage.json +21 -21
- package/src/abis/UniMulticall.json +17 -17
- package/src/abis/index.ts +28 -28
- package/src/abis/legacy_AaveV2Subscriptions.json +7 -7
- package/src/abis/legacy_AuthCheck.json +7 -7
- package/src/abis/legacy_CompoundV2Subscriptions.json +8 -8
- package/src/abis/legacy_MakerSubscriptions.json +8 -8
- package/src/automation/private/Automation.ts +44 -44
- package/src/automation/private/LegacyAutomation.ts +135 -135
- package/src/automation/private/LegacyProtocol.test.ts +23 -23
- package/src/automation/private/LegacyProtocol.ts +51 -51
- package/src/automation/private/Protocol.test.ts +23 -23
- package/src/automation/private/Protocol.ts +51 -51
- package/src/automation/private/StrategiesAutomation.test.ts +663 -663
- package/src/automation/private/StrategiesAutomation.ts +254 -242
- package/src/automation/public/ArbitrumStrategies.ts +10 -10
- package/src/automation/public/BaseStrategies.ts +10 -10
- package/src/automation/public/EthereumStrategies.ts +10 -10
- package/src/automation/public/OptimismStrategies.ts +10 -10
- package/src/automation/public/Strategies.test.ts +49 -0
- package/src/automation/public/legacy/LegacyAaveAutomation.ts +20 -20
- package/src/automation/public/legacy/LegacyCompoundAutomation.ts +20 -20
- package/src/automation/public/legacy/LegacyMakerAutomation.ts +20 -20
- package/src/configuration.ts +8 -8
- package/src/constants/index.ts +523 -507
- package/src/index.ts +39 -39
- package/src/services/contractService.ts +77 -77
- package/src/services/ethereumService.test.ts +257 -257
- package/src/services/ethereumService.ts +69 -69
- package/src/services/strategiesService.test.ts +105 -105
- package/src/services/strategiesService.ts +935 -934
- package/src/services/strategySubService.test.ts +1122 -1122
- package/src/services/strategySubService.ts +524 -524
- package/src/services/subDataService.test.ts +1387 -1387
- package/src/services/subDataService.ts +645 -645
- package/src/services/triggerService.test.ts +1004 -1004
- package/src/services/triggerService.ts +449 -449
- package/src/services/utils.test.ts +430 -430
- package/src/services/utils.ts +103 -103
- package/src/types/enums.ts +202 -200
- package/src/types/index.ts +279 -279
- package/tsconfig.esm.json +8 -8
- package/tsconfig.json +22 -22
- package/umd/index.js +0 -34103
|
@@ -1,645 +1,645 @@
|
|
|
1
|
-
import Dec from 'decimal.js';
|
|
2
|
-
import AbiCoder from 'web3-eth-abi';
|
|
3
|
-
import { fromWei, toWei } from 'web3-utils';
|
|
4
|
-
|
|
5
|
-
import { assetAmountInEth, getAssetInfo, getAssetInfoByAddress } from '@defisaver/tokens';
|
|
6
|
-
import { otherAddresses } from '@defisaver/sdk';
|
|
7
|
-
|
|
8
|
-
import type { SubData, EthereumAddress } from '../types';
|
|
9
|
-
import type { OrderType } from '../types/enums';
|
|
10
|
-
import { ChainId, RatioState } from '../types/enums';
|
|
11
|
-
|
|
12
|
-
import { AAVE_V3_VARIABLE_BORROW_RATE, ZERO_ADDRESS } from '../constants';
|
|
13
|
-
|
|
14
|
-
import { compareAddresses, ratioPercentageToWei, weiToRatioPercentage } from './utils';
|
|
15
|
-
|
|
16
|
-
export const makerRepayFromSavingsSubData = {
|
|
17
|
-
encode(
|
|
18
|
-
vaultId: number,
|
|
19
|
-
targetRatioPercentage: number,
|
|
20
|
-
chainId: ChainId,
|
|
21
|
-
daiAddr?: EthereumAddress,
|
|
22
|
-
mcdCdpManagerAddr?: EthereumAddress,
|
|
23
|
-
): SubData {
|
|
24
|
-
const _daiAddr = daiAddr || getAssetInfo('DAI', chainId).address;
|
|
25
|
-
// @ts-ignore // TODO - this requires change in @defisaver/tokens
|
|
26
|
-
const _mcdCdpManagerAddr = mcdCdpManagerAddr || otherAddresses(chainId).McdCdpManager;
|
|
27
|
-
|
|
28
|
-
const vaultIdEncoded = AbiCoder.encodeParameter('uint256', vaultId.toString());
|
|
29
|
-
const targetRatioWei = ratioPercentageToWei(targetRatioPercentage);
|
|
30
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', targetRatioWei);
|
|
31
|
-
const daiAddrEncoded = AbiCoder.encodeParameter('address', _daiAddr);
|
|
32
|
-
const mcdManagerAddrEncoded = AbiCoder.encodeParameter('address', _mcdCdpManagerAddr);
|
|
33
|
-
|
|
34
|
-
return [vaultIdEncoded, targetRatioEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
35
|
-
},
|
|
36
|
-
decode(subData: SubData): { vaultId: number, daiAddr: string, mcdManagerAddr: string, targetRatio: number } {
|
|
37
|
-
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
38
|
-
|
|
39
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
40
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
41
|
-
|
|
42
|
-
const daiAddr = AbiCoder.decodeParameter('address', subData[2])!.toString();
|
|
43
|
-
const mcdManagerAddr = AbiCoder.decodeParameter('address', subData[3])!.toString();
|
|
44
|
-
|
|
45
|
-
return {
|
|
46
|
-
vaultId, targetRatio, daiAddr, mcdManagerAddr,
|
|
47
|
-
};
|
|
48
|
-
},
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
export const liquityRepayFromSavingsSubData = {
|
|
52
|
-
decode(subData: SubData): { targetRatio: number } {
|
|
53
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
54
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
55
|
-
|
|
56
|
-
return { targetRatio };
|
|
57
|
-
},
|
|
58
|
-
};
|
|
59
|
-
|
|
60
|
-
export const makerCloseSubData = {
|
|
61
|
-
encode(
|
|
62
|
-
vaultId: number,
|
|
63
|
-
closeToAssetAddr: EthereumAddress,
|
|
64
|
-
chainId: ChainId,
|
|
65
|
-
daiAddr?: EthereumAddress,
|
|
66
|
-
mcdCdpManagerAddr?: EthereumAddress,
|
|
67
|
-
): SubData {
|
|
68
|
-
const _daiAddr = daiAddr || getAssetInfo('DAI', chainId).address;
|
|
69
|
-
// @ts-ignore // TODO - this requires change in @defisaver/tokens
|
|
70
|
-
const _mcdCdpManagerAddr = mcdCdpManagerAddr || otherAddresses(chainId).McdCdpManager;
|
|
71
|
-
|
|
72
|
-
const vaultIdEncoded = AbiCoder.encodeParameter('uint256', vaultId.toString());
|
|
73
|
-
const daiAddrEncoded = AbiCoder.encodeParameter('address', _daiAddr);
|
|
74
|
-
const mcdManagerAddrEncoded = AbiCoder.encodeParameter('address', _mcdCdpManagerAddr);
|
|
75
|
-
|
|
76
|
-
if (compareAddresses(closeToAssetAddr, _daiAddr)) {
|
|
77
|
-
// Close to DAI strategy
|
|
78
|
-
return [vaultIdEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
79
|
-
}
|
|
80
|
-
// Close to collateral strategy
|
|
81
|
-
const collAddrEncoded = AbiCoder.encodeParameter('address', closeToAssetAddr);
|
|
82
|
-
return [vaultIdEncoded, collAddrEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
83
|
-
},
|
|
84
|
-
decode(subData: SubData): { vaultId: number, closeToAssetAddr: EthereumAddress } {
|
|
85
|
-
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!;
|
|
86
|
-
// if closing to collateral, asset addr will be 2nd param out of 4
|
|
87
|
-
// if closing to DAI, will return 2nd param out of 3, which will be DAI addr
|
|
88
|
-
const closeToAssetAddr = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
89
|
-
|
|
90
|
-
return {
|
|
91
|
-
vaultId, closeToAssetAddr,
|
|
92
|
-
};
|
|
93
|
-
},
|
|
94
|
-
};
|
|
95
|
-
|
|
96
|
-
export const makerLeverageManagementSubData = {
|
|
97
|
-
decode: (subData:SubData) => {
|
|
98
|
-
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
99
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
100
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
101
|
-
return { vaultId, targetRatio };
|
|
102
|
-
},
|
|
103
|
-
};
|
|
104
|
-
|
|
105
|
-
export const liquityLeverageManagementSubData = {
|
|
106
|
-
decode: (subData:SubData) => {
|
|
107
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
108
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
109
|
-
return { targetRatio };
|
|
110
|
-
},
|
|
111
|
-
};
|
|
112
|
-
|
|
113
|
-
export const liquityCloseSubData = {
|
|
114
|
-
encode(
|
|
115
|
-
closeToAssetAddr: EthereumAddress,
|
|
116
|
-
chainId: ChainId = ChainId.Ethereum,
|
|
117
|
-
collAddr?: EthereumAddress,
|
|
118
|
-
debtAddr?: EthereumAddress,
|
|
119
|
-
): SubData {
|
|
120
|
-
const _collAddr = collAddr || getAssetInfo('WETH', chainId).address;
|
|
121
|
-
const _debtAddr = debtAddr || getAssetInfo('LUSD', chainId).address;
|
|
122
|
-
|
|
123
|
-
const collAddrEncoded = AbiCoder.encodeParameter('address', _collAddr);
|
|
124
|
-
const debtAddrEncoded = AbiCoder.encodeParameter('address', _debtAddr);
|
|
125
|
-
// if (compareAddresses(closeToAssetAddr, _debtAddr)) { // Closing to debt strategy was not implemented, but it should be in the future
|
|
126
|
-
// // close to LUSD strategy
|
|
127
|
-
// return [debtAddrEncoded, collAddrEncoded];
|
|
128
|
-
// }
|
|
129
|
-
// close to collateral strategy
|
|
130
|
-
return [collAddrEncoded, debtAddrEncoded];
|
|
131
|
-
},
|
|
132
|
-
decode(subData: SubData): { closeToAssetAddr: EthereumAddress, debtAddr: string } {
|
|
133
|
-
const closeToAssetAddr = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
134
|
-
const debtAddr = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
135
|
-
|
|
136
|
-
return { closeToAssetAddr, debtAddr };
|
|
137
|
-
},
|
|
138
|
-
};
|
|
139
|
-
|
|
140
|
-
export const aaveV2LeverageManagementSubData = {
|
|
141
|
-
encode(
|
|
142
|
-
triggerRepayRatio: number,
|
|
143
|
-
triggerBoostRatio: number,
|
|
144
|
-
targetBoostRatio: number,
|
|
145
|
-
targetRepayRatio: number,
|
|
146
|
-
boostEnabled: boolean,
|
|
147
|
-
): SubData {
|
|
148
|
-
return [
|
|
149
|
-
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
150
|
-
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
151
|
-
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
152
|
-
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
153
|
-
// @ts-ignore // TODO
|
|
154
|
-
boostEnabled,
|
|
155
|
-
];
|
|
156
|
-
},
|
|
157
|
-
decode(subData: SubData): { targetRatio: number } {
|
|
158
|
-
const ratioWei = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
159
|
-
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
160
|
-
|
|
161
|
-
return { targetRatio };
|
|
162
|
-
},
|
|
163
|
-
};
|
|
164
|
-
|
|
165
|
-
export const aaveV3LeverageManagementSubData = { // TODO encode?
|
|
166
|
-
decode(subData: SubData): { targetRatio: number } {
|
|
167
|
-
const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
168
|
-
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
169
|
-
|
|
170
|
-
return { targetRatio };
|
|
171
|
-
},
|
|
172
|
-
};
|
|
173
|
-
|
|
174
|
-
export const aaveV3QuotePriceSubData = {
|
|
175
|
-
encode(
|
|
176
|
-
collAsset: EthereumAddress,
|
|
177
|
-
collAssetId: number,
|
|
178
|
-
debtAsset: EthereumAddress,
|
|
179
|
-
debtAssetId: number,
|
|
180
|
-
nullAddress: EthereumAddress = ZERO_ADDRESS,
|
|
181
|
-
): SubData {
|
|
182
|
-
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
183
|
-
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
184
|
-
|
|
185
|
-
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
186
|
-
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
187
|
-
|
|
188
|
-
const encodedNullAddress = AbiCoder.encodeParameter('address', nullAddress);
|
|
189
|
-
|
|
190
|
-
return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedNullAddress];
|
|
191
|
-
},
|
|
192
|
-
decode(subData: SubData): { collAsset: EthereumAddress, collAssetId: number, debtAsset: EthereumAddress, debtAssetId: number } {
|
|
193
|
-
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
194
|
-
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
195
|
-
|
|
196
|
-
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
197
|
-
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
198
|
-
|
|
199
|
-
return {
|
|
200
|
-
collAsset, collAssetId, debtAsset, debtAssetId,
|
|
201
|
-
};
|
|
202
|
-
},
|
|
203
|
-
};
|
|
204
|
-
|
|
205
|
-
export const compoundV2LeverageManagementSubData = {
|
|
206
|
-
encode(
|
|
207
|
-
triggerRepayRatio: number,
|
|
208
|
-
triggerBoostRatio: number,
|
|
209
|
-
targetBoostRatio: number,
|
|
210
|
-
targetRepayRatio: number,
|
|
211
|
-
boostEnabled: boolean,
|
|
212
|
-
): SubData {
|
|
213
|
-
return [
|
|
214
|
-
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
215
|
-
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
216
|
-
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
217
|
-
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
218
|
-
// @ts-ignore // TODO
|
|
219
|
-
boostEnabled,
|
|
220
|
-
];
|
|
221
|
-
},
|
|
222
|
-
decode(subData: SubData): { targetRatio: number } {
|
|
223
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
224
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
225
|
-
|
|
226
|
-
return { targetRatio };
|
|
227
|
-
},
|
|
228
|
-
};
|
|
229
|
-
|
|
230
|
-
export const compoundV3LeverageManagementSubData = {
|
|
231
|
-
encode(
|
|
232
|
-
market: EthereumAddress,
|
|
233
|
-
baseToken: EthereumAddress,
|
|
234
|
-
triggerRepayRatio: number,
|
|
235
|
-
triggerBoostRatio: number,
|
|
236
|
-
targetBoostRatio: number,
|
|
237
|
-
targetRepayRatio: number,
|
|
238
|
-
boostEnabled: boolean,
|
|
239
|
-
isEOA: boolean,
|
|
240
|
-
): SubData {
|
|
241
|
-
return [
|
|
242
|
-
market,
|
|
243
|
-
baseToken,
|
|
244
|
-
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
245
|
-
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
246
|
-
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
247
|
-
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
248
|
-
// @ts-ignore // TODO
|
|
249
|
-
boostEnabled, isEOA,
|
|
250
|
-
];
|
|
251
|
-
},
|
|
252
|
-
decode(subData: SubData): { targetRatio: number } {
|
|
253
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
254
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
255
|
-
|
|
256
|
-
return { targetRatio };
|
|
257
|
-
},
|
|
258
|
-
};
|
|
259
|
-
|
|
260
|
-
export const compoundV3L2LeverageManagementSubData = {
|
|
261
|
-
encode(
|
|
262
|
-
market: EthereumAddress,
|
|
263
|
-
baseToken: EthereumAddress,
|
|
264
|
-
triggerRepayRatio: number,
|
|
265
|
-
triggerBoostRatio: number,
|
|
266
|
-
targetBoostRatio: number,
|
|
267
|
-
targetRepayRatio: number,
|
|
268
|
-
boostEnabled: boolean,
|
|
269
|
-
): string {
|
|
270
|
-
let subInput = '0x';
|
|
271
|
-
|
|
272
|
-
subInput = subInput.concat(market.slice(2));
|
|
273
|
-
subInput = subInput.concat(baseToken.slice(2));
|
|
274
|
-
subInput = subInput.concat(new Dec(triggerRepayRatio).mul(1e16).toHex().slice(2)
|
|
275
|
-
.padStart(32, '0'));
|
|
276
|
-
subInput = subInput.concat(new Dec(triggerBoostRatio).mul(1e16).toHex().slice(2)
|
|
277
|
-
.padStart(32, '0'));
|
|
278
|
-
subInput = subInput.concat(new Dec(targetBoostRatio).mul(1e16).toHex().slice(2)
|
|
279
|
-
.padStart(32, '0'));
|
|
280
|
-
subInput = subInput.concat(new Dec(targetRepayRatio).mul(1e16).toHex().slice(2)
|
|
281
|
-
.padStart(32, '0'));
|
|
282
|
-
subInput = subInput.concat(boostEnabled ? '01' : '00');
|
|
283
|
-
|
|
284
|
-
return subInput;
|
|
285
|
-
},
|
|
286
|
-
decode(subData: SubData): { targetRatio: number } {
|
|
287
|
-
const ratioWei = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
288
|
-
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
289
|
-
|
|
290
|
-
return { targetRatio };
|
|
291
|
-
},
|
|
292
|
-
};
|
|
293
|
-
|
|
294
|
-
export const morphoAaveV2LeverageManagementSubData = {
|
|
295
|
-
encode(
|
|
296
|
-
triggerRepayRatio: number,
|
|
297
|
-
triggerBoostRatio: number,
|
|
298
|
-
targetBoostRatio: number,
|
|
299
|
-
targetRepayRatio: number,
|
|
300
|
-
boostEnabled: boolean,
|
|
301
|
-
): SubData {
|
|
302
|
-
return [
|
|
303
|
-
ratioPercentageToWei(triggerRepayRatio),
|
|
304
|
-
ratioPercentageToWei(triggerBoostRatio),
|
|
305
|
-
ratioPercentageToWei(targetBoostRatio),
|
|
306
|
-
ratioPercentageToWei(targetRepayRatio),
|
|
307
|
-
// @ts-ignore
|
|
308
|
-
boostEnabled,
|
|
309
|
-
];
|
|
310
|
-
},
|
|
311
|
-
decode(subData: SubData): { targetRatio: number } {
|
|
312
|
-
const ratioWei = AbiCoder.decodeParameter('uint128', subData[1]) as any as string;
|
|
313
|
-
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
314
|
-
|
|
315
|
-
return { targetRatio };
|
|
316
|
-
},
|
|
317
|
-
};
|
|
318
|
-
|
|
319
|
-
export const cBondsRebondSubData = {
|
|
320
|
-
encode(bondId: number | string): SubData {
|
|
321
|
-
const bondIdEncoded = AbiCoder.encodeParameter('uint256', bondId);
|
|
322
|
-
return [bondIdEncoded];
|
|
323
|
-
},
|
|
324
|
-
decode(subData: SubData): { bondId: string } {
|
|
325
|
-
const bondId = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
|
|
326
|
-
return { bondId };
|
|
327
|
-
},
|
|
328
|
-
};
|
|
329
|
-
|
|
330
|
-
export const liquityPaybackUsingChickenBondSubData = {
|
|
331
|
-
/**
|
|
332
|
-
* @param sourceId bondId or subId
|
|
333
|
-
* @param sourceType 0 for bond, 1 for subId
|
|
334
|
-
* @param chainId
|
|
335
|
-
*/
|
|
336
|
-
encode: (sourceId: string, sourceType: number, chainId: ChainId = ChainId.Ethereum): SubData => {
|
|
337
|
-
const sourceIdEncoded = AbiCoder.encodeParameter('uint256', sourceId);
|
|
338
|
-
const sourceTypeEncoded = AbiCoder.encodeParameter('uint256', sourceType);
|
|
339
|
-
const lusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('LUSD', chainId).address);
|
|
340
|
-
const bLusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('bLUSD', chainId).address);
|
|
341
|
-
|
|
342
|
-
return [sourceIdEncoded, sourceTypeEncoded, lusdAddressEncoded, bLusdAddressEncoded];
|
|
343
|
-
},
|
|
344
|
-
decode: (subData: SubData) => {
|
|
345
|
-
const sourceId = AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
346
|
-
const sourceType = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
|
|
347
|
-
|
|
348
|
-
return { sourceId, sourceType };
|
|
349
|
-
},
|
|
350
|
-
};
|
|
351
|
-
|
|
352
|
-
export const exchangeDcaSubData = {
|
|
353
|
-
encode: (fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, interval: number) : SubData => {
|
|
354
|
-
const sellTokenEncoded = AbiCoder.encodeParameter('address', fromToken);
|
|
355
|
-
const buyTokenEncoded = AbiCoder.encodeParameter('address', toToken);
|
|
356
|
-
const amountEncoded = AbiCoder.encodeParameter('uint256', amount);
|
|
357
|
-
const intervalEncoded = AbiCoder.encodeParameter('uint256', interval);
|
|
358
|
-
|
|
359
|
-
return [sellTokenEncoded, buyTokenEncoded, amountEncoded, intervalEncoded];
|
|
360
|
-
},
|
|
361
|
-
decode: (subData: SubData, chainId: ChainId) => {
|
|
362
|
-
const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
363
|
-
const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
364
|
-
const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
|
|
365
|
-
const interval = AbiCoder.decodeParameter('uint256', subData[3])!.toString();
|
|
366
|
-
return {
|
|
367
|
-
fromToken,
|
|
368
|
-
toToken,
|
|
369
|
-
amount,
|
|
370
|
-
interval,
|
|
371
|
-
};
|
|
372
|
-
},
|
|
373
|
-
};
|
|
374
|
-
|
|
375
|
-
export const exchangeLimitOrderSubData = {
|
|
376
|
-
encode(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, targetPrice: string, goodUntil: string | number, orderType: OrderType) : SubData {
|
|
377
|
-
return [
|
|
378
|
-
fromToken,
|
|
379
|
-
toToken,
|
|
380
|
-
amount,
|
|
381
|
-
targetPrice,
|
|
382
|
-
new Dec(goodUntil).toString(),
|
|
383
|
-
new Dec(orderType).toString(),
|
|
384
|
-
];
|
|
385
|
-
},
|
|
386
|
-
decode: (subData: SubData, chainId: ChainId) => {
|
|
387
|
-
const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
388
|
-
const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
389
|
-
const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
|
|
390
|
-
return { fromToken, toToken, amount };
|
|
391
|
-
},
|
|
392
|
-
};
|
|
393
|
-
|
|
394
|
-
export const sparkLeverageManagementSubData = { // TODO encode?
|
|
395
|
-
decode(subData: SubData): { targetRatio: number } {
|
|
396
|
-
const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
397
|
-
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
398
|
-
|
|
399
|
-
return { targetRatio };
|
|
400
|
-
},
|
|
401
|
-
};
|
|
402
|
-
|
|
403
|
-
export const sparkQuotePriceSubData = {
|
|
404
|
-
encode(
|
|
405
|
-
collAsset: EthereumAddress,
|
|
406
|
-
collAssetId: number,
|
|
407
|
-
debtAsset: EthereumAddress,
|
|
408
|
-
debtAssetId: number,
|
|
409
|
-
nullAddress: EthereumAddress = ZERO_ADDRESS,
|
|
410
|
-
): SubData {
|
|
411
|
-
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
412
|
-
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
413
|
-
|
|
414
|
-
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
415
|
-
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
416
|
-
|
|
417
|
-
const encodedNullAddress = AbiCoder.encodeParameter('address', nullAddress);
|
|
418
|
-
|
|
419
|
-
return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedNullAddress];
|
|
420
|
-
},
|
|
421
|
-
decode(subData: SubData): { collAsset: EthereumAddress, collAssetId: number, debtAsset: EthereumAddress, debtAssetId: number } {
|
|
422
|
-
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
423
|
-
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
424
|
-
|
|
425
|
-
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
426
|
-
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
427
|
-
|
|
428
|
-
return {
|
|
429
|
-
collAsset, collAssetId, debtAsset, debtAssetId,
|
|
430
|
-
};
|
|
431
|
-
},
|
|
432
|
-
};
|
|
433
|
-
|
|
434
|
-
export const liquityDsrPaybackSubData = {
|
|
435
|
-
encode: (targetRatio: number) => {
|
|
436
|
-
const daiAddress = getAssetInfo('DAI').address;
|
|
437
|
-
const lusdAddress = getAssetInfo('LUSD').address;
|
|
438
|
-
|
|
439
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
|
|
440
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
441
|
-
const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
|
|
442
|
-
const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
|
|
443
|
-
|
|
444
|
-
return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, lusdAddressEncoded];
|
|
445
|
-
},
|
|
446
|
-
decode: (subData: SubData) => {
|
|
447
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
448
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
449
|
-
return { targetRatio };
|
|
450
|
-
},
|
|
451
|
-
};
|
|
452
|
-
|
|
453
|
-
export const liquityDsrSupplySubData = {
|
|
454
|
-
encode: (targetRatio: number) => {
|
|
455
|
-
const daiAddress = getAssetInfo('DAI').address;
|
|
456
|
-
const wethAddress = getAssetInfo('WETH').address;
|
|
457
|
-
|
|
458
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
|
|
459
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
460
|
-
const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
|
|
461
|
-
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
462
|
-
|
|
463
|
-
return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, wethAddressEncoded];
|
|
464
|
-
},
|
|
465
|
-
decode: (subData: SubData) => {
|
|
466
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
467
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
468
|
-
return { targetRatio };
|
|
469
|
-
},
|
|
470
|
-
};
|
|
471
|
-
|
|
472
|
-
export const liquityDebtInFrontRepaySubData = {
|
|
473
|
-
encode: (targetRatioIncrease: number) => {
|
|
474
|
-
const wethAddress = getAssetInfo('WETH').address;
|
|
475
|
-
const lusdAddress = getAssetInfo('LUSD').address;
|
|
476
|
-
|
|
477
|
-
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
478
|
-
const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
|
|
479
|
-
const targetRatioIncreaseEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatioIncrease));
|
|
480
|
-
const withdrawIdEncoded = AbiCoder.encodeParameter('uint8', 1); // withdraw - 1
|
|
481
|
-
const paybackIdEncoded = AbiCoder.encodeParameter('uint8', 0); // payback - 0
|
|
482
|
-
|
|
483
|
-
return [wethAddressEncoded, lusdAddressEncoded, targetRatioIncreaseEncoded, withdrawIdEncoded, paybackIdEncoded];
|
|
484
|
-
},
|
|
485
|
-
decode: (subData: SubData) => {
|
|
486
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
|
|
487
|
-
const targetRatioIncrease = weiToRatioPercentage(weiRatio);
|
|
488
|
-
return { targetRatioIncrease };
|
|
489
|
-
},
|
|
490
|
-
};
|
|
491
|
-
|
|
492
|
-
export const crvUSDLeverageManagementSubData = {
|
|
493
|
-
encode: (
|
|
494
|
-
controllerAddr: EthereumAddress,
|
|
495
|
-
ratioState: RatioState,
|
|
496
|
-
targetRatio: number,
|
|
497
|
-
collTokenAddr: EthereumAddress,
|
|
498
|
-
crvUSDAddr: EthereumAddress,
|
|
499
|
-
) => {
|
|
500
|
-
const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
|
|
501
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
502
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
503
|
-
const collTokenAddrEncoded = AbiCoder.encodeParameter('address', collTokenAddr);
|
|
504
|
-
const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
|
|
505
|
-
return [controllerAddrEncoded, ratioStateEncoded, targetRatioEncoded, collTokenAddrEncoded, crvUSDAddrEncoded];
|
|
506
|
-
},
|
|
507
|
-
decode: (subData: SubData) => {
|
|
508
|
-
const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
509
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
|
|
510
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
511
|
-
|
|
512
|
-
return { controller, targetRatio };
|
|
513
|
-
},
|
|
514
|
-
};
|
|
515
|
-
|
|
516
|
-
export const crvUSDPaybackSubData = {
|
|
517
|
-
encode: (
|
|
518
|
-
controllerAddr: EthereumAddress,
|
|
519
|
-
addressToPullTokensFrom: EthereumAddress,
|
|
520
|
-
positionOwner: EthereumAddress,
|
|
521
|
-
paybackAmount: string,
|
|
522
|
-
crvUSDAddr: EthereumAddress,
|
|
523
|
-
) => {
|
|
524
|
-
const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
|
|
525
|
-
const addressToPullTokensFromEncoded = AbiCoder.encodeParameter('address', addressToPullTokensFrom);
|
|
526
|
-
const positionOwnerEncoded = AbiCoder.encodeParameter('address', positionOwner);
|
|
527
|
-
const paybackAmountEncoded = AbiCoder.encodeParameter('uint256', toWei(paybackAmount, 'ether'));
|
|
528
|
-
const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
|
|
529
|
-
return [
|
|
530
|
-
controllerAddrEncoded,
|
|
531
|
-
addressToPullTokensFromEncoded,
|
|
532
|
-
positionOwnerEncoded,
|
|
533
|
-
paybackAmountEncoded,
|
|
534
|
-
crvUSDAddrEncoded,
|
|
535
|
-
];
|
|
536
|
-
},
|
|
537
|
-
decode: (subData: SubData) => {
|
|
538
|
-
const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
539
|
-
const addressToPullTokensFrom = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
540
|
-
const positionOwner = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
541
|
-
const weiPaybackAmount = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
542
|
-
const paybackAmount = fromWei(weiPaybackAmount, 'ether');
|
|
543
|
-
return {
|
|
544
|
-
controller,
|
|
545
|
-
addressToPullTokensFrom,
|
|
546
|
-
positionOwner,
|
|
547
|
-
paybackAmount,
|
|
548
|
-
};
|
|
549
|
-
},
|
|
550
|
-
};
|
|
551
|
-
|
|
552
|
-
export const morphoBlueLeverageManagementSubData = {
|
|
553
|
-
encode: (
|
|
554
|
-
loanToken: EthereumAddress,
|
|
555
|
-
collToken: EthereumAddress,
|
|
556
|
-
oracle: EthereumAddress,
|
|
557
|
-
irm: EthereumAddress,
|
|
558
|
-
lltv: string,
|
|
559
|
-
ratioState: RatioState,
|
|
560
|
-
targetRatio: number,
|
|
561
|
-
user: EthereumAddress,
|
|
562
|
-
isEOA: boolean,
|
|
563
|
-
) => {
|
|
564
|
-
const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
|
|
565
|
-
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
566
|
-
const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
|
|
567
|
-
const irmEncoded = AbiCoder.encodeParameter('address', irm);
|
|
568
|
-
const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
|
|
569
|
-
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
570
|
-
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
571
|
-
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
572
|
-
const isEOAEncoded = AbiCoder.encodeParameter('bool', isEOA);
|
|
573
|
-
return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, ratioStateEncoded, targetRatioEncoded, userEncoded, isEOAEncoded];
|
|
574
|
-
},
|
|
575
|
-
decode: (subData: SubData) => {
|
|
576
|
-
const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
577
|
-
const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
578
|
-
const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
579
|
-
const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
580
|
-
const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
|
|
581
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[6]) as any as EthereumAddress;
|
|
582
|
-
const user = AbiCoder.decodeParameter('address', subData[7]) as any as EthereumAddress;
|
|
583
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
584
|
-
|
|
585
|
-
return {
|
|
586
|
-
loanToken,
|
|
587
|
-
collToken,
|
|
588
|
-
oracle,
|
|
589
|
-
irm,
|
|
590
|
-
lltv,
|
|
591
|
-
user,
|
|
592
|
-
targetRatio,
|
|
593
|
-
};
|
|
594
|
-
},
|
|
595
|
-
};
|
|
596
|
-
|
|
597
|
-
export const
|
|
598
|
-
encode(
|
|
599
|
-
collAsset: EthereumAddress,
|
|
600
|
-
collAssetId: number,
|
|
601
|
-
debtAsset: EthereumAddress,
|
|
602
|
-
debtAssetId: number,
|
|
603
|
-
marketAddr: EthereumAddress,
|
|
604
|
-
targetRatio: number,
|
|
605
|
-
): SubData {
|
|
606
|
-
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
607
|
-
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
608
|
-
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
609
|
-
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
610
|
-
const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
|
|
611
|
-
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
612
|
-
const useOnBehalfEncoded = AbiCoder.encodeParameter('bool', false);
|
|
613
|
-
|
|
614
|
-
return [
|
|
615
|
-
encodedColl,
|
|
616
|
-
encodedCollId,
|
|
617
|
-
encodedDebt,
|
|
618
|
-
encodedDebtId,
|
|
619
|
-
encodedMarket,
|
|
620
|
-
encodedTargetRatio,
|
|
621
|
-
useOnBehalfEncoded,
|
|
622
|
-
];
|
|
623
|
-
},
|
|
624
|
-
decode(subData: SubData): {
|
|
625
|
-
collAsset: EthereumAddress,
|
|
626
|
-
collAssetId: number,
|
|
627
|
-
debtAsset: EthereumAddress,
|
|
628
|
-
debtAssetId: number,
|
|
629
|
-
marketAddr: EthereumAddress,
|
|
630
|
-
targetRatio: number,
|
|
631
|
-
} {
|
|
632
|
-
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
633
|
-
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
634
|
-
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
635
|
-
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
636
|
-
const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
637
|
-
|
|
638
|
-
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
|
|
639
|
-
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
640
|
-
|
|
641
|
-
return {
|
|
642
|
-
collAsset, collAssetId, debtAsset, debtAssetId, marketAddr, targetRatio,
|
|
643
|
-
};
|
|
644
|
-
},
|
|
645
|
-
};
|
|
1
|
+
import Dec from 'decimal.js';
|
|
2
|
+
import AbiCoder from 'web3-eth-abi';
|
|
3
|
+
import { fromWei, toWei } from 'web3-utils';
|
|
4
|
+
|
|
5
|
+
import { assetAmountInEth, getAssetInfo, getAssetInfoByAddress } from '@defisaver/tokens';
|
|
6
|
+
import { otherAddresses } from '@defisaver/sdk';
|
|
7
|
+
|
|
8
|
+
import type { SubData, EthereumAddress } from '../types';
|
|
9
|
+
import type { OrderType } from '../types/enums';
|
|
10
|
+
import { ChainId, RatioState } from '../types/enums';
|
|
11
|
+
|
|
12
|
+
import { AAVE_V3_VARIABLE_BORROW_RATE, ZERO_ADDRESS } from '../constants';
|
|
13
|
+
|
|
14
|
+
import { compareAddresses, ratioPercentageToWei, weiToRatioPercentage } from './utils';
|
|
15
|
+
|
|
16
|
+
export const makerRepayFromSavingsSubData = {
|
|
17
|
+
encode(
|
|
18
|
+
vaultId: number,
|
|
19
|
+
targetRatioPercentage: number,
|
|
20
|
+
chainId: ChainId,
|
|
21
|
+
daiAddr?: EthereumAddress,
|
|
22
|
+
mcdCdpManagerAddr?: EthereumAddress,
|
|
23
|
+
): SubData {
|
|
24
|
+
const _daiAddr = daiAddr || getAssetInfo('DAI', chainId).address;
|
|
25
|
+
// @ts-ignore // TODO - this requires change in @defisaver/tokens
|
|
26
|
+
const _mcdCdpManagerAddr = mcdCdpManagerAddr || otherAddresses(chainId).McdCdpManager;
|
|
27
|
+
|
|
28
|
+
const vaultIdEncoded = AbiCoder.encodeParameter('uint256', vaultId.toString());
|
|
29
|
+
const targetRatioWei = ratioPercentageToWei(targetRatioPercentage);
|
|
30
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', targetRatioWei);
|
|
31
|
+
const daiAddrEncoded = AbiCoder.encodeParameter('address', _daiAddr);
|
|
32
|
+
const mcdManagerAddrEncoded = AbiCoder.encodeParameter('address', _mcdCdpManagerAddr);
|
|
33
|
+
|
|
34
|
+
return [vaultIdEncoded, targetRatioEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
35
|
+
},
|
|
36
|
+
decode(subData: SubData): { vaultId: number, daiAddr: string, mcdManagerAddr: string, targetRatio: number } {
|
|
37
|
+
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
38
|
+
|
|
39
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
40
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
41
|
+
|
|
42
|
+
const daiAddr = AbiCoder.decodeParameter('address', subData[2])!.toString();
|
|
43
|
+
const mcdManagerAddr = AbiCoder.decodeParameter('address', subData[3])!.toString();
|
|
44
|
+
|
|
45
|
+
return {
|
|
46
|
+
vaultId, targetRatio, daiAddr, mcdManagerAddr,
|
|
47
|
+
};
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
export const liquityRepayFromSavingsSubData = {
|
|
52
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
53
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
54
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
55
|
+
|
|
56
|
+
return { targetRatio };
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
export const makerCloseSubData = {
|
|
61
|
+
encode(
|
|
62
|
+
vaultId: number,
|
|
63
|
+
closeToAssetAddr: EthereumAddress,
|
|
64
|
+
chainId: ChainId,
|
|
65
|
+
daiAddr?: EthereumAddress,
|
|
66
|
+
mcdCdpManagerAddr?: EthereumAddress,
|
|
67
|
+
): SubData {
|
|
68
|
+
const _daiAddr = daiAddr || getAssetInfo('DAI', chainId).address;
|
|
69
|
+
// @ts-ignore // TODO - this requires change in @defisaver/tokens
|
|
70
|
+
const _mcdCdpManagerAddr = mcdCdpManagerAddr || otherAddresses(chainId).McdCdpManager;
|
|
71
|
+
|
|
72
|
+
const vaultIdEncoded = AbiCoder.encodeParameter('uint256', vaultId.toString());
|
|
73
|
+
const daiAddrEncoded = AbiCoder.encodeParameter('address', _daiAddr);
|
|
74
|
+
const mcdManagerAddrEncoded = AbiCoder.encodeParameter('address', _mcdCdpManagerAddr);
|
|
75
|
+
|
|
76
|
+
if (compareAddresses(closeToAssetAddr, _daiAddr)) {
|
|
77
|
+
// Close to DAI strategy
|
|
78
|
+
return [vaultIdEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
79
|
+
}
|
|
80
|
+
// Close to collateral strategy
|
|
81
|
+
const collAddrEncoded = AbiCoder.encodeParameter('address', closeToAssetAddr);
|
|
82
|
+
return [vaultIdEncoded, collAddrEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
83
|
+
},
|
|
84
|
+
decode(subData: SubData): { vaultId: number, closeToAssetAddr: EthereumAddress } {
|
|
85
|
+
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!;
|
|
86
|
+
// if closing to collateral, asset addr will be 2nd param out of 4
|
|
87
|
+
// if closing to DAI, will return 2nd param out of 3, which will be DAI addr
|
|
88
|
+
const closeToAssetAddr = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
89
|
+
|
|
90
|
+
return {
|
|
91
|
+
vaultId, closeToAssetAddr,
|
|
92
|
+
};
|
|
93
|
+
},
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
export const makerLeverageManagementSubData = {
|
|
97
|
+
decode: (subData:SubData) => {
|
|
98
|
+
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
99
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
100
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
101
|
+
return { vaultId, targetRatio };
|
|
102
|
+
},
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
export const liquityLeverageManagementSubData = {
|
|
106
|
+
decode: (subData:SubData) => {
|
|
107
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
108
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
109
|
+
return { targetRatio };
|
|
110
|
+
},
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
export const liquityCloseSubData = {
|
|
114
|
+
encode(
|
|
115
|
+
closeToAssetAddr: EthereumAddress,
|
|
116
|
+
chainId: ChainId = ChainId.Ethereum,
|
|
117
|
+
collAddr?: EthereumAddress,
|
|
118
|
+
debtAddr?: EthereumAddress,
|
|
119
|
+
): SubData {
|
|
120
|
+
const _collAddr = collAddr || getAssetInfo('WETH', chainId).address;
|
|
121
|
+
const _debtAddr = debtAddr || getAssetInfo('LUSD', chainId).address;
|
|
122
|
+
|
|
123
|
+
const collAddrEncoded = AbiCoder.encodeParameter('address', _collAddr);
|
|
124
|
+
const debtAddrEncoded = AbiCoder.encodeParameter('address', _debtAddr);
|
|
125
|
+
// if (compareAddresses(closeToAssetAddr, _debtAddr)) { // Closing to debt strategy was not implemented, but it should be in the future
|
|
126
|
+
// // close to LUSD strategy
|
|
127
|
+
// return [debtAddrEncoded, collAddrEncoded];
|
|
128
|
+
// }
|
|
129
|
+
// close to collateral strategy
|
|
130
|
+
return [collAddrEncoded, debtAddrEncoded];
|
|
131
|
+
},
|
|
132
|
+
decode(subData: SubData): { closeToAssetAddr: EthereumAddress, debtAddr: string } {
|
|
133
|
+
const closeToAssetAddr = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
134
|
+
const debtAddr = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
135
|
+
|
|
136
|
+
return { closeToAssetAddr, debtAddr };
|
|
137
|
+
},
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
export const aaveV2LeverageManagementSubData = {
|
|
141
|
+
encode(
|
|
142
|
+
triggerRepayRatio: number,
|
|
143
|
+
triggerBoostRatio: number,
|
|
144
|
+
targetBoostRatio: number,
|
|
145
|
+
targetRepayRatio: number,
|
|
146
|
+
boostEnabled: boolean,
|
|
147
|
+
): SubData {
|
|
148
|
+
return [
|
|
149
|
+
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
150
|
+
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
151
|
+
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
152
|
+
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
153
|
+
// @ts-ignore // TODO
|
|
154
|
+
boostEnabled,
|
|
155
|
+
];
|
|
156
|
+
},
|
|
157
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
158
|
+
const ratioWei = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
159
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
160
|
+
|
|
161
|
+
return { targetRatio };
|
|
162
|
+
},
|
|
163
|
+
};
|
|
164
|
+
|
|
165
|
+
export const aaveV3LeverageManagementSubData = { // TODO encode?
|
|
166
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
167
|
+
const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
168
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
169
|
+
|
|
170
|
+
return { targetRatio };
|
|
171
|
+
},
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
export const aaveV3QuotePriceSubData = {
|
|
175
|
+
encode(
|
|
176
|
+
collAsset: EthereumAddress,
|
|
177
|
+
collAssetId: number,
|
|
178
|
+
debtAsset: EthereumAddress,
|
|
179
|
+
debtAssetId: number,
|
|
180
|
+
nullAddress: EthereumAddress = ZERO_ADDRESS,
|
|
181
|
+
): SubData {
|
|
182
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
183
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
184
|
+
|
|
185
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
186
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
187
|
+
|
|
188
|
+
const encodedNullAddress = AbiCoder.encodeParameter('address', nullAddress);
|
|
189
|
+
|
|
190
|
+
return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedNullAddress];
|
|
191
|
+
},
|
|
192
|
+
decode(subData: SubData): { collAsset: EthereumAddress, collAssetId: number, debtAsset: EthereumAddress, debtAssetId: number } {
|
|
193
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
194
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
195
|
+
|
|
196
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
197
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
198
|
+
|
|
199
|
+
return {
|
|
200
|
+
collAsset, collAssetId, debtAsset, debtAssetId,
|
|
201
|
+
};
|
|
202
|
+
},
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
export const compoundV2LeverageManagementSubData = {
|
|
206
|
+
encode(
|
|
207
|
+
triggerRepayRatio: number,
|
|
208
|
+
triggerBoostRatio: number,
|
|
209
|
+
targetBoostRatio: number,
|
|
210
|
+
targetRepayRatio: number,
|
|
211
|
+
boostEnabled: boolean,
|
|
212
|
+
): SubData {
|
|
213
|
+
return [
|
|
214
|
+
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
215
|
+
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
216
|
+
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
217
|
+
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
218
|
+
// @ts-ignore // TODO
|
|
219
|
+
boostEnabled,
|
|
220
|
+
];
|
|
221
|
+
},
|
|
222
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
223
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
224
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
225
|
+
|
|
226
|
+
return { targetRatio };
|
|
227
|
+
},
|
|
228
|
+
};
|
|
229
|
+
|
|
230
|
+
export const compoundV3LeverageManagementSubData = {
|
|
231
|
+
encode(
|
|
232
|
+
market: EthereumAddress,
|
|
233
|
+
baseToken: EthereumAddress,
|
|
234
|
+
triggerRepayRatio: number,
|
|
235
|
+
triggerBoostRatio: number,
|
|
236
|
+
targetBoostRatio: number,
|
|
237
|
+
targetRepayRatio: number,
|
|
238
|
+
boostEnabled: boolean,
|
|
239
|
+
isEOA: boolean,
|
|
240
|
+
): SubData {
|
|
241
|
+
return [
|
|
242
|
+
market,
|
|
243
|
+
baseToken,
|
|
244
|
+
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
245
|
+
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
246
|
+
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
247
|
+
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
248
|
+
// @ts-ignore // TODO
|
|
249
|
+
boostEnabled, isEOA,
|
|
250
|
+
];
|
|
251
|
+
},
|
|
252
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
253
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
254
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
255
|
+
|
|
256
|
+
return { targetRatio };
|
|
257
|
+
},
|
|
258
|
+
};
|
|
259
|
+
|
|
260
|
+
export const compoundV3L2LeverageManagementSubData = {
|
|
261
|
+
encode(
|
|
262
|
+
market: EthereumAddress,
|
|
263
|
+
baseToken: EthereumAddress,
|
|
264
|
+
triggerRepayRatio: number,
|
|
265
|
+
triggerBoostRatio: number,
|
|
266
|
+
targetBoostRatio: number,
|
|
267
|
+
targetRepayRatio: number,
|
|
268
|
+
boostEnabled: boolean,
|
|
269
|
+
): string {
|
|
270
|
+
let subInput = '0x';
|
|
271
|
+
|
|
272
|
+
subInput = subInput.concat(market.slice(2));
|
|
273
|
+
subInput = subInput.concat(baseToken.slice(2));
|
|
274
|
+
subInput = subInput.concat(new Dec(triggerRepayRatio).mul(1e16).toHex().slice(2)
|
|
275
|
+
.padStart(32, '0'));
|
|
276
|
+
subInput = subInput.concat(new Dec(triggerBoostRatio).mul(1e16).toHex().slice(2)
|
|
277
|
+
.padStart(32, '0'));
|
|
278
|
+
subInput = subInput.concat(new Dec(targetBoostRatio).mul(1e16).toHex().slice(2)
|
|
279
|
+
.padStart(32, '0'));
|
|
280
|
+
subInput = subInput.concat(new Dec(targetRepayRatio).mul(1e16).toHex().slice(2)
|
|
281
|
+
.padStart(32, '0'));
|
|
282
|
+
subInput = subInput.concat(boostEnabled ? '01' : '00');
|
|
283
|
+
|
|
284
|
+
return subInput;
|
|
285
|
+
},
|
|
286
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
287
|
+
const ratioWei = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
288
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
289
|
+
|
|
290
|
+
return { targetRatio };
|
|
291
|
+
},
|
|
292
|
+
};
|
|
293
|
+
|
|
294
|
+
export const morphoAaveV2LeverageManagementSubData = {
|
|
295
|
+
encode(
|
|
296
|
+
triggerRepayRatio: number,
|
|
297
|
+
triggerBoostRatio: number,
|
|
298
|
+
targetBoostRatio: number,
|
|
299
|
+
targetRepayRatio: number,
|
|
300
|
+
boostEnabled: boolean,
|
|
301
|
+
): SubData {
|
|
302
|
+
return [
|
|
303
|
+
ratioPercentageToWei(triggerRepayRatio),
|
|
304
|
+
ratioPercentageToWei(triggerBoostRatio),
|
|
305
|
+
ratioPercentageToWei(targetBoostRatio),
|
|
306
|
+
ratioPercentageToWei(targetRepayRatio),
|
|
307
|
+
// @ts-ignore
|
|
308
|
+
boostEnabled,
|
|
309
|
+
];
|
|
310
|
+
},
|
|
311
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
312
|
+
const ratioWei = AbiCoder.decodeParameter('uint128', subData[1]) as any as string;
|
|
313
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
314
|
+
|
|
315
|
+
return { targetRatio };
|
|
316
|
+
},
|
|
317
|
+
};
|
|
318
|
+
|
|
319
|
+
export const cBondsRebondSubData = {
|
|
320
|
+
encode(bondId: number | string): SubData {
|
|
321
|
+
const bondIdEncoded = AbiCoder.encodeParameter('uint256', bondId);
|
|
322
|
+
return [bondIdEncoded];
|
|
323
|
+
},
|
|
324
|
+
decode(subData: SubData): { bondId: string } {
|
|
325
|
+
const bondId = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
|
|
326
|
+
return { bondId };
|
|
327
|
+
},
|
|
328
|
+
};
|
|
329
|
+
|
|
330
|
+
export const liquityPaybackUsingChickenBondSubData = {
|
|
331
|
+
/**
|
|
332
|
+
* @param sourceId bondId or subId
|
|
333
|
+
* @param sourceType 0 for bond, 1 for subId
|
|
334
|
+
* @param chainId
|
|
335
|
+
*/
|
|
336
|
+
encode: (sourceId: string, sourceType: number, chainId: ChainId = ChainId.Ethereum): SubData => {
|
|
337
|
+
const sourceIdEncoded = AbiCoder.encodeParameter('uint256', sourceId);
|
|
338
|
+
const sourceTypeEncoded = AbiCoder.encodeParameter('uint256', sourceType);
|
|
339
|
+
const lusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('LUSD', chainId).address);
|
|
340
|
+
const bLusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('bLUSD', chainId).address);
|
|
341
|
+
|
|
342
|
+
return [sourceIdEncoded, sourceTypeEncoded, lusdAddressEncoded, bLusdAddressEncoded];
|
|
343
|
+
},
|
|
344
|
+
decode: (subData: SubData) => {
|
|
345
|
+
const sourceId = AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
346
|
+
const sourceType = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
|
|
347
|
+
|
|
348
|
+
return { sourceId, sourceType };
|
|
349
|
+
},
|
|
350
|
+
};
|
|
351
|
+
|
|
352
|
+
export const exchangeDcaSubData = {
|
|
353
|
+
encode: (fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, interval: number) : SubData => {
|
|
354
|
+
const sellTokenEncoded = AbiCoder.encodeParameter('address', fromToken);
|
|
355
|
+
const buyTokenEncoded = AbiCoder.encodeParameter('address', toToken);
|
|
356
|
+
const amountEncoded = AbiCoder.encodeParameter('uint256', amount);
|
|
357
|
+
const intervalEncoded = AbiCoder.encodeParameter('uint256', interval);
|
|
358
|
+
|
|
359
|
+
return [sellTokenEncoded, buyTokenEncoded, amountEncoded, intervalEncoded];
|
|
360
|
+
},
|
|
361
|
+
decode: (subData: SubData, chainId: ChainId) => {
|
|
362
|
+
const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
363
|
+
const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
364
|
+
const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
|
|
365
|
+
const interval = AbiCoder.decodeParameter('uint256', subData[3])!.toString();
|
|
366
|
+
return {
|
|
367
|
+
fromToken,
|
|
368
|
+
toToken,
|
|
369
|
+
amount,
|
|
370
|
+
interval,
|
|
371
|
+
};
|
|
372
|
+
},
|
|
373
|
+
};
|
|
374
|
+
|
|
375
|
+
export const exchangeLimitOrderSubData = {
|
|
376
|
+
encode(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, targetPrice: string, goodUntil: string | number, orderType: OrderType) : SubData {
|
|
377
|
+
return [
|
|
378
|
+
fromToken,
|
|
379
|
+
toToken,
|
|
380
|
+
amount,
|
|
381
|
+
targetPrice,
|
|
382
|
+
new Dec(goodUntil).toString(),
|
|
383
|
+
new Dec(orderType).toString(),
|
|
384
|
+
];
|
|
385
|
+
},
|
|
386
|
+
decode: (subData: SubData, chainId: ChainId) => {
|
|
387
|
+
const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
388
|
+
const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
389
|
+
const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
|
|
390
|
+
return { fromToken, toToken, amount };
|
|
391
|
+
},
|
|
392
|
+
};
|
|
393
|
+
|
|
394
|
+
export const sparkLeverageManagementSubData = { // TODO encode?
|
|
395
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
396
|
+
const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
397
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
398
|
+
|
|
399
|
+
return { targetRatio };
|
|
400
|
+
},
|
|
401
|
+
};
|
|
402
|
+
|
|
403
|
+
export const sparkQuotePriceSubData = {
|
|
404
|
+
encode(
|
|
405
|
+
collAsset: EthereumAddress,
|
|
406
|
+
collAssetId: number,
|
|
407
|
+
debtAsset: EthereumAddress,
|
|
408
|
+
debtAssetId: number,
|
|
409
|
+
nullAddress: EthereumAddress = ZERO_ADDRESS,
|
|
410
|
+
): SubData {
|
|
411
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
412
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
413
|
+
|
|
414
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
415
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
416
|
+
|
|
417
|
+
const encodedNullAddress = AbiCoder.encodeParameter('address', nullAddress);
|
|
418
|
+
|
|
419
|
+
return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedNullAddress];
|
|
420
|
+
},
|
|
421
|
+
decode(subData: SubData): { collAsset: EthereumAddress, collAssetId: number, debtAsset: EthereumAddress, debtAssetId: number } {
|
|
422
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
423
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
424
|
+
|
|
425
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
426
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
427
|
+
|
|
428
|
+
return {
|
|
429
|
+
collAsset, collAssetId, debtAsset, debtAssetId,
|
|
430
|
+
};
|
|
431
|
+
},
|
|
432
|
+
};
|
|
433
|
+
|
|
434
|
+
export const liquityDsrPaybackSubData = {
|
|
435
|
+
encode: (targetRatio: number) => {
|
|
436
|
+
const daiAddress = getAssetInfo('DAI').address;
|
|
437
|
+
const lusdAddress = getAssetInfo('LUSD').address;
|
|
438
|
+
|
|
439
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
|
|
440
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
441
|
+
const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
|
|
442
|
+
const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
|
|
443
|
+
|
|
444
|
+
return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, lusdAddressEncoded];
|
|
445
|
+
},
|
|
446
|
+
decode: (subData: SubData) => {
|
|
447
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
448
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
449
|
+
return { targetRatio };
|
|
450
|
+
},
|
|
451
|
+
};
|
|
452
|
+
|
|
453
|
+
export const liquityDsrSupplySubData = {
|
|
454
|
+
encode: (targetRatio: number) => {
|
|
455
|
+
const daiAddress = getAssetInfo('DAI').address;
|
|
456
|
+
const wethAddress = getAssetInfo('WETH').address;
|
|
457
|
+
|
|
458
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
|
|
459
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
460
|
+
const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
|
|
461
|
+
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
462
|
+
|
|
463
|
+
return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, wethAddressEncoded];
|
|
464
|
+
},
|
|
465
|
+
decode: (subData: SubData) => {
|
|
466
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
467
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
468
|
+
return { targetRatio };
|
|
469
|
+
},
|
|
470
|
+
};
|
|
471
|
+
|
|
472
|
+
export const liquityDebtInFrontRepaySubData = {
|
|
473
|
+
encode: (targetRatioIncrease: number) => {
|
|
474
|
+
const wethAddress = getAssetInfo('WETH').address;
|
|
475
|
+
const lusdAddress = getAssetInfo('LUSD').address;
|
|
476
|
+
|
|
477
|
+
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
478
|
+
const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
|
|
479
|
+
const targetRatioIncreaseEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatioIncrease));
|
|
480
|
+
const withdrawIdEncoded = AbiCoder.encodeParameter('uint8', 1); // withdraw - 1
|
|
481
|
+
const paybackIdEncoded = AbiCoder.encodeParameter('uint8', 0); // payback - 0
|
|
482
|
+
|
|
483
|
+
return [wethAddressEncoded, lusdAddressEncoded, targetRatioIncreaseEncoded, withdrawIdEncoded, paybackIdEncoded];
|
|
484
|
+
},
|
|
485
|
+
decode: (subData: SubData) => {
|
|
486
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
|
|
487
|
+
const targetRatioIncrease = weiToRatioPercentage(weiRatio);
|
|
488
|
+
return { targetRatioIncrease };
|
|
489
|
+
},
|
|
490
|
+
};
|
|
491
|
+
|
|
492
|
+
export const crvUSDLeverageManagementSubData = {
|
|
493
|
+
encode: (
|
|
494
|
+
controllerAddr: EthereumAddress,
|
|
495
|
+
ratioState: RatioState,
|
|
496
|
+
targetRatio: number,
|
|
497
|
+
collTokenAddr: EthereumAddress,
|
|
498
|
+
crvUSDAddr: EthereumAddress,
|
|
499
|
+
) => {
|
|
500
|
+
const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
|
|
501
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
502
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
503
|
+
const collTokenAddrEncoded = AbiCoder.encodeParameter('address', collTokenAddr);
|
|
504
|
+
const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
|
|
505
|
+
return [controllerAddrEncoded, ratioStateEncoded, targetRatioEncoded, collTokenAddrEncoded, crvUSDAddrEncoded];
|
|
506
|
+
},
|
|
507
|
+
decode: (subData: SubData) => {
|
|
508
|
+
const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
509
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
|
|
510
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
511
|
+
|
|
512
|
+
return { controller, targetRatio };
|
|
513
|
+
},
|
|
514
|
+
};
|
|
515
|
+
|
|
516
|
+
export const crvUSDPaybackSubData = {
|
|
517
|
+
encode: (
|
|
518
|
+
controllerAddr: EthereumAddress,
|
|
519
|
+
addressToPullTokensFrom: EthereumAddress,
|
|
520
|
+
positionOwner: EthereumAddress,
|
|
521
|
+
paybackAmount: string,
|
|
522
|
+
crvUSDAddr: EthereumAddress,
|
|
523
|
+
) => {
|
|
524
|
+
const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
|
|
525
|
+
const addressToPullTokensFromEncoded = AbiCoder.encodeParameter('address', addressToPullTokensFrom);
|
|
526
|
+
const positionOwnerEncoded = AbiCoder.encodeParameter('address', positionOwner);
|
|
527
|
+
const paybackAmountEncoded = AbiCoder.encodeParameter('uint256', toWei(paybackAmount, 'ether'));
|
|
528
|
+
const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
|
|
529
|
+
return [
|
|
530
|
+
controllerAddrEncoded,
|
|
531
|
+
addressToPullTokensFromEncoded,
|
|
532
|
+
positionOwnerEncoded,
|
|
533
|
+
paybackAmountEncoded,
|
|
534
|
+
crvUSDAddrEncoded,
|
|
535
|
+
];
|
|
536
|
+
},
|
|
537
|
+
decode: (subData: SubData) => {
|
|
538
|
+
const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
539
|
+
const addressToPullTokensFrom = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
540
|
+
const positionOwner = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
541
|
+
const weiPaybackAmount = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
542
|
+
const paybackAmount = fromWei(weiPaybackAmount, 'ether');
|
|
543
|
+
return {
|
|
544
|
+
controller,
|
|
545
|
+
addressToPullTokensFrom,
|
|
546
|
+
positionOwner,
|
|
547
|
+
paybackAmount,
|
|
548
|
+
};
|
|
549
|
+
},
|
|
550
|
+
};
|
|
551
|
+
|
|
552
|
+
export const morphoBlueLeverageManagementSubData = {
|
|
553
|
+
encode: (
|
|
554
|
+
loanToken: EthereumAddress,
|
|
555
|
+
collToken: EthereumAddress,
|
|
556
|
+
oracle: EthereumAddress,
|
|
557
|
+
irm: EthereumAddress,
|
|
558
|
+
lltv: string,
|
|
559
|
+
ratioState: RatioState,
|
|
560
|
+
targetRatio: number,
|
|
561
|
+
user: EthereumAddress,
|
|
562
|
+
isEOA: boolean,
|
|
563
|
+
) => {
|
|
564
|
+
const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
|
|
565
|
+
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
566
|
+
const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
|
|
567
|
+
const irmEncoded = AbiCoder.encodeParameter('address', irm);
|
|
568
|
+
const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
|
|
569
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
570
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
571
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
572
|
+
const isEOAEncoded = AbiCoder.encodeParameter('bool', isEOA);
|
|
573
|
+
return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, ratioStateEncoded, targetRatioEncoded, userEncoded, isEOAEncoded];
|
|
574
|
+
},
|
|
575
|
+
decode: (subData: SubData) => {
|
|
576
|
+
const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
577
|
+
const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
578
|
+
const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
579
|
+
const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
580
|
+
const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
|
|
581
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[6]) as any as EthereumAddress;
|
|
582
|
+
const user = AbiCoder.decodeParameter('address', subData[7]) as any as EthereumAddress;
|
|
583
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
584
|
+
|
|
585
|
+
return {
|
|
586
|
+
loanToken,
|
|
587
|
+
collToken,
|
|
588
|
+
oracle,
|
|
589
|
+
irm,
|
|
590
|
+
lltv,
|
|
591
|
+
user,
|
|
592
|
+
targetRatio,
|
|
593
|
+
};
|
|
594
|
+
},
|
|
595
|
+
};
|
|
596
|
+
|
|
597
|
+
export const aaveV3LeverageManagementOnPriceSubData = {
|
|
598
|
+
encode(
|
|
599
|
+
collAsset: EthereumAddress,
|
|
600
|
+
collAssetId: number,
|
|
601
|
+
debtAsset: EthereumAddress,
|
|
602
|
+
debtAssetId: number,
|
|
603
|
+
marketAddr: EthereumAddress,
|
|
604
|
+
targetRatio: number,
|
|
605
|
+
): SubData {
|
|
606
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
607
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
608
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
609
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
610
|
+
const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
|
|
611
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
612
|
+
const useOnBehalfEncoded = AbiCoder.encodeParameter('bool', false);
|
|
613
|
+
|
|
614
|
+
return [
|
|
615
|
+
encodedColl,
|
|
616
|
+
encodedCollId,
|
|
617
|
+
encodedDebt,
|
|
618
|
+
encodedDebtId,
|
|
619
|
+
encodedMarket,
|
|
620
|
+
encodedTargetRatio,
|
|
621
|
+
useOnBehalfEncoded,
|
|
622
|
+
];
|
|
623
|
+
},
|
|
624
|
+
decode(subData: SubData): {
|
|
625
|
+
collAsset: EthereumAddress,
|
|
626
|
+
collAssetId: number,
|
|
627
|
+
debtAsset: EthereumAddress,
|
|
628
|
+
debtAssetId: number,
|
|
629
|
+
marketAddr: EthereumAddress,
|
|
630
|
+
targetRatio: number,
|
|
631
|
+
} {
|
|
632
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
633
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
634
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
635
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
636
|
+
const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
637
|
+
|
|
638
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
|
|
639
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
640
|
+
|
|
641
|
+
return {
|
|
642
|
+
collAsset, collAssetId, debtAsset, debtAssetId, marketAddr, targetRatio,
|
|
643
|
+
};
|
|
644
|
+
},
|
|
645
|
+
};
|