@aztec/foundation 0.0.0-test.1 → 0.0.1-commit.023c3e5

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 (701) hide show
  1. package/dest/array/array.d.ts +6 -9
  2. package/dest/array/array.d.ts.map +1 -1
  3. package/dest/array/array.js +11 -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 +10 -0
  8. package/dest/array/sorted_array.d.ts.map +1 -0
  9. package/dest/array/sorted_array.js +106 -0
  10. package/dest/async-map/index.d.ts +1 -1
  11. package/dest/async-pool/index.d.ts +1 -1
  12. package/dest/async-pool/index.d.ts.map +1 -1
  13. package/dest/async-pool/index.js +1 -0
  14. package/dest/bigint/index.d.ts +7 -0
  15. package/dest/bigint/index.d.ts.map +1 -0
  16. package/dest/bigint/index.js +15 -0
  17. package/dest/bigint-buffer/index.d.ts +1 -3
  18. package/dest/bigint-buffer/index.d.ts.map +1 -1
  19. package/dest/branded-types/block_number.d.ts +56 -0
  20. package/dest/branded-types/block_number.d.ts.map +1 -0
  21. package/dest/branded-types/block_number.js +78 -0
  22. package/dest/branded-types/checkpoint_number.d.ts +54 -0
  23. package/dest/branded-types/checkpoint_number.d.ts.map +1 -0
  24. package/dest/branded-types/checkpoint_number.js +77 -0
  25. package/dest/branded-types/epoch.d.ts +42 -0
  26. package/dest/branded-types/epoch.d.ts.map +1 -0
  27. package/dest/branded-types/epoch.js +59 -0
  28. package/dest/branded-types/index.d.ts +7 -0
  29. package/dest/branded-types/index.d.ts.map +1 -0
  30. package/dest/branded-types/index.js +5 -0
  31. package/dest/branded-types/index_within_checkpoint.d.ts +42 -0
  32. package/dest/branded-types/index_within_checkpoint.d.ts.map +1 -0
  33. package/dest/branded-types/index_within_checkpoint.js +59 -0
  34. package/dest/branded-types/slot.d.ts +42 -0
  35. package/dest/branded-types/slot.d.ts.map +1 -0
  36. package/dest/branded-types/slot.js +59 -0
  37. package/dest/branded-types/types.d.ts +5 -0
  38. package/dest/branded-types/types.d.ts.map +1 -0
  39. package/dest/branded-types/types.js +1 -0
  40. package/dest/buffer/buffer16.d.ts +80 -0
  41. package/dest/buffer/buffer16.d.ts.map +1 -0
  42. package/dest/buffer/buffer16.js +102 -0
  43. package/dest/buffer/buffer32.d.ts +5 -9
  44. package/dest/buffer/buffer32.d.ts.map +1 -1
  45. package/dest/buffer/buffer32.js +9 -7
  46. package/dest/buffer/index.d.ts +2 -1
  47. package/dest/buffer/index.d.ts.map +1 -1
  48. package/dest/buffer/index.js +1 -0
  49. package/dest/collection/array.d.ts +28 -4
  50. package/dest/collection/array.d.ts.map +1 -1
  51. package/dest/collection/array.js +108 -3
  52. package/dest/collection/index.d.ts +1 -1
  53. package/dest/collection/object.d.ts +17 -1
  54. package/dest/collection/object.d.ts.map +1 -1
  55. package/dest/collection/object.js +25 -0
  56. package/dest/committable/committable.d.ts +1 -1
  57. package/dest/committable/committable.d.ts.map +1 -1
  58. package/dest/committable/index.d.ts +1 -1
  59. package/dest/config/env_var.d.ts +2 -2
  60. package/dest/config/env_var.d.ts.map +1 -1
  61. package/dest/config/index.d.ts +62 -4
  62. package/dest/config/index.d.ts.map +1 -1
  63. package/dest/config/index.js +143 -12
  64. package/dest/config/network_config.d.ts +54 -0
  65. package/dest/config/network_config.d.ts.map +1 -0
  66. package/dest/config/network_config.js +11 -0
  67. package/dest/config/network_name.d.ts +3 -0
  68. package/dest/config/network_name.d.ts.map +1 -0
  69. package/dest/config/network_name.js +19 -0
  70. package/dest/config/parse-env.d.ts +3 -0
  71. package/dest/config/parse-env.d.ts.map +1 -0
  72. package/dest/config/parse-env.js +7 -0
  73. package/dest/config/secret_value.d.ts +28 -0
  74. package/dest/config/secret_value.d.ts.map +1 -0
  75. package/dest/config/secret_value.js +36 -0
  76. package/dest/crypto/aes128/index.d.ts +3 -5
  77. package/dest/crypto/aes128/index.d.ts.map +1 -1
  78. package/dest/crypto/aes128/index.js +19 -6
  79. package/dest/crypto/bls/bn254_keystore.d.ts +296 -0
  80. package/dest/crypto/bls/bn254_keystore.d.ts.map +1 -0
  81. package/dest/crypto/bls/bn254_keystore.js +218 -0
  82. package/dest/crypto/bls/index.d.ts +13 -0
  83. package/dest/crypto/bls/index.d.ts.map +1 -0
  84. package/dest/crypto/bls/index.js +87 -0
  85. package/dest/crypto/bn254/index.d.ts +39 -0
  86. package/dest/crypto/bn254/index.d.ts.map +1 -0
  87. package/dest/crypto/bn254/index.js +56 -0
  88. package/dest/crypto/ecdsa/index.d.ts +3 -3
  89. package/dest/crypto/ecdsa/index.d.ts.map +1 -1
  90. package/dest/crypto/ecdsa/index.js +62 -48
  91. package/dest/crypto/ecdsa/signature.d.ts +3 -5
  92. package/dest/crypto/ecdsa/signature.d.ts.map +1 -1
  93. package/dest/crypto/ecdsa/signature.js +2 -2
  94. package/dest/crypto/grumpkin/index.d.ts +10 -15
  95. package/dest/crypto/grumpkin/index.d.ts.map +1 -1
  96. package/dest/crypto/grumpkin/index.js +61 -55
  97. package/dest/crypto/keccak/index.d.ts +3 -5
  98. package/dest/crypto/keccak/index.d.ts.map +1 -1
  99. package/dest/crypto/keys/index.d.ts +2 -4
  100. package/dest/crypto/keys/index.d.ts.map +1 -1
  101. package/dest/crypto/keys/index.js +8 -5
  102. package/dest/crypto/pedersen/index.d.ts +1 -1
  103. package/dest/crypto/pedersen/pedersen.noble.d.ts +3 -5
  104. package/dest/crypto/pedersen/pedersen.noble.d.ts.map +1 -1
  105. package/dest/crypto/pedersen/pedersen.wasm.d.ts +4 -6
  106. package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -1
  107. package/dest/crypto/pedersen/pedersen.wasm.js +24 -14
  108. package/dest/crypto/poseidon/index.d.ts +2 -5
  109. package/dest/crypto/poseidon/index.d.ts.map +1 -1
  110. package/dest/crypto/poseidon/index.js +27 -21
  111. package/dest/crypto/random/index.d.ts +2 -4
  112. package/dest/crypto/random/index.d.ts.map +1 -1
  113. package/dest/crypto/random/index.js +2 -34
  114. package/dest/crypto/random/randomness_singleton.d.ts +4 -5
  115. package/dest/crypto/random/randomness_singleton.d.ts.map +1 -1
  116. package/dest/crypto/random/randomness_singleton.js +5 -5
  117. package/dest/crypto/schnorr/index.d.ts +3 -2
  118. package/dest/crypto/schnorr/index.d.ts.map +1 -1
  119. package/dest/crypto/schnorr/index.js +30 -38
  120. package/dest/crypto/schnorr/signature.d.ts +5 -7
  121. package/dest/crypto/schnorr/signature.d.ts.map +1 -1
  122. package/dest/crypto/schnorr/signature.js +2 -2
  123. package/dest/crypto/secp256k1/index.d.ts +5 -7
  124. package/dest/crypto/secp256k1/index.d.ts.map +1 -1
  125. package/dest/crypto/secp256k1/index.js +23 -18
  126. package/dest/crypto/secp256k1-signer/index.d.ts +1 -1
  127. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts +1 -1
  128. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts.map +1 -1
  129. package/dest/crypto/secp256k1-signer/utils.d.ts +56 -5
  130. package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -1
  131. package/dest/crypto/secp256k1-signer/utils.js +92 -6
  132. package/dest/crypto/serialize.d.ts +5 -7
  133. package/dest/crypto/serialize.d.ts.map +1 -1
  134. package/dest/crypto/sha256/index.d.ts +23 -6
  135. package/dest/crypto/sha256/index.d.ts.map +1 -1
  136. package/dest/crypto/sha256/index.js +43 -1
  137. package/dest/crypto/sha512/index.d.ts +3 -5
  138. package/dest/crypto/sha512/index.d.ts.map +1 -1
  139. package/dest/crypto/sha512/index.js +1 -1
  140. package/dest/crypto/signature/index.d.ts +2 -4
  141. package/dest/crypto/signature/index.d.ts.map +1 -1
  142. package/dest/crypto/sync/index.d.ts +1 -1
  143. package/dest/crypto/sync/index.js +1 -1
  144. package/dest/crypto/sync/pedersen/index.d.ts +4 -6
  145. package/dest/crypto/sync/pedersen/index.d.ts.map +1 -1
  146. package/dest/crypto/sync/pedersen/index.js +18 -11
  147. package/dest/crypto/sync/poseidon/index.d.ts +2 -5
  148. package/dest/crypto/sync/poseidon/index.d.ts.map +1 -1
  149. package/dest/crypto/sync/poseidon/index.js +23 -16
  150. package/dest/curves/bls12/field.d.ts +148 -0
  151. package/dest/curves/bls12/field.d.ts.map +1 -0
  152. package/dest/curves/bls12/field.js +362 -0
  153. package/dest/curves/bls12/index.d.ts +3 -0
  154. package/dest/curves/bls12/index.d.ts.map +1 -0
  155. package/dest/curves/bls12/index.js +2 -0
  156. package/dest/curves/bls12/point.d.ts +229 -0
  157. package/dest/curves/bls12/point.d.ts.map +1 -0
  158. package/dest/curves/bls12/point.js +400 -0
  159. package/dest/curves/bn254/field.d.ts +180 -0
  160. package/dest/curves/bn254/field.d.ts.map +1 -0
  161. package/dest/{fields/fields.js → curves/bn254/field.js} +90 -62
  162. package/dest/curves/bn254/index.d.ts +3 -0
  163. package/dest/curves/bn254/index.d.ts.map +1 -0
  164. package/dest/curves/bn254/index.js +2 -0
  165. package/dest/curves/bn254/point.d.ts +54 -0
  166. package/dest/curves/bn254/point.d.ts.map +1 -0
  167. package/dest/curves/bn254/point.js +143 -0
  168. package/dest/curves/grumpkin/index.d.ts +10 -0
  169. package/dest/curves/grumpkin/index.d.ts.map +1 -0
  170. package/dest/curves/grumpkin/index.js +3 -0
  171. package/dest/{fields → curves/grumpkin}/point.d.ts +14 -7
  172. package/dest/curves/grumpkin/point.d.ts.map +1 -0
  173. package/dest/{fields → curves/grumpkin}/point.js +27 -10
  174. package/dest/decorators/index.d.ts +1 -1
  175. package/dest/decorators/memoize.d.ts +1 -1
  176. package/dest/decorators/memoize.d.ts.map +1 -1
  177. package/dest/error/index.d.ts +1 -1
  178. package/dest/eth-address/index.d.ts +18 -9
  179. package/dest/eth-address/index.d.ts.map +1 -1
  180. package/dest/eth-address/index.js +31 -2
  181. package/dest/eth-signature/eth_signature.d.ts +17 -15
  182. package/dest/eth-signature/eth_signature.d.ts.map +1 -1
  183. package/dest/eth-signature/eth_signature.js +31 -17
  184. package/dest/eth-signature/index.d.ts +1 -1
  185. package/dest/fs/index.d.ts +2 -1
  186. package/dest/fs/index.d.ts.map +1 -1
  187. package/dest/fs/index.js +1 -0
  188. package/dest/fs/run_in_dir.d.ts +1 -1
  189. package/dest/fs/try_rm_dir.d.ts +3 -0
  190. package/dest/fs/try_rm_dir.d.ts.map +1 -0
  191. package/dest/fs/try_rm_dir.js +16 -0
  192. package/dest/iterable/all.d.ts +1 -1
  193. package/dest/iterable/filter.d.ts +1 -1
  194. package/dest/iterable/filter.js +1 -1
  195. package/dest/iterable/index.d.ts +1 -1
  196. package/dest/iterable/isAsyncIt.d.ts +1 -1
  197. package/dest/iterable/map.d.ts +1 -1
  198. package/dest/iterable/map.js +1 -1
  199. package/dest/iterable/peek.d.ts +1 -1
  200. package/dest/iterable/sort.d.ts +1 -1
  201. package/dest/iterable/take.d.ts +1 -1
  202. package/dest/iterable/toArray.d.ts +1 -1
  203. package/dest/iterator/filter.d.ts +3 -0
  204. package/dest/iterator/filter.d.ts.map +1 -0
  205. package/dest/iterator/filter.js +7 -0
  206. package/dest/iterator/index.d.ts +2 -0
  207. package/dest/iterator/index.d.ts.map +1 -0
  208. package/dest/iterator/index.js +1 -0
  209. package/dest/jest/env.js +48 -0
  210. package/dest/jest/setup.js +4 -1
  211. package/dest/jest/setupAfterEnv.js +3 -0
  212. package/dest/json-rpc/client/fetch.d.ts +3 -3
  213. package/dest/json-rpc/client/fetch.d.ts.map +1 -1
  214. package/dest/json-rpc/client/fetch.js +16 -30
  215. package/dest/json-rpc/client/index.d.ts +1 -1
  216. package/dest/json-rpc/client/safe_json_rpc_client.d.ts +10 -4
  217. package/dest/json-rpc/client/safe_json_rpc_client.d.ts.map +1 -1
  218. package/dest/json-rpc/client/safe_json_rpc_client.js +173 -13
  219. package/dest/json-rpc/client/undici.d.ts +1 -1
  220. package/dest/json-rpc/client/undici.d.ts.map +1 -1
  221. package/dest/json-rpc/client/undici.js +27 -11
  222. package/dest/json-rpc/convert.d.ts +3 -10
  223. package/dest/json-rpc/convert.d.ts.map +1 -1
  224. package/dest/json-rpc/convert.js +1 -9
  225. package/dest/json-rpc/errors.d.ts +4 -0
  226. package/dest/json-rpc/errors.d.ts.map +1 -0
  227. package/dest/json-rpc/errors.js +6 -0
  228. package/dest/json-rpc/fixtures/class_a.d.ts +6 -4
  229. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -1
  230. package/dest/json-rpc/fixtures/class_b.d.ts +6 -4
  231. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -1
  232. package/dest/json-rpc/fixtures/test_state.d.ts +1 -1
  233. package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -1
  234. package/dest/json-rpc/index.d.ts +3 -2
  235. package/dest/json-rpc/index.d.ts.map +1 -1
  236. package/dest/json-rpc/index.js +2 -1
  237. package/dest/json-rpc/js_utils.d.ts +1 -1
  238. package/dest/json-rpc/js_utils.d.ts.map +1 -1
  239. package/dest/json-rpc/server/index.d.ts +1 -1
  240. package/dest/json-rpc/server/safe_json_rpc_server.d.ts +22 -23
  241. package/dest/json-rpc/server/safe_json_rpc_server.d.ts.map +1 -1
  242. package/dest/json-rpc/server/safe_json_rpc_server.js +161 -56
  243. package/dest/json-rpc/test/index.d.ts +1 -1
  244. package/dest/json-rpc/test/integration.d.ts +2 -3
  245. package/dest/json-rpc/test/integration.d.ts.map +1 -1
  246. package/dest/log/console.d.ts +1 -1
  247. package/dest/log/console.d.ts.map +1 -1
  248. package/dest/log/gcloud-logger-config.d.ts +1 -2
  249. package/dest/log/gcloud-logger-config.d.ts.map +1 -1
  250. package/dest/log/gcloud-logger-config.js +1 -9
  251. package/dest/log/index.d.ts +5 -5
  252. package/dest/log/index.d.ts.map +1 -1
  253. package/dest/log/index.js +4 -4
  254. package/dest/log/libp2p_logger.d.ts +5 -2
  255. package/dest/log/libp2p_logger.d.ts.map +1 -1
  256. package/dest/log/libp2p_logger.js +27 -6
  257. package/dest/log/log-filters.d.ts +1 -1
  258. package/dest/log/log-levels.d.ts +1 -1
  259. package/dest/log/log_fn.d.ts +2 -2
  260. package/dest/log/log_fn.d.ts.map +1 -1
  261. package/dest/log/noir_debug_log_util.d.ts +14 -0
  262. package/dest/log/noir_debug_log_util.d.ts.map +1 -0
  263. package/dest/log/noir_debug_log_util.js +14 -0
  264. package/dest/log/pino-logger-server.d.ts +9 -0
  265. package/dest/log/pino-logger-server.d.ts.map +1 -0
  266. package/dest/log/pino-logger-server.js +18 -0
  267. package/dest/log/pino-logger.d.ts +40 -11
  268. package/dest/log/pino-logger.d.ts.map +1 -1
  269. package/dest/log/pino-logger.js +143 -28
  270. package/dest/message/index.d.ts +1 -1
  271. package/dest/message/index.d.ts.map +1 -1
  272. package/dest/mutex/index.d.ts +1 -1
  273. package/dest/mutex/index.d.ts.map +1 -1
  274. package/dest/mutex/mutex_database.d.ts +1 -1
  275. package/dest/mutex/mutex_database.d.ts.map +1 -1
  276. package/dest/noir/index.d.ts +1 -1
  277. package/dest/noir/noir_package_config.d.ts +9 -9
  278. package/dest/number/index.d.ts +3 -0
  279. package/dest/number/index.d.ts.map +1 -0
  280. package/dest/number/index.js +12 -0
  281. package/dest/profiler/index.d.ts +2 -0
  282. package/dest/profiler/index.d.ts.map +1 -0
  283. package/dest/profiler/index.js +1 -0
  284. package/dest/profiler/profiler.d.ts +8 -0
  285. package/dest/profiler/profiler.d.ts.map +1 -0
  286. package/dest/profiler/profiler.js +97 -0
  287. package/dest/promise/index.d.ts +1 -1
  288. package/dest/promise/running-promise.d.ts +2 -2
  289. package/dest/promise/running-promise.d.ts.map +1 -1
  290. package/dest/promise/running-promise.js +2 -2
  291. package/dest/promise/utils.d.ts +1 -1
  292. package/dest/queue/base_memory_queue.d.ts +1 -1
  293. package/dest/queue/base_memory_queue.d.ts.map +1 -1
  294. package/dest/queue/batch_queue.d.ts +2 -2
  295. package/dest/queue/batch_queue.d.ts.map +1 -1
  296. package/dest/queue/batch_queue.js +1 -1
  297. package/dest/queue/bounded_serial_queue.d.ts +1 -1
  298. package/dest/queue/bounded_serial_queue.d.ts.map +1 -1
  299. package/dest/queue/fifo_memory_queue.d.ts +1 -1
  300. package/dest/queue/fifo_memory_queue.d.ts.map +1 -1
  301. package/dest/queue/index.d.ts +1 -1
  302. package/dest/queue/priority_memory_queue.d.ts +1 -1
  303. package/dest/queue/priority_memory_queue.d.ts.map +1 -1
  304. package/dest/queue/priority_queue.d.ts +1 -1
  305. package/dest/queue/priority_queue.d.ts.map +1 -1
  306. package/dest/queue/semaphore.d.ts +5 -1
  307. package/dest/queue/semaphore.d.ts.map +1 -1
  308. package/dest/queue/serial_queue.d.ts +3 -3
  309. package/dest/queue/serial_queue.d.ts.map +1 -1
  310. package/dest/queue/serial_queue.js +7 -5
  311. package/dest/retry/index.d.ts +14 -3
  312. package/dest/retry/index.d.ts.map +1 -1
  313. package/dest/retry/index.js +13 -2
  314. package/dest/running-promise/index.d.ts +1 -1
  315. package/dest/schemas/api.d.ts +1 -1
  316. package/dest/schemas/api.d.ts.map +1 -1
  317. package/dest/schemas/index.d.ts +1 -1
  318. package/dest/schemas/parse.d.ts +1 -1
  319. package/dest/schemas/parse.js +1 -1
  320. package/dest/schemas/schemas.d.ts +21 -20
  321. package/dest/schemas/schemas.d.ts.map +1 -1
  322. package/dest/schemas/schemas.js +29 -11
  323. package/dest/schemas/types.d.ts +31 -1
  324. package/dest/schemas/types.d.ts.map +1 -1
  325. package/dest/schemas/types.js +25 -1
  326. package/dest/schemas/utils.d.ts +4 -6
  327. package/dest/schemas/utils.d.ts.map +1 -1
  328. package/dest/schemas/utils.js +15 -5
  329. package/dest/serialize/buffer_reader.d.ts +34 -6
  330. package/dest/serialize/buffer_reader.d.ts.map +1 -1
  331. package/dest/serialize/buffer_reader.js +57 -6
  332. package/dest/serialize/field_reader.d.ts +12 -3
  333. package/dest/serialize/field_reader.d.ts.map +1 -1
  334. package/dest/serialize/field_reader.js +19 -2
  335. package/dest/serialize/free_funcs.d.ts +25 -23
  336. package/dest/serialize/free_funcs.d.ts.map +1 -1
  337. package/dest/serialize/free_funcs.js +22 -28
  338. package/dest/serialize/index.d.ts +1 -1
  339. package/dest/serialize/serialize.d.ts +6 -7
  340. package/dest/serialize/serialize.d.ts.map +1 -1
  341. package/dest/serialize/serialize.js +1 -1
  342. package/dest/serialize/type_registry.d.ts +1 -1
  343. package/dest/serialize/type_registry.d.ts.map +1 -1
  344. package/dest/serialize/types.d.ts +1 -1
  345. package/dest/sleep/index.d.ts +3 -1
  346. package/dest/sleep/index.d.ts.map +1 -1
  347. package/dest/sleep/index.js +4 -0
  348. package/dest/string/index.d.ts +8 -3
  349. package/dest/string/index.d.ts.map +1 -1
  350. package/dest/string/index.js +27 -1
  351. package/dest/testing/files/index.d.ts +2 -3
  352. package/dest/testing/files/index.d.ts.map +1 -1
  353. package/dest/testing/files/index.js +3 -3
  354. package/dest/testing/formatting.d.ts +4 -0
  355. package/dest/testing/formatting.d.ts.map +1 -0
  356. package/dest/testing/formatting.js +3 -0
  357. package/dest/testing/index.d.ts +2 -1
  358. package/dest/testing/index.d.ts.map +1 -1
  359. package/dest/testing/index.js +1 -0
  360. package/dest/testing/port_allocator.d.ts +1 -1
  361. package/dest/testing/snapshot_serializer.d.ts +1 -1
  362. package/dest/testing/test_data.d.ts +1 -1
  363. package/dest/timer/date.d.ts +4 -2
  364. package/dest/timer/date.d.ts.map +1 -1
  365. package/dest/timer/date.js +8 -3
  366. package/dest/timer/elapsed.d.ts +1 -1
  367. package/dest/timer/index.d.ts +2 -2
  368. package/dest/timer/index.d.ts.map +1 -1
  369. package/dest/timer/index.js +1 -1
  370. package/dest/timer/timeout.d.ts +19 -6
  371. package/dest/timer/timeout.d.ts.map +1 -1
  372. package/dest/timer/timeout.js +43 -22
  373. package/dest/timer/timer.d.ts +1 -1
  374. package/dest/timer/timer.d.ts.map +1 -1
  375. package/dest/transport/dispatch/create_dispatch_fn.d.ts +1 -1
  376. package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -1
  377. package/dest/transport/dispatch/create_dispatch_proxy.d.ts +1 -1
  378. package/dest/transport/dispatch/messages.d.ts +1 -1
  379. package/dest/transport/index.d.ts +1 -2
  380. package/dest/transport/index.d.ts.map +1 -1
  381. package/dest/transport/index.js +0 -1
  382. package/dest/transport/interface/connector.d.ts +1 -1
  383. package/dest/transport/interface/connector.d.ts.map +1 -1
  384. package/dest/transport/interface/listener.d.ts +1 -2
  385. package/dest/transport/interface/listener.d.ts.map +1 -1
  386. package/dest/transport/interface/socket.d.ts +1 -1
  387. package/dest/transport/interface/socket.d.ts.map +1 -1
  388. package/dest/transport/interface/transferable.d.ts +1 -1
  389. package/dest/transport/node/index.d.ts +1 -1
  390. package/dest/transport/node/node_connector.d.ts +1 -2
  391. package/dest/transport/node/node_connector.d.ts.map +1 -1
  392. package/dest/transport/node/node_connector_socket.d.ts +1 -2
  393. package/dest/transport/node/node_connector_socket.d.ts.map +1 -1
  394. package/dest/transport/node/node_listener.d.ts +1 -2
  395. package/dest/transport/node/node_listener.d.ts.map +1 -1
  396. package/dest/transport/node/node_listener_socket.d.ts +1 -2
  397. package/dest/transport/node/node_listener_socket.d.ts.map +1 -1
  398. package/dest/transport/transport_client.d.ts +1 -2
  399. package/dest/transport/transport_client.d.ts.map +1 -1
  400. package/dest/transport/transport_server.d.ts +1 -10
  401. package/dest/transport/transport_server.d.ts.map +1 -1
  402. package/dest/trees/balanced_merkle_tree_root.d.ts +17 -0
  403. package/dest/trees/balanced_merkle_tree_root.d.ts.map +1 -0
  404. package/dest/trees/balanced_merkle_tree_root.js +51 -0
  405. package/dest/trees/hasher.d.ts +7 -7
  406. package/dest/trees/hasher.d.ts.map +1 -1
  407. package/dest/trees/hasher.js +10 -5
  408. package/dest/trees/index.d.ts +5 -3
  409. package/dest/trees/index.d.ts.map +1 -1
  410. package/dest/trees/index.js +4 -2
  411. package/dest/trees/indexed_merkle_tree.d.ts +1 -3
  412. package/dest/trees/indexed_merkle_tree.d.ts.map +1 -1
  413. package/dest/trees/indexed_merkle_tree.js +1 -1
  414. package/dest/trees/indexed_merkle_tree_calculator.d.ts +2 -4
  415. package/dest/trees/indexed_merkle_tree_calculator.d.ts.map +1 -1
  416. package/dest/trees/indexed_tree_leaf.d.ts +1 -3
  417. package/dest/trees/indexed_tree_leaf.d.ts.map +1 -1
  418. package/dest/trees/membership_witness.d.ts +10 -5
  419. package/dest/trees/membership_witness.d.ts.map +1 -1
  420. package/dest/trees/membership_witness.js +23 -1
  421. package/dest/trees/merkle_tree.d.ts +1 -3
  422. package/dest/trees/merkle_tree.d.ts.map +1 -1
  423. package/dest/trees/merkle_tree_calculator.d.ts +2 -4
  424. package/dest/trees/merkle_tree_calculator.d.ts.map +1 -1
  425. package/dest/trees/merkle_tree_calculator.js +2 -2
  426. package/dest/trees/sibling_path.d.ts +6 -41
  427. package/dest/trees/sibling_path.d.ts.map +1 -1
  428. package/dest/trees/sibling_path.js +3 -3
  429. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts +48 -0
  430. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts.map +1 -0
  431. package/dest/trees/unbalanced_merkle_tree_calculator.js +154 -0
  432. package/dest/trees/unbalanced_merkle_tree_root.d.ts +28 -0
  433. package/dest/trees/unbalanced_merkle_tree_root.d.ts.map +1 -0
  434. package/dest/trees/unbalanced_merkle_tree_root.js +84 -0
  435. package/dest/trees/unbalanced_tree_store.d.ts +6 -1
  436. package/dest/trees/unbalanced_tree_store.d.ts.map +1 -1
  437. package/dest/trees/unbalanced_tree_store.js +55 -1
  438. package/dest/types/index.d.ts +30 -3
  439. package/dest/types/index.d.ts.map +1 -1
  440. package/dest/types/index.js +6 -0
  441. package/dest/url/index.d.ts +1 -1
  442. package/dest/url/index.d.ts.map +1 -1
  443. package/dest/url/index.js +1 -1
  444. package/dest/validation/index.d.ts +1 -1
  445. package/package.json +60 -45
  446. package/src/array/array.ts +13 -16
  447. package/src/array/index.ts +1 -0
  448. package/src/array/sorted_array.ts +133 -0
  449. package/src/async-pool/index.ts +1 -0
  450. package/src/bigint/index.ts +20 -0
  451. package/src/branded-types/block_number.ts +117 -0
  452. package/src/branded-types/checkpoint_number.ts +115 -0
  453. package/src/branded-types/epoch.ts +88 -0
  454. package/src/branded-types/index.ts +7 -0
  455. package/src/branded-types/index_within_checkpoint.ts +88 -0
  456. package/src/branded-types/slot.ts +88 -0
  457. package/src/branded-types/types.ts +2 -0
  458. package/src/buffer/buffer16.ts +133 -0
  459. package/src/buffer/buffer32.ts +10 -8
  460. package/src/buffer/index.ts +1 -0
  461. package/src/collection/array.ts +118 -4
  462. package/src/collection/object.ts +37 -0
  463. package/src/config/env_var.ts +186 -59
  464. package/src/config/index.ts +226 -10
  465. package/src/config/network_config.ts +18 -0
  466. package/src/config/network_name.ts +28 -0
  467. package/src/config/parse-env.ts +4 -0
  468. package/src/config/secret_value.ts +49 -0
  469. package/src/crypto/aes128/index.ts +19 -10
  470. package/src/crypto/bls/bn254_keystore.ts +287 -0
  471. package/src/crypto/bls/index.ts +77 -0
  472. package/src/crypto/bn254/index.ts +64 -0
  473. package/src/crypto/ecdsa/index.ts +41 -23
  474. package/src/crypto/ecdsa/signature.ts +2 -2
  475. package/src/crypto/grumpkin/index.ts +38 -46
  476. package/src/crypto/keys/index.ts +6 -6
  477. package/src/crypto/pedersen/pedersen.wasm.ts +23 -19
  478. package/src/crypto/poseidon/index.ts +27 -29
  479. package/src/crypto/random/index.ts +2 -40
  480. package/src/crypto/random/randomness_singleton.ts +6 -4
  481. package/src/crypto/schnorr/index.ts +22 -18
  482. package/src/crypto/schnorr/signature.ts +2 -2
  483. package/src/crypto/secp256k1/index.ts +15 -11
  484. package/src/crypto/secp256k1-signer/utils.ts +120 -7
  485. package/src/crypto/sha256/index.ts +48 -1
  486. package/src/crypto/sha512/index.ts +1 -1
  487. package/src/crypto/signature/index.ts +1 -1
  488. package/src/crypto/sync/index.ts +1 -1
  489. package/src/crypto/sync/pedersen/index.ts +17 -16
  490. package/src/crypto/sync/poseidon/index.ts +23 -27
  491. package/src/curves/bls12/field.ts +463 -0
  492. package/src/curves/bls12/index.ts +2 -0
  493. package/src/curves/bls12/point.ts +450 -0
  494. package/src/{fields/fields.ts → curves/bn254/field.ts} +84 -63
  495. package/src/curves/bn254/index.ts +2 -0
  496. package/src/curves/bn254/point.ts +170 -0
  497. package/src/curves/grumpkin/index.ts +11 -0
  498. package/src/{fields → curves/grumpkin}/point.ts +27 -10
  499. package/src/eth-address/index.ts +35 -3
  500. package/src/eth-signature/eth_signature.ts +44 -22
  501. package/src/fs/index.ts +1 -0
  502. package/src/fs/try_rm_dir.ts +15 -0
  503. package/src/iterable/filter.ts +1 -1
  504. package/src/iterable/map.ts +1 -1
  505. package/src/iterator/filter.ts +11 -0
  506. package/src/iterator/index.ts +1 -0
  507. package/src/jest/env.mjs +52 -0
  508. package/src/jest/setup.mjs +4 -1
  509. package/src/jest/setupAfterEnv.mjs +3 -0
  510. package/src/json-rpc/client/fetch.ts +14 -33
  511. package/src/json-rpc/client/safe_json_rpc_client.ts +226 -13
  512. package/src/json-rpc/client/undici.ts +29 -18
  513. package/src/json-rpc/convert.ts +3 -12
  514. package/src/json-rpc/errors.ts +6 -0
  515. package/src/json-rpc/fixtures/class_a.ts +4 -1
  516. package/src/json-rpc/fixtures/class_b.ts +4 -1
  517. package/src/json-rpc/index.ts +2 -1
  518. package/src/json-rpc/server/safe_json_rpc_server.ts +141 -48
  519. package/src/json-rpc/test/integration.ts +1 -1
  520. package/src/log/console.ts +4 -1
  521. package/src/log/gcloud-logger-config.ts +3 -7
  522. package/src/log/index.ts +4 -4
  523. package/src/log/libp2p_logger.ts +33 -7
  524. package/src/log/log_fn.ts +1 -1
  525. package/src/log/noir_debug_log_util.ts +21 -0
  526. package/src/log/pino-logger-server.ts +25 -0
  527. package/src/log/pino-logger.ts +169 -37
  528. package/src/message/index.ts +5 -1
  529. package/src/mutex/mutex_database.ts +2 -3
  530. package/src/number/index.ts +14 -0
  531. package/src/profiler/index.ts +1 -0
  532. package/src/profiler/profiler.ts +125 -0
  533. package/src/promise/running-promise.ts +2 -2
  534. package/src/queue/batch_queue.ts +1 -1
  535. package/src/queue/bounded_serial_queue.ts +4 -1
  536. package/src/queue/semaphore.ts +5 -0
  537. package/src/queue/serial_queue.ts +5 -5
  538. package/src/retry/index.ts +28 -5
  539. package/src/schemas/api.ts +4 -4
  540. package/src/schemas/parse.ts +1 -1
  541. package/src/schemas/schemas.ts +42 -13
  542. package/src/schemas/types.ts +33 -0
  543. package/src/schemas/utils.ts +21 -8
  544. package/src/serialize/buffer_reader.ts +81 -12
  545. package/src/serialize/field_reader.ts +28 -4
  546. package/src/serialize/free_funcs.ts +26 -32
  547. package/src/serialize/serialize.ts +3 -1
  548. package/src/sleep/index.ts +6 -0
  549. package/src/string/index.ts +36 -1
  550. package/src/testing/files/index.ts +7 -3
  551. package/src/testing/formatting.ts +3 -0
  552. package/src/testing/index.ts +1 -0
  553. package/src/timer/date.ts +13 -3
  554. package/src/timer/index.ts +1 -1
  555. package/src/timer/timeout.ts +54 -19
  556. package/src/transport/index.ts +0 -1
  557. package/src/transport/interface/connector.ts +0 -1
  558. package/src/transport/interface/listener.ts +2 -3
  559. package/src/transport/interface/socket.ts +2 -3
  560. package/src/transport/transport_client.ts +3 -4
  561. package/src/transport/transport_server.ts +4 -1
  562. package/src/trees/balanced_merkle_tree_root.ts +68 -0
  563. package/src/trees/hasher.ts +13 -4
  564. package/src/trees/index.ts +4 -2
  565. package/src/trees/indexed_merkle_tree.ts +6 -2
  566. package/src/trees/indexed_merkle_tree_calculator.ts +2 -2
  567. package/src/trees/membership_witness.ts +22 -1
  568. package/src/trees/merkle_tree.ts +4 -1
  569. package/src/trees/merkle_tree_calculator.ts +10 -5
  570. package/src/trees/sibling_path.ts +3 -3
  571. package/src/trees/unbalanced_merkle_tree_calculator.ts +176 -0
  572. package/src/trees/unbalanced_merkle_tree_root.ts +115 -0
  573. package/src/trees/unbalanced_tree_store.ts +62 -3
  574. package/src/types/index.ts +35 -4
  575. package/src/url/index.ts +0 -1
  576. package/dest/crypto/index.d.ts +0 -15
  577. package/dest/crypto/index.d.ts.map +0 -1
  578. package/dest/crypto/index.js +0 -14
  579. package/dest/crypto/pedersen/pedersen.elliptic.d.ts +0 -13
  580. package/dest/crypto/pedersen/pedersen.elliptic.d.ts.map +0 -1
  581. package/dest/crypto/pedersen/pedersen.elliptic.js +0 -582
  582. package/dest/fields/coordinate.d.ts +0 -68
  583. package/dest/fields/coordinate.d.ts.map +0 -1
  584. package/dest/fields/coordinate.js +0 -96
  585. package/dest/fields/fields.d.ts +0 -176
  586. package/dest/fields/fields.d.ts.map +0 -1
  587. package/dest/fields/index.d.ts +0 -4
  588. package/dest/fields/index.d.ts.map +0 -1
  589. package/dest/fields/index.js +0 -3
  590. package/dest/fields/point.d.ts.map +0 -1
  591. package/dest/index.d.ts +0 -31
  592. package/dest/index.d.ts.map +0 -1
  593. package/dest/index.js +0 -31
  594. package/dest/json-rpc/server/telemetry.d.ts +0 -2
  595. package/dest/json-rpc/server/telemetry.d.ts.map +0 -1
  596. package/dest/json-rpc/server/telemetry.js +0 -0
  597. package/dest/log/debug.d.ts +0 -56
  598. package/dest/log/debug.d.ts.map +0 -1
  599. package/dest/log/debug.js +0 -75
  600. package/dest/log/log_history.d.ts +0 -31
  601. package/dest/log/log_history.d.ts.map +0 -1
  602. package/dest/log/log_history.js +0 -38
  603. package/dest/transport/browser/index.d.ts +0 -5
  604. package/dest/transport/browser/index.d.ts.map +0 -1
  605. package/dest/transport/browser/index.js +0 -4
  606. package/dest/transport/browser/message_port_socket.d.ts +0 -37
  607. package/dest/transport/browser/message_port_socket.d.ts.map +0 -1
  608. package/dest/transport/browser/message_port_socket.js +0 -42
  609. package/dest/transport/browser/shared_worker_connector.d.ts +0 -19
  610. package/dest/transport/browser/shared_worker_connector.d.ts.map +0 -1
  611. package/dest/transport/browser/shared_worker_connector.js +0 -19
  612. package/dest/transport/browser/shared_worker_listener.d.ts +0 -38
  613. package/dest/transport/browser/shared_worker_listener.d.ts.map +0 -1
  614. package/dest/transport/browser/shared_worker_listener.js +0 -33
  615. package/dest/transport/browser/worker_connector.d.ts +0 -26
  616. package/dest/transport/browser/worker_connector.d.ts.map +0 -1
  617. package/dest/transport/browser/worker_connector.js +0 -30
  618. package/dest/transport/browser/worker_listener.d.ts +0 -39
  619. package/dest/transport/browser/worker_listener.d.ts.map +0 -1
  620. package/dest/transport/browser/worker_listener.js +0 -35
  621. package/dest/trees/unbalanced_merkle_tree.d.ts +0 -17
  622. package/dest/trees/unbalanced_merkle_tree.d.ts.map +0 -1
  623. package/dest/trees/unbalanced_merkle_tree.js +0 -100
  624. package/dest/wasm/empty_wasi_sdk.d.ts +0 -130
  625. package/dest/wasm/empty_wasi_sdk.d.ts.map +0 -1
  626. package/dest/wasm/empty_wasi_sdk.js +0 -148
  627. package/dest/wasm/index.d.ts +0 -2
  628. package/dest/wasm/index.d.ts.map +0 -1
  629. package/dest/wasm/index.js +0 -1
  630. package/dest/wasm/wasm_module.d.ts +0 -136
  631. package/dest/wasm/wasm_module.d.ts.map +0 -1
  632. package/dest/wasm/wasm_module.js +0 -196
  633. package/dest/worker/browser/index.d.ts +0 -3
  634. package/dest/worker/browser/index.d.ts.map +0 -1
  635. package/dest/worker/browser/index.js +0 -2
  636. package/dest/worker/browser/start_web_module.d.ts +0 -7
  637. package/dest/worker/browser/start_web_module.d.ts.map +0 -1
  638. package/dest/worker/browser/start_web_module.js +0 -27
  639. package/dest/worker/browser/web_data_store.d.ts +0 -24
  640. package/dest/worker/browser/web_data_store.d.ts.map +0 -1
  641. package/dest/worker/browser/web_data_store.js +0 -29
  642. package/dest/worker/browser/web_worker.d.ts +0 -10
  643. package/dest/worker/browser/web_worker.d.ts.map +0 -1
  644. package/dest/worker/browser/web_worker.js +0 -25
  645. package/dest/worker/data_store.d.ts +0 -21
  646. package/dest/worker/data_store.d.ts.map +0 -1
  647. package/dest/worker/data_store.js +0 -3
  648. package/dest/worker/index.d.ts +0 -3
  649. package/dest/worker/index.d.ts.map +0 -1
  650. package/dest/worker/index.js +0 -1
  651. package/dest/worker/node/index.d.ts +0 -3
  652. package/dest/worker/node/index.d.ts.map +0 -1
  653. package/dest/worker/node/index.js +0 -2
  654. package/dest/worker/node/node_data_store.d.ts +0 -13
  655. package/dest/worker/node/node_data_store.d.ts.map +0 -1
  656. package/dest/worker/node/node_data_store.js +0 -20
  657. package/dest/worker/node/node_worker.d.ts +0 -6
  658. package/dest/worker/node/node_worker.d.ts.map +0 -1
  659. package/dest/worker/node/node_worker.js +0 -22
  660. package/dest/worker/node/start_node_module.d.ts +0 -7
  661. package/dest/worker/node/start_node_module.d.ts.map +0 -1
  662. package/dest/worker/node/start_node_module.js +0 -31
  663. package/dest/worker/wasm_worker.d.ts +0 -9
  664. package/dest/worker/wasm_worker.d.ts.map +0 -1
  665. package/dest/worker/wasm_worker.js +0 -3
  666. package/dest/worker/worker_pool.d.ts +0 -40
  667. package/dest/worker/worker_pool.d.ts.map +0 -1
  668. package/dest/worker/worker_pool.js +0 -51
  669. package/src/crypto/index.ts +0 -14
  670. package/src/crypto/pedersen/pedersen.elliptic.ts +0 -584
  671. package/src/fields/coordinate.ts +0 -104
  672. package/src/fields/index.ts +0 -3
  673. package/src/index.ts +0 -31
  674. package/src/json-rpc/server/telemetry.ts +0 -0
  675. package/src/log/debug.ts +0 -104
  676. package/src/log/log_history.ts +0 -44
  677. package/src/transport/browser/index.ts +0 -4
  678. package/src/transport/browser/message_port_socket.ts +0 -48
  679. package/src/transport/browser/shared_worker_connector.ts +0 -21
  680. package/src/transport/browser/shared_worker_listener.ts +0 -53
  681. package/src/transport/browser/worker_connector.ts +0 -30
  682. package/src/transport/browser/worker_listener.ts +0 -54
  683. package/src/trees/unbalanced_merkle_tree.ts +0 -103
  684. package/src/wasm/README.md +0 -6
  685. package/src/wasm/empty_wasi_sdk.ts +0 -166
  686. package/src/wasm/fixtures/gcd.wasm +0 -0
  687. package/src/wasm/fixtures/gcd.wat +0 -27
  688. package/src/wasm/index.ts +0 -1
  689. package/src/wasm/wasm_module.ts +0 -260
  690. package/src/worker/browser/index.ts +0 -2
  691. package/src/worker/browser/start_web_module.ts +0 -24
  692. package/src/worker/browser/web_data_store.ts +0 -38
  693. package/src/worker/browser/web_worker.ts +0 -25
  694. package/src/worker/data_store.ts +0 -19
  695. package/src/worker/index.ts +0 -2
  696. package/src/worker/node/index.ts +0 -2
  697. package/src/worker/node/node_data_store.ts +0 -27
  698. package/src/worker/node/node_worker.ts +0 -23
  699. package/src/worker/node/start_node_module.ts +0 -30
  700. package/src/worker/wasm_worker.ts +0 -7
  701. package/src/worker/worker_pool.ts +0 -73
