@openzeppelin/confidential-contracts 0.2.0 → 0.3.0

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 (35) hide show
  1. package/build/contracts/Checkpoints.json +2 -2
  2. package/build/contracts/CheckpointsConfidential.json +2 -2
  3. package/build/contracts/{ConfidentialFungibleToken.json → ERC7984.json} +87 -58
  4. package/build/contracts/{ConfidentialFungibleTokenERC20Wrapper.json → ERC7984ERC20Wrapper.json} +143 -59
  5. package/build/contracts/ERC7984Freezable.json +700 -0
  6. package/build/contracts/ERC7984ObserverAccess.json +710 -0
  7. package/build/contracts/ERC7984Omnibus.json +1028 -0
  8. package/build/contracts/ERC7984Restricted.json +711 -0
  9. package/build/contracts/ERC7984Rwa.json +1385 -0
  10. package/build/contracts/{ConfidentialFungibleTokenUtils.json → ERC7984Utils.json} +4 -4
  11. package/build/contracts/{ConfidentialFungibleTokenVotes.json → ERC7984Votes.json} +142 -113
  12. package/build/contracts/FHESafeMath.json +2 -2
  13. package/build/contracts/{IConfidentialFungibleToken.json → IERC7984.json} +26 -7
  14. package/build/contracts/{IConfidentialFungibleTokenReceiver.json → IERC7984Receiver.json} +2 -2
  15. package/build/contracts/IERC7984Rwa.json +797 -0
  16. package/build/contracts/VestingWalletConfidentialFactory.json +2 -2
  17. package/finance/ERC7821WithExecutor.sol +3 -4
  18. package/finance/VestingWalletCliffConfidential.sol +3 -4
  19. package/finance/VestingWalletConfidential.sol +8 -12
  20. package/finance/VestingWalletConfidentialFactory.sol +7 -12
  21. package/interfaces/{IConfidentialFungibleToken.sol → IERC7984.sol} +6 -5
  22. package/interfaces/{IConfidentialFungibleTokenReceiver.sol → IERC7984Receiver.sol} +3 -3
  23. package/interfaces/IERC7984Rwa.sol +63 -0
  24. package/package.json +4 -4
  25. package/token/{ConfidentialFungibleToken.sol → ERC7984/ERC7984.sol} +81 -82
  26. package/token/{extensions/ConfidentialFungibleTokenERC20Wrapper.sol → ERC7984/extensions/ERC7984ERC20Wrapper.sol} +40 -35
  27. package/token/ERC7984/extensions/ERC7984Freezable.sol +75 -0
  28. package/token/ERC7984/extensions/ERC7984ObserverAccess.sol +63 -0
  29. package/token/ERC7984/extensions/ERC7984Omnibus.sol +209 -0
  30. package/token/ERC7984/extensions/ERC7984Restricted.sol +110 -0
  31. package/token/ERC7984/extensions/ERC7984Rwa.sol +248 -0
  32. package/token/{extensions/ConfidentialFungibleTokenVotes.sol → ERC7984/extensions/ERC7984Votes.sol} +8 -14
  33. package/token/{utils/ConfidentialFungibleTokenUtils.sol → ERC7984/utils/ERC7984Utils.sol} +14 -13
  34. package/utils/FHESafeMath.sol +45 -7
  35. package/utils/structs/temporary-Checkpoints.sol +2 -2
