@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/src/config.ts ADDED
@@ -0,0 +1,371 @@
1
+ import {
2
+ type ConfigMappingsType,
3
+ booleanConfigHelper,
4
+ getConfigFromMappings,
5
+ getDefaultConfig,
6
+ numberConfigHelper,
7
+ pickConfigMappings,
8
+ } from '@aztec/foundation/config';
9
+ import { type DataStoreConfig, dataConfigMappings } from '@aztec/kv-store/config';
10
+ import { type ChainConfig, chainConfigMappings } from '@aztec/stdlib/config';
11
+
12
+ import { type P2PReqRespConfig, p2pReqRespConfigMappings } from './services/reqresp/config.js';
13
+
14
+ /**
15
+ * P2P client configuration values.
16
+ */
17
+ export interface P2PConfig extends P2PReqRespConfig, ChainConfig {
18
+ /**
19
+ * A flag dictating whether the P2P subsystem should be enabled.
20
+ */
21
+ p2pEnabled: boolean;
22
+
23
+ /**
24
+ * The frequency in which to check for new L2 blocks.
25
+ */
26
+ blockCheckIntervalMS: number;
27
+
28
+ /**
29
+ * The number of blocks to fetch in a single batch.
30
+ */
31
+ blockRequestBatchSize: number;
32
+
33
+ /**
34
+ * DEBUG: Disable colocation penalty - for testing purposes only
35
+ */
36
+ debugDisableColocationPenalty: boolean;
37
+
38
+ /**
39
+ * The frequency in which to check for new peers.
40
+ */
41
+ peerCheckIntervalMS: number;
42
+
43
+ /**
44
+ * Size of queue of L2 blocks to store.
45
+ */
46
+ l2QueueSize: number;
47
+
48
+ /**
49
+ * The announce address for TCP.
50
+ */
51
+ tcpAnnounceAddress?: string;
52
+
53
+ /**
54
+ * The announce address for UDP.
55
+ */
56
+ udpAnnounceAddress?: string;
57
+
58
+ /**
59
+ * The listen address for TCP.
60
+ */
61
+ tcpListenAddress: string;
62
+
63
+ /**
64
+ * The listen address for UDP.
65
+ */
66
+ udpListenAddress: string;
67
+
68
+ /**
69
+ * An optional peer id private key. If blank, will generate a random key.
70
+ */
71
+ peerIdPrivateKey?: string;
72
+
73
+ /**
74
+ * A list of bootstrap peers to connect to.
75
+ */
76
+ bootstrapNodes: string[];
77
+
78
+ /** Whether to execute the version check in the bootstrap node ENR. */
79
+ bootstrapNodeEnrVersionCheck: boolean;
80
+
81
+ /** Whether to consider any configured bootnodes as full peers, e.g. for transaction gossiping */
82
+ bootstrapNodesAsFullPeers: boolean;
83
+
84
+ /**
85
+ * The maximum number of peers (a peer count above this will cause the node to refuse connection attempts)
86
+ */
87
+ maxPeerCount: number;
88
+
89
+ /**
90
+ * If announceUdpAddress or announceTcpAddress are not provided, query for the IP address of the machine. Default is false.
91
+ */
92
+ queryForIp: boolean;
93
+
94
+ /** How many blocks have to pass after a block is proven before its txs are deleted (zero to delete immediately once proven) */
95
+ keepProvenTxsInPoolFor: number;
96
+
97
+ /** How many slots to keep attestations for. */
98
+ keepAttestationsInPoolFor: number;
99
+
100
+ /**
101
+ * The interval of the gossipsub heartbeat to perform maintenance tasks.
102
+ */
103
+ gossipsubInterval: number;
104
+
105
+ /**
106
+ * The D parameter for the gossipsub protocol.
107
+ */
108
+ gossipsubD: number;
109
+
110
+ /**
111
+ * The Dlo parameter for the gossipsub protocol.
112
+ */
113
+ gossipsubDlo: number;
114
+
115
+ /**
116
+ * The Dhi parameter for the gossipsub protocol.
117
+ */
118
+ gossipsubDhi: number;
119
+
120
+ /**
121
+ * The Dlazy parameter for the gossipsub protocol.
122
+ */
123
+ gossipsubDLazy: number;
124
+
125
+ /**
126
+ * Whether to flood publish messages. - For testing purposes only
127
+ */
128
+ gossipsubFloodPublish: boolean;
129
+
130
+ /**
131
+ * The number of gossipsub interval message cache windows to keep.
132
+ */
133
+ gossipsubMcacheLength: number;
134
+
135
+ /**
136
+ * How many message cache windows to include when gossiping with other pears.
137
+ */
138
+ gossipsubMcacheGossip: number;
139
+
140
+ /**
141
+ * The 'age' (in # of L2 blocks) of a processed tx after which we heavily penalize a peer for re-sending it.
142
+ */
143
+ doubleSpendSeverePeerPenaltyWindow: number;
144
+
145
+ /**
146
+ * The weight of the tx topic for the gossipsub protocol. This determines how much the score for this specific topic contributes to the overall peer score.
147
+ */
148
+ gossipsubTxTopicWeight: number;
149
+
150
+ /**
151
+ * This is the weight applied to the penalty for delivering invalid messages.
152
+ */
153
+ gossipsubTxInvalidMessageDeliveriesWeight: number;
154
+
155
+ /**
156
+ * determines how quickly the penalty for invalid message deliveries decays over time. Between 0 and 1.
157
+ */
158
+ gossipsubTxInvalidMessageDeliveriesDecay: number;
159
+
160
+ /**
161
+ * The values for the peer scoring system. Passed as a comma separated list of values in order: low, mid, high tolerance errors.
162
+ */
163
+ peerPenaltyValues: number[];
164
+
165
+ /** Limit of transactions to archive in the tx pool. Once the archived tx limit is reached, the oldest archived txs will be purged. */
166
+ archivedTxLimit: number;
167
+ }
168
+
169
+ export const p2pConfigMappings: ConfigMappingsType<P2PConfig> = {
170
+ p2pEnabled: {
171
+ env: 'P2P_ENABLED',
172
+ description: 'A flag dictating whether the P2P subsystem should be enabled.',
173
+ ...booleanConfigHelper(),
174
+ },
175
+ blockCheckIntervalMS: {
176
+ env: 'P2P_BLOCK_CHECK_INTERVAL_MS',
177
+ description: 'The frequency in which to check for new L2 blocks.',
178
+ ...numberConfigHelper(100),
179
+ },
180
+ debugDisableColocationPenalty: {
181
+ env: 'DEBUG_P2P_DISABLE_COLOCATION_PENALTY',
182
+ description: 'DEBUG: Disable colocation penalty - NEVER set to true in production',
183
+ ...booleanConfigHelper(false),
184
+ },
185
+ peerCheckIntervalMS: {
186
+ env: 'P2P_PEER_CHECK_INTERVAL_MS',
187
+ description: 'The frequency in which to check for new peers.',
188
+ ...numberConfigHelper(30_000),
189
+ },
190
+ l2QueueSize: {
191
+ env: 'P2P_L2_QUEUE_SIZE',
192
+ description: 'Size of queue of L2 blocks to store.',
193
+ ...numberConfigHelper(1_000),
194
+ },
195
+ tcpListenAddress: {
196
+ env: 'P2P_TCP_LISTEN_ADDR',
197
+ defaultValue: '0.0.0.0:40400',
198
+ description: 'The listen address for TCP. Format: <IP_ADDRESS>:<PORT>.',
199
+ },
200
+ udpListenAddress: {
201
+ env: 'P2P_UDP_LISTEN_ADDR',
202
+ defaultValue: '0.0.0.0:40400',
203
+ description: 'The listen address for UDP. Format: <IP_ADDRESS>:<PORT>.',
204
+ },
205
+ tcpAnnounceAddress: {
206
+ env: 'P2P_TCP_ANNOUNCE_ADDR',
207
+ description:
208
+ 'The announce address for TCP. Format: <IP_ADDRESS>:<PORT>. Leave IP_ADDRESS blank to query for public IP.',
209
+ },
210
+ udpAnnounceAddress: {
211
+ env: 'P2P_UDP_ANNOUNCE_ADDR',
212
+ description:
213
+ 'The announce address for UDP. Format: <IP_ADDRESS>:<PORT>. Leave IP_ADDRESS blank to query for public IP.',
214
+ },
215
+ peerIdPrivateKey: {
216
+ env: 'PEER_ID_PRIVATE_KEY',
217
+ description: 'An optional peer id private key. If blank, will generate a random key.',
218
+ },
219
+ bootstrapNodes: {
220
+ env: 'BOOTSTRAP_NODES',
221
+ parseEnv: (val: string) => val.split(','),
222
+ description: 'A list of bootstrap peer ENRs to connect to. Separated by commas.',
223
+ },
224
+ bootstrapNodeEnrVersionCheck: {
225
+ env: 'P2P_BOOTSTRAP_NODE_ENR_VERSION_CHECK',
226
+ description: 'Whether to check the version of the bootstrap node ENR.',
227
+ ...booleanConfigHelper(),
228
+ },
229
+ bootstrapNodesAsFullPeers: {
230
+ env: 'P2P_BOOTSTRAP_NODES_AS_FULL_PEERS',
231
+ description: 'Whether to consider our configured bootnodes as full peers',
232
+ ...booleanConfigHelper(false),
233
+ },
234
+ maxPeerCount: {
235
+ env: 'P2P_MAX_PEERS',
236
+ description: 'The maximum number of peers to connect to.',
237
+ ...numberConfigHelper(100),
238
+ },
239
+ queryForIp: {
240
+ env: 'P2P_QUERY_FOR_IP',
241
+ description:
242
+ 'If announceUdpAddress or announceTcpAddress are not provided, query for the IP address of the machine. Default is false.',
243
+ ...booleanConfigHelper(),
244
+ },
245
+ keepProvenTxsInPoolFor: {
246
+ env: 'P2P_TX_POOL_KEEP_PROVEN_FOR',
247
+ description:
248
+ 'How many blocks have to pass after a block is proven before its txs are deleted (zero to delete immediately once proven)',
249
+ ...numberConfigHelper(0),
250
+ },
251
+ keepAttestationsInPoolFor: {
252
+ env: 'P2P_ATTESTATION_POOL_KEEP_FOR',
253
+ description: 'How many slots to keep attestations for.',
254
+ ...numberConfigHelper(96),
255
+ },
256
+ gossipsubInterval: {
257
+ env: 'P2P_GOSSIPSUB_INTERVAL_MS',
258
+ description: 'The interval of the gossipsub heartbeat to perform maintenance tasks.',
259
+ ...numberConfigHelper(700),
260
+ },
261
+ gossipsubD: {
262
+ env: 'P2P_GOSSIPSUB_D',
263
+ description: 'The D parameter for the gossipsub protocol.',
264
+ ...numberConfigHelper(8),
265
+ },
266
+ gossipsubDlo: {
267
+ env: 'P2P_GOSSIPSUB_DLO',
268
+ description: 'The Dlo parameter for the gossipsub protocol.',
269
+ ...numberConfigHelper(4),
270
+ },
271
+ gossipsubDhi: {
272
+ env: 'P2P_GOSSIPSUB_DHI',
273
+ description: 'The Dhi parameter for the gossipsub protocol.',
274
+ ...numberConfigHelper(12),
275
+ },
276
+ gossipsubDLazy: {
277
+ env: 'P2P_GOSSIPSUB_DLAZY',
278
+ description: 'The Dlazy parameter for the gossipsub protocol.',
279
+ ...numberConfigHelper(8),
280
+ },
281
+ gossipsubFloodPublish: {
282
+ env: 'P2P_GOSSIPSUB_FLOOD_PUBLISH',
283
+ description: 'Whether to flood publish messages. - For testing purposes only',
284
+ ...booleanConfigHelper(true),
285
+ },
286
+ gossipsubMcacheLength: {
287
+ env: 'P2P_GOSSIPSUB_MCACHE_LENGTH',
288
+ description: 'The number of gossipsub interval message cache windows to keep.',
289
+ ...numberConfigHelper(6),
290
+ },
291
+ gossipsubMcacheGossip: {
292
+ env: 'P2P_GOSSIPSUB_MCACHE_GOSSIP',
293
+ description: 'How many message cache windows to include when gossiping with other pears.',
294
+ ...numberConfigHelper(3),
295
+ },
296
+ gossipsubTxTopicWeight: {
297
+ env: 'P2P_GOSSIPSUB_TX_TOPIC_WEIGHT',
298
+ description: 'The weight of the tx topic for the gossipsub protocol.',
299
+ ...numberConfigHelper(1),
300
+ },
301
+ gossipsubTxInvalidMessageDeliveriesWeight: {
302
+ env: 'P2P_GOSSIPSUB_TX_INVALID_MESSAGE_DELIVERIES_WEIGHT',
303
+ description: 'The weight of the tx invalid message deliveries for the gossipsub protocol.',
304
+ ...numberConfigHelper(-20),
305
+ },
306
+ gossipsubTxInvalidMessageDeliveriesDecay: {
307
+ env: 'P2P_GOSSIPSUB_TX_INVALID_MESSAGE_DELIVERIES_DECAY',
308
+ description: 'Determines how quickly the penalty for invalid message deliveries decays over time. Between 0 and 1.',
309
+ ...numberConfigHelper(0.5),
310
+ },
311
+ peerPenaltyValues: {
312
+ env: 'P2P_PEER_PENALTY_VALUES',
313
+ parseEnv: (val: string) => val.split(',').map(Number),
314
+ description:
315
+ 'The values for the peer scoring system. Passed as a comma separated list of values in order: low, mid, high tolerance errors.',
316
+ defaultValue: [2, 10, 50],
317
+ },
318
+ doubleSpendSeverePeerPenaltyWindow: {
319
+ env: 'P2P_DOUBLE_SPEND_SEVERE_PEER_PENALTY_WINDOW',
320
+ description: 'The "age" (in L2 blocks) of a tx after which we heavily penalize a peer for sending it.',
321
+ ...numberConfigHelper(30),
322
+ },
323
+ blockRequestBatchSize: {
324
+ env: 'P2P_BLOCK_REQUEST_BATCH_SIZE',
325
+ description: 'The number of blocks to fetch in a single batch.',
326
+ ...numberConfigHelper(20),
327
+ },
328
+ archivedTxLimit: {
329
+ env: 'P2P_ARCHIVED_TX_LIMIT',
330
+ description:
331
+ 'The number of transactions that will be archived. If the limit is set to 0 then archiving will be disabled.',
332
+ ...numberConfigHelper(0),
333
+ },
334
+ ...p2pReqRespConfigMappings,
335
+ ...chainConfigMappings,
336
+ };
337
+
338
+ /**
339
+ * Gets the config values for p2p client from environment variables.
340
+ * @returns The config values for p2p client.
341
+ */
342
+ export function getP2PConfigFromEnv(): P2PConfig {
343
+ return getConfigFromMappings<P2PConfig>(p2pConfigMappings);
344
+ }
345
+
346
+ export function getP2PDefaultConfig(): P2PConfig {
347
+ return getDefaultConfig<P2PConfig>(p2pConfigMappings);
348
+ }
349
+
350
+ /**
351
+ * Required P2P config values for a bootstrap node.
352
+ */
353
+ export type BootnodeConfig = Pick<P2PConfig, 'udpAnnounceAddress' | 'peerIdPrivateKey' | 'bootstrapNodes'> &
354
+ Required<Pick<P2PConfig, 'udpListenAddress'>> &
355
+ Pick<DataStoreConfig, 'dataDirectory' | 'dataStoreMapSizeKB'> &
356
+ Pick<ChainConfig, 'l1ChainId'>;
357
+
358
+ const bootnodeConfigKeys: (keyof BootnodeConfig)[] = [
359
+ 'udpAnnounceAddress',
360
+ 'peerIdPrivateKey',
361
+ 'udpListenAddress',
362
+ 'dataDirectory',
363
+ 'dataStoreMapSizeKB',
364
+ 'bootstrapNodes',
365
+ 'l1ChainId',
366
+ ];
367
+
368
+ export const bootnodeConfigMappings = pickConfigMappings(
369
+ { ...p2pConfigMappings, ...dataConfigMappings, ...chainConfigMappings },
370
+ bootnodeConfigKeys,
371
+ );
@@ -0,0 +1,39 @@
1
+ import type { LogFn } from '@aztec/foundation/log';
2
+ import { type ChainConfig, emptyChainConfig } from '@aztec/stdlib/config';
3
+
4
+ import { ENR, SignableENR } from '@chainsafe/enr';
5
+ import type { PeerId } from '@libp2p/interface';
6
+ import { multiaddr } from '@multiformats/multiaddr';
7
+
8
+ import { AZTEC_ENR_KEY } from '../types/index.js';
9
+ import { convertToMultiaddr, createLibP2PPeerIdFromPrivateKey } from '../util.js';
10
+ import { setAztecEnrKey } from '../versioning.js';
11
+
12
+ export async function createBootnodeENRandPeerId(
13
+ privateKey: string,
14
+ udpAnnounceAddress: string,
15
+ l1ChainId: number,
16
+ ): Promise<{ enr: SignableENR; peerId: PeerId }> {
17
+ const peerId = await createLibP2PPeerIdFromPrivateKey(privateKey);
18
+ const enr = SignableENR.createFromPeerId(peerId);
19
+ const publicAddr = multiaddr(convertToMultiaddr(udpAnnounceAddress, 'udp'));
20
+ enr.setLocationMultiaddr(publicAddr);
21
+
22
+ const config: ChainConfig = {
23
+ ...emptyChainConfig,
24
+ l1ChainId,
25
+ };
26
+
27
+ setAztecEnrKey(enr, config);
28
+ return { enr, peerId };
29
+ }
30
+
31
+ export async function printENR(enr: string, log: LogFn) {
32
+ const decoded = ENR.decodeTxt(enr);
33
+ log(`PeerID: ${await decoded.peerId()}`);
34
+ log(`IP: ${decoded.ip}`);
35
+ log(`UDP: ${decoded.udp}`);
36
+ log(`TCP: ${decoded.tcp}`);
37
+ const aztec = decoded.kvs.get(AZTEC_ENR_KEY);
38
+ log(`Aztec version: ${aztec?.toString()}`);
39
+ }
@@ -0,0 +1 @@
1
+ export * from './generate-enr.js';
@@ -0,0 +1,35 @@
1
+ /** Individual request timeout error
2
+ *
3
+ * This error will be thrown when a request to a specific peer times out.
4
+ * @category Errors
5
+ */
6
+ export class IndividualReqRespTimeoutError extends Error {
7
+ constructor() {
8
+ super(`Request to peer timed out`);
9
+ }
10
+ }
11
+
12
+ /** Collective request timeout error
13
+ *
14
+ * This error will be thrown when a req resp request times out regardless of the peer.
15
+ * @category Errors
16
+ */
17
+ export class CollectiveReqRespTimeoutError extends Error {
18
+ constructor() {
19
+ super(`Request to all peers timed out`);
20
+ }
21
+ }
22
+
23
+ /** Invalid response error
24
+ *
25
+ * This error will be thrown when a response is received that is not valid.
26
+ *
27
+ * This error does not need to be punished as message validators will handle punishing invalid
28
+ * requests
29
+ * @category Errors
30
+ */
31
+ export class InvalidResponseError extends Error {
32
+ constructor() {
33
+ super(`Invalid response received`);
34
+ }
35
+ }
package/src/index.ts ADDED
@@ -0,0 +1,7 @@
1
+ export * from './bootstrap/bootstrap.js';
2
+ export * from './client/index.js';
3
+ export * from './config.js';
4
+ export * from './mem_pools/attestation_pool/index.js';
5
+ export * from './mem_pools/tx_pool/index.js';
6
+ export * from './msg_validators/index.js';
7
+ export * from './services/index.js';
@@ -0,0 +1,62 @@
1
+ import type { BlockAttestation } from '@aztec/stdlib/p2p';
2
+
3
+ /**
4
+ * An Attestation Pool contains attestations collected by a validator
5
+ *
6
+ * Attestations that are observed via the p2p network are stored for requests
7
+ * from the validator to produce a block, or to serve to other peers.
8
+ */
9
+ export interface AttestationPool {
10
+ /**
11
+ * AddAttestation
12
+ *
13
+ * @param attestations - Attestations to add into the pool
14
+ */
15
+ addAttestations(attestations: BlockAttestation[]): Promise<void>;
16
+
17
+ /**
18
+ * DeleteAttestation
19
+ *
20
+ * @param attestations - Attestations to remove from the pool
21
+ */
22
+ deleteAttestations(attestations: BlockAttestation[]): Promise<void>;
23
+
24
+ /**
25
+ * Delete Attestations with a slot number smaller than the given slot
26
+ *
27
+ * Removes all attestations associated with a slot
28
+ *
29
+ * @param slot - The oldest slot to keep.
30
+ */
31
+ deleteAttestationsOlderThan(slot: bigint): Promise<void>;
32
+
33
+ /**
34
+ * Delete Attestations for slot
35
+ *
36
+ * Removes all attestations associated with a slot
37
+ *
38
+ * @param slot - The slot to delete.
39
+ */
40
+ deleteAttestationsForSlot(slot: bigint): Promise<void>;
41
+
42
+ /**
43
+ * Delete Attestations for slot and proposal
44
+ *
45
+ * Removes all attestations associated with a slot and proposal
46
+ *
47
+ * @param slot - The slot to delete.
48
+ * @param proposalId - The proposal to delete.
49
+ */
50
+ deleteAttestationsForSlotAndProposal(slot: bigint, proposalId: string): Promise<void>;
51
+
52
+ /**
53
+ * Get Attestations for slot
54
+ *
55
+ * Retrieve all of the attestations observed pertaining to a given slot
56
+ *
57
+ * @param slot - The slot to query
58
+ * @param proposalId - The proposal to query
59
+ * @return BlockAttestations
60
+ */
61
+ getAttestationsForSlot(slot: bigint, proposalId: string): Promise<BlockAttestation[]>;
62
+ }