@aztec/foundation 0.0.1-commit.fce3e4f → 0.0.1-commit.ffe5b04ea

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 (335) hide show
  1. package/dest/array/index.d.ts +2 -1
  2. package/dest/array/index.d.ts.map +1 -1
  3. package/dest/array/index.js +1 -0
  4. package/dest/array/sorted_array.d.ts +15 -0
  5. package/dest/array/sorted_array.d.ts.map +1 -0
  6. package/dest/array/sorted_array.js +109 -0
  7. package/dest/branded-types/block_number.d.ts +56 -0
  8. package/dest/branded-types/block_number.d.ts.map +1 -0
  9. package/dest/branded-types/block_number.js +78 -0
  10. package/dest/branded-types/checkpoint_number.d.ts +54 -0
  11. package/dest/branded-types/checkpoint_number.d.ts.map +1 -0
  12. package/dest/branded-types/checkpoint_number.js +77 -0
  13. package/dest/branded-types/index.d.ts +4 -1
  14. package/dest/branded-types/index.d.ts.map +1 -1
  15. package/dest/branded-types/index.js +3 -0
  16. package/dest/branded-types/index_within_checkpoint.d.ts +42 -0
  17. package/dest/branded-types/index_within_checkpoint.d.ts.map +1 -0
  18. package/dest/branded-types/index_within_checkpoint.js +59 -0
  19. package/dest/buffer/buffer16.d.ts +5 -2
  20. package/dest/buffer/buffer16.d.ts.map +1 -1
  21. package/dest/buffer/buffer16.js +4 -2
  22. package/dest/buffer/buffer32.d.ts +5 -2
  23. package/dest/buffer/buffer32.d.ts.map +1 -1
  24. package/dest/buffer/buffer32.js +4 -2
  25. package/dest/collection/array.d.ts +12 -1
  26. package/dest/collection/array.d.ts.map +1 -1
  27. package/dest/collection/array.js +51 -0
  28. package/dest/config/env_var.d.ts +2 -2
  29. package/dest/config/env_var.d.ts.map +1 -1
  30. package/dest/config/index.d.ts +15 -4
  31. package/dest/config/index.d.ts.map +1 -1
  32. package/dest/config/index.js +47 -9
  33. package/dest/config/network_config.d.ts +25 -1
  34. package/dest/config/network_config.d.ts.map +1 -1
  35. package/dest/config/network_config.js +5 -1
  36. package/dest/config/network_name.d.ts +2 -2
  37. package/dest/config/network_name.d.ts.map +1 -1
  38. package/dest/config/network_name.js +2 -0
  39. package/dest/config/parse-env.d.ts +3 -0
  40. package/dest/config/parse-env.d.ts.map +1 -0
  41. package/dest/config/parse-env.js +7 -0
  42. package/dest/config/secret_value.js +3 -1
  43. package/dest/crypto/bls/bn254_keystore.js +1 -1
  44. package/dest/crypto/bls/index.js +1 -1
  45. package/dest/crypto/bn254/index.d.ts +35 -51
  46. package/dest/crypto/bn254/index.d.ts.map +1 -1
  47. package/dest/crypto/bn254/index.js +51 -140
  48. package/dest/crypto/ecdsa/signature.d.ts +11 -2
  49. package/dest/crypto/ecdsa/signature.d.ts.map +1 -1
  50. package/dest/crypto/ecdsa/signature.js +2 -2
  51. package/dest/crypto/grumpkin/index.d.ts +4 -2
  52. package/dest/crypto/grumpkin/index.d.ts.map +1 -1
  53. package/dest/crypto/grumpkin/index.js +2 -1
  54. package/dest/crypto/keys/index.d.ts +2 -2
  55. package/dest/crypto/keys/index.d.ts.map +1 -1
  56. package/dest/crypto/keys/index.js +1 -1
  57. package/dest/crypto/pedersen/pedersen.wasm.d.ts +2 -2
  58. package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -1
  59. package/dest/crypto/pedersen/pedersen.wasm.js +1 -1
  60. package/dest/crypto/poseidon/index.d.ts +2 -3
  61. package/dest/crypto/poseidon/index.d.ts.map +1 -1
  62. package/dest/crypto/poseidon/index.js +14 -23
  63. package/dest/crypto/random/randomness_singleton.d.ts +4 -3
  64. package/dest/crypto/random/randomness_singleton.d.ts.map +1 -1
  65. package/dest/crypto/random/randomness_singleton.js +5 -5
  66. package/dest/crypto/schnorr/index.d.ts +3 -2
  67. package/dest/crypto/schnorr/index.d.ts.map +1 -1
  68. package/dest/crypto/schnorr/index.js +1 -1
  69. package/dest/crypto/schnorr/signature.d.ts +2 -2
  70. package/dest/crypto/schnorr/signature.d.ts.map +1 -1
  71. package/dest/crypto/schnorr/signature.js +2 -2
  72. package/dest/crypto/secp256k1-signer/utils.d.ts +12 -1
  73. package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -1
  74. package/dest/crypto/secp256k1-signer/utils.js +26 -0
  75. package/dest/crypto/sha256/index.d.ts +2 -2
  76. package/dest/crypto/sha256/index.d.ts.map +1 -1
  77. package/dest/crypto/sha256/index.js +1 -1
  78. package/dest/crypto/sha512/index.d.ts +2 -2
  79. package/dest/crypto/sha512/index.d.ts.map +1 -1
  80. package/dest/crypto/sha512/index.js +1 -1
  81. package/dest/crypto/signature/index.d.ts +2 -2
  82. package/dest/crypto/signature/index.d.ts.map +1 -1
  83. package/dest/crypto/sync/pedersen/index.d.ts +2 -2
  84. package/dest/crypto/sync/pedersen/index.d.ts.map +1 -1
  85. package/dest/crypto/sync/pedersen/index.js +1 -1
  86. package/dest/crypto/sync/poseidon/index.d.ts +2 -3
  87. package/dest/crypto/sync/poseidon/index.d.ts.map +1 -1
  88. package/dest/crypto/sync/poseidon/index.js +1 -9
  89. package/dest/{fields/bls12_fields.d.ts → curves/bls12/field.d.ts} +3 -3
  90. package/dest/curves/bls12/field.d.ts.map +1 -0
  91. package/dest/{fields/bls12_fields.js → curves/bls12/field.js} +12 -9
  92. package/dest/curves/bls12/index.d.ts +3 -0
  93. package/dest/curves/bls12/index.d.ts.map +1 -0
  94. package/dest/curves/bls12/index.js +2 -0
  95. package/dest/{fields/bls12_point.d.ts → curves/bls12/point.d.ts} +13 -4
  96. package/dest/curves/bls12/point.d.ts.map +1 -0
  97. package/dest/{fields/bls12_point.js → curves/bls12/point.js} +10 -8
  98. package/dest/{fields/fields.d.ts → curves/bn254/field.d.ts} +8 -15
  99. package/dest/curves/bn254/field.d.ts.map +1 -0
  100. package/dest/{fields/fields.js → curves/bn254/field.js} +38 -49
  101. package/dest/curves/bn254/index.d.ts +3 -0
  102. package/dest/curves/bn254/index.d.ts.map +1 -0
  103. package/dest/curves/bn254/index.js +2 -0
  104. package/dest/curves/bn254/point.d.ts +54 -0
  105. package/dest/curves/bn254/point.d.ts.map +1 -0
  106. package/dest/curves/bn254/point.js +143 -0
  107. package/dest/curves/grumpkin/index.d.ts +10 -0
  108. package/dest/curves/grumpkin/index.d.ts.map +1 -0
  109. package/dest/curves/grumpkin/index.js +3 -0
  110. package/dest/{fields → curves/grumpkin}/point.d.ts +13 -4
  111. package/dest/curves/grumpkin/point.d.ts.map +1 -0
  112. package/dest/{fields → curves/grumpkin}/point.js +7 -7
  113. package/dest/error/index.d.ts +4 -4
  114. package/dest/error/index.d.ts.map +1 -1
  115. package/dest/eth-address/index.d.ts +3 -2
  116. package/dest/eth-address/index.d.ts.map +1 -1
  117. package/dest/eth-address/index.js +10 -3
  118. package/dest/eth-signature/eth_signature.d.ts +5 -1
  119. package/dest/eth-signature/eth_signature.d.ts.map +1 -1
  120. package/dest/eth-signature/eth_signature.js +7 -2
  121. package/dest/iterator/filter.d.ts +3 -0
  122. package/dest/iterator/filter.d.ts.map +1 -0
  123. package/dest/iterator/filter.js +7 -0
  124. package/dest/iterator/index.d.ts +2 -0
  125. package/dest/iterator/index.d.ts.map +1 -0
  126. package/dest/iterator/index.js +1 -0
  127. package/dest/jest/setup.js +28 -1
  128. package/dest/json-rpc/client/safe_json_rpc_client.d.ts +2 -1
  129. package/dest/json-rpc/client/safe_json_rpc_client.d.ts.map +1 -1
  130. package/dest/json-rpc/client/safe_json_rpc_client.js +1 -1
  131. package/dest/json-rpc/client/undici.d.ts +1 -1
  132. package/dest/json-rpc/client/undici.d.ts.map +1 -1
  133. package/dest/json-rpc/client/undici.js +21 -4
  134. package/dest/json-rpc/fixtures/class_a.d.ts +3 -3
  135. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -1
  136. package/dest/json-rpc/fixtures/class_b.d.ts +3 -3
  137. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -1
  138. package/dest/json-rpc/server/api_key_auth.d.ts +19 -0
  139. package/dest/json-rpc/server/api_key_auth.d.ts.map +1 -0
  140. package/dest/json-rpc/server/api_key_auth.js +57 -0
  141. package/dest/json-rpc/server/index.d.ts +2 -1
  142. package/dest/json-rpc/server/index.d.ts.map +1 -1
  143. package/dest/json-rpc/server/index.js +1 -0
  144. package/dest/json-rpc/server/safe_json_rpc_server.js +1 -1
  145. package/dest/log/bigint-utils.d.ts +5 -0
  146. package/dest/log/bigint-utils.d.ts.map +1 -0
  147. package/dest/log/bigint-utils.js +21 -0
  148. package/dest/log/gcloud-logger-config.d.ts +1 -1
  149. package/dest/log/gcloud-logger-config.d.ts.map +1 -1
  150. package/dest/log/gcloud-logger-config.js +3 -0
  151. package/dest/log/libp2p_logger.d.ts +5 -2
  152. package/dest/log/libp2p_logger.d.ts.map +1 -1
  153. package/dest/log/libp2p_logger.js +14 -4
  154. package/dest/log/log-filters.d.ts +17 -4
  155. package/dest/log/log-filters.d.ts.map +1 -1
  156. package/dest/log/log-filters.js +26 -12
  157. package/dest/log/pino-logger-server.d.ts +9 -0
  158. package/dest/log/pino-logger-server.d.ts.map +1 -0
  159. package/dest/log/pino-logger-server.js +18 -0
  160. package/dest/log/pino-logger.d.ts +37 -8
  161. package/dest/log/pino-logger.d.ts.map +1 -1
  162. package/dest/log/pino-logger.js +122 -29
  163. package/dest/queue/base_memory_queue.d.ts +2 -2
  164. package/dest/queue/base_memory_queue.d.ts.map +1 -1
  165. package/dest/queue/semaphore.d.ts +5 -1
  166. package/dest/queue/semaphore.d.ts.map +1 -1
  167. package/dest/retry/index.d.ts +11 -1
  168. package/dest/retry/index.d.ts.map +1 -1
  169. package/dest/retry/index.js +11 -0
  170. package/dest/schemas/schemas.d.ts +7 -3
  171. package/dest/schemas/schemas.d.ts.map +1 -1
  172. package/dest/schemas/schemas.js +9 -3
  173. package/dest/schemas/types.d.ts +31 -1
  174. package/dest/schemas/types.d.ts.map +1 -1
  175. package/dest/schemas/types.js +25 -1
  176. package/dest/serialize/buffer_reader.d.ts +14 -4
  177. package/dest/serialize/buffer_reader.d.ts.map +1 -1
  178. package/dest/serialize/buffer_reader.js +26 -4
  179. package/dest/serialize/field_reader.d.ts +2 -2
  180. package/dest/serialize/field_reader.d.ts.map +1 -1
  181. package/dest/serialize/field_reader.js +1 -1
  182. package/dest/serialize/free_funcs.d.ts +2 -2
  183. package/dest/serialize/free_funcs.d.ts.map +1 -1
  184. package/dest/serialize/free_funcs.js +1 -1
  185. package/dest/serialize/serialize.d.ts +20 -2
  186. package/dest/serialize/serialize.d.ts.map +1 -1
  187. package/dest/serialize/serialize.js +32 -1
  188. package/dest/sleep/index.d.ts +4 -1
  189. package/dest/sleep/index.d.ts.map +1 -1
  190. package/dest/sleep/index.js +14 -1
  191. package/dest/timer/date.d.ts +26 -1
  192. package/dest/timer/date.d.ts.map +1 -1
  193. package/dest/timer/date.js +36 -0
  194. package/dest/transport/transport_client.js +2 -2
  195. package/dest/trees/balanced_merkle_tree_root.d.ts +17 -0
  196. package/dest/trees/balanced_merkle_tree_root.d.ts.map +1 -0
  197. package/dest/trees/{balanced_merkle_tree.js → balanced_merkle_tree_root.js} +2 -15
  198. package/dest/trees/hasher.d.ts +3 -1
  199. package/dest/trees/hasher.d.ts.map +1 -1
  200. package/dest/trees/hasher.js +10 -5
  201. package/dest/trees/index.d.ts +4 -4
  202. package/dest/trees/index.d.ts.map +1 -1
  203. package/dest/trees/index.js +3 -3
  204. package/dest/trees/indexed_merkle_tree.js +1 -1
  205. package/dest/trees/membership_witness.d.ts +12 -2
  206. package/dest/trees/membership_witness.d.ts.map +1 -1
  207. package/dest/trees/membership_witness.js +10 -1
  208. package/dest/trees/merkle_tree_calculator.d.ts +1 -1
  209. package/dest/trees/merkle_tree_calculator.d.ts.map +1 -1
  210. package/dest/trees/merkle_tree_calculator.js +2 -2
  211. package/dest/trees/sibling_path.d.ts +3 -2
  212. package/dest/trees/sibling_path.d.ts.map +1 -1
  213. package/dest/trees/sibling_path.js +3 -3
  214. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts +2 -3
  215. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts.map +1 -1
  216. package/dest/trees/unbalanced_merkle_tree_calculator.js +1 -5
  217. package/dest/trees/{unbalanced_merkle_tree.d.ts → unbalanced_merkle_tree_root.d.ts} +3 -5
  218. package/dest/trees/unbalanced_merkle_tree_root.d.ts.map +1 -0
  219. package/dest/trees/{unbalanced_merkle_tree.js → unbalanced_merkle_tree_root.js} +11 -49
  220. package/dest/trees/unbalanced_tree_store.d.ts +5 -1
  221. package/dest/trees/unbalanced_tree_store.d.ts.map +1 -1
  222. package/dest/trees/unbalanced_tree_store.js +49 -1
  223. package/dest/types/index.d.ts +6 -2
  224. package/dest/types/index.d.ts.map +1 -1
  225. package/dest/types/index.js +6 -0
  226. package/package.json +48 -9
  227. package/src/array/index.ts +1 -0
  228. package/src/array/sorted_array.ts +138 -0
  229. package/src/branded-types/block_number.ts +117 -0
  230. package/src/branded-types/checkpoint_number.ts +115 -0
  231. package/src/branded-types/index.ts +3 -0
  232. package/src/branded-types/index_within_checkpoint.ts +88 -0
  233. package/src/buffer/buffer16.ts +2 -2
  234. package/src/buffer/buffer32.ts +2 -2
  235. package/src/collection/array.ts +52 -0
  236. package/src/config/env_var.ts +81 -17
  237. package/src/config/index.ts +54 -6
  238. package/src/config/network_config.ts +4 -0
  239. package/src/config/network_name.ts +4 -1
  240. package/src/config/parse-env.ts +4 -0
  241. package/src/crypto/bls/bn254_keystore.ts +1 -1
  242. package/src/crypto/bls/index.ts +1 -1
  243. package/src/crypto/bn254/index.ts +50 -159
  244. package/src/crypto/ecdsa/signature.ts +2 -2
  245. package/src/crypto/grumpkin/index.ts +3 -1
  246. package/src/crypto/keys/index.ts +1 -1
  247. package/src/crypto/pedersen/pedersen.wasm.ts +1 -1
  248. package/src/crypto/poseidon/index.ts +14 -24
  249. package/src/crypto/random/randomness_singleton.ts +6 -4
  250. package/src/crypto/schnorr/index.ts +2 -1
  251. package/src/crypto/schnorr/signature.ts +2 -2
  252. package/src/crypto/secp256k1-signer/utils.ts +32 -0
  253. package/src/crypto/sha256/index.ts +1 -1
  254. package/src/crypto/sha512/index.ts +1 -1
  255. package/src/crypto/signature/index.ts +1 -1
  256. package/src/crypto/sync/pedersen/index.ts +1 -1
  257. package/src/crypto/sync/poseidon/index.ts +1 -10
  258. package/src/{fields/bls12_fields.ts → curves/bls12/field.ts} +6 -6
  259. package/src/curves/bls12/index.ts +2 -0
  260. package/src/{fields/bls12_point.ts → curves/bls12/point.ts} +7 -7
  261. package/src/{fields/fields.ts → curves/bn254/field.ts} +37 -56
  262. package/src/curves/bn254/index.ts +2 -0
  263. package/src/curves/bn254/point.ts +170 -0
  264. package/src/curves/grumpkin/index.ts +11 -0
  265. package/src/{fields → curves/grumpkin}/point.ts +7 -7
  266. package/src/eth-address/index.ts +8 -2
  267. package/src/eth-signature/eth_signature.ts +7 -1
  268. package/src/iterator/filter.ts +11 -0
  269. package/src/iterator/index.ts +1 -0
  270. package/src/jest/setup.mjs +31 -1
  271. package/src/json-rpc/client/safe_json_rpc_client.ts +2 -0
  272. package/src/json-rpc/client/undici.ts +21 -3
  273. package/src/json-rpc/server/api_key_auth.ts +63 -0
  274. package/src/json-rpc/server/index.ts +1 -0
  275. package/src/json-rpc/server/safe_json_rpc_server.ts +1 -1
  276. package/src/log/bigint-utils.ts +25 -0
  277. package/src/log/gcloud-logger-config.ts +5 -0
  278. package/src/log/libp2p_logger.ts +12 -5
  279. package/src/log/log-filters.ts +29 -11
  280. package/src/log/pino-logger-server.ts +25 -0
  281. package/src/log/pino-logger.ts +144 -39
  282. package/src/queue/base_memory_queue.ts +1 -1
  283. package/src/queue/semaphore.ts +5 -0
  284. package/src/retry/index.ts +18 -0
  285. package/src/schemas/schemas.ts +14 -3
  286. package/src/schemas/types.ts +33 -0
  287. package/src/serialize/buffer_reader.ts +36 -9
  288. package/src/serialize/field_reader.ts +1 -1
  289. package/src/serialize/free_funcs.ts +1 -1
  290. package/src/serialize/serialize.ts +33 -1
  291. package/src/sleep/index.ts +16 -1
  292. package/src/timer/date.ts +52 -0
  293. package/src/transport/transport_client.ts +2 -2
  294. package/src/trees/{balanced_merkle_tree.ts → balanced_merkle_tree_root.ts} +2 -16
  295. package/src/trees/hasher.ts +9 -0
  296. package/src/trees/index.ts +3 -3
  297. package/src/trees/indexed_merkle_tree.ts +1 -1
  298. package/src/trees/membership_witness.ts +9 -1
  299. package/src/trees/merkle_tree_calculator.ts +2 -2
  300. package/src/trees/sibling_path.ts +3 -3
  301. package/src/trees/unbalanced_merkle_tree_calculator.ts +1 -12
  302. package/src/trees/{unbalanced_merkle_tree.ts → unbalanced_merkle_tree_root.ts} +17 -61
  303. package/src/trees/unbalanced_tree_store.ts +57 -2
  304. package/src/types/index.ts +11 -1
  305. package/dest/crypto/bn254/bn254_utils.d.ts +0 -39
  306. package/dest/crypto/bn254/bn254_utils.d.ts.map +0 -1
  307. package/dest/crypto/bn254/bn254_utils.js +0 -56
  308. package/dest/crypto/index.d.ts +0 -17
  309. package/dest/crypto/index.d.ts.map +0 -1
  310. package/dest/crypto/index.js +0 -16
  311. package/dest/fields/bls12_fields.d.ts.map +0 -1
  312. package/dest/fields/bls12_point.d.ts.map +0 -1
  313. package/dest/fields/coordinate.d.ts +0 -63
  314. package/dest/fields/coordinate.d.ts.map +0 -1
  315. package/dest/fields/coordinate.js +0 -96
  316. package/dest/fields/fields.d.ts.map +0 -1
  317. package/dest/fields/index.d.ts +0 -6
  318. package/dest/fields/index.d.ts.map +0 -1
  319. package/dest/fields/index.js +0 -5
  320. package/dest/fields/point.d.ts.map +0 -1
  321. package/dest/index.d.ts +0 -31
  322. package/dest/index.d.ts.map +0 -1
  323. package/dest/index.js +0 -31
  324. package/dest/json-rpc/server/telemetry.d.ts +0 -2
  325. package/dest/json-rpc/server/telemetry.d.ts.map +0 -1
  326. package/dest/json-rpc/server/telemetry.js +0 -0
  327. package/dest/trees/balanced_merkle_tree.d.ts +0 -22
  328. package/dest/trees/balanced_merkle_tree.d.ts.map +0 -1
  329. package/dest/trees/unbalanced_merkle_tree.d.ts.map +0 -1
  330. package/src/crypto/bn254/bn254_utils.ts +0 -64
  331. package/src/crypto/index.ts +0 -16
  332. package/src/fields/coordinate.ts +0 -104
  333. package/src/fields/index.ts +0 -5
  334. package/src/index.ts +0 -31
  335. package/src/json-rpc/server/telemetry.ts +0 -0
