@aztec/foundation 0.0.0-test.1 → 0.0.1-commit.0b941701

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 (693) hide show
  1. package/dest/array/array.d.ts +6 -9
  2. package/dest/array/array.d.ts.map +1 -1
  3. package/dest/array/array.js +11 -11
  4. package/dest/array/index.d.ts +2 -1
  5. package/dest/array/index.d.ts.map +1 -1
  6. package/dest/array/index.js +1 -0
  7. package/dest/array/sorted_array.d.ts +10 -0
  8. package/dest/array/sorted_array.d.ts.map +1 -0
  9. package/dest/array/sorted_array.js +106 -0
  10. package/dest/async-map/index.d.ts +1 -1
  11. package/dest/async-pool/index.d.ts +1 -1
  12. package/dest/async-pool/index.d.ts.map +1 -1
  13. package/dest/async-pool/index.js +1 -0
  14. package/dest/bigint/index.d.ts +7 -0
  15. package/dest/bigint/index.d.ts.map +1 -0
  16. package/dest/bigint/index.js +15 -0
  17. package/dest/bigint-buffer/index.d.ts +1 -3
  18. package/dest/bigint-buffer/index.d.ts.map +1 -1
  19. package/dest/branded-types/block_number.d.ts +56 -0
  20. package/dest/branded-types/block_number.d.ts.map +1 -0
  21. package/dest/branded-types/block_number.js +78 -0
  22. package/dest/branded-types/checkpoint_number.d.ts +54 -0
  23. package/dest/branded-types/checkpoint_number.d.ts.map +1 -0
  24. package/dest/branded-types/checkpoint_number.js +77 -0
  25. package/dest/branded-types/epoch.d.ts +42 -0
  26. package/dest/branded-types/epoch.d.ts.map +1 -0
  27. package/dest/branded-types/epoch.js +59 -0
  28. package/dest/branded-types/index.d.ts +7 -0
  29. package/dest/branded-types/index.d.ts.map +1 -0
  30. package/dest/branded-types/index.js +5 -0
  31. package/dest/branded-types/index_within_checkpoint.d.ts +42 -0
  32. package/dest/branded-types/index_within_checkpoint.d.ts.map +1 -0
  33. package/dest/branded-types/index_within_checkpoint.js +59 -0
  34. package/dest/branded-types/slot.d.ts +42 -0
  35. package/dest/branded-types/slot.d.ts.map +1 -0
  36. package/dest/branded-types/slot.js +59 -0
  37. package/dest/branded-types/types.d.ts +5 -0
  38. package/dest/branded-types/types.d.ts.map +1 -0
  39. package/dest/branded-types/types.js +1 -0
  40. package/dest/buffer/buffer16.d.ts +80 -0
  41. package/dest/buffer/buffer16.d.ts.map +1 -0
  42. package/dest/buffer/buffer16.js +102 -0
  43. package/dest/buffer/buffer32.d.ts +5 -9
  44. package/dest/buffer/buffer32.d.ts.map +1 -1
  45. package/dest/buffer/buffer32.js +9 -7
  46. package/dest/buffer/index.d.ts +2 -1
  47. package/dest/buffer/index.d.ts.map +1 -1
  48. package/dest/buffer/index.js +1 -0
  49. package/dest/collection/array.d.ts +22 -4
  50. package/dest/collection/array.d.ts.map +1 -1
  51. package/dest/collection/array.js +84 -3
  52. package/dest/collection/index.d.ts +1 -1
  53. package/dest/collection/object.d.ts +17 -1
  54. package/dest/collection/object.d.ts.map +1 -1
  55. package/dest/collection/object.js +25 -0
  56. package/dest/committable/committable.d.ts +1 -1
  57. package/dest/committable/committable.d.ts.map +1 -1
  58. package/dest/committable/index.d.ts +1 -1
  59. package/dest/config/env_var.d.ts +2 -2
  60. package/dest/config/env_var.d.ts.map +1 -1
  61. package/dest/config/index.d.ts +62 -4
  62. package/dest/config/index.d.ts.map +1 -1
  63. package/dest/config/index.js +143 -12
  64. package/dest/config/network_config.d.ts +54 -0
  65. package/dest/config/network_config.d.ts.map +1 -0
  66. package/dest/config/network_config.js +11 -0
  67. package/dest/config/network_name.d.ts +3 -0
  68. package/dest/config/network_name.d.ts.map +1 -0
  69. package/dest/config/network_name.js +19 -0
  70. package/dest/config/parse-env.d.ts +3 -0
  71. package/dest/config/parse-env.d.ts.map +1 -0
  72. package/dest/config/parse-env.js +7 -0
  73. package/dest/config/secret_value.d.ts +28 -0
  74. package/dest/config/secret_value.d.ts.map +1 -0
  75. package/dest/config/secret_value.js +36 -0
  76. package/dest/crypto/aes128/index.d.ts +3 -5
  77. package/dest/crypto/aes128/index.d.ts.map +1 -1
  78. package/dest/crypto/aes128/index.js +19 -6
  79. package/dest/crypto/bls/bn254_keystore.d.ts +296 -0
  80. package/dest/crypto/bls/bn254_keystore.d.ts.map +1 -0
  81. package/dest/crypto/bls/bn254_keystore.js +218 -0
  82. package/dest/crypto/bls/index.d.ts +13 -0
  83. package/dest/crypto/bls/index.d.ts.map +1 -0
  84. package/dest/crypto/bls/index.js +87 -0
  85. package/dest/crypto/bn254/index.d.ts +39 -0
  86. package/dest/crypto/bn254/index.d.ts.map +1 -0
  87. package/dest/crypto/bn254/index.js +56 -0
  88. package/dest/crypto/ecdsa/index.d.ts +3 -3
  89. package/dest/crypto/ecdsa/index.d.ts.map +1 -1
  90. package/dest/crypto/ecdsa/index.js +62 -48
  91. package/dest/crypto/ecdsa/signature.d.ts +3 -5
  92. package/dest/crypto/ecdsa/signature.d.ts.map +1 -1
  93. package/dest/crypto/ecdsa/signature.js +2 -2
  94. package/dest/crypto/grumpkin/index.d.ts +10 -15
  95. package/dest/crypto/grumpkin/index.d.ts.map +1 -1
  96. package/dest/crypto/grumpkin/index.js +61 -55
  97. package/dest/crypto/keccak/index.d.ts +3 -5
  98. package/dest/crypto/keccak/index.d.ts.map +1 -1
  99. package/dest/crypto/keys/index.d.ts +2 -4
  100. package/dest/crypto/keys/index.d.ts.map +1 -1
  101. package/dest/crypto/keys/index.js +8 -5
  102. package/dest/crypto/pedersen/index.d.ts +1 -1
  103. package/dest/crypto/pedersen/pedersen.noble.d.ts +3 -5
  104. package/dest/crypto/pedersen/pedersen.noble.d.ts.map +1 -1
  105. package/dest/crypto/pedersen/pedersen.wasm.d.ts +4 -6
  106. package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -1
  107. package/dest/crypto/pedersen/pedersen.wasm.js +24 -14
  108. package/dest/crypto/poseidon/index.d.ts +2 -5
  109. package/dest/crypto/poseidon/index.d.ts.map +1 -1
  110. package/dest/crypto/poseidon/index.js +27 -21
  111. package/dest/crypto/random/index.d.ts +2 -4
  112. package/dest/crypto/random/index.d.ts.map +1 -1
  113. package/dest/crypto/random/index.js +2 -34
  114. package/dest/crypto/random/randomness_singleton.d.ts +2 -4
  115. package/dest/crypto/random/randomness_singleton.d.ts.map +1 -1
  116. package/dest/crypto/random/randomness_singleton.js +3 -3
  117. package/dest/crypto/schnorr/index.d.ts +3 -2
  118. package/dest/crypto/schnorr/index.d.ts.map +1 -1
  119. package/dest/crypto/schnorr/index.js +30 -38
  120. package/dest/crypto/schnorr/signature.d.ts +5 -7
  121. package/dest/crypto/schnorr/signature.d.ts.map +1 -1
  122. package/dest/crypto/schnorr/signature.js +2 -2
  123. package/dest/crypto/secp256k1/index.d.ts +5 -7
  124. package/dest/crypto/secp256k1/index.d.ts.map +1 -1
  125. package/dest/crypto/secp256k1/index.js +23 -18
  126. package/dest/crypto/secp256k1-signer/index.d.ts +1 -1
  127. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts +1 -1
  128. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts.map +1 -1
  129. package/dest/crypto/secp256k1-signer/utils.d.ts +56 -5
  130. package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -1
  131. package/dest/crypto/secp256k1-signer/utils.js +92 -6
  132. package/dest/crypto/serialize.d.ts +5 -7
  133. package/dest/crypto/serialize.d.ts.map +1 -1
  134. package/dest/crypto/sha256/index.d.ts +23 -6
  135. package/dest/crypto/sha256/index.d.ts.map +1 -1
  136. package/dest/crypto/sha256/index.js +43 -1
  137. package/dest/crypto/sha512/index.d.ts +3 -5
  138. package/dest/crypto/sha512/index.d.ts.map +1 -1
  139. package/dest/crypto/sha512/index.js +1 -1
  140. package/dest/crypto/signature/index.d.ts +2 -4
  141. package/dest/crypto/signature/index.d.ts.map +1 -1
  142. package/dest/crypto/sync/index.d.ts +1 -1
  143. package/dest/crypto/sync/index.js +1 -1
  144. package/dest/crypto/sync/pedersen/index.d.ts +4 -6
  145. package/dest/crypto/sync/pedersen/index.d.ts.map +1 -1
  146. package/dest/crypto/sync/pedersen/index.js +18 -11
  147. package/dest/crypto/sync/poseidon/index.d.ts +2 -5
  148. package/dest/crypto/sync/poseidon/index.d.ts.map +1 -1
  149. package/dest/crypto/sync/poseidon/index.js +23 -16
  150. package/dest/curves/bls12/field.d.ts +148 -0
  151. package/dest/curves/bls12/field.d.ts.map +1 -0
  152. package/dest/curves/bls12/field.js +362 -0
  153. package/dest/curves/bls12/index.d.ts +3 -0
  154. package/dest/curves/bls12/index.d.ts.map +1 -0
  155. package/dest/curves/bls12/index.js +2 -0
  156. package/dest/curves/bls12/point.d.ts +229 -0
  157. package/dest/curves/bls12/point.d.ts.map +1 -0
  158. package/dest/curves/bls12/point.js +400 -0
  159. package/dest/curves/bn254/field.d.ts +180 -0
  160. package/dest/curves/bn254/field.d.ts.map +1 -0
  161. package/dest/{fields/fields.js → curves/bn254/field.js} +90 -62
  162. package/dest/curves/bn254/index.d.ts +3 -0
  163. package/dest/curves/bn254/index.d.ts.map +1 -0
  164. package/dest/curves/bn254/index.js +2 -0
  165. package/dest/curves/bn254/point.d.ts +54 -0
  166. package/dest/curves/bn254/point.d.ts.map +1 -0
  167. package/dest/curves/bn254/point.js +143 -0
  168. package/dest/curves/grumpkin/index.d.ts +10 -0
  169. package/dest/curves/grumpkin/index.d.ts.map +1 -0
  170. package/dest/curves/grumpkin/index.js +3 -0
  171. package/dest/{fields → curves/grumpkin}/point.d.ts +14 -7
  172. package/dest/curves/grumpkin/point.d.ts.map +1 -0
  173. package/dest/{fields → curves/grumpkin}/point.js +27 -10
  174. package/dest/decorators/index.d.ts +1 -1
  175. package/dest/decorators/memoize.d.ts +1 -1
  176. package/dest/decorators/memoize.d.ts.map +1 -1
  177. package/dest/error/index.d.ts +1 -1
  178. package/dest/eth-address/index.d.ts +18 -9
  179. package/dest/eth-address/index.d.ts.map +1 -1
  180. package/dest/eth-address/index.js +31 -2
  181. package/dest/eth-signature/eth_signature.d.ts +17 -15
  182. package/dest/eth-signature/eth_signature.d.ts.map +1 -1
  183. package/dest/eth-signature/eth_signature.js +31 -17
  184. package/dest/eth-signature/index.d.ts +1 -1
  185. package/dest/fs/index.d.ts +2 -1
  186. package/dest/fs/index.d.ts.map +1 -1
  187. package/dest/fs/index.js +1 -0
  188. package/dest/fs/run_in_dir.d.ts +1 -1
  189. package/dest/fs/try_rm_dir.d.ts +3 -0
  190. package/dest/fs/try_rm_dir.d.ts.map +1 -0
  191. package/dest/fs/try_rm_dir.js +16 -0
  192. package/dest/iterable/all.d.ts +1 -1
  193. package/dest/iterable/filter.d.ts +1 -1
  194. package/dest/iterable/filter.js +1 -1
  195. package/dest/iterable/index.d.ts +1 -1
  196. package/dest/iterable/isAsyncIt.d.ts +1 -1
  197. package/dest/iterable/map.d.ts +1 -1
  198. package/dest/iterable/map.js +1 -1
  199. package/dest/iterable/peek.d.ts +1 -1
  200. package/dest/iterable/sort.d.ts +1 -1
  201. package/dest/iterable/take.d.ts +1 -1
  202. package/dest/iterable/toArray.d.ts +1 -1
  203. package/dest/iterator/filter.d.ts +3 -0
  204. package/dest/iterator/filter.d.ts.map +1 -0
  205. package/dest/iterator/filter.js +7 -0
  206. package/dest/iterator/index.d.ts +2 -0
  207. package/dest/iterator/index.d.ts.map +1 -0
  208. package/dest/iterator/index.js +1 -0
  209. package/dest/jest/env.js +48 -0
  210. package/dest/jest/setupAfterEnv.js +3 -0
  211. package/dest/json-rpc/client/fetch.d.ts +3 -3
  212. package/dest/json-rpc/client/fetch.d.ts.map +1 -1
  213. package/dest/json-rpc/client/fetch.js +16 -30
  214. package/dest/json-rpc/client/index.d.ts +1 -1
  215. package/dest/json-rpc/client/safe_json_rpc_client.d.ts +10 -4
  216. package/dest/json-rpc/client/safe_json_rpc_client.d.ts.map +1 -1
  217. package/dest/json-rpc/client/safe_json_rpc_client.js +173 -13
  218. package/dest/json-rpc/client/undici.d.ts +1 -1
  219. package/dest/json-rpc/client/undici.d.ts.map +1 -1
  220. package/dest/json-rpc/client/undici.js +27 -11
  221. package/dest/json-rpc/convert.d.ts +3 -10
  222. package/dest/json-rpc/convert.d.ts.map +1 -1
  223. package/dest/json-rpc/convert.js +1 -9
  224. package/dest/json-rpc/errors.d.ts +4 -0
  225. package/dest/json-rpc/errors.d.ts.map +1 -0
  226. package/dest/json-rpc/errors.js +6 -0
  227. package/dest/json-rpc/fixtures/class_a.d.ts +6 -4
  228. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -1
  229. package/dest/json-rpc/fixtures/class_b.d.ts +6 -4
  230. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -1
  231. package/dest/json-rpc/fixtures/test_state.d.ts +1 -1
  232. package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -1
  233. package/dest/json-rpc/index.d.ts +3 -2
  234. package/dest/json-rpc/index.d.ts.map +1 -1
  235. package/dest/json-rpc/index.js +2 -1
  236. package/dest/json-rpc/js_utils.d.ts +1 -1
  237. package/dest/json-rpc/js_utils.d.ts.map +1 -1
  238. package/dest/json-rpc/server/index.d.ts +1 -1
  239. package/dest/json-rpc/server/safe_json_rpc_server.d.ts +22 -23
  240. package/dest/json-rpc/server/safe_json_rpc_server.d.ts.map +1 -1
  241. package/dest/json-rpc/server/safe_json_rpc_server.js +161 -56
  242. package/dest/json-rpc/test/index.d.ts +1 -1
  243. package/dest/json-rpc/test/integration.d.ts +2 -3
  244. package/dest/json-rpc/test/integration.d.ts.map +1 -1
  245. package/dest/log/console.d.ts +1 -1
  246. package/dest/log/console.d.ts.map +1 -1
  247. package/dest/log/gcloud-logger-config.d.ts +1 -2
  248. package/dest/log/gcloud-logger-config.d.ts.map +1 -1
  249. package/dest/log/gcloud-logger-config.js +1 -9
  250. package/dest/log/index.d.ts +5 -5
  251. package/dest/log/index.d.ts.map +1 -1
  252. package/dest/log/index.js +4 -4
  253. package/dest/log/libp2p_logger.d.ts +1 -1
  254. package/dest/log/libp2p_logger.js +13 -2
  255. package/dest/log/log-filters.d.ts +1 -1
  256. package/dest/log/log-levels.d.ts +1 -1
  257. package/dest/log/log_fn.d.ts +2 -2
  258. package/dest/log/log_fn.d.ts.map +1 -1
  259. package/dest/log/noir_debug_log_util.d.ts +14 -0
  260. package/dest/log/noir_debug_log_util.d.ts.map +1 -0
  261. package/dest/log/noir_debug_log_util.js +14 -0
  262. package/dest/log/pino-logger.d.ts +4 -4
  263. package/dest/log/pino-logger.d.ts.map +1 -1
  264. package/dest/log/pino-logger.js +29 -3
  265. package/dest/message/index.d.ts +1 -1
  266. package/dest/message/index.d.ts.map +1 -1
  267. package/dest/mutex/index.d.ts +1 -1
  268. package/dest/mutex/index.d.ts.map +1 -1
  269. package/dest/mutex/mutex_database.d.ts +1 -1
  270. package/dest/mutex/mutex_database.d.ts.map +1 -1
  271. package/dest/noir/index.d.ts +1 -1
  272. package/dest/noir/noir_package_config.d.ts +9 -9
  273. package/dest/number/index.d.ts +3 -0
  274. package/dest/number/index.d.ts.map +1 -0
  275. package/dest/number/index.js +12 -0
  276. package/dest/profiler/index.d.ts +2 -0
  277. package/dest/profiler/index.d.ts.map +1 -0
  278. package/dest/profiler/index.js +1 -0
  279. package/dest/profiler/profiler.d.ts +8 -0
  280. package/dest/profiler/profiler.d.ts.map +1 -0
  281. package/dest/profiler/profiler.js +97 -0
  282. package/dest/promise/index.d.ts +1 -1
  283. package/dest/promise/running-promise.d.ts +2 -2
  284. package/dest/promise/running-promise.d.ts.map +1 -1
  285. package/dest/promise/running-promise.js +2 -2
  286. package/dest/promise/utils.d.ts +1 -1
  287. package/dest/queue/base_memory_queue.d.ts +1 -1
  288. package/dest/queue/base_memory_queue.d.ts.map +1 -1
  289. package/dest/queue/batch_queue.d.ts +2 -2
  290. package/dest/queue/batch_queue.d.ts.map +1 -1
  291. package/dest/queue/batch_queue.js +1 -1
  292. package/dest/queue/bounded_serial_queue.d.ts +1 -1
  293. package/dest/queue/bounded_serial_queue.d.ts.map +1 -1
  294. package/dest/queue/fifo_memory_queue.d.ts +1 -1
  295. package/dest/queue/fifo_memory_queue.d.ts.map +1 -1
  296. package/dest/queue/index.d.ts +1 -1
  297. package/dest/queue/priority_memory_queue.d.ts +1 -1
  298. package/dest/queue/priority_memory_queue.d.ts.map +1 -1
  299. package/dest/queue/priority_queue.d.ts +1 -1
  300. package/dest/queue/priority_queue.d.ts.map +1 -1
  301. package/dest/queue/semaphore.d.ts +1 -1
  302. package/dest/queue/semaphore.d.ts.map +1 -1
  303. package/dest/queue/serial_queue.d.ts +3 -3
  304. package/dest/queue/serial_queue.d.ts.map +1 -1
  305. package/dest/queue/serial_queue.js +7 -5
  306. package/dest/retry/index.d.ts +14 -3
  307. package/dest/retry/index.d.ts.map +1 -1
  308. package/dest/retry/index.js +13 -2
  309. package/dest/running-promise/index.d.ts +1 -1
  310. package/dest/schemas/api.d.ts +1 -1
  311. package/dest/schemas/api.d.ts.map +1 -1
  312. package/dest/schemas/index.d.ts +1 -1
  313. package/dest/schemas/parse.d.ts +1 -1
  314. package/dest/schemas/parse.js +1 -1
  315. package/dest/schemas/schemas.d.ts +21 -20
  316. package/dest/schemas/schemas.d.ts.map +1 -1
  317. package/dest/schemas/schemas.js +29 -11
  318. package/dest/schemas/types.d.ts +31 -1
  319. package/dest/schemas/types.d.ts.map +1 -1
  320. package/dest/schemas/types.js +25 -1
  321. package/dest/schemas/utils.d.ts +4 -6
  322. package/dest/schemas/utils.d.ts.map +1 -1
  323. package/dest/schemas/utils.js +15 -5
  324. package/dest/serialize/buffer_reader.d.ts +34 -6
  325. package/dest/serialize/buffer_reader.d.ts.map +1 -1
  326. package/dest/serialize/buffer_reader.js +57 -6
  327. package/dest/serialize/field_reader.d.ts +12 -3
  328. package/dest/serialize/field_reader.d.ts.map +1 -1
  329. package/dest/serialize/field_reader.js +19 -2
  330. package/dest/serialize/free_funcs.d.ts +25 -23
  331. package/dest/serialize/free_funcs.d.ts.map +1 -1
  332. package/dest/serialize/free_funcs.js +22 -28
  333. package/dest/serialize/index.d.ts +1 -1
  334. package/dest/serialize/serialize.d.ts +6 -7
  335. package/dest/serialize/serialize.d.ts.map +1 -1
  336. package/dest/serialize/serialize.js +1 -1
  337. package/dest/serialize/type_registry.d.ts +1 -1
  338. package/dest/serialize/type_registry.d.ts.map +1 -1
  339. package/dest/serialize/types.d.ts +1 -1
  340. package/dest/sleep/index.d.ts +3 -1
  341. package/dest/sleep/index.d.ts.map +1 -1
  342. package/dest/sleep/index.js +4 -0
  343. package/dest/string/index.d.ts +8 -3
  344. package/dest/string/index.d.ts.map +1 -1
  345. package/dest/string/index.js +27 -1
  346. package/dest/testing/files/index.d.ts +2 -3
  347. package/dest/testing/files/index.d.ts.map +1 -1
  348. package/dest/testing/files/index.js +3 -3
  349. package/dest/testing/formatting.d.ts +4 -0
  350. package/dest/testing/formatting.d.ts.map +1 -0
  351. package/dest/testing/formatting.js +3 -0
  352. package/dest/testing/index.d.ts +2 -1
  353. package/dest/testing/index.d.ts.map +1 -1
  354. package/dest/testing/index.js +1 -0
  355. package/dest/testing/port_allocator.d.ts +1 -1
  356. package/dest/testing/snapshot_serializer.d.ts +1 -1
  357. package/dest/testing/test_data.d.ts +1 -1
  358. package/dest/timer/date.d.ts +4 -2
  359. package/dest/timer/date.d.ts.map +1 -1
  360. package/dest/timer/date.js +8 -3
  361. package/dest/timer/elapsed.d.ts +1 -1
  362. package/dest/timer/index.d.ts +2 -2
  363. package/dest/timer/index.d.ts.map +1 -1
  364. package/dest/timer/index.js +1 -1
  365. package/dest/timer/timeout.d.ts +19 -6
  366. package/dest/timer/timeout.d.ts.map +1 -1
  367. package/dest/timer/timeout.js +43 -22
  368. package/dest/timer/timer.d.ts +1 -1
  369. package/dest/timer/timer.d.ts.map +1 -1
  370. package/dest/transport/dispatch/create_dispatch_fn.d.ts +1 -1
  371. package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -1
  372. package/dest/transport/dispatch/create_dispatch_proxy.d.ts +1 -1
  373. package/dest/transport/dispatch/messages.d.ts +1 -1
  374. package/dest/transport/index.d.ts +1 -2
  375. package/dest/transport/index.d.ts.map +1 -1
  376. package/dest/transport/index.js +0 -1
  377. package/dest/transport/interface/connector.d.ts +1 -1
  378. package/dest/transport/interface/connector.d.ts.map +1 -1
  379. package/dest/transport/interface/listener.d.ts +1 -2
  380. package/dest/transport/interface/listener.d.ts.map +1 -1
  381. package/dest/transport/interface/socket.d.ts +1 -1
  382. package/dest/transport/interface/socket.d.ts.map +1 -1
  383. package/dest/transport/interface/transferable.d.ts +1 -1
  384. package/dest/transport/node/index.d.ts +1 -1
  385. package/dest/transport/node/node_connector.d.ts +1 -2
  386. package/dest/transport/node/node_connector.d.ts.map +1 -1
  387. package/dest/transport/node/node_connector_socket.d.ts +1 -2
  388. package/dest/transport/node/node_connector_socket.d.ts.map +1 -1
  389. package/dest/transport/node/node_listener.d.ts +1 -2
  390. package/dest/transport/node/node_listener.d.ts.map +1 -1
  391. package/dest/transport/node/node_listener_socket.d.ts +1 -2
  392. package/dest/transport/node/node_listener_socket.d.ts.map +1 -1
  393. package/dest/transport/transport_client.d.ts +1 -2
  394. package/dest/transport/transport_client.d.ts.map +1 -1
  395. package/dest/transport/transport_server.d.ts +1 -10
  396. package/dest/transport/transport_server.d.ts.map +1 -1
  397. package/dest/trees/balanced_merkle_tree_root.d.ts +17 -0
  398. package/dest/trees/balanced_merkle_tree_root.d.ts.map +1 -0
  399. package/dest/trees/balanced_merkle_tree_root.js +51 -0
  400. package/dest/trees/hasher.d.ts +7 -7
  401. package/dest/trees/hasher.d.ts.map +1 -1
  402. package/dest/trees/hasher.js +10 -5
  403. package/dest/trees/index.d.ts +5 -3
  404. package/dest/trees/index.d.ts.map +1 -1
  405. package/dest/trees/index.js +4 -2
  406. package/dest/trees/indexed_merkle_tree.d.ts +1 -3
  407. package/dest/trees/indexed_merkle_tree.d.ts.map +1 -1
  408. package/dest/trees/indexed_merkle_tree.js +1 -1
  409. package/dest/trees/indexed_merkle_tree_calculator.d.ts +2 -4
  410. package/dest/trees/indexed_merkle_tree_calculator.d.ts.map +1 -1
  411. package/dest/trees/indexed_tree_leaf.d.ts +1 -3
  412. package/dest/trees/indexed_tree_leaf.d.ts.map +1 -1
  413. package/dest/trees/membership_witness.d.ts +10 -5
  414. package/dest/trees/membership_witness.d.ts.map +1 -1
  415. package/dest/trees/membership_witness.js +23 -1
  416. package/dest/trees/merkle_tree.d.ts +1 -3
  417. package/dest/trees/merkle_tree.d.ts.map +1 -1
  418. package/dest/trees/merkle_tree_calculator.d.ts +2 -4
  419. package/dest/trees/merkle_tree_calculator.d.ts.map +1 -1
  420. package/dest/trees/merkle_tree_calculator.js +2 -2
  421. package/dest/trees/sibling_path.d.ts +6 -41
  422. package/dest/trees/sibling_path.d.ts.map +1 -1
  423. package/dest/trees/sibling_path.js +3 -3
  424. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts +48 -0
  425. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts.map +1 -0
  426. package/dest/trees/unbalanced_merkle_tree_calculator.js +154 -0
  427. package/dest/trees/unbalanced_merkle_tree_root.d.ts +28 -0
  428. package/dest/trees/unbalanced_merkle_tree_root.d.ts.map +1 -0
  429. package/dest/trees/unbalanced_merkle_tree_root.js +84 -0
  430. package/dest/trees/unbalanced_tree_store.d.ts +6 -1
  431. package/dest/trees/unbalanced_tree_store.d.ts.map +1 -1
  432. package/dest/trees/unbalanced_tree_store.js +55 -1
  433. package/dest/types/index.d.ts +28 -3
  434. package/dest/types/index.d.ts.map +1 -1
  435. package/dest/types/index.js +3 -0
  436. package/dest/url/index.d.ts +1 -1
  437. package/dest/url/index.d.ts.map +1 -1
  438. package/dest/url/index.js +1 -1
  439. package/dest/validation/index.d.ts +1 -1
  440. package/package.json +59 -45
  441. package/src/array/array.ts +13 -16
  442. package/src/array/index.ts +1 -0
  443. package/src/array/sorted_array.ts +133 -0
  444. package/src/async-pool/index.ts +1 -0
  445. package/src/bigint/index.ts +20 -0
  446. package/src/branded-types/block_number.ts +117 -0
  447. package/src/branded-types/checkpoint_number.ts +115 -0
  448. package/src/branded-types/epoch.ts +88 -0
  449. package/src/branded-types/index.ts +7 -0
  450. package/src/branded-types/index_within_checkpoint.ts +88 -0
  451. package/src/branded-types/slot.ts +88 -0
  452. package/src/branded-types/types.ts +2 -0
  453. package/src/buffer/buffer16.ts +133 -0
  454. package/src/buffer/buffer32.ts +10 -8
  455. package/src/buffer/index.ts +1 -0
  456. package/src/collection/array.ts +97 -4
  457. package/src/collection/object.ts +37 -0
  458. package/src/config/env_var.ts +180 -59
  459. package/src/config/index.ts +226 -10
  460. package/src/config/network_config.ts +18 -0
  461. package/src/config/network_name.ts +28 -0
  462. package/src/config/parse-env.ts +4 -0
  463. package/src/config/secret_value.ts +49 -0
  464. package/src/crypto/aes128/index.ts +19 -10
  465. package/src/crypto/bls/bn254_keystore.ts +287 -0
  466. package/src/crypto/bls/index.ts +77 -0
  467. package/src/crypto/bn254/index.ts +64 -0
  468. package/src/crypto/ecdsa/index.ts +41 -23
  469. package/src/crypto/ecdsa/signature.ts +2 -2
  470. package/src/crypto/grumpkin/index.ts +38 -46
  471. package/src/crypto/keys/index.ts +6 -6
  472. package/src/crypto/pedersen/pedersen.wasm.ts +23 -19
  473. package/src/crypto/poseidon/index.ts +27 -29
  474. package/src/crypto/random/index.ts +2 -40
  475. package/src/crypto/random/randomness_singleton.ts +2 -4
  476. package/src/crypto/schnorr/index.ts +22 -18
  477. package/src/crypto/schnorr/signature.ts +2 -2
  478. package/src/crypto/secp256k1/index.ts +15 -11
  479. package/src/crypto/secp256k1-signer/utils.ts +120 -7
  480. package/src/crypto/sha256/index.ts +48 -1
  481. package/src/crypto/sha512/index.ts +1 -1
  482. package/src/crypto/signature/index.ts +1 -1
  483. package/src/crypto/sync/index.ts +1 -1
  484. package/src/crypto/sync/pedersen/index.ts +17 -16
  485. package/src/crypto/sync/poseidon/index.ts +23 -27
  486. package/src/curves/bls12/field.ts +463 -0
  487. package/src/curves/bls12/index.ts +2 -0
  488. package/src/curves/bls12/point.ts +450 -0
  489. package/src/{fields/fields.ts → curves/bn254/field.ts} +84 -63
  490. package/src/curves/bn254/index.ts +2 -0
  491. package/src/curves/bn254/point.ts +170 -0
  492. package/src/curves/grumpkin/index.ts +11 -0
  493. package/src/{fields → curves/grumpkin}/point.ts +27 -10
  494. package/src/eth-address/index.ts +35 -3
  495. package/src/eth-signature/eth_signature.ts +44 -22
  496. package/src/fs/index.ts +1 -0
  497. package/src/fs/try_rm_dir.ts +15 -0
  498. package/src/iterable/filter.ts +1 -1
  499. package/src/iterable/map.ts +1 -1
  500. package/src/iterator/filter.ts +11 -0
  501. package/src/iterator/index.ts +1 -0
  502. package/src/jest/env.mjs +52 -0
  503. package/src/jest/setupAfterEnv.mjs +3 -0
  504. package/src/json-rpc/client/fetch.ts +14 -33
  505. package/src/json-rpc/client/safe_json_rpc_client.ts +226 -13
  506. package/src/json-rpc/client/undici.ts +29 -18
  507. package/src/json-rpc/convert.ts +3 -12
  508. package/src/json-rpc/errors.ts +6 -0
  509. package/src/json-rpc/fixtures/class_a.ts +4 -1
  510. package/src/json-rpc/fixtures/class_b.ts +4 -1
  511. package/src/json-rpc/index.ts +2 -1
  512. package/src/json-rpc/server/safe_json_rpc_server.ts +141 -48
  513. package/src/json-rpc/test/integration.ts +1 -1
  514. package/src/log/console.ts +4 -1
  515. package/src/log/gcloud-logger-config.ts +3 -7
  516. package/src/log/index.ts +4 -4
  517. package/src/log/libp2p_logger.ts +21 -2
  518. package/src/log/log_fn.ts +1 -1
  519. package/src/log/noir_debug_log_util.ts +21 -0
  520. package/src/log/pino-logger.ts +35 -3
  521. package/src/message/index.ts +5 -1
  522. package/src/mutex/mutex_database.ts +2 -3
  523. package/src/number/index.ts +14 -0
  524. package/src/profiler/index.ts +1 -0
  525. package/src/profiler/profiler.ts +125 -0
  526. package/src/promise/running-promise.ts +2 -2
  527. package/src/queue/batch_queue.ts +1 -1
  528. package/src/queue/bounded_serial_queue.ts +4 -1
  529. package/src/queue/serial_queue.ts +5 -5
  530. package/src/retry/index.ts +28 -5
  531. package/src/schemas/api.ts +4 -4
  532. package/src/schemas/parse.ts +1 -1
  533. package/src/schemas/schemas.ts +42 -13
  534. package/src/schemas/types.ts +33 -0
  535. package/src/schemas/utils.ts +21 -8
  536. package/src/serialize/buffer_reader.ts +81 -12
  537. package/src/serialize/field_reader.ts +28 -4
  538. package/src/serialize/free_funcs.ts +26 -32
  539. package/src/serialize/serialize.ts +3 -1
  540. package/src/sleep/index.ts +6 -0
  541. package/src/string/index.ts +36 -1
  542. package/src/testing/files/index.ts +7 -3
  543. package/src/testing/formatting.ts +3 -0
  544. package/src/testing/index.ts +1 -0
  545. package/src/timer/date.ts +13 -3
  546. package/src/timer/index.ts +1 -1
  547. package/src/timer/timeout.ts +54 -19
  548. package/src/transport/index.ts +0 -1
  549. package/src/transport/interface/connector.ts +0 -1
  550. package/src/transport/interface/listener.ts +2 -3
  551. package/src/transport/interface/socket.ts +2 -3
  552. package/src/transport/transport_client.ts +3 -4
  553. package/src/transport/transport_server.ts +4 -1
  554. package/src/trees/balanced_merkle_tree_root.ts +68 -0
  555. package/src/trees/hasher.ts +13 -4
  556. package/src/trees/index.ts +4 -2
  557. package/src/trees/indexed_merkle_tree.ts +6 -2
  558. package/src/trees/indexed_merkle_tree_calculator.ts +2 -2
  559. package/src/trees/membership_witness.ts +22 -1
  560. package/src/trees/merkle_tree.ts +4 -1
  561. package/src/trees/merkle_tree_calculator.ts +10 -5
  562. package/src/trees/sibling_path.ts +3 -3
  563. package/src/trees/unbalanced_merkle_tree_calculator.ts +176 -0
  564. package/src/trees/unbalanced_merkle_tree_root.ts +115 -0
  565. package/src/trees/unbalanced_tree_store.ts +62 -3
  566. package/src/types/index.ts +30 -4
  567. package/src/url/index.ts +0 -1
  568. package/dest/crypto/index.d.ts +0 -15
  569. package/dest/crypto/index.d.ts.map +0 -1
  570. package/dest/crypto/index.js +0 -14
  571. package/dest/crypto/pedersen/pedersen.elliptic.d.ts +0 -13
  572. package/dest/crypto/pedersen/pedersen.elliptic.d.ts.map +0 -1
  573. package/dest/crypto/pedersen/pedersen.elliptic.js +0 -582
  574. package/dest/fields/coordinate.d.ts +0 -68
  575. package/dest/fields/coordinate.d.ts.map +0 -1
  576. package/dest/fields/coordinate.js +0 -96
  577. package/dest/fields/fields.d.ts +0 -176
  578. package/dest/fields/fields.d.ts.map +0 -1
  579. package/dest/fields/index.d.ts +0 -4
  580. package/dest/fields/index.d.ts.map +0 -1
  581. package/dest/fields/index.js +0 -3
  582. package/dest/fields/point.d.ts.map +0 -1
  583. package/dest/index.d.ts +0 -31
  584. package/dest/index.d.ts.map +0 -1
  585. package/dest/index.js +0 -31
  586. package/dest/json-rpc/server/telemetry.d.ts +0 -2
  587. package/dest/json-rpc/server/telemetry.d.ts.map +0 -1
  588. package/dest/json-rpc/server/telemetry.js +0 -0
  589. package/dest/log/debug.d.ts +0 -56
  590. package/dest/log/debug.d.ts.map +0 -1
  591. package/dest/log/debug.js +0 -75
  592. package/dest/log/log_history.d.ts +0 -31
  593. package/dest/log/log_history.d.ts.map +0 -1
  594. package/dest/log/log_history.js +0 -38
  595. package/dest/transport/browser/index.d.ts +0 -5
  596. package/dest/transport/browser/index.d.ts.map +0 -1
  597. package/dest/transport/browser/index.js +0 -4
  598. package/dest/transport/browser/message_port_socket.d.ts +0 -37
  599. package/dest/transport/browser/message_port_socket.d.ts.map +0 -1
  600. package/dest/transport/browser/message_port_socket.js +0 -42
  601. package/dest/transport/browser/shared_worker_connector.d.ts +0 -19
  602. package/dest/transport/browser/shared_worker_connector.d.ts.map +0 -1
  603. package/dest/transport/browser/shared_worker_connector.js +0 -19
  604. package/dest/transport/browser/shared_worker_listener.d.ts +0 -38
  605. package/dest/transport/browser/shared_worker_listener.d.ts.map +0 -1
  606. package/dest/transport/browser/shared_worker_listener.js +0 -33
  607. package/dest/transport/browser/worker_connector.d.ts +0 -26
  608. package/dest/transport/browser/worker_connector.d.ts.map +0 -1
  609. package/dest/transport/browser/worker_connector.js +0 -30
  610. package/dest/transport/browser/worker_listener.d.ts +0 -39
  611. package/dest/transport/browser/worker_listener.d.ts.map +0 -1
  612. package/dest/transport/browser/worker_listener.js +0 -35
  613. package/dest/trees/unbalanced_merkle_tree.d.ts +0 -17
  614. package/dest/trees/unbalanced_merkle_tree.d.ts.map +0 -1
  615. package/dest/trees/unbalanced_merkle_tree.js +0 -100
  616. package/dest/wasm/empty_wasi_sdk.d.ts +0 -130
  617. package/dest/wasm/empty_wasi_sdk.d.ts.map +0 -1
  618. package/dest/wasm/empty_wasi_sdk.js +0 -148
  619. package/dest/wasm/index.d.ts +0 -2
  620. package/dest/wasm/index.d.ts.map +0 -1
  621. package/dest/wasm/index.js +0 -1
  622. package/dest/wasm/wasm_module.d.ts +0 -136
  623. package/dest/wasm/wasm_module.d.ts.map +0 -1
  624. package/dest/wasm/wasm_module.js +0 -196
  625. package/dest/worker/browser/index.d.ts +0 -3
  626. package/dest/worker/browser/index.d.ts.map +0 -1
  627. package/dest/worker/browser/index.js +0 -2
  628. package/dest/worker/browser/start_web_module.d.ts +0 -7
  629. package/dest/worker/browser/start_web_module.d.ts.map +0 -1
  630. package/dest/worker/browser/start_web_module.js +0 -27
  631. package/dest/worker/browser/web_data_store.d.ts +0 -24
  632. package/dest/worker/browser/web_data_store.d.ts.map +0 -1
  633. package/dest/worker/browser/web_data_store.js +0 -29
  634. package/dest/worker/browser/web_worker.d.ts +0 -10
  635. package/dest/worker/browser/web_worker.d.ts.map +0 -1
  636. package/dest/worker/browser/web_worker.js +0 -25
  637. package/dest/worker/data_store.d.ts +0 -21
  638. package/dest/worker/data_store.d.ts.map +0 -1
  639. package/dest/worker/data_store.js +0 -3
  640. package/dest/worker/index.d.ts +0 -3
  641. package/dest/worker/index.d.ts.map +0 -1
  642. package/dest/worker/index.js +0 -1
  643. package/dest/worker/node/index.d.ts +0 -3
  644. package/dest/worker/node/index.d.ts.map +0 -1
  645. package/dest/worker/node/index.js +0 -2
  646. package/dest/worker/node/node_data_store.d.ts +0 -13
  647. package/dest/worker/node/node_data_store.d.ts.map +0 -1
  648. package/dest/worker/node/node_data_store.js +0 -20
  649. package/dest/worker/node/node_worker.d.ts +0 -6
  650. package/dest/worker/node/node_worker.d.ts.map +0 -1
  651. package/dest/worker/node/node_worker.js +0 -22
  652. package/dest/worker/node/start_node_module.d.ts +0 -7
  653. package/dest/worker/node/start_node_module.d.ts.map +0 -1
  654. package/dest/worker/node/start_node_module.js +0 -31
  655. package/dest/worker/wasm_worker.d.ts +0 -9
  656. package/dest/worker/wasm_worker.d.ts.map +0 -1
  657. package/dest/worker/wasm_worker.js +0 -3
  658. package/dest/worker/worker_pool.d.ts +0 -40
  659. package/dest/worker/worker_pool.d.ts.map +0 -1
  660. package/dest/worker/worker_pool.js +0 -51
  661. package/src/crypto/index.ts +0 -14
  662. package/src/crypto/pedersen/pedersen.elliptic.ts +0 -584
  663. package/src/fields/coordinate.ts +0 -104
  664. package/src/fields/index.ts +0 -3
  665. package/src/index.ts +0 -31
  666. package/src/json-rpc/server/telemetry.ts +0 -0
  667. package/src/log/debug.ts +0 -104
  668. package/src/log/log_history.ts +0 -44
  669. package/src/transport/browser/index.ts +0 -4
  670. package/src/transport/browser/message_port_socket.ts +0 -48
  671. package/src/transport/browser/shared_worker_connector.ts +0 -21
  672. package/src/transport/browser/shared_worker_listener.ts +0 -53
  673. package/src/transport/browser/worker_connector.ts +0 -30
  674. package/src/transport/browser/worker_listener.ts +0 -54
  675. package/src/trees/unbalanced_merkle_tree.ts +0 -103
  676. package/src/wasm/README.md +0 -6
  677. package/src/wasm/empty_wasi_sdk.ts +0 -166
  678. package/src/wasm/fixtures/gcd.wasm +0 -0
  679. package/src/wasm/fixtures/gcd.wat +0 -27
  680. package/src/wasm/index.ts +0 -1
  681. package/src/wasm/wasm_module.ts +0 -260
  682. package/src/worker/browser/index.ts +0 -2
  683. package/src/worker/browser/start_web_module.ts +0 -24
  684. package/src/worker/browser/web_data_store.ts +0 -38
  685. package/src/worker/browser/web_worker.ts +0 -25
  686. package/src/worker/data_store.ts +0 -19
  687. package/src/worker/index.ts +0 -2
  688. package/src/worker/node/index.ts +0 -2
  689. package/src/worker/node/node_data_store.ts +0 -27
  690. package/src/worker/node/node_worker.ts +0 -23
  691. package/src/worker/node/start_node_module.ts +0 -30
  692. package/src/worker/wasm_worker.ts +0 -7
  693. package/src/worker/worker_pool.ts +0 -73
