@aztec/sequencer-client 3.0.0-rc.5 → 4.0.0-nightly.20260107
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 +9 -8
- package/dest/client/sequencer-client.d.ts.map +1 -1
- package/dest/client/sequencer-client.js +28 -24
- package/dest/config.d.ts +7 -1
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +63 -26
- package/dest/global_variable_builder/global_builder.d.ts +16 -8
- package/dest/global_variable_builder/global_builder.d.ts.map +1 -1
- package/dest/global_variable_builder/global_builder.js +37 -28
- package/dest/index.d.ts +2 -2
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +1 -1
- package/dest/publisher/config.d.ts +3 -3
- package/dest/publisher/config.d.ts.map +1 -1
- package/dest/publisher/config.js +2 -2
- package/dest/publisher/sequencer-publisher-factory.d.ts +3 -3
- package/dest/publisher/sequencer-publisher-factory.d.ts.map +1 -1
- package/dest/publisher/sequencer-publisher-factory.js +1 -1
- package/dest/publisher/sequencer-publisher-metrics.d.ts +3 -3
- package/dest/publisher/sequencer-publisher-metrics.d.ts.map +1 -1
- package/dest/publisher/sequencer-publisher.d.ts +27 -23
- package/dest/publisher/sequencer-publisher.d.ts.map +1 -1
- package/dest/publisher/sequencer-publisher.js +119 -64
- package/dest/sequencer/block_builder.d.ts +1 -3
- package/dest/sequencer/block_builder.d.ts.map +1 -1
- package/dest/sequencer/block_builder.js +4 -2
- package/dest/sequencer/checkpoint_builder.d.ts +63 -0
- package/dest/sequencer/checkpoint_builder.d.ts.map +1 -0
- package/dest/sequencer/checkpoint_builder.js +131 -0
- package/dest/sequencer/checkpoint_proposal_job.d.ts +74 -0
- package/dest/sequencer/checkpoint_proposal_job.d.ts.map +1 -0
- package/dest/sequencer/checkpoint_proposal_job.js +642 -0
- package/dest/sequencer/checkpoint_voter.d.ts +34 -0
- package/dest/sequencer/checkpoint_voter.d.ts.map +1 -0
- package/dest/sequencer/checkpoint_voter.js +85 -0
- package/dest/sequencer/events.d.ts +46 -0
- package/dest/sequencer/events.d.ts.map +1 -0
- package/dest/sequencer/events.js +1 -0
- package/dest/sequencer/index.d.ts +5 -1
- package/dest/sequencer/index.d.ts.map +1 -1
- package/dest/sequencer/index.js +4 -0
- package/dest/sequencer/metrics.d.ts +21 -1
- package/dest/sequencer/metrics.d.ts.map +1 -1
- package/dest/sequencer/metrics.js +154 -0
- package/dest/sequencer/sequencer.d.ts +91 -125
- package/dest/sequencer/sequencer.d.ts.map +1 -1
- package/dest/sequencer/sequencer.js +581 -582
- package/dest/sequencer/timetable.d.ts +54 -14
- package/dest/sequencer/timetable.d.ts.map +1 -1
- package/dest/sequencer/timetable.js +148 -59
- package/dest/sequencer/types.d.ts +3 -0
- package/dest/sequencer/types.d.ts.map +1 -0
- package/dest/sequencer/types.js +1 -0
- package/dest/sequencer/utils.d.ts +14 -8
- package/dest/sequencer/utils.d.ts.map +1 -1
- package/dest/sequencer/utils.js +7 -4
- package/dest/test/index.d.ts +3 -1
- package/dest/test/index.d.ts.map +1 -1
- package/dest/test/mock_checkpoint_builder.d.ts +83 -0
- package/dest/test/mock_checkpoint_builder.d.ts.map +1 -0
- package/dest/test/mock_checkpoint_builder.js +179 -0
- package/dest/test/utils.d.ts +49 -0
- package/dest/test/utils.d.ts.map +1 -0
- package/dest/test/utils.js +94 -0
- package/package.json +27 -27
- package/src/client/sequencer-client.ts +24 -31
- package/src/config.ts +68 -25
- package/src/global_variable_builder/global_builder.ts +47 -41
- package/src/index.ts +2 -0
- package/src/publisher/config.ts +3 -3
- package/src/publisher/sequencer-publisher-factory.ts +3 -3
- package/src/publisher/sequencer-publisher-metrics.ts +2 -2
- package/src/publisher/sequencer-publisher.ts +170 -74
- package/src/sequencer/README.md +531 -0
- package/src/sequencer/block_builder.ts +4 -1
- package/src/sequencer/checkpoint_builder.ts +217 -0
- package/src/sequencer/checkpoint_proposal_job.ts +706 -0
- package/src/sequencer/checkpoint_voter.ts +105 -0
- package/src/sequencer/events.ts +27 -0
- package/src/sequencer/index.ts +4 -0
- package/src/sequencer/metrics.ts +202 -0
- package/src/sequencer/sequencer.ts +300 -779
- package/src/sequencer/timetable.ts +173 -79
- package/src/sequencer/types.ts +6 -0
- package/src/sequencer/utils.ts +18 -9
- package/src/test/index.ts +2 -0
- package/src/test/mock_checkpoint_builder.ts +247 -0
- package/src/test/utils.ts +137 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { SlotNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import type { EthAddress } from '@aztec/foundation/eth-address';
|
|
3
|
+
import type { Logger } from '@aztec/foundation/log';
|
|
4
|
+
import type { SlasherClientInterface } from '@aztec/slasher';
|
|
5
|
+
import type { ResolvedSequencerConfig } from '@aztec/stdlib/interfaces/server';
|
|
6
|
+
import type { ValidatorClient } from '@aztec/validator-client';
|
|
7
|
+
import type { SequencerPublisher } from '../publisher/sequencer-publisher.js';
|
|
8
|
+
import type { SequencerMetrics } from './metrics.js';
|
|
9
|
+
import type { SequencerRollupConstants } from './types.js';
|
|
10
|
+
/**
|
|
11
|
+
* Handles governance and slashing voting for a given slot.
|
|
12
|
+
*/
|
|
13
|
+
export declare class CheckpointVoter {
|
|
14
|
+
private readonly slot;
|
|
15
|
+
private readonly publisher;
|
|
16
|
+
private readonly attestorAddress;
|
|
17
|
+
private readonly validatorClient;
|
|
18
|
+
private readonly slasherClient;
|
|
19
|
+
private readonly l1Constants;
|
|
20
|
+
private readonly config;
|
|
21
|
+
private readonly metrics;
|
|
22
|
+
private readonly log;
|
|
23
|
+
private slotTimestamp;
|
|
24
|
+
private signer;
|
|
25
|
+
constructor(slot: SlotNumber, publisher: SequencerPublisher, attestorAddress: EthAddress, validatorClient: ValidatorClient, slasherClient: SlasherClientInterface | undefined, l1Constants: SequencerRollupConstants, config: ResolvedSequencerConfig, metrics: SequencerMetrics, log: Logger);
|
|
26
|
+
/**
|
|
27
|
+
* Enqueues governance and slashing votes with the publisher.
|
|
28
|
+
* Returns a tuple of promises that resolve to whether each vote was successfully enqueued.
|
|
29
|
+
*/
|
|
30
|
+
enqueueVotes(): [Promise<boolean | undefined>, Promise<boolean | undefined>];
|
|
31
|
+
private enqueueGovernanceVote;
|
|
32
|
+
private enqueueSlashingVote;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2twb2ludF92b3Rlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcXVlbmNlci9jaGVja3BvaW50X3ZvdGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xFLE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2hFLE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3BELE9BQU8sS0FBSyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFN0QsT0FBTyxLQUFLLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUMvRSxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUkvRCxPQUFPLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzlFLE9BQU8sS0FBSyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ3JELE9BQU8sS0FBSyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRTNEOztHQUVHO0FBQ0gscUJBQWEsZUFBZTtJQUt4QixPQUFPLENBQUMsUUFBUSxDQUFDLElBQUk7SUFDckIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxTQUFTO0lBQzFCLE9BQU8sQ0FBQyxRQUFRLENBQUMsZUFBZTtJQUNoQyxPQUFPLENBQUMsUUFBUSxDQUFDLGVBQWU7SUFDaEMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxhQUFhO0lBQzlCLE9BQU8sQ0FBQyxRQUFRLENBQUMsV0FBVztJQUM1QixPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU07SUFDdkIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPO0lBQ3hCLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRztJQVp0QixPQUFPLENBQUMsYUFBYSxDQUFTO0lBQzlCLE9BQU8sQ0FBQyxNQUFNLENBQXVEO0lBRXJFLFlBQ21CLElBQUksRUFBRSxVQUFVLEVBQ2hCLFNBQVMsRUFBRSxrQkFBa0IsRUFDN0IsZUFBZSxFQUFFLFVBQVUsRUFDM0IsZUFBZSxFQUFFLGVBQWUsRUFDaEMsYUFBYSxFQUFFLHNCQUFzQixHQUFHLFNBQVMsRUFDakQsV0FBVyxFQUFFLHdCQUF3QixFQUNyQyxNQUFNLEVBQUUsdUJBQXVCLEVBQy9CLE9BQU8sRUFBRSxnQkFBZ0IsRUFDekIsR0FBRyxFQUFFLE1BQU0sRUFLN0I7SUFFRDs7O09BR0c7SUFDSCxZQUFZLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxHQUFHLFNBQVMsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxPQUFPLEdBQUcsU0FBUyxDQUFDLENBQUMsQ0FVM0U7WUFFYSxxQkFBcUI7WUF5QnJCLG1CQUFtQjtDQTBCbEMifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkpoint_voter.d.ts","sourceRoot":"","sources":["../../src/sequencer/checkpoint_voter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AAE7D,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC/E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAI/D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAC9E,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAC;AAE3D;;GAEG;AACH,qBAAa,eAAe;IAKxB,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,GAAG;IAZtB,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,MAAM,CAAuD;IAErE,YACmB,IAAI,EAAE,UAAU,EAChB,SAAS,EAAE,kBAAkB,EAC7B,eAAe,EAAE,UAAU,EAC3B,eAAe,EAAE,eAAe,EAChC,aAAa,EAAE,sBAAsB,GAAG,SAAS,EACjD,WAAW,EAAE,wBAAwB,EACrC,MAAM,EAAE,uBAAuB,EAC/B,OAAO,EAAE,gBAAgB,EACzB,GAAG,EAAE,MAAM,EAK7B;IAED;;;OAGG;IACH,YAAY,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,EAAE,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,CAAC,CAU3E;YAEa,qBAAqB;YAyBrB,mBAAmB;CA0BlC"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { getTimestampForSlot } from '@aztec/stdlib/epoch-helpers';
|
|
2
|
+
/**
|
|
3
|
+
* Handles governance and slashing voting for a given slot.
|
|
4
|
+
*/ export class CheckpointVoter {
|
|
5
|
+
slot;
|
|
6
|
+
publisher;
|
|
7
|
+
attestorAddress;
|
|
8
|
+
validatorClient;
|
|
9
|
+
slasherClient;
|
|
10
|
+
l1Constants;
|
|
11
|
+
config;
|
|
12
|
+
metrics;
|
|
13
|
+
log;
|
|
14
|
+
slotTimestamp;
|
|
15
|
+
signer;
|
|
16
|
+
constructor(slot, publisher, attestorAddress, validatorClient, slasherClient, l1Constants, config, metrics, log){
|
|
17
|
+
this.slot = slot;
|
|
18
|
+
this.publisher = publisher;
|
|
19
|
+
this.attestorAddress = attestorAddress;
|
|
20
|
+
this.validatorClient = validatorClient;
|
|
21
|
+
this.slasherClient = slasherClient;
|
|
22
|
+
this.l1Constants = l1Constants;
|
|
23
|
+
this.config = config;
|
|
24
|
+
this.metrics = metrics;
|
|
25
|
+
this.log = log;
|
|
26
|
+
this.slotTimestamp = getTimestampForSlot(this.slot, this.l1Constants);
|
|
27
|
+
this.signer = (msg)=>this.validatorClient.signWithAddress(this.attestorAddress, msg).then((s)=>s.toString());
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Enqueues governance and slashing votes with the publisher.
|
|
31
|
+
* Returns a tuple of promises that resolve to whether each vote was successfully enqueued.
|
|
32
|
+
*/ enqueueVotes() {
|
|
33
|
+
try {
|
|
34
|
+
const enqueueGovernancePromise = this.enqueueGovernanceVote();
|
|
35
|
+
const enqueueSlashingPromise = this.enqueueSlashingVote();
|
|
36
|
+
return [
|
|
37
|
+
enqueueGovernancePromise,
|
|
38
|
+
enqueueSlashingPromise
|
|
39
|
+
];
|
|
40
|
+
} catch (err) {
|
|
41
|
+
this.log.error(`Error enqueueing governance and slashing votes`, err);
|
|
42
|
+
return [
|
|
43
|
+
Promise.resolve(false),
|
|
44
|
+
Promise.resolve(false)
|
|
45
|
+
];
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
async enqueueGovernanceVote() {
|
|
49
|
+
const governanceProposerPayload = this.config.governanceProposerPayload;
|
|
50
|
+
if (!governanceProposerPayload || governanceProposerPayload.isZero()) {
|
|
51
|
+
return undefined;
|
|
52
|
+
}
|
|
53
|
+
this.log.info(`Enqueuing vote for ${governanceProposerPayload} governance for slot ${this.slot}`, {
|
|
54
|
+
slot: this.slot,
|
|
55
|
+
governanceProposerPayload: governanceProposerPayload.toString()
|
|
56
|
+
});
|
|
57
|
+
try {
|
|
58
|
+
return await this.publisher.enqueueGovernanceCastSignal(governanceProposerPayload, this.slot, this.slotTimestamp, this.attestorAddress, this.signer);
|
|
59
|
+
} catch (err) {
|
|
60
|
+
this.log.error(`Error enqueuing governance vote`, err, {
|
|
61
|
+
slot: this.slot
|
|
62
|
+
});
|
|
63
|
+
return false;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
async enqueueSlashingVote() {
|
|
67
|
+
try {
|
|
68
|
+
const actions = await this.slasherClient?.getProposerActions(this.slot);
|
|
69
|
+
if (!actions || actions.length === 0) {
|
|
70
|
+
return undefined;
|
|
71
|
+
}
|
|
72
|
+
this.log.info(`Enqueuing vote for ${actions.length} slashing actions for slot ${this.slot}`, {
|
|
73
|
+
slot: this.slot,
|
|
74
|
+
actionCount: actions.length
|
|
75
|
+
});
|
|
76
|
+
this.metrics.recordSlashingAttempt(actions.length);
|
|
77
|
+
return await this.publisher.enqueueSlashingActions(actions, this.slot, this.slotTimestamp, this.attestorAddress, this.signer);
|
|
78
|
+
} catch (err) {
|
|
79
|
+
this.log.error(`Error enqueuing slashing vote`, err, {
|
|
80
|
+
slot: this.slot
|
|
81
|
+
});
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import type { BlockNumber, CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import type { Action } from '../publisher/sequencer-publisher.js';
|
|
3
|
+
import type { SequencerState } from './utils.js';
|
|
4
|
+
export type SequencerEvents = {
|
|
5
|
+
['state-changed']: (args: {
|
|
6
|
+
oldState: SequencerState;
|
|
7
|
+
newState: SequencerState;
|
|
8
|
+
secondsIntoSlot?: number;
|
|
9
|
+
slot?: SlotNumber;
|
|
10
|
+
}) => void;
|
|
11
|
+
['proposer-rollup-check-failed']: (args: {
|
|
12
|
+
reason: string;
|
|
13
|
+
slot: SlotNumber;
|
|
14
|
+
}) => void;
|
|
15
|
+
['block-tx-count-check-failed']: (args: {
|
|
16
|
+
minTxs: number;
|
|
17
|
+
availableTxs: number;
|
|
18
|
+
slot: SlotNumber;
|
|
19
|
+
}) => void;
|
|
20
|
+
['block-build-failed']: (args: {
|
|
21
|
+
reason: string;
|
|
22
|
+
slot: SlotNumber;
|
|
23
|
+
}) => void;
|
|
24
|
+
['block-proposed']: (args: {
|
|
25
|
+
blockNumber: BlockNumber;
|
|
26
|
+
slot: SlotNumber;
|
|
27
|
+
}) => void;
|
|
28
|
+
['checkpoint-empty']: (args: {
|
|
29
|
+
slot: SlotNumber;
|
|
30
|
+
}) => void;
|
|
31
|
+
['checkpoint-publish-failed']: (args: {
|
|
32
|
+
slot: SlotNumber;
|
|
33
|
+
successfulActions?: Action[];
|
|
34
|
+
failedActions?: Action[];
|
|
35
|
+
sentActions?: Action[];
|
|
36
|
+
expiredActions?: Action[];
|
|
37
|
+
}) => void;
|
|
38
|
+
['checkpoint-published']: (args: {
|
|
39
|
+
checkpoint: CheckpointNumber;
|
|
40
|
+
slot: SlotNumber;
|
|
41
|
+
}) => void;
|
|
42
|
+
['checkpoint-error']: (args: {
|
|
43
|
+
error: Error;
|
|
44
|
+
}) => void;
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VxdWVuY2VyL2V2ZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFakcsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDbEUsT0FBTyxLQUFLLEVBQUUsY0FBYyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRWpELE1BQU0sTUFBTSxlQUFlLEdBQUc7SUFDNUIsQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRTtRQUN4QixRQUFRLEVBQUUsY0FBYyxDQUFDO1FBQ3pCLFFBQVEsRUFBRSxjQUFjLENBQUM7UUFDekIsZUFBZSxDQUFDLEVBQUUsTUFBTSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxFQUFFLFVBQVUsQ0FBQztLQUNuQixLQUFLLElBQUksQ0FBQztJQUNYLENBQUMsOEJBQThCLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRTtRQUFFLE1BQU0sRUFBRSxNQUFNLENBQUM7UUFBQyxJQUFJLEVBQUUsVUFBVSxDQUFBO0tBQUUsS0FBSyxJQUFJLENBQUM7SUFDdkYsQ0FBQyw2QkFBNkIsQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFO1FBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQztRQUFDLFlBQVksRUFBRSxNQUFNLENBQUM7UUFBQyxJQUFJLEVBQUUsVUFBVSxDQUFBO0tBQUUsS0FBSyxJQUFJLENBQUM7SUFDNUcsQ0FBQyxvQkFBb0IsQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFO1FBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQztRQUFDLElBQUksRUFBRSxVQUFVLENBQUE7S0FBRSxLQUFLLElBQUksQ0FBQztJQUM3RSxDQUFDLGdCQUFnQixDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUU7UUFBRSxXQUFXLEVBQUUsV0FBVyxDQUFDO1FBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQTtLQUFFLEtBQUssSUFBSSxDQUFDO0lBQ25GLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRTtRQUFFLElBQUksRUFBRSxVQUFVLENBQUE7S0FBRSxLQUFLLElBQUksQ0FBQztJQUMzRCxDQUFDLDJCQUEyQixDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUU7UUFDcEMsSUFBSSxFQUFFLFVBQVUsQ0FBQztRQUNqQixpQkFBaUIsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQzdCLGFBQWEsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQ3pCLFdBQVcsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQ3ZCLGNBQWMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDO0tBQzNCLEtBQUssSUFBSSxDQUFDO0lBQ1gsQ0FBQyxzQkFBc0IsQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFO1FBQUUsVUFBVSxFQUFFLGdCQUFnQixDQUFDO1FBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQTtLQUFFLEtBQUssSUFBSSxDQUFDO0lBQzdGLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRTtRQUFFLEtBQUssRUFBRSxLQUFLLENBQUE7S0FBRSxLQUFLLElBQUksQ0FBQztDQUN4RCxDQUFDIn0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../src/sequencer/events.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAEjG,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qCAAqC,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAEjD,MAAM,MAAM,eAAe,GAAG;IAC5B,CAAC,eAAe,CAAC,EAAE,CAAC,IAAI,EAAE;QACxB,QAAQ,EAAE,cAAc,CAAC;QACzB,QAAQ,EAAE,cAAc,CAAC;QACzB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,IAAI,CAAC,EAAE,UAAU,CAAC;KACnB,KAAK,IAAI,CAAC;IACX,CAAC,8BAA8B,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,UAAU,CAAA;KAAE,KAAK,IAAI,CAAC;IACvF,CAAC,6BAA6B,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,UAAU,CAAA;KAAE,KAAK,IAAI,CAAC;IAC5G,CAAC,oBAAoB,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,UAAU,CAAA;KAAE,KAAK,IAAI,CAAC;IAC7E,CAAC,gBAAgB,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,WAAW,EAAE,WAAW,CAAC;QAAC,IAAI,EAAE,UAAU,CAAA;KAAE,KAAK,IAAI,CAAC;IACnF,CAAC,kBAAkB,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,IAAI,EAAE,UAAU,CAAA;KAAE,KAAK,IAAI,CAAC;IAC3D,CAAC,2BAA2B,CAAC,EAAE,CAAC,IAAI,EAAE;QACpC,IAAI,EAAE,UAAU,CAAC;QACjB,iBAAiB,CAAC,EAAE,MAAM,EAAE,CAAC;QAC7B,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;QACzB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;QACvB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;KAC3B,KAAK,IAAI,CAAC;IACX,CAAC,sBAAsB,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,UAAU,EAAE,gBAAgB,CAAC;QAAC,IAAI,EAAE,UAAU,CAAA;KAAE,KAAK,IAAI,CAAC;IAC7F,CAAC,kBAAkB,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,KAAK,CAAA;KAAE,KAAK,IAAI,CAAC;CACxD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
export * from './block_builder.js';
|
|
2
|
+
export * from './checkpoint_builder.js';
|
|
3
|
+
export * from './checkpoint_proposal_job.js';
|
|
4
|
+
export * from './checkpoint_voter.js';
|
|
2
5
|
export * from './config.js';
|
|
6
|
+
export * from './events.js';
|
|
3
7
|
export * from './sequencer.js';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXF1ZW5jZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGdCQUFnQixDQUFDIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sequencer/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sequencer/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,gBAAgB,CAAC"}
|
package/dest/sequencer/index.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { EthAddress } from '@aztec/aztec.js/addresses';
|
|
2
2
|
import type { RollupContract } from '@aztec/ethereum/contracts';
|
|
3
|
+
import type { L1FeeAnalysisResult } from '@aztec/ethereum/l1-fee-analysis';
|
|
3
4
|
import type { SlotNumber } from '@aztec/foundation/branded-types';
|
|
4
5
|
import { type TelemetryClient, type Tracer } from '@aztec/telemetry-client';
|
|
5
6
|
import { type Hex } from 'viem';
|
|
@@ -22,19 +23,38 @@ export declare class SequencerMetrics {
|
|
|
22
23
|
private blockProposalFailed;
|
|
23
24
|
private blockProposalSuccess;
|
|
24
25
|
private blockProposalPrecheckFailed;
|
|
26
|
+
private checkpointSuccess;
|
|
25
27
|
private slashingAttempts;
|
|
28
|
+
private blockAttestationDelay;
|
|
29
|
+
private fishermanWouldBeIncluded;
|
|
30
|
+
private fishermanTimeBeforeBlock;
|
|
31
|
+
private fishermanPendingBlobTxCount;
|
|
32
|
+
private fishermanIncludedBlobTxCount;
|
|
33
|
+
private fishermanCalculatedPriorityFee;
|
|
34
|
+
private fishermanPriorityFeeDelta;
|
|
35
|
+
private fishermanEstimatedCost;
|
|
36
|
+
private fishermanEstimatedOverpayment;
|
|
37
|
+
private fishermanMinedBlobTxPriorityFee;
|
|
38
|
+
private fishermanMinedBlobTxTotalCost;
|
|
26
39
|
private lastSeenSlot?;
|
|
27
40
|
constructor(client: TelemetryClient, rollup: RollupContract, name?: string);
|
|
28
41
|
recordRequiredAttestations(requiredAttestationsCount: number, allowanceMs: number): void;
|
|
42
|
+
recordBlockAttestationDelay(duration: number): void;
|
|
29
43
|
recordCollectedAttestations(count: number, durationMs: number): void;
|
|
30
44
|
recordBuiltBlock(buildDurationMs: number, totalMana: number): void;
|
|
31
45
|
recordFailedBlock(): void;
|
|
32
46
|
recordStateTransitionBufferMs(durationMs: number, state: SequencerState): void;
|
|
33
47
|
incOpenSlot(slot: SlotNumber, proposer: string): void;
|
|
34
48
|
incFilledSlot(proposer: string, coinbase: Hex | EthAddress | undefined): Promise<void>;
|
|
49
|
+
recordCheckpointSuccess(): void;
|
|
35
50
|
recordBlockProposalFailed(reason?: string): void;
|
|
36
51
|
recordBlockProposalSuccess(): void;
|
|
37
52
|
recordBlockProposalPrecheckFailed(checkType: string): void;
|
|
38
53
|
recordSlashingAttempt(actionCount: number): void;
|
|
54
|
+
/**
|
|
55
|
+
* Records metrics for a completed fisherman fee analysis
|
|
56
|
+
* @param analysis - The completed fee analysis result
|
|
57
|
+
*/
|
|
58
|
+
recordFishermanFeeAnalysis(analysis: L1FeeAnalysisResult): void;
|
|
39
59
|
}
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWV0cmljcy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcXVlbmNlci9tZXRyaWNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUN2RCxPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNoRSxPQUFPLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzNFLE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xFLE9BQU8sRUFNTCxLQUFLLGVBQWUsRUFDcEIsS0FBSyxNQUFNLEVBR1osTUFBTSx5QkFBeUIsQ0FBQztBQUVqQyxPQUFPLEVBQUUsS0FBSyxHQUFHLEVBQWUsTUFBTSxNQUFNLENBQUM7QUFFN0MsT0FBTyxLQUFLLEVBQUUsY0FBYyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBR2pELHFCQUFhLGdCQUFnQjtJQTJDekIsT0FBTyxDQUFDLE1BQU07SUExQ2hCLFNBQWdCLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDL0IsT0FBTyxDQUFDLEtBQUssQ0FBUTtJQUVyQixPQUFPLENBQUMsWUFBWSxDQUFnQjtJQUNwQyxPQUFPLENBQUMsa0JBQWtCLENBQVk7SUFDdEMsT0FBTyxDQUFDLHVCQUF1QixDQUFRO0lBQ3ZDLE9BQU8sQ0FBQyw2QkFBNkIsQ0FBWTtJQUdqRCxPQUFPLENBQUMseUJBQXlCLENBQVE7SUFDekMsT0FBTyxDQUFDLDhCQUE4QixDQUFRO0lBQzlDLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBUTtJQUNsQyxPQUFPLENBQUMsbUJBQW1CLENBQVE7SUFFbkMsT0FBTyxDQUFDLE9BQU8sQ0FBUTtJQUV2QixPQUFPLENBQUMsS0FBSyxDQUFnQjtJQUM3QixPQUFPLENBQUMsV0FBVyxDQUFnQjtJQUVuQyxPQUFPLENBQUMsbUJBQW1CLENBQWdCO0lBQzNDLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBZ0I7SUFDNUMsT0FBTyxDQUFDLDJCQUEyQixDQUFnQjtJQUNuRCxPQUFPLENBQUMsaUJBQWlCLENBQWdCO0lBQ3pDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBZ0I7SUFDeEMsT0FBTyxDQUFDLHFCQUFxQixDQUFZO0lBR3pDLE9BQU8sQ0FBQyx3QkFBd0IsQ0FBZ0I7SUFDaEQsT0FBTyxDQUFDLHdCQUF3QixDQUFZO0lBQzVDLE9BQU8sQ0FBQywyQkFBMkIsQ0FBWTtJQUMvQyxPQUFPLENBQUMsNEJBQTRCLENBQVk7SUFDaEQsT0FBTyxDQUFDLDhCQUE4QixDQUFZO0lBQ2xELE9BQU8sQ0FBQyx5QkFBeUIsQ0FBWTtJQUM3QyxPQUFPLENBQUMsc0JBQXNCLENBQVk7SUFDMUMsT0FBTyxDQUFDLDZCQUE2QixDQUFZO0lBQ2pELE9BQU8sQ0FBQywrQkFBK0IsQ0FBWTtJQUNuRCxPQUFPLENBQUMsNkJBQTZCLENBQVk7SUFFakQsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFhO0lBRWxDLFlBQ0UsTUFBTSxFQUFFLGVBQWUsRUFDZixNQUFNLEVBQUUsY0FBYyxFQUM5QixJQUFJLFNBQWMsRUE4TG5CO0lBRU0sMEJBQTBCLENBQUMseUJBQXlCLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxNQUFNLFFBT3ZGO0lBRU0sMkJBQTJCLENBQUMsUUFBUSxFQUFFLE1BQU0sUUFFbEQ7SUFFTSwyQkFBMkIsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLFFBR25FO0lBRUQsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxRQU0xRDtJQUVELGlCQUFpQixTQUloQjtJQUVELDZCQUE2QixDQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLGNBQWMsUUFJdEU7SUFFRCxXQUFXLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsTUFBTSxRQVc3QztJQUVLLGFBQWEsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLEdBQUcsVUFBVSxHQUFHLFNBQVMsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBaUIzRjtJQUVELHVCQUF1QixTQUV0QjtJQUVELHlCQUF5QixDQUFDLE1BQU0sQ0FBQyxFQUFFLE1BQU0sUUFJeEM7SUFFRCwwQkFBMEIsU0FFekI7SUFFRCxpQ0FBaUMsQ0FBQyxTQUFTLEVBQUUsTUFBTSxRQUlsRDtJQUVELHFCQUFxQixDQUFDLFdBQVcsRUFBRSxNQUFNLFFBRXhDO0lBRUQ7OztPQUdHO0lBQ0gsMEJBQTBCLENBQUMsUUFBUSxFQUFFLG1CQUFtQixRQXFGdkQ7Q0FDRiJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metrics.d.ts","sourceRoot":"","sources":["../../src/sequencer/metrics.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAML,KAAK,eAAe,EACpB,KAAK,MAAM,EAGZ,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EAAE,KAAK,GAAG,EAAe,MAAM,MAAM,CAAC;AAE7C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"metrics.d.ts","sourceRoot":"","sources":["../../src/sequencer/metrics.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AAC3E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAML,KAAK,eAAe,EACpB,KAAK,MAAM,EAGZ,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EAAE,KAAK,GAAG,EAAe,MAAM,MAAM,CAAC;AAE7C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAGjD,qBAAa,gBAAgB;IA2CzB,OAAO,CAAC,MAAM;IA1ChB,SAAgB,MAAM,EAAE,MAAM,CAAC;IAC/B,OAAO,CAAC,KAAK,CAAQ;IAErB,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,kBAAkB,CAAY;IACtC,OAAO,CAAC,uBAAuB,CAAQ;IACvC,OAAO,CAAC,6BAA6B,CAAY;IAGjD,OAAO,CAAC,yBAAyB,CAAQ;IACzC,OAAO,CAAC,8BAA8B,CAAQ;IAC9C,OAAO,CAAC,kBAAkB,CAAQ;IAClC,OAAO,CAAC,mBAAmB,CAAQ;IAEnC,OAAO,CAAC,OAAO,CAAQ;IAEvB,OAAO,CAAC,KAAK,CAAgB;IAC7B,OAAO,CAAC,WAAW,CAAgB;IAEnC,OAAO,CAAC,mBAAmB,CAAgB;IAC3C,OAAO,CAAC,oBAAoB,CAAgB;IAC5C,OAAO,CAAC,2BAA2B,CAAgB;IACnD,OAAO,CAAC,iBAAiB,CAAgB;IACzC,OAAO,CAAC,gBAAgB,CAAgB;IACxC,OAAO,CAAC,qBAAqB,CAAY;IAGzC,OAAO,CAAC,wBAAwB,CAAgB;IAChD,OAAO,CAAC,wBAAwB,CAAY;IAC5C,OAAO,CAAC,2BAA2B,CAAY;IAC/C,OAAO,CAAC,4BAA4B,CAAY;IAChD,OAAO,CAAC,8BAA8B,CAAY;IAClD,OAAO,CAAC,yBAAyB,CAAY;IAC7C,OAAO,CAAC,sBAAsB,CAAY;IAC1C,OAAO,CAAC,6BAA6B,CAAY;IACjD,OAAO,CAAC,+BAA+B,CAAY;IACnD,OAAO,CAAC,6BAA6B,CAAY;IAEjD,OAAO,CAAC,YAAY,CAAC,CAAa;IAElC,YACE,MAAM,EAAE,eAAe,EACf,MAAM,EAAE,cAAc,EAC9B,IAAI,SAAc,EA8LnB;IAEM,0BAA0B,CAAC,yBAAyB,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,QAOvF;IAEM,2BAA2B,CAAC,QAAQ,EAAE,MAAM,QAElD;IAEM,2BAA2B,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,QAGnE;IAED,gBAAgB,CAAC,eAAe,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,QAM1D;IAED,iBAAiB,SAIhB;IAED,6BAA6B,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,cAAc,QAItE;IAED,WAAW,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,QAW7C;IAEK,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,GAAG,UAAU,GAAG,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAiB3F;IAED,uBAAuB,SAEtB;IAED,yBAAyB,CAAC,MAAM,CAAC,EAAE,MAAM,QAIxC;IAED,0BAA0B,SAEzB;IAED,iCAAiC,CAAC,SAAS,EAAE,MAAM,QAIlD;IAED,qBAAqB,CAAC,WAAW,EAAE,MAAM,QAExC;IAED;;;OAGG;IACH,0BAA0B,CAAC,QAAQ,EAAE,mBAAmB,QAqFvD;CACF"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Attributes, Metrics, ValueType } from '@aztec/telemetry-client';
|
|
2
2
|
import { formatUnits } from 'viem';
|
|
3
|
+
// TODO(palla/mbps): Review all metrics and add any missing ones per checkpoint
|
|
3
4
|
export class SequencerMetrics {
|
|
4
5
|
rollup;
|
|
5
6
|
tracer;
|
|
@@ -19,7 +20,20 @@ export class SequencerMetrics {
|
|
|
19
20
|
blockProposalFailed;
|
|
20
21
|
blockProposalSuccess;
|
|
21
22
|
blockProposalPrecheckFailed;
|
|
23
|
+
checkpointSuccess;
|
|
22
24
|
slashingAttempts;
|
|
25
|
+
blockAttestationDelay;
|
|
26
|
+
// Fisherman fee analysis metrics
|
|
27
|
+
fishermanWouldBeIncluded;
|
|
28
|
+
fishermanTimeBeforeBlock;
|
|
29
|
+
fishermanPendingBlobTxCount;
|
|
30
|
+
fishermanIncludedBlobTxCount;
|
|
31
|
+
fishermanCalculatedPriorityFee;
|
|
32
|
+
fishermanPriorityFeeDelta;
|
|
33
|
+
fishermanEstimatedCost;
|
|
34
|
+
fishermanEstimatedOverpayment;
|
|
35
|
+
fishermanMinedBlobTxPriorityFee;
|
|
36
|
+
fishermanMinedBlobTxTotalCost;
|
|
23
37
|
lastSeenSlot;
|
|
24
38
|
constructor(client, rollup, name = 'Sequencer'){
|
|
25
39
|
this.rollup = rollup;
|
|
@@ -41,6 +55,11 @@ export class SequencerMetrics {
|
|
|
41
55
|
description: 'The time difference between when the sequencer needed to transition to a new state and when it actually did.',
|
|
42
56
|
valueType: ValueType.INT
|
|
43
57
|
});
|
|
58
|
+
this.blockAttestationDelay = this.meter.createHistogram(Metrics.SEQUENCER_BLOCK_ATTESTATION_DELAY, {
|
|
59
|
+
unit: 'ms',
|
|
60
|
+
description: 'The time difference between block proposal and minimal attestation count reached,',
|
|
61
|
+
valueType: ValueType.INT
|
|
62
|
+
});
|
|
44
63
|
// Init gauges and counters
|
|
45
64
|
this.blockCounter.add(0, {
|
|
46
65
|
[Attributes.STATUS]: 'failed'
|
|
@@ -89,6 +108,10 @@ export class SequencerMetrics {
|
|
|
89
108
|
valueType: ValueType.INT,
|
|
90
109
|
description: 'The number of times block proposal succeeded (including validation builds)'
|
|
91
110
|
});
|
|
111
|
+
this.checkpointSuccess = this.meter.createUpDownCounter(Metrics.SEQUENCER_CHECKPOINT_SUCCESS_COUNT, {
|
|
112
|
+
valueType: ValueType.INT,
|
|
113
|
+
description: 'The number of times checkpoint publishing succeeded'
|
|
114
|
+
});
|
|
92
115
|
this.blockProposalPrecheckFailed = this.meter.createUpDownCounter(Metrics.SEQUENCER_BLOCK_PROPOSAL_PRECHECK_FAILED_COUNT, {
|
|
93
116
|
valueType: ValueType.INT,
|
|
94
117
|
description: 'The number of times block proposal pre-build checks failed'
|
|
@@ -97,6 +120,54 @@ export class SequencerMetrics {
|
|
|
97
120
|
valueType: ValueType.INT,
|
|
98
121
|
description: 'The number of slashing action attempts'
|
|
99
122
|
});
|
|
123
|
+
// Fisherman fee analysis metrics
|
|
124
|
+
this.fishermanWouldBeIncluded = this.meter.createUpDownCounter(Metrics.FISHERMAN_FEE_ANALYSIS_WOULD_BE_INCLUDED, {
|
|
125
|
+
valueType: ValueType.INT,
|
|
126
|
+
description: 'Whether the transaction would have been included in the block'
|
|
127
|
+
});
|
|
128
|
+
this.fishermanTimeBeforeBlock = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_TIME_BEFORE_BLOCK, {
|
|
129
|
+
unit: 'ms',
|
|
130
|
+
description: 'Time in ms between fee analysis and block being mined',
|
|
131
|
+
valueType: ValueType.INT
|
|
132
|
+
});
|
|
133
|
+
this.fishermanPendingBlobTxCount = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_PENDING_BLOB_TX_COUNT, {
|
|
134
|
+
description: 'Number of blob transactions seen in the pending block',
|
|
135
|
+
valueType: ValueType.INT
|
|
136
|
+
});
|
|
137
|
+
this.fishermanIncludedBlobTxCount = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_INCLUDED_BLOB_TX_COUNT, {
|
|
138
|
+
description: 'Number of blob transactions that got included in the mined block',
|
|
139
|
+
valueType: ValueType.INT
|
|
140
|
+
});
|
|
141
|
+
this.fishermanCalculatedPriorityFee = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_CALCULATED_PRIORITY_FEE, {
|
|
142
|
+
unit: 'gwei',
|
|
143
|
+
description: 'Priority fee calculated by each strategy',
|
|
144
|
+
valueType: ValueType.DOUBLE
|
|
145
|
+
});
|
|
146
|
+
this.fishermanPriorityFeeDelta = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_PRIORITY_FEE_DELTA, {
|
|
147
|
+
unit: 'gwei',
|
|
148
|
+
description: 'Difference between our priority fee and minimum included priority fee',
|
|
149
|
+
valueType: ValueType.DOUBLE
|
|
150
|
+
});
|
|
151
|
+
this.fishermanEstimatedCost = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_ESTIMATED_COST, {
|
|
152
|
+
unit: 'eth',
|
|
153
|
+
description: 'Estimated total cost in ETH for the transaction with this strategy',
|
|
154
|
+
valueType: ValueType.DOUBLE
|
|
155
|
+
});
|
|
156
|
+
this.fishermanEstimatedOverpayment = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_ESTIMATED_OVERPAYMENT, {
|
|
157
|
+
unit: 'eth',
|
|
158
|
+
description: 'Estimated overpayment in ETH vs minimum required for inclusion',
|
|
159
|
+
valueType: ValueType.DOUBLE
|
|
160
|
+
});
|
|
161
|
+
this.fishermanMinedBlobTxPriorityFee = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_MINED_BLOB_TX_PRIORITY_FEE, {
|
|
162
|
+
unit: 'gwei',
|
|
163
|
+
description: 'Priority fee per gas for blob transactions in mined blocks',
|
|
164
|
+
valueType: ValueType.DOUBLE
|
|
165
|
+
});
|
|
166
|
+
this.fishermanMinedBlobTxTotalCost = this.meter.createHistogram(Metrics.FISHERMAN_FEE_ANALYSIS_MINED_BLOB_TX_TOTAL_COST, {
|
|
167
|
+
unit: 'eth',
|
|
168
|
+
description: 'Total cost in ETH for blob transactions in mined blocks',
|
|
169
|
+
valueType: ValueType.DOUBLE
|
|
170
|
+
});
|
|
100
171
|
}
|
|
101
172
|
recordRequiredAttestations(requiredAttestationsCount, allowanceMs) {
|
|
102
173
|
this.requiredAttestions.record(requiredAttestationsCount);
|
|
@@ -105,6 +176,9 @@ export class SequencerMetrics {
|
|
|
105
176
|
this.collectedAttestions.record(0);
|
|
106
177
|
this.timeToCollectAttestations.record(0);
|
|
107
178
|
}
|
|
179
|
+
recordBlockAttestationDelay(duration) {
|
|
180
|
+
this.blockAttestationDelay.record(duration);
|
|
181
|
+
}
|
|
108
182
|
recordCollectedAttestations(count, durationMs) {
|
|
109
183
|
this.collectedAttestions.record(count);
|
|
110
184
|
this.timeToCollectAttestations.record(Math.ceil(durationMs));
|
|
@@ -153,6 +227,9 @@ export class SequencerMetrics {
|
|
|
153
227
|
}
|
|
154
228
|
}
|
|
155
229
|
}
|
|
230
|
+
recordCheckpointSuccess() {
|
|
231
|
+
this.checkpointSuccess.add(1);
|
|
232
|
+
}
|
|
156
233
|
recordBlockProposalFailed(reason) {
|
|
157
234
|
this.blockProposalFailed.add(1, {
|
|
158
235
|
...reason && {
|
|
@@ -171,4 +248,81 @@ export class SequencerMetrics {
|
|
|
171
248
|
recordSlashingAttempt(actionCount) {
|
|
172
249
|
this.slashingAttempts.add(actionCount);
|
|
173
250
|
}
|
|
251
|
+
/**
|
|
252
|
+
* Records metrics for a completed fisherman fee analysis
|
|
253
|
+
* @param analysis - The completed fee analysis result
|
|
254
|
+
*/ recordFishermanFeeAnalysis(analysis) {
|
|
255
|
+
// In fisherman mode, we should always have strategy results
|
|
256
|
+
if (!analysis.computedPrices.strategyResults || analysis.computedPrices.strategyResults.length === 0) {
|
|
257
|
+
// This should never happen in fisherman mode - log an error
|
|
258
|
+
// We don't record metrics without strategy IDs as that defeats the purpose
|
|
259
|
+
throw new Error(`No strategy results found in fisherman fee analysis ${analysis.id}. This indicates a bug in the fee analysis.`);
|
|
260
|
+
}
|
|
261
|
+
// Record metrics for each strategy separately
|
|
262
|
+
for (const strategyResult of analysis.computedPrices.strategyResults){
|
|
263
|
+
const strategyAttributes = {
|
|
264
|
+
[Attributes.FISHERMAN_FEE_STRATEGY_ID]: strategyResult.strategyId
|
|
265
|
+
};
|
|
266
|
+
// Record pending block snapshot data (once per strategy for comparison)
|
|
267
|
+
this.fishermanPendingBlobTxCount.record(analysis.pendingSnapshot.pendingBlobTxCount, strategyAttributes);
|
|
268
|
+
// Record mined block data if available
|
|
269
|
+
if (analysis.minedBlock) {
|
|
270
|
+
this.fishermanIncludedBlobTxCount.record(analysis.minedBlock.includedBlobTxCount, strategyAttributes);
|
|
271
|
+
// Record actual fees from blob transactions in the mined block
|
|
272
|
+
for (const blobTx of analysis.minedBlock.includedBlobTxs){
|
|
273
|
+
// Record priority fee per gas in Gwei
|
|
274
|
+
const priorityFeeGwei = Number(blobTx.maxPriorityFeePerGas) / 1e9;
|
|
275
|
+
this.fishermanMinedBlobTxPriorityFee.record(priorityFeeGwei, strategyAttributes);
|
|
276
|
+
// Calculate total cost in ETH
|
|
277
|
+
// Cost = (gas * (baseFee + priorityFee)) + (blobCount * blobGasPerBlob * blobBaseFee)
|
|
278
|
+
const baseFee = analysis.minedBlock.baseFeePerGas;
|
|
279
|
+
const effectiveGasPrice = baseFee + blobTx.maxPriorityFeePerGas;
|
|
280
|
+
// Calculate execution cost using actual gas limit from the transaction
|
|
281
|
+
const executionCost = blobTx.gas * effectiveGasPrice;
|
|
282
|
+
// Calculate blob cost using maxFeePerBlobGas * blobCount * GAS_PER_BLOB
|
|
283
|
+
const blobCost = blobTx.maxFeePerBlobGas * BigInt(blobTx.blobCount) * 131072n; // 128KB per blob
|
|
284
|
+
const totalCostWei = executionCost + blobCost;
|
|
285
|
+
const totalCostEth = Number(totalCostWei) / 1e18;
|
|
286
|
+
this.fishermanMinedBlobTxTotalCost.record(totalCostEth, strategyAttributes);
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
// Record the calculated priority fee for this strategy
|
|
290
|
+
const calculatedPriorityFeeGwei = Number(strategyResult.calculatedPriorityFee) / 1e9;
|
|
291
|
+
this.fishermanCalculatedPriorityFee.record(calculatedPriorityFeeGwei, strategyAttributes);
|
|
292
|
+
// Record analysis results if available
|
|
293
|
+
if (analysis.analysis) {
|
|
294
|
+
this.fishermanTimeBeforeBlock.record(Math.ceil(analysis.analysis.timeBeforeBlockMs), strategyAttributes);
|
|
295
|
+
// Record strategy-specific inclusion result
|
|
296
|
+
if (strategyResult.wouldBeIncluded !== undefined) {
|
|
297
|
+
if (strategyResult.wouldBeIncluded) {
|
|
298
|
+
this.fishermanWouldBeIncluded.add(1, {
|
|
299
|
+
...strategyAttributes,
|
|
300
|
+
[Attributes.OK]: true
|
|
301
|
+
});
|
|
302
|
+
} else {
|
|
303
|
+
this.fishermanWouldBeIncluded.add(1, {
|
|
304
|
+
...strategyAttributes,
|
|
305
|
+
[Attributes.OK]: false,
|
|
306
|
+
...strategyResult.exclusionReason && {
|
|
307
|
+
[Attributes.ERROR_TYPE]: strategyResult.exclusionReason
|
|
308
|
+
}
|
|
309
|
+
});
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
// Record strategy-specific priority fee delta
|
|
313
|
+
if (strategyResult.priorityFeeDelta !== undefined) {
|
|
314
|
+
const priorityFeeDeltaGwei = Number(strategyResult.priorityFeeDelta) / 1e9;
|
|
315
|
+
this.fishermanPriorityFeeDelta.record(priorityFeeDeltaGwei, strategyAttributes);
|
|
316
|
+
}
|
|
317
|
+
// Record estimated cost if available
|
|
318
|
+
if (strategyResult.estimatedCostEth !== undefined) {
|
|
319
|
+
this.fishermanEstimatedCost.record(strategyResult.estimatedCostEth, strategyAttributes);
|
|
320
|
+
}
|
|
321
|
+
// Record estimated overpayment if available
|
|
322
|
+
if (strategyResult.estimatedOverpaymentEth !== undefined) {
|
|
323
|
+
this.fishermanEstimatedOverpayment.record(strategyResult.estimatedOverpaymentEth, strategyAttributes);
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
}
|
|
174
328
|
}
|