@aztec/prover-client 3.0.0-canary.a9708bd → 3.0.0-devnet.2-patch.1
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/block-factory/index.d.ts +1 -1
- package/dest/block-factory/light.d.ts +5 -3
- package/dest/block-factory/light.d.ts.map +1 -1
- package/dest/block-factory/light.js +32 -11
- package/dest/config.d.ts +1 -1
- package/dest/config.js +1 -1
- package/dest/index.d.ts +1 -1
- package/dest/light/lightweight_checkpoint_builder.d.ts +29 -0
- package/dest/light/lightweight_checkpoint_builder.d.ts.map +1 -0
- package/dest/light/lightweight_checkpoint_builder.js +108 -0
- package/dest/mocks/fixtures.d.ts +5 -5
- package/dest/mocks/fixtures.d.ts.map +1 -1
- package/dest/mocks/fixtures.js +33 -15
- package/dest/mocks/test_context.d.ts +37 -33
- package/dest/mocks/test_context.d.ts.map +1 -1
- package/dest/mocks/test_context.js +124 -82
- package/dest/orchestrator/block-building-helpers.d.ts +35 -35
- package/dest/orchestrator/block-building-helpers.d.ts.map +1 -1
- package/dest/orchestrator/block-building-helpers.js +151 -187
- package/dest/orchestrator/block-proving-state.d.ts +68 -55
- package/dest/orchestrator/block-proving-state.d.ts.map +1 -1
- package/dest/orchestrator/block-proving-state.js +273 -185
- package/dest/orchestrator/checkpoint-proving-state.d.ts +63 -0
- package/dest/orchestrator/checkpoint-proving-state.d.ts.map +1 -0
- package/dest/orchestrator/checkpoint-proving-state.js +210 -0
- package/dest/orchestrator/epoch-proving-state.d.ts +38 -31
- package/dest/orchestrator/epoch-proving-state.d.ts.map +1 -1
- package/dest/orchestrator/epoch-proving-state.js +128 -84
- package/dest/orchestrator/index.d.ts +1 -1
- package/dest/orchestrator/orchestrator.d.ts +33 -32
- package/dest/orchestrator/orchestrator.d.ts.map +1 -1
- package/dest/orchestrator/orchestrator.js +369 -243
- package/dest/orchestrator/orchestrator_metrics.d.ts +1 -1
- package/dest/orchestrator/orchestrator_metrics.d.ts.map +1 -1
- package/dest/orchestrator/tx-proving-state.d.ts +12 -10
- package/dest/orchestrator/tx-proving-state.d.ts.map +1 -1
- package/dest/orchestrator/tx-proving-state.js +23 -29
- package/dest/prover-client/factory.d.ts +1 -1
- package/dest/prover-client/index.d.ts +1 -1
- package/dest/prover-client/prover-client.d.ts +1 -1
- package/dest/prover-client/prover-client.d.ts.map +1 -1
- package/dest/prover-client/server-epoch-prover.d.ts +13 -11
- package/dest/prover-client/server-epoch-prover.d.ts.map +1 -1
- package/dest/prover-client/server-epoch-prover.js +9 -9
- package/dest/proving_broker/broker_prover_facade.d.ts +23 -18
- package/dest/proving_broker/broker_prover_facade.d.ts.map +1 -1
- package/dest/proving_broker/broker_prover_facade.js +41 -25
- package/dest/proving_broker/config.d.ts +18 -14
- package/dest/proving_broker/config.d.ts.map +1 -1
- package/dest/proving_broker/config.js +13 -7
- package/dest/proving_broker/factory.d.ts +1 -1
- package/dest/proving_broker/factory.js +1 -1
- package/dest/proving_broker/fixtures.d.ts +3 -2
- package/dest/proving_broker/fixtures.d.ts.map +1 -1
- package/dest/proving_broker/fixtures.js +3 -2
- package/dest/proving_broker/index.d.ts +1 -1
- package/dest/proving_broker/proof_store/factory.d.ts +2 -2
- package/dest/proving_broker/proof_store/gcs_proof_store.d.ts +1 -1
- package/dest/proving_broker/proof_store/gcs_proof_store.d.ts.map +1 -1
- package/dest/proving_broker/proof_store/index.d.ts +2 -1
- package/dest/proving_broker/proof_store/index.d.ts.map +1 -1
- package/dest/proving_broker/proof_store/index.js +1 -0
- package/dest/proving_broker/proof_store/inline_proof_store.d.ts +1 -1
- package/dest/proving_broker/proof_store/inline_proof_store.d.ts.map +1 -1
- package/dest/proving_broker/proof_store/proof_store.d.ts +1 -1
- package/dest/proving_broker/proving_agent.d.ts +1 -1
- package/dest/proving_broker/proving_agent.d.ts.map +1 -1
- package/dest/proving_broker/proving_agent_instrumentation.d.ts +1 -1
- package/dest/proving_broker/proving_agent_instrumentation.d.ts.map +1 -1
- package/dest/proving_broker/proving_broker.d.ts +2 -2
- package/dest/proving_broker/proving_broker.d.ts.map +1 -1
- package/dest/proving_broker/proving_broker.js +31 -19
- package/dest/proving_broker/proving_broker_database/memory.d.ts +3 -2
- package/dest/proving_broker/proving_broker_database/memory.d.ts.map +1 -1
- package/dest/proving_broker/proving_broker_database/persisted.d.ts +3 -2
- package/dest/proving_broker/proving_broker_database/persisted.d.ts.map +1 -1
- package/dest/proving_broker/proving_broker_database/persisted.js +8 -7
- package/dest/proving_broker/proving_broker_database.d.ts +3 -2
- package/dest/proving_broker/proving_broker_database.d.ts.map +1 -1
- package/dest/proving_broker/proving_broker_instrumentation.d.ts +1 -1
- package/dest/proving_broker/proving_broker_instrumentation.d.ts.map +1 -1
- package/dest/proving_broker/proving_job_controller.d.ts +3 -2
- package/dest/proving_broker/proving_job_controller.d.ts.map +1 -1
- package/dest/proving_broker/proving_job_controller.js +39 -19
- package/dest/proving_broker/rpc.d.ts +4 -4
- package/dest/test/mock_proof_store.d.ts +3 -3
- package/dest/test/mock_proof_store.d.ts.map +1 -1
- package/dest/test/mock_prover.d.ts +23 -19
- package/dest/test/mock_prover.d.ts.map +1 -1
- package/dest/test/mock_prover.js +35 -20
- package/package.json +19 -19
- package/src/block-factory/light.ts +40 -17
- package/src/config.ts +1 -1
- package/src/light/lightweight_checkpoint_builder.ts +144 -0
- package/src/mocks/fixtures.ts +41 -36
- package/src/mocks/test_context.ts +188 -114
- package/src/orchestrator/block-building-helpers.ts +233 -313
- package/src/orchestrator/block-proving-state.ts +315 -247
- package/src/orchestrator/checkpoint-proving-state.ts +303 -0
- package/src/orchestrator/epoch-proving-state.ts +176 -129
- package/src/orchestrator/orchestrator.ts +554 -319
- package/src/orchestrator/tx-proving-state.ts +48 -55
- package/src/prover-client/server-epoch-prover.ts +30 -21
- package/src/proving_broker/broker_prover_facade.ts +175 -103
- package/src/proving_broker/config.ts +15 -8
- package/src/proving_broker/factory.ts +1 -1
- package/src/proving_broker/fixtures.ts +8 -3
- package/src/proving_broker/proof_store/index.ts +1 -0
- package/src/proving_broker/proving_broker.ts +38 -19
- package/src/proving_broker/proving_broker_database/memory.ts +2 -1
- package/src/proving_broker/proving_broker_database/persisted.ts +10 -9
- package/src/proving_broker/proving_broker_database.ts +2 -1
- package/src/proving_broker/proving_job_controller.ts +41 -20
- package/src/test/mock_prover.ts +142 -60
- package/dest/bin/get-proof-inputs.d.ts +0 -2
- package/dest/bin/get-proof-inputs.d.ts.map +0 -1
- package/dest/bin/get-proof-inputs.js +0 -51
- package/src/bin/get-proof-inputs.ts +0 -59
|
@@ -1,28 +1,26 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
PRIVATE_TUBE_VK_INDEX,
|
|
5
|
-
PUBLIC_TUBE_VK_INDEX,
|
|
6
|
-
type TUBE_PROOF_LENGTH,
|
|
7
|
-
} from '@aztec/constants';
|
|
8
|
-
import { getVKSiblingPath } from '@aztec/noir-protocol-circuits-types/vk-tree';
|
|
1
|
+
import { AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED, NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH } from '@aztec/constants';
|
|
2
|
+
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
|
+
import { getAvmVkData, getVkData } from '@aztec/noir-protocol-circuits-types/server/vks';
|
|
9
4
|
import type { AvmCircuitInputs } from '@aztec/stdlib/avm';
|
|
10
|
-
import type { ProofAndVerificationKey } from '@aztec/stdlib/interfaces/server';
|
|
5
|
+
import type { ProofAndVerificationKey, PublicInputsAndRecursiveProof } from '@aztec/stdlib/interfaces/server';
|
|
6
|
+
import { ProofData } from '@aztec/stdlib/proofs';
|
|
11
7
|
import {
|
|
12
|
-
AvmProofData,
|
|
13
8
|
type BaseRollupHints,
|
|
14
9
|
PrivateBaseRollupHints,
|
|
15
|
-
|
|
16
|
-
PrivateTubeData,
|
|
10
|
+
PrivateTxBaseRollupPrivateInputs,
|
|
17
11
|
PublicBaseRollupHints,
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
TubeInputs,
|
|
12
|
+
PublicChonkVerifierPublicInputs,
|
|
13
|
+
PublicTxBaseRollupPrivateInputs,
|
|
21
14
|
} from '@aztec/stdlib/rollup';
|
|
22
15
|
import type { CircuitName } from '@aztec/stdlib/stats';
|
|
23
16
|
import type { AppendOnlyTreeSnapshot, MerkleTreeId } from '@aztec/stdlib/trees';
|
|
24
17
|
import type { ProcessedTx } from '@aztec/stdlib/tx';
|
|
25
|
-
|
|
18
|
+
|
|
19
|
+
import {
|
|
20
|
+
getChonkProofFromTx,
|
|
21
|
+
getPublicChonkVerifierPrivateInputsFromTx,
|
|
22
|
+
toProofData,
|
|
23
|
+
} from './block-building-helpers.js';
|
|
26
24
|
|
|
27
25
|
/**
|
|
28
26
|
* Helper class to manage the proving cycle of a transaction
|
|
@@ -30,13 +28,17 @@ import { VerificationKeyData, VkData } from '@aztec/stdlib/vks';
|
|
|
30
28
|
* Also stores the inputs to the base rollup for this transaction and the tree snapshots
|
|
31
29
|
*/
|
|
32
30
|
export class TxProvingState {
|
|
33
|
-
private
|
|
31
|
+
private publicChonkVerifier?: PublicInputsAndRecursiveProof<
|
|
32
|
+
PublicChonkVerifierPublicInputs,
|
|
33
|
+
typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH
|
|
34
|
+
>;
|
|
34
35
|
private avm?: ProofAndVerificationKey<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>;
|
|
35
36
|
|
|
36
37
|
constructor(
|
|
37
38
|
public readonly processedTx: ProcessedTx,
|
|
38
39
|
private readonly baseRollupHints: BaseRollupHints,
|
|
39
40
|
public readonly treeSnapshots: Map<MerkleTreeId, AppendOnlyTreeSnapshot>,
|
|
41
|
+
private readonly proverId: Fr,
|
|
40
42
|
) {}
|
|
41
43
|
|
|
42
44
|
get requireAvmProof() {
|
|
@@ -44,33 +46,38 @@ export class TxProvingState {
|
|
|
44
46
|
}
|
|
45
47
|
|
|
46
48
|
public ready() {
|
|
47
|
-
return
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
public getTubeInputs() {
|
|
51
|
-
return new TubeInputs(!!this.processedTx.data.forPublic, this.processedTx.clientIvcProof);
|
|
49
|
+
return !this.requireAvmProof || (!!this.avm && !!this.publicChonkVerifier);
|
|
52
50
|
}
|
|
53
51
|
|
|
54
52
|
public getAvmInputs(): AvmCircuitInputs {
|
|
55
53
|
return this.processedTx.avmProvingRequest!.inputs;
|
|
56
54
|
}
|
|
57
55
|
|
|
56
|
+
public getPublicChonkVerifierPrivateInputs() {
|
|
57
|
+
return getPublicChonkVerifierPrivateInputsFromTx(this.processedTx, this.proverId);
|
|
58
|
+
}
|
|
59
|
+
|
|
58
60
|
public getBaseRollupTypeAndInputs() {
|
|
59
61
|
if (this.requireAvmProof) {
|
|
60
62
|
return {
|
|
61
|
-
rollupType: '
|
|
63
|
+
rollupType: 'rollup-tx-base-public' satisfies CircuitName,
|
|
62
64
|
inputs: this.#getPublicBaseInputs(),
|
|
63
65
|
};
|
|
64
66
|
} else {
|
|
65
67
|
return {
|
|
66
|
-
rollupType: '
|
|
68
|
+
rollupType: 'rollup-tx-base-private' satisfies CircuitName,
|
|
67
69
|
inputs: this.#getPrivateBaseInputs(),
|
|
68
70
|
};
|
|
69
71
|
}
|
|
70
72
|
}
|
|
71
73
|
|
|
72
|
-
public
|
|
73
|
-
|
|
74
|
+
public setPublicChonkVerifierProof(
|
|
75
|
+
publicChonkVerifierProofAndVk: PublicInputsAndRecursiveProof<
|
|
76
|
+
PublicChonkVerifierPublicInputs,
|
|
77
|
+
typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH
|
|
78
|
+
>,
|
|
79
|
+
) {
|
|
80
|
+
this.publicChonkVerifier = publicChonkVerifierProofAndVk;
|
|
74
81
|
}
|
|
75
82
|
|
|
76
83
|
public setAvmProof(avmProofAndVk: ProofAndVerificationKey<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>) {
|
|
@@ -78,55 +85,41 @@ export class TxProvingState {
|
|
|
78
85
|
}
|
|
79
86
|
|
|
80
87
|
#getPrivateBaseInputs() {
|
|
81
|
-
if (!this.
|
|
82
|
-
throw new Error('
|
|
88
|
+
if (!(this.baseRollupHints instanceof PrivateBaseRollupHints)) {
|
|
89
|
+
throw new Error('Mismatched base rollup hints, expected private base rollup hints');
|
|
83
90
|
}
|
|
84
91
|
|
|
85
|
-
const
|
|
86
|
-
const tubeData = new PrivateTubeData(
|
|
92
|
+
const privateTailProofData = new ProofData(
|
|
87
93
|
this.processedTx.data.toPrivateToRollupKernelCircuitPublicInputs(),
|
|
88
|
-
this.
|
|
89
|
-
|
|
94
|
+
getChonkProofFromTx(this.processedTx),
|
|
95
|
+
getVkData('HidingKernelToRollup'),
|
|
90
96
|
);
|
|
91
97
|
|
|
92
|
-
|
|
93
|
-
throw new Error('Mismatched base rollup hints, expected private base rollup hints');
|
|
94
|
-
}
|
|
95
|
-
return new PrivateBaseRollupInputs(tubeData, this.baseRollupHints);
|
|
98
|
+
return new PrivateTxBaseRollupPrivateInputs(privateTailProofData, this.baseRollupHints);
|
|
96
99
|
}
|
|
97
100
|
|
|
98
101
|
#getPublicBaseInputs() {
|
|
99
102
|
if (!this.processedTx.avmProvingRequest) {
|
|
100
103
|
throw new Error('Should create private base rollup for a tx not requiring avm proof.');
|
|
101
104
|
}
|
|
102
|
-
if (!this.
|
|
103
|
-
throw new Error('Tx not ready for proving base rollup:
|
|
105
|
+
if (!this.publicChonkVerifier) {
|
|
106
|
+
throw new Error('Tx not ready for proving base rollup: public chonk verifier proof undefined');
|
|
104
107
|
}
|
|
105
108
|
if (!this.avm) {
|
|
106
109
|
throw new Error('Tx not ready for proving base rollup: avm proof undefined');
|
|
107
110
|
}
|
|
111
|
+
if (!(this.baseRollupHints instanceof PublicBaseRollupHints)) {
|
|
112
|
+
throw new Error('Mismatched base rollup hints, expected public base rollup hints');
|
|
113
|
+
}
|
|
108
114
|
|
|
109
|
-
const
|
|
110
|
-
this.processedTx.data.toPrivateToPublicKernelCircuitPublicInputs(),
|
|
111
|
-
this.tube.proof,
|
|
112
|
-
this.#getVkData(this.tube!.verificationKey, PUBLIC_TUBE_VK_INDEX),
|
|
113
|
-
);
|
|
115
|
+
const publicChonkVerifierProofData = toProofData(this.publicChonkVerifier);
|
|
114
116
|
|
|
115
|
-
const avmProofData = new
|
|
117
|
+
const avmProofData = new ProofData(
|
|
116
118
|
this.processedTx.avmProvingRequest.inputs.publicInputs,
|
|
117
119
|
this.avm.proof,
|
|
118
|
-
|
|
120
|
+
getAvmVkData(),
|
|
119
121
|
);
|
|
120
122
|
|
|
121
|
-
|
|
122
|
-
throw new Error('Mismatched base rollup hints, expected public base rollup hints');
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
return new PublicBaseRollupInputs(tubeData, avmProofData, this.baseRollupHints);
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
#getVkData(verificationKey: VerificationKeyData, vkIndex: number) {
|
|
129
|
-
const vkPath = getVKSiblingPath(vkIndex);
|
|
130
|
-
return new VkData(verificationKey, vkIndex, vkPath);
|
|
123
|
+
return new PublicTxBaseRollupPrivateInputs(publicChonkVerifierProofData, avmProofData, this.baseRollupHints);
|
|
131
124
|
}
|
|
132
125
|
}
|
|
@@ -1,10 +1,12 @@
|
|
|
1
|
-
import type { BatchedBlob, FinalBlobBatchingChallenges } from '@aztec/blob-lib';
|
|
2
|
-
import
|
|
3
|
-
import type {
|
|
1
|
+
import type { BatchedBlob, FinalBlobBatchingChallenges } from '@aztec/blob-lib/types';
|
|
2
|
+
import { BlockNumber, EpochNumber } from '@aztec/foundation/branded-types';
|
|
3
|
+
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
|
+
import type { EthAddress } from '@aztec/stdlib/block';
|
|
4
5
|
import type { EpochProver } from '@aztec/stdlib/interfaces/server';
|
|
5
6
|
import type { Proof } from '@aztec/stdlib/proofs';
|
|
6
|
-
import type { RootRollupPublicInputs } from '@aztec/stdlib/rollup';
|
|
7
|
-
import type { BlockHeader,
|
|
7
|
+
import type { CheckpointConstantData, RootRollupPublicInputs } from '@aztec/stdlib/rollup';
|
|
8
|
+
import type { BlockHeader, ProcessedTx, Tx } from '@aztec/stdlib/tx';
|
|
9
|
+
import type { UInt64 } from '@aztec/stdlib/types';
|
|
8
10
|
|
|
9
11
|
import type { ProvingOrchestrator } from '../orchestrator/orchestrator.js';
|
|
10
12
|
import type { BrokerCircuitProverFacade } from '../proving_broker/broker_prover_facade.js';
|
|
@@ -17,18 +19,32 @@ export class ServerEpochProver implements EpochProver {
|
|
|
17
19
|
) {}
|
|
18
20
|
|
|
19
21
|
startNewEpoch(
|
|
20
|
-
epochNumber:
|
|
21
|
-
|
|
22
|
-
totalNumBlocks: number,
|
|
22
|
+
epochNumber: EpochNumber,
|
|
23
|
+
totalNumCheckpoints: number,
|
|
23
24
|
finalBlobBatchingChallenges: FinalBlobBatchingChallenges,
|
|
24
25
|
): void {
|
|
25
|
-
this.orchestrator.startNewEpoch(epochNumber,
|
|
26
|
+
this.orchestrator.startNewEpoch(epochNumber, totalNumCheckpoints, finalBlobBatchingChallenges);
|
|
26
27
|
this.facade.start();
|
|
27
28
|
}
|
|
28
|
-
|
|
29
|
-
|
|
29
|
+
startNewCheckpoint(
|
|
30
|
+
checkpointIndex: number,
|
|
31
|
+
constants: CheckpointConstantData,
|
|
32
|
+
l1ToL2Messages: Fr[],
|
|
33
|
+
totalNumBlocks: number,
|
|
34
|
+
headerOfLastBlockInPreviousCheckpoint: BlockHeader,
|
|
35
|
+
): Promise<void> {
|
|
36
|
+
return this.orchestrator.startNewCheckpoint(
|
|
37
|
+
checkpointIndex,
|
|
38
|
+
constants,
|
|
39
|
+
l1ToL2Messages,
|
|
40
|
+
totalNumBlocks,
|
|
41
|
+
headerOfLastBlockInPreviousCheckpoint,
|
|
42
|
+
);
|
|
43
|
+
}
|
|
44
|
+
startChonkVerifierCircuits(txs: Tx[]): Promise<void> {
|
|
45
|
+
return this.orchestrator.startChonkVerifierCircuits(txs);
|
|
30
46
|
}
|
|
31
|
-
setBlockCompleted(blockNumber:
|
|
47
|
+
setBlockCompleted(blockNumber: BlockNumber, expectedBlockHeader?: BlockHeader): Promise<BlockHeader> {
|
|
32
48
|
return this.orchestrator.setBlockCompleted(blockNumber, expectedBlockHeader);
|
|
33
49
|
}
|
|
34
50
|
finalizeEpoch(): Promise<{ publicInputs: RootRollupPublicInputs; proof: Proof; batchedBlobInputs: BatchedBlob }> {
|
|
@@ -40,19 +56,12 @@ export class ServerEpochProver implements EpochProver {
|
|
|
40
56
|
getProverId(): EthAddress {
|
|
41
57
|
return this.orchestrator.getProverId();
|
|
42
58
|
}
|
|
43
|
-
getBlock(index: number): L2Block {
|
|
44
|
-
return this.orchestrator.getBlock(index);
|
|
45
|
-
}
|
|
46
59
|
async stop(): Promise<void> {
|
|
47
60
|
await this.facade.stop();
|
|
48
61
|
await this.orchestrator.stop();
|
|
49
62
|
}
|
|
50
|
-
startNewBlock(
|
|
51
|
-
|
|
52
|
-
l1ToL2Messages: Fr[],
|
|
53
|
-
previousBlockHeader: BlockHeader,
|
|
54
|
-
): Promise<void> {
|
|
55
|
-
return this.orchestrator.startNewBlock(globalVariables, l1ToL2Messages, previousBlockHeader);
|
|
63
|
+
startNewBlock(blockNumber: BlockNumber, timestamp: UInt64, totalNumTxs: number): Promise<void> {
|
|
64
|
+
return this.orchestrator.startNewBlock(blockNumber, timestamp, totalNumTxs);
|
|
56
65
|
}
|
|
57
66
|
addTxs(txs: ProcessedTx[]): Promise<void> {
|
|
58
67
|
return this.orchestrator.addTxs(txs);
|
|
@@ -3,10 +3,10 @@ import type {
|
|
|
3
3
|
NESTED_RECURSIVE_PROOF_LENGTH,
|
|
4
4
|
NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH,
|
|
5
5
|
RECURSIVE_PROOF_LENGTH,
|
|
6
|
-
TUBE_PROOF_LENGTH,
|
|
7
6
|
} from '@aztec/constants';
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
7
|
+
import { EpochNumber } from '@aztec/foundation/branded-types';
|
|
8
|
+
import { sha256 } from '@aztec/foundation/crypto/sha256';
|
|
9
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
10
10
|
import { createLogger } from '@aztec/foundation/log';
|
|
11
11
|
import { type PromiseWithResolvers, RunningPromise, promiseWithResolvers } from '@aztec/foundation/promise';
|
|
12
12
|
import { truncate } from '@aztec/foundation/string';
|
|
@@ -23,22 +23,29 @@ import {
|
|
|
23
23
|
type ServerCircuitProver,
|
|
24
24
|
makeProvingJobId,
|
|
25
25
|
} from '@aztec/stdlib/interfaces/server';
|
|
26
|
-
import type {
|
|
26
|
+
import type { ParityBasePrivateInputs, ParityPublicInputs, ParityRootPrivateInputs } from '@aztec/stdlib/parity';
|
|
27
27
|
import { ProvingRequestType } from '@aztec/stdlib/proofs';
|
|
28
28
|
import type {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
29
|
+
BlockMergeRollupPrivateInputs,
|
|
30
|
+
BlockRollupPublicInputs,
|
|
31
|
+
BlockRootEmptyTxFirstRollupPrivateInputs,
|
|
32
|
+
BlockRootFirstRollupPrivateInputs,
|
|
33
|
+
BlockRootRollupPrivateInputs,
|
|
34
|
+
BlockRootSingleTxFirstRollupPrivateInputs,
|
|
35
|
+
BlockRootSingleTxRollupPrivateInputs,
|
|
36
|
+
CheckpointMergeRollupPrivateInputs,
|
|
37
|
+
CheckpointPaddingRollupPrivateInputs,
|
|
38
|
+
CheckpointRollupPublicInputs,
|
|
39
|
+
CheckpointRootRollupPrivateInputs,
|
|
40
|
+
CheckpointRootSingleBlockRollupPrivateInputs,
|
|
41
|
+
PrivateTxBaseRollupPrivateInputs,
|
|
42
|
+
PublicChonkVerifierPrivateInputs,
|
|
43
|
+
PublicChonkVerifierPublicInputs,
|
|
44
|
+
PublicTxBaseRollupPrivateInputs,
|
|
45
|
+
RootRollupPrivateInputs,
|
|
39
46
|
RootRollupPublicInputs,
|
|
40
|
-
|
|
41
|
-
|
|
47
|
+
TxMergeRollupPrivateInputs,
|
|
48
|
+
TxRollupPublicInputs,
|
|
42
49
|
} from '@aztec/stdlib/rollup';
|
|
43
50
|
|
|
44
51
|
import { InlineProofStore, type ProofStore } from './proof_store/index.js';
|
|
@@ -124,7 +131,7 @@ export class BrokerCircuitProverFacade implements ServerCircuitProver {
|
|
|
124
131
|
id: ProvingJobId,
|
|
125
132
|
type: T,
|
|
126
133
|
inputs: ProvingJobInputsMap[T],
|
|
127
|
-
epochNumber =
|
|
134
|
+
epochNumber = EpochNumber.ZERO,
|
|
128
135
|
signal?: AbortSignal,
|
|
129
136
|
): Promise<ProvingJobResultsMap[T]> {
|
|
130
137
|
const { job: job, isEnqueued } = this.getOrCreateProvingJob(id, type, signal);
|
|
@@ -393,7 +400,7 @@ export class BrokerCircuitProverFacade implements ServerCircuitProver {
|
|
|
393
400
|
inputs: AvmCircuitInputs,
|
|
394
401
|
skipPublicInputsValidation?: boolean, // TODO(#14234)[Unconditional PIs validation]: remove this argument
|
|
395
402
|
signal?: AbortSignal,
|
|
396
|
-
epochNumber?:
|
|
403
|
+
epochNumber?: EpochNumber,
|
|
397
404
|
): Promise<ProofAndVerificationKey<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>> {
|
|
398
405
|
this.log.info(`getAvmProof() called with skipPublicInputsValidation: ${skipPublicInputsValidation}`);
|
|
399
406
|
|
|
@@ -412,189 +419,254 @@ export class BrokerCircuitProverFacade implements ServerCircuitProver {
|
|
|
412
419
|
}
|
|
413
420
|
|
|
414
421
|
getBaseParityProof(
|
|
415
|
-
inputs:
|
|
422
|
+
inputs: ParityBasePrivateInputs,
|
|
416
423
|
signal?: AbortSignal,
|
|
417
|
-
epochNumber?:
|
|
424
|
+
epochNumber?: EpochNumber,
|
|
418
425
|
): Promise<PublicInputsAndRecursiveProof<ParityPublicInputs, typeof RECURSIVE_PROOF_LENGTH>> {
|
|
419
426
|
return this.enqueueJob(
|
|
420
|
-
this.generateId(ProvingRequestType.
|
|
421
|
-
ProvingRequestType.
|
|
427
|
+
this.generateId(ProvingRequestType.PARITY_BASE, inputs, epochNumber),
|
|
428
|
+
ProvingRequestType.PARITY_BASE,
|
|
422
429
|
inputs,
|
|
423
430
|
epochNumber,
|
|
424
431
|
signal,
|
|
425
432
|
);
|
|
426
433
|
}
|
|
427
434
|
|
|
428
|
-
|
|
429
|
-
input:
|
|
435
|
+
getTxMergeRollupProof(
|
|
436
|
+
input: TxMergeRollupPrivateInputs,
|
|
430
437
|
signal?: AbortSignal,
|
|
431
|
-
epochNumber?:
|
|
432
|
-
): Promise<
|
|
433
|
-
PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
434
|
-
> {
|
|
438
|
+
epochNumber?: EpochNumber,
|
|
439
|
+
): Promise<PublicInputsAndRecursiveProof<TxRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
435
440
|
return this.enqueueJob(
|
|
436
|
-
this.generateId(ProvingRequestType.
|
|
437
|
-
ProvingRequestType.
|
|
441
|
+
this.generateId(ProvingRequestType.TX_MERGE_ROLLUP, input, epochNumber),
|
|
442
|
+
ProvingRequestType.TX_MERGE_ROLLUP,
|
|
438
443
|
input,
|
|
439
444
|
epochNumber,
|
|
440
445
|
signal,
|
|
441
446
|
);
|
|
442
447
|
}
|
|
443
448
|
|
|
444
|
-
|
|
445
|
-
|
|
449
|
+
getPublicChonkVerifierProof(
|
|
450
|
+
inputs: PublicChonkVerifierPrivateInputs,
|
|
446
451
|
signal?: AbortSignal,
|
|
447
|
-
epochNumber?:
|
|
452
|
+
epochNumber?: EpochNumber,
|
|
448
453
|
): Promise<
|
|
449
|
-
PublicInputsAndRecursiveProof<
|
|
454
|
+
PublicInputsAndRecursiveProof<PublicChonkVerifierPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
450
455
|
> {
|
|
451
456
|
return this.enqueueJob(
|
|
452
|
-
this.generateId(ProvingRequestType.
|
|
453
|
-
ProvingRequestType.
|
|
457
|
+
this.generateId(ProvingRequestType.PUBLIC_CHONK_VERIFIER, inputs, epochNumber),
|
|
458
|
+
ProvingRequestType.PUBLIC_CHONK_VERIFIER,
|
|
459
|
+
inputs,
|
|
460
|
+
epochNumber,
|
|
461
|
+
signal,
|
|
462
|
+
);
|
|
463
|
+
}
|
|
464
|
+
|
|
465
|
+
getPrivateTxBaseRollupProof(
|
|
466
|
+
baseRollupInput: PrivateTxBaseRollupPrivateInputs,
|
|
467
|
+
signal?: AbortSignal,
|
|
468
|
+
epochNumber?: EpochNumber,
|
|
469
|
+
): Promise<PublicInputsAndRecursiveProof<TxRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
470
|
+
return this.enqueueJob(
|
|
471
|
+
this.generateId(ProvingRequestType.PRIVATE_TX_BASE_ROLLUP, baseRollupInput, epochNumber),
|
|
472
|
+
ProvingRequestType.PRIVATE_TX_BASE_ROLLUP,
|
|
473
|
+
baseRollupInput,
|
|
474
|
+
epochNumber,
|
|
475
|
+
signal,
|
|
476
|
+
);
|
|
477
|
+
}
|
|
478
|
+
|
|
479
|
+
getPublicTxBaseRollupProof(
|
|
480
|
+
inputs: PublicTxBaseRollupPrivateInputs,
|
|
481
|
+
signal?: AbortSignal,
|
|
482
|
+
epochNumber?: EpochNumber,
|
|
483
|
+
): Promise<PublicInputsAndRecursiveProof<TxRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
484
|
+
return this.enqueueJob(
|
|
485
|
+
this.generateId(ProvingRequestType.PUBLIC_TX_BASE_ROLLUP, inputs, epochNumber),
|
|
486
|
+
ProvingRequestType.PUBLIC_TX_BASE_ROLLUP,
|
|
487
|
+
inputs,
|
|
488
|
+
epochNumber,
|
|
489
|
+
signal,
|
|
490
|
+
);
|
|
491
|
+
}
|
|
492
|
+
|
|
493
|
+
getRootParityProof(
|
|
494
|
+
inputs: ParityRootPrivateInputs,
|
|
495
|
+
signal?: AbortSignal,
|
|
496
|
+
epochNumber?: EpochNumber,
|
|
497
|
+
): Promise<PublicInputsAndRecursiveProof<ParityPublicInputs, typeof NESTED_RECURSIVE_PROOF_LENGTH>> {
|
|
498
|
+
return this.enqueueJob(
|
|
499
|
+
this.generateId(ProvingRequestType.PARITY_ROOT, inputs, epochNumber),
|
|
500
|
+
ProvingRequestType.PARITY_ROOT,
|
|
501
|
+
inputs,
|
|
502
|
+
epochNumber,
|
|
503
|
+
signal,
|
|
504
|
+
);
|
|
505
|
+
}
|
|
506
|
+
|
|
507
|
+
getBlockRootFirstRollupProof(
|
|
508
|
+
input: BlockRootFirstRollupPrivateInputs,
|
|
509
|
+
signal?: AbortSignal,
|
|
510
|
+
epochNumber?: EpochNumber,
|
|
511
|
+
): Promise<PublicInputsAndRecursiveProof<BlockRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
512
|
+
return this.enqueueJob(
|
|
513
|
+
this.generateId(ProvingRequestType.BLOCK_ROOT_FIRST_ROLLUP, input, epochNumber),
|
|
514
|
+
ProvingRequestType.BLOCK_ROOT_FIRST_ROLLUP,
|
|
454
515
|
input,
|
|
455
516
|
epochNumber,
|
|
456
517
|
signal,
|
|
457
518
|
);
|
|
458
519
|
}
|
|
459
520
|
|
|
460
|
-
|
|
461
|
-
input:
|
|
521
|
+
getBlockRootSingleTxFirstRollupProof(
|
|
522
|
+
input: BlockRootSingleTxFirstRollupPrivateInputs,
|
|
462
523
|
signal?: AbortSignal,
|
|
463
|
-
epochNumber?:
|
|
464
|
-
): Promise<
|
|
465
|
-
PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
466
|
-
> {
|
|
524
|
+
epochNumber?: EpochNumber,
|
|
525
|
+
): Promise<PublicInputsAndRecursiveProof<BlockRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
467
526
|
return this.enqueueJob(
|
|
468
|
-
this.generateId(ProvingRequestType.
|
|
469
|
-
ProvingRequestType.
|
|
527
|
+
this.generateId(ProvingRequestType.BLOCK_ROOT_SINGLE_TX_FIRST_ROLLUP, input, epochNumber),
|
|
528
|
+
ProvingRequestType.BLOCK_ROOT_SINGLE_TX_FIRST_ROLLUP,
|
|
470
529
|
input,
|
|
471
530
|
epochNumber,
|
|
472
531
|
signal,
|
|
473
532
|
);
|
|
474
533
|
}
|
|
475
534
|
|
|
476
|
-
|
|
477
|
-
input:
|
|
535
|
+
getBlockRootEmptyTxFirstRollupProof(
|
|
536
|
+
input: BlockRootEmptyTxFirstRollupPrivateInputs,
|
|
478
537
|
signal?: AbortSignal,
|
|
479
|
-
epochNumber?:
|
|
480
|
-
): Promise<
|
|
481
|
-
PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
482
|
-
> {
|
|
538
|
+
epochNumber?: EpochNumber,
|
|
539
|
+
): Promise<PublicInputsAndRecursiveProof<BlockRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
483
540
|
return this.enqueueJob(
|
|
484
|
-
this.generateId(ProvingRequestType.
|
|
485
|
-
ProvingRequestType.
|
|
541
|
+
this.generateId(ProvingRequestType.BLOCK_ROOT_EMPTY_TX_FIRST_ROLLUP, input, epochNumber),
|
|
542
|
+
ProvingRequestType.BLOCK_ROOT_EMPTY_TX_FIRST_ROLLUP,
|
|
486
543
|
input,
|
|
487
544
|
epochNumber,
|
|
488
545
|
signal,
|
|
489
546
|
);
|
|
490
547
|
}
|
|
491
548
|
|
|
492
|
-
|
|
493
|
-
input:
|
|
549
|
+
getBlockRootRollupProof(
|
|
550
|
+
input: BlockRootRollupPrivateInputs,
|
|
494
551
|
signal?: AbortSignal,
|
|
495
|
-
epochNumber?:
|
|
496
|
-
): Promise<
|
|
497
|
-
PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
498
|
-
> {
|
|
552
|
+
epochNumber?: EpochNumber,
|
|
553
|
+
): Promise<PublicInputsAndRecursiveProof<BlockRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
499
554
|
return this.enqueueJob(
|
|
500
|
-
this.generateId(ProvingRequestType.
|
|
501
|
-
ProvingRequestType.
|
|
555
|
+
this.generateId(ProvingRequestType.BLOCK_ROOT_ROLLUP, input, epochNumber),
|
|
556
|
+
ProvingRequestType.BLOCK_ROOT_ROLLUP,
|
|
502
557
|
input,
|
|
503
558
|
epochNumber,
|
|
504
559
|
signal,
|
|
505
560
|
);
|
|
506
561
|
}
|
|
507
562
|
|
|
508
|
-
|
|
509
|
-
input:
|
|
563
|
+
getBlockRootSingleTxRollupProof(
|
|
564
|
+
input: BlockRootSingleTxRollupPrivateInputs,
|
|
510
565
|
signal?: AbortSignal,
|
|
511
|
-
epochNumber?:
|
|
512
|
-
): Promise<
|
|
513
|
-
|
|
514
|
-
|
|
566
|
+
epochNumber?: EpochNumber,
|
|
567
|
+
): Promise<PublicInputsAndRecursiveProof<BlockRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
568
|
+
return this.enqueueJob(
|
|
569
|
+
this.generateId(ProvingRequestType.BLOCK_ROOT_SINGLE_TX_ROLLUP, input, epochNumber),
|
|
570
|
+
ProvingRequestType.BLOCK_ROOT_SINGLE_TX_ROLLUP,
|
|
571
|
+
input,
|
|
572
|
+
epochNumber,
|
|
573
|
+
signal,
|
|
574
|
+
);
|
|
575
|
+
}
|
|
576
|
+
|
|
577
|
+
getBlockMergeRollupProof(
|
|
578
|
+
input: BlockMergeRollupPrivateInputs,
|
|
579
|
+
signal?: AbortSignal,
|
|
580
|
+
epochNumber?: EpochNumber,
|
|
581
|
+
): Promise<PublicInputsAndRecursiveProof<BlockRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>> {
|
|
515
582
|
return this.enqueueJob(
|
|
516
|
-
this.generateId(ProvingRequestType.
|
|
517
|
-
ProvingRequestType.
|
|
583
|
+
this.generateId(ProvingRequestType.BLOCK_MERGE_ROLLUP, input, epochNumber),
|
|
584
|
+
ProvingRequestType.BLOCK_MERGE_ROLLUP,
|
|
518
585
|
input,
|
|
519
586
|
epochNumber,
|
|
520
587
|
signal,
|
|
521
588
|
);
|
|
522
589
|
}
|
|
523
|
-
|
|
524
|
-
|
|
590
|
+
|
|
591
|
+
getCheckpointRootRollupProof(
|
|
592
|
+
input: CheckpointRootRollupPrivateInputs,
|
|
525
593
|
signal?: AbortSignal,
|
|
526
|
-
epochNumber?:
|
|
594
|
+
epochNumber?: EpochNumber,
|
|
527
595
|
): Promise<
|
|
528
|
-
PublicInputsAndRecursiveProof<
|
|
596
|
+
PublicInputsAndRecursiveProof<CheckpointRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
529
597
|
> {
|
|
530
598
|
return this.enqueueJob(
|
|
531
|
-
this.generateId(ProvingRequestType.
|
|
532
|
-
ProvingRequestType.
|
|
533
|
-
|
|
599
|
+
this.generateId(ProvingRequestType.CHECKPOINT_ROOT_ROLLUP, input, epochNumber),
|
|
600
|
+
ProvingRequestType.CHECKPOINT_ROOT_ROLLUP,
|
|
601
|
+
input,
|
|
534
602
|
epochNumber,
|
|
535
603
|
signal,
|
|
536
604
|
);
|
|
537
605
|
}
|
|
538
606
|
|
|
539
|
-
|
|
540
|
-
|
|
607
|
+
getCheckpointRootSingleBlockRollupProof(
|
|
608
|
+
input: CheckpointRootSingleBlockRollupPrivateInputs,
|
|
541
609
|
signal?: AbortSignal,
|
|
542
|
-
epochNumber?:
|
|
610
|
+
epochNumber?: EpochNumber,
|
|
543
611
|
): Promise<
|
|
544
|
-
PublicInputsAndRecursiveProof<
|
|
612
|
+
PublicInputsAndRecursiveProof<CheckpointRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
545
613
|
> {
|
|
546
614
|
return this.enqueueJob(
|
|
547
|
-
this.generateId(ProvingRequestType.
|
|
548
|
-
ProvingRequestType.
|
|
549
|
-
|
|
615
|
+
this.generateId(ProvingRequestType.CHECKPOINT_ROOT_SINGLE_BLOCK_ROLLUP, input, epochNumber),
|
|
616
|
+
ProvingRequestType.CHECKPOINT_ROOT_SINGLE_BLOCK_ROLLUP,
|
|
617
|
+
input,
|
|
550
618
|
epochNumber,
|
|
551
619
|
signal,
|
|
552
620
|
);
|
|
553
621
|
}
|
|
554
622
|
|
|
555
|
-
|
|
556
|
-
|
|
623
|
+
getCheckpointPaddingRollupProof(
|
|
624
|
+
input: CheckpointPaddingRollupPrivateInputs,
|
|
557
625
|
signal?: AbortSignal,
|
|
558
|
-
epochNumber?:
|
|
559
|
-
): Promise<
|
|
626
|
+
epochNumber?: EpochNumber,
|
|
627
|
+
): Promise<
|
|
628
|
+
PublicInputsAndRecursiveProof<CheckpointRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
629
|
+
> {
|
|
560
630
|
return this.enqueueJob(
|
|
561
|
-
this.generateId(ProvingRequestType.
|
|
562
|
-
ProvingRequestType.
|
|
563
|
-
|
|
631
|
+
this.generateId(ProvingRequestType.CHECKPOINT_PADDING_ROLLUP, input, epochNumber),
|
|
632
|
+
ProvingRequestType.CHECKPOINT_PADDING_ROLLUP,
|
|
633
|
+
input,
|
|
564
634
|
epochNumber,
|
|
565
635
|
signal,
|
|
566
636
|
);
|
|
567
637
|
}
|
|
568
638
|
|
|
569
|
-
|
|
570
|
-
input:
|
|
639
|
+
getCheckpointMergeRollupProof(
|
|
640
|
+
input: CheckpointMergeRollupPrivateInputs,
|
|
571
641
|
signal?: AbortSignal,
|
|
572
|
-
epochNumber?:
|
|
573
|
-
): Promise<
|
|
642
|
+
epochNumber?: EpochNumber,
|
|
643
|
+
): Promise<
|
|
644
|
+
PublicInputsAndRecursiveProof<CheckpointRollupPublicInputs, typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH>
|
|
645
|
+
> {
|
|
574
646
|
return this.enqueueJob(
|
|
575
|
-
this.generateId(ProvingRequestType.
|
|
576
|
-
ProvingRequestType.
|
|
647
|
+
this.generateId(ProvingRequestType.CHECKPOINT_MERGE_ROLLUP, input, epochNumber),
|
|
648
|
+
ProvingRequestType.CHECKPOINT_MERGE_ROLLUP,
|
|
577
649
|
input,
|
|
578
650
|
epochNumber,
|
|
579
651
|
signal,
|
|
580
652
|
);
|
|
581
653
|
}
|
|
582
654
|
|
|
583
|
-
|
|
584
|
-
|
|
655
|
+
getRootRollupProof(
|
|
656
|
+
input: RootRollupPrivateInputs,
|
|
585
657
|
signal?: AbortSignal,
|
|
586
|
-
epochNumber?:
|
|
587
|
-
): Promise<
|
|
658
|
+
epochNumber?: EpochNumber,
|
|
659
|
+
): Promise<PublicInputsAndRecursiveProof<RootRollupPublicInputs, typeof RECURSIVE_PROOF_LENGTH>> {
|
|
588
660
|
return this.enqueueJob(
|
|
589
|
-
this.generateId(ProvingRequestType.
|
|
590
|
-
ProvingRequestType.
|
|
591
|
-
|
|
661
|
+
this.generateId(ProvingRequestType.ROOT_ROLLUP, input, epochNumber),
|
|
662
|
+
ProvingRequestType.ROOT_ROLLUP,
|
|
663
|
+
input,
|
|
592
664
|
epochNumber,
|
|
593
665
|
signal,
|
|
594
666
|
);
|
|
595
667
|
}
|
|
596
668
|
|
|
597
|
-
private generateId(type: ProvingRequestType, inputs: { toBuffer(): Buffer }, epochNumber =
|
|
669
|
+
private generateId(type: ProvingRequestType, inputs: { toBuffer(): Buffer }, epochNumber = EpochNumber.ZERO) {
|
|
598
670
|
const inputsHash = sha256(inputs.toBuffer());
|
|
599
671
|
return makeProvingJobId(epochNumber, type, inputsHash.toString('hex'));
|
|
600
672
|
}
|