@@ -0,0 +1,180 @@
1
+ import { inspect } from 'util';
2
+ import { BufferReader } from '../../serialize/buffer_reader.js';
3
+ /**
4
+ * Represents a field derived from BaseField.
5
+ */
6
+ type DerivedField<T extends BaseField> = {
7
+ new (value: any): T;
8
+ /**
9
+ * All derived fields will specify a MODULUS.
10
+ */
11
+ MODULUS: bigint;
12
+ };
13
+ /**
14
+ * Base field class.
15
+ * Uses bigint as the internal representation.
16
+ * Buffers are generated on demand from the bigint value.
17
+ */
18
+ declare abstract class BaseField {
19
+ static SIZE_IN_BYTES: number;
20
+ private readonly asBigInt;
21
+ /**
22
+ * Return bigint representation.
23
+ * @deprecated Just to get things compiling. Use toBigInt().
24
+ * */
25
+ get value(): bigint;
26
+ /** Returns the size in bytes. */
27
+ get size(): number;
28
+ protected constructor(value: number | bigint | boolean | BaseField | Buffer);
29
+ protected abstract modulus(): bigint;
30
+ /**
31
+ * Converts the bigint to a Buffer.
32
+ */
33
+ toBuffer(): Buffer;
34
+ toString(): `0x${string}`;
35
+ toBigInt(): bigint;
36
+ toBool(): boolean;
37
+ /**
38
+ * Converts this field to a number.
39
+ * Throws if the underlying value is greater than MAX_SAFE_INTEGER.
40
+ */
41
+ toNumber(): number;
42
+ /**
43
+ * Converts this field to a number.
44
+ * May cause loss of precision if the underlying value is greater than MAX_SAFE_INTEGER.
45
+ */
46
+ toNumberUnsafe(): number;
47
+ toShortString(): string;
48
+ equals(rhs: BaseField): boolean;
49
+ lt(rhs: BaseField): boolean;
50
+ cmp(rhs: BaseField): -1 | 0 | 1;
51
+ static cmp(lhs: BaseField, rhs: BaseField): -1 | 0 | 1;
52
+ isZero(): boolean;
53
+ isEmpty(): boolean;
54
+ toFriendlyJSON(): string;
55
+ toField(): this;
56
+ }
57
+ /**
58
+ * Constructs a field from a Buffer of BufferReader.
59
+ * It maybe not read the full 32 bytes if the Buffer is shorter, but it will padded in BaseField constructor.
60
+ */
61
+ export declare function fromBuffer<T extends BaseField>(buffer: Buffer | BufferReader, f: DerivedField<T>): T;
62
+ /** Branding to ensure fields are not interchangeable types. */
63
+ export interface Fr {
64
+ /** Brand. */
65
+ _branding: 'Fr';
66
+ }
67
+ /**
68
+ * Fr field class.
69
+ * @dev This class is used to represent elements of BN254 scalar field or elements in the base field of Grumpkin.
70
+ * (Grumpkin's scalar field corresponds to BN254's base field and vice versa.)
71
+ */
72
+ export declare class Fr extends BaseField {
73
+ static ZERO: Fr;
74
+ static ONE: Fr;
75
+ static MODULUS: bigint;
76
+ static MAX_FIELD_VALUE: Fr;
77
+ constructor(value: number | bigint | boolean | Fr | Buffer);
78
+ [inspect.custom](): string;
79
+ protected modulus(): bigint;
80
+ static random(): Fr;
81
+ static zero(): Fr;
82
+ static isZero(value: Fr): boolean;
83
+ static fromBuffer(buffer: Buffer | BufferReader): Fr;
84
+ static fromBufferReduce(buffer: Buffer): Fr;
85
+ /**
86
+ * Creates a Fr instance from a string.
87
+ * @param buf - the string to create a Fr from.
88
+ * @returns the Fr instance
89
+ * @remarks if the string only consists of numbers, we assume we are parsing a bigint,
90
+ * otherwise we require the hex string to be prepended with "0x", to ensure there is no misunderstanding
91
+ * as to what is being parsed.
92
+ */
93
+ static fromString(buf: string): Fr;
94
+ /**
95
+ * Creates a Fr instance from a hex string.
96
+ * @param buf - a hex encoded string.
97
+ * @returns the Fr instance
98
+ */
99
+ static fromHexString(buf: string): Fr;
100
+ /** Arithmetic */
101
+ add(rhs: Fr): Fr;
102
+ square(): Fr;
103
+ negate(): Fr;
104
+ sub(rhs: Fr): Fr;
105
+ mul(rhs: Fr): Fr;
106
+ div(rhs: Fr): Fr;
107
+ ediv(rhs: Fr): Fr;
108
+ /**
109
+ * Computes a square root of the field element.
110
+ * @returns A square root of the field element (null if it does not exist).
111
+ */
112
+ sqrt(): Promise<Fr | null>;
113
+ toJSON(): `0x${string}`;
114
+ /**
115
+ * Creates an Fr instance from a plain object without Zod validation.
116
+ * This method is optimized for performance and skips validation, making it suitable
117
+ * for deserializing trusted data (e.g., from C++ via MessagePack).
118
+ * Handles buffers, strings, numbers, bigints, or existing instances.
119
+ * @param obj - Plain object, buffer, string, number, bigint, boolean, or Fr instance
120
+ * @returns An Fr instance
121
+ */
122
+ static fromPlainObject(obj: any): Fr;
123
+ static get schema(): import("zod").ZodType<Fr, any, string>;
124
+ }
125
+ /**
126
+ * Branding to ensure fields are not interchangeable types.
127
+ */
128
+ export interface Fq {
129
+ /** Brand. */
130
+ _branding: 'Fq';
131
+ }
132
+ /**
133
+ * Fq field class.
134
+ * @dev This class is used to represent elements of BN254 base field or elements in the scalar field of Grumpkin.
135
+ * (Grumpkin's scalar field corresponds to BN254's base field and vice versa.)
136
+ */
137
+ export declare class Fq extends BaseField {
138
+ static ZERO: Fq;
139
+ static MODULUS: bigint;
140
+ private static HIGH_SHIFT;
141
+ private static LOW_MASK;
142
+ [inspect.custom](): string;
143
+ get lo(): Fr;
144
+ get hi(): Fr;
145
+ constructor(value: number | bigint | boolean | Fq | Buffer);
146
+ protected modulus(): bigint;
147
+ static random(): Fq;
148
+ static zero(): Fq;
149
+ static fromBuffer(buffer: Buffer | BufferReader): Fq;
150
+ static fromBufferReduce(buffer: Buffer): Fq;
151
+ /**
152
+ * Creates a Fq instance from a string.
153
+ * @param buf - the string to create a Fq from.
154
+ * @returns the Fq instance
155
+ * @remarks if the string only consists of numbers, we assume we are parsing a bigint,
156
+ * otherwise we require the hex string to be prepended with "0x", to ensure there is no misunderstanding
157
+ * as to what is being parsed.
158
+ */
159
+ static fromString(buf: string): Fq;
160
+ /**
161
+ * Creates a Fq instance from a hex string.
162
+ * @param buf - a hex encoded string.
163
+ * @returns the Fq instance
164
+ */
165
+ static fromHexString(buf: string): Fq;
166
+ static fromHighLow(high: Fr, low: Fr): Fq;
167
+ add(rhs: Fq): Fq;
168
+ /**
169
+ * Computes a square root of the field element.
170
+ * @returns A square root of the field element (null if it does not exist).
171
+ */
172
+ sqrt(): Promise<Fq | null>;
173
+ toJSON(): `0x${string}`;
174
+ toFields(): Fr[];
175
+ static get schema(): import("zod").ZodType<Fq, any, string>;
176
+ }
177
+ /** Wraps a function that returns a buffer so that all results are reduced into a field of the given type. */
178
+ export declare function reduceFn<TInput, TField extends BaseField>(fn: (input: TInput) => Buffer, field: DerivedField<TField>): (input: TInput) => TField;
179
+ export {};
180
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jdXJ2ZXMvYm4yNTQvZmllbGQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUsvQixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFLaEU7O0dBRUc7QUFDSCxLQUFLLFlBQVksQ0FBQyxDQUFDLFNBQVMsU0FBUyxJQUFJO0lBQ3ZDLEtBQUssS0FBSyxFQUFFLEdBQUcsR0FBRyxDQUFDLENBQUM7SUFDcEI7O09BRUc7SUFDSCxPQUFPLEVBQUUsTUFBTSxDQUFDO0NBQ2pCLENBQUM7QUFFRjs7OztHQUlHO0FBQ0gsdUJBQWUsU0FBUztJQUN0QixNQUFNLENBQUMsYUFBYSxTQUFNO0lBQzFCLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFTO0lBRWxDOzs7U0FHSztJQUNMLElBQUksS0FBSyxJQUFJLE1BQU0sQ0FFbEI7SUFFRCxpQ0FBaUM7SUFDakMsSUFBSSxJQUFJLElBQUksTUFBTSxDQUVqQjtJQUVELFNBQVMsYUFBYSxLQUFLLEVBQUUsTUFBTSxHQUFHLE1BQU0sR0FBRyxPQUFPLEdBQUcsU0FBUyxHQUFHLE1BQU0sRUFtQjFFO0lBRUQsU0FBUyxDQUFDLFFBQVEsQ0FBQyxPQUFPLElBQUksTUFBTSxDQUFDO0lBRXJDOztPQUVHO0lBQ0gsUUFBUSxJQUFJLE1BQU0sQ0FFakI7SUFFRCxRQUFRLElBQUksS0FBSyxNQUFNLEVBQUUsQ0FFeEI7SUFFRCxRQUFRLElBQUksTUFBTSxDQUVqQjtJQUVELE1BQU0sSUFBSSxPQUFPLENBRWhCO0lBRUQ7OztPQUdHO0lBQ0gsUUFBUSxJQUFJLE1BQU0sQ0FLakI7SUFFRDs7O09BR0c7SUFDSCxjQUFjLElBQUksTUFBTSxDQUV2QjtJQUVELGFBQWEsSUFBSSxNQUFNLENBR3RCO0lBRUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxT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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"field.d.ts","sourceRoot":"","sources":["../../../src/curves/bn254/field.ts"],"names":[],"mappings":"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"}
@@ -1,19 +1,17 @@
1
+ var _computedKey, _computedKey1;
1
2
  import { BarretenbergSync } from '@aztec/bb.js';
