@aztec/sequencer-client 0.0.1-commit.03f7ef2 → 0.0.1-commit.0b941701

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 (74) hide show
  1. package/dest/client/sequencer-client.d.ts +5 -6
  2. package/dest/client/sequencer-client.d.ts.map +1 -1
  3. package/dest/config.d.ts +1 -1
  4. package/dest/config.d.ts.map +1 -1
  5. package/dest/config.js +6 -1
  6. package/dest/global_variable_builder/global_builder.d.ts +4 -4
  7. package/dest/global_variable_builder/global_builder.d.ts.map +1 -1
  8. package/dest/global_variable_builder/global_builder.js +13 -13
  9. package/dest/index.d.ts +2 -3
  10. package/dest/index.d.ts.map +1 -1
  11. package/dest/index.js +1 -2
  12. package/dest/publisher/sequencer-publisher-factory.d.ts +2 -2
  13. package/dest/publisher/sequencer-publisher-factory.d.ts.map +1 -1
  14. package/dest/publisher/sequencer-publisher-metrics.d.ts +1 -1
  15. package/dest/publisher/sequencer-publisher-metrics.d.ts.map +1 -1
  16. package/dest/publisher/sequencer-publisher-metrics.js +15 -86
  17. package/dest/publisher/sequencer-publisher.d.ts +19 -18
  18. package/dest/publisher/sequencer-publisher.d.ts.map +1 -1
  19. package/dest/publisher/sequencer-publisher.js +443 -53
  20. package/dest/sequencer/checkpoint_proposal_job.d.ts +14 -9
  21. package/dest/sequencer/checkpoint_proposal_job.d.ts.map +1 -1
  22. package/dest/sequencer/checkpoint_proposal_job.js +565 -40
  23. package/dest/sequencer/checkpoint_voter.d.ts +3 -2
  24. package/dest/sequencer/checkpoint_voter.d.ts.map +1 -1
  25. package/dest/sequencer/checkpoint_voter.js +34 -10
  26. package/dest/sequencer/index.d.ts +1 -3
  27. package/dest/sequencer/index.d.ts.map +1 -1
  28. package/dest/sequencer/index.js +0 -2
  29. package/dest/sequencer/metrics.d.ts +3 -3
  30. package/dest/sequencer/metrics.d.ts.map +1 -1
  31. package/dest/sequencer/metrics.js +30 -121
  32. package/dest/sequencer/sequencer.d.ts +25 -15
  33. package/dest/sequencer/sequencer.d.ts.map +1 -1
  34. package/dest/sequencer/sequencer.js +486 -42
  35. package/dest/test/index.d.ts +2 -3
  36. package/dest/test/index.d.ts.map +1 -1
  37. package/dest/test/mock_checkpoint_builder.d.ts +23 -11
  38. package/dest/test/mock_checkpoint_builder.d.ts.map +1 -1
  39. package/dest/test/mock_checkpoint_builder.js +50 -7
  40. package/dest/test/utils.d.ts +13 -9
  41. package/dest/test/utils.d.ts.map +1 -1
  42. package/dest/test/utils.js +26 -17
  43. package/package.json +30 -28
  44. package/src/client/sequencer-client.ts +4 -5
  45. package/src/config.ts +5 -0
  46. package/src/global_variable_builder/global_builder.ts +13 -13
  47. package/src/index.ts +1 -9
  48. package/src/publisher/sequencer-publisher-factory.ts +1 -1
  49. package/src/publisher/sequencer-publisher-metrics.ts +14 -70
  50. package/src/publisher/sequencer-publisher.ts +87 -77
  51. package/src/sequencer/checkpoint_proposal_job.ts +201 -59
  52. package/src/sequencer/checkpoint_voter.ts +32 -7
  53. package/src/sequencer/index.ts +0 -2
  54. package/src/sequencer/metrics.ts +23 -131
  55. package/src/sequencer/sequencer.ts +124 -41
  56. package/src/test/index.ts +1 -2
  57. package/src/test/mock_checkpoint_builder.ts +92 -28
  58. package/src/test/utils.ts +55 -28
  59. package/dest/sequencer/block_builder.d.ts +0 -26
  60. package/dest/sequencer/block_builder.d.ts.map +0 -1
  61. package/dest/sequencer/block_builder.js +0 -129
  62. package/dest/sequencer/checkpoint_builder.d.ts +0 -63
  63. package/dest/sequencer/checkpoint_builder.d.ts.map +0 -1
  64. package/dest/sequencer/checkpoint_builder.js +0 -131
  65. package/dest/tx_validator/nullifier_cache.d.ts +0 -14
  66. package/dest/tx_validator/nullifier_cache.d.ts.map +0 -1
  67. package/dest/tx_validator/nullifier_cache.js +0 -24
  68. package/dest/tx_validator/tx_validator_factory.d.ts +0 -18
  69. package/dest/tx_validator/tx_validator_factory.d.ts.map +0 -1
  70. package/dest/tx_validator/tx_validator_factory.js +0 -53
  71. package/src/sequencer/block_builder.ts +0 -217
  72. package/src/sequencer/checkpoint_builder.ts +0 -217
  73. package/src/tx_validator/nullifier_cache.ts +0 -30
  74. package/src/tx_validator/tx_validator_factory.ts +0 -133
