@aztec/bb.js 0.85.0-alpha-testnet.2 → 0.85.0-alpha-testnet.4

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 (221) hide show
  1. package/dest/browser/733.655674bbbb79bdf168c4.js +7 -0
  2. package/dest/browser/barretenberg-threads.js +2 -29
  3. package/dest/browser/barretenberg.js +2 -29
  4. package/dest/browser/index.js +10996 -8241
  5. package/dest/browser/main.worker.js +1316 -0
  6. package/dest/browser/thread.worker.js +1200 -0
  7. package/dest/node/barretenberg/backend.d.ts +5 -6
  8. package/dest/node/barretenberg/backend.d.ts.map +1 -1
  9. package/dest/node/barretenberg/backend.js +49 -10
  10. package/dest/node/barretenberg/index.d.ts +3 -1
  11. package/dest/node/barretenberg/index.d.ts.map +1 -1
  12. package/dest/node/barretenberg/index.js +6 -3
  13. package/dest/node/barretenberg_api/index.d.ts +20 -33
  14. package/dest/node/barretenberg_api/index.d.ts.map +1 -1
  15. package/dest/node/barretenberg_api/index.js +93 -194
  16. package/dest/node/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  17. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +1 -1
  18. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -1
  19. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -4
  20. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +1 -2
  21. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -1
  22. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +5 -5
  23. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +1 -1
  24. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -1
  25. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +2 -2
  26. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +1 -1
  27. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -1
  28. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -4
  29. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +1 -2
  30. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -1
  31. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +5 -5
  32. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +1 -1
  33. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -1
  34. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +2 -2
  35. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts +7 -1
  36. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -1
  37. package/dest/node/barretenberg_wasm/helpers/browser/index.js +15 -2
  38. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts +1 -1
  39. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts.map +1 -1
  40. package/dest/node/barretenberg_wasm/helpers/node/index.js +1 -1
  41. package/dest/node/barretenberg_wasm/index.d.ts +0 -13
  42. package/dest/node/barretenberg_wasm/index.d.ts.map +1 -1
  43. package/dest/node/barretenberg_wasm/index.js +2 -18
  44. package/dest/node/barretenberg_wasm/index.test.js +6 -6
  45. package/dest/node/bindgen/mappings.d.ts.map +1 -1
  46. package/dest/node/bindgen/mappings.js +2 -1
  47. package/dest/node/bindgen/typescript.js +4 -4
  48. package/dest/node/index.d.ts +2 -2
  49. package/dest/node/index.d.ts.map +1 -1
  50. package/dest/node/index.js +1 -1
  51. package/dest/node/main.d.ts +0 -1
  52. package/dest/node/main.d.ts.map +1 -1
  53. package/dest/node/main.js +1 -35
  54. package/dest/node-cjs/barretenberg/backend.d.ts +5 -6
  55. package/dest/node-cjs/barretenberg/backend.d.ts.map +1 -1
  56. package/dest/node-cjs/barretenberg/backend.js +49 -10
  57. package/dest/node-cjs/barretenberg/index.d.ts +3 -1
  58. package/dest/node-cjs/barretenberg/index.d.ts.map +1 -1
  59. package/dest/node-cjs/barretenberg/index.js +12 -9
  60. package/dest/node-cjs/barretenberg_api/index.d.ts +20 -33
  61. package/dest/node-cjs/barretenberg_api/index.d.ts.map +1 -1
  62. package/dest/node-cjs/barretenberg_api/index.js +92 -193
  63. package/dest/node-cjs/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  64. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +1 -1
  65. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -1
  66. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -4
  67. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +1 -2
  68. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -1
  69. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +5 -5
  70. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +1 -1
  71. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -1
  72. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +2 -2
  73. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +1 -1
  74. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -1
  75. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -4
  76. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +1 -2
  77. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -1
  78. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +5 -5
  79. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +1 -1
  80. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -1
  81. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +2 -2
  82. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts +7 -1
  83. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -1
  84. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.js +17 -3
  85. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts +1 -1
  86. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts.map +1 -1
  87. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.js +1 -1
  88. package/dest/node-cjs/barretenberg_wasm/index.d.ts +0 -13
  89. package/dest/node-cjs/barretenberg_wasm/index.d.ts.map +1 -1
  90. package/dest/node-cjs/barretenberg_wasm/index.js +6 -23
  91. package/dest/node-cjs/barretenberg_wasm/index.test.js +6 -6
  92. package/dest/node-cjs/bindgen/mappings.d.ts.map +1 -1
  93. package/dest/node-cjs/bindgen/mappings.js +2 -1
  94. package/dest/node-cjs/bindgen/typescript.js +4 -4
  95. package/dest/node-cjs/index.d.ts +2 -2
  96. package/dest/node-cjs/index.d.ts.map +1 -1
  97. package/dest/node-cjs/index.js +1 -1
  98. package/dest/node-cjs/main.d.ts +0 -1
  99. package/dest/node-cjs/main.d.ts.map +1 -1
  100. package/dest/node-cjs/main.js +2 -37
  101. package/package.json +10 -12
  102. package/src/barretenberg/backend.ts +64 -11
  103. package/src/barretenberg/index.ts +7 -3
  104. package/src/barretenberg_api/index.ts +156 -360
  105. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.ts +8 -3
  106. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.ts +4 -6
  107. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.ts +1 -1
  108. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.ts +8 -3
  109. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.ts +4 -6
  110. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.ts +1 -1
  111. package/src/barretenberg_wasm/helpers/browser/index.ts +18 -2
  112. package/src/barretenberg_wasm/helpers/node/index.ts +2 -2
  113. package/src/barretenberg_wasm/index.test.ts +7 -7
  114. package/src/barretenberg_wasm/index.ts +1 -24
  115. package/src/bindgen/mappings.ts +1 -0
  116. package/src/bindgen/typescript.ts +4 -4
  117. package/src/index.ts +2 -2
  118. package/src/main.ts +0 -39
  119. package/dest/browser/522.6386c00ebfb22619e11b.js +0 -3
  120. package/dest/browser/barretenberg/backend.d.ts +0 -89
  121. package/dest/browser/barretenberg/backend.d.ts.map +0 -1
  122. package/dest/browser/barretenberg/index.d.ts +0 -51
  123. package/dest/browser/barretenberg/index.d.ts.map +0 -1
  124. package/dest/browser/barretenberg/verifier.d.ts +0 -16
  125. package/dest/browser/barretenberg/verifier.d.ts.map +0 -1
  126. package/dest/browser/barretenberg_api/index.d.ts +0 -114
  127. package/dest/browser/barretenberg_api/index.d.ts.map +0 -1
  128. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +0 -44
  129. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +0 -1
  130. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +0 -2
  131. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +0 -1
  132. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +0 -3
  133. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +0 -1
  134. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +0 -4
  135. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +0 -1
  136. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +0 -21
  137. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +0 -1
  138. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +0 -47
  139. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +0 -1
  140. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +0 -2
  141. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +0 -1
  142. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +0 -3
  143. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +0 -1
  144. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +0 -4
  145. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +0 -1
  146. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +0 -28
  147. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +0 -1
  148. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +0 -3
  149. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +0 -1
  150. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +0 -3
  151. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +0 -1
  152. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts +0 -2
  153. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts.map +0 -1
  154. package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts +0 -2
  155. package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts.map +0 -1
  156. package/dest/browser/barretenberg_wasm/fetch_code/node/index.d.ts +0 -2
  157. package/dest/browser/barretenberg_wasm/fetch_code/node/index.d.ts.map +0 -1
  158. package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts +0 -6
  159. package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts.map +0 -1
  160. package/dest/browser/barretenberg_wasm/helpers/index.d.ts +0 -2
  161. package/dest/browser/barretenberg_wasm/helpers/index.d.ts.map +0 -1
  162. package/dest/browser/barretenberg_wasm/helpers/node/index.d.ts +0 -22
  163. package/dest/browser/barretenberg_wasm/helpers/node/index.d.ts.map +0 -1
  164. package/dest/browser/barretenberg_wasm/helpers/node/node_endpoint.d.ts +0 -8
  165. package/dest/browser/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +0 -1
  166. package/dest/browser/barretenberg_wasm/index.d.ts +0 -18
  167. package/dest/browser/barretenberg_wasm/index.d.ts.map +0 -1
  168. package/dest/browser/bigint-array/index.d.ts +0 -18
  169. package/dest/browser/bigint-array/index.d.ts.map +0 -1
  170. package/dest/browser/crs/browser/cached_net_crs.d.ts +0 -43
  171. package/dest/browser/crs/browser/cached_net_crs.d.ts.map +0 -1
  172. package/dest/browser/crs/browser/index.d.ts +0 -2
  173. package/dest/browser/crs/browser/index.d.ts.map +0 -1
  174. package/dest/browser/crs/index.d.ts +0 -2
  175. package/dest/browser/crs/index.d.ts.map +0 -1
  176. package/dest/browser/crs/net_crs.d.ts +0 -85
  177. package/dest/browser/crs/net_crs.d.ts.map +0 -1
  178. package/dest/browser/crs/node/index.d.ts +0 -38
  179. package/dest/browser/crs/node/index.d.ts.map +0 -1
  180. package/dest/browser/index.d.ts +0 -5
  181. package/dest/browser/index.d.ts.map +0 -1
  182. package/dest/browser/proof/index.d.ts +0 -20
  183. package/dest/browser/proof/index.d.ts.map +0 -1
  184. package/dest/browser/random/browser/index.d.ts +0 -2
  185. package/dest/browser/random/browser/index.d.ts.map +0 -1
  186. package/dest/browser/random/index.d.ts +0 -2
  187. package/dest/browser/random/index.d.ts.map +0 -1
  188. package/dest/browser/random/node/index.d.ts +0 -2
  189. package/dest/browser/random/node/index.d.ts.map +0 -1
  190. package/dest/browser/retry/index.d.ts +0 -26
  191. package/dest/browser/retry/index.d.ts.map +0 -1
  192. package/dest/browser/serialize/buffer_reader.d.ts +0 -28
  193. package/dest/browser/serialize/buffer_reader.d.ts.map +0 -1
  194. package/dest/browser/serialize/index.d.ts +0 -4
  195. package/dest/browser/serialize/index.d.ts.map +0 -1
  196. package/dest/browser/serialize/output_type.d.ts +0 -11
  197. package/dest/browser/serialize/output_type.d.ts.map +0 -1
  198. package/dest/browser/serialize/serialize.d.ts +0 -53
  199. package/dest/browser/serialize/serialize.d.ts.map +0 -1
  200. package/dest/browser/thread.worker.worker.worker.js.LICENSE.txt +0 -5
  201. package/dest/browser/types/fields.d.ts +0 -44
  202. package/dest/browser/types/fields.d.ts.map +0 -1
  203. package/dest/browser/types/fixed_size_buffer.d.ts +0 -26
  204. package/dest/browser/types/fixed_size_buffer.d.ts.map +0 -1
  205. package/dest/browser/types/index.d.ts +0 -6
  206. package/dest/browser/types/index.d.ts.map +0 -1
  207. package/dest/browser/types/point.d.ts +0 -17
  208. package/dest/browser/types/point.d.ts.map +0 -1
  209. package/dest/browser/types/ptr.d.ts +0 -13
  210. package/dest/browser/types/ptr.d.ts.map +0 -1
  211. package/dest/browser/types/raw_buffer.d.ts +0 -3
  212. package/dest/browser/types/raw_buffer.d.ts.map +0 -1
  213. package/dest/node/barretenberg/schnorr.test.d.ts +0 -2
  214. package/dest/node/barretenberg/schnorr.test.d.ts.map +0 -1
  215. package/dest/node/barretenberg/schnorr.test.js +0 -113
  216. package/dest/node-cjs/barretenberg/schnorr.test.d.ts +0 -2
  217. package/dest/node-cjs/barretenberg/schnorr.test.d.ts.map +0 -1
  218. package/dest/node-cjs/barretenberg/schnorr.test.js +0 -115
  219. package/src/barretenberg/schnorr.test.ts +0 -182
  220. /package/dest/browser/{main.worker.worker.js.LICENSE.txt → main.worker.js.LICENSE.txt} +0 -0
  221. /package/dest/browser/{thread.worker.worker.js.LICENSE.txt → thread.worker.js.LICENSE.txt} +0 -0