2
3
  import { inspect } from 'util';
3
- import { toBigIntBE, toBufferBE } from '../bigint-buffer/index.js';
4
- import { randomBytes } from '../crypto/random/index.js';
5
- import { hexSchemaFor } from '../schemas/utils.js';
6
- import { BufferReader } from '../serialize/buffer_reader.js';
7
- import { TypeRegistry } from '../serialize/type_registry.js';
8
- const ZERO_BUFFER = Buffer.alloc(32);
4
+ import { toBigIntBE, toBufferBE } from '../../bigint-buffer/index.js';
5
+ import { randomBytes } from '../../crypto/random/index.js';
6
+ import { hexSchemaFor } from '../../schemas/utils.js';
7
+ import { BufferReader } from '../../serialize/buffer_reader.js';
8
+ import { TypeRegistry } from '../../serialize/type_registry.js';
9
9
  /**
10
10
  * Base field class.
11
- * Conversions from Buffer to BigInt and vice-versa are not cheap.
12
- * We allow construction with either form and lazily convert to other as needed.
13
- * We only check we are within the field modulus when initializing with bigint.
11
+ * Uses bigint as the internal representation.
12
+ * Buffers are generated on demand from the bigint value.
14
13
  */ class BaseField {
15
14
  static SIZE_IN_BYTES = 32;
16
- asBuffer;
17
15
  asBigInt;
18
16
  /**
19
17
  * Return bigint representation.
@@ -29,79 +27,68 @@ const ZERO_BUFFER = Buffer.alloc(32);
29
27
  if (value.length > BaseField.SIZE_IN_BYTES) {
30
28
  throw new Error(`Value length ${value.length} exceeds ${BaseField.SIZE_IN_BYTES}`);
31
29
  }
32
- this.asBuffer = value.length === BaseField.SIZE_IN_BYTES ? value : Buffer.concat([
33
- Buffer.alloc(BaseField.SIZE_IN_BYTES - value.length),
34
- value
35
- ]);
30
+ this.asBigInt = toBigIntBE(value);
36
31
  } else if (typeof value === 'bigint' || typeof value === 'number' || typeof value === 'boolean') {
37
32
  this.asBigInt = BigInt(value);
38
- if (this.asBigInt >= this.modulus()) {
39
- throw new Error(`Value 0x${this.asBigInt.toString(16)} is greater or equal to field modulus.`);
40
- }
41
33
  } else if (value instanceof BaseField) {
42
- this.asBuffer = value.asBuffer;
43
34
  this.asBigInt = value.asBigInt;
44
35
  } else {
45
36
  throw new Error(`Type '${typeof value}' with value '${value}' passed to BaseField ctor.`);
46
37
  }
38
+ if (this.asBigInt < 0n) {
39
+ throw new Error(`Value 0x${this.asBigInt.toString(16)} is negative.`);
40
+ } else if (this.asBigInt >= this.modulus()) {
41
+ throw new Error(`Value 0x${this.asBigInt.toString(16)} is greater or equal to field modulus.`);
42
+ }
47
43
  }
48
44
  /**
49
- * We return a copy of the Buffer to ensure this remains immutable.
45
+ * Converts the bigint to a Buffer.
50
46
  */ toBuffer() {
51
- if (!this.asBuffer) {
52
- this.asBuffer = toBufferBE(this.asBigInt, 32);
53
- }
54
- return Buffer.from(this.asBuffer);
47
+ return toBufferBE(this.asBigInt, 32);
55
48
  }
56
49
  toString() {
57
- return `0x${this.toBuffer().toString('hex')}`;
50
+ return `0x${this.asBigInt.toString(16).padStart(64, '0')}`;
58
51
  }
59
52
  toBigInt() {
60
- if (this.asBigInt === undefined) {
61
- this.asBigInt = toBigIntBE(this.asBuffer);
62
- if (this.asBigInt >= this.modulus()) {
63
- throw new Error(`Value 0x${this.asBigInt.toString(16)} is greater or equal to field modulus.`);
64
- }
65
- }
66
53
  return this.asBigInt;
67
54
  }
68
55
  toBool() {
69
- return Boolean(this.toBigInt());
56
+ return this.asBigInt !== 0n;
70
57
  }
71
58
  /**
72
59
  * Converts this field to a number.
73
60
  * Throws if the underlying value is greater than MAX_SAFE_INTEGER.
74
61
  */ toNumber() {
75
- const value = this.toBigInt();
76
- if (value > Number.MAX_SAFE_INTEGER) {
77
- throw new Error(`Value ${value.toString(16)} greater than than max safe integer`);
62
+ if (this.asBigInt > Number.MAX_SAFE_INTEGER) {
63
+ throw new Error(`Value ${this.asBigInt.toString(16)} greater than than max safe integer`);
78
64
  }
79
- return Number(value);
65
+ return Number(this.asBigInt);
80
66
  }
81
67
  /**
82
68
  * Converts this field to a number.
83
69
  * May cause loss of precision if the underlying value is greater than MAX_SAFE_INTEGER.
84
70
  */ toNumberUnsafe() {
85
- const value = this.toBigInt();
86
- return Number(value);
71
+ return Number(this.asBigInt);
87
72
  }
88
73
  toShortString() {
89
74
  const str = this.toString();
90
75
  return `${str.slice(0, 10)}...${str.slice(-4)}`;
91
76
  }
92
77
  equals(rhs) {
93
- return this.toBuffer().equals(rhs.toBuffer());
78
+ return this.asBigInt === rhs.asBigInt;
94
79
  }
95
80
  lt(rhs) {
96
- return this.toBigInt() < rhs.toBigInt();
81
+ return this.asBigInt < rhs.asBigInt;
97
82
  }
98
83
  cmp(rhs) {
99
- const lhsBigInt = this.toBigInt();
100
- const rhsBigInt = rhs.toBigInt();
101
- return lhsBigInt === rhsBigInt ? 0 : lhsBigInt < rhsBigInt ? -1 : 1;
84
+ const rhsBigInt = rhs.asBigInt;
85
+ return this.asBigInt === rhsBigInt ? 0 : this.asBigInt < rhsBigInt ? -1 : 1;
86
+ }
87
+ static cmp(lhs, rhs) {
88
+ return lhs.cmp(rhs);
102
89
  }
103
90
  isZero() {
104
- return this.toBuffer().equals(ZERO_BUFFER);
91
+ return this.asBigInt === 0n;
105
92
  }
106
93
  isEmpty() {
107
94
  return this.isZero();
@@ -141,8 +128,9 @@ const ZERO_BUFFER = Buffer.alloc(32);
141
128
  throw new Error(`Invalid hex-encoded string: "${buf}"`);
142
129
  }
143
130
  const buffer = Buffer.from(checked.length % 2 === 1 ? '0' + checked : checked, 'hex');
144
- return new f(buffer);
131
+ return new f(toBigIntBE(buffer));
145
132
  }
133
+ _computedKey = inspect.custom;
146
134
  /**
147
135
  * Fr field class.
148
136
  * @dev This class is used to represent elements of BN254 scalar field or elements in the base field of Grumpkin.
@@ -155,7 +143,7 @@ const ZERO_BUFFER = Buffer.alloc(32);
155
143
  constructor(value){
156
144
  super(value);
157
145
  }
158
- [inspect.custom]() {
146
+ [_computedKey]() {
159
147
  return `Fr<${this.toString()}>`;
160
148
  }
161
149
  modulus() {
@@ -233,29 +221,41 @@ const ZERO_BUFFER = Buffer.alloc(32);
233
221
  * Computes a square root of the field element.
234
222
  * @returns A square root of the field element (null if it does not exist).
235
223
  */ async sqrt() {
236
- const api = await BarretenbergSync.initSingleton(process.env.BB_WASM_PATH);
237
- const wasm = api.getWasm();
238
- const [buf] = wasm.callWasmExport('bn254_fr_sqrt', [
239
- this.toBuffer()
240
- ], [
241
- Fr.SIZE_IN_BYTES + 1
242
- ]);
243
- const isSqrt = buf[0] === 1;
244
- if (!isSqrt) {
224
+ await BarretenbergSync.initSingleton();
225
+ const api = BarretenbergSync.getSingleton();
226
+ const response = api.bn254FrSqrt({
227
+ input: this.toBuffer()
228
+ });
229
+ if (!response.isSquareRoot) {
245
230
  // Field element is not a quadratic residue mod p so it has no square root.
246
231
  return null;
247
232
  }
248
- return new Fr(Buffer.from(buf.slice(1)));
233
+ return Fr.fromBuffer(Buffer.from(response.value));
249
234
  }
250
235
  toJSON() {
251
236
  return this.toString();
252
237
  }
238
+ /**
239
+ * Creates an Fr instance from a plain object without Zod validation.
240
+ * This method is optimized for performance and skips validation, making it suitable
241
+ * for deserializing trusted data (e.g., from C++ via MessagePack).
242
+ * Handles buffers, strings, numbers, bigints, or existing instances.
243
+ * @param obj - Plain object, buffer, string, number, bigint, boolean, or Fr instance
244
+ * @returns An Fr instance
245
+ */ static fromPlainObject(obj) {
246
+ if (obj instanceof Fr) {
247
+ return obj;
248
+ }
249
+ return new Fr(obj);
250
+ }
253
251
  static get schema() {
252
+ // Serialization from hex string.
254
253
  return hexSchemaFor(Fr);
255
254
  }
256
255
  }
257
256
  // For deserializing JSON.
258
257
  TypeRegistry.register('Fr', Fr);
258
+ _computedKey1 = inspect.custom;
259
259
  /**
260
260
  * Fq field class.
261
261
  * @dev This class is used to represent elements of BN254 base field or elements in the scalar field of Grumpkin.
@@ -265,7 +265,7 @@ TypeRegistry.register('Fr', Fr);
265
265
  static MODULUS = 0x30644e72e131a029b85045b68181585d97816a916871ca8d3c208c16d87cfd47n;
266
266
  static HIGH_SHIFT = BigInt(BaseField.SIZE_IN_BYTES / 2 * 8);
267
267
  static LOW_MASK = (1n << Fq.HIGH_SHIFT) - 1n;
268
- [inspect.custom]() {
268
+ [_computedKey1]() {
269
269
  return `Fq<${this.toString()}>`;
270
270
  }
271
271
  get lo() {
@@ -321,9 +321,33 @@ TypeRegistry.register('Fr', Fr);
321
321
  add(rhs) {
322
322
  return new Fq((this.toBigInt() + rhs.toBigInt()) % Fq.MODULUS);
323
323
  }
324
+ /**
325
+ * Computes a square root of the field element.
326
+ * @returns A square root of the field element (null if it does not exist).
327
+ */ async sqrt() {
328
+ await BarretenbergSync.initSingleton();
329
+ const api = BarretenbergSync.getSingleton();
330
+ const response = api.bn254FqSqrt({
331
+ input: this.toBuffer()
332
+ });
333
+ if (!response.isSquareRoot) {
334
+ // Field element is not a quadratic residue mod p so it has no square root.
335
+ return null;
336
+ }
337
+ return Fq.fromBuffer(Buffer.from(response.value));
338
+ }
324
339
  toJSON() {
325
340
  return this.toString();
326
341
  }
342
+ toFields() {
343
+ // The following has to match the order of the limbs in EmbeddedCurveScalar struct in noir::std. This is because
344
+ // this function is used when returning Scalar from the getAddressSecret oracle and in Noir the values get deserialized
345
+ // using the intrinsic serialization of Noir (which follows the order of the fields/members in the struct).
346
+ return [
347
+ this.lo,
348
+ this.hi
349
+ ];
350
+ }
327
351
  static get schema() {
328
352
  return hexSchemaFor(Fq);
329
353
  }
@@ -360,11 +384,10 @@ TypeRegistry.register('Fq', Fq);
360
384
  ];
