@aztec/foundation 0.0.1-commit.b655e406 → 0.0.1-commit.c0b82b2

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 (508) hide show
  1. package/dest/array/array.d.ts +1 -9
  2. package/dest/array/array.d.ts.map +1 -1
  3. package/dest/array/array.js +0 -11
  4. package/dest/array/index.d.ts +2 -1
  5. package/dest/array/index.d.ts.map +1 -1
  6. package/dest/array/index.js +1 -0
  7. package/dest/array/sorted_array.d.ts +15 -0
  8. package/dest/array/sorted_array.d.ts.map +1 -0
  9. package/dest/array/sorted_array.js +109 -0
  10. package/dest/async-map/index.d.ts +1 -1
  11. package/dest/async-pool/index.d.ts +1 -1
  12. package/dest/bigint/index.d.ts +1 -1
  13. package/dest/bigint-buffer/index.d.ts +1 -1
  14. package/dest/branded-types/block_number.d.ts +56 -0
  15. package/dest/branded-types/block_number.d.ts.map +1 -0
  16. package/dest/branded-types/block_number.js +78 -0
  17. package/dest/branded-types/checkpoint_number.d.ts +54 -0
  18. package/dest/branded-types/checkpoint_number.d.ts.map +1 -0
  19. package/dest/branded-types/checkpoint_number.js +77 -0
  20. package/dest/branded-types/epoch.d.ts +42 -0
  21. package/dest/branded-types/epoch.d.ts.map +1 -0
  22. package/dest/branded-types/epoch.js +59 -0
  23. package/dest/branded-types/index.d.ts +7 -0
  24. package/dest/branded-types/index.d.ts.map +1 -0
  25. package/dest/branded-types/index.js +5 -0
  26. package/dest/branded-types/index_within_checkpoint.d.ts +42 -0
  27. package/dest/branded-types/index_within_checkpoint.d.ts.map +1 -0
  28. package/dest/branded-types/index_within_checkpoint.js +59 -0
  29. package/dest/branded-types/slot.d.ts +42 -0
  30. package/dest/branded-types/slot.d.ts.map +1 -0
  31. package/dest/branded-types/slot.js +59 -0
  32. package/dest/branded-types/types.d.ts +5 -0
  33. package/dest/branded-types/types.d.ts.map +1 -0
  34. package/dest/branded-types/types.js +1 -0
  35. package/dest/buffer/buffer16.d.ts +2 -2
  36. package/dest/buffer/buffer16.d.ts.map +1 -1
  37. package/dest/buffer/buffer16.js +4 -2
  38. package/dest/buffer/buffer32.d.ts +2 -2
  39. package/dest/buffer/buffer32.d.ts.map +1 -1
  40. package/dest/buffer/buffer32.js +4 -2
  41. package/dest/buffer/index.d.ts +1 -1
  42. package/dest/collection/array.d.ts +12 -1
  43. package/dest/collection/array.d.ts.map +1 -1
  44. package/dest/collection/array.js +51 -0
  45. package/dest/collection/index.d.ts +1 -1
  46. package/dest/collection/object.d.ts +1 -1
  47. package/dest/committable/committable.d.ts +1 -1
  48. package/dest/committable/committable.d.ts.map +1 -1
  49. package/dest/committable/index.d.ts +1 -1
  50. package/dest/config/env_var.d.ts +2 -2
  51. package/dest/config/env_var.d.ts.map +1 -1
  52. package/dest/config/index.d.ts +15 -4
  53. package/dest/config/index.d.ts.map +1 -1
  54. package/dest/config/index.js +32 -9
  55. package/dest/config/network_config.d.ts +13 -1
  56. package/dest/config/network_config.d.ts.map +1 -1
  57. package/dest/config/network_config.js +3 -1
  58. package/dest/config/network_name.d.ts +2 -2
  59. package/dest/config/network_name.d.ts.map +1 -1
  60. package/dest/config/network_name.js +2 -0
  61. package/dest/config/parse-env.d.ts +3 -0
  62. package/dest/config/parse-env.d.ts.map +1 -0
  63. package/dest/config/parse-env.js +7 -0
  64. package/dest/config/secret_value.d.ts +1 -1
  65. package/dest/config/secret_value.d.ts.map +1 -1
  66. package/dest/config/secret_value.js +3 -1
  67. package/dest/crypto/aes128/index.d.ts +1 -1
  68. package/dest/crypto/aes128/index.d.ts.map +1 -1
  69. package/dest/crypto/aes128/index.js +2 -6
  70. package/dest/crypto/bls/bn254_keystore.d.ts +15 -15
  71. package/dest/crypto/bls/bn254_keystore.d.ts.map +1 -1
  72. package/dest/crypto/bls/bn254_keystore.js +1 -1
  73. package/dest/crypto/bls/index.d.ts +1 -1
  74. package/dest/crypto/bls/index.js +1 -1
  75. package/dest/crypto/bn254/index.d.ts +35 -51
  76. package/dest/crypto/bn254/index.d.ts.map +1 -1
  77. package/dest/crypto/bn254/index.js +51 -137
  78. package/dest/crypto/ecdsa/index.d.ts +1 -1
  79. package/dest/crypto/ecdsa/index.d.ts.map +1 -1
  80. package/dest/crypto/ecdsa/index.js +4 -12
  81. package/dest/crypto/ecdsa/signature.d.ts +2 -2
  82. package/dest/crypto/ecdsa/signature.d.ts.map +1 -1
  83. package/dest/crypto/ecdsa/signature.js +2 -2
  84. package/dest/crypto/grumpkin/index.d.ts +4 -2
  85. package/dest/crypto/grumpkin/index.d.ts.map +1 -1
  86. package/dest/crypto/grumpkin/index.js +7 -16
  87. package/dest/crypto/keccak/index.d.ts +1 -1
  88. package/dest/crypto/keys/index.d.ts +2 -2
  89. package/dest/crypto/keys/index.d.ts.map +1 -1
  90. package/dest/crypto/keys/index.js +2 -4
  91. package/dest/crypto/pedersen/index.d.ts +1 -1
  92. package/dest/crypto/pedersen/pedersen.noble.d.ts +1 -1
  93. package/dest/crypto/pedersen/pedersen.wasm.d.ts +2 -2
  94. package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -1
  95. package/dest/crypto/pedersen/pedersen.wasm.js +4 -10
  96. package/dest/crypto/poseidon/index.d.ts +2 -3
  97. package/dest/crypto/poseidon/index.d.ts.map +1 -1
  98. package/dest/crypto/poseidon/index.js +14 -33
  99. package/dest/crypto/random/index.d.ts +1 -1
  100. package/dest/crypto/random/index.d.ts.map +1 -1
  101. package/dest/crypto/random/randomness_singleton.d.ts +4 -3
  102. package/dest/crypto/random/randomness_singleton.d.ts.map +1 -1
  103. package/dest/crypto/random/randomness_singleton.js +5 -5
  104. package/dest/crypto/schnorr/index.d.ts +3 -2
  105. package/dest/crypto/schnorr/index.d.ts.map +1 -1
  106. package/dest/crypto/schnorr/index.js +4 -10
  107. package/dest/crypto/schnorr/signature.d.ts +2 -2
  108. package/dest/crypto/schnorr/signature.d.ts.map +1 -1
  109. package/dest/crypto/schnorr/signature.js +2 -2
  110. package/dest/crypto/secp256k1/index.d.ts +1 -1
  111. package/dest/crypto/secp256k1/index.d.ts.map +1 -1
  112. package/dest/crypto/secp256k1/index.js +3 -9
  113. package/dest/crypto/secp256k1-signer/index.d.ts +1 -1
  114. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts +1 -1
  115. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts.map +1 -1
  116. package/dest/crypto/secp256k1-signer/utils.d.ts +1 -1
  117. package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -1
  118. package/dest/crypto/serialize.d.ts +1 -1
  119. package/dest/crypto/sha256/index.d.ts +2 -2
  120. package/dest/crypto/sha256/index.d.ts.map +1 -1
  121. package/dest/crypto/sha256/index.js +1 -1
  122. package/dest/crypto/sha512/index.d.ts +3 -3
  123. package/dest/crypto/sha512/index.d.ts.map +1 -1
  124. package/dest/crypto/sha512/index.js +1 -1
  125. package/dest/crypto/signature/index.d.ts +2 -2
  126. package/dest/crypto/signature/index.d.ts.map +1 -1
  127. package/dest/crypto/sync/index.d.ts +1 -1
  128. package/dest/crypto/sync/index.js +1 -3
  129. package/dest/crypto/sync/pedersen/index.d.ts +2 -2
  130. package/dest/crypto/sync/pedersen/index.d.ts.map +1 -1
  131. package/dest/crypto/sync/pedersen/index.js +1 -1
  132. package/dest/crypto/sync/poseidon/index.d.ts +2 -3
  133. package/dest/crypto/sync/poseidon/index.d.ts.map +1 -1
  134. package/dest/crypto/sync/poseidon/index.js +1 -9
  135. package/dest/{fields/bls12_fields.d.ts → curves/bls12/field.d.ts} +3 -3
  136. package/dest/curves/bls12/field.d.ts.map +1 -0
  137. package/dest/{fields/bls12_fields.js → curves/bls12/field.js} +12 -9
  138. package/dest/curves/bls12/index.d.ts +3 -0
  139. package/dest/curves/bls12/index.d.ts.map +1 -0
  140. package/dest/curves/bls12/index.js +2 -0
  141. package/dest/{fields/bls12_point.d.ts → curves/bls12/point.d.ts} +4 -4
  142. package/dest/curves/bls12/point.d.ts.map +1 -0
  143. package/dest/{fields/bls12_point.js → curves/bls12/point.js} +10 -8
  144. package/dest/curves/bn254/field.d.ts +181 -0
  145. package/dest/curves/bn254/field.d.ts.map +1 -0
  146. package/dest/{fields/fields.js → curves/bn254/field.js} +52 -49
  147. package/dest/curves/bn254/index.d.ts +3 -0
  148. package/dest/curves/bn254/index.d.ts.map +1 -0
  149. package/dest/curves/bn254/index.js +2 -0
  150. package/dest/curves/bn254/point.d.ts +54 -0
  151. package/dest/curves/bn254/point.d.ts.map +1 -0
  152. package/dest/curves/bn254/point.js +143 -0
  153. package/dest/curves/grumpkin/index.d.ts +10 -0
  154. package/dest/curves/grumpkin/index.d.ts.map +1 -0
  155. package/dest/curves/grumpkin/index.js +3 -0
  156. package/dest/{fields → curves/grumpkin}/point.d.ts +12 -3
  157. package/dest/curves/grumpkin/point.d.ts.map +1 -0
  158. package/dest/{fields → curves/grumpkin}/point.js +24 -7
  159. package/dest/decorators/index.d.ts +1 -1
  160. package/dest/decorators/memoize.d.ts +1 -1
  161. package/dest/decorators/memoize.d.ts.map +1 -1
  162. package/dest/error/index.d.ts +1 -1
  163. package/dest/eth-address/index.d.ts +12 -2
  164. package/dest/eth-address/index.d.ts.map +1 -1
  165. package/dest/eth-address/index.js +27 -3
  166. package/dest/eth-signature/eth_signature.d.ts +1 -1
  167. package/dest/eth-signature/eth_signature.d.ts.map +1 -1
  168. package/dest/eth-signature/index.d.ts +1 -1
  169. package/dest/fs/index.d.ts +1 -1
  170. package/dest/fs/run_in_dir.d.ts +1 -1
  171. package/dest/fs/try_rm_dir.d.ts +1 -1
  172. package/dest/iterable/all.d.ts +1 -1
  173. package/dest/iterable/filter.d.ts +1 -1
  174. package/dest/iterable/index.d.ts +1 -1
  175. package/dest/iterable/isAsyncIt.d.ts +1 -1
  176. package/dest/iterable/map.d.ts +1 -1
  177. package/dest/iterable/peek.d.ts +1 -1
  178. package/dest/iterable/sort.d.ts +1 -1
  179. package/dest/iterable/take.d.ts +1 -1
  180. package/dest/iterable/toArray.d.ts +1 -1
  181. package/dest/iterator/filter.d.ts +3 -0
  182. package/dest/iterator/filter.d.ts.map +1 -0
  183. package/dest/iterator/filter.js +7 -0
  184. package/dest/iterator/index.d.ts +2 -0
  185. package/dest/iterator/index.d.ts.map +1 -0
  186. package/dest/iterator/index.js +1 -0
  187. package/dest/jest/setup.js +28 -1
  188. package/dest/json-rpc/client/fetch.d.ts +1 -1
  189. package/dest/json-rpc/client/index.d.ts +1 -1
  190. package/dest/json-rpc/client/safe_json_rpc_client.d.ts +2 -1
  191. package/dest/json-rpc/client/safe_json_rpc_client.d.ts.map +1 -1
  192. package/dest/json-rpc/client/safe_json_rpc_client.js +1 -1
  193. package/dest/json-rpc/client/undici.d.ts +1 -1
  194. package/dest/json-rpc/client/undici.d.ts.map +1 -1
  195. package/dest/json-rpc/client/undici.js +21 -4
  196. package/dest/json-rpc/convert.d.ts +1 -1
  197. package/dest/json-rpc/errors.d.ts +1 -1
  198. package/dest/json-rpc/errors.d.ts.map +1 -1
  199. package/dest/json-rpc/fixtures/class_a.d.ts +1 -1
  200. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -1
  201. package/dest/json-rpc/fixtures/class_b.d.ts +1 -1
  202. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -1
  203. package/dest/json-rpc/fixtures/test_state.d.ts +1 -1
  204. package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -1
  205. package/dest/json-rpc/index.d.ts +1 -1
  206. package/dest/json-rpc/js_utils.d.ts +1 -1
  207. package/dest/json-rpc/js_utils.d.ts.map +1 -1
  208. package/dest/json-rpc/server/api_key_auth.d.ts +19 -0
  209. package/dest/json-rpc/server/api_key_auth.d.ts.map +1 -0
  210. package/dest/json-rpc/server/api_key_auth.js +57 -0
  211. package/dest/json-rpc/server/index.d.ts +2 -1
  212. package/dest/json-rpc/server/index.d.ts.map +1 -1
  213. package/dest/json-rpc/server/index.js +1 -0
  214. package/dest/json-rpc/server/safe_json_rpc_server.d.ts +1 -1
  215. package/dest/json-rpc/server/safe_json_rpc_server.d.ts.map +1 -1
  216. package/dest/json-rpc/server/safe_json_rpc_server.js +1 -1
  217. package/dest/json-rpc/test/index.d.ts +1 -1
  218. package/dest/json-rpc/test/integration.d.ts +1 -1
  219. package/dest/log/bigint-utils.d.ts +5 -0
  220. package/dest/log/bigint-utils.d.ts.map +1 -0
  221. package/dest/log/bigint-utils.js +18 -0
  222. package/dest/log/console.d.ts +1 -1
  223. package/dest/log/gcloud-logger-config.d.ts +1 -1
  224. package/dest/log/gcloud-logger-config.d.ts.map +1 -1
  225. package/dest/log/gcloud-logger-config.js +3 -0
  226. package/dest/log/index.d.ts +1 -1
  227. package/dest/log/libp2p_logger.d.ts +5 -2
  228. package/dest/log/libp2p_logger.d.ts.map +1 -1
  229. package/dest/log/libp2p_logger.js +14 -4
  230. package/dest/log/log-filters.d.ts +17 -4
  231. package/dest/log/log-filters.d.ts.map +1 -1
  232. package/dest/log/log-filters.js +26 -12
  233. package/dest/log/log-levels.d.ts +1 -1
  234. package/dest/log/log_fn.d.ts +1 -1
  235. package/dest/log/noir_debug_log_util.d.ts +1 -1
  236. package/dest/log/pino-logger-server.d.ts +9 -0
  237. package/dest/log/pino-logger-server.d.ts.map +1 -0
  238. package/dest/log/pino-logger-server.js +18 -0
  239. package/dest/log/pino-logger.d.ts +38 -9
  240. package/dest/log/pino-logger.d.ts.map +1 -1
  241. package/dest/log/pino-logger.js +122 -29
  242. package/dest/message/index.d.ts +1 -1
  243. package/dest/message/index.d.ts.map +1 -1
  244. package/dest/mutex/index.d.ts +1 -1
  245. package/dest/mutex/index.d.ts.map +1 -1
  246. package/dest/mutex/mutex_database.d.ts +1 -1
  247. package/dest/noir/index.d.ts +1 -1
  248. package/dest/noir/noir_package_config.d.ts +9 -9
  249. package/dest/number/index.d.ts +1 -1
  250. package/dest/profiler/index.d.ts +1 -1
  251. package/dest/profiler/profiler.d.ts +1 -1
  252. package/dest/promise/index.d.ts +1 -1
  253. package/dest/promise/running-promise.d.ts +1 -1
  254. package/dest/promise/running-promise.d.ts.map +1 -1
  255. package/dest/promise/utils.d.ts +1 -1
  256. package/dest/queue/base_memory_queue.d.ts +2 -2
  257. package/dest/queue/base_memory_queue.d.ts.map +1 -1
  258. package/dest/queue/batch_queue.d.ts +1 -1
  259. package/dest/queue/batch_queue.d.ts.map +1 -1
  260. package/dest/queue/bounded_serial_queue.d.ts +1 -1
  261. package/dest/queue/bounded_serial_queue.d.ts.map +1 -1
  262. package/dest/queue/fifo_memory_queue.d.ts +1 -1
  263. package/dest/queue/fifo_memory_queue.d.ts.map +1 -1
  264. package/dest/queue/index.d.ts +1 -1
  265. package/dest/queue/priority_memory_queue.d.ts +1 -1
  266. package/dest/queue/priority_memory_queue.d.ts.map +1 -1
  267. package/dest/queue/priority_queue.d.ts +1 -1
  268. package/dest/queue/priority_queue.d.ts.map +1 -1
  269. package/dest/queue/semaphore.d.ts +5 -1
  270. package/dest/queue/semaphore.d.ts.map +1 -1
  271. package/dest/queue/serial_queue.d.ts +1 -1
  272. package/dest/queue/serial_queue.d.ts.map +1 -1
  273. package/dest/retry/index.d.ts +11 -1
  274. package/dest/retry/index.d.ts.map +1 -1
  275. package/dest/retry/index.js +11 -0
  276. package/dest/running-promise/index.d.ts +1 -1
  277. package/dest/schemas/api.d.ts +1 -1
  278. package/dest/schemas/index.d.ts +1 -1
  279. package/dest/schemas/parse.d.ts +1 -1
  280. package/dest/schemas/schemas.d.ts +15 -17
  281. package/dest/schemas/schemas.d.ts.map +1 -1
  282. package/dest/schemas/schemas.js +14 -10
  283. package/dest/schemas/types.d.ts +31 -1
  284. package/dest/schemas/types.d.ts.map +1 -1
  285. package/dest/schemas/types.js +25 -1
  286. package/dest/schemas/utils.d.ts +4 -4
  287. package/dest/schemas/utils.d.ts.map +1 -1
  288. package/dest/schemas/utils.js +15 -5
  289. package/dest/serialize/buffer_reader.d.ts +14 -4
  290. package/dest/serialize/buffer_reader.d.ts.map +1 -1
  291. package/dest/serialize/buffer_reader.js +26 -4
  292. package/dest/serialize/field_reader.d.ts +2 -2
  293. package/dest/serialize/field_reader.d.ts.map +1 -1
  294. package/dest/serialize/field_reader.js +1 -1
  295. package/dest/serialize/free_funcs.d.ts +2 -2
  296. package/dest/serialize/free_funcs.d.ts.map +1 -1
  297. package/dest/serialize/free_funcs.js +1 -1
  298. package/dest/serialize/index.d.ts +1 -1
  299. package/dest/serialize/serialize.d.ts +20 -2
  300. package/dest/serialize/serialize.d.ts.map +1 -1
  301. package/dest/serialize/serialize.js +32 -1
  302. package/dest/serialize/type_registry.d.ts +1 -1
  303. package/dest/serialize/type_registry.d.ts.map +1 -1
  304. package/dest/serialize/types.d.ts +1 -1
  305. package/dest/sleep/index.d.ts +4 -1
  306. package/dest/sleep/index.d.ts.map +1 -1
  307. package/dest/sleep/index.js +14 -1
  308. package/dest/string/index.d.ts +1 -1
  309. package/dest/testing/files/index.d.ts +2 -1
  310. package/dest/testing/files/index.d.ts.map +1 -1
  311. package/dest/testing/files/index.js +1 -1
  312. package/dest/testing/formatting.d.ts +1 -1
  313. package/dest/testing/index.d.ts +1 -1
  314. package/dest/testing/port_allocator.d.ts +1 -1
  315. package/dest/testing/snapshot_serializer.d.ts +1 -1
  316. package/dest/testing/test_data.d.ts +1 -1
  317. package/dest/timer/date.d.ts +26 -1
  318. package/dest/timer/date.d.ts.map +1 -1
  319. package/dest/timer/date.js +36 -0
  320. package/dest/timer/elapsed.d.ts +1 -1
  321. package/dest/timer/index.d.ts +1 -1
  322. package/dest/timer/timeout.d.ts +1 -1
  323. package/dest/timer/timeout.d.ts.map +1 -1
  324. package/dest/timer/timer.d.ts +1 -1
  325. package/dest/timer/timer.d.ts.map +1 -1
  326. package/dest/transport/dispatch/create_dispatch_fn.d.ts +1 -1
  327. package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -1
  328. package/dest/transport/dispatch/create_dispatch_proxy.d.ts +1 -1
  329. package/dest/transport/dispatch/messages.d.ts +1 -1
  330. package/dest/transport/index.d.ts +1 -1
  331. package/dest/transport/interface/connector.d.ts +1 -1
  332. package/dest/transport/interface/listener.d.ts +1 -1
  333. package/dest/transport/interface/socket.d.ts +1 -1
  334. package/dest/transport/interface/transferable.d.ts +1 -1
  335. package/dest/transport/node/index.d.ts +1 -1
  336. package/dest/transport/node/node_connector.d.ts +1 -1
  337. package/dest/transport/node/node_connector.d.ts.map +1 -1
  338. package/dest/transport/node/node_connector_socket.d.ts +1 -1
  339. package/dest/transport/node/node_connector_socket.d.ts.map +1 -1
  340. package/dest/transport/node/node_listener.d.ts +1 -1
  341. package/dest/transport/node/node_listener.d.ts.map +1 -1
  342. package/dest/transport/node/node_listener_socket.d.ts +1 -1
  343. package/dest/transport/node/node_listener_socket.d.ts.map +1 -1
  344. package/dest/transport/transport_client.d.ts +1 -1
  345. package/dest/transport/transport_client.d.ts.map +1 -1
  346. package/dest/transport/transport_client.js +2 -2
  347. package/dest/transport/transport_server.d.ts +1 -10
  348. package/dest/transport/transport_server.d.ts.map +1 -1
  349. package/dest/trees/balanced_merkle_tree_root.d.ts +17 -0
  350. package/dest/trees/balanced_merkle_tree_root.d.ts.map +1 -0
  351. package/dest/trees/balanced_merkle_tree_root.js +51 -0
  352. package/dest/trees/hasher.d.ts +3 -1
  353. package/dest/trees/hasher.d.ts.map +1 -1
  354. package/dest/trees/hasher.js +10 -5
  355. package/dest/trees/index.d.ts +4 -3
  356. package/dest/trees/index.d.ts.map +1 -1
  357. package/dest/trees/index.js +3 -2
  358. package/dest/trees/indexed_merkle_tree.d.ts +1 -1
  359. package/dest/trees/indexed_merkle_tree.d.ts.map +1 -1
  360. package/dest/trees/indexed_merkle_tree.js +1 -1
  361. package/dest/trees/indexed_merkle_tree_calculator.d.ts +1 -1
  362. package/dest/trees/indexed_merkle_tree_calculator.d.ts.map +1 -1
  363. package/dest/trees/indexed_tree_leaf.d.ts +1 -1
  364. package/dest/trees/membership_witness.d.ts +7 -18
  365. package/dest/trees/membership_witness.d.ts.map +1 -1
  366. package/dest/trees/membership_witness.js +10 -1
  367. package/dest/trees/merkle_tree.d.ts +1 -1
  368. package/dest/trees/merkle_tree.d.ts.map +1 -1
  369. package/dest/trees/merkle_tree_calculator.d.ts +2 -12
  370. package/dest/trees/merkle_tree_calculator.d.ts.map +1 -1
  371. package/dest/trees/merkle_tree_calculator.js +2 -32
  372. package/dest/trees/sibling_path.d.ts +5 -38
  373. package/dest/trees/sibling_path.d.ts.map +1 -1
  374. package/dest/trees/sibling_path.js +3 -3
  375. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts +6 -6
  376. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts.map +1 -1
  377. package/dest/trees/unbalanced_merkle_tree_calculator.js +34 -42
  378. package/dest/trees/unbalanced_merkle_tree_root.d.ts +28 -0
  379. package/dest/trees/unbalanced_merkle_tree_root.d.ts.map +1 -0
  380. package/dest/trees/unbalanced_merkle_tree_root.js +84 -0
  381. package/dest/trees/unbalanced_tree_store.d.ts +5 -1
  382. package/dest/trees/unbalanced_tree_store.d.ts.map +1 -1
  383. package/dest/trees/unbalanced_tree_store.js +49 -1
  384. package/dest/types/index.d.ts +6 -2
  385. package/dest/types/index.d.ts.map +1 -1
  386. package/dest/types/index.js +6 -0
  387. package/dest/url/index.d.ts +1 -1
  388. package/dest/validation/index.d.ts +1 -1
  389. package/package.json +50 -9
  390. package/src/array/array.ts +0 -16
  391. package/src/array/index.ts +1 -0
  392. package/src/array/sorted_array.ts +138 -0
  393. package/src/branded-types/block_number.ts +117 -0
  394. package/src/branded-types/checkpoint_number.ts +115 -0
  395. package/src/branded-types/epoch.ts +88 -0
  396. package/src/branded-types/index.ts +7 -0
  397. package/src/branded-types/index_within_checkpoint.ts +88 -0
  398. package/src/branded-types/slot.ts +88 -0
  399. package/src/branded-types/types.ts +2 -0
  400. package/src/buffer/buffer16.ts +2 -2
  401. package/src/buffer/buffer32.ts +2 -2
  402. package/src/collection/array.ts +52 -0
  403. package/src/config/env_var.ts +82 -15
  404. package/src/config/index.ts +39 -6
  405. package/src/config/network_config.ts +2 -0
  406. package/src/config/network_name.ts +4 -1
  407. package/src/config/parse-env.ts +4 -0
  408. package/src/crypto/aes128/index.ts +2 -2
  409. package/src/crypto/bls/bn254_keystore.ts +1 -1
  410. package/src/crypto/bls/index.ts +1 -1
  411. package/src/crypto/bn254/index.ts +50 -156
  412. package/src/crypto/ecdsa/index.ts +4 -4
  413. package/src/crypto/ecdsa/signature.ts +2 -2
  414. package/src/crypto/grumpkin/index.ts +8 -6
  415. package/src/crypto/keys/index.ts +2 -2
  416. package/src/crypto/pedersen/pedersen.wasm.ts +4 -4
  417. package/src/crypto/poseidon/index.ts +14 -24
  418. package/src/crypto/random/randomness_singleton.ts +6 -4
  419. package/src/crypto/schnorr/index.ts +5 -4
  420. package/src/crypto/schnorr/signature.ts +2 -2
  421. package/src/crypto/secp256k1/index.ts +3 -3
  422. package/src/crypto/sha256/index.ts +1 -1
  423. package/src/crypto/sha512/index.ts +1 -1
  424. package/src/crypto/signature/index.ts +1 -1
  425. package/src/crypto/sync/index.ts +1 -1
  426. package/src/crypto/sync/pedersen/index.ts +1 -1
  427. package/src/crypto/sync/poseidon/index.ts +1 -10
  428. package/src/{fields/bls12_fields.ts → curves/bls12/field.ts} +6 -6
  429. package/src/curves/bls12/index.ts +2 -0
  430. package/src/{fields/bls12_point.ts → curves/bls12/point.ts} +7 -7
  431. package/src/{fields/fields.ts → curves/bn254/field.ts} +53 -56
  432. package/src/curves/bn254/index.ts +2 -0
  433. package/src/curves/bn254/point.ts +170 -0
  434. package/src/curves/grumpkin/index.ts +11 -0
  435. package/src/{fields → curves/grumpkin}/point.ts +26 -7
  436. package/src/eth-address/index.ts +27 -2
  437. package/src/iterator/filter.ts +11 -0
  438. package/src/iterator/index.ts +1 -0
  439. package/src/jest/setup.mjs +31 -1
  440. package/src/json-rpc/client/safe_json_rpc_client.ts +2 -0
  441. package/src/json-rpc/client/undici.ts +21 -3
  442. package/src/json-rpc/server/api_key_auth.ts +63 -0
  443. package/src/json-rpc/server/index.ts +1 -0
  444. package/src/json-rpc/server/safe_json_rpc_server.ts +1 -1
  445. package/src/log/bigint-utils.ts +22 -0
  446. package/src/log/gcloud-logger-config.ts +5 -0
  447. package/src/log/libp2p_logger.ts +12 -5
  448. package/src/log/log-filters.ts +29 -11
  449. package/src/log/pino-logger-server.ts +25 -0
  450. package/src/log/pino-logger.ts +144 -39
  451. package/src/queue/base_memory_queue.ts +1 -1
  452. package/src/queue/semaphore.ts +5 -0
  453. package/src/retry/index.ts +18 -0
  454. package/src/schemas/schemas.ts +24 -13
  455. package/src/schemas/types.ts +33 -0
  456. package/src/schemas/utils.ts +21 -8
  457. package/src/serialize/buffer_reader.ts +36 -9
  458. package/src/serialize/field_reader.ts +1 -1
  459. package/src/serialize/free_funcs.ts +1 -1
  460. package/src/serialize/serialize.ts +33 -1
  461. package/src/sleep/index.ts +16 -1
  462. package/src/testing/files/index.ts +1 -1
  463. package/src/timer/date.ts +52 -0
  464. package/src/transport/transport_client.ts +2 -2
  465. package/src/trees/balanced_merkle_tree_root.ts +68 -0
  466. package/src/trees/hasher.ts +9 -0
  467. package/src/trees/index.ts +3 -2
  468. package/src/trees/indexed_merkle_tree.ts +1 -1
  469. package/src/trees/membership_witness.ts +9 -1
  470. package/src/trees/merkle_tree_calculator.ts +2 -35
  471. package/src/trees/sibling_path.ts +3 -3
  472. package/src/trees/unbalanced_merkle_tree_calculator.ts +32 -50
  473. package/src/trees/unbalanced_merkle_tree_root.ts +115 -0
  474. package/src/trees/unbalanced_tree_store.ts +57 -2
  475. package/src/types/index.ts +11 -1
  476. package/dest/crypto/bn254/bn254_utils.d.ts +0 -39
  477. package/dest/crypto/bn254/bn254_utils.d.ts.map +0 -1
  478. package/dest/crypto/bn254/bn254_utils.js +0 -56
  479. package/dest/crypto/index.d.ts +0 -17
  480. package/dest/crypto/index.d.ts.map +0 -1
  481. package/dest/crypto/index.js +0 -16
  482. package/dest/fields/bls12_fields.d.ts.map +0 -1
  483. package/dest/fields/bls12_point.d.ts.map +0 -1
  484. package/dest/fields/coordinate.d.ts +0 -66
  485. package/dest/fields/coordinate.d.ts.map +0 -1
  486. package/dest/fields/coordinate.js +0 -96
  487. package/dest/fields/fields.d.ts +0 -179
  488. package/dest/fields/fields.d.ts.map +0 -1
  489. package/dest/fields/index.d.ts +0 -6
  490. package/dest/fields/index.d.ts.map +0 -1
  491. package/dest/fields/index.js +0 -5
  492. package/dest/fields/point.d.ts.map +0 -1
  493. package/dest/index.d.ts +0 -30
  494. package/dest/index.d.ts.map +0 -1
  495. package/dest/index.js +0 -30
  496. package/dest/json-rpc/server/telemetry.d.ts +0 -2
  497. package/dest/json-rpc/server/telemetry.d.ts.map +0 -1
  498. package/dest/json-rpc/server/telemetry.js +0 -0
  499. package/dest/trees/unbalanced_merkle_tree.d.ts +0 -28
  500. package/dest/trees/unbalanced_merkle_tree.d.ts.map +0 -1
  501. package/dest/trees/unbalanced_merkle_tree.js +0 -99
  502. package/src/crypto/bn254/bn254_utils.ts +0 -64
  503. package/src/crypto/index.ts +0 -16
  504. package/src/fields/coordinate.ts +0 -104
  505. package/src/fields/index.ts +0 -5
  506. package/src/index.ts +0 -30
  507. package/src/json-rpc/server/telemetry.ts +0 -0
  508. package/src/trees/unbalanced_merkle_tree.ts +0 -111