@@ -1,55 +1,39 @@
1
- import { Fq, Fr } from '../../fields/fields.js';
2
1
  /**
3
- * BN254 G1 point using foundation field classes.
4
- * Represents a point on the BN254 elliptic curve in affine coordinates.
2
+ * BN254 utility functions for point operations.
3
+ * Provides compression, decompression, and public key generation for the BN254 curve.
4
+ * Uses the bb.js Barretenberg backend for point operations.
5
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
6
  /**
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).
7
+ * Generate a compressed BN254 G1 public key from a private key.
8
+ *
9
+ * @param privateKeyHex - Private key as 0x-prefixed hex string
10
+ * @returns Compressed G1 point (32 bytes with sign bit in MSB)
38
11
  */
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
- export { computeBn254G1PublicKeyCompressed, computeBn254G1PublicKey, computeBn254G2PublicKey } from './bn254_utils.js';
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vYm4yNTQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUUEsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUVoRDs7O0dBR0c7QUFDSCxxQkFBYSxZQUFZO2FBRUwsQ0FBQyxFQUFFLEVBQUU7YUFDTCxDQUFDLEVBQUUsRUFBRTtJQUZ2QixZQUNrQixDQUFDLEVBQUUsRUFBRSxFQUNMLENBQUMsRUFBRSxFQUFFLEVBQ25CO0lBRUosT0FBTyxDQUFDLFlBQVk7SUFPcEIsT0FBTyxDQUFDLE1BQU0sQ0FBQyxjQUFjO0lBSXZCLFNBQVMsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLENBT2xDO0lBRUQ7Ozs7T0FJRztJQUNILE9BQWEsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDLENBaUJ6RDtJQUVEOzs7O09BSUc7SUFDSCxPQUFhLGNBQWMsQ0FBQyxVQUFVLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxZQUFZLENBQUMsQ0FZckU7SUFFRDs7OztPQUlHO0lBQ0gsUUFBUSxJQUFJLE1BQU0sQ0FTakI7SUFFRCxNQUFNLENBQUMsS0FBSyxFQUFFLFlBQVksR0FBRyxPQUFPLENBRW5DO0lBRUQsUUFBUSxJQUFJLE1BQU0sQ0FFakI7Q0FDRjtBQUVEOzs7O0dBSUc7QUFDSCxxQkFBYSxZQUFZO2FBRUwsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQzthQUNYLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUM7SUFGN0IsWUFDa0IsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUNYLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFDekI7SUFFSixPQUFPLENBQUMsWUFBWTtJQU9wQixPQUFPLENBQUMsTUFBTSxDQUFDLGNBQWM7SUFPN0I7Ozs7T0FJRztJQUNILE9BQWEsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDLENBaUJ6RDtJQUVELE1BQU0sQ0FBQyxLQUFLLEVBQUUsWUFBWSxHQUFHLE9BQU8sQ0FPbkM7SUFFRCxRQUFRLElBQUksTUFBTSxDQUVqQjtDQUNGO0FBR0QsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLHVCQUF1QixFQUFFLHVCQUF1QixFQUFFLE1BQU0sa0JBQWtCLENBQUMifQ==
12
+ export declare function computeBn254G1PublicKeyCompressed(privateKeyHex: string): Promise<string>;
13
+ /**
14
+ * Generate uncompressed BN254 G1 public key from a private key.
15
+ *
16
+ * @param privateKeyHex - Private key as 0x-prefixed hex string
17
+ * @returns G1 point in affine coordinates
18
+ */
19
+ export declare function computeBn254G1PublicKey(privateKeyHex: string): Promise<{
20
+ x: bigint;
21
+ y: bigint;
22
+ }>;
23
+ /**
24
+ * Generate BN254 G2 public key from a private key.
25
+ *
26
+ * @param privateKeyHex - Private key as 0x-prefixed hex string
27
+ * @returns G2 point in affine coordinates
28
+ */
29
+ export declare function computeBn254G2PublicKey(privateKeyHex: string): Promise<{
30
+ x: {
31
+ c0: bigint;
32
+ c1: bigint;
33
+ };
34
+ y: {
35
+ c0: bigint;
36
+ c1: bigint;
37
+ };
38
+ }>;
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vYm4yNTQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0E7Ozs7R0FJRztBQUVIOzs7OztHQUtHO0FBQ0gsd0JBQXNCLGlDQUFpQyxDQUFDLGFBQWEsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQVU5RjtBQUVEOzs7OztHQUtHO0FBQ0gsd0JBQXNCLHVCQUF1QixDQUFDLGFBQWEsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDO0lBQUUsQ0FBQyxFQUFFLE1BQU0sQ0FBQztJQUFDLENBQUMsRUFBRSxNQUFNLENBQUE7Q0FBRSxDQUFDLENBUXRHO0FBRUQ7Ozs7O0dBS0c7QUFDSCx3QkFBc0IsdUJBQXVCLENBQUMsYUFBYSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUM7SUFDNUUsQ0FBQyxFQUFFO1FBQUUsRUFBRSxFQUFFLE1BQU0sQ0FBQztRQUFDLEVBQUUsRUFBRSxNQUFNLENBQUE7S0FBRSxDQUFDO0lBQzlCLENBQUMsRUFBRTtRQUFFLEVBQUUsRUFBRSxNQUFNLENBQUM7UUFBQyxFQUFFLEVBQUUsTUFBTSxDQUFBO0tBQUUsQ0FBQztDQUMvQixDQUFDLENBV0QifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/bn254/index.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAEhD;;;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;AAGD,OAAO,EAAE,iCAAiC,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/bn254/index.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AAEH;;;;;GAKG;AACH,wBAAsB,iCAAiC,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAU9F;AAED;;;;;GAKG;AACH,wBAAsB,uBAAuB,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC;IAAE,CAAC,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CAQtG;AAED;;;;;GAKG;AACH,wBAAsB,uBAAuB,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC;IAC5E,CAAC,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,MAAM,CAAA;KAAE,CAAC;IAC9B,CAAC,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,MAAM,CAAA;KAAE,CAAC;CAC/B,CAAC,CAWD"}
@@ -1,145 +1,56 @@
1
- import { BN254_G1_GENERATOR, BN254_G2_GENERATOR, BarretenbergSync } from '@aztec/bb.js';
2
- import { Fq } from '../../fields/fields.js';
1
+ import { Fr } from '../../curves/bn254/field.js';
2
+ import { Bn254G1Point, Bn254G2Point } from '../../curves/bn254/point.js';
3
3
  /**
4
- * BN254 G1 point using foundation field classes.
5
- * Represents a point on the BN254 elliptic curve in affine coordinates.
6
- */ export class Bn254G1Point {
7
- x;
8
- y;
9
- constructor(x, y){
10
- this.x = x;
11
- this.y = y;
12
- }
13
- toBbApiPoint() {
14
- return {
15
- x: this.x.toBuffer(),
16
- y: this.y.toBuffer()
17
- };
18
- }
19
- static fromBbApiPoint(point) {
20
- return new Bn254G1Point(Fq.fromBuffer(Buffer.from(point.x)), Fq.fromBuffer(Buffer.from(point.y)));
21
- }
22
- async isOnCurve() {
23
- await BarretenbergSync.initSingleton();
24
- const api = BarretenbergSync.getSingleton();
25
- const apiPoint = this.toBbApiPoint();
26
- const response = api.bn254G1IsOnCurve({
27
- point: apiPoint
28
- });
29
- return response.isOnCurve;
30
- }
31
- /**
32
- * Get the generator point for BN254 G1, or perform scalar multiplication.
33
- * When called without arguments, returns the base generator point.
34
- * When called with a scalar, returns scalar * generator (useful for public key derivation).
35
- */ static async generator(scalar) {
36
- if (!scalar) {
37
- return new Bn254G1Point(Fq.fromBuffer(Buffer.from(BN254_G1_GENERATOR.x)), Fq.fromBuffer(Buffer.from(BN254_G1_GENERATOR.y)));
38
- }
39
- await BarretenbergSync.initSingleton();
40
- const api = BarretenbergSync.getSingleton();
41
- const response = api.bn254G1Mul({
42
- point: BN254_G1_GENERATOR,
43
- scalar: scalar.toBuffer()
44
- });
45
- return Bn254G1Point.fromBbApiPoint(response.point);
46
- }
47
- /**
48
- * Decompress a BN254 G1 point from compressed form (32 bytes).
49
- * The compressed format encodes the x-coordinate and the sign bit of the y-coordinate
50
- * in the most significant bit.
51
- */ static async fromCompressed(compressed) {
52
- if (compressed.length !== 32) {
53
- throw new Error('Invalid compressed point length');
54
- }
55
- await BarretenbergSync.initSingleton();
56
- const api = BarretenbergSync.getSingleton();
57
- const response = api.bn254G1FromCompressed({
58
- compressed: new Uint8Array(compressed)
59
- });
60
- return Bn254G1Point.fromBbApiPoint(response.point);
61
- }
62
- /**
63
- * Compress this BN254 G1 point to 32 bytes.
64
- * The compressed format encodes the x-coordinate and the sign bit of the y-coordinate
65
- * in the most significant bit (bit 255).
66
- */ compress() {
67
- const xBytes = this.x.toBuffer();
68
- // Get the least significant bit of y to determine the sign
69
- const yLsb = this.y.toBigInt() & 1n;
70
- // If y is odd, set the most significant bit (bit 255) of the output
71
- if (yLsb === 1n) {
72
- xBytes[0] |= 0x80;
73
- }
74
- return xBytes;
75
- }
76
- equals(other) {
77
- return this.x.equals(other.x) && this.y.equals(other.y);
78
- }
79
- toString() {
80
- return `Bn254G1Point(x: ${this.x.toString()}, y: ${this.y.toString()})`;
81
- }
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
+ };
82
35
  }
