@aztec/prover-client 0.0.1-commit.c7c42ec → 0.0.1-commit.c80b6263

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (86) hide show
  1. package/dest/light/lightweight_checkpoint_builder.d.ts +15 -6
  2. package/dest/light/lightweight_checkpoint_builder.d.ts.map +1 -1
  3. package/dest/light/lightweight_checkpoint_builder.js +62 -12
  4. package/dest/mocks/fixtures.d.ts +1 -1
  5. package/dest/mocks/fixtures.d.ts.map +1 -1
  6. package/dest/mocks/fixtures.js +2 -1
  7. package/dest/mocks/test_context.d.ts +4 -2
  8. package/dest/mocks/test_context.d.ts.map +1 -1
  9. package/dest/mocks/test_context.js +14 -3
  10. package/dest/orchestrator/block-building-helpers.d.ts +1 -1
  11. package/dest/orchestrator/block-building-helpers.js +2 -2
  12. package/dest/orchestrator/checkpoint-proving-state.d.ts +15 -2
  13. package/dest/orchestrator/checkpoint-proving-state.d.ts.map +1 -1
  14. package/dest/orchestrator/checkpoint-proving-state.js +34 -1
  15. package/dest/orchestrator/epoch-proving-state.d.ts +5 -4
  16. package/dest/orchestrator/epoch-proving-state.d.ts.map +1 -1
  17. package/dest/orchestrator/epoch-proving-state.js +35 -1
  18. package/dest/orchestrator/orchestrator.d.ts +18 -3
  19. package/dest/orchestrator/orchestrator.d.ts.map +1 -1
  20. package/dest/orchestrator/orchestrator.js +533 -109
  21. package/dest/orchestrator/orchestrator_metrics.d.ts +1 -1
  22. package/dest/orchestrator/orchestrator_metrics.d.ts.map +1 -1
  23. package/dest/orchestrator/orchestrator_metrics.js +2 -6
  24. package/dest/orchestrator/tx-proving-state.d.ts +5 -4
  25. package/dest/orchestrator/tx-proving-state.d.ts.map +1 -1
  26. package/dest/orchestrator/tx-proving-state.js +6 -6
  27. package/dest/prover-client/prover-client.d.ts +1 -1
  28. package/dest/prover-client/prover-client.d.ts.map +1 -1
  29. package/dest/prover-client/prover-client.js +7 -4
  30. package/dest/proving_broker/broker_prover_facade.d.ts +7 -5
  31. package/dest/proving_broker/broker_prover_facade.d.ts.map +1 -1
  32. package/dest/proving_broker/broker_prover_facade.js +3 -3
  33. package/dest/proving_broker/config.d.ts +5 -1
  34. package/dest/proving_broker/config.d.ts.map +1 -1
  35. package/dest/proving_broker/config.js +7 -1
  36. package/dest/proving_broker/proving_agent.d.ts +5 -9
  37. package/dest/proving_broker/proving_agent.d.ts.map +1 -1
  38. package/dest/proving_broker/proving_agent.js +4 -19
  39. package/dest/proving_broker/proving_broker.d.ts +1 -1
  40. package/dest/proving_broker/proving_broker.d.ts.map +1 -1
  41. package/dest/proving_broker/proving_broker.js +1 -10
  42. package/dest/proving_broker/proving_broker_database/persisted.d.ts +3 -2
  43. package/dest/proving_broker/proving_broker_database/persisted.d.ts.map +1 -1
  44. package/dest/proving_broker/proving_broker_database/persisted.js +389 -1
  45. package/dest/proving_broker/proving_broker_instrumentation.d.ts +1 -1
  46. package/dest/proving_broker/proving_broker_instrumentation.d.ts.map +1 -1
  47. package/dest/proving_broker/proving_broker_instrumentation.js +15 -35
  48. package/dest/proving_broker/proving_job_controller.d.ts +4 -3
  49. package/dest/proving_broker/proving_job_controller.d.ts.map +1 -1
  50. package/dest/proving_broker/proving_job_controller.js +6 -3
  51. package/dest/test/mock_proof_store.d.ts +3 -3
  52. package/dest/test/mock_proof_store.d.ts.map +1 -1
  53. package/dest/test/mock_prover.d.ts +2 -2
  54. package/dest/test/mock_prover.d.ts.map +1 -1
  55. package/dest/test/mock_prover.js +3 -3
  56. package/package.json +16 -17
  57. package/src/light/lightweight_checkpoint_builder.ts +100 -14
  58. package/src/mocks/fixtures.ts +2 -1
  59. package/src/mocks/test_context.ts +11 -1
  60. package/src/orchestrator/block-building-helpers.ts +2 -2
  61. package/src/orchestrator/checkpoint-proving-state.ts +47 -1
  62. package/src/orchestrator/epoch-proving-state.ts +56 -8
  63. package/src/orchestrator/orchestrator.ts +126 -85
  64. package/src/orchestrator/orchestrator_metrics.ts +2 -6
  65. package/src/orchestrator/tx-proving-state.ts +8 -11
  66. package/src/prover-client/prover-client.ts +22 -13
  67. package/src/proving_broker/broker_prover_facade.ts +8 -6
  68. package/src/proving_broker/config.ts +9 -0
  69. package/src/proving_broker/proving_agent.ts +6 -19
  70. package/src/proving_broker/proving_broker.ts +1 -8
  71. package/src/proving_broker/proving_broker_database/persisted.ts +15 -1
  72. package/src/proving_broker/proving_broker_instrumentation.ts +14 -35
  73. package/src/proving_broker/proving_job_controller.ts +9 -3
  74. package/src/test/mock_prover.ts +1 -8
  75. package/dest/block-factory/index.d.ts +0 -2
  76. package/dest/block-factory/index.d.ts.map +0 -1
  77. package/dest/block-factory/index.js +0 -1
  78. package/dest/block-factory/light.d.ts +0 -38
  79. package/dest/block-factory/light.d.ts.map +0 -1
  80. package/dest/block-factory/light.js +0 -108
  81. package/dest/proving_broker/proving_agent_instrumentation.d.ts +0 -8
  82. package/dest/proving_broker/proving_agent_instrumentation.d.ts.map +0 -1
  83. package/dest/proving_broker/proving_agent_instrumentation.js +0 -16
  84. package/src/block-factory/index.ts +0 -1
  85. package/src/block-factory/light.ts +0 -137
  86. package/src/proving_broker/proving_agent_instrumentation.ts +0 -21
