@aztec/bb-prover 0.40.0 → 0.41.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/dest/bb/execute.d.ts +7 -1
- package/dest/bb/execute.d.ts.map +1 -1
- package/dest/bb/execute.js +35 -26
- package/dest/prover/bb_native_proof_creator.d.ts +3 -2
- package/dest/prover/bb_native_proof_creator.d.ts.map +1 -1
- package/dest/prover/bb_native_proof_creator.js +53 -35
- package/dest/prover/bb_prover.d.ts +14 -3
- package/dest/prover/bb_prover.d.ts.map +1 -1
- package/dest/prover/bb_prover.js +67 -40
- package/dest/stats.d.ts +2 -5
- package/dest/stats.d.ts.map +1 -1
- package/dest/stats.js +20 -25
- package/package.json +6 -6
- package/src/bb/execute.ts +41 -26
- package/src/prover/bb_native_proof_creator.ts +104 -42
- package/src/prover/bb_prover.ts +122 -82
- package/src/stats.ts +23 -44
package/dest/prover/bb_prover.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* eslint-disable require-await */
|
|
2
2
|
import { PublicKernelType, makePublicInputsAndProof, } from '@aztec/circuit-types';
|
|
3
|
-
import { Fr, Proof, RecursiveProof, RollupTypes, RootParityInput, VerificationKeyAsFields, } from '@aztec/circuits.js';
|
|
3
|
+
import { Fr, NESTED_RECURSIVE_PROOF_LENGTH, Proof, RECURSIVE_PROOF_LENGTH, RecursiveProof, RollupTypes, RootParityInput, VerificationKeyAsFields, } from '@aztec/circuits.js';
|
|
4
4
|
import { randomBytes } from '@aztec/foundation/crypto';
|
|
5
5
|
import { createDebugLogger } from '@aztec/foundation/log';
|
|
6
6
|
import { Timer } from '@aztec/foundation/timer';
|
|
@@ -9,7 +9,7 @@ import { NativeACVMSimulator } from '@aztec/simulator';
|
|
|
9
9
|
import * as fs from 'fs/promises';
|
|
10
10
|
import { BB_RESULT, PROOF_FIELDS_FILENAME, PROOF_FILENAME, VK_FIELDS_FILENAME, VK_FILENAME, generateKeyForNoirCircuit, generateProof, verifyProof, } from '../bb/execute.js';
|
|
11
11
|
import { PublicKernelArtifactMapping } from '../mappings/mappings.js';
|
|
12
|
-
import {
|
|
12
|
+
import { mapProtocolArtifactNameToCircuitName } from '../stats.js';
|
|
13
13
|
import { AGGREGATION_OBJECT_SIZE, CIRCUIT_PUBLIC_INPUTS_INDEX, CIRCUIT_RECURSIVE_INDEX, CIRCUIT_SIZE_INDEX, } from './verification_key_data.js';
|
|
14
14
|
const logger = createDebugLogger('aztec:bb-prover');
|
|
15
15
|
const CIRCUITS_WITHOUT_AGGREGATION = new Set(['BaseParityArtifact']);
|
|
@@ -36,8 +36,7 @@ export class BBNativeRollupProver {
|
|
|
36
36
|
* @returns The public inputs of the parity circuit.
|
|
37
37
|
*/
|
|
38
38
|
async getBaseParityProof(inputs) {
|
|
39
|
-
const
|
|
40
|
-
const [circuitOutput, proof] = await this.createRecursiveProof(witnessMap, 'BaseParityArtifact', convertBaseParityOutputsFromWitnessMap);
|
|
39
|
+
const [circuitOutput, proof] = await this.createRecursiveProof(inputs, 'BaseParityArtifact', RECURSIVE_PROOF_LENGTH, convertBaseParityInputsToWitnessMap, convertBaseParityOutputsFromWitnessMap);
|
|
41
40
|
const verificationKey = await this.getVerificationKeyDataForCircuit('BaseParityArtifact');
|
|
42
41
|
const vk = new VerificationKeyAsFields(verificationKey.keyAsFields, verificationKey.hash);
|
|
43
42
|
return new RootParityInput(proof, vk, circuitOutput);
|
|
@@ -48,8 +47,7 @@ export class BBNativeRollupProver {
|
|
|
48
47
|
* @returns The public inputs of the parity circuit.
|
|
49
48
|
*/
|
|
50
49
|
async getRootParityProof(inputs) {
|
|
51
|
-
const
|
|
52
|
-
const [circuitOutput, proof] = await this.createRecursiveProof(witnessMap, 'RootParityArtifact', convertRootParityOutputsFromWitnessMap);
|
|
50
|
+
const [circuitOutput, proof] = await this.createRecursiveProof(inputs, 'RootParityArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertRootParityInputsToWitnessMap, convertRootParityOutputsFromWitnessMap);
|
|
53
51
|
const verificationKey = await this.getVerificationKeyDataForCircuit('RootParityArtifact');
|
|
54
52
|
const vk = new VerificationKeyAsFields(verificationKey.keyAsFields, verificationKey.hash);
|
|
55
53
|
return new RootParityInput(proof, vk, circuitOutput);
|
|
@@ -64,9 +62,7 @@ export class BBNativeRollupProver {
|
|
|
64
62
|
if (kernelOps === undefined) {
|
|
65
63
|
throw new Error(`Unable to prove kernel type ${PublicKernelType[kernelRequest.type]}`);
|
|
66
64
|
}
|
|
67
|
-
const
|
|
68
|
-
const [outputWitness, proof] = await this.createProof(witnessMap, kernelOps.artifact);
|
|
69
|
-
const result = kernelOps.convertOutputs(outputWitness);
|
|
65
|
+
const [result, proof] = await this.createProof(kernelRequest.inputs, kernelOps.artifact, kernelOps.convertInputs, kernelOps.convertOutputs);
|
|
70
66
|
return makePublicInputsAndProof(result, proof);
|
|
71
67
|
}
|
|
72
68
|
/**
|
|
@@ -75,9 +71,7 @@ export class BBNativeRollupProver {
|
|
|
75
71
|
* @returns The requested circuit's public inputs and proof
|
|
76
72
|
*/
|
|
77
73
|
async getPublicTailProof(kernelRequest) {
|
|
78
|
-
const
|
|
79
|
-
const [outputWitness, proof] = await this.createProof(witnessMap, 'PublicKernelTailArtifact');
|
|
80
|
-
const result = convertPublicTailOutputFromWitnessMap(outputWitness);
|
|
74
|
+
const [result, proof] = await this.createProof(kernelRequest.inputs, 'PublicKernelTailArtifact', convertPublicTailInputsToWitnessMap, convertPublicTailOutputFromWitnessMap);
|
|
81
75
|
return makePublicInputsAndProof(result, proof);
|
|
82
76
|
}
|
|
83
77
|
/**
|
|
@@ -86,9 +80,7 @@ export class BBNativeRollupProver {
|
|
|
86
80
|
* @returns The public inputs as outputs of the simulation.
|
|
87
81
|
*/
|
|
88
82
|
async getBaseRollupProof(input) {
|
|
89
|
-
const
|
|
90
|
-
const [outputWitness, proof] = await this.createProof(witnessMap, 'BaseRollupArtifact');
|
|
91
|
-
const result = convertBaseRollupOutputsFromWitnessMap(outputWitness);
|
|
83
|
+
const [result, proof] = await this.createProof(input, 'BaseRollupArtifact', convertBaseRollupInputsToWitnessMap, convertBaseRollupOutputsFromWitnessMap);
|
|
92
84
|
return makePublicInputsAndProof(result, proof);
|
|
93
85
|
}
|
|
94
86
|
/**
|
|
@@ -99,9 +91,7 @@ export class BBNativeRollupProver {
|
|
|
99
91
|
async getMergeRollupProof(input) {
|
|
100
92
|
// verify both inputs
|
|
101
93
|
await Promise.all(input.previousRollupData.map(prev => this.verifyPreviousRollupProof(prev)));
|
|
102
|
-
const
|
|
103
|
-
const [outputWitness, proof] = await this.createProof(witnessMap, 'MergeRollupArtifact');
|
|
104
|
-
const result = convertMergeRollupOutputsFromWitnessMap(outputWitness);
|
|
94
|
+
const [result, proof] = await this.createProof(input, 'MergeRollupArtifact', convertMergeRollupInputsToWitnessMap, convertMergeRollupOutputsFromWitnessMap);
|
|
105
95
|
return makePublicInputsAndProof(result, proof);
|
|
106
96
|
}
|
|
107
97
|
/**
|
|
@@ -112,14 +102,12 @@ export class BBNativeRollupProver {
|
|
|
112
102
|
async getRootRollupProof(input) {
|
|
113
103
|
// verify the inputs
|
|
114
104
|
await Promise.all(input.previousRollupData.map(prev => this.verifyPreviousRollupProof(prev)));
|
|
115
|
-
const
|
|
116
|
-
const [outputWitness, proof] = await this.createProof(witnessMap, 'RootRollupArtifact');
|
|
105
|
+
const [result, proof] = await this.createProof(input, 'RootRollupArtifact', convertRootRollupInputsToWitnessMap, convertRootRollupOutputsFromWitnessMap);
|
|
117
106
|
await this.verifyProof('RootRollupArtifact', proof);
|
|
118
|
-
const result = convertRootRollupOutputsFromWitnessMap(outputWitness);
|
|
119
107
|
return makePublicInputsAndProof(result, proof);
|
|
120
108
|
}
|
|
121
109
|
// TODO(@PhilWindle): Delete when no longer required
|
|
122
|
-
async createProof(
|
|
110
|
+
async createProof(input, circuitType, convertInput, convertOutput) {
|
|
123
111
|
// Create random directory to be used for temp files
|
|
124
112
|
const bbWorkingDirectory = `${this.config.bbWorkingDirectory}/${randomBytes(8).toString('hex')}`;
|
|
125
113
|
await fs.mkdir(bbWorkingDirectory, { recursive: true });
|
|
@@ -131,9 +119,16 @@ export class BBNativeRollupProver {
|
|
|
131
119
|
const simulator = new NativeACVMSimulator(this.config.acvmWorkingDirectory, this.config.acvmBinaryPath, outputWitnessFile);
|
|
132
120
|
const artifact = ServerCircuitArtifacts[circuitType];
|
|
133
121
|
logger.debug(`Generating witness data for ${circuitType}`);
|
|
122
|
+
const witnessMap = convertInput(input);
|
|
134
123
|
const timer = new Timer();
|
|
135
124
|
const outputWitness = await simulator.simulateCircuit(witnessMap, artifact);
|
|
136
|
-
|
|
125
|
+
logger.debug(`Generated witness`, {
|
|
126
|
+
circuitName: mapProtocolArtifactNameToCircuitName(circuitType),
|
|
127
|
+
duration: timer.ms(),
|
|
128
|
+
inputSize: witnessMap.size * Fr.SIZE_IN_BYTES,
|
|
129
|
+
outputSize: outputWitness.size * Fr.SIZE_IN_BYTES,
|
|
130
|
+
eventName: 'circuit-witness-generation',
|
|
131
|
+
});
|
|
137
132
|
// Now prove the circuit from the generated witness
|
|
138
133
|
logger.debug(`Proving ${circuitType}...`);
|
|
139
134
|
const provingResult = await generateProof(this.config.bbBinaryPath, bbWorkingDirectory, circuitType, Buffer.from(artifact.bytecode, 'base64'), outputWitnessFile, logger.debug);
|
|
@@ -142,23 +137,35 @@ export class BBNativeRollupProver {
|
|
|
142
137
|
throw new Error(provingResult.reason);
|
|
143
138
|
}
|
|
144
139
|
// Ensure our vk cache is up to date
|
|
145
|
-
await this.updateVerificationKeyAfterProof(provingResult.vkPath, circuitType);
|
|
140
|
+
const vkData = await this.updateVerificationKeyAfterProof(provingResult.vkPath, circuitType);
|
|
146
141
|
// Read the proof and then cleanup up our temporary directory
|
|
147
|
-
const
|
|
148
|
-
// does not include reading the proof from disk above because duration comes from the bb wrapper
|
|
149
|
-
emitCircuitProvingStats(circuitTypeToCircuitName(circuitType), provingResult.duration, witnessMap.size * Fr.SIZE_IN_BYTES, outputWitness.size * Fr.SIZE_IN_BYTES, proof.length, logger);
|
|
142
|
+
const rawProof = await fs.readFile(`${provingResult.proofPath}/${PROOF_FILENAME}`);
|
|
150
143
|
await fs.rm(bbWorkingDirectory, { recursive: true, force: true });
|
|
151
|
-
|
|
152
|
-
|
|
144
|
+
const output = convertOutput(outputWitness);
|
|
145
|
+
const proof = new Proof(rawProof);
|
|
146
|
+
logger.info(`Generated proof for ${circuitType} in ${provingResult.duration} ms, size: ${proof.buffer.length} fields`, {
|
|
147
|
+
circuitName: mapProtocolArtifactNameToCircuitName(circuitType),
|
|
148
|
+
// does not include reading the proof from disk
|
|
149
|
+
duration: provingResult.duration,
|
|
150
|
+
proofSize: proof.buffer.length,
|
|
151
|
+
eventName: 'circuit-proving',
|
|
152
|
+
inputSize: input.toBuffer().length,
|
|
153
|
+
outputSize: output.toBuffer().length,
|
|
154
|
+
circuitSize: vkData.circuitSize,
|
|
155
|
+
numPublicInputs: vkData.numPublicInputs,
|
|
156
|
+
});
|
|
157
|
+
return [output, proof];
|
|
153
158
|
}
|
|
154
159
|
/**
|
|
155
160
|
* Executes a circuit and returns it's outputs and corresponding proof with embedded aggregation object
|
|
156
161
|
* @param witnessMap - The input witness
|
|
157
162
|
* @param circuitType - The type of circuit to be executed
|
|
163
|
+
* @param proofLength - The length of the proof to be generated. This is a dummy parameter to aid in type checking
|
|
164
|
+
* @param convertInput - Function for mapping the input object to a witness map.
|
|
158
165
|
* @param convertOutput - Function for parsing the output witness to it's corresponding object
|
|
159
166
|
* @returns The circuits output object and it's proof
|
|
160
167
|
*/
|
|
161
|
-
async createRecursiveProof(
|
|
168
|
+
async createRecursiveProof(input, circuitType, proofLength, convertInput, convertOutput) {
|
|
162
169
|
// Create random directory to be used for temp files
|
|
163
170
|
const bbWorkingDirectory = `${this.config.bbWorkingDirectory}/${randomBytes(8).toString('hex')}`;
|
|
164
171
|
await fs.mkdir(bbWorkingDirectory, { recursive: true });
|
|
@@ -172,9 +179,18 @@ export class BBNativeRollupProver {
|
|
|
172
179
|
const artifact = ServerCircuitArtifacts[circuitType];
|
|
173
180
|
logger.debug(`Generating witness data for ${circuitType}`);
|
|
174
181
|
const timer = new Timer();
|
|
182
|
+
const witnessMap = convertInput(input);
|
|
175
183
|
const outputWitness = await simulator.simulateCircuit(witnessMap, artifact);
|
|
176
|
-
|
|
177
|
-
const
|
|
184
|
+
const output = convertOutput(outputWitness);
|
|
185
|
+
const inputSize = input.toBuffer().length;
|
|
186
|
+
const outputSize = output.toBuffer().length;
|
|
187
|
+
logger.debug(`Generated witness`, {
|
|
188
|
+
circuitName: mapProtocolArtifactNameToCircuitName(circuitType),
|
|
189
|
+
duration: timer.ms(),
|
|
190
|
+
inputSize,
|
|
191
|
+
outputSize,
|
|
192
|
+
eventName: 'circuit-witness-generation',
|
|
193
|
+
});
|
|
178
194
|
// Now prove the circuit from the generated witness
|
|
179
195
|
logger.debug(`Proving ${circuitType}...`);
|
|
180
196
|
const provingResult = await generateProof(this.config.bbBinaryPath, bbWorkingDirectory, circuitType, Buffer.from(artifact.bytecode, 'base64'), outputWitnessFile, logger.debug);
|
|
@@ -183,12 +199,20 @@ export class BBNativeRollupProver {
|
|
|
183
199
|
throw new Error(provingResult.reason);
|
|
184
200
|
}
|
|
185
201
|
// Ensure our vk cache is up to date
|
|
186
|
-
await this.updateVerificationKeyAfterProof(provingResult.vkPath, circuitType);
|
|
202
|
+
const vkData = await this.updateVerificationKeyAfterProof(provingResult.vkPath, circuitType);
|
|
187
203
|
// Read the proof and then cleanup up our temporary directory
|
|
188
|
-
const proof = await this.readProofAsFields(provingResult.proofPath, circuitType);
|
|
189
|
-
logger.info(`Generated proof for ${circuitType} in ${provingResult.duration} ms, size: ${proof.proof.length} fields
|
|
190
|
-
|
|
191
|
-
|
|
204
|
+
const proof = await this.readProofAsFields(provingResult.proofPath, circuitType, proofLength);
|
|
205
|
+
logger.info(`Generated proof for ${circuitType} in ${provingResult.duration} ms, size: ${proof.proof.length} fields`, {
|
|
206
|
+
circuitName: mapProtocolArtifactNameToCircuitName(circuitType),
|
|
207
|
+
circuitSize: vkData.circuitSize,
|
|
208
|
+
duration: provingResult.duration,
|
|
209
|
+
inputSize,
|
|
210
|
+
outputSize,
|
|
211
|
+
proofSize: proof.binaryProof.buffer.length,
|
|
212
|
+
eventName: 'circuit-proving',
|
|
213
|
+
numPublicInputs: vkData.numPublicInputs,
|
|
214
|
+
});
|
|
215
|
+
return [output, proof];
|
|
192
216
|
}
|
|
193
217
|
finally {
|
|
194
218
|
await fs.rm(bbWorkingDirectory, { recursive: true, force: true });
|
|
@@ -290,7 +314,7 @@ export class BBNativeRollupProver {
|
|
|
290
314
|
promise = this.convertVk(filePath);
|
|
291
315
|
this.verificationKeys.set(circuitType, promise);
|
|
292
316
|
}
|
|
293
|
-
|
|
317
|
+
return promise;
|
|
294
318
|
}
|
|
295
319
|
/**
|
|
296
320
|
* Parses and returns the proof data stored at the specified directory
|
|
@@ -298,7 +322,7 @@ export class BBNativeRollupProver {
|
|
|
298
322
|
* @param circuitType - The type of circuit proven
|
|
299
323
|
* @returns The proof
|
|
300
324
|
*/
|
|
301
|
-
async readProofAsFields(filePath, circuitType) {
|
|
325
|
+
async readProofAsFields(filePath, circuitType, proofLength) {
|
|
302
326
|
const [binaryProof, proofString] = await Promise.all([
|
|
303
327
|
fs.readFile(`${filePath}/${PROOF_FILENAME}`),
|
|
304
328
|
fs.readFile(`${filePath}/${PROOF_FIELDS_FILENAME}`, { encoding: 'utf-8' }),
|
|
@@ -315,7 +339,10 @@ export class BBNativeRollupProver {
|
|
|
315
339
|
const fieldsWithoutPublicInputs = fields.slice(numPublicInputs);
|
|
316
340
|
logger.debug(`Circuit type: ${circuitType}, complete proof length: ${fields.length}, without public inputs: ${fieldsWithoutPublicInputs.length}, num public inputs: ${numPublicInputs}, circuit size: ${vkData.circuitSize}, is recursive: ${vkData.isRecursive}, raw length: ${binaryProof.length}`);
|
|
317
341
|
const proof = new RecursiveProof(fieldsWithoutPublicInputs, new Proof(binaryProof));
|
|
342
|
+
if (proof.proof.length !== proofLength) {
|
|
343
|
+
throw new Error("Proof length doesn't match expected length");
|
|
344
|
+
}
|
|
318
345
|
return proof;
|
|
319
346
|
}
|
|
320
347
|
}
|
|
321
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bb_prover.js","sourceRoot":"","sources":["../../src/prover/bb_prover.ts"],"names":[],"mappings":"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"}
|
|
348
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bb_prover.js","sourceRoot":"","sources":["../../src/prover/bb_prover.ts"],"names":[],"mappings":"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"}
|
package/dest/stats.d.ts
CHANGED
|
@@ -1,9 +1,6 @@
|
|
|
1
1
|
import { type PublicKernelRequest } from '@aztec/circuit-types';
|
|
2
2
|
import type { CircuitName } from '@aztec/circuit-types/stats';
|
|
3
|
-
import { type
|
|
4
|
-
import { type ServerProtocolArtifact } from '@aztec/noir-protocol-circuits-types';
|
|
5
|
-
export declare function emitCircuitWitnessGenerationStats(circuitName: CircuitName, duration: number, inputSize: number, outputSize: number, logger: Logger): void;
|
|
6
|
-
export declare function emitCircuitProvingStats(circuitName: CircuitName, duration: number, inputSize: number, outputSize: number, proofSize: number, logger: Logger): void;
|
|
3
|
+
import { type ClientProtocolArtifact, type ServerProtocolArtifact } from '@aztec/noir-protocol-circuits-types';
|
|
7
4
|
export declare function mapPublicKernelToCircuitName(kernelType: PublicKernelRequest['type']): CircuitName;
|
|
8
|
-
export declare function
|
|
5
|
+
export declare function mapProtocolArtifactNameToCircuitName(artifact: ServerProtocolArtifact | ClientProtocolArtifact): CircuitName;
|
|
9
6
|
//# sourceMappingURL=stats.d.ts.map
|
package/dest/stats.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stats.d.ts","sourceRoot":"","sources":["../src/stats.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAoB,MAAM,sBAAsB,CAAC;AAClF,OAAO,KAAK,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"stats.d.ts","sourceRoot":"","sources":["../src/stats.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAoB,MAAM,sBAAsB,CAAC;AAClF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,KAAK,sBAAsB,EAAE,KAAK,sBAAsB,EAAE,MAAM,qCAAqC,CAAC;AAE/G,wBAAgB,4BAA4B,CAAC,UAAU,EAAE,mBAAmB,CAAC,MAAM,CAAC,GAAG,WAAW,CAajG;AAED,wBAAgB,oCAAoC,CAClD,QAAQ,EAAE,sBAAsB,GAAG,sBAAsB,GACxD,WAAW,CAuCb"}
|
package/dest/stats.js
CHANGED
|
@@ -1,25 +1,4 @@
|
|
|
1
1
|
import { PublicKernelType } from '@aztec/circuit-types';
|
|
2
|
-
export function emitCircuitWitnessGenerationStats(circuitName, duration, inputSize, outputSize, logger) {
|
|
3
|
-
const stats = {
|
|
4
|
-
eventName: 'circuit-witness-generation',
|
|
5
|
-
circuitName,
|
|
6
|
-
inputSize,
|
|
7
|
-
outputSize,
|
|
8
|
-
duration,
|
|
9
|
-
};
|
|
10
|
-
logger.debug('Circuit witness generation stats', stats);
|
|
11
|
-
}
|
|
12
|
-
export function emitCircuitProvingStats(circuitName, duration, inputSize, outputSize, proofSize, logger) {
|
|
13
|
-
const stats = {
|
|
14
|
-
eventName: 'circuit-proving',
|
|
15
|
-
circuitName,
|
|
16
|
-
duration,
|
|
17
|
-
inputSize,
|
|
18
|
-
outputSize,
|
|
19
|
-
proofSize,
|
|
20
|
-
};
|
|
21
|
-
logger.debug('Circuit proving stats', stats);
|
|
22
|
-
}
|
|
23
2
|
export function mapPublicKernelToCircuitName(kernelType) {
|
|
24
3
|
switch (kernelType) {
|
|
25
4
|
case PublicKernelType.SETUP:
|
|
@@ -34,8 +13,8 @@ export function mapPublicKernelToCircuitName(kernelType) {
|
|
|
34
13
|
throw new Error(`Unknown kernel type: ${kernelType}`);
|
|
35
14
|
}
|
|
36
15
|
}
|
|
37
|
-
export function
|
|
38
|
-
switch (
|
|
16
|
+
export function mapProtocolArtifactNameToCircuitName(artifact) {
|
|
17
|
+
switch (artifact) {
|
|
39
18
|
case 'BaseParityArtifact':
|
|
40
19
|
return 'base-parity';
|
|
41
20
|
case 'RootParityArtifact':
|
|
@@ -54,8 +33,24 @@ export function circuitTypeToCircuitName(circuitType) {
|
|
|
54
33
|
return 'public-kernel-teardown';
|
|
55
34
|
case 'PublicKernelTailArtifact':
|
|
56
35
|
return 'public-kernel-tail';
|
|
36
|
+
case 'PrivateKernelInitArtifact':
|
|
37
|
+
return 'private-kernel-init';
|
|
38
|
+
case 'PrivateKernelInnerArtifact':
|
|
39
|
+
return 'private-kernel-inner';
|
|
40
|
+
case 'PrivateKernelTailArtifact':
|
|
41
|
+
return 'private-kernel-tail';
|
|
42
|
+
case 'PrivateKernelTailToPublicArtifact':
|
|
43
|
+
return 'private-kernel-tail-to-public';
|
|
44
|
+
case 'PrivateKernelResetFullArtifact':
|
|
45
|
+
return 'private-kernel-reset-full';
|
|
46
|
+
case 'PrivateKernelResetBigArtifact':
|
|
47
|
+
return 'private-kernel-reset-big';
|
|
48
|
+
case 'PrivateKernelResetMediumArtifact':
|
|
49
|
+
return 'private-kernel-reset-medium';
|
|
50
|
+
case 'PrivateKernelResetSmallArtifact':
|
|
51
|
+
return 'private-kernel-reset-small';
|
|
57
52
|
default:
|
|
58
|
-
throw new Error(`Unknown circuit type: ${
|
|
53
|
+
throw new Error(`Unknown circuit type: ${artifact}`);
|
|
59
54
|
}
|
|
60
55
|
}
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvc3RhdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUE0QixnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBSWxGLE1BQU0sVUFBVSw0QkFBNEIsQ0FBQyxVQUF1QztJQUNsRixRQUFRLFVBQVUsRUFBRSxDQUFDO1FBQ25CLEtBQUssZ0JBQWdCLENBQUMsS0FBSztZQUN6QixPQUFPLHFCQUFxQixDQUFDO1FBQy9CLEtBQUssZ0JBQWdCLENBQUMsU0FBUztZQUM3QixPQUFPLHlCQUF5QixDQUFDO1FBQ25DLEtBQUssZ0JBQWdCLENBQUMsUUFBUTtZQUM1QixPQUFPLHdCQUF3QixDQUFDO1FBQ2xDLEtBQUssZ0JBQWdCLENBQUMsSUFBSTtZQUN4QixPQUFPLG9CQUFvQixDQUFDO1FBQzlCO1lBQ0UsTUFBTSxJQUFJLEtBQUssQ0FBQyx3QkFBd0IsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUMxRCxDQUFDO0FBQ0gsQ0FBQztBQUVELE1BQU0sVUFBVSxvQ0FBb0MsQ0FDbEQsUUFBeUQ7SUFFekQsUUFBUSxRQUFRLEVBQUUsQ0FBQztRQUNqQixLQUFLLG9CQUFvQjtZQUN2QixPQUFPLGFBQWEsQ0FBQztRQUN2QixLQUFLLG9CQUFvQjtZQUN2QixPQUFPLGFBQWEsQ0FBQztRQUN2QixLQUFLLG9CQUFvQjtZQUN2QixPQUFPLGFBQWEsQ0FBQztRQUN2QixLQUFLLHFCQUFxQjtZQUN4QixPQUFPLGNBQWMsQ0FBQztRQUN4QixLQUFLLG9CQUFvQjtZQUN2QixPQUFPLGFBQWEsQ0FBQztRQUN2QixLQUFLLDJCQUEyQjtZQUM5QixPQUFPLHFCQUFxQixDQUFDO1FBQy9CLEtBQUssOEJBQThCO1lBQ2pDLE9BQU8seUJBQXlCLENBQUM7UUFDbkMsS0FBSyw4QkFBOEI7WUFDakMsT0FBTyx3QkFBd0IsQ0FBQztRQUNsQyxLQUFLLDBCQUEwQjtZQUM3QixPQUFPLG9CQUFvQixDQUFDO1FBQzlCLEtBQUssMkJBQTJCO1lBQzlCLE9BQU8scUJBQXFCLENBQUM7UUFDL0IsS0FBSyw0QkFBNEI7WUFDL0IsT0FBTyxzQkFBc0IsQ0FBQztRQUNoQyxLQUFLLDJCQUEyQjtZQUM5QixPQUFPLHFCQUFxQixDQUFDO1FBQy9CLEtBQUssbUNBQW1DO1lBQ3RDLE9BQU8sK0JBQStCLENBQUM7UUFDekMsS0FBSyxnQ0FBZ0M7WUFDbkMsT0FBTywyQkFBMkIsQ0FBQztRQUNyQyxLQUFLLCtCQUErQjtZQUNsQyxPQUFPLDBCQUEwQixDQUFDO1FBQ3BDLEtBQUssa0NBQWtDO1lBQ3JDLE9BQU8sNkJBQTZCLENBQUM7UUFDdkMsS0FBSyxpQ0FBaUM7WUFDcEMsT0FBTyw0QkFBNEIsQ0FBQztRQUN0QztZQUNFLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLFFBQVEsRUFBRSxDQUFDLENBQUM7SUFDekQsQ0FBQztBQUNILENBQUMifQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/bb-prover",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.41.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": {
|
|
6
6
|
".": "./dest/index.js"
|
|
@@ -51,11 +51,11 @@
|
|
|
51
51
|
]
|
|
52
52
|
},
|
|
53
53
|
"dependencies": {
|
|
54
|
-
"@aztec/circuit-types": "0.
|
|
55
|
-
"@aztec/circuits.js": "0.
|
|
56
|
-
"@aztec/foundation": "0.
|
|
57
|
-
"@aztec/noir-protocol-circuits-types": "0.
|
|
58
|
-
"@aztec/simulator": "0.
|
|
54
|
+
"@aztec/circuit-types": "0.41.0",
|
|
55
|
+
"@aztec/circuits.js": "0.41.0",
|
|
56
|
+
"@aztec/foundation": "0.41.0",
|
|
57
|
+
"@aztec/noir-protocol-circuits-types": "0.41.0",
|
|
58
|
+
"@aztec/simulator": "0.41.0",
|
|
59
59
|
"@noir-lang/noirc_abi": "portal:../../noir/packages/noirc_abi",
|
|
60
60
|
"@noir-lang/types": "portal:../../noir/packages/types",
|
|
61
61
|
"commander": "^9.0.0",
|
package/src/bb/execute.ts
CHANGED
|
@@ -32,6 +32,12 @@ export type BBFailure = {
|
|
|
32
32
|
|
|
33
33
|
export type BBResult = BBSuccess | BBFailure;
|
|
34
34
|
|
|
35
|
+
type BBExecResult = {
|
|
36
|
+
status: BB_RESULT;
|
|
37
|
+
exitCode: number;
|
|
38
|
+
signal: string | undefined;
|
|
39
|
+
};
|
|
40
|
+
|
|
35
41
|
/**
|
|
36
42
|
* Invokes the Barretenberg binary with the provided command and args
|
|
37
43
|
* @param pathToBB - The path to the BB binary
|
|
@@ -47,26 +53,20 @@ export function executeBB(
|
|
|
47
53
|
args: string[],
|
|
48
54
|
logger: LogFn,
|
|
49
55
|
resultParser = (code: number) => code === 0,
|
|
50
|
-
) {
|
|
51
|
-
return new Promise<
|
|
56
|
+
): Promise<BBExecResult> {
|
|
57
|
+
return new Promise<BBExecResult>(resolve => {
|
|
52
58
|
// spawn the bb process
|
|
53
|
-
const bb = proc.spawn(pathToBB, [command, ...args]
|
|
54
|
-
|
|
55
|
-
const message = data.toString('utf-8').replace(/\n$/, '');
|
|
56
|
-
logger(message);
|
|
59
|
+
const bb = proc.spawn(pathToBB, [command, ...args], {
|
|
60
|
+
stdio: 'pipe',
|
|
57
61
|
});
|
|
58
|
-
bb.
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
});
|
|
62
|
-
bb.on('close', (code: number) => {
|
|
63
|
-
if (resultParser(code)) {
|
|
64
|
-
resolve(BB_RESULT.SUCCESS);
|
|
62
|
+
bb.on('close', (exitCode: number, signal?: string) => {
|
|
63
|
+
if (resultParser(exitCode)) {
|
|
64
|
+
resolve({ status: BB_RESULT.SUCCESS, exitCode, signal });
|
|
65
65
|
} else {
|
|
66
|
-
|
|
66
|
+
resolve({ status: BB_RESULT.FAILURE, exitCode, signal });
|
|
67
67
|
}
|
|
68
68
|
});
|
|
69
|
-
}).catch(_ => BB_RESULT.FAILURE);
|
|
69
|
+
}).catch(_ => ({ status: BB_RESULT.FAILURE, exitCode: -1, signal: undefined }));
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
const bytecodeHashFilename = 'bytecode_hash';
|
|
@@ -154,14 +154,14 @@ export async function generateKeyForNoirCircuit(
|
|
|
154
154
|
const timer = new Timer();
|
|
155
155
|
let result = await executeBB(pathToBB, `write_${key}`, args, log);
|
|
156
156
|
// If we succeeded and the type of key if verification, have bb write the 'fields' version too
|
|
157
|
-
if (result == BB_RESULT.SUCCESS && key === 'vk') {
|
|
157
|
+
if (result.status == BB_RESULT.SUCCESS && key === 'vk') {
|
|
158
158
|
const asFieldsArgs = ['-k', `${outputPath}/${VK_FILENAME}`, '-o', `${outputPath}/${VK_FIELDS_FILENAME}`, '-v'];
|
|
159
159
|
result = await executeBB(pathToBB, `vk_as_fields`, asFieldsArgs, log);
|
|
160
160
|
}
|
|
161
161
|
const duration = timer.ms();
|
|
162
162
|
// Cleanup the bytecode file
|
|
163
163
|
await fs.rm(bytecodePath, { force: true });
|
|
164
|
-
if (result == BB_RESULT.SUCCESS) {
|
|
164
|
+
if (result.status == BB_RESULT.SUCCESS) {
|
|
165
165
|
// Store the bytecode hash so we don't need to regenerate at a later time
|
|
166
166
|
await fs.writeFile(bytecodeHashPath, bytecodeHash);
|
|
167
167
|
return {
|
|
@@ -173,7 +173,10 @@ export async function generateKeyForNoirCircuit(
|
|
|
173
173
|
};
|
|
174
174
|
}
|
|
175
175
|
// Not a great error message here but it is difficult to decipher what comes from bb
|
|
176
|
-
return {
|
|
176
|
+
return {
|
|
177
|
+
status: BB_RESULT.FAILURE,
|
|
178
|
+
reason: `Failed to generate key. Exit code: ${result.exitCode}. Signal ${result.signal}.`,
|
|
179
|
+
};
|
|
177
180
|
} catch (error) {
|
|
178
181
|
return { status: BB_RESULT.FAILURE, reason: `${error}` };
|
|
179
182
|
}
|
|
@@ -231,7 +234,7 @@ export async function generateProof(
|
|
|
231
234
|
const duration = timer.ms();
|
|
232
235
|
// cleanup the bytecode
|
|
233
236
|
await fs.rm(bytecodePath, { force: true });
|
|
234
|
-
if (result == BB_RESULT.SUCCESS) {
|
|
237
|
+
if (result.status == BB_RESULT.SUCCESS) {
|
|
235
238
|
return {
|
|
236
239
|
status: BB_RESULT.SUCCESS,
|
|
237
240
|
duration,
|
|
@@ -241,7 +244,10 @@ export async function generateProof(
|
|
|
241
244
|
};
|
|
242
245
|
}
|
|
243
246
|
// Not a great error message here but it is difficult to decipher what comes from bb
|
|
244
|
-
return {
|
|
247
|
+
return {
|
|
248
|
+
status: BB_RESULT.FAILURE,
|
|
249
|
+
reason: `Failed to generate proof. Exit code ${result.exitCode}. Signal ${result.signal}.`,
|
|
250
|
+
};
|
|
245
251
|
} catch (error) {
|
|
246
252
|
return { status: BB_RESULT.FAILURE, reason: `${error}` };
|
|
247
253
|
}
|
|
@@ -274,11 +280,14 @@ export async function verifyProof(
|
|
|
274
280
|
const timer = new Timer();
|
|
275
281
|
const result = await executeBB(pathToBB, 'verify', args, log);
|
|
276
282
|
const duration = timer.ms();
|
|
277
|
-
if (result == BB_RESULT.SUCCESS) {
|
|
283
|
+
if (result.status == BB_RESULT.SUCCESS) {
|
|
278
284
|
return { status: BB_RESULT.SUCCESS, duration };
|
|
279
285
|
}
|
|
280
286
|
// Not a great error message here but it is difficult to decipher what comes from bb
|
|
281
|
-
return {
|
|
287
|
+
return {
|
|
288
|
+
status: BB_RESULT.FAILURE,
|
|
289
|
+
reason: `Failed to verify proof. Exit code ${result.exitCode}. Signal ${result.signal}.`,
|
|
290
|
+
};
|
|
282
291
|
} catch (error) {
|
|
283
292
|
return { status: BB_RESULT.FAILURE, reason: `${error}` };
|
|
284
293
|
}
|
|
@@ -311,11 +320,14 @@ export async function writeVkAsFields(
|
|
|
311
320
|
const timer = new Timer();
|
|
312
321
|
const result = await executeBB(pathToBB, 'vk_as_fields', args, log);
|
|
313
322
|
const duration = timer.ms();
|
|
314
|
-
if (result == BB_RESULT.SUCCESS) {
|
|
323
|
+
if (result.status == BB_RESULT.SUCCESS) {
|
|
315
324
|
return { status: BB_RESULT.SUCCESS, duration, vkPath: verificationKeyPath };
|
|
316
325
|
}
|
|
317
326
|
// Not a great error message here but it is difficult to decipher what comes from bb
|
|
318
|
-
return {
|
|
327
|
+
return {
|
|
328
|
+
status: BB_RESULT.FAILURE,
|
|
329
|
+
reason: `Failed to create vk as fields. Exit code ${result.exitCode}. Signal ${result.signal}.`,
|
|
330
|
+
};
|
|
319
331
|
} catch (error) {
|
|
320
332
|
return { status: BB_RESULT.FAILURE, reason: `${error}` };
|
|
321
333
|
}
|
|
@@ -348,11 +360,14 @@ export async function writeProofAsFields(
|
|
|
348
360
|
const timer = new Timer();
|
|
349
361
|
const result = await executeBB(pathToBB, 'proof_as_fields', args, log);
|
|
350
362
|
const duration = timer.ms();
|
|
351
|
-
if (result == BB_RESULT.SUCCESS) {
|
|
363
|
+
if (result.status == BB_RESULT.SUCCESS) {
|
|
352
364
|
return { status: BB_RESULT.SUCCESS, duration, proofPath: proofPath };
|
|
353
365
|
}
|
|
354
366
|
// Not a great error message here but it is difficult to decipher what comes from bb
|
|
355
|
-
return {
|
|
367
|
+
return {
|
|
368
|
+
status: BB_RESULT.FAILURE,
|
|
369
|
+
reason: `Failed to create proof as fields. Exit code ${result.exitCode}. Signal ${result.signal}.`,
|
|
370
|
+
};
|
|
356
371
|
} catch (error) {
|
|
357
372
|
return { status: BB_RESULT.FAILURE, reason: `${error}` };
|
|
358
373
|
}
|