@@ -1,182 +0,0 @@
1
- import { TextEncoder } from 'util';
2
- import { Buffer128, Buffer32, Fq, Fr, Point } from '../types/index.js';
3
- import { Barretenberg } from './index.js';
4
- import { asyncMap } from '../async_map/index.js';
5
-
6
- describe('schnorr', () => {
7
- const msg = Buffer.from(new TextEncoder().encode('The quick brown dog jumped over the lazy fox.'));
8
- let api: Barretenberg;
9
-
10
- beforeAll(async () => {
11
- api = await Barretenberg.new({ threads: 1 });
12
- }, 30000);
13
-
14
- afterAll(async () => {
15
- await api.destroy();
16
- });
17
-
18
- it('should verify signature', async () => {
19
- const pk = Fr.fromBuffer(
20
- new Uint8Array([
21
- 0x0b, 0x9b, 0x3a, 0xde, 0xe6, 0xb3, 0xd8, 0x1b, 0x28, 0xa0, 0x88, 0x6b, 0x2a, 0x84, 0x15, 0xc7, 0xda, 0x31,
22
- 0x29, 0x1a, 0x5e, 0x96, 0xbb, 0x7a, 0x56, 0x63, 0x9e, 0x17, 0x7d, 0x30, 0x1b, 0xeb,
23
- ]),
24
- );
25
- const pubKey = await api.schnorrComputePublicKey(pk);
26
- const [s, e] = await api.schnorrConstructSignature(msg, pk);
27
- const verified = await api.schnorrVerifySignature(msg, pubKey, s, e);
28
-
29
- expect(verified).toBe(true);
30
- });
31
-
32
- it('public key negation should work', async () => {
33
- const publicKeyStr =
34
- '0x164f01b1011a1b292217acf53eef4d74f625f6e9bd5edfdb74c56fd81aafeebb21912735f9266a3719f61c1eb747ddee0cac9917f5c807485d356709b529b62c';
35
- const publicKey = Point.fromString(publicKeyStr);
36
- // hardcoded expected negated public key
37
- const expectedInvertedStr =
38
- '0x164f01b1011a1b292217acf53eef4d74f625f6e9bd5edfdb74c56fd81aafeebb0ed3273ce80b35f29e5a2997ca397a6f1b874f3083f16948e6ac8e8a3ad649d5';
39
- const expectedInverted = Point.fromString(expectedInvertedStr);
40
-
41
- // negate - should match expected negated key
42
- const negatedPublicKey = await api.schnorrNegatePublicKey(publicKey);
43
- expect(negatedPublicKey.equals(expectedInverted)).toEqual(true);
44
- // negate again - should be original public key now
45
- expect((await api.schnorrNegatePublicKey(negatedPublicKey)).equals(publicKey)).toEqual(true);
46
- });
47
-
48
- it('should create + verify multi signature', async () => {
49
- // set up multisig accounts
50
- const numSigners = 7;
51
- const pks = [...Array(numSigners)].map(() => Fq.random());
52
- const pubKeys = await asyncMap(pks, pk => api.schnorrMultisigCreateMultisigPublicKey(pk));
53
-
54
- // round one
55
- const roundOnePublicOutputs: Buffer128[] = [];
56
- const roundOnePrivateOutputs: Buffer128[] = [];
57
- for (let i = 0; i < numSigners; ++i) {
58
- const [publicOutput, privateOutput] = await api.schnorrMultisigConstructSignatureRound1();
59
- roundOnePublicOutputs.push(publicOutput);
60
- roundOnePrivateOutputs.push(privateOutput);
61
- }
62
-
63
- // round two
64
- const roundTwoOutputs = await asyncMap(
65
- pks,
66
- async (pk, i) =>
67
- (
68
- await api.schnorrMultisigConstructSignatureRound2(
69
- msg,
70
- pk,
71
- roundOnePrivateOutputs[i],
72
- pubKeys,
73
- roundOnePublicOutputs,
74
- )
75
- )[0],
76
- );
77
-
78
- // generate signature
79
- const [s, e] = await api.schnorrMultisigCombineSignatures(msg, pubKeys, roundOnePublicOutputs, roundTwoOutputs)!;
80
- const [combinedKey] = await api.schnorrMultisigValidateAndCombineSignerPubkeys(pubKeys);
81
- expect(combinedKey).not.toEqual(Buffer.alloc(64));
82
- const verified = await api.schnorrVerifySignature(msg, combinedKey, s, e);
83
- expect(verified).toBe(true);
84
- });
85
-
86
- it('should identify invalid multi signature', async () => {
87
- const pks = [...Array(3)].map(() => Fq.random());
88
- const pubKeys = await asyncMap(pks, pk => api.schnorrMultisigCreateMultisigPublicKey(pk));
89
- const [combinedKey] = await api.schnorrMultisigValidateAndCombineSignerPubkeys(pubKeys);
90
-
91
- const verified = await api.schnorrVerifySignature(msg, combinedKey, Buffer32.random(), Buffer32.random());
92
- expect(verified).toBe(false);
93
- });
94
-
95
- it('should not construct invalid multi signature', async () => {
96
- // set up multisig accounts
97
- const numSigners = 7;
98
- const pks = [...Array(numSigners)].map(() => Fq.random());
99
- const pubKeys = await asyncMap(pks, pk => api.schnorrMultisigCreateMultisigPublicKey(pk));
100
-
101
- // round one
102
- const roundOnePublicOutputs: Buffer128[] = [];
103
- const roundOnePrivateOutputs: Buffer128[] = [];
104
- for (let i = 0; i < numSigners; ++i) {
105
- const [publicOutput, privateOutput] = await api.schnorrMultisigConstructSignatureRound1();
106
- roundOnePublicOutputs.push(publicOutput);
107
- roundOnePrivateOutputs.push(privateOutput);
108
- }
109
-
110
- // round two
111
- const roundTwoOutputs = await asyncMap(
112
- pks,
113
- async (pk, i) =>
114
- (
115
- await api.schnorrMultisigConstructSignatureRound2(
116
- msg,
117
- pk,
118
- roundOnePrivateOutputs[i],
119
- pubKeys,
120
- roundOnePublicOutputs,
121
- )
122
- )[0],
123
- );
124
-
125
- // wrong number of data
126
- {
127
- expect(
128
- (
129
- await api.schnorrMultisigCombineSignatures(
130
- msg,
131
- pubKeys.slice(0, -1),
132
- roundOnePublicOutputs.slice(0, -1),
133
- roundTwoOutputs.slice(0, -1),
134
- )
135
- )[2],
136
- ).toBe(false);
137
- }
138
-
139
- // invalid round two output
140
- {
141
- const invalidOutputs = [...roundTwoOutputs];
142
- invalidOutputs[1] = (
143
- await api.schnorrMultisigConstructSignatureRound2(
144
- msg,
145
- pks[2], // <- Wrong private key.
146
- roundOnePrivateOutputs[1],
147
- pubKeys,
148
- roundOnePublicOutputs,
149
- )
150
- )[0];
151
- expect((await api.schnorrMultisigCombineSignatures(msg, pubKeys, roundOnePublicOutputs, invalidOutputs))[2]).toBe(
152
- false,
153
- );
154
- }
155
-
156
- // contains duplicates
157
- {
158
- const invalidOutputs = [...roundTwoOutputs];
159
- invalidOutputs[1] = roundTwoOutputs[2];
160
- expect((await api.schnorrMultisigCombineSignatures(msg, pubKeys, roundOnePublicOutputs, invalidOutputs))[2]).toBe(
161
- false,
162
- );
163
- }
164
- });
165
-
166
- it('should not create combined key from public keys containing invalid key', async () => {
167
- const pks = [...Array(5)].map(() => Fq.random());
168
- const pubKeys = await asyncMap(pks, pk => api.schnorrMultisigCreateMultisigPublicKey(pk));
169
-
170
- // not a valid point
171
- {
172
- pubKeys[1] = new Buffer128(Buffer.alloc(128));
173
- expect((await api.schnorrMultisigValidateAndCombineSignerPubkeys(pubKeys))[1]).toBe(false);
174
- }
175
-
176
- // contains duplicates
177
- {
178
- pubKeys[1] = pubKeys[2];
179
- expect((await api.schnorrMultisigValidateAndCombineSignerPubkeys(pubKeys))[1]).toBe(false);
180
- }
181
- });
182
- });