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