@aztec/archiver 0.0.1-commit.c7c42ec → 0.0.1-commit.f295ac2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (187) hide show
  1. package/README.md +147 -22
  2. package/dest/archiver.d.ts +135 -0
  3. package/dest/archiver.d.ts.map +1 -0
  4. package/dest/archiver.js +769 -0
  5. package/dest/{archiver/config.d.ts → config.d.ts} +9 -1
  6. package/dest/config.d.ts.map +1 -0
  7. package/dest/{archiver/config.js → config.js} +11 -2
  8. package/dest/{archiver/errors.d.ts → errors.d.ts} +1 -1
  9. package/dest/errors.d.ts.map +1 -0
  10. package/dest/factory.d.ts +5 -6
  11. package/dest/factory.d.ts.map +1 -1
  12. package/dest/factory.js +82 -5
  13. package/dest/index.d.ts +10 -4
  14. package/dest/index.d.ts.map +1 -1
  15. package/dest/index.js +8 -3
  16. package/dest/interfaces.d.ts +9 -0
  17. package/dest/interfaces.d.ts.map +1 -0
  18. package/dest/interfaces.js +3 -0
  19. package/dest/{archiver/l1 → l1}/bin/retrieve-calldata.d.ts +1 -1
  20. package/dest/l1/bin/retrieve-calldata.d.ts.map +1 -0
  21. package/dest/{archiver/l1 → l1}/calldata_retriever.d.ts +3 -3
  22. package/dest/l1/calldata_retriever.d.ts.map +1 -0
  23. package/dest/{archiver/l1 → l1}/calldata_retriever.js +2 -2
  24. package/dest/l1/data_retrieval.d.ts +88 -0
  25. package/dest/l1/data_retrieval.d.ts.map +1 -0
  26. package/dest/{archiver/l1 → l1}/data_retrieval.js +34 -53
  27. package/dest/{archiver/l1 → l1}/debug_tx.d.ts +1 -1
  28. package/dest/l1/debug_tx.d.ts.map +1 -0
  29. package/dest/{archiver/l1 → l1}/spire_proposer.d.ts +1 -1
  30. package/dest/l1/spire_proposer.d.ts.map +1 -0
  31. package/dest/{archiver/l1 → l1}/trace_tx.d.ts +1 -1
  32. package/dest/l1/trace_tx.d.ts.map +1 -0
  33. package/dest/l1/types.d.ts +12 -0
  34. package/dest/l1/types.d.ts.map +1 -0
  35. package/dest/{archiver/l1 → l1}/validate_trace.d.ts +1 -1
  36. package/dest/l1/validate_trace.d.ts.map +1 -0
  37. package/dest/{archiver/l1 → l1}/validate_trace.js +1 -1
  38. package/dest/modules/data_source_base.d.ts +85 -0
  39. package/dest/modules/data_source_base.d.ts.map +1 -0
  40. package/dest/modules/data_source_base.js +291 -0
  41. package/dest/modules/data_store_updater.d.ts +69 -0
  42. package/dest/modules/data_store_updater.d.ts.map +1 -0
  43. package/dest/modules/data_store_updater.js +304 -0
  44. package/dest/modules/instrumentation.d.ts +37 -0
  45. package/dest/modules/instrumentation.d.ts.map +1 -0
  46. package/dest/{archiver → modules}/instrumentation.js +15 -63
  47. package/dest/modules/l1_synchronizer.d.ts +75 -0
  48. package/dest/modules/l1_synchronizer.d.ts.map +1 -0
  49. package/dest/modules/l1_synchronizer.js +1113 -0
  50. package/dest/modules/validation.d.ts +17 -0
  51. package/dest/modules/validation.d.ts.map +1 -0
  52. package/dest/{archiver → modules}/validation.js +7 -1
  53. package/dest/{archiver/kv_archiver_store → store}/block_store.d.ts +27 -6
  54. package/dest/store/block_store.d.ts.map +1 -0
  55. package/dest/{archiver/kv_archiver_store → store}/block_store.js +87 -14
  56. package/dest/store/contract_class_store.d.ts +18 -0
  57. package/dest/store/contract_class_store.d.ts.map +1 -0
  58. package/dest/{archiver/kv_archiver_store → store}/contract_class_store.js +1 -1
  59. package/dest/store/contract_instance_store.d.ts +24 -0
  60. package/dest/store/contract_instance_store.d.ts.map +1 -0
  61. package/dest/{archiver/kv_archiver_store → store}/contract_instance_store.js +1 -1
  62. package/dest/{archiver/archiver_store.d.ts → store/kv_archiver_store.d.ts} +155 -132
  63. package/dest/store/kv_archiver_store.d.ts.map +1 -0
  64. package/dest/{archiver/kv_archiver_store → store}/kv_archiver_store.js +173 -48
  65. package/dest/{archiver/kv_archiver_store → store}/log_store.d.ts +1 -1
  66. package/dest/store/log_store.d.ts.map +1 -0
  67. package/dest/{archiver/kv_archiver_store → store}/log_store.js +69 -48
  68. package/dest/{archiver/kv_archiver_store → store}/message_store.d.ts +1 -1
  69. package/dest/store/message_store.d.ts.map +1 -0
  70. package/dest/{archiver/structs → structs}/data_retrieval.d.ts +1 -1
  71. package/dest/structs/data_retrieval.d.ts.map +1 -0
  72. package/dest/structs/inbox_message.d.ts +15 -0
  73. package/dest/structs/inbox_message.d.ts.map +1 -0
  74. package/dest/{archiver/structs → structs}/published.d.ts +1 -1
  75. package/dest/structs/published.d.ts.map +1 -0
  76. package/dest/test/fake_l1_state.d.ts +190 -0
  77. package/dest/test/fake_l1_state.d.ts.map +1 -0
  78. package/dest/test/fake_l1_state.js +383 -0
  79. package/dest/test/index.d.ts +2 -1
  80. package/dest/test/index.d.ts.map +1 -1
  81. package/dest/test/index.js +1 -0
  82. package/dest/test/mock_archiver.d.ts +2 -2
  83. package/dest/test/mock_archiver.d.ts.map +1 -1
  84. package/dest/test/mock_archiver.js +1 -2
  85. package/dest/test/mock_l1_to_l2_message_source.d.ts +2 -2
  86. package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
  87. package/dest/test/mock_l1_to_l2_message_source.js +12 -3
  88. package/dest/test/mock_l2_block_source.d.ts +21 -14
  89. package/dest/test/mock_l2_block_source.d.ts.map +1 -1
  90. package/dest/test/mock_l2_block_source.js +147 -40
  91. package/dest/test/mock_structs.d.ts +76 -2
  92. package/dest/test/mock_structs.d.ts.map +1 -1
  93. package/dest/test/mock_structs.js +133 -2
  94. package/package.json +15 -17
  95. package/src/archiver.ts +525 -0
  96. package/src/{archiver/config.ts → config.ts} +13 -2
  97. package/src/factory.ts +118 -6
  98. package/src/index.ts +10 -3
  99. package/src/interfaces.ts +9 -0
  100. package/src/{archiver/l1 → l1}/calldata_retriever.ts +3 -3
  101. package/src/{archiver/l1 → l1}/data_retrieval.ts +54 -71
  102. package/src/{archiver/l1 → l1}/validate_trace.ts +1 -1
  103. package/src/modules/data_source_base.ts +414 -0
  104. package/src/modules/data_store_updater.ts +419 -0
  105. package/src/{archiver → modules}/instrumentation.ts +14 -63
  106. package/src/modules/l1_synchronizer.ts +931 -0
  107. package/src/{archiver → modules}/validation.ts +11 -6
  108. package/src/{archiver/kv_archiver_store → store}/block_store.ts +116 -19
  109. package/src/{archiver/kv_archiver_store → store}/contract_class_store.ts +1 -1
  110. package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +1 -1
  111. package/src/{archiver/kv_archiver_store → store}/kv_archiver_store.ts +196 -12
  112. package/src/{archiver/kv_archiver_store → store}/log_store.ts +112 -76
  113. package/src/test/fake_l1_state.ts +599 -0
  114. package/src/test/index.ts +1 -0
  115. package/src/test/mock_archiver.ts +2 -2
  116. package/src/test/mock_l1_to_l2_message_source.ts +10 -4
  117. package/src/test/mock_l2_block_source.ts +168 -52
  118. package/src/test/mock_structs.ts +247 -2
  119. package/dest/archiver/archiver.d.ts +0 -304
  120. package/dest/archiver/archiver.d.ts.map +0 -1
  121. package/dest/archiver/archiver.js +0 -1645
  122. package/dest/archiver/archiver_store.d.ts.map +0 -1
  123. package/dest/archiver/archiver_store.js +0 -4
  124. package/dest/archiver/archiver_store_test_suite.d.ts +0 -8
  125. package/dest/archiver/archiver_store_test_suite.d.ts.map +0 -1
  126. package/dest/archiver/archiver_store_test_suite.js +0 -2770
  127. package/dest/archiver/config.d.ts.map +0 -1
  128. package/dest/archiver/errors.d.ts.map +0 -1
  129. package/dest/archiver/index.d.ts +0 -7
  130. package/dest/archiver/index.d.ts.map +0 -1
  131. package/dest/archiver/index.js +0 -4
  132. package/dest/archiver/instrumentation.d.ts +0 -37
  133. package/dest/archiver/instrumentation.d.ts.map +0 -1
  134. package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
  135. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +0 -18
  136. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +0 -1
  137. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +0 -24
  138. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +0 -1
  139. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +0 -158
  140. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +0 -1
  141. package/dest/archiver/kv_archiver_store/log_store.d.ts.map +0 -1
  142. package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
  143. package/dest/archiver/l1/bin/retrieve-calldata.d.ts.map +0 -1
  144. package/dest/archiver/l1/calldata_retriever.d.ts.map +0 -1
  145. package/dest/archiver/l1/data_retrieval.d.ts +0 -90
  146. package/dest/archiver/l1/data_retrieval.d.ts.map +0 -1
  147. package/dest/archiver/l1/debug_tx.d.ts.map +0 -1
  148. package/dest/archiver/l1/spire_proposer.d.ts.map +0 -1
  149. package/dest/archiver/l1/trace_tx.d.ts.map +0 -1
  150. package/dest/archiver/l1/types.d.ts +0 -12
  151. package/dest/archiver/l1/types.d.ts.map +0 -1
  152. package/dest/archiver/l1/validate_trace.d.ts.map +0 -1
  153. package/dest/archiver/structs/data_retrieval.d.ts.map +0 -1
  154. package/dest/archiver/structs/inbox_message.d.ts +0 -15
  155. package/dest/archiver/structs/inbox_message.d.ts.map +0 -1
  156. package/dest/archiver/structs/published.d.ts.map +0 -1
  157. package/dest/archiver/validation.d.ts +0 -17
  158. package/dest/archiver/validation.d.ts.map +0 -1
  159. package/dest/rpc/index.d.ts +0 -9
  160. package/dest/rpc/index.d.ts.map +0 -1
  161. package/dest/rpc/index.js +0 -15
  162. package/src/archiver/archiver.ts +0 -2157
  163. package/src/archiver/archiver_store.ts +0 -372
  164. package/src/archiver/archiver_store_test_suite.ts +0 -2843
  165. package/src/archiver/index.ts +0 -6
  166. package/src/rpc/index.ts +0 -16
  167. /package/dest/{archiver/errors.js → errors.js} +0 -0
  168. /package/dest/{archiver/l1 → l1}/bin/retrieve-calldata.js +0 -0
  169. /package/dest/{archiver/l1 → l1}/debug_tx.js +0 -0
  170. /package/dest/{archiver/l1 → l1}/spire_proposer.js +0 -0
  171. /package/dest/{archiver/l1 → l1}/trace_tx.js +0 -0
  172. /package/dest/{archiver/l1 → l1}/types.js +0 -0
  173. /package/dest/{archiver/kv_archiver_store → store}/message_store.js +0 -0
  174. /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
  175. /package/dest/{archiver/structs → structs}/inbox_message.js +0 -0
  176. /package/dest/{archiver/structs → structs}/published.js +0 -0
  177. /package/src/{archiver/errors.ts → errors.ts} +0 -0
  178. /package/src/{archiver/l1 → l1}/README.md +0 -0
  179. /package/src/{archiver/l1 → l1}/bin/retrieve-calldata.ts +0 -0
  180. /package/src/{archiver/l1 → l1}/debug_tx.ts +0 -0
  181. /package/src/{archiver/l1 → l1}/spire_proposer.ts +0 -0
  182. /package/src/{archiver/l1 → l1}/trace_tx.ts +0 -0
  183. /package/src/{archiver/l1 → l1}/types.ts +0 -0
  184. /package/src/{archiver/kv_archiver_store → store}/message_store.ts +0 -0
  185. /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
  186. /package/src/{archiver/structs → structs}/inbox_message.ts +0 -0
  187. /package/src/{archiver/structs → structs}/published.ts +0 -0