@@ -1,9 +1,376 @@
1
- function _ts_decorate(decorators, target, key, desc) {
2
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
- else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1
+ function applyDecs2203RFactory() {
2
+ function createAddInitializerMethod(initializers, decoratorFinishedRef) {
3
+ return function addInitializer(initializer) {
4
+ assertNotFinished(decoratorFinishedRef, "addInitializer");
5
+ assertCallable(initializer, "An initializer");
6
+ initializers.push(initializer);
7
+ };
8
+ }
9
+ function memberDec(dec, name, desc, initializers, kind, isStatic, isPrivate, metadata, value) {
10
+ var kindStr;
11
+ switch(kind){
12
+ case 1:
13
+ kindStr = "accessor";
14
+ break;
15
+ case 2:
16
+ kindStr = "method";
17
+ break;
18
+ case 3:
19
+ kindStr = "getter";
20
+ break;
21
+ case 4:
22
+ kindStr = "setter";
23
+ break;
24
+ default:
25
+ kindStr = "field";
26
+ }
27
+ var ctx = {
28
+ kind: kindStr,
29
+ name: isPrivate ? "#" + name : name,
30
+ static: isStatic,
31
+ private: isPrivate,
32
+ metadata: metadata
33
+ };
34
+ var decoratorFinishedRef = {
35
+ v: false
36
+ };
37
+ ctx.addInitializer = createAddInitializerMethod(initializers, decoratorFinishedRef);
38
+ var get, set;
39
+ if (kind === 0) {
40
+ if (isPrivate) {
41
+ get = desc.get;
42
+ set = desc.set;
43
+ } else {
44
+ get = function() {
45
+ return this[name];
46
+ };
47
+ set = function(v) {
48
+ this[name] = v;
49
+ };
50
+ }
51
+ } else if (kind === 2) {
52
+ get = function() {
53
+ return desc.value;
54
+ };
55
+ } else {
56
+ if (kind === 1 || kind === 3) {
57
+ get = function() {
58
+ return desc.get.call(this);
59
+ };
60
+ }
61
+ if (kind === 1 || kind === 4) {
62
+ set = function(v) {
63
+ desc.set.call(this, v);
64
+ };
65
+ }
66
+ }
67
+ ctx.access = get && set ? {
68
+ get: get,
69
+ set: set
70
+ } : get ? {
71
+ get: get
72
+ } : {
73
+ set: set
74
+ };
75
+ try {
76
+ return dec(value, ctx);
77
+ } finally{
78
+ decoratorFinishedRef.v = true;
79
+ }
80
+ }
81
+ function assertNotFinished(decoratorFinishedRef, fnName) {
82
+ if (decoratorFinishedRef.v) {
83
+ throw new Error("attempted to call " + fnName + " after decoration was finished");
84
+ }
85
+ }
86
+ function assertCallable(fn, hint) {
87
+ if (typeof fn !== "function") {
88
+ throw new TypeError(hint + " must be a function");
89
+ }
90
+ }
91
+ function assertValidReturnValue(kind, value) {
92
+ var type = typeof value;
93
+ if (kind === 1) {
94
+ if (type !== "object" || value === null) {
95
+ throw new TypeError("accessor decorators must return an object with get, set, or init properties or void 0");
96
+ }
97
+ if (value.get !== undefined) {
98
+ assertCallable(value.get, "accessor.get");
99
+ }
100
+ if (value.set !== undefined) {
101
+ assertCallable(value.set, "accessor.set");
102
+ }
103
+ if (value.init !== undefined) {
104
+ assertCallable(value.init, "accessor.init");
105
+ }
106
+ } else if (type !== "function") {
107
+ var hint;
108
+ if (kind === 0) {
109
+ hint = "field";
110
+ } else if (kind === 10) {
111
+ hint = "class";
112
+ } else {
113
+ hint = "method";
114
+ }
115
+ throw new TypeError(hint + " decorators must return a function or void 0");
116
+ }
117
+ }
118
+ function applyMemberDec(ret, base, decInfo, name, kind, isStatic, isPrivate, initializers, metadata) {
119
+ var decs = decInfo[0];
120
+ var desc, init, value;
121
+ if (isPrivate) {
122
+ if (kind === 0 || kind === 1) {
123
+ desc = {
124
+ get: decInfo[3],
125
+ set: decInfo[4]
126
+ };
127
+ } else if (kind === 3) {
128
+ desc = {
129
+ get: decInfo[3]
130
+ };
131
+ } else if (kind === 4) {
132
+ desc = {
133
+ set: decInfo[3]
134
+ };
135
+ } else {
136
+ desc = {
137
+ value: decInfo[3]
138
+ };
139
+ }
140
+ } else if (kind !== 0) {
141
+ desc = Object.getOwnPropertyDescriptor(base, name);
142
+ }
143
+ if (kind === 1) {
144
+ value = {
145
+ get: desc.get,
146
+ set: desc.set
147
+ };
148
+ } else if (kind === 2) {
149
+ value = desc.value;
150
+ } else if (kind === 3) {
151
+ value = desc.get;
152
+ } else if (kind === 4) {
153
+ value = desc.set;
154
+ }
155
+ var newValue, get, set;
156
+ if (typeof decs === "function") {
157
+ newValue = memberDec(decs, name, desc, initializers, kind, isStatic, isPrivate, metadata, value);
158
+ if (newValue !== void 0) {
159
+ assertValidReturnValue(kind, newValue);
160
+ if (kind === 0) {
161
+ init = newValue;
162
+ } else if (kind === 1) {
163
+ init = newValue.init;
164
+ get = newValue.get || value.get;
165
+ set = newValue.set || value.set;
166
+ value = {
167
+ get: get,
168
+ set: set
169
+ };
170
+ } else {
171
+ value = newValue;
172
+ }
173
+ }
174
+ } else {
175
+ for(var i = decs.length - 1; i >= 0; i--){
176
+ var dec = decs[i];
177
+ newValue = memberDec(dec, name, desc, initializers, kind, isStatic, isPrivate, metadata, value);
178
+ if (newValue !== void 0) {
179
+ assertValidReturnValue(kind, newValue);
180
+ var newInit;
181
+ if (kind === 0) {
182
+ newInit = newValue;
183
+ } else if (kind === 1) {
184
+ newInit = newValue.init;
185
+ get = newValue.get || value.get;
186
+ set = newValue.set || value.set;
187
+ value = {
188
+ get: get,
189
+ set: set
190
+ };
191
+ } else {
192
+ value = newValue;
193
+ }
194
+ if (newInit !== void 0) {
195
+ if (init === void 0) {
196
+ init = newInit;
197
+ } else if (typeof init === "function") {
198
+ init = [
199
+ init,
200
+ newInit
201
+ ];
202
+ } else {
203
+ init.push(newInit);
204
+ }
205
+ }
206
+ }
207
+ }
208
+ }
209
+ if (kind === 0 || kind === 1) {
210
+ if (init === void 0) {
211
+ init = function(instance, init) {
212
+ return init;
213
+ };
214
+ } else if (typeof init !== "function") {
215
+ var ownInitializers = init;
216
+ init = function(instance, init) {
217
+ var value = init;
218
+ for(var i = 0; i < ownInitializers.length; i++){
219
+ value = ownInitializers[i].call(instance, value);
220
+ }
221
+ return value;
222
+ };
223
+ } else {
224
+ var originalInitializer = init;
225
+ init = function(instance, init) {
226
+ return originalInitializer.call(instance, init);
227
+ };
228
+ }
229
+ ret.push(init);
230
+ }
231
+ if (kind !== 0) {
232
+ if (kind === 1) {
233
+ desc.get = value.get;
234
+ desc.set = value.set;
235
+ } else if (kind === 2) {
236
+ desc.value = value;
237
+ } else if (kind === 3) {
238
+ desc.get = value;
239
+ } else if (kind === 4) {
240
+ desc.set = value;
241
+ }
242
+ if (isPrivate) {
243
+ if (kind === 1) {
244
+ ret.push(function(instance, args) {
245
+ return value.get.call(instance, args);
246
+ });
247
+ ret.push(function(instance, args) {
248
+ return value.set.call(instance, args);
249
+ });
250
+ } else if (kind === 2) {
251
+ ret.push(value);
252
+ } else {
253
+ ret.push(function(instance, args) {
254
+ return value.call(instance, args);
255
+ });
256
+ }
257
+ } else {
258
+ Object.defineProperty(base, name, desc);
259
+ }
260
+ }
261
+ }
262
+ function applyMemberDecs(Class, decInfos, metadata) {
263
+ var ret = [];
264
+ var protoInitializers;
265
+ var staticInitializers;
266
+ var existingProtoNonFields = new Map();
267
+ var existingStaticNonFields = new Map();
268
+ for(var i = 0; i < decInfos.length; i++){
269
+ var decInfo = decInfos[i];
270
+ if (!Array.isArray(decInfo)) continue;
271
+ var kind = decInfo[1];
272
+ var name = decInfo[2];
273
+ var isPrivate = decInfo.length > 3;
274
+ var isStatic = kind >= 5;
275
+ var base;
276
+ var initializers;
277
+ if (isStatic) {
278
+ base = Class;
279
+ kind = kind - 5;
280
+ staticInitializers = staticInitializers || [];
281
+ initializers = staticInitializers;
282
+ } else {
283
+ base = Class.prototype;
284
+ protoInitializers = protoInitializers || [];
285
+ initializers = protoInitializers;
286
+ }
287
+ if (kind !== 0 && !isPrivate) {
288
+ var existingNonFields = isStatic ? existingStaticNonFields : existingProtoNonFields;
289
+ var existingKind = existingNonFields.get(name) || 0;
290
+ if (existingKind === true || existingKind === 3 && kind !== 4 || existingKind === 4 && kind !== 3) {
291
+ throw new Error("Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: " + name);
292
+ } else if (!existingKind && kind > 2) {
293
+ existingNonFields.set(name, kind);
294
+ } else {
295
+ existingNonFields.set(name, true);
296
+ }
297
+ }
298
+ applyMemberDec(ret, base, decInfo, name, kind, isStatic, isPrivate, initializers, metadata);
299
+ }
300
+ pushInitializers(ret, protoInitializers);
301
+ pushInitializers(ret, staticInitializers);
302
+ return ret;
303
+ }
304
+ function pushInitializers(ret, initializers) {
305
+ if (initializers) {
306
+ ret.push(function(instance) {
307
+ for(var i = 0; i < initializers.length; i++){
308
+ initializers[i].call(instance);
309
+ }
310
+ return instance;
311
+ });
312
+ }
313
+ }
314
+ function applyClassDecs(targetClass, classDecs, metadata) {
315
+ if (classDecs.length > 0) {
316
+ var initializers = [];
317
+ var newClass = targetClass;
318
+ var name = targetClass.name;
319
+ for(var i = classDecs.length - 1; i >= 0; i--){
320
+ var decoratorFinishedRef = {
321
+ v: false
322
+ };
323
+ try {
324
+ var nextNewClass = classDecs[i](newClass, {
325
+ kind: "class",
326
+ name: name,
327
+ addInitializer: createAddInitializerMethod(initializers, decoratorFinishedRef),
328
+ metadata
329
+ });
330
+ } finally{
331
+ decoratorFinishedRef.v = true;
332
+ }
333
+ if (nextNewClass !== undefined) {
334
+ assertValidReturnValue(10, nextNewClass);
335
+ newClass = nextNewClass;
336
+ }
337
+ }
338
+ return [
339
+ defineMetadata(newClass, metadata),
340
+ function() {
341
+ for(var i = 0; i < initializers.length; i++){
342
+ initializers[i].call(newClass);
343
+ }
344
+ }
345
+ ];
346
+ }
347
+ }
348
+ function defineMetadata(Class, metadata) {
349
+ return Object.defineProperty(Class, Symbol.metadata || Symbol.for("Symbol.metadata"), {
350
+ configurable: true,
351
+ enumerable: true,
352
+ value: metadata
353
+ });
354
+ }
355
+ return function applyDecs2203R(targetClass, memberDecs, classDecs, parentClass) {
356
+ if (parentClass !== void 0) {
357
+ var parentMetadata = parentClass[Symbol.metadata || Symbol.for("Symbol.metadata")];
358
+ }
359
+ var metadata = Object.create(parentMetadata === void 0 ? null : parentMetadata);
360
+ var e = applyMemberDecs(targetClass, memberDecs, metadata);
361
+ if (!classDecs.length) defineMetadata(targetClass, metadata);
362
+ return {
363
+ e: e,
364
+ get c () {
365
+ return applyClassDecs(targetClass, classDecs, metadata);
366
+ }
367
+ };
368
+ };
369
+ }
370
+ function _apply_decs_2203_r(targetClass, memberDecs, classDecs, parentClass) {
371
+ return (_apply_decs_2203_r = applyDecs2203RFactory())(targetClass, memberDecs, classDecs, parentClass);
6
372
  }
373
+ var _dec, _dec1, _dec2, _dec3, _dec4, _initProto;
7
374
  import { L1_TO_L2_MSG_SUBTREE_HEIGHT, L1_TO_L2_MSG_SUBTREE_ROOT_SIBLING_PATH_LENGTH, NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH, NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP, NUM_BASE_PARITY_PER_ROOT_PARITY } from '@aztec/constants';
8
375
  import { BlockNumber } from '@aztec/foundation/branded-types';
9
376
  import { padArrayEnd } from '@aztec/foundation/collection';
@@ -22,7 +389,15 @@ import { buildHeaderFromCircuitOutputs, getLastSiblingPath, getPublicChonkVerifi
22
389
  import { EpochProvingState } from './epoch-proving-state.js';
23
390
  import { ProvingOrchestratorMetrics } from './orchestrator_metrics.js';
24
391
  import { TxProvingState } from './tx-proving-state.js';
25
- const logger = createLogger('prover-client:orchestrator');
392
+ _dec = trackSpan('ProvingOrchestrator.startNewBlock', (blockNumber)=>({
393
+ [Attributes.BLOCK_NUMBER]: blockNumber
394
+ })), _dec1 = trackSpan('ProvingOrchestrator.addTxs', (txs)=>({
395
+ [Attributes.BLOCK_TXS_COUNT]: txs.length
396
+ })), _dec2 = trackSpan('ProvingOrchestrator.startChonkVerifierCircuits'), _dec3 = trackSpan('ProvingOrchestrator.setBlockCompleted', (blockNumber)=>({
397
+ [Attributes.BLOCK_NUMBER]: blockNumber
398
+ })), _dec4 = trackSpan('ProvingOrchestrator.prepareBaseRollupInputs', (tx)=>({
399
+ [Attributes.TX_HASH]: tx.hash.toString()
400
+ }));
26
401
  /**
27
402
  * Implements an event driven proving scheduler to build the recursive proof tree. The idea being:
28
403
  * 1. Transactions are provided to the scheduler post simulation.
@@ -38,20 +413,53 @@ const logger = createLogger('prover-client:orchestrator');
38
413
  dbProvider;
39
414
  prover;
40
415
  proverId;
416
+ cancelJobsOnStop;
417
+ static{
418
+ ({ e: [_initProto] } = _apply_decs_2203_r(this, [
419
+ [
420
+ _dec,
421
+ 2,
422
+ "startNewBlock"
423
+ ],
424
+ [
425
+ _dec1,
426
+ 2,
427
+ "addTxs"
428
+ ],
429
+ [
430
+ _dec2,
431
+ 2,
432
+ "startChonkVerifierCircuits"
433
+ ],
434
+ [
435
+ _dec3,
436
+ 2,
437
+ "setBlockCompleted"
438
+ ],
439
+ [
440
+ _dec4,
441
+ 2,
442
+ "prepareBaseRollupInputs"
443
+ ]
444
+ ], []));
445
+ }
41
446
  provingState;
42
447
  pendingProvingJobs;
43
448
  provingPromise;
44
449
  metrics;
45
450
  // eslint-disable-next-line aztec-custom/no-non-primitive-in-collections
46
451
  dbs;
47
- constructor(dbProvider, prover, proverId, telemetryClient = getTelemetryClient()){
452
+ logger;
453
+ constructor(dbProvider, prover, proverId, cancelJobsOnStop = false, telemetryClient = getTelemetryClient(), bindings){
48
454
  this.dbProvider = dbProvider;
49
455
  this.prover = prover;
50
456
  this.proverId = proverId;
51
- this.provingState = undefined;
457
+ this.cancelJobsOnStop = cancelJobsOnStop;
458
+ this.provingState = (_initProto(this), undefined);
52
459
  this.pendingProvingJobs = [];
53
460
  this.provingPromise = undefined;
54
461
  this.dbs = new Map();
462
+ this.logger = createLogger('prover-client:orchestrator', bindings);
55
463
  this.metrics = new ProvingOrchestratorMetrics(telemetryClient, 'ProvingOrchestrator');
56
464
  }
57
465
  get tracer() {
@@ -60,6 +468,9 @@ const logger = createLogger('prover-client:orchestrator');
60
468
  getProverId() {
61
469
  return this.proverId;
62
470
  }
471
+ getNumActiveForks() {
472
+ return this.dbs.size;
473
+ }
63
474
  stop() {
64
475
  this.cancel();
65
476
  return Promise.resolve();
@@ -73,11 +484,18 @@ const logger = createLogger('prover-client:orchestrator');
73
484
  status: 'failure',
74
485
  reason
75
486
  }));
76
- logger.info(`Starting epoch ${epochNumber} with ${totalNumCheckpoints} checkpoints.`);
487
+ this.logger.info(`Starting epoch ${epochNumber} with ${totalNumCheckpoints} checkpoints.`);
77
488
  this.provingState = new EpochProvingState(epochNumber, totalNumCheckpoints, finalBlobBatchingChallenges, (provingState)=>this.checkAndEnqueueCheckpointRootRollup(provingState), resolve, reject);
78
489
  this.provingPromise = promise;
79
490
  }
80
- async startNewCheckpoint(checkpointIndex, constants, l1ToL2Messages, totalNumBlocks, headerOfLastBlockInPreviousCheckpoint) {
491
+ /**
492
+ * Starts a new checkpoint.
493
+ * @param checkpointIndex - The index of the checkpoint in the epoch.
494
+ * @param constants - The constants for this checkpoint.
495
+ * @param l1ToL2Messages - The set of L1 to L2 messages to be inserted at the beginning of this checkpoint.
496
+ * @param totalNumBlocks - The total number of blocks expected in the checkpoint (must be at least one).
497
+ * @param headerOfLastBlockInPreviousCheckpoint - The header of the last block in the previous checkpoint.
498
+ */ async startNewCheckpoint(checkpointIndex, constants, l1ToL2Messages, totalNumBlocks, headerOfLastBlockInPreviousCheckpoint) {
81
499
  if (!this.provingState) {
82
500
  throw new Error('Empty epoch proving state. Call startNewEpoch before starting a checkpoint.');
83
501
  }
@@ -88,7 +506,10 @@ const logger = createLogger('prover-client:orchestrator');
88
506
  const lastBlockNumber = headerOfLastBlockInPreviousCheckpoint.globalVariables.blockNumber;
89
507
  const db = await this.dbProvider.fork(lastBlockNumber);
90
508
  const firstBlockNumber = BlockNumber(lastBlockNumber + 1);
91
- this.dbs.set(firstBlockNumber, db);
509
+ this.dbs.set(firstBlockNumber, {
510
+ fork: db,
511
+ cleanupPromise: undefined
512
+ });
92
513
  // Get archive sibling path before any block in this checkpoint lands.
93
514
  const lastArchiveSiblingPath = await getLastSiblingPath(MerkleTreeId.ARCHIVE, db);
94
515
  // Insert all the l1 to l2 messages into the db. And get the states before and after the insertion.
@@ -113,14 +534,17 @@ const logger = createLogger('prover-client:orchestrator');
113
534
  throw new Error(`Checkpoint not accepting further blocks.`);
114
535
  }
115
536
  const constants = checkpointProvingState.constants;
116
- logger.info(`Starting block ${blockNumber} for slot ${constants.slotNumber}.`);
537
+ this.logger.info(`Starting block ${blockNumber} for slot ${constants.slotNumber}.`);
117
538
  // Fork the db only when it's not already set. The db for the first block is set in `startNewCheckpoint`.
118
539
  if (!this.dbs.has(blockNumber)) {
119
540
  // Fork world state at the end of the immediately previous block
120
541
  const db = await this.dbProvider.fork(BlockNumber(blockNumber - 1));
121
- this.dbs.set(blockNumber, db);
542
+ this.dbs.set(blockNumber, {
543
+ fork: db,
544
+ cleanupPromise: undefined
545
+ });
122
546
  }
123
- const db = this.dbs.get(blockNumber);
547
+ const db = this.dbs.get(blockNumber).fork;
124
548
  // Get archive snapshot and sibling path before any txs in this block lands.
125
549
  const lastArchiveTreeSnapshot = await getTreeSnapshot(MerkleTreeId.ARCHIVE, db);
126
550
  const lastArchiveSiblingPath = await getRootTreeSiblingPath(MerkleTreeId.ARCHIVE, db);
@@ -140,7 +564,8 @@ const logger = createLogger('prover-client:orchestrator');
140
564
  const blockEndBlobFields = blockProvingState.getBlockEndBlobFields();
141
565
  await endSpongeBlob.absorb(blockEndBlobFields);
142
566
  blockProvingState.setEndSpongeBlob(endSpongeBlob);
143
- // And also try to accumulate the blobs as far as we can:
567
+ // Try to accumulate the out hashes and blobs as far as we can:
568
+ await this.provingState.accumulateCheckpointOutHashes();
144
569
  await this.provingState.setBlobAccumulators();
145
570
  }
146
571
  }
