@aztec/bb.js 3.0.0-canary.a9708bd → 3.0.0-devnet.2-patch.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (723) hide show
  1. package/README.md +13 -79
  2. package/build/amd64-linux/bb +0 -0
  3. package/build/amd64-linux/nodejs_module.node +0 -0
  4. package/build/amd64-macos/bb +0 -0
  5. package/build/amd64-macos/nodejs_module.node +0 -0
  6. package/build/arm64-linux/bb +0 -0
  7. package/build/arm64-linux/nodejs_module.node +0 -0
  8. package/build/arm64-macos/bb +0 -0
  9. package/build/arm64-macos/nodejs_module.node +0 -0
  10. package/dest/browser/async_map/index.d.ts +1 -1
  11. package/dest/browser/async_map/index.js +1 -1
  12. package/dest/browser/barretenberg/backend.d.ts +32 -41
  13. package/dest/browser/barretenberg/backend.d.ts.map +1 -1
  14. package/dest/browser/barretenberg/backend.js +128 -108
  15. package/dest/browser/barretenberg/index.d.ts +47 -48
  16. package/dest/browser/barretenberg/index.d.ts.map +1 -1
  17. package/dest/browser/barretenberg/index.js +132 -90
  18. package/dest/browser/barretenberg/testing/bigint-buffer.d.ts +17 -0
  19. package/dest/browser/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  20. package/dest/browser/barretenberg/testing/bigint-buffer.js +37 -0
  21. package/dest/browser/barretenberg/testing/fields.d.ts +16 -0
  22. package/dest/browser/barretenberg/testing/fields.d.ts.map +1 -0
  23. package/dest/browser/barretenberg/testing/fields.js +47 -0
  24. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +2 -2
  25. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
  26. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.js +6 -7
  27. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +1 -1
  28. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -1
  29. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +1 -3
  30. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +1 -1
  31. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +1 -7
  32. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +5 -5
  33. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -1
  34. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +20 -11
  35. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +16 -7
  36. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
  37. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.js +94 -26
  38. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +1 -1
  39. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -1
  40. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +1 -3
  41. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +1 -1
  42. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +1 -7
  43. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +9 -8
  44. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
  45. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.js +4 -3
  46. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +1 -1
  47. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +1 -1
  48. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +1 -1
  49. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.js +1 -1
  50. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts +1 -1
  51. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.js +1 -1
  52. package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts +1 -1
  53. package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts +2 -2
  54. package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -1
  55. package/dest/browser/barretenberg_wasm/helpers/browser/index.js +9 -2
  56. package/dest/browser/barretenberg_wasm/helpers/index.d.ts +1 -1
  57. package/dest/browser/barretenberg_wasm/index.d.ts +1 -1
  58. package/dest/browser/barretenberg_wasm/index.d.ts.map +1 -1
  59. package/dest/browser/barretenberg_wasm/index.js +2 -3
  60. package/dest/browser/bb_backends/browser/index.d.ts +11 -0
  61. package/dest/browser/bb_backends/browser/index.d.ts.map +1 -0
  62. package/dest/browser/bb_backends/browser/index.js +39 -0
  63. package/dest/browser/bb_backends/browser/platform.d.ts +4 -0
  64. package/dest/browser/bb_backends/browser/platform.d.ts.map +1 -0
  65. package/dest/browser/bb_backends/browser/platform.js +10 -0
  66. package/dest/browser/bb_backends/index.d.ts +50 -0
  67. package/dest/browser/bb_backends/index.d.ts.map +1 -0
  68. package/dest/browser/bb_backends/index.js +16 -0
  69. package/dest/browser/bb_backends/interface.d.ts +33 -0
  70. package/dest/browser/bb_backends/interface.d.ts.map +1 -0
  71. package/dest/browser/bb_backends/interface.js +2 -0
  72. package/dest/browser/bb_backends/wasm.d.ts +49 -0
  73. package/dest/browser/bb_backends/wasm.d.ts.map +1 -0
  74. package/dest/browser/bb_backends/wasm.js +85 -0
  75. package/dest/browser/bbapi_exception.d.ts +7 -0
  76. package/dest/browser/bbapi_exception.d.ts.map +1 -0
  77. package/dest/browser/bbapi_exception.js +14 -0
  78. package/dest/browser/bin/index.d.ts +3 -0
  79. package/dest/{node/bindgen → browser/bin}/index.d.ts.map +1 -1
  80. package/dest/browser/bin/index.js +11 -0
  81. package/dest/browser/cbind/generate.d.ts +1 -1
  82. package/dest/browser/cbind/generate.js +94 -7
  83. package/dest/browser/cbind/generated/api_types.d.ts +1629 -230
  84. package/dest/browser/cbind/generated/api_types.d.ts.map +1 -1
  85. package/dest/browser/cbind/generated/api_types.js +2349 -479
  86. package/dest/browser/cbind/generated/async.d.ts +53 -14
  87. package/dest/browser/cbind/generated/async.d.ts.map +1 -1
  88. package/dest/browser/cbind/generated/async.js +587 -72
  89. package/dest/browser/cbind/generated/curve_constants.d.ts +45 -0
  90. package/dest/browser/cbind/generated/curve_constants.d.ts.map +1 -0
  91. package/dest/browser/cbind/generated/curve_constants.js +45 -0
  92. package/dest/browser/cbind/generated/sync.d.ts +54 -15
  93. package/dest/browser/cbind/generated/sync.d.ts.map +1 -1
  94. package/dest/browser/cbind/generated/sync.js +549 -72
  95. package/dest/browser/cbind/schema_compiler.d.ts +3 -5
  96. package/dest/browser/cbind/schema_compiler.d.ts.map +1 -1
  97. package/dest/browser/cbind/schema_compiler.js +102 -185
  98. package/dest/browser/crs/browser/cached_net_crs.d.ts +1 -1
  99. package/dest/browser/crs/browser/cached_net_crs.d.ts.map +1 -1
  100. package/dest/browser/crs/browser/cached_net_crs.js +6 -1
  101. package/dest/browser/crs/browser/index.d.ts +1 -1
  102. package/dest/browser/crs/index.d.ts +1 -1
  103. package/dest/browser/crs/net_crs.d.ts +1 -16
  104. package/dest/browser/crs/net_crs.d.ts.map +1 -1
  105. package/dest/browser/crs/net_crs.js +6 -1
  106. package/dest/browser/index.d.ts +6 -3
  107. package/dest/browser/index.d.ts.map +1 -1
  108. package/dest/browser/index.js +6 -3
  109. package/dest/browser/proof/index.d.ts +1 -1
  110. package/dest/browser/proof/index.js +1 -1
  111. package/dest/browser/random/browser/index.d.ts +1 -1
  112. package/dest/browser/random/browser/index.d.ts.map +1 -1
  113. package/dest/browser/random/browser/index.js +1 -1
  114. package/dest/browser/random/index.d.ts +1 -1
  115. package/dest/browser/retry/index.d.ts +1 -1
  116. package/dest/browser/retry/index.js +1 -1
  117. package/dest/node/async_map/index.d.ts +1 -1
  118. package/dest/node/async_map/index.js +1 -1
  119. package/dest/node/barretenberg/__snapshots__/pedersen.test.js.snap +2 -2
  120. package/dest/node/barretenberg/__snapshots__/poseidon.test.js.snap +3 -3
  121. package/dest/node/barretenberg/backend.d.ts +32 -41
  122. package/dest/node/barretenberg/backend.d.ts.map +1 -1
  123. package/dest/node/barretenberg/backend.js +128 -108
  124. package/dest/node/barretenberg/blake2s.test.d.ts +1 -1
  125. package/dest/node/barretenberg/blake2s.test.js +21 -18
  126. package/dest/node/barretenberg/index.d.ts +47 -48
  127. package/dest/node/barretenberg/index.d.ts.map +1 -1
  128. package/dest/node/barretenberg/index.js +132 -90
  129. package/dest/node/barretenberg/pedersen.test.d.ts +1 -1
  130. package/dest/node/barretenberg/pedersen.test.js +25 -18
  131. package/dest/node/barretenberg/poseidon.bench.test.d.ts +2 -0
  132. package/dest/node/barretenberg/poseidon.bench.test.d.ts.map +1 -0
  133. package/dest/node/barretenberg/poseidon.bench.test.js +218 -0
  134. package/dest/node/barretenberg/poseidon.test.d.ts +1 -1
  135. package/dest/node/barretenberg/poseidon.test.js +16 -16
  136. package/dest/node/barretenberg/testing/bigint-buffer.d.ts +17 -0
  137. package/dest/node/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  138. package/dest/node/barretenberg/testing/bigint-buffer.js +37 -0
  139. package/dest/node/barretenberg/testing/fields.d.ts +16 -0
  140. package/dest/node/barretenberg/testing/fields.d.ts.map +1 -0
  141. package/dest/node/barretenberg/testing/fields.js +47 -0
  142. package/dest/node/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  143. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +2 -2
  144. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
  145. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.js +6 -7
  146. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +1 -1
  147. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -1
  148. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +1 -3
  149. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +1 -1
  150. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +1 -7
  151. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +1 -1
  152. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -1
  153. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +1 -3
  154. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +1 -1
  155. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +1 -8
  156. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +5 -5
  157. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -1
  158. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +20 -11
  159. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +16 -7
  160. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
  161. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.js +94 -26
  162. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +1 -1
  163. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -1
  164. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +1 -3
  165. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +1 -1
  166. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +1 -7
  167. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +1 -1
  168. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -1
  169. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +1 -3
  170. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +1 -1
  171. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +1 -7
  172. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +9 -8
  173. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
  174. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.js +4 -3
  175. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +1 -1
  176. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +1 -1
  177. package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts +1 -1
  178. package/dest/node/barretenberg_wasm/fetch_code/browser/index.js +1 -1
  179. package/dest/node/barretenberg_wasm/fetch_code/index.d.ts +1 -1
  180. package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts +1 -1
  181. package/dest/node/barretenberg_wasm/fetch_code/node/index.js +1 -1
  182. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts +2 -2
  183. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -1
  184. package/dest/node/barretenberg_wasm/helpers/browser/index.js +9 -2
  185. package/dest/node/barretenberg_wasm/helpers/index.d.ts +1 -1
  186. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts +5 -6
  187. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts.map +1 -1
  188. package/dest/node/barretenberg_wasm/helpers/node/index.js +14 -6
  189. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts +2 -2
  190. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -1
  191. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.js +1 -1
  192. package/dest/node/barretenberg_wasm/index.d.ts +1 -1
  193. package/dest/node/barretenberg_wasm/index.d.ts.map +1 -1
  194. package/dest/node/barretenberg_wasm/index.js +2 -3
  195. package/dest/node/barretenberg_wasm/index.test.d.ts +1 -1
  196. package/dest/node/barretenberg_wasm/index.test.js +11 -10
  197. package/dest/node/bb_backends/browser/index.d.ts +11 -0
  198. package/dest/node/bb_backends/browser/index.d.ts.map +1 -0
  199. package/dest/node/bb_backends/browser/index.js +39 -0
  200. package/dest/node/bb_backends/browser/platform.d.ts +4 -0
  201. package/dest/node/bb_backends/browser/platform.d.ts.map +1 -0
  202. package/dest/node/bb_backends/browser/platform.js +10 -0
  203. package/dest/node/bb_backends/index.d.ts +50 -0
  204. package/dest/node/bb_backends/index.d.ts.map +1 -0
  205. package/dest/node/bb_backends/index.js +16 -0
  206. package/dest/node/bb_backends/interface.d.ts +33 -0
  207. package/dest/node/bb_backends/interface.d.ts.map +1 -0
  208. package/dest/node/bb_backends/interface.js +2 -0
  209. package/dest/node/bb_backends/node/index.d.ts +11 -0
  210. package/dest/node/bb_backends/node/index.d.ts.map +1 -0
  211. package/dest/node/bb_backends/node/index.js +86 -0
  212. package/dest/node/bb_backends/node/native_pipe.d.ts +25 -0
  213. package/dest/node/bb_backends/node/native_pipe.d.ts.map +1 -0
  214. package/dest/node/bb_backends/node/native_pipe.js +114 -0
  215. package/dest/node/bb_backends/node/native_shm.d.ts +28 -0
  216. package/dest/node/bb_backends/node/native_shm.d.ts.map +1 -0
  217. package/dest/node/bb_backends/node/native_shm.js +172 -0
  218. package/dest/node/bb_backends/node/native_shm_async.d.ts +51 -0
  219. package/dest/node/bb_backends/node/native_shm_async.d.ts.map +1 -0
  220. package/dest/node/bb_backends/node/native_shm_async.js +232 -0
  221. package/dest/node/bb_backends/node/native_socket.d.ts +34 -0
  222. package/dest/node/bb_backends/node/native_socket.d.ts.map +1 -0
  223. package/dest/node/bb_backends/node/native_socket.js +281 -0
  224. package/dest/node/bb_backends/node/platform.d.ts +27 -0
  225. package/dest/node/bb_backends/node/platform.d.ts.map +1 -0
  226. package/dest/node/bb_backends/node/platform.js +129 -0
  227. package/dest/node/bb_backends/wasm.d.ts +49 -0
  228. package/dest/node/bb_backends/wasm.d.ts.map +1 -0
  229. package/dest/node/bb_backends/wasm.js +85 -0
  230. package/dest/node/bbapi/exception_handling.test.d.ts +2 -0
  231. package/dest/node/bbapi/exception_handling.test.d.ts.map +1 -0
  232. package/dest/node/bbapi/exception_handling.test.js +48 -0
  233. package/dest/node/bbapi_exception.d.ts +7 -0
  234. package/dest/node/bbapi_exception.d.ts.map +1 -0
  235. package/dest/node/bbapi_exception.js +14 -0
  236. package/dest/node/benchmark/index.d.ts +1 -1
  237. package/dest/node/benchmark/index.js +1 -1
  238. package/dest/node/benchmark/timer.d.ts +1 -1
  239. package/dest/node/benchmark/timer.d.ts.map +1 -1
  240. package/dest/node/benchmark/timer.js +2 -1
  241. package/dest/node/bin/index.d.ts +3 -0
  242. package/dest/node/bin/index.d.ts.map +1 -0
  243. package/dest/node/bin/index.js +11 -0
  244. package/dest/node/cbind/generate.d.ts +1 -1
  245. package/dest/node/cbind/generate.js +94 -7
  246. package/dest/node/cbind/generated/api_types.d.ts +1629 -230
  247. package/dest/node/cbind/generated/api_types.d.ts.map +1 -1
  248. package/dest/node/cbind/generated/api_types.js +2349 -479
  249. package/dest/node/cbind/generated/async.d.ts +53 -14
  250. package/dest/node/cbind/generated/async.d.ts.map +1 -1
  251. package/dest/node/cbind/generated/async.js +587 -72
  252. package/dest/node/cbind/generated/curve_constants.d.ts +45 -0
  253. package/dest/node/cbind/generated/curve_constants.d.ts.map +1 -0
  254. package/dest/node/cbind/generated/curve_constants.js +45 -0
  255. package/dest/node/cbind/generated/sync.d.ts +54 -15
  256. package/dest/node/cbind/generated/sync.d.ts.map +1 -1
  257. package/dest/node/cbind/generated/sync.js +549 -72
  258. package/dest/node/cbind/schema_compiler.d.ts +3 -5
  259. package/dest/node/cbind/schema_compiler.d.ts.map +1 -1
  260. package/dest/node/cbind/schema_compiler.js +102 -185
  261. package/dest/node/crs/browser/cached_net_crs.d.ts +1 -1
  262. package/dest/node/crs/browser/cached_net_crs.d.ts.map +1 -1
  263. package/dest/node/crs/browser/cached_net_crs.js +6 -1
  264. package/dest/node/crs/browser/index.d.ts +1 -1
  265. package/dest/node/crs/index.d.ts +1 -1
  266. package/dest/node/crs/net_crs.d.ts +1 -16
  267. package/dest/node/crs/net_crs.d.ts.map +1 -1
  268. package/dest/node/crs/net_crs.js +6 -1
  269. package/dest/node/crs/node/index.d.ts +1 -1
  270. package/dest/node/crs/node/index.d.ts.map +1 -1
  271. package/dest/node/crs/node/index.js +11 -6
  272. package/dest/node/index.d.ts +6 -3
  273. package/dest/node/index.d.ts.map +1 -1
  274. package/dest/node/index.js +6 -3
  275. package/dest/node/proof/index.d.ts +1 -1
  276. package/dest/node/proof/index.js +1 -1
  277. package/dest/node/random/browser/index.d.ts +1 -1
  278. package/dest/node/random/browser/index.d.ts.map +1 -1
  279. package/dest/node/random/browser/index.js +1 -1
  280. package/dest/node/random/index.d.ts +1 -1
  281. package/dest/node/random/node/index.d.ts +1 -1
  282. package/dest/node/random/node/index.js +1 -1
  283. package/dest/node/retry/index.d.ts +1 -1
  284. package/dest/node/retry/index.js +1 -1
  285. package/dest/node-cjs/async_map/index.d.ts +1 -1
  286. package/dest/node-cjs/async_map/index.js +1 -1
  287. package/dest/node-cjs/barretenberg/backend.d.ts +32 -41
  288. package/dest/node-cjs/barretenberg/backend.d.ts.map +1 -1
  289. package/dest/node-cjs/barretenberg/backend.js +131 -111
  290. package/dest/node-cjs/barretenberg/blake2s.test.d.ts +1 -1
  291. package/dest/node-cjs/barretenberg/blake2s.test.js +22 -19
  292. package/dest/node-cjs/barretenberg/index.d.ts +47 -48
  293. package/dest/node-cjs/barretenberg/index.d.ts.map +1 -1
  294. package/dest/node-cjs/barretenberg/index.js +136 -93
  295. package/dest/node-cjs/barretenberg/pedersen.test.d.ts +1 -1
  296. package/dest/node-cjs/barretenberg/pedersen.test.js +27 -20
  297. package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts +2 -0
  298. package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts.map +1 -0
  299. package/dest/node-cjs/barretenberg/poseidon.bench.test.js +220 -0
  300. package/dest/node-cjs/barretenberg/poseidon.test.d.ts +1 -1
  301. package/dest/node-cjs/barretenberg/poseidon.test.js +16 -16
  302. package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts +17 -0
  303. package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  304. package/dest/node-cjs/barretenberg/testing/bigint-buffer.js +43 -0
  305. package/dest/node-cjs/barretenberg/testing/fields.d.ts +16 -0
  306. package/dest/node-cjs/barretenberg/testing/fields.d.ts.map +1 -0
  307. package/dest/node-cjs/barretenberg/testing/fields.js +51 -0
  308. package/dest/node-cjs/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  309. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +2 -2
  310. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
  311. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.js +8 -9
  312. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +1 -1
  313. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -1
  314. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +3 -5
  315. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +1 -1
  316. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +1 -7
  317. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +1 -1
  318. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -1
  319. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +1 -3
  320. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +1 -1
  321. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +1 -8
  322. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +5 -5
  323. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -1
  324. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +20 -11
  325. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +16 -7
  326. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
  327. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.js +94 -26
  328. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +1 -1
  329. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -1
  330. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +3 -5
  331. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +1 -1
  332. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +1 -7
  333. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +1 -1
  334. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -1
  335. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +1 -3
  336. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +1 -1
  337. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +1 -7
  338. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +9 -8
  339. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
  340. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.js +4 -3
  341. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +1 -1
  342. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +1 -1
  343. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +1 -1
  344. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.js +1 -1
  345. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts +1 -1
  346. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.js +2 -2
  347. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts +1 -1
  348. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts +1 -1
  349. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.js +2 -2
  350. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts +2 -2
  351. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -1
  352. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.js +9 -2
  353. package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts +1 -1
  354. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts +5 -6
  355. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts.map +1 -1
  356. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.js +15 -7
  357. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts +2 -2
  358. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -1
  359. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.js +1 -1
  360. package/dest/node-cjs/barretenberg_wasm/index.d.ts +1 -1
  361. package/dest/node-cjs/barretenberg_wasm/index.d.ts.map +1 -1
  362. package/dest/node-cjs/barretenberg_wasm/index.js +2 -3
  363. package/dest/node-cjs/barretenberg_wasm/index.test.d.ts +1 -1
  364. package/dest/node-cjs/barretenberg_wasm/index.test.js +11 -10
  365. package/dest/node-cjs/bb_backends/browser/index.d.ts +11 -0
  366. package/dest/node-cjs/bb_backends/browser/index.d.ts.map +1 -0
  367. package/dest/node-cjs/bb_backends/browser/index.js +43 -0
  368. package/dest/node-cjs/bb_backends/browser/platform.d.ts +4 -0
  369. package/dest/node-cjs/bb_backends/browser/platform.d.ts.map +1 -0
  370. package/dest/node-cjs/bb_backends/browser/platform.js +15 -0
  371. package/dest/node-cjs/bb_backends/index.d.ts +50 -0
  372. package/dest/node-cjs/bb_backends/index.d.ts.map +1 -0
  373. package/dest/node-cjs/bb_backends/index.js +18 -0
  374. package/dest/node-cjs/bb_backends/interface.d.ts +33 -0
  375. package/dest/node-cjs/bb_backends/interface.d.ts.map +1 -0
  376. package/dest/node-cjs/bb_backends/interface.js +3 -0
  377. package/dest/node-cjs/bb_backends/node/index.d.ts +11 -0
  378. package/dest/node-cjs/bb_backends/node/index.d.ts.map +1 -0
  379. package/dest/node-cjs/bb_backends/node/index.js +90 -0
  380. package/dest/node-cjs/bb_backends/node/native_pipe.d.ts +25 -0
  381. package/dest/node-cjs/bb_backends/node/native_pipe.d.ts.map +1 -0
  382. package/dest/node-cjs/bb_backends/node/native_pipe.js +118 -0
  383. package/dest/node-cjs/bb_backends/node/native_shm.d.ts +28 -0
  384. package/dest/node-cjs/bb_backends/node/native_shm.d.ts.map +1 -0
  385. package/dest/node-cjs/bb_backends/node/native_shm.js +176 -0
  386. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts +51 -0
  387. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts.map +1 -0
  388. package/dest/node-cjs/bb_backends/node/native_shm_async.js +236 -0
  389. package/dest/node-cjs/bb_backends/node/native_socket.d.ts +34 -0
  390. package/dest/node-cjs/bb_backends/node/native_socket.d.ts.map +1 -0
  391. package/dest/node-cjs/bb_backends/node/native_socket.js +286 -0
  392. package/dest/node-cjs/bb_backends/node/platform.d.ts +27 -0
  393. package/dest/node-cjs/bb_backends/node/platform.d.ts.map +1 -0
  394. package/dest/node-cjs/bb_backends/node/platform.js +136 -0
  395. package/dest/node-cjs/bb_backends/wasm.d.ts +49 -0
  396. package/dest/node-cjs/bb_backends/wasm.d.ts.map +1 -0
  397. package/dest/node-cjs/bb_backends/wasm.js +90 -0
  398. package/dest/node-cjs/bbapi/exception_handling.test.d.ts +2 -0
  399. package/dest/node-cjs/bbapi/exception_handling.test.d.ts.map +1 -0
  400. package/dest/node-cjs/bbapi/exception_handling.test.js +50 -0
  401. package/dest/node-cjs/bbapi_exception.d.ts +7 -0
  402. package/dest/node-cjs/bbapi_exception.d.ts.map +1 -0
  403. package/dest/node-cjs/bbapi_exception.js +18 -0
  404. package/dest/node-cjs/benchmark/index.d.ts +1 -1
  405. package/dest/node-cjs/benchmark/index.js +2 -2
  406. package/dest/node-cjs/benchmark/timer.d.ts +1 -1
  407. package/dest/node-cjs/benchmark/timer.d.ts.map +1 -1
  408. package/dest/node-cjs/benchmark/timer.js +2 -1
  409. package/dest/node-cjs/bin/index.d.ts +3 -0
  410. package/dest/node-cjs/{bindgen → bin}/index.d.ts.map +1 -1
  411. package/dest/node-cjs/bin/index.js +13 -0
  412. package/dest/node-cjs/cbind/generate.d.ts +1 -1
  413. package/dest/node-cjs/cbind/generate.js +93 -6
  414. package/dest/node-cjs/cbind/generated/api_types.d.ts +1629 -230
  415. package/dest/node-cjs/cbind/generated/api_types.d.ts.map +1 -1
  416. package/dest/node-cjs/cbind/generated/api_types.js +2555 -519
  417. package/dest/node-cjs/cbind/generated/async.d.ts +53 -14
  418. package/dest/node-cjs/cbind/generated/async.d.ts.map +1 -1
  419. package/dest/node-cjs/cbind/generated/async.js +586 -71
  420. package/dest/node-cjs/cbind/generated/curve_constants.d.ts +45 -0
  421. package/dest/node-cjs/cbind/generated/curve_constants.d.ts.map +1 -0
  422. package/dest/node-cjs/cbind/generated/curve_constants.js +48 -0
  423. package/dest/node-cjs/cbind/generated/sync.d.ts +54 -15
  424. package/dest/node-cjs/cbind/generated/sync.d.ts.map +1 -1
  425. package/dest/node-cjs/cbind/generated/sync.js +548 -71
  426. package/dest/node-cjs/cbind/schema_compiler.d.ts +3 -5
  427. package/dest/node-cjs/cbind/schema_compiler.d.ts.map +1 -1
  428. package/dest/node-cjs/cbind/schema_compiler.js +102 -186
  429. package/dest/node-cjs/crs/browser/cached_net_crs.d.ts +1 -1
  430. package/dest/node-cjs/crs/browser/cached_net_crs.d.ts.map +1 -1
  431. package/dest/node-cjs/crs/browser/cached_net_crs.js +6 -1
  432. package/dest/node-cjs/crs/browser/index.d.ts +1 -1
  433. package/dest/node-cjs/crs/browser/index.js +2 -2
  434. package/dest/node-cjs/crs/index.d.ts +1 -1
  435. package/dest/node-cjs/crs/index.js +2 -2
  436. package/dest/node-cjs/crs/net_crs.d.ts +1 -16
  437. package/dest/node-cjs/crs/net_crs.d.ts.map +1 -1
  438. package/dest/node-cjs/crs/net_crs.js +6 -1
  439. package/dest/node-cjs/crs/node/index.d.ts +1 -1
  440. package/dest/node-cjs/crs/node/index.d.ts.map +1 -1
  441. package/dest/node-cjs/crs/node/index.js +11 -6
  442. package/dest/node-cjs/index.d.ts +6 -3
  443. package/dest/node-cjs/index.d.ts.map +1 -1
  444. package/dest/node-cjs/index.js +29 -12
  445. package/dest/node-cjs/proof/index.d.ts +1 -1
  446. package/dest/node-cjs/proof/index.js +1 -1
  447. package/dest/node-cjs/random/browser/index.d.ts +1 -1
  448. package/dest/node-cjs/random/browser/index.d.ts.map +1 -1
  449. package/dest/node-cjs/random/browser/index.js +1 -1
  450. package/dest/node-cjs/random/index.d.ts +1 -1
  451. package/dest/node-cjs/random/node/index.d.ts +1 -1
  452. package/dest/node-cjs/random/node/index.js +1 -1
  453. package/dest/node-cjs/retry/index.d.ts +1 -1
  454. package/dest/node-cjs/retry/index.js +1 -1
  455. package/package.json +12 -10
  456. package/src/barretenberg/__snapshots__/pedersen.test.ts.snap +2 -2
  457. package/src/barretenberg/__snapshots__/poseidon.test.ts.snap +3 -3
  458. package/src/barretenberg/backend.ts +165 -154
  459. package/src/barretenberg/blake2s.test.ts +20 -21
  460. package/src/barretenberg/index.ts +144 -130
  461. package/src/barretenberg/pedersen.test.ts +24 -17
  462. package/src/barretenberg/poseidon.bench.test.ts +271 -0
  463. package/src/barretenberg/poseidon.test.ts +15 -15
  464. package/src/barretenberg/testing/fields.ts +63 -0
  465. package/src/barretenberg_wasm/barretenberg_wasm_base/index.ts +4 -5
  466. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.ts +0 -2
  467. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.ts +0 -7
  468. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.ts +0 -2
  469. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.ts +0 -9
  470. package/src/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.ts +17 -9
  471. package/src/barretenberg_wasm/barretenberg_wasm_main/index.ts +104 -20
  472. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.ts +0 -2
  473. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.ts +0 -7
  474. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.ts +0 -2
  475. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.ts +0 -7
  476. package/src/barretenberg_wasm/barretenberg_wasm_thread/index.ts +3 -2
  477. package/src/barretenberg_wasm/helpers/browser/index.ts +8 -1
  478. package/src/barretenberg_wasm/helpers/node/index.ts +13 -6
  479. package/src/barretenberg_wasm/index.test.ts +12 -11
  480. package/src/barretenberg_wasm/index.ts +1 -2
  481. package/src/bb_backends/browser/index.ts +50 -0
  482. package/src/bb_backends/browser/platform.ts +11 -0
  483. package/src/bb_backends/index.ts +55 -0
  484. package/src/bb_backends/interface.ts +35 -0
  485. package/src/bb_backends/node/index.ts +107 -0
  486. package/src/bb_backends/node/native_pipe.ts +127 -0
  487. package/src/bb_backends/node/native_shm.ts +190 -0
  488. package/src/bb_backends/node/native_shm_async.ts +261 -0
  489. package/src/bb_backends/node/native_socket.ts +325 -0
  490. package/src/bb_backends/node/platform.ts +156 -0
  491. package/src/bb_backends/wasm.ts +102 -0
  492. package/src/bbapi/exception_handling.test.ts +54 -0
  493. package/src/bbapi_exception.ts +13 -0
  494. package/src/bin/index.ts +14 -0
  495. package/src/cbind/README.md +1 -1
  496. package/src/cbind/generate.ts +99 -6
  497. package/src/cbind/generated/api_types.ts +4241 -0
  498. package/src/cbind/generated/async.ts +717 -0
  499. package/src/cbind/generated/curve_constants.ts +53 -0
  500. package/src/cbind/generated/sync.ts +663 -0
  501. package/src/cbind/schema_compiler.ts +156 -244
  502. package/src/crs/node/index.ts +4 -5
  503. package/src/index.ts +33 -1
  504. package/dest/browser/barretenberg_api/index.d.ts +0 -109
  505. package/dest/browser/barretenberg_api/index.d.ts.map +0 -1
  506. package/dest/browser/barretenberg_api/index.js +0 -699
  507. package/dest/browser/bigint-array/index.d.ts +0 -17
  508. package/dest/browser/bigint-array/index.d.ts.map +0 -1
  509. package/dest/browser/bigint-array/index.js +0 -37
  510. package/dest/browser/cbind/generated/native.d.ts +0 -31
  511. package/dest/browser/cbind/generated/native.d.ts.map +0 -1
  512. package/dest/browser/cbind/generated/native.js +0 -234
  513. package/dest/browser/log/browser/index.d.ts +0 -6
  514. package/dest/browser/log/browser/index.d.ts.map +0 -1
  515. package/dest/browser/log/browser/index.js +0 -28
  516. package/dest/browser/log/index.d.ts +0 -2
  517. package/dest/browser/log/index.d.ts.map +0 -1
  518. package/dest/browser/log/index.js +0 -2
  519. package/dest/browser/log/types.d.ts +0 -6
  520. package/dest/browser/log/types.d.ts.map +0 -1
  521. package/dest/browser/log/types.js +0 -2
  522. package/dest/browser/serialize/buffer_reader.d.ts +0 -28
  523. package/dest/browser/serialize/buffer_reader.d.ts.map +0 -1
  524. package/dest/browser/serialize/buffer_reader.js +0 -66
  525. package/dest/browser/serialize/index.d.ts +0 -4
  526. package/dest/browser/serialize/index.d.ts.map +0 -1
  527. package/dest/browser/serialize/index.js +0 -4
  528. package/dest/browser/serialize/output_type.d.ts +0 -11
  529. package/dest/browser/serialize/output_type.d.ts.map +0 -1
  530. package/dest/browser/serialize/output_type.js +0 -44
  531. package/dest/browser/serialize/serialize.d.ts +0 -53
  532. package/dest/browser/serialize/serialize.d.ts.map +0 -1
  533. package/dest/browser/serialize/serialize.js +0 -139
  534. package/dest/browser/types/fields.d.ts +0 -43
  535. package/dest/browser/types/fields.d.ts.map +0 -1
  536. package/dest/browser/types/fields.js +0 -102
  537. package/dest/browser/types/fixed_size_buffer.d.ts +0 -26
  538. package/dest/browser/types/fixed_size_buffer.d.ts.map +0 -1
  539. package/dest/browser/types/fixed_size_buffer.js +0 -51
  540. package/dest/browser/types/index.d.ts +0 -6
  541. package/dest/browser/types/index.d.ts.map +0 -1
  542. package/dest/browser/types/index.js +0 -6
  543. package/dest/browser/types/point.d.ts +0 -16
  544. package/dest/browser/types/point.d.ts.map +0 -1
  545. package/dest/browser/types/point.js +0 -31
  546. package/dest/browser/types/ptr.d.ts +0 -13
  547. package/dest/browser/types/ptr.d.ts.map +0 -1
  548. package/dest/browser/types/ptr.js +0 -19
  549. package/dest/browser/types/raw_buffer.d.ts +0 -3
  550. package/dest/browser/types/raw_buffer.d.ts.map +0 -1
  551. package/dest/browser/types/raw_buffer.js +0 -5
  552. package/dest/node/barretenberg/common.test.d.ts +0 -2
  553. package/dest/node/barretenberg/common.test.d.ts.map +0 -1
  554. package/dest/node/barretenberg/common.test.js +0 -20
  555. package/dest/node/barretenberg_api/index.d.ts +0 -109
  556. package/dest/node/barretenberg_api/index.d.ts.map +0 -1
  557. package/dest/node/barretenberg_api/index.js +0 -699
  558. package/dest/node/bigint-array/index.d.ts +0 -17
  559. package/dest/node/bigint-array/index.d.ts.map +0 -1
  560. package/dest/node/bigint-array/index.js +0 -37
  561. package/dest/node/bindgen/function_declaration.d.ts +0 -11
  562. package/dest/node/bindgen/function_declaration.d.ts.map +0 -1
  563. package/dest/node/bindgen/function_declaration.js +0 -2
  564. package/dest/node/bindgen/index.d.ts +0 -2
  565. package/dest/node/bindgen/index.js +0 -15
  566. package/dest/node/bindgen/mappings.d.ts +0 -4
  567. package/dest/node/bindgen/mappings.d.ts.map +0 -1
  568. package/dest/node/bindgen/mappings.js +0 -64
  569. package/dest/node/bindgen/rust.d.ts +0 -2
  570. package/dest/node/bindgen/rust.d.ts.map +0 -1
  571. package/dest/node/bindgen/rust.js +0 -43
  572. package/dest/node/bindgen/to_camel_case.d.ts +0 -2
  573. package/dest/node/bindgen/to_camel_case.d.ts.map +0 -1
  574. package/dest/node/bindgen/to_camel_case.js +0 -11
  575. package/dest/node/bindgen/typescript.d.ts +0 -2
  576. package/dest/node/bindgen/typescript.d.ts.map +0 -1
  577. package/dest/node/bindgen/typescript.js +0 -100
  578. package/dest/node/cbind/generated/native.d.ts +0 -31
  579. package/dest/node/cbind/generated/native.d.ts.map +0 -1
  580. package/dest/node/cbind/generated/native.js +0 -234
  581. package/dest/node/log/browser/index.d.ts +0 -6
  582. package/dest/node/log/browser/index.d.ts.map +0 -1
  583. package/dest/node/log/browser/index.js +0 -28
  584. package/dest/node/log/index.d.ts +0 -2
  585. package/dest/node/log/index.d.ts.map +0 -1
  586. package/dest/node/log/index.js +0 -2
  587. package/dest/node/log/node/index.d.ts +0 -6
  588. package/dest/node/log/node/index.d.ts.map +0 -1
  589. package/dest/node/log/node/index.js +0 -40
  590. package/dest/node/log/types.d.ts +0 -6
  591. package/dest/node/log/types.d.ts.map +0 -1
  592. package/dest/node/log/types.js +0 -2
  593. package/dest/node/main.d.ts +0 -13
  594. package/dest/node/main.d.ts.map +0 -1
  595. package/dest/node/main.js +0 -459
  596. package/dest/node/serialize/buffer_reader.d.ts +0 -28
  597. package/dest/node/serialize/buffer_reader.d.ts.map +0 -1
  598. package/dest/node/serialize/buffer_reader.js +0 -66
  599. package/dest/node/serialize/index.d.ts +0 -4
  600. package/dest/node/serialize/index.d.ts.map +0 -1
  601. package/dest/node/serialize/index.js +0 -4
  602. package/dest/node/serialize/output_type.d.ts +0 -11
  603. package/dest/node/serialize/output_type.d.ts.map +0 -1
  604. package/dest/node/serialize/output_type.js +0 -44
  605. package/dest/node/serialize/serialize.d.ts +0 -53
  606. package/dest/node/serialize/serialize.d.ts.map +0 -1
  607. package/dest/node/serialize/serialize.js +0 -139
  608. package/dest/node/types/fields.d.ts +0 -43
  609. package/dest/node/types/fields.d.ts.map +0 -1
  610. package/dest/node/types/fields.js +0 -102
  611. package/dest/node/types/fixed_size_buffer.d.ts +0 -26
  612. package/dest/node/types/fixed_size_buffer.d.ts.map +0 -1
  613. package/dest/node/types/fixed_size_buffer.js +0 -51
  614. package/dest/node/types/index.d.ts +0 -6
  615. package/dest/node/types/index.d.ts.map +0 -1
  616. package/dest/node/types/index.js +0 -6
  617. package/dest/node/types/point.d.ts +0 -16
  618. package/dest/node/types/point.d.ts.map +0 -1
  619. package/dest/node/types/point.js +0 -31
  620. package/dest/node/types/ptr.d.ts +0 -13
  621. package/dest/node/types/ptr.d.ts.map +0 -1
  622. package/dest/node/types/ptr.js +0 -19
  623. package/dest/node/types/raw_buffer.d.ts +0 -3
  624. package/dest/node/types/raw_buffer.d.ts.map +0 -1
  625. package/dest/node/types/raw_buffer.js +0 -5
  626. package/dest/node-cjs/barretenberg/common.test.d.ts +0 -2
  627. package/dest/node-cjs/barretenberg/common.test.d.ts.map +0 -1
  628. package/dest/node-cjs/barretenberg/common.test.js +0 -22
  629. package/dest/node-cjs/barretenberg_api/index.d.ts +0 -109
  630. package/dest/node-cjs/barretenberg_api/index.d.ts.map +0 -1
  631. package/dest/node-cjs/barretenberg_api/index.js +0 -704
  632. package/dest/node-cjs/bigint-array/index.d.ts +0 -17
  633. package/dest/node-cjs/bigint-array/index.d.ts.map +0 -1
  634. package/dest/node-cjs/bigint-array/index.js +0 -43
  635. package/dest/node-cjs/bindgen/function_declaration.d.ts +0 -11
  636. package/dest/node-cjs/bindgen/function_declaration.d.ts.map +0 -1
  637. package/dest/node-cjs/bindgen/function_declaration.js +0 -3
  638. package/dest/node-cjs/bindgen/index.d.ts +0 -2
  639. package/dest/node-cjs/bindgen/index.js +0 -17
  640. package/dest/node-cjs/bindgen/mappings.d.ts +0 -4
  641. package/dest/node-cjs/bindgen/mappings.d.ts.map +0 -1
  642. package/dest/node-cjs/bindgen/mappings.js +0 -69
  643. package/dest/node-cjs/bindgen/rust.d.ts +0 -2
  644. package/dest/node-cjs/bindgen/rust.d.ts.map +0 -1
  645. package/dest/node-cjs/bindgen/rust.js +0 -47
  646. package/dest/node-cjs/bindgen/to_camel_case.d.ts +0 -2
  647. package/dest/node-cjs/bindgen/to_camel_case.d.ts.map +0 -1
  648. package/dest/node-cjs/bindgen/to_camel_case.js +0 -14
  649. package/dest/node-cjs/bindgen/typescript.d.ts +0 -2
  650. package/dest/node-cjs/bindgen/typescript.d.ts.map +0 -1
  651. package/dest/node-cjs/bindgen/typescript.js +0 -104
  652. package/dest/node-cjs/cbind/generated/native.d.ts +0 -31
  653. package/dest/node-cjs/cbind/generated/native.d.ts.map +0 -1
  654. package/dest/node-cjs/cbind/generated/native.js +0 -238
  655. package/dest/node-cjs/log/browser/index.d.ts +0 -6
  656. package/dest/node-cjs/log/browser/index.d.ts.map +0 -1
  657. package/dest/node-cjs/log/browser/index.js +0 -30
  658. package/dest/node-cjs/log/index.d.ts +0 -2
  659. package/dest/node-cjs/log/index.d.ts.map +0 -1
  660. package/dest/node-cjs/log/index.js +0 -8
  661. package/dest/node-cjs/log/node/index.d.ts +0 -6
  662. package/dest/node-cjs/log/node/index.d.ts.map +0 -1
  663. package/dest/node-cjs/log/node/index.js +0 -42
  664. package/dest/node-cjs/log/types.d.ts +0 -6
  665. package/dest/node-cjs/log/types.d.ts.map +0 -1
  666. package/dest/node-cjs/log/types.js +0 -3
  667. package/dest/node-cjs/main.d.ts +0 -13
  668. package/dest/node-cjs/main.d.ts.map +0 -1
  669. package/dest/node-cjs/main.js +0 -470
  670. package/dest/node-cjs/serialize/buffer_reader.d.ts +0 -28
  671. package/dest/node-cjs/serialize/buffer_reader.d.ts.map +0 -1
  672. package/dest/node-cjs/serialize/buffer_reader.js +0 -70
  673. package/dest/node-cjs/serialize/index.d.ts +0 -4
  674. package/dest/node-cjs/serialize/index.d.ts.map +0 -1
  675. package/dest/node-cjs/serialize/index.js +0 -7
  676. package/dest/node-cjs/serialize/output_type.d.ts +0 -11
  677. package/dest/node-cjs/serialize/output_type.d.ts.map +0 -1
  678. package/dest/node-cjs/serialize/output_type.js +0 -51
  679. package/dest/node-cjs/serialize/serialize.d.ts +0 -53
  680. package/dest/node-cjs/serialize/serialize.d.ts.map +0 -1
  681. package/dest/node-cjs/serialize/serialize.js +0 -160
  682. package/dest/node-cjs/types/fields.d.ts +0 -43
  683. package/dest/node-cjs/types/fields.d.ts.map +0 -1
  684. package/dest/node-cjs/types/fields.js +0 -107
  685. package/dest/node-cjs/types/fixed_size_buffer.d.ts +0 -26
  686. package/dest/node-cjs/types/fixed_size_buffer.d.ts.map +0 -1
  687. package/dest/node-cjs/types/fixed_size_buffer.js +0 -57
  688. package/dest/node-cjs/types/index.d.ts +0 -6
  689. package/dest/node-cjs/types/index.d.ts.map +0 -1
  690. package/dest/node-cjs/types/index.js +0 -9
  691. package/dest/node-cjs/types/point.d.ts +0 -16
  692. package/dest/node-cjs/types/point.d.ts.map +0 -1
  693. package/dest/node-cjs/types/point.js +0 -35
  694. package/dest/node-cjs/types/ptr.d.ts +0 -13
  695. package/dest/node-cjs/types/ptr.d.ts.map +0 -1
  696. package/dest/node-cjs/types/ptr.js +0 -23
  697. package/dest/node-cjs/types/raw_buffer.d.ts +0 -3
  698. package/dest/node-cjs/types/raw_buffer.d.ts.map +0 -1
  699. package/dest/node-cjs/types/raw_buffer.js +0 -9
  700. package/src/barretenberg/common.test.ts +0 -23
  701. package/src/barretenberg_api/index.ts +0 -1216
  702. package/src/bindgen/function_declaration.ts +0 -11
  703. package/src/bindgen/index.ts +0 -17
  704. package/src/bindgen/mappings.ts +0 -67
  705. package/src/bindgen/rust.ts +0 -52
  706. package/src/bindgen/to_camel_case.ts +0 -10
  707. package/src/bindgen/typescript.ts +0 -116
  708. package/src/log/browser/index.ts +0 -35
  709. package/src/log/index.ts +0 -1
  710. package/src/log/node/index.ts +0 -52
  711. package/src/log/types.ts +0 -6
  712. package/src/main.ts +0 -534
  713. package/src/serialize/buffer_reader.ts +0 -85
  714. package/src/serialize/index.ts +0 -3
  715. package/src/serialize/output_type.ts +0 -53
  716. package/src/serialize/serialize.ts +0 -157
  717. package/src/types/fields.ts +0 -126
  718. package/src/types/fixed_size_buffer.ts +0 -59
  719. package/src/types/index.ts +0 -5
  720. package/src/types/point.ts +0 -38
  721. package/src/types/ptr.ts +0 -20
  722. package/src/types/raw_buffer.ts +0 -3
  723. /package/src/{bigint-array/index.ts → barretenberg/testing/bigint-buffer.ts} +0 -0
