@aztec/foundation 3.0.0-devnet.6 → 3.0.0-devnet.6-patch.1

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 (411) 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 +1 -1
  5. package/dest/async-map/index.d.ts +1 -1
  6. package/dest/async-pool/index.d.ts +1 -1
  7. package/dest/bigint/index.d.ts +1 -1
  8. package/dest/bigint-buffer/index.d.ts +1 -1
  9. package/dest/branded-types/block_number.d.ts +53 -0
  10. package/dest/branded-types/block_number.d.ts.map +1 -0
  11. package/dest/branded-types/block_number.js +75 -0
  12. package/dest/branded-types/checkpoint_number.d.ts +46 -0
  13. package/dest/branded-types/checkpoint_number.d.ts.map +1 -0
  14. package/dest/branded-types/checkpoint_number.js +68 -0
  15. package/dest/branded-types/epoch.d.ts +42 -0
  16. package/dest/branded-types/epoch.d.ts.map +1 -0
  17. package/dest/branded-types/epoch.js +59 -0
  18. package/dest/branded-types/index.d.ts +6 -0
  19. package/dest/branded-types/index.d.ts.map +1 -0
  20. package/dest/branded-types/index.js +4 -0
  21. package/dest/branded-types/slot.d.ts +42 -0
  22. package/dest/branded-types/slot.d.ts.map +1 -0
  23. package/dest/branded-types/slot.js +59 -0
  24. package/dest/branded-types/types.d.ts +5 -0
  25. package/dest/branded-types/types.d.ts.map +1 -0
  26. package/dest/branded-types/types.js +1 -0
  27. package/dest/buffer/buffer16.d.ts +2 -5
  28. package/dest/buffer/buffer16.d.ts.map +1 -1
  29. package/dest/buffer/buffer16.js +1 -1
  30. package/dest/buffer/buffer32.d.ts +2 -5
  31. package/dest/buffer/buffer32.d.ts.map +1 -1
  32. package/dest/buffer/buffer32.js +1 -1
  33. package/dest/buffer/index.d.ts +1 -1
  34. package/dest/collection/array.d.ts +3 -1
  35. package/dest/collection/array.d.ts.map +1 -1
  36. package/dest/collection/array.js +12 -3
  37. package/dest/collection/index.d.ts +1 -1
  38. package/dest/collection/object.d.ts +1 -1
  39. package/dest/committable/committable.d.ts +1 -1
  40. package/dest/committable/committable.d.ts.map +1 -1
  41. package/dest/committable/index.d.ts +1 -1
  42. package/dest/config/env_var.d.ts +2 -2
  43. package/dest/config/env_var.d.ts.map +1 -1
  44. package/dest/config/index.d.ts +10 -2
  45. package/dest/config/index.d.ts.map +1 -1
  46. package/dest/config/index.js +16 -2
  47. package/dest/config/network_config.d.ts +1 -1
  48. package/dest/config/network_name.d.ts +1 -1
  49. package/dest/config/secret_value.d.ts +1 -1
  50. package/dest/config/secret_value.d.ts.map +1 -1
  51. package/dest/crypto/aes128/index.d.ts +1 -1
  52. package/dest/crypto/aes128/index.d.ts.map +1 -1
  53. package/dest/crypto/aes128/index.js +2 -6
  54. package/dest/crypto/bls/bn254_keystore.d.ts +296 -0
  55. package/dest/crypto/bls/bn254_keystore.d.ts.map +1 -0
  56. package/dest/crypto/bls/bn254_keystore.js +218 -0
  57. package/dest/crypto/bls/index.d.ts +13 -0
  58. package/dest/crypto/bls/index.d.ts.map +1 -0
  59. package/dest/crypto/bls/index.js +87 -0
  60. package/dest/crypto/bn254/index.d.ts +39 -0
  61. package/dest/crypto/bn254/index.d.ts.map +1 -0
  62. package/dest/crypto/bn254/index.js +56 -0
  63. package/dest/crypto/ecdsa/index.d.ts +1 -1
  64. package/dest/crypto/ecdsa/index.d.ts.map +1 -1
  65. package/dest/crypto/ecdsa/index.js +4 -12
  66. package/dest/crypto/ecdsa/signature.d.ts +2 -11
  67. package/dest/crypto/ecdsa/signature.d.ts.map +1 -1
  68. package/dest/crypto/ecdsa/signature.js +2 -2
  69. package/dest/crypto/grumpkin/index.d.ts +10 -13
  70. package/dest/crypto/grumpkin/index.d.ts.map +1 -1
  71. package/dest/crypto/grumpkin/index.js +12 -27
  72. package/dest/crypto/keccak/index.d.ts +1 -1
  73. package/dest/crypto/keys/index.d.ts +2 -2
  74. package/dest/crypto/keys/index.d.ts.map +1 -1
  75. package/dest/crypto/keys/index.js +2 -4
  76. package/dest/crypto/pedersen/index.d.ts +1 -1
  77. package/dest/crypto/pedersen/pedersen.noble.d.ts +1 -1
  78. package/dest/crypto/pedersen/pedersen.wasm.d.ts +2 -2
  79. package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -1
  80. package/dest/crypto/pedersen/pedersen.wasm.js +4 -10
  81. package/dest/crypto/poseidon/index.d.ts +2 -2
  82. package/dest/crypto/poseidon/index.d.ts.map +1 -1
  83. package/dest/crypto/poseidon/index.js +6 -16
  84. package/dest/crypto/random/index.d.ts +1 -1
  85. package/dest/crypto/random/index.d.ts.map +1 -1
  86. package/dest/crypto/random/randomness_singleton.d.ts +1 -1
  87. package/dest/crypto/random/randomness_singleton.d.ts.map +1 -1
  88. package/dest/crypto/schnorr/index.d.ts +3 -2
  89. package/dest/crypto/schnorr/index.d.ts.map +1 -1
  90. package/dest/crypto/schnorr/index.js +4 -10
  91. package/dest/crypto/schnorr/signature.d.ts +2 -2
  92. package/dest/crypto/schnorr/signature.d.ts.map +1 -1
  93. package/dest/crypto/schnorr/signature.js +2 -2
  94. package/dest/crypto/secp256k1/index.d.ts +1 -1
  95. package/dest/crypto/secp256k1/index.d.ts.map +1 -1
  96. package/dest/crypto/secp256k1/index.js +3 -9
  97. package/dest/crypto/secp256k1-signer/index.d.ts +1 -1
  98. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts +1 -1
  99. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts.map +1 -1
  100. package/dest/crypto/secp256k1-signer/utils.d.ts +43 -5
  101. package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -1
  102. package/dest/crypto/secp256k1-signer/utils.js +76 -8
  103. package/dest/crypto/serialize.d.ts +1 -1
  104. package/dest/crypto/sha256/index.d.ts +2 -2
  105. package/dest/crypto/sha256/index.d.ts.map +1 -1
  106. package/dest/crypto/sha256/index.js +1 -1
  107. package/dest/crypto/sha512/index.d.ts +3 -3
  108. package/dest/crypto/sha512/index.d.ts.map +1 -1
  109. package/dest/crypto/sha512/index.js +1 -1
  110. package/dest/crypto/signature/index.d.ts +2 -2
  111. package/dest/crypto/signature/index.d.ts.map +1 -1
  112. package/dest/crypto/sync/index.d.ts +1 -1
  113. package/dest/crypto/sync/index.js +1 -3
  114. package/dest/crypto/sync/pedersen/index.d.ts +2 -2
  115. package/dest/crypto/sync/pedersen/index.d.ts.map +1 -1
  116. package/dest/crypto/sync/pedersen/index.js +1 -1
  117. package/dest/crypto/sync/poseidon/index.d.ts +2 -2
  118. package/dest/crypto/sync/poseidon/index.d.ts.map +1 -1
  119. package/dest/crypto/sync/poseidon/index.js +1 -1
  120. package/dest/{fields/bls12_fields.d.ts → curves/bls12/field.d.ts} +3 -3
  121. package/dest/curves/bls12/field.d.ts.map +1 -0
  122. package/dest/{fields/bls12_fields.js → curves/bls12/field.js} +6 -6
  123. package/dest/curves/bls12/index.d.ts +3 -0
  124. package/dest/curves/bls12/index.d.ts.map +1 -0
  125. package/dest/curves/bls12/index.js +2 -0
  126. package/dest/{fields/bls12_point.d.ts → curves/bls12/point.d.ts} +4 -13
  127. package/dest/curves/bls12/point.d.ts.map +1 -0
  128. package/dest/{fields/bls12_point.js → curves/bls12/point.js} +7 -7
  129. package/dest/{fields/fields.d.ts → curves/bn254/field.d.ts} +16 -9
  130. package/dest/curves/bn254/field.d.ts.map +1 -0
  131. package/dest/{fields/fields.js → curves/bn254/field.js} +35 -9
  132. package/dest/curves/bn254/index.d.ts +3 -0
  133. package/dest/curves/bn254/index.d.ts.map +1 -0
  134. package/dest/curves/bn254/index.js +2 -0
  135. package/dest/curves/bn254/point.d.ts +54 -0
  136. package/dest/curves/bn254/point.d.ts.map +1 -0
  137. package/dest/curves/bn254/point.js +143 -0
  138. package/dest/curves/grumpkin/index.d.ts +10 -0
  139. package/dest/curves/grumpkin/index.d.ts.map +1 -0
  140. package/dest/curves/grumpkin/index.js +3 -0
  141. package/dest/{fields → curves/grumpkin}/point.d.ts +13 -13
  142. package/dest/curves/grumpkin/point.d.ts.map +1 -0
  143. package/dest/{fields → curves/grumpkin}/point.js +24 -7
  144. package/dest/decorators/index.d.ts +1 -1
  145. package/dest/decorators/memoize.d.ts +1 -1
  146. package/dest/decorators/memoize.d.ts.map +1 -1
  147. package/dest/error/index.d.ts +4 -4
  148. package/dest/error/index.d.ts.map +1 -1
  149. package/dest/eth-address/index.d.ts +12 -2
  150. package/dest/eth-address/index.d.ts.map +1 -1
  151. package/dest/eth-address/index.js +23 -1
  152. package/dest/eth-signature/eth_signature.d.ts +1 -4
  153. package/dest/eth-signature/eth_signature.d.ts.map +1 -1
  154. package/dest/eth-signature/index.d.ts +1 -1
  155. package/dest/fs/index.d.ts +1 -1
  156. package/dest/fs/run_in_dir.d.ts +1 -1
  157. package/dest/fs/try_rm_dir.d.ts +1 -1
  158. package/dest/iterable/all.d.ts +1 -1
  159. package/dest/iterable/filter.d.ts +1 -1
  160. package/dest/iterable/index.d.ts +1 -1
  161. package/dest/iterable/isAsyncIt.d.ts +1 -1
  162. package/dest/iterable/map.d.ts +1 -1
  163. package/dest/iterable/peek.d.ts +1 -1
  164. package/dest/iterable/sort.d.ts +1 -1
  165. package/dest/iterable/take.d.ts +1 -1
  166. package/dest/iterable/toArray.d.ts +1 -1
  167. package/dest/json-rpc/client/fetch.d.ts +1 -1
  168. package/dest/json-rpc/client/index.d.ts +1 -1
  169. package/dest/json-rpc/client/safe_json_rpc_client.d.ts +1 -1
  170. package/dest/json-rpc/client/undici.d.ts +1 -1
  171. package/dest/json-rpc/convert.d.ts +1 -1
  172. package/dest/json-rpc/errors.d.ts +1 -1
  173. package/dest/json-rpc/errors.d.ts.map +1 -1
  174. package/dest/json-rpc/fixtures/class_a.d.ts +3 -3
  175. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -1
  176. package/dest/json-rpc/fixtures/class_b.d.ts +3 -3
  177. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -1
  178. package/dest/json-rpc/fixtures/test_state.d.ts +1 -1
  179. package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -1
  180. package/dest/json-rpc/index.d.ts +1 -1
  181. package/dest/json-rpc/js_utils.d.ts +1 -1
  182. package/dest/json-rpc/js_utils.d.ts.map +1 -1
  183. package/dest/json-rpc/server/index.d.ts +1 -1
  184. package/dest/json-rpc/server/safe_json_rpc_server.d.ts +1 -1
  185. package/dest/json-rpc/server/safe_json_rpc_server.d.ts.map +1 -1
  186. package/dest/json-rpc/server/telemetry.d.ts +1 -1
  187. package/dest/json-rpc/test/index.d.ts +1 -1
  188. package/dest/json-rpc/test/integration.d.ts +1 -1
  189. package/dest/log/console.d.ts +1 -1
  190. package/dest/log/gcloud-logger-config.d.ts +1 -1
  191. package/dest/log/gcloud-logger-config.d.ts.map +1 -1
  192. package/dest/log/index.d.ts +1 -1
  193. package/dest/log/libp2p_logger.d.ts +1 -1
  194. package/dest/log/log-filters.d.ts +1 -1
  195. package/dest/log/log-levels.d.ts +1 -1
  196. package/dest/log/log_fn.d.ts +1 -1
  197. package/dest/log/noir_debug_log_util.d.ts +1 -1
  198. package/dest/log/pino-logger.d.ts +2 -2
  199. package/dest/message/index.d.ts +1 -1
  200. package/dest/message/index.d.ts.map +1 -1
  201. package/dest/mutex/index.d.ts +1 -1
  202. package/dest/mutex/index.d.ts.map +1 -1
  203. package/dest/mutex/mutex_database.d.ts +1 -1
  204. package/dest/noir/index.d.ts +1 -1
  205. package/dest/noir/noir_package_config.d.ts +9 -9
  206. package/dest/number/index.d.ts +1 -1
  207. package/dest/profiler/index.d.ts +1 -1
  208. package/dest/profiler/profiler.d.ts +1 -1
  209. package/dest/promise/index.d.ts +1 -1
  210. package/dest/promise/running-promise.d.ts +1 -1
  211. package/dest/promise/running-promise.d.ts.map +1 -1
  212. package/dest/promise/utils.d.ts +1 -1
  213. package/dest/queue/base_memory_queue.d.ts +1 -1
  214. package/dest/queue/base_memory_queue.d.ts.map +1 -1
  215. package/dest/queue/batch_queue.d.ts +1 -1
  216. package/dest/queue/batch_queue.d.ts.map +1 -1
  217. package/dest/queue/bounded_serial_queue.d.ts +1 -1
  218. package/dest/queue/bounded_serial_queue.d.ts.map +1 -1
  219. package/dest/queue/fifo_memory_queue.d.ts +1 -1
  220. package/dest/queue/fifo_memory_queue.d.ts.map +1 -1
  221. package/dest/queue/index.d.ts +1 -1
  222. package/dest/queue/priority_memory_queue.d.ts +1 -1
  223. package/dest/queue/priority_memory_queue.d.ts.map +1 -1
  224. package/dest/queue/priority_queue.d.ts +1 -1
  225. package/dest/queue/priority_queue.d.ts.map +1 -1
  226. package/dest/queue/semaphore.d.ts +1 -1
  227. package/dest/queue/semaphore.d.ts.map +1 -1
  228. package/dest/queue/serial_queue.d.ts +1 -1
  229. package/dest/queue/serial_queue.d.ts.map +1 -1
  230. package/dest/retry/index.d.ts +1 -1
  231. package/dest/running-promise/index.d.ts +1 -1
  232. package/dest/schemas/api.d.ts +1 -1
  233. package/dest/schemas/index.d.ts +1 -1
  234. package/dest/schemas/parse.d.ts +1 -1
  235. package/dest/schemas/schemas.d.ts +13 -17
  236. package/dest/schemas/schemas.d.ts.map +1 -1
  237. package/dest/schemas/schemas.js +9 -10
  238. package/dest/schemas/types.d.ts +1 -1
  239. package/dest/schemas/utils.d.ts +4 -4
  240. package/dest/schemas/utils.d.ts.map +1 -1
  241. package/dest/schemas/utils.js +15 -5
  242. package/dest/serialize/buffer_reader.d.ts +1 -1
  243. package/dest/serialize/buffer_reader.d.ts.map +1 -1
  244. package/dest/serialize/field_reader.d.ts +2 -2
  245. package/dest/serialize/field_reader.d.ts.map +1 -1
  246. package/dest/serialize/field_reader.js +1 -1
  247. package/dest/serialize/free_funcs.d.ts +2 -2
  248. package/dest/serialize/free_funcs.d.ts.map +1 -1
  249. package/dest/serialize/free_funcs.js +1 -1
  250. package/dest/serialize/index.d.ts +1 -1
  251. package/dest/serialize/serialize.d.ts +2 -2
  252. package/dest/serialize/serialize.d.ts.map +1 -1
  253. package/dest/serialize/serialize.js +1 -1
  254. package/dest/serialize/type_registry.d.ts +1 -1
  255. package/dest/serialize/type_registry.d.ts.map +1 -1
  256. package/dest/serialize/types.d.ts +1 -1
  257. package/dest/sleep/index.d.ts +1 -1
  258. package/dest/sleep/index.d.ts.map +1 -1
  259. package/dest/string/index.d.ts +5 -1
  260. package/dest/string/index.d.ts.map +1 -1
  261. package/dest/string/index.js +1 -1
  262. package/dest/testing/files/index.d.ts +2 -1
  263. package/dest/testing/files/index.d.ts.map +1 -1
  264. package/dest/testing/files/index.js +1 -1
  265. package/dest/testing/formatting.d.ts +1 -1
  266. package/dest/testing/index.d.ts +1 -1
  267. package/dest/testing/port_allocator.d.ts +1 -1
  268. package/dest/testing/snapshot_serializer.d.ts +1 -1
  269. package/dest/testing/test_data.d.ts +1 -1
  270. package/dest/timer/date.d.ts +1 -1
  271. package/dest/timer/date.d.ts.map +1 -1
  272. package/dest/timer/elapsed.d.ts +1 -1
  273. package/dest/timer/index.d.ts +1 -1
  274. package/dest/timer/timeout.d.ts +1 -1
  275. package/dest/timer/timeout.d.ts.map +1 -1
  276. package/dest/timer/timer.d.ts +1 -1
  277. package/dest/timer/timer.d.ts.map +1 -1
  278. package/dest/transport/dispatch/create_dispatch_fn.d.ts +1 -1
  279. package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -1
  280. package/dest/transport/dispatch/create_dispatch_proxy.d.ts +1 -1
  281. package/dest/transport/dispatch/messages.d.ts +1 -1
  282. package/dest/transport/index.d.ts +1 -1
  283. package/dest/transport/interface/connector.d.ts +1 -1
  284. package/dest/transport/interface/listener.d.ts +1 -1
  285. package/dest/transport/interface/socket.d.ts +1 -1
  286. package/dest/transport/interface/transferable.d.ts +1 -1
  287. package/dest/transport/node/index.d.ts +1 -1
  288. package/dest/transport/node/node_connector.d.ts +1 -1
  289. package/dest/transport/node/node_connector.d.ts.map +1 -1
  290. package/dest/transport/node/node_connector_socket.d.ts +1 -1
  291. package/dest/transport/node/node_connector_socket.d.ts.map +1 -1
  292. package/dest/transport/node/node_listener.d.ts +1 -1
  293. package/dest/transport/node/node_listener.d.ts.map +1 -1
  294. package/dest/transport/node/node_listener_socket.d.ts +1 -1
  295. package/dest/transport/node/node_listener_socket.d.ts.map +1 -1
  296. package/dest/transport/transport_client.d.ts +1 -1
  297. package/dest/transport/transport_client.d.ts.map +1 -1
  298. package/dest/transport/transport_server.d.ts +1 -10
  299. package/dest/transport/transport_server.d.ts.map +1 -1
  300. package/dest/trees/balanced_merkle_tree.d.ts +22 -0
  301. package/dest/trees/balanced_merkle_tree.d.ts.map +1 -0
  302. package/dest/trees/balanced_merkle_tree.js +66 -0
  303. package/dest/trees/hasher.d.ts +1 -1
  304. package/dest/trees/index.d.ts +2 -1
  305. package/dest/trees/index.d.ts.map +1 -1
  306. package/dest/trees/index.js +1 -0
  307. package/dest/trees/indexed_merkle_tree.d.ts +1 -1
  308. package/dest/trees/indexed_merkle_tree.d.ts.map +1 -1
  309. package/dest/trees/indexed_merkle_tree.js +1 -1
  310. package/dest/trees/indexed_merkle_tree_calculator.d.ts +1 -1
  311. package/dest/trees/indexed_merkle_tree_calculator.d.ts.map +1 -1
  312. package/dest/trees/indexed_tree_leaf.d.ts +1 -1
  313. package/dest/trees/membership_witness.d.ts +3 -24
  314. package/dest/trees/membership_witness.d.ts.map +1 -1
  315. package/dest/trees/membership_witness.js +1 -1
  316. package/dest/trees/merkle_tree.d.ts +1 -1
  317. package/dest/trees/merkle_tree.d.ts.map +1 -1
  318. package/dest/trees/merkle_tree_calculator.d.ts +2 -12
  319. package/dest/trees/merkle_tree_calculator.d.ts.map +1 -1
  320. package/dest/trees/merkle_tree_calculator.js +1 -31
  321. package/dest/trees/sibling_path.d.ts +5 -39
  322. package/dest/trees/sibling_path.d.ts.map +1 -1
  323. package/dest/trees/sibling_path.js +2 -2
  324. package/dest/trees/unbalanced_merkle_tree.d.ts +5 -3
  325. package/dest/trees/unbalanced_merkle_tree.d.ts.map +1 -1
  326. package/dest/trees/unbalanced_merkle_tree.js +32 -9
  327. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts +6 -5
  328. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts.map +1 -1
  329. package/dest/trees/unbalanced_merkle_tree_calculator.js +36 -40
  330. package/dest/trees/unbalanced_tree_store.d.ts +1 -1
  331. package/dest/trees/unbalanced_tree_store.d.ts.map +1 -1
  332. package/dest/types/index.d.ts +1 -1
  333. package/dest/url/index.d.ts +1 -1
  334. package/dest/validation/index.d.ts +1 -1
  335. package/package.json +29 -7
  336. package/src/array/array.ts +0 -16
  337. package/src/branded-types/block_number.ts +112 -0
  338. package/src/branded-types/checkpoint_number.ts +100 -0
  339. package/src/branded-types/epoch.ts +88 -0
  340. package/src/branded-types/index.ts +6 -0
  341. package/src/branded-types/slot.ts +88 -0
  342. package/src/branded-types/types.ts +2 -0
  343. package/src/buffer/buffer16.ts +2 -2
  344. package/src/buffer/buffer32.ts +2 -2
  345. package/src/collection/array.ts +15 -3
  346. package/src/config/env_var.ts +20 -2
  347. package/src/config/index.ts +20 -2
  348. package/src/crypto/aes128/index.ts +2 -2
  349. package/src/crypto/bls/bn254_keystore.ts +287 -0
  350. package/src/crypto/bls/index.ts +77 -0
  351. package/src/crypto/bn254/index.ts +64 -0
  352. package/src/crypto/ecdsa/index.ts +4 -4
  353. package/src/crypto/ecdsa/signature.ts +2 -2
  354. package/src/crypto/grumpkin/index.ts +14 -20
  355. package/src/crypto/keys/index.ts +2 -2
  356. package/src/crypto/pedersen/pedersen.wasm.ts +4 -4
  357. package/src/crypto/poseidon/index.ts +6 -6
  358. package/src/crypto/schnorr/index.ts +5 -4
  359. package/src/crypto/schnorr/signature.ts +2 -2
  360. package/src/crypto/secp256k1/index.ts +3 -3
  361. package/src/crypto/secp256k1-signer/utils.ts +102 -10
  362. package/src/crypto/sha256/index.ts +1 -1
  363. package/src/crypto/sha512/index.ts +1 -1
  364. package/src/crypto/signature/index.ts +1 -1
  365. package/src/crypto/sync/index.ts +1 -1
  366. package/src/crypto/sync/pedersen/index.ts +1 -1
  367. package/src/crypto/sync/poseidon/index.ts +1 -1
  368. package/src/{fields/bls12_fields.ts → curves/bls12/field.ts} +6 -6
  369. package/src/curves/bls12/index.ts +2 -0
  370. package/src/{fields/bls12_point.ts → curves/bls12/point.ts} +7 -7
  371. package/src/{fields/fields.ts → curves/bn254/field.ts} +37 -14
  372. package/src/curves/bn254/index.ts +2 -0
  373. package/src/curves/bn254/point.ts +170 -0
  374. package/src/curves/grumpkin/index.ts +11 -0
  375. package/src/{fields → curves/grumpkin}/point.ts +26 -7
  376. package/src/eth-address/index.ts +26 -1
  377. package/src/schemas/schemas.ts +16 -13
  378. package/src/schemas/utils.ts +21 -8
  379. package/src/serialize/field_reader.ts +1 -1
  380. package/src/serialize/free_funcs.ts +1 -1
  381. package/src/serialize/serialize.ts +1 -1
  382. package/src/string/index.ts +3 -0
  383. package/src/testing/files/index.ts +1 -1
  384. package/src/trees/balanced_merkle_tree.ts +84 -0
  385. package/src/trees/index.ts +1 -0
  386. package/src/trees/indexed_merkle_tree.ts +1 -1
  387. package/src/trees/membership_witness.ts +1 -1
  388. package/src/trees/merkle_tree_calculator.ts +1 -34
  389. package/src/trees/sibling_path.ts +2 -2
  390. package/src/trees/unbalanced_merkle_tree.ts +54 -6
  391. package/src/trees/unbalanced_merkle_tree_calculator.ts +34 -41
  392. package/dest/crypto/index.d.ts +0 -15
  393. package/dest/crypto/index.d.ts.map +0 -1
  394. package/dest/crypto/index.js +0 -14
  395. package/dest/fields/bls12_fields.d.ts.map +0 -1
  396. package/dest/fields/bls12_point.d.ts.map +0 -1
  397. package/dest/fields/coordinate.d.ts +0 -66
  398. package/dest/fields/coordinate.d.ts.map +0 -1
  399. package/dest/fields/coordinate.js +0 -96
  400. package/dest/fields/fields.d.ts.map +0 -1
  401. package/dest/fields/index.d.ts +0 -6
  402. package/dest/fields/index.d.ts.map +0 -1
  403. package/dest/fields/index.js +0 -5
  404. package/dest/fields/point.d.ts.map +0 -1
  405. package/dest/index.d.ts +0 -30
  406. package/dest/index.d.ts.map +0 -1
  407. package/dest/index.js +0 -30
  408. package/src/crypto/index.ts +0 -14
  409. package/src/fields/coordinate.ts +0 -104
  410. package/src/fields/index.ts +0 -5
  411. package/src/index.ts +0 -30