@@ -1,2 +1,2 @@
1
1
  export * from './eth_signature.js';
2
- //# sourceMappingURL=index.d.ts.map
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ldGgtc2lnbmF0dXJlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUMifQ==
@@ -1,2 +1,3 @@
1
1
  export * from './run_in_dir.js';
2
- //# sourceMappingURL=index.d.ts.map
2
+ export * from './try_rm_dir.js';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsaUJBQWlCLENBQUMifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/fs/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/fs/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC"}
package/dest/fs/index.js CHANGED
@@ -1 +1,2 @@
1
1
  export * from './run_in_dir.js';
2
+ export * from './try_rm_dir.js';
@@ -1,2 +1,2 @@
1
1
  export declare function runInDirectory<T>(workingDirBase: string, fn: (dir: string) => Promise<T>, skipCleanup: boolean | undefined, logger?: import("../log/pino-logger.js").Logger): Promise<T>;
2
- //# sourceMappingURL=run_in_dir.d.ts.map
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVuX2luX2Rpci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZzL3J1bl9pbl9kaXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0Esd0JBQXNCLGNBQWMsQ0FBQyxDQUFDLEVBQ3BDLGNBQWMsRUFBRSxNQUFNLEVBQ3RCLEVBQUUsRUFBRSxDQUFDLEdBQUcsRUFBRSxNQUFNLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUMvQixXQUFXLEVBQUUsT0FBTyxHQUFHLFNBQVMsRUFDaEMsTUFBTSx5Q0FBOEMsR0FDbkQsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQW9CWiJ9
@@ -0,0 +1,3 @@
1
+ import type { Logger } from '../log/index.js';
2
+ export declare function tryRmDir(dir: string | undefined, logger?: Logger): Promise<void>;
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ5X3JtX2Rpci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZzL3RyeV9ybV9kaXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFOUMsd0JBQXNCLFFBQVEsQ0FBQyxHQUFHLEVBQUUsTUFBTSxHQUFHLFNBQVMsRUFBRSxNQUFNLENBQUMsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQVV0RiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"try_rm_dir.d.ts","sourceRoot":"","sources":["../../src/fs/try_rm_dir.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,wBAAsB,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAUtF"}
@@ -0,0 +1,16 @@
1
+ import { rm } from 'fs/promises';
2
+ export async function tryRmDir(dir, logger) {
3
+ if (dir === undefined) {
4
+ return;
5
+ }
6
+ try {
7
+ logger?.debug(`Cleaning up directory at ${dir}`);
8
+ await rm(dir, {
9
+ recursive: true,
10
+ force: true,
11
+ maxRetries: 3
12
+ });
13
+ } catch (err) {
14
+ logger?.warn(`Failed to delete directory at ${dir}: ${err}`);
15
+ }
16
+ }
@@ -6,4 +6,4 @@
6
6
  declare function all<T>(source: Iterable<T>): T[];
