@aztec/p2p 0.0.0-test.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.
Files changed (311) hide show
  1. package/README.md +7 -0
  2. package/dest/bootstrap/bootstrap.d.ts +38 -0
  3. package/dest/bootstrap/bootstrap.d.ts.map +1 -0
  4. package/dest/bootstrap/bootstrap.js +123 -0
  5. package/dest/client/factory.d.ts +21 -0
  6. package/dest/client/factory.d.ts.map +1 -0
  7. package/dest/client/factory.js +37 -0
  8. package/dest/client/index.d.ts +3 -0
  9. package/dest/client/index.d.ts.map +1 -0
  10. package/dest/client/index.js +2 -0
  11. package/dest/client/p2p_client.d.ts +314 -0
  12. package/dest/client/p2p_client.d.ts.map +1 -0
  13. package/dest/client/p2p_client.js +505 -0
  14. package/dest/config.d.ts +180 -0
  15. package/dest/config.d.ts.map +1 -0
  16. package/dest/config.js +193 -0
  17. package/dest/enr/generate-enr.d.ts +9 -0
  18. package/dest/enr/generate-enr.d.ts.map +1 -0
  19. package/dest/enr/generate-enr.js +30 -0
  20. package/dest/enr/index.d.ts +2 -0
  21. package/dest/enr/index.d.ts.map +1 -0
  22. package/dest/enr/index.js +1 -0
  23. package/dest/errors/reqresp.error.d.ts +28 -0
  24. package/dest/errors/reqresp.error.d.ts.map +1 -0
  25. package/dest/errors/reqresp.error.js +30 -0
  26. package/dest/index.d.ts +8 -0
  27. package/dest/index.d.ts.map +1 -0
  28. package/dest/index.js +7 -0
  29. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +57 -0
  30. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -0
  31. package/dest/mem_pools/attestation_pool/attestation_pool.js +6 -0
  32. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +3 -0
  33. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -0
  34. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +195 -0
  35. package/dest/mem_pools/attestation_pool/index.d.ts +3 -0
  36. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -0
  37. package/dest/mem_pools/attestation_pool/index.js +2 -0
  38. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +22 -0
  39. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -0
  40. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +112 -0
  41. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +17 -0
  42. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +1 -0
  43. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +129 -0
  44. package/dest/mem_pools/attestation_pool/mocks.d.ts +19 -0
  45. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -0
  46. package/dest/mem_pools/attestation_pool/mocks.js +33 -0
  47. package/dest/mem_pools/index.d.ts +4 -0
  48. package/dest/mem_pools/index.d.ts.map +1 -0
  49. package/dest/mem_pools/index.js +1 -0
  50. package/dest/mem_pools/instrumentation.d.ts +30 -0
  51. package/dest/mem_pools/instrumentation.d.ts.map +1 -0
  52. package/dest/mem_pools/instrumentation.js +84 -0
  53. package/dest/mem_pools/interface.d.ts +11 -0
  54. package/dest/mem_pools/interface.d.ts.map +1 -0
  55. package/dest/mem_pools/interface.js +3 -0
  56. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +66 -0
  57. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -0
  58. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +245 -0
  59. package/dest/mem_pools/tx_pool/index.d.ts +4 -0
  60. package/dest/mem_pools/tx_pool/index.d.ts.map +1 -0
  61. package/dest/mem_pools/tx_pool/index.js +3 -0
  62. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +56 -0
  63. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +1 -0
  64. package/dest/mem_pools/tx_pool/memory_tx_pool.js +141 -0
  65. package/dest/mem_pools/tx_pool/priority.d.ts +8 -0
  66. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -0
  67. package/dest/mem_pools/tx_pool/priority.js +10 -0
  68. package/dest/mem_pools/tx_pool/tx_pool.d.ts +66 -0
  69. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -0
  70. package/dest/mem_pools/tx_pool/tx_pool.js +3 -0
  71. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +7 -0
  72. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -0
  73. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +169 -0
  74. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +8 -0
  75. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -0
  76. package/dest/msg_validators/attestation_validator/attestation_validator.js +19 -0
  77. package/dest/msg_validators/attestation_validator/index.d.ts +2 -0
  78. package/dest/msg_validators/attestation_validator/index.d.ts.map +1 -0
  79. package/dest/msg_validators/attestation_validator/index.js +1 -0
  80. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +8 -0
  81. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +1 -0
  82. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +21 -0
  83. package/dest/msg_validators/block_proposal_validator/index.d.ts +2 -0
  84. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +1 -0
  85. package/dest/msg_validators/block_proposal_validator/index.js +1 -0
  86. package/dest/msg_validators/index.d.ts +4 -0
  87. package/dest/msg_validators/index.d.ts.map +1 -0
  88. package/dest/msg_validators/index.js +3 -0
  89. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +7 -0
  90. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -0
  91. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +31 -0
  92. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +11 -0
  93. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -0
  94. package/dest/msg_validators/tx_validator/block_header_validator.js +26 -0
  95. package/dest/msg_validators/tx_validator/data_validator.d.ts +6 -0
  96. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -0
  97. package/dest/msg_validators/tx_validator/data_validator.js +107 -0
  98. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +12 -0
  99. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -0
  100. package/dest/msg_validators/tx_validator/double_spend_validator.js +41 -0
  101. package/dest/msg_validators/tx_validator/index.d.ts +7 -0
  102. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -0
  103. package/dest/msg_validators/tx_validator/index.js +6 -0
  104. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +10 -0
  105. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -0
  106. package/dest/msg_validators/tx_validator/metadata_validator.js +44 -0
  107. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +9 -0
  108. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -0
  109. package/dest/msg_validators/tx_validator/tx_proof_validator.js +25 -0
  110. package/dest/services/data_store.d.ts +27 -0
  111. package/dest/services/data_store.d.ts.map +1 -0
  112. package/dest/services/data_store.js +188 -0
  113. package/dest/services/discv5/discV5_service.d.ts +42 -0
  114. package/dest/services/discv5/discV5_service.d.ts.map +1 -0
  115. package/dest/services/discv5/discV5_service.js +214 -0
  116. package/dest/services/dummy_service.d.ts +85 -0
  117. package/dest/services/dummy_service.d.ts.map +1 -0
  118. package/dest/services/dummy_service.js +92 -0
  119. package/dest/services/encoding.d.ts +31 -0
  120. package/dest/services/encoding.d.ts.map +1 -0
  121. package/dest/services/encoding.js +66 -0
  122. package/dest/services/gossipsub/scoring.d.ts +7 -0
  123. package/dest/services/gossipsub/scoring.d.ts.map +1 -0
  124. package/dest/services/gossipsub/scoring.js +10 -0
  125. package/dest/services/index.d.ts +3 -0
  126. package/dest/services/index.d.ts.map +1 -0
  127. package/dest/services/index.js +2 -0
  128. package/dest/services/libp2p/libp2p_service.d.ts +186 -0
  129. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -0
  130. package/dest/services/libp2p/libp2p_service.js +712 -0
  131. package/dest/services/peer-manager/metrics.d.ts +12 -0
  132. package/dest/services/peer-manager/metrics.d.ts.map +1 -0
  133. package/dest/services/peer-manager/metrics.js +33 -0
  134. package/dest/services/peer-manager/peer_manager.d.ts +94 -0
  135. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -0
  136. package/dest/services/peer-manager/peer_manager.js +445 -0
  137. package/dest/services/peer-manager/peer_scoring.d.ts +28 -0
  138. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -0
  139. package/dest/services/peer-manager/peer_scoring.js +86 -0
  140. package/dest/services/reqresp/config.d.ts +16 -0
  141. package/dest/services/reqresp/config.d.ts.map +1 -0
  142. package/dest/services/reqresp/config.js +20 -0
  143. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +45 -0
  144. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -0
  145. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +88 -0
  146. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +61 -0
  147. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -0
  148. package/dest/services/reqresp/connection-sampler/connection_sampler.js +181 -0
  149. package/dest/services/reqresp/index.d.ts +6 -0
  150. package/dest/services/reqresp/index.d.ts.map +1 -0
  151. package/dest/services/reqresp/index.js +4 -0
  152. package/dest/services/reqresp/interface.d.ts +116 -0
  153. package/dest/services/reqresp/interface.d.ts.map +1 -0
  154. package/dest/services/reqresp/interface.js +84 -0
  155. package/dest/services/reqresp/metrics.d.ts +15 -0
  156. package/dest/services/reqresp/metrics.d.ts.map +1 -0
  157. package/dest/services/reqresp/metrics.js +55 -0
  158. package/dest/services/reqresp/protocols/block.d.ts +4 -0
  159. package/dest/services/reqresp/protocols/block.d.ts.map +1 -0
  160. package/dest/services/reqresp/protocols/block.js +8 -0
  161. package/dest/services/reqresp/protocols/goodbye.d.ts +51 -0
  162. package/dest/services/reqresp/protocols/goodbye.d.ts.map +1 -0
  163. package/dest/services/reqresp/protocols/goodbye.js +87 -0
  164. package/dest/services/reqresp/protocols/index.d.ts +9 -0
  165. package/dest/services/reqresp/protocols/index.d.ts.map +1 -0
  166. package/dest/services/reqresp/protocols/index.js +7 -0
  167. package/dest/services/reqresp/protocols/ping.d.ts +9 -0
  168. package/dest/services/reqresp/protocols/ping.d.ts.map +1 -0
  169. package/dest/services/reqresp/protocols/ping.js +7 -0
  170. package/dest/services/reqresp/protocols/status.d.ts +9 -0
  171. package/dest/services/reqresp/protocols/status.d.ts.map +1 -0
  172. package/dest/services/reqresp/protocols/status.js +7 -0
  173. package/dest/services/reqresp/protocols/tx.d.ts +13 -0
  174. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -0
  175. package/dest/services/reqresp/protocols/tx.js +20 -0
  176. package/dest/services/reqresp/rate-limiter/index.d.ts +2 -0
  177. package/dest/services/reqresp/rate-limiter/index.d.ts.map +1 -0
  178. package/dest/services/reqresp/rate-limiter/index.js +1 -0
  179. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +102 -0
  180. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -0
  181. package/dest/services/reqresp/rate-limiter/rate_limiter.js +184 -0
  182. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts +3 -0
  183. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts.map +1 -0
  184. package/dest/services/reqresp/rate-limiter/rate_limits.js +54 -0
  185. package/dest/services/reqresp/reqresp.d.ts +166 -0
  186. package/dest/services/reqresp/reqresp.d.ts.map +1 -0
  187. package/dest/services/reqresp/reqresp.js +516 -0
  188. package/dest/services/reqresp/status.d.ts +31 -0
  189. package/dest/services/reqresp/status.d.ts.map +1 -0
  190. package/dest/services/reqresp/status.js +51 -0
  191. package/dest/services/service.d.ts +87 -0
  192. package/dest/services/service.d.ts.map +1 -0
  193. package/dest/services/service.js +5 -0
  194. package/dest/test-helpers/generate-peer-id-private-keys.d.ts +7 -0
  195. package/dest/test-helpers/generate-peer-id-private-keys.d.ts.map +1 -0
  196. package/dest/test-helpers/generate-peer-id-private-keys.js +13 -0
  197. package/dest/test-helpers/get-ports.d.ts +7 -0
  198. package/dest/test-helpers/get-ports.d.ts.map +1 -0
  199. package/dest/test-helpers/get-ports.js +8 -0
  200. package/dest/test-helpers/index.d.ts +6 -0
  201. package/dest/test-helpers/index.d.ts.map +1 -0
  202. package/dest/test-helpers/index.js +5 -0
  203. package/dest/test-helpers/make-enrs.d.ts +16 -0
  204. package/dest/test-helpers/make-enrs.d.ts.map +1 -0
  205. package/dest/test-helpers/make-enrs.js +32 -0
  206. package/dest/test-helpers/make-test-p2p-clients.d.ts +36 -0
  207. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -0
  208. package/dest/test-helpers/make-test-p2p-clients.js +68 -0
  209. package/dest/test-helpers/reqresp-nodes.d.ts +66 -0
  210. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -0
  211. package/dest/test-helpers/reqresp-nodes.js +207 -0
  212. package/dest/testbench/p2p_client_testbench_worker.d.ts +2 -0
  213. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -0
  214. package/dest/testbench/p2p_client_testbench_worker.js +132 -0
  215. package/dest/testbench/parse_log_file.d.ts +2 -0
  216. package/dest/testbench/parse_log_file.d.ts.map +1 -0
  217. package/dest/testbench/parse_log_file.js +131 -0
  218. package/dest/testbench/testbench.d.ts +2 -0
  219. package/dest/testbench/testbench.d.ts.map +1 -0
  220. package/dest/testbench/testbench.js +61 -0
  221. package/dest/testbench/worker_client_manager.d.ts +56 -0
  222. package/dest/testbench/worker_client_manager.d.ts.map +1 -0
  223. package/dest/testbench/worker_client_manager.js +266 -0
  224. package/dest/types/index.d.ts +32 -0
  225. package/dest/types/index.d.ts.map +1 -0
  226. package/dest/types/index.js +28 -0
  227. package/dest/util.d.ts +53 -0
  228. package/dest/util.d.ts.map +1 -0
  229. package/dest/util.js +140 -0
  230. package/dest/versioning.d.ts +12 -0
  231. package/dest/versioning.d.ts.map +1 -0
  232. package/dest/versioning.js +33 -0
  233. package/package.json +127 -0
  234. package/src/bootstrap/bootstrap.ts +146 -0
  235. package/src/client/factory.ts +89 -0
  236. package/src/client/index.ts +2 -0
  237. package/src/client/p2p_client.ts +754 -0
  238. package/src/config.ts +371 -0
  239. package/src/enr/generate-enr.ts +39 -0
  240. package/src/enr/index.ts +1 -0
  241. package/src/errors/reqresp.error.ts +35 -0
  242. package/src/index.ts +7 -0
  243. package/src/mem_pools/attestation_pool/attestation_pool.ts +62 -0
  244. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +230 -0
  245. package/src/mem_pools/attestation_pool/index.ts +2 -0
  246. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +159 -0
  247. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +161 -0
  248. package/src/mem_pools/attestation_pool/mocks.ts +44 -0
  249. package/src/mem_pools/index.ts +3 -0
  250. package/src/mem_pools/instrumentation.ts +126 -0
  251. package/src/mem_pools/interface.ts +12 -0
  252. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +309 -0
  253. package/src/mem_pools/tx_pool/index.ts +3 -0
  254. package/src/mem_pools/tx_pool/memory_tx_pool.ts +174 -0
  255. package/src/mem_pools/tx_pool/priority.ts +13 -0
  256. package/src/mem_pools/tx_pool/tx_pool.ts +76 -0
  257. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +130 -0
  258. package/src/msg_validators/attestation_validator/attestation_validator.ts +26 -0
  259. package/src/msg_validators/attestation_validator/index.ts +1 -0
  260. package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +29 -0
  261. package/src/msg_validators/block_proposal_validator/index.ts +1 -0
  262. package/src/msg_validators/index.ts +3 -0
  263. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +32 -0
  264. package/src/msg_validators/tx_validator/block_header_validator.ts +25 -0
  265. package/src/msg_validators/tx_validator/data_validator.ts +106 -0
  266. package/src/msg_validators/tx_validator/double_spend_validator.ts +38 -0
  267. package/src/msg_validators/tx_validator/index.ts +6 -0
  268. package/src/msg_validators/tx_validator/metadata_validator.ts +48 -0
  269. package/src/msg_validators/tx_validator/tx_proof_validator.ts +18 -0
  270. package/src/services/data_store.ts +235 -0
  271. package/src/services/discv5/discV5_service.ts +256 -0
  272. package/src/services/dummy_service.ts +134 -0
  273. package/src/services/encoding.ts +79 -0
  274. package/src/services/gossipsub/scoring.ts +13 -0
  275. package/src/services/index.ts +2 -0
  276. package/src/services/libp2p/libp2p_service.ts +871 -0
  277. package/src/services/peer-manager/metrics.ts +41 -0
  278. package/src/services/peer-manager/peer_manager.ts +530 -0
  279. package/src/services/peer-manager/peer_scoring.ts +105 -0
  280. package/src/services/reqresp/config.ts +35 -0
  281. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +94 -0
  282. package/src/services/reqresp/connection-sampler/connection_sampler.ts +217 -0
  283. package/src/services/reqresp/index.ts +4 -0
  284. package/src/services/reqresp/interface.ts +185 -0
  285. package/src/services/reqresp/metrics.ts +57 -0
  286. package/src/services/reqresp/protocols/block.ts +15 -0
  287. package/src/services/reqresp/protocols/goodbye.ts +101 -0
  288. package/src/services/reqresp/protocols/index.ts +8 -0
  289. package/src/services/reqresp/protocols/ping.ts +8 -0
  290. package/src/services/reqresp/protocols/status.ts +8 -0
  291. package/src/services/reqresp/protocols/tx.ts +29 -0
  292. package/src/services/reqresp/rate-limiter/index.ts +1 -0
  293. package/src/services/reqresp/rate-limiter/rate_limiter.ts +228 -0
  294. package/src/services/reqresp/rate-limiter/rate_limits.ts +55 -0
  295. package/src/services/reqresp/reqresp.ts +661 -0
  296. package/src/services/reqresp/status.ts +59 -0
  297. package/src/services/service.ts +112 -0
  298. package/src/test-helpers/generate-peer-id-private-keys.ts +15 -0
  299. package/src/test-helpers/get-ports.ts +8 -0
  300. package/src/test-helpers/index.ts +5 -0
  301. package/src/test-helpers/make-enrs.ts +44 -0
  302. package/src/test-helpers/make-test-p2p-clients.ts +122 -0
  303. package/src/test-helpers/reqresp-nodes.ts +289 -0
  304. package/src/testbench/README.md +20 -0
  305. package/src/testbench/p2p_client_testbench_worker.ts +152 -0
  306. package/src/testbench/parse_log_file.ts +175 -0
  307. package/src/testbench/testbench.ts +66 -0
  308. package/src/testbench/worker_client_manager.ts +318 -0
  309. package/src/types/index.ts +36 -0
  310. package/src/util.ts +196 -0
  311. package/src/versioning.ts +50 -0
