@aztec/bb.js 0.0.1-alpha.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 (206) hide show
  1. package/README.md +3 -0
  2. package/dest/async_map/index.d.ts +10 -0
  3. package/dest/async_map/index.d.ts.map +1 -0
  4. package/dest/async_map/index.js +16 -0
  5. package/dest/barretenberg-threads.wasm +0 -0
  6. package/dest/barretenberg.wasm +0 -0
  7. package/dest/barretenberg_api/blake2s.test.d.ts +2 -0
  8. package/dest/barretenberg_api/blake2s.test.d.ts.map +1 -0
  9. package/dest/barretenberg_api/blake2s.test.js +30 -0
  10. package/dest/barretenberg_api/common.test.d.ts +2 -0
  11. package/dest/barretenberg_api/common.test.d.ts.map +1 -0
  12. package/dest/barretenberg_api/common.test.js +18 -0
  13. package/dest/barretenberg_api/index.d.ts +101 -0
  14. package/dest/barretenberg_api/index.d.ts.map +1 -0
  15. package/dest/barretenberg_api/index.js +371 -0
  16. package/dest/barretenberg_api/pedersen.test.d.ts +2 -0
  17. package/dest/barretenberg_api/pedersen.test.d.ts.map +1 -0
  18. package/dest/barretenberg_api/pedersen.test.js +69 -0
  19. package/dest/barretenberg_api/schnorr.test.d.ts +2 -0
  20. package/dest/barretenberg_api/schnorr.test.d.ts.map +1 -0
  21. package/dest/barretenberg_api/schnorr.test.js +113 -0
  22. package/dest/barretenberg_binder/heap_allocator.d.ts +22 -0
  23. package/dest/barretenberg_binder/heap_allocator.d.ts.map +1 -0
  24. package/dest/barretenberg_binder/heap_allocator.js +59 -0
  25. package/dest/barretenberg_binder/heap_allocator_sync.d.ts +22 -0
  26. package/dest/barretenberg_binder/heap_allocator_sync.d.ts.map +1 -0
  27. package/dest/barretenberg_binder/heap_allocator_sync.js +58 -0
  28. package/dest/barretenberg_binder/index.d.ts +32 -0
  29. package/dest/barretenberg_binder/index.d.ts.map +1 -0
  30. package/dest/barretenberg_binder/index.js +73 -0
  31. package/dest/barretenberg_wasm/barretenberg_wasm.d.ts +49 -0
  32. package/dest/barretenberg_wasm/barretenberg_wasm.d.ts.map +1 -0
  33. package/dest/barretenberg_wasm/barretenberg_wasm.js +190 -0
  34. package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts +2 -0
  35. package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts.map +1 -0
  36. package/dest/barretenberg_wasm/barretenberg_wasm.test.js +43 -0
  37. package/dest/barretenberg_wasm/browser/index.d.ts +8 -0
  38. package/dest/barretenberg_wasm/browser/index.d.ts.map +1 -0
  39. package/dest/barretenberg_wasm/browser/index.js +26 -0
  40. package/dest/barretenberg_wasm/browser/worker.d.ts +2 -0
  41. package/dest/barretenberg_wasm/browser/worker.d.ts.map +1 -0
  42. package/dest/barretenberg_wasm/browser/worker.js +11 -0
  43. package/dest/barretenberg_wasm/index.d.ts +2 -0
  44. package/dest/barretenberg_wasm/index.d.ts.map +1 -0
  45. package/dest/barretenberg_wasm/index.js +2 -0
  46. package/dest/barretenberg_wasm/node/index.d.ts +17 -0
  47. package/dest/barretenberg_wasm/node/index.d.ts.map +1 -0
  48. package/dest/barretenberg_wasm/node/index.js +40 -0
  49. package/dest/barretenberg_wasm/node/node_endpoint.d.ts +8 -0
  50. package/dest/barretenberg_wasm/node/node_endpoint.d.ts.map +1 -0
  51. package/dest/barretenberg_wasm/node/node_endpoint.js +28 -0
  52. package/dest/barretenberg_wasm/node/worker.d.ts +2 -0
  53. package/dest/barretenberg_wasm/node/worker.d.ts.map +1 -0
  54. package/dest/barretenberg_wasm/node/worker.js +9 -0
  55. package/dest/barretenberg_wasm.js +2 -0
  56. package/dest/barretenberg_wasm.js.LICENSE.txt +5 -0
  57. package/dest/bigint-array/index.d.ts +3 -0
  58. package/dest/bigint-array/index.d.ts.map +1 -0
  59. package/dest/bigint-array/index.js +21 -0
  60. package/dest/bindgen/function_declaration.d.ts +11 -0
  61. package/dest/bindgen/function_declaration.d.ts.map +1 -0
  62. package/dest/bindgen/function_declaration.js +2 -0
  63. package/dest/bindgen/index.d.ts +2 -0
  64. package/dest/bindgen/index.d.ts.map +1 -0
  65. package/dest/bindgen/index.js +15 -0
  66. package/dest/bindgen/mappings.d.ts +4 -0
  67. package/dest/bindgen/mappings.d.ts.map +1 -0
  68. package/dest/bindgen/mappings.js +63 -0
  69. package/dest/bindgen/rust.d.ts +2 -0
  70. package/dest/bindgen/rust.d.ts.map +1 -0
  71. package/dest/bindgen/rust.js +43 -0
  72. package/dest/bindgen/to_camel_case.d.ts +2 -0
  73. package/dest/bindgen/to_camel_case.d.ts.map +1 -0
  74. package/dest/bindgen/to_camel_case.js +11 -0
  75. package/dest/bindgen/typescript.d.ts +2 -0
  76. package/dest/bindgen/typescript.d.ts.map +1 -0
  77. package/dest/bindgen/typescript.js +80 -0
  78. package/dest/crs/browser/cached_net_crs.d.ts +25 -0
  79. package/dest/crs/browser/cached_net_crs.d.ts.map +1 -0
  80. package/dest/crs/browser/cached_net_crs.js +54 -0
  81. package/dest/crs/browser/index.d.ts +2 -0
  82. package/dest/crs/browser/index.d.ts.map +1 -0
  83. package/dest/crs/browser/index.js +2 -0
  84. package/dest/crs/index.d.ts +2 -0
  85. package/dest/crs/index.d.ts.map +1 -0
  86. package/dest/crs/index.js +2 -0
  87. package/dest/crs/net_crs.d.ts +36 -0
  88. package/dest/crs/net_crs.d.ts.map +1 -0
  89. package/dest/crs/net_crs.js +59 -0
  90. package/dest/crs/node/file_crs.d.ts +37 -0
  91. package/dest/crs/node/file_crs.d.ts.map +1 -0
  92. package/dest/crs/node/file_crs.js +51 -0
  93. package/dest/crs/node/index.d.ts +31 -0
  94. package/dest/crs/node/index.d.ts.map +1 -0
  95. package/dest/crs/node/index.js +41 -0
  96. package/dest/examples/simple.rawtest.d.ts +2 -0
  97. package/dest/examples/simple.rawtest.d.ts.map +1 -0
  98. package/dest/examples/simple.rawtest.js +24 -0
  99. package/dest/examples/simple.test.d.ts +2 -0
  100. package/dest/examples/simple.test.d.ts.map +1 -0
  101. package/dest/examples/simple.test.js +22 -0
  102. package/dest/factory/index.d.ts +21 -0
  103. package/dest/factory/index.d.ts.map +1 -0
  104. package/dest/factory/index.js +34 -0
  105. package/dest/index.d.ts +4 -0
  106. package/dest/index.d.ts.map +1 -0
  107. package/dest/index.html +1 -0
  108. package/dest/index.js +4 -0
  109. package/dest/main-dev.d.ts +3 -0
  110. package/dest/main-dev.d.ts.map +1 -0
  111. package/dest/main-dev.js +3 -0
  112. package/dest/main.d.ts +10 -0
  113. package/dest/main.d.ts.map +1 -0
  114. package/dest/main.js +288 -0
  115. package/dest/random/browser/index.d.ts +2 -0
  116. package/dest/random/browser/index.d.ts.map +1 -0
  117. package/dest/random/browser/index.js +31 -0
  118. package/dest/random/index.d.ts +2 -0
  119. package/dest/random/index.d.ts.map +1 -0
  120. package/dest/random/index.js +2 -0
  121. package/dest/random/node/index.d.ts +2 -0
  122. package/dest/random/node/index.d.ts.map +1 -0
  123. package/dest/random/node/index.js +5 -0
  124. package/dest/serialize/buffer_reader.d.ts +28 -0
  125. package/dest/serialize/buffer_reader.d.ts.map +1 -0
  126. package/dest/serialize/buffer_reader.js +66 -0
  127. package/dest/serialize/index.d.ts +4 -0
  128. package/dest/serialize/index.d.ts.map +1 -0
  129. package/dest/serialize/index.js +4 -0
  130. package/dest/serialize/output_type.d.ts +11 -0
  131. package/dest/serialize/output_type.d.ts.map +1 -0
  132. package/dest/serialize/output_type.js +44 -0
  133. package/dest/serialize/serialize.d.ts +53 -0
  134. package/dest/serialize/serialize.d.ts.map +1 -0
  135. package/dest/serialize/serialize.js +139 -0
  136. package/dest/simple_test.js +2 -0
  137. package/dest/simple_test.js.LICENSE.txt +14 -0
  138. package/dest/types/fields.d.ts +33 -0
  139. package/dest/types/fields.d.ts.map +1 -0
  140. package/dest/types/fields.js +86 -0
  141. package/dest/types/fixed_size_buffer.d.ts +26 -0
  142. package/dest/types/fixed_size_buffer.d.ts.map +1 -0
  143. package/dest/types/fixed_size_buffer.js +54 -0
  144. package/dest/types/index.d.ts +6 -0
  145. package/dest/types/index.d.ts.map +1 -0
  146. package/dest/types/index.js +6 -0
  147. package/dest/types/point.d.ts +17 -0
  148. package/dest/types/point.d.ts.map +1 -0
  149. package/dest/types/point.js +32 -0
  150. package/dest/types/ptr.d.ts +13 -0
  151. package/dest/types/ptr.d.ts.map +1 -0
  152. package/dest/types/ptr.js +20 -0
  153. package/dest/types/raw_buffer.d.ts +3 -0
  154. package/dest/types/raw_buffer.d.ts.map +1 -0
  155. package/dest/types/raw_buffer.js +5 -0
  156. package/package.json +79 -0
  157. package/src/async_map/index.ts +15 -0
  158. package/src/barretenberg_api/blake2s.test.ts +39 -0
  159. package/src/barretenberg_api/common.test.ts +21 -0
  160. package/src/barretenberg_api/index.ts +461 -0
  161. package/src/barretenberg_api/pedersen.test.ts +84 -0
  162. package/src/barretenberg_api/schnorr.test.ts +169 -0
  163. package/src/barretenberg_binder/heap_allocator.ts +62 -0
  164. package/src/barretenberg_binder/heap_allocator_sync.ts +61 -0
  165. package/src/barretenberg_binder/index.ts +76 -0
  166. package/src/barretenberg_wasm/barretenberg_wasm.test.ts +52 -0
  167. package/src/barretenberg_wasm/barretenberg_wasm.ts +222 -0
  168. package/src/barretenberg_wasm/browser/index.ts +32 -0
  169. package/src/barretenberg_wasm/browser/worker.ts +13 -0
  170. package/src/barretenberg_wasm/index.ts +1 -0
  171. package/src/barretenberg_wasm/node/index.ts +46 -0
  172. package/src/barretenberg_wasm/node/node_endpoint.ts +28 -0
  173. package/src/barretenberg_wasm/node/worker.ts +10 -0
  174. package/src/bigint-array/index.ts +21 -0
  175. package/src/bindgen/function_declaration.ts +11 -0
  176. package/src/bindgen/index.ts +17 -0
  177. package/src/bindgen/mappings.ts +66 -0
  178. package/src/bindgen/rust.ts +52 -0
  179. package/src/bindgen/to_camel_case.ts +10 -0
  180. package/src/bindgen/typescript.ts +91 -0
  181. package/src/crs/browser/cached_net_crs.ts +60 -0
  182. package/src/crs/browser/index.ts +1 -0
  183. package/src/crs/index.ts +1 -0
  184. package/src/crs/net_crs.ts +69 -0
  185. package/src/crs/node/file_crs.ts +60 -0
  186. package/src/crs/node/index.ts +48 -0
  187. package/src/examples/simple.rawtest.ts +32 -0
  188. package/src/examples/simple.test.ts +27 -0
  189. package/src/factory/index.ts +36 -0
  190. package/src/index.html +9 -0
  191. package/src/index.ts +3 -0
  192. package/src/main-dev.ts +2 -0
  193. package/src/main.ts +329 -0
  194. package/src/random/browser/index.ts +32 -0
  195. package/src/random/index.ts +1 -0
  196. package/src/random/node/index.ts +5 -0
  197. package/src/serialize/buffer_reader.ts +82 -0
  198. package/src/serialize/index.ts +3 -0
  199. package/src/serialize/output_type.ts +53 -0
  200. package/src/serialize/serialize.ts +157 -0
  201. package/src/types/fields.ts +98 -0
  202. package/src/types/fixed_size_buffer.ts +59 -0
  203. package/src/types/index.ts +5 -0
  204. package/src/types/point.ts +35 -0
  205. package/src/types/ptr.ts +20 -0
  206. package/src/types/raw_buffer.ts +3 -0
