@aztec/foundation 0.0.0-test.0 → 0.0.1-commit.001888fc

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 (721) hide show
  1. package/dest/array/array.d.ts +6 -9
  2. package/dest/array/array.d.ts.map +1 -1
  3. package/dest/array/array.js +11 -11
  4. package/dest/array/index.d.ts +2 -1
  5. package/dest/array/index.d.ts.map +1 -1
  6. package/dest/array/index.js +1 -0
  7. package/dest/array/sorted_array.d.ts +15 -0
  8. package/dest/array/sorted_array.d.ts.map +1 -0
  9. package/dest/array/sorted_array.js +109 -0
  10. package/dest/async-map/index.d.ts +1 -1
  11. package/dest/async-pool/index.d.ts +1 -1
  12. package/dest/async-pool/index.d.ts.map +1 -1
  13. package/dest/async-pool/index.js +1 -0
  14. package/dest/bigint/index.d.ts +7 -0
  15. package/dest/bigint/index.d.ts.map +1 -0
  16. package/dest/bigint/index.js +15 -0
  17. package/dest/bigint-buffer/index.d.ts +1 -3
  18. package/dest/bigint-buffer/index.d.ts.map +1 -1
  19. package/dest/branded-types/block_number.d.ts +56 -0
  20. package/dest/branded-types/block_number.d.ts.map +1 -0
  21. package/dest/branded-types/block_number.js +78 -0
  22. package/dest/branded-types/checkpoint_number.d.ts +54 -0
  23. package/dest/branded-types/checkpoint_number.d.ts.map +1 -0
  24. package/dest/branded-types/checkpoint_number.js +77 -0
  25. package/dest/branded-types/epoch.d.ts +42 -0
  26. package/dest/branded-types/epoch.d.ts.map +1 -0
  27. package/dest/branded-types/epoch.js +59 -0
  28. package/dest/branded-types/index.d.ts +7 -0
  29. package/dest/branded-types/index.d.ts.map +1 -0
  30. package/dest/branded-types/index.js +5 -0
  31. package/dest/branded-types/index_within_checkpoint.d.ts +42 -0
  32. package/dest/branded-types/index_within_checkpoint.d.ts.map +1 -0
  33. package/dest/branded-types/index_within_checkpoint.js +59 -0
  34. package/dest/branded-types/slot.d.ts +42 -0
  35. package/dest/branded-types/slot.d.ts.map +1 -0
  36. package/dest/branded-types/slot.js +59 -0
  37. package/dest/branded-types/types.d.ts +5 -0
  38. package/dest/branded-types/types.d.ts.map +1 -0
  39. package/dest/branded-types/types.js +1 -0
  40. package/dest/buffer/buffer16.d.ts +80 -0
  41. package/dest/buffer/buffer16.d.ts.map +1 -0
  42. package/dest/buffer/buffer16.js +102 -0
  43. package/dest/buffer/buffer32.d.ts +5 -9
  44. package/dest/buffer/buffer32.d.ts.map +1 -1
  45. package/dest/buffer/buffer32.js +9 -7
  46. package/dest/buffer/index.d.ts +3 -1
  47. package/dest/buffer/index.d.ts.map +1 -1
  48. package/dest/buffer/index.js +2 -0
  49. package/dest/buffer/utils.d.ts +3 -0
  50. package/dest/buffer/utils.d.ts.map +1 -0
  51. package/dest/buffer/utils.js +7 -0
  52. package/dest/collection/array.d.ts +28 -4
  53. package/dest/collection/array.d.ts.map +1 -1
  54. package/dest/collection/array.js +108 -3
  55. package/dest/collection/index.d.ts +1 -1
  56. package/dest/collection/object.d.ts +17 -1
  57. package/dest/collection/object.d.ts.map +1 -1
  58. package/dest/collection/object.js +25 -0
  59. package/dest/committable/committable.d.ts +1 -1
  60. package/dest/committable/committable.d.ts.map +1 -1
  61. package/dest/committable/index.d.ts +1 -1
  62. package/dest/config/env_var.d.ts +2 -2
  63. package/dest/config/env_var.d.ts.map +1 -1
  64. package/dest/config/index.d.ts +62 -4
  65. package/dest/config/index.d.ts.map +1 -1
  66. package/dest/config/index.js +158 -12
  67. package/dest/config/network_config.d.ts +72 -0
  68. package/dest/config/network_config.d.ts.map +1 -0
  69. package/dest/config/network_config.js +14 -0
  70. package/dest/config/network_name.d.ts +3 -0
  71. package/dest/config/network_name.d.ts.map +1 -0
  72. package/dest/config/network_name.js +21 -0
  73. package/dest/config/parse-env.d.ts +3 -0
  74. package/dest/config/parse-env.d.ts.map +1 -0
  75. package/dest/config/parse-env.js +7 -0
  76. package/dest/config/secret_value.d.ts +28 -0
  77. package/dest/config/secret_value.d.ts.map +1 -0
  78. package/dest/config/secret_value.js +36 -0
  79. package/dest/crypto/aes128/index.d.ts +3 -5
  80. package/dest/crypto/aes128/index.d.ts.map +1 -1
  81. package/dest/crypto/aes128/index.js +19 -6
  82. package/dest/crypto/bls/bn254_keystore.d.ts +296 -0
  83. package/dest/crypto/bls/bn254_keystore.d.ts.map +1 -0
  84. package/dest/crypto/bls/bn254_keystore.js +218 -0
  85. package/dest/crypto/bls/index.d.ts +13 -0
  86. package/dest/crypto/bls/index.d.ts.map +1 -0
  87. package/dest/crypto/bls/index.js +87 -0
  88. package/dest/crypto/bn254/index.d.ts +39 -0
  89. package/dest/crypto/bn254/index.d.ts.map +1 -0
  90. package/dest/crypto/bn254/index.js +56 -0
  91. package/dest/crypto/ecdsa/index.d.ts +3 -3
  92. package/dest/crypto/ecdsa/index.d.ts.map +1 -1
  93. package/dest/crypto/ecdsa/index.js +62 -48
  94. package/dest/crypto/ecdsa/signature.d.ts +3 -5
  95. package/dest/crypto/ecdsa/signature.d.ts.map +1 -1
  96. package/dest/crypto/ecdsa/signature.js +2 -2
  97. package/dest/crypto/grumpkin/index.d.ts +10 -15
  98. package/dest/crypto/grumpkin/index.d.ts.map +1 -1
  99. package/dest/crypto/grumpkin/index.js +61 -55
  100. package/dest/crypto/keccak/index.d.ts +3 -5
  101. package/dest/crypto/keccak/index.d.ts.map +1 -1
  102. package/dest/crypto/keys/index.d.ts +2 -4
  103. package/dest/crypto/keys/index.d.ts.map +1 -1
  104. package/dest/crypto/keys/index.js +8 -5
  105. package/dest/crypto/pedersen/index.d.ts +1 -1
  106. package/dest/crypto/pedersen/pedersen.noble.d.ts +3 -5
  107. package/dest/crypto/pedersen/pedersen.noble.d.ts.map +1 -1
  108. package/dest/crypto/pedersen/pedersen.wasm.d.ts +4 -6
  109. package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -1
  110. package/dest/crypto/pedersen/pedersen.wasm.js +24 -14
  111. package/dest/crypto/poseidon/index.d.ts +2 -5
  112. package/dest/crypto/poseidon/index.d.ts.map +1 -1
  113. package/dest/crypto/poseidon/index.js +27 -21
  114. package/dest/crypto/random/index.d.ts +2 -4
  115. package/dest/crypto/random/index.d.ts.map +1 -1
  116. package/dest/crypto/random/index.js +2 -34
  117. package/dest/crypto/random/randomness_singleton.d.ts +4 -5
  118. package/dest/crypto/random/randomness_singleton.d.ts.map +1 -1
  119. package/dest/crypto/random/randomness_singleton.js +5 -5
  120. package/dest/crypto/schnorr/index.d.ts +3 -2
  121. package/dest/crypto/schnorr/index.d.ts.map +1 -1
  122. package/dest/crypto/schnorr/index.js +30 -38
  123. package/dest/crypto/schnorr/signature.d.ts +5 -7
  124. package/dest/crypto/schnorr/signature.d.ts.map +1 -1
  125. package/dest/crypto/schnorr/signature.js +2 -2
  126. package/dest/crypto/secp256k1/index.d.ts +5 -7
  127. package/dest/crypto/secp256k1/index.d.ts.map +1 -1
  128. package/dest/crypto/secp256k1/index.js +23 -18
  129. package/dest/crypto/secp256k1-signer/index.d.ts +1 -1
  130. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts +1 -1
  131. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts.map +1 -1
  132. package/dest/crypto/secp256k1-signer/utils.d.ts +67 -5
  133. package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -1
  134. package/dest/crypto/secp256k1-signer/utils.js +118 -6
  135. package/dest/crypto/serialize.d.ts +5 -7
  136. package/dest/crypto/serialize.d.ts.map +1 -1
  137. package/dest/crypto/sha256/index.d.ts +23 -6
  138. package/dest/crypto/sha256/index.d.ts.map +1 -1
  139. package/dest/crypto/sha256/index.js +43 -1
  140. package/dest/crypto/sha512/index.d.ts +3 -5
  141. package/dest/crypto/sha512/index.d.ts.map +1 -1
  142. package/dest/crypto/sha512/index.js +1 -1
  143. package/dest/crypto/signature/index.d.ts +2 -4
  144. package/dest/crypto/signature/index.d.ts.map +1 -1
  145. package/dest/crypto/sync/index.d.ts +1 -1
  146. package/dest/crypto/sync/index.js +1 -1
  147. package/dest/crypto/sync/pedersen/index.d.ts +4 -6
  148. package/dest/crypto/sync/pedersen/index.d.ts.map +1 -1
  149. package/dest/crypto/sync/pedersen/index.js +18 -11
  150. package/dest/crypto/sync/poseidon/index.d.ts +2 -5
  151. package/dest/crypto/sync/poseidon/index.d.ts.map +1 -1
  152. package/dest/crypto/sync/poseidon/index.js +23 -16
  153. package/dest/curves/bls12/field.d.ts +148 -0
  154. package/dest/curves/bls12/field.d.ts.map +1 -0
  155. package/dest/curves/bls12/field.js +362 -0
  156. package/dest/curves/bls12/index.d.ts +3 -0
  157. package/dest/curves/bls12/index.d.ts.map +1 -0
  158. package/dest/curves/bls12/index.js +2 -0
  159. package/dest/curves/bls12/point.d.ts +229 -0
  160. package/dest/curves/bls12/point.d.ts.map +1 -0
  161. package/dest/curves/bls12/point.js +400 -0
  162. package/dest/curves/bn254/field.d.ts +181 -0
  163. package/dest/curves/bn254/field.d.ts.map +1 -0
  164. package/dest/{fields/fields.js → curves/bn254/field.js} +93 -62
  165. package/dest/curves/bn254/index.d.ts +3 -0
  166. package/dest/curves/bn254/index.d.ts.map +1 -0
  167. package/dest/curves/bn254/index.js +2 -0
  168. package/dest/curves/bn254/point.d.ts +54 -0
  169. package/dest/curves/bn254/point.d.ts.map +1 -0
  170. package/dest/curves/bn254/point.js +143 -0
  171. package/dest/curves/grumpkin/index.d.ts +10 -0
  172. package/dest/curves/grumpkin/index.d.ts.map +1 -0
  173. package/dest/curves/grumpkin/index.js +3 -0
  174. package/dest/{fields → curves/grumpkin}/point.d.ts +14 -7
  175. package/dest/curves/grumpkin/point.d.ts.map +1 -0
  176. package/dest/{fields → curves/grumpkin}/point.js +27 -10
  177. package/dest/decorators/index.d.ts +1 -1
  178. package/dest/decorators/memoize.d.ts +1 -1
  179. package/dest/decorators/memoize.d.ts.map +1 -1
  180. package/dest/error/index.d.ts +1 -1
  181. package/dest/eth-address/index.d.ts +18 -9
  182. package/dest/eth-address/index.d.ts.map +1 -1
  183. package/dest/eth-address/index.js +31 -2
  184. package/dest/eth-signature/eth_signature.d.ts +18 -15
  185. package/dest/eth-signature/eth_signature.d.ts.map +1 -1
  186. package/dest/eth-signature/eth_signature.js +37 -18
  187. package/dest/eth-signature/index.d.ts +1 -1
  188. package/dest/fs/index.d.ts +2 -1
  189. package/dest/fs/index.d.ts.map +1 -1
  190. package/dest/fs/index.js +1 -0
  191. package/dest/fs/run_in_dir.d.ts +1 -1
  192. package/dest/fs/try_rm_dir.d.ts +3 -0
  193. package/dest/fs/try_rm_dir.d.ts.map +1 -0
  194. package/dest/fs/try_rm_dir.js +16 -0
  195. package/dest/iterable/all.d.ts +1 -1
  196. package/dest/iterable/filter.d.ts +1 -1
  197. package/dest/iterable/filter.js +1 -1
  198. package/dest/iterable/index.d.ts +1 -1
  199. package/dest/iterable/isAsyncIt.d.ts +1 -1
  200. package/dest/iterable/map.d.ts +1 -1
  201. package/dest/iterable/map.js +1 -1
  202. package/dest/iterable/peek.d.ts +1 -1
  203. package/dest/iterable/sort.d.ts +1 -1
  204. package/dest/iterable/take.d.ts +1 -1
  205. package/dest/iterable/toArray.d.ts +1 -1
  206. package/dest/iterator/filter.d.ts +3 -0
  207. package/dest/iterator/filter.d.ts.map +1 -0
  208. package/dest/iterator/filter.js +7 -0
  209. package/dest/iterator/index.d.ts +2 -0
  210. package/dest/iterator/index.d.ts.map +1 -0
  211. package/dest/iterator/index.js +1 -0
  212. package/dest/jest/env.js +48 -0
  213. package/dest/jest/setup.js +28 -1
  214. package/dest/jest/setupAfterEnv.js +3 -0
  215. package/dest/json-rpc/client/fetch.d.ts +3 -3
  216. package/dest/json-rpc/client/fetch.d.ts.map +1 -1
  217. package/dest/json-rpc/client/fetch.js +16 -30
  218. package/dest/json-rpc/client/index.d.ts +1 -1
  219. package/dest/json-rpc/client/safe_json_rpc_client.d.ts +11 -4
  220. package/dest/json-rpc/client/safe_json_rpc_client.d.ts.map +1 -1
  221. package/dest/json-rpc/client/safe_json_rpc_client.js +173 -13
  222. package/dest/json-rpc/client/undici.d.ts +1 -1
  223. package/dest/json-rpc/client/undici.d.ts.map +1 -1
  224. package/dest/json-rpc/client/undici.js +27 -11
  225. package/dest/json-rpc/convert.d.ts +3 -10
  226. package/dest/json-rpc/convert.d.ts.map +1 -1
  227. package/dest/json-rpc/convert.js +1 -9
  228. package/dest/json-rpc/errors.d.ts +4 -0
  229. package/dest/json-rpc/errors.d.ts.map +1 -0
  230. package/dest/json-rpc/errors.js +6 -0
  231. package/dest/json-rpc/fixtures/class_a.d.ts +6 -4
  232. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -1
  233. package/dest/json-rpc/fixtures/class_b.d.ts +6 -4
  234. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -1
  235. package/dest/json-rpc/fixtures/test_state.d.ts +1 -1
  236. package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -1
  237. package/dest/json-rpc/index.d.ts +3 -2
  238. package/dest/json-rpc/index.d.ts.map +1 -1
  239. package/dest/json-rpc/index.js +2 -1
  240. package/dest/json-rpc/js_utils.d.ts +1 -1
  241. package/dest/json-rpc/js_utils.d.ts.map +1 -1
  242. package/dest/json-rpc/server/api_key_auth.d.ts +19 -0
  243. package/dest/json-rpc/server/api_key_auth.d.ts.map +1 -0
  244. package/dest/json-rpc/server/api_key_auth.js +57 -0
  245. package/dest/json-rpc/server/index.d.ts +2 -1
  246. package/dest/json-rpc/server/index.d.ts.map +1 -1
  247. package/dest/json-rpc/server/index.js +1 -0
  248. package/dest/json-rpc/server/safe_json_rpc_server.d.ts +22 -23
  249. package/dest/json-rpc/server/safe_json_rpc_server.d.ts.map +1 -1
  250. package/dest/json-rpc/server/safe_json_rpc_server.js +161 -56
  251. package/dest/json-rpc/test/index.d.ts +1 -1
  252. package/dest/json-rpc/test/integration.d.ts +2 -3
  253. package/dest/json-rpc/test/integration.d.ts.map +1 -1
  254. package/dest/log/bigint-utils.d.ts +5 -0
  255. package/dest/log/bigint-utils.d.ts.map +1 -0
  256. package/dest/log/bigint-utils.js +21 -0
  257. package/dest/log/console.d.ts +1 -1
  258. package/dest/log/console.d.ts.map +1 -1
  259. package/dest/log/gcloud-logger-config.d.ts +1 -2
  260. package/dest/log/gcloud-logger-config.d.ts.map +1 -1
  261. package/dest/log/gcloud-logger-config.js +4 -9
  262. package/dest/log/index.d.ts +5 -5
  263. package/dest/log/index.d.ts.map +1 -1
  264. package/dest/log/index.js +4 -4
  265. package/dest/log/libp2p_logger.d.ts +5 -2
  266. package/dest/log/libp2p_logger.d.ts.map +1 -1
  267. package/dest/log/libp2p_logger.js +27 -6
  268. package/dest/log/log-filters.d.ts +17 -4
  269. package/dest/log/log-filters.d.ts.map +1 -1
  270. package/dest/log/log-filters.js +26 -12
  271. package/dest/log/log-levels.d.ts +1 -1
  272. package/dest/log/log_fn.d.ts +2 -2
  273. package/dest/log/log_fn.d.ts.map +1 -1
  274. package/dest/log/noir_debug_log_util.d.ts +14 -0
  275. package/dest/log/noir_debug_log_util.d.ts.map +1 -0
  276. package/dest/log/noir_debug_log_util.js +14 -0
  277. package/dest/log/pino-logger-server.d.ts +9 -0
  278. package/dest/log/pino-logger-server.d.ts.map +1 -0
  279. package/dest/log/pino-logger-server.js +18 -0
  280. package/dest/log/pino-logger.d.ts +40 -11
  281. package/dest/log/pino-logger.d.ts.map +1 -1
  282. package/dest/log/pino-logger.js +149 -30
  283. package/dest/message/index.d.ts +1 -1
  284. package/dest/message/index.d.ts.map +1 -1
  285. package/dest/mutex/index.d.ts +1 -1
  286. package/dest/mutex/index.d.ts.map +1 -1
  287. package/dest/mutex/mutex_database.d.ts +1 -1
  288. package/dest/mutex/mutex_database.d.ts.map +1 -1
  289. package/dest/noir/index.d.ts +1 -1
  290. package/dest/noir/noir_package_config.d.ts +9 -9
  291. package/dest/number/index.d.ts +3 -0
  292. package/dest/number/index.d.ts.map +1 -0
  293. package/dest/number/index.js +12 -0
  294. package/dest/profiler/index.d.ts +2 -0
  295. package/dest/profiler/index.d.ts.map +1 -0
  296. package/dest/profiler/index.js +1 -0
  297. package/dest/profiler/profiler.d.ts +8 -0
  298. package/dest/profiler/profiler.d.ts.map +1 -0
  299. package/dest/profiler/profiler.js +97 -0
  300. package/dest/promise/index.d.ts +1 -1
  301. package/dest/promise/running-promise.d.ts +2 -2
  302. package/dest/promise/running-promise.d.ts.map +1 -1
  303. package/dest/promise/running-promise.js +2 -2
  304. package/dest/promise/utils.d.ts +1 -1
  305. package/dest/queue/base_memory_queue.d.ts +2 -2
  306. package/dest/queue/base_memory_queue.d.ts.map +1 -1
  307. package/dest/queue/batch_queue.d.ts +2 -2
  308. package/dest/queue/batch_queue.d.ts.map +1 -1
  309. package/dest/queue/batch_queue.js +1 -1
  310. package/dest/queue/bounded_serial_queue.d.ts +1 -1
  311. package/dest/queue/bounded_serial_queue.d.ts.map +1 -1
  312. package/dest/queue/fifo_memory_queue.d.ts +1 -1
  313. package/dest/queue/fifo_memory_queue.d.ts.map +1 -1
  314. package/dest/queue/index.d.ts +1 -1
  315. package/dest/queue/priority_memory_queue.d.ts +1 -1
  316. package/dest/queue/priority_memory_queue.d.ts.map +1 -1
  317. package/dest/queue/priority_queue.d.ts +1 -1
  318. package/dest/queue/priority_queue.d.ts.map +1 -1
  319. package/dest/queue/semaphore.d.ts +5 -1
  320. package/dest/queue/semaphore.d.ts.map +1 -1
  321. package/dest/queue/serial_queue.d.ts +3 -3
  322. package/dest/queue/serial_queue.d.ts.map +1 -1
  323. package/dest/queue/serial_queue.js +7 -5
  324. package/dest/retry/index.d.ts +14 -3
  325. package/dest/retry/index.d.ts.map +1 -1
  326. package/dest/retry/index.js +13 -2
  327. package/dest/running-promise/index.d.ts +1 -1
  328. package/dest/schemas/api.d.ts +1 -1
  329. package/dest/schemas/api.d.ts.map +1 -1
  330. package/dest/schemas/index.d.ts +1 -1
  331. package/dest/schemas/parse.d.ts +1 -1
  332. package/dest/schemas/parse.js +1 -1
  333. package/dest/schemas/schemas.d.ts +21 -20
  334. package/dest/schemas/schemas.d.ts.map +1 -1
  335. package/dest/schemas/schemas.js +29 -11
  336. package/dest/schemas/types.d.ts +31 -1
  337. package/dest/schemas/types.d.ts.map +1 -1
  338. package/dest/schemas/types.js +25 -1
  339. package/dest/schemas/utils.d.ts +4 -6
  340. package/dest/schemas/utils.d.ts.map +1 -1
  341. package/dest/schemas/utils.js +15 -5
  342. package/dest/serialize/buffer_reader.d.ts +41 -6
  343. package/dest/serialize/buffer_reader.d.ts.map +1 -1
  344. package/dest/serialize/buffer_reader.js +70 -6
  345. package/dest/serialize/field_reader.d.ts +12 -3
  346. package/dest/serialize/field_reader.d.ts.map +1 -1
  347. package/dest/serialize/field_reader.js +19 -2
  348. package/dest/serialize/free_funcs.d.ts +25 -23
  349. package/dest/serialize/free_funcs.d.ts.map +1 -1
  350. package/dest/serialize/free_funcs.js +22 -28
  351. package/dest/serialize/index.d.ts +1 -1
  352. package/dest/serialize/serialize.d.ts +24 -7
  353. package/dest/serialize/serialize.d.ts.map +1 -1
  354. package/dest/serialize/serialize.js +32 -1
  355. package/dest/serialize/type_registry.d.ts +1 -1
  356. package/dest/serialize/type_registry.d.ts.map +1 -1
  357. package/dest/serialize/types.d.ts +1 -1
  358. package/dest/sleep/index.d.ts +4 -1
  359. package/dest/sleep/index.d.ts.map +1 -1
  360. package/dest/sleep/index.js +14 -1
  361. package/dest/string/index.d.ts +8 -3
  362. package/dest/string/index.d.ts.map +1 -1
  363. package/dest/string/index.js +27 -1
  364. package/dest/testing/files/index.d.ts +2 -3
  365. package/dest/testing/files/index.d.ts.map +1 -1
  366. package/dest/testing/files/index.js +3 -3
  367. package/dest/testing/formatting.d.ts +4 -0
  368. package/dest/testing/formatting.d.ts.map +1 -0
  369. package/dest/testing/formatting.js +3 -0
  370. package/dest/testing/index.d.ts +2 -1
  371. package/dest/testing/index.d.ts.map +1 -1
  372. package/dest/testing/index.js +1 -0
  373. package/dest/testing/port_allocator.d.ts +1 -1
  374. package/dest/testing/snapshot_serializer.d.ts +1 -1
  375. package/dest/testing/test_data.d.ts +1 -1
  376. package/dest/timer/date.d.ts +28 -2
  377. package/dest/timer/date.d.ts.map +1 -1
  378. package/dest/timer/date.js +41 -3
  379. package/dest/timer/elapsed.d.ts +1 -1
  380. package/dest/timer/index.d.ts +2 -2
  381. package/dest/timer/index.d.ts.map +1 -1
  382. package/dest/timer/index.js +1 -1
  383. package/dest/timer/timeout.d.ts +19 -6
  384. package/dest/timer/timeout.d.ts.map +1 -1
  385. package/dest/timer/timeout.js +43 -22
  386. package/dest/timer/timer.d.ts +1 -1
  387. package/dest/timer/timer.d.ts.map +1 -1
  388. package/dest/transport/dispatch/create_dispatch_fn.d.ts +1 -1
  389. package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -1
  390. package/dest/transport/dispatch/create_dispatch_proxy.d.ts +1 -1
  391. package/dest/transport/dispatch/messages.d.ts +1 -1
  392. package/dest/transport/index.d.ts +1 -2
  393. package/dest/transport/index.d.ts.map +1 -1
  394. package/dest/transport/index.js +0 -1
  395. package/dest/transport/interface/connector.d.ts +1 -1
  396. package/dest/transport/interface/connector.d.ts.map +1 -1
  397. package/dest/transport/interface/listener.d.ts +1 -2
  398. package/dest/transport/interface/listener.d.ts.map +1 -1
  399. package/dest/transport/interface/socket.d.ts +1 -1
  400. package/dest/transport/interface/socket.d.ts.map +1 -1
  401. package/dest/transport/interface/transferable.d.ts +1 -1
  402. package/dest/transport/node/index.d.ts +1 -1
  403. package/dest/transport/node/node_connector.d.ts +1 -2
  404. package/dest/transport/node/node_connector.d.ts.map +1 -1
  405. package/dest/transport/node/node_connector_socket.d.ts +1 -2
  406. package/dest/transport/node/node_connector_socket.d.ts.map +1 -1
  407. package/dest/transport/node/node_listener.d.ts +1 -2
  408. package/dest/transport/node/node_listener.d.ts.map +1 -1
  409. package/dest/transport/node/node_listener_socket.d.ts +1 -2
  410. package/dest/transport/node/node_listener_socket.d.ts.map +1 -1
  411. package/dest/transport/transport_client.d.ts +1 -2
  412. package/dest/transport/transport_client.d.ts.map +1 -1
  413. package/dest/transport/transport_client.js +2 -2
  414. package/dest/transport/transport_server.d.ts +1 -10
  415. package/dest/transport/transport_server.d.ts.map +1 -1
  416. package/dest/trees/balanced_merkle_tree_root.d.ts +17 -0
  417. package/dest/trees/balanced_merkle_tree_root.d.ts.map +1 -0
  418. package/dest/trees/balanced_merkle_tree_root.js +51 -0
  419. package/dest/trees/hasher.d.ts +7 -7
  420. package/dest/trees/hasher.d.ts.map +1 -1
  421. package/dest/trees/hasher.js +10 -5
  422. package/dest/trees/index.d.ts +5 -3
  423. package/dest/trees/index.d.ts.map +1 -1
  424. package/dest/trees/index.js +4 -2
  425. package/dest/trees/indexed_merkle_tree.d.ts +1 -3
  426. package/dest/trees/indexed_merkle_tree.d.ts.map +1 -1
  427. package/dest/trees/indexed_merkle_tree.js +1 -1
  428. package/dest/trees/indexed_merkle_tree_calculator.d.ts +2 -4
  429. package/dest/trees/indexed_merkle_tree_calculator.d.ts.map +1 -1
  430. package/dest/trees/indexed_tree_leaf.d.ts +1 -3
  431. package/dest/trees/indexed_tree_leaf.d.ts.map +1 -1
  432. package/dest/trees/membership_witness.d.ts +10 -5
  433. package/dest/trees/membership_witness.d.ts.map +1 -1
  434. package/dest/trees/membership_witness.js +23 -1
  435. package/dest/trees/merkle_tree.d.ts +1 -3
  436. package/dest/trees/merkle_tree.d.ts.map +1 -1
  437. package/dest/trees/merkle_tree_calculator.d.ts +2 -4
  438. package/dest/trees/merkle_tree_calculator.d.ts.map +1 -1
  439. package/dest/trees/merkle_tree_calculator.js +2 -2
  440. package/dest/trees/sibling_path.d.ts +6 -41
  441. package/dest/trees/sibling_path.d.ts.map +1 -1
  442. package/dest/trees/sibling_path.js +3 -3
  443. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts +48 -0
  444. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts.map +1 -0
  445. package/dest/trees/unbalanced_merkle_tree_calculator.js +154 -0
  446. package/dest/trees/unbalanced_merkle_tree_root.d.ts +28 -0
  447. package/dest/trees/unbalanced_merkle_tree_root.d.ts.map +1 -0
  448. package/dest/trees/unbalanced_merkle_tree_root.js +84 -0
  449. package/dest/trees/unbalanced_tree_store.d.ts +6 -1
  450. package/dest/trees/unbalanced_tree_store.d.ts.map +1 -1
  451. package/dest/trees/unbalanced_tree_store.js +55 -1
  452. package/dest/types/index.d.ts +30 -3
  453. package/dest/types/index.d.ts.map +1 -1
  454. package/dest/types/index.js +6 -0
  455. package/dest/url/index.d.ts +1 -1
  456. package/dest/url/index.d.ts.map +1 -1
  457. package/dest/url/index.js +1 -1
  458. package/dest/validation/index.d.ts +1 -1
  459. package/package.json +80 -45
  460. package/src/array/array.ts +13 -16
  461. package/src/array/index.ts +1 -0
  462. package/src/array/sorted_array.ts +138 -0
  463. package/src/async-pool/index.ts +1 -0
  464. package/src/bigint/index.ts +20 -0
  465. package/src/branded-types/block_number.ts +117 -0
  466. package/src/branded-types/checkpoint_number.ts +115 -0
  467. package/src/branded-types/epoch.ts +88 -0
  468. package/src/branded-types/index.ts +7 -0
  469. package/src/branded-types/index_within_checkpoint.ts +88 -0
  470. package/src/branded-types/slot.ts +88 -0
  471. package/src/branded-types/types.ts +2 -0
  472. package/src/buffer/buffer16.ts +133 -0
  473. package/src/buffer/buffer32.ts +10 -8
  474. package/src/buffer/index.ts +2 -0
  475. package/src/buffer/utils.ts +8 -0
  476. package/src/collection/array.ts +118 -4
  477. package/src/collection/object.ts +37 -0
  478. package/src/config/env_var.ts +227 -60
  479. package/src/config/index.ts +241 -10
  480. package/src/config/network_config.ts +21 -0
  481. package/src/config/network_name.ts +31 -0
  482. package/src/config/parse-env.ts +4 -0
  483. package/src/config/secret_value.ts +49 -0
  484. package/src/crypto/aes128/index.ts +19 -10
  485. package/src/crypto/bls/bn254_keystore.ts +287 -0
  486. package/src/crypto/bls/index.ts +77 -0
  487. package/src/crypto/bn254/index.ts +64 -0
  488. package/src/crypto/ecdsa/index.ts +41 -23
  489. package/src/crypto/ecdsa/signature.ts +2 -2
  490. package/src/crypto/grumpkin/index.ts +38 -46
  491. package/src/crypto/keys/index.ts +6 -6
  492. package/src/crypto/pedersen/pedersen.wasm.ts +23 -19
  493. package/src/crypto/poseidon/index.ts +27 -29
  494. package/src/crypto/random/index.ts +2 -40
  495. package/src/crypto/random/randomness_singleton.ts +6 -4
  496. package/src/crypto/schnorr/index.ts +22 -18
  497. package/src/crypto/schnorr/signature.ts +2 -2
  498. package/src/crypto/secp256k1/index.ts +15 -11
  499. package/src/crypto/secp256k1-signer/utils.ts +152 -7
  500. package/src/crypto/sha256/index.ts +48 -1
  501. package/src/crypto/sha512/index.ts +1 -1
  502. package/src/crypto/signature/index.ts +1 -1
  503. package/src/crypto/sync/index.ts +1 -1
  504. package/src/crypto/sync/pedersen/index.ts +17 -16
  505. package/src/crypto/sync/poseidon/index.ts +23 -27
  506. package/src/curves/bls12/field.ts +463 -0
  507. package/src/curves/bls12/index.ts +2 -0
  508. package/src/curves/bls12/point.ts +450 -0
  509. package/src/{fields/fields.ts → curves/bn254/field.ts} +88 -63
  510. package/src/curves/bn254/index.ts +2 -0
  511. package/src/curves/bn254/point.ts +170 -0
  512. package/src/curves/grumpkin/index.ts +11 -0
  513. package/src/{fields → curves/grumpkin}/point.ts +27 -10
  514. package/src/eth-address/index.ts +35 -3
  515. package/src/eth-signature/eth_signature.ts +50 -22
  516. package/src/fs/index.ts +1 -0
  517. package/src/fs/try_rm_dir.ts +15 -0
  518. package/src/iterable/filter.ts +1 -1
  519. package/src/iterable/map.ts +1 -1
  520. package/src/iterator/filter.ts +11 -0
  521. package/src/iterator/index.ts +1 -0
  522. package/src/jest/env.mjs +52 -0
  523. package/src/jest/setup.mjs +31 -1
  524. package/src/jest/setupAfterEnv.mjs +3 -0
  525. package/src/json-rpc/client/fetch.ts +14 -33
  526. package/src/json-rpc/client/safe_json_rpc_client.ts +228 -13
  527. package/src/json-rpc/client/undici.ts +29 -18
  528. package/src/json-rpc/convert.ts +3 -12
  529. package/src/json-rpc/errors.ts +6 -0
  530. package/src/json-rpc/fixtures/class_a.ts +4 -1
  531. package/src/json-rpc/fixtures/class_b.ts +4 -1
  532. package/src/json-rpc/index.ts +2 -1
  533. package/src/json-rpc/server/api_key_auth.ts +63 -0
  534. package/src/json-rpc/server/index.ts +1 -0
  535. package/src/json-rpc/server/safe_json_rpc_server.ts +141 -48
  536. package/src/json-rpc/test/integration.ts +1 -1
  537. package/src/log/bigint-utils.ts +25 -0
  538. package/src/log/console.ts +4 -1
  539. package/src/log/gcloud-logger-config.ts +8 -7
  540. package/src/log/index.ts +4 -4
  541. package/src/log/libp2p_logger.ts +33 -7
  542. package/src/log/log-filters.ts +29 -11
  543. package/src/log/log_fn.ts +1 -1
  544. package/src/log/noir_debug_log_util.ts +21 -0
  545. package/src/log/pino-logger-server.ts +25 -0
  546. package/src/log/pino-logger.ts +175 -39
  547. package/src/message/index.ts +5 -1
  548. package/src/mutex/mutex_database.ts +2 -3
  549. package/src/number/index.ts +14 -0
  550. package/src/profiler/index.ts +1 -0
  551. package/src/profiler/profiler.ts +125 -0
  552. package/src/promise/running-promise.ts +2 -2
  553. package/src/queue/base_memory_queue.ts +1 -1
  554. package/src/queue/batch_queue.ts +1 -1
  555. package/src/queue/bounded_serial_queue.ts +4 -1
  556. package/src/queue/semaphore.ts +5 -0
  557. package/src/queue/serial_queue.ts +5 -5
  558. package/src/retry/index.ts +28 -5
  559. package/src/schemas/api.ts +4 -4
  560. package/src/schemas/parse.ts +1 -1
  561. package/src/schemas/schemas.ts +42 -13
  562. package/src/schemas/types.ts +33 -0
  563. package/src/schemas/utils.ts +21 -8
  564. package/src/serialize/buffer_reader.ts +96 -12
  565. package/src/serialize/field_reader.ts +28 -4
  566. package/src/serialize/free_funcs.ts +26 -32
  567. package/src/serialize/serialize.ts +35 -1
  568. package/src/sleep/index.ts +16 -1
  569. package/src/string/index.ts +36 -1
  570. package/src/testing/files/index.ts +7 -3
  571. package/src/testing/formatting.ts +3 -0
  572. package/src/testing/index.ts +1 -0
  573. package/src/timer/date.ts +61 -3
  574. package/src/timer/index.ts +1 -1
  575. package/src/timer/timeout.ts +54 -19
  576. package/src/transport/index.ts +0 -1
  577. package/src/transport/interface/connector.ts +0 -1
  578. package/src/transport/interface/listener.ts +2 -3
  579. package/src/transport/interface/socket.ts +2 -3
  580. package/src/transport/transport_client.ts +5 -6
  581. package/src/transport/transport_server.ts +4 -1
  582. package/src/trees/balanced_merkle_tree_root.ts +68 -0
  583. package/src/trees/hasher.ts +13 -4
  584. package/src/trees/index.ts +4 -2
  585. package/src/trees/indexed_merkle_tree.ts +6 -2
  586. package/src/trees/indexed_merkle_tree_calculator.ts +2 -2
  587. package/src/trees/membership_witness.ts +22 -1
  588. package/src/trees/merkle_tree.ts +4 -1
  589. package/src/trees/merkle_tree_calculator.ts +10 -5
  590. package/src/trees/sibling_path.ts +3 -3
  591. package/src/trees/unbalanced_merkle_tree_calculator.ts +176 -0
  592. package/src/trees/unbalanced_merkle_tree_root.ts +115 -0
  593. package/src/trees/unbalanced_tree_store.ts +62 -3
  594. package/src/types/index.ts +35 -4
  595. package/src/url/index.ts +0 -1
  596. package/dest/crypto/index.d.ts +0 -15
  597. package/dest/crypto/index.d.ts.map +0 -1
  598. package/dest/crypto/index.js +0 -14
  599. package/dest/crypto/pedersen/pedersen.elliptic.d.ts +0 -13
  600. package/dest/crypto/pedersen/pedersen.elliptic.d.ts.map +0 -1
  601. package/dest/crypto/pedersen/pedersen.elliptic.js +0 -582
  602. package/dest/fields/coordinate.d.ts +0 -68
  603. package/dest/fields/coordinate.d.ts.map +0 -1
  604. package/dest/fields/coordinate.js +0 -96
  605. package/dest/fields/fields.d.ts +0 -176
  606. package/dest/fields/fields.d.ts.map +0 -1
  607. package/dest/fields/index.d.ts +0 -4
  608. package/dest/fields/index.d.ts.map +0 -1
  609. package/dest/fields/index.js +0 -3
  610. package/dest/fields/point.d.ts.map +0 -1
  611. package/dest/index.d.ts +0 -31
  612. package/dest/index.d.ts.map +0 -1
  613. package/dest/index.js +0 -31
  614. package/dest/json-rpc/server/telemetry.d.ts +0 -2
  615. package/dest/json-rpc/server/telemetry.d.ts.map +0 -1
  616. package/dest/json-rpc/server/telemetry.js +0 -0
  617. package/dest/log/debug.d.ts +0 -56
  618. package/dest/log/debug.d.ts.map +0 -1
  619. package/dest/log/debug.js +0 -75
  620. package/dest/log/log_history.d.ts +0 -31
  621. package/dest/log/log_history.d.ts.map +0 -1
  622. package/dest/log/log_history.js +0 -38
  623. package/dest/transport/browser/index.d.ts +0 -5
  624. package/dest/transport/browser/index.d.ts.map +0 -1
  625. package/dest/transport/browser/index.js +0 -4
  626. package/dest/transport/browser/message_port_socket.d.ts +0 -37
  627. package/dest/transport/browser/message_port_socket.d.ts.map +0 -1
  628. package/dest/transport/browser/message_port_socket.js +0 -42
  629. package/dest/transport/browser/shared_worker_connector.d.ts +0 -19
  630. package/dest/transport/browser/shared_worker_connector.d.ts.map +0 -1
  631. package/dest/transport/browser/shared_worker_connector.js +0 -19
  632. package/dest/transport/browser/shared_worker_listener.d.ts +0 -38
  633. package/dest/transport/browser/shared_worker_listener.d.ts.map +0 -1
  634. package/dest/transport/browser/shared_worker_listener.js +0 -33
  635. package/dest/transport/browser/worker_connector.d.ts +0 -26
  636. package/dest/transport/browser/worker_connector.d.ts.map +0 -1
  637. package/dest/transport/browser/worker_connector.js +0 -30
  638. package/dest/transport/browser/worker_listener.d.ts +0 -39
  639. package/dest/transport/browser/worker_listener.d.ts.map +0 -1
  640. package/dest/transport/browser/worker_listener.js +0 -35
  641. package/dest/trees/unbalanced_merkle_tree.d.ts +0 -17
  642. package/dest/trees/unbalanced_merkle_tree.d.ts.map +0 -1
  643. package/dest/trees/unbalanced_merkle_tree.js +0 -100
  644. package/dest/wasm/empty_wasi_sdk.d.ts +0 -130
  645. package/dest/wasm/empty_wasi_sdk.d.ts.map +0 -1
  646. package/dest/wasm/empty_wasi_sdk.js +0 -148
  647. package/dest/wasm/index.d.ts +0 -2
  648. package/dest/wasm/index.d.ts.map +0 -1
  649. package/dest/wasm/index.js +0 -1
  650. package/dest/wasm/wasm_module.d.ts +0 -136
  651. package/dest/wasm/wasm_module.d.ts.map +0 -1
  652. package/dest/wasm/wasm_module.js +0 -196
  653. package/dest/worker/browser/index.d.ts +0 -3
  654. package/dest/worker/browser/index.d.ts.map +0 -1
  655. package/dest/worker/browser/index.js +0 -2
  656. package/dest/worker/browser/start_web_module.d.ts +0 -7
  657. package/dest/worker/browser/start_web_module.d.ts.map +0 -1
  658. package/dest/worker/browser/start_web_module.js +0 -27
  659. package/dest/worker/browser/web_data_store.d.ts +0 -24
  660. package/dest/worker/browser/web_data_store.d.ts.map +0 -1
  661. package/dest/worker/browser/web_data_store.js +0 -29
  662. package/dest/worker/browser/web_worker.d.ts +0 -10
  663. package/dest/worker/browser/web_worker.d.ts.map +0 -1
  664. package/dest/worker/browser/web_worker.js +0 -25
  665. package/dest/worker/data_store.d.ts +0 -21
  666. package/dest/worker/data_store.d.ts.map +0 -1
  667. package/dest/worker/data_store.js +0 -3
  668. package/dest/worker/index.d.ts +0 -3
  669. package/dest/worker/index.d.ts.map +0 -1
  670. package/dest/worker/index.js +0 -1
  671. package/dest/worker/node/index.d.ts +0 -3
  672. package/dest/worker/node/index.d.ts.map +0 -1
  673. package/dest/worker/node/index.js +0 -2
  674. package/dest/worker/node/node_data_store.d.ts +0 -13
  675. package/dest/worker/node/node_data_store.d.ts.map +0 -1
  676. package/dest/worker/node/node_data_store.js +0 -20
  677. package/dest/worker/node/node_worker.d.ts +0 -6
  678. package/dest/worker/node/node_worker.d.ts.map +0 -1
  679. package/dest/worker/node/node_worker.js +0 -22
  680. package/dest/worker/node/start_node_module.d.ts +0 -7
  681. package/dest/worker/node/start_node_module.d.ts.map +0 -1
  682. package/dest/worker/node/start_node_module.js +0 -31
  683. package/dest/worker/wasm_worker.d.ts +0 -9
  684. package/dest/worker/wasm_worker.d.ts.map +0 -1
  685. package/dest/worker/wasm_worker.js +0 -3
  686. package/dest/worker/worker_pool.d.ts +0 -40
  687. package/dest/worker/worker_pool.d.ts.map +0 -1
  688. package/dest/worker/worker_pool.js +0 -51
  689. package/src/crypto/index.ts +0 -14
  690. package/src/crypto/pedersen/pedersen.elliptic.ts +0 -584
  691. package/src/fields/coordinate.ts +0 -104
  692. package/src/fields/index.ts +0 -3
  693. package/src/index.ts +0 -31
  694. package/src/json-rpc/server/telemetry.ts +0 -0
  695. package/src/log/debug.ts +0 -104
  696. package/src/log/log_history.ts +0 -44
  697. package/src/transport/browser/index.ts +0 -4
  698. package/src/transport/browser/message_port_socket.ts +0 -48
  699. package/src/transport/browser/shared_worker_connector.ts +0 -21
  700. package/src/transport/browser/shared_worker_listener.ts +0 -53
  701. package/src/transport/browser/worker_connector.ts +0 -30
  702. package/src/transport/browser/worker_listener.ts +0 -54
  703. package/src/trees/unbalanced_merkle_tree.ts +0 -103
  704. package/src/wasm/README.md +0 -6
  705. package/src/wasm/empty_wasi_sdk.ts +0 -166
  706. package/src/wasm/fixtures/gcd.wasm +0 -0
  707. package/src/wasm/fixtures/gcd.wat +0 -27
  708. package/src/wasm/index.ts +0 -1
  709. package/src/wasm/wasm_module.ts +0 -260
  710. package/src/worker/browser/index.ts +0 -2
  711. package/src/worker/browser/start_web_module.ts +0 -24
  712. package/src/worker/browser/web_data_store.ts +0 -38
  713. package/src/worker/browser/web_worker.ts +0 -25
  714. package/src/worker/data_store.ts +0 -19
  715. package/src/worker/index.ts +0 -2
  716. package/src/worker/node/index.ts +0 -2
  717. package/src/worker/node/node_data_store.ts +0 -27
  718. package/src/worker/node/node_worker.ts +0 -23
  719. package/src/worker/node/start_node_module.ts +0 -30
  720. package/src/worker/wasm_worker.ts +0 -7
  721. package/src/worker/worker_pool.ts +0 -73
