@defisaver/automation-sdk 3.1.9 → 3.1.14-spark-dev
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.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 +35 -33
- package/cjs/automation/private/StrategiesAutomation.js +198 -181
- package/cjs/automation/private/StrategiesAutomation.test.d.ts +1 -1
- package/cjs/automation/private/StrategiesAutomation.test.js +696 -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 +29 -28
- package/cjs/constants/index.js +905 -534
- package/cjs/index.d.ts +24 -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 +56 -49
- package/cjs/services/ethereumService.test.d.ts +1 -1
- package/cjs/services/ethereumService.test.js +245 -242
- package/cjs/services/strategiesService.d.ts +2 -2
- package/cjs/services/strategiesService.js +1173 -861
- package/cjs/services/strategiesService.test.d.ts +1 -1
- package/cjs/services/strategiesService.test.js +111 -110
- package/cjs/services/strategySubService.d.ts +129 -107
- package/cjs/services/strategySubService.js +414 -300
- package/cjs/services/strategySubService.test.d.ts +1 -1
- package/cjs/services/strategySubService.test.js +1812 -936
- package/cjs/services/subDataService.d.ts +527 -245
- package/cjs/services/subDataService.js +1219 -636
- package/cjs/services/subDataService.test.d.ts +1 -1
- package/cjs/services/subDataService.test.js +2427 -1282
- package/cjs/services/triggerService.d.ts +325 -226
- package/cjs/services/triggerService.js +616 -433
- package/cjs/services/triggerService.test.d.ts +1 -1
- package/cjs/services/triggerService.test.js +1317 -926
- package/cjs/services/utils.d.ts +30 -30
- package/cjs/services/utils.js +190 -182
- package/cjs/services/utils.test.d.ts +1 -1
- package/cjs/services/utils.test.js +299 -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 +302 -219
- package/cjs/types/enums.js +328 -245
- package/cjs/types/index.d.ts +306 -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 +35 -33
- package/esm/automation/private/StrategiesAutomation.js +192 -175
- package/esm/automation/private/StrategiesAutomation.test.d.ts +1 -1
- package/esm/automation/private/StrategiesAutomation.test.js +691 -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 +29 -28
- package/esm/constants/index.js +899 -528
- package/esm/index.d.ts +24 -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 +48 -41
- package/esm/services/ethereumService.test.d.ts +1 -1
- package/esm/services/ethereumService.test.js +240 -237
- package/esm/services/strategiesService.d.ts +2 -2
- package/esm/services/strategiesService.js +1143 -831
- package/esm/services/strategiesService.test.d.ts +1 -1
- package/esm/services/strategiesService.test.js +109 -108
- package/esm/services/strategySubService.d.ts +129 -107
- package/esm/services/strategySubService.js +385 -271
- package/esm/services/strategySubService.test.d.ts +1 -1
- package/esm/services/strategySubService.test.js +1784 -908
- package/esm/services/subDataService.d.ts +527 -245
- package/esm/services/subDataService.js +1213 -630
- package/esm/services/subDataService.test.d.ts +1 -1
- package/esm/services/subDataService.test.js +2399 -1254
- package/esm/services/triggerService.d.ts +325 -226
- package/esm/services/triggerService.js +587 -404
- package/esm/services/triggerService.test.d.ts +1 -1
- package/esm/services/triggerService.test.js +1292 -901
- package/esm/services/utils.d.ts +30 -30
- package/esm/services/utils.js +139 -131
- package/esm/services/utils.test.d.ts +1 -1
- package/esm/services/utils.test.js +297 -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 +302 -219
- package/esm/types/enums.js +325 -242
- package/esm/types/index.d.ts +306 -248
- package/esm/types/index.js +1 -1
- package/package.json +60 -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 +703 -663
- package/src/automation/private/StrategiesAutomation.ts +265 -242
- package/src/automation/public/ArbitrumStrategies.ts +10 -10
- package/src/automation/public/BaseStrategies.ts +10 -10
- package/src/automation/public/EthereumStrategies.ts +10 -10
- package/src/automation/public/OptimismStrategies.ts +10 -10
- package/src/automation/public/Strategies.test.ts +49 -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 +935 -563
- package/src/index.ts +41 -39
- package/src/services/contractService.ts +77 -77
- package/src/services/ethereumService.test.ts +260 -257
- package/src/services/ethereumService.ts +76 -69
- package/src/services/strategiesService.test.ts +106 -105
- package/src/services/strategiesService.ts +1473 -1111
- package/src/services/strategySubService.test.ts +2136 -1122
- package/src/services/strategySubService.ts +987 -617
- package/src/services/subDataService.test.ts +2630 -1387
- package/src/services/subDataService.ts +1631 -870
- package/src/services/triggerService.test.ts +1434 -1004
- package/src/services/triggerService.ts +819 -553
- package/src/services/utils.test.ts +371 -430
- package/src/services/utils.ts +173 -162
- package/src/types/enums.ts +322 -239
- package/src/types/index.ts +385 -312
- package/tsconfig.esm.json +8 -8
- package/tsconfig.json +22 -22
- package/umd/index.js +0 -34103
|
@@ -1,870 +1,1631 @@
|
|
|
1
|
-
import Dec from 'decimal.js';
|
|
2
|
-
import AbiCoder from 'web3-eth-abi';
|
|
3
|
-
import { fromWei, toWei } from 'web3-utils';
|
|
4
|
-
|
|
5
|
-
import { assetAmountInEth, getAssetInfo, getAssetInfoByAddress } from '@defisaver/tokens';
|
|
6
|
-
import { otherAddresses } from '@defisaver/sdk';
|
|
7
|
-
|
|
8
|
-
import type { SubData, EthereumAddress } from '../types';
|
|
9
|
-
import type { CloseStrategyType, OrderType } from '../types/enums';
|
|
10
|
-
import {
|
|
11
|
-
ChainId, CollActionType, DebtActionType, RatioState,
|
|
12
|
-
} from '../types/enums';
|
|
13
|
-
|
|
14
|
-
import {
|
|
15
|
-
|
|
16
|
-
import { compareAddresses, ratioPercentageToWei, weiToRatioPercentage } from './utils';
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
const
|
|
45
|
-
const
|
|
46
|
-
|
|
47
|
-
return {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
const
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
const
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
const
|
|
76
|
-
const
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
const
|
|
101
|
-
|
|
102
|
-
const
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
const
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
const
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
export const
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
const
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
const
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
const
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
const
|
|
340
|
-
const
|
|
341
|
-
const
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
const
|
|
357
|
-
const
|
|
358
|
-
const
|
|
359
|
-
const
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
const
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
}
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
];
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
},
|
|
394
|
-
};
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
const
|
|
414
|
-
const
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
const
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
const
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
},
|
|
467
|
-
decode: (subData: SubData) => {
|
|
468
|
-
const
|
|
469
|
-
const
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
const
|
|
568
|
-
const
|
|
569
|
-
const
|
|
570
|
-
const
|
|
571
|
-
const
|
|
572
|
-
const
|
|
573
|
-
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
574
|
-
|
|
575
|
-
return [
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
const
|
|
659
|
-
const
|
|
660
|
-
const
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
|
|
675
|
-
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
const
|
|
707
|
-
const
|
|
708
|
-
const
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
}
|
|
733
|
-
|
|
734
|
-
const
|
|
735
|
-
const
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
const
|
|
739
|
-
|
|
740
|
-
return {
|
|
741
|
-
|
|
742
|
-
};
|
|
743
|
-
},
|
|
744
|
-
};
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
targetRatio: number,
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
const
|
|
756
|
-
const
|
|
757
|
-
const
|
|
758
|
-
const
|
|
759
|
-
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
const
|
|
785
|
-
|
|
786
|
-
const
|
|
787
|
-
const
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
|
|
797
|
-
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
const
|
|
811
|
-
const
|
|
812
|
-
const
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
|
|
830
|
-
|
|
831
|
-
|
|
832
|
-
|
|
833
|
-
|
|
834
|
-
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
ratioState: RatioState,
|
|
843
|
-
|
|
844
|
-
|
|
845
|
-
const
|
|
846
|
-
const
|
|
847
|
-
const
|
|
848
|
-
const
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
862
|
-
|
|
863
|
-
|
|
864
|
-
|
|
865
|
-
|
|
866
|
-
|
|
867
|
-
|
|
868
|
-
|
|
869
|
-
|
|
870
|
-
|
|
1
|
+
import Dec from 'decimal.js';
|
|
2
|
+
import AbiCoder from 'web3-eth-abi';
|
|
3
|
+
import { fromWei, toWei } from 'web3-utils';
|
|
4
|
+
|
|
5
|
+
import { assetAmountInEth, getAssetInfo, getAssetInfoByAddress } from '@defisaver/tokens';
|
|
6
|
+
import { otherAddresses } from '@defisaver/sdk';
|
|
7
|
+
|
|
8
|
+
import type { SubData, EthereumAddress } from '../types';
|
|
9
|
+
import type { CloseStrategyType, OrderType } from '../types/enums';
|
|
10
|
+
import {
|
|
11
|
+
ChainId, CollActionType, DebtActionType, RatioState,
|
|
12
|
+
} from '../types/enums';
|
|
13
|
+
|
|
14
|
+
import { EMPTY_SLOT, ZERO_ADDRESS } from '../constants';
|
|
15
|
+
|
|
16
|
+
import { compareAddresses, ratioPercentageToWei, weiToRatioPercentage } from './utils';
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
_______ _______ .______ .______ _______ ______ ___ .___________. _______ _______
|
|
20
|
+
| \ | ____|| _ \ | _ \ | ____| / | / \ | || ____|| \
|
|
21
|
+
| .--. || |__ | |_) | | |_) | | |__ | ,----' / ^ \ `---| |----`| |__ | .--. |
|
|
22
|
+
| | | || __| | ___/ | / | __| | | / /_\ \ | | | __| | | | |
|
|
23
|
+
| '--' || |____ | | | |\ \----.| |____ | `----./ _____ \ | | | |____ | '--' |
|
|
24
|
+
|_______/ |_______|| _| | _| `._____||_______| \______/__/ \__\ |__| |_______||_______/
|
|
25
|
+
*/
|
|
26
|
+
export const morphoAaveV2LeverageManagementSubData = {
|
|
27
|
+
encode(
|
|
28
|
+
triggerRepayRatio: number,
|
|
29
|
+
triggerBoostRatio: number,
|
|
30
|
+
targetBoostRatio: number,
|
|
31
|
+
targetRepayRatio: number,
|
|
32
|
+
boostEnabled: boolean,
|
|
33
|
+
): SubData {
|
|
34
|
+
return [
|
|
35
|
+
ratioPercentageToWei(triggerRepayRatio),
|
|
36
|
+
ratioPercentageToWei(triggerBoostRatio),
|
|
37
|
+
ratioPercentageToWei(targetBoostRatio),
|
|
38
|
+
ratioPercentageToWei(targetRepayRatio),
|
|
39
|
+
// @ts-ignore
|
|
40
|
+
boostEnabled,
|
|
41
|
+
];
|
|
42
|
+
},
|
|
43
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
44
|
+
const ratioWei = AbiCoder.decodeParameter('uint128', subData[1]) as any as string;
|
|
45
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
46
|
+
|
|
47
|
+
return { targetRatio };
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
export const cBondsRebondSubData = {
|
|
51
|
+
encode(bondId: number | string): SubData {
|
|
52
|
+
const bondIdEncoded = AbiCoder.encodeParameter('uint256', bondId);
|
|
53
|
+
return [bondIdEncoded];
|
|
54
|
+
},
|
|
55
|
+
decode(subData: SubData): { bondId: string } {
|
|
56
|
+
const bondId = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
|
|
57
|
+
return { bondId };
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
export const liquityPaybackUsingChickenBondSubData = {
|
|
61
|
+
/**
|
|
62
|
+
* @param sourceId bondId or subId
|
|
63
|
+
* @param sourceType 0 for bond, 1 for subId
|
|
64
|
+
* @param chainId
|
|
65
|
+
*/
|
|
66
|
+
encode: (sourceId: string, sourceType: number, chainId: ChainId = ChainId.Ethereum): SubData => {
|
|
67
|
+
const sourceIdEncoded = AbiCoder.encodeParameter('uint256', sourceId);
|
|
68
|
+
const sourceTypeEncoded = AbiCoder.encodeParameter('uint256', sourceType);
|
|
69
|
+
const lusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('LUSD', chainId).address);
|
|
70
|
+
const bLusdAddressEncoded = AbiCoder.encodeParameter('address', getAssetInfo('bLUSD', chainId).address);
|
|
71
|
+
|
|
72
|
+
return [sourceIdEncoded, sourceTypeEncoded, lusdAddressEncoded, bLusdAddressEncoded];
|
|
73
|
+
},
|
|
74
|
+
decode: (subData: SubData) => {
|
|
75
|
+
const sourceId = AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
76
|
+
const sourceType = AbiCoder.decodeParameter('uint256', subData[1])!.toString();
|
|
77
|
+
|
|
78
|
+
return { sourceId, sourceType };
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
.___ ___. ___ __ ___ _______ .______
|
|
84
|
+
| \/ | / \ | |/ / | ____|| _ \
|
|
85
|
+
| \ / | / ^ \ | ' / | |__ | |_) |
|
|
86
|
+
| |\/| | / /_\ \ | < | __| | /
|
|
87
|
+
| | | | / _____ \ | . \ | |____ | |\ \----.
|
|
88
|
+
|__| |__| /__/ \__\ |__|\__\ |_______|| _| `._____|
|
|
89
|
+
*/
|
|
90
|
+
export const makerRepayFromSavingsSubData = {
|
|
91
|
+
encode(
|
|
92
|
+
vaultId: number,
|
|
93
|
+
targetRatioPercentage: number,
|
|
94
|
+
chainId: ChainId,
|
|
95
|
+
daiAddr?: EthereumAddress,
|
|
96
|
+
mcdCdpManagerAddr?: EthereumAddress,
|
|
97
|
+
): SubData {
|
|
98
|
+
const _daiAddr = daiAddr || getAssetInfo('DAI', chainId).address;
|
|
99
|
+
// @ts-ignore // TODO - this requires change in @defisaver/tokens
|
|
100
|
+
const _mcdCdpManagerAddr = mcdCdpManagerAddr || otherAddresses(chainId).McdCdpManager;
|
|
101
|
+
|
|
102
|
+
const vaultIdEncoded = AbiCoder.encodeParameter('uint256', vaultId.toString());
|
|
103
|
+
const targetRatioWei = ratioPercentageToWei(targetRatioPercentage);
|
|
104
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', targetRatioWei);
|
|
105
|
+
const daiAddrEncoded = AbiCoder.encodeParameter('address', _daiAddr);
|
|
106
|
+
const mcdManagerAddrEncoded = AbiCoder.encodeParameter('address', _mcdCdpManagerAddr);
|
|
107
|
+
|
|
108
|
+
return [vaultIdEncoded, targetRatioEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
109
|
+
},
|
|
110
|
+
decode(subData: SubData): { vaultId: number, daiAddr: string, mcdManagerAddr: string, targetRatio: number } {
|
|
111
|
+
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
112
|
+
|
|
113
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
114
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
115
|
+
|
|
116
|
+
const daiAddr = AbiCoder.decodeParameter('address', subData[2])!.toString();
|
|
117
|
+
const mcdManagerAddr = AbiCoder.decodeParameter('address', subData[3])!.toString();
|
|
118
|
+
|
|
119
|
+
return {
|
|
120
|
+
vaultId, targetRatio, daiAddr, mcdManagerAddr,
|
|
121
|
+
};
|
|
122
|
+
},
|
|
123
|
+
};
|
|
124
|
+
export const makerCloseSubData = {
|
|
125
|
+
encode(
|
|
126
|
+
vaultId: number,
|
|
127
|
+
closeToAssetAddr: EthereumAddress,
|
|
128
|
+
chainId: ChainId,
|
|
129
|
+
daiAddr?: EthereumAddress,
|
|
130
|
+
mcdCdpManagerAddr?: EthereumAddress,
|
|
131
|
+
): SubData {
|
|
132
|
+
const _daiAddr = daiAddr || getAssetInfo('DAI', chainId).address;
|
|
133
|
+
// @ts-ignore // TODO - this requires change in @defisaver/tokens
|
|
134
|
+
const _mcdCdpManagerAddr = mcdCdpManagerAddr || otherAddresses(chainId).McdCdpManager;
|
|
135
|
+
|
|
136
|
+
const vaultIdEncoded = AbiCoder.encodeParameter('uint256', vaultId.toString());
|
|
137
|
+
const daiAddrEncoded = AbiCoder.encodeParameter('address', _daiAddr);
|
|
138
|
+
const mcdManagerAddrEncoded = AbiCoder.encodeParameter('address', _mcdCdpManagerAddr);
|
|
139
|
+
|
|
140
|
+
if (compareAddresses(closeToAssetAddr, _daiAddr)) {
|
|
141
|
+
// Close to DAI strategy
|
|
142
|
+
return [vaultIdEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
143
|
+
}
|
|
144
|
+
// Close to collateral strategy
|
|
145
|
+
const collAddrEncoded = AbiCoder.encodeParameter('address', closeToAssetAddr);
|
|
146
|
+
return [vaultIdEncoded, collAddrEncoded, daiAddrEncoded, mcdManagerAddrEncoded];
|
|
147
|
+
},
|
|
148
|
+
decode(subData: SubData): { vaultId: number, closeToAssetAddr: EthereumAddress } {
|
|
149
|
+
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!;
|
|
150
|
+
// if closing to collateral, asset addr will be 2nd param out of 4
|
|
151
|
+
// if closing to DAI, will return 2nd param out of 3, which will be DAI addr
|
|
152
|
+
const closeToAssetAddr = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
153
|
+
|
|
154
|
+
return {
|
|
155
|
+
vaultId, closeToAssetAddr,
|
|
156
|
+
};
|
|
157
|
+
},
|
|
158
|
+
};
|
|
159
|
+
export const makerLeverageManagementSubData = {
|
|
160
|
+
decode: (subData:SubData) => {
|
|
161
|
+
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
162
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
163
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
164
|
+
return { vaultId, targetRatio };
|
|
165
|
+
},
|
|
166
|
+
};
|
|
167
|
+
export const makerLeverageManagementWithoutSubProxy = {
|
|
168
|
+
encode(
|
|
169
|
+
vaultId: number,
|
|
170
|
+
targetRatio: number,
|
|
171
|
+
daiAddr?: EthereumAddress,
|
|
172
|
+
): SubData {
|
|
173
|
+
const encodedVaultId = AbiCoder.encodeParameter('uint256', vaultId);
|
|
174
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
175
|
+
const encodedDaiAddr = AbiCoder.encodeParameter('address', daiAddr || getAssetInfo('DAI', 1).address);
|
|
176
|
+
return [encodedVaultId, encodedTargetRatio, encodedDaiAddr];
|
|
177
|
+
},
|
|
178
|
+
decode(subData: SubData): { vaultId: number, targetRatio: number, daiAddr: string } {
|
|
179
|
+
const vaultId = +AbiCoder.decodeParameter('uint256', subData[0])!.toString();
|
|
180
|
+
const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[1]) as any as string);
|
|
181
|
+
const daiAddr = AbiCoder.decodeParameter('address', subData[2])!.toString();
|
|
182
|
+
|
|
183
|
+
return { vaultId, targetRatio, daiAddr };
|
|
184
|
+
},
|
|
185
|
+
};
|
|
186
|
+
|
|
187
|
+
/**
|
|
188
|
+
__ __ ______ __ __ __ .___________.____ ____ ____ ____ __
|
|
189
|
+
| | | | / __ \ | | | | | | | |\ \ / / \ \ / / /_ |
|
|
190
|
+
| | | | | | | | | | | | | | `---| |----` \ \/ / \ \/ / | |
|
|
191
|
+
| | | | | | | | | | | | | | | | \_ _/ \ / | |
|
|
192
|
+
| `----.| | | `--' '--.| `--' | | | | | | | \ / | |
|
|
193
|
+
|_______||__| \_____\_____\\______/ |__| |__| |__| \__/ |_|
|
|
194
|
+
*/
|
|
195
|
+
export const liquityRepayFromSavingsSubData = {
|
|
196
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
197
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
198
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
199
|
+
|
|
200
|
+
return { targetRatio };
|
|
201
|
+
},
|
|
202
|
+
};
|
|
203
|
+
export const liquityLeverageManagementSubData = {
|
|
204
|
+
decode: (subData:SubData) => {
|
|
205
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
206
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
207
|
+
return { targetRatio };
|
|
208
|
+
},
|
|
209
|
+
};
|
|
210
|
+
export const liquityCloseSubData = {
|
|
211
|
+
encode(
|
|
212
|
+
closeToAssetAddr: EthereumAddress,
|
|
213
|
+
chainId: ChainId = ChainId.Ethereum,
|
|
214
|
+
collAddr?: EthereumAddress,
|
|
215
|
+
debtAddr?: EthereumAddress,
|
|
216
|
+
): SubData {
|
|
217
|
+
const _collAddr = collAddr || getAssetInfo('WETH', chainId).address;
|
|
218
|
+
const _debtAddr = debtAddr || getAssetInfo('LUSD', chainId).address;
|
|
219
|
+
|
|
220
|
+
const collAddrEncoded = AbiCoder.encodeParameter('address', _collAddr);
|
|
221
|
+
const debtAddrEncoded = AbiCoder.encodeParameter('address', _debtAddr);
|
|
222
|
+
// if (compareAddresses(closeToAssetAddr, _debtAddr)) { // Closing to debt strategy was not implemented, but it should be in the future
|
|
223
|
+
// // close to LUSD strategy
|
|
224
|
+
// return [debtAddrEncoded, collAddrEncoded];
|
|
225
|
+
// }
|
|
226
|
+
// close to collateral strategy
|
|
227
|
+
return [collAddrEncoded, debtAddrEncoded];
|
|
228
|
+
},
|
|
229
|
+
decode(subData: SubData): { closeToAssetAddr: EthereumAddress, debtAddr: string } {
|
|
230
|
+
const closeToAssetAddr = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
231
|
+
const debtAddr = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
232
|
+
|
|
233
|
+
return { closeToAssetAddr, debtAddr };
|
|
234
|
+
},
|
|
235
|
+
};
|
|
236
|
+
export const liquityDsrPaybackSubData = {
|
|
237
|
+
encode: (targetRatio: number) => {
|
|
238
|
+
const daiAddress = getAssetInfo('DAI').address;
|
|
239
|
+
const lusdAddress = getAssetInfo('LUSD').address;
|
|
240
|
+
|
|
241
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
|
|
242
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
243
|
+
const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
|
|
244
|
+
const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
|
|
245
|
+
|
|
246
|
+
return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, lusdAddressEncoded];
|
|
247
|
+
},
|
|
248
|
+
decode: (subData: SubData) => {
|
|
249
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
250
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
251
|
+
return { targetRatio };
|
|
252
|
+
},
|
|
253
|
+
};
|
|
254
|
+
export const liquityDsrSupplySubData = {
|
|
255
|
+
encode: (targetRatio: number) => {
|
|
256
|
+
const daiAddress = getAssetInfo('DAI').address;
|
|
257
|
+
const wethAddress = getAssetInfo('WETH').address;
|
|
258
|
+
|
|
259
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', RatioState.UNDER);
|
|
260
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
261
|
+
const daiAddressEncoded = AbiCoder.encodeParameter('address', daiAddress);
|
|
262
|
+
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
263
|
+
|
|
264
|
+
return [ratioStateEncoded, targetRatioEncoded, daiAddressEncoded, wethAddressEncoded];
|
|
265
|
+
},
|
|
266
|
+
decode: (subData: SubData) => {
|
|
267
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
268
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
269
|
+
return { targetRatio };
|
|
270
|
+
},
|
|
271
|
+
};
|
|
272
|
+
export const liquityDebtInFrontRepaySubData = {
|
|
273
|
+
encode: (targetRatioIncrease: number) => {
|
|
274
|
+
const wethAddress = getAssetInfo('WETH').address;
|
|
275
|
+
const lusdAddress = getAssetInfo('LUSD').address;
|
|
276
|
+
|
|
277
|
+
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
278
|
+
const lusdAddressEncoded = AbiCoder.encodeParameter('address', lusdAddress);
|
|
279
|
+
const targetRatioIncreaseEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatioIncrease));
|
|
280
|
+
const withdrawIdEncoded = AbiCoder.encodeParameter('uint8', 1); // withdraw - 1
|
|
281
|
+
const paybackIdEncoded = AbiCoder.encodeParameter('uint8', 0); // payback - 0
|
|
282
|
+
|
|
283
|
+
return [wethAddressEncoded, lusdAddressEncoded, targetRatioIncreaseEncoded, withdrawIdEncoded, paybackIdEncoded];
|
|
284
|
+
},
|
|
285
|
+
decode: (subData: SubData) => {
|
|
286
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
|
|
287
|
+
const targetRatioIncrease = weiToRatioPercentage(weiRatio);
|
|
288
|
+
return { targetRatioIncrease };
|
|
289
|
+
},
|
|
290
|
+
};
|
|
291
|
+
|
|
292
|
+
/**
|
|
293
|
+
* __ __ ______ __ __ __ .___________.____ ____ ____ ____ ___
|
|
294
|
+
| | | | / __ \ | | | | | | | |\ \ / / \ \ / / |__ \
|
|
295
|
+
| | | | | | | | | | | | | | `---| |----` \ \/ / \ \/ / ) |
|
|
296
|
+
| | | | | | | | | | | | | | | | \_ _/ \ / / /
|
|
297
|
+
| `----.| | | `--' '--.| `--' | | | | | | | \ / / /_
|
|
298
|
+
|_______||__| \_____\_____\\______/ |__| |__| |__| \__/ |____|
|
|
299
|
+
*/
|
|
300
|
+
export const liquityV2LeverageManagementSubData = {
|
|
301
|
+
encode: (
|
|
302
|
+
market: EthereumAddress,
|
|
303
|
+
troveId: string,
|
|
304
|
+
collToken: EthereumAddress,
|
|
305
|
+
boldToken: EthereumAddress,
|
|
306
|
+
ratioState: RatioState,
|
|
307
|
+
targetRatio: number,
|
|
308
|
+
) => {
|
|
309
|
+
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
310
|
+
const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
|
|
311
|
+
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
312
|
+
const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
|
|
313
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
314
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
315
|
+
|
|
316
|
+
const isRepay = ratioState === RatioState.UNDER;
|
|
317
|
+
const collActionType = isRepay ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
|
|
318
|
+
const debtActionType = isRepay ? DebtActionType.PAYBACK : DebtActionType.BORROW;
|
|
319
|
+
|
|
320
|
+
const collActionTypeEncoded = AbiCoder.encodeParameter('uint8', collActionType);
|
|
321
|
+
const debtActionTypeEncoded = AbiCoder.encodeParameter('uint8', debtActionType);
|
|
322
|
+
|
|
323
|
+
return [
|
|
324
|
+
marketEncoded,
|
|
325
|
+
troveIdEncoded,
|
|
326
|
+
collTokenEncoded,
|
|
327
|
+
boldTokenEncoded,
|
|
328
|
+
ratioStateEncoded,
|
|
329
|
+
targetRatioEncoded,
|
|
330
|
+
collActionTypeEncoded,
|
|
331
|
+
debtActionTypeEncoded,
|
|
332
|
+
];
|
|
333
|
+
},
|
|
334
|
+
decode: (subData: SubData) => {
|
|
335
|
+
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
336
|
+
const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
337
|
+
const collToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
338
|
+
const boldToken = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
339
|
+
const ratioState = AbiCoder.decodeParameter('uint8', subData[4]) as any as RatioState;
|
|
340
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
|
|
341
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
342
|
+
|
|
343
|
+
return {
|
|
344
|
+
market, troveId, collToken, boldToken, ratioState, targetRatio,
|
|
345
|
+
};
|
|
346
|
+
},
|
|
347
|
+
};
|
|
348
|
+
export const liquityV2CloseSubData = {
|
|
349
|
+
encode(
|
|
350
|
+
market: EthereumAddress,
|
|
351
|
+
troveId: string,
|
|
352
|
+
collToken: EthereumAddress,
|
|
353
|
+
boldToken: EthereumAddress,
|
|
354
|
+
closeType: CloseStrategyType,
|
|
355
|
+
): SubData {
|
|
356
|
+
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
357
|
+
const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
|
|
358
|
+
const collAddrEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
359
|
+
const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
|
|
360
|
+
const wethAddress = getAssetInfo('WETH').address;
|
|
361
|
+
const wethAddressEncoded = AbiCoder.encodeParameter('address', wethAddress);
|
|
362
|
+
const gasCompensation = new Dec('0.0375').mul(1e18).toString();
|
|
363
|
+
const gasCompensationEncoded = AbiCoder.encodeParameter('uint256', gasCompensation);
|
|
364
|
+
const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
|
|
365
|
+
|
|
366
|
+
return [
|
|
367
|
+
marketEncoded,
|
|
368
|
+
troveIdEncoded,
|
|
369
|
+
collAddrEncoded,
|
|
370
|
+
boldTokenEncoded,
|
|
371
|
+
wethAddressEncoded,
|
|
372
|
+
gasCompensationEncoded,
|
|
373
|
+
closeTypeEncoded,
|
|
374
|
+
];
|
|
375
|
+
},
|
|
376
|
+
decode(subData: SubData): {
|
|
377
|
+
market: EthereumAddress,
|
|
378
|
+
troveId: string,
|
|
379
|
+
collToken: EthereumAddress,
|
|
380
|
+
boldToken: EthereumAddress,
|
|
381
|
+
closeType: CloseStrategyType,
|
|
382
|
+
} {
|
|
383
|
+
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
384
|
+
const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
385
|
+
const collToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
386
|
+
const boldToken = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
387
|
+
// skip wethAddress and gasCompensation
|
|
388
|
+
const closeType = AbiCoder.decodeParameter('uint8', subData[6]) as any as CloseStrategyType;
|
|
389
|
+
|
|
390
|
+
return {
|
|
391
|
+
market, troveId, collToken, boldToken, closeType,
|
|
392
|
+
};
|
|
393
|
+
},
|
|
394
|
+
};
|
|
395
|
+
export const liquityV2LeverageManagementOnPriceSubData = {
|
|
396
|
+
encode(
|
|
397
|
+
market: EthereumAddress,
|
|
398
|
+
troveId: string,
|
|
399
|
+
collToken: EthereumAddress,
|
|
400
|
+
boldToken: EthereumAddress,
|
|
401
|
+
targetRatio: number,
|
|
402
|
+
isRepayOnPrice: boolean,
|
|
403
|
+
): SubData {
|
|
404
|
+
const encodedMarket = AbiCoder.encodeParameter('address', market);
|
|
405
|
+
const encodedTroveId = AbiCoder.encodeParameter('uint256', troveId);
|
|
406
|
+
const encodedCollToken = AbiCoder.encodeParameter('address', collToken);
|
|
407
|
+
const encodedBoldToken = AbiCoder.encodeParameter('address', boldToken);
|
|
408
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
409
|
+
|
|
410
|
+
const collActionType = isRepayOnPrice ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
|
|
411
|
+
const debtActionType = isRepayOnPrice ? DebtActionType.PAYBACK : DebtActionType.BORROW;
|
|
412
|
+
|
|
413
|
+
const encodedCollActionType = AbiCoder.encodeParameter('uint8', collActionType);
|
|
414
|
+
const encodedDebtActionType = AbiCoder.encodeParameter('uint8', debtActionType);
|
|
415
|
+
|
|
416
|
+
return [
|
|
417
|
+
encodedMarket,
|
|
418
|
+
encodedTroveId,
|
|
419
|
+
encodedCollToken,
|
|
420
|
+
encodedBoldToken,
|
|
421
|
+
encodedTargetRatio,
|
|
422
|
+
encodedCollActionType,
|
|
423
|
+
encodedDebtActionType,
|
|
424
|
+
];
|
|
425
|
+
},
|
|
426
|
+
decode(subData: SubData): {
|
|
427
|
+
market: EthereumAddress,
|
|
428
|
+
troveId: string,
|
|
429
|
+
collToken: EthereumAddress,
|
|
430
|
+
boldToken: EthereumAddress,
|
|
431
|
+
targetRatio: number,
|
|
432
|
+
} {
|
|
433
|
+
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
434
|
+
const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
435
|
+
const collToken = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
436
|
+
const boldToken = AbiCoder.decodeParameter('address', subData[3]) as unknown as EthereumAddress;
|
|
437
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[4]) as any as string;
|
|
438
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
439
|
+
|
|
440
|
+
return {
|
|
441
|
+
market, troveId, collToken, boldToken, targetRatio,
|
|
442
|
+
};
|
|
443
|
+
},
|
|
444
|
+
};
|
|
445
|
+
export const liquityV2PaybackSubData = {
|
|
446
|
+
encode: (
|
|
447
|
+
market: EthereumAddress,
|
|
448
|
+
troveId: string,
|
|
449
|
+
boldToken: EthereumAddress,
|
|
450
|
+
targetRatio: number,
|
|
451
|
+
ratioState: RatioState,
|
|
452
|
+
) => {
|
|
453
|
+
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
454
|
+
const troveIdEncoded = AbiCoder.encodeParameter('uint256', troveId);
|
|
455
|
+
const boldTokenEncoded = AbiCoder.encodeParameter('address', boldToken);
|
|
456
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
457
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
458
|
+
|
|
459
|
+
return [
|
|
460
|
+
marketEncoded,
|
|
461
|
+
troveIdEncoded,
|
|
462
|
+
boldTokenEncoded,
|
|
463
|
+
targetRatioEncoded,
|
|
464
|
+
ratioStateEncoded,
|
|
465
|
+
];
|
|
466
|
+
},
|
|
467
|
+
decode: (subData: SubData) => {
|
|
468
|
+
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
469
|
+
const troveId = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
470
|
+
const boldToken = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
471
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
472
|
+
const ratioState = AbiCoder.decodeParameter('uint8', subData[4]) as any as RatioState;
|
|
473
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
474
|
+
|
|
475
|
+
return {
|
|
476
|
+
market, troveId, boldToken, ratioState, targetRatio,
|
|
477
|
+
};
|
|
478
|
+
},
|
|
479
|
+
};
|
|
480
|
+
|
|
481
|
+
/**
|
|
482
|
+
___ ___ ____ ____ _______ ____ ____ ___
|
|
483
|
+
/ \ / \ \ \ / / | ____| \ \ / / |__ \
|
|
484
|
+
/ ^ \ / ^ \ \ \/ / | |__ \ \/ / ) |
|
|
485
|
+
/ /_\ \ / /_\ \ \ / | __| \ / / /
|
|
486
|
+
/ _____ \ / _____ \ \ / | |____ \ / / /_
|
|
487
|
+
/__/ \__\ /__/ \__\ \__/ |_______| \__/ |____|
|
|
488
|
+
*/
|
|
489
|
+
export const aaveV2LeverageManagementSubData = {
|
|
490
|
+
encode(
|
|
491
|
+
triggerRepayRatio: number,
|
|
492
|
+
triggerBoostRatio: number,
|
|
493
|
+
targetBoostRatio: number,
|
|
494
|
+
targetRepayRatio: number,
|
|
495
|
+
boostEnabled: boolean,
|
|
496
|
+
): SubData {
|
|
497
|
+
return [
|
|
498
|
+
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
499
|
+
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
500
|
+
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
501
|
+
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
502
|
+
// @ts-ignore // TODO
|
|
503
|
+
boostEnabled,
|
|
504
|
+
];
|
|
505
|
+
},
|
|
506
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
507
|
+
const ratioWei = AbiCoder.decodeParameter('uint256', subData[1]) as any as string;
|
|
508
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
509
|
+
|
|
510
|
+
return { targetRatio };
|
|
511
|
+
},
|
|
512
|
+
};
|
|
513
|
+
|
|
514
|
+
/**
|
|
515
|
+
___ ___ ____ ____ _______ ____ ____ ____
|
|
516
|
+
/ \ / \ \ \ / / | ____| \ \ / / |___ \
|
|
517
|
+
/ ^ \ / ^ \ \ \/ / | |__ \ \/ / __) |
|
|
518
|
+
/ /_\ \ / /_\ \ \ / | __| \ / |__ <
|
|
519
|
+
/ _____ \ / _____ \ \ / | |____ \ / ___) |
|
|
520
|
+
/__/ \__\ /__/ \__\ \__/ |_______| \__/ |____/
|
|
521
|
+
*/
|
|
522
|
+
export const aaveV3LeverageManagementSubData = {
|
|
523
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
524
|
+
const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
525
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
526
|
+
|
|
527
|
+
return { targetRatio };
|
|
528
|
+
},
|
|
529
|
+
};
|
|
530
|
+
export const aaveV3LeverageManagementSubDataWithoutSubProxy = {
|
|
531
|
+
encode(
|
|
532
|
+
targetRatio: number,
|
|
533
|
+
ratioState: RatioState,
|
|
534
|
+
market: EthereumAddress,
|
|
535
|
+
user: EthereumAddress,
|
|
536
|
+
isGeneric: boolean,
|
|
537
|
+
): SubData {
|
|
538
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
539
|
+
const encodedRatioState = AbiCoder.encodeParameter('uint8', ratioState);
|
|
540
|
+
|
|
541
|
+
if (isGeneric) {
|
|
542
|
+
const encodedMarket = AbiCoder.encodeParameter('address', market);
|
|
543
|
+
const encodedUser = AbiCoder.encodeParameter('address', user);
|
|
544
|
+
return [encodedTargetRatio, encodedRatioState, encodedMarket, encodedUser];
|
|
545
|
+
}
|
|
546
|
+
const encodedUseDefaultMarket = AbiCoder.encodeParameter('bool', true);
|
|
547
|
+
const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', false);
|
|
548
|
+
return [encodedTargetRatio, encodedRatioState, encodedUseDefaultMarket, encodedUseOnBehalf];
|
|
549
|
+
},
|
|
550
|
+
decode(subData: SubData): { targetRatio: number, ratioState: RatioState } {
|
|
551
|
+
const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[0]) as any as string);
|
|
552
|
+
const ratioState = AbiCoder.decodeParameter('uint8', subData[1]) as any as RatioState;
|
|
553
|
+
|
|
554
|
+
return { targetRatio, ratioState };
|
|
555
|
+
},
|
|
556
|
+
};
|
|
557
|
+
export const aaveV3LeverageManagementOnPriceGeneric = {
|
|
558
|
+
encode(
|
|
559
|
+
collAsset: EthereumAddress,
|
|
560
|
+
collAssetId: number,
|
|
561
|
+
debtAsset: EthereumAddress,
|
|
562
|
+
debtAssetId: number,
|
|
563
|
+
marketAddr: EthereumAddress,
|
|
564
|
+
targetRatio: number,
|
|
565
|
+
user: EthereumAddress,
|
|
566
|
+
): SubData {
|
|
567
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
568
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
569
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
570
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
571
|
+
const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
|
|
572
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
573
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
574
|
+
|
|
575
|
+
return [
|
|
576
|
+
encodedColl,
|
|
577
|
+
encodedCollId,
|
|
578
|
+
encodedDebt,
|
|
579
|
+
encodedDebtId,
|
|
580
|
+
encodedMarket,
|
|
581
|
+
encodedTargetRatio,
|
|
582
|
+
userEncoded,
|
|
583
|
+
];
|
|
584
|
+
},
|
|
585
|
+
decode(subData: SubData): {
|
|
586
|
+
collAsset: EthereumAddress,
|
|
587
|
+
collAssetId: number,
|
|
588
|
+
debtAsset: EthereumAddress,
|
|
589
|
+
debtAssetId: number,
|
|
590
|
+
marketAddr: EthereumAddress,
|
|
591
|
+
targetRatio: number,
|
|
592
|
+
owner: EthereumAddress,
|
|
593
|
+
} {
|
|
594
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
595
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
596
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
597
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
598
|
+
const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
599
|
+
|
|
600
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as unknown as string;
|
|
601
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
602
|
+
|
|
603
|
+
const owner = AbiCoder.decodeParameter('address', subData[6]) as unknown as EthereumAddress;
|
|
604
|
+
|
|
605
|
+
return {
|
|
606
|
+
collAsset,
|
|
607
|
+
collAssetId,
|
|
608
|
+
debtAsset,
|
|
609
|
+
debtAssetId,
|
|
610
|
+
marketAddr,
|
|
611
|
+
targetRatio,
|
|
612
|
+
owner,
|
|
613
|
+
};
|
|
614
|
+
},
|
|
615
|
+
};
|
|
616
|
+
export const aaveV3CloseGenericSubData = {
|
|
617
|
+
encode(
|
|
618
|
+
collAsset: EthereumAddress,
|
|
619
|
+
collAssetId: number,
|
|
620
|
+
debtAsset: EthereumAddress,
|
|
621
|
+
debtAssetId: number,
|
|
622
|
+
closeType: CloseStrategyType,
|
|
623
|
+
marketAddr: EthereumAddress,
|
|
624
|
+
user: EthereumAddress,
|
|
625
|
+
): SubData {
|
|
626
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
627
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
628
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
629
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
630
|
+
const encodedCloseType = AbiCoder.encodeParameter('uint8', closeType);
|
|
631
|
+
const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
|
|
632
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
633
|
+
|
|
634
|
+
return [
|
|
635
|
+
encodedColl,
|
|
636
|
+
encodedCollId,
|
|
637
|
+
encodedDebt,
|
|
638
|
+
encodedDebtId,
|
|
639
|
+
encodedCloseType,
|
|
640
|
+
encodedMarket,
|
|
641
|
+
userEncoded,
|
|
642
|
+
];
|
|
643
|
+
},
|
|
644
|
+
|
|
645
|
+
decode(subData: SubData): {
|
|
646
|
+
collAsset: EthereumAddress,
|
|
647
|
+
collAssetId: number,
|
|
648
|
+
debtAsset: EthereumAddress,
|
|
649
|
+
debtAssetId: number,
|
|
650
|
+
closeType: CloseStrategyType,
|
|
651
|
+
marketAddr: EthereumAddress,
|
|
652
|
+
owner: EthereumAddress,
|
|
653
|
+
} {
|
|
654
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
655
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
656
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
657
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
658
|
+
const closeType = Number(AbiCoder.decodeParameter('uint8', subData[4])) as CloseStrategyType;
|
|
659
|
+
const marketAddr = AbiCoder.decodeParameter('address', subData[5]) as unknown as EthereumAddress;
|
|
660
|
+
const owner = AbiCoder.decodeParameter('address', subData[6]) as unknown as EthereumAddress;
|
|
661
|
+
|
|
662
|
+
return {
|
|
663
|
+
collAsset, collAssetId, debtAsset, debtAssetId, closeType, marketAddr, owner,
|
|
664
|
+
};
|
|
665
|
+
},
|
|
666
|
+
};
|
|
667
|
+
export const aaveV3CollateralSwitchSubData = {
|
|
668
|
+
encode(
|
|
669
|
+
fromAsset: EthereumAddress,
|
|
670
|
+
fromAssetId: number,
|
|
671
|
+
toAsset: EthereumAddress,
|
|
672
|
+
toAssetId: number,
|
|
673
|
+
marketAddr: EthereumAddress,
|
|
674
|
+
amountToSwitch: string,
|
|
675
|
+
useOnBehalf: boolean = false,
|
|
676
|
+
): SubData {
|
|
677
|
+
const encodedFromAsset = AbiCoder.encodeParameter('address', fromAsset);
|
|
678
|
+
const encodedFromAssetId = AbiCoder.encodeParameter('uint8', fromAssetId);
|
|
679
|
+
const encodedToAsset = AbiCoder.encodeParameter('address', toAsset);
|
|
680
|
+
const encodedToAssetId = AbiCoder.encodeParameter('uint8', toAssetId);
|
|
681
|
+
const encodedMarketAddr = AbiCoder.encodeParameter('address', marketAddr);
|
|
682
|
+
const encodedAmountToSwitch = AbiCoder.encodeParameter('uint256', amountToSwitch);
|
|
683
|
+
const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', useOnBehalf);
|
|
684
|
+
|
|
685
|
+
return [
|
|
686
|
+
encodedFromAsset,
|
|
687
|
+
encodedFromAssetId,
|
|
688
|
+
encodedToAsset,
|
|
689
|
+
encodedToAssetId,
|
|
690
|
+
encodedMarketAddr,
|
|
691
|
+
encodedAmountToSwitch,
|
|
692
|
+
encodedUseOnBehalf,
|
|
693
|
+
];
|
|
694
|
+
},
|
|
695
|
+
decode(subData: SubData): {
|
|
696
|
+
fromAsset: EthereumAddress,
|
|
697
|
+
fromAssetId: number,
|
|
698
|
+
toAsset: EthereumAddress,
|
|
699
|
+
toAssetId: number,
|
|
700
|
+
marketAddr: EthereumAddress,
|
|
701
|
+
amountToSwitch: string,
|
|
702
|
+
} {
|
|
703
|
+
const fromAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
704
|
+
const fromAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
705
|
+
const toAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
706
|
+
const toAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
707
|
+
const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
708
|
+
const amountToSwitch = AbiCoder.decodeParameter('uint256', subData[5]) as unknown as string;
|
|
709
|
+
|
|
710
|
+
return {
|
|
711
|
+
fromAsset, fromAssetId, toAsset, toAssetId, marketAddr, amountToSwitch,
|
|
712
|
+
};
|
|
713
|
+
},
|
|
714
|
+
};
|
|
715
|
+
export const aaveV3QuotePriceSubData = {
|
|
716
|
+
encode(
|
|
717
|
+
collAsset: EthereumAddress,
|
|
718
|
+
collAssetId: number,
|
|
719
|
+
debtAsset: EthereumAddress,
|
|
720
|
+
debtAssetId: number,
|
|
721
|
+
nullAddress: EthereumAddress = ZERO_ADDRESS,
|
|
722
|
+
): SubData {
|
|
723
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
724
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
725
|
+
|
|
726
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
727
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
728
|
+
|
|
729
|
+
const encodedNullAddress = AbiCoder.encodeParameter('address', nullAddress);
|
|
730
|
+
|
|
731
|
+
return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedNullAddress];
|
|
732
|
+
},
|
|
733
|
+
decode(subData: SubData): { collAsset: EthereumAddress, collAssetId: number, debtAsset: EthereumAddress, debtAssetId: number } {
|
|
734
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
735
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
736
|
+
|
|
737
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
738
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
739
|
+
|
|
740
|
+
return {
|
|
741
|
+
collAsset, collAssetId, debtAsset, debtAssetId,
|
|
742
|
+
};
|
|
743
|
+
},
|
|
744
|
+
};
|
|
745
|
+
export const aaveV3LeverageManagementOnPriceSubData = {
|
|
746
|
+
encode(
|
|
747
|
+
collAsset: EthereumAddress,
|
|
748
|
+
collAssetId: number,
|
|
749
|
+
debtAsset: EthereumAddress,
|
|
750
|
+
debtAssetId: number,
|
|
751
|
+
marketAddr: EthereumAddress,
|
|
752
|
+
targetRatio: number,
|
|
753
|
+
): SubData {
|
|
754
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
755
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
756
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
757
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
758
|
+
const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
|
|
759
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
760
|
+
const useOnBehalfEncoded = AbiCoder.encodeParameter('bool', false);
|
|
761
|
+
|
|
762
|
+
return [
|
|
763
|
+
encodedColl,
|
|
764
|
+
encodedCollId,
|
|
765
|
+
encodedDebt,
|
|
766
|
+
encodedDebtId,
|
|
767
|
+
encodedMarket,
|
|
768
|
+
encodedTargetRatio,
|
|
769
|
+
useOnBehalfEncoded,
|
|
770
|
+
];
|
|
771
|
+
},
|
|
772
|
+
decode(subData: SubData): {
|
|
773
|
+
collAsset: EthereumAddress,
|
|
774
|
+
collAssetId: number,
|
|
775
|
+
debtAsset: EthereumAddress,
|
|
776
|
+
debtAssetId: number,
|
|
777
|
+
marketAddr: EthereumAddress,
|
|
778
|
+
targetRatio: number,
|
|
779
|
+
} {
|
|
780
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
781
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
782
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
783
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
784
|
+
const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
785
|
+
|
|
786
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
|
|
787
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
788
|
+
|
|
789
|
+
return {
|
|
790
|
+
collAsset, collAssetId, debtAsset, debtAssetId, marketAddr, targetRatio,
|
|
791
|
+
};
|
|
792
|
+
},
|
|
793
|
+
};
|
|
794
|
+
|
|
795
|
+
/**
|
|
796
|
+
* ___ ___ ____ ____ _______ ____ ____ _ _
|
|
797
|
+
/ \ / \ \ \ / / | ____| \ \ / / | || |
|
|
798
|
+
/ ^ \ / ^ \ \ \/ / | |__ \ \/ / | || |_
|
|
799
|
+
/ /_\ \ / /_\ \ \ / | __| \ / |__ _|
|
|
800
|
+
/ _____ \ / _____ \ \ / | |____ \ / | |
|
|
801
|
+
/__/ \__\ /__/ \__\ \__/ |_______| \__/ |_|
|
|
802
|
+
*/
|
|
803
|
+
export const aaveV4LeverageManagementSubData = {
|
|
804
|
+
encode: (
|
|
805
|
+
spoke: EthereumAddress,
|
|
806
|
+
owner: EthereumAddress,
|
|
807
|
+
ratioState: RatioState,
|
|
808
|
+
targetRatio: number,
|
|
809
|
+
) => {
|
|
810
|
+
const spokeEncoded = AbiCoder.encodeParameter('address', spoke);
|
|
811
|
+
const ownerEncoded = AbiCoder.encodeParameter('address', owner);
|
|
812
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
813
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
814
|
+
// Add two empty slots for future addons (e.g tsi or slippage settings)
|
|
815
|
+
return [
|
|
816
|
+
spokeEncoded,
|
|
817
|
+
ownerEncoded,
|
|
818
|
+
ratioStateEncoded,
|
|
819
|
+
targetRatioEncoded,
|
|
820
|
+
EMPTY_SLOT,
|
|
821
|
+
EMPTY_SLOT,
|
|
822
|
+
];
|
|
823
|
+
},
|
|
824
|
+
decode: (subData: SubData) => {
|
|
825
|
+
const spoke = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
826
|
+
const owner = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
827
|
+
const ratioState = Number(AbiCoder.decodeParameter('uint8', subData[2])) as RatioState;
|
|
828
|
+
const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[3]) as any as string);
|
|
829
|
+
return {
|
|
830
|
+
spoke, owner, ratioState, targetRatio,
|
|
831
|
+
};
|
|
832
|
+
},
|
|
833
|
+
};
|
|
834
|
+
export const aaveV4LeverageManagementOnPriceSubData = {
|
|
835
|
+
encode: (
|
|
836
|
+
spoke: EthereumAddress,
|
|
837
|
+
owner: EthereumAddress,
|
|
838
|
+
collAsset: EthereumAddress,
|
|
839
|
+
collAssetId: number,
|
|
840
|
+
debtAsset: EthereumAddress,
|
|
841
|
+
debtAssetId: number,
|
|
842
|
+
ratioState: RatioState,
|
|
843
|
+
targetRatio: number,
|
|
844
|
+
) => {
|
|
845
|
+
const spokeEncoded = AbiCoder.encodeParameter('address', spoke);
|
|
846
|
+
const ownerEncoded = AbiCoder.encodeParameter('address', owner);
|
|
847
|
+
const collAssetEncoded = AbiCoder.encodeParameter('address', collAsset);
|
|
848
|
+
const collAssetIdEncoded = AbiCoder.encodeParameter('uint256', collAssetId);
|
|
849
|
+
const debtAssetEncoded = AbiCoder.encodeParameter('address', debtAsset);
|
|
850
|
+
const debtAssetIdEncoded = AbiCoder.encodeParameter('uint256', debtAssetId);
|
|
851
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
852
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
853
|
+
// Add two empty slots for future addons (e.g tsi or slippage settings)
|
|
854
|
+
return [
|
|
855
|
+
spokeEncoded,
|
|
856
|
+
ownerEncoded,
|
|
857
|
+
collAssetEncoded,
|
|
858
|
+
collAssetIdEncoded,
|
|
859
|
+
debtAssetEncoded,
|
|
860
|
+
debtAssetIdEncoded,
|
|
861
|
+
ratioStateEncoded,
|
|
862
|
+
targetRatioEncoded,
|
|
863
|
+
EMPTY_SLOT,
|
|
864
|
+
EMPTY_SLOT,
|
|
865
|
+
];
|
|
866
|
+
},
|
|
867
|
+
decode: (subData: SubData) => {
|
|
868
|
+
const spoke = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
869
|
+
const owner = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
870
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
871
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint256', subData[3]));
|
|
872
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
873
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint256', subData[5]));
|
|
874
|
+
const ratioState = Number(AbiCoder.decodeParameter('uint8', subData[6])) as RatioState;
|
|
875
|
+
const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[7]) as any as string);
|
|
876
|
+
return {
|
|
877
|
+
spoke, owner, collAsset, collAssetId, debtAsset, debtAssetId, ratioState, targetRatio,
|
|
878
|
+
};
|
|
879
|
+
},
|
|
880
|
+
};
|
|
881
|
+
export const aaveV4CloseSubData = {
|
|
882
|
+
encode: (
|
|
883
|
+
spoke: EthereumAddress,
|
|
884
|
+
owner: EthereumAddress,
|
|
885
|
+
collAsset: EthereumAddress,
|
|
886
|
+
collAssetId: number,
|
|
887
|
+
debtAsset: EthereumAddress,
|
|
888
|
+
debtAssetId: number,
|
|
889
|
+
closeType: CloseStrategyType,
|
|
890
|
+
) => {
|
|
891
|
+
const spokeEncoded = AbiCoder.encodeParameter('address', spoke);
|
|
892
|
+
const ownerEncoded = AbiCoder.encodeParameter('address', owner);
|
|
893
|
+
const collAssetEncoded = AbiCoder.encodeParameter('address', collAsset);
|
|
894
|
+
const collAssetIdEncoded = AbiCoder.encodeParameter('uint256', collAssetId);
|
|
895
|
+
const debtAssetEncoded = AbiCoder.encodeParameter('address', debtAsset);
|
|
896
|
+
const debtAssetIdEncoded = AbiCoder.encodeParameter('uint256', debtAssetId);
|
|
897
|
+
const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
|
|
898
|
+
// Add two empty slots for future addons (e.g tsi or slippage settings)
|
|
899
|
+
return [
|
|
900
|
+
spokeEncoded,
|
|
901
|
+
ownerEncoded,
|
|
902
|
+
collAssetEncoded,
|
|
903
|
+
collAssetIdEncoded,
|
|
904
|
+
debtAssetEncoded,
|
|
905
|
+
debtAssetIdEncoded,
|
|
906
|
+
closeTypeEncoded,
|
|
907
|
+
EMPTY_SLOT,
|
|
908
|
+
EMPTY_SLOT,
|
|
909
|
+
];
|
|
910
|
+
},
|
|
911
|
+
decode: (subData: SubData) => {
|
|
912
|
+
const spoke = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
913
|
+
const owner = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
914
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
915
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint256', subData[3]));
|
|
916
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
917
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint256', subData[5]));
|
|
918
|
+
const closeType = Number(AbiCoder.decodeParameter('uint8', subData[6])) as CloseStrategyType;
|
|
919
|
+
return {
|
|
920
|
+
spoke, owner, collAsset, collAssetId, debtAsset, debtAssetId, closeType,
|
|
921
|
+
};
|
|
922
|
+
},
|
|
923
|
+
};
|
|
924
|
+
export const aaveV4CollateralSwitchSubData = {
|
|
925
|
+
encode: (
|
|
926
|
+
spoke: EthereumAddress,
|
|
927
|
+
owner: EthereumAddress,
|
|
928
|
+
fromAsset: EthereumAddress,
|
|
929
|
+
fromAssetId: number,
|
|
930
|
+
toAsset: EthereumAddress,
|
|
931
|
+
toAssetId: number,
|
|
932
|
+
amountToSwitch: string,
|
|
933
|
+
) => {
|
|
934
|
+
const spokeEncoded = AbiCoder.encodeParameter('address', spoke);
|
|
935
|
+
const ownerEncoded = AbiCoder.encodeParameter('address', owner);
|
|
936
|
+
const fromAssetEncoded = AbiCoder.encodeParameter('address', fromAsset);
|
|
937
|
+
const fromAssetIdEncoded = AbiCoder.encodeParameter('uint256', fromAssetId);
|
|
938
|
+
const toAssetEncoded = AbiCoder.encodeParameter('address', toAsset);
|
|
939
|
+
const toAssetIdEncoded = AbiCoder.encodeParameter('uint256', toAssetId);
|
|
940
|
+
const amountToSwitchEncoded = AbiCoder.encodeParameter('uint256', amountToSwitch);
|
|
941
|
+
// Add two empty slots for future addons (e.g tsi or slippage settings)
|
|
942
|
+
return [
|
|
943
|
+
spokeEncoded,
|
|
944
|
+
ownerEncoded,
|
|
945
|
+
fromAssetEncoded,
|
|
946
|
+
fromAssetIdEncoded,
|
|
947
|
+
toAssetEncoded,
|
|
948
|
+
toAssetIdEncoded,
|
|
949
|
+
amountToSwitchEncoded,
|
|
950
|
+
EMPTY_SLOT,
|
|
951
|
+
EMPTY_SLOT,
|
|
952
|
+
];
|
|
953
|
+
},
|
|
954
|
+
decode: (subData: SubData) => {
|
|
955
|
+
const spoke = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
956
|
+
const owner = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
957
|
+
const fromAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
958
|
+
const fromAssetId = Number(AbiCoder.decodeParameter('uint256', subData[3]));
|
|
959
|
+
const toAsset = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
960
|
+
const toAssetId = Number(AbiCoder.decodeParameter('uint256', subData[5]));
|
|
961
|
+
const amountToSwitch = AbiCoder.decodeParameter('uint256', subData[6]) as any as string;
|
|
962
|
+
return {
|
|
963
|
+
spoke, owner, fromAsset, fromAssetId, toAsset, toAssetId, amountToSwitch,
|
|
964
|
+
};
|
|
965
|
+
},
|
|
966
|
+
};
|
|
967
|
+
|
|
968
|
+
/**
|
|
969
|
+
______ ______ .___ ___. .______ ____ ____ ___
|
|
970
|
+
/ | / __ \ | \/ | | _ \ \ \ / / |__ \
|
|
971
|
+
| ,----'| | | | | \ / | | |_) | \ \/ / ) |
|
|
972
|
+
| | | | | | | |\/| | | ___/ \ / / /
|
|
973
|
+
| `----.| `--' | | | | | | | \ / / /_
|
|
974
|
+
\______| \______/ |__| |__| | _| \__/ |____|
|
|
975
|
+
*/
|
|
976
|
+
export const compoundV2LeverageManagementSubData = {
|
|
977
|
+
encode(
|
|
978
|
+
triggerRepayRatio: number,
|
|
979
|
+
triggerBoostRatio: number,
|
|
980
|
+
targetBoostRatio: number,
|
|
981
|
+
targetRepayRatio: number,
|
|
982
|
+
boostEnabled: boolean,
|
|
983
|
+
): SubData {
|
|
984
|
+
return [
|
|
985
|
+
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
986
|
+
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
987
|
+
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
988
|
+
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
989
|
+
// @ts-ignore // TODO
|
|
990
|
+
boostEnabled,
|
|
991
|
+
];
|
|
992
|
+
},
|
|
993
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
994
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
995
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
996
|
+
|
|
997
|
+
return { targetRatio };
|
|
998
|
+
},
|
|
999
|
+
};
|
|
1000
|
+
|
|
1001
|
+
/**
|
|
1002
|
+
______ ______ .___ ___. .______ ____ ____ ____
|
|
1003
|
+
/ | / __ \ | \/ | | _ \ \ \ / / |___ \
|
|
1004
|
+
| ,----'| | | | | \ / | | |_) | \ \/ / __) |
|
|
1005
|
+
| | | | | | | |\/| | | ___/ \ / |__ <
|
|
1006
|
+
| `----.| `--' | | | | | | | \ / ___) |
|
|
1007
|
+
\______| \______/ |__| |__| | _| \__/ |____/
|
|
1008
|
+
*/
|
|
1009
|
+
export const compoundV3LeverageManagementSubData = {
|
|
1010
|
+
encode(
|
|
1011
|
+
market: EthereumAddress,
|
|
1012
|
+
baseToken: EthereumAddress,
|
|
1013
|
+
triggerRepayRatio: number,
|
|
1014
|
+
triggerBoostRatio: number,
|
|
1015
|
+
targetBoostRatio: number,
|
|
1016
|
+
targetRepayRatio: number,
|
|
1017
|
+
boostEnabled: boolean,
|
|
1018
|
+
isEOA: boolean,
|
|
1019
|
+
): SubData {
|
|
1020
|
+
return [
|
|
1021
|
+
market,
|
|
1022
|
+
baseToken,
|
|
1023
|
+
new Dec(triggerRepayRatio).mul(1e16).toString(),
|
|
1024
|
+
new Dec(triggerBoostRatio).mul(1e16).toString(),
|
|
1025
|
+
new Dec(targetBoostRatio).mul(1e16).toString(),
|
|
1026
|
+
new Dec(targetRepayRatio).mul(1e16).toString(),
|
|
1027
|
+
// @ts-ignore // TODO
|
|
1028
|
+
boostEnabled, isEOA,
|
|
1029
|
+
];
|
|
1030
|
+
},
|
|
1031
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
1032
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
1033
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1034
|
+
|
|
1035
|
+
return { targetRatio };
|
|
1036
|
+
},
|
|
1037
|
+
};
|
|
1038
|
+
export const compoundV3L2LeverageManagementSubData = {
|
|
1039
|
+
encode(
|
|
1040
|
+
market: EthereumAddress,
|
|
1041
|
+
baseToken: EthereumAddress,
|
|
1042
|
+
triggerRepayRatio: number,
|
|
1043
|
+
triggerBoostRatio: number,
|
|
1044
|
+
targetBoostRatio: number,
|
|
1045
|
+
targetRepayRatio: number,
|
|
1046
|
+
boostEnabled: boolean,
|
|
1047
|
+
isEOA: boolean,
|
|
1048
|
+
): string {
|
|
1049
|
+
let subInput = '0x';
|
|
1050
|
+
|
|
1051
|
+
subInput = subInput.concat(market.slice(2));
|
|
1052
|
+
subInput = subInput.concat(baseToken.slice(2));
|
|
1053
|
+
subInput = subInput.concat(new Dec(triggerRepayRatio).mul(1e16).toHex().slice(2)
|
|
1054
|
+
.padStart(32, '0'));
|
|
1055
|
+
subInput = subInput.concat(new Dec(triggerBoostRatio).mul(1e16).toHex().slice(2)
|
|
1056
|
+
.padStart(32, '0'));
|
|
1057
|
+
subInput = subInput.concat(new Dec(targetBoostRatio).mul(1e16).toHex().slice(2)
|
|
1058
|
+
.padStart(32, '0'));
|
|
1059
|
+
subInput = subInput.concat(new Dec(targetRepayRatio).mul(1e16).toHex().slice(2)
|
|
1060
|
+
.padStart(32, '0'));
|
|
1061
|
+
subInput = subInput.concat(boostEnabled ? '01' : '00');
|
|
1062
|
+
subInput = subInput.concat(isEOA ? '01' : '00');
|
|
1063
|
+
|
|
1064
|
+
return subInput;
|
|
1065
|
+
},
|
|
1066
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
1067
|
+
const ratioWei = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
1068
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
1069
|
+
|
|
1070
|
+
return { targetRatio };
|
|
1071
|
+
},
|
|
1072
|
+
};
|
|
1073
|
+
export const compoundV3LeverageManagementOnPriceSubData = {
|
|
1074
|
+
encode(
|
|
1075
|
+
market: EthereumAddress,
|
|
1076
|
+
collToken: EthereumAddress,
|
|
1077
|
+
baseToken: EthereumAddress,
|
|
1078
|
+
targetRatio: number,
|
|
1079
|
+
ratioState: RatioState,
|
|
1080
|
+
user: EthereumAddress,
|
|
1081
|
+
): SubData {
|
|
1082
|
+
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
1083
|
+
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
1084
|
+
const baseTokenEncoded = AbiCoder.encodeParameter('address', baseToken);
|
|
1085
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
1086
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
1087
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1088
|
+
|
|
1089
|
+
return [
|
|
1090
|
+
marketEncoded,
|
|
1091
|
+
collTokenEncoded,
|
|
1092
|
+
baseTokenEncoded,
|
|
1093
|
+
targetRatioEncoded,
|
|
1094
|
+
ratioStateEncoded,
|
|
1095
|
+
userEncoded,
|
|
1096
|
+
];
|
|
1097
|
+
},
|
|
1098
|
+
decode(subData: SubData): {
|
|
1099
|
+
market: EthereumAddress,
|
|
1100
|
+
collToken: EthereumAddress,
|
|
1101
|
+
baseToken: EthereumAddress,
|
|
1102
|
+
targetRatio: number,
|
|
1103
|
+
ratioState: RatioState,
|
|
1104
|
+
owner: EthereumAddress,
|
|
1105
|
+
} {
|
|
1106
|
+
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1107
|
+
const collToken = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
1108
|
+
const baseToken = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
1109
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
1110
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1111
|
+
const ratioState = Number(AbiCoder.decodeParameter('uint8', subData[4])) as any as RatioState;
|
|
1112
|
+
const owner = AbiCoder.decodeParameter('address', subData[5]) as unknown as EthereumAddress;
|
|
1113
|
+
|
|
1114
|
+
return {
|
|
1115
|
+
market, collToken, baseToken, targetRatio, ratioState, owner,
|
|
1116
|
+
};
|
|
1117
|
+
},
|
|
1118
|
+
};
|
|
1119
|
+
export const compoundV3CloseSubData = {
|
|
1120
|
+
encode(
|
|
1121
|
+
market: EthereumAddress,
|
|
1122
|
+
collToken: EthereumAddress,
|
|
1123
|
+
baseToken: EthereumAddress,
|
|
1124
|
+
closeType: CloseStrategyType,
|
|
1125
|
+
user: EthereumAddress,
|
|
1126
|
+
): SubData {
|
|
1127
|
+
const marketEncoded = AbiCoder.encodeParameter('address', market);
|
|
1128
|
+
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
1129
|
+
const baseTokenEncoded = AbiCoder.encodeParameter('address', baseToken);
|
|
1130
|
+
const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
|
|
1131
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1132
|
+
|
|
1133
|
+
return [
|
|
1134
|
+
marketEncoded,
|
|
1135
|
+
collTokenEncoded,
|
|
1136
|
+
baseTokenEncoded,
|
|
1137
|
+
closeTypeEncoded,
|
|
1138
|
+
userEncoded,
|
|
1139
|
+
];
|
|
1140
|
+
},
|
|
1141
|
+
decode(subData: SubData): {
|
|
1142
|
+
market: EthereumAddress,
|
|
1143
|
+
collToken: EthereumAddress,
|
|
1144
|
+
baseToken: EthereumAddress,
|
|
1145
|
+
closeType: CloseStrategyType,
|
|
1146
|
+
owner: EthereumAddress,
|
|
1147
|
+
} {
|
|
1148
|
+
const market = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1149
|
+
const collToken = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
1150
|
+
const baseToken = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
1151
|
+
const closeType = Number(AbiCoder.decodeParameter('uint8', subData[3])) as CloseStrategyType;
|
|
1152
|
+
const owner = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
1153
|
+
|
|
1154
|
+
return {
|
|
1155
|
+
market, collToken, baseToken, closeType, owner,
|
|
1156
|
+
};
|
|
1157
|
+
},
|
|
1158
|
+
};
|
|
1159
|
+
|
|
1160
|
+
/**
|
|
1161
|
+
__________ ___ ______ __ __ ___ .__ __. _______ _______
|
|
1162
|
+
| ____\ \ / / / || | | | / \ | \ | | / _____|| ____|
|
|
1163
|
+
| |__ \ V / | ,----'| |__| | / ^ \ | \| | | | __ | |__
|
|
1164
|
+
| __| > < | | | __ | / /_\ \ | . ` | | | |_ | | __|
|
|
1165
|
+
| |____ / . \ | `----.| | | | / _____ \ | |\ | | |__| | | |____
|
|
1166
|
+
|_______/__/ \__\ \______||__| |__| /__/ \__\ |__| \__| \______| |_______|
|
|
1167
|
+
*/
|
|
1168
|
+
export const exchangeDcaSubData = {
|
|
1169
|
+
encode: (fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, interval: number) : SubData => {
|
|
1170
|
+
const sellTokenEncoded = AbiCoder.encodeParameter('address', fromToken);
|
|
1171
|
+
const buyTokenEncoded = AbiCoder.encodeParameter('address', toToken);
|
|
1172
|
+
const amountEncoded = AbiCoder.encodeParameter('uint256', amount);
|
|
1173
|
+
const intervalEncoded = AbiCoder.encodeParameter('uint256', interval);
|
|
1174
|
+
|
|
1175
|
+
return [sellTokenEncoded, buyTokenEncoded, amountEncoded, intervalEncoded];
|
|
1176
|
+
},
|
|
1177
|
+
decode: (subData: SubData, chainId: ChainId) => {
|
|
1178
|
+
const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
1179
|
+
const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
1180
|
+
const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
|
|
1181
|
+
const interval = AbiCoder.decodeParameter('uint256', subData[3])!.toString();
|
|
1182
|
+
return {
|
|
1183
|
+
fromToken,
|
|
1184
|
+
toToken,
|
|
1185
|
+
amount,
|
|
1186
|
+
interval,
|
|
1187
|
+
};
|
|
1188
|
+
},
|
|
1189
|
+
};
|
|
1190
|
+
export const exchangeLimitOrderSubData = {
|
|
1191
|
+
encode(fromToken: EthereumAddress, toToken: EthereumAddress, amount: string, targetPrice: string, goodUntil: string | number, orderType: OrderType) : SubData {
|
|
1192
|
+
return [
|
|
1193
|
+
fromToken,
|
|
1194
|
+
toToken,
|
|
1195
|
+
amount,
|
|
1196
|
+
targetPrice,
|
|
1197
|
+
new Dec(goodUntil).toString(),
|
|
1198
|
+
new Dec(orderType).toString(),
|
|
1199
|
+
];
|
|
1200
|
+
},
|
|
1201
|
+
decode: (subData: SubData, chainId: ChainId) => {
|
|
1202
|
+
const fromToken = AbiCoder.decodeParameter('address', subData[0])!.toString();
|
|
1203
|
+
const toToken = AbiCoder.decodeParameter('address', subData[1])!.toString();
|
|
1204
|
+
const amount = assetAmountInEth(AbiCoder.decodeParameter('uint256', subData[2])!.toString(), getAssetInfoByAddress(fromToken, chainId).symbol);
|
|
1205
|
+
return { fromToken, toToken, amount };
|
|
1206
|
+
},
|
|
1207
|
+
};
|
|
1208
|
+
|
|
1209
|
+
/**
|
|
1210
|
+
_______..______ ___ .______ __ ___
|
|
1211
|
+
/ || _ \ / \ | _ \ | |/ /
|
|
1212
|
+
| (----`| |_) | / ^ \ | |_) | | ' /
|
|
1213
|
+
\ \ | ___/ / /_\ \ | / | <
|
|
1214
|
+
.----) | | | / _____ \ | |\ \----.| . \
|
|
1215
|
+
|_______/ | _| /__/ \__\ | _| `._____||__|\__\
|
|
1216
|
+
*/
|
|
1217
|
+
export const sparkLeverageManagementSubData = {
|
|
1218
|
+
decode(subData: SubData): { targetRatio: number } {
|
|
1219
|
+
const ratioWei = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
1220
|
+
const targetRatio = weiToRatioPercentage(ratioWei);
|
|
1221
|
+
|
|
1222
|
+
return { targetRatio };
|
|
1223
|
+
},
|
|
1224
|
+
};
|
|
1225
|
+
export const sparkLeverageManagementSubDataWithoutSubProxy = {
|
|
1226
|
+
encode(
|
|
1227
|
+
targetRatio: number,
|
|
1228
|
+
ratioState: RatioState,
|
|
1229
|
+
): SubData {
|
|
1230
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
1231
|
+
const encodedRatioState = AbiCoder.encodeParameter('uint8', ratioState);
|
|
1232
|
+
|
|
1233
|
+
const encodedUseDefaultMarket = AbiCoder.encodeParameter('bool', true);
|
|
1234
|
+
const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', false);
|
|
1235
|
+
return [encodedTargetRatio, encodedRatioState, encodedUseDefaultMarket, encodedUseOnBehalf];
|
|
1236
|
+
},
|
|
1237
|
+
decode(subData: SubData): { targetRatio: number, ratioState: RatioState } {
|
|
1238
|
+
const targetRatio = weiToRatioPercentage(AbiCoder.decodeParameter('uint256', subData[0]) as any as string);
|
|
1239
|
+
const ratioState = AbiCoder.decodeParameter('uint8', subData[1]) as any as RatioState;
|
|
1240
|
+
|
|
1241
|
+
return { targetRatio, ratioState };
|
|
1242
|
+
},
|
|
1243
|
+
};
|
|
1244
|
+
export const sparkCloseGenericSubData = {
|
|
1245
|
+
encode(
|
|
1246
|
+
collAsset: EthereumAddress,
|
|
1247
|
+
collAssetId: number,
|
|
1248
|
+
debtAsset: EthereumAddress,
|
|
1249
|
+
debtAssetId: number,
|
|
1250
|
+
closeType: CloseStrategyType,
|
|
1251
|
+
marketAddr: EthereumAddress,
|
|
1252
|
+
user: EthereumAddress,
|
|
1253
|
+
): SubData {
|
|
1254
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
1255
|
+
const encodedCollId = AbiCoder.encodeParameter('uint8', collAssetId);
|
|
1256
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
1257
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint8', debtAssetId);
|
|
1258
|
+
const encodedCloseType = AbiCoder.encodeParameter('uint8', closeType);
|
|
1259
|
+
const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
|
|
1260
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1261
|
+
|
|
1262
|
+
return [
|
|
1263
|
+
encodedColl,
|
|
1264
|
+
encodedCollId,
|
|
1265
|
+
encodedDebt,
|
|
1266
|
+
encodedDebtId,
|
|
1267
|
+
encodedCloseType,
|
|
1268
|
+
encodedMarket,
|
|
1269
|
+
userEncoded,
|
|
1270
|
+
];
|
|
1271
|
+
},
|
|
1272
|
+
|
|
1273
|
+
decode(subData: SubData): {
|
|
1274
|
+
collAsset: EthereumAddress,
|
|
1275
|
+
collAssetId: number,
|
|
1276
|
+
debtAsset: EthereumAddress,
|
|
1277
|
+
debtAssetId: number,
|
|
1278
|
+
closeType: CloseStrategyType,
|
|
1279
|
+
marketAddr: EthereumAddress,
|
|
1280
|
+
owner: EthereumAddress,
|
|
1281
|
+
} {
|
|
1282
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1283
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
1284
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
1285
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
1286
|
+
const closeType = Number(AbiCoder.decodeParameter('uint8', subData[4])) as CloseStrategyType;
|
|
1287
|
+
const marketAddr = AbiCoder.decodeParameter('address', subData[5]) as unknown as EthereumAddress;
|
|
1288
|
+
const owner = AbiCoder.decodeParameter('address', subData[6]) as unknown as EthereumAddress;
|
|
1289
|
+
|
|
1290
|
+
return {
|
|
1291
|
+
collAsset, collAssetId, debtAsset, debtAssetId, closeType, marketAddr, owner,
|
|
1292
|
+
};
|
|
1293
|
+
},
|
|
1294
|
+
};
|
|
1295
|
+
export const sparkLeverageManagementOnPriceSubData = {
|
|
1296
|
+
encode(
|
|
1297
|
+
collAsset: EthereumAddress,
|
|
1298
|
+
collAssetId: number,
|
|
1299
|
+
debtAsset: EthereumAddress,
|
|
1300
|
+
debtAssetId: number,
|
|
1301
|
+
marketAddr: EthereumAddress,
|
|
1302
|
+
targetRatio: number,
|
|
1303
|
+
): SubData {
|
|
1304
|
+
const encodedColl = AbiCoder.encodeParameter('address', collAsset);
|
|
1305
|
+
const encodedCollId = AbiCoder.encodeParameter('uint16', collAssetId);
|
|
1306
|
+
const encodedDebt = AbiCoder.encodeParameter('address', debtAsset);
|
|
1307
|
+
const encodedDebtId = AbiCoder.encodeParameter('uint16', debtAssetId);
|
|
1308
|
+
const encodedMarket = AbiCoder.encodeParameter('address', marketAddr);
|
|
1309
|
+
const encodedTargetRatio = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
1310
|
+
const useOnBehalfEncoded = AbiCoder.encodeParameter('bool', false);
|
|
1311
|
+
return [encodedColl, encodedCollId, encodedDebt, encodedDebtId, encodedMarket, encodedTargetRatio, useOnBehalfEncoded];
|
|
1312
|
+
},
|
|
1313
|
+
decode(subData: SubData): {
|
|
1314
|
+
collAsset: EthereumAddress,
|
|
1315
|
+
collAssetId: number,
|
|
1316
|
+
debtAsset: EthereumAddress,
|
|
1317
|
+
debtAssetId: number,
|
|
1318
|
+
marketAddr: EthereumAddress,
|
|
1319
|
+
targetRatio: number,
|
|
1320
|
+
} {
|
|
1321
|
+
const collAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1322
|
+
const collAssetId = Number(AbiCoder.decodeParameter('uint16', subData[1]));
|
|
1323
|
+
const debtAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
1324
|
+
const debtAssetId = Number(AbiCoder.decodeParameter('uint16', subData[3]));
|
|
1325
|
+
const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
1326
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as string;
|
|
1327
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1328
|
+
return {
|
|
1329
|
+
collAsset, collAssetId, debtAsset, debtAssetId, marketAddr, targetRatio,
|
|
1330
|
+
};
|
|
1331
|
+
},
|
|
1332
|
+
};
|
|
1333
|
+
export const sparkCollateralSwitchSubData = {
|
|
1334
|
+
encode(
|
|
1335
|
+
fromAsset: EthereumAddress,
|
|
1336
|
+
fromAssetId: number,
|
|
1337
|
+
toAsset: EthereumAddress,
|
|
1338
|
+
toAssetId: number,
|
|
1339
|
+
marketAddr: EthereumAddress,
|
|
1340
|
+
amountToSwitch: string,
|
|
1341
|
+
useOnBehalf: boolean = false,
|
|
1342
|
+
): SubData {
|
|
1343
|
+
const encodedFromAsset = AbiCoder.encodeParameter('address', fromAsset);
|
|
1344
|
+
const encodedFromAssetId = AbiCoder.encodeParameter('uint8', fromAssetId);
|
|
1345
|
+
const encodedToAsset = AbiCoder.encodeParameter('address', toAsset);
|
|
1346
|
+
const encodedToAssetId = AbiCoder.encodeParameter('uint8', toAssetId);
|
|
1347
|
+
const encodedMarketAddr = AbiCoder.encodeParameter('address', marketAddr);
|
|
1348
|
+
const encodedAmountToSwitch = AbiCoder.encodeParameter('uint256', amountToSwitch);
|
|
1349
|
+
const encodedUseOnBehalf = AbiCoder.encodeParameter('bool', useOnBehalf);
|
|
1350
|
+
|
|
1351
|
+
return [
|
|
1352
|
+
encodedFromAsset,
|
|
1353
|
+
encodedFromAssetId,
|
|
1354
|
+
encodedToAsset,
|
|
1355
|
+
encodedToAssetId,
|
|
1356
|
+
encodedMarketAddr,
|
|
1357
|
+
encodedAmountToSwitch,
|
|
1358
|
+
encodedUseOnBehalf,
|
|
1359
|
+
];
|
|
1360
|
+
},
|
|
1361
|
+
decode(subData: SubData): {
|
|
1362
|
+
fromAsset: EthereumAddress,
|
|
1363
|
+
fromAssetId: number,
|
|
1364
|
+
toAsset: EthereumAddress,
|
|
1365
|
+
toAssetId: number,
|
|
1366
|
+
marketAddr: EthereumAddress,
|
|
1367
|
+
amountToSwitch: string,
|
|
1368
|
+
} {
|
|
1369
|
+
const fromAsset = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1370
|
+
const fromAssetId = Number(AbiCoder.decodeParameter('uint8', subData[1]));
|
|
1371
|
+
const toAsset = AbiCoder.decodeParameter('address', subData[2]) as unknown as EthereumAddress;
|
|
1372
|
+
const toAssetId = Number(AbiCoder.decodeParameter('uint8', subData[3]));
|
|
1373
|
+
const marketAddr = AbiCoder.decodeParameter('address', subData[4]) as unknown as EthereumAddress;
|
|
1374
|
+
const amountToSwitch = AbiCoder.decodeParameter('uint256', subData[5]) as unknown as string;
|
|
1375
|
+
|
|
1376
|
+
return {
|
|
1377
|
+
fromAsset, fromAssetId, toAsset, toAssetId, marketAddr, amountToSwitch,
|
|
1378
|
+
};
|
|
1379
|
+
},
|
|
1380
|
+
};
|
|
1381
|
+
|
|
1382
|
+
|
|
1383
|
+
/**
|
|
1384
|
+
______ .______ ____ ____ __ __ _______. _______
|
|
1385
|
+
/ || _ \ \ \ / / | | | | / || \
|
|
1386
|
+
| ,----'| |_) | \ \/ / | | | | | (----`| .--. |
|
|
1387
|
+
| | | / \ / | | | | \ \ | | | |
|
|
1388
|
+
| `----.| |\ \----. \ / | `--' | .----) | | '--' |
|
|
1389
|
+
\______|| _| `._____| \__/ \______/ |_______/ |_______/
|
|
1390
|
+
*/
|
|
1391
|
+
export const crvUSDLeverageManagementSubData = {
|
|
1392
|
+
encode: (
|
|
1393
|
+
controllerAddr: EthereumAddress,
|
|
1394
|
+
ratioState: RatioState,
|
|
1395
|
+
targetRatio: number,
|
|
1396
|
+
collTokenAddr: EthereumAddress,
|
|
1397
|
+
crvUSDAddr: EthereumAddress,
|
|
1398
|
+
) => {
|
|
1399
|
+
const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
|
|
1400
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
1401
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
1402
|
+
const collTokenAddrEncoded = AbiCoder.encodeParameter('address', collTokenAddr);
|
|
1403
|
+
const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
|
|
1404
|
+
return [controllerAddrEncoded, ratioStateEncoded, targetRatioEncoded, collTokenAddrEncoded, crvUSDAddrEncoded];
|
|
1405
|
+
},
|
|
1406
|
+
decode: (subData: SubData) => {
|
|
1407
|
+
const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1408
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[2]) as any as string;
|
|
1409
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1410
|
+
|
|
1411
|
+
return { controller, targetRatio };
|
|
1412
|
+
},
|
|
1413
|
+
};
|
|
1414
|
+
export const crvUSDPaybackSubData = {
|
|
1415
|
+
encode: (
|
|
1416
|
+
controllerAddr: EthereumAddress,
|
|
1417
|
+
addressToPullTokensFrom: EthereumAddress,
|
|
1418
|
+
positionOwner: EthereumAddress,
|
|
1419
|
+
paybackAmount: string,
|
|
1420
|
+
crvUSDAddr: EthereumAddress,
|
|
1421
|
+
) => {
|
|
1422
|
+
const controllerAddrEncoded = AbiCoder.encodeParameter('address', controllerAddr);
|
|
1423
|
+
const addressToPullTokensFromEncoded = AbiCoder.encodeParameter('address', addressToPullTokensFrom);
|
|
1424
|
+
const positionOwnerEncoded = AbiCoder.encodeParameter('address', positionOwner);
|
|
1425
|
+
const paybackAmountEncoded = AbiCoder.encodeParameter('uint256', toWei(paybackAmount, 'ether'));
|
|
1426
|
+
const crvUSDAddrEncoded = AbiCoder.encodeParameter('address', crvUSDAddr);
|
|
1427
|
+
return [
|
|
1428
|
+
controllerAddrEncoded,
|
|
1429
|
+
addressToPullTokensFromEncoded,
|
|
1430
|
+
positionOwnerEncoded,
|
|
1431
|
+
paybackAmountEncoded,
|
|
1432
|
+
crvUSDAddrEncoded,
|
|
1433
|
+
];
|
|
1434
|
+
},
|
|
1435
|
+
decode: (subData: SubData) => {
|
|
1436
|
+
const controller = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1437
|
+
const addressToPullTokensFrom = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
1438
|
+
const positionOwner = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
1439
|
+
const weiPaybackAmount = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
1440
|
+
const paybackAmount = fromWei(weiPaybackAmount, 'ether');
|
|
1441
|
+
return {
|
|
1442
|
+
controller,
|
|
1443
|
+
addressToPullTokensFrom,
|
|
1444
|
+
positionOwner,
|
|
1445
|
+
paybackAmount,
|
|
1446
|
+
};
|
|
1447
|
+
},
|
|
1448
|
+
};
|
|
1449
|
+
|
|
1450
|
+
/**
|
|
1451
|
+
.___ ___. ______ .______ .______ __ __ ______
|
|
1452
|
+
| \/ | / __ \ | _ \ | _ \ | | | | / __ \
|
|
1453
|
+
| \ / | | | | | | |_) | | |_) | | |__| | | | | |
|
|
1454
|
+
| |\/| | | | | | | / | ___/ | __ | | | | |
|
|
1455
|
+
| | | | | `--' | | |\ \----.| | | | | | | `--' |
|
|
1456
|
+
|__| |__| \______/ | _| `._____|| _| |__| |__| \______/
|
|
1457
|
+
*/
|
|
1458
|
+
export const morphoBlueLeverageManagementSubData = {
|
|
1459
|
+
encode: (
|
|
1460
|
+
loanToken: EthereumAddress,
|
|
1461
|
+
collToken: EthereumAddress,
|
|
1462
|
+
oracle: EthereumAddress,
|
|
1463
|
+
irm: EthereumAddress,
|
|
1464
|
+
lltv: string,
|
|
1465
|
+
ratioState: RatioState,
|
|
1466
|
+
targetRatio: number,
|
|
1467
|
+
user: EthereumAddress,
|
|
1468
|
+
isEOA: boolean,
|
|
1469
|
+
) => {
|
|
1470
|
+
const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
|
|
1471
|
+
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
1472
|
+
const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
|
|
1473
|
+
const irmEncoded = AbiCoder.encodeParameter('address', irm);
|
|
1474
|
+
const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
|
|
1475
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
1476
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
1477
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1478
|
+
const isEOAEncoded = AbiCoder.encodeParameter('bool', isEOA);
|
|
1479
|
+
return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, ratioStateEncoded, targetRatioEncoded, userEncoded, isEOAEncoded];
|
|
1480
|
+
},
|
|
1481
|
+
decode: (subData: SubData) => {
|
|
1482
|
+
const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1483
|
+
const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
1484
|
+
const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
1485
|
+
const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
1486
|
+
const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
|
|
1487
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[6]) as any as EthereumAddress;
|
|
1488
|
+
const user = AbiCoder.decodeParameter('address', subData[7]) as any as EthereumAddress;
|
|
1489
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1490
|
+
|
|
1491
|
+
return {
|
|
1492
|
+
loanToken,
|
|
1493
|
+
collToken,
|
|
1494
|
+
oracle,
|
|
1495
|
+
irm,
|
|
1496
|
+
lltv,
|
|
1497
|
+
user,
|
|
1498
|
+
targetRatio,
|
|
1499
|
+
};
|
|
1500
|
+
},
|
|
1501
|
+
};
|
|
1502
|
+
export const morphoBlueLeverageManagementOnPriceSubData = {
|
|
1503
|
+
encode(
|
|
1504
|
+
loanToken: EthereumAddress,
|
|
1505
|
+
collToken: EthereumAddress,
|
|
1506
|
+
oracle: EthereumAddress,
|
|
1507
|
+
irm: EthereumAddress,
|
|
1508
|
+
lltv: string,
|
|
1509
|
+
targetRatio: number,
|
|
1510
|
+
user: EthereumAddress,
|
|
1511
|
+
): SubData {
|
|
1512
|
+
const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
|
|
1513
|
+
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
1514
|
+
const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
|
|
1515
|
+
const irmEncoded = AbiCoder.encodeParameter('address', irm);
|
|
1516
|
+
const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
|
|
1517
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
1518
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1519
|
+
return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, targetRatioEncoded, userEncoded];
|
|
1520
|
+
},
|
|
1521
|
+
decode(subData: SubData) {
|
|
1522
|
+
const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1523
|
+
const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
1524
|
+
const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
1525
|
+
const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
1526
|
+
const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
|
|
1527
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[5]) as any as EthereumAddress;
|
|
1528
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1529
|
+
const user = AbiCoder.decodeParameter('address', subData[6]) as any as EthereumAddress;
|
|
1530
|
+
|
|
1531
|
+
return {
|
|
1532
|
+
loanToken,
|
|
1533
|
+
collToken,
|
|
1534
|
+
oracle,
|
|
1535
|
+
irm,
|
|
1536
|
+
lltv,
|
|
1537
|
+
targetRatio,
|
|
1538
|
+
user,
|
|
1539
|
+
};
|
|
1540
|
+
},
|
|
1541
|
+
};
|
|
1542
|
+
export const morphoBlueCloseOnPriceSubData = {
|
|
1543
|
+
encode(
|
|
1544
|
+
loanToken: EthereumAddress,
|
|
1545
|
+
collToken: EthereumAddress,
|
|
1546
|
+
oracle: EthereumAddress,
|
|
1547
|
+
irm: EthereumAddress,
|
|
1548
|
+
lltv: string,
|
|
1549
|
+
user: EthereumAddress,
|
|
1550
|
+
closeType: CloseStrategyType,
|
|
1551
|
+
): SubData {
|
|
1552
|
+
const loanTokenEncoded = AbiCoder.encodeParameter('address', loanToken);
|
|
1553
|
+
const collTokenEncoded = AbiCoder.encodeParameter('address', collToken);
|
|
1554
|
+
const oracleEncoded = AbiCoder.encodeParameter('address', oracle);
|
|
1555
|
+
const irmEncoded = AbiCoder.encodeParameter('address', irm);
|
|
1556
|
+
const lltvEncoded = AbiCoder.encodeParameter('uint256', lltv);
|
|
1557
|
+
const userEncoded = AbiCoder.encodeParameter('address', user);
|
|
1558
|
+
const closeTypeEncoded = AbiCoder.encodeParameter('uint8', closeType);
|
|
1559
|
+
return [loanTokenEncoded, collTokenEncoded, oracleEncoded, irmEncoded, lltvEncoded, userEncoded, closeTypeEncoded];
|
|
1560
|
+
},
|
|
1561
|
+
decode(subData: SubData) {
|
|
1562
|
+
const loanToken = AbiCoder.decodeParameter('address', subData[0]) as unknown as EthereumAddress;
|
|
1563
|
+
const collToken = AbiCoder.decodeParameter('address', subData[1]) as any as EthereumAddress;
|
|
1564
|
+
const oracle = AbiCoder.decodeParameter('address', subData[2]) as any as EthereumAddress;
|
|
1565
|
+
const irm = AbiCoder.decodeParameter('address', subData[3]) as any as EthereumAddress;
|
|
1566
|
+
const lltv = AbiCoder.decodeParameter('uint256', subData[4]) as any as EthereumAddress;
|
|
1567
|
+
const user = AbiCoder.decodeParameter('address', subData[5]) as any as EthereumAddress;
|
|
1568
|
+
const closeType = Number(AbiCoder.decodeParameter('uint8', subData[6])) as CloseStrategyType;
|
|
1569
|
+
|
|
1570
|
+
return {
|
|
1571
|
+
loanToken,
|
|
1572
|
+
collToken,
|
|
1573
|
+
oracle,
|
|
1574
|
+
irm,
|
|
1575
|
+
lltv,
|
|
1576
|
+
user,
|
|
1577
|
+
closeType,
|
|
1578
|
+
};
|
|
1579
|
+
},
|
|
1580
|
+
};
|
|
1581
|
+
|
|
1582
|
+
/**
|
|
1583
|
+
_______ __ __ __ __ _______
|
|
1584
|
+
| ____|| | | | | | | | | \
|
|
1585
|
+
| |__ | | | | | | | | | .--. |
|
|
1586
|
+
| __| | | | | | | | | | | | |
|
|
1587
|
+
| | | `----.| `--' | | | | '--' |
|
|
1588
|
+
|__| |_______| \______/ |__| |_______/
|
|
1589
|
+
*/
|
|
1590
|
+
export const fluidLeverageManagementSubData = {
|
|
1591
|
+
encode: (
|
|
1592
|
+
nftId: string,
|
|
1593
|
+
vault: EthereumAddress,
|
|
1594
|
+
ratioState: RatioState,
|
|
1595
|
+
targetRatio: number,
|
|
1596
|
+
) => {
|
|
1597
|
+
const nftIdEncoded = AbiCoder.encodeParameter('uint256', nftId);
|
|
1598
|
+
const vaultEncoded = AbiCoder.encodeParameter('address', vault);
|
|
1599
|
+
const ratioStateEncoded = AbiCoder.encodeParameter('uint8', ratioState);
|
|
1600
|
+
const targetRatioEncoded = AbiCoder.encodeParameter('uint256', ratioPercentageToWei(targetRatio));
|
|
1601
|
+
const wrapEthEncoded = AbiCoder.encodeParameter('bool', true);
|
|
1602
|
+
|
|
1603
|
+
const isRepay = ratioState === RatioState.UNDER;
|
|
1604
|
+
const collActionType = isRepay ? CollActionType.WITHDRAW : CollActionType.SUPPLY;
|
|
1605
|
+
const debtActionType = isRepay ? DebtActionType.PAYBACK : DebtActionType.BORROW;
|
|
1606
|
+
|
|
1607
|
+
const collActionTypeEncoded = AbiCoder.encodeParameter('uint8', collActionType);
|
|
1608
|
+
const debtActionTypeEncoded = AbiCoder.encodeParameter('uint8', debtActionType);
|
|
1609
|
+
|
|
1610
|
+
return [
|
|
1611
|
+
nftIdEncoded,
|
|
1612
|
+
vaultEncoded,
|
|
1613
|
+
ratioStateEncoded,
|
|
1614
|
+
targetRatioEncoded,
|
|
1615
|
+
wrapEthEncoded,
|
|
1616
|
+
collActionTypeEncoded,
|
|
1617
|
+
debtActionTypeEncoded,
|
|
1618
|
+
];
|
|
1619
|
+
},
|
|
1620
|
+
decode: (subData: SubData) => {
|
|
1621
|
+
const nftId = AbiCoder.decodeParameter('uint256', subData[0]) as any as string;
|
|
1622
|
+
const vault = AbiCoder.decodeParameter('address', subData[1]) as unknown as EthereumAddress;
|
|
1623
|
+
const ratioState = AbiCoder.decodeParameter('uint8', subData[2]) as any as RatioState;
|
|
1624
|
+
const weiRatio = AbiCoder.decodeParameter('uint256', subData[3]) as any as string;
|
|
1625
|
+
const targetRatio = weiToRatioPercentage(weiRatio);
|
|
1626
|
+
|
|
1627
|
+
return {
|
|
1628
|
+
nftId, vault, ratioState, targetRatio,
|
|
1629
|
+
};
|
|
1630
|
+
},
|
|
1631
|
+
};
|