@@ -154,7 +579,7 @@ const logger = createLogger('prover-client:orchestrator');
154
579
  if (!txs.length) {
155
580
  // To avoid an ugly throw below. If we require an empty block, we can just call setBlockCompleted
156
581
  // on a block with no txs. We cannot do that here because we cannot find the blockNumber without any txs.
157
- logger.warn(`Provided no txs to orchestrator addTxs.`);
582
+ this.logger.warn(`Provided no txs to orchestrator addTxs.`);
158
583
  return;
159
584
  }
160
585
  const blockNumber = BlockNumber(txs[0].globalVariables.blockNumber);
@@ -168,8 +593,8 @@ const logger = createLogger('prover-client:orchestrator');
168
593
  if (!provingState.isAcceptingTxs()) {
169
594
  throw new Error(`Block ${blockNumber} has been initialized with transactions.`);
170
595
  }
171
- logger.info(`Adding ${txs.length} transactions to block ${blockNumber}`);
172
- const db = this.dbs.get(blockNumber);
596
+ this.logger.info(`Adding ${txs.length} transactions to block ${blockNumber}`);
597
+ const db = this.dbs.get(blockNumber).fork;
173
598
  const lastArchive = provingState.lastArchiveTreeSnapshot;
174
599
  const newL1ToL2MessageTreeSnapshot = provingState.newL1ToL2MessageTreeSnapshot;
