@aztec/prover-client 0.0.1-fake-ceab37513c → 0.0.2-commit.217f559981
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/config.d.ts +2 -2
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +2 -2
- package/dest/index.d.ts +1 -1
- package/dest/light/index.d.ts +2 -0
- package/dest/light/index.d.ts.map +1 -0
- package/dest/light/index.js +1 -0
- package/dest/light/lightweight_checkpoint_builder.d.ts +48 -0
- package/dest/light/lightweight_checkpoint_builder.d.ts.map +1 -0
- package/dest/light/lightweight_checkpoint_builder.js +202 -0
- package/dest/mocks/fixtures.d.ts +5 -5
- package/dest/mocks/fixtures.d.ts.map +1 -1
- package/dest/mocks/fixtures.js +35 -16
- package/dest/mocks/test_context.d.ts +39 -33
- package/dest/mocks/test_context.d.ts.map +1 -1
- package/dest/mocks/test_context.js +141 -82
- package/dest/orchestrator/block-building-helpers.d.ts +34 -34
- 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 +71 -55
- package/dest/orchestrator/block-proving-state.d.ts.map +1 -1
- package/dest/orchestrator/block-proving-state.js +280 -185
- package/dest/orchestrator/checkpoint-proving-state.d.ts +76 -0
- package/dest/orchestrator/checkpoint-proving-state.d.ts.map +1 -0
- package/dest/orchestrator/checkpoint-proving-state.js +243 -0
- package/dest/orchestrator/epoch-proving-state.d.ts +40 -32
- package/dest/orchestrator/epoch-proving-state.d.ts.map +1 -1
- package/dest/orchestrator/epoch-proving-state.js +165 -85
- package/dest/orchestrator/index.d.ts +1 -1
- package/dest/orchestrator/orchestrator.d.ts +51 -35
- package/dest/orchestrator/orchestrator.d.ts.map +1 -1
- package/dest/orchestrator/orchestrator.js +847 -329
- package/dest/orchestrator/orchestrator_metrics.d.ts +1 -3
- package/dest/orchestrator/orchestrator_metrics.d.ts.map +1 -1
- package/dest/orchestrator/orchestrator_metrics.js +2 -15
- package/dest/orchestrator/tx-proving-state.d.ts +15 -12
- package/dest/orchestrator/tx-proving-state.d.ts.map +1 -1
- package/dest/orchestrator/tx-proving-state.js +27 -33
- package/dest/prover-client/factory.d.ts +3 -3
- package/dest/prover-client/factory.d.ts.map +1 -1
- package/dest/prover-client/index.d.ts +1 -1
- package/dest/prover-client/prover-client.d.ts +5 -5
- package/dest/prover-client/prover-client.d.ts.map +1 -1
- package/dest/prover-client/prover-client.js +15 -10
- 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 +28 -21
- package/dest/proving_broker/broker_prover_facade.d.ts.map +1 -1
- package/dest/proving_broker/broker_prover_facade.js +45 -36
- package/dest/proving_broker/config.d.ts +24 -8
- package/dest/proving_broker/config.d.ts.map +1 -1
- package/dest/proving_broker/config.js +26 -3
- package/dest/proving_broker/factory.d.ts +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 -5
- package/dest/proving_broker/proof_store/factory.d.ts.map +1 -1
- package/dest/proving_broker/proof_store/factory.js +7 -30
- package/dest/proving_broker/proof_store/file_store_proof_store.d.ts +18 -0
- package/dest/proving_broker/proof_store/file_store_proof_store.d.ts.map +1 -0
- package/dest/proving_broker/proof_store/file_store_proof_store.js +60 -0
- 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 +5 -9
- package/dest/proving_broker/proving_agent.d.ts.map +1 -1
- package/dest/proving_broker/proving_agent.js +4 -19
- package/dest/proving_broker/proving_broker.d.ts +7 -4
- package/dest/proving_broker/proving_broker.d.ts.map +1 -1
- package/dest/proving_broker/proving_broker.js +64 -30
- 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 +5 -3
- package/dest/proving_broker/proving_broker_database/persisted.d.ts.map +1 -1
- package/dest/proving_broker/proving_broker_database/persisted.js +392 -3
- 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_broker_instrumentation.js +15 -35
- package/dest/proving_broker/proving_job_controller.d.ts +5 -3
- package/dest/proving_broker/proving_job_controller.d.ts.map +1 -1
- package/dest/proving_broker/proving_job_controller.js +46 -24
- package/dest/proving_broker/rpc.d.ts +7 -5
- package/dest/proving_broker/rpc.d.ts.map +1 -1
- package/dest/proving_broker/rpc.js +8 -0
- package/dest/test/mock_proof_store.d.ts +1 -1
- 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 +38 -23
- package/package.json +21 -20
- package/src/config.ts +2 -2
- package/src/light/index.ts +1 -0
- package/src/light/lightweight_checkpoint_builder.ts +294 -0
- package/src/mocks/fixtures.ts +43 -37
- package/src/mocks/test_context.ts +201 -114
- package/src/orchestrator/block-building-helpers.ts +233 -313
- package/src/orchestrator/block-proving-state.ts +324 -247
- package/src/orchestrator/checkpoint-proving-state.ts +349 -0
- package/src/orchestrator/epoch-proving-state.ts +229 -132
- package/src/orchestrator/orchestrator.ts +630 -385
- package/src/orchestrator/orchestrator_metrics.ts +2 -25
- package/src/orchestrator/tx-proving-state.ts +49 -60
- package/src/prover-client/factory.ts +6 -2
- package/src/prover-client/prover-client.ts +31 -23
- package/src/prover-client/server-epoch-prover.ts +30 -21
- package/src/proving_broker/broker_prover_facade.ts +183 -118
- package/src/proving_broker/config.ts +30 -1
- package/src/proving_broker/fixtures.ts +8 -3
- package/src/proving_broker/proof_store/factory.ts +10 -32
- package/src/proving_broker/proof_store/file_store_proof_store.ts +78 -0
- package/src/proving_broker/proof_store/index.ts +1 -0
- package/src/proving_broker/proving_agent.ts +6 -19
- package/src/proving_broker/proving_broker.ts +72 -28
- package/src/proving_broker/proving_broker_database/memory.ts +2 -1
- package/src/proving_broker/proving_broker_database/persisted.ts +20 -5
- package/src/proving_broker/proving_broker_database.ts +2 -1
- package/src/proving_broker/proving_broker_instrumentation.ts +14 -35
- package/src/proving_broker/proving_job_controller.ts +51 -25
- package/src/proving_broker/rpc.ts +14 -0
- package/src/test/mock_prover.ts +144 -74
- 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/dest/block-factory/index.d.ts +0 -2
- package/dest/block-factory/index.d.ts.map +0 -1
- package/dest/block-factory/index.js +0 -1
- package/dest/block-factory/light.d.ts +0 -36
- package/dest/block-factory/light.d.ts.map +0 -1
- package/dest/block-factory/light.js +0 -87
- package/dest/proving_broker/proof_store/gcs_proof_store.d.ts +0 -14
- package/dest/proving_broker/proof_store/gcs_proof_store.d.ts.map +0 -1
- package/dest/proving_broker/proof_store/gcs_proof_store.js +0 -52
- package/dest/proving_broker/proving_agent_instrumentation.d.ts +0 -8
- package/dest/proving_broker/proving_agent_instrumentation.d.ts.map +0 -1
- package/dest/proving_broker/proving_agent_instrumentation.js +0 -16
- package/src/bin/get-proof-inputs.ts +0 -59
- package/src/block-factory/index.ts +0 -1
- package/src/block-factory/light.ts +0 -114
- package/src/proving_broker/proof_store/gcs_proof_store.ts +0 -76
- package/src/proving_broker/proving_agent_instrumentation.ts +0 -21
|
@@ -1,8 +1,11 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
1
|
+
import { BatchedBlobAccumulator } from '@aztec/blob-lib';
|
|
2
|
+
import { OUT_HASH_TREE_HEIGHT } from '@aztec/constants';
|
|
3
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
|
+
import { MerkleTreeCalculator, UnbalancedTreeStore, shaMerkleHash } from '@aztec/foundation/trees';
|
|
5
|
+
import { CheckpointMergeRollupPrivateInputs, CheckpointPaddingRollupPrivateInputs, RootRollupPrivateInputs } from '@aztec/stdlib/rollup';
|
|
6
|
+
import { AppendOnlyTreeSnapshot } from '@aztec/stdlib/trees';
|
|
7
|
+
import { toProofData } from './block-building-helpers.js';
|
|
8
|
+
import { CheckpointProvingState } from './checkpoint-proving-state.js';
|
|
6
9
|
var PROVING_STATE_LIFECYCLE = /*#__PURE__*/ function(PROVING_STATE_LIFECYCLE) {
|
|
7
10
|
PROVING_STATE_LIFECYCLE[PROVING_STATE_LIFECYCLE["PROVING_STATE_CREATED"] = 0] = "PROVING_STATE_CREATED";
|
|
8
11
|
PROVING_STATE_LIFECYCLE[PROVING_STATE_LIFECYCLE["PROVING_STATE_FULL"] = 1] = "PROVING_STATE_FULL";
|
|
@@ -17,131 +20,213 @@ var PROVING_STATE_LIFECYCLE = /*#__PURE__*/ function(PROVING_STATE_LIFECYCLE) {
|
|
|
17
20
|
* Captures resolve and reject callbacks to provide a promise base interface to the consumer of our proving.
|
|
18
21
|
*/ export class EpochProvingState {
|
|
19
22
|
epochNumber;
|
|
20
|
-
|
|
21
|
-
totalNumBlocks;
|
|
23
|
+
totalNumCheckpoints;
|
|
22
24
|
finalBlobBatchingChallenges;
|
|
25
|
+
onCheckpointBlobAccumulatorSet;
|
|
23
26
|
completionCallback;
|
|
24
27
|
rejectionCallback;
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
+
checkpointProofs;
|
|
29
|
+
checkpointPaddingProof;
|
|
30
|
+
rootRollupProof;
|
|
31
|
+
checkpoints;
|
|
32
|
+
startBlobAccumulator;
|
|
33
|
+
endBlobAccumulator;
|
|
28
34
|
finalBatchedBlob;
|
|
29
35
|
provingStateLifecycle;
|
|
30
|
-
// Map from tx hash to
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
constructor(epochNumber, firstBlockNumber, totalNumBlocks, finalBlobBatchingChallenges, completionCallback, rejectionCallback){
|
|
36
|
+
// Map from tx hash to chonk verifier proof promise. Used when kickstarting chonk verifier proofs before tx processing.
|
|
37
|
+
cachedChonkVerifierProofs;
|
|
38
|
+
constructor(epochNumber, totalNumCheckpoints, finalBlobBatchingChallenges, onCheckpointBlobAccumulatorSet, completionCallback, rejectionCallback){
|
|
34
39
|
this.epochNumber = epochNumber;
|
|
35
|
-
this.
|
|
36
|
-
this.totalNumBlocks = totalNumBlocks;
|
|
40
|
+
this.totalNumCheckpoints = totalNumCheckpoints;
|
|
37
41
|
this.finalBlobBatchingChallenges = finalBlobBatchingChallenges;
|
|
42
|
+
this.onCheckpointBlobAccumulatorSet = onCheckpointBlobAccumulatorSet;
|
|
38
43
|
this.completionCallback = completionCallback;
|
|
39
44
|
this.rejectionCallback = rejectionCallback;
|
|
45
|
+
this.checkpoints = [];
|
|
40
46
|
this.provingStateLifecycle = 0;
|
|
41
|
-
this.
|
|
42
|
-
this.
|
|
43
|
-
this.
|
|
47
|
+
this.cachedChonkVerifierProofs = new Map();
|
|
48
|
+
this.checkpointProofs = new UnbalancedTreeStore(totalNumCheckpoints);
|
|
49
|
+
this.startBlobAccumulator = BatchedBlobAccumulator.newWithChallenges(finalBlobBatchingChallenges);
|
|
44
50
|
}
|
|
45
51
|
// Adds a block to the proving state, returns its index
|
|
46
52
|
// Will update the proving life cycle if this is the last block
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
53
|
+
startNewCheckpoint(checkpointIndex, constants, totalNumBlocks, previousBlockHeader, lastArchiveSiblingPath, l1ToL2Messages, lastL1ToL2MessageTreeSnapshot, lastL1ToL2MessageSubtreeRootSiblingPath, newL1ToL2MessageTreeSnapshot, newL1ToL2MessageSubtreeRootSiblingPath) {
|
|
54
|
+
if (checkpointIndex >= this.totalNumCheckpoints) {
|
|
55
|
+
throw new Error(`Unable to start a new checkpoint at index ${checkpointIndex}. Expected at most ${this.totalNumCheckpoints} checkpoints.`);
|
|
56
|
+
}
|
|
57
|
+
const checkpoint = new CheckpointProvingState(checkpointIndex, constants, totalNumBlocks, this.finalBlobBatchingChallenges, previousBlockHeader, lastArchiveSiblingPath, l1ToL2Messages, lastL1ToL2MessageTreeSnapshot, lastL1ToL2MessageSubtreeRootSiblingPath, newL1ToL2MessageTreeSnapshot, newL1ToL2MessageSubtreeRootSiblingPath, this, this.onCheckpointBlobAccumulatorSet);
|
|
58
|
+
this.checkpoints[checkpointIndex] = checkpoint;
|
|
59
|
+
if (this.checkpoints.filter((c)=>!!c).length === this.totalNumCheckpoints) {
|
|
52
60
|
this.provingStateLifecycle = 1;
|
|
53
61
|
}
|
|
54
|
-
return
|
|
62
|
+
return checkpoint;
|
|
63
|
+
}
|
|
64
|
+
getCheckpointProvingState(index) {
|
|
65
|
+
return this.checkpoints[index];
|
|
66
|
+
}
|
|
67
|
+
getCheckpointProvingStateByBlockNumber(blockNumber) {
|
|
68
|
+
return this.checkpoints.find((c)=>c && Number(blockNumber) >= Number(c.firstBlockNumber) && Number(blockNumber) < Number(c.firstBlockNumber) + c.totalNumBlocks);
|
|
69
|
+
}
|
|
70
|
+
getBlockProvingStateByBlockNumber(blockNumber) {
|
|
71
|
+
return this.getCheckpointProvingStateByBlockNumber(blockNumber)?.getBlockProvingStateByBlockNumber(blockNumber);
|
|
55
72
|
}
|
|
56
73
|
// Returns true if this proving state is still valid, false otherwise
|
|
57
74
|
verifyState() {
|
|
58
75
|
return this.provingStateLifecycle === 0 || this.provingStateLifecycle === 1;
|
|
59
76
|
}
|
|
60
|
-
// Returns true if we are still able to accept
|
|
61
|
-
|
|
62
|
-
return this.
|
|
77
|
+
// Returns true if we are still able to accept checkpoints, false otherwise.
|
|
78
|
+
isAcceptingCheckpoints() {
|
|
79
|
+
return this.checkpoints.filter((c)=>!!c).length < this.totalNumCheckpoints;
|
|
80
|
+
}
|
|
81
|
+
setCheckpointRootRollupProof(checkpointIndex, provingOutput) {
|
|
82
|
+
return this.checkpointProofs.setLeaf(checkpointIndex, {
|
|
83
|
+
provingOutput
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
tryStartProvingCheckpointMerge(location) {
|
|
87
|
+
if (this.checkpointProofs.getNode(location)?.isProving) {
|
|
88
|
+
return false;
|
|
89
|
+
} else {
|
|
90
|
+
this.checkpointProofs.setNode(location, {
|
|
91
|
+
isProving: true
|
|
92
|
+
});
|
|
93
|
+
return true;
|
|
94
|
+
}
|
|
63
95
|
}
|
|
64
|
-
|
|
65
|
-
|
|
96
|
+
setCheckpointMergeRollupProof(location, provingOutput) {
|
|
97
|
+
this.checkpointProofs.setNode(location, {
|
|
98
|
+
provingOutput
|
|
99
|
+
});
|
|
66
100
|
}
|
|
67
|
-
|
|
68
|
-
this.
|
|
101
|
+
tryStartProvingRootRollup() {
|
|
102
|
+
if (this.rootRollupProof?.isProving) {
|
|
103
|
+
return false;
|
|
104
|
+
} else {
|
|
105
|
+
this.rootRollupProof = {
|
|
106
|
+
isProving: true
|
|
107
|
+
};
|
|
108
|
+
return true;
|
|
109
|
+
}
|
|
69
110
|
}
|
|
70
|
-
setRootRollupProof(
|
|
71
|
-
this.
|
|
111
|
+
setRootRollupProof(provingOutput) {
|
|
112
|
+
this.rootRollupProof = {
|
|
113
|
+
provingOutput
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
tryStartProvingPaddingCheckpoint() {
|
|
117
|
+
if (this.checkpointPaddingProof?.isProving) {
|
|
118
|
+
return false;
|
|
119
|
+
} else {
|
|
120
|
+
this.checkpointPaddingProof = {
|
|
121
|
+
isProving: true
|
|
122
|
+
};
|
|
123
|
+
return true;
|
|
124
|
+
}
|
|
72
125
|
}
|
|
73
|
-
|
|
74
|
-
this.
|
|
126
|
+
setCheckpointPaddingProof(provingOutput) {
|
|
127
|
+
this.checkpointPaddingProof = {
|
|
128
|
+
provingOutput
|
|
129
|
+
};
|
|
75
130
|
}
|
|
76
|
-
|
|
77
|
-
|
|
131
|
+
async accumulateCheckpointOutHashes() {
|
|
132
|
+
const treeCalculator = await MerkleTreeCalculator.create(OUT_HASH_TREE_HEIGHT, undefined, (left, right)=>Promise.resolve(shaMerkleHash(left, right)));
|
|
133
|
+
const computeOutHashHint = async (leaves)=>{
|
|
134
|
+
const tree = await treeCalculator.computeTree(leaves.map((l)=>l.toBuffer()));
|
|
135
|
+
const nextAvailableLeafIndex = leaves.length;
|
|
136
|
+
return {
|
|
137
|
+
treeSnapshot: new AppendOnlyTreeSnapshot(Fr.fromBuffer(tree.root), nextAvailableLeafIndex),
|
|
138
|
+
siblingPath: tree.getSiblingPath(nextAvailableLeafIndex).map(Fr.fromBuffer)
|
|
139
|
+
};
|
|
140
|
+
};
|
|
141
|
+
let hint = this.checkpoints[0]?.getOutHashHint();
|
|
142
|
+
const outHashes = [];
|
|
143
|
+
for(let i = 0; i < this.totalNumCheckpoints; i++){
|
|
144
|
+
const checkpoint = this.checkpoints[i];
|
|
145
|
+
if (!checkpoint) {
|
|
146
|
+
break;
|
|
147
|
+
}
|
|
148
|
+
// If hints are not set yet, it must be the first checkpoint. Compute the hints with an empty tree.
|
|
149
|
+
hint ??= await computeOutHashHint([]);
|
|
150
|
+
checkpoint.setOutHashHint(hint);
|
|
151
|
+
// Get the out hash for this checkpoint.
|
|
152
|
+
const outHash = checkpoint.accumulateBlockOutHashes();
|
|
153
|
+
if (!outHash) {
|
|
154
|
+
break;
|
|
155
|
+
}
|
|
156
|
+
outHashes.push(outHash);
|
|
157
|
+
// If this is NOT the last checkpoint, get or create the hint for the next checkpoint.
|
|
158
|
+
if (i !== this.totalNumCheckpoints - 1) {
|
|
159
|
+
hint = checkpoint.getOutHashHintForNextCheckpoint() ?? await computeOutHashHint(outHashes);
|
|
160
|
+
checkpoint.setOutHashHintForNextCheckpoint(hint);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
78
163
|
}
|
|
79
|
-
async setBlobAccumulators(
|
|
80
|
-
let previousAccumulator;
|
|
81
|
-
const end = toBlock ? toBlock - this.firstBlockNumber : this.blocks.length;
|
|
164
|
+
async setBlobAccumulators() {
|
|
165
|
+
let previousAccumulator = this.startBlobAccumulator;
|
|
82
166
|
// Accumulate blobs as far as we can for this epoch.
|
|
83
|
-
for(let i = 0; i
|
|
84
|
-
const
|
|
85
|
-
if (!
|
|
167
|
+
for(let i = 0; i < this.totalNumCheckpoints; i++){
|
|
168
|
+
const checkpoint = this.checkpoints[i];
|
|
169
|
+
if (!checkpoint) {
|
|
86
170
|
break;
|
|
87
171
|
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
172
|
+
const endAccumulator = checkpoint.getEndBlobAccumulator() || await checkpoint.accumulateBlobs(previousAccumulator);
|
|
173
|
+
if (!endAccumulator) {
|
|
174
|
+
break;
|
|
91
175
|
}
|
|
92
|
-
|
|
93
|
-
|
|
176
|
+
previousAccumulator = endAccumulator;
|
|
177
|
+
// If this is the last checkpoint, set the end blob accumulator.
|
|
178
|
+
if (i === this.totalNumCheckpoints - 1) {
|
|
179
|
+
this.endBlobAccumulator = endAccumulator;
|
|
94
180
|
}
|
|
95
|
-
previousAccumulator = block.endBlobAccumulator;
|
|
96
181
|
}
|
|
97
182
|
}
|
|
183
|
+
async finalizeBatchedBlob() {
|
|
184
|
+
if (!this.endBlobAccumulator) {
|
|
185
|
+
throw new Error('End blob accumulator not ready.');
|
|
186
|
+
}
|
|
187
|
+
this.finalBatchedBlob = await this.endBlobAccumulator.finalize(true);
|
|
188
|
+
}
|
|
98
189
|
getParentLocation(location) {
|
|
99
|
-
return this.
|
|
190
|
+
return this.checkpointProofs.getParentLocation(location);
|
|
100
191
|
}
|
|
101
|
-
|
|
102
|
-
const [left, right] = this.
|
|
192
|
+
getCheckpointMergeRollupInputs(mergeLocation) {
|
|
193
|
+
const [left, right] = this.checkpointProofs.getChildren(mergeLocation).map((c)=>c?.provingOutput);
|
|
103
194
|
if (!left || !right) {
|
|
104
|
-
throw new Error('At
|
|
195
|
+
throw new Error('At least one child is not ready for the checkpoint merge rollup.');
|
|
105
196
|
}
|
|
106
|
-
return new
|
|
107
|
-
|
|
108
|
-
|
|
197
|
+
return new CheckpointMergeRollupPrivateInputs([
|
|
198
|
+
toProofData(left),
|
|
199
|
+
toProofData(right)
|
|
109
200
|
]);
|
|
110
201
|
}
|
|
111
202
|
getRootRollupInputs() {
|
|
112
203
|
const [left, right] = this.#getChildProofsForRoot();
|
|
113
204
|
if (!left || !right) {
|
|
114
|
-
throw new Error('At
|
|
205
|
+
throw new Error('At least one child is not ready for the root rollup.');
|
|
115
206
|
}
|
|
116
|
-
return
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
207
|
+
return RootRollupPrivateInputs.from({
|
|
208
|
+
previousRollups: [
|
|
209
|
+
toProofData(left),
|
|
210
|
+
toProofData(right)
|
|
120
211
|
]
|
|
121
212
|
});
|
|
122
213
|
}
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
throw new Error('Epoch needs one completed block in order to be padded.');
|
|
126
|
-
}
|
|
127
|
-
return this.blocks[0].getPaddingBlockRootInputs();
|
|
128
|
-
}
|
|
129
|
-
// Returns a specific transaction proving state
|
|
130
|
-
getBlockProvingStateByBlockNumber(blockNumber) {
|
|
131
|
-
return this.blocks.find((block)=>block?.blockNumber === blockNumber);
|
|
214
|
+
getPaddingCheckpointInputs() {
|
|
215
|
+
return new CheckpointPaddingRollupPrivateInputs();
|
|
132
216
|
}
|
|
133
217
|
getEpochProofResult() {
|
|
134
|
-
|
|
218
|
+
const provingOutput = this.rootRollupProof?.provingOutput;
|
|
219
|
+
if (!provingOutput || !this.finalBatchedBlob) {
|
|
135
220
|
throw new Error('Unable to get epoch proof result. Root rollup is not ready.');
|
|
136
221
|
}
|
|
137
222
|
return {
|
|
138
|
-
proof:
|
|
139
|
-
publicInputs:
|
|
223
|
+
proof: provingOutput.proof.binaryProof,
|
|
224
|
+
publicInputs: provingOutput.inputs,
|
|
140
225
|
batchedBlobInputs: this.finalBatchedBlob
|
|
141
226
|
};
|
|
142
227
|
}
|
|
143
|
-
|
|
144
|
-
return this.
|
|
228
|
+
isReadyForCheckpointMerge(location) {
|
|
229
|
+
return !!this.checkpointProofs.getSibling(location)?.provingOutput;
|
|
145
230
|
}
|
|
146
231
|
// Returns true if we have sufficient inputs to execute the block root rollup
|
|
147
232
|
isReadyForRootRollup() {
|
|
@@ -176,14 +261,9 @@ var PROVING_STATE_LIFECYCLE = /*#__PURE__*/ function(PROVING_STATE_LIFECYCLE) {
|
|
|
176
261
|
index: 0
|
|
177
262
|
};
|
|
178
263
|
// If there's only 1 block, its block root proof will be stored at the root.
|
|
179
|
-
return this.
|
|
180
|
-
this.
|
|
181
|
-
this.
|
|
182
|
-
] : this.
|
|
183
|
-
}
|
|
184
|
-
#getPreviousRollupData({ inputs, proof, verificationKey }) {
|
|
185
|
-
const leafIndex = getVKIndex(verificationKey.keyAsFields);
|
|
186
|
-
const vkData = new VkData(verificationKey, leafIndex, getVKSiblingPath(leafIndex));
|
|
187
|
-
return new PreviousRollupBlockData(inputs, proof, vkData);
|
|
264
|
+
return this.totalNumCheckpoints === 1 ? [
|
|
265
|
+
this.checkpointProofs.getNode(rootLocation)?.provingOutput,
|
|
266
|
+
this.checkpointPaddingProof?.provingOutput
|
|
267
|
+
] : this.checkpointProofs.getChildren(rootLocation).map((c)=>c?.provingOutput);
|
|
188
268
|
}
|
|
189
269
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export { ProvingOrchestrator } from './orchestrator.js';
|
|
2
|
-
//# sourceMappingURL=
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9vcmNoZXN0cmF0b3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbUJBQW1CLENBQUMifQ==
|
|
@@ -1,10 +1,15 @@
|
|
|
1
|
-
import { FinalBlobBatchingChallenges } from '@aztec/blob-lib';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
1
|
+
import { BatchedBlob, FinalBlobBatchingChallenges } from '@aztec/blob-lib/types';
|
|
2
|
+
import { BlockNumber, EpochNumber } from '@aztec/foundation/branded-types';
|
|
3
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
|
+
import { type LoggerBindings } from '@aztec/foundation/log';
|
|
5
|
+
import { EthAddress } from '@aztec/stdlib/block';
|
|
6
|
+
import type { EpochProver, ForkMerkleTreeOperations, ReadonlyWorldStateAccess, ServerCircuitProver } from '@aztec/stdlib/interfaces/server';
|
|
7
|
+
import type { Proof } from '@aztec/stdlib/proofs';
|
|
8
|
+
import { CheckpointConstantData, RootRollupPublicInputs } from '@aztec/stdlib/rollup';
|
|
9
|
+
import type { BlockHeader, ProcessedTx, Tx } from '@aztec/stdlib/tx';
|
|
10
|
+
import type { UInt64 } from '@aztec/stdlib/types';
|
|
7
11
|
import { type TelemetryClient, type Tracer } from '@aztec/telemetry-client';
|
|
12
|
+
import type { BlockProvingState } from './block-proving-state.js';
|
|
8
13
|
/**
|
|
9
14
|
* Implements an event driven proving scheduler to build the recursive proof tree. The idea being:
|
|
10
15
|
* 1. Transactions are provided to the scheduler post simulation.
|
|
@@ -22,60 +27,67 @@ export declare class ProvingOrchestrator implements EpochProver {
|
|
|
22
27
|
private dbProvider;
|
|
23
28
|
private prover;
|
|
24
29
|
private readonly proverId;
|
|
30
|
+
private readonly cancelJobsOnStop;
|
|
25
31
|
private provingState;
|
|
26
32
|
private pendingProvingJobs;
|
|
27
33
|
private provingPromise;
|
|
28
34
|
private metrics;
|
|
29
35
|
private dbs;
|
|
30
|
-
|
|
36
|
+
private logger;
|
|
37
|
+
constructor(dbProvider: ReadonlyWorldStateAccess & ForkMerkleTreeOperations, prover: ServerCircuitProver, proverId: EthAddress, cancelJobsOnStop?: boolean, telemetryClient?: TelemetryClient, bindings?: LoggerBindings);
|
|
31
38
|
get tracer(): Tracer;
|
|
32
39
|
getProverId(): EthAddress;
|
|
40
|
+
getNumActiveForks(): number;
|
|
33
41
|
stop(): Promise<void>;
|
|
34
|
-
startNewEpoch(epochNumber:
|
|
42
|
+
startNewEpoch(epochNumber: EpochNumber, totalNumCheckpoints: number, finalBlobBatchingChallenges: FinalBlobBatchingChallenges): void;
|
|
43
|
+
/**
|
|
44
|
+
* Starts a new checkpoint.
|
|
45
|
+
* @param checkpointIndex - The index of the checkpoint in the epoch.
|
|
46
|
+
* @param constants - The constants for this checkpoint.
|
|
47
|
+
* @param l1ToL2Messages - The set of L1 to L2 messages to be inserted at the beginning of this checkpoint.
|
|
48
|
+
* @param totalNumBlocks - The total number of blocks expected in the checkpoint (must be at least one).
|
|
49
|
+
* @param headerOfLastBlockInPreviousCheckpoint - The header of the last block in the previous checkpoint.
|
|
50
|
+
*/
|
|
51
|
+
startNewCheckpoint(checkpointIndex: number, constants: CheckpointConstantData, l1ToL2Messages: Fr[], totalNumBlocks: number, headerOfLastBlockInPreviousCheckpoint: BlockHeader): Promise<void>;
|
|
35
52
|
/**
|
|
36
53
|
* Starts off a new block
|
|
37
|
-
* @param
|
|
38
|
-
* @param
|
|
39
|
-
*
|
|
54
|
+
* @param blockNumber - The block number
|
|
55
|
+
* @param timestamp - The timestamp of the block. This is only required for constructing the private inputs for the
|
|
56
|
+
* block that doesn't have any txs.
|
|
57
|
+
* @param totalNumTxs - The total number of txs in the block
|
|
40
58
|
*/
|
|
41
|
-
startNewBlock(
|
|
59
|
+
startNewBlock(blockNumber: BlockNumber, timestamp: UInt64, totalNumTxs: number): Promise<void>;
|
|
42
60
|
/**
|
|
43
61
|
* The interface to add simulated transactions to the scheduler. This can only be called once per block.
|
|
44
62
|
* @param txs - The transactions to be proven
|
|
45
63
|
*/
|
|
46
64
|
addTxs(txs: ProcessedTx[]): Promise<void>;
|
|
47
65
|
/**
|
|
48
|
-
* Kickstarts
|
|
49
|
-
* Note that if the
|
|
66
|
+
* Kickstarts chonk verifier circuits for the specified txs. These will be used during epoch proving.
|
|
67
|
+
* Note that if the chonk verifier circuits are not started this way, they will be started nontheless after processing.
|
|
50
68
|
*/
|
|
51
|
-
|
|
69
|
+
startChonkVerifierCircuits(txs: Tx[]): Promise<void>;
|
|
52
70
|
/**
|
|
53
71
|
* Marks the block as completed.
|
|
54
72
|
* Computes the block header and updates the archive tree.
|
|
55
73
|
*/
|
|
56
|
-
setBlockCompleted(blockNumber:
|
|
57
|
-
|
|
58
|
-
getBlock(index: number): L2Block;
|
|
59
|
-
private buildBlock;
|
|
60
|
-
protected verifyBuiltBlockAgainstSyncedState(l2Block: L2Block, newArchive: AppendOnlyTreeSnapshot): Promise<void>;
|
|
74
|
+
setBlockCompleted(blockNumber: BlockNumber, expectedHeader?: BlockHeader): Promise<BlockHeader>;
|
|
75
|
+
protected verifyBuiltBlockAgainstSyncedState(provingState: BlockProvingState): Promise<void>;
|
|
61
76
|
/**
|
|
62
|
-
* Cancel any further proving
|
|
77
|
+
* Cancel any further proving.
|
|
78
|
+
* If cancelJobsOnStop is true, aborts all pending jobs with the broker (which marks them as 'Aborted').
|
|
79
|
+
* If cancelJobsOnStop is false (default), jobs remain in the broker queue and can be reused on restart/reorg.
|
|
63
80
|
*/
|
|
64
81
|
cancel(): void;
|
|
82
|
+
private getDbForBlock;
|
|
65
83
|
/**
|
|
66
84
|
* Returns the proof for the current epoch.
|
|
67
85
|
*/
|
|
68
86
|
finalizeEpoch(): Promise<{
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
batchedBlobInputs:
|
|
87
|
+
publicInputs: RootRollupPublicInputs;
|
|
88
|
+
proof: Proof;
|
|
89
|
+
batchedBlobInputs: BatchedBlob;
|
|
72
90
|
}>;
|
|
73
|
-
/**
|
|
74
|
-
* Starts the proving process for the given transaction and adds it to our state
|
|
75
|
-
* @param tx - The transaction whose proving we wish to commence
|
|
76
|
-
* @param provingState - The proving state being worked on
|
|
77
|
-
*/
|
|
78
|
-
private prepareTransaction;
|
|
79
91
|
/**
|
|
80
92
|
* Enqueue a job to be scheduled
|
|
81
93
|
* @param provingState - The proving state object being operated on
|
|
@@ -83,22 +95,26 @@ export declare class ProvingOrchestrator implements EpochProver {
|
|
|
83
95
|
* @param job - The actual job, returns a promise notifying of the job's completion
|
|
84
96
|
*/
|
|
85
97
|
private deferredProving;
|
|
86
|
-
private
|
|
98
|
+
private updateL1ToL2MessageTree;
|
|
87
99
|
private prepareBaseRollupInputs;
|
|
88
100
|
private enqueueBaseRollup;
|
|
89
|
-
private
|
|
90
|
-
private
|
|
101
|
+
private getOrEnqueueChonkVerifier;
|
|
102
|
+
private doEnqueueChonkVerifier;
|
|
91
103
|
private enqueueMergeRollup;
|
|
92
104
|
private enqueueBlockRootRollup;
|
|
93
105
|
private enqueueBaseParityCircuit;
|
|
94
106
|
private checkAndEnqueueRootParityCircuit;
|
|
95
107
|
private enqueueRootParityCircuit;
|
|
96
108
|
private enqueueBlockMergeRollup;
|
|
109
|
+
private enqueueCheckpointRootRollup;
|
|
110
|
+
private enqueueCheckpointMergeRollup;
|
|
97
111
|
private enqueueEpochPadding;
|
|
98
112
|
private enqueueRootRollup;
|
|
99
113
|
private checkAndEnqueueNextMergeRollup;
|
|
100
114
|
private checkAndEnqueueBlockRootRollup;
|
|
101
115
|
private checkAndEnqueueNextBlockMergeRollup;
|
|
116
|
+
private checkAndEnqueueCheckpointRootRollup;
|
|
117
|
+
private checkAndEnqueueNextCheckpointMergeRollup;
|
|
102
118
|
private checkAndEnqueueRootRollup;
|
|
103
119
|
/**
|
|
104
120
|
* Executes the VM circuit for a public function, will enqueue the corresponding kernel if the
|
|
@@ -107,6 +123,6 @@ export declare class ProvingOrchestrator implements EpochProver {
|
|
|
107
123
|
* @param txIndex - The index of the transaction being proven
|
|
108
124
|
*/
|
|
109
125
|
private enqueueVM;
|
|
110
|
-
private
|
|
126
|
+
private checkAndEnqueueBaseRollup;
|
|
111
127
|
}
|
|
112
|
-
//# sourceMappingURL=
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JjaGVzdHJhdG9yLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvb3JjaGVzdHJhdG9yL29yY2hlc3RyYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLDJCQUEyQixFQUFjLE1BQU0sdUJBQXVCLENBQUM7QUFRN0YsT0FBTyxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUUzRSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFFcEQsT0FBTyxFQUFlLEtBQUssY0FBYyxFQUFnQixNQUFNLHVCQUF1QixDQUFDO0FBTXZGLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNqRCxPQUFPLEtBQUssRUFDVixXQUFXLEVBQ1gsd0JBQXdCLEVBR3hCLHdCQUF3QixFQUN4QixtQkFBbUIsRUFDcEIsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNsRCxPQUFPLEVBTUwsc0JBQXNCLEVBS3RCLHNCQUFzQixFQUN2QixNQUFNLHNCQUFzQixDQUFDO0FBRzlCLE9BQU8sS0FBSyxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsRUFBRSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDckUsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbEQsT0FBTyxFQUVMLEtBQUssZUFBZSxFQUNwQixLQUFLLE1BQU0sRUFJWixNQUFNLHlCQUF5QixDQUFDO0FBZWpDLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFNbEU7Ozs7Ozs7OztHQVNHO0FBRUg7O0dBRUc7QUFDSCxxQkFBYSxtQkFBb0IsWUFBVyxXQUFXO0lBV25ELE9BQU8sQ0FBQyxVQUFVO0lBQ2xCLE9BQU8sQ0FBQyxNQUFNO0lB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
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"orchestrator.d.ts","sourceRoot":"","sources":["../../src/orchestrator/orchestrator.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"orchestrator.d.ts","sourceRoot":"","sources":["../../src/orchestrator/orchestrator.ts"],"names":[],"mappings":"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"}
|