7
7
  declare function all<T>(source: Iterable<T> | AsyncIterable<T>): Promise<T[]>;
8
8
  export { all };
9
- //# sourceMappingURL=all.d.ts.map
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxsLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaXRlcmFibGUvYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBOzs7O0dBSUc7QUFDSCxpQkFBUyxHQUFHLENBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7QUFDMUMsaUJBQVMsR0FBRyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsQ0FBQyxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQXVCdEUsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDIn0=
@@ -7,4 +7,4 @@ declare function filter<T>(source: Iterable<T>, fn: (val: T, index: number) => P
7
7
  declare function filter<T>(source: Iterable<T>, fn: (val: T, index: number) => boolean): Generator<T, void, undefined>;
8
8
  declare function filter<T>(source: Iterable<T> | AsyncIterable<T>, fn: (val: T, index: number) => boolean | Promise<boolean>): AsyncGenerator<T, void, undefined>;
9
9
  export { filter };
10
- //# sourceMappingURL=filter.d.ts.map
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaXRlcmFibGUvZmlsdGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1BOzs7O0dBSUc7QUFDSCxpQkFBUyxNQUFNLENBQUMsQ0FBQyxFQUNmLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQ25CLEVBQUUsRUFBRSxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sS0FBSyxPQUFPLENBQUMsT0FBTyxDQUFDLEdBQzlDLGNBQWMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0FBQ3RDLGlCQUFTLE1BQU0sQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLEtBQUssT0FBTyxHQUFHLFNBQVMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0FBQy9HLGlCQUFTLE1BQU0sQ0FBQyxDQUFDLEVBQ2YsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxhQUFhLENBQUMsQ0FBQyxDQUFDLEVBQ3RDLEVBQUUsRUFBRSxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sS0FBSyxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUN4RCxjQUFjLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztBQXlEdEMsT0FBTyxFQUFFLE1BQU0sRUFBRSxDQUFDIn0=
@@ -26,7 +26,7 @@ function filter(source, fn) {
26
26
  if (await res) {
27
27
  yield value;
28
28
  }
29
- for await (const entry of peekable){
29
+ for (const entry of peekable){
30
30
  if (await fn(entry, index++)) {
31
31
  yield entry;
32
32
  }
@@ -5,4 +5,4 @@ export * from './take.js';
5
5
  export * from './all.js';
6
6
  export * from './peek.js';
7
7
  export * from './toArray.js';
8
- //# sourceMappingURL=index.d.ts.map
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pdGVyYWJsZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLGNBQWMsQ0FBQyJ9
@@ -4,4 +4,4 @@
4
4
  * @returns Type-checked input
5
5
  */
6
6
  export declare function isAsyncIterable<T>(thing: any): thing is AsyncIterable<T>;
7
- //# sourceMappingURL=isAsyncIt.d.ts.map
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNBc3luY0l0LmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaXRlcmFibGUvaXNBc3luY0l0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCx3QkFBZ0IsZUFBZSxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsR0FBRyxHQUFHLEtBQUssSUFBSSxhQUFhLENBQUMsQ0FBQyxDQUFDLENBRXhFIn0=
@@ -9,4 +9,4 @@ declare function map<I, O>(source: Iterable<I>, func: (val: I, index: number) =>
9
9
  declare function map<I, O>(source: Iterable<I>, func: (val: I, index: number) => O): Generator<O, void, undefined>;
10
10
  declare function map<I, O>(source: AsyncIterable<I> | Iterable<I>, func: (val: I, index: number) => O | Promise<O>): AsyncGenerator<O, void, undefined>;
11
11
  export { map };
12
- //# sourceMappingURL=map.d.ts.map
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaXRlcmFibGUvbWFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBOzs7Ozs7R0FNRztBQUNILGlCQUFTLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUNmLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQ25CLElBQUksRUFBRSxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sS0FBSyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQzFDLGNBQWMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0FBQ3RDLGlCQUFTLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUUsTUFBTSxLQUFLLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztBQUMzRyxpQkFBUyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFDZixNQUFNLEVBQUUsYUFBYSxDQUFDLENBQUMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFDdEMsSUFBSSxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUUsTUFBTSxLQUFLLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQzlDLGNBQWMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0FBK0N0QyxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMifQ==
@@ -20,7 +20,7 @@ function map(source, func) {
20
20
  if (typeof res.then === 'function') {
21
21
  return async function*() {
22
22
  yield await res;
23
- for await (const val of peekable){
23
+ for (const val of peekable){
24
24
  yield func(val, index++);
25
25
  }
26
26
  }();
@@ -16,4 +16,4 @@ export type AsyncPeekable<T> = AsyncIterable<T> & AsyncPeek<T> & Push<T> & Async
16
16
  declare function peekable<T>(iterable: Iterable<T>): Peekable<T>;
17
17
  declare function peekable<T>(iterable: AsyncIterable<T>): AsyncPeekable<T>;
18
18
  export { peekable as peek };
19
- //# sourceMappingURL=peek.d.ts.map
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVlay5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2l0ZXJhYmxlL3BlZWsudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxXQUFXLElBQUksQ0FBQyxDQUFDO0lBQ3JCLElBQUksSUFBSSxjQUFjLENBQUMsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0NBQ3RDO0FBRUQsTUFBTSxXQUFXLFNBQVMsQ0FBQyxDQUFDO0lBQzFCLElBQUksSUFBSSxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUMsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDO0NBQy9DO0FBRUQsTUFBTSxXQUFXLElBQUksQ0FBQyxDQUFDO0lBQ3JCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQztDQUN0QjtBQUVELE1BQU0sTUFBTSxRQUFRLENBQUMsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUV4RSxNQUFNLE1BQU0sYUFBYSxDQUFDLENBQUMsSUFBSSxhQUFhLENBQUMsQ0FBQyxDQUFDLEdBQUcsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFFNUY7OztHQUdHO0FBQ0gsaUJBQVMsUUFBUSxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUN6RCxpQkFBUyxRQUFRLENBQUMsQ0FBQyxFQUFFLFFBQVEsRUFBRSxhQUFhLENBQUMsQ0FBQyxDQUFDLEdBQUcsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBb0NuRSxPQUFPLEVBQUUsUUFBUSxJQUFJLElBQUksRUFBRSxDQUFDIn0=
@@ -11,4 +11,4 @@ export interface CompareFunction<T> {
11
11
  declare function sort<T>(source: Iterable<T>, sorter: CompareFunction<T>): Generator<T, void, undefined>;
12
12
  declare function sort<T>(source: Iterable<T> | AsyncIterable<T>, sorter: CompareFunction<T>): AsyncGenerator<T, void, undefined>;
13
13
  export { sort };
14
- //# sourceMappingURL=sort.d.ts.map
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2l0ZXJhYmxlL3NvcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxXQUFXLGVBQWUsQ0FBQyxDQUFDO0lBQ2hDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxHQUFHLE1BQU0sQ0FBQztDQUN0QjtBQUVEOzs7Ozs7R0FNRztBQUNILGlCQUFTLElBQUksQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsZUFBZSxDQUFDLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0FBQ2pHLGlCQUFTLElBQUksQ0FBQyxDQUFDLEVBQ2IsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxhQUFhLENBQUMsQ0FBQyxDQUFDLEVBQ3RDLE1BQU0sRUFBRSxlQUFlLENBQUMsQ0FBQyxDQUFDLEdBQ3pCLGNBQWMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0FBb0J0QyxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUMifQ==
@@ -7,4 +7,4 @@
7
7
  declare function take<T>(source: Iterable<T>, limit: number): Generator<T, void, undefined>;
8
8
  declare function take<T>(source: Iterable<T> | AsyncIterable<T>, limit: number): AsyncGenerator<T, void, undefined>;
9
9
  export { take };
10
- //# sourceMappingURL=take.d.ts.map
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFrZS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2l0ZXJhYmxlL3Rha2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7Ozs7O0dBS0c7QUFDSCxpQkFBUyxJQUFJLENBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sR0FBRyxTQUFTLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztBQUNwRixpQkFBUyxJQUFJLENBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcsYUFBYSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLEdBQUcsY0FBYyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7QUE0QzVHLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyJ9
@@ -1,2 +1,2 @@
1
1
  export declare function toArray<T>(iterator: Iterable<T> | AsyncIterableIterator<T> | AsyncIterable<T> | IterableIterator<T>): Promise<T[]>;
2
- //# sourceMappingURL=toArray.d.ts.map
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9BcnJheS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2l0ZXJhYmxlL3RvQXJyYXkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsd0JBQXNCLE9BQU8sQ0FBQyxDQUFDLEVBQzdCLFFBQVEsRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcscUJBQXFCLENBQUMsQ0FBQyxDQUFDLEdBQUcsYUFBYSxDQUFDLENBQUMsQ0FBQyxHQUFHLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxHQUN4RixPQUFPLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FNZCJ9
@@ -0,0 +1,3 @@
1
+ /** Wraps an async iterable iterator such that it filters values based on a predicate. */
2
+ export declare function filter<T>(iterator: AsyncIterableIterator<T>, predicate: (item: T) => boolean | Promise<boolean>): AsyncIterableIterator<T>;
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaXRlcmF0b3IvZmlsdGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHlGQUF5RjtBQUN6Rix3QkFBdUIsTUFBTSxDQUFDLENBQUMsRUFDN0IsUUFBUSxFQUFFLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxFQUNsQyxTQUFTLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxLQUFLLE9BQU8sR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLEdBQ2pELHFCQUFxQixDQUFDLENBQUMsQ0FBQyxDQU0xQiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../src/iterator/filter.ts"],"names":[],"mappings":"AAAA,yFAAyF;AACzF,wBAAuB,MAAM,CAAC,CAAC,EAC7B,QAAQ,EAAE,qBAAqB,CAAC,CAAC,CAAC,EAClC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,GACjD,qBAAqB,CAAC,CAAC,CAAC,CAM1B"}
@@ -0,0 +1,7 @@
1
+ /** Wraps an async iterable iterator such that it filters values based on a predicate. */ export async function* filter(iterator, predicate) {
2
+ for await (const item of iterator){
3
+ if (await predicate(item)) {
4
+ yield item;
5
+ }
6
+ }
7
+ }
@@ -0,0 +1,2 @@
1
+ export { filter } from './filter.js';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pdGVyYXRvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sYUFBYSxDQUFDIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/iterator/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1 @@
1
+ export { filter } from './filter.js';
@@ -0,0 +1,48 @@
1
+ import { TestEnvironment } from 'jest-environment-node';
2
+ // What errors should be ignored in after hooks
3
+ const IgnoredErrors = [
4
+ 'HttpRequestError',
5
+ 'CodeError'
6
+ ];
7
+ /** Custom Jest environment that ignores any whitelisted unhandled rejections that occur during `after` hooks */ export default class CustomEnvironment extends TestEnvironment {
8
+ constructor(config, context){
9
+ super(config, context);
10
+ }
11
+ async handleTestEvent(event, state) {
12
+ if (event.name === 'setup') {
13
+ // Jest 29 reports both unhandledRejection and uncaughtException events as plain `error`, without any means to differentiate them
14
+ // (see https://github.com/jestjs/jest/issues/9210). Jest 30 fixes it as part of a larger change (see
15
+ // https://github.com/jestjs/jest/pull/14315/files#diff-9bdc1fdb60c8631b1e346eff6e4899c4e64ae3a44f4f12d0d7ac70c2aabd1d93R12-R29),
16
+ // but we cannot update to 30 as it is still in beta at the time of writing this code. So we remove jest's unhandledRejection listener,
17
+ // replace it with our own, and delegate to the original listener only if the error is not in the ignored list.
18
+ const parentProcess = event.parentProcess;
19
+ const [jestListener] = parentProcess.listeners('unhandledRejection');
20
+ parentProcess.removeAllListeners('unhandledRejection');
21
+ const patchedListener = (err, _promise)=>{
22
+ if (state.isInAfterHook && IgnoredErrors.some((error)=>err && err.name && err.name.includes(error))) {
23
+ // Ignore the error only if it was an unhandled async rejection (not sync exception), it's on the IgnoredErrors list, and we're in an after hook.
24
+ console.error('Ignoring unhandled rejection in after hook:', err);
25
+ } else if (state.isInAfterHook) {
26
+ // Log non-ignored unhandled rejection in an after hook, and pass the error to the original jest listener to fail the test.
27
+ console.error(`Unhandled rejection in after hook:`, err);
28
+ jestListener && jestListener(err);
29
+ } else {
30
+ // Otherwise, just delegate to the original jest listener, to emit the `error` event under the hood.
31
+ jestListener && jestListener(err);
32
+ }
33
+ };
34
+ parentProcess.on('unhandledRejection', patchedListener);
35
+ state.patchedListener = patchedListener;
36
+ } else if (event.name === 'teardown') {
37
+ // Remove the patched handler we added in setup.
38
+ const parentProcess = state.parentProcess;
39
+ parentProcess.removeListener('unhandledRejection', state.patchedListener);
40
+ } else if (event.name === 'hook_start' && event.hook.type.startsWith('after')) {
41
+ // Track that we have entered an after hook.
42
+ state.isInAfterHook = true;
43
+ } else if ((event.name === 'hook_success' || event.name === 'hook_failure') && event.hook.type.startsWith('after')) {
44
+ // Reset the flag that we are in an after hook when we exit it.
45
+ state.isInAfterHook = false;
46
+ }
47
+ }
48
+ }
@@ -1,7 +1,10 @@
1
+ import { parseBooleanEnv } from '@aztec/foundation/config';
1
2
  import { overwriteLoggingStream, pinoPrettyOpts } from '@aztec/foundation/log';
2
3
  import pretty from 'pino-pretty';
3
4
  // Overwrite logging stream with pino-pretty. We define this as a separate
4
5
  // file so we don't mess up with dependencies in non-testing environments,
5
6
  // since pino-pretty messes up with browser bundles.
6
7
  // See also https://www.npmjs.com/package/pino-pretty?activeTab=readme#user-content-usage-with-jest
7
- overwriteLoggingStream(pretty(pinoPrettyOpts));
8
+ if (!parseBooleanEnv(process.env.LOG_JSON)) {
9
+ overwriteLoggingStream(pretty(pinoPrettyOpts));
10
+ }
@@ -0,0 +1,3 @@
1
+ if (Array.isArray(globalThis.__extraEqualityTesters)) {
2
+ expect.addEqualityTesters(globalThis.__extraEqualityTesters);
3
+ }
@@ -1,5 +1,5 @@
1
1
  import { type Logger } from '../../log/index.js';
2
- export type JsonRpcFetch = (host: string, rpcMethod: string, body: any, useApiEndpoints: boolean, extraHeaders?: Record<string, string>, noRetry?: boolean) => Promise<{
2
+ export type JsonRpcFetch = (host: string, body: any, extraHeaders?: Record<string, string>, noRetry?: boolean) => Promise<{
3
3
  response: any;
4
4
  headers: {
5
5
  get: (header: string) => string | null | undefined;
@@ -15,7 +15,7 @@ export type JsonRpcFetch = (host: string, rpcMethod: string, body: any, useApiEn
15
15
  * message (see `retry` function for more details).
16
16
  * @returns The parsed JSON response, or throws an error.
17
17
  */
18
- export declare function defaultFetch(host: string, rpcMethod: string, body: any, useApiEndpoints: boolean, extraHeaders?: Record<string, string>, noRetry?: boolean): Promise<{
18
+ export declare function defaultFetch(host: string, body: unknown, extraHeaders?: Record<string, string>, noRetry?: boolean): Promise<{
19
19
  response: any;
20
20
  headers: {
21
21
  get: (header: string) => string | null | undefined;
@@ -29,4 +29,4 @@ export declare function defaultFetch(host: string, rpcMethod: string, body: any,
29
29
  * @returns A fetch function.
30
30
  */
31
31
  export declare function makeFetch(retries: number[], defaultNoRetry: boolean, log?: Logger): typeof defaultFetch;
32
- //# sourceMappingURL=fetch.d.ts.map
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmV0Y2guZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9qc29uLXJwYy9jbGllbnQvZmV0Y2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLG9CQUFvQixDQUFDO0FBTS9ELE1BQU0sTUFBTSxZQUFZLEdBQUcsQ0FDekIsSUFBSSxFQUFFLE1BQU0sRUFDWixJQUFJLEVBQUUsR0FBRyxFQUNULFlBQVksQ0FBQyxFQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLEVBQ3JDLE9BQU8sQ0FBQyxFQUFFLE9BQU8sS0FDZCxPQUFPLENBQUM7SUFBRSxRQUFRLEVBQUUsR0FBRyxDQUFDO0lBQUMsT0FBTyxFQUFFO1FBQUUsR0FBRyxFQUFFLENBQUMsTUFBTSxFQUFFLE1BQU0sS0FBSyxNQUFNLEdBQUcsSUFBSSxHQUFHLFNBQVMsQ0FBQTtLQUFFLENBQUE7Q0FBRSxDQUFDLENBQUM7QUFFakc7Ozs7Ozs7OztHQVNHO0FBQ0gsd0JBQXNCLFlBQVksQ0FDaEMsSUFBSSxFQUFFLE1BQU0sRUFDWixJQUFJLEVBQUUsT0FBTyxFQUNiLFlBQVksR0FBRSxNQUFNLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBTSxFQUN6QyxPQUFPLFVBQVEsR0FDZCxPQUFPLENBQUM7SUFBRSxRQUFRLEVBQUUsR0FBRyxDQUFDO0lBQUMsT0FBTyxFQUFFO1FBQUUsR0FBRyxFQUFFLENBQUMsTUFBTSxFQUFFLE1BQU0sS0FBSyxNQUFNLEdBQUcsSUFBSSxHQUFHLFNBQVMsQ0FBQTtLQUFFLENBQUE7Q0FBRSxDQUFDLENBa0M3RjtBQUVEOzs7Ozs7R0FNRztBQUNILHdCQUFnQixTQUFTLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFLGNBQWMsRUFBRSxPQUFPLEVBQUUsR0FBRyxDQUFDLEVBQUUsTUFBTSxHQUFHLE9BQU8sWUFBWSxDQVV2RyJ9
@@ -1 +1 @@
1
- {"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../../src/json-rpc/client/fetch.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,oBAAoB,CAAC;AAM/D,MAAM,MAAM,YAAY,GAAG,CACzB,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,GAAG,EACT,eAAe,EAAE,OAAO,EACxB,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACrC,OAAO,CAAC,EAAE,OAAO,KACd,OAAO,CAAC;IAAE,QAAQ,EAAE,GAAG,CAAC;IAAC,OAAO,EAAE;QAAE,GAAG,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;KAAE,CAAA;CAAE,CAAC,CAAC;AAEjG;;;;;;;;;GASG;AACH,wBAAsB,YAAY,CAChC,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,GAAG,EACT,eAAe,EAAE,OAAO,EACxB,YAAY,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAM,EACzC,OAAO,UAAQ,GACd,OAAO,CAAC;IAAE,QAAQ,EAAE,GAAG,CAAC;IAAC,OAAO,EAAE;QAAE,GAAG,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;KAAE,CAAA;CAAE,CAAC,CA0C7F;AAED;;;;;;GAMG;AACH,wBAAgB,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,cAAc,EAAE,OAAO,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,YAAY,CAiBvG"}
1
+ {"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../../src/json-rpc/client/fetch.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,oBAAoB,CAAC;AAM/D,MAAM,MAAM,YAAY,GAAG,CACzB,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,GAAG,EACT,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACrC,OAAO,CAAC,EAAE,OAAO,KACd,OAAO,CAAC;IAAE,QAAQ,EAAE,GAAG,CAAC;IAAC,OAAO,EAAE;QAAE,GAAG,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;KAAE,CAAA;CAAE,CAAC,CAAC;AAEjG;;;;;;;;;GASG;AACH,wBAAsB,YAAY,CAChC,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,OAAO,EACb,YAAY,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAM,EACzC,OAAO,UAAQ,GACd,OAAO,CAAC;IAAE,QAAQ,EAAE,GAAG,CAAC;IAAC,OAAO,EAAE;QAAE,GAAG,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;KAAE,CAAA;CAAE,CAAC,CAkC7F;AAED;;;;;;GAMG;AACH,wBAAgB,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,cAAc,EAAE,OAAO,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,YAAY,CAUvG"}
@@ -12,47 +12,33 @@ const log = createLogger('json-rpc:json_rpc_client');
12
12
  * @param noRetry - Whether to throw a `NoRetryError` in case the response is a 5xx error and the body contains an error
13
13
  * message (see `retry` function for more details).
14
14
  * @returns The parsed JSON response, or throws an error.
15
- */ export async function defaultFetch(host, rpcMethod, body, useApiEndpoints, extraHeaders = {}, noRetry = false) {
16
- log.debug(format(`JsonRpcClient.fetch`, host, rpcMethod, '->', body));
15
+ */ export async function defaultFetch(host, body, extraHeaders = {}, noRetry = false) {
16
+ log.debug(format(`JsonRpcClient.fetch`, host, '->', body));
17
17
  let resp;
18
18
  try {
19
- if (useApiEndpoints) {
20
- resp = await fetch(`${host}/${rpcMethod}`, {
21
- method: 'POST',
22
- body: jsonStringify(body),
23
- headers: {
24
- 'content-type': 'application/json',
25
- ...extraHeaders
26
- }
27
- });
28
- } else {
29
- resp = await fetch(host, {
30
- method: 'POST',
31
- body: jsonStringify({
32
- ...body,
33
- method: rpcMethod
34
- }),
35
- headers: {
36
- 'content-type': 'application/json',
37
- ...extraHeaders
38
- }
39
- });
40
- }
19
+ resp = await fetch(host, {
20
+ method: 'POST',
21
+ body: jsonStringify(body),
22
+ headers: {
23
+ 'content-type': 'application/json',
24
+ ...extraHeaders
25
+ }
26
+ });
41
27
  } catch (err) {
42
- const errorMessage = `Error fetching from host ${host} with method ${rpcMethod}: ${inspect(err)}`;
28
+ const errorMessage = `Error fetching from host ${host}: ${inspect(err)}`;
43
29
  throw new Error(errorMessage);
44
30
  }
45
31
  let responseJson;
46
32
  try {
47
33
  responseJson = await resp.json();
48
- } catch (err) {
34
+ } catch {
49
35
  if (!resp.ok) {
50
36
  throw new Error(resp.statusText);
51
37
  }
52
- throw new Error(`Failed to parse body as JSON: ${resp.text()}`);
38
+ throw new Error(`Failed to parse body as JSON: ${await resp.text()}`);
53
39
  }
54
40
  if (!resp.ok) {
55
- const errorMessage = `Error ${resp.status} from server ${host} on ${rpcMethod}: ${responseJson.error.message}`;
41
+ const errorMessage = `Error ${resp.status} from server ${host}: ${responseJson.error.message}`;
56
42
  if (noRetry || resp.status >= 400 && resp.status < 500) {
57
43
  throw new NoRetryError(errorMessage);
58
44
  } else {
@@ -71,7 +57,7 @@ const log = createLogger('json-rpc:json_rpc_client');
71
57
  * @param log - Optional logger for logging attempts.
72
58
  * @returns A fetch function.
73
59
  */ export function makeFetch(retries, defaultNoRetry, log) {
74
- return async (host, rpcMethod, body, useApiEndpoints, extraHeaders = {}, noRetry)=>{
75
- return await retry(()=>defaultFetch(host, rpcMethod, body, useApiEndpoints, extraHeaders, noRetry ?? defaultNoRetry), `JsonRpcClient request ${rpcMethod} to ${host}`, makeBackoff(retries), log, false);
60
+ return async (host, body, extraHeaders = {}, noRetry)=>{
61
+ return await retry(()=>defaultFetch(host, body, extraHeaders, noRetry ?? defaultNoRetry), `JsonRpcClient request to ${host}`, makeBackoff(retries), log, false);
76
62
  };
77
63
  }
@@ -1,3 +1,3 @@
1
1
  export * from './safe_json_rpc_client.js';
2
2
  export * from './fetch.js';
3
- //# sourceMappingURL=index.d.ts.map
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9qc29uLXJwYy9jbGllbnQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLFlBQVksQ0FBQyJ9
@@ -2,10 +2,12 @@ import { type Logger } from '../../log/pino-logger.js';
2
2
  import { type ApiSchemaFor } from '../../schemas/api.js';
3
3
  import { type JsonRpcFetch } from './fetch.js';
4
4
  export type SafeJsonRpcClientOptions = {
5
- useApiEndpoints?: boolean;
6
5
  namespaceMethods?: string | false;
7
6
  fetch?: JsonRpcFetch;
8
7
  log?: Logger;
8
+ batchWindowMS?: number;
9
+ maxBatchSize?: number;
10
+ maxRequestBodySize?: number;
9
11
  onResponse?: (res: {
10
12
  response: any;
11
13
  headers: {
@@ -18,9 +20,13 @@ export type SafeJsonRpcClientOptions = {
18
20
  * The server is expected to be a JsonRpcServer.
19
21
  * @param host - The host URL.
20
22
  * @param schema - The api schema to validate returned data against.
21
- * @param useApiEndpoints - Whether to use the API endpoints or the default RPC endpoint.
22
- * @param namespaceMethods - String value (or false/empty) to namespace all methods sent to the server. e.g. 'getInfo' -\> 'pxe_getInfo'
23
23
  * @param fetch - The fetch implementation to use.
24
24
  */
25
25
  export declare function createSafeJsonRpcClient<T extends object>(host: string, schema: ApiSchemaFor<T>, config?: SafeJsonRpcClientOptions): T;
26
- //# sourceMappingURL=safe_json_rpc_client.d.ts.map
26
+ /**
27
+ * Triggers a batch to be sent immediately
28
+ */
29
+ export declare function batch<T extends readonly unknown[]>(values: T): Promise<{
30
+ -readonly [P in keyof T]: Awaited<T[P]>;
31
+ }>;
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZV9qc29uX3JwY19jbGllbnQuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9qc29uLXJwYy9jbGllbnQvc2FmZV9qc29uX3JwY19jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLDBCQUEwQixDQUFDO0FBRXJFLE9BQU8sRUFBa0IsS0FBSyxZQUFZLEVBQW1CLE1BQU0sc0JBQXNCLENBQUM7QUFFMUYsT0FBTyxFQUFFLEtBQUssWUFBWSxFQUFnQixNQUFNLFlBQVksQ0FBQztBQWE3RCxNQUFNLE1BQU0sd0JBQXdCLEdBQUc7SUFDckMsZ0JBQWdCLENBQUMsRUFBRSxNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ2xDLEtBQUssQ0FBQyxFQUFFLFlBQVksQ0FBQztJQUNyQixHQUFHLENBQUMsRUFBRSxNQUFNLENBQUM7SUFDYixhQUFhLENBQUMsRUFBRSxNQUFNLENBQUM7SUFDdkIsWUFBWSxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ3RCLGtCQUFrQixDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQzVCLFVBQVUsQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFO1FBQ2pCLFFBQVEsRUFBRSxHQUFHLENBQUM7UUFDZCxPQUFPLEVBQUU7WUFBRSxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsTUFBTSxLQUFLLE1BQU0sR0FBRyxJQUFJLEdBQUcsU0FBUyxDQUFBO1NBQUUsQ0FBQztLQUNqRSxLQUFLLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztDQUNyQixDQUFDO0FBNkJGOzs7Ozs7R0FNRztBQUNILHdCQUFnQix1QkFBdUIsQ0FBQyxDQUFDLFNBQVMsTUFBTSxFQUN0RCxJQUFJLEVBQUUsTUFBTSxFQUNaLE1BQU0sRUFBRSxZQUFZLENBQUMsQ0FBQyxDQUFDLEVBQ3ZCLE1BQU0sR0FBRSx3QkFBNkIsR0FDcEMsQ0FBQyxDQW1MSDtBQUVEOztHQUVHO0FBQ0gsd0JBQXNCLEtBQUssQ0FBQyxDQUFDLFNBQVMsU0FBUyxPQUFPLEVBQUUsRUFDdEQsTUFBTSxFQUFFLENBQUMsR0FDUixPQUFPLENBQUM7SUFBRSxDQUFDLFVBQVUsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FBRSxDQUFDLENBdUJ0RCJ9
@@ -1 +1 @@
1
- {"version":3,"file":"safe_json_rpc_client.d.ts","sourceRoot":"","sources":["../../../src/json-rpc/client/safe_json_rpc_client.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,0BAA0B,CAAC;AACrE,OAAO,EAAkB,KAAK,YAAY,EAAmB,MAAM,sBAAsB,CAAC;AAC1F,OAAO,EAAE,KAAK,YAAY,EAAgB,MAAM,YAAY,CAAC;AAE7D,MAAM,MAAM,wBAAwB,GAAG;IACrC,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,gBAAgB,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC;IAClC,KAAK,CAAC,EAAE,YAAY,CAAC;IACrB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,CAAC,GAAG,EAAE;QACjB,QAAQ,EAAE,GAAG,CAAC;QACd,OAAO,EAAE;YAAE,GAAG,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;SAAE,CAAC;KACjE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CACrB,CAAC;AAEF;;;;;;;;GAQG;AACH,wBAAgB,uBAAuB,CAAC,CAAC,SAAS,MAAM,EACtD,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,EACvB,MAAM,GAAE,wBAA6B,GACpC,CAAC,CAoCH"}
1
+ {"version":3,"file":"safe_json_rpc_client.d.ts","sourceRoot":"","sources":["../../../src/json-rpc/client/safe_json_rpc_client.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,0BAA0B,CAAC;AAErE,OAAO,EAAkB,KAAK,YAAY,EAAmB,MAAM,sBAAsB,CAAC;AAE1F,OAAO,EAAE,KAAK,YAAY,EAAgB,MAAM,YAAY,CAAC;AAa7D,MAAM,MAAM,wBAAwB,GAAG;IACrC,gBAAgB,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC;IAClC,KAAK,CAAC,EAAE,YAAY,CAAC;IACrB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,UAAU,CAAC,EAAE,CAAC,GAAG,EAAE;QACjB,QAAQ,EAAE,GAAG,CAAC;QACd,OAAO,EAAE;YAAE,GAAG,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;SAAE,CAAC;KACjE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CACrB,CAAC;AA6BF;;;;;;GAMG;AACH,wBAAgB,uBAAuB,CAAC,CAAC,SAAS,MAAM,EACtD,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,EACvB,MAAM,GAAE,wBAA6B,GACpC,CAAC,CAmLH;AAED;;GAEG;AACH,wBAAsB,KAAK,CAAC,CAAC,SAAS,SAAS,OAAO,EAAE,EACtD,MAAM,EAAE,CAAC,GACR,OAAO,CAAC;IAAE,CAAC,UAAU,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CAAE,CAAC,CAuBtD"}
@@ -1,20 +1,141 @@
1
1
  import { format } from 'util';
2
2
  import { createLogger } from '../../log/pino-logger.js';
3
+ import { promiseWithResolvers } from '../../promise/utils.js';
3
4
  import { schemaHasMethod } from '../../schemas/api.js';
5
+ import { jsonStringify } from '../convert.js';
4
6
  import { defaultFetch } from './fetch.js';
7
+ // batch window of 0 would capture all requests in the current sync iteration of the event loop
8
+ // and send them all at once in a single batch
9
+ // minimal latency
10
+ const DEFAULT_BATCH_WINDOW_MS = 0;
11
+ // the maximum size of a batched request
12
+ const DEFAULT_MAX_BATCH_SIZE = 100;
13
+ // 10 mb
14
+ const DEFAULT_MAX_REQUESTY_BODY_SIZE = 10 * 1024 * 1024;
15
+ // expose helpful information on the RPC clients such that we can recognize them later
16
+ const SEND_BATCH = Symbol('JsonRpcClient.sendBatch');
17
+ const CLIENT_ID = Symbol('JsonRpcClient.clientId');
18
+ let nextClientId = 1;
19
+ // keep a reference to clients so that we can force send a batch
20
+ const clients = new Map();
5
21
  /**
6
22
  * Creates a Proxy object that delegates over RPC and validates outputs against a given schema.
7
23
  * The server is expected to be a JsonRpcServer.
8
24
  * @param host - The host URL.
9
25
  * @param schema - The api schema to validate returned data against.
10
- * @param useApiEndpoints - Whether to use the API endpoints or the default RPC endpoint.
11
- * @param namespaceMethods - String value (or false/empty) to namespace all methods sent to the server. e.g. 'getInfo' -\> 'pxe_getInfo'
12
26
  * @param fetch - The fetch implementation to use.
13
27
  */ export function createSafeJsonRpcClient(host, schema, config = {}) {
14
28
  const fetch = config.fetch ?? defaultFetch;
15
29
  const log = config.log ?? createLogger('json-rpc:client');
16
- const { useApiEndpoints = false, namespaceMethods = false } = config;
30
+ const { namespaceMethods = false, batchWindowMS = DEFAULT_BATCH_WINDOW_MS, maxBatchSize = DEFAULT_MAX_BATCH_SIZE, maxRequestBodySize = DEFAULT_MAX_REQUESTY_BODY_SIZE } = config;
17
31
  let id = 0;
32
+ let sendBatchTimeoutHandle;
33
+ const queue = [];
34
+ const sendBatch = async ()=>{
35
+ if (sendBatchTimeoutHandle !== undefined) {
36
+ clearTimeout(sendBatchTimeoutHandle);
37
+ sendBatchTimeoutHandle = undefined;
38
+ }
39
+ const rpcCalls = [];
40
+ let bodySize = 0;
41
+ while(queue.length > 0 && rpcCalls.length < maxBatchSize && bodySize < maxRequestBodySize){
42
+ const item = queue[0];
43
+ if (!item) {
44
+ break;
45
+ }
46
+ const tmpBodySize = bodySize + item.encodedLength;
47
+ if (tmpBodySize >= maxRequestBodySize) {
48
+ break;
49
+ }
50
+ bodySize = tmpBodySize;
51
+ queue.shift();
52
+ rpcCalls.push(item);
53
+ }
54
+ // no-op
55
+ if (rpcCalls.length === 0) {
56
+ return;
57
+ }
58
+ // schedule another call if there are more items to send
59
+ if (queue.length > 0) {
60
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
61
+ sendBatchTimeoutHandle = setTimeout(sendBatch, batchWindowMS);
62
+ }
63
+ log.debug(`Executing JSON-RPC batch of size: ${rpcCalls.length} body size: ${bodySize} bytes`, {
64
+ methods: rpcCalls.map(({ request })=>request.method)
65
+ });
66
+ try {
67
+ const { response, headers } = await fetch(host, rpcCalls.map(({ request })=>request));
68
+ if (config.onResponse) {
69
+ await config.onResponse({
70
+ response,
71
+ headers
72
+ });
73
+ }
74
+ if (!Array.isArray(response) || response.length !== rpcCalls.length) {
75
+ log.warn(`Invalid response received from JSON-RPC server. Expected array of responses of length ${rpcCalls.length}`, {
76
+ response
77
+ });
78
+ for(let i = 0; i < rpcCalls.length; i++){
79
+ const { request, deferred } = rpcCalls[i];
80
+ deferred.resolve({
81
+ id: request.id,
82
+ jsonrpc: '2.0',
83
+ error: {
84
+ code: -32000,
85
+ data: response,
86
+ message: response.message ?? 'Failed request'
87
+ }
88
+ });
89
+ }
90
+ } else {
91
+ for(let i = 0; i < response.length; i++){
92
+ const resp = response[i];
93
+ const { request, deferred } = rpcCalls[i];
94
+ if (resp.id !== request.id) {
95
+ log.warn(`Invalid response received at index ${i} from JSON-RPC server: id mismatch`, {
96
+ requestMethod: request.method,
97
+ requestId: request.id,
98
+ responseId: resp.id
99
+ });
100
+ deferred.resolve({
101
+ id: request.id,
102
+ jsonrpc: '2.0',
103
+ error: {
104
+ code: -32001,
105
+ data: resp,
106
+ message: 'RPC id mismatch'
107
+ }
108
+ });
109
+ } else {
110
+ deferred.resolve(resp);
111
+ }
112
+ }
113
+ }
114
+ } catch (err) {
115
+ // Re-throw ComponentsVersionsError immediately without converting to JSON-RPC error
116
+ // This ensures version mismatch errors are surfaced to the user instead of being hidden
117
+ if (err && typeof err === 'object' && 'name' in err && err.name === 'ComponentsVersionsError') {
118
+ // Reject all pending requests with the version error
119
+ for(let i = 0; i < rpcCalls.length; i++){
120
+ rpcCalls[i].deferred.reject(err);
121
+ }
122
+ return; // Return early, the promises are already rejected
123
+ }
124
+ log.warn(`Failed to fetch from the remote server`, err);
125
+ for(let i = 0; i < rpcCalls.length; i++){
126
+ const { request, deferred } = rpcCalls[i];
127
+ deferred.resolve({
128
+ id: request.id,
129
+ jsonrpc: '2.0',
130
+ error: {
131
+ code: -32000,
132
+ data: err,
133
+ message: err.message ?? 'Failed request'
134
+ }
135
+ });
136
+ }
137
+ }
138
+ };
18
139
  const request = async (methodName, params)=>{
19
140
  if (!schemaHasMethod(schema, methodName)) {
20
141
  throw new Error(`Unspecified method ${methodName} in client schema`);
@@ -26,18 +147,28 @@ import { defaultFetch } from './fetch.js';
26
147
  method,
27
148
  params
28
149
  };
150
+ const deferred = promiseWithResolvers();
151
+ const encodedLength = jsonStringify(body).length;
152
+ if (encodedLength >= maxRequestBodySize) {
153
+ throw new Error(`Request body too large: ${encodedLength}`);
154
+ }
155
+ queue.push({
156
+ request: body,
157
+ deferred,
158
+ encodedLength
159
+ });
160
+ if (sendBatchTimeoutHandle === undefined) {
161
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
162
+ sendBatchTimeoutHandle = setTimeout(sendBatch, batchWindowMS);
163
+ }
29
164
  log.debug(format(`request`, method, params));
30
- const { response, headers } = await fetch(host, method, body, useApiEndpoints);
165
+ const response = await deferred.promise;
31
166
  log.debug(format(`result`, method, response));
32
- if (config.onResponse) {
33
- await config.onResponse({
34
- response,
35
- headers
167
+ if ('error' in response) {
168
+ throw new Error(response.error.message, {
169
+ cause: response.error
36
170
  });
37
171
  }
38
- if (response.error) {
39
- throw response.error;
40
- }
41
172
  // TODO(palla/schemas): Find a better way to handle null responses (JSON.stringify(null) is string "null").
42
173
  if ([
43
174
  null,
@@ -49,9 +180,38 @@ import { defaultFetch } from './fetch.js';
49
180
  }
50
181
  return schema[methodName].returnType().parseAsync(response.result);
51
182
  };
52
- const proxy = {};
183
+ const clientId = nextClientId++;
184
+ const proxy = {
185
+ [CLIENT_ID]: clientId,
186
+ [SEND_BATCH]: sendBatch
187
+ };
53
188
  for (const method of Object.keys(schema)){
54
- proxy[method] = (...params)=>request(method, params);
189
+ // attach the clientId to the promise so that if we want to trigger a batch immediately, we can do that
190
+ proxy[method] = (...params)=>Object.assign(request(method, params), {
191
+ [CLIENT_ID]: clientId
192
+ });
55
193
  }
194
+ clients.set(clientId, new WeakRef(proxy));
56
195
  return proxy;
57
196
  }
197
+ /**
198
+ * Triggers a batch to be sent immediately
199
+ */ export async function batch(values) {
200
+ const clientIdsSeen = new Set();
201
+ await Promise.allSettled(values.map((val)=>{
202
+ if (typeof val === 'object' && val && Object.hasOwn(val, CLIENT_ID)) {
203
+ const clientId = val[CLIENT_ID];
204
+ if (typeof clientId === 'number') {
205
+ if (clientIdsSeen.has(clientId)) {
206
+ return;
207
+ }
208
+ clientIdsSeen.add(clientId);
209
+ const client = clients.get(clientId)?.deref();
210
+ if (client) {
211
+ return client[SEND_BATCH]();
212
+ }
213
+ }
214
+ }
215
+ }));
216
+ return Promise.all(values);
217
+ }