@@ -1,4 +1,376 @@
1
- import { createBlobClient } from '@aztec/blob-client/client';
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);
372
+ }
373
+ var _dec, _dec1, _dec2, _initProto;
2
374
  import { Blob, getBlobsPerL1Block, getPrefixedEthBlobCommitments } from '@aztec/blob-lib';
3
375
  import { MULTI_CALL_3_ADDRESS, Multicall3, RollupContract } from '@aztec/ethereum/contracts';
4
376
  import { L1FeeAnalyzer } from '@aztec/ethereum/l1-fee-analysis';
@@ -6,7 +378,7 @@ import { WEI_CONST } from '@aztec/ethereum/l1-tx-utils';
6
378
  import { FormattedViemError, formatViemError, tryExtractEvent } from '@aztec/ethereum/utils';
7
379
  import { sumBigint } from '@aztec/foundation/bigint';
8
380
  import { toHex as toPaddedHex } from '@aztec/foundation/bigint-buffer';
9
- import { BlockNumber, CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
381
+ import { CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
10
382
  import { pick } from '@aztec/foundation/collection';
11
383
  import { EthAddress } from '@aztec/foundation/eth-address';
12
384
  import { Signature } from '@aztec/foundation/eth-signature';
@@ -16,7 +388,7 @@ import { Timer } from '@aztec/foundation/timer';
16
388
  import { EmpireBaseAbi, ErrorsAbi, RollupAbi } from '@aztec/l1-artifacts';
17
389
  import { encodeSlashConsensusVotes } from '@aztec/slasher';
18
390
  import { CommitteeAttestationsAndSigners } from '@aztec/stdlib/block';
19
- import { getTelemetryClient } from '@aztec/telemetry-client';
391
+ import { getTelemetryClient, trackSpan } from '@aztec/telemetry-client';
20
392
  import { encodeFunctionData, toHex } from 'viem';
21
393
  import { SequencerPublisherMetrics } from './sequencer-publisher-metrics.js';
22
394
  export const Actions = [
@@ -32,8 +404,28 @@ export const Actions = [
32
404
  ];
33
405
  // Sorting for actions such that invalidations go before proposals, and proposals go before votes
34
406
  export const compareActions = (a, b)=>Actions.indexOf(a) - Actions.indexOf(b);
407
+ _dec = trackSpan('SequencerPublisher.sendRequests'), _dec1 = trackSpan('SequencerPublisher.validateBlockHeader'), _dec2 = trackSpan('SequencerPublisher.validateCheckpointForSubmission');
35
408
  export class SequencerPublisher {
36
409
  config;
410
+ static{
411
+ ({ e: [_initProto] } = _apply_decs_2203_r(this, [
412
+ [
413
+ _dec,
414
+ 2,
415
+ "sendRequests"
416
+ ],
417
+ [
418
+ _dec1,
419
+ 2,
420
+ "validateBlockHeader"
421
+ ],
422
+ [
423
+ _dec2,
424
+ 2,
425
+ "validateCheckpointForSubmission"
426
+ ]
427
+ ], []));
428
+ }
37
429
  interrupted;
38
430
  metrics;
39
431
  epochCache;
@@ -59,10 +451,11 @@ export class SequencerPublisher {
59
451
  govProposerContract;
60
452
  slashingProposerContract;
61
453
  slashFactoryContract;
454
+ tracer;
62
455
  requests;
63
456
  constructor(config, deps){
64
457
  this.config = config;
65
- this.interrupted = false;
458
+ this.interrupted = (_initProto(this), false);
66
459
  this.governanceLog = createLogger('sequencer:publisher:governance');
67
460
  this.slashingLog = createLogger('sequencer:publisher:slashing');
68
461
  this.lastActions = {};
@@ -72,11 +465,10 @@ export class SequencerPublisher {
72
465
  this.ethereumSlotDuration = BigInt(config.ethereumSlotDuration);
73
466
  this.epochCache = deps.epochCache;
74
467
  this.lastActions = deps.lastActions;
75
- this.blobClient = deps.blobClient ?? createBlobClient(config, {
76
- logger: createLogger('sequencer:blob-client:client')
77
- });
468
+ this.blobClient = deps.blobClient;
78
469
  const telemetry = deps.telemetry ?? getTelemetryClient();
79
470
  this.metrics = deps.metrics ?? new SequencerPublisherMetrics(telemetry, 'SequencerPublisher');
471
+ this.tracer = telemetry.getTracer('SequencerPublisher');
80
472
  this.l1TxUtils = deps.l1TxUtils;
81
473
  this.rollupContract = deps.rollupContract;
82
474
  this.govProposerContract = deps.governanceProposerContract;
@@ -285,7 +677,7 @@ export class SequencerPublisher {
285
677
  'InvalidArchive'
286
678
  ];
287
679
  return this.rollupContract.canProposeAtNextEthBlock(tipArchive.toBuffer(), msgSender.toString(), Number(this.ethereumSlotDuration), {
288
- forcePendingCheckpointNumber: opts.forcePendingBlockNumber !== undefined ? CheckpointNumber.fromBlockNumber(opts.forcePendingBlockNumber) : undefined
680
+ forcePendingCheckpointNumber: opts.forcePendingCheckpointNumber
289
681
  }).catch((err)=>{
290
682
  if (err instanceof FormattedViemError && ignoredErrors.find((e)=>err.message.includes(e))) {
291
683
  this.log.warn(`Failed canProposeAtTime check with ${ignoredErrors.find((e)=>err.message.includes(e))}`, {
@@ -313,12 +705,11 @@ export class SequencerPublisher {
313
705
  [],
314
706
  Signature.empty().toViemSignature(),
315
707
  `0x${'0'.repeat(64)}`,
316
- header.contentCommitment.blobsHash.toString(),
708
+ header.blobsHash.toString(),
317
709
  flags
318
710
  ];
319
711
  const ts = BigInt((await this.l1TxUtils.getBlock()).timestamp + this.ethereumSlotDuration);
320
- const optsForcePendingCheckpointNumber = opts?.forcePendingBlockNumber !== undefined ? CheckpointNumber.fromBlockNumber(opts.forcePendingBlockNumber) : undefined;
321
- const stateOverrides = await this.rollupContract.makePendingCheckpointNumberOverride(optsForcePendingCheckpointNumber);
712
+ const stateOverrides = await this.rollupContract.makePendingCheckpointNumberOverride(opts?.forcePendingCheckpointNumber);
322
713
  let balance = 0n;
323
714
  if (this.config.fishermanMode) {
324
715
  // In fisherman mode, we can't know where the proposer is publishing from
@@ -345,34 +736,34 @@ export class SequencerPublisher {
345
736
  this.log.debug(`Simulated validateHeader`);
346
737
  }
347
738
  /**
348
- * Simulate making a call to invalidate a block with invalid attestations. Returns undefined if no need to invalidate.
349
- * @param block - The block to invalidate and the criteria for invalidation (as returned by the archiver)
350
- */ async simulateInvalidateBlock(validationResult) {
739
+ * Simulate making a call to invalidate a checkpoint with invalid attestations. Returns undefined if no need to invalidate.
740
+ * @param validationResult - The validation result indicating which checkpoint to invalidate (as returned by the archiver)
741
+ */ async simulateInvalidateCheckpoint(validationResult) {
351
742
  if (validationResult.valid) {
352
743
  return undefined;
353
744
  }
354
- const { reason, block } = validationResult;
355
- const blockNumber = block.blockNumber;
745
+ const { reason, checkpoint } = validationResult;
746
+ const checkpointNumber = checkpoint.checkpointNumber;
356
747
  const logData = {
357
- ...block,
748
+ ...checkpoint,
358
749
  reason
359
750
  };
360
- const currentBlockNumber = await this.rollupContract.getCheckpointNumber();
361
- if (currentBlockNumber < validationResult.block.blockNumber) {
362
- this.log.verbose(`Skipping block ${blockNumber} invalidation since it has already been removed from the pending chain`, {
363
- currentBlockNumber,
751
+ const currentCheckpointNumber = await this.rollupContract.getCheckpointNumber();
752
+ if (currentCheckpointNumber < checkpointNumber) {
753
+ this.log.verbose(`Skipping checkpoint ${checkpointNumber} invalidation since it has already been removed from the pending chain`, {
754
+ currentCheckpointNumber,
364
755
  ...logData
365
756
  });
366
757
  return undefined;
367
758
  }
368
- const request = this.buildInvalidateBlockRequest(validationResult);
369
- this.log.debug(`Simulating invalidate block ${blockNumber}`, {
759
+ const request = this.buildInvalidateCheckpointRequest(validationResult);
760
+ this.log.debug(`Simulating invalidate checkpoint ${checkpointNumber}`, {
370
761
  ...logData,
371
762
  request
372
763
  });
373
764
  try {
374
765
  const { gasUsed } = await this.l1TxUtils.simulate(request, undefined, undefined, ErrorsAbi);
375
- this.log.verbose(`Simulation for invalidate block ${blockNumber} succeeded`, {
766
+ this.log.verbose(`Simulation for invalidate checkpoint ${checkpointNumber} succeeded`, {
376
767
  ...logData,
377
768
  request,
378
769
  gasUsed
@@ -380,55 +771,55 @@ export class SequencerPublisher {
380
771
  return {
381
772
  request,
382
773
  gasUsed,
383
- blockNumber,
384
- forcePendingBlockNumber: BlockNumber(blockNumber - 1),
774
+ checkpointNumber,
775
+ forcePendingCheckpointNumber: CheckpointNumber(checkpointNumber - 1),
385
776
  reason
386
777
  };
387
778
  } catch (err) {
388
779
  const viemError = formatViemError(err);
389
- // If the error is due to the block not being in the pending chain, and it was indeed removed by someone else,
390
- // we can safely ignore it and return undefined so we go ahead with block building.
780
+ // If the error is due to the checkpoint not being in the pending chain, and it was indeed removed by someone else,
781
+ // we can safely ignore it and return undefined so we go ahead with checkpoint building.
391
782
  if (viemError.message?.includes('Rollup__BlockNotInPendingChain')) {
392
- this.log.verbose(`Simulation for invalidate block ${blockNumber} failed due to block not being in pending chain`, {
783
+ this.log.verbose(`Simulation for invalidate checkpoint ${checkpointNumber} failed due to checkpoint not being in pending chain`, {
393
784
  ...logData,
394
785
  request,
395
786
  error: viemError.message
396
787
  });
397
- const latestPendingBlockNumber = await this.rollupContract.getCheckpointNumber();
398
- if (latestPendingBlockNumber < blockNumber) {
399
- this.log.verbose(`Block number ${blockNumber} has already been invalidated`, {
788
+ const latestPendingCheckpointNumber = await this.rollupContract.getCheckpointNumber();
789
+ if (latestPendingCheckpointNumber < checkpointNumber) {
790
+ this.log.verbose(`Checkpoint ${checkpointNumber} has already been invalidated`, {
400
791
  ...logData
401
792
  });
402
793
  return undefined;
403
794
  } else {
404
- this.log.error(`Simulation for invalidate ${blockNumber} failed and it is still in pending chain`, viemError, logData);
405
- throw new Error(`Failed to simulate invalidate block ${blockNumber} while it is still in pending chain`, {
795
+ this.log.error(`Simulation for invalidate checkpoint ${checkpointNumber} failed and it is still in pending chain`, viemError, logData);
796
+ throw new Error(`Failed to simulate invalidate checkpoint ${checkpointNumber} while it is still in pending chain`, {
406
797
  cause: viemError
407
798
  });
408
799
  }
409
800
  }
410
- // Otherwise, throw. We cannot build the next block if we cannot invalidate the previous one.
411
- this.log.error(`Simulation for invalidate block ${blockNumber} failed`, viemError, logData);
412
- throw new Error(`Failed to simulate invalidate block ${blockNumber}`, {
801
+ // Otherwise, throw. We cannot build the next checkpoint if we cannot invalidate the previous one.
802
+ this.log.error(`Simulation for invalidate checkpoint ${checkpointNumber} failed`, viemError, logData);
803
+ throw new Error(`Failed to simulate invalidate checkpoint ${checkpointNumber}`, {
413
804
  cause: viemError
414
805
  });
415
806
  }
416
807
  }
417
- buildInvalidateBlockRequest(validationResult) {
808
+ buildInvalidateCheckpointRequest(validationResult) {
418
809
  if (validationResult.valid) {
419
- throw new Error('Cannot invalidate a valid block');
810
+ throw new Error('Cannot invalidate a valid checkpoint');
420
811
  }
421
- const { block, committee, reason } = validationResult;
812
+ const { checkpoint, committee, reason } = validationResult;
422
813
  const logData = {
423
- ...block,
814
+ ...checkpoint,
424
815
  reason
425
816
  };
426
- this.log.debug(`Simulating invalidate block ${block.blockNumber}`, logData);
817
+ this.log.debug(`Building invalidate checkpoint ${checkpoint.checkpointNumber} request`, logData);
427
818
  const attestationsAndSigners = new CommitteeAttestationsAndSigners(validationResult.attestations).getPackedAttestations();
428
819
  if (reason === 'invalid-attestation') {
429
- return this.rollupContract.buildInvalidateBadAttestationRequest(CheckpointNumber.fromBlockNumber(block.blockNumber), attestationsAndSigners, committee, validationResult.invalidIndex);
820
+ return this.rollupContract.buildInvalidateBadAttestationRequest(checkpoint.checkpointNumber, attestationsAndSigners, committee, validationResult.invalidIndex);
430
821
  } else if (reason === 'insufficient-attestations') {
431
- return this.rollupContract.buildInvalidateInsufficientAttestationsRequest(CheckpointNumber.fromBlockNumber(block.blockNumber), attestationsAndSigners, committee);
822
+ return this.rollupContract.buildInvalidateInsufficientAttestationsRequest(checkpoint.checkpointNumber, attestationsAndSigners, committee);
432
823
  } else {
433
824
  const _ = reason;
434
825
  throw new Error(`Unknown reason for invalidation`);
@@ -670,7 +1061,7 @@ export class SequencerPublisher {
670
1061
  this.log.error(`Checkpoint validation failed. ${err instanceof Error ? err.message : 'No error message'}`, err, {
671
1062
  ...checkpoint.getStats(),
672
1063
  slotNumber: checkpoint.header.slotNumber,
673
- forcePendingBlockNumber: opts.forcePendingBlockNumber
1064
+ forcePendingCheckpointNumber: opts.forcePendingCheckpointNumber
674
1065
  });
675
1066
  throw err;
676
1067
  }
@@ -680,20 +1071,20 @@ export class SequencerPublisher {
680
1071
  });
681
1072
  await this.addProposeTx(checkpoint, proposeTxArgs, opts, ts);
682
1073
  }
683
- enqueueInvalidateBlock(request, opts = {}) {
1074
+ enqueueInvalidateCheckpoint(request, opts = {}) {
684
1075
  if (!request) {
685
1076
  return;
686
1077
  }
687
1078
  // We issued the simulation against the rollup contract, so we need to account for the overhead of the multicall3
688
1079
  const gasLimit = this.l1TxUtils.bumpGasLimit(BigInt(Math.ceil(Number(request.gasUsed) * 64 / 63)));
689
- const { gasUsed, blockNumber } = request;
1080
+ const { gasUsed, checkpointNumber } = request;
690
1081
  const logData = {
691
1082
  gasUsed,
692
- blockNumber,
1083
+ checkpointNumber,
693
1084
  gasLimit,
694
1085
  opts
695
1086
  };
696
- this.log.verbose(`Enqueuing invalidate block request`, logData);
1087
+ this.log.verbose(`Enqueuing invalidate checkpoint request`, logData);
697
1088
  this.addRequest({
698
1089
  action: `invalidate-by-${request.reason}`,
699
1090
  request: request.request,
@@ -705,12 +1096,12 @@ export class SequencerPublisher {
705
1096
  checkSuccess: (_req, result)=>{
706
1097
  const success = result && result.receipt && result.receipt.status === 'success' && tryExtractEvent(result.receipt.logs, this.rollupContract.address, RollupAbi, 'CheckpointInvalidated');
707
1098
  if (!success) {
708
- this.log.warn(`Invalidate block ${request.blockNumber} failed`, {
1099
+ this.log.warn(`Invalidate checkpoint ${request.checkpointNumber} failed`, {
709
1100
  ...result,
710
1101
  ...logData
711
1102
  });
712
1103
  } else {
713
- this.log.info(`Invalidate block ${request.blockNumber} succeeded`, {
1104
+ this.log.info(`Invalidate checkpoint ${request.checkpointNumber} succeeded`, {
714
1105
  ...result,
715
1106
  ...logData
716
1107
  });
@@ -860,8 +1251,7 @@ export class SequencerPublisher {
860
1251
  args
861
1252
  });
862
1253
  // override the pending checkpoint number if requested
863
- const optsForcePendingCheckpointNumber = options.forcePendingBlockNumber !== undefined ? CheckpointNumber.fromBlockNumber(options.forcePendingBlockNumber) : undefined;
864
- const forcePendingCheckpointNumberStateDiff = (optsForcePendingCheckpointNumber !== undefined ? await this.rollupContract.makePendingCheckpointNumberOverride(optsForcePendingCheckpointNumber) : []).flatMap((override)=>override.stateDiff ?? []);
1254
+ const forcePendingCheckpointNumberStateDiff = (options.forcePendingCheckpointNumber !== undefined ? await this.rollupContract.makePendingCheckpointNumberOverride(options.forcePendingCheckpointNumber) : []).flatMap((override)=>override.stateDiff ?? []);
865
1255
  const stateOverrides = [
866
1256
  {
867
1257
  address: this.rollupContract.address,