@instadapp/avocado-base 0.0.0-dev.f5f443b → 0.0.0-dev.fa14908

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.
Files changed (77) hide show
  1. package/abi/forwarder.json +8 -8
  2. package/app.vue +7 -0
  3. package/assets/images/icons/arrow-left.svg +5 -0
  4. package/assets/images/icons/arrow-right.svg +5 -0
  5. package/assets/images/icons/avocado.svg +4 -0
  6. package/assets/images/icons/bridge-2.svg +3 -0
  7. package/assets/images/icons/bridge.svg +7 -0
  8. package/assets/images/icons/calendar.svg +8 -0
  9. package/assets/images/icons/change-threshold.svg +4 -0
  10. package/assets/images/icons/check-circle.svg +4 -0
  11. package/assets/images/icons/chevron-down.svg +4 -0
  12. package/assets/images/icons/clipboard.svg +7 -0
  13. package/assets/images/icons/clock-circle.svg +5 -0
  14. package/assets/images/icons/copy.svg +5 -0
  15. package/assets/images/icons/cross-transfer.svg +7 -0
  16. package/assets/images/icons/dapp.svg +4 -0
  17. package/assets/images/icons/deploy.svg +12 -0
  18. package/assets/images/icons/error-circle.svg +6 -0
  19. package/assets/images/icons/exclamation-circle.svg +13 -0
  20. package/assets/images/icons/exclamation-octagon.svg +13 -0
  21. package/assets/images/icons/exclamation-triangle.svg +5 -0
  22. package/assets/images/icons/external-link.svg +6 -0
  23. package/assets/images/icons/eye.svg +4 -0
  24. package/assets/images/icons/flowers.svg +8 -0
  25. package/assets/images/icons/gas-emoji.svg +193 -0
  26. package/assets/images/icons/gas.svg +14 -0
  27. package/assets/images/icons/gift.svg +153 -0
  28. package/assets/images/icons/globe.svg +110 -0
  29. package/assets/images/icons/hamburger.svg +6 -0
  30. package/assets/images/icons/instadapp-pro.svg +4 -0
  31. package/assets/images/icons/logout.svg +3 -0
  32. package/assets/images/icons/moon.svg +3 -0
  33. package/assets/images/icons/multi-send.svg +7 -0
  34. package/assets/images/icons/network.svg +13 -0
  35. package/assets/images/icons/options.svg +5 -0
  36. package/assets/images/icons/permit-sign.svg +11 -0
  37. package/assets/images/icons/plus-circle.svg +6 -0
  38. package/assets/images/icons/plus.svg +5 -0
  39. package/assets/images/icons/power-off-bg.svg +24 -0
  40. package/assets/images/icons/power-off.svg +19 -0
  41. package/assets/images/icons/power-on.svg +19 -0
  42. package/assets/images/icons/qr.svg +20 -0
  43. package/assets/images/icons/question-circle.svg +14 -0
  44. package/assets/images/icons/refresh.svg +6 -0
  45. package/assets/images/icons/reject-proposal.svg +6 -0
  46. package/assets/images/icons/search.svg +12 -0
  47. package/assets/images/icons/sun.svg +3 -0
  48. package/assets/images/icons/transfer.svg +5 -0
  49. package/assets/images/icons/trash-2.svg +8 -0
  50. package/assets/images/icons/upgrade.svg +4 -0
  51. package/assets/images/icons/wave.svg +214 -0
  52. package/assets/images/icons/x.svg +5 -0
  53. package/components/ActionLogo.vue +38 -0
  54. package/components/ActionMetadata.vue +72 -0
  55. package/components/AuthorityAvatar.vue +38 -0
  56. package/components/ChainLogo.vue +14 -556
  57. package/components/CopyClipboard.vue +64 -0
  58. package/components/metadata/Bridge.vue +59 -0
  59. package/components/metadata/CrossTransfer.vue +71 -0
  60. package/components/metadata/GasTopup.vue +39 -0
  61. package/components/metadata/Permit2.vue +42 -0
  62. package/components/metadata/Signers.vue +45 -0
  63. package/components/metadata/Swap.vue +74 -0
  64. package/components/metadata/Transfer.vue +50 -0
  65. package/components.d.ts +13 -0
  66. package/contracts/Forwarder.ts +4 -4
  67. package/contracts/factories/Forwarder__factory.ts +8 -8
  68. package/nuxt.config.ts +17 -1
  69. package/package.json +9 -4
  70. package/utils/avocado.ts +2 -0
  71. package/utils/bignumber.ts +20 -0
  72. package/utils/formatter.ts +1 -1
  73. package/utils/helper.ts +8 -0
  74. package/utils/metadata.ts +296 -169
  75. package/utils/network.ts +133 -79
  76. package/utils/services.ts +21 -0
  77. package/utils/utils.d.ts +129 -114