@@ -1 +1 @@
1
- {"version":3,"file":"membership_witness.d.ts","sourceRoot":"","sources":["../../src/trees/membership_witness.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,qBAAqB,CAAC;AAEzC,OAAO,EAAE,YAAY,EAAE,KAAK,KAAK,EAAqB,MAAM,uBAAuB,CAAC;AACpF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErD;;GAEG;AACH,qBAAa,iBAAiB,CAAC,CAAC,SAAS,MAAM;IAM3C;;OAEG;IACI,SAAS,EAAE,MAAM;IACxB;;OAEG;IACI,WAAW,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;;IAXhC;;OAEG;IACH,QAAQ,EAAE,CAAC;IACX;;OAEG;IACI,SAAS,EAAE,MAAM;IACxB;;OAEG;IACI,WAAW,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IAKlC,QAAQ;IAIR,MAAM;IAIN,QAAQ,IAAI,EAAE,EAAE;IAIhB,MAAM,CAAC,SAAS,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,CAAC;;;;;;;;;;;;;;;;IAI1C;;;;OAIG;WACW,MAAM,CAAC,CAAC,SAAS,MAAM,EAAE,QAAQ,EAAE,CAAC;IAUlD;;;;;OAKG;WACW,KAAK,CAAC,CAAC,SAAS,MAAM,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS,SAAK,GAAG,iBAAiB,CAAC,CAAC,CAAC;IAOxF,MAAM,CAAC,eAAe,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC;IAQhH;;;;OAIG;IACH,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,YAAY,EAAE,IAAI,EAAE,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC;IAOjG;;;;OAIG;IACH,MAAM,CAAC,YAAY,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,CAAC,GAAG;QAAE,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAA;KAAE;IAWnH,MAAM,CAAC,eAAe,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC;CAG/G"}
1
+ {"version":3,"file":"membership_witness.d.ts","sourceRoot":"","sources":["../../src/trees/membership_witness.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAE9C,OAAO,EAAE,YAAY,EAAE,KAAK,KAAK,EAAqB,MAAM,uBAAuB,CAAC;AACpF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErD;;GAEG;AACH,qBAAa,iBAAiB,CAAC,CAAC,SAAS,MAAM;IASpC,SAAS,EAAE,MAAM;IAIjB,WAAW,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IAZlC;IACE;;OAEG;IACH,QAAQ,EAAE,CAAC;IACX;;OAEG;IACI,SAAS,EAAE,MAAM;IACxB;;OAEG;IACI,WAAW,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EAGjC;IAED,QAAQ,4BAEP;IAED,MAAM,4BAEL;IAED,QAAQ,IAAI,EAAE,EAAE,CAEf;IAED,MAAM,CAAC,SAAS,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,CAAC,sHAEzC;IAED;;;;OAIG;IACH,OAAc,MAAM,CAAC,CAAC,SAAS,MAAM,EAAE,QAAQ,EAAE,CAAC,wBAQjD;IAED;;;;;OAKG;IACH,OAAc,KAAK,CAAC,CAAC,SAAS,MAAM,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS,SAAK,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAKvF;IAED,MAAM,CAAC,eAAe,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAM/G;IAED;;;;OAIG;IACH,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,YAAY,EAAE,IAAI,EAAE,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAKhG;IAED;;;;OAIG;IACH,MAAM,CAAC,YAAY,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,CAAC,GAAG;QAAE,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAA;KAAE,CASlH;IAED,MAAM,CAAC,eAAe,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAE7G;CACF"}
@@ -1,6 +1,6 @@
1
1
  import { assertMemberLength } from '../array/array.js';
2
2
  import { toBigIntBE, toBufferBE } from '../bigint-buffer/index.js';
3
- import { Fr } from '../fields/fields.js';
3
+ import { Fr } from '../curves/bn254/field.js';
4
4
  import { schemas } from '../schemas/schemas.js';
5
5
  import { BufferReader, serializeToBuffer } from '../serialize/index.js';
6
6
  /**
@@ -13,4 +13,4 @@ export declare class MerkleTree {
13
13
  /** Returns a nice string representation of the tree, useful for debugging purposes. */
14
14
  drawTree(elemSize?: number): string;
15
15
  }
16
- //# sourceMappingURL=merkle_tree.d.ts.map
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVya2xlX3RyZWUuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmVlcy9tZXJrbGVfdHJlZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSwwSEFBMEg7QUFDMUgscUJBQWEsVUFBVTthQUVILE1BQU0sRUFBRSxNQUFNO2FBQ2QsS0FBSyxFQUFFLE1BQU0sRUFBRTtJQUZqQyxZQUNrQixNQUFNLEVBQUUsTUFBTSxFQUNkLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFNaEM7SUFFRCxJQUFJLElBQUksSUFBSSxNQUFNLENBRWpCO0lBRUQsSUFBSSxNQUFNLElBQUksTUFBTSxFQUFFLENBRXJCO0lBRUQsd0ZBQXdGO0lBQ2pGLGNBQWMsQ0FBQyxTQUFTLEVBQUUsTUFBTSxHQUFHLE1BQU0sRUFBRSxDQUFDO0lBQzVDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsTUFBTSxHQUFHLE1BQU0sRUFBRSxDQUFDO0lBd0I5QyxrREFBa0Q7SUFDM0MsUUFBUSxDQUFDLE9BQU8sRUFBRSxNQUFNLFVBRTlCO0lBRUQsdUZBQXVGO0lBQ2hGLFFBQVEsQ0FBQyxRQUFRLFNBQUksVUFxQjNCO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"merkle_tree.d.ts","sourceRoot":"","sources":["../../src/trees/merkle_tree.ts"],"names":[],"mappings":"AAAA,0HAA0H;AAC1H,qBAAa,UAAU;aAEH,MAAM,EAAE,MAAM;aACd,KAAK,EAAE,MAAM,EAAE;gBADf,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EAAE;IAQjC,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,IAAI,MAAM,IAAI,MAAM,EAAE,CAErB;IAED,wFAAwF;IACjF,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE;IAC3C,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE;IAwB7C,kDAAkD;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM;IAI/B,uFAAuF;IAChF,QAAQ,CAAC,QAAQ,SAAI;CAsB7B"}
1
+ {"version":3,"file":"merkle_tree.d.ts","sourceRoot":"","sources":["../../src/trees/merkle_tree.ts"],"names":[],"mappings":"AAAA,0HAA0H;AAC1H,qBAAa,UAAU;aAEH,MAAM,EAAE,MAAM;aACd,KAAK,EAAE,MAAM,EAAE;IAFjC,YACkB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EAAE,EAMhC;IAED,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,IAAI,MAAM,IAAI,MAAM,EAAE,CAErB;IAED,wFAAwF;IACjF,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAC5C,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAwB9C,kDAAkD;IAC3C,QAAQ,CAAC,OAAO,EAAE,MAAM,UAE9B;IAED,uFAAuF;IAChF,QAAQ,CAAC,QAAQ,SAAI,UAqB3B;CACF"}
@@ -1,4 +1,3 @@
1
- import { sha256Trunc } from '@aztec/foundation/crypto';
2
1
  import { MerkleTree } from './merkle_tree.js';