@@ -0,0 +1,56 @@
1
+ import { Fr } from '../../curves/bn254/field.js';
2
+ import { Bn254G1Point, Bn254G2Point } from '../../curves/bn254/point.js';
3
+ /**
4
+ * BN254 utility functions for point operations.
5
+ * Provides compression, decompression, and public key generation for the BN254 curve.
6
+ * Uses the bb.js Barretenberg backend for point operations.
7
+ */ /**
8
+ * Generate a compressed BN254 G1 public key from a private key.
9
+ *
10
+ * @param privateKeyHex - Private key as 0x-prefixed hex string
11
+ * @returns Compressed G1 point (32 bytes with sign bit in MSB)
12
+ */ export async function computeBn254G1PublicKeyCompressed(privateKeyHex) {
13
+ const sk = BigInt(privateKeyHex);
14
+ const skReduced = sk % Fr.MODULUS;
15
+ // Generate G1 point on BN254 curve using bb.js
16
+ const scalar = Fr.fromString(skReduced.toString());
17
+ const pk1 = await Bn254G1Point.generator(scalar);
18
+ // Compress the point using the primitive method
19
+ return '0x' + pk1.compress().toString('hex');
20
+ }
21
+ /**
22
+ * Generate uncompressed BN254 G1 public key from a private key.
23
+ *
24
+ * @param privateKeyHex - Private key as 0x-prefixed hex string
25
+ * @returns G1 point in affine coordinates
26
+ */ export async function computeBn254G1PublicKey(privateKeyHex) {
27
+ const sk = BigInt(privateKeyHex);
28
+ const skReduced = sk % Fr.MODULUS;
29
+ const scalar = Fr.fromString(skReduced.toString());
30
+ const pk1 = await Bn254G1Point.generator(scalar);
31
+ return {
32
+ x: pk1.x.toBigInt(),
33
+ y: pk1.y.toBigInt()
34
+ };
35
+ }
36
+ /**
37
+ * Generate BN254 G2 public key from a private key.
38
+ *
39
+ * @param privateKeyHex - Private key as 0x-prefixed hex string
40
+ * @returns G2 point in affine coordinates
41
+ */ export async function computeBn254G2PublicKey(privateKeyHex) {
42
+ const sk = BigInt(privateKeyHex);
43
+ const skReduced = sk % Fr.MODULUS;
44
+ const scalar = Fr.fromString(skReduced.toString());
45
+ const pk2 = await Bn254G2Point.generator(scalar);
46
+ return {
47
+ x: {
48
+ c0: pk2.x[0].toBigInt(),
49
+ c1: pk2.x[1].toBigInt()
50
+ },
51
+ y: {
52
+ c0: pk2.y[0].toBigInt(),
53
+ c1: pk2.y[1].toBigInt()
54
+ }
55
+ };
56
+ }
@@ -1,5 +1,3 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- /// <reference types="node" resolution-mode="require"/>
3
1
  import { EcdsaSignature } from './signature.js';
