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

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 (434) 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 +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/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 +53 -0
  15. package/dest/branded-types/block_number.d.ts.map +1 -0
  16. package/dest/branded-types/block_number.js +75 -0
  17. package/dest/branded-types/checkpoint_number.d.ts +46 -0
  18. package/dest/branded-types/checkpoint_number.d.ts.map +1 -0
  19. package/dest/branded-types/checkpoint_number.js +68 -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 +6 -0
  24. package/dest/branded-types/index.d.ts.map +1 -0
  25. package/dest/branded-types/index.js +4 -0
  26. package/dest/branded-types/slot.d.ts +42 -0
  27. package/dest/branded-types/slot.d.ts.map +1 -0
  28. package/dest/branded-types/slot.js +59 -0
  29. package/dest/branded-types/types.d.ts +5 -0
  30. package/dest/branded-types/types.d.ts.map +1 -0
  31. package/dest/branded-types/types.js +1 -0
  32. package/dest/buffer/buffer16.d.ts +2 -5
  33. package/dest/buffer/buffer16.d.ts.map +1 -1
  34. package/dest/buffer/buffer16.js +1 -1
  35. package/dest/buffer/buffer32.d.ts +2 -5
  36. package/dest/buffer/buffer32.d.ts.map +1 -1
  37. package/dest/buffer/buffer32.js +1 -1
  38. package/dest/buffer/index.d.ts +1 -1
  39. package/dest/collection/array.d.ts +1 -1
  40. package/dest/collection/index.d.ts +1 -1
  41. package/dest/collection/object.d.ts +1 -1
  42. package/dest/committable/committable.d.ts +1 -1
  43. package/dest/committable/committable.d.ts.map +1 -1
  44. package/dest/committable/index.d.ts +1 -1
  45. package/dest/config/env_var.d.ts +2 -2
  46. package/dest/config/env_var.d.ts.map +1 -1
  47. package/dest/config/index.d.ts +10 -2
  48. package/dest/config/index.d.ts.map +1 -1
  49. package/dest/config/index.js +16 -2
  50. package/dest/config/network_config.d.ts +13 -1
  51. package/dest/config/network_config.d.ts.map +1 -1
  52. package/dest/config/network_config.js +3 -1
  53. package/dest/config/network_name.d.ts +1 -1
  54. package/dest/config/secret_value.d.ts +1 -1
  55. package/dest/config/secret_value.d.ts.map +1 -1
  56. package/dest/crypto/aes128/index.d.ts +1 -1
  57. package/dest/crypto/aes128/index.d.ts.map +1 -1
  58. package/dest/crypto/aes128/index.js +2 -6
  59. package/dest/crypto/bls/bn254_keystore.d.ts +15 -15
  60. package/dest/crypto/bls/bn254_keystore.d.ts.map +1 -1
  61. package/dest/crypto/bls/bn254_keystore.js +1 -1
  62. package/dest/crypto/bls/index.d.ts +1 -1
  63. package/dest/crypto/bls/index.js +1 -1
  64. package/dest/crypto/bn254/index.d.ts +35 -51
  65. package/dest/crypto/bn254/index.d.ts.map +1 -1
  66. package/dest/crypto/bn254/index.js +51 -137
  67. package/dest/crypto/ecdsa/index.d.ts +1 -1
  68. package/dest/crypto/ecdsa/index.d.ts.map +1 -1
  69. package/dest/crypto/ecdsa/index.js +4 -12
  70. package/dest/crypto/ecdsa/signature.d.ts +2 -11
  71. package/dest/crypto/ecdsa/signature.d.ts.map +1 -1
  72. package/dest/crypto/ecdsa/signature.js +2 -2
  73. package/dest/crypto/grumpkin/index.d.ts +4 -2
  74. package/dest/crypto/grumpkin/index.d.ts.map +1 -1
  75. package/dest/crypto/grumpkin/index.js +7 -16
  76. package/dest/crypto/keccak/index.d.ts +1 -1
  77. package/dest/crypto/keys/index.d.ts +2 -2
  78. package/dest/crypto/keys/index.d.ts.map +1 -1
  79. package/dest/crypto/keys/index.js +2 -4
  80. package/dest/crypto/pedersen/index.d.ts +1 -1
  81. package/dest/crypto/pedersen/pedersen.noble.d.ts +1 -1
  82. package/dest/crypto/pedersen/pedersen.wasm.d.ts +2 -2
  83. package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -1
  84. package/dest/crypto/pedersen/pedersen.wasm.js +4 -10
  85. package/dest/crypto/poseidon/index.d.ts +2 -2
  86. package/dest/crypto/poseidon/index.d.ts.map +1 -1
  87. package/dest/crypto/poseidon/index.js +6 -16
  88. package/dest/crypto/random/index.d.ts +1 -1
  89. package/dest/crypto/random/index.d.ts.map +1 -1
  90. package/dest/crypto/random/randomness_singleton.d.ts +1 -1
  91. package/dest/crypto/random/randomness_singleton.d.ts.map +1 -1
  92. package/dest/crypto/schnorr/index.d.ts +3 -2
  93. package/dest/crypto/schnorr/index.d.ts.map +1 -1
  94. package/dest/crypto/schnorr/index.js +4 -10
  95. package/dest/crypto/schnorr/signature.d.ts +2 -2
  96. package/dest/crypto/schnorr/signature.d.ts.map +1 -1
  97. package/dest/crypto/schnorr/signature.js +2 -2
  98. package/dest/crypto/secp256k1/index.d.ts +1 -1
  99. package/dest/crypto/secp256k1/index.d.ts.map +1 -1
  100. package/dest/crypto/secp256k1/index.js +3 -9
  101. package/dest/crypto/secp256k1-signer/index.d.ts +1 -1
  102. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts +1 -1
  103. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts.map +1 -1
  104. package/dest/crypto/secp256k1-signer/utils.d.ts +1 -1
  105. package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -1
  106. package/dest/crypto/serialize.d.ts +1 -1
  107. package/dest/crypto/sha256/index.d.ts +2 -2
  108. package/dest/crypto/sha256/index.d.ts.map +1 -1
  109. package/dest/crypto/sha256/index.js +1 -1
  110. package/dest/crypto/sha512/index.d.ts +3 -3
  111. package/dest/crypto/sha512/index.d.ts.map +1 -1
  112. package/dest/crypto/sha512/index.js +1 -1
  113. package/dest/crypto/signature/index.d.ts +2 -2
  114. package/dest/crypto/signature/index.d.ts.map +1 -1
  115. package/dest/crypto/sync/index.d.ts +1 -1
  116. package/dest/crypto/sync/index.js +1 -3
  117. package/dest/crypto/sync/pedersen/index.d.ts +2 -2
  118. package/dest/crypto/sync/pedersen/index.d.ts.map +1 -1
  119. package/dest/crypto/sync/pedersen/index.js +1 -1
  120. package/dest/crypto/sync/poseidon/index.d.ts +2 -2
  121. package/dest/crypto/sync/poseidon/index.d.ts.map +1 -1
  122. package/dest/crypto/sync/poseidon/index.js +1 -1
  123. package/dest/{fields/bls12_fields.d.ts → curves/bls12/field.d.ts} +3 -3
  124. package/dest/curves/bls12/field.d.ts.map +1 -0
  125. package/dest/{fields/bls12_fields.js → curves/bls12/field.js} +6 -6
  126. package/dest/curves/bls12/index.d.ts +3 -0
  127. package/dest/curves/bls12/index.d.ts.map +1 -0
  128. package/dest/curves/bls12/index.js +2 -0
  129. package/dest/{fields/bls12_point.d.ts → curves/bls12/point.d.ts} +4 -13
  130. package/dest/curves/bls12/point.d.ts.map +1 -0
  131. package/dest/{fields/bls12_point.js → curves/bls12/point.js} +7 -7
  132. package/dest/{fields/fields.d.ts → curves/bn254/field.d.ts} +16 -15
  133. package/dest/curves/bn254/field.d.ts.map +1 -0
  134. package/dest/{fields/fields.js → curves/bn254/field.js} +44 -47
  135. package/dest/curves/bn254/index.d.ts +3 -0
  136. package/dest/curves/bn254/index.d.ts.map +1 -0
  137. package/dest/curves/bn254/index.js +2 -0
  138. package/dest/curves/bn254/point.d.ts +54 -0
  139. package/dest/curves/bn254/point.d.ts.map +1 -0
  140. package/dest/curves/bn254/point.js +143 -0
  141. package/dest/curves/grumpkin/index.d.ts +10 -0
  142. package/dest/curves/grumpkin/index.d.ts.map +1 -0
  143. package/dest/curves/grumpkin/index.js +3 -0
  144. package/dest/{fields → curves/grumpkin}/point.d.ts +13 -13
  145. package/dest/curves/grumpkin/point.d.ts.map +1 -0
  146. package/dest/{fields → curves/grumpkin}/point.js +24 -7
  147. package/dest/decorators/index.d.ts +1 -1
  148. package/dest/decorators/memoize.d.ts +1 -1
  149. package/dest/decorators/memoize.d.ts.map +1 -1
  150. package/dest/error/index.d.ts +4 -4
  151. package/dest/error/index.d.ts.map +1 -1
  152. package/dest/eth-address/index.d.ts +12 -2
  153. package/dest/eth-address/index.d.ts.map +1 -1
  154. package/dest/eth-address/index.js +23 -1
  155. package/dest/eth-signature/eth_signature.d.ts +1 -4
  156. package/dest/eth-signature/eth_signature.d.ts.map +1 -1
  157. package/dest/eth-signature/index.d.ts +1 -1
  158. package/dest/fs/index.d.ts +1 -1
  159. package/dest/fs/run_in_dir.d.ts +1 -1
  160. package/dest/fs/try_rm_dir.d.ts +1 -1
  161. package/dest/iterable/all.d.ts +1 -1
  162. package/dest/iterable/filter.d.ts +1 -1
  163. package/dest/iterable/index.d.ts +1 -1
  164. package/dest/iterable/isAsyncIt.d.ts +1 -1
  165. package/dest/iterable/map.d.ts +1 -1
  166. package/dest/iterable/peek.d.ts +1 -1
  167. package/dest/iterable/sort.d.ts +1 -1
  168. package/dest/iterable/take.d.ts +1 -1
  169. package/dest/iterable/toArray.d.ts +1 -1
  170. package/dest/iterator/filter.d.ts +3 -0
  171. package/dest/iterator/filter.d.ts.map +1 -0
  172. package/dest/iterator/filter.js +7 -0
  173. package/dest/iterator/index.d.ts +2 -0
  174. package/dest/iterator/index.d.ts.map +1 -0
  175. package/dest/iterator/index.js +1 -0
  176. package/dest/json-rpc/client/fetch.d.ts +1 -1
  177. package/dest/json-rpc/client/index.d.ts +1 -1
  178. package/dest/json-rpc/client/safe_json_rpc_client.d.ts +1 -1
  179. package/dest/json-rpc/client/undici.d.ts +1 -1
  180. package/dest/json-rpc/convert.d.ts +1 -1
  181. package/dest/json-rpc/errors.d.ts +1 -1
  182. package/dest/json-rpc/errors.d.ts.map +1 -1
  183. package/dest/json-rpc/fixtures/class_a.d.ts +3 -3
  184. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -1
  185. package/dest/json-rpc/fixtures/class_b.d.ts +3 -3
  186. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -1
  187. package/dest/json-rpc/fixtures/test_state.d.ts +1 -1
  188. package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -1
  189. package/dest/json-rpc/index.d.ts +1 -1
  190. package/dest/json-rpc/js_utils.d.ts +1 -1
  191. package/dest/json-rpc/js_utils.d.ts.map +1 -1
  192. package/dest/json-rpc/server/index.d.ts +1 -1
  193. package/dest/json-rpc/server/safe_json_rpc_server.d.ts +1 -1
  194. package/dest/json-rpc/server/safe_json_rpc_server.d.ts.map +1 -1
  195. package/dest/json-rpc/server/telemetry.d.ts +1 -1
  196. package/dest/json-rpc/test/index.d.ts +1 -1
  197. package/dest/json-rpc/test/integration.d.ts +1 -1
  198. package/dest/log/console.d.ts +1 -1
  199. package/dest/log/gcloud-logger-config.d.ts +1 -1
  200. package/dest/log/gcloud-logger-config.d.ts.map +1 -1
  201. package/dest/log/index.d.ts +1 -1
  202. package/dest/log/libp2p_logger.d.ts +1 -1
  203. package/dest/log/log-filters.d.ts +1 -1
  204. package/dest/log/log-levels.d.ts +1 -1
  205. package/dest/log/log_fn.d.ts +1 -1
  206. package/dest/log/noir_debug_log_util.d.ts +1 -1
  207. package/dest/log/pino-logger.d.ts +2 -2
  208. package/dest/message/index.d.ts +1 -1
  209. package/dest/message/index.d.ts.map +1 -1
  210. package/dest/mutex/index.d.ts +1 -1
  211. package/dest/mutex/index.d.ts.map +1 -1
  212. package/dest/mutex/mutex_database.d.ts +1 -1
  213. package/dest/noir/index.d.ts +1 -1
  214. package/dest/noir/noir_package_config.d.ts +9 -9
  215. package/dest/number/index.d.ts +1 -1
  216. package/dest/profiler/index.d.ts +1 -1
  217. package/dest/profiler/profiler.d.ts +1 -1
  218. package/dest/promise/index.d.ts +1 -1
  219. package/dest/promise/running-promise.d.ts +1 -1
  220. package/dest/promise/running-promise.d.ts.map +1 -1
  221. package/dest/promise/utils.d.ts +1 -1
  222. package/dest/queue/base_memory_queue.d.ts +1 -1
  223. package/dest/queue/base_memory_queue.d.ts.map +1 -1
  224. package/dest/queue/batch_queue.d.ts +1 -1
  225. package/dest/queue/batch_queue.d.ts.map +1 -1
  226. package/dest/queue/bounded_serial_queue.d.ts +1 -1
  227. package/dest/queue/bounded_serial_queue.d.ts.map +1 -1
  228. package/dest/queue/fifo_memory_queue.d.ts +1 -1
  229. package/dest/queue/fifo_memory_queue.d.ts.map +1 -1
  230. package/dest/queue/index.d.ts +1 -1
  231. package/dest/queue/priority_memory_queue.d.ts +1 -1
  232. package/dest/queue/priority_memory_queue.d.ts.map +1 -1
  233. package/dest/queue/priority_queue.d.ts +1 -1
  234. package/dest/queue/priority_queue.d.ts.map +1 -1
  235. package/dest/queue/semaphore.d.ts +1 -1
  236. package/dest/queue/semaphore.d.ts.map +1 -1
  237. package/dest/queue/serial_queue.d.ts +1 -1
  238. package/dest/queue/serial_queue.d.ts.map +1 -1
  239. package/dest/retry/index.d.ts +1 -1
  240. package/dest/running-promise/index.d.ts +1 -1
  241. package/dest/schemas/api.d.ts +1 -1
  242. package/dest/schemas/index.d.ts +1 -1
  243. package/dest/schemas/parse.d.ts +1 -1
  244. package/dest/schemas/schemas.d.ts +15 -17
  245. package/dest/schemas/schemas.d.ts.map +1 -1
  246. package/dest/schemas/schemas.js +14 -10
  247. package/dest/schemas/types.d.ts +31 -1
  248. package/dest/schemas/types.d.ts.map +1 -1
  249. package/dest/schemas/types.js +25 -1
  250. package/dest/schemas/utils.d.ts +4 -4
  251. package/dest/schemas/utils.d.ts.map +1 -1
  252. package/dest/schemas/utils.js +15 -5
  253. package/dest/serialize/buffer_reader.d.ts +1 -1
  254. package/dest/serialize/buffer_reader.d.ts.map +1 -1
  255. package/dest/serialize/field_reader.d.ts +2 -2
  256. package/dest/serialize/field_reader.d.ts.map +1 -1
  257. package/dest/serialize/field_reader.js +1 -1
  258. package/dest/serialize/free_funcs.d.ts +2 -2
  259. package/dest/serialize/free_funcs.d.ts.map +1 -1
  260. package/dest/serialize/free_funcs.js +1 -1
  261. package/dest/serialize/index.d.ts +1 -1
  262. package/dest/serialize/serialize.d.ts +2 -2
  263. package/dest/serialize/serialize.d.ts.map +1 -1
  264. package/dest/serialize/serialize.js +1 -1
  265. package/dest/serialize/type_registry.d.ts +1 -1
  266. package/dest/serialize/type_registry.d.ts.map +1 -1
  267. package/dest/serialize/types.d.ts +1 -1
  268. package/dest/sleep/index.d.ts +3 -1
  269. package/dest/sleep/index.d.ts.map +1 -1
  270. package/dest/sleep/index.js +4 -0
  271. package/dest/string/index.d.ts +1 -1
  272. package/dest/testing/files/index.d.ts +2 -1
  273. package/dest/testing/files/index.d.ts.map +1 -1
  274. package/dest/testing/files/index.js +1 -1
  275. package/dest/testing/formatting.d.ts +1 -1
  276. package/dest/testing/index.d.ts +1 -1
  277. package/dest/testing/port_allocator.d.ts +1 -1
  278. package/dest/testing/snapshot_serializer.d.ts +1 -1
  279. package/dest/testing/test_data.d.ts +1 -1
  280. package/dest/timer/date.d.ts +2 -1
  281. package/dest/timer/date.d.ts.map +1 -1
  282. package/dest/timer/date.js +3 -0
  283. package/dest/timer/elapsed.d.ts +1 -1
  284. package/dest/timer/index.d.ts +1 -1
  285. package/dest/timer/timeout.d.ts +1 -1
  286. package/dest/timer/timeout.d.ts.map +1 -1
  287. package/dest/timer/timer.d.ts +1 -1
  288. package/dest/timer/timer.d.ts.map +1 -1
  289. package/dest/transport/dispatch/create_dispatch_fn.d.ts +1 -1
  290. package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -1
  291. package/dest/transport/dispatch/create_dispatch_proxy.d.ts +1 -1
  292. package/dest/transport/dispatch/messages.d.ts +1 -1
  293. package/dest/transport/index.d.ts +1 -1
  294. package/dest/transport/interface/connector.d.ts +1 -1
  295. package/dest/transport/interface/listener.d.ts +1 -1
  296. package/dest/transport/interface/socket.d.ts +1 -1
  297. package/dest/transport/interface/transferable.d.ts +1 -1
  298. package/dest/transport/node/index.d.ts +1 -1
  299. package/dest/transport/node/node_connector.d.ts +1 -1
  300. package/dest/transport/node/node_connector.d.ts.map +1 -1
  301. package/dest/transport/node/node_connector_socket.d.ts +1 -1
  302. package/dest/transport/node/node_connector_socket.d.ts.map +1 -1
  303. package/dest/transport/node/node_listener.d.ts +1 -1
  304. package/dest/transport/node/node_listener.d.ts.map +1 -1
  305. package/dest/transport/node/node_listener_socket.d.ts +1 -1
  306. package/dest/transport/node/node_listener_socket.d.ts.map +1 -1
  307. package/dest/transport/transport_client.d.ts +1 -1
  308. package/dest/transport/transport_client.d.ts.map +1 -1
  309. package/dest/transport/transport_server.d.ts +1 -10
  310. package/dest/transport/transport_server.d.ts.map +1 -1
  311. package/dest/trees/balanced_merkle_tree.d.ts +22 -0
  312. package/dest/trees/balanced_merkle_tree.d.ts.map +1 -0
  313. package/dest/trees/balanced_merkle_tree.js +66 -0
  314. package/dest/trees/hasher.d.ts +1 -1
  315. package/dest/trees/index.d.ts +2 -1
  316. package/dest/trees/index.d.ts.map +1 -1
  317. package/dest/trees/index.js +1 -0
  318. package/dest/trees/indexed_merkle_tree.d.ts +1 -1
  319. package/dest/trees/indexed_merkle_tree.d.ts.map +1 -1
  320. package/dest/trees/indexed_merkle_tree.js +1 -1
  321. package/dest/trees/indexed_merkle_tree_calculator.d.ts +1 -1
  322. package/dest/trees/indexed_merkle_tree_calculator.d.ts.map +1 -1
  323. package/dest/trees/indexed_tree_leaf.d.ts +1 -1
  324. package/dest/trees/membership_witness.d.ts +3 -24
  325. package/dest/trees/membership_witness.d.ts.map +1 -1
  326. package/dest/trees/membership_witness.js +1 -1
  327. package/dest/trees/merkle_tree.d.ts +1 -1
  328. package/dest/trees/merkle_tree.d.ts.map +1 -1
  329. package/dest/trees/merkle_tree_calculator.d.ts +2 -12
  330. package/dest/trees/merkle_tree_calculator.d.ts.map +1 -1
  331. package/dest/trees/merkle_tree_calculator.js +1 -31
  332. package/dest/trees/sibling_path.d.ts +5 -39
  333. package/dest/trees/sibling_path.d.ts.map +1 -1
  334. package/dest/trees/sibling_path.js +2 -2
  335. package/dest/trees/unbalanced_merkle_tree.d.ts +5 -3
  336. package/dest/trees/unbalanced_merkle_tree.d.ts.map +1 -1
  337. package/dest/trees/unbalanced_merkle_tree.js +32 -9
  338. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts +6 -5
  339. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts.map +1 -1
  340. package/dest/trees/unbalanced_merkle_tree_calculator.js +36 -40
  341. package/dest/trees/unbalanced_tree_store.d.ts +1 -1
  342. package/dest/trees/unbalanced_tree_store.d.ts.map +1 -1
  343. package/dest/types/index.d.ts +3 -1
  344. package/dest/types/index.d.ts.map +1 -1
  345. package/dest/types/index.js +3 -0
  346. package/dest/url/index.d.ts +1 -1
  347. package/dest/validation/index.d.ts +1 -1
  348. package/package.json +28 -8
  349. package/src/array/array.ts +0 -16
  350. package/src/array/index.ts +1 -0
  351. package/src/array/sorted_array.ts +133 -0
  352. package/src/branded-types/block_number.ts +112 -0
  353. package/src/branded-types/checkpoint_number.ts +100 -0
  354. package/src/branded-types/epoch.ts +88 -0
  355. package/src/branded-types/index.ts +6 -0
  356. package/src/branded-types/slot.ts +88 -0
  357. package/src/branded-types/types.ts +2 -0
  358. package/src/buffer/buffer16.ts +2 -2
  359. package/src/buffer/buffer32.ts +2 -2
  360. package/src/config/env_var.ts +27 -7
  361. package/src/config/index.ts +20 -2
  362. package/src/config/network_config.ts +2 -0
  363. package/src/crypto/aes128/index.ts +2 -2
  364. package/src/crypto/bls/bn254_keystore.ts +1 -1
  365. package/src/crypto/bls/index.ts +1 -1
  366. package/src/crypto/bn254/index.ts +50 -156
  367. package/src/crypto/ecdsa/index.ts +4 -4
  368. package/src/crypto/ecdsa/signature.ts +2 -2
  369. package/src/crypto/grumpkin/index.ts +8 -6
  370. package/src/crypto/keys/index.ts +2 -2
  371. package/src/crypto/pedersen/pedersen.wasm.ts +4 -4
  372. package/src/crypto/poseidon/index.ts +6 -6
  373. package/src/crypto/schnorr/index.ts +5 -4
  374. package/src/crypto/schnorr/signature.ts +2 -2
  375. package/src/crypto/secp256k1/index.ts +3 -3
  376. package/src/crypto/sha256/index.ts +1 -1
  377. package/src/crypto/sha512/index.ts +1 -1
  378. package/src/crypto/signature/index.ts +1 -1
  379. package/src/crypto/sync/index.ts +1 -1
  380. package/src/crypto/sync/pedersen/index.ts +1 -1
  381. package/src/crypto/sync/poseidon/index.ts +1 -1
  382. package/src/{fields/bls12_fields.ts → curves/bls12/field.ts} +6 -6
  383. package/src/curves/bls12/index.ts +2 -0
  384. package/src/{fields/bls12_point.ts → curves/bls12/point.ts} +7 -7
  385. package/src/{fields/fields.ts → curves/bn254/field.ts} +49 -56
  386. package/src/curves/bn254/index.ts +2 -0
  387. package/src/curves/bn254/point.ts +170 -0
  388. package/src/curves/grumpkin/index.ts +11 -0
  389. package/src/{fields → curves/grumpkin}/point.ts +26 -7
  390. package/src/eth-address/index.ts +26 -1
  391. package/src/iterator/filter.ts +11 -0
  392. package/src/iterator/index.ts +1 -0
  393. package/src/schemas/schemas.ts +24 -13
  394. package/src/schemas/types.ts +33 -0
  395. package/src/schemas/utils.ts +21 -8
  396. package/src/serialize/field_reader.ts +1 -1
  397. package/src/serialize/free_funcs.ts +1 -1
  398. package/src/serialize/serialize.ts +1 -1
  399. package/src/sleep/index.ts +6 -0
  400. package/src/testing/files/index.ts +1 -1
  401. package/src/timer/date.ts +4 -0
  402. package/src/trees/balanced_merkle_tree.ts +84 -0
  403. package/src/trees/index.ts +1 -0
  404. package/src/trees/indexed_merkle_tree.ts +1 -1
  405. package/src/trees/membership_witness.ts +1 -1
  406. package/src/trees/merkle_tree_calculator.ts +1 -34
  407. package/src/trees/sibling_path.ts +2 -2
  408. package/src/trees/unbalanced_merkle_tree.ts +54 -6
  409. package/src/trees/unbalanced_merkle_tree_calculator.ts +34 -41
  410. package/src/types/index.ts +5 -0
  411. package/dest/crypto/bn254/bn254_utils.d.ts +0 -39
  412. package/dest/crypto/bn254/bn254_utils.d.ts.map +0 -1
  413. package/dest/crypto/bn254/bn254_utils.js +0 -56
  414. package/dest/crypto/index.d.ts +0 -17
  415. package/dest/crypto/index.d.ts.map +0 -1
  416. package/dest/crypto/index.js +0 -16
  417. package/dest/fields/bls12_fields.d.ts.map +0 -1
  418. package/dest/fields/bls12_point.d.ts.map +0 -1
  419. package/dest/fields/coordinate.d.ts +0 -66
  420. package/dest/fields/coordinate.d.ts.map +0 -1
  421. package/dest/fields/coordinate.js +0 -96
  422. package/dest/fields/fields.d.ts.map +0 -1
  423. package/dest/fields/index.d.ts +0 -6
  424. package/dest/fields/index.d.ts.map +0 -1
  425. package/dest/fields/index.js +0 -5
  426. package/dest/fields/point.d.ts.map +0 -1
  427. package/dest/index.d.ts +0 -30
  428. package/dest/index.d.ts.map +0 -1
  429. package/dest/index.js +0 -30
  430. package/src/crypto/bn254/bn254_utils.ts +0 -64
  431. package/src/crypto/index.ts +0 -16
  432. package/src/fields/coordinate.ts +0 -104
  433. package/src/fields/index.ts +0 -5
  434. package/src/index.ts +0 -30