@@ -0,0 +1,37 @@
1
+ import type { L2BlockNew } from '@aztec/stdlib/block';
2
+ import { type LmdbStatsCallback, type TelemetryClient, type Tracer } from '@aztec/telemetry-client';
3
+ export declare class ArchiverInstrumentation {
4
+ private telemetry;
5
+ readonly tracer: Tracer;
6
+ private blockHeight;
7
+ private txCount;
8
+ private l1BlockHeight;
9
+ private proofsSubmittedDelay;
10
+ private proofsSubmittedCount;
11
+ private dbMetrics;
12
+ private pruneDuration;
13
+ private pruneCount;
14
+ private syncDurationPerBlock;
15
+ private syncBlockCount;
16
+ private manaPerBlock;
17
+ private txsPerBlock;
18
+ private syncDurationPerMessage;
19
+ private syncMessageCount;
20
+ private blockProposalTxTargetCount;
21
+ private log;
22
+ private constructor();
23
+ static new(telemetry: TelemetryClient, lmdbStats?: LmdbStatsCallback): Promise<ArchiverInstrumentation>;
24
+ isEnabled(): boolean;
25
+ processNewBlocks(syncTimePerBlock: number, blocks: L2BlockNew[]): void;
26
+ processNewMessages(count: number, syncPerMessageMs: number): void;
27
+ processPrune(duration: number): void;
28
+ updateLastProvenBlock(blockNumber: number): void;
29
+ processProofsVerified(logs: {
30
+ proverId: string;
31
+ l2BlockNumber: bigint;
32
+ delay: bigint;
33
+ }[]): void;
34
+ updateL1BlockHeight(blockNumber: bigint): void;
35
+ recordBlockProposalTxTarget(target: string, usedTrace: boolean): void;
36
+ }
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5zdHJ1bWVudGF0aW9uLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kdWxlcy9pbnN0cnVtZW50YXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUtMLEtBQUssaUJBQWlCLEVBRXRCLEtBQUssZUFBZSxFQUNwQixLQUFLLE1BQU0sRUFFWixNQUFNLHlCQUF5QixDQUFDO0FBRWpDLHFCQUFhLHVCQUF1QjtJQTBCaEMsT0FBTyxDQUFDLFNBQVM7SUF6Qm5CLFNBQWdCLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFFL0IsT0FBTyxDQUFDLFdBQVcsQ0FBUTtJQUMzQixPQUFPLENBQUMsT0FBTyxDQUFnQjtJQUMvQixPQUFPLENBQUMsYUFBYSxDQUFRO0lBQzdCLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBWTtJQUN4QyxPQUFPLENBQUMsb0JBQW9CLENBQWdCO0lBQzVDLE9BQU8sQ0FBQyxTQUFTLENBQWM7SUFFL0IsT0FBTyxDQUFDLGFBQWEsQ0FBWTtJQUNqQyxPQUFPLENBQUMsVUFBVSxDQUFnQjtJQUVsQyxPQUFPLENBQUMsb0JBQW9CLENBQVk7SUFDeEMsT0FBTyxDQUFDLGNBQWMsQ0FBZ0I7SUFDdEMsT0FBTyxDQUFDLFlBQVksQ0FBWTtJQUNoQyxPQUFPLENBQUMsV0FBVyxDQUFZO0lBRS9CLE9BQU8sQ0FBQyxzQkFBc0IsQ0FBWTtJQUMxQyxPQUFPLENBQUMsZ0JBQWdCLENBQWdCO0lBRXhDLE9BQU8sQ0FBQywwQkFBMEIsQ0FBZ0I7SUFFbEQsT0FBTyxDQUFDLEdBQUcsQ0FBNEM7SUFFdkQsT0FBTyxlQTBDTjtJQUVELE9BQW9CLEdBQUcsQ0FBQyxTQUFTLEVBQUUsZUFBZSxFQUFFLFNBQVMsQ0FBQyxFQUFFLGlCQUFpQixvQ0FVaEY7SUFFTSxTQUFTLElBQUksT0FBTyxDQUUxQjtJQUVNLGdCQUFnQixDQUFDLGdCQUFnQixFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLFFBVXJFO0lBRU0sa0JBQWtCLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLFFBTWhFO0lBRU0sWUFBWSxDQUFDLFFBQVEsRUFBRSxNQUFNLFFBR25DO0lBRU0scUJBQXFCLENBQUMsV0FBVyxFQUFFLE1BQU0sUUFFL0M7SUFFTSxxQkFBcUIsQ0FBQyxJQUFJLEVBQUU7UUFBRSxRQUFRLEVBQUUsTUFBTSxDQUFDO1FBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQztRQUFDLEtBQUssRUFBRSxNQUFNLENBQUE7S0FBRSxFQUFFLFFBVzlGO0lBRU0sbUJBQW1CLENBQUMsV0FBVyxFQUFFLE1BQU0sUUFFN0M7SUFFTSwyQkFBMkIsQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxPQUFPLFFBS3BFO0NBQ0YifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instrumentation.d.ts","sourceRoot":"","sources":["../../src/modules/instrumentation.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAKL,KAAK,iBAAiB,EAEtB,KAAK,eAAe,EACpB,KAAK,MAAM,EAEZ,MAAM,yBAAyB,CAAC;AAEjC,qBAAa,uBAAuB;IA0BhC,OAAO,CAAC,SAAS;IAzBnB,SAAgB,MAAM,EAAE,MAAM,CAAC;IAE/B,OAAO,CAAC,WAAW,CAAQ;IAC3B,OAAO,CAAC,OAAO,CAAgB;IAC/B,OAAO,CAAC,aAAa,CAAQ;IAC7B,OAAO,CAAC,oBAAoB,CAAY;IACxC,OAAO,CAAC,oBAAoB,CAAgB;IAC5C,OAAO,CAAC,SAAS,CAAc;IAE/B,OAAO,CAAC,aAAa,CAAY;IACjC,OAAO,CAAC,UAAU,CAAgB;IAElC,OAAO,CAAC,oBAAoB,CAAY;IACxC,OAAO,CAAC,cAAc,CAAgB;IACtC,OAAO,CAAC,YAAY,CAAY;IAChC,OAAO,CAAC,WAAW,CAAY;IAE/B,OAAO,CAAC,sBAAsB,CAAY;IAC1C,OAAO,CAAC,gBAAgB,CAAgB;IAExC,OAAO,CAAC,0BAA0B,CAAgB;IAElD,OAAO,CAAC,GAAG,CAA4C;IAEvD,OAAO,eA0CN;IAED,OAAoB,GAAG,CAAC,SAAS,EAAE,eAAe,EAAE,SAAS,CAAC,EAAE,iBAAiB,oCAUhF;IAEM,SAAS,IAAI,OAAO,CAE1B;IAEM,gBAAgB,CAAC,gBAAgB,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,QAUrE;IAEM,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,QAMhE;IAEM,YAAY,CAAC,QAAQ,EAAE,MAAM,QAGnC;IAEM,qBAAqB,CAAC,WAAW,EAAE,MAAM,QAE/C;IAEM,qBAAqB,CAAC,IAAI,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,aAAa,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,QAW9F;IAEM,mBAAmB,CAAC,WAAW,EAAE,MAAM,QAE7C;IAEM,2BAA2B,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,QAKpE;CACF"}
@@ -1,5 +1,5 @@
1
1
  import { createLogger } from '@aztec/foundation/log';