@@ -1,16 +1,7 @@
1
- import { BackendOptions, Barretenberg, CircuitOptions } from './index.js';
2
- import { RawBuffer } from '../types/raw_buffer.js';
3
- import {
4
- ProofData,
5
- reconstructHonkProof,
6
- splitHonkProof,
7
- PAIRING_POINTS_SIZE,
8
- uint8ArrayToHex,
9
- hexToUint8Array,
10
- } from '../proof/index.js';
11
- import { fromClientIVCProof, toClientIVCProof } from '../cbind/generated/api_types.js';
1
+ import { Barretenberg } from './index.js';
2
+ import { ProofData, uint8ArrayToHex, hexToUint8Array } from '../proof/index.js';
3
+ import { fromChonkProof, toChonkProof } from '../cbind/generated/api_types.js';
12
4
  import { ungzip } from 'pako';
13
- import { Buffer } from 'buffer';
14
5
  import { Decoder, Encoder } from 'msgpackr';
15
6
 
16
7
  export class AztecClientBackendError extends Error {
@@ -19,65 +10,136 @@ export class AztecClientBackendError extends Error {
19
10
  }
20
11
  }
21
12
 
13
+ /**
14
+ * Target verification environment for proof generation.
15
+ * This determines the hash function used and whether zero-knowledge is enabled.
16
+ */
17
+ export type VerifierTarget =
18
+ | 'evm' // Ethereum/Solidity verification (keccak, ZK enabled)
19
+ | 'evm-no-zk' // Ethereum/Solidity without zero-knowledge
20
+ | 'noir-recursive' // Recursive verification in Noir circuits (poseidon2, ZK enabled)
21
+ | 'noir-recursive-no-zk' // Recursive verification without ZK
22
+ | 'noir-rollup' // Rollup circuits with IPA accumulation (poseidon2, ZK enabled)
23
+ | 'noir-rollup-no-zk' // Rollup circuits without ZK
24
+ | 'starknet' // Starknet verification via Garaga (ZK enabled)
25
+ | 'starknet-no-zk'; // Starknet without zero-knowledge
26
+
22
27
  /**
23
28
  * Options for the UltraHonkBackend.
24
29
  */