3
2
  /**
4
3
  * Merkle tree calculator.
@@ -8,17 +7,8 @@ export declare class MerkleTreeCalculator {
8
7
  private zeroHashes;
9
8
  private hasher;
10
9
  private constructor();
11
- static create(height: number, zeroLeaf?: Buffer, hasher?: (left: Buffer, right: Buffer) => Promise<Buffer<ArrayBuffer>>): Promise<MerkleTreeCalculator>;
10
+ static create(height: number, zeroLeaf?: Buffer, hasher?: (left: Buffer<ArrayBufferLike>, right: Buffer<ArrayBufferLike>) => Promise<Buffer<ArrayBuffer>>): Promise<MerkleTreeCalculator>;
12
11
  computeTree(leaves?: Buffer[]): Promise<MerkleTree>;
13
12
  computeTreeRoot(leaves?: Buffer[]): Promise<Buffer>;
14
- /**
15
- * Computes the Merkle root with the provided leaves **synchronously**.
16
- *
17
- * This method uses a synchronous hash function (defaults to `sha256Trunc`) and **does not** allow for padding.
18
- * If the number of leaves is not a power of two, it throws an error.
19
- * This contrasts with the above non-static async method `computeTreeRoot`, which can handle any number of leaves by
20
- * padding with zero hashes.
21
- */
22
- static computeTreeRootSync(leaves: Buffer[], hasher?: typeof sha256Trunc): Buffer;
23
13
  }