2
- import { Attributes, LmdbMetrics, Metrics, ValueType } from '@aztec/telemetry-client';
2
+ import { Attributes, LmdbMetrics, Metrics } from '@aztec/telemetry-client';
3
3
  export class ArchiverInstrumentation {
4
4
  telemetry;
5
5
  tracer;
@@ -24,68 +24,20 @@ export class ArchiverInstrumentation {
24
24
  this.log = createLogger('archiver:instrumentation');
25
25
  this.tracer = telemetry.getTracer('Archiver');
26
26
  const meter = telemetry.getMeter('Archiver');
27
- this.blockHeight = meter.createGauge(Metrics.ARCHIVER_BLOCK_HEIGHT, {
28
- description: 'The height of the latest block processed by the archiver',
29
- valueType: ValueType.INT
30
- });
31
- this.l1BlockHeight = meter.createGauge(Metrics.ARCHIVER_L1_BLOCK_HEIGHT, {
32
- description: 'The height of the latest L1 block processed by the archiver',
33
- valueType: ValueType.INT
34
- });
35
- this.txCount = meter.createUpDownCounter(Metrics.ARCHIVER_TOTAL_TXS, {
36
- description: 'The total number of transactions',
37
- valueType: ValueType.INT
38
- });
39
- this.proofsSubmittedCount = meter.createUpDownCounter(Metrics.ARCHIVER_ROLLUP_PROOF_COUNT, {
40
- description: 'Number of proofs submitted',
41
- valueType: ValueType.INT
42
- });
43
- this.proofsSubmittedDelay = meter.createHistogram(Metrics.ARCHIVER_ROLLUP_PROOF_DELAY, {
44
- unit: 'ms',
45
- description: 'Time after a block is submitted until its proof is published',
46
- valueType: ValueType.INT
47
- });
48
- this.syncDurationPerBlock = meter.createHistogram(Metrics.ARCHIVER_SYNC_PER_BLOCK, {
49
- unit: 'ms',
50
- description: 'Duration to sync a block',
51
- valueType: ValueType.INT
52
- });
53
- this.syncBlockCount = meter.createUpDownCounter(Metrics.ARCHIVER_SYNC_BLOCK_COUNT, {
54
- description: 'Number of blocks synced from L1',
55
- valueType: ValueType.INT
56
- });
57
- this.manaPerBlock = meter.createHistogram(Metrics.ARCHIVER_MANA_PER_BLOCK, {
58
- description: 'The mana consumed by blocks',
59
- valueType: ValueType.DOUBLE,
60
- unit: 'Mmana'
61
- });
62
- this.txsPerBlock = meter.createHistogram(Metrics.ARCHIVER_TXS_PER_BLOCK, {
63
- description: 'The block tx count',
64
- valueType: ValueType.INT,
65
- unit: 'tx'
66
- });
67
- this.syncDurationPerMessage = meter.createHistogram(Metrics.ARCHIVER_SYNC_PER_MESSAGE, {
68
- unit: 'ms',
69
- description: 'Duration to sync a message',
70
- valueType: ValueType.INT
71
- });
72
- this.syncMessageCount = meter.createUpDownCounter(Metrics.ARCHIVER_SYNC_MESSAGE_COUNT, {
73
- description: 'Number of L1 to L2 messages synced',
74
- valueType: ValueType.INT
75
- });
76
- this.pruneDuration = meter.createHistogram(Metrics.ARCHIVER_PRUNE_DURATION, {
77
- unit: 'ms',
78
- description: 'Duration to sync a message',
79
- valueType: ValueType.INT
80
- });
81
- this.pruneCount = meter.createUpDownCounter(Metrics.ARCHIVER_PRUNE_COUNT, {
82
- description: 'Number of prunes detected',
83
- valueType: ValueType.INT
84
- });
85
- this.blockProposalTxTargetCount = meter.createUpDownCounter(Metrics.ARCHIVER_BLOCK_PROPOSAL_TX_TARGET_COUNT, {
86
- description: 'Number of block proposals by tx target',
87
- valueType: ValueType.INT
88
- });
27
+ this.blockHeight = meter.createGauge(Metrics.ARCHIVER_BLOCK_HEIGHT);
28
+ this.l1BlockHeight = meter.createGauge(Metrics.ARCHIVER_L1_BLOCK_HEIGHT);
29
+ this.txCount = meter.createUpDownCounter(Metrics.ARCHIVER_TOTAL_TXS);
30
+ this.proofsSubmittedCount = meter.createUpDownCounter(Metrics.ARCHIVER_ROLLUP_PROOF_COUNT);
31
+ this.proofsSubmittedDelay = meter.createHistogram(Metrics.ARCHIVER_ROLLUP_PROOF_DELAY);
32
+ this.syncDurationPerBlock = meter.createHistogram(Metrics.ARCHIVER_SYNC_PER_BLOCK);
33
+ this.syncBlockCount = meter.createUpDownCounter(Metrics.ARCHIVER_SYNC_BLOCK_COUNT);
34
+ this.manaPerBlock = meter.createHistogram(Metrics.ARCHIVER_MANA_PER_BLOCK);
35
+ this.txsPerBlock = meter.createHistogram(Metrics.ARCHIVER_TXS_PER_BLOCK);
36
+ this.syncDurationPerMessage = meter.createHistogram(Metrics.ARCHIVER_SYNC_PER_MESSAGE);
37
+ this.syncMessageCount = meter.createUpDownCounter(Metrics.ARCHIVER_SYNC_MESSAGE_COUNT);
38
+ this.pruneDuration = meter.createHistogram(Metrics.ARCHIVER_PRUNE_DURATION);
39
+ this.pruneCount = meter.createUpDownCounter(Metrics.ARCHIVER_PRUNE_COUNT);
40
+ this.blockProposalTxTargetCount = meter.createUpDownCounter(Metrics.ARCHIVER_BLOCK_PROPOSAL_TX_TARGET_COUNT);
89
41
  this.dbMetrics = new LmdbMetrics(meter, {
90
42
  [Attributes.DB_DATA_TYPE]: 'archiver'
91
43
  }, lmdbStats);
@@ -0,0 +1,75 @@
1
+ import type { BlobClientInterface } from '@aztec/blob-client/client';
2
+ import { EpochCache } from '@aztec/epoch-cache';
3
+ import { InboxContract, RollupContract } from '@aztec/ethereum/contracts';
4
+ import type { L1ContractAddresses } from '@aztec/ethereum/l1-contract-addresses';
5
+ import type { ViemPublicClient, ViemPublicDebugClient } from '@aztec/ethereum/types';
6
+ import { Buffer32 } from '@aztec/foundation/buffer';
7
+ import { Fr } from '@aztec/foundation/curves/bn254';
8
+ import { EthAddress } from '@aztec/foundation/eth-address';
9
+ import { type Logger } from '@aztec/foundation/log';
10
+ import { DateProvider } from '@aztec/foundation/timer';
11
+ import { type ArchiverEmitter } from '@aztec/stdlib/block';
12
+ import { type L1RollupConstants } from '@aztec/stdlib/epoch-helpers';
13
+ import { type Traceable, type Tracer } from '@aztec/telemetry-client';
14
+ import type { KVArchiverDataStore } from '../store/kv_archiver_store.js';
15
+ import type { ArchiverInstrumentation } from './instrumentation.js';
16
+ /**
17
+ * Handles L1 synchronization for the archiver.
18
+ * Responsible for fetching checkpoints, L1→L2 messages, and handling L1 reorgs.
19
+ */
20
+ export declare class ArchiverL1Synchronizer implements Traceable {
21
+ private readonly publicClient;
22
+ private readonly debugClient;
23
+ private readonly rollup;
24
+ private readonly inbox;
25
+ private readonly l1Addresses;
26
+ private readonly store;
27
+ private config;
28
+ private readonly blobClient;
29
+ private readonly epochCache;
30
+ private readonly dateProvider;
31
+ private readonly instrumentation;
32
+ private readonly l1Constants;
33
+ private readonly events;
34
+ private readonly log;
35
+ private l1BlockNumber;
36
+ private l1BlockHash;
37
+ private l1Timestamp;
38
+ private readonly updater;
39
+ readonly tracer: Tracer;
40
+ constructor(publicClient: ViemPublicClient, debugClient: ViemPublicDebugClient, rollup: RollupContract, inbox: InboxContract, l1Addresses: Pick<L1ContractAddresses, 'registryAddress' | 'governanceProposerAddress' | 'slashFactoryAddress'> & {
41
+ slashingProposerAddress: EthAddress;
42
+ }, store: KVArchiverDataStore, config: {
43
+ batchSize: number;
44
+ skipValidateCheckpointAttestations?: boolean;
45
+ maxAllowedEthClientDriftSeconds: number;
46
+ }, blobClient: BlobClientInterface, epochCache: EpochCache, dateProvider: DateProvider, instrumentation: ArchiverInstrumentation, l1Constants: L1RollupConstants & {
47
+ l1StartBlockHash: Buffer32;
48
+ genesisArchiveRoot: Fr;
49
+ }, events: ArchiverEmitter, tracer: Tracer, log?: Logger);
50
+ /** Sets new config */
51
+ setConfig(newConfig: {
52
+ batchSize: number;
53
+ skipValidateCheckpointAttestations?: boolean;
54
+ maxAllowedEthClientDriftSeconds: number;
55
+ }): void;
56
+ /** Returns the last L1 block number that was synced. */
57
+ getL1BlockNumber(): bigint | undefined;
58
+ /** Returns the last L1 timestamp that was synced. */
59
+ getL1Timestamp(): bigint | undefined;
60
+ /** Checks that the ethereum node we are connected to has a latest timestamp no more than the allowed drift. Throw if not. */
61
+ testEthereumNodeSynced(): Promise<void>;
62
+ syncFromL1(initialSyncComplete: boolean): Promise<void>;
63
+ private pruneUncheckpointedBlocks;
64
+ private canPrune;
65
+ private handleEpochPrune;
66
+ private nextRange;
67
+ private handleL1ToL2Messages;
68
+ private retrieveL1ToL2Message;
69
+ private rollbackL1ToL2Messages;
70
+ private getL1BlockHash;
71
+ private handleCheckpoints;
72
+ private checkForNewCheckpointsBeforeL1SyncPoint;
73
+ private getCheckpointHeader;
74
+ }
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibDFfc3luY2hyb25pemVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kdWxlcy9sMV9zeW5jaHJvbml6ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNyRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRSxPQUFPLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRWpGLE9BQU8sS0FBSyxFQUFFLGdCQUFnQixFQUFFLHFCQUFxQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFHckYsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRXBELE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDM0QsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLHVCQUF1QixDQUFDO0FBRWxFLE9BQU8sRUFBRSxZQUFZLEVBQWtCLE1BQU0seUJBQXlCLENBQUM7QUFFdkUsT0FBTyxFQUFFLEtBQUssZUFBZSxFQUFzRCxNQUFNLHFCQUFxQixDQUFDO0FBRS9HLE9BQU8sRUFBRSxLQUFLLGlCQUFpQixFQUFzQyxNQUFNLDZCQUE2QixDQUFDO0FBRXpHLE9BQU8sRUFBRSxLQUFLLFNBQVMsRUFBRSxLQUFLLE1BQU0sRUFBeUIsTUFBTSx5QkFBeUIsQ0FBQztBQVM3RixPQUFPLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBR3pFLE9BQU8sS0FBSyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFhcEU7OztHQUdHO0FBQ0gscUJBQWEs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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"l1_synchronizer.d.ts","sourceRoot":"","sources":["../../src/modules/l1_synchronizer.ts"],"names":[],"mappings":"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"}