package/utils/metadata.ts CHANGED
@@ -1,11 +1,29 @@
1
1
  import { ethers, utils } from "ethers";
2
2
  import { Forwarder__factory } from "../contracts";
3
3
 
4
+ export const MetadataEnums = {
5
+ "transfer": "transfer",
6
+ "bridge": "bridge",
7
+ "swap": "swap",
8
+ "gas-topup": "gas-topup",
9
+ "upgrade": "upgrade",
10
+ "dapp": "dapp",
11
+ "deploy": "deploy",
12
+ "permit2": "permit2",
13
+ "cross-transfer": "cross-transfer",
14
+ "auth": "auth",
15
+ "rejection": "rejection",
16
+ "instadapp-pro": "instadapp-pro",
17
+ "add-signers": "add-signers",
18
+ "remove-signers": "remove-signers",
19
+ "change-threshold": "change-threshold",
20
+ } as const;
21
+
4
22
  const multiMetadataTypes = ["bytes[]"];
5
23
 
6
24
  const metadataTypes = ["bytes32 type", "uint8 version", "bytes data"];
7
25
 
8
- const actionMetadataTypes = {
26
+ const actionMetadataTypes: Record<MetadataTypes, string[]> = {
9
27
  transfer: ["address token", "uint256 amount", "address receiver"],
10
28
  "cross-transfer": [
11
29
  "address fromToken",
@@ -42,6 +60,11 @@ const actionMetadataTypes = {
42
60
  "uint160 amount",
43
61
  "uint48 expiration",
44
62
  ],
63
+ "instadapp-pro": ["string castDetails"],
64
+ 'add-signers': ['address[] signers'],
65
+ 'remove-signers': ['address[] signers'],
66
+ 'change-threshold': ['uint8 count'],
67
+ 'rejection': ['bytes32 id'],
45
68
  };
46
69
 
47
70
  const encodeMetadata = (props: MetadataProps) => {
@@ -62,7 +85,7 @@ export const encodeDappMetadata = (
62
85
  );
63
86
 
64
87
  const data = encodeMetadata({
65
- type: "dapp",
88
+ type: MetadataEnums.dapp,
66
89
  encodedData,
67
90
  });
68
91
 
@@ -79,7 +102,21 @@ export const encodeTransferMetadata = (
79
102
  );
80
103
 
81
104
  const data = encodeMetadata({
82
- type: "transfer",
105
+ type: MetadataEnums.transfer,
106
+ encodedData,
107
+ });
108
+
109
+ return single ? encodeMultipleActions(data) : data;
110
+ };
111
+
112
+ export const encodeRejectionMetadata = (id: string, single = true) => {
113
+ const encodedData = ethers.utils.defaultAbiCoder.encode(
114
+ actionMetadataTypes.rejection,
115
+ [id]
116
+ );
117
+
118
+ const data = encodeMetadata({
119
+ type: MetadataEnums.rejection,
83
120
  encodedData,
84
121
  });
85
122
 
@@ -102,7 +139,7 @@ export const encodeCrossTransferMetadata = (
102
139
  );
103
140
 
104
141
  const data = encodeMetadata({
105
- type: "cross-transfer",
142
+ type: MetadataEnums["cross-transfer"],
106
143
  encodedData,
107
144
  });
108
145
 
@@ -119,7 +156,7 @@ export const encodeAuthMetadata = (
119
156
  );
120
157
 
121
158
  const data = encodeMetadata({
122
- type: "auth",
159
+ type: MetadataEnums.auth,
123
160
  encodedData,
124
161
  });
125
162
 
@@ -128,7 +165,7 @@ export const encodeAuthMetadata = (
128
165
 
129
166
  export const encodeDeployMetadata = (single = true) => {
130
167
  const data = encodeMetadata({
131
- type: "deploy",
168
+ type: MetadataEnums.deploy,
132
169
  encodedData: "0x",
133
170
  });
134
171
 
@@ -145,7 +182,7 @@ export const encodeWCSignMetadata = (
145
182
  );
146
183
 
147
184
  const data = encodeMetadata({
148
- type: "permit2",
185
+ type: MetadataEnums.permit2,
149
186
  encodedData,
150
187
  });
151
188
 
@@ -162,7 +199,7 @@ export const encodeUpgradeMetadata = (
162
199
  );
163
200
 
164
201
  const data = encodeMetadata({
165
- type: "upgrade",
202
+ type: MetadataEnums.upgrade,
166
203
  encodedData,
167
204
  });
168
205
 
@@ -186,7 +223,7 @@ export const encodeSwapMetadata = (
186
223
  );
187
224
 
188
225
  const data = encodeMetadata({
189
- type: "swap",
226
+ type: MetadataEnums.swap,
190
227
  encodedData,
191
228
  });
192
229
 
@@ -202,10 +239,8 @@ export const encodeTopupMetadata = (
202
239
  [params.amount, params.token, params.onBehalf]
203
240
  );
204
241
 
205
- console.log(params);
206
-
207
242
  const data = encodeMetadata({
208
- type: "gas-topup",
243
+ type: MetadataEnums["gas-topup"],
209
244
  encodedData,
210
245
  });
211
246
 
@@ -230,7 +265,58 @@ export const encodeBridgeMetadata = (
230
265
  );
231
266
 
232
267
  const data = encodeMetadata({
233
- type: "bridge",
268
+ type: MetadataEnums.bridge,
269
+ encodedData,
270
+ });
271
+
272
+ return single ? encodeMultipleActions(data) : data;
273
+ };
274
+
275
+ export const encodeChangeThresholdMetadata = (
276
+ threshold: string | number,
277
+ single = true
278
+ ) => {
279
+ const encodedData = ethers.utils.defaultAbiCoder.encode(
280
+ actionMetadataTypes["change-threshold"],
281
+ [toBN(threshold).toNumber()]
282
+ );
283
+
284
+ const data = encodeMetadata({
285
+ type: MetadataEnums["change-threshold"],
286
+ encodedData,
287
+ });
288
+
289
+ return single ? encodeMultipleActions(data) : data;
290
+ };
291
+
292
+ export const encodeRemoveSignersMetadata = (
293
+ addresses: string[],
294
+ single = true
295
+ ) => {
296
+ const encodedData = ethers.utils.defaultAbiCoder.encode(
297
+ actionMetadataTypes["remove-signers"],
298
+ [addresses]
299
+ );
300
+
301
+ const data = encodeMetadata({
302
+ type: MetadataEnums["remove-signers"],
303
+ encodedData,
304
+ });
305
+
306
+ return single ? encodeMultipleActions(data) : data;
307
+ };
308
+
309
+ export const encodeAddSignersMetadata = (
310
+ addresses: string[],
311
+ single = true
312
+ ) => {
313
+ const encodedData = ethers.utils.defaultAbiCoder.encode(
314
+ actionMetadataTypes["add-signers"],
315
+ [addresses]
316
+ );
317
+
318
+ const data = encodeMetadata({
319
+ type: MetadataEnums["add-signers"],
234
320
  encodedData,
235
321
  });
236
322
 
@@ -241,169 +327,210 @@ export const encodeMultipleActions = (...actionData: string[]) => {
241
327
  return ethers.utils.defaultAbiCoder.encode(multiMetadataTypes, [actionData]);
242
328
  };
243
329
 
244
- export const decodeMetadata = (data: string) => {
330
+ export const decodeData = (data: string) => {
331
+ try {
332
+ const metadata = getMetadataFromData(data) || "0x";
333
+
334
+ return parseMetadata(metadata);
335
+ } catch (e) {
336
+ // console.log(e);
337
+ return null;
338
+ }
339
+ };
340
+
341
+ export const decodeMetadata = (metadata: string) => {
245
342
  try {
246
- const iface = Forwarder__factory.createInterface();
247
- let metadata = "0x";
248
- let payload = {};
249
-
250
- if (!data) return payload;
251
-
252
- if (data.startsWith("0x18e7f485")) {
253
- const executeData = iface.decodeFunctionData("execute", data);
254
- if (executeData.metadata_ === "0x" || !executeData.metadata_) {
255
- return null;
256
- } else {
257
- metadata = executeData.metadata_;
258
- }
259
- } else if (data.startsWith("0x14f80a8d")) {
260
- const executeDataV2 = iface.decodeFunctionData("executeV2", data);
261
- if (
262
- executeDataV2.params_.metadata === "0x" ||
263
- !executeDataV2.params_.metadata
264
- ) {
265
- return null;
266
- } else {
267
- metadata = executeDataV2.params_.metadata;
268
- }
343
+ return parseMetadata(metadata);
344
+ } catch (e) {
345
+ return null;
346
+ }
347
+ };
348
+
349
+ const getMetadataFromData = (data: string) => {
350
+ const iface = Forwarder__factory.createInterface();
351
+ let metadata = "0x";
352
+
353
+ if (data.startsWith("0x18e7f485")) {
354
+ const executeData = iface.decodeFunctionData("execute", data);
355
+ if (executeData.metadata_ === "0x" || !executeData.metadata_) {
356
+ return null;
357
+ } else {
358
+ metadata = executeData.metadata_;
359
+ }
360
+ } else if (data.startsWith("0x14f80a8d")) {
361
+ const executeDataV2 = iface.decodeFunctionData("executeV2", data);
362
+ if (
363
+ executeDataV2.params_.metadata === "0x" ||
364
+ !executeDataV2.params_.metadata
365
+ ) {
366
+ return null;
367
+ } else {
368
+ metadata = executeDataV2.params_.metadata;
369
+ }
370
+ } else if (data.startsWith("0x85114d53")) {
371
+ const executeDataV3 = iface.decodeFunctionData("executeV3", data);
372
+ if (
373
+ executeDataV3.params_.metadata === "0x" ||
374
+ !executeDataV3.params_.metadata
375
+ ) {
376
+ return null;
269
377
  } else {
270
- const executeDataV3 = iface.decodeFunctionData("executeV3", data);
271
- if (
272
- executeDataV3.params_.metadata === "0x" ||
273
- !executeDataV3.params_.metadata
274
- ) {
275
- return null;
276
- } else {
277
- metadata = executeDataV3.params_.metadata;
278
- }
378
+ metadata = executeDataV3.params_.metadata;
279
379
  }
380
+ } else {
381
+ const executeDataMultisigV3 = iface.decodeFunctionData(
382
+ "executeMultisigV3",
383
+ data
384
+ );
385
+ if (
386
+ executeDataMultisigV3.params_.metadata === "0x" ||
387
+ !executeDataMultisigV3.params_.metadata
388
+ ) {
389
+ return null;
390
+ } else {
391
+ metadata = executeDataMultisigV3.params_.metadata;
392
+ }
393
+ }
394
+
395
+ return metadata;
396
+ };
280
397
 
281
- const metadataArr = [];
282
-
283
- const [decodedMultiMetadata = []] =
284
- (ethers.utils.defaultAbiCoder.decode(
285
- multiMetadataTypes,
286
- metadata
287
- ) as string[]) || [];
288
-
289
- for (let metadata of decodedMultiMetadata) {
290
- const decodedMetadata = ethers.utils.defaultAbiCoder.decode(
291
- metadataTypes,
292
- metadata
293
- );
294
-
295
- const type = ethers.utils.parseBytes32String(
296
- decodedMetadata.type
297
- ) as keyof typeof actionMetadataTypes;
298
-
299
- const decodedData = ethers.utils.defaultAbiCoder.decode(
300
- actionMetadataTypes[type],
301
- decodedMetadata.data
302
- );
303
-
304
- switch (type) {
305
- case "transfer":
306
- payload = {
307
- type,
308
- token: decodedData.token,
309
- amount: toBN(decodedData.amount).toFixed(),
310
- receiver: decodedData.receiver,
311
- };
312
- break;
313
- case "bridge":
314
- payload = {
315
- type,
316
- amount: toBN(decodedData.amount).toFixed(),
317
- receiver: decodedData.receiver,
318
- toToken: decodedData.toToken,
319
- fromToken: decodedData.fromToken,
320
- toChainId: decodedData.toChainId
321
- ? decodedData.toChainId.toString()
322
- : null,
323
- bridgeFee: toBN(decodedData.bridgeFee).toFixed(),
324
- };
325
- break;
326
- case "swap":
327
- payload = {
328
- type,
329
- buyAmount: toBN(decodedData.buyAmount).toFixed(),
330
- sellAmount: toBN(decodedData.sellAmount).toFixed(),
331
- buyToken: decodedData.buyToken,
332
- sellToken: decodedData.sellToken,
333
- receiver: decodedData.receiver,
334
- protocol: utils.parseBytes32String(decodedData?.protocol || ""),
335
- };
336
- break;
337
- case "upgrade":
338
- payload = {
339
- type,
340
- version: utils.parseBytes32String(decodedData?.version || ""),
341
- walletImpl: decodedData?.walletImpl,
342
- };
343
- break;
344
- case "gas-topup":
345
- payload = {
346
- type,
347
- amount: toBN(decodedData.amount).toFixed(),
348
- token: decodedData.token,
349
- onBehalf: decodedData.onBehalf,
350
- };
351
- break;
352
- case "dapp":
353
- payload = {
354
- type,
355
- name: decodedData?.name,
356
- url: decodedData?.url,
357
- };
358
- break;
359
- case "deploy":
360
- payload = {
361
- type,
362
- };
363
- break;
364
-
365
- case "permit2":
366
- payload = {
367
- type,
368
- token: decodedData.token,
369
- spender: decodedData.spender,
370
- amount: toBN(decodedData.amount).toFixed(),
371
- expiration: decodedData.expiration,
372
- };
373
- break;
374
-
375
- case "cross-transfer":
376
- payload = {
377
- type,
378
- fromToken: decodedData.fromToken,
379
- toToken: decodedData.toToken,
380
- toChainId: decodedData.toChainId
381
- ? decodedData.toChainId.toString()
382
- : null,
383
- amount: toBN(decodedData.amount).toFixed(),
384
- receiver: decodedData.receiver,
385
- };
386
-
387
- break;
388
- case "auth":
389
- payload = {
390
- type: decodedData.remove ? "remove-authority" : "add-authority",
391
- address: decodedData.address,
392
- chainId: decodedData.chainId
393
- ? decodedData.chainId.toString()
394
- : null,
395
- remove: decodedData.remove,
396
- };
397
-
398
- break;
399
- }
400
398
 
399
+ const typesPayload: IPayload = {
400
+ transfer: (data, type) => ({
401
+ type,
402
+ token: data.token,
403
+ amount: toBN(data.amount).toFixed(),
404
+ receiver: data.receiver,
405
+ }),
406
+ bridge: (data, type) => ({
407
+ type,
408
+ amount: toBN(data.amount).toFixed(),
409
+ receiver: data.receiver,
410
+ toToken: data.toToken,
411
+ fromToken: data.fromToken,
412
+ toChainId: data.toChainId ? data.toChainId.toString() : null,
413
+ bridgeFee: toBN(data.bridgeFee).toFixed(),
414
+ }),
415
+ swap: (data, type) => ({
416
+ type,
417
+ buyAmount: toBN(data.buyAmount).toFixed(),
418
+ sellAmount: toBN(data.sellAmount).toFixed(),
419
+ buyToken: data.buyToken,
420
+ sellToken: data.sellToken,
421
+ receiver: data.receiver,
422
+ protocol: utils.parseBytes32String(data.protocol || ""),
423
+ }),
424
+ upgrade: (data, type) => ({
425
+ type,
426
+ version: utils.parseBytes32String(data.version || ""),
427
+ walletImpl: data.walletImpl,
428
+ }),
429
+ "gas-topup": (data, type) => ({
430
+ type,
431
+ amount: toBN(data.amount).toFixed(),
432
+ token: data.token,
433
+ onBehalf: data.onBehalf,
434
+ }),
435
+ "dapp": (data, type) => ({
436
+ type,
437
+ name: data.name,
438
+ url: data.url,
439
+ }),
440
+ "deploy": (data, type) => ({
441
+ type,
442
+ }),
443
+ "permit2": (data, type) => ({
444
+ type,
445
+ token: data.token,
446
+ spender: data.spender,
447
+ amount: toBN(data.amount).toFixed(),
448
+ expiration: data.expiration,
449
+ }),
450
+ "cross-transfer": (data, type) => ({
451
+ type,
452
+ fromToken: data.fromToken,
453
+ toToken: data.toToken,
454
+ toChainId: data.toChainId ? data.toChainId.toString() : null,
455
+ amount: toBN(data.amount).toFixed(),
456
+ receiver: data.receiver,
457
+ }),
458
+ "auth": (data) => ({
459
+ type: data.remove ? "remove-authority" : "add-authority",
460
+ address: data.address,
461
+ chainId: data.chainId ? data.chainId.toString() : null,
462
+ remove: data.remove,
463
+ }),
464
+ "instadapp-pro": (data, type) => ({
465
+ type,
466
+ castDetails: data.castDetails,
467
+ }),
468
+ "rejection": (data, type) => ({
469
+ type,
470
+ id: data.id,
471
+ }),
472
+ "add-signers": (data, type) => ({
473
+ type,
474
+ addresses: data.signers,
475
+ }),
476
+ "remove-signers": (data, type) => ({
477
+ type,
478
+ addresses: data.signers,
479
+ }),
480
+ "change-threshold": (data, type) => ({
481
+ type,
482
+ count: data.count,
483
+ }),
484
+ };
485
+
486
+ const parseMetadata = (metadata: string) => {
487
+ const metadataArr = [];
488
+
489
+ const [decodedMultiMetadata = []] =
490
+ (ethers.utils.defaultAbiCoder.decode(
491
+ multiMetadataTypes,
492
+ metadata
493
+ ) as string[]) || [];
494
+
495
+ for (let metadata of decodedMultiMetadata) {
496
+ const decodedMetadata = ethers.utils.defaultAbiCoder.decode(
497
+ metadataTypes,
498
+ metadata
499
+ );
500
+
501
+ const type = ethers.utils.parseBytes32String(
502
+ decodedMetadata.type
503
+ ) as keyof typeof actionMetadataTypes;
504
+
505
+ const decodedData = ethers.utils.defaultAbiCoder.decode(
506
+ actionMetadataTypes[type],
507
+ decodedMetadata.data
508
+ );
509
+
510
+ const payloadFunc = typesPayload[type]
511
+
512
+ if (payloadFunc) {
513
+ const payload = payloadFunc(decodedData, type)
401
514
  metadataArr.push(payload);
402
515
  }
403
516
 
404
- return metadataArr;
405
- } catch (e) {
406
- console.log(e);
407
- return null;
408
517
  }
518
+
519
+ return metadataArr;
520
+ };
521
+
522
+
523
+
524
+ /**
525
+ * Replaces hyphens with spaces and capitalizes the first letter of each word in a sentence.
526
+ * @param {string} txType - The input sentence to modify
527
+ *
528
+ * @returns {string} - The modified sentence with hyphens replaced with spaces and the first letter of each word capitalized.
529
+ */
530
+ export const formatTxType = (txType: string) => {
531
+ const finalSentence = txType
532
+ .replace("-", " ")
533
+ .replace(/(^\w{1})|(\s+\w{1})/g, (letter) => letter.toUpperCase());
534
+
535
+ return finalSentence;
409
536
  };