4
2
  export * from './signature.js';
5
3
  /**
@@ -7,6 +5,8 @@ export * from './signature.js';
7
5
  * TODO: Replace with codegen api on bb.js.
8
6
  */
9
7
  export declare class Ecdsa {
8
+ private curve;
9
+ constructor(curve?: 'secp256k1' | 'secp256r1');
10
10
  /**
11
11
  * Computes a secp256k1 public key from a private key.
12
12
  * @param privateKey - Secp256k1 private key.
@@ -36,4 +36,4 @@ export declare class Ecdsa {
36
36
  */
37
37
  verifySignature(msg: Uint8Array, pubKey: Buffer, sig: EcdsaSignature): Promise<boolean>;
38
38
  }
39
- //# sourceMappingURL=index.d.ts.map
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vZWNkc2EvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWhELGNBQWMsZ0JBQWdCLENBQUM7QUFFL0I7OztHQUdHO0FBQ0gscUJBQWEsS0FBSztJQUNKLE9BQU8sQ0FBQyxLQUFLO0lBQXpCLFlBQW9CLEtBQUssR0FBRSxXQUFXLEdBQUcsV0FBeUIsRUFBSTtJQUN0RTs7OztPQUlHO0lBQ1UsZ0JBQWdCLENBQUMsVUFBVSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBUWpFO0lBRUQ7Ozs7O09BS0c7SUFDVSxrQkFBa0IsQ0FBQyxHQUFHLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQVFsRTtJQUVEOzs7OztPQUtHO0lBQ1UsZ0JBQWdCLENBQUMsR0FBRyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsY0FBYyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FRbkY7SUFFRDs7Ozs7O09BTUc7SUFDVSxlQUFlLENBQUMsR0FBRyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxjQUFjLG9CQW9CaEY7Q0FDRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/ecdsa/index.ts"],"names":[],"mappings":";;AAIA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEhD,cAAc,gBAAgB,CAAC;AAE/B;;;GAGG;AACH,qBAAa,KAAK;IAChB;;;;OAIG;IACU,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAMlE;;;;;OAKG;IACU,kBAAkB,CAAC,GAAG,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM;IASnE;;;;;OAKG;IACU,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,EAAE,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC;IASpF;;;;;;OAMG;IACU,eAAe,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,cAAc;CAQlF"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/ecdsa/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEhD,cAAc,gBAAgB,CAAC;AAE/B;;;GAGG;AACH,qBAAa,KAAK;IACJ,OAAO,CAAC,KAAK;IAAzB,YAAoB,KAAK,GAAE,WAAW,GAAG,WAAyB,EAAI;IACtE;;;;OAIG;IACU,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAQjE;IAED;;;;;OAKG;IACU,kBAAkB,CAAC,GAAG,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,2BAQlE;IAED;;;;;OAKG;IACU,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,EAAE,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC,CAQnF;IAED;;;;;;OAMG;IACU,eAAe,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,cAAc,oBAoBhF;CACF"}
@@ -1,24 +1,30 @@
1
1
  import { BarretenbergSync } from '@aztec/bb.js';