361
385
  }
362
386
  }
363
- export const GrumpkinScalar = Fq;
364
387
  /** Wraps a function that returns a buffer so that all results are reduced into a field of the given type. */ export function reduceFn(fn, field) {
365
388
  return (input)=>fromBufferReduce(fn(input), field);
366
389
  }
367
- /** If we are in test mode, we register a special equality for fields. */ if (process.env.NODE_ENV === 'test' && typeof expect !== 'undefined') {
390
+ /** If we are in test mode, we register a special equality for fields. */ if (process.env.NODE_ENV === 'test') {
368
391
  const areFieldsEqual = (a, b)=>{
369
392
  const isAField = a instanceof BaseField;
370
393
  const isBField = b instanceof BaseField;
@@ -376,8 +399,13 @@ export const GrumpkinScalar = Fq;
376
399
  return false;
377
400
  }
378
401
  };
379
- // `addEqualityTesters` doesn't seem to be in the types yet.
380
- expect.addEqualityTesters([
381
- areFieldsEqual
382
- ]);
402
+ if (typeof expect !== 'undefined') {
403
+ // `addEqualityTesters` doesn't seem to be in the types yet.
404
+ expect.addEqualityTesters([
405
+ areFieldsEqual
406
+ ]);
407
+ } else {
408
+ globalThis.__extraEqualityTesters ??= [];
409
+ globalThis.__extraEqualityTesters.push(areFieldsEqual);
410
+ }
383
411
  }