175
600
  const spongeBlobState = provingState.getStartSpongeBlob().clone();
@@ -179,7 +604,7 @@ const logger = createLogger('prover-client:orchestrator');
179
604
  throw new Error(`Invalid proving state when adding a tx`);
180
605
  }
181
606
  validateTx(tx);
182
- logger.debug(`Received transaction: ${tx.hash}`);
607
+ this.logger.debug(`Received transaction: ${tx.hash}`);
183
608
  const startSpongeBlob = spongeBlobState.clone();
184
609
  const [hints, treeSnapshots] = await this.prepareBaseRollupInputs(tx, lastArchive, newL1ToL2MessageTreeSnapshot, startSpongeBlob, db);
185
610
  if (!provingState.verifyState()) {
@@ -190,10 +615,10 @@ const logger = createLogger('prover-client:orchestrator');
190
615
  const txIndex = provingState.addNewTx(txProvingState);
191
616
  if (txProvingState.requireAvmProof) {
192
617
  this.getOrEnqueueChonkVerifier(provingState, txIndex);
193
- logger.debug(`Enqueueing public VM for tx ${txIndex}`);
618
+ this.logger.debug(`Enqueueing public VM for tx ${txIndex}`);
194
619
  this.enqueueVM(provingState, txIndex);
195
620
  } else {
196
- logger.debug(`Enqueueing base rollup for private-only tx ${txIndex}`);
621
+ this.logger.debug(`Enqueueing base rollup for private-only tx ${txIndex}`);
197
622
  this.enqueueBaseRollup(provingState, txIndex);
198
623
  }
199
624
  } catch (err) {
@@ -207,7 +632,8 @@ const logger = createLogger('prover-client:orchestrator');
207
632
  const blockEndBlobFields = provingState.getBlockEndBlobFields();
208
633
  await spongeBlobState.absorb(blockEndBlobFields);
209
634
  provingState.setEndSpongeBlob(spongeBlobState);
210
- // Txs have been added to the block. Now try to accumulate the blobs as far as we can:
635
+ // Txs have been added to the block. Now try to accumulate the out hashes and blobs as far as we can:
636
+ await this.provingState.accumulateCheckpointOutHashes();
211
637
  await this.provingState.setBlobAccumulators();
212
638
  }