25
30
  export type UltraHonkBackendOptions = {
26
- /** Selecting this option will use the keccak hash function instead of poseidon
27
- * when generating challenges in the proof.
28
- * Use this when you want to verify the created proof on an EVM chain.
31
+ /**
32
+ * Target verification environment. Determines hash function and ZK settings.
33
+ * This is the recommended way to configure proof generation.
34
+ *
35
+ * @example
36
+ * // For EVM/Solidity verification
37
+ * backend.generateProof(witness, { verifierTarget: 'evm' });
38
+ *
39
+ * // For recursive verification in Noir
40
+ * backend.generateProof(witness, { verifierTarget: 'noir-recursive' });
29
41
  */
42
+ verifierTarget?: VerifierTarget;
43
+
44
+ // Legacy options - prefer using verifierTarget instead
45
+
46
+ /** @deprecated Use verifierTarget: 'evm-no-zk' instead */
30
47
  keccak?: boolean;
31
- /** Selecting this option will use the keccak hash function instead of poseidon
32
- * when generating challenges in the proof.
33
- * Use this when you want to verify the created proof on an EVM chain.
34
- */
48
+ /** @deprecated Use verifierTarget: 'evm' instead */
35
49
  keccakZK?: boolean;
36
- /** Selecting this option will use the poseidon/stark252 hash function instead of poseidon
37
- * when generating challenges in the proof.
38
- * Use this when you want to verify the created proof on an Starknet chain with Garaga.
39
- */
50
+ /** @deprecated Use verifierTarget: 'starknet-no-zk' instead */
40
51
  starknet?: boolean;
41
- /** Selecting this option will use the poseidon/stark252 hash function instead of poseidon
42
- * when generating challenges in the proof.
43
- * Use this when you want to verify the created proof on an Starknet chain with Garaga.
44
- */
52
+ /** @deprecated Use verifierTarget: 'starknet' instead */
45
53
  starknetZK?: boolean;
46
54
  };