@@ -0,0 +1,84 @@
1
+ import { computeBalancedMerkleTreeRoot, computeBalancedMerkleTreeRootAsync } from './balanced_merkle_tree_root.js';
2
+ import { poseidonMerkleHash, shaMerkleHash } from './hasher.js';
3
+ import { UnbalancedMerkleTreeCalculator } from './unbalanced_merkle_tree_calculator.js';
4
+ export const computeUnbalancedShaRoot = (leaves)=>computeUnbalancedMerkleTreeRoot(leaves, shaMerkleHash);
5
+ export const computeUnbalancedPoseidonRoot = async (leaves)=>await computeUnbalancedMerkleTreeRootAsync(leaves, poseidonMerkleHash);
6
+ export const computeWonkyShaRoot = (leaves)=>computeWonkyMerkleTreeRoot(leaves);
7
+ /**
8
+ * Computes the Merkle root of an unbalanced tree.
9
+ *
10
+ * Unlike a balanced Merkle tree, which requires the number of leaves to be a power of two, an unbalanced tree can have
11
+ * any number of leaves.
12
+ *
13
+ * The tree is constructed by iteratively extracting the smallest power-of-two-sized subtrees from **right to left**.
14
+ * For each such subtree, it computes the subtree root and then combines all subtree roots (again from right to left)
15
+ * into a single root using the provided hash function.
16
+ *
17
+ * Note: We need the final tree to be as shallow as possible, to minimize the size of the sibling path required to prove
18
+ * membership of a leaf. Therefor, the computation proceeds from right to left - smaller subtrees must always be
19
+ * combined before being merged with a larger sibling on their left.
20
+ *
21
+ * For example, consider an unbalanced tree made of three subtrees of sizes 2, 4, and 8. If we combine the size-2 and
22
+ * size-4 subtrees first (producing a subtree of depth 3), and then merge it with the size-8 subtree (also depth 3), the
23
+ * resulting tree has a maximum depth of 4.
24
+ *
25
+ * But if we instead combine the size-4 and size-8 subtrees first (depth 4), and then merge with the size-2 subtree
26
+ * (depth 1), the final tree has a depth of 5.
27
+ */ export function computeUnbalancedMerkleTreeRoot(leaves, hasher = shaMerkleHash, emptyRoot = Buffer.alloc(32)) {
28
+ if (!leaves.length) {
29
+ return emptyRoot;
30
+ }
31
+ if (leaves.length === 1) {
32
+ return leaves[0];
33
+ }
34
+ let numRemainingLeaves = leaves.length;
35
+ let subtreeSize = 1;
36
+ let root;
37
+ while(numRemainingLeaves > 1){
38
+ if ((numRemainingLeaves & subtreeSize) !== 0) {
39
+ const subtreeLeaves = leaves.slice(numRemainingLeaves - subtreeSize, numRemainingLeaves);
40
+ const subtreeRoot = computeBalancedMerkleTreeRoot(subtreeLeaves, hasher);
41
+ if (!root) {
42
+ root = subtreeRoot;
43
+ } else {
44
+ root = hasher(subtreeRoot, root);
45
+ }
46
+ numRemainingLeaves -= subtreeSize;
47
+ }
48
+ subtreeSize *= 2;
49
+ }
50
+ return root;
51
+ }
52
+ export async function computeUnbalancedMerkleTreeRootAsync(leaves, hasher = poseidonMerkleHash, emptyRoot = Buffer.alloc(32)) {
53
+ if (!leaves.length) {
54
+ return emptyRoot;
55
+ }
56
+ if (leaves.length === 1) {
57
+ return leaves[0];
58
+ }
59
+ let numRemainingLeaves = leaves.length;
60
+ let subtreeSize = 1;
61
+ let root;
62
+ while(numRemainingLeaves > 1){
63
+ if ((numRemainingLeaves & subtreeSize) !== 0) {
64
+ const subtreeLeaves = leaves.slice(numRemainingLeaves - subtreeSize, numRemainingLeaves);
65
+ const subtreeRoot = await computeBalancedMerkleTreeRootAsync(subtreeLeaves, hasher);
66
+ if (!root) {
67
+ root = subtreeRoot;
68
+ } else {
69
+ root = await hasher(subtreeRoot, root);
70
+ }
71
+ numRemainingLeaves -= subtreeSize;
72
+ }
73
+ subtreeSize *= 2;
74
+ }
75
+ return root;
76
+ }
77
+ // A **wonky** tree is a "compressed" unbalanced Merkle tree.
78
+ // It is constructed in the same way as an unbalanced tree: by first creating the largest possible left subtree, with
79
+ // the remaining leaves forming a right subtree that follows the same process recursively.
80
+ // During construction, leaves equal to `valueToCompress` are skipped (compressed) and do not contribute to the tree.
81
+ export function computeWonkyMerkleTreeRoot(leaves, valueToCompress = Buffer.alloc(32), emptyRoot = Buffer.alloc(32), hasher = shaMerkleHash) {
82
+ const calculator = UnbalancedMerkleTreeCalculator.create(leaves, valueToCompress, emptyRoot, hasher);
83
+ return calculator.getRoot();
84
+ }
@@ -17,4 +17,8 @@ export declare class UnbalancedTreeStore<T> {
17
17
  getSibling(location: TreeNodeLocation): T | undefined;
18
18
  getChildren(location: TreeNodeLocation): [T | undefined, T | undefined];
19
19
  }