213
639
  /**
@@ -222,7 +648,7 @@ const logger = createLogger('prover-client:orchestrator');
222
648
  const txHash = tx.getTxHash().toString();
223
649
  const privateInputs = getPublicChonkVerifierPrivateInputsFromTx(tx, this.proverId.toField());
224
650
  const tubeProof = promiseWithResolvers();
225
- logger.debug(`Starting chonk verifier circuit for tx ${txHash}`);
651
+ this.logger.debug(`Starting chonk verifier circuit for tx ${txHash}`);
226
652
  this.doEnqueueChonkVerifier(txHash, privateInputs, (proof)=>{
227
653
  tubeProof.resolve(proof);
228
654
  });
@@ -251,16 +677,16 @@ const logger = createLogger('prover-client:orchestrator');
251
677
  throw new Error(`Block ${blockNumber} is still accepting txs. Call setBlockCompleted after all txs have been added.`);
252
678
  }
253
679
  // Given we've applied every change from this block, now assemble the block header:
254
- logger.verbose(`Block ${blockNumber} completed. Assembling header.`);
680
+ this.logger.verbose(`Block ${blockNumber} completed. Assembling header.`);
255
681
  const header = await provingState.buildBlockHeader();
256
682
  if (expectedHeader && !header.equals(expectedHeader)) {
257
- logger.error(`Block header mismatch: header=${header} expectedHeader=${expectedHeader}`);
683
+ this.logger.error(`Block header mismatch: header=${header} expectedHeader=${expectedHeader}`);
258
684
  throw new Error('Block header mismatch');
259
685
  }
260
686
  // Get db for this block
261
- const db = this.dbs.get(provingState.blockNumber);
687
+ const db = this.dbs.get(provingState.blockNumber).fork;
262
688
  // Update the archive tree, so we're ready to start processing the next block:
263
- logger.verbose(`Updating archive tree with block ${provingState.blockNumber} header ${(await header.hash()).toString()}`);
689
+ this.logger.verbose(`Updating archive tree with block ${provingState.blockNumber} header ${(await header.hash()).toString()}`);
264
690
  await db.updateArchive(header);
265
691
  await this.verifyBuiltBlockAgainstSyncedState(provingState);
266
692
  return header;
@@ -269,33 +695,33 @@ const logger = createLogger('prover-client:orchestrator');
269
695
  async verifyBuiltBlockAgainstSyncedState(provingState) {
270
696
  const builtBlockHeader = provingState.getBuiltBlockHeader();
271
697
  if (!builtBlockHeader) {
272
- logger.debug('Block header not built yet, skipping header check.');
698
+ this.logger.debug('Block header not built yet, skipping header check.');
273
699
  return;
274
700
  }
275
701
  const output = provingState.getBlockRootRollupOutput();
276
702
  if (!output) {
277
- logger.debug('Block root rollup proof not built yet, skipping header check.');
703
+ this.logger.debug('Block root rollup proof not built yet, skipping header check.');
278
704
  return;
279
705
  }
280
706
  const header = await buildHeaderFromCircuitOutputs(output);
281
707
  if (!(await header.hash()).equals(await builtBlockHeader.hash())) {
282
- logger.error(`Block header mismatch.\nCircuit: ${inspect(header)}\nComputed: ${inspect(builtBlockHeader)}`);
708
+ this.logger.error(`Block header mismatch.\nCircuit: ${inspect(header)}\nComputed: ${inspect(builtBlockHeader)}`);
283
709
  provingState.reject(`Block header hash mismatch.`);
284
710
  return;
285
711
  }
286
712
  // Get db for this block
287
713
  const blockNumber = provingState.blockNumber;
288
- const db = this.dbs.get(blockNumber);
714
+ const db = this.dbs.get(blockNumber).fork;
289
715
  const newArchive = await getTreeSnapshot(MerkleTreeId.ARCHIVE, db);
290
716
  const syncedArchive = await getTreeSnapshot(MerkleTreeId.ARCHIVE, this.dbProvider.getSnapshot(blockNumber));
291
717
  if (!syncedArchive.equals(newArchive)) {
292
- logger.error(`Archive tree mismatch for block ${blockNumber}: world state synced to ${inspect(syncedArchive)} but built ${inspect(newArchive)}`);
718
+ this.logger.error(`Archive tree mismatch for block ${blockNumber}: world state synced to ${inspect(syncedArchive)} but built ${inspect(newArchive)}`);
293
719
  provingState.reject(`Archive tree mismatch.`);
294
720
  return;
295
721
  }
296
722
  const circuitArchive = output.newArchive;
297
723
  if (!newArchive.equals(circuitArchive)) {
298
- logger.error(`New archive mismatch.\nCircuit: ${output.newArchive}\nComputed: ${newArchive}`);
724
+ this.logger.error(`New archive mismatch.\nCircuit: ${output.newArchive}\nComputed: ${newArchive}`);
299
725
  provingState.reject(`New archive mismatch.`);
300
726
  return;
301
727
  }
@@ -303,14 +729,17 @@ const logger = createLogger('prover-client:orchestrator');
303
729
  // is aborted and never reaches this point, it will leak the fork. We need to add a global cleanup,
304
730
  // but have to make sure it only runs once all operations are completed, otherwise some function here
305
731
  // will attempt to access the fork after it was closed.
306
- logger.debug(`Cleaning up world state fork for ${blockNumber}`);
307
- void this.dbs.get(blockNumber)?.close().then(()=>this.dbs.delete(blockNumber)).catch((err)=>logger.error(`Error closing db for block ${blockNumber}`, err));
732
+ void this.cleanupDBFork(blockNumber);
308
733
  }
309
734
  /**
310
- * Cancel any further proving
735
+ * Cancel any further proving.
736
+ * If cancelJobsOnStop is true, aborts all pending jobs with the broker (which marks them as 'Aborted').
737
+ * If cancelJobsOnStop is false (default), jobs remain in the broker queue and can be reused on restart/reorg.
311
738
  */ cancel() {
312
- for (const controller of this.pendingProvingJobs){
313
- controller.abort();
739
+ if (this.cancelJobsOnStop) {
740
+ for (const controller of this.pendingProvingJobs){
741
+ controller.abort();
742
+ }
314
743
  }
315
744
  this.provingState?.cancel();
316
745
  }
@@ -332,6 +761,22 @@ const logger = createLogger('prover-client:orchestrator');
332
761
  });
333
762
  return epochProofResult;
334
763
  }
