@defisaver/automation-sdk 3.1.2 → 3.1.3
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 +181 -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/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 +489 -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 +723 -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 +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 +184 -184
- package/cjs/types/enums.js +206 -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 +175 -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/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 +483 -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 +696 -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 +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 +184 -184
- package/esm/types/enums.js +203 -203
- package/esm/types/index.d.ts +224 -224
- package/esm/types/index.js +1 -1
- package/package.json +61 -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 +242 -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/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 +507 -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 +934 -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 +644 -644
- 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 +200 -200
- package/src/types/index.ts +279 -279
- package/tsconfig.esm.json +8 -8
- package/tsconfig.json +22 -22
- package/umd/index.js +34103 -0
|
@@ -1,469 +1,469 @@
|
|
|
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, 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 aaveV3OpenOrderSubData = {
|
|
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
|
-
};
|
|
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, 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 aaveV3OpenOrderSubData = {
|
|
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
|
+
};
|