@@ -2,13 +2,11 @@ import { BarretenbergSync } from '@aztec/bb.js';
2
2
 
3
3
  import { inspect } from 'util';
4
4
 
5
- import { toBigIntBE, toBufferBE } from '../bigint-buffer/index.js';
6
- import { randomBytes } from '../crypto/random/index.js';
7
- import { hexSchemaFor } from '../schemas/utils.js';
8
- import { BufferReader } from '../serialize/buffer_reader.js';
9
- import { TypeRegistry } from '../serialize/type_registry.js';
10
-
11
- const ZERO_BUFFER = Buffer.alloc(32);
5
+ import { toBigIntBE, toBufferBE } from '../../bigint-buffer/index.js';
6
+ import { randomBytes } from '../../crypto/random/index.js';
7
+ import { hexSchemaFor } from '../../schemas/utils.js';
8
+ import { BufferReader } from '../../serialize/buffer_reader.js';
9
+ import { TypeRegistry } from '../../serialize/type_registry.js';
12
10
 
13
11
  /* eslint-disable @typescript-eslint/no-unsafe-declaration-merging */
14
12
 
@@ -25,14 +23,12 @@ type DerivedField<T extends BaseField> = {
25
23
 
26
24
  /**
27
25
  * Base field class.
28
- * Conversions from Buffer to BigInt and vice-versa are not cheap.
29
- * We allow construction with either form and lazily convert to other as needed.
30
- * We only check we are within the field modulus when initializing with bigint.
26
+ * Uses bigint as the internal representation.
27
+ * Buffers are generated on demand from the bigint value.
31
28
  */
32
29
  abstract class BaseField {
33
30
  static SIZE_IN_BYTES = 32;
34
- private asBuffer?: Buffer;
35
- private asBigInt?: bigint;
31
+ private readonly asBigInt: bigint;
36
32
 
37
33
  /**
38
34
  * Return bigint representation.
@@ -52,53 +48,41 @@ abstract class BaseField {
52
48
  if (value.length > BaseField.SIZE_IN_BYTES) {
53
49
  throw new Error(`Value length ${value.length} exceeds ${BaseField.SIZE_IN_BYTES}`);
54
50
  }
55
- this.asBuffer =
56
- value.length === BaseField.SIZE_IN_BYTES
57
- ? value
58
- : Buffer.concat([Buffer.alloc(BaseField.SIZE_IN_BYTES - value.length), value]);
51
+ this.asBigInt = toBigIntBE(value);
59
52
  } else if (typeof value === 'bigint' || typeof value === 'number' || typeof value === 'boolean') {
60
53
  this.asBigInt = BigInt(value);
61
- if (this.asBigInt >= this.modulus()) {
62
- throw new Error(`Value 0x${this.asBigInt.toString(16)} is greater or equal to field modulus.`);
63
- } else if (this.asBigInt < 0n) {
64
- throw new Error(`Value 0x${this.asBigInt.toString(16)} is negative.`);
65
- }
66
54
  } else if (value instanceof BaseField) {
67
- this.asBuffer = value.asBuffer;
68
55
  this.asBigInt = value.asBigInt;
69
56
  } else {
70
57
  throw new Error(`Type '${typeof value}' with value '${value}' passed to BaseField ctor.`);
71
58
  }
59
+
60
+ if (this.asBigInt < 0n) {
61
+ throw new Error(`Value 0x${this.asBigInt.toString(16)} is negative.`);
62
+ } else if (this.asBigInt >= this.modulus()) {
63
+ throw new Error(`Value 0x${this.asBigInt.toString(16)} is greater or equal to field modulus.`);
64
+ }
72
65
  }
73
66
 
74
67
  protected abstract modulus(): bigint;
75
68
 
76
69
  /**
77
- * We return a copy of the Buffer to ensure this remains immutable.
70
+ * Converts the bigint to a Buffer.
78
71
  */
79
72
  toBuffer(): Buffer {
80
- if (!this.asBuffer) {
81
- this.asBuffer = toBufferBE(this.asBigInt!, 32);
82
- }
83
- return Buffer.from(this.asBuffer);
73
+ return toBufferBE(this.asBigInt, 32);
84
74
  }
85
75
 
86
76
  toString(): `0x${string}` {
87
- return `0x${this.toBuffer().toString('hex')}`;
77
+ return `0x${this.asBigInt.toString(16).padStart(64, '0')}`;
88
78
  }
89
79
 
90
80
  toBigInt(): bigint {
91
- if (this.asBigInt === undefined) {
92
- this.asBigInt = toBigIntBE(this.asBuffer!);
93
- if (this.asBigInt >= this.modulus()) {
94
- throw new Error(`Value 0x${this.asBigInt.toString(16)} is greater or equal to field modulus.`);
95
- }
96
- }
97
81
  return this.asBigInt;
98
82
  }
99
83
 
100
84
  toBool(): boolean {
101
- return Boolean(this.toBigInt());
85
+ return this.asBigInt !== 0n;
102
86
  }
103
87
 
104
88
  /**
@@ -106,11 +90,10 @@ abstract class BaseField {
106
90
  * Throws if the underlying value is greater than MAX_SAFE_INTEGER.
107
91
  */
108
92
  toNumber(): number {
109
- const value = this.toBigInt();
110
- if (value > Number.MAX_SAFE_INTEGER) {
111
- throw new Error(`Value ${value.toString(16)} greater than than max safe integer`);
93
+ if (this.asBigInt > Number.MAX_SAFE_INTEGER) {
94
+ throw new Error(`Value ${this.asBigInt.toString(16)} greater than than max safe integer`);
112
95
  }
113
- return Number(value);
96
+ return Number(this.asBigInt);
114
97
  }
115
98
 
116
99
  /**
@@ -118,8 +101,7 @@ abstract class BaseField {
118
101
  * May cause loss of precision if the underlying value is greater than MAX_SAFE_INTEGER.
119
102
  */
120
103
  toNumberUnsafe(): number {
121
- const value = this.toBigInt();
122
- return Number(value);
104
+ return Number(this.asBigInt);
123
105
  }
124
106
 
125
107
  toShortString(): string {
@@ -128,21 +110,24 @@ abstract class BaseField {
128
110
  }
129
111
 
130
112
  equals(rhs: BaseField): boolean {
131
- return this.toBuffer().equals(rhs.toBuffer());
113
+ return this.asBigInt === rhs.asBigInt;
132
114
  }
133
115
 
134
116
  lt(rhs: BaseField): boolean {
135
- return this.toBigInt() < rhs.toBigInt();
117
+ return this.asBigInt < rhs.asBigInt;
136
118
  }
137
119
 
138
120
  cmp(rhs: BaseField): -1 | 0 | 1 {
139
- const lhsBigInt = this.toBigInt();
140
- const rhsBigInt = rhs.toBigInt();
141
- return lhsBigInt === rhsBigInt ? 0 : lhsBigInt < rhsBigInt ? -1 : 1;
121
+ const rhsBigInt = rhs.asBigInt;
122
+ return this.asBigInt === rhsBigInt ? 0 : this.asBigInt < rhsBigInt ? -1 : 1;
123
+ }
124
+
125
+ static cmp(lhs: BaseField, rhs: BaseField): -1 | 0 | 1 {
126
+ return lhs.cmp(rhs);
142
127
  }
143
128
 
144
129
  isZero(): boolean {
145
- return this.toBuffer().equals(ZERO_BUFFER);
130
+ return this.asBigInt === 0n;
146
131
  }
147
132
 
148
133
  isEmpty(): boolean {
@@ -195,7 +180,7 @@ function fromHexString<T extends BaseField>(buf: string, f: DerivedField<T>) {
195
180
 
196
181
  const buffer = Buffer.from(checked.length % 2 === 1 ? '0' + checked : checked, 'hex');
197
182
 
198
- return new f(buffer);
183
+ return new f(toBigIntBE(buffer));
199
184
  }
200
185
 
201
186
  /** Branding to ensure fields are not interchangeable types. */
@@ -335,7 +320,23 @@ export class Fr extends BaseField {
335
320
  return this.toString();
336
321
  }
337
322
 
323
+ /**
324
+ * Creates an Fr instance from a plain object without Zod validation.
325
+ * This method is optimized for performance and skips validation, making it suitable
326
+ * for deserializing trusted data (e.g., from C++ via MessagePack).
327
+ * Handles buffers, strings, numbers, bigints, or existing instances.
328
+ * @param obj - Plain object, buffer, string, number, bigint, boolean, or Fr instance
329
+ * @returns An Fr instance
330
+ */
331
+ static fromPlainObject(obj: any): Fr {
332
+ if (obj instanceof Fr) {
333
+ return obj;
334
+ }
335
+ return new Fr(obj);
336
+ }
337
+
338
338
  static get schema() {
339
+ // Serialization from hex string.
339
340
  return hexSchemaFor(Fr);
340
341
  }
341
342
  }
@@ -495,14 +496,6 @@ function extendedEuclidean(a: bigint, modulus: bigint): [bigint, bigint, bigint]
495
496
  }
496
497
  }
497
498
 
498
- /**
499
- * GrumpkinScalar is an Fq.
500
- * @remarks Called GrumpkinScalar because it is used to represent elements in Grumpkin's scalar field as defined in
501
- * the Aztec Protocol Specs.
502
- */
503
- export type GrumpkinScalar = Fq;
504
- export const GrumpkinScalar = Fq;
505
-
506
499
  /** Wraps a function that returns a buffer so that all results are reduced into a field of the given type. */
507
500
  export function reduceFn<TInput, TField extends BaseField>(fn: (input: TInput) => Buffer, field: DerivedField<TField>) {
508
501
  return (input: TInput) => fromBufferReduce(fn(input), field);
@@ -0,0 +1,2 @@
1
+ export * from './field.js';
2
+ export * from './point.js';
@@ -0,0 +1,170 @@
1
+ import {
2
+ BN254_G1_GENERATOR,
3
+ BN254_G2_GENERATOR,
4
+ BarretenbergSync,
5
+ type Bn254G1Point as BbApiBn254G1Point,
6
+ type Bn254G2Point as BbApiBn254G2Point,
7
+ } from '@aztec/bb.js';
8
+
9
+ import { Fq, Fr } from './field.js';
10
+
11
+ /**
12
+ * BN254 G1 point using foundation field classes.
13
+ * Represents a point on the BN254 elliptic curve in affine coordinates.
14
+ */
15
+ export class Bn254G1Point {
16
+ constructor(
17
+ public readonly x: Fq,
18
+ public readonly y: Fq,
19
+ ) {}
20
+
21
+ private toBbApiPoint(): BbApiBn254G1Point {
22
+ return {
23
+ x: this.x.toBuffer(),
24
+ y: this.y.toBuffer(),
25
+ };
26
+ }
27
+
28
+ private static fromBbApiPoint(point: BbApiBn254G1Point): Bn254G1Point {
29
+ return new Bn254G1Point(Fq.fromBuffer(Buffer.from(point.x)), Fq.fromBuffer(Buffer.from(point.y)));
30
+ }
31
+
32
+ async isOnCurve(): Promise<boolean> {
33
+ await BarretenbergSync.initSingleton();
34
+ const api = BarretenbergSync.getSingleton();
35
+
36
+ const apiPoint = this.toBbApiPoint();
37
+ const response = api.bn254G1IsOnCurve({ point: apiPoint });
38
+ return response.isOnCurve;
39
+ }
40
+
41
+ /**
42
+ * Get the generator point for BN254 G1, or perform scalar multiplication.
43
+ * When called without arguments, returns the base generator point.
44
+ * When called with a scalar, returns scalar * generator (useful for public key derivation).
45
+ */
46
+ static async generator(scalar?: Fr): Promise<Bn254G1Point> {
47
+ if (!scalar) {
48
+ return new Bn254G1Point(
49
+ Fq.fromBuffer(Buffer.from(BN254_G1_GENERATOR.x)),
50
+ Fq.fromBuffer(Buffer.from(BN254_G1_GENERATOR.y)),
51
+ );
52
+ }
53
+
54
+ await BarretenbergSync.initSingleton();
55
+ const api = BarretenbergSync.getSingleton();
56
+
57
+ const response = api.bn254G1Mul({
58
+ point: BN254_G1_GENERATOR,
59
+ scalar: scalar.toBuffer(),
60
+ });
61
+
62
+ return Bn254G1Point.fromBbApiPoint(response.point);
63
+ }
64
+
65
+ /**
66
+ * Decompress a BN254 G1 point from compressed form (32 bytes).
67
+ * The compressed format encodes the x-coordinate and the sign bit of the y-coordinate
68
+ * in the most significant bit.
69
+ */
70
+ static async fromCompressed(compressed: Buffer): Promise<Bn254G1Point> {
71
+ if (compressed.length !== 32) {
72
+ throw new Error('Invalid compressed point length');
73
+ }
74
+ await BarretenbergSync.initSingleton();
75
+ const api = BarretenbergSync.getSingleton();
76
+
77
+ const response = api.bn254G1FromCompressed({
78
+ compressed: new Uint8Array(compressed),
79
+ });
80
+
81
+ return Bn254G1Point.fromBbApiPoint(response.point);
82
+ }
83
+
84
+ /**
85
+ * Compress this BN254 G1 point to 32 bytes.
86
+ * The compressed format encodes the x-coordinate and the sign bit of the y-coordinate
87
+ * in the most significant bit (bit 255).
88
+ */
89
+ compress(): Buffer {
90
+ const xBytes = this.x.toBuffer();
91
+ // Get the least significant bit of y to determine the sign
92
+ const yLsb = this.y.toBigInt() & 1n;
93
+ // If y is odd, set the most significant bit (bit 255) of the output
94
+ if (yLsb === 1n) {
95
+ xBytes[0] |= 0x80;
96
+ }
97
+ return xBytes;
98
+ }
99
+
100
+ equals(other: Bn254G1Point): boolean {
101
+ return this.x.equals(other.x) && this.y.equals(other.y);
102
+ }
103
+
104
+ toString(): string {
105
+ return `Bn254G1Point(x: ${this.x.toString()}, y: ${this.y.toString()})`;
106
+ }
107
+ }
108
+
109
+ /**
110
+ * BN254 G2 point using foundation field classes.
111
+ * Represents a point on the BN254 G2 curve (twist curve) in affine coordinates.
112
+ * G2 points use extension field coordinates (Fq2).
113
+ */
114
+ export class Bn254G2Point {
115
+ constructor(
116
+ public readonly x: [Fq, Fq],
117
+ public readonly y: [Fq, Fq],
118
+ ) {}
119
+
120
+ private toBbApiPoint(): BbApiBn254G2Point {
121
+ return {
122
+ x: [this.x[0].toBuffer(), this.x[1].toBuffer()],
123
+ y: [this.y[0].toBuffer(), this.y[1].toBuffer()],
124
+ };
125
+ }
126
+
127
+ private static fromBbApiPoint(point: BbApiBn254G2Point): Bn254G2Point {
128
+ return new Bn254G2Point(
129
+ [Fq.fromBuffer(Buffer.from(point.x[0])), Fq.fromBuffer(Buffer.from(point.x[1]))],
130
+ [Fq.fromBuffer(Buffer.from(point.y[0])), Fq.fromBuffer(Buffer.from(point.y[1]))],
131
+ );
132
+ }
133
+
134
+ /**
135
+ * Get the generator point for BN254 G2, or perform scalar multiplication.
136
+ * When called without arguments, returns the base generator point.
137
+ * When called with a scalar, returns scalar * generator.
138
+ */
139
+ static async generator(scalar?: Fr): Promise<Bn254G2Point> {
140
+ if (!scalar) {
141
+ return new Bn254G2Point(
142
+ [Fq.fromBuffer(Buffer.from(BN254_G2_GENERATOR.x[0])), Fq.fromBuffer(Buffer.from(BN254_G2_GENERATOR.x[1]))],
143
+ [Fq.fromBuffer(Buffer.from(BN254_G2_GENERATOR.y[0])), Fq.fromBuffer(Buffer.from(BN254_G2_GENERATOR.y[1]))],
144
+ );
145
+ }
146
+
147
+ await BarretenbergSync.initSingleton();
148
+ const api = BarretenbergSync.getSingleton();
149
+
150
+ const response = api.bn254G2Mul({
151
+ point: BN254_G2_GENERATOR as BbApiBn254G2Point,
152
+ scalar: scalar.toBuffer(),
153
+ });
154
+
155
+ return Bn254G2Point.fromBbApiPoint(response.point);
156
+ }
157
+
158
+ equals(other: Bn254G2Point): boolean {
159
+ return (
160
+ this.x[0].equals(other.x[0]) &&
161
+ this.x[1].equals(other.x[1]) &&
162
+ this.y[0].equals(other.y[0]) &&
163
+ this.y[1].equals(other.y[1])
164
+ );
165
+ }
166
+
167
+ toString(): string {
168
+ return `Bn254G2Point(x: (${this.x[0].toString()}, ${this.x[1].toString()}), y: (${this.y[0].toString()}, ${this.y[1].toString()}))`;
169
+ }
170
+ }
@@ -0,0 +1,11 @@
1
+ import { Fq } from '../bn254/field.js';
2
+
3
+ export * from './point.js';
4
+
5
+ /**
6
+ * GrumpkinScalar is an Fq.
7
+ * @remarks Called GrumpkinScalar because it is used to represent elements in Grumpkin's scalar field as defined in
8
+ * the Aztec Protocol Specs.
9
+ */
10
+ export type GrumpkinScalar = Fq;
11
+ export const GrumpkinScalar = Fq;
@@ -1,10 +1,10 @@
1
- import { toBigIntBE } from '../bigint-buffer/index.js';
2
- import { poseidon2Hash } from '../crypto/poseidon/index.js';
3
- import { randomBoolean } from '../crypto/random/index.js';
4
- import { hexSchemaFor } from '../schemas/utils.js';
5
- import { BufferReader, FieldReader, serializeToBuffer } from '../serialize/index.js';
6
- import { bufferToHex, hexToBuffer } from '../string/index.js';
7
- import { Fr } from './fields.js';
1
+ import { toBigIntBE } from '../../bigint-buffer/index.js';
2
+ import { poseidon2Hash } from '../../crypto/poseidon/index.js';
3
+ import { randomBoolean } from '../../crypto/random/index.js';
4
+ import { hexSchemaFor } from '../../schemas/utils.js';
5
+ import { BufferReader, FieldReader, serializeToBuffer } from '../../serialize/index.js';
6
+ import { bufferToHex, hexToBuffer } from '../../string/index.js';
7
+ import { Fr } from '../bn254/field.js';
8
8
 
9
9
  /**
10
10
  * Represents a Point on an elliptic curve with x and y coordinates.
@@ -42,9 +42,28 @@ export class Point {
42
42
  }
43
43
 
44
44
  static get schema() {
45
+ // Serialization from hex string.
45
46
  return hexSchemaFor(Point);
46
47
  }
47
48
 
49
+ /**
50
+ * Creates a Point from a plain object without Zod validation.
51
+ * This method is optimized for performance and skips validation, making it suitable
52
+ * for deserializing trusted data (e.g., from C++ via MessagePack).
53
+ * Handles buffers, existing instances, or objects with x, y, and isInfinite fields.
54
+ * @param obj - Plain object, buffer, or Point instance
55
+ * @returns A Point instance
56
+ */
57
+ static fromPlainObject(obj: any): Point {
58
+ if (obj instanceof Point) {
59
+ return obj;
60
+ }
61
+ if (obj instanceof Buffer || Buffer.isBuffer(obj)) {
62
+ return Point.fromBuffer(obj);
63
+ }
64
+ return new Point(Fr.fromPlainObject(obj.x), Fr.fromPlainObject(obj.y), obj.isInfinite ?? false);
65
+ }
66
+
48
67
  /**
49
68
  * Generate a random Point instance.
50
69
  *
@@ -2,7 +2,7 @@ import { inspect } from 'util';
2
2
 
3
3
  import { keccak256String } from '../crypto/keccak/index.js';
4
4
  import { randomBytes } from '../crypto/random/index.js';
5
- import { Fr } from '../fields/index.js';
5
+ import { Fr } from '../curves/bn254/index.js';
6
6
  import { hexSchemaFor } from '../schemas/utils.js';
7
7
  import { BufferReader, FieldReader } from '../serialize/index.js';
8
8
  import { TypeRegistry } from '../serialize/type_registry.js';
@@ -41,6 +41,24 @@ export class EthAddress {
41
41
  return new EthAddress(Buffer.from(address.replace(/^0x/i, ''), 'hex'));
42
42
  }
43
43
 
44
+ /**
45
+ * Creates an EthAddress from a plain object without Zod validation.
46
+ * This method is optimized for performance and skips validation, making it suitable
47
+ * for deserializing trusted data (e.g., from C++ via MessagePack).
48
+ * Handles buffers (20 or 32 bytes), strings, or existing instances.
49
+ * @param obj - Plain object, buffer, string, or EthAddress instance
50
+ * @returns An EthAddress instance
51
+ */
52
+ public static fromPlainObject(obj: any): EthAddress {
53
+ if (obj instanceof EthAddress) {
54
+ return obj;
55
+ }
56
+ if (obj instanceof Buffer || Buffer.isBuffer(obj)) {
57
+ return obj.length === 20 ? new EthAddress(obj) : EthAddress.fromField(new Fr(obj));
58
+ }
59
+ return EthAddress.fromString(obj);
60
+ }
61
+
44
62
  /**
45
63
  * Create a random EthAddress instance with 20 random bytes.
46
64
  * This method generates a new Ethereum address with a randomly generated set of 20 bytes.
@@ -240,8 +258,15 @@ export class EthAddress {
240
258
  }
241
259
 
242
260
  static get schema() {
261
+ // Serialization from hex string.
243
262
  return hexSchemaFor(EthAddress, EthAddress.isAddress);
244
263
  }
264
+
265
+ static areEqual(a: EthAddress | string, b: EthAddress | string) {
266
+ const addrA = typeof a === 'string' ? EthAddress.fromString(a) : a;
267
+ const addrB = typeof b === 'string' ? EthAddress.fromString(b) : b;
268
+ return addrA.equals(addrB);
269
+ }
245
270
  }
246
271
 
247
272
  // For deserializing JSON.
@@ -0,0 +1,11 @@
1
+ /** Wraps an async iterable iterator such that it filters values based on a predicate. */
2
+ export async function* filter<T>(
3
+ iterator: AsyncIterableIterator<T>,
4
+ predicate: (item: T) => boolean | Promise<boolean>,
5
+ ): AsyncIterableIterator<T> {
6
+ for await (const item of iterator) {
7
+ if (await predicate(item)) {
8
+ yield item;
9
+ }
10
+ }
11
+ }
@@ -0,0 +1 @@
1
+ export { filter } from './filter.js';
@@ -1,14 +1,22 @@
1
1
  import { z } from 'zod';
2
2
 
3
+ import { EpochNumber, EpochNumberSchema } from '../branded-types/epoch.js';
4
+ import { SlotNumber, SlotNumberSchema } from '../branded-types/slot.js';
3
5
  import { Buffer32 } from '../buffer/buffer32.js';
4
6
  import { SecretValue } from '../config/secret_value.js';
7
+ import { Fq, Fr } from '../curves/bn254/field.js';
8
+ import { Point } from '../curves/grumpkin/point.js';
5
9
  import { EthAddress } from '../eth-address/index.js';
6
- import { Fq, Fr } from '../fields/fields.js';
7
- import { Point } from '../fields/point.js';
8
- import { isHex, withoutHexPrefix } from '../string/index.js';
10
+ import { isHex, withHexPrefix, withoutHexPrefix } from '../string/index.js';
9
11
  import { bufferSchema, hexSchema } from './utils.js';
10
12
 
11
13
  export const schemas = {
14
+ /** Accepts a number, bigint, or string as an EpochNumber. */
15
+ EpochNumber: EpochNumberSchema,
16
+
17
+ /** Accepts a number, bigint, or string as a SlotNumber. */
18
+ SlotNumber: SlotNumberSchema,
19
+
12
20
  /** Accepts a hex string. */
13
21
  EthAddress: EthAddress.schema,
14
22
 
@@ -50,19 +58,19 @@ export const schemas = {
50
58
  .max(2 ** 32 - 1),
51
59
  ),
52
60
 
61
+ /** Coerces input to UInt64. */
62
+ UInt64: z.union([z.bigint(), z.number(), z.string()]).pipe(
63
+ z.coerce
64
+ .bigint()
65
+ .min(0n)
66
+ .max(2n ** 64n - 1n),
67
+ ),
68
+
53
69
  /** Accepts a hex string as a Buffer32 type. */
54
70
  Buffer32: z.string().refine(isHex, 'Not a valid hex string').transform(Buffer32.fromString),
55
71
 
56
72
  /** Accepts a base64 string or an object `{ type: 'Buffer', data: [byte, byte...] }` as a buffer. */
57
- Buffer: z.union([
58
- bufferSchema,
59
- z
60
- .object({
61
- type: z.literal('Buffer'),
62
- data: z.array(z.number().int().min(0).max(255)),
63
- })
64
- .transform(({ data }) => Buffer.from(data)),
65
- ]),
73
+ Buffer: bufferSchema,
66
74
 
67
75
  /** Accepts a hex string as a buffer. */
68
76
  BufferHex: z
@@ -74,9 +82,12 @@ export const schemas = {
74
82
  /** Hex string with an optional 0x prefix which gets removed as part of the parsing. */
75
83
  HexString: hexSchema,
76
84
 
85
+ /** Hex string with an optional 0x prefix which gets enforced as part of the parsing. */
86
+ HexStringWith0x: z.string().refine(isHex, 'Not a valid hex string').transform(withHexPrefix),
87
+
77
88
  /** A secret config value */
78
89
  SecretValue: SecretValue.schema,
79
90
  };
80
91
 
81
92
  // These are needed to avoid errors such as: "The inferred type of 'YourClassSchema' cannot be named without a reference to..."
82
- export type { EthAddress, Fq, Fr, Point };
93
+ export type { EpochNumber, EthAddress, Fq, Fr, Point, SlotNumber };
@@ -1,3 +1,36 @@
1
1
  import type { ZodType } from 'zod';
2
2
 
3
3
  export type ZodFor<T> = ZodType<T, any, any>;
4
+
5
+ /**
6
+ * Creates a schema validator that enforces all properties of type T are present in the schema.
7
+ * This provides compile-time safety to ensure schemas don't miss optional properties.
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * interface MyConfig {
12
+ * foo: string;
13
+ * bar?: number;
14
+ * }
15
+ *
16
+ * // ✅ This will work - all keys present
17
+ * const schema1 = zodFor<MyConfig>()(z.object({
18
+ * foo: z.string(),
19
+ * bar: z.number().optional(),
20
+ * }));
21
+ *
22
+ * // ❌ This will error - 'bar' is missing
23
+ * const schema2 = zodFor<MyConfig>()(z.object({
24
+ * foo: z.string(),
25
+ * }));
26
+ * ```
27
+ */
28
+ export function zodFor<T>() {
29
+ return (schema => schema) as <S extends ZodType<any, any, any>>(
30
+ schema: keyof T extends keyof S['_output']
31
+ ? keyof S['_output'] extends keyof T
32
+ ? S
33
+ : S & { __error__: 'Schema has extra keys not in type'; __extra__: Exclude<keyof S['_output'], keyof T> }
34
+ : S & { __error__: 'Schema is missing keys from type'; __missing__: Exclude<keyof T, keyof S['_output']> },
35
+ ) => S;
36
+ }
@@ -21,13 +21,25 @@ export const hexSchema = z.string().refine(isHex, 'Not a valid hex string').tran
21
21
  // Copied from zod internals, which was copied from https://stackoverflow.com/questions/7860392/determine-if-string-is-in-base64-using-javascript
22
22
  const base64Regex = /^([0-9a-zA-Z+/]{4})*(([0-9a-zA-Z+/]{2}==)|([0-9a-zA-Z+/]{3}=))?$/;
23
23
 
24
- /** Schema for a buffer represented as a base64 string. */
25
- export const bufferSchema = z
26
- .string()
27
- // We only test the str for base64 if it's shorter than 1024 bytes, otherwise we've run into maximum
28
- // stack size exceeded errors when trying to validate excessively long strings (such as contract bytecode).
29
- .refine(str => str.length > 1024 || base64Regex.test(str), 'Not a valid base64 string')
30
- .transform(data => Buffer.from(data, 'base64'));
24
+ /** Schema for a buffer represented as a base64 string or a Buffer object. */
25
+ export const bufferSchema: ZodFor<Buffer> = z.union([
26
+ // Serialization from base64 string.
27
+ z
28
+ .string()
29
+ // We only test the str for base64 if it's shorter than 1024 bytes, otherwise we've run into maximum
30
+ // stack size exceeded errors when trying to validate excessively long strings (such as contract bytecode).
31
+ .refine(str => str.length > 1024 || base64Regex.test(str), 'Not a valid base64 string')
32
+ .transform(data => Buffer.from(data, 'base64')),
33
+ // Serialization from Buffer-annotated object.
34
+ z
35
+ .object({
36
+ type: z.literal('Buffer'),
37
+ data: z.array(z.number().int().min(0).max(255)),
38
+ })
39
+ .transform(({ data }) => Buffer.from(data)),
40
+ // Serialization from Buffer
41
+ z.instanceof(Buffer),
42
+ ]);
31
43
 
32
44
  export class ZodNullableOptional<T extends ZodTypeAny> extends ZodOptional<T> {
33
45
  _isNullableOptional = true;
@@ -88,12 +100,13 @@ export function hexSchemaFor<TClass extends { fromString(str: string): any } | {
88
100
  */
89
101
  export function bufferSchemaFor<TClass extends { fromBuffer(buf: Buffer): any }>(
90
102
  klazz: TClass,
103
+ refinement?: (buf: Buffer) => boolean,
91
104
  ): ZodType<
92
105
  TClass extends { fromBuffer(buf: Buffer): infer TInstance } ? ToJsonIs<TInstance, Buffer> : never,
93
106
  any,
94
107
  string
95
108
  > {
96
- return bufferSchema.transform(klazz.fromBuffer.bind(klazz));
109
+ return bufferSchema.refine(refinement ?? (() => true), 'Not a valid buffer').transform(klazz.fromBuffer.bind(klazz));
97
110
  }
98
111
 
99
112
  /** Creates a schema for a js Map type that matches the serialization used in jsonStringify. */
@@ -1,4 +1,4 @@
1
- import { Fq, type Fr } from '../fields/fields.js';
1
+ import { Fq, type Fr } from '../curves/bn254/field.js';
2
2
  import type { Tuple } from './types.js';
3
3
 
4
4
  /**
@@ -1,5 +1,5 @@
1
1
  import { toBufferBE } from '../bigint-buffer/index.js';
2
- import { Fr } from '../fields/fields.js';
2
+ import { Fr } from '../curves/bn254/field.js';
3
3
  import type { Tuple } from './types.js';
4
4
 
5
5
  /**