@aztec/archiver 0.0.1-commit.03f7ef2 → 0.0.1-commit.04d373f
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/README.md +164 -22
- package/dest/archiver.d.ts +158 -0
- package/dest/archiver.d.ts.map +1 -0
- package/dest/archiver.js +881 -0
- package/dest/config.d.ts +33 -0
- package/dest/config.d.ts.map +1 -0
- package/dest/config.js +79 -0
- package/dest/errors.d.ts +87 -0
- package/dest/errors.d.ts.map +1 -0
- package/dest/errors.js +129 -0
- package/dest/factory.d.ts +16 -10
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +112 -20
- package/dest/index.d.ts +19 -4
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +17 -3
- package/dest/interfaces.d.ts +9 -0
- package/dest/interfaces.d.ts.map +1 -0
- package/dest/interfaces.js +3 -0
- package/dest/{archiver/l1 → l1}/bin/retrieve-calldata.d.ts +1 -1
- package/dest/l1/bin/retrieve-calldata.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/bin/retrieve-calldata.js +35 -32
- package/dest/l1/calldata_retriever.d.ts +136 -0
- package/dest/l1/calldata_retriever.d.ts.map +1 -0
- package/dest/l1/calldata_retriever.js +412 -0
- package/dest/l1/data_retrieval.d.ts +97 -0
- package/dest/l1/data_retrieval.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/data_retrieval.js +65 -89
- package/dest/{archiver/l1 → l1}/debug_tx.d.ts +1 -1
- package/dest/l1/debug_tx.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/spire_proposer.d.ts +5 -5
- package/dest/l1/spire_proposer.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/spire_proposer.js +9 -17
- package/dest/l1/trace_tx.d.ts +43 -0
- package/dest/l1/trace_tx.d.ts.map +1 -0
- package/dest/l1/types.d.ts +12 -0
- package/dest/l1/types.d.ts.map +1 -0
- package/dest/l1/validate_historical_logs.d.ts +23 -0
- package/dest/l1/validate_historical_logs.d.ts.map +1 -0
- package/dest/l1/validate_historical_logs.js +108 -0
- package/dest/{archiver/l1 → l1}/validate_trace.d.ts +6 -3
- package/dest/l1/validate_trace.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/validate_trace.js +14 -10
- package/dest/modules/contract_data_source_adapter.d.ts +25 -0
- package/dest/modules/contract_data_source_adapter.d.ts.map +1 -0
- package/dest/modules/contract_data_source_adapter.js +40 -0
- package/dest/modules/data_source_base.d.ts +113 -0
- package/dest/modules/data_source_base.d.ts.map +1 -0
- package/dest/modules/data_source_base.js +351 -0
- package/dest/modules/data_store_updater.d.ts +105 -0
- package/dest/modules/data_store_updater.d.ts.map +1 -0
- package/dest/modules/data_store_updater.js +392 -0
- package/dest/modules/instrumentation.d.ts +55 -0
- package/dest/modules/instrumentation.d.ts.map +1 -0
- package/dest/modules/instrumentation.js +145 -0
- package/dest/modules/l1_synchronizer.d.ts +77 -0
- package/dest/modules/l1_synchronizer.d.ts.map +1 -0
- package/dest/modules/l1_synchronizer.js +1344 -0
- package/dest/modules/validation.d.ts +18 -0
- package/dest/modules/validation.d.ts.map +1 -0
- package/dest/{archiver → modules}/validation.js +13 -7
- package/dest/store/block_store.d.ts +300 -0
- package/dest/store/block_store.d.ts.map +1 -0
- package/dest/store/block_store.js +1219 -0
- package/dest/store/contract_class_store.d.ts +31 -0
- package/dest/store/contract_class_store.d.ts.map +1 -0
- package/dest/store/contract_class_store.js +80 -0
- package/dest/store/contract_instance_store.d.ts +51 -0
- package/dest/store/contract_instance_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/contract_instance_store.js +38 -3
- package/dest/store/data_stores.d.ts +68 -0
- package/dest/store/data_stores.d.ts.map +1 -0
- package/dest/store/data_stores.js +54 -0
- package/dest/store/function_names_cache.d.ts +17 -0
- package/dest/store/function_names_cache.d.ts.map +1 -0
- package/dest/store/function_names_cache.js +30 -0
- package/dest/store/l2_tips_cache.d.ts +25 -0
- package/dest/store/l2_tips_cache.d.ts.map +1 -0
- package/dest/store/l2_tips_cache.js +26 -0
- package/dest/store/log_store.d.ts +59 -0
- package/dest/store/log_store.d.ts.map +1 -0
- package/dest/store/log_store.js +310 -0
- package/dest/store/log_store_codec.d.ts +70 -0
- package/dest/store/log_store_codec.d.ts.map +1 -0
- package/dest/store/log_store_codec.js +101 -0
- package/dest/store/message_store.d.ts +50 -0
- package/dest/store/message_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/message_store.js +51 -9
- package/dest/{archiver/structs → structs}/data_retrieval.d.ts +1 -1
- package/dest/structs/data_retrieval.d.ts.map +1 -0
- package/dest/structs/inbox_message.d.ts +15 -0
- package/dest/structs/inbox_message.d.ts.map +1 -0
- package/dest/{archiver/structs → structs}/published.d.ts +1 -1
- package/dest/structs/published.d.ts.map +1 -0
- package/dest/test/fake_l1_state.d.ts +214 -0
- package/dest/test/fake_l1_state.d.ts.map +1 -0
- package/dest/test/fake_l1_state.js +517 -0
- package/dest/test/index.d.ts +2 -1
- package/dest/test/index.d.ts.map +1 -1
- package/dest/test/index.js +4 -1
- package/dest/test/mock_archiver.d.ts +2 -2
- package/dest/test/mock_archiver.d.ts.map +1 -1
- package/dest/test/mock_archiver.js +3 -3
- package/dest/test/mock_l1_to_l2_message_source.d.ts +2 -2
- package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/test/mock_l1_to_l2_message_source.js +14 -4
- package/dest/test/mock_l2_block_source.d.ts +68 -40
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +356 -131
- package/dest/test/mock_structs.d.ts +81 -3
- package/dest/test/mock_structs.d.ts.map +1 -1
- package/dest/test/mock_structs.js +152 -7
- package/dest/test/noop_l1_archiver.d.ts +29 -0
- package/dest/test/noop_l1_archiver.d.ts.map +1 -0
- package/dest/test/noop_l1_archiver.js +85 -0
- package/package.json +17 -18
- package/src/archiver.ts +681 -0
- package/src/{archiver/config.ts → config.ts} +45 -14
- package/src/errors.ts +203 -0
- package/src/factory.ts +175 -22
- package/src/index.ts +27 -3
- package/src/interfaces.ts +9 -0
- package/src/l1/README.md +55 -0
- package/src/{archiver/l1 → l1}/bin/retrieve-calldata.ts +45 -33
- package/src/l1/calldata_retriever.ts +522 -0
- package/src/{archiver/l1 → l1}/data_retrieval.ts +106 -134
- package/src/{archiver/l1 → l1}/spire_proposer.ts +7 -15
- package/src/l1/validate_historical_logs.ts +140 -0
- package/src/{archiver/l1 → l1}/validate_trace.ts +25 -7
- package/src/modules/contract_data_source_adapter.ts +55 -0
- package/src/modules/data_source_base.ts +493 -0
- package/src/modules/data_store_updater.ts +518 -0
- package/src/modules/instrumentation.ts +204 -0
- package/src/modules/l1_synchronizer.ts +1257 -0
- package/src/{archiver → modules}/validation.ts +21 -15
- package/src/store/block_store.ts +1590 -0
- package/src/store/contract_class_store.ts +108 -0
- package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +52 -6
- package/src/store/data_stores.ts +104 -0
- package/src/store/function_names_cache.ts +37 -0
- package/src/store/l2_tips_cache.ts +35 -0
- package/src/store/log_store.ts +379 -0
- package/src/store/log_store_codec.ts +132 -0
- package/src/{archiver/kv_archiver_store → store}/message_store.ts +60 -10
- package/src/{archiver/structs → structs}/inbox_message.ts +1 -1
- package/src/test/fake_l1_state.ts +770 -0
- package/src/test/index.ts +4 -0
- package/src/test/mock_archiver.ts +4 -3
- package/src/test/mock_l1_to_l2_message_source.ts +11 -4
- package/src/test/mock_l2_block_source.ts +434 -144
- package/src/test/mock_structs.ts +283 -8
- package/src/test/noop_l1_archiver.ts +139 -0
- package/dest/archiver/archiver.d.ts +0 -304
- package/dest/archiver/archiver.d.ts.map +0 -1
- package/dest/archiver/archiver.js +0 -1645
- package/dest/archiver/archiver_store.d.ts +0 -308
- package/dest/archiver/archiver_store.d.ts.map +0 -1
- package/dest/archiver/archiver_store.js +0 -4
- package/dest/archiver/archiver_store_test_suite.d.ts +0 -8
- package/dest/archiver/archiver_store_test_suite.d.ts.map +0 -1
- package/dest/archiver/archiver_store_test_suite.js +0 -2790
- package/dest/archiver/config.d.ts +0 -22
- package/dest/archiver/config.d.ts.map +0 -1
- package/dest/archiver/config.js +0 -62
- package/dest/archiver/errors.d.ts +0 -36
- package/dest/archiver/errors.d.ts.map +0 -1
- package/dest/archiver/errors.js +0 -54
- package/dest/archiver/index.d.ts +0 -7
- package/dest/archiver/index.d.ts.map +0 -1
- package/dest/archiver/index.js +0 -4
- package/dest/archiver/instrumentation.d.ts +0 -37
- package/dest/archiver/instrumentation.d.ts.map +0 -1
- package/dest/archiver/instrumentation.js +0 -151
- package/dest/archiver/kv_archiver_store/block_store.d.ts +0 -157
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/block_store.js +0 -607
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +0 -18
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/contract_class_store.js +0 -120
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +0 -24
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +0 -158
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.js +0 -313
- package/dest/archiver/kv_archiver_store/log_store.d.ts +0 -45
- package/dest/archiver/kv_archiver_store/log_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/log_store.js +0 -404
- package/dest/archiver/kv_archiver_store/message_store.d.ts +0 -40
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
- package/dest/archiver/l1/bin/retrieve-calldata.d.ts.map +0 -1
- package/dest/archiver/l1/calldata_retriever.d.ts +0 -112
- package/dest/archiver/l1/calldata_retriever.d.ts.map +0 -1
- package/dest/archiver/l1/calldata_retriever.js +0 -471
- package/dest/archiver/l1/data_retrieval.d.ts +0 -90
- package/dest/archiver/l1/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/l1/debug_tx.d.ts.map +0 -1
- package/dest/archiver/l1/spire_proposer.d.ts.map +0 -1
- package/dest/archiver/l1/trace_tx.d.ts +0 -97
- package/dest/archiver/l1/trace_tx.d.ts.map +0 -1
- package/dest/archiver/l1/types.d.ts +0 -12
- package/dest/archiver/l1/types.d.ts.map +0 -1
- package/dest/archiver/l1/validate_trace.d.ts.map +0 -1
- package/dest/archiver/structs/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/structs/inbox_message.d.ts +0 -15
- package/dest/archiver/structs/inbox_message.d.ts.map +0 -1
- package/dest/archiver/structs/published.d.ts.map +0 -1
- package/dest/archiver/validation.d.ts +0 -17
- package/dest/archiver/validation.d.ts.map +0 -1
- package/dest/rpc/index.d.ts +0 -9
- package/dest/rpc/index.d.ts.map +0 -1
- package/dest/rpc/index.js +0 -15
- package/src/archiver/archiver.ts +0 -2157
- package/src/archiver/archiver_store.ts +0 -372
- package/src/archiver/archiver_store_test_suite.ts +0 -2863
- package/src/archiver/errors.ts +0 -90
- package/src/archiver/index.ts +0 -6
- package/src/archiver/instrumentation.ts +0 -201
- package/src/archiver/kv_archiver_store/block_store.ts +0 -822
- package/src/archiver/kv_archiver_store/contract_class_store.ts +0 -176
- package/src/archiver/kv_archiver_store/kv_archiver_store.ts +0 -438
- package/src/archiver/kv_archiver_store/log_store.ts +0 -522
- package/src/archiver/l1/README.md +0 -98
- package/src/archiver/l1/calldata_retriever.ts +0 -641
- package/src/rpc/index.ts +0 -16
- /package/dest/{archiver/l1 → l1}/debug_tx.js +0 -0
- /package/dest/{archiver/l1 → l1}/trace_tx.js +0 -0
- /package/dest/{archiver/l1 → l1}/types.js +0 -0
- /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
- /package/dest/{archiver/structs → structs}/inbox_message.js +0 -0
- /package/dest/{archiver/structs → structs}/published.js +0 -0
- /package/src/{archiver/l1 → l1}/debug_tx.ts +0 -0
- /package/src/{archiver/l1 → l1}/trace_tx.ts +0 -0
- /package/src/{archiver/l1 → l1}/types.ts +0 -0
- /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
- /package/src/{archiver/structs → structs}/published.ts +0 -0
package/src/archiver/errors.ts
DELETED
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import type { Fr } from '@aztec/foundation/schemas';
|
|
2
|
-
|
|
3
|
-
export class NoBlobBodiesFoundError extends Error {
|
|
4
|
-
constructor(l2BlockNum: number) {
|
|
5
|
-
super(`No blob bodies found for block ${l2BlockNum}`);
|
|
6
|
-
}
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export class InitialBlockNumberNotSequentialError extends Error {
|
|
10
|
-
constructor(
|
|
11
|
-
public readonly newBlockNumber: number,
|
|
12
|
-
public readonly previousBlockNumber: number | undefined,
|
|
13
|
-
) {
|
|
14
|
-
super(
|
|
15
|
-
`Cannot insert new block ${newBlockNumber} given previous block number in store is ${
|
|
16
|
-
previousBlockNumber ?? 'undefined'
|
|
17
|
-
}`,
|
|
18
|
-
);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export class BlockNumberNotSequentialError extends Error {
|
|
23
|
-
constructor(newBlockNumber: number, previous: number | undefined) {
|
|
24
|
-
super(
|
|
25
|
-
`Cannot insert new block ${newBlockNumber} given previous block number in batch is ${previous ?? 'undefined'}`,
|
|
26
|
-
);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
export class InitialCheckpointNumberNotSequentialError extends Error {
|
|
31
|
-
constructor(
|
|
32
|
-
public readonly newCheckpointNumber: number,
|
|
33
|
-
public readonly previousCheckpointNumber: number | undefined,
|
|
34
|
-
) {
|
|
35
|
-
super(
|
|
36
|
-
`Cannot insert new checkpoint ${newCheckpointNumber} given previous checkpoint number in store is ${
|
|
37
|
-
previousCheckpointNumber ?? 'undefined'
|
|
38
|
-
}`,
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
export class CheckpointNumberNotSequentialError extends Error {
|
|
44
|
-
constructor(newCheckpointNumber: number, previous: number | undefined) {
|
|
45
|
-
super(
|
|
46
|
-
`Cannot insert new checkpoint ${newCheckpointNumber} given previous checkpoint number in batch is ${previous ?? 'undefined'}`,
|
|
47
|
-
);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export class CheckpointNumberNotConsistentError extends Error {
|
|
52
|
-
constructor(newCheckpointNumber: number, previous: number | undefined) {
|
|
53
|
-
super(
|
|
54
|
-
`Cannot insert block for new checkpoint ${newCheckpointNumber} given previous block was checkpoint ${previous ?? 'undefined'}`,
|
|
55
|
-
);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
export class BlockIndexNotSequentialError extends Error {
|
|
60
|
-
constructor(newBlockIndex: number, previousBlockIndex: number | undefined) {
|
|
61
|
-
super(
|
|
62
|
-
`Cannot insert new block at checkpoint index ${newBlockIndex} given previous block index is ${previousBlockIndex ?? 'undefined'}`,
|
|
63
|
-
);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
export class BlockArchiveNotConsistentError extends Error {
|
|
68
|
-
constructor(
|
|
69
|
-
newBlockNumber: number,
|
|
70
|
-
previousBlockNumber: number | undefined,
|
|
71
|
-
newBlockArchive: Fr,
|
|
72
|
-
previousBlockArchive: Fr,
|
|
73
|
-
) {
|
|
74
|
-
super(
|
|
75
|
-
`Cannot insert new block number ${newBlockNumber} with archive ${newBlockArchive.toString()} previous block number is ${previousBlockNumber ?? 'undefined'}, previous archive is ${previousBlockArchive?.toString() ?? 'undefined'}`,
|
|
76
|
-
);
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
export class CheckpointNotFoundError extends Error {
|
|
81
|
-
constructor(checkpointNumber: number) {
|
|
82
|
-
super(`Failed to find expected checkpoint number ${checkpointNumber}`);
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
export class BlockNotFoundError extends Error {
|
|
87
|
-
constructor(blockNumber: number) {
|
|
88
|
-
super(`Failed to find expected block number ${blockNumber}`);
|
|
89
|
-
}
|
|
90
|
-
}
|
package/src/archiver/index.ts
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
export * from './archiver.js';
|
|
2
|
-
export * from './config.js';
|
|
3
|
-
export { type L1PublishedData } from './structs/published.js';
|
|
4
|
-
export type { ArchiverDataStore } from './archiver_store.js';
|
|
5
|
-
export { KVArchiverDataStore, ARCHIVER_DB_VERSION } from './kv_archiver_store/kv_archiver_store.js';
|
|
6
|
-
export { ContractInstanceStore } from './kv_archiver_store/contract_instance_store.js';
|
|
@@ -1,201 +0,0 @@
|
|
|
1
|
-
import { createLogger } from '@aztec/foundation/log';
|
|
2
|
-
import type { L2BlockNew } from '@aztec/stdlib/block';
|
|
3
|
-
import {
|
|
4
|
-
Attributes,
|
|
5
|
-
type Gauge,
|
|
6
|
-
type Histogram,
|
|
7
|
-
LmdbMetrics,
|
|
8
|
-
type LmdbStatsCallback,
|
|
9
|
-
Metrics,
|
|
10
|
-
type TelemetryClient,
|
|
11
|
-
type Tracer,
|
|
12
|
-
type UpDownCounter,
|
|
13
|
-
ValueType,
|
|
14
|
-
} from '@aztec/telemetry-client';
|
|
15
|
-
|
|
16
|
-
export class ArchiverInstrumentation {
|
|
17
|
-
public readonly tracer: Tracer;
|
|
18
|
-
|
|
19
|
-
private blockHeight: Gauge;
|
|
20
|
-
private txCount: UpDownCounter;
|
|
21
|
-
private l1BlockHeight: Gauge;
|
|
22
|
-
private proofsSubmittedDelay: Histogram;
|
|
23
|
-
private proofsSubmittedCount: UpDownCounter;
|
|
24
|
-
private dbMetrics: LmdbMetrics;
|
|
25
|
-
|
|
26
|
-
private pruneDuration: Histogram;
|
|
27
|
-
private pruneCount: UpDownCounter;
|
|
28
|
-
|
|
29
|
-
private syncDurationPerBlock: Histogram;
|
|
30
|
-
private syncBlockCount: UpDownCounter;
|
|
31
|
-
private manaPerBlock: Histogram;
|
|
32
|
-
private txsPerBlock: Histogram;
|
|
33
|
-
|
|
34
|
-
private syncDurationPerMessage: Histogram;
|
|
35
|
-
private syncMessageCount: UpDownCounter;
|
|
36
|
-
|
|
37
|
-
private blockProposalTxTargetCount: UpDownCounter;
|
|
38
|
-
|
|
39
|
-
private log = createLogger('archiver:instrumentation');
|
|
40
|
-
|
|
41
|
-
private constructor(
|
|
42
|
-
private telemetry: TelemetryClient,
|
|
43
|
-
lmdbStats?: LmdbStatsCallback,
|
|
44
|
-
) {
|
|
45
|
-
this.tracer = telemetry.getTracer('Archiver');
|
|
46
|
-
const meter = telemetry.getMeter('Archiver');
|
|
47
|
-
|
|
48
|
-
this.blockHeight = meter.createGauge(Metrics.ARCHIVER_BLOCK_HEIGHT, {
|
|
49
|
-
description: 'The height of the latest block processed by the archiver',
|
|
50
|
-
valueType: ValueType.INT,
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
this.l1BlockHeight = meter.createGauge(Metrics.ARCHIVER_L1_BLOCK_HEIGHT, {
|
|
54
|
-
description: 'The height of the latest L1 block processed by the archiver',
|
|
55
|
-
valueType: ValueType.INT,
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
this.txCount = meter.createUpDownCounter(Metrics.ARCHIVER_TOTAL_TXS, {
|
|
59
|
-
description: 'The total number of transactions',
|
|
60
|
-
valueType: ValueType.INT,
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
this.proofsSubmittedCount = meter.createUpDownCounter(Metrics.ARCHIVER_ROLLUP_PROOF_COUNT, {
|
|
64
|
-
description: 'Number of proofs submitted',
|
|
65
|
-
valueType: ValueType.INT,
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
this.proofsSubmittedDelay = meter.createHistogram(Metrics.ARCHIVER_ROLLUP_PROOF_DELAY, {
|
|
69
|
-
unit: 'ms',
|
|
70
|
-
description: 'Time after a block is submitted until its proof is published',
|
|
71
|
-
valueType: ValueType.INT,
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
this.syncDurationPerBlock = meter.createHistogram(Metrics.ARCHIVER_SYNC_PER_BLOCK, {
|
|
75
|
-
unit: 'ms',
|
|
76
|
-
description: 'Duration to sync a block',
|
|
77
|
-
valueType: ValueType.INT,
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
this.syncBlockCount = meter.createUpDownCounter(Metrics.ARCHIVER_SYNC_BLOCK_COUNT, {
|
|
81
|
-
description: 'Number of blocks synced from L1',
|
|
82
|
-
valueType: ValueType.INT,
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
this.manaPerBlock = meter.createHistogram(Metrics.ARCHIVER_MANA_PER_BLOCK, {
|
|
86
|
-
description: 'The mana consumed by blocks',
|
|
87
|
-
valueType: ValueType.DOUBLE,
|
|
88
|
-
unit: 'Mmana',
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
this.txsPerBlock = meter.createHistogram(Metrics.ARCHIVER_TXS_PER_BLOCK, {
|
|
92
|
-
description: 'The block tx count',
|
|
93
|
-
valueType: ValueType.INT,
|
|
94
|
-
unit: 'tx',
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
this.syncDurationPerMessage = meter.createHistogram(Metrics.ARCHIVER_SYNC_PER_MESSAGE, {
|
|
98
|
-
unit: 'ms',
|
|
99
|
-
description: 'Duration to sync a message',
|
|
100
|
-
valueType: ValueType.INT,
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
this.syncMessageCount = meter.createUpDownCounter(Metrics.ARCHIVER_SYNC_MESSAGE_COUNT, {
|
|
104
|
-
description: 'Number of L1 to L2 messages synced',
|
|
105
|
-
valueType: ValueType.INT,
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
this.pruneDuration = meter.createHistogram(Metrics.ARCHIVER_PRUNE_DURATION, {
|
|
109
|
-
unit: 'ms',
|
|
110
|
-
description: 'Duration to sync a message',
|
|
111
|
-
valueType: ValueType.INT,
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
this.pruneCount = meter.createUpDownCounter(Metrics.ARCHIVER_PRUNE_COUNT, {
|
|
115
|
-
description: 'Number of prunes detected',
|
|
116
|
-
valueType: ValueType.INT,
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
this.blockProposalTxTargetCount = meter.createUpDownCounter(Metrics.ARCHIVER_BLOCK_PROPOSAL_TX_TARGET_COUNT, {
|
|
120
|
-
description: 'Number of block proposals by tx target',
|
|
121
|
-
valueType: ValueType.INT,
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
this.dbMetrics = new LmdbMetrics(
|
|
125
|
-
meter,
|
|
126
|
-
{
|
|
127
|
-
[Attributes.DB_DATA_TYPE]: 'archiver',
|
|
128
|
-
},
|
|
129
|
-
lmdbStats,
|
|
130
|
-
);
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
public static async new(telemetry: TelemetryClient, lmdbStats?: LmdbStatsCallback) {
|
|
134
|
-
const instance = new ArchiverInstrumentation(telemetry, lmdbStats);
|
|
135
|
-
|
|
136
|
-
instance.syncBlockCount.add(0);
|
|
137
|
-
instance.syncMessageCount.add(0);
|
|
138
|
-
instance.pruneCount.add(0);
|
|
139
|
-
|
|
140
|
-
await instance.telemetry.flush();
|
|
141
|
-
|
|
142
|
-
return instance;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
public isEnabled(): boolean {
|
|
146
|
-
return this.telemetry.isEnabled();
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
public processNewBlocks(syncTimePerBlock: number, blocks: L2BlockNew[]) {
|
|
150
|
-
this.syncDurationPerBlock.record(Math.ceil(syncTimePerBlock));
|
|
151
|
-
this.blockHeight.record(Math.max(...blocks.map(b => b.number)));
|
|
152
|
-
this.syncBlockCount.add(blocks.length);
|
|
153
|
-
|
|
154
|
-
for (const block of blocks) {
|
|
155
|
-
this.txCount.add(block.body.txEffects.length);
|
|
156
|
-
this.txsPerBlock.record(block.body.txEffects.length);
|
|
157
|
-
this.manaPerBlock.record(block.header.totalManaUsed.toNumber() / 1e6);
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
public processNewMessages(count: number, syncPerMessageMs: number) {
|
|
162
|
-
if (count === 0) {
|
|
163
|
-
return;
|
|
164
|
-
}
|
|
165
|
-
this.syncMessageCount.add(count);
|
|
166
|
-
this.syncDurationPerMessage.record(Math.ceil(syncPerMessageMs));
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
public processPrune(duration: number) {
|
|
170
|
-
this.pruneCount.add(1);
|
|
171
|
-
this.pruneDuration.record(Math.ceil(duration));
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
public updateLastProvenBlock(blockNumber: number) {
|
|
175
|
-
this.blockHeight.record(blockNumber, { [Attributes.STATUS]: 'proven' });
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
public processProofsVerified(logs: { proverId: string; l2BlockNumber: bigint; delay: bigint }[]) {
|
|
179
|
-
for (const log of logs) {
|
|
180
|
-
this.log.debug('Recording proof verified event', log);
|
|
181
|
-
this.proofsSubmittedCount.add(1, {
|
|
182
|
-
[Attributes.ROLLUP_PROVER_ID]: log.proverId,
|
|
183
|
-
[Attributes.PROOF_TIMED_OUT]: log.delay > 20n * 60n * 1000n,
|
|
184
|
-
});
|
|
185
|
-
this.proofsSubmittedDelay.record(Math.ceil(Number(log.delay)), {
|
|
186
|
-
[Attributes.ROLLUP_PROVER_ID]: log.proverId,
|
|
187
|
-
});
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
public updateL1BlockHeight(blockNumber: bigint) {
|
|
192
|
-
this.l1BlockHeight.record(Number(blockNumber));
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
public recordBlockProposalTxTarget(target: string, usedTrace: boolean) {
|
|
196
|
-
this.blockProposalTxTargetCount.add(1, {
|
|
197
|
-
[Attributes.L1_BLOCK_PROPOSAL_TX_TARGET]: target.toLowerCase(),
|
|
198
|
-
[Attributes.L1_BLOCK_PROPOSAL_USED_TRACE]: usedTrace,
|
|
199
|
-
});
|
|
200
|
-
}
|
|
201
|
-
}
|