20
- //# sourceMappingURL=unbalanced_tree_store.d.ts.map
20
+ export declare function findLeafLevelAndIndex(numLeaves: number, leafIndex: number): {
21
+ level: number;
22
+ indexAtLevel: number;
23
+ };
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iYWxhbmNlZF90cmVlX3N0b3JlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHJlZXMvdW5iYWxhbmNlZF90cmVlX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sV0FBVyxnQkFBZ0I7SUFDL0IsS0FBSyxFQUFFLE1BQU0sQ0FBQztJQUNkLEtBQUssRUFBRSxNQUFNLENBQUM7Q0FDZjtBQU9ELHFCQUFhLG1CQUFtQixDQUFDLENBQUM7O0lBSWhDLFlBQVksU0FBUyxFQUFFLE1BQU0sRUFFNUI7SUFFRCxPQUFPLENBQUMsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsQ0FBQyxHQUFHLGdCQUFnQixDQWVyRDtJQUVELE9BQU8sQ0FBQyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxnQkFBZ0IsRUFBRSxLQUFLLEVBQUUsQ0FBQyxRQVNuRDtJQUVELGlCQUFpQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLGdCQUFnQixDQU10RTtJQUVELGtCQUFrQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLGdCQUFnQixDQU12RTtJQUVELGlCQUFpQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLENBQUMsZ0JBQWdCLEVBQUUsZ0JBQWdCLENBQUMsQ0FJMUY7SUFFRCxPQUFPLENBQUMsU0FBUyxFQUFFLE1BQU0sR0FBRyxDQUFDLEdBQUcsU0FBUyxDQU94QztJQUVELE9BQU8sQ0FBQyxRQUFRLEVBQUUsZ0JBQWdCLEdBQUcsQ0FBQyxHQUFHLFNBQVMsQ0FFakQ7SUFFRCxPQUFPLElBQUksQ0FBQyxHQUFHLFNBQVMsQ0FFdkI7SUFFRCxTQUFTLENBQUMsUUFBUSxFQUFFLGdCQUFnQixHQUFHLENBQUMsR0FBRyxTQUFTLENBR25EO0lBRUQsVUFBVSxDQUFDLFFBQVEsRUFBRSxnQkFBZ0IsR0FBRyxDQUFDLEdBQUcsU0FBUyxDQUdwRDtJQUVELFdBQVcsQ0FBQyxRQUFRLEVBQUUsZ0JBQWdCLEdBQUcsQ0FBQyxDQUFDLEdBQUcsU0FBUyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FHdEU7Q0FLRjtBQXNERCx3QkFBZ0IscUJBQXFCLENBQUMsU0FBUyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTTs7O0VBR3pFIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"unbalanced_tree_store.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_tree_store.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAOD,qBAAa,mBAAmB,CAAC,CAAC;;gBAIpB,SAAS,EAAE,MAAM;IAI7B,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,gBAAgB;IAiBtD,OAAO,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC;IAWpD,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB;IAQvE,kBAAkB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB;IAQxE,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,CAAC,gBAAgB,EAAE,gBAAgB,CAAC;IAM3F,OAAO,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,GAAG,SAAS;IASzC,OAAO,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAIlD,OAAO,IAAI,CAAC,GAAG,SAAS;IAIxB,SAAS,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAKpD,UAAU,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAKrD,WAAW,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC;CAQxE"}
1
+ {"version":3,"file":"unbalanced_tree_store.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_tree_store.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAOD,qBAAa,mBAAmB,CAAC,CAAC;;IAIhC,YAAY,SAAS,EAAE,MAAM,EAE5B;IAED,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,gBAAgB,CAerD;IAED,OAAO,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,QASnD;IAED,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB,CAMtE;IAED,kBAAkB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB,CAMvE;IAED,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,CAAC,gBAAgB,EAAE,gBAAgB,CAAC,CAI1F;IAED,OAAO,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,GAAG,SAAS,CAOxC;IAED,OAAO,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAEjD;IAED,OAAO,IAAI,CAAC,GAAG,SAAS,CAEvB;IAED,SAAS,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAGnD;IAED,UAAU,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAGpD;IAED,WAAW,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC,CAGtE;CAKF;AAsDD,wBAAgB,qBAAqB,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;;;EAGzE"}
@@ -1,4 +1,3 @@
1
- import { findLeafLevelAndIndex } from './unbalanced_merkle_tree.js';
2
1
  export class UnbalancedTreeStore {
3
2
  #nodeMapping = new Map();
4
3
  #numLeaves;
@@ -98,3 +97,52 @@ export class UnbalancedTreeStore {
98
97
  return `${location.level}-${location.index}`;
99
98
  }
100
99
  }
