@instadapp/avocado-base 0.0.0-dev.0e37fd2 → 0.0.0-dev.0f85f1a
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/abi/forwarder.json +1253 -149
- package/components/ChainLogo.vue +1 -1
- package/contracts/Forwarder.ts +856 -2
- package/contracts/factories/Forwarder__factory.ts +816 -16
- package/package.json +1 -1
- package/utils/formatter.ts +49 -6
- package/utils/metadata.ts +93 -2
- package/utils/network.ts +34 -10
- package/utils/utils.d.ts +19 -1
package/package.json
CHANGED
package/utils/formatter.ts
CHANGED
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
export function formatPercent(
|
|
2
|
-
value
|
|
2
|
+
value?: number | string,
|
|
3
3
|
fractionDigits = 2,
|
|
4
4
|
maxValue = null
|
|
5
5
|
) {
|
|
6
|
-
if (isZero(value)) return "0.00%";
|
|
6
|
+
if (!value || isZero(value)) return "0.00%";
|
|
7
7
|
|
|
8
|
-
|
|
8
|
+
const valueAsNumber = toBN(value).toNumber();
|
|
9
|
+
|
|
10
|
+
if (maxValue && gt(times(valueAsNumber, "100"), maxValue))
|
|
11
|
+
return `>${maxValue}%`;
|
|
9
12
|
|
|
10
13
|
const formatter = new Intl.NumberFormat("en-US", {
|
|
11
14
|
style: "percent",
|
|
@@ -13,7 +16,7 @@ export function formatPercent(
|
|
|
13
16
|
maximumFractionDigits: fractionDigits,
|
|
14
17
|
});
|
|
15
18
|
|
|
16
|
-
return formatter.format(
|
|
19
|
+
return formatter.format(valueAsNumber);
|
|
17
20
|
}
|
|
18
21
|
|
|
19
22
|
export function shortenHash(hash: string, length: number = 4) {
|
|
@@ -42,10 +45,50 @@ export function signedNumber(numb: string | number) {
|
|
|
42
45
|
}).format(toBN(numb).toNumber());
|
|
43
46
|
}
|
|
44
47
|
|
|
45
|
-
|
|
48
|
+
function getFractionDigits(value: string | number) {
|
|
49
|
+
const absoluteValue = toBN(value).abs();
|
|
50
|
+
|
|
51
|
+
if (isZero(absoluteValue)) {
|
|
52
|
+
return 2;
|
|
53
|
+
} else if (lt(absoluteValue, 0.01)) {
|
|
54
|
+
return 6;
|
|
55
|
+
} else if (lt(absoluteValue, 1)) {
|
|
56
|
+
return 4;
|
|
57
|
+
} else if (lt(absoluteValue, 10000)) {
|
|
58
|
+
return 2;
|
|
59
|
+
} else {
|
|
60
|
+
return 0;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
export function formatDecimal(value: string | number, fractionDigits?: number) {
|
|
46
65
|
if (!value) {
|
|
47
66
|
value = "0";
|
|
48
67
|
}
|
|
68
|
+
if (lt(value, "0.0001") && gt(value, "0")) {
|
|
69
|
+
return "< 0.0001";
|
|
70
|
+
} else {
|
|
71
|
+
const num = toBN(value);
|
|
72
|
+
let decimals;
|
|
73
|
+
|
|
74
|
+
if (num.lt(1)) {
|
|
75
|
+
decimals = 8;
|
|
76
|
+
} else if (num.lt(10)) {
|
|
77
|
+
decimals = 6;
|
|
78
|
+
} else if (num.lt(100)) {
|
|
79
|
+
decimals = 4;
|
|
80
|
+
} else if (num.lt(1000)) {
|
|
81
|
+
decimals = 3;
|
|
82
|
+
} else if (num.lt(10000)) {
|
|
83
|
+
decimals = 2;
|
|
84
|
+
} else if (num.lt(100000)) {
|
|
85
|
+
decimals = 1;
|
|
86
|
+
} else {
|
|
87
|
+
decimals = 0;
|
|
88
|
+
}
|
|
49
89
|
|
|
50
|
-
|
|
90
|
+
const formattedNumber = num.toFixed(fractionDigits || decimals);
|
|
91
|
+
|
|
92
|
+
return toBN(formattedNumber).toFormat();
|
|
93
|
+
}
|
|
51
94
|
}
|
package/utils/metadata.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ethers, utils } from "ethers";
|
|
2
|
-
import { Forwarder__factory } from "
|
|
2
|
+
import { Forwarder__factory } from "../contracts";
|
|
3
3
|
|
|
4
4
|
const multiMetadataTypes = ["bytes[]"];
|
|
5
5
|
|
|
@@ -7,6 +7,13 @@ const metadataTypes = ["bytes32 type", "uint8 version", "bytes data"];
|
|
|
7
7
|
|
|
8
8
|
const actionMetadataTypes = {
|
|
9
9
|
transfer: ["address token", "uint256 amount", "address receiver"],
|
|
10
|
+
"cross-transfer": [
|
|
11
|
+
"address fromToken",
|
|
12
|
+
"address toToken",
|
|
13
|
+
"uint256 toChainId",
|
|
14
|
+
"uint256 amount",
|
|
15
|
+
"address receiver",
|
|
16
|
+
],
|
|
10
17
|
bridge: [
|
|
11
18
|
"uint256 amount",
|
|
12
19
|
"address receiver",
|
|
@@ -27,6 +34,7 @@ const actionMetadataTypes = {
|
|
|
27
34
|
"gas-topup": ["uint256 amount", "address token", "address onBehalf"],
|
|
28
35
|
upgrade: ["bytes32 version", "address walletImpl"],
|
|
29
36
|
dapp: ["string name", "string url"],
|
|
37
|
+
auth: ["address address", "uint256 chainId", "bool remove"],
|
|
30
38
|
deploy: [],
|
|
31
39
|
permit2: [
|
|
32
40
|
"address token",
|
|
@@ -34,6 +42,7 @@ const actionMetadataTypes = {
|
|
|
34
42
|
"uint160 amount",
|
|
35
43
|
"uint48 expiration",
|
|
36
44
|
],
|
|
45
|
+
"instadapp-pro": ["string castDetails"],
|
|
37
46
|
};
|
|
38
47
|
|
|
39
48
|
const encodeMetadata = (props: MetadataProps) => {
|
|
@@ -78,6 +87,46 @@ export const encodeTransferMetadata = (
|
|
|
78
87
|
return single ? encodeMultipleActions(data) : data;
|
|
79
88
|
};
|
|
80
89
|
|
|
90
|
+
export const encodeCrossTransferMetadata = (
|
|
91
|
+
params: CrossSendMetadataProps,
|
|
92
|
+
single = true
|
|
93
|
+
) => {
|
|
94
|
+
const encodedData = ethers.utils.defaultAbiCoder.encode(
|
|
95
|
+
actionMetadataTypes["cross-transfer"],
|
|
96
|
+
[
|
|
97
|
+
params.fromToken,
|
|
98
|
+
params.toToken,
|
|
99
|
+
params.toChainId,
|
|
100
|
+
params.amount,
|
|
101
|
+
params.receiver,
|
|
102
|
+
]
|
|
103
|
+
);
|
|
104
|
+
|
|
105
|
+
const data = encodeMetadata({
|
|
106
|
+
type: "cross-transfer",
|
|
107
|
+
encodedData,
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
return single ? encodeMultipleActions(data) : data;
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
export const encodeAuthMetadata = (
|
|
114
|
+
params: AuthMetadataProps,
|
|
115
|
+
single = true
|
|
116
|
+
) => {
|
|
117
|
+
const encodedData = ethers.utils.defaultAbiCoder.encode(
|
|
118
|
+
actionMetadataTypes["auth"],
|
|
119
|
+
[params.address, params.chainId, params.remove]
|
|
120
|
+
);
|
|
121
|
+
|
|
122
|
+
const data = encodeMetadata({
|
|
123
|
+
type: "auth",
|
|
124
|
+
encodedData,
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
return single ? encodeMultipleActions(data) : data;
|
|
128
|
+
};
|
|
129
|
+
|
|
81
130
|
export const encodeDeployMetadata = (single = true) => {
|
|
82
131
|
const data = encodeMetadata({
|
|
83
132
|
type: "deploy",
|
|
@@ -208,7 +257,7 @@ export const decodeMetadata = (data: string) => {
|
|
|
208
257
|
} else {
|
|
209
258
|
metadata = executeData.metadata_;
|
|
210
259
|
}
|
|
211
|
-
} else {
|
|
260
|
+
} else if (data.startsWith("0x14f80a8d")) {
|
|
212
261
|
const executeDataV2 = iface.decodeFunctionData("executeV2", data);
|
|
213
262
|
if (
|
|
214
263
|
executeDataV2.params_.metadata === "0x" ||
|
|
@@ -218,6 +267,16 @@ export const decodeMetadata = (data: string) => {
|
|
|
218
267
|
} else {
|
|
219
268
|
metadata = executeDataV2.params_.metadata;
|
|
220
269
|
}
|
|
270
|
+
} else {
|
|
271
|
+
const executeDataV3 = iface.decodeFunctionData("executeV3", data);
|
|
272
|
+
if (
|
|
273
|
+
executeDataV3.params_.metadata === "0x" ||
|
|
274
|
+
!executeDataV3.params_.metadata
|
|
275
|
+
) {
|
|
276
|
+
return null;
|
|
277
|
+
} else {
|
|
278
|
+
metadata = executeDataV3.params_.metadata;
|
|
279
|
+
}
|
|
221
280
|
}
|
|
222
281
|
|
|
223
282
|
const metadataArr = [];
|
|
@@ -302,6 +361,7 @@ export const decodeMetadata = (data: string) => {
|
|
|
302
361
|
payload = {
|
|
303
362
|
type,
|
|
304
363
|
};
|
|
364
|
+
break;
|
|
305
365
|
|
|
306
366
|
case "permit2":
|
|
307
367
|
payload = {
|
|
@@ -311,6 +371,37 @@ export const decodeMetadata = (data: string) => {
|
|
|
311
371
|
amount: toBN(decodedData.amount).toFixed(),
|
|
312
372
|
expiration: decodedData.expiration,
|
|
313
373
|
};
|
|
374
|
+
break;
|
|
375
|
+
|
|
376
|
+
case "cross-transfer":
|
|
377
|
+
payload = {
|
|
378
|
+
type,
|
|
379
|
+
fromToken: decodedData.fromToken,
|
|
380
|
+
toToken: decodedData.toToken,
|
|
381
|
+
toChainId: decodedData.toChainId
|
|
382
|
+
? decodedData.toChainId.toString()
|
|
383
|
+
: null,
|
|
384
|
+
amount: toBN(decodedData.amount).toFixed(),
|
|
385
|
+
receiver: decodedData.receiver,
|
|
386
|
+
};
|
|
387
|
+
|
|
388
|
+
break;
|
|
389
|
+
case "auth":
|
|
390
|
+
payload = {
|
|
391
|
+
type: decodedData.remove ? "remove-authority" : "add-authority",
|
|
392
|
+
address: decodedData.address,
|
|
393
|
+
chainId: decodedData.chainId
|
|
394
|
+
? decodedData.chainId.toString()
|
|
395
|
+
: null,
|
|
396
|
+
remove: decodedData.remove,
|
|
397
|
+
};
|
|
398
|
+
|
|
399
|
+
break;
|
|
400
|
+
case "instadapp-pro":
|
|
401
|
+
payload = {
|
|
402
|
+
type,
|
|
403
|
+
castDetails: decodedData.castDetails,
|
|
404
|
+
};
|
|
314
405
|
|
|
315
406
|
break;
|
|
316
407
|
}
|
package/utils/network.ts
CHANGED
|
@@ -7,8 +7,10 @@ export const networks: Network[] = [
|
|
|
7
7
|
name: "Mainnet",
|
|
8
8
|
debankName: "eth",
|
|
9
9
|
ankrName: "eth",
|
|
10
|
+
zerionName: "ethereum",
|
|
10
11
|
chainId: 1,
|
|
11
12
|
explorerUrl: "https://etherscan.io",
|
|
13
|
+
color: "#5D5FEF",
|
|
12
14
|
get serverRpcUrl() {
|
|
13
15
|
return process.env?.MAINNET_RPC_URL || this.params.rpcUrls[0];
|
|
14
16
|
},
|
|
@@ -27,6 +29,8 @@ export const networks: Network[] = [
|
|
|
27
29
|
name: "Polygon",
|
|
28
30
|
debankName: "matic",
|
|
29
31
|
ankrName: "polygon",
|
|
32
|
+
zerionName: "polygon",
|
|
33
|
+
color: "#7A4ADD",
|
|
30
34
|
chainId: 137,
|
|
31
35
|
balanceResolverAddress: "0x58632D23120b20650262b8A629a14e4F4043E0D9",
|
|
32
36
|
usdcAddress: "0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174",
|
|
@@ -48,6 +52,8 @@ export const networks: Network[] = [
|
|
|
48
52
|
name: "Arbitrum",
|
|
49
53
|
debankName: "arb",
|
|
50
54
|
ankrName: "arbitrum",
|
|
55
|
+
zerionName: "arbitrum",
|
|
56
|
+
color: "#2D374B",
|
|
51
57
|
chainId: 42161,
|
|
52
58
|
usdcAddress: "0xff970a61a04b1ca14834a43f5de4533ebddb5cc8",
|
|
53
59
|
balanceResolverAddress: "0xca5f37e6D8bB24c5A7958d5eccE7Bd9Aacc944f2",
|
|
@@ -69,6 +75,8 @@ export const networks: Network[] = [
|
|
|
69
75
|
name: "Optimism",
|
|
70
76
|
debankName: "op",
|
|
71
77
|
ankrName: "optimism",
|
|
78
|
+
zerionName: "optimism",
|
|
79
|
+
color: "#FF0420",
|
|
72
80
|
chainId: 10,
|
|
73
81
|
usdcAddress: "0x7f5c764cbc14f9669b88837ca1490cca17c31607",
|
|
74
82
|
balanceResolverAddress: "0xca5f37e6D8bB24c5A7958d5eccE7Bd9Aacc944f2",
|
|
@@ -83,13 +91,15 @@ export const networks: Network[] = [
|
|
|
83
91
|
symbol: "ETH",
|
|
84
92
|
decimals: 18,
|
|
85
93
|
},
|
|
86
|
-
rpcUrls: ["https://
|
|
94
|
+
rpcUrls: ["https://rpc.ankr.com/optimism"],
|
|
87
95
|
},
|
|
88
96
|
},
|
|
89
97
|
{
|
|
90
98
|
name: "Avalanche",
|
|
91
99
|
debankName: "avax",
|
|
92
100
|
ankrName: "avalanche",
|
|
101
|
+
zerionName: "avalanche",
|
|
102
|
+
color: "#EB5757",
|
|
93
103
|
chainId: 43114,
|
|
94
104
|
usdcAddress: "0xb97ef9ef8734c71904d8002f8b6bc66dd9c48a6e",
|
|
95
105
|
balanceResolverAddress: "0x63009f31D054E0ac9F321Cf0D642375236A4Bf1E",
|
|
@@ -104,13 +114,15 @@ export const networks: Network[] = [
|
|
|
104
114
|
symbol: "AVAX",
|
|
105
115
|
decimals: 18,
|
|
106
116
|
},
|
|
107
|
-
rpcUrls: ["https://
|
|
117
|
+
rpcUrls: ["https://rpc.ankr.com/avalanche"],
|
|
108
118
|
},
|
|
109
119
|
},
|
|
110
120
|
{
|
|
111
121
|
name: "BSC",
|
|
112
122
|
debankName: "bsc",
|
|
113
123
|
ankrName: "bsc",
|
|
124
|
+
zerionName: "binance-smart-chain",
|
|
125
|
+
color: "#F3BA2F",
|
|
114
126
|
chainId: 56,
|
|
115
127
|
explorerUrl: "https://bscscan.com",
|
|
116
128
|
usdcAddress: "0x8ac76a51cc950d9822d68b83fe1ad97b32cd580d",
|
|
@@ -131,7 +143,8 @@ export const networks: Network[] = [
|
|
|
131
143
|
{
|
|
132
144
|
name: "Gnosis",
|
|
133
145
|
debankName: "xdai",
|
|
134
|
-
|
|
146
|
+
zerionName: "xdai",
|
|
147
|
+
color: "#04795C",
|
|
135
148
|
chainId: 100,
|
|
136
149
|
balanceResolverAddress: "0xfaa244e276b1597f663975ed007ee4ff70d27849",
|
|
137
150
|
explorerUrl: "https://gnosisscan.io",
|
|
@@ -152,6 +165,7 @@ export const networks: Network[] = [
|
|
|
152
165
|
{
|
|
153
166
|
name: "Polygon zkEVM",
|
|
154
167
|
chainId: 1101,
|
|
168
|
+
color: "#8544f6",
|
|
155
169
|
explorerUrl: "https://zkevm.polygonscan.com",
|
|
156
170
|
balanceResolverAddress: "0x48D1Fa5Ee6691a1E0B45d2B515650997BEA27a01",
|
|
157
171
|
usdcAddress: "0xa8ce8aee21bc2a48a5ef670afcc9274c7bbbc035",
|
|
@@ -160,7 +174,7 @@ export const networks: Network[] = [
|
|
|
160
174
|
},
|
|
161
175
|
params: {
|
|
162
176
|
chainName: "polygon zkEVM",
|
|
163
|
-
rpcUrls: ["https://rpc.
|
|
177
|
+
rpcUrls: ["https://zkevm-rpc.com"],
|
|
164
178
|
|
|
165
179
|
nativeCurrency: {
|
|
166
180
|
name: "Ethereum",
|
|
@@ -172,6 +186,8 @@ export const networks: Network[] = [
|
|
|
172
186
|
{
|
|
173
187
|
name: "Aurora",
|
|
174
188
|
chainId: 1313161554,
|
|
189
|
+
zerionName: "aurora",
|
|
190
|
+
color: "#78d64b",
|
|
175
191
|
explorerUrl: "https://explorer.mainnet.aurora.dev",
|
|
176
192
|
get serverRpcUrl() {
|
|
177
193
|
return process.env?.AURORA_RPC_URL || this.params.rpcUrls[0];
|
|
@@ -189,9 +205,12 @@ export const networks: Network[] = [
|
|
|
189
205
|
},
|
|
190
206
|
},
|
|
191
207
|
{
|
|
192
|
-
name: "Fantom
|
|
208
|
+
name: "Fantom",
|
|
193
209
|
chainId: 250,
|
|
210
|
+
zerionName: "fantom",
|
|
194
211
|
explorerUrl: "https://ftmscan.com",
|
|
212
|
+
ankrName: "fantom",
|
|
213
|
+
color: "#1969ff",
|
|
195
214
|
get serverRpcUrl() {
|
|
196
215
|
return process.env?.FANTOM_RPC_URL || this.params.rpcUrls[0];
|
|
197
216
|
},
|
|
@@ -199,7 +218,7 @@ export const networks: Network[] = [
|
|
|
199
218
|
balanceResolverAddress: "0x929376c77a2fb8152375a089a4fccf84ff481479",
|
|
200
219
|
params: {
|
|
201
220
|
rpcUrls: ["https://rpc.ankr.com/fantom"],
|
|
202
|
-
chainName: "Fantom
|
|
221
|
+
chainName: "Fantom",
|
|
203
222
|
nativeCurrency: {
|
|
204
223
|
name: "Fantom",
|
|
205
224
|
symbol: "FTM",
|
|
@@ -212,6 +231,7 @@ export const networks: Network[] = [
|
|
|
212
231
|
chainId: AVO_PROD_CHAIN_ID,
|
|
213
232
|
isAvocado: true,
|
|
214
233
|
balanceResolverAddress: "",
|
|
234
|
+
color: "#16A34A",
|
|
215
235
|
usdcAddress: "",
|
|
216
236
|
serverRpcUrl: AVO_PROD_RPC_URL,
|
|
217
237
|
explorerUrl: AVO_PROD_EXPLORER_URL,
|
|
@@ -230,6 +250,7 @@ export const networks: Network[] = [
|
|
|
230
250
|
name: AVO_STAGING_CHAIN_NAME,
|
|
231
251
|
chainId: AVO_STAGING_CHAIN_ID,
|
|
232
252
|
serverRpcUrl: AVO_STAGING_RPC_URL,
|
|
253
|
+
color: "#16A34A",
|
|
233
254
|
explorerUrl: AVO_STAGING_EXPLORER_URL,
|
|
234
255
|
isAvocado: true,
|
|
235
256
|
balanceResolverAddress: "",
|
|
@@ -274,13 +295,16 @@ export const RPCMap = networks.reduce((acc, network) => {
|
|
|
274
295
|
|
|
275
296
|
export const networkIds = networks.map((network) => network.chainId);
|
|
276
297
|
|
|
277
|
-
const rpcInstances: Record<string, ethers.providers.
|
|
278
|
-
const serverRpcInstances: Record<
|
|
298
|
+
const rpcInstances: Record<string, ethers.providers.StaticJsonRpcProvider> = {};
|
|
299
|
+
const serverRpcInstances: Record<
|
|
300
|
+
string,
|
|
301
|
+
ethers.providers.StaticJsonRpcProvider
|
|
302
|
+
> = {};
|
|
279
303
|
|
|
280
304
|
export const getServerRpcProvider = (chainId: number | string) => {
|
|
281
305
|
if (!rpcInstances[chainId]) {
|
|
282
306
|
const network = networks.find((n) => n.chainId == chainId);
|
|
283
|
-
serverRpcInstances[chainId] = new ethers.providers.
|
|
307
|
+
serverRpcInstances[chainId] = new ethers.providers.StaticJsonRpcProvider(
|
|
284
308
|
network?.serverRpcUrl
|
|
285
309
|
);
|
|
286
310
|
}
|
|
@@ -290,7 +314,7 @@ export const getServerRpcProvider = (chainId: number | string) => {
|
|
|
290
314
|
|
|
291
315
|
export const getRpcProvider = (chainId: number | string) => {
|
|
292
316
|
if (!rpcInstances[chainId]) {
|
|
293
|
-
rpcInstances[chainId] = new ethers.providers.
|
|
317
|
+
rpcInstances[chainId] = new ethers.providers.StaticJsonRpcProvider(
|
|
294
318
|
getRpcURLByChainId(Number(chainId))
|
|
295
319
|
);
|
|
296
320
|
}
|
package/utils/utils.d.ts
CHANGED
|
@@ -18,7 +18,9 @@ interface Network {
|
|
|
18
18
|
name: string;
|
|
19
19
|
debankName?: string;
|
|
20
20
|
ankrName?: string;
|
|
21
|
+
zerionName?: string;
|
|
21
22
|
chainId: ChainId;
|
|
23
|
+
color: string;
|
|
22
24
|
isAvocado?: boolean;
|
|
23
25
|
serverRpcUrl: string | undefined;
|
|
24
26
|
balanceResolverAddress?: string;
|
|
@@ -54,6 +56,20 @@ type SendMetadataProps = {
|
|
|
54
56
|
receiver: string;
|
|
55
57
|
};
|
|
56
58
|
|
|
59
|
+
type CrossSendMetadataProps = {
|
|
60
|
+
fromToken: string;
|
|
61
|
+
toToken: string;
|
|
62
|
+
toChainId: string;
|
|
63
|
+
amount: string;
|
|
64
|
+
receiver: string;
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
type AuthMetadataProps = {
|
|
68
|
+
address: string;
|
|
69
|
+
chainId: string;
|
|
70
|
+
remove: boolean;
|
|
71
|
+
};
|
|
72
|
+
|
|
57
73
|
type UpgradeMetadataProps = {
|
|
58
74
|
version: string;
|
|
59
75
|
walletImpl: string;
|
|
@@ -94,7 +110,9 @@ type MetadataProps = {
|
|
|
94
110
|
| "upgrade"
|
|
95
111
|
| "dapp"
|
|
96
112
|
| "deploy"
|
|
97
|
-
| "permit2"
|
|
113
|
+
| "permit2"
|
|
114
|
+
| "cross-transfer"
|
|
115
|
+
| "auth";
|
|
98
116
|
encodedData: string;
|
|
99
117
|
version?: string;
|
|
100
118
|
};
|