764
+ async cleanupDBFork(blockNumber) {
765
+ this.logger.debug(`Cleaning up world state fork for ${blockNumber}`);
766
+ const fork = this.dbs.get(blockNumber);
767
+ if (!fork) {
768
+ return;
769
+ }
770
+ try {
771
+ if (!fork.cleanupPromise) {
772
+ fork.cleanupPromise = fork.fork.close();
773
+ }
774
+ await fork.cleanupPromise;
775
+ this.dbs.delete(blockNumber);
776
+ } catch (err) {
777
+ this.logger.error(`Error closing db for block ${blockNumber}`, err);
778
+ }
779
+ }
335
780
  /**
336
781
  * Enqueue a job to be scheduled
337
782
  * @param provingState - The proving state object being operated on
@@ -339,7 +784,7 @@ const logger = createLogger('prover-client:orchestrator');
339
784
  * @param job - The actual job, returns a promise notifying of the job's completion
340
785
  */ deferredProving(provingState, request, callback) {
341
786
  if (!provingState.verifyState()) {
342
- logger.debug(`Not enqueuing job, state no longer valid`);
787
+ this.logger.debug(`Not enqueuing job, state no longer valid`);
343
788
  return;
344
789
  }
345
790
  const controller = new AbortController();
@@ -354,7 +799,7 @@ const logger = createLogger('prover-client:orchestrator');
354
799
  }
355
800
  const result = await request(controller.signal);
356
801
  if (!provingState.verifyState()) {
357
- logger.debug(`State no longer valid, discarding result`);
802
+ this.logger.debug(`State no longer valid, discarding result`);
358
803
  return;
359
804
  }
360
805
  // we could have been cancelled whilst waiting for the result
@@ -369,7 +814,7 @@ const logger = createLogger('prover-client:orchestrator');
369
814
  // drop this result
370
815
  return;
371
816
  }
372
- logger.error(`Error thrown when proving job`, err);
817
+ this.logger.error(`Error thrown when proving job`, err);
373
818
  provingState.reject(`${err}`);