@@ -0,0 +1,371 @@
1
+ import { BufferDeserializer, NumberDeserializer, VectorDeserializer, BoolDeserializer, StringDeserializer } from '../serialize/index.js';
2
+ import { Fr, Fq, Point, Buffer32, Buffer128, Ptr } from '../types/index.js';
3
+ export class BarretenbergApi {
4
+ constructor(binder) {
5
+ this.binder = binder;
6
+ }
7
+ async destroy() {
8
+ await this.binder.wasm.destroy();
9
+ }
10
+ async pedersenInit() {
11
+ const result = await this.binder.callWasmExport('pedersen_init', [], []);
12
+ return;
13
+ }
14
+ async pedersenCompressFields(left, right) {
15
+ const result = await this.binder.callWasmExport('pedersen_compress_fields', [left, right], [Fr]);
16
+ return result[0];
17
+ }
18
+ async pedersenPlookupCompressFields(left, right) {
19
+ const result = await this.binder.callWasmExport('pedersen_plookup_compress_fields', [left, right], [Fr]);
20
+ return result[0];
21
+ }
22
+ async pedersenCompress(inputsBuffer) {
23
+ const result = await this.binder.callWasmExport('pedersen_compress', [inputsBuffer], [Fr]);
24
+ return result[0];
25
+ }
26
+ async pedersenPlookupCompress(inputsBuffer) {
27
+ const result = await this.binder.callWasmExport('pedersen_plookup_compress', [inputsBuffer], [Fr]);
28
+ return result[0];
29
+ }
30
+ async pedersenCompressWithHashIndex(inputsBuffer, hashIndex) {
31
+ const result = await this.binder.callWasmExport('pedersen_compress_with_hash_index', [inputsBuffer, hashIndex], [Fr]);
32
+ return result[0];
33
+ }
34
+ async pedersenCommit(inputsBuffer) {
35
+ const result = await this.binder.callWasmExport('pedersen_commit', [inputsBuffer], [Fr]);
36
+ return result[0];
37
+ }
38
+ async pedersenPlookupCommit(inputsBuffer) {
39
+ const result = await this.binder.callWasmExport('pedersen_plookup_commit', [inputsBuffer], [Fr]);
40
+ return result[0];
41
+ }
42
+ async pedersenBufferToField(data) {
43
+ const result = await this.binder.callWasmExport('pedersen_buffer_to_field', [data], [Fr]);
44
+ return result[0];
45
+ }
46
+ async pedersenHashInit() {
47
+ const result = await this.binder.callWasmExport('pedersen_hash_init', [], []);
48
+ return;
49
+ }
50
+ async pedersenHashPair(left, right) {
51
+ const result = await this.binder.callWasmExport('pedersen_hash_pair', [left, right], [Fr]);
52
+ return result[0];
53
+ }
54
+ async pedersenHashMultiple(inputsBuffer) {
55
+ const result = await this.binder.callWasmExport('pedersen_hash_multiple', [inputsBuffer], [Fr]);
56
+ return result[0];
57
+ }
58
+ async pedersenHashMultipleWithHashIndex(inputsBuffer, hashIndex) {
59
+ const result = await this.binder.callWasmExport('pedersen_hash_multiple_with_hash_index', [inputsBuffer, hashIndex], [Fr]);
60
+ return result[0];
61
+ }
62
+ async pedersenHashToTree(data) {
63
+ const result = await this.binder.callWasmExport('pedersen_hash_to_tree', [data], [VectorDeserializer(Fr)]);
64
+ return result[0];
65
+ }
66
+ async blake2s(data) {
67
+ const result = await this.binder.callWasmExport('blake2s', [data], [Buffer32]);
68
+ return result[0];
69
+ }
70
+ async blake2sToField(data) {
71
+ const result = await this.binder.callWasmExport('blake2s_to_field_', [data], [Fr]);
72
+ return result[0];
73
+ }
74
+ async schnorrComputePublicKey(privateKey) {
75
+ const result = await this.binder.callWasmExport('schnorr_compute_public_key', [privateKey], [Point]);
76
+ return result[0];
77
+ }
78
+ async schnorrNegatePublicKey(publicKeyBuffer) {
79
+ const result = await this.binder.callWasmExport('schnorr_negate_public_key', [publicKeyBuffer], [Point]);
80
+ return result[0];
81
+ }
82
+ async schnorrConstructSignature(message, privateKey) {
83
+ const result = await this.binder.callWasmExport('schnorr_construct_signature', [message, privateKey], [Buffer32, Buffer32]);
84
+ return result;
85
+ }
86
+ async schnorrVerifySignature(message, pubKey, sigS, sigE) {
87
+ const result = await this.binder.callWasmExport('schnorr_verify_signature', [message, pubKey, sigS, sigE], [BoolDeserializer()]);
88
+ return result[0];
89
+ }
90
+ async schnorrMultisigCreateMultisigPublicKey(privateKey) {
91
+ const result = await this.binder.callWasmExport('schnorr_multisig_create_multisig_public_key', [privateKey], [Buffer128]);
92
+ return result[0];
93
+ }
94
+ async schnorrMultisigValidateAndCombineSignerPubkeys(signerPubkeyBuf) {
95
+ const result = await this.binder.callWasmExport('schnorr_multisig_validate_and_combine_signer_pubkeys', [signerPubkeyBuf], [Point, BoolDeserializer()]);
96
+ return result;
97
+ }
98
+ async schnorrMultisigConstructSignatureRound1() {
99
+ const result = await this.binder.callWasmExport('schnorr_multisig_construct_signature_round_1', [], [Buffer128, Buffer128]);
100
+ return result;
101
+ }
102
+ async schnorrMultisigConstructSignatureRound2(message, privateKey, signerRoundOnePrivateBuf, signerPubkeysBuf, roundOnePublicBuf) {
103
+ const result = await this.binder.callWasmExport('schnorr_multisig_construct_signature_round_2', [message, privateKey, signerRoundOnePrivateBuf, signerPubkeysBuf, roundOnePublicBuf], [Fq, BoolDeserializer()]);
104
+ return result;
105
+ }
106
+ async schnorrMultisigCombineSignatures(message, signerPubkeysBuf, roundOneBuf, roundTwoBuf) {
107
+ const result = await this.binder.callWasmExport('schnorr_multisig_combine_signatures', [message, signerPubkeysBuf, roundOneBuf, roundTwoBuf], [Buffer32, Buffer32, BoolDeserializer()]);
108
+ return result;
109
+ }
110
+ async srsInitSrs(pointsBuf, numPoints, g2PointBuf) {
111
+ const result = await this.binder.callWasmExport('srs_init_srs', [pointsBuf, numPoints, g2PointBuf], []);
112
+ return;
113
+ }
114
+ async examplesSimpleCreateAndVerifyProof() {
115
+ const result = await this.binder.callWasmExport('examples_simple_create_and_verify_proof', [], [BoolDeserializer()]);
116
+ return result[0];
117
+ }
118
+ async testThreads(threads, iterations) {
119
+ const result = await this.binder.callWasmExport('test_threads', [threads, iterations], [NumberDeserializer()]);
120
+ return result[0];
121
+ }
122
+ async testThreadAbort() {
123
+ const result = await this.binder.callWasmExport('test_thread_abort', [], []);
124
+ return;
125
+ }
126
+ async testAbort() {
127
+ const result = await this.binder.callWasmExport('test_abort', [], []);
128
+ return;
129
+ }
130
+ async commonInitSlabAllocator(circuitSize) {
131
+ const result = await this.binder.callWasmExport('common_init_slab_allocator', [circuitSize], []);
132
+ return;
133
+ }
134
+ async acirGetCircuitSizes(constraintSystemBuf) {
135
+ const result = await this.binder.callWasmExport('acir_get_circuit_sizes', [constraintSystemBuf], [NumberDeserializer(), NumberDeserializer(), NumberDeserializer()]);
136
+ return result;
137
+ }
138
+ async acirNewAcirComposer() {
139
+ const result = await this.binder.callWasmExport('acir_new_acir_composer', [], [Ptr]);
140
+ return result[0];
141
+ }
142
+ async acirDeleteAcirComposer(acirComposerPtr) {
143
+ const result = await this.binder.callWasmExport('acir_delete_acir_composer', [acirComposerPtr], []);
144
+ return;
145
+ }
146
+ async acirCreateCircuit(acirComposerPtr, constraintSystemBuf, sizeHint) {
147
+ const result = await this.binder.callWasmExport('acir_create_circuit', [acirComposerPtr, constraintSystemBuf, sizeHint], []);
148
+ return;
149
+ }
150
+ async acirInitProvingKey(acirComposerPtr, constraintSystemBuf, sizeHint) {
151
+ const result = await this.binder.callWasmExport('acir_init_proving_key', [acirComposerPtr, constraintSystemBuf, sizeHint], []);
152
+ return;
153
+ }
154
+ async acirCreateProof(acirComposerPtr, constraintSystemBuf, witnessBuf, isRecursive) {
155
+ const result = await this.binder.callWasmExport('acir_create_proof', [acirComposerPtr, constraintSystemBuf, witnessBuf, isRecursive], [BufferDeserializer()]);
156
+ return result[0];
157
+ }
158
+ async acirLoadVerificationKey(acirComposerPtr, vkBuf) {
159
+ const result = await this.binder.callWasmExport('acir_load_verification_key', [acirComposerPtr, vkBuf], []);
160
+ return;
161
+ }
162
+ async acirInitVerificationKey(acirComposerPtr) {
163
+ const result = await this.binder.callWasmExport('acir_init_verification_key', [acirComposerPtr], []);
164
+ return;
165
+ }
166
+ async acirGetVerificationKey(acirComposerPtr) {
167
+ const result = await this.binder.callWasmExport('acir_get_verification_key', [acirComposerPtr], [BufferDeserializer()]);
168
+ return result[0];
169
+ }
170
+ async acirVerifyProof(acirComposerPtr, proofBuf, isRecursive) {
171
+ const result = await this.binder.callWasmExport('acir_verify_proof', [acirComposerPtr, proofBuf, isRecursive], [BoolDeserializer()]);
172
+ return result[0];
173
+ }
174
+ async acirGetSolidityVerifier(acirComposerPtr) {
175
+ const result = await this.binder.callWasmExport('acir_get_solidity_verifier', [acirComposerPtr], [StringDeserializer()]);
176
+ return result[0];
177
+ }
178
+ async acirSerializeProofIntoFields(acirComposerPtr, proofBuf, numInnerPublicInputs) {
179
+ const result = await this.binder.callWasmExport('acir_serialize_proof_into_fields', [acirComposerPtr, proofBuf, numInnerPublicInputs], [VectorDeserializer(Fr)]);
180
+ return result[0];
181
+ }
182
+ async acirSerializeVerificationKeyIntoFields(acirComposerPtr) {
183
+ const result = await this.binder.callWasmExport('acir_serialize_verification_key_into_fields', [acirComposerPtr], [VectorDeserializer(Fr), Fr]);
184
+ return result;
185
+ }
186
+ }
187
+ export class BarretenbergApiSync {
188
+ constructor(binder) {
189
+ this.binder = binder;
190
+ }
191
+ async destroy() {
192
+ await this.binder.wasm.destroy();
193
+ }
194
+ pedersenInit() {
195
+ const result = this.binder.callWasmExport('pedersen_init', [], []);
196
+ return;
197
+ }
198
+ pedersenCompressFields(left, right) {
199
+ const result = this.binder.callWasmExport('pedersen_compress_fields', [left, right], [Fr]);
200
+ return result[0];
201
+ }
202
+ pedersenPlookupCompressFields(left, right) {
203
+ const result = this.binder.callWasmExport('pedersen_plookup_compress_fields', [left, right], [Fr]);
204
+ return result[0];
205
+ }
206
+ pedersenCompress(inputsBuffer) {
207
+ const result = this.binder.callWasmExport('pedersen_compress', [inputsBuffer], [Fr]);
208
+ return result[0];
209
+ }
210
+ pedersenPlookupCompress(inputsBuffer) {
211
+ const result = this.binder.callWasmExport('pedersen_plookup_compress', [inputsBuffer], [Fr]);
212
+ return result[0];
213
+ }
214
+ pedersenCompressWithHashIndex(inputsBuffer, hashIndex) {
215
+ const result = this.binder.callWasmExport('pedersen_compress_with_hash_index', [inputsBuffer, hashIndex], [Fr]);
216
+ return result[0];
217
+ }
218
+ pedersenCommit(inputsBuffer) {
219
+ const result = this.binder.callWasmExport('pedersen_commit', [inputsBuffer], [Fr]);
220
+ return result[0];
221
+ }
222
+ pedersenPlookupCommit(inputsBuffer) {
223
+ const result = this.binder.callWasmExport('pedersen_plookup_commit', [inputsBuffer], [Fr]);
224
+ return result[0];
225
+ }
226
+ pedersenBufferToField(data) {
227
+ const result = this.binder.callWasmExport('pedersen_buffer_to_field', [data], [Fr]);
228
+ return result[0];
229
+ }
230
+ pedersenHashInit() {
231
+ const result = this.binder.callWasmExport('pedersen_hash_init', [], []);
232
+ return;
233
+ }
234
+ pedersenHashPair(left, right) {
235
+ const result = this.binder.callWasmExport('pedersen_hash_pair', [left, right], [Fr]);
236
+ return result[0];
237
+ }
238
+ pedersenHashMultiple(inputsBuffer) {
239
+ const result = this.binder.callWasmExport('pedersen_hash_multiple', [inputsBuffer], [Fr]);
240
+ return result[0];
241
+ }
242
+ pedersenHashMultipleWithHashIndex(inputsBuffer, hashIndex) {
243
+ const result = this.binder.callWasmExport('pedersen_hash_multiple_with_hash_index', [inputsBuffer, hashIndex], [Fr]);
244
+ return result[0];
245
+ }
246
+ pedersenHashToTree(data) {
247
+ const result = this.binder.callWasmExport('pedersen_hash_to_tree', [data], [VectorDeserializer(Fr)]);
248
+ return result[0];
249
+ }
250
+ blake2s(data) {
251
+ const result = this.binder.callWasmExport('blake2s', [data], [Buffer32]);
252
+ return result[0];
253
+ }
254
+ blake2sToField(data) {
255
+ const result = this.binder.callWasmExport('blake2s_to_field_', [data], [Fr]);
256
+ return result[0];
257
+ }
258
+ schnorrComputePublicKey(privateKey) {
259
+ const result = this.binder.callWasmExport('schnorr_compute_public_key', [privateKey], [Point]);
260
+ return result[0];
261
+ }
262
+ schnorrNegatePublicKey(publicKeyBuffer) {
263
+ const result = this.binder.callWasmExport('schnorr_negate_public_key', [publicKeyBuffer], [Point]);
264
+ return result[0];
265
+ }
266
+ schnorrConstructSignature(message, privateKey) {
267
+ const result = this.binder.callWasmExport('schnorr_construct_signature', [message, privateKey], [Buffer32, Buffer32]);
268
+ return result;
269
+ }
270
+ schnorrVerifySignature(message, pubKey, sigS, sigE) {
271
+ const result = this.binder.callWasmExport('schnorr_verify_signature', [message, pubKey, sigS, sigE], [BoolDeserializer()]);
272
+ return result[0];
273
+ }
274
+ schnorrMultisigCreateMultisigPublicKey(privateKey) {
275
+ const result = this.binder.callWasmExport('schnorr_multisig_create_multisig_public_key', [privateKey], [Buffer128]);
276
+ return result[0];
277
+ }
278
+ schnorrMultisigValidateAndCombineSignerPubkeys(signerPubkeyBuf) {
279
+ const result = this.binder.callWasmExport('schnorr_multisig_validate_and_combine_signer_pubkeys', [signerPubkeyBuf], [Point, BoolDeserializer()]);
280
+ return result;
281
+ }
282
+ schnorrMultisigConstructSignatureRound1() {
283
+ const result = this.binder.callWasmExport('schnorr_multisig_construct_signature_round_1', [], [Buffer128, Buffer128]);
284
+ return result;
285
+ }
286
+ schnorrMultisigConstructSignatureRound2(message, privateKey, signerRoundOnePrivateBuf, signerPubkeysBuf, roundOnePublicBuf) {
287
+ const result = this.binder.callWasmExport('schnorr_multisig_construct_signature_round_2', [message, privateKey, signerRoundOnePrivateBuf, signerPubkeysBuf, roundOnePublicBuf], [Fq, BoolDeserializer()]);
288
+ return result;
289
+ }
290
+ schnorrMultisigCombineSignatures(message, signerPubkeysBuf, roundOneBuf, roundTwoBuf) {
291
+ const result = this.binder.callWasmExport('schnorr_multisig_combine_signatures', [message, signerPubkeysBuf, roundOneBuf, roundTwoBuf], [Buffer32, Buffer32, BoolDeserializer()]);
292
+ return result;
293
+ }
294
+ srsInitSrs(pointsBuf, numPoints, g2PointBuf) {
295
+ const result = this.binder.callWasmExport('srs_init_srs', [pointsBuf, numPoints, g2PointBuf], []);
296
+ return;
297
+ }
298
+ examplesSimpleCreateAndVerifyProof() {
299
+ const result = this.binder.callWasmExport('examples_simple_create_and_verify_proof', [], [BoolDeserializer()]);
300
+ return result[0];
301
+ }
302
+ testThreads(threads, iterations) {
303
+ const result = this.binder.callWasmExport('test_threads', [threads, iterations], [NumberDeserializer()]);
304
+ return result[0];
305
+ }
306
+ testThreadAbort() {
307
+ const result = this.binder.callWasmExport('test_thread_abort', [], []);
308
+ return;
309
+ }
310
+ testAbort() {
311
+ const result = this.binder.callWasmExport('test_abort', [], []);
312
+ return;
313
+ }
314
+ commonInitSlabAllocator(circuitSize) {
315
+ const result = this.binder.callWasmExport('common_init_slab_allocator', [circuitSize], []);
316
+ return;
317
+ }
318
+ acirGetCircuitSizes(constraintSystemBuf) {
319
+ const result = this.binder.callWasmExport('acir_get_circuit_sizes', [constraintSystemBuf], [NumberDeserializer(), NumberDeserializer(), NumberDeserializer()]);
320
+ return result;
321
+ }
322
+ acirNewAcirComposer() {
323
+ const result = this.binder.callWasmExport('acir_new_acir_composer', [], [Ptr]);
324
+ return result[0];
325
+ }
326
+ acirDeleteAcirComposer(acirComposerPtr) {
327
+ const result = this.binder.callWasmExport('acir_delete_acir_composer', [acirComposerPtr], []);
328
+ return;
329
+ }
330
+ acirCreateCircuit(acirComposerPtr, constraintSystemBuf, sizeHint) {
331
+ const result = this.binder.callWasmExport('acir_create_circuit', [acirComposerPtr, constraintSystemBuf, sizeHint], []);
332
+ return;
333
+ }
334
+ acirInitProvingKey(acirComposerPtr, constraintSystemBuf, sizeHint) {
335
+ const result = this.binder.callWasmExport('acir_init_proving_key', [acirComposerPtr, constraintSystemBuf, sizeHint], []);
336
+ return;
337
+ }
338
+ acirCreateProof(acirComposerPtr, constraintSystemBuf, witnessBuf, isRecursive) {
339
+ const result = this.binder.callWasmExport('acir_create_proof', [acirComposerPtr, constraintSystemBuf, witnessBuf, isRecursive], [BufferDeserializer()]);
340
+ return result[0];
341
+ }
342
+ acirLoadVerificationKey(acirComposerPtr, vkBuf) {
343
+ const result = this.binder.callWasmExport('acir_load_verification_key', [acirComposerPtr, vkBuf], []);
344
+ return;
345
+ }
346
+ acirInitVerificationKey(acirComposerPtr) {
347
+ const result = this.binder.callWasmExport('acir_init_verification_key', [acirComposerPtr], []);
348
+ return;
349
+ }
350
+ acirGetVerificationKey(acirComposerPtr) {
351
+ const result = this.binder.callWasmExport('acir_get_verification_key', [acirComposerPtr], [BufferDeserializer()]);
352
+ return result[0];
353
+ }
354
+ acirVerifyProof(acirComposerPtr, proofBuf, isRecursive) {
355
+ const result = this.binder.callWasmExport('acir_verify_proof', [acirComposerPtr, proofBuf, isRecursive], [BoolDeserializer()]);
356
+ return result[0];
357
+ }
358
+ acirGetSolidityVerifier(acirComposerPtr) {
359
+ const result = this.binder.callWasmExport('acir_get_solidity_verifier', [acirComposerPtr], [StringDeserializer()]);
360
+ return result[0];
361
+ }
362
+ acirSerializeProofIntoFields(acirComposerPtr, proofBuf, numInnerPublicInputs) {
363
+ const result = this.binder.callWasmExport('acir_serialize_proof_into_fields', [acirComposerPtr, proofBuf, numInnerPublicInputs], [VectorDeserializer(Fr)]);
364
+ return result[0];
365
+ }
366
+ acirSerializeVerificationKeyIntoFields(acirComposerPtr) {
367
+ const result = this.binder.callWasmExport('acir_serialize_verification_key_into_fields', [acirComposerPtr], [VectorDeserializer(Fr), Fr]);
368
+ return result;
369
+ }
370
+ }
371
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYmFycmV0ZW5iZXJnX2FwaS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsZ0JBQWdCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6SSxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUU1RSxNQUFNLE9BQU8sZUFBZTtJQUMxQixZQUFtQixNQUEwQjtRQUExQixXQUFNLEdBQU4sTUFBTSxDQUFvQjtJQUFHLENBQUM7SUFFakQsS0FBSyxDQUFDLE9BQU87UUFDWCxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFRCxLQUFLLENBQUMsWUFBWTtRQUNoQixNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLGVBQWUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDekUsT0FBTztJQUNULENBQUM7SUFFRCxLQUFLLENBQUMsc0JBQXNCLENBQUMsSUFBUSxFQUFFLEtBQVM7UUFDOUMsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQywwQkFBMEIsRUFBRSxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDakcsT0FBTyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbkIsQ0FBQztJQUVELEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxJQUFRLEVBQUUsS0FBUztRQUNyRCxNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMs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
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=pedersen.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pedersen.test.d.ts","sourceRoot":"","sources":["../../src/barretenberg_api/pedersen.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,69 @@
1
+ import { newBarretenbergApiSync } from '../factory/index.js';
2
+ import { Fr } from '../types/index.js';
3
+ describe('pedersen', () => {
4
+ let api;
5
+ beforeAll(async () => {
6
+ api = await newBarretenbergApiSync();
7
+ api.pedersenHashInit();
8
+ });
9
+ afterAll(async () => {
10
+ await api.destroy();
11
+ });
12
+ it('pedersenCompressFields', () => {
13
+ const result = api.pedersenCompressFields(new Fr(4n), new Fr(8n));
14
+ expect(result).toEqual(new Fr(16672613430297770667465722499387909817686322516130512258122141976728892914370n));
15
+ });
16
+ it('pedersenPlookupCompressFields', () => {
17
+ const result = api.pedersenPlookupCompressFields(new Fr(4n), new Fr(8n));
18
+ expect(result).toEqual(new Fr(21568810706345846819294487214368613840251909831689369685420108292337497444070n));
19
+ });
20
+ it('pedersenCompress', () => {
21
+ const result = api.pedersenCompress([new Fr(4n), new Fr(8n), new Fr(12n)]);
22
+ expect(result).toEqual(new Fr(20749503715308760529311051818180468653739005441229560405092292242074298877245n));
23
+ });
24
+ it('pedersenPlookupCompress', () => {
25
+ const result = api.pedersenPlookupCompress([new Fr(4n), new Fr(8n), new Fr(12n)]);
26
+ expect(result).toEqual(new Fr(4213911891650716450883144878301329379460622830501147795631256054071351353887n));
27
+ });
28
+ it('pedersenCompressWithHashIndex', () => {
29
+ const result = api.pedersenCompressWithHashIndex([new Fr(4n), new Fr(8n)], 7);
30
+ expect(result).toEqual(new Fr(12675961871866002745031098923411501942277744385859978302365013982702509949754n));
31
+ });
32
+ it('pedersenCommit', () => {
33
+ const result = api.pedersenCommit([new Fr(4n), new Fr(8n), new Fr(12n)]);
34
+ expect(result).toEqual(new Fr(20749503715308760529311051818180468653739005441229560405092292242074298877245n));
35
+ });
36
+ it('pedersenPlookupCommit', () => {
37
+ const result = api.pedersenPlookupCommit([new Fr(4n), new Fr(8n)]);
38
+ expect(result).toEqual(new Fr(21568810706345846819294487214368613840251909831689369685420108292337497444070n));
39
+ });
40
+ it('pedersenBufferToField', () => {
41
+ const result = api.pedersenBufferToField(Buffer.from('Hello world! I am a buffer to be converted to a field!'));
42
+ expect(result).toEqual(new Fr(4923399520610513632896240312051201308554838580477778325691012985962614653619n));
43
+ });
44
+ it('pedersenHashPair', () => {
45
+ const result = api.pedersenHashPair(new Fr(4n), new Fr(8n));
46
+ expect(result).toEqual(new Fr(7508407170365331152493586290597472346478280823936748458450026785528968221772n));
47
+ });
48
+ it('pedersenHashMultiple', () => {
49
+ const result = api.pedersenHashMultiple([new Fr(4n), new Fr(8n), new Fr(12n)]);
50
+ expect(result).toEqual(new Fr(641613987782189905475142047603559162464012327378197326488471789040703504911n));
51
+ });
52
+ it('pedersenHashMultipleWithHashIndex', () => {
53
+ const result = api.pedersenHashMultipleWithHashIndex([new Fr(4n), new Fr(8n)], 7);
54
+ expect(result).toEqual(new Fr(14181105996307540196932058280391669339364159586581375348016341320932872505408n));
55
+ });
56
+ it('pedersenHashToTree', () => {
57
+ const result = api.pedersenHashToTree([new Fr(4n), new Fr(8n), new Fr(12n), new Fr(16n)]);
58
+ expect(result).toEqual([
59
+ new Fr(4n),
60
+ new Fr(8n),
61
+ new Fr(12n),
62
+ new Fr(16n),
63
+ new Fr(7508407170365331152493586290597472346478280823936748458450026785528968221772n),
64
+ new Fr(61370238324203854110612958249832030753990119715269709182131929073387209477n),
65
+ new Fr(7696240979753031171651958947943309270095593128155855154123615677953596407768n),
66
+ ]);
67
+ });
68
+ });
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVkZXJzZW4udGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iYXJyZXRlbmJlcmdfYXBpL3BlZGVyc2VuLnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDN0QsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBR3ZDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsR0FBRyxFQUFFO0lBQ3hCLElBQUksR0FBd0IsQ0FBQztJQUU3QixTQUFTLENBQUMsS0FBSyxJQUFJLEVBQUU7UUFDbkIsR0FBRyxHQUFHLE1BQU0sc0JBQXNCLEVBQUUsQ0FBQztRQUNyQyxHQUFHLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUN6QixDQUFDLENBQUMsQ0FBQztJQUVILFFBQVEsQ0FBQyxLQUFLLElBQUksRUFBRTtRQUNsQixNQUFNLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUN0QixDQUFDLENBQUMsQ0FBQztJQUVILEVBQUUsQ0FBQyx3QkFBd0IsRUFBRSxHQUFHLEVBQUU7UUFDaEMsTUFBTSxNQUFNLEdBQUcsR0FBRyxDQUFDLHNCQUFzQixDQUFDLElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDbEUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQyw4RUFBOEUsQ0FBQyxDQUFDLENBQUM7SUFDakgsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMsK0JBQStCLEVBQUUsR0FBRyxFQUFFO1FBQ3ZDLE1BQU0sTUFBTSxHQUFHLEdBQUcsQ0FBQyw2QkFBNkIsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3pFLE1BQU0sQ0FBQyxNQUFN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
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=schnorr.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schnorr.test.d.ts","sourceRoot":"","sources":["../../src/barretenberg_api/schnorr.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,113 @@
1
+ import { TextEncoder } from 'util';
2
+ import { Buffer128, Buffer32, Fr, Point } from '../types/index.js';
3
+ import { newBarretenbergApiSync } from '../factory/index.js';
4
+ describe('schnorr', () => {
5
+ const msg = Buffer.from(new TextEncoder().encode('The quick brown dog jumped over the lazy fox.'));
6
+ let api;
7
+ beforeAll(async () => {
8
+ api = await newBarretenbergApiSync();
9
+ api.pedersenInit();
10
+ });
11
+ afterAll(async () => {
12
+ await api.destroy();
13
+ });
14
+ it('should verify signature', () => {
15
+ const pk = Fr.fromBuffer(new Uint8Array([
16
+ 0x0b, 0x9b, 0x3a, 0xde, 0xe6, 0xb3, 0xd8, 0x1b, 0x28, 0xa0, 0x88, 0x6b, 0x2a, 0x84, 0x15, 0xc7, 0xda, 0x31,
17
+ 0x29, 0x1a, 0x5e, 0x96, 0xbb, 0x7a, 0x56, 0x63, 0x9e, 0x17, 0x7d, 0x30, 0x1b, 0xeb,
18
+ ]));
19
+ const pubKey = api.schnorrComputePublicKey(pk);
20
+ const [s, e] = api.schnorrConstructSignature(msg, pk);
21
+ const verified = api.schnorrVerifySignature(msg, pubKey, s, e);
22
+ expect(verified).toBe(true);
23
+ });
24
+ it('public key negation should work', () => {
25
+ const publicKeyStr = '0x164f01b1011a1b292217acf53eef4d74f625f6e9bd5edfdb74c56fd81aafeebb21912735f9266a3719f61c1eb747ddee0cac9917f5c807485d356709b529b62c';
26
+ const publicKey = Point.fromString(publicKeyStr);
27
+ // hardcoded expected negated public key
28
+ const expectedInvertedStr = '0x164f01b1011a1b292217acf53eef4d74f625f6e9bd5edfdb74c56fd81aafeebb0ed3273ce80b35f29e5a2997ca397a6f1b874f3083f16948e6ac8e8a3ad649d5';
29
+ const expectedInverted = Point.fromString(expectedInvertedStr);
30
+ // negate - should match expected negated key
31
+ const negatedPublicKey = api.schnorrNegatePublicKey(publicKey);
32
+ expect(negatedPublicKey.equals(expectedInverted)).toEqual(true);
33
+ // negate again - should be original public key now
34
+ expect(api.schnorrNegatePublicKey(negatedPublicKey).equals(publicKey)).toEqual(true);
35
+ });
36
+ it('should create + verify multi signature', () => {
37
+ // set up multisig accounts
38
+ const numSigners = 7;
39
+ const pks = [...Array(numSigners)].map(() => Fr.random());
40
+ const pubKeys = pks.map(pk => api.schnorrMultisigCreateMultisigPublicKey(pk));
41
+ // round one
42
+ const roundOnePublicOutputs = [];
43
+ const roundOnePrivateOutputs = [];
44
+ for (let i = 0; i < numSigners; ++i) {
45
+ const [publicOutput, privateOutput] = api.schnorrMultisigConstructSignatureRound1();
46
+ roundOnePublicOutputs.push(publicOutput);
47
+ roundOnePrivateOutputs.push(privateOutput);
48
+ }
49
+ // round two
50
+ const roundTwoOutputs = pks.map((pk, i) => api.schnorrMultisigConstructSignatureRound2(msg, pk, roundOnePrivateOutputs[i], pubKeys, roundOnePublicOutputs)[0]);
51
+ // generate signature
52
+ const [s, e] = api.schnorrMultisigCombineSignatures(msg, pubKeys, roundOnePublicOutputs, roundTwoOutputs);
53
+ const [combinedKey] = api.schnorrMultisigValidateAndCombineSignerPubkeys(pubKeys);
54
+ expect(combinedKey).not.toEqual(Buffer.alloc(64));
55
+ const verified = api.schnorrVerifySignature(msg, combinedKey, s, e);
56
+ expect(verified).toBe(true);
57
+ });
58
+ it('should identify invalid multi signature', () => {
59
+ const pks = [...Array(3)].map(() => Fr.random());
60
+ const pubKeys = pks.map(pk => api.schnorrMultisigCreateMultisigPublicKey(pk));
61
+ const [combinedKey] = api.schnorrMultisigValidateAndCombineSignerPubkeys(pubKeys);
62
+ const verified = api.schnorrVerifySignature(msg, combinedKey, Buffer32.random(), Buffer32.random());
63
+ expect(verified).toBe(false);
64
+ });
65
+ it('should not construct invalid multi signature', () => {
66
+ // set up multisig accounts
67
+ const numSigners = 7;
68
+ const pks = [...Array(numSigners)].map(() => Fr.random());
69
+ const pubKeys = pks.map(pk => api.schnorrMultisigCreateMultisigPublicKey(pk));
70
+ // round one
71
+ const roundOnePublicOutputs = [];
72
+ const roundOnePrivateOutputs = [];
73
+ for (let i = 0; i < numSigners; ++i) {
74
+ const [publicOutput, privateOutput] = api.schnorrMultisigConstructSignatureRound1();
75
+ roundOnePublicOutputs.push(publicOutput);
76
+ roundOnePrivateOutputs.push(privateOutput);
77
+ }
78
+ // round two
79
+ const roundTwoOutputs = pks.map((pk, i) => api.schnorrMultisigConstructSignatureRound2(msg, pk, roundOnePrivateOutputs[i], pubKeys, roundOnePublicOutputs)[0]);
80
+ // wrong number of data
81
+ {
82
+ expect(api.schnorrMultisigCombineSignatures(msg, pubKeys.slice(0, -1), roundOnePublicOutputs.slice(0, -1), roundTwoOutputs.slice(0, -1))[2]).toBe(false);
83
+ }
84
+ // invalid round two output
85
+ {
86
+ const invalidOutputs = [...roundTwoOutputs];
87
+ invalidOutputs[1] = api.schnorrMultisigConstructSignatureRound2(msg, pks[2], // <- Wrong private key.
88
+ roundOnePrivateOutputs[1], pubKeys, roundOnePublicOutputs)[0];
89
+ expect(api.schnorrMultisigCombineSignatures(msg, pubKeys, roundOnePublicOutputs, invalidOutputs)[2]).toBe(false);
90
+ }
91
+ // contains duplicates
92
+ {
93
+ const invalidOutputs = [...roundTwoOutputs];
94
+ invalidOutputs[1] = roundTwoOutputs[2];
95
+ expect(api.schnorrMultisigCombineSignatures(msg, pubKeys, roundOnePublicOutputs, invalidOutputs)[2]).toBe(false);
96
+ }
97
+ });
98
+ it('should not create combined key from public keys containing invalid key', () => {
99
+ const pks = [...Array(5)].map(() => Fr.random());
100
+ const pubKeys = pks.map(pk => api.schnorrMultisigCreateMultisigPublicKey(pk));
101
+ // not a valid point
102
+ {
103
+ pubKeys[1] = new Buffer128(Buffer.alloc(128));
104
+ expect(api.schnorrMultisigValidateAndCombineSignerPubkeys(pubKeys)[1]).toBe(false);
105
+ }
106
+ // contains duplicates
107
+ {
108
+ pubKeys[1] = pubKeys[2];
109
+ expect(api.schnorrMultisigValidateAndCombineSignerPubkeys(pubKeys)[1]).toBe(false);
110
+ }
111
+ });
112
+ });
113
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nobm9yci50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2JhcnJldGVuYmVyZ19hcGkvc2Nobm9yci50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDbkMsT0FBTyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRW5FLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRTdELFFBQVEsQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFO0lBQ3ZCLE1BQU0sR0FBRyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxXQUFXLEVBQUUsQ0FBQyxNQUFNLENBQUMsK0NBQStDLENBQUMsQ0FBQyxDQUFDO0lBQ25HLElBQUksR0FBd0IsQ0FBQztJQUU3QixTQUFTLENBQUMsS0FBSyxJQUFJLEVBQUU7UUFDbkIsR0FBRyxHQUFHLE1BQU0sc0JBQXNCLEVBQUUsQ0FBQztRQUNyQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDckIsQ0FBQyxDQUFDLENBQUM7SUFFSCxRQUFRLENBQUMsS0FBSyxJQUFJLEVBQUU7UUFDbEIsTUFBTSxHQUFHLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMseUJBQXlCLEVBQUUsR0FBRyxFQUFFO1FBQ2pDLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQ3RCLElBQUksVUFBVSxDQUFDO1lBQ2IsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUs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