@aztec/sequencer-client 0.43.0 → 0.45.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dest/client/sequencer-client.d.ts +2 -1
- package/dest/client/sequencer-client.d.ts.map +1 -1
- package/dest/client/sequencer-client.js +4 -4
- package/dest/sequencer/sequencer.d.ts +4 -1
- package/dest/sequencer/sequencer.d.ts.map +1 -1
- package/dest/sequencer/sequencer.js +280 -261
- package/package.json +24 -15
- package/src/client/sequencer-client.ts +9 -1
- package/src/sequencer/sequencer.ts +95 -81
|
@@ -2,6 +2,7 @@ import { type L1ToL2MessageSource, type L2BlockSource } from '@aztec/circuit-typ
|
|
|
2
2
|
import { type BlockProver } from '@aztec/circuit-types/interfaces';
|
|
3
3
|
import { type P2P } from '@aztec/p2p';
|
|
4
4
|
import { type SimulationProvider } from '@aztec/simulator';
|
|
5
|
+
import { type TelemetryClient } from '@aztec/telemetry-client';
|
|
5
6
|
import { type ContractDataSource } from '@aztec/types/contracts';
|
|
6
7
|
import { type WorldStateSynchronizer } from '@aztec/world-state';
|
|
7
8
|
import { type SequencerClientConfig } from '../config.js';
|
|
@@ -24,7 +25,7 @@ export declare class SequencerClient {
|
|
|
24
25
|
* @param simulationProvider - An instance of a simulation provider
|
|
25
26
|
* @returns A new running instance.
|
|
26
27
|
*/
|
|
27
|
-
static new(config: SequencerClientConfig, p2pClient: P2P, worldStateSynchronizer: WorldStateSynchronizer, contractDataSource: ContractDataSource, l2BlockSource: L2BlockSource, l1ToL2MessageSource: L1ToL2MessageSource, prover: BlockProver, simulationProvider: SimulationProvider): Promise<SequencerClient>;
|
|
28
|
+
static new(config: SequencerClientConfig, p2pClient: P2P, worldStateSynchronizer: WorldStateSynchronizer, contractDataSource: ContractDataSource, l2BlockSource: L2BlockSource, l1ToL2MessageSource: L1ToL2MessageSource, prover: BlockProver, simulationProvider: SimulationProvider, telemetryClient: TelemetryClient): Promise<SequencerClient>;
|
|
28
29
|
/**
|
|
29
30
|
* Updates sequencer config.
|
|
30
31
|
* @param config - New parameters.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sequencer-client.d.ts","sourceRoot":"","sources":["../../src/client/sequencer-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAE,KAAK,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACpF,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,KAAK,GAAG,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAA0B,KAAK,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACnF,OAAO,EAAE,KAAK,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,KAAK,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAEjE,OAAO,EAAE,KAAK,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAG1D,OAAO,EAAE,SAAS,EAAE,KAAK,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAGxE;;GAEG;AACH,qBAAa,eAAe;IACd,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE,SAAS;IAExC;;;;;;;;;;;OAWG;WACiB,GAAG,CACrB,MAAM,EAAE,qBAAqB,EAC7B,SAAS,EAAE,GAAG,EACd,sBAAsB,EAAE,sBAAsB,EAC9C,kBAAkB,EAAE,kBAAkB,EACtC,aAAa,EAAE,aAAa,EAC5B,mBAAmB,EAAE,mBAAmB,EACxC,MAAM,EAAE,WAAW,EACnB,kBAAkB,EAAE,kBAAkB;
|
|
1
|
+
{"version":3,"file":"sequencer-client.d.ts","sourceRoot":"","sources":["../../src/client/sequencer-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAE,KAAK,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACpF,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,KAAK,GAAG,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAA0B,KAAK,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACnF,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,KAAK,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,KAAK,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAEjE,OAAO,EAAE,KAAK,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAG1D,OAAO,EAAE,SAAS,EAAE,KAAK,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAGxE;;GAEG;AACH,qBAAa,eAAe;IACd,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE,SAAS;IAExC;;;;;;;;;;;OAWG;WACiB,GAAG,CACrB,MAAM,EAAE,qBAAqB,EAC7B,SAAS,EAAE,GAAG,EACd,sBAAsB,EAAE,sBAAsB,EAC9C,kBAAkB,EAAE,kBAAkB,EACtC,aAAa,EAAE,aAAa,EAC5B,mBAAmB,EAAE,mBAAmB,EACxC,MAAM,EAAE,WAAW,EACnB,kBAAkB,EAAE,kBAAkB,EACtC,eAAe,EAAE,eAAe;IA+BlC;;;OAGG;IACI,qBAAqB,CAAC,MAAM,EAAE,eAAe;IAIpD;;OAEG;IACU,IAAI;IAIjB;;OAEG;IACI,OAAO;IAId,IAAI,QAAQ,yCAEX;IAED,IAAI,YAAY,2CAEf;CACF"}
|
|
@@ -22,12 +22,12 @@ export class SequencerClient {
|
|
|
22
22
|
* @param simulationProvider - An instance of a simulation provider
|
|
23
23
|
* @returns A new running instance.
|
|
24
24
|
*/
|
|
25
|
-
static async new(config, p2pClient, worldStateSynchronizer, contractDataSource, l2BlockSource, l1ToL2MessageSource, prover, simulationProvider) {
|
|
25
|
+
static async new(config, p2pClient, worldStateSynchronizer, contractDataSource, l2BlockSource, l1ToL2MessageSource, prover, simulationProvider, telemetryClient) {
|
|
26
26
|
const publisher = getL1Publisher(config);
|
|
27
27
|
const globalsBuilder = getGlobalVariableBuilder(config);
|
|
28
28
|
const merkleTreeDb = worldStateSynchronizer.getLatest();
|
|
29
|
-
const publicProcessorFactory = new PublicProcessorFactory(merkleTreeDb, contractDataSource, simulationProvider);
|
|
30
|
-
const sequencer = new Sequencer(publisher, globalsBuilder, p2pClient, worldStateSynchronizer, prover, l2BlockSource, l1ToL2MessageSource, publicProcessorFactory, new TxValidatorFactory(merkleTreeDb, contractDataSource, !!config.enforceFees), config);
|
|
29
|
+
const publicProcessorFactory = new PublicProcessorFactory(merkleTreeDb, contractDataSource, simulationProvider, telemetryClient);
|
|
30
|
+
const sequencer = new Sequencer(publisher, globalsBuilder, p2pClient, worldStateSynchronizer, prover, l2BlockSource, l1ToL2MessageSource, publicProcessorFactory, new TxValidatorFactory(merkleTreeDb, contractDataSource, !!config.enforceFees), telemetryClient, config);
|
|
31
31
|
await sequencer.start();
|
|
32
32
|
return new SequencerClient(sequencer);
|
|
33
33
|
}
|
|
@@ -57,4 +57,4 @@ export class SequencerClient {
|
|
|
57
57
|
return this.sequencer.feeRecipient;
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VxdWVuY2VyLWNsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jbGllbnQvc2VxdWVuY2VyLWNsaWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQUUsc0JBQXNCLEVBQTJCLE1BQU0sa0JBQWtCLENBQUM7QUFNbkYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDL0UsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxTQUFTLEVBQXdCLE1BQU0sdUJBQXVCLENBQUM7QUFDeEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFN0U7O0dBRUc7QUFDSCxNQUFNLE9BQU8sZUFBZTtJQUMxQixZQUFvQixTQUFvQjtRQUFwQixjQUFTLEdBQVQsU0FBUyxDQUFXO0lBQUcsQ0FBQztJQUU1Qzs7Ozs7Ozs7Ozs7T0FXRztJQUNJLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUNyQixNQUE2QixFQUM3QixTQUFjLEVBQ2Qsc0JBQThDLEVBQzlDLGtCQUFzQyxFQUN0QyxhQUE0QixFQUM1QixtQkFBd0MsRUFDeEMsTUFBbUIsRUFDbkIsa0JBQXNDLEVBQ3RDLGVBQWdDO1FBRWhDLE1BQU0sU0FBUyxHQUFHLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN6QyxNQUFNLGNBQWMsR0FBRyx3QkFBd0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN4RCxNQUFNLFlBQVksR0FBRyxzQkFBc0IsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUV4RCxNQUFNLHNCQUFzQixHQUFHLElBQUksc0JBQXNCLENBQ3ZELFlBQVksRUFDWixrQkFBa0IsRUFDbEIsa0JBQWtCLEVBQ2xCLGVBQWUsQ0FDaEIsQ0FBQztRQUVGLE1BQU0sU0FBUyxHQUFHLElBQUksU0FBUyxDQUM3QixTQUFTLEVBQ1QsY0FBYyxFQUNkLFNBQVMsRUFDVCxzQkFBc0IsRUFDdEIsTUFBTSxFQUNOLGFBQWEsRUFDYixtQkFBbUIsRUFDbkIsc0JBQXNCLEVBQ3RCLElBQUksa0JBQWtCLENBQUMsWUFBWSxFQUFFLGtCQUFrQixFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLEVBQzlFLGVBQWUsRUFDZixNQUFNLENBQ1AsQ0FBQztRQUVGLE1BQU0sU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3hCLE9BQU8sSUFBSSxlQUFlLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVEOzs7T0FHRztJQUNJLHFCQUFxQixDQUFDLE1BQXVCO1FBQ2xELElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxJQUFJO1FBQ2YsTUFBTSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFFRDs7T0FFRztJQUNJLE9BQU87UUFDWixJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxJQUFJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDO0lBQ3JDLENBQUM7Q0FDRiJ9
|
|
@@ -4,6 +4,7 @@ import { AztecAddress, EthAddress, type Proof } from '@aztec/circuits.js';
|
|
|
4
4
|
import { Fr } from '@aztec/foundation/fields';
|
|
5
5
|
import { type P2P } from '@aztec/p2p';
|
|
6
6
|
import { type PublicProcessorFactory } from '@aztec/simulator';
|
|
7
|
+
import { type TelemetryClient, type Tracer } from '@aztec/telemetry-client';
|
|
7
8
|
import { type WorldStateSynchronizer } from '@aztec/world-state';
|
|
8
9
|
import { type GlobalVariableBuilder } from '../global_variable_builder/global_builder.js';
|
|
9
10
|
import { type L1Publisher } from '../publisher/l1-publisher.js';
|
|
@@ -40,7 +41,8 @@ export declare class Sequencer {
|
|
|
40
41
|
private allowedInSetup;
|
|
41
42
|
private allowedInTeardown;
|
|
42
43
|
private maxBlockSizeInBytes;
|
|
43
|
-
|
|
44
|
+
readonly tracer: Tracer;
|
|
45
|
+
constructor(publisher: L1Publisher, globalsBuilder: GlobalVariableBuilder, p2pClient: P2P, worldState: WorldStateSynchronizer, prover: BlockProver, l2BlockSource: L2BlockSource, l1ToL2MessageSource: L1ToL2MessageSource, publicProcessorFactory: PublicProcessorFactory, txValidatorFactory: TxValidatorFactory, telemetry: TelemetryClient, config?: SequencerConfig, log?: import("@aztec/foundation/log").Logger);
|
|
44
46
|
/**
|
|
45
47
|
* Updates sequencer config.
|
|
46
48
|
* @param config - New parameters.
|
|
@@ -70,6 +72,7 @@ export declare class Sequencer {
|
|
|
70
72
|
* Grabs up to maxTxsPerBlock from the p2p client, constructs a block, and pushes it to L1.
|
|
71
73
|
*/
|
|
72
74
|
protected work(): Promise<void>;
|
|
75
|
+
private buildBlockAndPublish;
|
|
73
76
|
/**
|
|
74
77
|
* Publishes the L2Block to the rollup contract.
|
|
75
78
|
* @param block - The L2Block to be published.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sequencer.d.ts","sourceRoot":"","sources":["../../src/sequencer/sequencer.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,mBAAmB,EACxB,KAAK,OAAO,EACZ,KAAK,aAAa,EAClB,KAAK,WAAW,EAChB,EAAE,EACF,KAAK,WAAW,EACjB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAGL,KAAK,WAAW,EAEjB,MAAM,iCAAiC,CAAC;AAEzC,OAAO,EAAE,YAAY,EAAE,UAAU,
|
|
1
|
+
{"version":3,"file":"sequencer.d.ts","sourceRoot":"","sources":["../../src/sequencer/sequencer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
1
2
|
import { Tx, } from '@aztec/circuit-types';
|
|
2
3
|
import { BlockProofError, PROVING_STATUS, } from '@aztec/circuit-types/interfaces';
|
|
3
4
|
import { AztecAddress, EthAddress } from '@aztec/circuits.js';
|
|
@@ -5,6 +6,7 @@ import { Fr } from '@aztec/foundation/fields';
|
|
|
5
6
|
import { createDebugLogger } from '@aztec/foundation/log';
|
|
6
7
|
import { RunningPromise } from '@aztec/foundation/running-promise';
|
|
7
8
|
import { Timer, elapsed } from '@aztec/foundation/timer';
|
|
9
|
+
import { Attributes, trackSpan } from '@aztec/telemetry-client';
|
|
8
10
|
/**
|
|
9
11
|
* Sequencer client
|
|
10
12
|
* - Wins a period of time to become the sequencer (depending on finalized protocol).
|
|
@@ -14,281 +16,298 @@ import { Timer, elapsed } from '@aztec/foundation/timer';
|
|
|
14
16
|
* - Receives results to those proofs from the network (repeats as necessary) (not for this milestone).
|
|
15
17
|
* - Publishes L1 tx(s) to the rollup contract via RollupPublisher.
|
|
16
18
|
*/
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
async stop() {
|
|
88
|
-
this.log.debug(`Stopping sequencer`);
|
|
89
|
-
await this.runningPromise?.stop();
|
|
90
|
-
this.publisher.interrupt();
|
|
91
|
-
this.state = SequencerState.STOPPED;
|
|
92
|
-
this.log.info('Stopped sequencer');
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* Starts a previously stopped sequencer.
|
|
96
|
-
*/
|
|
97
|
-
restart() {
|
|
98
|
-
this.log.info('Restarting sequencer');
|
|
99
|
-
this.publisher.restart();
|
|
100
|
-
this.runningPromise.start();
|
|
101
|
-
this.state = SequencerState.IDLE;
|
|
102
|
-
}
|
|
103
|
-
/**
|
|
104
|
-
* Returns the current state of the sequencer.
|
|
105
|
-
* @returns An object with a state entry with one of SequencerState.
|
|
106
|
-
*/
|
|
107
|
-
status() {
|
|
108
|
-
return { state: this.state };
|
|
109
|
-
}
|
|
110
|
-
async initialSync() {
|
|
111
|
-
// TODO: Should we wait for world state to be ready, or is the caller expected to run await start?
|
|
112
|
-
this.lastPublishedBlock = await this.worldState.status().then((s) => s.syncedToL2Block);
|
|
113
|
-
}
|
|
114
|
-
/**
|
|
115
|
-
* Grabs up to maxTxsPerBlock from the p2p client, constructs a block, and pushes it to L1.
|
|
116
|
-
*/
|
|
117
|
-
async work() {
|
|
118
|
-
try {
|
|
119
|
-
// Update state when the previous block has been synced
|
|
120
|
-
const prevBlockSynced = await this.isBlockSynced();
|
|
121
|
-
if (prevBlockSynced && this.state === SequencerState.PUBLISHING_BLOCK) {
|
|
122
|
-
this.log.debug(`Block has been synced`);
|
|
19
|
+
let Sequencer = (() => {
|
|
20
|
+
var _a;
|
|
21
|
+
let _instanceExtraInitializers = [];
|
|
22
|
+
let _buildBlockAndPublish_decorators;
|
|
23
|
+
let _publishL2Block_decorators;
|
|
24
|
+
return _a = class Sequencer {
|
|
25
|
+
constructor(publisher, globalsBuilder, p2pClient, worldState, prover, l2BlockSource, l1ToL2MessageSource, publicProcessorFactory, txValidatorFactory, telemetry, config = {}, log = createDebugLogger('aztec:sequencer')) {
|
|
26
|
+
this.publisher = (__runInitializers(this, _instanceExtraInitializers), publisher);
|
|
27
|
+
this.globalsBuilder = globalsBuilder;
|
|
28
|
+
this.p2pClient = p2pClient;
|
|
29
|
+
this.worldState = worldState;
|
|
30
|
+
this.prover = prover;
|
|
31
|
+
this.l2BlockSource = l2BlockSource;
|
|
32
|
+
this.l1ToL2MessageSource = l1ToL2MessageSource;
|
|
33
|
+
this.publicProcessorFactory = publicProcessorFactory;
|
|
34
|
+
this.txValidatorFactory = txValidatorFactory;
|
|
35
|
+
this.log = log;
|
|
36
|
+
this.pollingIntervalMs = 1000;
|
|
37
|
+
this.maxTxsPerBlock = 32;
|
|
38
|
+
this.minTxsPerBLock = 1;
|
|
39
|
+
// TODO: zero values should not be allowed for the following 2 values in PROD
|
|
40
|
+
this._coinbase = EthAddress.ZERO;
|
|
41
|
+
this._feeRecipient = AztecAddress.ZERO;
|
|
42
|
+
this.lastPublishedBlock = 0;
|
|
43
|
+
this.state = SequencerState.STOPPED;
|
|
44
|
+
this.allowedInSetup = [];
|
|
45
|
+
this.allowedInTeardown = [];
|
|
46
|
+
this.maxBlockSizeInBytes = 1024 * 1024;
|
|
47
|
+
this.updateConfig(config);
|
|
48
|
+
this.tracer = telemetry.getTracer('Sequencer');
|
|
49
|
+
this.log.verbose(`Initialized sequencer with ${this.minTxsPerBLock}-${this.maxTxsPerBlock} txs per block.`);
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Updates sequencer config.
|
|
53
|
+
* @param config - New parameters.
|
|
54
|
+
*/
|
|
55
|
+
updateConfig(config) {
|
|
56
|
+
if (config.transactionPollingIntervalMS) {
|
|
57
|
+
this.pollingIntervalMs = config.transactionPollingIntervalMS;
|
|
58
|
+
}
|
|
59
|
+
if (config.maxTxsPerBlock) {
|
|
60
|
+
this.maxTxsPerBlock = config.maxTxsPerBlock;
|
|
61
|
+
}
|
|
62
|
+
if (config.minTxsPerBlock) {
|
|
63
|
+
this.minTxsPerBLock = config.minTxsPerBlock;
|
|
64
|
+
}
|
|
65
|
+
if (config.coinbase) {
|
|
66
|
+
this._coinbase = config.coinbase;
|
|
67
|
+
}
|
|
68
|
+
if (config.feeRecipient) {
|
|
69
|
+
this._feeRecipient = config.feeRecipient;
|
|
70
|
+
}
|
|
71
|
+
if (config.allowedInSetup) {
|
|
72
|
+
this.allowedInSetup = config.allowedInSetup;
|
|
73
|
+
}
|
|
74
|
+
if (config.maxBlockSizeInBytes) {
|
|
75
|
+
this.maxBlockSizeInBytes = config.maxBlockSizeInBytes;
|
|
76
|
+
}
|
|
77
|
+
// TODO(#5917) remove this. it is no longer needed since we don't need to whitelist functions in teardown
|
|
78
|
+
if (config.allowedInTeardown) {
|
|
79
|
+
this.allowedInTeardown = config.allowedInTeardown;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Starts the sequencer and moves to IDLE state. Blocks until the initial sync is complete.
|
|
84
|
+
*/
|
|
85
|
+
async start() {
|
|
86
|
+
await this.initialSync();
|
|
87
|
+
this.runningPromise = new RunningPromise(this.work.bind(this), this.pollingIntervalMs);
|
|
88
|
+
this.runningPromise.start();
|
|
123
89
|
this.state = SequencerState.IDLE;
|
|
90
|
+
this.log.info('Sequencer started');
|
|
124
91
|
}
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
92
|
+
/**
|
|
93
|
+
* Stops the sequencer from processing txs and moves to STOPPED state.
|
|
94
|
+
*/
|
|
95
|
+
async stop() {
|
|
96
|
+
this.log.debug(`Stopping sequencer`);
|
|
97
|
+
await this.runningPromise?.stop();
|
|
98
|
+
this.publisher.interrupt();
|
|
99
|
+
this.state = SequencerState.STOPPED;
|
|
100
|
+
this.log.info('Stopped sequencer');
|
|
128
101
|
}
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
this.
|
|
136
|
-
|
|
102
|
+
/**
|
|
103
|
+
* Starts a previously stopped sequencer.
|
|
104
|
+
*/
|
|
105
|
+
restart() {
|
|
106
|
+
this.log.info('Restarting sequencer');
|
|
107
|
+
this.publisher.restart();
|
|
108
|
+
this.runningPromise.start();
|
|
109
|
+
this.state = SequencerState.IDLE;
|
|
137
110
|
}
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
return;
|
|
111
|
+
/**
|
|
112
|
+
* Returns the current state of the sequencer.
|
|
113
|
+
* @returns An object with a state entry with one of SequencerState.
|
|
114
|
+
*/
|
|
115
|
+
status() {
|
|
116
|
+
return { state: this.state };
|
|
117
|
+
}
|
|
118
|
+
async initialSync() {
|
|
119
|
+
// TODO: Should we wait for world state to be ready, or is the caller expected to run await start?
|
|
120
|
+
this.lastPublishedBlock = await this.worldState.status().then((s) => s.syncedToL2Block);
|
|
144
121
|
}
|
|
145
|
-
this.log.debug(`Retrieved ${pendingTxs.length} txs from P2P pool`);
|
|
146
122
|
/**
|
|
147
|
-
*
|
|
123
|
+
* Grabs up to maxTxsPerBlock from the p2p client, constructs a block, and pushes it to L1.
|
|
148
124
|
*/
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
125
|
+
async work() {
|
|
126
|
+
try {
|
|
127
|
+
// Update state when the previous block has been synced
|
|
128
|
+
const prevBlockSynced = await this.isBlockSynced();
|
|
129
|
+
if (prevBlockSynced && this.state === SequencerState.PUBLISHING_BLOCK) {
|
|
130
|
+
this.log.debug(`Block has been synced`);
|
|
131
|
+
this.state = SequencerState.IDLE;
|
|
132
|
+
}
|
|
133
|
+
// Do not go forward with new block if the previous one has not been mined and processed
|
|
134
|
+
if (!prevBlockSynced) {
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
const historicalHeader = (await this.l2BlockSource.getBlock(-1))?.header;
|
|
138
|
+
const newBlockNumber = (historicalHeader === undefined
|
|
139
|
+
? await this.l2BlockSource.getBlockNumber()
|
|
140
|
+
: Number(historicalHeader.globalVariables.blockNumber.toBigInt())) + 1;
|
|
141
|
+
// Do not go forward with new block if not my turn
|
|
142
|
+
if (!(await this.publisher.isItMyTurnToSubmit(newBlockNumber))) {
|
|
143
|
+
this.log.verbose('Not my turn to submit block');
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
this.state = SequencerState.WAITING_FOR_TXS;
|
|
147
|
+
// Get txs to build the new block
|
|
148
|
+
const pendingTxs = await this.p2pClient.getTxs();
|
|
149
|
+
if (pendingTxs.length < this.minTxsPerBLock) {
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
this.log.debug(`Retrieved ${pendingTxs.length} txs from P2P pool`);
|
|
153
|
+
const newGlobalVariables = await this.globalsBuilder.buildGlobalVariables(new Fr(newBlockNumber), this._coinbase, this._feeRecipient);
|
|
154
|
+
// TODO: It should be responsibility of the P2P layer to validate txs before passing them on here
|
|
155
|
+
const allValidTxs = await this.takeValidTxs(pendingTxs, this.txValidatorFactory.validatorForNewTxs(newGlobalVariables, this.allowedInSetup));
|
|
156
|
+
// TODO: We are taking the size of the tx from private-land, but we should be doing this after running
|
|
157
|
+
// public functions. Only reason why we do it here now is because the public processor and orchestrator
|
|
158
|
+
// are set up such that they require knowing the total number of txs in advance. Still, main reason for
|
|
159
|
+
// exceeding max block size in bytes is contract class registration, which happens in private-land. This
|
|
160
|
+
// may break if we start emitting lots of log data from public-land.
|
|
161
|
+
const validTxs = this.takeTxsWithinMaxSize(allValidTxs);
|
|
162
|
+
if (validTxs.length < this.minTxsPerBLock) {
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
await this.buildBlockAndPublish(validTxs, newGlobalVariables, historicalHeader);
|
|
153
166
|
}
|
|
154
|
-
|
|
155
|
-
|
|
167
|
+
catch (err) {
|
|
168
|
+
if (BlockProofError.isBlockProofError(err)) {
|
|
169
|
+
const txHashes = err.txHashes.filter(h => !h.isZero());
|
|
170
|
+
this.log.warn(`Proving block failed, removing ${txHashes.length} txs from pool`);
|
|
171
|
+
await this.p2pClient.deleteTxs(txHashes);
|
|
172
|
+
}
|
|
173
|
+
this.log.error(`Rolling back world state DB due to error assembling block`, err.stack);
|
|
174
|
+
// Cancel any further proving on the block
|
|
175
|
+
this.prover?.cancelBlock();
|
|
176
|
+
await this.worldState.getLatest().rollback();
|
|
156
177
|
}
|
|
157
|
-
};
|
|
158
|
-
const newGlobalVariables = await this.globalsBuilder.buildGlobalVariables(new Fr(newBlockNumber), this._coinbase, this._feeRecipient);
|
|
159
|
-
// TODO: It should be responsibility of the P2P layer to validate txs before passing them on here
|
|
160
|
-
const allValidTxs = await this.takeValidTxs(pendingTxs, this.txValidatorFactory.validatorForNewTxs(newGlobalVariables, this.allowedInSetup));
|
|
161
|
-
// TODO: We are taking the size of the tx from private-land, but we should be doing this after running
|
|
162
|
-
// public functions. Only reason why we do it here now is because the public processor and orchestrator
|
|
163
|
-
// are set up such that they require knowing the total number of txs in advance. Still, main reason for
|
|
164
|
-
// exceeding max block size in bytes is contract class registration, which happens in private-land. This
|
|
165
|
-
// may break if we start emitting lots of log data from public-land.
|
|
166
|
-
const validTxs = this.takeTxsWithinMaxSize(allValidTxs);
|
|
167
|
-
if (validTxs.length < this.minTxsPerBLock) {
|
|
168
|
-
return;
|
|
169
178
|
}
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
const
|
|
189
|
-
|
|
190
|
-
|
|
179
|
+
async buildBlockAndPublish(validTxs, newGlobalVariables, historicalHeader) {
|
|
180
|
+
const workTimer = new Timer();
|
|
181
|
+
this.state = SequencerState.CREATING_BLOCK;
|
|
182
|
+
this.log.info(`Building block ${newGlobalVariables.blockNumber.toNumber()} with ${validTxs.length} transactions`);
|
|
183
|
+
const assertBlockHeight = async () => {
|
|
184
|
+
const currentBlockNumber = await this.l2BlockSource.getBlockNumber();
|
|
185
|
+
if (currentBlockNumber + 1 !== newGlobalVariables.blockNumber.toNumber()) {
|
|
186
|
+
throw new Error('New block was emitted while building block');
|
|
187
|
+
}
|
|
188
|
+
if (!(await this.publisher.isItMyTurnToSubmit(newGlobalVariables.blockNumber.toNumber()))) {
|
|
189
|
+
throw new Error(`Not this sequencer turn to submit block`);
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
// Get l1 to l2 messages from the contract
|
|
193
|
+
this.log.debug('Requesting L1 to L2 messages from contract');
|
|
194
|
+
const l1ToL2Messages = await this.l1ToL2MessageSource.getL1ToL2Messages(newGlobalVariables.blockNumber.toBigInt());
|
|
195
|
+
this.log.verbose(`Retrieved ${l1ToL2Messages.length} L1 to L2 messages for block ${newGlobalVariables.blockNumber.toNumber()}`);
|
|
196
|
+
// We create a fresh processor each time to reset any cached state (eg storage writes)
|
|
197
|
+
const processor = await this.publicProcessorFactory.create(historicalHeader, newGlobalVariables);
|
|
198
|
+
const numRealTxs = validTxs.length;
|
|
199
|
+
const blockSize = Math.max(2, numRealTxs);
|
|
200
|
+
const blockBuildingTimer = new Timer();
|
|
201
|
+
const blockTicket = await this.prover.startNewBlock(blockSize, newGlobalVariables, l1ToL2Messages);
|
|
202
|
+
const [publicProcessorDuration, [processedTxs, failedTxs]] = await elapsed(() => processor.process(validTxs, blockSize, this.prover, this.txValidatorFactory.validatorForProcessedTxs()));
|
|
203
|
+
if (failedTxs.length > 0) {
|
|
204
|
+
const failedTxData = failedTxs.map(fail => fail.tx);
|
|
205
|
+
this.log.debug(`Dropping failed txs ${Tx.getHashes(failedTxData).join(', ')}`);
|
|
206
|
+
await this.p2pClient.deleteTxs(Tx.getHashes(failedTxData));
|
|
207
|
+
}
|
|
208
|
+
if (processedTxs.length === 0) {
|
|
209
|
+
this.log.verbose('No txs processed correctly to build block. Exiting');
|
|
210
|
+
this.prover.cancelBlock();
|
|
211
|
+
return;
|
|
212
|
+
}
|
|
213
|
+
await assertBlockHeight();
|
|
214
|
+
// All real transactions have been added, set the block as full and complete the proving.
|
|
215
|
+
await this.prover.setBlockCompleted();
|
|
216
|
+
// Here we are now waiting for the block to be proven.
|
|
217
|
+
// TODO(@PhilWindle) We should probably periodically check for things like another
|
|
218
|
+
// block being published before ours instead of just waiting on our block
|
|
219
|
+
const result = await blockTicket.provingPromise;
|
|
220
|
+
if (result.status === PROVING_STATUS.FAILURE) {
|
|
221
|
+
throw new Error(`Block proving failed, reason: ${result.reason}`);
|
|
222
|
+
}
|
|
223
|
+
await assertBlockHeight();
|
|
224
|
+
// Block is proven, now finalise and publish!
|
|
225
|
+
const { block, aggregationObject, proof } = await this.prover.finaliseBlock();
|
|
226
|
+
await assertBlockHeight();
|
|
227
|
+
this.log.verbose(`Assembled block ${block.number}`, {
|
|
228
|
+
eventName: 'l2-block-built',
|
|
229
|
+
duration: workTimer.ms(),
|
|
230
|
+
publicProcessDuration: publicProcessorDuration,
|
|
231
|
+
rollupCircuitsDuration: blockBuildingTimer.ms(),
|
|
232
|
+
...block.getStats(),
|
|
233
|
+
});
|
|
234
|
+
await this.publishL2Block(block, aggregationObject, proof);
|
|
235
|
+
this.log.info(`Submitted rollup block ${block.number} with ${processedTxs.length} transactions`);
|
|
191
236
|
}
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
237
|
+
/**
|
|
238
|
+
* Publishes the L2Block to the rollup contract.
|
|
239
|
+
* @param block - The L2Block to be published.
|
|
240
|
+
*/
|
|
241
|
+
async publishL2Block(block, aggregationObject, proof) {
|
|
242
|
+
// Publishes new block to the network and awaits the tx to be mined
|
|
243
|
+
this.state = SequencerState.PUBLISHING_BLOCK;
|
|
244
|
+
const publishedL2Block = await this.publisher.processL2Block(block, aggregationObject, proof);
|
|
245
|
+
if (publishedL2Block) {
|
|
246
|
+
this.lastPublishedBlock = block.number;
|
|
247
|
+
}
|
|
248
|
+
else {
|
|
249
|
+
throw new Error(`Failed to publish block`);
|
|
250
|
+
}
|
|
196
251
|
}
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
if (result.status === PROVING_STATUS.FAILURE) {
|
|
205
|
-
throw new Error(`Block proving failed, reason: ${result.reason}`);
|
|
252
|
+
async takeValidTxs(txs, validator) {
|
|
253
|
+
const [valid, invalid] = await validator.validateTxs(txs);
|
|
254
|
+
if (invalid.length > 0) {
|
|
255
|
+
this.log.debug(`Dropping invalid txs from the p2p pool ${Tx.getHashes(invalid).join(', ')}`);
|
|
256
|
+
await this.p2pClient.deleteTxs(Tx.getHashes(invalid));
|
|
257
|
+
}
|
|
258
|
+
return valid.slice(0, this.maxTxsPerBlock);
|
|
206
259
|
}
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
catch (err) {
|
|
222
|
-
if (BlockProofError.isBlockProofError(err)) {
|
|
223
|
-
const txHashes = err.txHashes.filter(h => !h.isZero());
|
|
224
|
-
this.log.warn(`Proving block failed, removing ${txHashes.length} txs from pool`);
|
|
225
|
-
await this.p2pClient.deleteTxs(txHashes);
|
|
260
|
+
takeTxsWithinMaxSize(txs) {
|
|
261
|
+
const maxSize = this.maxBlockSizeInBytes;
|
|
262
|
+
let totalSize = 0;
|
|
263
|
+
const toReturn = [];
|
|
264
|
+
for (const tx of txs) {
|
|
265
|
+
const txSize = tx.getSize() - tx.proof.toBuffer().length;
|
|
266
|
+
if (totalSize + txSize > maxSize) {
|
|
267
|
+
this.log.warn(`Dropping tx ${tx.getTxHash()} with estimated size ${txSize} due to exceeding ${maxSize} block size limit (currently at ${totalSize})`);
|
|
268
|
+
continue;
|
|
269
|
+
}
|
|
270
|
+
toReturn.push(tx);
|
|
271
|
+
totalSize += txSize;
|
|
272
|
+
}
|
|
273
|
+
return toReturn;
|
|
226
274
|
}
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
const publishedL2Block = await this.publisher.processL2Block(block, aggregationObject, proof);
|
|
241
|
-
if (publishedL2Block) {
|
|
242
|
-
this.lastPublishedBlock = block.number;
|
|
243
|
-
}
|
|
244
|
-
else {
|
|
245
|
-
throw new Error(`Failed to publish block`);
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
async takeValidTxs(txs, validator) {
|
|
249
|
-
const [valid, invalid] = await validator.validateTxs(txs);
|
|
250
|
-
if (invalid.length > 0) {
|
|
251
|
-
this.log.debug(`Dropping invalid txs from the p2p pool ${Tx.getHashes(invalid).join(', ')}`);
|
|
252
|
-
await this.p2pClient.deleteTxs(Tx.getHashes(invalid));
|
|
253
|
-
}
|
|
254
|
-
return valid.slice(0, this.maxTxsPerBlock);
|
|
255
|
-
}
|
|
256
|
-
takeTxsWithinMaxSize(txs) {
|
|
257
|
-
const maxSize = this.maxBlockSizeInBytes;
|
|
258
|
-
let totalSize = 0;
|
|
259
|
-
const toReturn = [];
|
|
260
|
-
for (const tx of txs) {
|
|
261
|
-
const txSize = tx.getSize() - tx.proof.toBuffer().length;
|
|
262
|
-
if (totalSize + txSize > maxSize) {
|
|
263
|
-
this.log.warn(`Dropping tx ${tx.getTxHash()} with estimated size ${txSize} due to exceeding ${maxSize} block size limit (currently at ${totalSize})`);
|
|
264
|
-
continue;
|
|
275
|
+
/**
|
|
276
|
+
* Returns whether the previous block sent has been mined, and all dependencies have caught up with it.
|
|
277
|
+
* @returns Boolean indicating if our dependencies are synced to the latest block.
|
|
278
|
+
*/
|
|
279
|
+
async isBlockSynced() {
|
|
280
|
+
const syncedBlocks = await Promise.all([
|
|
281
|
+
this.worldState.status().then((s) => s.syncedToL2Block),
|
|
282
|
+
this.p2pClient.getStatus().then(s => s.syncedToL2Block),
|
|
283
|
+
this.l2BlockSource.getBlockNumber(),
|
|
284
|
+
this.l1ToL2MessageSource.getBlockNumber(),
|
|
285
|
+
]);
|
|
286
|
+
const min = Math.min(...syncedBlocks);
|
|
287
|
+
return min >= this.lastPublishedBlock;
|
|
265
288
|
}
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
get feeRecipient() {
|
|
289
|
-
return this._feeRecipient;
|
|
290
|
-
}
|
|
291
|
-
}
|
|
289
|
+
get coinbase() {
|
|
290
|
+
return this._coinbase;
|
|
291
|
+
}
|
|
292
|
+
get feeRecipient() {
|
|
293
|
+
return this._feeRecipient;
|
|
294
|
+
}
|
|
295
|
+
},
|
|
296
|
+
(() => {
|
|
297
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
298
|
+
_buildBlockAndPublish_decorators = [trackSpan('Sequencer.buildBlockAndPublish', (_validTxs, newGlobalVariables, _historicalHeader) => ({
|
|
299
|
+
[Attributes.BLOCK_NUMBER]: newGlobalVariables.blockNumber.toNumber(),
|
|
300
|
+
}))];
|
|
301
|
+
_publishL2Block_decorators = [trackSpan('Sequencer.publishL2Block', block => ({
|
|
302
|
+
[Attributes.BLOCK_NUMBER]: block.number,
|
|
303
|
+
}))];
|
|
304
|
+
__esDecorate(_a, null, _buildBlockAndPublish_decorators, { kind: "method", name: "buildBlockAndPublish", static: false, private: false, access: { has: obj => "buildBlockAndPublish" in obj, get: obj => obj.buildBlockAndPublish }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
305
|
+
__esDecorate(_a, null, _publishL2Block_decorators, { kind: "method", name: "publishL2Block", static: false, private: false, access: { has: obj => "publishL2Block" in obj, get: obj => obj.publishL2Block }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
306
|
+
if (_metadata) Object.defineProperty(_a, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
307
|
+
})(),
|
|
308
|
+
_a;
|
|
309
|
+
})();
|
|
310
|
+
export { Sequencer };
|
|
292
311
|
/**
|
|
293
312
|
* State of the sequencer.
|
|
294
313
|
*/
|
|
@@ -319,4 +338,4 @@ export var SequencerState;
|
|
|
319
338
|
*/
|
|
320
339
|
SequencerState[SequencerState["STOPPED"] = 5] = "STOPPED";
|
|
321
340
|
})(SequencerState || (SequencerState = {}));
|
|
322
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sequencer.js","sourceRoot":"","sources":["../../src/sequencer/sequencer.ts"],"names":[],"mappings":"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"}
|
|
341
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sequencer.js","sourceRoot":"","sources":["../../src/sequencer/sequencer.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/sequencer-client",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.45.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": "./dest/index.js",
|
|
6
6
|
"typedocOptions": {
|
|
@@ -24,19 +24,20 @@
|
|
|
24
24
|
"test:integration:run": "NODE_NO_WARNINGS=1 node --experimental-vm-modules $(yarn bin jest) --no-cache --config jest.integration.config.json"
|
|
25
25
|
},
|
|
26
26
|
"dependencies": {
|
|
27
|
-
"@aztec/circuit-types": "0.
|
|
28
|
-
"@aztec/circuits.js": "0.
|
|
29
|
-
"@aztec/ethereum": "0.
|
|
30
|
-
"@aztec/foundation": "0.
|
|
31
|
-
"@aztec/l1-artifacts": "0.
|
|
32
|
-
"@aztec/merkle-tree": "0.
|
|
33
|
-
"@aztec/noir-contracts.js": "0.
|
|
34
|
-
"@aztec/noir-protocol-circuits-types": "0.
|
|
35
|
-
"@aztec/p2p": "0.
|
|
36
|
-
"@aztec/protocol-contracts": "0.
|
|
37
|
-
"@aztec/simulator": "0.
|
|
38
|
-
"@aztec/
|
|
39
|
-
"@aztec/
|
|
27
|
+
"@aztec/circuit-types": "0.45.0",
|
|
28
|
+
"@aztec/circuits.js": "0.45.0",
|
|
29
|
+
"@aztec/ethereum": "0.45.0",
|
|
30
|
+
"@aztec/foundation": "0.45.0",
|
|
31
|
+
"@aztec/l1-artifacts": "0.45.0",
|
|
32
|
+
"@aztec/merkle-tree": "0.45.0",
|
|
33
|
+
"@aztec/noir-contracts.js": "0.45.0",
|
|
34
|
+
"@aztec/noir-protocol-circuits-types": "0.45.0",
|
|
35
|
+
"@aztec/p2p": "0.45.0",
|
|
36
|
+
"@aztec/protocol-contracts": "0.45.0",
|
|
37
|
+
"@aztec/simulator": "0.45.0",
|
|
38
|
+
"@aztec/telemetry-client": "0.45.0",
|
|
39
|
+
"@aztec/types": "0.45.0",
|
|
40
|
+
"@aztec/world-state": "0.45.0",
|
|
40
41
|
"@noir-lang/acvm_js": "portal:../../noir/packages/acvm_js",
|
|
41
42
|
"@noir-lang/types": "portal:../../noir/packages/types",
|
|
42
43
|
"lodash.chunk": "^4.2.0",
|
|
@@ -78,7 +79,15 @@
|
|
|
78
79
|
],
|
|
79
80
|
"transform": {
|
|
80
81
|
"^.+\\.tsx?$": [
|
|
81
|
-
"@swc/jest"
|
|
82
|
+
"@swc/jest",
|
|
83
|
+
{
|
|
84
|
+
"jsc": {
|
|
85
|
+
"parser": {
|
|
86
|
+
"syntax": "typescript",
|
|
87
|
+
"decorators": true
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
82
91
|
]
|
|
83
92
|
},
|
|
84
93
|
"moduleNameMapper": {
|
|
@@ -2,6 +2,7 @@ import { type L1ToL2MessageSource, type L2BlockSource } from '@aztec/circuit-typ
|
|
|
2
2
|
import { type BlockProver } from '@aztec/circuit-types/interfaces';
|
|
3
3
|
import { type P2P } from '@aztec/p2p';
|
|
4
4
|
import { PublicProcessorFactory, type SimulationProvider } from '@aztec/simulator';
|
|
5
|
+
import { type TelemetryClient } from '@aztec/telemetry-client';
|
|
5
6
|
import { type ContractDataSource } from '@aztec/types/contracts';
|
|
6
7
|
import { type WorldStateSynchronizer } from '@aztec/world-state';
|
|
7
8
|
|
|
@@ -38,12 +39,18 @@ export class SequencerClient {
|
|
|
38
39
|
l1ToL2MessageSource: L1ToL2MessageSource,
|
|
39
40
|
prover: BlockProver,
|
|
40
41
|
simulationProvider: SimulationProvider,
|
|
42
|
+
telemetryClient: TelemetryClient,
|
|
41
43
|
) {
|
|
42
44
|
const publisher = getL1Publisher(config);
|
|
43
45
|
const globalsBuilder = getGlobalVariableBuilder(config);
|
|
44
46
|
const merkleTreeDb = worldStateSynchronizer.getLatest();
|
|
45
47
|
|
|
46
|
-
const publicProcessorFactory = new PublicProcessorFactory(
|
|
48
|
+
const publicProcessorFactory = new PublicProcessorFactory(
|
|
49
|
+
merkleTreeDb,
|
|
50
|
+
contractDataSource,
|
|
51
|
+
simulationProvider,
|
|
52
|
+
telemetryClient,
|
|
53
|
+
);
|
|
47
54
|
|
|
48
55
|
const sequencer = new Sequencer(
|
|
49
56
|
publisher,
|
|
@@ -55,6 +62,7 @@ export class SequencerClient {
|
|
|
55
62
|
l1ToL2MessageSource,
|
|
56
63
|
publicProcessorFactory,
|
|
57
64
|
new TxValidatorFactory(merkleTreeDb, contractDataSource, !!config.enforceFees),
|
|
65
|
+
telemetryClient,
|
|
58
66
|
config,
|
|
59
67
|
);
|
|
60
68
|
|
|
@@ -13,13 +13,14 @@ import {
|
|
|
13
13
|
PROVING_STATUS,
|
|
14
14
|
} from '@aztec/circuit-types/interfaces';
|
|
15
15
|
import { type L2BlockBuiltStats } from '@aztec/circuit-types/stats';
|
|
16
|
-
import { AztecAddress, EthAddress, type Proof } from '@aztec/circuits.js';
|
|
16
|
+
import { AztecAddress, EthAddress, type GlobalVariables, type Header, type Proof } from '@aztec/circuits.js';
|
|
17
17
|
import { Fr } from '@aztec/foundation/fields';
|
|
18
18
|
import { createDebugLogger } from '@aztec/foundation/log';
|
|
19
19
|
import { RunningPromise } from '@aztec/foundation/running-promise';
|
|
20
20
|
import { Timer, elapsed } from '@aztec/foundation/timer';
|
|
21
21
|
import { type P2P } from '@aztec/p2p';
|
|
22
22
|
import { type PublicProcessorFactory } from '@aztec/simulator';
|
|
23
|
+
import { Attributes, type TelemetryClient, type Tracer, trackSpan } from '@aztec/telemetry-client';
|
|
23
24
|
import { type WorldStateStatus, type WorldStateSynchronizer } from '@aztec/world-state';
|
|
24
25
|
|
|
25
26
|
import { type GlobalVariableBuilder } from '../global_variable_builder/global_builder.js';
|
|
@@ -50,6 +51,8 @@ export class Sequencer {
|
|
|
50
51
|
private allowedInTeardown: AllowedElement[] = [];
|
|
51
52
|
private maxBlockSizeInBytes: number = 1024 * 1024;
|
|
52
53
|
|
|
54
|
+
public readonly tracer: Tracer;
|
|
55
|
+
|
|
53
56
|
constructor(
|
|
54
57
|
private publisher: L1Publisher,
|
|
55
58
|
private globalsBuilder: GlobalVariableBuilder,
|
|
@@ -60,10 +63,12 @@ export class Sequencer {
|
|
|
60
63
|
private l1ToL2MessageSource: L1ToL2MessageSource,
|
|
61
64
|
private publicProcessorFactory: PublicProcessorFactory,
|
|
62
65
|
private txValidatorFactory: TxValidatorFactory,
|
|
66
|
+
telemetry: TelemetryClient,
|
|
63
67
|
config: SequencerConfig = {},
|
|
64
68
|
private log = createDebugLogger('aztec:sequencer'),
|
|
65
69
|
) {
|
|
66
70
|
this.updateConfig(config);
|
|
71
|
+
this.tracer = telemetry.getTracer('Sequencer');
|
|
67
72
|
this.log.verbose(`Initialized sequencer with ${this.minTxsPerBLock}-${this.maxTxsPerBlock} txs per block.`);
|
|
68
73
|
}
|
|
69
74
|
|
|
@@ -174,7 +179,6 @@ export class Sequencer {
|
|
|
174
179
|
return;
|
|
175
180
|
}
|
|
176
181
|
|
|
177
|
-
const workTimer = new Timer();
|
|
178
182
|
this.state = SequencerState.WAITING_FOR_TXS;
|
|
179
183
|
|
|
180
184
|
// Get txs to build the new block
|
|
@@ -184,19 +188,6 @@ export class Sequencer {
|
|
|
184
188
|
}
|
|
185
189
|
this.log.debug(`Retrieved ${pendingTxs.length} txs from P2P pool`);
|
|
186
190
|
|
|
187
|
-
/**
|
|
188
|
-
* We'll call this function before running expensive operations to avoid wasted work.
|
|
189
|
-
*/
|
|
190
|
-
const assertBlockHeight = async () => {
|
|
191
|
-
const currentBlockNumber = await this.l2BlockSource.getBlockNumber();
|
|
192
|
-
if (currentBlockNumber + 1 !== newBlockNumber) {
|
|
193
|
-
throw new Error('New block was emitted while building block');
|
|
194
|
-
}
|
|
195
|
-
if (!(await this.publisher.isItMyTurnToSubmit(newBlockNumber))) {
|
|
196
|
-
throw new Error(`Not this sequencer turn to submit block`);
|
|
197
|
-
}
|
|
198
|
-
};
|
|
199
|
-
|
|
200
191
|
const newGlobalVariables = await this.globalsBuilder.buildGlobalVariables(
|
|
201
192
|
new Fr(newBlockNumber),
|
|
202
193
|
this._coinbase,
|
|
@@ -220,72 +211,7 @@ export class Sequencer {
|
|
|
220
211
|
return;
|
|
221
212
|
}
|
|
222
213
|
|
|
223
|
-
this.
|
|
224
|
-
this.state = SequencerState.CREATING_BLOCK;
|
|
225
|
-
|
|
226
|
-
// Get l1 to l2 messages from the contract
|
|
227
|
-
this.log.debug('Requesting L1 to L2 messages from contract');
|
|
228
|
-
const l1ToL2Messages = await this.l1ToL2MessageSource.getL1ToL2Messages(BigInt(newBlockNumber));
|
|
229
|
-
this.log.verbose(`Retrieved ${l1ToL2Messages.length} L1 to L2 messages for block ${newBlockNumber}`);
|
|
230
|
-
|
|
231
|
-
// We create a fresh processor each time to reset any cached state (eg storage writes)
|
|
232
|
-
const processor = await this.publicProcessorFactory.create(historicalHeader, newGlobalVariables);
|
|
233
|
-
|
|
234
|
-
const blockBuildingTimer = new Timer();
|
|
235
|
-
|
|
236
|
-
// We must initialise the block to be a power of 2 in size
|
|
237
|
-
const numRealTxs = validTxs.length;
|
|
238
|
-
const pow2 = Math.log2(numRealTxs);
|
|
239
|
-
// TODO turn this back into a Math.ceil once we can pad blocks to the next-power-of-2 with empty txs
|
|
240
|
-
const totalTxs = 2 ** Math.ceil(pow2);
|
|
241
|
-
const blockSize = Math.max(2, totalTxs);
|
|
242
|
-
const blockTicket = await this.prover.startNewBlock(blockSize, newGlobalVariables, l1ToL2Messages);
|
|
243
|
-
|
|
244
|
-
const [publicProcessorDuration, [processedTxs, failedTxs]] = await elapsed(() =>
|
|
245
|
-
processor.process(validTxs, blockSize, this.prover, this.txValidatorFactory.validatorForProcessedTxs()),
|
|
246
|
-
);
|
|
247
|
-
if (failedTxs.length > 0) {
|
|
248
|
-
const failedTxData = failedTxs.map(fail => fail.tx);
|
|
249
|
-
this.log.debug(`Dropping failed txs ${Tx.getHashes(failedTxData).join(', ')}`);
|
|
250
|
-
await this.p2pClient.deleteTxs(Tx.getHashes(failedTxData));
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
if (processedTxs.length === 0) {
|
|
254
|
-
this.log.verbose('No txs processed correctly to build block. Exiting');
|
|
255
|
-
this.prover.cancelBlock();
|
|
256
|
-
return;
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
await assertBlockHeight();
|
|
260
|
-
|
|
261
|
-
// All real transactions have been added, set the block as full and complete the proving.
|
|
262
|
-
await this.prover.setBlockCompleted();
|
|
263
|
-
|
|
264
|
-
// Here we are now waiting for the block to be proven.
|
|
265
|
-
// TODO(@PhilWindle) We should probably periodically check for things like another
|
|
266
|
-
// block being published before ours instead of just waiting on our block
|
|
267
|
-
const result = await blockTicket.provingPromise;
|
|
268
|
-
if (result.status === PROVING_STATUS.FAILURE) {
|
|
269
|
-
throw new Error(`Block proving failed, reason: ${result.reason}`);
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
await assertBlockHeight();
|
|
273
|
-
|
|
274
|
-
// Block is proven, now finalise and publish!
|
|
275
|
-
const { block, aggregationObject, proof } = await this.prover.finaliseBlock();
|
|
276
|
-
|
|
277
|
-
await assertBlockHeight();
|
|
278
|
-
|
|
279
|
-
this.log.verbose(`Assembled block ${block.number}`, {
|
|
280
|
-
eventName: 'l2-block-built',
|
|
281
|
-
duration: workTimer.ms(),
|
|
282
|
-
publicProcessDuration: publicProcessorDuration,
|
|
283
|
-
rollupCircuitsDuration: blockBuildingTimer.ms(),
|
|
284
|
-
...block.getStats(),
|
|
285
|
-
} satisfies L2BlockBuiltStats);
|
|
286
|
-
|
|
287
|
-
await this.publishL2Block(block, aggregationObject, proof);
|
|
288
|
-
this.log.info(`Submitted rollup block ${block.number} with ${processedTxs.length} transactions`);
|
|
214
|
+
await this.buildBlockAndPublish(validTxs, newGlobalVariables, historicalHeader);
|
|
289
215
|
} catch (err) {
|
|
290
216
|
if (BlockProofError.isBlockProofError(err)) {
|
|
291
217
|
const txHashes = err.txHashes.filter(h => !h.isZero());
|
|
@@ -299,10 +225,98 @@ export class Sequencer {
|
|
|
299
225
|
}
|
|
300
226
|
}
|
|
301
227
|
|
|
228
|
+
@trackSpan('Sequencer.buildBlockAndPublish', (_validTxs, newGlobalVariables, _historicalHeader) => ({
|
|
229
|
+
[Attributes.BLOCK_NUMBER]: newGlobalVariables.blockNumber.toNumber(),
|
|
230
|
+
}))
|
|
231
|
+
private async buildBlockAndPublish(
|
|
232
|
+
validTxs: Tx[],
|
|
233
|
+
newGlobalVariables: GlobalVariables,
|
|
234
|
+
historicalHeader: Header | undefined,
|
|
235
|
+
): Promise<void> {
|
|
236
|
+
const workTimer = new Timer();
|
|
237
|
+
this.state = SequencerState.CREATING_BLOCK;
|
|
238
|
+
this.log.info(`Building block ${newGlobalVariables.blockNumber.toNumber()} with ${validTxs.length} transactions`);
|
|
239
|
+
|
|
240
|
+
const assertBlockHeight = async () => {
|
|
241
|
+
const currentBlockNumber = await this.l2BlockSource.getBlockNumber();
|
|
242
|
+
if (currentBlockNumber + 1 !== newGlobalVariables.blockNumber.toNumber()) {
|
|
243
|
+
throw new Error('New block was emitted while building block');
|
|
244
|
+
}
|
|
245
|
+
if (!(await this.publisher.isItMyTurnToSubmit(newGlobalVariables.blockNumber.toNumber()))) {
|
|
246
|
+
throw new Error(`Not this sequencer turn to submit block`);
|
|
247
|
+
}
|
|
248
|
+
};
|
|
249
|
+
|
|
250
|
+
// Get l1 to l2 messages from the contract
|
|
251
|
+
this.log.debug('Requesting L1 to L2 messages from contract');
|
|
252
|
+
const l1ToL2Messages = await this.l1ToL2MessageSource.getL1ToL2Messages(newGlobalVariables.blockNumber.toBigInt());
|
|
253
|
+
this.log.verbose(
|
|
254
|
+
`Retrieved ${l1ToL2Messages.length} L1 to L2 messages for block ${newGlobalVariables.blockNumber.toNumber()}`,
|
|
255
|
+
);
|
|
256
|
+
|
|
257
|
+
// We create a fresh processor each time to reset any cached state (eg storage writes)
|
|
258
|
+
const processor = await this.publicProcessorFactory.create(historicalHeader, newGlobalVariables);
|
|
259
|
+
|
|
260
|
+
const numRealTxs = validTxs.length;
|
|
261
|
+
const blockSize = Math.max(2, numRealTxs);
|
|
262
|
+
|
|
263
|
+
const blockBuildingTimer = new Timer();
|
|
264
|
+
const blockTicket = await this.prover.startNewBlock(blockSize, newGlobalVariables, l1ToL2Messages);
|
|
265
|
+
|
|
266
|
+
const [publicProcessorDuration, [processedTxs, failedTxs]] = await elapsed(() =>
|
|
267
|
+
processor.process(validTxs, blockSize, this.prover, this.txValidatorFactory.validatorForProcessedTxs()),
|
|
268
|
+
);
|
|
269
|
+
if (failedTxs.length > 0) {
|
|
270
|
+
const failedTxData = failedTxs.map(fail => fail.tx);
|
|
271
|
+
this.log.debug(`Dropping failed txs ${Tx.getHashes(failedTxData).join(', ')}`);
|
|
272
|
+
await this.p2pClient.deleteTxs(Tx.getHashes(failedTxData));
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
if (processedTxs.length === 0) {
|
|
276
|
+
this.log.verbose('No txs processed correctly to build block. Exiting');
|
|
277
|
+
this.prover.cancelBlock();
|
|
278
|
+
return;
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
await assertBlockHeight();
|
|
282
|
+
|
|
283
|
+
// All real transactions have been added, set the block as full and complete the proving.
|
|
284
|
+
await this.prover.setBlockCompleted();
|
|
285
|
+
|
|
286
|
+
// Here we are now waiting for the block to be proven.
|
|
287
|
+
// TODO(@PhilWindle) We should probably periodically check for things like another
|
|
288
|
+
// block being published before ours instead of just waiting on our block
|
|
289
|
+
const result = await blockTicket.provingPromise;
|
|
290
|
+
if (result.status === PROVING_STATUS.FAILURE) {
|
|
291
|
+
throw new Error(`Block proving failed, reason: ${result.reason}`);
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
await assertBlockHeight();
|
|
295
|
+
|
|
296
|
+
// Block is proven, now finalise and publish!
|
|
297
|
+
const { block, aggregationObject, proof } = await this.prover.finaliseBlock();
|
|
298
|
+
|
|
299
|
+
await assertBlockHeight();
|
|
300
|
+
|
|
301
|
+
this.log.verbose(`Assembled block ${block.number}`, {
|
|
302
|
+
eventName: 'l2-block-built',
|
|
303
|
+
duration: workTimer.ms(),
|
|
304
|
+
publicProcessDuration: publicProcessorDuration,
|
|
305
|
+
rollupCircuitsDuration: blockBuildingTimer.ms(),
|
|
306
|
+
...block.getStats(),
|
|
307
|
+
} satisfies L2BlockBuiltStats);
|
|
308
|
+
|
|
309
|
+
await this.publishL2Block(block, aggregationObject, proof);
|
|
310
|
+
this.log.info(`Submitted rollup block ${block.number} with ${processedTxs.length} transactions`);
|
|
311
|
+
}
|
|
312
|
+
|
|
302
313
|
/**
|
|
303
314
|
* Publishes the L2Block to the rollup contract.
|
|
304
315
|
* @param block - The L2Block to be published.
|
|
305
316
|
*/
|
|
317
|
+
@trackSpan('Sequencer.publishL2Block', block => ({
|
|
318
|
+
[Attributes.BLOCK_NUMBER]: block.number,
|
|
319
|
+
}))
|
|
306
320
|
protected async publishL2Block(block: L2Block, aggregationObject: Fr[], proof: Proof) {
|
|
307
321
|
// Publishes new block to the network and awaits the tx to be mined
|
|
308
322
|
this.state = SequencerState.PUBLISHING_BLOCK;
|