package/README.md ADDED
@@ -0,0 +1,7 @@
1
+ # P2P
2
+
3
+ This package includes the functionality of the P2P networking required by the aztec node. The `P2PClient` provides an interface for the introduction of transactions to the Tx Pool and propagation of those transactions through the network. The `P2PService` offers an abstraction of the P2P networking.
4
+
5
+ The package depends on a block source in order to reconcile the transaction pool and remove settled transactions.
6
+
7
+ Additionally, the `BootstrapNode` class provides the functionality for running a P2P 'bootnode', one that serves the purpose of introducing new peers to the network. It does not participate in transaction exchange.
@@ -0,0 +1,38 @@
1
+ import type { AztecAsyncKVStore } from '@aztec/kv-store';
2
+ import type { P2PBootstrapApi } from '@aztec/stdlib/interfaces/server';
3
+ import { type TelemetryClient } from '@aztec/telemetry-client';
4
+ import type { PeerId } from '@libp2p/interface';
5
+ import type { BootnodeConfig } from '../config.js';
6
+ /**
7
+ * Encapsulates a 'Bootstrap' node, used for the purpose of assisting new joiners in acquiring peers.
8
+ */
9
+ export declare class BootstrapNode implements P2PBootstrapApi {
10
+ private store;
11
+ private telemetry;
12
+ private logger;
13
+ private node?;
14
+ private peerId?;
15
+ constructor(store: AztecAsyncKVStore, telemetry: TelemetryClient, logger?: import("@aztec/foundation/log").Logger);
16
+ /**
17
+ * Starts the bootstrap node.
18
+ * @param config - A partial P2P configuration. No need for TCP values as well as aztec node specific values.
19
+ * @returns An empty promise.
20
+ */
21
+ start(config: BootnodeConfig): Promise<void>;
22
+ /**
23
+ * Stops the bootstrap node.
24
+ * @returns And empty promise.
25
+ */
26
+ stop(): Promise<void>;
27
+ private assertNodeStarted;
28
+ private assertPeerId;
29
+ /**
30
+ * Returns the peerId of this node.
31
+ * @returns The node's peer Id
32
+ */
33
+ getPeerId(): PeerId;
34
+ getENR(): any;
35
+ getEncodedEnr(): Promise<any>;
36
+ getRoutingTable(): Promise<any>;
37
+ }
38
+ //# sourceMappingURL=bootstrap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bootstrap.d.ts","sourceRoot":"","sources":["../../src/bootstrap/bootstrap.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAsB,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAInF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAGhD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAInD;;GAEG;AACH,qBAAa,aAAc,YAAW,eAAe;IAKjD,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,MAAM;IANhB,OAAO,CAAC,IAAI,CAAC,CAA0C;IACvD,OAAO,CAAC,MAAM,CAAC,CAAS;gBAGd,KAAK,EAAE,iBAAiB,EACxB,SAAS,EAAE,eAAe,EAC1B,MAAM,yCAAgC;IAGhD;;;;OAIG;IACU,KAAK,CAAC,MAAM,EAAE,cAAc;IAmEzC;;;OAGG;IACU,IAAI;IAOjB,OAAO,CAAC,iBAAiB;IAMzB,OAAO,CAAC,YAAY;IAMpB;;;OAGG;IACI,SAAS;IAKT,MAAM;IAKN,aAAa;IAKb,eAAe;CAIvB"}
@@ -0,0 +1,123 @@
1
+ import { createLogger } from '@aztec/foundation/log';
2
+ import { OtelMetricsAdapter } from '@aztec/telemetry-client';
3
+ import { Discv5 } from '@chainsafe/discv5';
4
+ import { ENR } from '@chainsafe/enr';
5
+ import { multiaddr } from '@multiformats/multiaddr';
6
+ import { createBootnodeENRandPeerId } from '../enr/generate-enr.js';
7
+ import { convertToMultiaddr, getPeerIdPrivateKey } from '../util.js';
8
+ /**
9
+ * Encapsulates a 'Bootstrap' node, used for the purpose of assisting new joiners in acquiring peers.
10
+ */ export class BootstrapNode {
11
+ store;
12
+ telemetry;
13
+ logger;
14
+ node;
15
+ peerId;
16
+ constructor(store, telemetry, logger = createLogger('p2p:bootstrap')){
17
+ this.store = store;
18
+ this.telemetry = telemetry;
19
+ this.logger = logger;
20
+ this.node = undefined;
21
+ }
22
+ /**
23
+ * Starts the bootstrap node.
24
+ * @param config - A partial P2P configuration. No need for TCP values as well as aztec node specific values.
25
+ * @returns An empty promise.
26
+ */ async start(config) {
27
+ const { udpListenAddress, udpAnnounceAddress } = config;
28
+ const listenAddrUdp = multiaddr(convertToMultiaddr(udpListenAddress, 'udp'));
29
+ if (!udpAnnounceAddress) {
30
+ throw new Error('You need to provide a UDP announce address.');
31
+ }
32
+ const peerIdPrivateKey = await getPeerIdPrivateKey(config, this.store);
33
+ const { enr: ourEnr, peerId } = await createBootnodeENRandPeerId(peerIdPrivateKey, udpAnnounceAddress, config.l1ChainId);
34
+ this.peerId = peerId;
35
+ this.logger.debug(`Starting bootstrap node ${peerId} listening on ${listenAddrUdp.toString()}`);
36
+ const metricsRegistry = new OtelMetricsAdapter(this.telemetry);
37
+ this.node = Discv5.create({
38
+ enr: ourEnr,
39
+ peerId,
40
+ bindAddrs: {
41
+ ip4: listenAddrUdp
42
+ },
43
+ config: {
44
+ lookupTimeout: 2000,
45
+ allowUnverifiedSessions: true
46
+ },
47
+ metricsRegistry
48
+ });
49
+ this.node.on('multiaddrUpdated', (addr)=>{
50
+ this.logger.info('Advertised socket address updated', {
51
+ addr: addr.toString()
52
+ });
53
+ });
54
+ this.node.on('discovered', async (enr)=>{
55
+ const addr = await enr.getFullMultiaddr('udp');
56
+ this.logger.verbose(`Discovered new peer`, {
57
+ enr: enr.encodeTxt(),
58
+ addr: addr?.toString()
59
+ });
60
+ });
61
+ try {
62
+ this.logger.info('Starting bootnode');
63
+ await this.node.start();
64
+ this.logger.info('Bootstrap node started', {
65
+ peerId,
66
+ enr: ourEnr.encodeTxt(),
67
+ addr: listenAddrUdp.toString()
68
+ });
69
+ } catch (e) {
70
+ this.logger.error('Error starting Discv5', e);
71
+ }
72
+ // Add bootnode ENRs if provided, making sure we filter our own
73
+ if (config.bootstrapNodes?.length) {
74
+ const otherBootnodeENRs = config.bootstrapNodes.map((x)=>ENR.decodeTxt(x)).filter((b)=>b.nodeId !== ourEnr.nodeId);
75
+ this.logger.info(`Adding bootstrap nodes ENRs: ${otherBootnodeENRs.map((x)=>x.encodeTxt()).join(', ')}`);
76
+ try {
77
+ otherBootnodeENRs.forEach((enr)=>{
78
+ this.node.addEnr(enr);
79
+ });
80
+ } catch (e) {
81
+ this.logger.error(`Error adding bootnode ENRs: ${e}`);
82
+ }
83
+ }
84
+ }
85
+ /**
86
+ * Stops the bootstrap node.
87
+ * @returns And empty promise.
88
+ */ async stop() {
89
+ // stop libp2p
90
+ this.logger.debug('Stopping bootstrap node');
91
+ await this.node?.stop();
92
+ this.logger.info('Bootstrap node stopped');
93
+ }
94
+ assertNodeStarted() {
95
+ if (!this.node) {
96
+ throw new Error('Node not started');
97
+ }
98
+ }
99
+ assertPeerId() {
100
+ if (!this.peerId) {
101
+ throw new Error('No peerId found');
102
+ }
103
+ }
104
+ /**
105
+ * Returns the peerId of this node.
106
+ * @returns The node's peer Id
107
+ */ getPeerId() {
108
+ this.assertPeerId();
109
+ return this.peerId;
110
+ }
111
+ getENR() {
112
+ this.assertNodeStarted();
113
+ return this.node?.enr.toENR();
114
+ }
115
+ getEncodedEnr() {
116
+ this.assertNodeStarted();
117
+ return Promise.resolve(this.node.enr.encodeTxt());
118
+ }
119
+ getRoutingTable() {
120
+ this.assertNodeStarted();
121
+ return Promise.resolve(this.node.kadValues().map((enr)=>enr.encodeTxt()));
122
+ }
123
+ }
@@ -0,0 +1,21 @@
1
+ import type { EpochCacheInterface } from '@aztec/epoch-cache';
2
+ import { type Logger } from '@aztec/foundation/log';
3
+ import type { AztecAsyncKVStore } from '@aztec/kv-store';
4
+ import type { DataStoreConfig } from '@aztec/kv-store/config';
5
+ import type { L2BlockSource } from '@aztec/stdlib/block';
6
+ import type { ClientProtocolCircuitVerifier, WorldStateSynchronizer } from '@aztec/stdlib/interfaces/server';
7
+ import { P2PClientType } from '@aztec/stdlib/p2p';
8
+ import { type TelemetryClient } from '@aztec/telemetry-client';
9
+ import { P2PClient } from '../client/p2p_client.js';
10
+ import type { P2PConfig } from '../config.js';
11
+ import type { AttestationPool } from '../mem_pools/attestation_pool/attestation_pool.js';
12
+ import { type TxPool } from '../mem_pools/tx_pool/index.js';
13
+ type P2PClientDeps<T extends P2PClientType> = {
14
+ txPool?: TxPool;
15
+ store?: AztecAsyncKVStore;
16
+ attestationPool?: T extends P2PClientType.Full ? AttestationPool : undefined;
17
+ logger?: Logger;
18
+ };
19
+ export declare const createP2PClient: <T extends P2PClientType>(clientType: T, _config: P2PConfig & DataStoreConfig, l2BlockSource: L2BlockSource, proofVerifier: ClientProtocolCircuitVerifier, worldStateSynchronizer: WorldStateSynchronizer, epochCache: EpochCacheInterface, telemetry?: TelemetryClient, deps?: P2PClientDeps<T>) => Promise<P2PClient<T>>;
20
+ export {};
21
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/client/factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAClE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,KAAK,EAAE,6BAA6B,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAC7G,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,KAAK,eAAe,EAAsB,MAAM,yBAAyB,CAAC;AAEnF,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mDAAmD,CAAC;AAGzF,OAAO,EAAiB,KAAK,MAAM,EAAE,MAAM,+BAA+B,CAAC;AAM3E,KAAK,aAAa,CAAC,CAAC,SAAS,aAAa,IAAI;IAC5C,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,iBAAiB,CAAC;IAC1B,eAAe,CAAC,EAAE,CAAC,SAAS,aAAa,CAAC,IAAI,GAAG,eAAe,GAAG,SAAS,CAAC;IAC7E,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,eAAO,MAAM,eAAe,wCACd,CAAC,WACJ,SAAS,GAAG,eAAe,iBACrB,aAAa,iBACb,6BAA6B,0BACpB,sBAAsB,cAClC,mBAAmB,cACpB,eAAe,SACpB,cAAc,CAAC,CAAC,0BAoDvB,CAAC"}
@@ -0,0 +1,37 @@
1
+ import { createLogger } from '@aztec/foundation/log';
2
+ import { createStore } from '@aztec/kv-store/lmdb-v2';
3
+ import { P2PClientType } from '@aztec/stdlib/p2p';
4
+ import { getTelemetryClient } from '@aztec/telemetry-client';
5
+ import { P2PClient } from '../client/p2p_client.js';
6
+ import { InMemoryAttestationPool } from '../mem_pools/attestation_pool/memory_attestation_pool.js';
7
+ import { AztecKVTxPool } from '../mem_pools/tx_pool/index.js';
8
+ import { DiscV5Service } from '../services/discv5/discV5_service.js';
9
+ import { DummyP2PService } from '../services/dummy_service.js';
10
+ import { LibP2PService } from '../services/index.js';
11
+ import { configureP2PClientAddresses, createLibP2PPeerIdFromPrivateKey, getPeerIdPrivateKey } from '../util.js';
12
+ export const createP2PClient = async (clientType, _config, l2BlockSource, proofVerifier, worldStateSynchronizer, epochCache, telemetry = getTelemetryClient(), deps = {})=>{
13
+ let config = {
14
+ ..._config
15
+ };
16
+ const logger = deps.logger ?? createLogger('p2p');
17
+ const store = deps.store ?? await createStore('p2p', 1, config, createLogger('p2p:lmdb-v2'));
18
+ const archive = await createStore('p2p-archive', 1, config, createLogger('p2p-archive:lmdb-v2'));
19
+ const mempools = {
20
+ txPool: deps.txPool ?? new AztecKVTxPool(store, archive, telemetry, config.archivedTxLimit),
21
+ attestationPool: clientType === P2PClientType.Full ? deps.attestationPool ?? new InMemoryAttestationPool(telemetry) : undefined
22
+ };
23
+ let p2pService;
24
+ if (_config.p2pEnabled) {
25
+ logger.verbose('P2P is enabled. Using LibP2P service.');
26
+ config = await configureP2PClientAddresses(_config);
27
+ // Create peer discovery service
28
+ const peerIdPrivateKey = await getPeerIdPrivateKey(config, store);
29
+ const peerId = await createLibP2PPeerIdFromPrivateKey(peerIdPrivateKey);
30
+ const discoveryService = new DiscV5Service(peerId, config, telemetry, createLogger(`${logger.module}:discv5_service`));
31
+ p2pService = await LibP2PService.new(clientType, config, discoveryService, peerId, mempools, l2BlockSource, epochCache, proofVerifier, worldStateSynchronizer, store, telemetry, createLogger(`${logger.module}:libp2p_service`));
32
+ } else {
33
+ logger.verbose('P2P is disabled. Using dummy P2P service');
34
+ p2pService = new DummyP2PService();
35
+ }
36
+ return new P2PClient(clientType, store, l2BlockSource, mempools, p2pService, config, telemetry);
37
+ };
@@ -0,0 +1,3 @@
1
+ export * from './p2p_client.js';
2
+ export * from './factory.js';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/client/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,cAAc,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from './p2p_client.js';
2
+ export * from './factory.js';
@@ -0,0 +1,314 @@
1
+ import type { AztecAsyncKVStore } from '@aztec/kv-store';
2
+ import type { L2BlockId, L2BlockSource, L2BlockStreamEvent, L2Tips } from '@aztec/stdlib/block';
3
+ import type { P2PApi, PeerInfo, ProverCoordination } from '@aztec/stdlib/interfaces/server';
4
+ import type { BlockAttestation, BlockProposal, P2PClientType } from '@aztec/stdlib/p2p';
5
+ import type { Tx, TxHash } from '@aztec/stdlib/tx';
6
+ import { type TelemetryClient, WithTracer } from '@aztec/telemetry-client';
7
+ import type { ENR } from '@chainsafe/enr';
8
+ import { type P2PConfig } from '../config.js';
9
+ import type { MemPools } from '../mem_pools/interface.js';
10
+ import type { P2PService } from '../services/service.js';
11
+ /**
12
+ * Enum defining the possible states of the p2p client.
13
+ */
14
+ export declare enum P2PClientState {
15
+ IDLE = 0,
16
+ SYNCHING = 1,
17
+ RUNNING = 2,
18
+ STOPPED = 3
19
+ }
20
+ /**
21
+ * The synchronization status of the P2P client.
22
+ */
23
+ export interface P2PSyncState {
24
+ /**
25
+ * The current state of the p2p client.
26
+ */
27
+ state: P2PClientState;
28
+ /**
29
+ * The block number that the p2p client is synced to.
30
+ */
31
+ syncedToL2Block: L2BlockId;
32
+ }
33
+ /**
34
+ * Interface of a P2P client.
35
+ **/
36
+ export type P2P<T extends P2PClientType = P2PClientType.Full> = ProverCoordination & P2PApi<T> & {
37
+ /**
38
+ * Broadcasts a block proposal to other peers.
39
+ *
40
+ * @param proposal - the block proposal
41
+ */
42
+ broadcastProposal(proposal: BlockProposal): void;
43
+ /**
44
+ * Registers a callback from the validator client that determines how to behave when
45
+ * foreign block proposals are received
46
+ *
47
+ * @param handler - A function taking a received block proposal and producing an attestation
48
+ */
49
+ registerBlockProposalHandler(handler: (block: BlockProposal) => Promise<BlockAttestation | undefined>): void;
50
+ /**
51
+ * Request a list of transactions from another peer by their tx hashes.
52
+ * @param txHashes - Hashes of the txs to query.
53
+ * @returns A list of transactions or undefined if the transactions are not found.
54
+ */
55
+ requestTxs(txHashes: TxHash[]): Promise<(Tx | undefined)[]>;
56
+ /**
57
+ * Request a transaction from another peer by its tx hash.
58
+ * @param txHash - Hash of the tx to query.
59
+ */
60
+ requestTxByHash(txHash: TxHash): Promise<Tx | undefined>;
61
+ /**
62
+ * Verifies the 'tx' and, if valid, adds it to local tx pool and forwards it to other peers.
63
+ * @param tx - The transaction.
64
+ **/
65
+ sendTx(tx: Tx): Promise<void>;
66
+ /**
67
+ * Deletes 'txs' from the pool, given hashes.
68
+ * NOT used if we use sendTx as reconcileTxPool will handle this.
69
+ * @param txHashes - Hashes to check.
70
+ **/
71
+ deleteTxs(txHashes: TxHash[]): Promise<void>;
72
+ /**
73
+ * Returns a transaction in the transaction pool by its hash.
74
+ * @param txHash - Hash of tx to return.
75
+ * @returns A single tx or undefined.
76
+ */
77
+ getTxByHashFromPool(txHash: TxHash): Promise<Tx | undefined>;
78
+ /**
79
+ * Returns a transaction in the transaction pool by its hash, requesting it from the network if it is not found.
80
+ * @param txHash - Hash of tx to return.
81
+ * @returns A single tx or undefined.
82
+ */
83
+ getTxByHash(txHash: TxHash): Promise<Tx | undefined>;
84
+ /**
85
+ * Returns an archived transaction from the transaction pool by its hash.
86
+ * @param txHash - Hash of tx to return.
87
+ * @returns A single tx or undefined.
88
+ */
89
+ getArchivedTxByHash(txHash: TxHash): Promise<Tx | undefined>;
90
+ /**
91
+ * Returns whether the given tx hash is flagged as pending or mined.
92
+ * @param txHash - Hash of the tx to query.
93
+ * @returns Pending or mined depending on its status, or undefined if not found.
94
+ */
95
+ getTxStatus(txHash: TxHash): Promise<'pending' | 'mined' | undefined>;
96
+ /** Returns an iterator over pending txs on the mempool. */
97
+ iteratePendingTxs(): AsyncIterableIterator<Tx>;
98
+ /** Returns the number of pending txs in the mempool. */
99
+ getPendingTxCount(): Promise<number>;
100
+ /**
101
+ * Starts the p2p client.
102
+ * @returns A promise signalling the completion of the block sync.
103
+ */
104
+ start(): Promise<void>;
105
+ /**
106
+ * Stops the p2p client.
107
+ * @returns A promise signalling the completion of the stop process.
108
+ */
109
+ stop(): Promise<void>;
110
+ /**
111
+ * Indicates if the p2p client is ready for transaction submission.
112
+ * @returns A boolean flag indicating readiness.
113
+ */
114
+ isReady(): boolean;
115
+ /**
116
+ * Returns the current status of the p2p client.
117
+ */
118
+ getStatus(): Promise<P2PSyncState>;
119
+ /**
120
+ * Returns the ENR of this node, if any.
121
+ */
122
+ getEnr(): ENR | undefined;
123
+ /** Identifies a p2p client. */
124
+ isP2PClient(): true;
125
+ };
126
+ /**
127
+ * The P2P client implementation.
128
+ */
129
+ export declare class P2PClient<T extends P2PClientType = P2PClientType.Full> extends WithTracer implements P2P, P2P<P2PClientType.Prover> {
130
+ #private;
131
+ private l2BlockSource;
132
+ private p2pService;
133
+ private log;
134
+ /** The JS promise that will be running to keep the client's data in sync. Can be interrupted if the client is stopped. */
135
+ private runningPromise;
136
+ private currentState;
137
+ private syncPromise;
138
+ private syncResolve?;
139
+ private latestBlockNumberAtStart;
140
+ private provenBlockNumberAtStart;
141
+ private synchedBlockHashes;
142
+ private synchedLatestBlockNumber;
143
+ private synchedProvenBlockNumber;
144
+ private txPool;
145
+ private attestationPool;
146
+ /** How many slots to keep attestations for. */
147
+ private keepAttestationsInPoolFor;
148
+ /** How many slots to keep proven txs for. */
149
+ private keepProvenTxsFor;
150
+ private blockStream;
151
+ /**
152
+ * In-memory P2P client constructor.
153
+ * @param store - The client's instance of the KV store.
154
+ * @param l2BlockSource - P2P client's source for fetching existing blocks.
155
+ * @param txPool - The client's instance of a transaction pool. Defaults to in-memory implementation.
156
+ * @param p2pService - The concrete instance of p2p networking to use.
157
+ * @param keepProvenTxsFor - How many blocks have to pass after a block is proven before its txs are deleted (zero to delete immediately once proven).
158
+ * @param log - A logger.
159
+ */
160
+ constructor(_clientType: T, store: AztecAsyncKVStore, l2BlockSource: L2BlockSource, mempools: MemPools<T>, p2pService: P2PService, config?: Partial<P2PConfig>, telemetry?: TelemetryClient, log?: import("@aztec/foundation/log").Logger);
161
+ isP2PClient(): true;
162
+ getPeers(includePending?: boolean): Promise<PeerInfo[]>;
163
+ getL2BlockHash(number: number): Promise<string | undefined>;
164
+ getL2Tips(): Promise<L2Tips>;
165
+ handleBlockStreamEvent(event: L2BlockStreamEvent): Promise<void>;
166
+ /**
167
+ * Starts the P2P client.
168
+ * @returns An empty promise signalling the synching process.
169
+ */
170
+ start(): Promise<void>;
171
+ /**
172
+ * Allows consumers to stop the instance of the P2P client.
173
+ * 'ready' will now return 'false' and the running promise that keeps the client synced is interrupted.
174
+ */
175
+ stop(): Promise<void>;
176
+ broadcastProposal(proposal: BlockProposal): void;
177
+ getAttestationsForSlot(slot: bigint, proposalId: string): Promise<BlockAttestation[]>;
178
+ registerBlockProposalHandler(handler: (block: BlockProposal) => Promise<BlockAttestation | undefined>): void;
179
+ /**
180
+ * Requests the transactions with the given hashes from the network.
181
+ *
182
+ * If a transaction can be retrieved, it will be returned, if not an undefined
183
+ * will be returned. In place.
184
+ *
185
+ * @param txHashes - The hashes of the transactions to request.
186
+ * @returns A promise that resolves to an array of transactions or undefined.
187
+ */
188
+ requestTxs(txHashes: TxHash[]): Promise<(Tx | undefined)[]>;
189
+ /**
190
+ * Uses the Request Response protocol to request a transaction from the network.
191
+ *
192
+ * If the underlying request response protocol fails, then we return undefined.
193
+ * If it succeeds then we add the transaction to our transaction pool and return.
194
+ *
195
+ * @param txHash - The hash of the transaction to request.
196
+ * @returns A promise that resolves to a transaction or undefined.
197
+ */
198
+ requestTxByHash(txHash: TxHash): Promise<Tx | undefined>;
199
+ /**
200
+ * Uses the batched Request Response protocol to request a set of transactions from the network.
201
+ */
202
+ requestTxsByHash(txHashes: TxHash[]): Promise<Tx[]>;
203
+ getPendingTxs(): Promise<Tx[]>;
204
+ getPendingTxCount(): Promise<number>;
205
+ iteratePendingTxs(): AsyncIterableIterator<Tx>;
206
+ /**
207
+ * Returns all transactions in the transaction pool.
208
+ * @returns An array of Txs.
209
+ */
210
+ getTxs(filter: 'all' | 'pending' | 'mined'): Promise<Tx[]>;
211
+ /**
212
+ * Returns a transaction in the transaction pool by its hash.
213
+ * @param txHash - Hash of the transaction to look for in the pool.
214
+ * @returns A single tx or undefined.
215
+ */
216
+ getTxByHashFromPool(txHash: TxHash): Promise<Tx | undefined>;
217
+ /**
218
+ * Returns a transaction in the transaction pool by its hash.
219
+ * If the transaction is not in the pool, it will be requested from the network.
220
+ * @param txHash - Hash of the transaction to look for in the pool.
221
+ * @returns A single tx or undefined.
222
+ */
223
+ getTxByHash(txHash: TxHash): Promise<Tx | undefined>;
224
+ /**
225
+ * Returns transactions in the transaction pool by hash.
226
+ * If a transaction is not in the pool, it will be requested from the network.
227
+ * @param txHashes - Hashes of the transactions to look for.
228
+ * @returns The txs found, not necessarily on the same order as the hashes.
229
+ */
230
+ getTxsByHash(txHashes: TxHash[]): Promise<Tx[]>;
231
+ /**
232
+ * Returns an archived transaction in the transaction pool by its hash.
233
+ * @param txHash - Hash of the archived transaction to look for.
234
+ * @returns A single tx or undefined.
235
+ */
236
+ getArchivedTxByHash(txHash: TxHash): Promise<Tx | undefined>;
237
+ /**
238
+ * Verifies the 'tx' and, if valid, adds it to local tx pool and forwards it to other peers.
239
+ * @param tx - The tx to verify.
240
+ * @returns Empty promise.
241
+ **/
242
+ sendTx(tx: Tx): Promise<void>;
243
+ /**
244
+ * Returns whether the given tx hash is flagged as pending or mined.
245
+ * @param txHash - Hash of the tx to query.
246
+ * @returns Pending or mined depending on its status, or undefined if not found.
247
+ */
248
+ getTxStatus(txHash: TxHash): Promise<'pending' | 'mined' | undefined>;
249
+ getEnr(): ENR | undefined;
250
+ getEncodedEnr(): Promise<string | undefined>;
251
+ /**
252
+ * Deletes the 'txs' from the pool.
253
+ * NOT used if we use sendTx as reconcileTxPool will handle this.
254
+ * @param txHashes - Hashes of the transactions to delete.
255
+ * @returns Empty promise.
256
+ **/
257
+ deleteTxs(txHashes: TxHash[]): Promise<void>;
258
+ /**
259
+ * Public function to check if the p2p client is fully synced and ready to receive txs.
260
+ * @returns True if the P2P client is ready to receive txs.
261
+ */
262
+ isReady(): boolean;
263
+ /**
264
+ * Public function to check the latest block number that the P2P client is synced to.
265
+ * @returns Block number of latest L2 Block we've synced with.
266
+ */
267
+ getSyncedLatestBlockNum(): Promise<number>;
268
+ /**
269
+ * Public function to check the latest proven block number that the P2P client is synced to.
270
+ * @returns Block number of latest proven L2 Block we've synced with.
271
+ */
272
+ getSyncedProvenBlockNum(): Promise<number>;
273
+ /**
274
+ * Method to check the status the p2p client.
275
+ * @returns Information about p2p client status: state & syncedToBlockNum.
276
+ */
277
+ getStatus(): Promise<P2PSyncState>;
278
+ /**
279
+ * Mark all txs from these blocks as mined.
280
+ * @param blocks - A list of existing blocks with txs that the P2P client needs to ensure the tx pool is reconciled with.
281
+ * @returns Empty promise.
282
+ */
283
+ private markTxsAsMinedFromBlocks;
284
+ /**
285
+ * Deletes txs from these blocks.
286
+ * @param blocks - A list of existing blocks with txs that the P2P client needs to ensure the tx pool is reconciled with.
287
+ * @returns Empty promise.
288
+ */
289
+ private deleteTxsFromBlocks;
290
+ /**
291
+ * Handles new mined blocks by marking the txs in them as mined.
292
+ * @param blocks - A list of existing blocks with txs that the P2P client needs to ensure the tx pool is reconciled with.
293
+ * @returns Empty promise.
294
+ */
295
+ private handleLatestL2Blocks;
296
+ /**
297
+ * Handles new proven blocks by deleting the txs in them, or by deleting the txs in blocks `keepProvenTxsFor` ago.
298
+ * @param blocks - A list of proven L2 blocks.
299
+ * @returns Empty promise.
300
+ */
301
+ private handleProvenL2Blocks;
302
+ /**
303
+ * Updates the tx pool after a chain prune.
304
+ * @param latestBlock - The block number the chain was pruned to.
305
+ */
306
+ private handlePruneL2Blocks;
307
+ private startServiceIfSynched;
308
+ /**
309
+ * Method to set the value of the current state.
310
+ * @param newState - New state value.
311
+ */
312
+ private setCurrentState;
313
+ }
314
+ //# sourceMappingURL=p2p_client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"p2p_client.d.ts","sourceRoot":"","sources":["../../src/client/p2p_client.ts"],"names":[],"mappings":"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"}