100
+ /// Get the depth of the maximum balanced tree that can be created with the given number of leaves. The subtree will be
101
+ /// the left most subtree of the unbalanced tree with a total of `numLeaves` leaves.
102
+ ///
103
+ /// Note: All the leaves may not be used to form the tree. For example, if there are 5 leaves, the maximum depth is 2,
104
+ /// only 4 leaves are used to form a balanced tree.
105
+ function getMaxBalancedSubtreeDepth(numLeaves) {
106
+ return Math.floor(Math.log2(numLeaves));
107
+ }
108
+ /// Get the maximum depth of an unbalanced tree that can be created with the given number of leaves.
109
+ function getMaxUnbalancedTreeDepth(numLeaves) {
110
+ return Math.ceil(Math.log2(numLeaves));
111
+ }
112
+ function findPosition(rootLevel, leafLevel, numLeaves, indexOffset, targetIndex) {
113
+ if (numLeaves <= 1) {
114
+ // Single leaf.
115
+ return {
116
+ level: rootLevel,
117
+ indexAtLevel: indexOffset
118
+ };
119
+ }
120
+ // The largest balanced tree that can be created with the given number of leaves.
121
+ const maxBalancedTreeDepth = getMaxBalancedSubtreeDepth(numLeaves);
122
+ const numBalancedLeaves = 2 ** maxBalancedTreeDepth;
123
+ const numRemainingLeaves = numLeaves - numBalancedLeaves;
124
+ if (targetIndex < numBalancedLeaves) {
125
+ // Target is in the balanced tree.
126
+ // - If numRemainingLeaves is 0: this balanced tree is grown from the current root.
127
+ // - If numRemainingLeaves is not 0: the remaining leaves will form another tree, which will become the right child of the root.
128
+ // And the balanced tree will be the left child of the root.
129
+ // There will be an extra level between the root of the balanced tree and the current root.
130
+ const extraLevel = numRemainingLeaves ? 1 : 0;
131
+ return {
132
+ level: rootLevel + maxBalancedTreeDepth + extraLevel,
133
+ indexAtLevel: indexOffset + targetIndex
134
+ };
135
+ } else {
136
+ // Target is in the right branch.
137
+ const rightBranchMaxLevel = getMaxUnbalancedTreeDepth(numRemainingLeaves);
138
+ const shiftedUp = leafLevel - rootLevel - rightBranchMaxLevel - 1;
139
+ const nextLeafLevel = leafLevel - shiftedUp;
140
+ const newIndexOffset = indexOffset + numBalancedLeaves >> shiftedUp;
141
+ const shiftedTargetIndex = targetIndex - numBalancedLeaves;
142
+ return findPosition(rootLevel + 1, nextLeafLevel, numRemainingLeaves, newIndexOffset, shiftedTargetIndex);
143
+ }
144
+ }
145
+ export function findLeafLevelAndIndex(numLeaves, leafIndex) {
146
+ const maxLevel = getMaxUnbalancedTreeDepth(numLeaves);
147
+ return findPosition(0, maxLevel, numLeaves, 0, leafIndex);
148
+ }
@@ -14,6 +14,10 @@ export type Writeable<T> = {
14
14
  };