@@ -0,0 +1,700 @@
1
+ {
2
+ "_format": "hh-sol-artifact-1",
3
+ "contractName": "ERC7984Freezable",
4
+ "sourceName": "contracts/token/ERC7984/extensions/ERC7984Freezable.sol",
5
+ "abi": [
6
+ {
7
+ "inputs": [
8
+ {
9
+ "internalType": "uint256",
10
+ "name": "requestId",
11
+ "type": "uint256"
12
+ }
13
+ ],
14
+ "name": "ERC7984InvalidGatewayRequest",
15
+ "type": "error"
16
+ },
17
+ {
18
+ "inputs": [
19
+ {
20
+ "internalType": "address",
21
+ "name": "receiver",
22
+ "type": "address"
23
+ }
24
+ ],
25
+ "name": "ERC7984InvalidReceiver",
26
+ "type": "error"
27
+ },
28
+ {
29
+ "inputs": [
30
+ {
31
+ "internalType": "address",
32
+ "name": "sender",
33
+ "type": "address"
34
+ }
35
+ ],
36
+ "name": "ERC7984InvalidSender",
37
+ "type": "error"
38
+ },
39
+ {
40
+ "inputs": [
41
+ {
42
+ "internalType": "address",
43
+ "name": "caller",
44
+ "type": "address"
45
+ }
46
+ ],
47
+ "name": "ERC7984UnauthorizedCaller",
48
+ "type": "error"
49
+ },
50
+ {
51
+ "inputs": [
52
+ {
53
+ "internalType": "address",
54
+ "name": "holder",
55
+ "type": "address"
56
+ },
57
+ {
58
+ "internalType": "address",
59
+ "name": "spender",
60
+ "type": "address"
61
+ }
62
+ ],
63
+ "name": "ERC7984UnauthorizedSpender",
64
+ "type": "error"
65
+ },
66
+ {
67
+ "inputs": [
68
+ {
69
+ "internalType": "euint64",
70
+ "name": "amount",
71
+ "type": "bytes32"
72
+ },
73
+ {
74
+ "internalType": "address",
75
+ "name": "user",
76
+ "type": "address"
77
+ }
78
+ ],
79
+ "name": "ERC7984UnauthorizedUseOfEncryptedAmount",
80
+ "type": "error"
81
+ },
82
+ {
83
+ "inputs": [
84
+ {
85
+ "internalType": "address",
86
+ "name": "holder",
87
+ "type": "address"
88
+ }
89
+ ],
90
+ "name": "ERC7984ZeroBalance",
91
+ "type": "error"
92
+ },
93
+ {
94
+ "inputs": [],
95
+ "name": "InvalidKMSSignatures",
96
+ "type": "error"
97
+ },
98
+ {
99
+ "anonymous": false,
100
+ "inputs": [
101
+ {
102
+ "indexed": true,
103
+ "internalType": "euint64",
104
+ "name": "encryptedAmount",
105
+ "type": "bytes32"
106
+ },
107
+ {
108
+ "indexed": true,
109
+ "internalType": "address",
110
+ "name": "requester",
111
+ "type": "address"
112
+ }
113
+ ],
114
+ "name": "AmountDiscloseRequested",
115
+ "type": "event"
116
+ },
117
+ {
118
+ "anonymous": false,
119
+ "inputs": [
120
+ {
121
+ "indexed": true,
122
+ "internalType": "euint64",
123
+ "name": "encryptedAmount",
124
+ "type": "bytes32"
125
+ },
126
+ {
127
+ "indexed": false,
128
+ "internalType": "uint64",
129
+ "name": "amount",
130
+ "type": "uint64"
131
+ }
132
+ ],
133
+ "name": "AmountDisclosed",
134
+ "type": "event"
135
+ },
136
+ {
137
+ "anonymous": false,
138
+ "inputs": [
139
+ {
140
+ "indexed": true,
141
+ "internalType": "address",
142
+ "name": "from",
143
+ "type": "address"
144
+ },
145
+ {
146
+ "indexed": true,
147
+ "internalType": "address",
148
+ "name": "to",
149
+ "type": "address"
150
+ },
151
+ {
152
+ "indexed": true,
153
+ "internalType": "euint64",
154
+ "name": "amount",
155
+ "type": "bytes32"
156
+ }
157
+ ],
158
+ "name": "ConfidentialTransfer",
159
+ "type": "event"
160
+ },
161
+ {
162
+ "anonymous": false,
163
+ "inputs": [
164
+ {
165
+ "indexed": true,
166
+ "internalType": "address",
167
+ "name": "holder",
168
+ "type": "address"
169
+ },
170
+ {
171
+ "indexed": true,
172
+ "internalType": "address",
173
+ "name": "operator",
174
+ "type": "address"
175
+ },
176
+ {
177
+ "indexed": false,
178
+ "internalType": "uint48",
179
+ "name": "until",
180
+ "type": "uint48"
181
+ }
182
+ ],
183
+ "name": "OperatorSet",
184
+ "type": "event"
185
+ },
186
+ {
187
+ "anonymous": false,
188
+ "inputs": [
189
+ {
190
+ "indexed": false,
191
+ "internalType": "bytes32[]",
192
+ "name": "handlesList",
193
+ "type": "bytes32[]"
194
+ },
195
+ {
196
+ "indexed": false,
197
+ "internalType": "bytes",
198
+ "name": "abiEncodedCleartexts",
199
+ "type": "bytes"
200
+ }
201
+ ],
202
+ "name": "PublicDecryptionVerified",
203
+ "type": "event"
204
+ },
205
+ {
206
+ "anonymous": false,
207
+ "inputs": [
208
+ {
209
+ "indexed": true,
210
+ "internalType": "address",
211
+ "name": "account",
212
+ "type": "address"
213
+ },
214
+ {
215
+ "indexed": false,
216
+ "internalType": "euint64",
217
+ "name": "encryptedAmount",
218
+ "type": "bytes32"
219
+ }
220
+ ],
221
+ "name": "TokensFrozen",
222
+ "type": "event"
223
+ },
224
+ {
225
+ "inputs": [
226
+ {
227
+ "internalType": "address",
228
+ "name": "account",
229
+ "type": "address"
230
+ }
231
+ ],
232
+ "name": "confidentialAvailable",
233
+ "outputs": [
234
+ {
235
+ "internalType": "euint64",
236
+ "name": "",
237
+ "type": "bytes32"
238
+ }
239
+ ],
240
+ "stateMutability": "nonpayable",
241
+ "type": "function"
242
+ },
243
+ {
244
+ "inputs": [
245
+ {
246
+ "internalType": "address",
247
+ "name": "account",
248
+ "type": "address"
249
+ }
250
+ ],
251
+ "name": "confidentialBalanceOf",
252
+ "outputs": [
253
+ {
254
+ "internalType": "euint64",
255
+ "name": "",
256
+ "type": "bytes32"
257
+ }
258
+ ],
259
+ "stateMutability": "view",
260
+ "type": "function"
261
+ },
262
+ {
263
+ "inputs": [
264
+ {
265
+ "internalType": "address",
266
+ "name": "account",
267
+ "type": "address"
268
+ }
269
+ ],
270
+ "name": "confidentialFrozen",
271
+ "outputs": [
272
+ {
273
+ "internalType": "euint64",
274
+ "name": "",
275
+ "type": "bytes32"
276
+ }
277
+ ],
278
+ "stateMutability": "view",
279
+ "type": "function"
280
+ },
281
+ {
282
+ "inputs": [],
283
+ "name": "confidentialTotalSupply",
284
+ "outputs": [
285
+ {
286
+ "internalType": "euint64",
287
+ "name": "",
288
+ "type": "bytes32"
289
+ }
290
+ ],
291
+ "stateMutability": "view",
292
+ "type": "function"
293
+ },
294
+ {
295
+ "inputs": [
296
+ {
297
+ "internalType": "address",
298
+ "name": "to",
299
+ "type": "address"
300
+ },
301
+ {
302
+ "internalType": "externalEuint64",
303
+ "name": "encryptedAmount",
304
+ "type": "bytes32"
305
+ },
306
+ {
307
+ "internalType": "bytes",
308
+ "name": "inputProof",
309
+ "type": "bytes"
310
+ }
311
+ ],
312
+ "name": "confidentialTransfer",
313
+ "outputs": [
314
+ {
315
+ "internalType": "euint64",
316
+ "name": "",
317
+ "type": "bytes32"
318
+ }
319
+ ],
320
+ "stateMutability": "nonpayable",
321
+ "type": "function"
322
+ },
323
+ {
324
+ "inputs": [
325
+ {
326
+ "internalType": "address",
327
+ "name": "to",
328
+ "type": "address"
329
+ },
330
+ {
331
+ "internalType": "euint64",
332
+ "name": "amount",
333
+ "type": "bytes32"
334
+ }
335
+ ],
336
+ "name": "confidentialTransfer",
337
+ "outputs": [
338
+ {
339
+ "internalType": "euint64",
340
+ "name": "",
341
+ "type": "bytes32"
342
+ }
343
+ ],
344
+ "stateMutability": "nonpayable",
345
+ "type": "function"
346
+ },
347
+ {
348
+ "inputs": [
349
+ {
350
+ "internalType": "address",
351
+ "name": "to",
352
+ "type": "address"
353
+ },
354
+ {
355
+ "internalType": "euint64",
356
+ "name": "amount",
357
+ "type": "bytes32"
358
+ },
359
+ {
360
+ "internalType": "bytes",
361
+ "name": "data",
362
+ "type": "bytes"
363
+ }
364
+ ],
365
+ "name": "confidentialTransferAndCall",
366
+ "outputs": [
367
+ {
368
+ "internalType": "euint64",
369
+ "name": "transferred",
370
+ "type": "bytes32"
371
+ }
372
+ ],
373
+ "stateMutability": "nonpayable",
374
+ "type": "function"
375
+ },
376
+ {
377
+ "inputs": [
378
+ {
379
+ "internalType": "address",
380
+ "name": "to",
381
+ "type": "address"
382
+ },
383
+ {
384
+ "internalType": "externalEuint64",
385
+ "name": "encryptedAmount",
386
+ "type": "bytes32"
387
+ },
388
+ {
389
+ "internalType": "bytes",
390
+ "name": "inputProof",
391
+ "type": "bytes"
392
+ },
393
+ {
394
+ "internalType": "bytes",
395
+ "name": "data",
396
+ "type": "bytes"
397
+ }
398
+ ],
399
+ "name": "confidentialTransferAndCall",
400
+ "outputs": [
401
+ {
402
+ "internalType": "euint64",
403
+ "name": "transferred",
404
+ "type": "bytes32"
405
+ }
406
+ ],
407
+ "stateMutability": "nonpayable",
408
+ "type": "function"
409
+ },
410
+ {
411
+ "inputs": [
412
+ {
413
+ "internalType": "address",
414
+ "name": "from",
415
+ "type": "address"
416
+ },
417
+ {
418
+ "internalType": "address",
419
+ "name": "to",
420
+ "type": "address"
421
+ },
422
+ {
423
+ "internalType": "externalEuint64",
424
+ "name": "encryptedAmount",
425
+ "type": "bytes32"
426
+ },
427
+ {
428
+ "internalType": "bytes",
429
+ "name": "inputProof",
430
+ "type": "bytes"
431
+ }
432
+ ],
433
+ "name": "confidentialTransferFrom",
434
+ "outputs": [
435
+ {
436
+ "internalType": "euint64",
437
+ "name": "transferred",
438
+ "type": "bytes32"
439
+ }
440
+ ],
441
+ "stateMutability": "nonpayable",
442
+ "type": "function"
443
+ },
444
+ {
445
+ "inputs": [
446
+ {
447
+ "internalType": "address",
448
+ "name": "from",
449
+ "type": "address"
450
+ },
451
+ {
452
+ "internalType": "address",
453
+ "name": "to",
454
+ "type": "address"
455
+ },
456
+ {
457
+ "internalType": "euint64",
458
+ "name": "amount",
459
+ "type": "bytes32"
460
+ }
461
+ ],
462
+ "name": "confidentialTransferFrom",
463
+ "outputs": [
464
+ {
465
+ "internalType": "euint64",
466
+ "name": "transferred",
467
+ "type": "bytes32"
468
+ }
469
+ ],
470
+ "stateMutability": "nonpayable",
471
+ "type": "function"
472
+ },
473
+ {
474
+ "inputs": [
475
+ {
476
+ "internalType": "address",
477
+ "name": "from",
478
+ "type": "address"
479
+ },
480
+ {
481
+ "internalType": "address",
482
+ "name": "to",
483
+ "type": "address"
484
+ },
485
+ {
486
+ "internalType": "externalEuint64",
487
+ "name": "encryptedAmount",
488
+ "type": "bytes32"
489
+ },
490
+ {
491
+ "internalType": "bytes",
492
+ "name": "inputProof",
493
+ "type": "bytes"
494
+ },
495
+ {
496
+ "internalType": "bytes",
497
+ "name": "data",
498
+ "type": "bytes"
499
+ }
500
+ ],
501
+ "name": "confidentialTransferFromAndCall",
502
+ "outputs": [
503
+ {
504
+ "internalType": "euint64",
505
+ "name": "transferred",
506
+ "type": "bytes32"
507
+ }
508
+ ],
509
+ "stateMutability": "nonpayable",
510
+ "type": "function"
511
+ },
512
+ {
513
+ "inputs": [
514
+ {
515
+ "internalType": "address",
516
+ "name": "from",
517
+ "type": "address"
518
+ },
519
+ {
520
+ "internalType": "address",
521
+ "name": "to",
522
+ "type": "address"
523
+ },
524
+ {
525
+ "internalType": "euint64",
526
+ "name": "amount",
527
+ "type": "bytes32"
528
+ },
529
+ {
530
+ "internalType": "bytes",
531
+ "name": "data",
532
+ "type": "bytes"
533
+ }
534
+ ],
535
+ "name": "confidentialTransferFromAndCall",
536
+ "outputs": [
537
+ {
538
+ "internalType": "euint64",
539
+ "name": "transferred",
540
+ "type": "bytes32"
541
+ }
542
+ ],
543
+ "stateMutability": "nonpayable",
544
+ "type": "function"
545
+ },
546
+ {
547
+ "inputs": [],
548
+ "name": "contractURI",
549
+ "outputs": [
550
+ {
551
+ "internalType": "string",
552
+ "name": "",
553
+ "type": "string"
554
+ }
555
+ ],
556
+ "stateMutability": "view",
557
+ "type": "function"
558
+ },
559
+ {
560
+ "inputs": [],
561
+ "name": "decimals",
562
+ "outputs": [
563
+ {
564
+ "internalType": "uint8",
565
+ "name": "",
566
+ "type": "uint8"
567
+ }
568
+ ],
569
+ "stateMutability": "view",
570
+ "type": "function"
571
+ },
572
+ {
573
+ "inputs": [
574
+ {
575
+ "internalType": "euint64",
576
+ "name": "encryptedAmount",
577
+ "type": "bytes32"
578
+ },
579
+ {
580
+ "internalType": "uint64",
581
+ "name": "cleartextAmount",
582
+ "type": "uint64"
583
+ },
584
+ {
585
+ "internalType": "bytes",
586
+ "name": "decryptionProof",
587
+ "type": "bytes"
588
+ }
589
+ ],
590
+ "name": "discloseEncryptedAmount",
591
+ "outputs": [],
592
+ "stateMutability": "nonpayable",
593
+ "type": "function"
594
+ },
595
+ {
596
+ "inputs": [
597
+ {
598
+ "internalType": "address",
599
+ "name": "holder",
600
+ "type": "address"
601
+ },
602
+ {
603
+ "internalType": "address",
604
+ "name": "spender",
605
+ "type": "address"
606
+ }
607
+ ],
608
+ "name": "isOperator",
609
+ "outputs": [
610
+ {
611
+ "internalType": "bool",
612
+ "name": "",
613
+ "type": "bool"
614
+ }
615
+ ],
616
+ "stateMutability": "view",
617
+ "type": "function"
618
+ },
619
+ {
620
+ "inputs": [],
621
+ "name": "name",
622
+ "outputs": [
623
+ {
624
+ "internalType": "string",
625
+ "name": "",
626
+ "type": "string"
627
+ }
628
+ ],
629
+ "stateMutability": "view",
630
+ "type": "function"
631
+ },
632
+ {
633
+ "inputs": [
634
+ {
635
+ "internalType": "euint64",
636
+ "name": "encryptedAmount",
637
+ "type": "bytes32"
638
+ }
639
+ ],
640
+ "name": "requestDiscloseEncryptedAmount",
641
+ "outputs": [],
642
+ "stateMutability": "nonpayable",
643
+ "type": "function"
644
+ },
645
+ {
646
+ "inputs": [
647
+ {
648
+ "internalType": "address",
649
+ "name": "operator",
650
+ "type": "address"
651
+ },
652
+ {
653
+ "internalType": "uint48",
654
+ "name": "until",
655
+ "type": "uint48"
656
+ }
657
+ ],
658
+ "name": "setOperator",
659
+ "outputs": [],
660
+ "stateMutability": "nonpayable",
661
+ "type": "function"
662
+ },
663
+ {
664
+ "inputs": [
665
+ {
666
+ "internalType": "bytes4",
667
+ "name": "interfaceId",
668
+ "type": "bytes4"
669
+ }
670
+ ],
671
+ "name": "supportsInterface",
672
+ "outputs": [
673
+ {
674
+ "internalType": "bool",
675
+ "name": "",
676
+ "type": "bool"
677
+ }
678
+ ],
679
+ "stateMutability": "view",
680
+ "type": "function"
681
+ },
682
+ {
683
+ "inputs": [],
684
+ "name": "symbol",
685
+ "outputs": [
686
+ {
687
+ "internalType": "string",
688
+ "name": "",
689
+ "type": "string"
690
+ }
691
+ ],
692
+ "stateMutability": "view",
693
+ "type": "function"
694
+ }
695
+ ],
696
+ "bytecode": "0x",
697
+ "deployedBytecode": "0x",
698
+ "linkReferences": {},
699
+ "deployedLinkReferences": {}
700
+ }