374
819
  } finally{
375
820
  const index = this.pendingProvingJobs.indexOf(controller);
@@ -425,17 +870,17 @@ const logger = createLogger('prover-client:orchestrator');
425
870
  // Executes the next level of merge if all inputs are available
426
871
  enqueueBaseRollup(provingState, txIndex) {
427
872
  if (!provingState.verifyState()) {
428
- logger.debug('Not running base rollup, state invalid');
873
+ this.logger.debug('Not running base rollup, state invalid');
429
874
  return;
430
875
  }
431
876
  if (!provingState.tryStartProvingBase(txIndex)) {
432
- logger.debug(`Base rollup for tx ${txIndex} already started.`);
877
+ this.logger.debug(`Base rollup for tx ${txIndex} already started.`);
433
878
  return;
434
879
  }
435
880
  const txProvingState = provingState.getTxProvingState(txIndex);
436
881
  const { processedTx } = txProvingState;
437
882
  const { rollupType, inputs } = txProvingState.getBaseRollupTypeAndInputs();
438
- logger.debug(`Enqueuing deferred proving base rollup for ${processedTx.hash.toString()}`);
883
+ this.logger.debug(`Enqueuing deferred proving base rollup for ${processedTx.hash.toString()}`);
439
884
  this.deferredProving(provingState, wrapCallbackInSpan(this.tracer, `ProvingOrchestrator.prover.${inputs instanceof PrivateTxBaseRollupPrivateInputs ? 'getPrivateTxBaseRollupProof' : 'getPublicTxBaseRollupProof'}`, {
440
885
  [Attributes.TX_HASH]: processedTx.hash.toString(),
441
886
  [Attributes.PROTOCOL_CIRCUIT_NAME]: rollupType
@@ -446,7 +891,7 @@ const logger = createLogger('prover-client:orchestrator');
446
891
  return this.prover.getPublicTxBaseRollupProof(inputs, signal, provingState.epochNumber);
447
892
  }
448
893
  }), (result)=>{
449
- logger.debug(`Completed proof for ${rollupType} for tx ${processedTx.hash.toString()}`);
894
+ this.logger.debug(`Completed proof for ${rollupType} for tx ${processedTx.hash.toString()}`);
450
895
  validatePartialState(result.inputs.endTreeSnapshots, txProvingState.treeSnapshots);
451
896
  const leafLocation = provingState.setBaseRollupProof(txIndex, result);
452
897
  if (provingState.totalNumTxs === 1) {
@@ -460,14 +905,14 @@ const logger = createLogger('prover-client:orchestrator');
460
905
  // Once completed, will enqueue the the public tx base rollup.
461
906
  getOrEnqueueChonkVerifier(provingState, txIndex) {
462
907
  if (!provingState.verifyState()) {
463
- logger.debug('Not running chonk verifier circuit, state invalid');
908
+ this.logger.debug('Not running chonk verifier circuit, state invalid');
464
909
  return;
465
910
  }
466
911
  const txProvingState = provingState.getTxProvingState(txIndex);
467
912
  const txHash = txProvingState.processedTx.hash.toString();
468
913
  NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH;
469
914
  const handleResult = (result)=>{
470
- logger.debug(`Got chonk verifier proof for tx index: ${txIndex}`, {
915
+ this.logger.debug(`Got chonk verifier proof for tx index: ${txIndex}`, {
471
916
  txHash
472
917
  });
473
918
  txProvingState.setPublicChonkVerifierProof(result);
@@ -475,18 +920,18 @@ const logger = createLogger('prover-client:orchestrator');
475
920
  this.checkAndEnqueueBaseRollup(provingState, txIndex);
476
921
  };
477
922
  if (this.provingState?.cachedChonkVerifierProofs.has(txHash)) {
478
- logger.debug(`Chonk verifier proof already enqueued for tx index: ${txIndex}`, {
923
+ this.logger.debug(`Chonk verifier proof already enqueued for tx index: ${txIndex}`, {
479
924
  txHash
480
925
  });
481
926
  void this.provingState.cachedChonkVerifierProofs.get(txHash).then(handleResult);
482
927
  return;
483
928
  }
484
- logger.debug(`Enqueuing chonk verifier circuit for tx index: ${txIndex}`);
929
+ this.logger.debug(`Enqueuing chonk verifier circuit for tx index: ${txIndex}`);
485
930
  this.doEnqueueChonkVerifier(txHash, txProvingState.getPublicChonkVerifierPrivateInputs(), handleResult);
486
931
  }
487
932
  doEnqueueChonkVerifier(txHash, inputs, handler, provingState = this.provingState) {
488
933
  if (!provingState.verifyState()) {
489
- logger.debug('Not running chonk verifier circuit, state invalid');
934
+ this.logger.debug('Not running chonk verifier circuit, state invalid');
490
935
  return;
491
936
  }
492
937
  this.deferredProving(provingState, wrapCallbackInSpan(this.tracer, 'ProvingOrchestrator.prover.getPublicChonkVerifierProof', {
@@ -498,11 +943,11 @@ const logger = createLogger('prover-client:orchestrator');
498
943
  // Enqueues the next level of merge if all inputs are available
499
944
  enqueueMergeRollup(provingState, location) {
500
945
  if (!provingState.verifyState()) {
501
- logger.debug('Not running merge rollup. State no longer valid.');
946
+ this.logger.debug('Not running merge rollup. State no longer valid.');
502
947
  return;
503
948
  }
504
949
  if (!provingState.tryStartProvingMerge(location)) {
505
- logger.debug('Merge rollup already started.');
950
+ this.logger.debug('Merge rollup already started.');
506
951
  return;
507
952
  }
508
953
  const inputs = provingState.getMergeRollupInputs(location);
@@ -516,15 +961,15 @@ const logger = createLogger('prover-client:orchestrator');
516
961
  // Executes the block root rollup circuit
517
962
  enqueueBlockRootRollup(provingState) {
518
963
  if (!provingState.verifyState()) {
519
- logger.debug('Not running block root rollup, state no longer valid');
964
+ this.logger.debug('Not running block root rollup, state no longer valid');
520
965
  return;
521
966
  }
522
967
  if (!provingState.tryStartProvingBlockRoot()) {
523
- logger.debug('Block root rollup already started.');
968
+ this.logger.debug('Block root rollup already started.');
524
969
  return;
525
970
  }
526
971
  const { rollupType, inputs } = provingState.getBlockRootRollupTypeAndInputs();
527
- logger.debug(`Enqueuing ${rollupType} for block ${provingState.blockNumber}.`);
972
+ this.logger.debug(`Enqueuing ${rollupType} for block ${provingState.blockNumber}.`);
528
973
  this.deferredProving(provingState, wrapCallbackInSpan(this.tracer, 'ProvingOrchestrator.prover.getBlockRootRollupProof', {
529
974
  [Attributes.PROTOCOL_CIRCUIT_NAME]: rollupType
530
975
  }, (signal)=>{
@@ -540,27 +985,29 @@ const logger = createLogger('prover-client:orchestrator');
540
985
  return this.prover.getBlockRootRollupProof(inputs, signal, provingState.epochNumber);
541
986
  }
542
987
  }), async (result)=>{
543
- // If the proofs were slower than the block header building, then we need to try validating the block header hashes here.
544
- await this.verifyBuiltBlockAgainstSyncedState(provingState);
545
- logger.debug(`Completed ${rollupType} proof for block ${provingState.blockNumber}`);
988
+ this.logger.debug(`Completed ${rollupType} proof for block ${provingState.blockNumber}`);
546
989
  const leafLocation = provingState.setBlockRootRollupProof(result);
547
990
  const checkpointProvingState = provingState.parentCheckpoint;
991
+ // If the proofs were slower than the block header building, then we need to try validating the block header hashes here.
992
+ await this.verifyBuiltBlockAgainstSyncedState(provingState);
548
993
  if (checkpointProvingState.totalNumBlocks === 1) {
549
994
  this.checkAndEnqueueCheckpointRootRollup(checkpointProvingState);
550
995
  } else {
551
996
  this.checkAndEnqueueNextBlockMergeRollup(checkpointProvingState, leafLocation);
552
997
  }
998
+ // We are finished with the block at this point, ensure the fork is cleaned up
999
+ void this.cleanupDBFork(provingState.blockNumber);
553
1000
  });
554
1001
  }
555
1002
  // Executes the base parity circuit and stores the intermediate state for the root parity circuit
556
1003
  // Enqueues the root parity circuit if all inputs are available
557
1004
  enqueueBaseParityCircuit(checkpointProvingState, provingState, baseParityIndex) {
558
1005
  if (!provingState.verifyState()) {
559
- logger.debug('Not running base parity. State no longer valid.');
1006
+ this.logger.debug('Not running base parity. State no longer valid.');
560
1007
  return;
561
1008
  }
562
1009
  if (!provingState.tryStartProvingBaseParity(baseParityIndex)) {
563
- logger.warn(`Base parity ${baseParityIndex} already started.`);
1010
+ this.logger.warn(`Base parity ${baseParityIndex} already started.`);
564
1011
  return;
565
1012
  }
566
1013
  const inputs = checkpointProvingState.getBaseParityInputs(baseParityIndex);
@@ -581,11 +1028,11 @@ const logger = createLogger('prover-client:orchestrator');
581
1028
  // Enqueues the root rollup proof if all inputs are available
582
1029
  enqueueRootParityCircuit(provingState) {
583
1030
  if (!provingState.verifyState()) {
584
- logger.debug('Not running root parity. State no longer valid.');
1031
+ this.logger.debug('Not running root parity. State no longer valid.');
585
1032
  return;
586
1033
  }
587
1034
  if (!provingState.tryStartProvingRootParity()) {
588
- logger.debug('Root parity already started.');
1035
+ this.logger.debug('Root parity already started.');
589
1036
  return;
590
1037
  }
591
1038
  const inputs = provingState.getParityRootInputs();
@@ -600,11 +1047,11 @@ const logger = createLogger('prover-client:orchestrator');
600
1047
  // Enqueues the next level of merge if all inputs are available
601
1048
  enqueueBlockMergeRollup(provingState, location) {
602
1049
  if (!provingState.verifyState()) {
603
- logger.debug('Not running block merge rollup. State no longer valid.');
1050
+ this.logger.debug('Not running block merge rollup. State no longer valid.');
604
1051
  return;
605
1052
  }
606
1053
  if (!provingState.tryStartProvingBlockMerge(location)) {
607
- logger.debug('Block merge rollup already started.');
1054
+ this.logger.debug('Block merge rollup already started.');
608
1055
  return;
609
1056
  }
610
1057
  const inputs = provingState.getBlockMergeRollupInputs(location);
@@ -617,15 +1064,15 @@ const logger = createLogger('prover-client:orchestrator');
617
1064
  }
618
1065
  enqueueCheckpointRootRollup(provingState) {
619
1066
  if (!provingState.verifyState()) {
620
- logger.debug('Not running checkpoint root rollup. State no longer valid.');
1067
+ this.logger.debug('Not running checkpoint root rollup. State no longer valid.');
621
1068
  return;
622
1069
  }
623
1070
  if (!provingState.tryStartProvingCheckpointRoot()) {
624
- logger.debug('Checkpoint root rollup already started.');
1071
+ this.logger.debug('Checkpoint root rollup already started.');
625
1072
  return;
626
1073
  }
627
1074
  const rollupType = provingState.getCheckpointRootRollupType();
628
- logger.debug(`Enqueuing ${rollupType} for checkpoint ${provingState.index}.`);
1075
+ this.logger.debug(`Enqueuing ${rollupType} for checkpoint ${provingState.index}.`);
629
1076
  const inputs = provingState.getCheckpointRootRollupInputs();
630
1077
  this.deferredProving(provingState, wrapCallbackInSpan(this.tracer, 'ProvingOrchestrator.prover.getCheckpointRootRollupProof', {
631
1078
  [Attributes.PROTOCOL_CIRCUIT_NAME]: rollupType
@@ -639,11 +1086,11 @@ const logger = createLogger('prover-client:orchestrator');
639
1086
  const computedEndBlobAccumulatorState = provingState.getEndBlobAccumulator().toBlobAccumulator();
640
1087
  const circuitEndBlobAccumulatorState = result.inputs.endBlobAccumulator;
641
1088
  if (!circuitEndBlobAccumulatorState.equals(computedEndBlobAccumulatorState)) {
642
- logger.error(`Blob accumulator state mismatch.\nCircuit: ${inspect(circuitEndBlobAccumulatorState)}\nComputed: ${inspect(computedEndBlobAccumulatorState)}`);
1089
+ this.logger.error(`Blob accumulator state mismatch.\nCircuit: ${inspect(circuitEndBlobAccumulatorState)}\nComputed: ${inspect(computedEndBlobAccumulatorState)}`);
643
1090
  provingState.reject(`Blob accumulator state mismatch.`);
644
1091
  return;
645
1092
  }
646
- logger.debug(`Completed ${rollupType} proof for checkpoint ${provingState.index}.`);
1093
+ this.logger.debug(`Completed ${rollupType} proof for checkpoint ${provingState.index}.`);
647
1094
  const leafLocation = provingState.setCheckpointRootRollupProof(result);
648
1095
  const epochProvingState = provingState.parentEpoch;
649
1096
  if (epochProvingState.totalNumCheckpoints === 1) {
@@ -655,37 +1102,37 @@ const logger = createLogger('prover-client:orchestrator');
655
1102
  }
656
1103
  enqueueCheckpointMergeRollup(provingState, location) {
657
1104
  if (!provingState.verifyState()) {
658
- logger.debug('Not running checkpoint merge rollup. State no longer valid.');
1105
+ this.logger.debug('Not running checkpoint merge rollup. State no longer valid.');
659
1106
  return;
660
1107
  }
661
1108
  if (!provingState.tryStartProvingCheckpointMerge(location)) {
662
- logger.debug('Checkpoint merge rollup already started.');
1109
+ this.logger.debug('Checkpoint merge rollup already started.');
663
1110
  return;
664
1111
  }
665
1112
  const inputs = provingState.getCheckpointMergeRollupInputs(location);
666
1113
  this.deferredProving(provingState, wrapCallbackInSpan(this.tracer, 'ProvingOrchestrator.prover.getCheckpointMergeRollupProof', {
667
1114
  [Attributes.PROTOCOL_CIRCUIT_NAME]: 'rollup-checkpoint-merge'
668
1115
  }, (signal)=>this.prover.getCheckpointMergeRollupProof(inputs, signal, provingState.epochNumber)), (result)=>{
669
- logger.debug('Completed proof for checkpoint merge rollup.');
1116
+ this.logger.debug('Completed proof for checkpoint merge rollup.');
670
1117
  provingState.setCheckpointMergeRollupProof(location, result);
671
1118
  this.checkAndEnqueueNextCheckpointMergeRollup(provingState, location);
672
1119
  });
673
1120
  }
674
1121
  enqueueEpochPadding(provingState) {
675
1122
  if (!provingState.verifyState()) {
676
- logger.debug('Not running epoch padding. State no longer valid.');
1123
+ this.logger.debug('Not running epoch padding. State no longer valid.');
677
1124
  return;
678
1125
  }
679
1126
  if (!provingState.tryStartProvingPaddingCheckpoint()) {
680
- logger.debug('Padding checkpoint already started.');
1127
+ this.logger.debug('Padding checkpoint already started.');
681
1128
  return;
682
1129
  }
683
- logger.debug('Padding epoch proof with a padding block root proof.');
1130
+ this.logger.debug('Padding epoch proof with a padding block root proof.');
684
1131
  const inputs = provingState.getPaddingCheckpointInputs();
685
1132
  this.deferredProving(provingState, wrapCallbackInSpan(this.tracer, 'ProvingOrchestrator.prover.getCheckpointPaddingRollupProof', {
686
1133
  [Attributes.PROTOCOL_CIRCUIT_NAME]: 'rollup-checkpoint-padding'
687
1134
  }, (signal)=>this.prover.getCheckpointPaddingRollupProof(inputs, signal, provingState.epochNumber)), (result)=>{
688
- logger.debug('Completed proof for padding checkpoint.');
1135
+ this.logger.debug('Completed proof for padding checkpoint.');
689
1136
  provingState.setCheckpointPaddingProof(result);
690
1137
  this.checkAndEnqueueRootRollup(provingState);
691
1138
  });
@@ -693,15 +1140,15 @@ const logger = createLogger('prover-client:orchestrator');
693
1140
  // Executes the root rollup circuit
694
1141
  enqueueRootRollup(provingState) {
695
1142
  if (!provingState.verifyState()) {
696
- logger.debug('Not running root rollup, state no longer valid');
1143
+ this.logger.debug('Not running root rollup, state no longer valid');
697
1144
  return;
698
1145
  }
699
- logger.debug(`Preparing root rollup`);
1146
+ this.logger.debug(`Preparing root rollup`);
700
1147
  const inputs = provingState.getRootRollupInputs();
701
1148
  this.deferredProving(provingState, wrapCallbackInSpan(this.tracer, 'ProvingOrchestrator.prover.getRootRollupProof', {
702
1149
  [Attributes.PROTOCOL_CIRCUIT_NAME]: 'rollup-root'
703
1150
  }, (signal)=>this.prover.getRootRollupProof(inputs, signal, provingState.epochNumber)), (result)=>{
704
- logger.verbose(`Orchestrator completed root rollup for epoch ${provingState.epochNumber}`);
1151
+ this.logger.verbose(`Orchestrator completed root rollup for epoch ${provingState.epochNumber}`);
705
1152
  provingState.setRootRollupProof(result);
706
1153
  provingState.resolve({
707
1154
  status: 'success'
@@ -721,7 +1168,7 @@ const logger = createLogger('prover-client:orchestrator');
721
1168
  }
722
1169
  checkAndEnqueueBlockRootRollup(provingState) {
723
1170
  if (!provingState.isReadyForBlockRootRollup()) {
724
- logger.debug('Not ready for block root rollup');
1171
+ this.logger.debug('Not ready for block root rollup');
725
1172
  return;
726
1173
  }
727
1174
  this.enqueueBlockRootRollup(provingState);
@@ -756,7 +1203,7 @@ const logger = createLogger('prover-client:orchestrator');
756
1203
  }
757
1204
  checkAndEnqueueRootRollup(provingState) {
758
1205
  if (!provingState.isReadyForRootRollup()) {
759
- logger.debug('Not ready for root rollup');
1206
+ this.logger.debug('Not ready for root rollup');
760
1207
  return;
761
1208
  }
762
1209
  this.enqueueRootRollup(provingState);
@@ -768,7 +1215,7 @@ const logger = createLogger('prover-client:orchestrator');
768
1215
  * @param txIndex - The index of the transaction being proven
769
1216
  */ enqueueVM(provingState, txIndex) {
770
1217
  if (!provingState.verifyState()) {
771
- logger.debug(`Not running VM circuit as state is no longer valid`);
1218
+ this.logger.debug(`Not running VM circuit as state is no longer valid`);
772
1219
  return;
773
1220
  }
774
1221
  const txProvingState = provingState.getTxProvingState(txIndex);
@@ -778,9 +1225,9 @@ const logger = createLogger('prover-client:orchestrator');
778
1225
  const inputs = txProvingState.getAvmInputs();
779
1226
  return await this.prover.getAvmProof(inputs, signal, provingState.epochNumber);
780
1227
  });
781
- this.deferredProving(provingState, doAvmProving, (proofAndVk)=>{
782
- logger.debug(`Proven VM for tx index: ${txIndex}`);
783
- txProvingState.setAvmProof(proofAndVk);
1228
+ this.deferredProving(provingState, doAvmProving, (proof)=>{
1229
+ this.logger.debug(`Proven VM for tx index: ${txIndex}`);
1230
+ txProvingState.setAvmProof(proof);
784
1231
  this.checkAndEnqueueBaseRollup(provingState, txIndex);
785
1232
  });
786
1233
  }
@@ -790,30 +1237,7 @@ const logger = createLogger('prover-client:orchestrator');
790
1237
  return;
791
1238
  }
792
1239
  // We must have completed all proving (chonk verifier proof and (if required) vm proof are generated), we now move to the base rollup.
793
- logger.debug(`Public functions completed for tx ${txIndex} enqueueing base rollup`);
1240
+ this.logger.debug(`Public functions completed for tx ${txIndex} enqueueing base rollup`);
794
1241
  this.enqueueBaseRollup(provingState, txIndex);
795
1242
  }
796
1243
  }
797
- _ts_decorate([
798
- trackSpan('ProvingOrchestrator.startNewBlock', (blockNumber)=>({
799
- [Attributes.BLOCK_NUMBER]: blockNumber
800
- }))
801
- ], ProvingOrchestrator.prototype, "startNewBlock", null);
802
- _ts_decorate([
803
- trackSpan('ProvingOrchestrator.addTxs', (txs)=>({
804
- [Attributes.BLOCK_TXS_COUNT]: txs.length
805
- }))
806
- ], ProvingOrchestrator.prototype, "addTxs", null);
807
- _ts_decorate([
808
- trackSpan('ProvingOrchestrator.startChonkVerifierCircuits')
809
- ], ProvingOrchestrator.prototype, "startChonkVerifierCircuits", null);
810
- _ts_decorate([
811
- trackSpan('ProvingOrchestrator.setBlockCompleted', (blockNumber)=>({
812
- [Attributes.BLOCK_NUMBER]: blockNumber
813
- }))
814
- ], ProvingOrchestrator.prototype, "setBlockCompleted", null);
815
- _ts_decorate([
816
- trackSpan('ProvingOrchestrator.prepareBaseRollupInputs', (tx)=>({
817
- [Attributes.TX_HASH]: tx.hash.toString()
818
- }))
819
- ], ProvingOrchestrator.prototype, "prepareBaseRollupInputs", null);