83
36
  /**
84
- * BN254 G2 point using foundation field classes.
85
- * Represents a point on the BN254 G2 curve (twist curve) in affine coordinates.
86
- * G2 points use extension field coordinates (Fq2).
87
- */ export class Bn254G2Point {
88
- x;
89
- y;
90
- constructor(x, y){
91
- this.x = x;
92
- this.y = y;
93
- }
94
- toBbApiPoint() {
95
- return {
96
- x: [
97
- this.x[0].toBuffer(),
98
- this.x[1].toBuffer()
99
- ],
100
- y: [
101
- this.y[0].toBuffer(),
102
- this.y[1].toBuffer()
103
- ]
104
- };
105
- }
106
- static fromBbApiPoint(point) {
107
- return new Bn254G2Point([
108
- Fq.fromBuffer(Buffer.from(point.x[0])),
109
- Fq.fromBuffer(Buffer.from(point.x[1]))
110
- ], [
111
- Fq.fromBuffer(Buffer.from(point.y[0])),
112
- Fq.fromBuffer(Buffer.from(point.y[1]))
113
- ]);
114
- }
115
- /**
116
- * Get the generator point for BN254 G2, or perform scalar multiplication.
117
- * When called without arguments, returns the base generator point.
118
- * When called with a scalar, returns scalar * generator.
119
- */ static async generator(scalar) {
120
- if (!scalar) {
121
- return new Bn254G2Point([
122
- Fq.fromBuffer(Buffer.from(BN254_G2_GENERATOR.x[0])),
123
- Fq.fromBuffer(Buffer.from(BN254_G2_GENERATOR.x[1]))
124
- ], [
125
- Fq.fromBuffer(Buffer.from(BN254_G2_GENERATOR.y[0])),
126
- Fq.fromBuffer(Buffer.from(BN254_G2_GENERATOR.y[1]))
127
- ]);
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()
128
54
  }
129
- await BarretenbergSync.initSingleton();
130
- const api = BarretenbergSync.getSingleton();
131
- const response = api.bn254G2Mul({
132
- point: BN254_G2_GENERATOR,
133
- scalar: scalar.toBuffer()
134
- });
135
- return Bn254G2Point.fromBbApiPoint(response.point);
136
- }
137
- equals(other) {
138
- return this.x[0].equals(other.x[0]) && this.x[1].equals(other.x[1]) && this.y[0].equals(other.y[0]) && this.y[1].equals(other.y[1]);
139
- }
140
- toString() {
141
- return `Bn254G2Point(x: (${this.x[0].toString()}, ${this.x[1].toString()}), y: (${this.y[0].toString()}, ${this.y[1].toString()}))`;
142
- }
55
+ };
143
56
  }