47
55
 
48
- function getProofSettingsFromOptions(
49
- options?: UltraHonkBackendOptions,
50
- ): { ipaAccumulation: boolean; oracleHashType: string; disableZk: boolean, optimizedSolidityVerifier: boolean } {
56
+ function getProofSettingsFromOptions(options?: UltraHonkBackendOptions): {
57
+ ipaAccumulation: boolean;
58
+ oracleHashType: string;
59
+ disableZk: boolean;
60
+ optimizedSolidityVerifier: boolean;
61
+ } {
62
+ // Check for conflicting options - verifierTarget should not be combined with legacy options
63
+ if (options?.verifierTarget) {
64
+ const legacyOptions = [options.keccak, options.keccakZK, options.starknet, options.starknetZK].filter(Boolean);
65
+ if (legacyOptions.length > 0) {
66
+ throw new Error(
67
+ 'Cannot use verifierTarget with legacy options (keccak, keccakZK, starknet, starknetZK). ' +
68
+ 'Use verifierTarget alone.',
69
+ );
70
+ }
71
+
72
+ switch (options.verifierTarget) {
73
+ case 'evm':
74
+ return { ipaAccumulation: false, oracleHashType: 'keccak', disableZk: false, optimizedSolidityVerifier: false };
75
+ case 'evm-no-zk':
76
+ return { ipaAccumulation: false, oracleHashType: 'keccak', disableZk: true, optimizedSolidityVerifier: false };
77
+ case 'noir-recursive':
78
+ return {
79
+ ipaAccumulation: false,
80
+ oracleHashType: 'poseidon2',
81
+ disableZk: false,
82
+ optimizedSolidityVerifier: false,
83
+ };
84
+ case 'noir-recursive-no-zk':
85
+ return {
86
+ ipaAccumulation: false,
87
+ oracleHashType: 'poseidon2',
88
+ disableZk: true,
89
+ optimizedSolidityVerifier: false,
90
+ };
91
+ case 'noir-rollup':
92
+ return {
93
+ ipaAccumulation: true,
94
+ oracleHashType: 'poseidon2',
95
+ disableZk: false,
96
+ optimizedSolidityVerifier: false,
97
+ };
98
+ case 'noir-rollup-no-zk':
99
+ return {
100
+ ipaAccumulation: true,
101
+ oracleHashType: 'poseidon2',
102
+ disableZk: true,
103
+ optimizedSolidityVerifier: false,
104
+ };
105
+ case 'starknet':
106
+ return {
107
+ ipaAccumulation: false,
108
+ oracleHashType: 'starknet',
109
+ disableZk: false,
110
+ optimizedSolidityVerifier: false,
111
+ };
112
+ case 'starknet-no-zk':
113
+ return {
114
+ ipaAccumulation: false,
115
+ oracleHashType: 'starknet',
116
+ disableZk: true,
117
+ optimizedSolidityVerifier: false,
118
+ };
119
+ }
120
+ }
121
+
122
+ // Legacy options support (deprecated)
51
123
  return {
52
124
  ipaAccumulation: false,
53
- oracleHashType: options?.keccak || options?.keccakZK ? 'keccak' : (options?.starknet || options?.starknetZK ? 'starknet' : 'poseidon2'),
54
- // TODO no current way to target non-zk poseidon2 hash
125
+ oracleHashType:
126
+ options?.keccak || options?.keccakZK
127
+ ? 'keccak'
128
+ : options?.starknet || options?.starknetZK
129
+ ? 'starknet'
130
+ : 'poseidon2',
55
131
  disableZk: options?.keccak || options?.starknet ? true : false,
56
132
  optimizedSolidityVerifier: false,
57
133
  };
58
134
  }
59
135
 
60
136
  export class UltraHonkVerifierBackend {
61
- protected api!: Barretenberg;
62
-
63
- constructor(
64
- protected backendOptions: BackendOptions = { threads: 1 },
65
- protected circuitOptions: CircuitOptions = { recursive: false },
66
- ) {}
67
- /** @ignore */
68
- private async instantiate(): Promise<void> {
69
- if (!this.api) {
70
- const api = await Barretenberg.new(this.backendOptions);
71
- const honkRecursion = true;
72
- await api.initSRSForCircuitSize(0);
73
-
74
- this.api = api;
75
- }
76
- }
77
-
78
- async verifyProof(proofData: ProofData & { verificationKey: Uint8Array }, options?: UltraHonkBackendOptions): Promise<boolean> {
79
- await this.instantiate();
137
+ constructor(private api: Barretenberg) {}
80
138
 
139
+ async verifyProof(
140
+ proofData: ProofData & { verificationKey: Uint8Array },
141
+ options?: UltraHonkBackendOptions,
142
+ ): Promise<boolean> {
81
143
  const proofFrs: Uint8Array[] = [];
82
144
  for (let i = 0; i < proofData.proof.length; i += 32) {
83
145
  proofFrs.push(proofData.proof.slice(i, i + 32));
@@ -90,12 +152,6 @@ export class UltraHonkVerifierBackend {
90
152
  });
91
153
  return verified;
92
154
  }
93
- destroy(): Promise<void> {
94
- if (!this.api) {
95
- return Promise.resolve();
96
- }
97
- return this.api.destroy();
98
- }
99
155
  }
100
156
 
101
157
  export class UltraHonkBackend {
@@ -104,39 +160,25 @@ export class UltraHonkBackend {
104
160
  // These are initialized asynchronously in the `init` function,
105
161
  // constructors cannot be asynchronous which is why we do this.
106
162
 
107
- protected api!: Barretenberg;
108
- protected acirUncompressedBytecode: Uint8Array;
163
+ private acirUncompressedBytecode: Uint8Array;
109
164
 
110
165
  constructor(
111
166
  acirBytecode: string,
112
- protected backendOptions: BackendOptions = { threads: 1 },
113
- protected circuitOptions: CircuitOptions = { recursive: false },
167
+ private api: Barretenberg,
114
168
  ) {
115
169
  this.acirUncompressedBytecode = acirToUint8Array(acirBytecode);
116
170
  }
117
- /** @ignore */
118
- private async instantiate(): Promise<void> {
119
- if (!this.api) {
120
- const api = await Barretenberg.new(this.backendOptions);
121
- const honkRecursion = true;
122
- await api.acirInitSRS(this.acirUncompressedBytecode, this.circuitOptions.recursive, honkRecursion);
123
-
124
- this.api = api;
125
- }
126
- }
127
171
 
128
172
  async generateProof(compressedWitness: Uint8Array, options?: UltraHonkBackendOptions): Promise<ProofData> {
129
- await this.instantiate();
130
-
131
173
  const witness = ungzip(compressedWitness);
132
174
  const { proof, publicInputs } = await this.api.circuitProve({
133
175
  witness,
134
176
  circuit: {
135
177
  name: 'circuit',
136
- bytecode: Buffer.from(this.acirUncompressedBytecode),
137
- verificationKey: Buffer.from([]), // Empty VK - lower performance.
178
+ bytecode: this.acirUncompressedBytecode,
179
+ verificationKey: new Uint8Array(0), // Empty VK - lower performance.
138
180
  },
139
- settings: getProofSettingsFromOptions(options)
181
+ settings: getProofSettingsFromOptions(options),
140
182
  });
141
183
  console.log(`Generated proof for circuit with ${publicInputs.length} public inputs and ${proof.length} fields.`);
142
184
 
@@ -150,8 +192,6 @@ export class UltraHonkBackend {
150
192
  }
151
193
 
152
194
  async verifyProof(proofData: ProofData, options?: UltraHonkBackendOptions): Promise<boolean> {
153
- await this.instantiate();
154
-
155
195
  const proofFrs: Uint8Array[] = [];
156
196
  for (let i = 0; i < proofData.proof.length; i += 32) {
157
197
  proofFrs.push(proofData.proof.slice(i, i + 32));
@@ -164,7 +204,7 @@ export class UltraHonkBackend {
164
204
  },
165
205
  settings: getProofSettingsFromOptions(options),
166
206
  });
167
- const {verified} = await this.api.circuitVerify({
207
+ const { verified } = await this.api.circuitVerify({
168
208
  verificationKey: vkResult.bytes,
169
209
  publicInputs: proofData.publicInputs.map(hexToUint8Array),
170
210
  proof: proofFrs,
@@ -174,12 +214,10 @@ export class UltraHonkBackend {
174
214
  }
175
215
 
176
216
  async getVerificationKey(options?: UltraHonkBackendOptions): Promise<Uint8Array> {
177
- await this.instantiate();
178
-
179
217
  const vkResult = await this.api.circuitComputeVk({
180
218
  circuit: {
181
219
  name: 'circuit',
182
- bytecode: Buffer.from(this.acirUncompressedBytecode),
220
+ bytecode: this.acirUncompressedBytecode,
183
221
  },
184
222
  settings: getProofSettingsFromOptions(options),
185
223
  });
@@ -187,10 +225,12 @@ export class UltraHonkBackend {
187
225
  }
188
226
 
189
227
  /** @description Returns a solidity verifier */
190
- async getSolidityVerifier(vk?: Uint8Array): Promise<string> {
191
- await this.instantiate();
192
- const vkBuf = vk ?? (await this.api.acirWriteVkUltraKeccakHonk(this.acirUncompressedBytecode));
193
- return await this.api.acirHonkSolidityVerifier(this.acirUncompressedBytecode, new RawBuffer(vkBuf));
228
+ async getSolidityVerifier(vk: Uint8Array, options?: UltraHonkBackendOptions): Promise<string> {
229
+ const result = await this.api.circuitWriteSolidityVerifier({
230
+ verificationKey: vk,
231
+ settings: getProofSettingsFromOptions(options),
232
+ });
233
+ return result.solidityCode;
194
234
  }
195
235
 
196
236
  // TODO(https://github.com/noir-lang/noir/issues/5661): Update this to handle Honk recursive aggregation in the browser once it is ready in the backend itself
@@ -200,7 +240,6 @@ export class UltraHonkBackend {
200
240
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
201
241
  _numOfPublicInputs: number,
202
242
  ): Promise<{ proofAsFields: string[]; vkAsFields: string[]; vkHash: string }> {
203
- await this.instantiate();
204
243
  // TODO(https://github.com/noir-lang/noir/issues/5661): This needs to be updated to handle recursive aggregation.
205
244
  // There is still a proofAsFields method but we could consider getting rid of it as the proof itself
206
245
  // is a list of field elements.
@@ -214,7 +253,7 @@ export class UltraHonkBackend {
214
253
  const vkResult = await this.api.circuitComputeVk({
215
254
  circuit: {
216
255
  name: 'circuit',
217
- bytecode: Buffer.from(this.acirUncompressedBytecode),
256
+ bytecode: this.acirUncompressedBytecode,
218
257
  },
219
258
  settings: getProofSettingsFromOptions({}),
220
259
  });
@@ -233,16 +272,9 @@ export class UltraHonkBackend {
233
272
  // We use an empty string for the vk hash here as it is unneeded as part of the recursive artifacts
234
273
  // The user can be expected to hash the vk inside their circuit to check whether the vk is the circuit
235
274
  // they expect
236
- vkHash: uint8ArrayToHex(vkResult.hash)
275
+ vkHash: uint8ArrayToHex(vkResult.hash),
237
276
  };
238
277
  }
239
-
240
- async destroy(): Promise<void> {
241
- if (!this.api) {
242
- return;
243
- }
244
- await this.api.destroy();
245
- }
246
278
  }
247
279
 
248
280
  export class AztecClientBackend {
@@ -251,23 +283,12 @@ export class AztecClientBackend {
251
283
  // These are initialized asynchronously in the `init` function,
252
284
  // constructors cannot be asynchronous which is why we do this.
253
285
 
254
- protected api!: Barretenberg;
255
-
256
286
  constructor(
257
- protected acirBuf: Uint8Array[],
258
- protected options: BackendOptions = { threads: 1 },
287
+ private acirBuf: Uint8Array[],
288
+ private api: Barretenberg,
259
289
  ) {}
260
290
 
261
- /** @ignore */
262
- private async instantiate(): Promise<void> {
263
- if (!this.api) {
264
- const api = await Barretenberg.new(this.options);
265
- await api.initSRSClientIVC();
266
- this.api = api;
267
- }
268
- }
269
-
270
- async prove(witnessBuf: Uint8Array[], vksBuf: Uint8Array[] = []): Promise<[Uint8Array, Uint8Array]> {
291
+ async prove(witnessBuf: Uint8Array[], vksBuf: Uint8Array[] = []): Promise<[Uint8Array[], Uint8Array, Uint8Array]> {
271
292
  if (vksBuf.length !== 0 && this.acirBuf.length !== witnessBuf.length) {
272
293
  throw new AztecClientBackendError('Witness and bytecodes must have the same stack depth!');
273
294
  }
@@ -275,85 +296,81 @@ export class AztecClientBackend {
275
296
  // NOTE: we allow 0 as an explicit 'I have no VKs'. This is a deprecated feature.
276
297
  throw new AztecClientBackendError('Witness and VKs must have the same stack depth!');
277
298
  }
278
- await this.instantiate();
279
299
 
280
300
  // Queue IVC start with the number of circuits
281
- this.api.clientIvcStart({ numCircuits: this.acirBuf.length });
301
+ this.api.chonkStart({ numCircuits: this.acirBuf.length });
282
302
 
283
303
  // Queue load and accumulate for each circuit
284
304
  for (let i = 0; i < this.acirBuf.length; i++) {
285
305
  const bytecode = this.acirBuf[i];
286
- const witness = witnessBuf[i] || Buffer.from([]);
287
- const vk = vksBuf[i] || Buffer.from([]);
306
+ const witness = witnessBuf[i] || new Uint8Array(0);
307
+ const vk = vksBuf[i] || new Uint8Array(0);
288
308
  const functionName = `unknown_wasm_${i}`;
289
309
 
290
310
  // Load the circuit
291
- this.api.clientIvcLoad({
311
+ this.api.chonkLoad({
292
312
  circuit: {
293
313
  name: functionName,
294
- bytecode: Buffer.from(bytecode),
295
- verificationKey: Buffer.from(vk),
296
- }
314
+ bytecode: bytecode,
315
+ verificationKey: vk,
316
+ },
297
317
  });
298
318
 
299
319
  // Accumulate with witness
300
- this.api.clientIvcAccumulate({
301
- witness: Buffer.from(witness),
320
+ this.api.chonkAccumulate({
321
+ witness,
302
322
  });
303
-
304
323
  }
305
324
 
306
-
307
-
308
325
  // Generate the proof (and wait for all previous steps to finish)
309
- const proveResult = await this.api.clientIvcProve({});
326
+ const proveResult = await this.api.chonkProve({});
310
327
  // The API currently expects a msgpack-encoded API.
311
- const proof = new Encoder({useRecords: false}).encode(fromClientIVCProof(proveResult.proof));
328
+ const proof = new Encoder({ useRecords: false }).encode(fromChonkProof(proveResult.proof));
312
329
  // Generate the VK
313
- const vkResult = await this.api.clientIvcComputeIvcVk({ circuit: {
314
- name: 'hiding',
315
- bytecode: this.acirBuf[this.acirBuf.length - 1],
316
- } });
330
+ const vkResult = await this.api.chonkComputeIvcVk({
331
+ circuit: {
332
+ name: 'hiding',
333
+ bytecode: this.acirBuf[this.acirBuf.length - 1],
334
+ },
335
+ });
317
336
 
337
+ const proofFields = [
338
+ proveResult.proof.megaProof,
339
+ proveResult.proof.goblinProof.mergeProof,
340
+ proveResult.proof.goblinProof.eccvmProof,
341
+ proveResult.proof.goblinProof.ipaProof,
342
+ proveResult.proof.goblinProof.translatorProof,
343
+ ].flat();
318
344
 
319
345
  // Note: Verification may not work correctly until we properly serialize the proof
320
346
  if (!(await this.verify(proof, vkResult.bytes))) {
321
- throw new AztecClientBackendError('Failed to verify the private (ClientIVC) transaction proof!');
347
+ throw new AztecClientBackendError('Failed to verify the private (Chonk) transaction proof!');
322
348
  }
323
- return [proof, vkResult.bytes];
349
+ return [proofFields, proof, vkResult.bytes];
324
350
  }
325
351
 
326
352
  async verify(proof: Uint8Array, vk: Uint8Array): Promise<boolean> {
327
- await this.instantiate();
328
- const result = await this.api.clientIvcVerify({
329
- proof: toClientIVCProof(new Decoder({useRecords: false}).decode(proof)),
330
- vk: Buffer.from(vk),
353
+ const result = await this.api.chonkVerify({
354
+ proof: toChonkProof(new Decoder({ useRecords: false }).decode(proof)),
355
+ vk,
331
356
  });
332
357
  return result.valid;
333
358
  }
334
359
 
335
360
  async gates(): Promise<number[]> {
336
- await this.instantiate();
337
361
  const circuitSizes: number[] = [];
338
362
  for (const buf of this.acirBuf) {
339
- const gates = await this.api.clientIvcStats({
363
+ const gates = await this.api.chonkStats({
340
364
  circuit: {
341
365
  name: 'circuit',
342
366
  bytecode: buf,
343
367
  },
344
- includeGatesPerOpcode: false
368
+ includeGatesPerOpcode: false,
345
369
  });
346
370
  circuitSizes.push(gates.circuitSize);
347
371
  }
348
372
  return circuitSizes;
349
373
  }
350
-
351
- async destroy(): Promise<void> {
352
- if (!this.api) {
353
- return;
354
- }
355
- await this.api.destroy();
356
- }
357
374
  }
358
375
 
359
376
  // Converts bytecode from a base64 string to a Uint8Array
@@ -362,17 +379,11 @@ function acirToUint8Array(base64EncodedBytecode: string): Uint8Array {
362
379
  return ungzip(compressedByteCode);
363
380
  }
364
381
 
365
- // Since this is a simple function, we can use feature detection to
366
- // see if we are in the nodeJs environment or the browser environment.
382
+ // Base64 decode using atob (works in both browser and Node.js 18+)
367
383
  function base64Decode(input: string): Uint8Array {
368
- if (typeof Buffer !== 'undefined') {
369
- // Node.js environment
370
- const b = Buffer.from(input, 'base64');
371
- return new Uint8Array(b.buffer, b.byteOffset, b.byteLength);
372
- } else if (typeof atob === 'function') {
373
- // Browser environment
384
+ if (typeof atob === 'function') {
374
385
  return Uint8Array.from(atob(input), c => c.charCodeAt(0));
375
386
  } else {
376
- throw new Error('No implementation found for base64 decoding.');
387
+ throw new Error('atob is not available. Node.js 18+ or browser required.');
377
388
  }
378
389
  }
@@ -1,11 +1,12 @@
1
- import { Barretenberg, BarretenbergSync } from './index.js';
2
- import { Buffer32, Fr } from '../types/index.js';
1
+ import { BackendType, Barretenberg, BarretenbergSync } from './index.js';
2
+ import { Fr } from './testing/fields.js';
3
3
 
4
4
  describe('blake2s async', () => {
5
5
  let api: Barretenberg;
6
6
 
7
7
  beforeAll(async () => {
8
- api = await Barretenberg.new({ threads: 1 });
8
+ // We're going to test over a worker backend to cover more code paths.
9
+ api = await Barretenberg.new({ threads: 1, backend: BackendType.WasmWorker });
9
10
  });
10
11
 
11
12
  afterAll(async () => {
@@ -14,14 +15,12 @@ describe('blake2s async', () => {
14
15
 
15
16
  it('blake2s', async () => {
16
17
  const input = Buffer.from('abcdefghijklmnopqrstuvwxyz0123456789abcdefghijklmnopqrstuvwxyz0123456789');
17
- const expected = Buffer32.fromBuffer(
18
- new Uint8Array([
19
- 0x44, 0xdd, 0xdb, 0x39, 0xbd, 0xb2, 0xaf, 0x80, 0xc1, 0x47, 0x89, 0x4c, 0x1d, 0x75, 0x6a, 0xda, 0x3d, 0x1c,
20
- 0x2a, 0xc2, 0xb1, 0x00, 0x54, 0x1e, 0x04, 0xfe, 0x87, 0xb4, 0xa5, 0x9e, 0x12, 0x43,
21
- ]),
22
- );
23
- const result = await api.blake2s(input);
24
- expect(result).toEqual(expected);
18
+ const expected = new Uint8Array([
19
+ 0x44, 0xdd, 0xdb, 0x39, 0xbd, 0xb2, 0xaf, 0x80, 0xc1, 0x47, 0x89, 0x4c, 0x1d, 0x75, 0x6a, 0xda, 0x3d, 0x1c, 0x2a,
20
+ 0xc2, 0xb1, 0x00, 0x54, 0x1e, 0x04, 0xfe, 0x87, 0xb4, 0xa5, 0x9e, 0x12, 0x43,
21
+ ]);
22
+ const response = await api.blake2s({ data: input });
23
+ expect(response.hash).toEqual(expected);
25
24
  });
26
25
 
27
26
  it('blake2sToField', async () => {
@@ -32,7 +31,8 @@ describe('blake2s async', () => {
32
31
  0x2a, 0xc2, 0xb1, 0x00, 0x54, 0x1e, 0x04, 0xfe, 0x87, 0xb4, 0xa5, 0x9e, 0x12, 0x43,
33
32
  ]),
34
33
  );
35
- const result = await api.blake2sToField(input);
34
+ const response = await api.blake2sToField({ data: input });
35
+ const result = Fr.fromBuffer(response.field);
36
36
  expect(result).toEqual(expected);
37
37
  });
38
38
  });
@@ -46,14 +46,12 @@ describe('blake2s sync', () => {
46
46
 
47
47
  it('blake2s', () => {
48
48
  const input = Buffer.from('abcdefghijklmnopqrstuvwxyz0123456789abcdefghijklmnopqrstuvwxyz0123456789');
49
- const expected = Buffer32.fromBuffer(
50
- new Uint8Array([
51
- 0x44, 0xdd, 0xdb, 0x39, 0xbd, 0xb2, 0xaf, 0x80, 0xc1, 0x47, 0x89, 0x4c, 0x1d, 0x75, 0x6a, 0xda, 0x3d, 0x1c,
52
- 0x2a, 0xc2, 0xb1, 0x00, 0x54, 0x1e, 0x04, 0xfe, 0x87, 0xb4, 0xa5, 0x9e, 0x12, 0x43,
53
- ]),
54
- );
55
- const result = api.blake2s(input);
56
- expect(result).toEqual(expected);
49
+ const expected = new Uint8Array([
50
+ 0x44, 0xdd, 0xdb, 0x39, 0xbd, 0xb2, 0xaf, 0x80, 0xc1, 0x47, 0x89, 0x4c, 0x1d, 0x75, 0x6a, 0xda, 0x3d, 0x1c, 0x2a,
51
+ 0xc2, 0xb1, 0x00, 0x54, 0x1e, 0x04, 0xfe, 0x87, 0xb4, 0xa5, 0x9e, 0x12, 0x43,
52
+ ]);
53
+ const response = api.blake2s({ data: input });
54
+ expect(response.hash).toEqual(expected);
57
55
  });
58
56
 
59
57
  it('blake2sToField', () => {
@@ -64,7 +62,8 @@ describe('blake2s sync', () => {
64
62
  0x2a, 0xc2, 0xb1, 0x00, 0x54, 0x1e, 0x04, 0xfe, 0x87, 0xb4, 0xa5, 0x9e, 0x12, 0x43,
65
63
  ]),
66
64
  );
67
- const result = api.blake2sToField(input);
65
+ const response = api.blake2sToField({ data: input });
66
+ const result = Fr.fromBuffer(response.field);
68
67
  expect(result).toEqual(expected);
69
68
  });
70
69
  });