@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.
- package/README.md +3 -0
- package/dest/async_map/index.d.ts +10 -0
- package/dest/async_map/index.d.ts.map +1 -0
- package/dest/async_map/index.js +16 -0
- package/dest/barretenberg-threads.wasm +0 -0
- package/dest/barretenberg.wasm +0 -0
- package/dest/barretenberg_api/blake2s.test.d.ts +2 -0
- package/dest/barretenberg_api/blake2s.test.d.ts.map +1 -0
- package/dest/barretenberg_api/blake2s.test.js +30 -0
- package/dest/barretenberg_api/common.test.d.ts +2 -0
- package/dest/barretenberg_api/common.test.d.ts.map +1 -0
- package/dest/barretenberg_api/common.test.js +18 -0
- package/dest/barretenberg_api/index.d.ts +101 -0
- package/dest/barretenberg_api/index.d.ts.map +1 -0
- package/dest/barretenberg_api/index.js +371 -0
- package/dest/barretenberg_api/pedersen.test.d.ts +2 -0
- package/dest/barretenberg_api/pedersen.test.d.ts.map +1 -0
- package/dest/barretenberg_api/pedersen.test.js +69 -0
- package/dest/barretenberg_api/schnorr.test.d.ts +2 -0
- package/dest/barretenberg_api/schnorr.test.d.ts.map +1 -0
- package/dest/barretenberg_api/schnorr.test.js +113 -0
- package/dest/barretenberg_binder/heap_allocator.d.ts +22 -0
- package/dest/barretenberg_binder/heap_allocator.d.ts.map +1 -0
- package/dest/barretenberg_binder/heap_allocator.js +59 -0
- package/dest/barretenberg_binder/heap_allocator_sync.d.ts +22 -0
- package/dest/barretenberg_binder/heap_allocator_sync.d.ts.map +1 -0
- package/dest/barretenberg_binder/heap_allocator_sync.js +58 -0
- package/dest/barretenberg_binder/index.d.ts +32 -0
- package/dest/barretenberg_binder/index.d.ts.map +1 -0
- package/dest/barretenberg_binder/index.js +73 -0
- package/dest/barretenberg_wasm/barretenberg_wasm.d.ts +49 -0
- package/dest/barretenberg_wasm/barretenberg_wasm.d.ts.map +1 -0
- package/dest/barretenberg_wasm/barretenberg_wasm.js +190 -0
- package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts +2 -0
- package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts.map +1 -0
- package/dest/barretenberg_wasm/barretenberg_wasm.test.js +43 -0
- package/dest/barretenberg_wasm/browser/index.d.ts +8 -0
- package/dest/barretenberg_wasm/browser/index.d.ts.map +1 -0
- package/dest/barretenberg_wasm/browser/index.js +26 -0
- package/dest/barretenberg_wasm/browser/worker.d.ts +2 -0
- package/dest/barretenberg_wasm/browser/worker.d.ts.map +1 -0
- package/dest/barretenberg_wasm/browser/worker.js +11 -0
- package/dest/barretenberg_wasm/index.d.ts +2 -0
- package/dest/barretenberg_wasm/index.d.ts.map +1 -0
- package/dest/barretenberg_wasm/index.js +2 -0
- package/dest/barretenberg_wasm/node/index.d.ts +17 -0
- package/dest/barretenberg_wasm/node/index.d.ts.map +1 -0
- package/dest/barretenberg_wasm/node/index.js +40 -0
- package/dest/barretenberg_wasm/node/node_endpoint.d.ts +8 -0
- package/dest/barretenberg_wasm/node/node_endpoint.d.ts.map +1 -0
- package/dest/barretenberg_wasm/node/node_endpoint.js +28 -0
- package/dest/barretenberg_wasm/node/worker.d.ts +2 -0
- package/dest/barretenberg_wasm/node/worker.d.ts.map +1 -0
- package/dest/barretenberg_wasm/node/worker.js +9 -0
- package/dest/barretenberg_wasm.js +2 -0
- package/dest/barretenberg_wasm.js.LICENSE.txt +5 -0
- package/dest/bigint-array/index.d.ts +3 -0
- package/dest/bigint-array/index.d.ts.map +1 -0
- package/dest/bigint-array/index.js +21 -0
- package/dest/bindgen/function_declaration.d.ts +11 -0
- package/dest/bindgen/function_declaration.d.ts.map +1 -0
- package/dest/bindgen/function_declaration.js +2 -0
- package/dest/bindgen/index.d.ts +2 -0
- package/dest/bindgen/index.d.ts.map +1 -0
- package/dest/bindgen/index.js +15 -0
- package/dest/bindgen/mappings.d.ts +4 -0
- package/dest/bindgen/mappings.d.ts.map +1 -0
- package/dest/bindgen/mappings.js +63 -0
- package/dest/bindgen/rust.d.ts +2 -0
- package/dest/bindgen/rust.d.ts.map +1 -0
- package/dest/bindgen/rust.js +43 -0
- package/dest/bindgen/to_camel_case.d.ts +2 -0
- package/dest/bindgen/to_camel_case.d.ts.map +1 -0
- package/dest/bindgen/to_camel_case.js +11 -0
- package/dest/bindgen/typescript.d.ts +2 -0
- package/dest/bindgen/typescript.d.ts.map +1 -0
- package/dest/bindgen/typescript.js +80 -0
- package/dest/crs/browser/cached_net_crs.d.ts +25 -0
- package/dest/crs/browser/cached_net_crs.d.ts.map +1 -0
- package/dest/crs/browser/cached_net_crs.js +54 -0
- package/dest/crs/browser/index.d.ts +2 -0
- package/dest/crs/browser/index.d.ts.map +1 -0
- package/dest/crs/browser/index.js +2 -0
- package/dest/crs/index.d.ts +2 -0
- package/dest/crs/index.d.ts.map +1 -0
- package/dest/crs/index.js +2 -0
- package/dest/crs/net_crs.d.ts +36 -0
- package/dest/crs/net_crs.d.ts.map +1 -0
- package/dest/crs/net_crs.js +59 -0
- package/dest/crs/node/file_crs.d.ts +37 -0
- package/dest/crs/node/file_crs.d.ts.map +1 -0
- package/dest/crs/node/file_crs.js +51 -0
- package/dest/crs/node/index.d.ts +31 -0
- package/dest/crs/node/index.d.ts.map +1 -0
- package/dest/crs/node/index.js +41 -0
- package/dest/examples/simple.rawtest.d.ts +2 -0
- package/dest/examples/simple.rawtest.d.ts.map +1 -0
- package/dest/examples/simple.rawtest.js +24 -0
- package/dest/examples/simple.test.d.ts +2 -0
- package/dest/examples/simple.test.d.ts.map +1 -0
- package/dest/examples/simple.test.js +22 -0
- package/dest/factory/index.d.ts +21 -0
- package/dest/factory/index.d.ts.map +1 -0
- package/dest/factory/index.js +34 -0
- package/dest/index.d.ts +4 -0
- package/dest/index.d.ts.map +1 -0
- package/dest/index.html +1 -0
- package/dest/index.js +4 -0
- package/dest/main-dev.d.ts +3 -0
- package/dest/main-dev.d.ts.map +1 -0
- package/dest/main-dev.js +3 -0
- package/dest/main.d.ts +10 -0
- package/dest/main.d.ts.map +1 -0
- package/dest/main.js +288 -0
- package/dest/random/browser/index.d.ts +2 -0
- package/dest/random/browser/index.d.ts.map +1 -0
- package/dest/random/browser/index.js +31 -0
- package/dest/random/index.d.ts +2 -0
- package/dest/random/index.d.ts.map +1 -0
- package/dest/random/index.js +2 -0
- package/dest/random/node/index.d.ts +2 -0
- package/dest/random/node/index.d.ts.map +1 -0
- package/dest/random/node/index.js +5 -0
- package/dest/serialize/buffer_reader.d.ts +28 -0
- package/dest/serialize/buffer_reader.d.ts.map +1 -0
- package/dest/serialize/buffer_reader.js +66 -0
- package/dest/serialize/index.d.ts +4 -0
- package/dest/serialize/index.d.ts.map +1 -0
- package/dest/serialize/index.js +4 -0
- package/dest/serialize/output_type.d.ts +11 -0
- package/dest/serialize/output_type.d.ts.map +1 -0
- package/dest/serialize/output_type.js +44 -0
- package/dest/serialize/serialize.d.ts +53 -0
- package/dest/serialize/serialize.d.ts.map +1 -0
- package/dest/serialize/serialize.js +139 -0
- package/dest/simple_test.js +2 -0
- package/dest/simple_test.js.LICENSE.txt +14 -0
- package/dest/types/fields.d.ts +33 -0
- package/dest/types/fields.d.ts.map +1 -0
- package/dest/types/fields.js +86 -0
- package/dest/types/fixed_size_buffer.d.ts +26 -0
- package/dest/types/fixed_size_buffer.d.ts.map +1 -0
- package/dest/types/fixed_size_buffer.js +54 -0
- package/dest/types/index.d.ts +6 -0
- package/dest/types/index.d.ts.map +1 -0
- package/dest/types/index.js +6 -0
- package/dest/types/point.d.ts +17 -0
- package/dest/types/point.d.ts.map +1 -0
- package/dest/types/point.js +32 -0
- package/dest/types/ptr.d.ts +13 -0
- package/dest/types/ptr.d.ts.map +1 -0
- package/dest/types/ptr.js +20 -0
- package/dest/types/raw_buffer.d.ts +3 -0
- package/dest/types/raw_buffer.d.ts.map +1 -0
- package/dest/types/raw_buffer.js +5 -0
- package/package.json +79 -0
- package/src/async_map/index.ts +15 -0
- package/src/barretenberg_api/blake2s.test.ts +39 -0
- package/src/barretenberg_api/common.test.ts +21 -0
- package/src/barretenberg_api/index.ts +461 -0
- package/src/barretenberg_api/pedersen.test.ts +84 -0
- package/src/barretenberg_api/schnorr.test.ts +169 -0
- package/src/barretenberg_binder/heap_allocator.ts +62 -0
- package/src/barretenberg_binder/heap_allocator_sync.ts +61 -0
- package/src/barretenberg_binder/index.ts +76 -0
- package/src/barretenberg_wasm/barretenberg_wasm.test.ts +52 -0
- package/src/barretenberg_wasm/barretenberg_wasm.ts +222 -0
- package/src/barretenberg_wasm/browser/index.ts +32 -0
- package/src/barretenberg_wasm/browser/worker.ts +13 -0
- package/src/barretenberg_wasm/index.ts +1 -0
- package/src/barretenberg_wasm/node/index.ts +46 -0
- package/src/barretenberg_wasm/node/node_endpoint.ts +28 -0
- package/src/barretenberg_wasm/node/worker.ts +10 -0
- package/src/bigint-array/index.ts +21 -0
- package/src/bindgen/function_declaration.ts +11 -0
- package/src/bindgen/index.ts +17 -0
- package/src/bindgen/mappings.ts +66 -0
- package/src/bindgen/rust.ts +52 -0
- package/src/bindgen/to_camel_case.ts +10 -0
- package/src/bindgen/typescript.ts +91 -0
- package/src/crs/browser/cached_net_crs.ts +60 -0
- package/src/crs/browser/index.ts +1 -0
- package/src/crs/index.ts +1 -0
- package/src/crs/net_crs.ts +69 -0
- package/src/crs/node/file_crs.ts +60 -0
- package/src/crs/node/index.ts +48 -0
- package/src/examples/simple.rawtest.ts +32 -0
- package/src/examples/simple.test.ts +27 -0
- package/src/factory/index.ts +36 -0
- package/src/index.html +9 -0
- package/src/index.ts +3 -0
- package/src/main-dev.ts +2 -0
- package/src/main.ts +329 -0
- package/src/random/browser/index.ts +32 -0
- package/src/random/index.ts +1 -0
- package/src/random/node/index.ts +5 -0
- package/src/serialize/buffer_reader.ts +82 -0
- package/src/serialize/index.ts +3 -0
- package/src/serialize/output_type.ts +53 -0
- package/src/serialize/serialize.ts +157 -0
- package/src/types/fields.ts +98 -0
- package/src/types/fixed_size_buffer.ts +59 -0
- package/src/types/index.ts +5 -0
- package/src/types/point.ts +35 -0
- package/src/types/ptr.ts +20 -0
- 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 @@
|
|
|
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 @@
|
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nobm9yci50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2JhcnJldGVuYmVyZ19hcGkvc2Nobm9yci50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDbkMsT0FBTyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRW5FLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRTdELFFBQVEsQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFO0lBQ3ZCLE1BQU0sR0FBRyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxXQUFXLEVBQUUsQ0FBQyxNQUFNLENBQUMsK0NBQStDLENBQUMsQ0FBQyxDQUFDO0lBQ25HLElBQUksR0FBd0IsQ0FBQztJQUU3QixTQUFTLENBQUMsS0FBSyxJQUFJLEVBQUU7UUFDbkIsR0FBRyxHQUFHLE1BQU0sc0JBQXNCLEVBQUUsQ0FBQztRQUNyQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDckIsQ0FBQyxDQUFDLENBQUM7SUFFSCxRQUFRLENBQUMsS0FBSyxJQUFJLEVBQUU7UUFDbEIsTUFBTSxHQUFHLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMseUJBQXlCLEVBQUUsR0FBRyxFQUFFO1FBQ2pDLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQ3RCLElBQUksVUFBVSxDQUFDO1lBQ2IsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJO1lBQzFHLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJO1NBQ25GLENBQUMsQ0FDSCxDQUFDO1FBQ0YsTUFBTSxNQUFNLEdBQUcsR0FBRyxDQUFDLHVCQUF1QixDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQy9DLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLHlCQUF5QixDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUN0RCxNQUFNLFFBQVEsR0FBRyxHQUFHLENBQUMsc0JBQXNCLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFL0QsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM5QixDQUFDLENBQUMsQ0FBQztJQUVILEVBQUUsQ0FBQyxpQ0FBaUMsRUFBRSxHQUFHLEVBQUU7UUFDekMsTUFBTSxZQUFZLEdBQ2hCLG9JQUFvSSxDQUFDO1FBQ3ZJLE1BQU0sU0FBUyxHQUFHLEtBQUssQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDakQsd0NBQXdDO1FBQ3hDLE1BQU0sbUJBQW1CLEdBQ3ZCLG9JQUFvSSxDQUFDO1FBQ3ZJLE1BQU0sZ0JBQWdCLEdBQUcsS0FBSyxDQUFDLFVBQVUsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBRS9ELDZDQUE2QztRQUM3QyxNQUFNLGdCQUFnQixHQUFHLEdBQUcsQ0FBQyxzQkFBc0IsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUMvRCxNQUFNLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDaEUsbURBQW1EO1FBQ25ELE1BQU0sQ0FBQyxHQUFHLENBQUMsc0JBQXNCLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkYsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMsd0NBQXdDLEVBQUUsR0FBRyxFQUFFO1FBQ2hELDJCQUEyQjtRQUMzQixNQUFNLFVBQVUsR0FBRyxDQUFDLENBQUM7UUFDckIsTUFBTSxHQUFHLEdBQUcsQ0FBQyxHQUFHLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUMxRCxNQUFNLE9BQU8sR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLHNDQUFzQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFOUUsWUFBWTtRQUNaLE1BQU0scUJBQXFCLEdBQWdCLEVBQUUsQ0FBQztRQUM5QyxNQUFNLHNCQUFzQixHQUFnQixFQUFFLENBQUM7UUFDL0MsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFVBQVUsRUFBRSxFQUFFLENBQUMsRUFBRTtZQUNuQyxNQUFNLENBQUMsWUFBWSxFQUFFLGFBQWEsQ0FBQyxHQUFHLEdBQUcsQ0FBQyx1Q0FBdUMsRUFBRSxDQUFDO1lBQ3BGLHFCQUFxQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUN6QyxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7U0FDNUM7UUFFRCxZQUFZO1FBQ1osTUFBTSxlQUFlLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FDN0IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FDUixHQUFHLENBQUMsdUNBQXVDLENBQ3pDLEdBQUcsRUFDSCxFQUFFLEVBQ0Ysc0JBQXNCLENBQUMsQ0FBQyxDQUFDLEVBQ3pCLE9BQU8sRUFDUCxxQkFBcUIsQ0FDdEIsQ0FBQyxDQUFDLENBQUMsQ0FDUCxDQUFDO1FBRUYscUJBQXFCO1FBQ3JCLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLGdDQUFnQyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsZUFBZSxDQUFFLENBQUM7UUFDM0csTUFBTSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyw4Q0FBOEMsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNsRixNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDbEQsTUFBTSxRQUFRLEdBQUcsR0FBRyxDQUFDLHNCQUFzQixDQUFDLEdBQUcsRUFBRSxXQUFXLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3BFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUIsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMseUNBQXlDLEVBQUUsR0FBRyxFQUFFO1FBQ2pELE1BQU0sR0FBRyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7UUFDakQsTUFBTSxPQUFPLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxzQ0FBc0MsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQzlFLE1BQU0sQ0FBQyxXQUFXLENBQUMsR0FBRyxHQUFHLENBQUMsOENBQThDLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFbEYsTUFBTSxRQUFRLEdBQUcsR0FBRyxDQUFDLHNCQUFzQixDQUFDLEdBQUcsRUFBRSxXQUFXLEVBQUUsUUFBUSxDQUFDLE1BQU0sRUFBRSxFQUFFLFFBQVEsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO1FBQ3BHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMsOENBQThDLEVBQUUsR0FBRyxFQUFFO1FBQ3RELDJCQUEyQjtRQUMzQixNQUFNLFVBQVUsR0FBRyxDQUFDLENBQUM7UUFDckIsTUFBTSxHQUFHLEdBQUcsQ0FBQyxHQUFHLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUMxRCxNQUFNLE9BQU8sR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLHNDQUFzQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFOUUsWUFBWTtRQUNaLE1BQU0scUJBQXFCLEdBQWdCLEVBQUUsQ0FBQztRQUM5QyxNQUFNLHNCQUFzQixHQUFnQixFQUFFLENBQUM7UUFDL0MsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFVBQVUsRUFBRSxFQUFFLENBQUMsRUFBRTtZQUNuQyxNQUFNLENBQUMsWUFBWSxFQUFFLGFBQWEsQ0FBQyxHQUFHLEdBQUcsQ0FBQyx1Q0FBdUMsRUFBRSxDQUFDO1lBQ3BGLHFCQUFxQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUN6QyxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7U0FDNUM7UUFFRCxZQUFZO1FBQ1osTUFBTSxlQUFlLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FDN0IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FDUixHQUFHLENBQUMsdUNBQXVDLENBQ3pDLEdBQUcsRUFDSCxFQUFFLEVBQ0Ysc0JBQXNCLENBQUMsQ0FBQyxDQUFDLEVBQ3pCLE9BQU8sRUFDUCxxQkFBcUIsQ0FDdEIsQ0FBQyxDQUFDLENBQUMsQ0FDUCxDQUFDO1FBRUYsdUJBQXVCO1FBQ3ZCO1lBQ0UsTUFBTSxDQUNKLEdBQUcsQ0FBQyxnQ0FBZ0MsQ0FDbEMsR0FBRyxFQUNILE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQ3BCLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFDbEMsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FDN0IsQ0FBQyxDQUFDLENBQUMsQ0FDTCxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUNmO1FBRUQsMkJBQTJCO1FBQzNCO1lBQ0UsTUFBTSxjQUFjLEdBQUcsQ0FBQyxHQUFHLGVBQWUsQ0FBQyxDQUFDO1lBQzVDLGNBQWMsQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLENBQUMsdUNBQXVDLENBQzdELEdBQUcsRUFDSCxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsd0JBQXdCO1lBQ2hDLHNCQUFzQixDQUFDLENBQUMsQ0FBQyxFQUN6QixPQUFPLEVBQ1AscUJBQXFCLENBQ3RCLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDTCxNQUFNLENBQUMsR0FBRyxDQUFDLGdDQUFnQyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDbEg7UUFFRCxzQkFBc0I7UUFDdEI7WUFDRSxNQUFNLGNBQWMsR0FBRyxDQUFDLEdBQUcsZUFBZSxDQUFDLENBQUM7WUFDNUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxHQUFHLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN2QyxNQUFNLENBQUMsR0FBRyxDQUFDLGdDQUFnQyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDbEg7SUFDSCxDQUFDLENBQUMsQ0FBQztJQUVILEVBQUUsQ0FBQyx3RUFBd0UsRUFBRSxHQUFHLEVBQUU7UUFDaEYsTUFBTSxHQUFHLEdBQUcsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUNqRCxNQUFNLE9BQU8sR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLHNDQUFzQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFOUUsb0JBQW9CO1FBQ3BCO1lBQ0UsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksU0FBUyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUM5QyxNQUFNLENBQUMsR0FBRyxDQUFDLDhDQUE4QyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3BGO1FBRUQsc0JBQXNCO1FBQ3RCO1lBQ0UsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN4QixNQUFNLENBQUMsR0FBRyxDQUFDLDhDQUE4QyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3BGO0lBQ0gsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQyJ9
|