144
- // Re-export BN254 point utility functions
145
- export { computeBn254G1PublicKeyCompressed, computeBn254G1PublicKey, computeBn254G2PublicKey } from './bn254_utils.js';
@@ -1,12 +1,21 @@
1
- import { Fr } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import type { Signature } from '../signature/index.js';
3
3
  /**
4
4
  * ECDSA signature used for transactions.
5
5
  * @see cpp/barretenberg/cpp/src/barretenberg/crypto/ecdsa/ecdsa.hpp
6
6
  */
7
7
  export declare class EcdsaSignature implements Signature {
8
+ /**
9
+ * The r byte-array (32 bytes) in an ECDSA signature.
10
+ */
8
11
  r: Buffer;
12
+ /**
13
+ * The s byte-array (32 bytes) in an ECDSA signature.
14
+ */
9
15
  s: Buffer;
16
+ /**
17
+ * The recovery id (1 byte) in an ECDSA signature.
18
+ */
10
19
  v: Buffer;
11
20
  constructor(
12
21
  /**
@@ -57,4 +66,4 @@ export declare class EcdsaSignature implements Signature {
57
66
  */
58
67
  toFields(includeV?: boolean): Fr[];
59
68
  }
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmF0dXJlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3J5cHRvL2VjZHNhL3NpZ25hdHVyZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFHOUMsT0FBTyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFdkQ7OztHQUdHO0FBQ0gscUJBQWEsY0FBZSxZQUFXLFNBQVM7SUFLckMsQ0FBQyxFQUFFLE1BQU07SUFJVCxDQUFDLEVBQUUsTUFBTTtJQUlULENBQUMsRUFBRSxNQUFNO0lBWmxCO0lBQ0U7O09BRUc7SUFDSSxDQUFDLEVBQUUsTUFBTTtJQUNoQjs7T0FFRztJQUNJLENBQUMsRUFBRSxNQUFNO0lBQ2hCOztPQUVHO0lBQ0ksQ0FBQyxFQUFFLE1BQU0sRUFXakI7SUFFRDs7O09BR0c7SUFDSCxRQUFRLHdCQUVQO0lBRUQ7Ozs7T0FJRztJQUNILE9BQWMsVUFBVSxDQUFDLE1BQU0sRUFBRSxNQUFNLGtCQUV0QztJQUVEOzs7Ozs7T0FNRztJQUNILE9BQWMsV0FBVyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsTUFBTSxrQkFFeEQ7SUFFRDs7O09BR0c7SUFDSCxPQUFjLE1BQU0sbUJBRW5CO0lBRUQ7OztPQUdHO0lBQ0gsUUFBUSxXQUVQO0lBRUQ7Ozs7T0FJRztJQUNILFFBQVEsQ0FBQyxRQUFRLFVBQVEsR0FBRyxFQUFFLEVBQUUsQ0FZL0I7Q0FDRiJ9
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;IAKrC,CAAC,EAAE,MAAM;IAIT,CAAC,EAAE,MAAM;IAIT,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
+ {"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,4 +1,6 @@
1
- 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';
2
4
  /**
3
5
  * Grumpkin elliptic curve operations.
4
6
  */
@@ -37,4 +39,4 @@ export declare class Grumpkin {
37
39
  */
38
40
  static reduce512BufferToFr(uint512Buf: Buffer): Promise<Fr>;
39
41
  }
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vZ3J1bXBraW4vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEVBQUUsRUFBRSxLQUFLLGNBQWMsRUFBRSxLQUFLLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUUxRTs7R0FFRztBQUNILHFCQUFhLFFBQVE7SUFFbkIsTUFBTSxDQUFDLFFBQVEsQ0FBQyxTQUFTLFFBS3JCO0lBRUo7Ozs7O09BS0c7SUFDSCxPQUFvQixHQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsY0FBYyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FRNUU7SUFFRDs7Ozs7T0FLRztJQUNILE9BQW9CLEdBQUcsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxLQUFLLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQVExRDtJQUVEOzs7OztPQUtHO0lBQ0gsT0FBb0IsUUFBUSxDQUFDLE1BQU0sRUFBRSxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsY0FBYyxvQkFTbkU7SUFFRDs7O09BR0c7SUFDSCxPQUFvQixXQUFXLElBQUksT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUs3QztJQUVEOzs7O09BSUc7SUFDSCxPQUFvQixtQkFBbUIsQ0FBQyxVQUFVLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FLdkU7Q0FDRiJ9
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,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
+ {"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 {
@@ -1,3 +1,3 @@
1
- import { Fr } from '../../fields/fields.js';
1
+ import { Fr } from '../../curves/bn254/field.js';
2
2
  export declare function vkAsFieldsMegaHonk(input: Buffer): Promise<Fr[]>;
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8va2V5cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFNUMsd0JBQXNCLGtCQUFrQixDQUFDLEtBQUssRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBS3JFIn0=
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,5 +1,5 @@
1
1
  import { BarretenbergSync } from '@aztec/bb.js';
2
- import { Fr } from '../../fields/fields.js';
2
+ import { Fr } from '../../curves/bn254/field.js';
3
3
  export async function vkAsFieldsMegaHonk(input) {
4
4
  await BarretenbergSync.initSingleton();
5
5
  const api = BarretenbergSync.getSingleton();
@@ -1,4 +1,4 @@
1
- import { Fr } from '../../fields/fields.js';
1
+ import { Fr } from '../../curves/bn254/field.js';
2
2
  import { type Fieldable } from '../../serialize/serialize.js';
3
3
  /**
4
4
  * Create a pedersen commitment (point) from an array of input fields.
@@ -16,4 +16,4 @@ export declare function pedersenHash(input: Fieldable[], index?: number): Promis
16
16
  * Create a pedersen hash from an arbitrary length buffer.
17
17
  */
18
18
  export declare function pedersenHashBuffer(input: Buffer, index?: number): Promise<Buffer<ArrayBuffer>>;
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVkZXJzZW4ud2FzbS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NyeXB0by9wZWRlcnNlbi9wZWRlcnNlbi53YXNtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1QyxPQUFPLEVBQUUsS0FBSyxTQUFTLEVBQXFCLE1BQU0sOEJBQThCLENBQUM7QUFFakY7OztHQUdHO0FBQ0gsd0JBQXNCLGNBQWMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLEVBQUUsTUFBTSxTQUFJLGtDQVkvRDtBQUVEOzs7OztHQUtHO0FBQ0gsd0JBQXNCLFlBQVksQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLEVBQUUsS0FBSyxTQUFJLEdBQUcsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQVM3RTtBQUVEOztHQUVHO0FBQ0gsd0JBQXNCLGtCQUFrQixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxTQUFJLGdDQVFoRSJ9
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,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"}
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"}
@@ -1,5 +1,5 @@
1
1
  import { BarretenbergSync } from '@aztec/bb.js';
2
- import { Fr } from '../../fields/fields.js';
2
+ import { Fr } from '../../curves/bn254/field.js';
3
3
  import { serializeToFields } from '../../serialize/serialize.js';
4
4
  /**
5
5
  * Create a pedersen commitment (point) from an array of input fields.
@@ -1,4 +1,4 @@
1
- import { Fr } from '../../fields/fields.js';
1
+ import { Fr } from '../../curves/bn254/field.js';
2
2
  import { type Fieldable } from '../../serialize/serialize.js';
3
3
  /**
4
4
  * Create a poseidon hash (field) from an array of input fields.
@@ -13,7 +13,6 @@ export declare function poseidon2Hash(input: Fieldable[]): Promise<Fr>;
13
13
  * @returns The poseidon hash.
14
14
  */
15
15
  export declare function poseidon2HashWithSeparator(input: Fieldable[], separator: number): Promise<Fr>;
16
- export declare function poseidon2HashAccumulate(input: Fieldable[]): Promise<Fr>;
17
16
  /**
18
17
  * Runs a Poseidon2 permutation.
19
18
  * @param input the input state. Expected to be of size 4.
@@ -21,4 +20,4 @@ export declare function poseidon2HashAccumulate(input: Fieldable[]): Promise<Fr>
21
20
  */
22
21
  export declare function poseidon2Permutation(input: Fieldable[]): Promise<Fr[]>;
23
22
  export declare function poseidon2HashBytes(input: Buffer): Promise<Fr>;
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vcG9zZWlkb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVDLE9BQU8sRUFBRSxLQUFLLFNBQVMsRUFBcUIsTUFBTSw4QkFBOEIsQ0FBQztBQUVqRjs7OztHQUlHO0FBQ0gsd0JBQXNCLGFBQWEsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLEdBQUcsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQVFuRTtBQUVEOzs7OztHQUtHO0FBQ0gsd0JBQXNCLDBCQUEwQixDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsRUFBRSxTQUFTLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FTbkc7QUFFRCx3QkFBc0IsdUJBQXVCLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxHQUFHLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FRN0U7QUFFRDs7OztHQUlHO0FBQ0gsd0JBQXNCLG9CQUFvQixDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsR0FBRyxPQUFPLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FZNUU7QUFFRCx3QkFBc0Isa0JBQWtCLENBQUMsS0FBSyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsRUFBRSxDQUFDLENBa0JuRSJ9
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vcG9zZWlkb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2pELE9BQU8sRUFBRSxLQUFLLFNBQVMsRUFBcUIsTUFBTSw4QkFBOEIsQ0FBQztBQUVqRjs7OztHQUlHO0FBQ0gsd0JBQXNCLGFBQWEsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLEdBQUcsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQVFuRTtBQUVEOzs7OztHQUtHO0FBQ0gsd0JBQXNCLDBCQUEwQixDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsRUFBRSxTQUFTLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FTbkc7QUFFRDs7OztHQUlHO0FBQ0gsd0JBQXNCLG9CQUFvQixDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsR0FBRyxPQUFPLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FZNUU7QUFFRCx3QkFBc0Isa0JBQWtCLENBQUMsS0FBSyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsRUFBRSxDQUFDLENBa0JuRSJ9
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/poseidon/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAC5C,OAAO,EAAE,KAAK,SAAS,EAAqB,MAAM,8BAA8B,CAAC;AAEjF;;;;GAIG;AACH,wBAAsB,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC,CAQnE;AAED;;;;;GAKG;AACH,wBAAsB,0BAA0B,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,CAAC,CASnG;AAED,wBAAsB,uBAAuB,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC,CAQ7E;AAED;;;;GAIG;AACH,wBAAsB,oBAAoB,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,EAAE,EAAE,CAAC,CAY5E;AAED,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,CAAC,CAkBnE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/poseidon/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,6BAA6B,CAAC;AACjD,OAAO,EAAE,KAAK,SAAS,EAAqB,MAAM,8BAA8B,CAAC;AAEjF;;;;GAIG;AACH,wBAAsB,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC,CAQnE;AAED;;;;;GAKG;AACH,wBAAsB,0BAA0B,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,CAAC,CASnG;AAED;;;;GAIG;AACH,wBAAsB,oBAAoB,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,EAAE,EAAE,CAAC,CAY5E;AAED,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,CAAC,CAkBnE"}
@@ -1,5 +1,5 @@
1
- import { BarretenbergSync } from '@aztec/bb.js';
2
- import { Fr } from '../../fields/fields.js';
1
+ import { Barretenberg } from '@aztec/bb.js';
2
+ import { Fr } from '../../curves/bn254/field.js';
3
3
  import { serializeToFields } from '../../serialize/serialize.js';
4
4
  /**
5
5
  * Create a poseidon hash (field) from an array of input fields.
@@ -7,9 +7,9 @@ import { serializeToFields } from '../../serialize/serialize.js';
7
7
  * @returns The poseidon hash.
8
8
  */ export async function poseidon2Hash(input) {
9
9
  const inputFields = serializeToFields(input);
10
- await BarretenbergSync.initSingleton();
11
- const api = BarretenbergSync.getSingleton();
12
- const response = api.poseidon2Hash({
10
+ await Barretenberg.initSingleton();
11
+ const api = Barretenberg.getSingleton();
12
+ const response = await api.poseidon2Hash({
13
13
  inputs: inputFields.map((i)=>i.toBuffer())
14
14
  });
15
15
  return Fr.fromBuffer(Buffer.from(response.hash));
@@ -22,18 +22,9 @@ import { serializeToFields } from '../../serialize/serialize.js';
22
22
  */ export async function poseidon2HashWithSeparator(input, separator) {
23
23
  const inputFields = serializeToFields(input);
24
24
  inputFields.unshift(new Fr(separator));
25
- await BarretenbergSync.initSingleton();
26
- const api = BarretenbergSync.getSingleton();
27
- const response = api.poseidon2Hash({
28
- inputs: inputFields.map((i)=>i.toBuffer())
29
- });
30
- return Fr.fromBuffer(Buffer.from(response.hash));
31
- }
32
- export async function poseidon2HashAccumulate(input) {
33
- const inputFields = serializeToFields(input);
34
- await BarretenbergSync.initSingleton();
35
- const api = BarretenbergSync.getSingleton();
36
- const response = api.poseidon2HashAccumulate({
25
+ await Barretenberg.initSingleton();
26
+ const api = Barretenberg.getSingleton();
27
+ const response = await api.poseidon2Hash({
37
28
  inputs: inputFields.map((i)=>i.toBuffer())
38
29
  });
39
30
  return Fr.fromBuffer(Buffer.from(response.hash));
@@ -46,9 +37,9 @@ export async function poseidon2HashAccumulate(input) {
46
37
  const inputFields = serializeToFields(input);
47
38
  // We'd like this assertion but it's not possible to use it in the browser.
48
39
  // assert(input.length === 4, 'Input state must be of size 4');
49
- await BarretenbergSync.initSingleton();
50
- const api = BarretenbergSync.getSingleton();
51
- const response = api.poseidon2Permutation({
40
+ await Barretenberg.initSingleton();
41
+ const api = Barretenberg.getSingleton();
42
+ const response = await api.poseidon2Permutation({
52
43
  inputs: inputFields.map((i)=>i.toBuffer())
53
44
  });
54
45
  // We'd like this assertion but it's not possible to use it in the browser.
@@ -64,9 +55,9 @@ export async function poseidon2HashBytes(input) {
64
55
  fieldBytes.reverse();
65
56
  inputFields.push(Fr.fromBuffer(fieldBytes));
66
57
  }
67
- await BarretenbergSync.initSingleton();
68
- const api = BarretenbergSync.getSingleton();
69
- const response = api.poseidon2Hash({
58
+ await Barretenberg.initSingleton();
59
+ const api = Barretenberg.getSingleton();
60
+ const response = await api.poseidon2Hash({
70
61
  inputs: inputFields.map((i)=>i.toBuffer())
71
62
  });
72
63
  return Fr.fromBuffer(Buffer.from(response.hash));
@@ -1,3 +1,4 @@
1
+ import { type LoggerBindings } from '../../log/pino-logger.js';
1
2
  /**
2
3
  * A number generator which is used as a source of randomness in the system. If the SEED env variable is set, the
3
4
  * generator will be deterministic and will always produce the same sequence of numbers. Otherwise a true randomness
@@ -8,11 +9,11 @@
8
9
  */
9
10
  export declare class RandomnessSingleton {
10
11
  private readonly seed?;
11
- private readonly log;
12
12
  private static instance;
13
13
  private counter;
14
+ private log;
14
15
  private constructor();
15
- static getInstance(): RandomnessSingleton;
16
+ static getInstance(bindings?: LoggerBindings): RandomnessSingleton;
16
17
  /**
17
18
  * Indicates whether the generator is deterministic (was seeded) or not.
18
19
  * @returns Whether the generator is deterministic.
@@ -20,4 +21,4 @@ export declare class RandomnessSingleton {
20
21
  isDeterministic(): boolean;
21
22
  getBytes(length: number): Buffer;
22
23
  }
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZG9tbmVzc19zaW5nbGV0b24uZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vcmFuZG9tL3JhbmRvbW5lc3Nfc2luZ2xldG9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBOzs7Ozs7O0dBT0c7QUFDSCxxQkFBYSxtQkFBbUI7SUFNNUIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7SUFDdEIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHO0lBTnRCLE9BQU8sQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFzQjtJQUU3QyxPQUFPLENBQUMsT0FBTyxDQUFLO0lBRXBCLE9BQU8sZUFVTjtJQUVELE9BQWMsV0FBVyxJQUFJLG1CQUFtQixDQU8vQztJQUVEOzs7T0FHRztJQUNJLGVBQWUsSUFBSSxPQUFPLENBRWhDO0lBRU0sUUFBUSxDQUFDLE1BQU0sRUFBRSxNQUFNLEdBQUcsTUFBTSxDQWdCdEM7Q0FDRiJ9
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZG9tbmVzc19zaW5nbGV0b24uZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vcmFuZG9tL3JhbmRvbW5lc3Nfc2luZ2xldG9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBZSxLQUFLLGNBQWMsRUFBZ0IsTUFBTSwwQkFBMEIsQ0FBQztBQUUxRjs7Ozs7OztHQU9HO0FBQ0gscUJBQWEsbUJBQW1CO0lBTzVCLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO0lBTnhCLE9BQU8sQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFzQjtJQUU3QyxPQUFPLENBQUMsT0FBTyxDQUFLO0lBQ3BCLE9BQU8sQ0FBQyxHQUFHLENBQVM7SUFFcEIsT0FBTyxlQVdOO0lBRUQsT0FBYyxXQUFXLENBQUMsUUFBUSxDQUFDLEVBQUUsY0FBYyxHQUFHLG1CQUFtQixDQU94RTtJQUVEOzs7T0FHRztJQUNJLGVBQWUsSUFBSSxPQUFPLENBRWhDO0lBRU0sUUFBUSxDQUFDLE1BQU0sRUFBRSxNQUFNLEdBQUcsTUFBTSxDQWdCdEM7Q0FDRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"randomness_singleton.d.ts","sourceRoot":"","sources":["../../../src/crypto/random/randomness_singleton.ts"],"names":[],"mappings":"AAEA;;;;;;;GAOG;AACH,qBAAa,mBAAmB;IAM5B,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;IACtB,OAAO,CAAC,QAAQ,CAAC,GAAG;IANtB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAsB;IAE7C,OAAO,CAAC,OAAO,CAAK;IAEpB,OAAO,eAUN;IAED,OAAc,WAAW,IAAI,mBAAmB,CAO/C;IAED;;;OAGG;IACI,eAAe,IAAI,OAAO,CAEhC;IAEM,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAgBtC;CACF"}
1
+ {"version":3,"file":"randomness_singleton.d.ts","sourceRoot":"","sources":["../../../src/crypto/random/randomness_singleton.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,KAAK,cAAc,EAAgB,MAAM,0BAA0B,CAAC;AAE1F;;;;;;;GAOG;AACH,qBAAa,mBAAmB;IAO5B,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;IANxB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAsB;IAE7C,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,GAAG,CAAS;IAEpB,OAAO,eAWN;IAED,OAAc,WAAW,CAAC,QAAQ,CAAC,EAAE,cAAc,GAAG,mBAAmB,CAOxE;IAED;;;OAGG;IACI,eAAe,IAAI,OAAO,CAEhC;IAEM,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAgBtC;CACF"}
@@ -8,13 +8,13 @@ import { createLogger } from '../../log/pino-logger.js';
8
8
  * TODO(#3949): This is not safe enough for production and should be made safer or removed before mainnet.
9
9
  */ export class RandomnessSingleton {
10
10
  seed;
11
- log;
12
11
  static instance;
13
12
  counter;
14
- constructor(seed, log = createLogger('foundation:randomness_singleton')){
13
+ log;
14
+ constructor(seed, bindings){
15
15
  this.seed = seed;
16
- this.log = log;
17
16
  this.counter = 0;
17
+ this.log = createLogger('foundation:randomness_singleton', bindings);
18
18
  if (seed !== undefined) {
19
19
  this.log.debug(`Using pseudo-randomness with seed: ${seed}`);
20
20
  this.counter = seed;
@@ -22,10 +22,10 @@ import { createLogger } from '../../log/pino-logger.js';
22
22
  this.log.debug('Using true randomness');
23
23
  }
24
24
  }
25
- static getInstance() {
25
+ static getInstance(bindings) {
26
26
  if (!RandomnessSingleton.instance) {
27
27
  const seed = process.env.SEED ? Number(process.env.SEED) : undefined;
28
- RandomnessSingleton.instance = new RandomnessSingleton(seed);
28
+ RandomnessSingleton.instance = new RandomnessSingleton(seed, bindings);
29
29
  }
30
30
  return RandomnessSingleton.instance;
31
31
  }
@@ -1,4 +1,5 @@
1
- import { type GrumpkinScalar, Point } from '@aztec/foundation/fields';
1
+ import type { GrumpkinScalar } from '@aztec/foundation/curves/grumpkin';
2
+ import { Point } from '@aztec/foundation/curves/grumpkin';
2
3
  import { SchnorrSignature } from './signature.js';
3
4
  export * from './signature.js';
4
5
  /**
@@ -27,4 +28,4 @@ export declare class Schnorr {
27
28
  */
28
29
  verifySignature(msg: Uint8Array, pubKey: Point, sig: SchnorrSignature): Promise<boolean>;
29
30
  }
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vc2Nobm9yci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsS0FBSyxjQUFjLEVBQUUsS0FBSyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbEQsY0FBYyxnQkFBZ0IsQ0FBQztBQUUvQjs7R0FFRztBQUNILHFCQUFhLE9BQU87SUFDbEI7Ozs7T0FJRztJQUNVLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxjQUFjLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUt4RTtJQUVEOzs7OztPQUtHO0lBQ1Usa0JBQWtCLENBQUMsR0FBRyxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsY0FBYyw2QkFRMUU7SUFFRDs7Ozs7O09BTUc7SUFDVSxlQUFlLENBQUMsR0FBRyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxnQkFBZ0Isb0JBVWpGO0NBQ0YifQ==
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jcnlwdG8vc2Nobm9yci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFFMUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbEQsY0FBYyxnQkFBZ0IsQ0FBQztBQUUvQjs7R0FFRztBQUNILHFCQUFhLE9BQU87SUFDbEI7Ozs7T0FJRztJQUNVLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxjQUFjLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUt4RTtJQUVEOzs7OztPQUtHO0lBQ1Usa0JBQWtCLENBQUMsR0FBRyxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsY0FBYyw2QkFRMUU7SUFFRDs7Ozs7O09BTUc7SUFDVSxlQUFlLENBQUMsR0FBRyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxnQkFBZ0Isb0JBVWpGO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/schnorr/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAC;AAEtE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,cAAc,gBAAgB,CAAC;AAE/B;;GAEG;AACH,qBAAa,OAAO;IAClB;;;;OAIG;IACU,gBAAgB,CAAC,UAAU,EAAE,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,CAKxE;IAED;;;;;OAKG;IACU,kBAAkB,CAAC,GAAG,EAAE,UAAU,EAAE,UAAU,EAAE,cAAc,6BAQ1E;IAED;;;;;;OAMG;IACU,eAAe,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,gBAAgB,oBAUjF;CACF"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/schnorr/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,KAAK,EAAE,MAAM,mCAAmC,CAAC;AAE1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,cAAc,gBAAgB,CAAC;AAE/B;;GAEG;AACH,qBAAa,OAAO;IAClB;;;;OAIG;IACU,gBAAgB,CAAC,UAAU,EAAE,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,CAKxE;IAED;;;;;OAKG;IACU,kBAAkB,CAAC,GAAG,EAAE,UAAU,EAAE,UAAU,EAAE,cAAc,6BAQ1E;IAED;;;;;;OAMG;IACU,eAAe,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,gBAAgB,oBAUjF;CACF"}