24
- //# sourceMappingURL=merkle_tree_calculator.d.ts.map
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVya2xlX3RyZWVfY2FsY3VsYXRvci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3RyZWVzL21lcmtsZV90cmVlX2NhbGN1bGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRTlDOztHQUVHO0FBQ0gscUJBQWEsb0JBQW9CO0lBRTdCLE9BQU8sQ0FBQyxNQUFNO0lBQ2QsT0FBTyxDQUFDLFVBQVU7SUFDbEIsT0FBTyxDQUFDLE1BQU07SUFIaEIsT0FBTyxlQU1OO0lBRUQsT0FBYSxNQUFNLENBQ2pCLE1BQU0sRUFBRSxNQUFNLEVBQ2QsUUFBUSxHQUFFLE1BQXlCLEVBQ25DLE1BQU0sa0dBQ2lFLGlDQU94RTtJQUVLLFdBQVcsQ0FBQyxNQUFNLEdBQUUsTUFBTSxFQUFPLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQW9CNUQ7SUFFSyxlQUFlLENBQUMsTUFBTSxHQUFFLE1BQU0sRUFBTyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FrQjVEO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"merkle_tree_calculator.d.ts","sourceRoot":"","sources":["../../src/trees/merkle_tree_calculator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAGrE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C;;GAEG;AACH,qBAAa,oBAAoB;IAE7B,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,MAAM;IAHhB,OAAO;WAQM,MAAM,CACjB,MAAM,EAAE,MAAM,EACd,QAAQ,GAAE,MAAyB,EACnC,MAAM,IAAU,MAAM,MAAM,EAAE,OAAO,MAAM,iCAC4B;IASnE,WAAW,CAAC,MAAM,GAAE,MAAM,EAAO,GAAG,OAAO,CAAC,UAAU,CAAC;IAsBvD,eAAe,CAAC,MAAM,GAAE,MAAM,EAAO,GAAG,OAAO,CAAC,MAAM,CAAC;IAoB7D;;;;;;;OAOG;IACH,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,qBAAc,GAAG,MAAM;CAwB3E"}
1
+ {"version":3,"file":"merkle_tree_calculator.d.ts","sourceRoot":"","sources":["../../src/trees/merkle_tree_calculator.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C;;GAEG;AACH,qBAAa,oBAAoB;IAE7B,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,MAAM;IAHhB,OAAO,eAMN;IAED,OAAa,MAAM,CACjB,MAAM,EAAE,MAAM,EACd,QAAQ,GAAE,MAAyB,EACnC,MAAM,kGACiE,iCAOxE;IAEK,WAAW,CAAC,MAAM,GAAE,MAAM,EAAO,GAAG,OAAO,CAAC,UAAU,CAAC,CAoB5D;IAEK,eAAe,CAAC,MAAM,GAAE,MAAM,EAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAkB5D;CACF"}
@@ -1,4 +1,4 @@
1
- import { pedersenHash, sha256Trunc } from '@aztec/foundation/crypto';
1
+ import { pedersenHash } from '@aztec/foundation/crypto/pedersen';
2
2
  import { MerkleTree } from './merkle_tree.js';
3
3
  /**
4
4
  * Merkle tree calculator.
@@ -58,34 +58,4 @@ import { MerkleTree } from './merkle_tree.js';
58
58
  }
59
59
  return leaves[0];
60
60
  }
61
- /**
62
- * Computes the Merkle root with the provided leaves **synchronously**.
63
- *
64
- * This method uses a synchronous hash function (defaults to `sha256Trunc`) and **does not** allow for padding.
65
- * If the number of leaves is not a power of two, it throws an error.
66
- * This contrasts with the above non-static async method `computeTreeRoot`, which can handle any number of leaves by
67
- * padding with zero hashes.
68
- */ static computeTreeRootSync(leaves, hasher = sha256Trunc) {
69
- if (leaves.length === 0) {
70
- throw new Error('Cannot compute a Merkle root with no leaves');
71
- }
72
- const height = Math.log2(leaves.length);
73
- if (!Number.isInteger(height)) {
74
- throw new Error('Cannot compute a Merkle root with a non-power-of-two number of leaves');
75
- }
76
- let nodes = leaves.slice();
77
- for(let i = 0; i < height; ++i){
78
- let j = 0;
79
- for(; j < nodes.length / 2; ++j){
80
- const l = nodes[j * 2];
81
- const r = nodes[j * 2 + 1];
82
- nodes[j] = hasher(Buffer.concat([
83
- l,
84
- r
85
- ]));
86
- }
87
- nodes = nodes.slice(0, j);
88
- }
89
- return nodes[0];
90
- }
91
61
  }
@@ -1,4 +1,4 @@
1
- import { Fr } from '../fields/index.js';
1
+ import { Fr } from '../curves/bn254/index.js';
2
2
  import { type Tuple } from '../serialize/index.js';
3
3
  import type { Hasher } from './hasher.js';
4
4
  /**
@@ -12,7 +12,6 @@ import type { Hasher } from './hasher.js';
12
12
  * And the elements would be ordered as: [ leaf_at_index_2, node_at_level_2_index_0, node_at_level_1_index_1 ].
13
13
  */
14
14
  export declare class SiblingPath<N extends number> {
15
- /** Size of the sibling path (number of fields it contains). */
16
15
  pathSize: N;
17
16
  private data;
18
17
  /**
@@ -25,41 +24,8 @@ export declare class SiblingPath<N extends number> {
25
24
  pathSize: N,
26
25
  /** The sibling path data. */
27
26
  path: Buffer[]);
28
- static get schema(): import("zod").ZodEffects<import("zod").ZodUnion<[import("zod").ZodEffects<import("zod").ZodEffects<import("zod").ZodString, string, string>, Buffer<ArrayBuffer>, string>, import("zod").ZodEffects<import("zod").ZodObject<{
29
- type: import("zod").ZodLiteral<"Buffer">;
30
- data: import("zod").ZodArray<import("zod").ZodNumber, "many">;
31
- }, "strip", import("zod").ZodTypeAny, {
32
- type: "Buffer";
33
- data: number[];
34
- }, {
35
- type: "Buffer";
36
- data: number[];
37
- }>, Buffer<ArrayBuffer>, {
38
- type: "Buffer";
39
- data: number[];
40
- }>]>, SiblingPath<number>, string | {
41
- type: "Buffer";
42
- data: number[];
43
- }>;
44
- static schemaFor<N extends number>(size: N): import("zod").ZodEffects<import("zod").ZodEffects<import("zod").ZodUnion<[import("zod").ZodEffects<import("zod").ZodEffects<import("zod").ZodString, string, string>, Buffer<ArrayBuffer>, string>, import("zod").ZodEffects<import("zod").ZodObject<{
45
- type: import("zod").ZodLiteral<"Buffer">;
46
- data: import("zod").ZodArray<import("zod").ZodNumber, "many">;
47
- }, "strip", import("zod").ZodTypeAny, {
48
- type: "Buffer";
49
- data: number[];
50
- }, {
51
- type: "Buffer";
52
- data: number[];
53
- }>, Buffer<ArrayBuffer>, {
54
- type: "Buffer";
55
- data: number[];
56
- }>]>, SiblingPath<N>, string | {
57
- type: "Buffer";
58
- data: number[];
59
- }>, SiblingPath<N>, string | {
60
- type: "Buffer";
61
- data: number[];
62
- }>;
27
+ static get schema(): import("zod").ZodEffects<import("../schemas/types.js").ZodFor<Buffer<ArrayBufferLike>>, SiblingPath<number>, any>;
28
+ static schemaFor<N extends number>(size: N): import("zod").ZodEffects<import("zod").ZodEffects<import("../schemas/types.js").ZodFor<Buffer<ArrayBufferLike>>, SiblingPath<N>, any>, SiblingPath<N>, any>;
63
29
  toJSON(): Buffer<ArrayBufferLike>;
64
30
  /**
65
31
  * Returns sibling path hashed up from the a element.
@@ -126,5 +92,5 @@ export declare class SiblingPath<N extends number> {
126
92
  getSubtreeSiblingPath<SubtreeHeight extends number, SubtreeSiblingPathHeight extends number>(subtreeHeight: SubtreeHeight): SiblingPath<SubtreeSiblingPathHeight>;
127
93
  }
128
94
  /** Computes the expected root of a merkle tree given a leaf and its sibling path. */