@@ -0,0 +1,3 @@
1
+ export * from './field.js';
2
+ export * from './point.js';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jdXJ2ZXMvYm4yNTQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxZQUFZLENBQUMifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/curves/bn254/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from './field.js';
2
+ export * from './point.js';
@@ -0,0 +1,54 @@
1
+ import { Fq, Fr } from './field.js';
2
+ /**
3
+ * BN254 G1 point using foundation field classes.
4
+ * Represents a point on the BN254 elliptic curve in affine coordinates.
5
+ */
6
+ export declare class Bn254G1Point {
7
+ readonly x: Fq;
8
+ readonly y: Fq;
9
+ constructor(x: Fq, y: Fq);
10
+ private toBbApiPoint;
11
+ private static fromBbApiPoint;
12
+ isOnCurve(): Promise<boolean>;
13
+ /**
14
+ * Get the generator point for BN254 G1, or perform scalar multiplication.
15
+ * When called without arguments, returns the base generator point.
16
+ * When called with a scalar, returns scalar * generator (useful for public key derivation).
17
+ */
18
+ static generator(scalar?: Fr): Promise<Bn254G1Point>;
19
+ /**
20
+ * Decompress a BN254 G1 point from compressed form (32 bytes).
21
+ * The compressed format encodes the x-coordinate and the sign bit of the y-coordinate
22
+ * in the most significant bit.
23
+ */
24
+ static fromCompressed(compressed: Buffer): Promise<Bn254G1Point>;
25
+ /**
26
+ * Compress this BN254 G1 point to 32 bytes.
27
+ * The compressed format encodes the x-coordinate and the sign bit of the y-coordinate
28
+ * in the most significant bit (bit 255).
29
+ */
30
+ compress(): Buffer;
31
+ equals(other: Bn254G1Point): boolean;
32
+ toString(): string;
33
+ }
34
+ /**
35
+ * BN254 G2 point using foundation field classes.
36
+ * Represents a point on the BN254 G2 curve (twist curve) in affine coordinates.
37
+ * G2 points use extension field coordinates (Fq2).
38
+ */
39
+ export declare class Bn254G2Point {
40
+ readonly x: [Fq, Fq];
41
+ readonly y: [Fq, Fq];
42
+ constructor(x: [Fq, Fq], y: [Fq, Fq]);
43
+ private toBbApiPoint;
44
+ private static fromBbApiPoint;
45
+ /**
46
+ * Get the generator point for BN254 G2, or perform scalar multiplication.
47
+ * When called without arguments, returns the base generator point.
48
+ * When called with a scalar, returns scalar * generator.
49
+ */
50
+ static generator(scalar?: Fr): Promise<Bn254G2Point>;
51
+ equals(other: Bn254G2Point): boolean;
52
+ toString(): string;
53
+ }
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9pbnQuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jdXJ2ZXMvYm4yNTQvcG9pbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUUEsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFcEM7OztHQUdHO0FBQ0gscUJBQWEsWUFBWTthQUVMLENBQUMsRUFBRSxFQUFFO2FBQ0wsQ0FBQyxFQUFFLEVBQUU7SUFGdkIsWUFDa0IsQ0FBQyxFQUFFLEVBQUUsRUFDTCxDQUFDLEVBQUUsRUFBRSxFQUNuQjtJQUVKLE9BQU8sQ0FBQyxZQUFZO0lBT3BCLE9BQU8sQ0FBQyxNQUFNLENBQUMsY0FBYztJQUl2QixTQUFTLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQU9sQztJQUVEOzs7O09BSUc7SUFDSCxPQUFhLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQWlCekQ7SUFFRDs7OztPQUlHO0lBQ0gsT0FBYSxjQUFjLENBQUMsVUFBVSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDLENBWXJFO0lBRUQ7Ozs7T0FJRztJQUNILFFBQVEsSUFBSSxNQUFNLENBU2pCO0lBRUQsTUFBTSxDQUFDLEtBQUssRUFBRSxZQUFZLEdBQUcsT0FBTyxDQUVuQztJQUVELFFBQVEsSUFBSSxNQUFNLENBRWpCO0NBQ0Y7QUFFRDs7OztHQUlHO0FBQ0gscUJBQWEsWUFBWTthQUVMLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUM7YUFDWCxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDO0lBRjdCLFlBQ2tCLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFDWCxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQ3pCO0lBRUosT0FBTyxDQUFDLFlBQVk7SUFPcEIsT0FBTyxDQUFDLE1BQU0sQ0FBQyxjQUFjO0lBTzdCOzs7O09BSUc7SUFDSCxPQUFhLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQWlCekQ7SUFFRCxNQUFNLENBQUMsS0FBSyxFQUFFLFlBQVksR0FBRyxPQUFPLENBT25DO0lBRUQsUUFBUSxJQUFJLE1BQU0sQ0FFakI7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"point.d.ts","sourceRoot":"","sources":["../../../src/curves/bn254/point.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,YAAY,CAAC;AAEpC;;;GAGG;AACH,qBAAa,YAAY;aAEL,CAAC,EAAE,EAAE;aACL,CAAC,EAAE,EAAE;IAFvB,YACkB,CAAC,EAAE,EAAE,EACL,CAAC,EAAE,EAAE,EACnB;IAEJ,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,MAAM,CAAC,cAAc;IAIvB,SAAS,IAAI,OAAO,CAAC,OAAO,CAAC,CAOlC;IAED;;;;OAIG;IACH,OAAa,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,OAAO,CAAC,YAAY,CAAC,CAiBzD;IAED;;;;OAIG;IACH,OAAa,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAYrE;IAED;;;;OAIG;IACH,QAAQ,IAAI,MAAM,CASjB;IAED,MAAM,CAAC,KAAK,EAAE,YAAY,GAAG,OAAO,CAEnC;IAED,QAAQ,IAAI,MAAM,CAEjB;CACF;AAED;;;;GAIG;AACH,qBAAa,YAAY;aAEL,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;aACX,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;IAF7B,YACkB,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EACX,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EACzB;IAEJ,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,MAAM,CAAC,cAAc;IAO7B;;;;OAIG;IACH,OAAa,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,OAAO,CAAC,YAAY,CAAC,CAiBzD;IAED,MAAM,CAAC,KAAK,EAAE,YAAY,GAAG,OAAO,CAOnC;IAED,QAAQ,IAAI,MAAM,CAEjB;CACF"}