15
15
  /** Removes readonly modifiers for an object. */
16
16
  export declare function unfreeze<T>(obj: T): Writeable<T>;
17
+ /** Is defined type guard */
18
+ export declare function isDefined<T>(value: T | undefined): value is T;
19
+ /** Type guard for error classes */
20
+ export declare function isErrorClass<T extends Error>(value: unknown, errorClass: new (...args: any[]) => T): value is T;
17
21
  /** Resolves a record-like type. Lifted from viem. */
18
22
  export type Prettify<T> = {
19
23
  [K in keyof T]: T[K];
@@ -22,7 +26,7 @@ export type Prettify<T> = {
22
26
  * Type-safe Event Emitter type
23
27
  * @example
24
28
  * export type ArchiverEmitter = TypedEventEmitter<{
25
- * [L2BlockSourceEvents.L2PruneDetected]: (args: L2BlockSourceEvent) => void;
29
+ * [L2BlockSourceEvents.L2PruneUnproven]: (args: L2BlockSourceEvent) => void;
26
30
  * [L2BlockSourceEvents.L2BlockProven]: (args: L2BlockSourceEvent) => void;
27
31
  * }>;
28
32
  * class Archiver extends (EventEmitter as new () => ArchiverEmitter) {
@@ -39,4 +43,4 @@ export interface TypedEventEmitter<TEventMap extends {
39
43
  removeListener<K extends keyof TEventMap>(event: K, listener: TEventMap[K]): this;
40
44
  removeAllListeners<K extends keyof TEventMap>(event: K): this;
41
45
  }
42
- //# sourceMappingURL=index.d.ts.map
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxnQ0FBZ0M7QUFDaEMsTUFBTSxNQUFNLFFBQVEsQ0FBQyxDQUFDLElBQUk7S0FDdkIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxRQUFRLEdBQUcsS0FBSyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQzFELENBQUM7QUFFRixrQ0FBa0M7QUFDbEMsTUFBTSxNQUFNLFdBQVcsQ0FBQyxDQUFDLElBQUk7S0FDMUIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxRQUFRLEdBQUcsQ0FBQyxHQUFHLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQzFELENBQUM7QUFFRix1REFBdUQ7QUFDdkQsTUFBTSxNQUFNLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxTQUFTLE1BQU0sQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUUvRSw2Q0FBNkM7QUFDN0MsTUFBTSxNQUFNLFNBQVMsQ0FBQyxDQUFDLElBQUk7SUFBRSxDQUFDLFVBQVUsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FBRSxDQUFDO0FBRTlELGdEQUFnRDtBQUNoRCx3QkFBZ0IsUUFBUSxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FFaEQ7QUFFRCw0QkFBNEI7QUFDNUIsd0JBQWdCLFNBQVMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsR0FBRyxTQUFTLEdBQUcsS0FBSyxJQUFJLENBQUMsQ0FFN0Q7QUFFRCxtQ0FBbUM7QUFDbkMsd0JBQWdCLFlBQVksQ0FBQyxDQUFDLFNBQVMsS0FBSyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLEtBQUssR0FBRyxJQUFJLEVBQUUsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHLEtBQUssSUFBSSxDQUFDLENBRS9HO0FBRUQscURBQXFEO0FBQ3JELE1BQU0sTUFBTSxRQUFRLENBQUMsQ0FBQyxJQUFJO0tBQ3ZCLENBQUMsSUFBSSxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQ3JCLEdBQUcsRUFBRSxDQUFDO0FBRVA7Ozs7Ozs7Ozs7R0FVRztBQUNILE1BQU0sV0FBVyxpQkFBaUIsQ0FBQyxTQUFTLFNBQVM7S0FBRyxHQUFHLElBQUksTUFBTSxTQUFTLEdBQUcsQ0FBQyxHQUFHLElBQUksRUFBRSxHQUFHLEVBQUUsS0FBSyxJQUFJO0NBQUU7SUFDekcsSUFBSSxDQUFDLENBQUMsU0FBUyxNQUFNLFNBQVMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0lBQ3hFLEVBQUUsQ0FBQyxDQUFDLFNBQVMsTUFBTSxTQUFTLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxRQUFRLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUN0RSxHQUFHLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDdkUsSUFBSSxDQUFDLENBQUMsU0FBUyxNQUFNLFNBQVMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLEdBQUcsSUFBSSxFQUFFLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUM7SUFDdEYsY0FBYyxDQUFDLENBQUMsU0FBUyxNQUFNLFNBQVMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0lBQ2xGLGtCQUFrQixDQUFDLENBQUMsU0FBUyxNQUFNLFNBQVMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQztDQUUvRCJ9
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,gCAAgC;AAChC,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;KACvB,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,QAAQ,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1D,CAAC;AAEF,kCAAkC;AAClC,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI;KAC1B,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,QAAQ,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1D,CAAC;AAEF,uDAAuD;AACvD,MAAM,MAAM,SAAS,CAAC,CAAC,EAAE,CAAC,SAAS,MAAM,CAAC,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAE/E,6CAA6C;AAC7C,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI;IAAE,CAAC,UAAU,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAE,CAAC;AAE9D,gDAAgD;AAChD,wBAAgB,QAAQ,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAEhD;AAED,qDAAqD;AACrD,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;KACvB,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CACrB,GAAG,EAAE,CAAC;AAEP;;;;;;;;;;GAUG;AACH,MAAM,WAAW,iBAAiB,CAAC,SAAS,SAAS;KAAG,GAAG,IAAI,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI;CAAE;IACzG,IAAI,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACxE,EAAE,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACtE,GAAG,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACvE,IAAI,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;IACtF,cAAc,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAClF,kBAAkB,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC;CAE/D"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,gCAAgC;AAChC,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;KACvB,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,QAAQ,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1D,CAAC;AAEF,kCAAkC;AAClC,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI;KAC1B,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,QAAQ,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1D,CAAC;AAEF,uDAAuD;AACvD,MAAM,MAAM,SAAS,CAAC,CAAC,EAAE,CAAC,SAAS,MAAM,CAAC,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAE/E,6CAA6C;AAC7C,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI;IAAE,CAAC,UAAU,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAE,CAAC;AAE9D,gDAAgD;AAChD,wBAAgB,QAAQ,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAEhD;AAED,4BAA4B;AAC5B,wBAAgB,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,SAAS,GAAG,KAAK,IAAI,CAAC,CAE7D;AAED,mCAAmC;AACnC,wBAAgB,YAAY,CAAC,CAAC,SAAS,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,CAE/G;AAED,qDAAqD;AACrD,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;KACvB,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CACrB,GAAG,EAAE,CAAC;AAEP;;;;;;;;;;GAUG;AACH,MAAM,WAAW,iBAAiB,CAAC,SAAS,SAAS;KAAG,GAAG,IAAI,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI;CAAE;IACzG,IAAI,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACxE,EAAE,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACtE,GAAG,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACvE,IAAI,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;IACtF,cAAc,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAClF,kBAAkB,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC;CAE/D"}
@@ -1,3 +1,9 @@
1
1
  /** Strips methods of a type. */ /** Removes readonly modifiers for an object. */ export function unfreeze(obj) {
2
2
  return obj;
3
3
  }
4
+ /** Is defined type guard */ export function isDefined(value) {
5
+ return value !== undefined;
6
+ }
7
+ /** Type guard for error classes */ export function isErrorClass(value, errorClass) {
8
+ return value instanceof errorClass || value instanceof Error && value.name === errorClass.name;
9
+ }
@@ -6,4 +6,4 @@
6
6
  * @api public
7
7
  */
8
8
  export declare function fileURLToPath(uri: string): string;
9
- //# sourceMappingURL=index.d.ts.map
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cmwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJBOzs7Ozs7R0FNRztBQUVILHdCQUFnQixhQUFhLENBQUMsR0FBRyxFQUFFLE1BQU0sR0FBRyxNQUFNLENBNENqRCJ9
@@ -6,4 +6,4 @@ export declare function required<T>(value: T | undefined, errMsg?: string): T;
6
6
  * @param err - Error message to throw if x isn't met.
7
7
  */
8
8
  export declare function assert(x: any, err: string): asserts x;
9
- //# sourceMappingURL=index.d.ts.map
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy92YWxpZGF0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHlFQUF5RTtBQUN6RSx3QkFBZ0IsUUFBUSxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxHQUFHLFNBQVMsRUFBRSxNQUFNLENBQUMsRUFBRSxNQUFNLEdBQUcsQ0FBQyxDQUtwRTtBQUVEOzs7O0dBSUc7QUFDSCx3QkFBZ0IsTUFBTSxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUlyRCJ9
package/package.json CHANGED
@@ -1,9 +1,29 @@
1
1
  {
2
2
  "name": "@aztec/foundation",
3
- "version": "0.0.1-commit.b655e406",
3
+ "version": "0.0.1-commit.c0b82b2",
4
4
  "type": "module",
5
5
  "main": "./dest/index.js",
6
6
  "types": "./dest/index.d.ts",
7
+ "typedocOptions": {
8
+ "entryPoints": [
9
+ "./src/buffer/index.ts",
10
+ "./src/collection/index.ts",
11
+ "./src/config/index.ts",
12
+ "./src/crypto/random/index.ts",
13
+ "./src/error/index.ts",
14
+ "./src/eth-address/index.ts",
15
+ "./src/json-rpc/index.ts",
16
+ "./src/log/index.ts",
17
+ "./src/retry/index.ts",
18
+ "./src/schemas/index.ts",
19
+ "./src/serialize/index.ts",
20
+ "./src/sleep/index.ts",
21
+ "./src/timer/index.ts",
22
+ "./src/types/index.ts"
23
+ ],
24
+ "name": "Foundation",
25
+ "tsconfig": "./tsconfig.json"
26
+ },
7
27
  "exports": {
8
28
  "./eslint": "./eslint.config.js",
9
29
  "./eslint.docs": "./eslint.config.docs.js",
@@ -12,11 +32,30 @@
12
32
  "./async-map": "./dest/async-map/index.js",
13
33
  "./async-pool": "./dest/async-pool/index.js",
14
34
  "./bigint": "./dest/bigint/index.js",
35
+ "./branded-types": "./dest/branded-types/index.js",
15
36
  "./collection": "./dest/collection/index.js",
16
37
  "./config": "./dest/config/index.js",
17
- "./crypto": "./dest/crypto/index.js",
18
- "./crypto/sync": "./dest/crypto/sync/index.js",
38
+ "./crypto/aes128": "./dest/crypto/aes128/index.js",
39
+ "./crypto/bls": "./dest/crypto/bls/index.js",
19
40
  "./crypto/bls/bn254_keystore": "./dest/crypto/bls/bn254_keystore.js",
41
+ "./crypto/bn254": "./dest/crypto/bn254/index.js",
42
+ "./crypto/ecdsa": "./dest/crypto/ecdsa/index.js",
43
+ "./crypto/grumpkin": "./dest/crypto/grumpkin/index.js",
44
+ "./crypto/keccak": "./dest/crypto/keccak/index.js",
45
+ "./crypto/keys": "./dest/crypto/keys/index.js",
46
+ "./crypto/pedersen": "./dest/crypto/pedersen/index.js",
47
+ "./crypto/poseidon": "./dest/crypto/poseidon/index.js",
48
+ "./crypto/random": "./dest/crypto/random/index.js",
49
+ "./crypto/schnorr": "./dest/crypto/schnorr/index.js",
50
+ "./crypto/secp256k1": "./dest/crypto/secp256k1/index.js",
51
+ "./crypto/secp256k1-signer": "./dest/crypto/secp256k1-signer/index.js",
52
+ "./crypto/sha256": "./dest/crypto/sha256/index.js",
53
+ "./crypto/sha512": "./dest/crypto/sha512/index.js",
54
+ "./crypto/signature": "./dest/crypto/signature/index.js",
55
+ "./crypto/sync": "./dest/crypto/sync/index.js",
56
+ "./curves/bn254": "./dest/curves/bn254/index.js",
57
+ "./curves/grumpkin": "./dest/curves/grumpkin/index.js",
58
+ "./curves/bls12": "./dest/curves/bls12/index.js",
20
59
  "./decorators": "./dest/decorators/index.js",
21
60
  "./error": "./dest/error/index.js",
22
61
  "./eth-address": "./dest/eth-address/index.js",
@@ -30,9 +69,10 @@
30
69
  "./json-rpc/undici": "./dest/json-rpc/client/undici.js",
31
70
  "./json-rpc/test": "./dest/json-rpc/test/index.js",
32
71
  "./iterable": "./dest/iterable/index.js",
72
+ "./iterator": "./dest/iterator/index.js",
33
73
  "./log": "./dest/log/index.js",
74
+ "./log/server": "./dest/log/pino-logger-server.js",
34
75
  "./mutex": "./dest/mutex/index.js",
35
- "./fields": "./dest/fields/index.js",
36
76
  "./retry": "./dest/retry/index.js",
37
77
  "./running-promise": "./dest/running-promise/index.js",
38
78
  "./serialize": "./dest/serialize/index.js",
@@ -57,8 +97,8 @@
57
97
  "./number": "./dest/number/index.js"
58
98
  },
59
99
  "scripts": {
60
- "build": "yarn clean && tsc -b",
61
- "build:dev": "tsc -b --watch",
100
+ "build": "yarn clean && ../scripts/tsc.sh",
101
+ "build:dev": "../scripts/tsc.sh --watch",
62
102
  "clean": "rm -rf ./dest .tsbuildinfo",
63
103
  "generate": "true",
64
104
  "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}"
@@ -104,7 +144,7 @@
104
144
  "testEnvironment": "../../foundation/src/jest/env.mjs"
105
145
  },
106
146
  "dependencies": {
107
- "@aztec/bb.js": "0.0.1-commit.b655e406",
147
+ "@aztec/bb.js": "0.0.1-commit.c0b82b2",
108
148
  "@koa/cors": "^5.0.0",
109
149
  "@noble/curves": "=1.7.0",
110
150
  "@noble/hashes": "^1.6.1",
@@ -143,10 +183,11 @@
143
183
  "@types/node": "^22.15.17",
144
184
  "@types/pako": "^2.0.0",
145
185
  "@types/supertest": "^2.0.12",
186
+ "@typescript/native-preview": "7.0.0-dev.20260113.1",
146
187
  "comlink": "^4.4.1",
147
188
  "eslint": "^9.26.0",
148
189
  "eslint-config-prettier": "^10.1.5",
149
- "eslint-plugin-import": "^2.31.0",
190
+ "eslint-plugin-import-x": "^4.6.1",
150
191
  "eslint-plugin-jsdoc": "^50.6.14",
151
192
  "eslint-plugin-no-only-tests": "^3.3.0",
152
193
  "eslint-plugin-tsdoc": "^0.4.0",
@@ -157,7 +198,7 @@
157
198
  "ts-node": "^10.9.1",
158
199
  "typescript": "^5.3.3",
159
200
  "typescript-eslint": "^8.32.1",
160
- "viem": "npm:@spalladino/viem@2.38.2-eip7594.0"
201
+ "viem": "npm:@aztec/viem@2.38.2"
161
202
  },
162
203
  "files": [
163
204
  "dest",
@@ -42,22 +42,6 @@ export async function makeTupleAsync<T, N extends number>(length: N, fn: (i: num
42
42
  )) as Tuple<T, N>;
43
43
  }
44
44
 
45
- /**
46
- * Create an array over an integer range, filled with a function 'fn'. However, the latter half of the array are set to zeros.
47
- * see `makeTuple` above.
48
- * @param n - The number of integers.
49
- * @param fn - The generator function.
50
- * @returns The array of numbers.
51
- */
52
- export function makeHalfFullTuple<T, N extends number>(
53
- length: N,
54
- fn: (i: number) => T,
55
- offset = 0,
56
- makeEmpty: () => T,
57
- ) {
58
- return Array.from({ length }, (_: any, i: number) => (i < length / 2 ? fn(i + offset) : makeEmpty())) as Tuple<T, N>;
59
- }
60
-
61
45
  /**
62
46
  * Assert a member of an object is a certain length.
63
47
  * @param obj - An object.
@@ -1 +1,2 @@
1
1
  export * from './array.js';
2
+ export * from './sorted_array.js';
@@ -0,0 +1,138 @@
1
+ type Cmp<T> = (a: T, b: T) => -1 | 0 | 1;
2
+
3
+ export function dedupeSortedArray<T>(arr: T[], cmp: Cmp<T>): void {
4
+ for (let i = 0; i < arr.length; i++) {
5
+ let j = i + 1;
6
+ for (; j < arr.length; j++) {
7
+ const res = cmp(arr[i], arr[j]);
8
+ if (res === 0) {
9
+ continue;
10
+ } else if (res < 0) {
11
+ break;
12
+ } else {
13
+ throw new Error('Array not sorted');
14
+ }
15
+ }
16
+
17
+ if (j - i > 1) {
18
+ arr.splice(i + 1, j - i - 1);
19
+ }
20
+ }
21
+ }
22
+
23
+ export function insertIntoSortedArray<T>(arr: T[], item: T, cmp: Cmp<T>, allowDuplicates = true): boolean {
24
+ const index = findInsertionIndexInSortedArray(arr, item, cmp);
25
+
26
+ if (!allowDuplicates) {
27
+ // Check element before insertion point (upper bound returns index after equal elements)
28
+ if (index > 0 && cmp(arr[index - 1], item) === 0) {
29
+ return false;
30
+ }
31
+ }
32
+
33
+ arr.splice(index, 0, item);
34
+ return true;
35
+ }
36
+
37
+ /**
38
+ * Finds the index where needle would be inserted to maintain sorted order.
39
+ * Returns the count of elements less than or equal to needle.
40
+ */
41
+ export function findInsertionIndexInSortedArray<T, N>(values: T[], needle: N, cmp: (a: T, b: N) => number): number {
42
+ let start = 0;
43
+ let end = values.length;
44
+
45
+ while (start < end) {
46
+ const mid = start + (((end - start) / 2) | 0);
47
+ const comparison = cmp(values[mid], needle);
48
+
49
+ if (comparison <= 0) {
50
+ start = mid + 1;
51
+ } else {
52
+ end = mid;
53
+ }
54
+ }
55
+
56
+ return start;
57
+ }
58
+
59
+ export function findIndexInSortedArray<T, N>(values: T[], needle: N, cmp: (a: T, b: N) => number): number {
60
+ let start = 0;
61
+ let end = values.length - 1;
62
+
63
+ while (start <= end) {
64
+ const mid = start + (((end - start) / 2) | 0);
65
+ const comparison = cmp(values[mid], needle);
66
+
67
+ if (comparison === 0) {
68
+ return mid;
69
+ }
70
+
71
+ if (comparison > 0) {
72
+ end = mid - 1;
73
+ } else {
74
+ start = mid + 1;
75
+ }
76
+ }
77
+
78
+ return -1;
79
+ }
80
+
81
+ export function findInSortedArray<T, N>(values: T[], needle: N, cmp: (a: T, b: N) => number): T | undefined {
82
+ const idx = findIndexInSortedArray(values, needle, cmp);
83
+ return idx > -1 ? values[idx] : undefined;
84
+ }
85
+
86
+ export function removeAnyOf<T, N>(arr: T[], vals: N[], cmp: (a: T, b: N) => -1 | 0 | 1): void {
87
+ let writeIdx = 0;
88
+ let readIdx = 0;
89
+ let valIdx = 0;
90
+
91
+ while (readIdx < arr.length && valIdx < vals.length) {
92
+ const comparison = cmp(arr[readIdx], vals[valIdx]);
93
+
94
+ if (comparison < 0) {
95
+ arr[writeIdx++] = arr[readIdx++];
96
+ } else if (comparison > 0) {
97
+ valIdx++;
98
+ } else {
99
+ readIdx++;
100
+ }
101
+ }
102
+
103
+ while (readIdx < arr.length) {
104
+ arr[writeIdx++] = arr[readIdx++];
105
+ }
106
+
107
+ arr.length = writeIdx;
108
+ }
109
+
110
+ export function removeFromSortedArray<T, N>(arr: T[], val: N, cmp: (a: T, b: N) => -1 | 0 | 1) {
111
+ const idx = findIndexInSortedArray(arr, val, cmp);
112
+ if (idx > -1) {
113
+ arr.splice(idx, 1);
114
+ }
115
+ }
116
+
117
+ export function merge<T>(arr: T[], toInsert: T[], cmp: (a: T, b: T) => -1 | 0 | 1): void {
118
+ const result = new Array<T>(arr.length + toInsert.length);
119
+ let i = 0,
120
+ j = 0,
121
+ k = 0;
122
+
123
+ while (i < arr.length && j < toInsert.length) {
124
+ result[k++] = cmp(arr[i], toInsert[j]) <= 0 ? arr[i++] : toInsert[j++];
125
+ }
126
+
127
+ while (i < arr.length) {
128
+ result[k++] = arr[i++];
129
+ }
130
+ while (j < toInsert.length) {
131
+ result[k++] = toInsert[j++];
132
+ }
133
+
134
+ for (i = 0; i < result.length; i++) {
135
+ arr[i] = result[i];
136
+ }
137
+ arr.length = result.length;
138
+ }
@@ -0,0 +1,117 @@
1
+ import { z } from 'zod';
2
+
3
+ import type { CheckpointNumber } from './checkpoint_number.js';
4
+ import type { Branded } from './types.js';
5
+
6
+ /**
7
+ * A branded type representing an Aztec (L2) block number.
8
+ * Block numbers are sequential identifiers for blocks in the Aztec rollup chain.
9
+ *
10
+ * This is a nominal type backed by a number, but TypeScript will treat it as
11
+ * incompatible with plain numbers and other branded numeric types (like EpochNumber, SlotNumber, etc.).
12
+ *
13
+ * Note: This type should ONLY be used for Aztec L2 block numbers, NOT for Ethereum L1 block numbers.
14
+ *
15
+ * @example
16
+ * ```ts
17
+ * const blockNumber = BlockNumber(100);
18
+ * const plainNumber: number = blockNumber; // OK - BlockNumber is assignable to number
19
+ * const blockFromNumber: BlockNumber = 100; // ERROR - number is not assignable to BlockNumber
20
+ * ```
21
+ */
22
+ export type BlockNumber = Branded<number, 'BlockNumber'>;
23
+
24
+ /**
25
+ * Creates a BlockNumber from a number.
26
+ * @param value - The block number (must be a non-negative integer)
27
+ * @returns The branded BlockNumber value
28
+ * @throws If the value is negative or not an integer
29
+ */
30
+ export function BlockNumber(value: number): BlockNumber {
31
+ if (!Number.isInteger(value)) {
32
+ throw new Error(`BlockNumber must be an integer, got ${value}`);
33
+ }
34
+ if (value < 0) {
35
+ throw new Error(`BlockNumber must be non-negative, got ${value}`);
36
+ }
37
+ return value as BlockNumber;
38
+ }
39
+
40
+ /**
41
+ * Creates a BlockNumber from a bigint.
42
+ * @param value - The block number as bigint (must be a non-negative integer within safe integer range)
43
+ * @returns The branded BlockNumber value
44
+ * @throws If the value is negative or exceeds Number.MAX_SAFE_INTEGER
45
+ */
46
+ BlockNumber.fromBigInt = function (value: bigint): BlockNumber {
47
+ if (value < 0n) {
48
+ throw new Error(`BlockNumber must be non-negative, got ${value}`);
49
+ }
50
+ if (value > BigInt(Number.MAX_SAFE_INTEGER)) {
51
+ throw new Error(`BlockNumber ${value} exceeds MAX_SAFE_INTEGER`);
52
+ }
53
+ return Number(value) as BlockNumber;
54
+ };
55
+
56
+ /**
57
+ * Creates a BlockNumber from a string.
58
+ * @param value - The block number as a string
59
+ * @returns The branded BlockNumber value
60
+ * @throws If the string cannot be parsed as a valid block number
61
+ */
62
+ BlockNumber.fromString = function (value: string): BlockNumber {
63
+ const parsed = parseInt(value, 10);
64
+ if (isNaN(parsed)) {
65
+ throw new Error(`Cannot parse BlockNumber from string: ${value}`);
66
+ }
67
+ return BlockNumber(parsed);
68
+ };
69
+
70
+ /**
71
+ * Converts a CheckpointNumber to a BlockNumber.
72
+ * This is used in checkpoint-based systems where checkpoint numbers align with block numbers.
73
+ * WARNING: This should only be used when you know the checkpoint number corresponds to a block number.
74
+ * @param value - The checkpoint number to convert
75
+ * @returns The corresponding BlockNumber
76
+ */
77
+ BlockNumber.fromCheckpointNumber = function (value: CheckpointNumber): BlockNumber {
78
+ return value as unknown as BlockNumber;
79
+ };
80
+
81
+ /**
82
+ * Type guard to check if a value is a valid BlockNumber.
83
+ * Note: At runtime, a BlockNumber is just a number, so this checks if the value
84
+ * is a non-negative integer.
85
+ */
86
+ BlockNumber.isValid = function (value: unknown): value is BlockNumber {
87
+ return typeof value === 'number' && Number.isInteger(value) && value >= 0;
88
+ };
89
+
90
+ /** Increments a BlockNumber by a given value. */
91
+ BlockNumber.add = function (bn: BlockNumber, increment: number): BlockNumber {
92
+ return BlockNumber(bn + increment);
93
+ };
94
+
95
+ /**
96
+ * The zero block value (genesis block).
97
+ */
98
+ BlockNumber.ZERO = BlockNumber(0);
99
+
100
+ function makeBlockNumberSchema(minValue: number) {
101
+ return z
102
+ .union([z.number(), z.bigint(), z.string()])
103
+ .pipe(z.coerce.number().int().min(minValue))
104
+ .transform(value => BlockNumber(value));
105
+ }
106
+
107
+ /**
108
+ * Zod schema for parsing and validating BlockNumber values.
109
+ * Accepts numbers, bigints, or strings and coerces them to BlockNumber.
110
+ */
111
+ export const BlockNumberSchema = makeBlockNumberSchema(0);
112
+
113
+ /**
114
+ * Zod schema for parsing and validating BlockNumber values that are strictly positive.
115
+ * Accepts numbers, bigints, or strings and coerces them to BlockNumber.
116
+ */
117
+ export const BlockNumberPositiveSchema = makeBlockNumberSchema(1);