129
- export declare function computeRootFromSiblingPath(leaf: Buffer, siblingPath: Buffer[], index: number, hasher?: (left: Buffer, right: Buffer) => Promise<Buffer<ArrayBufferLike>>): Promise<Buffer<ArrayBufferLike>>;
130
- //# sourceMappingURL=sibling_path.d.ts.map
95
+ export declare function computeRootFromSiblingPath(leaf: Buffer, siblingPath: Buffer[], index: number, hasher?: (left: Buffer<ArrayBufferLike>, right: Buffer<ArrayBufferLike>) => Promise<Buffer<ArrayBufferLike>>): Promise<Buffer<ArrayBufferLike>>;
96
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2libGluZ19wYXRoLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHJlZXMvc2libGluZ19wYXRoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUU5QyxPQUFPLEVBQ0wsS0FBSyxLQUFLLEVBSVgsTUFBTSx1QkFBdUIsQ0FBQztBQUUvQixPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFMUM7Ozs7Ozs7OztHQVNHO0FBQ0gscUJBQWEsV0FBVyxDQUFDLENBQUMsU0FBUyxNQUFNO0lBVTlCLFFBQVEsRUFBRSxDQUFDO0lBVHBCLE9BQU8sQ0FBQyxJQUFJLENBQW1CO0lBRS9COzs7O09BSUc7SUFDSDtJQUNFLCtEQUErRDtJQUN4RCxRQUFRLEVBQUUsQ0FBQztJQUNsQiw2QkFBNkI7SUFDN0IsSUFBSSxFQUFFLE1BQU0sRUFBRSxFQUdmO0lBRUQsTUFBTSxLQUFLLE1BQU0sc0hBRWhCO0lBRUQsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsTUFBTSxFQUFFLElBQUksRUFBRSxDQUFDLCtKQUt6QztJQUVELE1BQU0sNEJBRUw7SUFFRDs7Ozs7O09BTUc7SUFDSCxPQUFjLElBQUksQ0FBQyxDQUFDLFNBQVMsTUFBTSxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FRakc7SUFFRCxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsU0FBUyxNQUFNLEVBQUUsTUFBTSxFQUFFLENBQUMsa0JBR3hDO0lBRUQ7OztPQUdHO0lBQ0ksUUFBUSxJQUFJLE1BQU0sQ0FFeEI7SUFFRDs7O09BR0c7SUFDSSxhQUFhLElBQUksTUFBTSxFQUFFLENBRS9CO0lBRUQ7OztPQUdHO0lBQ0ksUUFBUSxJQUFJLEVBQUUsRUFBRSxDQUV0QjtJQUVEOzs7T0FHRztJQUNJLE9BQU8sSUFBSSxLQUFLLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUc3QjtJQUVEOzs7OztPQUtHO0lBQ0gsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsTUFBTSxFQUFFLEdBQUcsRUFBRSxNQUFNLEVBQUUsTUFBTSxTQUFJLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUczRTtJQUVEOzs7OztPQUtHO0lBQ0gsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLFNBQVMsTUFBTSxFQUFFLEdBQUcsRUFBRSxNQUFNLEVBQUUsTUFBTSxTQUFJOzs7TUFRM0Q7SUFFRDs7O09BR0c7SUFDSSxRQUFRLElBQUksTUFBTSxDQUV4QjtJQUVEOzs7O09BSUc7SUFDSCxPQUFjLFVBQVUsQ0FBQyxDQUFDLFNBQVMsTUFBTSxFQUFFLElBQUksRUFBRSxNQUFNLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUV2RTtJQUVEOzs7O09BSUc7SUFDSSxxQkFBcUIsQ0FBQyxhQUFhLFNBQVMsTUFBTSxFQUFFLHdCQUF3QixTQUFTLE1BQU0sRUFDaEcsYUFBYSxFQUFFLGFBQWEsR0FDM0IsV0FBVyxDQUFDLHdCQUF3QixDQUFDLENBS3ZDO0NBQ0Y7QUFFRCxxRkFBcUY7QUFDckYsd0JBQXNCLDBCQUEwQixDQUM5QyxJQUFJLEVBQUUsTUFBTSxFQUNaLFdBQVcsRUFBRSxNQUFNLEVBQUUsRUFDckIsS0FBSyxFQUFFLE1BQU0sRUFDYixNQUFNLHNHQUF3RixvQ0FRL0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"sibling_path.d.ts","sourceRoot":"","sources":["../../src/trees/sibling_path.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,oBAAoB,CAAC;AAExC,OAAO,EACL,KAAK,KAAK,EAIX,MAAM,uBAAuB,CAAC;AAE/B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1C;;;;;;;;;GASG;AACH,qBAAa,WAAW,CAAC,CAAC,SAAS,MAAM;IASrC,+DAA+D;IACxD,QAAQ,EAAE,CAAC;IATpB,OAAO,CAAC,IAAI,CAAmB;IAE/B;;;;OAIG;;IAED,+DAA+D;IACxD,QAAQ,EAAE,CAAC;IAClB,6BAA6B;IAC7B,IAAI,EAAE,MAAM,EAAE;IAKhB,MAAM,KAAK,MAAM;;;;;;;;;;;;;;;OAEhB;IAED,MAAM,CAAC,SAAS,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,CAAC;;;;;;;;;;;;;;;;;;;IAO1C,MAAM;IAIN;;;;;;OAMG;WACW,IAAI,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,CAAC,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC;IAUlG,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,CAAC;IAKzC;;;OAGG;IACI,QAAQ,IAAI,MAAM;IAIzB;;;OAGG;IACI,aAAa,IAAI,MAAM,EAAE;IAIhC;;;OAGG;IACI,QAAQ,IAAI,EAAE,EAAE;IAIvB;;;OAGG;IACI,OAAO,IAAI,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IAK9B;;;;;OAKG;IACH,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,SAAI,GAAG,WAAW,CAAC,CAAC,CAAC;IAK5E;;;;;OAKG;IACH,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,SAAI;;;;IAU5D;;;OAGG;IACI,QAAQ,IAAI,MAAM;IAIzB;;;;OAIG;WACW,UAAU,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC;IAIxE;;;;OAIG;IACI,qBAAqB,CAAC,aAAa,SAAS,MAAM,EAAE,wBAAwB,SAAS,MAAM,EAChG,aAAa,EAAE,aAAa,GAC3B,WAAW,CAAC,wBAAwB,CAAC;CAMzC;AAED,qFAAqF;AACrF,wBAAsB,0BAA0B,CAC9C,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EAAE,EACrB,KAAK,EAAE,MAAM,EACb,MAAM,IAAU,MAAM,MAAM,EAAE,OAAO,MAAM,qCAAmD,oCAQ/F"}
1
+ {"version":3,"file":"sibling_path.d.ts","sourceRoot":"","sources":["../../src/trees/sibling_path.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAE9C,OAAO,EACL,KAAK,KAAK,EAIX,MAAM,uBAAuB,CAAC;AAE/B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1C;;;;;;;;;GASG;AACH,qBAAa,WAAW,CAAC,CAAC,SAAS,MAAM;IAU9B,QAAQ,EAAE,CAAC;IATpB,OAAO,CAAC,IAAI,CAAmB;IAE/B;;;;OAIG;IACH;IACE,+DAA+D;IACxD,QAAQ,EAAE,CAAC;IAClB,6BAA6B;IAC7B,IAAI,EAAE,MAAM,EAAE,EAGf;IAED,MAAM,KAAK,MAAM,sHAEhB;IAED,MAAM,CAAC,SAAS,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,CAAC,+JAKzC;IAED,MAAM,4BAEL;IAED;;;;;;OAMG;IACH,OAAc,IAAI,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,CAAC,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC,CAQjG;IAED,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,CAAC,kBAGxC;IAED;;;OAGG;IACI,QAAQ,IAAI,MAAM,CAExB;IAED;;;OAGG;IACI,aAAa,IAAI,MAAM,EAAE,CAE/B;IAED;;;OAGG;IACI,QAAQ,IAAI,EAAE,EAAE,CAEtB;IAED;;;OAGG;IACI,OAAO,IAAI,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,CAG7B;IAED;;;;;OAKG;IACH,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,SAAI,GAAG,WAAW,CAAC,CAAC,CAAC,CAG3E;IAED;;;;;OAKG;IACH,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,SAAI;;;MAQ3D;IAED;;;OAGG;IACI,QAAQ,IAAI,MAAM,CAExB;IAED;;;;OAIG;IACH,OAAc,UAAU,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC,CAEvE;IAED;;;;OAIG;IACI,qBAAqB,CAAC,aAAa,SAAS,MAAM,EAAE,wBAAwB,SAAS,MAAM,EAChG,aAAa,EAAE,aAAa,GAC3B,WAAW,CAAC,wBAAwB,CAAC,CAKvC;CACF;AAED,qFAAqF;AACrF,wBAAsB,0BAA0B,CAC9C,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EAAE,EACrB,KAAK,EAAE,MAAM,EACb,MAAM,sGAAwF,oCAQ/F"}
@@ -1,6 +1,6 @@
1
1
  import { makeTuple } from '../array/array.js';
2
- import { pedersenHash } from '../crypto/index.js';
3
- import { Fr } from '../fields/index.js';
2
+ import { pedersenHash } from '../crypto/pedersen/index.js';
3
+ import { Fr } from '../curves/bn254/index.js';
4
4
  import { schemas } from '../schemas/index.js';
5
5
  import { assertLength, deserializeArrayFromVector, serializeArrayOfBufferableToVector } from '../serialize/index.js';
6
6
  import { bufferToHex, hexToBuffer } from '../string/index.js';
@@ -1,4 +1,5 @@
1
- import { sha256Trunc } from '../crypto/sha256/index.js';
1
+ export declare const computeUnbalancedShaRoot: (leaves: Buffer<ArrayBufferLike>[]) => Buffer<ArrayBufferLike>;
2
+ export declare const computeUnbalancedPoseidonRoot: (leaves: Buffer<ArrayBufferLike>[]) => Promise<Buffer<ArrayBufferLike>>;
2
3
  /**
3
4
  * Computes the Merkle root of an unbalanced tree.
4
5
  *
@@ -20,9 +21,10 @@ import { sha256Trunc } from '../crypto/sha256/index.js';
20
21
  * But if we instead combine the size-4 and size-8 subtrees first (depth 4), and then merge with the size-2 subtree
21
22
  * (depth 1), the final tree has a depth of 5.
22
23
  */
23
- export declare function computeUnbalancedMerkleTreeRoot(leaves: Buffer[], hasher?: typeof sha256Trunc): Buffer;
24
+ export declare function computeUnbalancedMerkleTreeRoot(leaves: Buffer[], hasher?: (lhs: Uint8Array<ArrayBufferLike>, rhs: Uint8Array<ArrayBufferLike>) => Buffer<ArrayBuffer>, emptyRoot?: Buffer<ArrayBuffer>): Buffer;
25
+ export declare function computeUnbalancedMerkleTreeRootAsync(leaves: Buffer[], hasher?: (lhs: Uint8Array<ArrayBufferLike>, rhs: Uint8Array<ArrayBufferLike>) => Promise<Buffer<ArrayBuffer>>, emptyRoot?: Buffer<ArrayBuffer>): Promise<Buffer>;
24
26
  export declare function findLeafLevelAndIndex(numLeaves: number, leafIndex: number): {
25
27
  level: number;
26
28
  indexAtLevel: number;
27
29
  };
28
- //# sourceMappingURL=unbalanced_merkle_tree.d.ts.map
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iYWxhbmNlZF9tZXJrbGVfdHJlZS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3RyZWVzL3VuYmFsYW5jZWRfbWVya2xlX3RyZWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsZUFBTyxNQUFNLHdCQUF3QixnRUFBK0UsQ0FBQztBQUVySCxlQUFPLE1BQU0sNkJBQTZCLHlFQUM4QixDQUFDO0FBRXpFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CRztBQUNILHdCQUFnQiwrQkFBK0IsQ0FDN0MsTUFBTSxFQUFFLE1BQU0sRUFBRSxFQUNoQixNQUFNLDhGQUFnQixFQUN0QixTQUFTLHNCQUFtQixHQUMzQixNQUFNLENBNkJSO0FBRUQsd0JBQXNCLG9DQUFvQyxDQUN4RCxNQUFNLEVBQUUsTUFBTSxFQUFFLEVBQ2hCLE1BQU0sdUdBQXFCLEVBQzNCLFNBQVMsc0JBQW1CLEdBQzNCLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0E2QmpCO0FBc0RELHdCQUFnQixxQkFBcUIsQ0FBQyxTQUFTLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNOzs7RUFHekUifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"unbalanced_merkle_tree.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_merkle_tree.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAGxD;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,+BAA+B,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,qBAAc,GAAG,MAAM,CA6B9F;AAsDD,wBAAgB,qBAAqB,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;WAhC9D,MAAM;kBAAgB,MAAM;EAmCvC"}
1
+ {"version":3,"file":"unbalanced_merkle_tree.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_merkle_tree.ts"],"names":[],"mappings":"AAOA,eAAO,MAAM,wBAAwB,gEAA+E,CAAC;AAErH,eAAO,MAAM,6BAA6B,yEAC8B,CAAC;AAEzE;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,+BAA+B,CAC7C,MAAM,EAAE,MAAM,EAAE,EAChB,MAAM,8FAAgB,EACtB,SAAS,sBAAmB,GAC3B,MAAM,CA6BR;AAED,wBAAsB,oCAAoC,CACxD,MAAM,EAAE,MAAM,EAAE,EAChB,MAAM,uGAAqB,EAC3B,SAAS,sBAAmB,GAC3B,OAAO,CAAC,MAAM,CAAC,CA6BjB;AAsDD,wBAAgB,qBAAqB,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;;;EAGzE"}
@@ -1,5 +1,6 @@
1
- import { sha256Trunc } from '../crypto/sha256/index.js';
2
- import { MerkleTreeCalculator } from './merkle_tree_calculator.js';
1
+ import { computeBalancedMerkleTreeRoot, computeBalancedMerkleTreeRootAsync, poseidonMerkleHash, shaMerkleHash } from './balanced_merkle_tree.js';
2
+ export const computeUnbalancedShaRoot = (leaves)=>computeUnbalancedMerkleTreeRoot(leaves, shaMerkleHash);
3
+ export const computeUnbalancedPoseidonRoot = async (leaves)=>await computeUnbalancedMerkleTreeRootAsync(leaves, poseidonMerkleHash);
3
4
  /**
4
5
  * Computes the Merkle root of an unbalanced tree.
5
6
  *
@@ -20,9 +21,9 @@ import { MerkleTreeCalculator } from './merkle_tree_calculator.js';
20
21
  *
21
22
  * But if we instead combine the size-4 and size-8 subtrees first (depth 4), and then merge with the size-2 subtree
22
23
  * (depth 1), the final tree has a depth of 5.
23
- */ export function computeUnbalancedMerkleTreeRoot(leaves, hasher = sha256Trunc) {
24
+ */ export function computeUnbalancedMerkleTreeRoot(leaves, hasher = shaMerkleHash, emptyRoot = Buffer.alloc(32)) {
24
25
  if (!leaves.length) {
25
- throw new Error('Cannot compute a Merkle root with no leaves');
26
+ return emptyRoot;
26
27
  }
27
28
  if (leaves.length === 1) {
28
29
  return leaves[0];
@@ -33,14 +34,36 @@ import { MerkleTreeCalculator } from './merkle_tree_calculator.js';
33
34
  while(numRemainingLeaves > 1){
34
35
  if ((numRemainingLeaves & subtreeSize) !== 0) {
35
36
  const subtreeLeaves = leaves.slice(numRemainingLeaves - subtreeSize, numRemainingLeaves);
36
- const subtreeRoot = MerkleTreeCalculator.computeTreeRootSync(subtreeLeaves, hasher);
37
+ const subtreeRoot = computeBalancedMerkleTreeRoot(subtreeLeaves, hasher);
37
38
  if (!root) {
38
39
  root = subtreeRoot;
39
40
  } else {
40
- root = hasher(Buffer.concat([
41
- subtreeRoot,
42
- root
43
- ]));
41
+ root = hasher(subtreeRoot, root);
42
+ }
43
+ numRemainingLeaves -= subtreeSize;
44
+ }
45
+ subtreeSize *= 2;
46
+ }
47
+ return root;
48
+ }
49
+ export async function computeUnbalancedMerkleTreeRootAsync(leaves, hasher = poseidonMerkleHash, emptyRoot = Buffer.alloc(32)) {
50
+ if (!leaves.length) {
51
+ return emptyRoot;
52
+ }
53
+ if (leaves.length === 1) {
54
+ return leaves[0];
55
+ }
56
+ let numRemainingLeaves = leaves.length;
57
+ let subtreeSize = 1;
58
+ let root;
59
+ while(numRemainingLeaves > 1){
60
+ if ((numRemainingLeaves & subtreeSize) !== 0) {
61
+ const subtreeLeaves = leaves.slice(numRemainingLeaves - subtreeSize, numRemainingLeaves);
62
+ const subtreeRoot = await computeBalancedMerkleTreeRootAsync(subtreeLeaves, hasher);
63
+ if (!root) {
64
+ root = subtreeRoot;
65
+ } else {
66
+ root = await hasher(subtreeRoot, root);
44
67
  }
45
68
  numRemainingLeaves -= subtreeSize;
46
69
  }
@@ -1,7 +1,7 @@
1
1
  import type { Hasher } from './hasher.js';
2
2
  import { SiblingPath } from './sibling_path.js';
3
3
  import { type TreeNodeLocation } from './unbalanced_tree_store.js';
4
- export declare function computeCompressedUnbalancedMerkleTreeRoot(leaves: Buffer[], valueToCompress?: Buffer<ArrayBuffer>, hasher?: Hasher['hash']): Buffer;
4
+ export declare function computeCompressedUnbalancedMerkleTreeRoot(leaves: Buffer[], valueToCompress?: Buffer<ArrayBuffer>, emptyRoot?: Buffer<ArrayBuffer>, hasher?: Hasher['hash']): Buffer;
5
5
  /**
6
6
  * An ephemeral unbalanced Merkle tree implementation.
7
7
  * Follows the rollup implementation which greedily hashes pairs of nodes up the tree.
@@ -13,11 +13,12 @@ export declare function computeCompressedUnbalancedMerkleTreeRoot(leaves: Buffer
13
13
  export declare class UnbalancedMerkleTreeCalculator {
14
14
  private readonly leaves;
15
15
  private readonly valueToCompress;
16
+ private readonly emptyRoot;
16
17
  private readonly hasher;
17
18
  private store;
18
19
  private leafLocations;
19
- constructor(leaves: Buffer[], valueToCompress: Buffer, hasher: Hasher['hash']);
20
- static create(leaves: Buffer[], valueToCompress?: Buffer<ArrayBuffer>, hasher?: (left: Buffer, right: Buffer) => Buffer<ArrayBuffer>): UnbalancedMerkleTreeCalculator;
20
+ constructor(leaves: Buffer[], valueToCompress: Buffer, emptyRoot: Buffer, hasher: Hasher['hash']);
21
+ static create(leaves: Buffer[], valueToCompress?: Buffer<ArrayBuffer>, emptyRoot?: Buffer<ArrayBuffer>, hasher?: (lhs: Uint8Array<ArrayBufferLike>, rhs: Uint8Array<ArrayBufferLike>) => Buffer<ArrayBuffer>): UnbalancedMerkleTreeCalculator;
21
22
  /**
22
23
  * Returns the root of the tree.
23
24
  * @returns The root of the tree.
@@ -43,6 +44,6 @@ export declare class UnbalancedMerkleTreeCalculator {
43
44
  */
44
45
  private buildTree;
45
46
  private shiftNodeUp;
46
- private shiftChildrenUp;
47
+ private collectNodesToShift;
47
48
  }
48
- //# sourceMappingURL=unbalanced_merkle_tree_calculator.d.ts.map
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iYWxhbmNlZF9tZXJrbGVfdHJlZV9jYWxjdWxhdG9yLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHJlZXMvdW5iYWxhbmNlZF9tZXJrbGVfdHJlZV9jYWxjdWxhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUMxQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDaEQsT0FBTyxFQUFFLEtBQUssZ0JBQWdCLEVBQXVCLE1BQU0sNEJBQTRCLENBQUM7QUFFeEYsd0JBQWdCLHlDQUF5QyxDQUN2RCxNQUFNLEVBQUUsTUFBTSxFQUFFLEVBQ2hCLGVBQWUsc0JBQW1CLEVBQ2xDLFNBQVMsc0JBQW1CLEVBQzVCLE1BQU0sQ0FBQyxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FDdEIsTUFBTSxDQUdSO0FBT0Q7Ozs7Ozs7R0FPRztBQUNILHFCQUFhLDhCQUE4QjtJQUt2QyxPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU07SUFDdkIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxlQUFlO0lBQ2hDLE9BQU8sQ0FBQyxRQUFRLENBQUMsU0FBUztJQUMxQixPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU07SUFQekIsT0FBTyxDQUFDLEtBQUssQ0FBZ0M7SUFDN0MsT0FBTyxDQUFDLGFBQWEsQ0FBMEI7SUFFL0MsWUFDbUIsTUFBTSxFQUFFLE1BQU0sRUFBRSxFQUNoQixlQUFlLEVBQUUsTUFBTSxFQUN2QixTQUFTLEVBQUUsTUFBTSxFQUNqQixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUl4QztJQUVELE1BQU0sQ0FBQyxNQUFNLENBQ1gsTUFBTSxFQUFFLE1BQU0sRUFBRSxFQUNoQixlQUFlLHNCQUFrQixFQUNqQyxTQUFTLHNCQUFtQixFQUM1QixNQUFNLDhGQUFnQixrQ0FHdkI7SUFFRDs7O09BR0c7SUFDSSxPQUFPLElBQUksTUFBTSxDQUV2QjtJQUVEOzs7OztPQUtHO0lBQ0ksY0FBYyxDQUFDLENBQUMsU0FBUyxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sR0FBRyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBT3JFO0lBRUQ7Ozs7T0FJRztJQUNJLHlCQUF5QixDQUFDLENBQUMsU0FBUyxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sR0FBRyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBbUJwRjtJQUVNLGVBQWUsQ0FBQyxTQUFTLEVBQUUsTUFBTSxvQkFFdkM7SUFFRDs7O09BR0c7SUFDSCxPQUFPLENBQUMsU0FBUztJQStDakIsT0FBTyxDQUFDLFdBQVc7SUFZbkIsT0FBTyxDQUFDLG1CQUFtQjtDQW1CNUIifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"unbalanced_merkle_tree_calculator.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_merkle_tree_calculator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,KAAK,gBAAgB,EAAuB,MAAM,4BAA4B,CAAC;AAExF,wBAAgB,yCAAyC,CACvD,MAAM,EAAE,MAAM,EAAE,EAChB,eAAe,sBAAmB,EAClC,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,GACtB,MAAM,CAGR;AAOD;;;;;;;GAOG;AACH,qBAAa,8BAA8B;IAKvC,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM;IANzB,OAAO,CAAC,KAAK,CAAgC;IAC7C,OAAO,CAAC,aAAa,CAA0B;gBAG5B,MAAM,EAAE,MAAM,EAAE,EAChB,eAAe,EAAE,MAAM,EACvB,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC;IAUzC,MAAM,CAAC,MAAM,CACX,MAAM,EAAE,MAAM,EAAE,EAChB,eAAe,sBAAkB,EACjC,MAAM,IAAI,MAAM,MAAM,EAAE,OAAO,MAAM,KAAkD,MAAM,CAAC,WAAW,CAAC;IAK5G;;;OAGG;IACI,OAAO,IAAI,MAAM;IAIxB;;;;;OAKG;IACI,cAAc,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC;IAStE;;;;OAIG;IACI,yBAAyB,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC;IAqB9E,eAAe,CAAC,SAAS,EAAE,MAAM;IAIxC;;;OAGG;IACH,OAAO,CAAC,SAAS;IAkDjB,OAAO,CAAC,WAAW;IAcnB,OAAO,CAAC,eAAe;CAoBxB"}
1
+ {"version":3,"file":"unbalanced_merkle_tree_calculator.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_merkle_tree_calculator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,KAAK,gBAAgB,EAAuB,MAAM,4BAA4B,CAAC;AAExF,wBAAgB,yCAAyC,CACvD,MAAM,EAAE,MAAM,EAAE,EAChB,eAAe,sBAAmB,EAClC,SAAS,sBAAmB,EAC5B,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,GACtB,MAAM,CAGR;AAOD;;;;;;;GAOG;AACH,qBAAa,8BAA8B;IAKvC,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAPzB,OAAO,CAAC,KAAK,CAAgC;IAC7C,OAAO,CAAC,aAAa,CAA0B;IAE/C,YACmB,MAAM,EAAE,MAAM,EAAE,EAChB,eAAe,EAAE,MAAM,EACvB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,EAIxC;IAED,MAAM,CAAC,MAAM,CACX,MAAM,EAAE,MAAM,EAAE,EAChB,eAAe,sBAAkB,EACjC,SAAS,sBAAmB,EAC5B,MAAM,8FAAgB,kCAGvB;IAED;;;OAGG;IACI,OAAO,IAAI,MAAM,CAEvB;IAED;;;;;OAKG;IACI,cAAc,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC,CAOrE;IAED;;;;OAIG;IACI,yBAAyB,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC,CAmBpF;IAEM,eAAe,CAAC,SAAS,EAAE,MAAM,oBAEvC;IAED;;;OAGG;IACH,OAAO,CAAC,SAAS;IA+CjB,OAAO,CAAC,WAAW;IAYnB,OAAO,CAAC,mBAAmB;CAmB5B"}
@@ -1,8 +1,8 @@
1
- import { sha256Trunc } from '../crypto/index.js';
1
+ import { shaMerkleHash } from './balanced_merkle_tree.js';
2
2
  import { SiblingPath } from './sibling_path.js';
3
3
  import { UnbalancedTreeStore } from './unbalanced_tree_store.js';
4
- export function computeCompressedUnbalancedMerkleTreeRoot(leaves, valueToCompress = Buffer.alloc(32), hasher) {
5
- const calculator = UnbalancedMerkleTreeCalculator.create(leaves, valueToCompress, hasher);
4
+ export function computeCompressedUnbalancedMerkleTreeRoot(leaves, valueToCompress = Buffer.alloc(32), emptyRoot = Buffer.alloc(32), hasher) {
5
+ const calculator = UnbalancedMerkleTreeCalculator.create(leaves, valueToCompress, emptyRoot, hasher);
6
6
  return calculator.getRoot();
7
7
  }
8
8
  /**
@@ -15,25 +15,21 @@ export function computeCompressedUnbalancedMerkleTreeRoot(leaves, valueToCompres
15
15
  */ export class UnbalancedMerkleTreeCalculator {
16
16
  leaves;
17
17
  valueToCompress;
18
+ emptyRoot;
18
19
  hasher;
19
20
  store;
20
21
  leafLocations;
21
- constructor(leaves, valueToCompress, hasher){
22
+ constructor(leaves, valueToCompress, emptyRoot, hasher){
22
23
  this.leaves = leaves;
23
24
  this.valueToCompress = valueToCompress;
25
+ this.emptyRoot = emptyRoot;
24
26
  this.hasher = hasher;
25
27
  this.leafLocations = [];
26
- if (leaves.length === 0) {
27
- throw Error('Cannot create a compressed unbalanced tree with 0 leaves.');
28
- }
29
28
  this.store = new UnbalancedTreeStore(leaves.length);
30
29
  this.buildTree();
31
30
  }
32
- static create(leaves, valueToCompress = Buffer.alloc(0), hasher = (left, right)=>sha256Trunc(Buffer.concat([
33
- left,
34
- right
35
- ]))) {
36
- return new UnbalancedMerkleTreeCalculator(leaves, valueToCompress, hasher);
31
+ static create(leaves, valueToCompress = Buffer.alloc(0), emptyRoot = Buffer.alloc(32), hasher = shaMerkleHash) {
32
+ return new UnbalancedMerkleTreeCalculator(leaves, valueToCompress, emptyRoot, hasher);
37
33
  }
38
34
  /**
39
35
  * Returns the root of the tree.
@@ -88,12 +84,12 @@ export function computeCompressedUnbalancedMerkleTreeRoot(leaves, valueToCompres
88
84
  // Start with the leaves that are not compressed.
89
85
  let toProcess = this.leafLocations.filter((_, i)=>!this.leaves[i].equals(this.valueToCompress));
90
86
  if (!toProcess.length) {
91
- // All leaves are compressed. Set 0 to the root.
87
+ // All leaves are compressed. Set empty root to the root.
92
88
  this.store.setNode({
93
89
  level: 0,
94
90
  index: 0
95
91
  }, {
96
- value: Buffer.alloc(32)
92
+ value: this.emptyRoot
97
93
  });
98
94
  return;
99
95
  }
@@ -114,10 +110,7 @@ export function computeCompressedUnbalancedMerkleTreeRoot(leaves, valueToCompres
114
110
  const shouldShiftUp = !sibling || sibling.value.equals(this.valueToCompress);
115
111
  if (shouldShiftUp) {
116
112
  // The node becomes the parent if the sibling is a compressed leaf.
117
- const isLeaf = this.shiftNodeUp(location, parentLocation);
118
- if (!isLeaf) {
119
- this.shiftChildrenUp(location);
120
- }
113
+ this.shiftNodeUp(location, parentLocation);
121
114
  } else {
122
115
  // Hash the value with the (right) sibling and update the parent node.
123
116
  const node = this.store.getNode(location);
@@ -132,31 +125,34 @@ export function computeCompressedUnbalancedMerkleTreeRoot(leaves, valueToCompres
132
125
  toProcess = toProcessNext;
133
126
  }
134
127
  }
135
- shiftNodeUp(fromLocation, toLocation) {
136
- const node = this.store.getNode(fromLocation);
137
- this.store.setNode(toLocation, node);
138
- const isLeaf = node.leafIndex !== undefined;
139
- if (isLeaf) {
140
- // Update the location if the node is a leaf.
141
- this.leafLocations[node.leafIndex] = toLocation;
128
+ shiftNodeUp(from, to) {
129
+ // Collect all nodes that need to shift.
130
+ const nodesToShift = this.collectNodesToShift(from, to);
131
+ // Move all nodes to their new locations.
132
+ for (const { node, newLocation } of nodesToShift){
133
+ this.store.setNode(newLocation, node);
134
+ if (node.leafIndex !== undefined) {
135
+ this.leafLocations[node.leafIndex] = newLocation;
136
+ }
142
137
  }
143
- return isLeaf;
144
138
  }
145
- shiftChildrenUp(parent) {
146
- const [left, right] = this.store.getChildLocations(parent);
147
- const level = parent.level;
148
- const groupSize = 2 ** level;
149
- const computeNewLocation = (index)=>({
150
- level,
151
- index: Math.floor(index / (groupSize * 2)) * groupSize + index % groupSize
152
- });
153
- const isLeftLeaf = this.shiftNodeUp(left, computeNewLocation(left.index));
154
- const isRightLeaf = this.shiftNodeUp(right, computeNewLocation(right.index));
155
- if (!isLeftLeaf) {
156
- this.shiftChildrenUp(left);
139
+ collectNodesToShift(from, to) {
140
+ const node = this.store.getNode(from);
141
+ if (!node) {
142
+ return [];
157
143
  }
158
- if (!isRightLeaf) {
159
- this.shiftChildrenUp(right);
144
+ let result = [
145
+ {
146
+ node,
147
+ newLocation: to
148
+ }
149
+ ];
150
+ // If not a leaf, collect its children.
151
+ if (node.leafIndex === undefined) {
152
+ const [leftChild, rightChild] = this.store.getChildLocations(from);
153
+ const [leftChildNew, rightChildNew] = this.store.getChildLocations(to);
154
+ result = result.concat(this.collectNodesToShift(leftChild, leftChildNew)).concat(this.collectNodesToShift(rightChild, rightChildNew));
160
155
  }
156
+ return result;
161
157
  }
162
158
  }
@@ -17,4 +17,4 @@ export declare class UnbalancedTreeStore<T> {
17
17
  getSibling(location: TreeNodeLocation): T | undefined;
18
18
  getChildren(location: TreeNodeLocation): [T | undefined, T | undefined];
19
19
  }
20
- //# sourceMappingURL=unbalanced_tree_store.d.ts.map
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iYWxhbmNlZF90cmVlX3N0b3JlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHJlZXMvdW5iYWxhbmNlZF90cmVlX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sV0FBVyxnQkFBZ0I7SUFDL0IsS0FBSyxFQUFFLE1BQU0sQ0FBQztJQUNkLEtBQUssRUFBRSxNQUFNLENBQUM7Q0FDZjtBQU9ELHFCQUFhLG1CQUFtQixDQUFDLENBQUM7O0lBSWhDLFlBQVksU0FBUyxFQUFFLE1BQU0sRUFFNUI7SUFFRCxPQUFPLENBQUMsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsQ0FBQyxHQUFHLGdCQUFnQixDQWVyRDtJQUVELE9BQU8sQ0FBQyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxnQkFBZ0IsRUFBRSxLQUFLLEVBQUUsQ0FBQyxRQVNuRDtJQUVELGlCQUFpQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLGdCQUFnQixDQU10RTtJQUVELGtCQUFrQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLGdCQUFnQixDQU12RTtJQUVELGlCQUFpQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLENBQUMsZ0JBQWdCLEVBQUUsZ0JBQWdCLENBQUMsQ0FJMUY7SUFFRCxPQUFPLENBQUMsU0FBUyxFQUFFLE1BQU0sR0FBRyxDQUFDLEdBQUcsU0FBUyxDQU94QztJQUVELE9BQU8sQ0FBQyxRQUFRLEVBQUUsZ0JBQWdCLEdBQUcsQ0FBQyxHQUFHLFNBQVMsQ0FFakQ7SUFFRCxPQUFPLElBQUksQ0FBQyxHQUFHLFNBQVMsQ0FFdkI7SUFFRCxTQUFTLENBQUMsUUFBUSxFQUFFLGdCQUFnQixHQUFHLENBQUMsR0FBRyxTQUFTLENBR25EO0lBRUQsVUFBVSxDQUFDLFFBQVEsRUFBRSxnQkFBZ0IsR0FBRyxDQUFDLEdBQUcsU0FBUyxDQUdwRDtJQUVELFdBQVcsQ0FBQyxRQUFRLEVBQUUsZ0JBQWdCLEdBQUcsQ0FBQyxDQUFDLEdBQUcsU0FBUyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FHdEU7Q0FLRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"unbalanced_tree_store.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_tree_store.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAOD,qBAAa,mBAAmB,CAAC,CAAC;;gBAIpB,SAAS,EAAE,MAAM;IAI7B,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,gBAAgB;IAiBtD,OAAO,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC;IAWpD,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB;IAQvE,kBAAkB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB;IAQxE,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,CAAC,gBAAgB,EAAE,gBAAgB,CAAC;IAM3F,OAAO,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,GAAG,SAAS;IASzC,OAAO,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAIlD,OAAO,IAAI,CAAC,GAAG,SAAS;IAIxB,SAAS,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAKpD,UAAU,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAKrD,WAAW,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC;CAQxE"}
1
+ {"version":3,"file":"unbalanced_tree_store.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_tree_store.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAOD,qBAAa,mBAAmB,CAAC,CAAC;;IAIhC,YAAY,SAAS,EAAE,MAAM,EAE5B;IAED,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,gBAAgB,CAerD;IAED,OAAO,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,QASnD;IAED,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB,CAMtE;IAED,kBAAkB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB,CAMvE;IAED,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,CAAC,gBAAgB,EAAE,gBAAgB,CAAC,CAI1F;IAED,OAAO,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,GAAG,SAAS,CAOxC;IAED,OAAO,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAEjD;IAED,OAAO,IAAI,CAAC,GAAG,SAAS,CAEvB;IAED,SAAS,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAGnD;IAED,UAAU,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAGpD;IAED,WAAW,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC,CAGtE;CAKF"}
@@ -39,4 +39,4 @@ export interface TypedEventEmitter<TEventMap extends {
39
39
  removeListener<K extends keyof TEventMap>(event: K, listener: TEventMap[K]): this;
40
40
  removeAllListeners<K extends keyof TEventMap>(event: K): this;
41
41
  }
42
- //# sourceMappingURL=index.d.ts.map
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxnQ0FBZ0M7QUFDaEMsTUFBTSxNQUFNLFFBQVEsQ0FBQyxDQUFDLElBQUk7S0FDdkIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxRQUFRLEdBQUcsS0FBSyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQzFELENBQUM7QUFFRixrQ0FBa0M7QUFDbEMsTUFBTSxNQUFNLFdBQVcsQ0FBQyxDQUFDLElBQUk7S0FDMUIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxRQUFRLEdBQUcsQ0FBQyxHQUFHLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQzFELENBQUM7QUFFRix1REFBdUQ7QUFDdkQsTUFBTSxNQUFNLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxTQUFTLE1BQU0sQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUUvRSw2Q0FBNkM7QUFDN0MsTUFBTSxNQUFNLFNBQVMsQ0FBQyxDQUFDLElBQUk7SUFBRSxDQUFDLFVBQVUsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FBRSxDQUFDO0FBRTlELGdEQUFnRDtBQUNoRCx3QkFBZ0IsUUFBUSxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FFaEQ7QUFFRCxxREFBcUQ7QUFDckQsTUFBTSxNQUFNLFFBQVEsQ0FBQyxDQUFDLElBQUk7S0FDdkIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FDckIsR0FBRyxFQUFFLENBQUM7QUFFUDs7Ozs7Ozs7OztHQVVHO0FBQ0gsTUFBTSxXQUFXLGlCQUFpQixDQUFDLFNBQVMsU0FBUztLQUFHLEdBQUcsSUFBSSxNQUFNLFNBQVMsR0FBRyxDQUFDLEdBQUcsSUFBSSxFQUFFLEdBQUcsRUFBRSxLQUFLLElBQUk7Q0FBRTtJQUN6RyxJQUFJLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDeEUsRUFBRSxDQUFDLENBQUMsU0FBUyxNQUFNLFNBQVMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0lBQ3RFLEdBQUcsQ0FBQyxDQUFDLFNBQVMsTUFBTSxTQUFTLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxRQUFRLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUN2RSxJQUFJLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsR0FBRyxJQUFJLEVBQUUsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLE9BQU8sQ0FBQztJQUN0RixjQUFjLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDbEYsa0JBQWtCLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDO0NBRS9EIn0=
@@ -6,4 +6,4 @@
6
6
  * @api public
7
7
  */
8
8
  export declare function fileURLToPath(uri: string): string;
9
- //# sourceMappingURL=index.d.ts.map
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cmwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJBOzs7Ozs7R0FNRztBQUVILHdCQUFnQixhQUFhLENBQUMsR0FBRyxFQUFFLE1BQU0sR0FBRyxNQUFNLENBNENqRCJ9
@@ -6,4 +6,4 @@ export declare function required<T>(value: T | undefined, errMsg?: string): T;
6
6
  * @param err - Error message to throw if x isn't met.
7
7
  */
8
8
  export declare function assert(x: any, err: string): asserts x;
9
- //# sourceMappingURL=index.d.ts.map
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy92YWxpZGF0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHlFQUF5RTtBQUN6RSx3QkFBZ0IsUUFBUSxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxHQUFHLFNBQVMsRUFBRSxNQUFNLENBQUMsRUFBRSxNQUFNLEdBQUcsQ0FBQyxDQUtwRTtBQUVEOzs7O0dBSUc7QUFDSCx3QkFBZ0IsTUFBTSxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUlyRCJ9
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/foundation",
3
- "version": "3.0.0-devnet.6",
3
+ "version": "3.0.0-devnet.6-patch.1",
4
4
  "type": "module",
5
5
  "main": "./dest/index.js",
6
6
  "types": "./dest/index.d.ts",
@@ -12,10 +12,30 @@
12
12
  "./async-map": "./dest/async-map/index.js",
13
13
  "./async-pool": "./dest/async-pool/index.js",
14
14
  "./bigint": "./dest/bigint/index.js",
15
+ "./branded-types": "./dest/branded-types/index.js",
15
16
  "./collection": "./dest/collection/index.js",
16
17
  "./config": "./dest/config/index.js",
17
- "./crypto": "./dest/crypto/index.js",
18
+ "./crypto/aes128": "./dest/crypto/aes128/index.js",
19
+ "./crypto/bls": "./dest/crypto/bls/index.js",
20
+ "./crypto/bls/bn254_keystore": "./dest/crypto/bls/bn254_keystore.js",
21
+ "./crypto/bn254": "./dest/crypto/bn254/index.js",
22
+ "./crypto/ecdsa": "./dest/crypto/ecdsa/index.js",
23
+ "./crypto/grumpkin": "./dest/crypto/grumpkin/index.js",
24
+ "./crypto/keccak": "./dest/crypto/keccak/index.js",
25
+ "./crypto/keys": "./dest/crypto/keys/index.js",
26
+ "./crypto/pedersen": "./dest/crypto/pedersen/index.js",
27
+ "./crypto/poseidon": "./dest/crypto/poseidon/index.js",
28
+ "./crypto/random": "./dest/crypto/random/index.js",
29
+ "./crypto/schnorr": "./dest/crypto/schnorr/index.js",
30
+ "./crypto/secp256k1": "./dest/crypto/secp256k1/index.js",
31
+ "./crypto/secp256k1-signer": "./dest/crypto/secp256k1-signer/index.js",
32
+ "./crypto/sha256": "./dest/crypto/sha256/index.js",
33
+ "./crypto/sha512": "./dest/crypto/sha512/index.js",
34
+ "./crypto/signature": "./dest/crypto/signature/index.js",
18
35
  "./crypto/sync": "./dest/crypto/sync/index.js",
36
+ "./curves/bn254": "./dest/curves/bn254/index.js",
37
+ "./curves/grumpkin": "./dest/curves/grumpkin/index.js",
38
+ "./curves/bls12": "./dest/curves/bls12/index.js",
19
39
  "./decorators": "./dest/decorators/index.js",
20
40
  "./error": "./dest/error/index.js",
21
41
  "./eth-address": "./dest/eth-address/index.js",
@@ -31,7 +51,6 @@
31
51
  "./iterable": "./dest/iterable/index.js",
32
52
  "./log": "./dest/log/index.js",
33
53
  "./mutex": "./dest/mutex/index.js",
34
- "./fields": "./dest/fields/index.js",
35
54
  "./retry": "./dest/retry/index.js",
36
55
  "./running-promise": "./dest/running-promise/index.js",
37
56
  "./serialize": "./dest/serialize/index.js",
@@ -56,8 +75,8 @@
56
75
  "./number": "./dest/number/index.js"
57
76
  },
58
77
  "scripts": {
59
- "build": "yarn clean && tsc -b",
60
- "build:dev": "tsc -b --watch",
78
+ "build": "yarn clean && ../scripts/tsc.sh",
79
+ "build:dev": "../scripts/tsc.sh --watch",
61
80
  "clean": "rm -rf ./dest .tsbuildinfo",
62
81
  "generate": "true",
63
82
  "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}"
@@ -103,9 +122,11 @@
103
122
  "testEnvironment": "../../foundation/src/jest/env.mjs"
104
123
  },
105
124
  "dependencies": {
106
- "@aztec/bb.js": "3.0.0-devnet.6",
125
+ "@aztec/bb.js": "3.0.0-devnet.6-patch.1",
107
126
  "@koa/cors": "^5.0.0",
108
127
  "@noble/curves": "=1.7.0",
128
+ "@noble/hashes": "^1.6.1",
129
+ "@scure/bip39": "^2.0.1",
109
130
  "bn.js": "^5.2.1",
110
131
  "colorette": "^2.0.20",
111
132
  "detect-node": "^2.1.0",
@@ -140,6 +161,7 @@
140
161
  "@types/node": "^22.15.17",
141
162
  "@types/pako": "^2.0.0",
142
163
  "@types/supertest": "^2.0.12",
164
+ "@typescript/native-preview": "7.0.0-dev.20251126.1",
143
165
  "comlink": "^4.4.1",
144
166
  "eslint": "^9.26.0",
145
167
  "eslint-config-prettier": "^10.1.5",
@@ -154,7 +176,7 @@
154
176
  "ts-node": "^10.9.1",
155
177
  "typescript": "^5.3.3",
156
178
  "typescript-eslint": "^8.32.1",
157
- "viem": "npm:@spalladino/viem@2.38.2-eip7594.0"
179
+ "viem": "npm:@aztec/viem@2.38.2"
158
180
  },
159
181
  "files": [
160
182
  "dest",
@@ -42,22 +42,6 @@ export async function makeTupleAsync<T, N extends number>(length: N, fn: (i: num
42
42
  )) as Tuple<T, N>;
43
43
  }
44
44
 
45
- /**
46
- * Create an array over an integer range, filled with a function 'fn'. However, the latter half of the array are set to zeros.
47
- * see `makeTuple` above.
48
- * @param n - The number of integers.
49
- * @param fn - The generator function.
50
- * @returns The array of numbers.
51
- */
52
- export function makeHalfFullTuple<T, N extends number>(
53
- length: N,
54
- fn: (i: number) => T,
55
- offset = 0,
56
- makeEmpty: () => T,
57
- ) {
58
- return Array.from({ length }, (_: any, i: number) => (i < length / 2 ? fn(i + offset) : makeEmpty())) as Tuple<T, N>;
59
- }
60
-
61
45
  /**
62
46
  * Assert a member of an object is a certain length.
63
47
  * @param obj - An object.