1
1
import {
2
2
AccountUpdate ,
3
+ Bool ,
3
4
Field ,
4
5
MerkleTree ,
5
6
Mina ,
6
7
PrivateKey ,
7
8
Signature ,
8
9
UInt64
9
10
} from "o1js" ;
10
- import { HumanIDWitness , Signatures } from "../humanIDv1" ;
11
+ import { HumanIDWitness , Signatures , authenticate } from "../humanIDv1" ;
11
12
import { Airdrop } from "./Airdrop" ;
12
13
13
14
describe ( 'Example Airdrop zkApp' , ( ) => {
@@ -17,10 +18,25 @@ describe('Example Airdrop zkApp', () => {
17
18
const sender = senderKey . toPublicKey ( ) ;
18
19
const appKey = PrivateKey . random ( ) ;
19
20
const appAddr = appKey . toPublicKey ( ) ;
21
+ const id1 = Field ( 1 ) ;
22
+ const id2 = Field ( 2 ) ;
23
+ const privKey1 = PrivateKey . fromBigInt ( 1n ) ;
24
+ const privKey2 = PrivateKey . fromBigInt ( 2n ) ;
25
+ const privKey3 = PrivateKey . fromBigInt ( 3n ) ;
20
26
const sigs = new Signatures ( {
21
- sig1 : Signature . create ( senderKey , [ Field ( 1 ) ] ) ,
22
- sig2 : Signature . create ( senderKey , [ Field ( 2 ) ] ) ,
23
- sig3 : Signature . create ( senderKey , [ Field ( 3 ) ] )
27
+ sig1 : Signature . create ( privKey1 , [ Field ( 100 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
28
+ sig2 : Signature . create ( privKey2 , [ Field ( 100 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
29
+ sig3 : Signature . create ( privKey3 , [ Field ( 100 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] )
30
+ } ) ;
31
+ const sigs1 = new Signatures ( {
32
+ sig1 : Signature . create ( privKey1 , [ id1 , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
33
+ sig2 : Signature . create ( privKey2 , [ id1 , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
34
+ sig3 : Signature . create ( privKey3 , [ id1 , sender . x . add ( sender . isOdd . toField ( ) ) ] )
35
+ } ) ;
36
+ const sigs2 = new Signatures ( {
37
+ sig1 : Signature . create ( privKey1 , [ id2 , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
38
+ sig2 : Signature . create ( privKey2 , [ id2 , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
39
+ sig3 : Signature . create ( privKey3 , [ id2 , sender . x . add ( sender . isOdd . toField ( ) ) ] )
24
40
} ) ;
25
41
let tree : MerkleTree ;
26
42
let app : Airdrop ;
@@ -49,6 +65,11 @@ describe('Example Airdrop zkApp', () => {
49
65
} ) . then ( ( txn ) => txn . prove ( ) )
50
66
. then ( ( txn ) => txn . sign ( [ deployerKey , appKey ] ) . send ( ) )
51
67
68
+ it ( 'should verify signatures' , ( ) => {
69
+ authenticate ( id1 , sigs1 , sender ) ;
70
+ authenticate ( id2 , sigs2 , sender ) ;
71
+ } )
72
+
52
73
it ( 'should deploy the app and fund it' , async ( ) => {
53
74
await deploy ( ) ;
54
75
await fundZkApp ( ) ;
@@ -71,9 +92,14 @@ describe('Example Airdrop zkApp', () => {
71
92
72
93
const id1 = 123123123123123123123123123123n ;
73
94
const truncatedId1 = id1 & 0xFFFFFFFFn ;
95
+ const sigsTest1 = new Signatures ( {
96
+ sig1 : Signature . create ( privKey1 , [ Field ( id1 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
97
+ sig2 : Signature . create ( privKey2 , [ Field ( id1 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
98
+ sig3 : Signature . create ( privKey3 , [ Field ( id1 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] )
99
+ } ) ;
74
100
await Mina . transaction (
75
101
sender ,
76
- ( ) => app . claimReward ( Field ( id1 ) , sigs , new HumanIDWitness ( tree . getWitness ( truncatedId1 ) ) )
102
+ ( ) => app . claimReward ( Field ( id1 ) , sigsTest1 , new HumanIDWitness ( tree . getWitness ( truncatedId1 ) ) )
77
103
)
78
104
. then ( ( txn ) => txn . prove ( ) )
79
105
. then ( ( txn ) => txn . sign ( [ senderKey ] ) . send ( ) ) ;
@@ -82,9 +108,14 @@ describe('Example Airdrop zkApp', () => {
82
108
83
109
const id2 = 123123123123123123123123123124n ;
84
110
const truncatedId2 = id2 & 0xFFFFFFFFn ;
111
+ const sigsTest2 = new Signatures ( {
112
+ sig1 : Signature . create ( privKey1 , [ Field ( id2 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
113
+ sig2 : Signature . create ( privKey2 , [ Field ( id2 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
114
+ sig3 : Signature . create ( privKey3 , [ Field ( id2 ) , sender . x . add ( sender . isOdd . toField ( ) ) ] )
115
+ } ) ;
85
116
await Mina . transaction (
86
117
sender ,
87
- ( ) => app . claimReward ( Field ( id2 ) , sigs , new HumanIDWitness ( tree . getWitness ( truncatedId2 ) ) )
118
+ ( ) => app . claimReward ( Field ( id2 ) , sigsTest2 , new HumanIDWitness ( tree . getWitness ( truncatedId2 ) ) )
88
119
)
89
120
. then ( ( txn ) => txn . prove ( ) )
90
121
. then ( ( txn ) => txn . sign ( [ senderKey ] ) . send ( ) ) ;
@@ -94,9 +125,14 @@ describe('Example Airdrop zkApp', () => {
94
125
await deploy ( ) ;
95
126
await fundZkApp ( ) ;
96
127
128
+ const sigsTest3 = new Signatures ( {
129
+ sig1 : Signature . create ( privKey1 , [ Field ( 123123123123123n ) , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
130
+ sig2 : Signature . create ( privKey2 , [ Field ( 123123123123123n ) , sender . x . add ( sender . isOdd . toField ( ) ) ] ) ,
131
+ sig3 : Signature . create ( privKey3 , [ Field ( 123123123123123n ) , sender . x . add ( sender . isOdd . toField ( ) ) ] )
132
+ } ) ;
97
133
await expect ( ( ) => Mina . transaction (
98
134
sender ,
99
- ( ) => app . claimReward ( Field ( 123123123123123n ) , sigs , new HumanIDWitness ( tree . getWitness ( 100n ) ) )
135
+ ( ) => app . claimReward ( Field ( 123123123123123n ) , sigsTest3 , new HumanIDWitness ( tree . getWitness ( 100n ) ) )
100
136
)
101
137
. then ( ( txn ) => txn . prove ( ) )
102
138
. then ( ( txn ) => txn . sign ( [ senderKey ] ) . send ( ) ) ) . rejects . toThrow ( / d o e s n o t m a t c h t h e w i t n e s s / ) ;
0 commit comments