2
- import { numToInt32BE } from '@aztec/foundation/serialize';
3
- import { concatenateUint8Arrays } from '../serialize.js';
4
2
  import { EcdsaSignature } from './signature.js';
5
3
  export * from './signature.js';
6
4
  /**
7
5
  * ECDSA signature construction and helper operations.
8
6
  * TODO: Replace with codegen api on bb.js.
9
7
  */ export class Ecdsa {
8
+ curve;
9
+ constructor(curve = 'secp256k1'){
10
+ this.curve = curve;
11
+ }
10
12
  /**
11
13
  * Computes a secp256k1 public key from a private key.
12
14
  * @param privateKey - Secp256k1 private key.
13
15
  * @returns A secp256k1 public key.
14
16
  */ async computePublicKey(privateKey) {
15
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
16
- const [result] = api.getWasm().callWasmExport('ecdsa__compute_public_key', [
17
+ await BarretenbergSync.initSingleton();
18
+ const api = BarretenbergSync.getSingleton();
19
+ const response = this.curve === 'secp256r1' ? api.ecdsaSecp256r1ComputePublicKey({
20
+ privateKey
21
+ }) : api.ecdsaSecp256k1ComputePublicKey({
17
22
  privateKey
18
- ], [
19
- 64
23
+ });
24
+ return Buffer.concat([
25
+ Buffer.from(response.publicKey.x),
26
+ Buffer.from(response.publicKey.y)
20
27
  ]);
21
- return Buffer.from(result);
22
28
  }
23
29
  /**
24
30
  * Constructs an ECDSA signature given a msg and a private key.
@@ -26,20 +32,18 @@ export * from './signature.js';
26
32
  * @param privateKey - The secp256k1 private key of the signer.
27
33
  * @returns An ECDSA signature of the form (r, s, v).
28
34
  */ async constructSignature(msg, privateKey) {
29
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
30
- const messageArray = concatenateUint8Arrays([
31
- numToInt32BE(msg.length),
32
- msg
33
- ]);
34
- const [r, s, v] = api.getWasm().callWasmExport('ecdsa__construct_signature_', [
35
- messageArray,
35
+ await BarretenbergSync.initSingleton();
36
+ const api = BarretenbergSync.getSingleton();
37
+ const response = this.curve === 'secp256r1' ? api.ecdsaSecp256r1ConstructSignature({
38
+ message: msg,
36
39
  privateKey
37
- ], [
38
- 32,
39
- 32,
40
- 1
41
- ]);
42
- return new EcdsaSignature(Buffer.from(r), Buffer.from(s), Buffer.from(v));
40
+ }) : api.ecdsaSecp256k1ConstructSignature({
41
+ message: msg,
42
+ privateKey
43
+ });
44
+ return new EcdsaSignature(Buffer.from(response.r), Buffer.from(response.s), Buffer.from([
45
+ response.v
46
+ ]));
43
47
  }
44
48
  /**
45
49
  * Recovers a secp256k1 public key from an ECDSA signature (similar to ecrecover).
@@ -47,20 +51,23 @@ export * from './signature.js';
47
51
  * @param sig - The ECDSA signature.
48
52
  * @returns The secp256k1 public key of the signer.
49
53
  */ async recoverPublicKey(msg, sig) {
50
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
51
- const messageArray = concatenateUint8Arrays([
52
- numToInt32BE(msg.length),
53
- msg
54
- ]);
55
- const [result] = api.getWasm().callWasmExport('ecdsa__recover_public_key_from_signature_', [
56
- messageArray,
57
- sig.r,
58
- sig.s,
59
- sig.v
60
- ], [
61
- 64
54
+ await BarretenbergSync.initSingleton();
55
+ const api = BarretenbergSync.getSingleton();
56
+ const response = this.curve === 'secp256r1' ? api.ecdsaSecp256r1RecoverPublicKey({
57
+ message: msg,
58
+ r: sig.r,
59
+ s: sig.s,
60
+ v: sig.v[0]
61
+ }) : api.ecdsaSecp256k1RecoverPublicKey({
62
+ message: msg,
63
+ r: sig.r,
64
+ s: sig.s,
65
+ v: sig.v[0]
66
+ });
67
+ return Buffer.concat([
68
+ Buffer.from(response.publicKey.x),
69
+ Buffer.from(response.publicKey.y)
62
70
  ]);
63
- return Buffer.from(result);
64
71
  }
65
72
  /**
66
73
  * Verifies and ECDSA signature given a secp256k1 public key.
@@ -69,20 +76,27 @@ export * from './signature.js';
69
76
  * @param sig - The ECDSA signature.
70
77
  * @returns True or false.
71
78
  */ async verifySignature(msg, pubKey, sig) {
72
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
73
- const messageArray = concatenateUint8Arrays([
74
- numToInt32BE(msg.length),
75
- msg
76
- ]);
77
- const [result] = api.getWasm().callWasmExport('ecdsa__verify_signature_', [
78
- messageArray,
79
- pubKey,
80
- sig.r,
81
- sig.s,
82
- sig.v
83
- ], [
84
- 1
85
- ]);
86
- return result[0] === 1;
79
+ await BarretenbergSync.initSingleton();
80
+ const api = BarretenbergSync.getSingleton();
81
+ const response = this.curve === 'secp256r1' ? api.ecdsaSecp256r1VerifySignature({
82
+ message: msg,
83
+ publicKey: {
84
+ x: pubKey.subarray(0, 32),
85
+ y: pubKey.subarray(32, 64)
86
+ },
87
+ r: sig.r,
88
+ s: sig.s,
89
+ v: sig.v[0]
90
+ }) : api.ecdsaSecp256k1VerifySignature({
91
+ message: msg,
92
+ publicKey: {
93
+ x: pubKey.subarray(0, 32),
94
+ y: pubKey.subarray(32, 64)
95
+ },
96
+ r: sig.r,
97
+ s: sig.s,
98
+ v: sig.v[0]
99
+ });
100
+ return response.verified;
87
101
  }
88
102
  }
@@ -1,6 +1,4 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- /// <reference types="node" resolution-mode="require"/>
3
- import { Fr } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
2
  import type { Signature } from '../signature/index.js';
5
3
  /**
6
4
  * ECDSA signature used for transactions.
@@ -36,7 +34,7 @@ export declare class EcdsaSignature implements Signature {
36
34
  * Converts an ECDSA signature to a buffer.
37
35
  * @returns A buffer.
38
36
  */
39
- toBuffer(): Buffer;
37
+ toBuffer(): Buffer<ArrayBuffer>;
40
38
  /**
41
39
  * Deserializes the signature from a buffer.
42
40
  * @param buffer - The buffer from which to deserialize the signature.
@@ -68,4 +66,4 @@ export declare class EcdsaSignature implements Signature {
68
66
  */
69
67
  toFields(includeV?: boolean): Fr[];
70
68
  }
71
- //# sourceMappingURL=signature.d.ts.map
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmF0dXJlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3J5cHRvL2VjZHNhL3NpZ25hdHVyZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFHcEQsT0FBTyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFdkQ7OztHQUdHO0FBQ0gscUJBQWEsY0FBZSxZQUFXLFNBQVM7SUFFNUM7O09BRUc7SUFDSSxDQUFDLEVBQUUsTUFBTTtJQUNoQjs7T0FFRztJQUNJLENBQUMsRUFBRSxNQUFNO0lBQ2hCOztPQUVHO0lBQ0ksQ0FBQyxFQUFFLE1BQU07SUFabEI7SUFDRTs7T0FFRztJQUNJLENBQUMsRUFBRSxNQUFNO0lBQ2hCOztPQUVHO0lBQ0ksQ0FBQyxFQUFFLE1BQU07SUFDaEI7O09BRUc7SUFDSSxDQUFDLEVBQUUsTUFBTSxFQVdqQjtJQUVEOzs7T0FHRztJQUNILFFBQVEsd0JBRVA7SUFFRDs7OztPQUlHO0lBQ0gsT0FBYyxVQUFVLENBQUMsTUFBTSxFQUFFLE1BQU0sa0JBRXRDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsT0FBYyxXQUFXLENBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsRUFBRSxNQUFNLGtCQUV4RDtJQUVEOzs7T0FHRztJQUNILE9BQWMsTUFBTSxtQkFFbkI7SUFFRDs7O09BR0c7SUFDSCxRQUFRLFdBRVA7SUFFRDs7OztPQUlHO0lBQ0gsUUFBUSxDQUFDLFFBQVEsVUFBUSxHQUFHLEVBQUUsRUFBRSxDQVkvQjtDQUNGIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"signature.d.ts","sourceRoot":"","sources":["../../../src/crypto/ecdsa/signature.ts"],"names":[],"mappings":";;AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAG9C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAEvD;;;GAGG;AACH,qBAAa,cAAe,YAAW,SAAS;IAE5C;;OAEG;IACI,CAAC,EAAE,MAAM;IAChB;;OAEG;IACI,CAAC,EAAE,MAAM;IAChB;;OAEG;IACI,CAAC,EAAE,MAAM;;IAXhB;;OAEG;IACI,CAAC,EAAE,MAAM;IAChB;;OAEG;IACI,CAAC,EAAE,MAAM;IAChB;;OAEG;IACI,CAAC,EAAE,MAAM;IAalB;;;OAGG;IACH,QAAQ;IAIR;;;;OAIG;WACW,UAAU,CAAC,MAAM,EAAE,MAAM;IAIvC;;;;;;OAMG;WACW,WAAW,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IAIzD;;;OAGG;WACW,MAAM;IAIpB;;;OAGG;IACH,QAAQ;IAIR;;;;OAIG;IACH,QAAQ,CAAC,QAAQ,UAAQ,GAAG,EAAE,EAAE;CAajC"}
1
+ {"version":3,"file":"signature.d.ts","sourceRoot":"","sources":["../../../src/crypto/ecdsa/signature.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAGpD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAEvD;;;GAGG;AACH,qBAAa,cAAe,YAAW,SAAS;IAE5C;;OAEG;IACI,CAAC,EAAE,MAAM;IAChB;;OAEG;IACI,CAAC,EAAE,MAAM;IAChB;;OAEG;IACI,CAAC,EAAE,MAAM;IAZlB;IACE;;OAEG;IACI,CAAC,EAAE,MAAM;IAChB;;OAEG;IACI,CAAC,EAAE,MAAM;IAChB;;OAEG;IACI,CAAC,EAAE,MAAM,EAWjB;IAED;;;OAGG;IACH,QAAQ,wBAEP;IAED;;;;OAIG;IACH,OAAc,UAAU,CAAC,MAAM,EAAE,MAAM,kBAEtC;IAED;;;;;;OAMG;IACH,OAAc,WAAW,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,kBAExD;IAED;;;OAGG;IACH,OAAc,MAAM,mBAEnB;IAED;;;OAGG;IACH,QAAQ,WAEP;IAED;;;;OAIG;IACH,QAAQ,CAAC,QAAQ,UAAQ,GAAG,EAAE,EAAE,CAY/B;CACF"}
@@ -1,6 +1,6 @@
1
1
  import { toBufferBE } from '@aztec/foundation/bigint-buffer';
2
- import { randomBytes } from '@aztec/foundation/crypto';
3
- import { Fr } from '@aztec/foundation/fields';
2
+ import { randomBytes } from '@aztec/foundation/crypto/random';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { mapTuple } from '@aztec/foundation/serialize';
5
5
  /**
6
6
  * ECDSA signature used for transactions.
@@ -1,47 +1,42 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- /// <reference types="node" resolution-mode="require"/>
3
- import { Fr, type GrumpkinScalar, Point } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
+ import type { GrumpkinScalar } from '@aztec/foundation/curves/grumpkin';
3
+ import { Point } from '@aztec/foundation/curves/grumpkin';
4
4
  /**
5
5
  * Grumpkin elliptic curve operations.
6
6
  */
7
7
  export declare class Grumpkin {
8
- static generator: Point;
9
- /**
10
- * Point generator
11
- * @returns The generator for the curve.
12
- */
13
- generator(): Point;
8
+ static readonly generator: Point;
14
9
  /**
15
10
  * Multiplies a point by a scalar (adds the point `scalar` amount of times).
16
11
  * @param point - Point to multiply.
17
12
  * @param scalar - Scalar to multiply by.
18
13
  * @returns Result of the multiplication.
19
14
  */
20
- mul(point: Point, scalar: GrumpkinScalar): Promise<Point>;
15
+ static mul(point: Point, scalar: GrumpkinScalar): Promise<Point>;
21
16
  /**
22
17
  * Add two points.
23
18
  * @param a - Point a in the addition
24
19
  * @param b - Point b to add to a
25
20
  * @returns Result of the addition.
26
21
  */
27
- add(a: Point, b: Point): Promise<Point>;
22
+ static add(a: Point, b: Point): Promise<Point>;
28
23
  /**
29
24
  * Multiplies a set of points by a scalar.
30
25
  * @param points - Points to multiply.
31
26
  * @param scalar - Scalar to multiply by.
32
27
  * @returns Points multiplied by the scalar.
33
28
  */
34
- batchMul(points: Point[], scalar: GrumpkinScalar): Promise<Point[]>;
29
+ static batchMul(points: Point[], scalar: GrumpkinScalar): Promise<Point[]>;
35
30
  /**
36
31
  * Gets a random field element.
37
32
  * @returns Random field element.
38
33
  */
39
- getRandomFr(): Promise<Fr>;
34
+ static getRandomFr(): Promise<Fr>;
40
35
  /**
41
36
  * Converts a 512 bits long buffer to a field.
42
37
  * @param uint512Buf - The buffer to convert.
43
38
  * @returns Buffer representation of the field element.
44
39
  */
45
- reduce512BufferToFr(uint512Buf: Buffer): Promise<Fr>;
40
+ static reduce512BufferToFr(uint512Buf: Buffer): Promise<Fr>;
46
41
  }
47
- //# sourceMappingURL=index.d.ts.map
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vZ3J1bXBraW4vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3BELE9BQU8sS0FBSyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUUxRDs7R0FFRztBQUNILHFCQUFhLFFBQVE7SUFFbkIsTUFBTSxDQUFDLFFBQVEsQ0FBQyxTQUFTLFFBS3JCO0lBRUo7Ozs7O09BS0c7SUFDSCxPQUFvQixHQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsY0FBYyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FRNUU7SUFFRDs7Ozs7T0FLRztJQUNILE9BQW9CLEdBQUcsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxLQUFLLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQVExRDtJQUVEOzs7OztPQUtHO0lBQ0gsT0FBb0IsUUFBUSxDQUFDLE1BQU0sRUFBRSxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsY0FBYyxvQkFTbkU7SUFFRDs7O09BR0c7SUFDSCxPQUFvQixXQUFXLElBQUksT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUs3QztJQUVEOzs7O09BSUc7SUFDSCxPQUFvQixtQkFBbUIsQ0FBQyxVQUFVLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FLdkU7Q0FDRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/grumpkin/index.ts"],"names":[],"mappings":";;AACA,OAAO,EAAE,EAAE,EAAE,KAAK,cAAc,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAC;AAE1E;;GAEG;AACH,qBAAa,QAAQ;IAEnB,MAAM,CAAC,SAAS,QAKZ;IAEJ;;;OAGG;IACI,SAAS,IAAI,KAAK;IAIzB;;;;;OAKG;IACU,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC;IAMtE;;;;;OAKG;IACU,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;IAMpD;;;;;OAKG;IACU,QAAQ,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,cAAc;IAqB7D;;;OAGG;IACU,WAAW,IAAI,OAAO,CAAC,EAAE,CAAC;IAMvC;;;;OAIG;IACU,mBAAmB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,CAAC;CAOlE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/grumpkin/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,KAAK,EAAE,MAAM,mCAAmC,CAAC;AAE1D;;GAEG;AACH,qBAAa,QAAQ;IAEnB,MAAM,CAAC,QAAQ,CAAC,SAAS,QAKrB;IAEJ;;;;;OAKG;IACH,OAAoB,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,CAQ5E;IAED;;;;;OAKG;IACH,OAAoB,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAQ1D;IAED;;;;;OAKG;IACH,OAAoB,QAAQ,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,cAAc,oBASnE;IAED;;;OAGG;IACH,OAAoB,WAAW,IAAI,OAAO,CAAC,EAAE,CAAC,CAK7C;IAED;;;;OAIG;IACH,OAAoB,mBAAmB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,CAAC,CAKvE;CACF"}
@@ -1,5 +1,6 @@
1
1
  import { BarretenbergSync } from '@aztec/bb.js';
2
- import { Fr, Point } from '@aztec/foundation/fields';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { Point } from '@aztec/foundation/curves/grumpkin';
3
4
  /**
4
5
  * Grumpkin elliptic curve operations.
5
6
  */ export class Grumpkin {
@@ -71,84 +72,89 @@ import { Fr, Point } from '@aztec/foundation/fields';
71
72
  0x2c
72
73
  ]));
73
74
  /**
74
- * Point generator
75
- * @returns The generator for the curve.
76
- */ generator() {
77
- return Grumpkin.generator;
78
- }
79
- /**
80
75
  * Multiplies a point by a scalar (adds the point `scalar` amount of times).
81
76
  * @param point - Point to multiply.
82
77
  * @param scalar - Scalar to multiply by.
83
78
  * @returns Result of the multiplication.
84
- */ async mul(point, scalar) {
85
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
86
- const [result] = api.getWasm().callWasmExport('ecc_grumpkin__mul', [
87
- point.toBuffer(),
88
- scalar.toBuffer()
89
- ], [
90
- 64
91
- ]);
92
- return Point.fromBuffer(Buffer.from(result));
79
+ */ static async mul(point, scalar) {
80
+ await BarretenbergSync.initSingleton();
81
+ const api = BarretenbergSync.getSingleton();
82
+ const response = api.grumpkinMul({
83
+ point: {
84
+ x: point.x.toBuffer(),
85
+ y: point.y.toBuffer()
86
+ },
87
+ scalar: scalar.toBuffer()
88
+ });
89
+ return Point.fromBuffer(Buffer.concat([
90
+ Buffer.from(response.point.x),
91
+ Buffer.from(response.point.y)
92
+ ]));
93
93
  }
94
94
  /**
95
95
  * Add two points.
96
96
  * @param a - Point a in the addition
97
97
  * @param b - Point b to add to a
98
98
  * @returns Result of the addition.
99
- */ async add(a, b) {
100
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
101
- const [result] = api.getWasm().callWasmExport('ecc_grumpkin__add', [
102
- a.toBuffer(),
103
- b.toBuffer()
104
- ], [
105
- 64
106
- ]);
107
- return Point.fromBuffer(Buffer.from(result));
99
+ */ static async add(a, b) {
100
+ await BarretenbergSync.initSingleton();
101
+ const api = BarretenbergSync.getSingleton();
102
+ const response = api.grumpkinAdd({
103
+ pointA: {
104
+ x: a.x.toBuffer(),
105
+ y: a.y.toBuffer()
106
+ },
107
+ pointB: {
108
+ x: b.x.toBuffer(),
109
+ y: b.y.toBuffer()
110
+ }
111
+ });
112
+ return Point.fromBuffer(Buffer.concat([
113
+ Buffer.from(response.point.x),
114
+ Buffer.from(response.point.y)
115
+ ]));
108
116
  }
109
117
  /**
110
118
  * Multiplies a set of points by a scalar.
111
119
  * @param points - Points to multiply.
112
120
  * @param scalar - Scalar to multiply by.
113
121
  * @returns Points multiplied by the scalar.
114
- */ async batchMul(points, scalar) {
115
- const concatenatedPoints = Buffer.concat(points.map((point)=>point.toBuffer()));
116
- const pointsByteLength = points.length * Point.SIZE_IN_BYTES;
117
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
118
- const [result] = api.getWasm().callWasmExport('ecc_grumpkin__batch_mul', [
119
- concatenatedPoints,
120
- scalar.toBuffer(),
121
- points.length
122
- ], [
123
- pointsByteLength
124
- ]);
125
- const parsedResult = [];
126
- for(let i = 0; i < pointsByteLength; i += 64){
127
- parsedResult.push(Point.fromBuffer(Buffer.from(result.subarray(i, i + 64))));
128
- }
129
- return parsedResult;
122
+ */ static async batchMul(points, scalar) {
123
+ await BarretenbergSync.initSingleton();
124
+ const api = BarretenbergSync.getSingleton();
125
+ const response = api.grumpkinBatchMul({
126
+ points: points.map((p)=>({
127
+ x: p.x.toBuffer(),
128
+ y: p.y.toBuffer()
129
+ })),
130
+ scalar: scalar.toBuffer()
131
+ });
132
+ return response.points.map((p)=>Point.fromBuffer(Buffer.concat([
133
+ Buffer.from(p.x),
134
+ Buffer.from(p.y)
135
+ ])));
130
136
  }
131
137
  /**
132
138
  * Gets a random field element.
133
139
  * @returns Random field element.
134
- */ async getRandomFr() {
135
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
136
- const [result] = api.getWasm().callWasmExport('ecc_grumpkin__get_random_scalar_mod_circuit_modulus', [], [
137
- 32
138
- ]);
139
- return Fr.fromBuffer(Buffer.from(result));
140
+ */ static async getRandomFr() {
141
+ await BarretenbergSync.initSingleton();
142
+ const api = BarretenbergSync.getSingleton();
143
+ const response = api.grumpkinGetRandomFr({
144
+ dummy: 0
145
+ });
146
+ return Fr.fromBuffer(Buffer.from(response.value));
140
147
  }
141
148
  /**
142
149
  * Converts a 512 bits long buffer to a field.
143
150
  * @param uint512Buf - The buffer to convert.
144
151
  * @returns Buffer representation of the field element.
145
- */ async reduce512BufferToFr(uint512Buf) {
146
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
147
- const [result] = api.getWasm().callWasmExport('ecc_grumpkin__reduce512_buffer_mod_circuit_modulus', [
148
- uint512Buf
149
- ], [
150
- 32
151
- ]);
152
- return Fr.fromBuffer(Buffer.from(result));
152
+ */ static async reduce512BufferToFr(uint512Buf) {
153
+ await BarretenbergSync.initSingleton();
154
+ const api = BarretenbergSync.getSingleton();
155
+ const response = api.grumpkinReduce512({
156
+ input: uint512Buf
157
+ });
158
+ return Fr.fromBuffer(Buffer.from(response.value));
153
159
  }
154
160
  }
@@ -1,5 +1,3 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- /// <reference types="node" resolution-mode="require"/>
3
1
  import { Buffer32 } from '../../buffer/buffer32.js';
4
2
  /**
5
3
  * Computes the Keccak-256 hash of the given input buffer.
@@ -7,7 +5,7 @@ import { Buffer32 } from '../../buffer/buffer32.js';
7
5
  * @param input - The input buffer to be hashed.
8
6
  * @returns The computed Keccak-256 hash as a Buffer.
9
7
  */
10
- export declare function keccak256(input: Buffer | Buffer32): Buffer;
8
+ export declare function keccak256(input: Buffer | Buffer32): Buffer<ArrayBufferLike>;
11
9
  /**
12
10
  * Computes the keccak-256 hash of a given input string and returns the result as a hexadecimal string.
13
11
  */
@@ -18,11 +16,11 @@ export declare function keccak256String(input: string): string;
18
16
  * @param input - The input buffer to be hashed.
19
17
  * @returns The computed Keccak-224 hash as a Buffer.
20
18
  */
21
- export declare function keccak224(input: Buffer): Buffer;
19
+ export declare function keccak224(input: Buffer): Buffer<ArrayBufferLike>;
22
20
  /**
23
21
  * Computes the Keccak-f1600 permutation of the input.
24
22
  * @param state 25 64-bit words.
25
23
  * @returns The permuted state.
26
24
  */
27
25
  export declare function keccakf1600(state: bigint[]): bigint[];
28
- //# sourceMappingURL=index.d.ts.map
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8va2VjY2FrL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUVwRDs7Ozs7R0FLRztBQUNILHdCQUFnQixTQUFTLENBQUMsS0FBSyxFQUFFLE1BQU0sR0FBRyxRQUFRLDJCQU1qRDtBQUVEOztHQUVHO0FBQ0gsd0JBQWdCLGVBQWUsQ0FBQyxLQUFLLEVBQUUsTUFBTSxVQUs1QztBQUVEOzs7OztHQUtHO0FBQ0gsd0JBQWdCLFNBQVMsQ0FBQyxLQUFLLEVBQUUsTUFBTSwyQkFHdEM7QUFFRDs7OztHQUlHO0FBQ0gsd0JBQWdCLFdBQVcsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLEdBQUcsTUFBTSxFQUFFLENBK01yRCJ9
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/keccak/index.ts"],"names":[],"mappings":";;AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAEpD;;;;;GAKG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,QAAQ,UAMjD;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,UAK5C;AAED;;;;;GAKG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,UAGtC;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CA+MrD"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/keccak/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAEpD;;;;;GAKG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,QAAQ,2BAMjD;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,UAK5C;AAED;;;;;GAKG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,2BAGtC;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CA+MrD"}
@@ -1,5 +1,3 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- /// <reference types="node" resolution-mode="require"/>
3
- import { Fr } from '../../fields/fields.js';
1
+ import { Fr } from '../../curves/bn254/field.js';
4
2
  export declare function vkAsFieldsMegaHonk(input: Buffer): Promise<Fr[]>;
5
- //# sourceMappingURL=index.d.ts.map
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8va2V5cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFFakQsd0JBQXNCLGtCQUFrQixDQUFDLEtBQUssRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBS3JFIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/keys/index.ts"],"names":[],"mappings":";;AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAE5C,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,EAAE,CAAC,CAKrE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/keys/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,6BAA6B,CAAC;AAEjD,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,EAAE,CAAC,CAKrE"}
@@ -1,7 +1,10 @@
1
- import { BarretenbergSync, RawBuffer } from '@aztec/bb.js';
2
- import { Fr } from '../../fields/fields.js';
1
+ import { BarretenbergSync } from '@aztec/bb.js';
2
+ import { Fr } from '../../curves/bn254/field.js';
3
3
  export async function vkAsFieldsMegaHonk(input) {
4
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
5
- const result = api.acirVkAsFieldsMegaHonk(new RawBuffer(input));
6
- return result.map((bbFr)=>Fr.fromBuffer(Buffer.from(bbFr.toBuffer()))); // TODO(#4189): remove this conversion
4
+ await BarretenbergSync.initSingleton();
5
+ const api = BarretenbergSync.getSingleton();
6
+ const response = api.megaVkAsFields({
7
+ verificationKey: input
8
+ });
9
+ return response.fields.map((field)=>Fr.fromBuffer(Buffer.from(field)));
7
10
  }
@@ -1,2 +1,2 @@
1
1
  export * from './pedersen.wasm.js';
2
- //# sourceMappingURL=index.d.ts.map
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vcGVkZXJzZW4vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQyJ9
@@ -1,11 +1,9 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- /// <reference types="node" resolution-mode="require"/>
3
1
  /**
4
2
  * Create a pedersen commitment (point) from an array of input fields.
5
3
  */
6
- export declare function pedersenCommitNoble(input: Buffer[], generatorOffset?: number): Buffer[];
4
+ export declare function pedersenCommitNoble(input: Buffer[], generatorOffset?: number): Buffer<ArrayBufferLike>[];
7
5
  /**
8
6
  * Create a pedersen hash (field) from an array of input fields.
9
7
  */
10
- export declare function pedersenHashWithHashIndexNoble(input: Buffer[], index?: number): Buffer;
11
- //# sourceMappingURL=pedersen.noble.d.ts.map
8
+ export declare function pedersenHashWithHashIndexNoble(input: Buffer[], index?: number): Buffer<ArrayBufferLike>;
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVkZXJzZW4ubm9ibGUuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vcGVkZXJzZW4vcGVkZXJzZW4ubm9ibGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOGlCQTs7R0FFRztBQUNILHdCQUFnQixtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLEVBQUUsZUFBZSxTQUFJLDZCQUd2RTtBQUVEOztHQUVHO0FBQ0gsd0JBQWdCLDhCQUE4QixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFBRSxLQUFLLFNBQUksMkJBR3hFIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"pedersen.noble.d.ts","sourceRoot":"","sources":["../../../src/crypto/pedersen/pedersen.noble.ts"],"names":[],"mappings":";;AA8iBA;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,eAAe,SAAI,YAGvE;AAED;;GAEG;AACH,wBAAgB,8BAA8B,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,KAAK,SAAI,UAGxE"}
1
+ {"version":3,"file":"pedersen.noble.d.ts","sourceRoot":"","sources":["../../../src/crypto/pedersen/pedersen.noble.ts"],"names":[],"mappings":"AA8iBA;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,eAAe,SAAI,6BAGvE;AAED;;GAEG;AACH,wBAAgB,8BAA8B,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,KAAK,SAAI,2BAGxE"}
@@ -1,12 +1,10 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- /// <reference types="node" resolution-mode="require"/>
3
- import { Fr } from '../../fields/fields.js';
1
+ import { Fr } from '../../curves/bn254/field.js';
4
2
  import { type Fieldable } from '../../serialize/serialize.js';
5
3
  /**
6
4
  * Create a pedersen commitment (point) from an array of input fields.
7
5
  * Left pads any inputs less than 32 bytes.
8
6
  */
9
- export declare function pedersenCommit(input: Buffer[], offset?: number): Promise<Buffer[]>;
7
+ export declare function pedersenCommit(input: Buffer[], offset?: number): Promise<Buffer<ArrayBuffer>[]>;
10
8
  /**
11
9
  * Create a pedersen hash (field) from an array of input fields.
12
10
  * @param input - The input fieldables to hash.
@@ -17,5 +15,5 @@ export declare function pedersenHash(input: Fieldable[], index?: number): Promis
17
15
  /**
18
16
  * Create a pedersen hash from an arbitrary length buffer.
19
17
  */
20
- export declare function pedersenHashBuffer(input: Buffer, index?: number): Promise<Buffer>;
21
- //# sourceMappingURL=pedersen.wasm.d.ts.map
18
+ export declare function pedersenHashBuffer(input: Buffer, index?: number): Promise<Buffer<ArrayBuffer>>;
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVkZXJzZW4ud2FzbS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NyeXB0by9wZWRlcnNlbi9wZWRlcnNlbi53YXNtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNqRCxPQUFPLEVBQUUsS0FBSyxTQUFTLEVBQXFCLE1BQU0sOEJBQThCLENBQUM7QUFFakY7OztHQUdHO0FBQ0gsd0JBQXNCLGNBQWMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLEVBQUUsTUFBTSxTQUFJLGtDQVkvRDtBQUVEOzs7OztHQUtHO0FBQ0gsd0JBQXNCLFlBQVksQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLEVBQUUsS0FBSyxTQUFJLEdBQUcsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQVM3RTtBQUVEOztHQUVHO0FBQ0gsd0JBQXNCLGtCQUFrQixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxTQUFJLGdDQVFoRSJ9
@@ -1 +1 @@
1
- {"version":3,"file":"pedersen.wasm.d.ts","sourceRoot":"","sources":["../../../src/crypto/pedersen/pedersen.wasm.ts"],"names":[],"mappings":";;AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAC5C,OAAO,EAAE,KAAK,SAAS,EAAqB,MAAM,8BAA8B,CAAC;AAEjF;;;GAGG;AACH,wBAAsB,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,MAAM,SAAI,qBAa/D;AAED;;;;;GAKG;AACH,wBAAsB,YAAY,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,KAAK,SAAI,GAAG,OAAO,CAAC,EAAE,CAAC,CAQ7E;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,SAAI,mBAIhE"}
1
+ {"version":3,"file":"pedersen.wasm.d.ts","sourceRoot":"","sources":["../../../src/crypto/pedersen/pedersen.wasm.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,6BAA6B,CAAC;AACjD,OAAO,EAAE,KAAK,SAAS,EAAqB,MAAM,8BAA8B,CAAC;AAEjF;;;GAGG;AACH,wBAAsB,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,MAAM,SAAI,kCAY/D;AAED;;;;;GAKG;AACH,wBAAsB,YAAY,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,KAAK,SAAI,GAAG,OAAO,CAAC,EAAE,CAAC,CAS7E;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,SAAI,gCAQhE"}