@aztec/bb.js 0.0.1-alpha.6 → 0.0.1-commit.21caa21

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 (777) hide show
  1. package/README.md +55 -85
  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/{async_map → browser/async_map}/index.d.ts +1 -1
  11. package/dest/browser/async_map/index.d.ts.map +1 -0
  12. package/dest/{async_map → browser/async_map}/index.js +1 -1
  13. package/dest/browser/barretenberg/backend.d.ts +61 -0
  14. package/dest/browser/barretenberg/backend.d.ts.map +1 -0
  15. package/dest/browser/barretenberg/backend.js +250 -0
  16. package/dest/browser/barretenberg/index.d.ts +65 -0
  17. package/dest/browser/barretenberg/index.d.ts.map +1 -0
  18. package/dest/browser/barretenberg/index.js +182 -0
  19. package/dest/browser/barretenberg/testing/bigint-buffer.d.ts +17 -0
  20. package/dest/browser/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  21. package/dest/browser/barretenberg/testing/bigint-buffer.js +37 -0
  22. package/dest/browser/barretenberg/testing/fields.d.ts +16 -0
  23. package/dest/browser/barretenberg/testing/fields.d.ts.map +1 -0
  24. package/dest/browser/barretenberg/testing/fields.js +47 -0
  25. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +45 -0
  26. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
  27. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.js +124 -0
  28. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
  29. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
  30. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -0
  31. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
  32. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
  33. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +6 -0
  34. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
  35. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
  36. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +71 -0
  37. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
  38. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
  39. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.js +197 -0
  40. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
  41. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
  42. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -0
  43. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
  44. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
  45. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +6 -0
  46. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
  47. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
  48. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.js +41 -0
  49. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
  50. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
  51. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +2 -0
  52. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
  53. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
  54. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.js +2 -0
  55. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
  56. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
  57. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.js +36 -0
  58. package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts +2 -0
  59. package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
  60. package/dest/browser/barretenberg_wasm/fetch_code/index.js +2 -0
  61. package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
  62. package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
  63. package/dest/browser/barretenberg_wasm/helpers/browser/index.js +47 -0
  64. package/dest/browser/barretenberg_wasm/helpers/index.d.ts +2 -0
  65. package/dest/browser/barretenberg_wasm/helpers/index.d.ts.map +1 -0
  66. package/dest/browser/barretenberg_wasm/helpers/index.js +2 -0
  67. package/dest/browser/barretenberg_wasm/index.d.ts +5 -0
  68. package/dest/browser/barretenberg_wasm/index.d.ts.map +1 -0
  69. package/dest/browser/barretenberg_wasm/index.js +15 -0
  70. package/dest/browser/bb_backends/browser/index.d.ts +11 -0
  71. package/dest/browser/bb_backends/browser/index.d.ts.map +1 -0
  72. package/dest/browser/bb_backends/browser/index.js +39 -0
  73. package/dest/browser/bb_backends/browser/platform.d.ts +4 -0
  74. package/dest/browser/bb_backends/browser/platform.d.ts.map +1 -0
  75. package/dest/browser/bb_backends/browser/platform.js +10 -0
  76. package/dest/browser/bb_backends/index.d.ts +48 -0
  77. package/dest/browser/bb_backends/index.d.ts.map +1 -0
  78. package/dest/browser/bb_backends/index.js +16 -0
  79. package/dest/browser/bb_backends/interface.d.ts +33 -0
  80. package/dest/browser/bb_backends/interface.d.ts.map +1 -0
  81. package/dest/browser/bb_backends/interface.js +2 -0
  82. package/dest/browser/bb_backends/wasm.d.ts +49 -0
  83. package/dest/browser/bb_backends/wasm.d.ts.map +1 -0
  84. package/dest/browser/bb_backends/wasm.js +85 -0
  85. package/dest/browser/bbapi_exception.d.ts +7 -0
  86. package/dest/browser/bbapi_exception.d.ts.map +1 -0
  87. package/dest/browser/bbapi_exception.js +14 -0
  88. package/dest/browser/bin/index.d.ts +3 -0
  89. package/dest/{bindgen → browser/bin}/index.d.ts.map +1 -1
  90. package/dest/browser/bin/index.js +11 -0
  91. package/dest/browser/cbind/generate.d.ts +5 -0
  92. package/dest/browser/cbind/generate.d.ts.map +1 -0
  93. package/dest/browser/cbind/generate.js +151 -0
  94. package/dest/browser/cbind/generated/api_types.d.ts +2051 -0
  95. package/dest/browser/cbind/generated/api_types.d.ts.map +1 -0
  96. package/dest/browser/cbind/generated/api_types.js +2747 -0
  97. package/dest/browser/cbind/generated/async.d.ts +62 -0
  98. package/dest/browser/cbind/generated/async.d.ts.map +1 -0
  99. package/dest/browser/cbind/generated/async.js +663 -0
  100. package/dest/browser/cbind/generated/curve_constants.d.ts +45 -0
  101. package/dest/browser/cbind/generated/curve_constants.d.ts.map +1 -0
  102. package/dest/browser/cbind/generated/curve_constants.js +45 -0
  103. package/dest/browser/cbind/generated/sync.d.ts +62 -0
  104. package/dest/browser/cbind/generated/sync.d.ts.map +1 -0
  105. package/dest/browser/cbind/generated/sync.js +610 -0
  106. package/dest/browser/cbind/schema_compiler.d.ts +68 -0
  107. package/dest/browser/cbind/schema_compiler.d.ts.map +1 -0
  108. package/dest/browser/cbind/schema_compiler.js +600 -0
  109. package/dest/browser/crs/browser/cached_net_crs.d.ts +43 -0
  110. package/dest/browser/crs/browser/cached_net_crs.d.ts.map +1 -0
  111. package/dest/browser/crs/browser/cached_net_crs.js +95 -0
  112. package/dest/browser/crs/browser/index.d.ts +2 -0
  113. package/dest/browser/crs/browser/index.d.ts.map +1 -0
  114. package/dest/browser/crs/browser/index.js +2 -0
  115. package/dest/browser/crs/index.d.ts +2 -0
  116. package/dest/browser/crs/index.d.ts.map +1 -0
  117. package/dest/browser/crs/index.js +2 -0
  118. package/dest/browser/crs/net_crs.d.ts +70 -0
  119. package/dest/browser/crs/net_crs.d.ts.map +1 -0
  120. package/dest/browser/crs/net_crs.js +141 -0
  121. package/dest/browser/index.d.ts +9 -0
  122. package/dest/browser/index.d.ts.map +1 -0
  123. package/dest/browser/index.js +9 -0
  124. package/dest/browser/proof/index.d.ts +21 -0
  125. package/dest/browser/proof/index.d.ts.map +1 -0
  126. package/dest/browser/proof/index.js +63 -0
  127. package/dest/browser/random/browser/index.d.ts +2 -0
  128. package/dest/browser/random/browser/index.d.ts.map +1 -0
  129. package/dest/browser/random/browser/index.js +31 -0
  130. package/dest/browser/random/index.d.ts +2 -0
  131. package/dest/browser/random/index.d.ts.map +1 -0
  132. package/dest/browser/random/index.js +2 -0
  133. package/dest/browser/retry/index.d.ts +26 -0
  134. package/dest/browser/retry/index.d.ts.map +1 -0
  135. package/dest/browser/retry/index.js +50 -0
  136. package/dest/node/async_map/index.d.ts +10 -0
  137. package/dest/node/async_map/index.d.ts.map +1 -0
  138. package/dest/node/async_map/index.js +16 -0
  139. package/dest/node/barretenberg/__snapshots__/pedersen.test.js.snap +156 -0
  140. package/dest/node/barretenberg/__snapshots__/poseidon.test.js.snap +40 -0
  141. package/dest/node/barretenberg/backend.d.ts +61 -0
  142. package/dest/node/barretenberg/backend.d.ts.map +1 -0
  143. package/dest/node/barretenberg/backend.js +250 -0
  144. package/dest/node/barretenberg/blake2s.test.d.ts +2 -0
  145. package/dest/node/barretenberg/blake2s.test.d.ts.map +1 -0
  146. package/dest/node/barretenberg/blake2s.test.js +57 -0
  147. package/dest/node/barretenberg/index.d.ts +65 -0
  148. package/dest/node/barretenberg/index.d.ts.map +1 -0
  149. package/dest/node/barretenberg/index.js +182 -0
  150. package/dest/node/barretenberg/pedersen.test.d.ts +2 -0
  151. package/dest/node/barretenberg/pedersen.test.d.ts.map +1 -0
  152. package/dest/node/barretenberg/pedersen.test.js +62 -0
  153. package/dest/node/barretenberg/poseidon.bench.test.d.ts +2 -0
  154. package/dest/node/barretenberg/poseidon.bench.test.d.ts.map +1 -0
  155. package/dest/node/barretenberg/poseidon.bench.test.js +218 -0
  156. package/dest/node/barretenberg/poseidon.test.d.ts +2 -0
  157. package/dest/node/barretenberg/poseidon.test.d.ts.map +1 -0
  158. package/dest/node/barretenberg/poseidon.test.js +35 -0
  159. package/dest/node/barretenberg/testing/bigint-buffer.d.ts +17 -0
  160. package/dest/node/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  161. package/dest/node/barretenberg/testing/bigint-buffer.js +37 -0
  162. package/dest/node/barretenberg/testing/fields.d.ts +16 -0
  163. package/dest/node/barretenberg/testing/fields.d.ts.map +1 -0
  164. package/dest/node/barretenberg/testing/fields.js +47 -0
  165. package/dest/node/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  166. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +45 -0
  167. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
  168. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.js +124 -0
  169. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
  170. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
  171. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -0
  172. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
  173. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
  174. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +6 -0
  175. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +3 -0
  176. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -0
  177. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +19 -0
  178. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +2 -0
  179. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts.map +1 -0
  180. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +9 -0
  181. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
  182. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
  183. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +71 -0
  184. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
  185. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
  186. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.js +197 -0
  187. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
  188. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
  189. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -0
  190. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
  191. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
  192. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +6 -0
  193. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +3 -0
  194. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -0
  195. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +19 -0
  196. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +2 -0
  197. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts.map +1 -0
  198. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +10 -0
  199. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
  200. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
  201. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.js +41 -0
  202. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
  203. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
  204. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +3 -0
  205. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
  206. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
  207. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.js +3 -0
  208. package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
  209. package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
  210. package/dest/node/barretenberg_wasm/fetch_code/browser/index.js +36 -0
  211. package/dest/node/barretenberg_wasm/fetch_code/index.d.ts +2 -0
  212. package/dest/node/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
  213. package/dest/node/barretenberg_wasm/fetch_code/index.js +2 -0
  214. package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts +2 -0
  215. package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts.map +1 -0
  216. package/dest/node/barretenberg_wasm/fetch_code/node/index.js +35 -0
  217. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
  218. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
  219. package/dest/node/barretenberg_wasm/helpers/browser/index.js +47 -0
  220. package/dest/node/barretenberg_wasm/helpers/index.d.ts +2 -0
  221. package/dest/node/barretenberg_wasm/helpers/index.d.ts.map +1 -0
  222. package/dest/node/barretenberg_wasm/helpers/index.js +2 -0
  223. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts +21 -0
  224. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts.map +1 -0
  225. package/dest/node/barretenberg_wasm/helpers/node/index.js +56 -0
  226. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts +8 -0
  227. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -0
  228. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.js +28 -0
  229. package/dest/node/barretenberg_wasm/index.d.ts +5 -0
  230. package/dest/node/barretenberg_wasm/index.d.ts.map +1 -0
  231. package/dest/node/barretenberg_wasm/index.js +15 -0
  232. package/dest/node/barretenberg_wasm/index.test.d.ts +2 -0
  233. package/dest/node/barretenberg_wasm/index.test.d.ts.map +1 -0
  234. package/dest/node/barretenberg_wasm/index.test.js +39 -0
  235. package/dest/node/bb_backends/browser/index.d.ts +11 -0
  236. package/dest/node/bb_backends/browser/index.d.ts.map +1 -0
  237. package/dest/node/bb_backends/browser/index.js +39 -0
  238. package/dest/node/bb_backends/browser/platform.d.ts +4 -0
  239. package/dest/node/bb_backends/browser/platform.d.ts.map +1 -0
  240. package/dest/node/bb_backends/browser/platform.js +10 -0
  241. package/dest/node/bb_backends/index.d.ts +48 -0
  242. package/dest/node/bb_backends/index.d.ts.map +1 -0
  243. package/dest/node/bb_backends/index.js +16 -0
  244. package/dest/node/bb_backends/interface.d.ts +33 -0
  245. package/dest/node/bb_backends/interface.d.ts.map +1 -0
  246. package/dest/node/bb_backends/interface.js +2 -0
  247. package/dest/node/bb_backends/node/index.d.ts +11 -0
  248. package/dest/node/bb_backends/node/index.d.ts.map +1 -0
  249. package/dest/node/bb_backends/node/index.js +86 -0
  250. package/dest/node/bb_backends/node/native_pipe.d.ts +25 -0
  251. package/dest/node/bb_backends/node/native_pipe.d.ts.map +1 -0
  252. package/dest/node/bb_backends/node/native_pipe.js +114 -0
  253. package/dest/node/bb_backends/node/native_shm.d.ts +28 -0
  254. package/dest/node/bb_backends/node/native_shm.d.ts.map +1 -0
  255. package/dest/node/bb_backends/node/native_shm.js +177 -0
  256. package/dest/node/bb_backends/node/native_shm_async.d.ts +51 -0
  257. package/dest/node/bb_backends/node/native_shm_async.d.ts.map +1 -0
  258. package/dest/node/bb_backends/node/native_shm_async.js +237 -0
  259. package/dest/node/bb_backends/node/native_socket.d.ts +34 -0
  260. package/dest/node/bb_backends/node/native_socket.d.ts.map +1 -0
  261. package/dest/node/bb_backends/node/native_socket.js +281 -0
  262. package/dest/node/bb_backends/node/platform.d.ts +27 -0
  263. package/dest/node/bb_backends/node/platform.d.ts.map +1 -0
  264. package/dest/node/bb_backends/node/platform.js +124 -0
  265. package/dest/node/bb_backends/wasm.d.ts +49 -0
  266. package/dest/node/bb_backends/wasm.d.ts.map +1 -0
  267. package/dest/node/bb_backends/wasm.js +85 -0
  268. package/dest/node/bbapi/exception_handling.test.d.ts +2 -0
  269. package/dest/node/bbapi/exception_handling.test.d.ts.map +1 -0
  270. package/dest/node/bbapi/exception_handling.test.js +48 -0
  271. package/dest/node/bbapi_exception.d.ts +7 -0
  272. package/dest/node/bbapi_exception.d.ts.map +1 -0
  273. package/dest/node/bbapi_exception.js +14 -0
  274. package/dest/node/benchmark/index.d.ts +3 -0
  275. package/dest/node/benchmark/index.d.ts.map +1 -0
  276. package/dest/node/benchmark/index.js +25 -0
  277. package/dest/node/benchmark/timer.d.ts +34 -0
  278. package/dest/node/benchmark/timer.d.ts.map +1 -0
  279. package/dest/node/benchmark/timer.js +42 -0
  280. package/dest/node/bin/index.d.ts +3 -0
  281. package/dest/node/bin/index.d.ts.map +1 -0
  282. package/dest/node/bin/index.js +11 -0
  283. package/dest/node/cbind/generate.d.ts +5 -0
  284. package/dest/node/cbind/generate.d.ts.map +1 -0
  285. package/dest/node/cbind/generate.js +151 -0
  286. package/dest/node/cbind/generated/api_types.d.ts +2051 -0
  287. package/dest/node/cbind/generated/api_types.d.ts.map +1 -0
  288. package/dest/node/cbind/generated/api_types.js +2747 -0
  289. package/dest/node/cbind/generated/async.d.ts +62 -0
  290. package/dest/node/cbind/generated/async.d.ts.map +1 -0
  291. package/dest/node/cbind/generated/async.js +663 -0
  292. package/dest/node/cbind/generated/curve_constants.d.ts +45 -0
  293. package/dest/node/cbind/generated/curve_constants.d.ts.map +1 -0
  294. package/dest/node/cbind/generated/curve_constants.js +45 -0
  295. package/dest/node/cbind/generated/sync.d.ts +62 -0
  296. package/dest/node/cbind/generated/sync.d.ts.map +1 -0
  297. package/dest/node/cbind/generated/sync.js +610 -0
  298. package/dest/node/cbind/schema_compiler.d.ts +68 -0
  299. package/dest/node/cbind/schema_compiler.d.ts.map +1 -0
  300. package/dest/node/cbind/schema_compiler.js +600 -0
  301. package/dest/node/crs/browser/cached_net_crs.d.ts +43 -0
  302. package/dest/node/crs/browser/cached_net_crs.d.ts.map +1 -0
  303. package/dest/node/crs/browser/cached_net_crs.js +95 -0
  304. package/dest/node/crs/browser/index.d.ts +2 -0
  305. package/dest/node/crs/browser/index.d.ts.map +1 -0
  306. package/dest/node/crs/browser/index.js +2 -0
  307. package/dest/node/crs/index.d.ts +2 -0
  308. package/dest/node/crs/index.d.ts.map +1 -0
  309. package/dest/node/crs/index.js +2 -0
  310. package/dest/node/crs/net_crs.d.ts +70 -0
  311. package/dest/node/crs/net_crs.d.ts.map +1 -0
  312. package/dest/node/crs/net_crs.js +141 -0
  313. package/dest/node/crs/node/index.d.ts +38 -0
  314. package/dest/node/crs/node/index.d.ts.map +1 -0
  315. package/dest/node/crs/node/index.js +107 -0
  316. package/dest/node/index.d.ts +9 -0
  317. package/dest/node/index.d.ts.map +1 -0
  318. package/dest/node/index.js +9 -0
  319. package/dest/node/proof/index.d.ts +21 -0
  320. package/dest/node/proof/index.d.ts.map +1 -0
  321. package/dest/node/proof/index.js +63 -0
  322. package/dest/node/random/browser/index.d.ts +2 -0
  323. package/dest/node/random/browser/index.d.ts.map +1 -0
  324. package/dest/node/random/browser/index.js +31 -0
  325. package/dest/node/random/index.d.ts +2 -0
  326. package/dest/node/random/index.d.ts.map +1 -0
  327. package/dest/{random → node/random}/index.js +1 -1
  328. package/dest/node/random/node/index.d.ts +2 -0
  329. package/dest/node/random/node/index.d.ts.map +1 -0
  330. package/dest/node/random/node/index.js +5 -0
  331. package/dest/node/retry/index.d.ts +26 -0
  332. package/dest/node/retry/index.d.ts.map +1 -0
  333. package/dest/node/retry/index.js +50 -0
  334. package/dest/node-cjs/async_map/index.d.ts +10 -0
  335. package/dest/node-cjs/async_map/index.d.ts.map +1 -0
  336. package/dest/node-cjs/async_map/index.js +19 -0
  337. package/dest/node-cjs/barretenberg/backend.d.ts +61 -0
  338. package/dest/node-cjs/barretenberg/backend.d.ts.map +1 -0
  339. package/dest/node-cjs/barretenberg/backend.js +257 -0
  340. package/dest/node-cjs/barretenberg/blake2s.test.d.ts +2 -0
  341. package/dest/node-cjs/barretenberg/blake2s.test.d.ts.map +1 -0
  342. package/dest/node-cjs/barretenberg/blake2s.test.js +59 -0
  343. package/dest/node-cjs/barretenberg/index.d.ts +65 -0
  344. package/dest/node-cjs/barretenberg/index.d.ts.map +1 -0
  345. package/dest/node-cjs/barretenberg/index.js +191 -0
  346. package/dest/node-cjs/barretenberg/pedersen.test.d.ts +2 -0
  347. package/dest/node-cjs/barretenberg/pedersen.test.d.ts.map +1 -0
  348. package/dest/node-cjs/barretenberg/pedersen.test.js +64 -0
  349. package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts +2 -0
  350. package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts.map +1 -0
  351. package/dest/node-cjs/barretenberg/poseidon.bench.test.js +220 -0
  352. package/dest/node-cjs/barretenberg/poseidon.test.d.ts +2 -0
  353. package/dest/node-cjs/barretenberg/poseidon.test.d.ts.map +1 -0
  354. package/dest/node-cjs/barretenberg/poseidon.test.js +37 -0
  355. package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts +17 -0
  356. package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  357. package/dest/node-cjs/barretenberg/testing/bigint-buffer.js +43 -0
  358. package/dest/node-cjs/barretenberg/testing/fields.d.ts +16 -0
  359. package/dest/node-cjs/barretenberg/testing/fields.d.ts.map +1 -0
  360. package/dest/node-cjs/barretenberg/testing/fields.js +51 -0
  361. package/dest/node-cjs/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  362. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +45 -0
  363. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
  364. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.js +128 -0
  365. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
  366. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
  367. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +12 -0
  368. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
  369. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
  370. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +8 -0
  371. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +3 -0
  372. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -0
  373. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +22 -0
  374. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +2 -0
  375. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts.map +1 -0
  376. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +11 -0
  377. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
  378. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
  379. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +75 -0
  380. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
  381. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
  382. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.js +201 -0
  383. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
  384. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
  385. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +12 -0
  386. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
  387. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
  388. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +8 -0
  389. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +3 -0
  390. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -0
  391. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +22 -0
  392. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +2 -0
  393. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts.map +1 -0
  394. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +12 -0
  395. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
  396. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
  397. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.js +45 -0
  398. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
  399. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
  400. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +6 -0
  401. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
  402. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
  403. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.js +6 -0
  404. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
  405. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
  406. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.js +40 -0
  407. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts +2 -0
  408. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
  409. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.js +5 -0
  410. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts +2 -0
  411. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts.map +1 -0
  412. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.js +39 -0
  413. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
  414. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
  415. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.js +57 -0
  416. package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts +2 -0
  417. package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts.map +1 -0
  418. package/dest/node-cjs/barretenberg_wasm/helpers/index.js +5 -0
  419. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts +21 -0
  420. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts.map +1 -0
  421. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.js +65 -0
  422. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts +8 -0
  423. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -0
  424. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.js +31 -0
  425. package/dest/node-cjs/barretenberg_wasm/index.d.ts +5 -0
  426. package/dest/node-cjs/barretenberg_wasm/index.d.ts.map +1 -0
  427. package/dest/node-cjs/barretenberg_wasm/index.js +18 -0
  428. package/dest/node-cjs/barretenberg_wasm/index.test.d.ts +2 -0
  429. package/dest/node-cjs/barretenberg_wasm/index.test.d.ts.map +1 -0
  430. package/dest/node-cjs/barretenberg_wasm/index.test.js +41 -0
  431. package/dest/node-cjs/bb_backends/browser/index.d.ts +11 -0
  432. package/dest/node-cjs/bb_backends/browser/index.d.ts.map +1 -0
  433. package/dest/node-cjs/bb_backends/browser/index.js +43 -0
  434. package/dest/node-cjs/bb_backends/browser/platform.d.ts +4 -0
  435. package/dest/node-cjs/bb_backends/browser/platform.d.ts.map +1 -0
  436. package/dest/node-cjs/bb_backends/browser/platform.js +15 -0
  437. package/dest/node-cjs/bb_backends/index.d.ts +48 -0
  438. package/dest/node-cjs/bb_backends/index.d.ts.map +1 -0
  439. package/dest/node-cjs/bb_backends/index.js +18 -0
  440. package/dest/node-cjs/bb_backends/interface.d.ts +33 -0
  441. package/dest/node-cjs/bb_backends/interface.d.ts.map +1 -0
  442. package/dest/node-cjs/bb_backends/interface.js +3 -0
  443. package/dest/node-cjs/bb_backends/node/index.d.ts +11 -0
  444. package/dest/node-cjs/bb_backends/node/index.d.ts.map +1 -0
  445. package/dest/node-cjs/bb_backends/node/index.js +90 -0
  446. package/dest/node-cjs/bb_backends/node/native_pipe.d.ts +25 -0
  447. package/dest/node-cjs/bb_backends/node/native_pipe.d.ts.map +1 -0
  448. package/dest/node-cjs/bb_backends/node/native_pipe.js +118 -0
  449. package/dest/node-cjs/bb_backends/node/native_shm.d.ts +28 -0
  450. package/dest/node-cjs/bb_backends/node/native_shm.d.ts.map +1 -0
  451. package/dest/node-cjs/bb_backends/node/native_shm.js +181 -0
  452. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts +51 -0
  453. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts.map +1 -0
  454. package/dest/node-cjs/bb_backends/node/native_shm_async.js +241 -0
  455. package/dest/node-cjs/bb_backends/node/native_socket.d.ts +34 -0
  456. package/dest/node-cjs/bb_backends/node/native_socket.d.ts.map +1 -0
  457. package/dest/node-cjs/bb_backends/node/native_socket.js +286 -0
  458. package/dest/node-cjs/bb_backends/node/platform.d.ts +27 -0
  459. package/dest/node-cjs/bb_backends/node/platform.d.ts.map +1 -0
  460. package/dest/node-cjs/bb_backends/node/platform.js +131 -0
  461. package/dest/node-cjs/bb_backends/wasm.d.ts +49 -0
  462. package/dest/node-cjs/bb_backends/wasm.d.ts.map +1 -0
  463. package/dest/node-cjs/bb_backends/wasm.js +90 -0
  464. package/dest/node-cjs/bbapi/exception_handling.test.d.ts +2 -0
  465. package/dest/node-cjs/bbapi/exception_handling.test.d.ts.map +1 -0
  466. package/dest/node-cjs/bbapi/exception_handling.test.js +50 -0
  467. package/dest/node-cjs/bbapi_exception.d.ts +7 -0
  468. package/dest/node-cjs/bbapi_exception.d.ts.map +1 -0
  469. package/dest/node-cjs/bbapi_exception.js +18 -0
  470. package/dest/node-cjs/benchmark/index.d.ts +3 -0
  471. package/dest/node-cjs/benchmark/index.d.ts.map +1 -0
  472. package/dest/node-cjs/benchmark/index.js +29 -0
  473. package/dest/node-cjs/benchmark/timer.d.ts +34 -0
  474. package/dest/node-cjs/benchmark/timer.d.ts.map +1 -0
  475. package/dest/node-cjs/benchmark/timer.js +46 -0
  476. package/dest/node-cjs/bin/index.d.ts +3 -0
  477. package/dest/node-cjs/bin/index.d.ts.map +1 -0
  478. package/dest/node-cjs/bin/index.js +13 -0
  479. package/dest/node-cjs/cbind/generate.d.ts +5 -0
  480. package/dest/node-cjs/cbind/generate.d.ts.map +1 -0
  481. package/dest/node-cjs/cbind/generate.js +153 -0
  482. package/dest/node-cjs/cbind/generated/api_types.d.ts +2051 -0
  483. package/dest/node-cjs/cbind/generated/api_types.d.ts.map +1 -0
  484. package/dest/node-cjs/cbind/generated/api_types.js +2989 -0
  485. package/dest/node-cjs/cbind/generated/async.d.ts +62 -0
  486. package/dest/node-cjs/cbind/generated/async.d.ts.map +1 -0
  487. package/dest/node-cjs/cbind/generated/async.js +667 -0
  488. package/dest/node-cjs/cbind/generated/curve_constants.d.ts +45 -0
  489. package/dest/node-cjs/cbind/generated/curve_constants.d.ts.map +1 -0
  490. package/dest/node-cjs/cbind/generated/curve_constants.js +48 -0
  491. package/dest/node-cjs/cbind/generated/sync.d.ts +62 -0
  492. package/dest/node-cjs/cbind/generated/sync.d.ts.map +1 -0
  493. package/dest/node-cjs/cbind/generated/sync.js +614 -0
  494. package/dest/node-cjs/cbind/schema_compiler.d.ts +68 -0
  495. package/dest/node-cjs/cbind/schema_compiler.d.ts.map +1 -0
  496. package/dest/node-cjs/cbind/schema_compiler.js +607 -0
  497. package/dest/node-cjs/crs/browser/cached_net_crs.d.ts +43 -0
  498. package/dest/node-cjs/crs/browser/cached_net_crs.d.ts.map +1 -0
  499. package/dest/node-cjs/crs/browser/cached_net_crs.js +100 -0
  500. package/dest/node-cjs/crs/browser/index.d.ts +2 -0
  501. package/dest/node-cjs/crs/browser/index.d.ts.map +1 -0
  502. package/dest/node-cjs/crs/browser/index.js +7 -0
  503. package/dest/node-cjs/crs/index.d.ts +2 -0
  504. package/dest/node-cjs/crs/index.d.ts.map +1 -0
  505. package/dest/node-cjs/crs/index.js +7 -0
  506. package/dest/node-cjs/crs/net_crs.d.ts +70 -0
  507. package/dest/node-cjs/crs/net_crs.d.ts.map +1 -0
  508. package/dest/node-cjs/crs/net_crs.js +146 -0
  509. package/dest/node-cjs/crs/node/index.d.ts +38 -0
  510. package/dest/node-cjs/crs/node/index.d.ts.map +1 -0
  511. package/dest/node-cjs/crs/node/index.js +112 -0
  512. package/dest/node-cjs/index.d.ts +9 -0
  513. package/dest/node-cjs/index.d.ts.map +1 -0
  514. package/dest/node-cjs/index.js +39 -0
  515. package/dest/node-cjs/package.json +3 -0
  516. package/dest/node-cjs/proof/index.d.ts +21 -0
  517. package/dest/node-cjs/proof/index.d.ts.map +1 -0
  518. package/dest/node-cjs/proof/index.js +72 -0
  519. package/dest/node-cjs/random/browser/index.d.ts +2 -0
  520. package/dest/node-cjs/random/browser/index.d.ts.map +1 -0
  521. package/dest/node-cjs/random/browser/index.js +35 -0
  522. package/dest/node-cjs/random/index.d.ts +2 -0
  523. package/dest/node-cjs/random/index.d.ts.map +1 -0
  524. package/dest/node-cjs/random/index.js +5 -0
  525. package/dest/node-cjs/random/node/index.d.ts +2 -0
  526. package/dest/node-cjs/random/node/index.d.ts.map +1 -0
  527. package/dest/node-cjs/random/node/index.js +8 -0
  528. package/dest/node-cjs/retry/index.d.ts +26 -0
  529. package/dest/node-cjs/retry/index.d.ts.map +1 -0
  530. package/dest/node-cjs/retry/index.js +55 -0
  531. package/package.json +59 -42
  532. package/src/barretenberg/__snapshots__/pedersen.test.ts.snap +156 -0
  533. package/src/barretenberg/__snapshots__/poseidon.test.ts.snap +40 -0
  534. package/src/barretenberg/backend.ts +312 -0
  535. package/src/barretenberg/blake2s.test.ts +69 -0
  536. package/src/barretenberg/index.ts +212 -0
  537. package/src/barretenberg/pedersen.test.ts +69 -0
  538. package/src/barretenberg/poseidon.bench.test.ts +271 -0
  539. package/src/barretenberg/poseidon.test.ts +39 -0
  540. package/src/barretenberg/testing/bigint-buffer.ts +43 -0
  541. package/src/barretenberg/testing/fields.ts +63 -0
  542. package/src/barretenberg_wasm/barretenberg_wasm_base/index.ts +137 -0
  543. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.ts +9 -0
  544. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.ts +6 -0
  545. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.ts +19 -0
  546. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.ts +10 -0
  547. package/src/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.ts +72 -0
  548. package/src/barretenberg_wasm/barretenberg_wasm_main/index.ts +251 -0
  549. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.ts +9 -0
  550. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.ts +6 -0
  551. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.ts +19 -0
  552. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.ts +12 -0
  553. package/src/barretenberg_wasm/barretenberg_wasm_thread/index.ts +48 -0
  554. package/src/barretenberg_wasm/fetch_code/browser/barretenberg-threads.ts +3 -0
  555. package/src/barretenberg_wasm/fetch_code/browser/barretenberg.ts +3 -0
  556. package/src/barretenberg_wasm/fetch_code/browser/index.ts +34 -0
  557. package/src/barretenberg_wasm/fetch_code/index.ts +1 -0
  558. package/src/barretenberg_wasm/fetch_code/node/index.ts +34 -0
  559. package/src/barretenberg_wasm/fetch_code/wasm-module.d.ts +4 -0
  560. package/src/barretenberg_wasm/helpers/browser/index.ts +54 -0
  561. package/src/barretenberg_wasm/helpers/index.ts +1 -0
  562. package/src/barretenberg_wasm/helpers/node/index.ts +62 -0
  563. package/src/barretenberg_wasm/index.test.ts +46 -0
  564. package/src/barretenberg_wasm/index.ts +21 -1
  565. package/src/bb_backends/browser/index.ts +50 -0
  566. package/src/bb_backends/browser/platform.ts +11 -0
  567. package/src/bb_backends/index.ts +52 -0
  568. package/src/bb_backends/interface.ts +35 -0
  569. package/src/bb_backends/node/index.ts +102 -0
  570. package/src/bb_backends/node/native_pipe.ts +127 -0
  571. package/src/bb_backends/node/native_shm.ts +195 -0
  572. package/src/bb_backends/node/native_shm_async.ts +266 -0
  573. package/src/bb_backends/node/native_socket.ts +326 -0
  574. package/src/bb_backends/node/platform.ts +151 -0
  575. package/src/bb_backends/wasm.ts +102 -0
  576. package/src/bbapi/exception_handling.test.ts +54 -0
  577. package/src/bbapi_exception.ts +13 -0
  578. package/src/benchmark/index.ts +26 -0
  579. package/src/benchmark/timer.ts +45 -0
  580. package/src/bin/index.ts +14 -0
  581. package/src/cbind/README.md +1 -0
  582. package/src/cbind/generate.ts +182 -0
  583. package/src/cbind/schema_compiler.ts +745 -0
  584. package/src/crs/browser/cached_net_crs.ts +41 -2
  585. package/src/crs/browser/index.ts +1 -1
  586. package/src/crs/index.ts +1 -1
  587. package/src/crs/net_crs.ts +114 -19
  588. package/src/crs/node/index.ts +97 -20
  589. package/src/index.html +1 -1
  590. package/src/index.ts +43 -5
  591. package/src/proof/index.ts +94 -0
  592. package/src/random/browser/index.ts +1 -1
  593. package/src/retry/index.ts +50 -0
  594. package/dest/async_map/index.d.ts.map +0 -1
  595. package/dest/barretenberg-threads.wasm +0 -0
  596. package/dest/barretenberg.wasm +0 -0
  597. package/dest/barretenberg_api/blake2s.test.d.ts +0 -2
  598. package/dest/barretenberg_api/blake2s.test.d.ts.map +0 -1
  599. package/dest/barretenberg_api/blake2s.test.js +0 -30
  600. package/dest/barretenberg_api/common.test.d.ts +0 -2
  601. package/dest/barretenberg_api/common.test.d.ts.map +0 -1
  602. package/dest/barretenberg_api/common.test.js +0 -18
  603. package/dest/barretenberg_api/index.d.ts +0 -103
  604. package/dest/barretenberg_api/index.d.ts.map +0 -1
  605. package/dest/barretenberg_api/index.js +0 -379
  606. package/dest/barretenberg_api/pedersen.test.d.ts +0 -2
  607. package/dest/barretenberg_api/pedersen.test.d.ts.map +0 -1
  608. package/dest/barretenberg_api/pedersen.test.js +0 -69
  609. package/dest/barretenberg_api/schnorr.test.d.ts +0 -2
  610. package/dest/barretenberg_api/schnorr.test.d.ts.map +0 -1
  611. package/dest/barretenberg_api/schnorr.test.js +0 -113
  612. package/dest/barretenberg_binder/heap_allocator.d.ts +0 -22
  613. package/dest/barretenberg_binder/heap_allocator.d.ts.map +0 -1
  614. package/dest/barretenberg_binder/heap_allocator.js +0 -59
  615. package/dest/barretenberg_binder/heap_allocator_sync.d.ts +0 -22
  616. package/dest/barretenberg_binder/heap_allocator_sync.d.ts.map +0 -1
  617. package/dest/barretenberg_binder/heap_allocator_sync.js +0 -58
  618. package/dest/barretenberg_binder/index.d.ts +0 -32
  619. package/dest/barretenberg_binder/index.d.ts.map +0 -1
  620. package/dest/barretenberg_binder/index.js +0 -73
  621. package/dest/barretenberg_wasm/barretenberg_wasm.d.ts +0 -50
  622. package/dest/barretenberg_wasm/barretenberg_wasm.d.ts.map +0 -1
  623. package/dest/barretenberg_wasm/barretenberg_wasm.js +0 -212
  624. package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts +0 -2
  625. package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts.map +0 -1
  626. package/dest/barretenberg_wasm/barretenberg_wasm.test.js +0 -43
  627. package/dest/barretenberg_wasm/browser/index.d.ts +0 -8
  628. package/dest/barretenberg_wasm/browser/index.d.ts.map +0 -1
  629. package/dest/barretenberg_wasm/browser/index.js +0 -26
  630. package/dest/barretenberg_wasm/browser/worker.d.ts +0 -2
  631. package/dest/barretenberg_wasm/browser/worker.d.ts.map +0 -1
  632. package/dest/barretenberg_wasm/browser/worker.js +0 -11
  633. package/dest/barretenberg_wasm/index.d.ts +0 -2
  634. package/dest/barretenberg_wasm/index.d.ts.map +0 -1
  635. package/dest/barretenberg_wasm/index.js +0 -2
  636. package/dest/barretenberg_wasm/node/index.d.ts +0 -17
  637. package/dest/barretenberg_wasm/node/index.d.ts.map +0 -1
  638. package/dest/barretenberg_wasm/node/index.js +0 -40
  639. package/dest/barretenberg_wasm/node/node_endpoint.d.ts +0 -8
  640. package/dest/barretenberg_wasm/node/node_endpoint.d.ts.map +0 -1
  641. package/dest/barretenberg_wasm/node/node_endpoint.js +0 -28
  642. package/dest/barretenberg_wasm/node/worker.d.ts +0 -2
  643. package/dest/barretenberg_wasm/node/worker.d.ts.map +0 -1
  644. package/dest/barretenberg_wasm/node/worker.js +0 -9
  645. package/dest/barretenberg_wasm.js +0 -2
  646. package/dest/barretenberg_wasm.js.LICENSE.txt +0 -5
  647. package/dest/bigint-array/index.d.ts +0 -3
  648. package/dest/bigint-array/index.d.ts.map +0 -1
  649. package/dest/bigint-array/index.js +0 -21
  650. package/dest/bindgen/function_declaration.d.ts +0 -11
  651. package/dest/bindgen/function_declaration.d.ts.map +0 -1
  652. package/dest/bindgen/function_declaration.js +0 -2
  653. package/dest/bindgen/index.d.ts +0 -2
  654. package/dest/bindgen/index.js +0 -15
  655. package/dest/bindgen/mappings.d.ts +0 -4
  656. package/dest/bindgen/mappings.d.ts.map +0 -1
  657. package/dest/bindgen/mappings.js +0 -63
  658. package/dest/bindgen/rust.d.ts +0 -2
  659. package/dest/bindgen/rust.d.ts.map +0 -1
  660. package/dest/bindgen/rust.js +0 -43
  661. package/dest/bindgen/to_camel_case.d.ts +0 -2
  662. package/dest/bindgen/to_camel_case.d.ts.map +0 -1
  663. package/dest/bindgen/to_camel_case.js +0 -11
  664. package/dest/bindgen/typescript.d.ts +0 -2
  665. package/dest/bindgen/typescript.d.ts.map +0 -1
  666. package/dest/bindgen/typescript.js +0 -80
  667. package/dest/crs/browser/cached_net_crs.d.ts +0 -25
  668. package/dest/crs/browser/cached_net_crs.d.ts.map +0 -1
  669. package/dest/crs/browser/cached_net_crs.js +0 -54
  670. package/dest/crs/browser/index.d.ts +0 -2
  671. package/dest/crs/browser/index.d.ts.map +0 -1
  672. package/dest/crs/browser/index.js +0 -2
  673. package/dest/crs/index.d.ts +0 -2
  674. package/dest/crs/index.d.ts.map +0 -1
  675. package/dest/crs/index.js +0 -2
  676. package/dest/crs/net_crs.d.ts +0 -36
  677. package/dest/crs/net_crs.d.ts.map +0 -1
  678. package/dest/crs/net_crs.js +0 -59
  679. package/dest/crs/node/file_crs.d.ts +0 -37
  680. package/dest/crs/node/file_crs.d.ts.map +0 -1
  681. package/dest/crs/node/file_crs.js +0 -51
  682. package/dest/crs/node/index.d.ts +0 -31
  683. package/dest/crs/node/index.d.ts.map +0 -1
  684. package/dest/crs/node/index.js +0 -41
  685. package/dest/examples/simple.rawtest.d.ts +0 -2
  686. package/dest/examples/simple.rawtest.d.ts.map +0 -1
  687. package/dest/examples/simple.rawtest.js +0 -29
  688. package/dest/examples/simple.test.d.ts +0 -2
  689. package/dest/examples/simple.test.d.ts.map +0 -1
  690. package/dest/examples/simple.test.js +0 -22
  691. package/dest/factory/index.d.ts +0 -21
  692. package/dest/factory/index.d.ts.map +0 -1
  693. package/dest/factory/index.js +0 -34
  694. package/dest/index.d.ts +0 -6
  695. package/dest/index.d.ts.map +0 -1
  696. package/dest/index.html +0 -1
  697. package/dest/index.js +0 -6
  698. package/dest/main.d.ts +0 -10
  699. package/dest/main.d.ts.map +0 -1
  700. package/dest/main.js +0 -280
  701. package/dest/random/browser/index.d.ts +0 -2
  702. package/dest/random/browser/index.d.ts.map +0 -1
  703. package/dest/random/browser/index.js +0 -31
  704. package/dest/random/index.d.ts +0 -2
  705. package/dest/random/index.d.ts.map +0 -1
  706. package/dest/random/node/index.d.ts +0 -2
  707. package/dest/random/node/index.d.ts.map +0 -1
  708. package/dest/random/node/index.js +0 -5
  709. package/dest/serialize/buffer_reader.d.ts +0 -28
  710. package/dest/serialize/buffer_reader.d.ts.map +0 -1
  711. package/dest/serialize/buffer_reader.js +0 -66
  712. package/dest/serialize/index.d.ts +0 -4
  713. package/dest/serialize/index.d.ts.map +0 -1
  714. package/dest/serialize/index.js +0 -4
  715. package/dest/serialize/output_type.d.ts +0 -11
  716. package/dest/serialize/output_type.d.ts.map +0 -1
  717. package/dest/serialize/output_type.js +0 -44
  718. package/dest/serialize/serialize.d.ts +0 -53
  719. package/dest/serialize/serialize.d.ts.map +0 -1
  720. package/dest/serialize/serialize.js +0 -139
  721. package/dest/simple_test.js +0 -2
  722. package/dest/simple_test.js.LICENSE.txt +0 -14
  723. package/dest/types/fields.d.ts +0 -33
  724. package/dest/types/fields.d.ts.map +0 -1
  725. package/dest/types/fields.js +0 -86
  726. package/dest/types/fixed_size_buffer.d.ts +0 -26
  727. package/dest/types/fixed_size_buffer.d.ts.map +0 -1
  728. package/dest/types/fixed_size_buffer.js +0 -54
  729. package/dest/types/index.d.ts +0 -6
  730. package/dest/types/index.d.ts.map +0 -1
  731. package/dest/types/index.js +0 -6
  732. package/dest/types/point.d.ts +0 -17
  733. package/dest/types/point.d.ts.map +0 -1
  734. package/dest/types/point.js +0 -32
  735. package/dest/types/ptr.d.ts +0 -13
  736. package/dest/types/ptr.d.ts.map +0 -1
  737. package/dest/types/ptr.js +0 -20
  738. package/dest/types/raw_buffer.d.ts +0 -3
  739. package/dest/types/raw_buffer.d.ts.map +0 -1
  740. package/dest/types/raw_buffer.js +0 -5
  741. package/src/barretenberg_api/blake2s.test.ts +0 -39
  742. package/src/barretenberg_api/common.test.ts +0 -21
  743. package/src/barretenberg_api/index.ts +0 -471
  744. package/src/barretenberg_api/pedersen.test.ts +0 -84
  745. package/src/barretenberg_api/schnorr.test.ts +0 -169
  746. package/src/barretenberg_binder/heap_allocator.ts +0 -62
  747. package/src/barretenberg_binder/heap_allocator_sync.ts +0 -61
  748. package/src/barretenberg_binder/index.ts +0 -76
  749. package/src/barretenberg_wasm/barretenberg_wasm.test.ts +0 -52
  750. package/src/barretenberg_wasm/barretenberg_wasm.ts +0 -246
  751. package/src/barretenberg_wasm/browser/index.ts +0 -32
  752. package/src/barretenberg_wasm/browser/worker.ts +0 -13
  753. package/src/barretenberg_wasm/node/index.ts +0 -46
  754. package/src/barretenberg_wasm/node/worker.ts +0 -10
  755. package/src/bigint-array/index.ts +0 -21
  756. package/src/bindgen/function_declaration.ts +0 -11
  757. package/src/bindgen/index.ts +0 -17
  758. package/src/bindgen/mappings.ts +0 -66
  759. package/src/bindgen/rust.ts +0 -52
  760. package/src/bindgen/to_camel_case.ts +0 -10
  761. package/src/bindgen/typescript.ts +0 -91
  762. package/src/crs/node/file_crs.ts +0 -60
  763. package/src/examples/simple.rawtest.ts +0 -37
  764. package/src/examples/simple.test.ts +0 -27
  765. package/src/factory/index.ts +0 -36
  766. package/src/main.ts +0 -324
  767. package/src/serialize/buffer_reader.ts +0 -82
  768. package/src/serialize/index.ts +0 -3
  769. package/src/serialize/output_type.ts +0 -53
  770. package/src/serialize/serialize.ts +0 -157
  771. package/src/types/fields.ts +0 -98
  772. package/src/types/fixed_size_buffer.ts +0 -59
  773. package/src/types/index.ts +0 -5
  774. package/src/types/point.ts +0 -35
  775. package/src/types/ptr.ts +0 -20
  776. package/src/types/raw_buffer.ts +0 -3
  777. /package/src/barretenberg_wasm/{node → helpers/node}/node_endpoint.ts +0 -0
package/README.md CHANGED
@@ -1,121 +1,91 @@
1
1
  # bb.js
2
2
 
3
- Prover/verifier executable and API for barretenberg. Default cli arguments are appropriate for running within Noir
4
- project structures.
3
+ Prover/verifier library for barretenberg. It bundles support for the following:
5
4
 
6
- ## Performance and limitations
5
+ - x86_64 on linux.
6
+ - aarch64 on linux.
7
+ - x86_64 on macos.
8
+ - aarch64 on macos.
9
+ - Single-threaded WASM.
10
+ - Multi-threaded WASM.
7
11
 
8
- Max circuit size is 2^19 gates (524,288). This is due to the underlying WASM 4GB memory limit. This should improve
9
- with future proving systems, and/or introduction of wasm64.
10
-
11
- If running from terminal, or within browser where you can set shared memory COOP/COEP headers, multithreading is enabled.
12
- Note there are two independent WASM builds, one with threading enabled and one without. This is because the shared
13
- memory flag is set within the WASM itself. If you're running in a context where you can't have shared memory, we want
14
- to fallback to single threaded performance.
15
-
16
- Performance for 2^19 (small witness generation phase):
17
-
18
- - 16 core x86: ~13s.
19
- - 10 core M1 Mac Pro: ~18s.
20
-
21
- Linear scaling was observed up to 32 cores, however we limit to 16 as 2^19 runs out of memory with 32 cores.
22
- This maybe resolvable.
23
-
24
- Witness generation phase is not multithreaded, and an interesting 512k circuit can take ~12s. This results in:
25
-
26
- - 16 core x86: ~26s.
27
- - 10 core M1 Mac Pro: (TBD)
28
-
29
- ## Using as a standalone binary
30
-
31
- ### Installing
32
-
33
- To install the package globally for running as a terminal application:
34
-
35
- ```
36
- npm install -g @aztec/bb.js@alpha
37
- ```
38
-
39
- This will install `bb.js` into your path.
40
-
41
- ### Usage
42
-
43
- Run `bb.js` for further usage information, you'll see e.g.
44
-
45
- ```
46
- % bb.js
47
- Usage: bb.js [options] [command]
48
-
49
- Options:
50
- -v, --verbose enable verbose logging (default: false)
51
- -h, --help display help for command
52
-
53
- Commands:
54
- prove_and_verify [options] Generate a proof and verify it. Process exits with success or failure code.
55
- prove [options] Generate a proof and write it to a file.
56
- gates [options] Print gate count to standard output.
57
- verify [options] Verify a proof. Process exists with success or failure code.
58
- contract [options] Output solidity verification key contract.
59
- write_vk [options] Output verification key.
60
- proof_as_fields [options] Return the proof as fields elements
61
- vk_as_fields [options] Return the verifiation key represented as fields elements. Also return the verification key hash.
62
- help [command] display help for command
63
- ```
64
-
65
- ## Using as a library
12
+ If running within node.js on a support os/architecture we will use appropriate native code.
13
+ If running within node.js on an unsupported architecture we will fallback to multi-threaded WASM.
14
+ If running within the browser and served without COOP/COEP headers, we use the single-threaded WASM.
15
+ If running within the browser served with COOP/COEP headers, we use the multi-threaded WASM.
66
16
 
67
17
  ### Installing
68
18
 
69
- To install as a package to be used as a library:
70
-
71
19
  ```
72
- npm install @aztec/bb.js@alpha
20
+ npm install @aztec/bb.js
73
21
  ```
74
22
 
75
23
  or with yarn
76
24
 
77
25
  ```
78
- yarn add @aztec/bb.js@alpha
26
+ yarn add @aztec/bb.js
79
27
  ```
80
28
 
81
29
  ### Usage
82
30
 
83
- To create a multithreaded version of the API:
31
+ To create the API and do a blake2s hash:
84
32
 
85
33
  ```typescript
86
- const api = await newBarretenbergApiAsync(/* num_threads */);
87
- // Use.
34
+ import { Crs, Barretenberg, RawBuffer } from './index.js';
35
+
36
+ const api = await Barretenberg.new({ threads: 1 });
88
37
  const input = Buffer.from('hello world!');
89
38
  const result = await api.blake2s(input);
90
39
  await api.destroy();
91
40
  ```
92
41
 
93
- All methods are asynchronous. If no threads are specified, will default to number of cores with a maximum of 16.
42
+ All methods are asynchronous. If no threads are specified, will default to number of cores with a maximum of 32.
94
43
  If `1` is specified, fallback to non multi-threaded wasm that doesn't need shared memory.
95
44
 
96
- You can also create a synchronous version of the api that also has no multi-threading. This is only useful in the
97
- browser if you don't call any multi-threaded functions. It's probably best to just always use async version of the api
98
- unless you're really trying to avoid the small overhead of worker communication.
45
+ See `src/main.ts` for larger example of how to use.
46
+
47
+ ### Browser Context
48
+
49
+ It's recommended to use a dynamic import. This allows the developer to pick the time at which the package (several MB
50
+ in size) is loaded and keeps page load times responsive.
99
51
 
100
52
  ```typescript
101
- const api = await newBarretenbergApiSync();
102
- // Use.
103
- const input = Buffer.from('hello world!');
104
- const result = api.blake2s(input);
105
- await api.destroy();
53
+ const { Barretenberg, RawBuffer, Crs } = await import('@aztec/bb.js');
106
54
  ```
107
55
 
108
- See `src/main.ts` for one example of how to use.
56
+ ### Multithreading in browser
57
+
58
+ Multithreading in bb.js requires [`SharedArrayBuffer`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer) to be enabled. It is only enabled in browsers if COOP and COEP headers are set by the server. Read more [here](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer#security_requirements).
59
+
60
+ You can configure your server to set these headers for pages that perform proof generation. See [this example project](https://github.com/saleel/gitclaim/blob/main/app/next.config.mjs#L48-L67) that implements multi-threaded browser proving, which contains the below Next.js config:
61
+
62
+ ```typescript
63
+ {
64
+ ...
65
+ async headers() {
66
+ return [
67
+ {
68
+ source: '/:path*',
69
+ headers: [
70
+ { key: 'Cross-Origin-Embedder-Policy', value: 'require-corp' },
71
+ { key: 'Cross-Origin-Opener-Policy', value: 'same-origin' },
72
+ ],
73
+ },
74
+ ];
75
+ },
76
+ }
77
+ ```
109
78
 
110
- ## Development
79
+ Note that adding COOP and COEP headers will disable loading of external scripts, which might be required by your application.
111
80
 
112
- Create a symlink to the root script `bb.js-dev` in your path. You can now run the current state of the code from
113
- anywhere in your filesystem with no `yarn build` required.
81
+ You can enable these headers for specific pages that perform proof generation, but this may be challenging, especially in single-page applications. One workaround is to move the proof generation to a separate page, load it in an invisible iframe within your main application, and then use `postMessage` to communicate between the pages for generating proofs.
114
82
 
115
- If you change the C++ code run `yarn build:wasm`.
83
+ ## Debugging
116
84
 
117
- To run the tests run `yarn test`.
85
+ Got an unhelpful stack trace in wasm? Run:
118
86
 
119
- To run a continuous "stress test" run `yarn simple_test` to do 10 full pk/proof/vk iterations.
87
+ ```
88
+ BUILD_CPP=1 NO_STRIP=1 ./script/copy_wasm.sh
89
+ ```
120
90
 
121
- To run the same test in the browser run `yarn serve`, navigate to appropriate URL and open the console.
91
+ This will drop unstripped wasms into the dest folder. Run your test again to get a trace.
Binary file
Binary file
Binary file
Binary file
@@ -7,4 +7,4 @@
7
7
  * The equivalent with asyncMap: `await asyncMap(arr, async e => { ... })`.
8
8
  */
9
9
  export declare function asyncMap<T, U>(arr: T[], fn: (e: T, i: number) => Promise<U>): Promise<U[]>;
10
- //# sourceMappingURL=index.d.ts.map
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hc3luY19tYXAvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7R0FPRztBQUNILHdCQUFzQixRQUFRLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsTUFBTSxLQUFLLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FNaEcifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/async_map/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,wBAAsB,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC,CAMhG"}
@@ -13,4 +13,4 @@ export async function asyncMap(arr, fn) {
13
13
  }
14
14
  return results;
15
15
  }
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXN5bmNfbWFwL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0dBT0c7QUFDSCxNQUFNLENBQUMsS0FBSyxVQUFVLFFBQVEsQ0FBTyxHQUFRLEVBQUUsRUFBbUM7SUFDaEYsTUFBTSxPQUFPLEdBQVEsRUFBRSxDQUFDO0lBQ3hCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFO1FBQ25DLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDbkM7SUFDRCxPQUFPLE9BQU8sQ0FBQztBQUNqQixDQUFDIn0=
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXN5bmNfbWFwL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0dBT0c7QUFDSCxNQUFNLENBQUMsS0FBSyxVQUFVLFFBQVEsQ0FBTyxHQUFRLEVBQUUsRUFBbUMsRUFBZ0I7SUFDaEcsTUFBTSxPQUFPLEdBQVEsRUFBRSxDQUFDO0lBQ3hCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7UUFDcEMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBQ0QsT0FBTyxPQUFPLENBQUM7QUFBQSxDQUNoQiJ9
@@ -0,0 +1,61 @@
1
+ import { Barretenberg } from './index.js';
2
+ import { ProofData } from '../proof/index.js';
3
+ export declare class AztecClientBackendError extends Error {
4
+ constructor(message: string);
5
+ }
6
+ /**
7
+ * Options for the UltraHonkBackend.
8
+ */
9
+ export type UltraHonkBackendOptions = {
10
+ /** Selecting this option will use the keccak hash function instead of poseidon
11
+ * when generating challenges in the proof.
12
+ * Use this when you want to verify the created proof on an EVM chain.
13
+ */
14
+ keccak?: boolean;
15
+ /** Selecting this option will use the keccak hash function instead of poseidon
16
+ * when generating challenges in the proof.
17
+ * Use this when you want to verify the created proof on an EVM chain.
18
+ */
19
+ keccakZK?: boolean;
20
+ /** Selecting this option will use the poseidon/stark252 hash function instead of poseidon
21
+ * when generating challenges in the proof.
22
+ * Use this when you want to verify the created proof on an Starknet chain with Garaga.
23
+ */
24
+ starknet?: boolean;
25
+ /** Selecting this option will use the poseidon/stark252 hash function instead of poseidon
26
+ * when generating challenges in the proof.
27
+ * Use this when you want to verify the created proof on an Starknet chain with Garaga.
28
+ */
29
+ starknetZK?: boolean;
30
+ };
31
+ export declare class UltraHonkVerifierBackend {
32
+ private api;
33
+ constructor(api: Barretenberg);
34
+ verifyProof(proofData: ProofData & {
35
+ verificationKey: Uint8Array;
36
+ }, options?: UltraHonkBackendOptions): Promise<boolean>;
37
+ }
38
+ export declare class UltraHonkBackend {
39
+ private api;
40
+ private acirUncompressedBytecode;
41
+ constructor(acirBytecode: string, api: Barretenberg);
42
+ generateProof(compressedWitness: Uint8Array, options?: UltraHonkBackendOptions): Promise<ProofData>;
43
+ verifyProof(proofData: ProofData, options?: UltraHonkBackendOptions): Promise<boolean>;
44
+ getVerificationKey(options?: UltraHonkBackendOptions): Promise<Uint8Array>;
45
+ /** @description Returns a solidity verifier */
46
+ getSolidityVerifier(vk: Uint8Array, options?: UltraHonkBackendOptions): Promise<string>;
47
+ generateRecursiveProofArtifacts(_proof: Uint8Array, _numOfPublicInputs: number): Promise<{
48
+ proofAsFields: string[];
49
+ vkAsFields: string[];
50
+ vkHash: string;
51
+ }>;
52
+ }
53
+ export declare class AztecClientBackend {
54
+ private acirBuf;
55
+ private api;
56
+ constructor(acirBuf: Uint8Array[], api: Barretenberg);
57
+ prove(witnessBuf: Uint8Array[], vksBuf?: Uint8Array[]): Promise<[Uint8Array[], Uint8Array, Uint8Array]>;
58
+ verify(proof: Uint8Array, vk: Uint8Array): Promise<boolean>;
59
+ gates(): Promise<number[]>;
60
+ }
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFja2VuZC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JhcnJldGVuYmVyZy9iYWNrZW5kLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDMUMsT0FBTyxFQUFFLFNBQVMsRUFBb0MsTUFBTSxtQkFBbUIsQ0FBQztBQUtoRixxQkFBYSx1QkFBd0IsU0FBUSxLQUFLO0lBQ2hELFlBQVksT0FBTyxFQUFFLE1BQU0sRUFFMUI7Q0FDRjtBQUVEOztHQUVHO0FBQ0gsTUFBTSxNQUFNLHVCQUF1QixHQUFHO0lBQ3BDOzs7T0FHRztJQUNILE1BQU0sQ0FBQyxFQUFFLE9BQU8sQ0FBQztJQUNqQjs7O09BR0c7SUFDSCxRQUFRLENBQUMsRUFBRSxPQUFPLENBQUM7SUFDbkI7OztPQUdHO0lBQ0gsUUFBUSxDQUFDLEVBQUUsT0FBTyxDQUFDO0lBQ25COzs7T0FHRztJQUNILFVBQVUsQ0FBQyxFQUFFLE9BQU8sQ0FBQztDQUN0QixDQUFDO0FBc0JGLHFCQUFhLHdCQUF3QjtJQUN2QixPQUFPLENBQUMsR0FBRztJQUF2QixZQUFvQixHQUFHLEVBQUUsWUFBWSxFQUFJO0lBRW5DLFdBQVcsQ0FDZixTQUFTLEVBQUUsU0FBUyxHQUFHO1FBQUUsZUFBZSxFQUFFLFVBQVUsQ0FBQTtLQUFFLEVBQ3RELE9BQU8sQ0FBQyxFQUFFLHVCQUF1QixHQUNoQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBWWxCO0NBQ0Y7QUFFRCxxQkFBYSxnQkFBZ0I7SUFVekIsT0FBTyxDQUFDLEdBQUc7SUFKYixPQUFPLENBQUMsd0JBQXdCLENBQWE7SUFFN0MsWUFDRSxZQUFZLEVBQUUsTUFBTSxFQUNaLEdBQUcsRUFBRSxZQUFZLEVBRzFCO0lBRUssYUFBYSxDQUFDLGlCQUFpQixFQUFFLFVBQVUsRUFBRSxPQUFPLENBQUMsRUFBRSx1QkFBdUIsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLENBb0J4RztJQUVLLFdBQVcsQ0FBQyxTQUFTLEVBQUUsU0FBUyxFQUFFLE9BQU8sQ0FBQyxFQUFFLHVCQUF1QixHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FvQjNGO0lBRUssa0JBQWtCLENBQUMsT0FBTyxDQUFDLEVBQUUsdUJBQXVCLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQVMvRTtJQUVELCtDQUErQztJQUN6QyxtQkFBbUIsQ0FBQyxFQUFFLEVBQUUsVUFBVSxFQUFFLE9BQU8sQ0FBQyxFQUFFLHVCQUF1QixHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FNNUY7SUFHSywrQkFBK0IsQ0FFbkMsTUFBTSxFQUFFLFVBQVUsRUFFbEIsa0JBQWtCLEVBQUUsTUFBTSxHQUN6QixPQUFPLENBQUM7UUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFFLENBQUM7UUFBQyxVQUFVLEVBQUUsTUFBTSxFQUFFLENBQUM7UUFBQyxNQUFNLEVBQUUsTUFBTSxDQUFBO0tBQUUsQ0FBQyxDQW1DNUU7Q0FDRjtBQUVELHFCQUFhLGtCQUFrQjtJQU8zQixPQUFPLENBQUMsT0FBTztJQUNmLE9BQU8sQ0FBQyxHQUFHO0lBRmIsWUFDVSxPQUFPLEVBQUUsVUFBVSxFQUFFLEVBQ3JCLEdBQUcsRUFBRSxZQUFZLEVBQ3ZCO0lBRUUsS0FBSyxDQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUUsRUFBRSxNQUFNLEdBQUUsVUFBVSxFQUFPLEdBQUcsT0FBTyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUUsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBMkRoSDtJQUVLLE1BQU0sQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLEVBQUUsRUFBRSxVQUFVLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQU1oRTtJQUVLLEtBQUssSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FhL0I7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"backend.d.ts","sourceRoot":"","sources":["../../../src/barretenberg/backend.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAoC,MAAM,mBAAmB,CAAC;AAKhF,qBAAa,uBAAwB,SAAQ,KAAK;IAChD,YAAY,OAAO,EAAE,MAAM,EAE1B;CACF;AAED;;GAEG;AACH,MAAM,MAAM,uBAAuB,GAAG;IACpC;;;OAGG;IACH,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB;;;OAGG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB;;;OAGG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB,CAAC;AAsBF,qBAAa,wBAAwB;IACvB,OAAO,CAAC,GAAG;IAAvB,YAAoB,GAAG,EAAE,YAAY,EAAI;IAEnC,WAAW,CACf,SAAS,EAAE,SAAS,GAAG;QAAE,eAAe,EAAE,UAAU,CAAA;KAAE,EACtD,OAAO,CAAC,EAAE,uBAAuB,GAChC,OAAO,CAAC,OAAO,CAAC,CAYlB;CACF;AAED,qBAAa,gBAAgB;IAUzB,OAAO,CAAC,GAAG;IAJb,OAAO,CAAC,wBAAwB,CAAa;IAE7C,YACE,YAAY,EAAE,MAAM,EACZ,GAAG,EAAE,YAAY,EAG1B;IAEK,aAAa,CAAC,iBAAiB,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,uBAAuB,GAAG,OAAO,CAAC,SAAS,CAAC,CAoBxG;IAEK,WAAW,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,uBAAuB,GAAG,OAAO,CAAC,OAAO,CAAC,CAoB3F;IAEK,kBAAkB,CAAC,OAAO,CAAC,EAAE,uBAAuB,GAAG,OAAO,CAAC,UAAU,CAAC,CAS/E;IAED,+CAA+C;IACzC,mBAAmB,CAAC,EAAE,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,uBAAuB,GAAG,OAAO,CAAC,MAAM,CAAC,CAM5F;IAGK,+BAA+B,CAEnC,MAAM,EAAE,UAAU,EAElB,kBAAkB,EAAE,MAAM,GACzB,OAAO,CAAC;QAAE,aAAa,EAAE,MAAM,EAAE,CAAC;QAAC,UAAU,EAAE,MAAM,EAAE,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAmC5E;CACF;AAED,qBAAa,kBAAkB;IAO3B,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,GAAG;IAFb,YACU,OAAO,EAAE,UAAU,EAAE,EACrB,GAAG,EAAE,YAAY,EACvB;IAEE,KAAK,CAAC,UAAU,EAAE,UAAU,EAAE,EAAE,MAAM,GAAE,UAAU,EAAO,GAAG,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC,CA2DhH;IAEK,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,CAMhE;IAEK,KAAK,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,CAa/B;CACF"}
@@ -0,0 +1,250 @@
1
+ import { uint8ArrayToHex, hexToUint8Array } from '../proof/index.js';
2
+ import { fromChonkProof, toChonkProof } from '../cbind/generated/api_types.js';
3
+ import { ungzip } from 'pako';
4
+ import { Decoder, Encoder } from 'msgpackr';
5
+ export class AztecClientBackendError extends Error {
6
+ constructor(message) {
7
+ super(message);
8
+ }
9
+ }
10
+ function getProofSettingsFromOptions(options) {
11
+ return {
12
+ ipaAccumulation: false,
13
+ oracleHashType: options?.keccak || options?.keccakZK
14
+ ? 'keccak'
15
+ : options?.starknet || options?.starknetZK
16
+ ? 'starknet'
17
+ : 'poseidon2',
18
+ // TODO no current way to target non-zk poseidon2 hash
19
+ disableZk: options?.keccak || options?.starknet ? true : false,
20
+ optimizedSolidityVerifier: false,
21
+ };
22
+ }
23
+ export class UltraHonkVerifierBackend {
24
+ api;
25
+ constructor(api) {
26
+ this.api = api;
27
+ }
28
+ async verifyProof(proofData, options) {
29
+ const proofFrs = [];
30
+ for (let i = 0; i < proofData.proof.length; i += 32) {
31
+ proofFrs.push(proofData.proof.slice(i, i + 32));
32
+ }
33
+ const { verified } = await this.api.circuitVerify({
34
+ verificationKey: proofData.verificationKey,
35
+ publicInputs: proofData.publicInputs.map(hexToUint8Array),
36
+ proof: proofFrs,
37
+ settings: getProofSettingsFromOptions(options),
38
+ });
39
+ return verified;
40
+ }
41
+ }
42
+ export class UltraHonkBackend {
43
+ api;
44
+ // These type assertions are used so that we don't
45
+ // have to initialize `api` in the constructor.
46
+ // These are initialized asynchronously in the `init` function,
47
+ // constructors cannot be asynchronous which is why we do this.
48
+ acirUncompressedBytecode;
49
+ constructor(acirBytecode, api) {
50
+ this.api = api;
51
+ this.acirUncompressedBytecode = acirToUint8Array(acirBytecode);
52
+ }
53
+ async generateProof(compressedWitness, options) {
54
+ const witness = ungzip(compressedWitness);
55
+ const { proof, publicInputs } = await this.api.circuitProve({
56
+ witness,
57
+ circuit: {
58
+ name: 'circuit',
59
+ bytecode: this.acirUncompressedBytecode,
60
+ verificationKey: new Uint8Array(0), // Empty VK - lower performance.
61
+ },
62
+ settings: getProofSettingsFromOptions(options),
63
+ });
64
+ console.log(`Generated proof for circuit with ${publicInputs.length} public inputs and ${proof.length} fields.`);
65
+ // We return ProofData as a flat buffer and an array of strings to match the current ProofData class.
66
+ const flatProof = new Uint8Array(proof.length * 32);
67
+ proof.forEach((fr, i) => {
68
+ flatProof.set(fr, i * 32);
69
+ });
70
+ return { proof: flatProof, publicInputs: publicInputs.map(uint8ArrayToHex) };
71
+ }
72
+ async verifyProof(proofData, options) {
73
+ const proofFrs = [];
74
+ for (let i = 0; i < proofData.proof.length; i += 32) {
75
+ proofFrs.push(proofData.proof.slice(i, i + 32));
76
+ }
77
+ // TODO reconsider API - computing the VK at this point is not optimal
78
+ const vkResult = await this.api.circuitComputeVk({
79
+ circuit: {
80
+ name: 'circuit',
81
+ bytecode: this.acirUncompressedBytecode,
82
+ },
83
+ settings: getProofSettingsFromOptions(options),
84
+ });
85
+ const { verified } = await this.api.circuitVerify({
86
+ verificationKey: vkResult.bytes,
87
+ publicInputs: proofData.publicInputs.map(hexToUint8Array),
88
+ proof: proofFrs,
89
+ settings: getProofSettingsFromOptions(options),
90
+ });
91
+ return verified;
92
+ }
93
+ async getVerificationKey(options) {
94
+ const vkResult = await this.api.circuitComputeVk({
95
+ circuit: {
96
+ name: 'circuit',
97
+ bytecode: this.acirUncompressedBytecode,
98
+ },
99
+ settings: getProofSettingsFromOptions(options),
100
+ });
101
+ return vkResult.bytes;
102
+ }
103
+ /** @description Returns a solidity verifier */
104
+ async getSolidityVerifier(vk, options) {
105
+ const result = await this.api.circuitWriteSolidityVerifier({
106
+ verificationKey: vk,
107
+ settings: getProofSettingsFromOptions(options),
108
+ });
109
+ return result.solidityCode;
110
+ }
111
+ // 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
112
+ async generateRecursiveProofArtifacts(
113
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
114
+ _proof,
115
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
116
+ _numOfPublicInputs) {
117
+ // TODO(https://github.com/noir-lang/noir/issues/5661): This needs to be updated to handle recursive aggregation.
118
+ // There is still a proofAsFields method but we could consider getting rid of it as the proof itself
119
+ // is a list of field elements.
120
+ // UltraHonk also does not have public inputs directly prepended to the proof and they are still instead
121
+ // inserted at an offset.
122
+ // const proof = reconstructProofWithPublicInputs(proofData);
123
+ // const proofAsFields = (await this.api.acirProofAsFieldsUltraHonk(proof)).slice(numOfPublicInputs);
124
+ // TODO: perhaps we should put this in the init function. Need to benchmark
125
+ // TODO how long it takes.
126
+ const vkResult = await this.api.circuitComputeVk({
127
+ circuit: {
128
+ name: 'circuit',
129
+ bytecode: this.acirUncompressedBytecode,
130
+ },
131
+ settings: getProofSettingsFromOptions({}),
132
+ });
133
+ // Convert VK bytes to field elements (32-byte chunks)
134
+ const vkAsFields = [];
135
+ for (let i = 0; i < vkResult.bytes.length; i += 32) {
136
+ const chunk = vkResult.bytes.slice(i, i + 32);
137
+ vkAsFields.push(uint8ArrayToHex(chunk));
138
+ }
139
+ return {
140
+ // TODO(https://github.com/noir-lang/noir/issues/5661)
141
+ proofAsFields: [],
142
+ vkAsFields,
143
+ // We use an empty string for the vk hash here as it is unneeded as part of the recursive artifacts
144
+ // The user can be expected to hash the vk inside their circuit to check whether the vk is the circuit
145
+ // they expect
146
+ vkHash: uint8ArrayToHex(vkResult.hash),
147
+ };
148
+ }
149
+ }
150
+ export class AztecClientBackend {
151
+ acirBuf;
152
+ api;
153
+ // These type assertions are used so that we don't
154
+ // have to initialize `api` in the constructor.
155
+ // These are initialized asynchronously in the `init` function,
156
+ // constructors cannot be asynchronous which is why we do this.
157
+ constructor(acirBuf, api) {
158
+ this.acirBuf = acirBuf;
159
+ this.api = api;
160
+ }
161
+ async prove(witnessBuf, vksBuf = []) {
162
+ if (vksBuf.length !== 0 && this.acirBuf.length !== witnessBuf.length) {
163
+ throw new AztecClientBackendError('Witness and bytecodes must have the same stack depth!');
164
+ }
165
+ if (vksBuf.length !== 0 && vksBuf.length !== witnessBuf.length) {
166
+ // NOTE: we allow 0 as an explicit 'I have no VKs'. This is a deprecated feature.
167
+ throw new AztecClientBackendError('Witness and VKs must have the same stack depth!');
168
+ }
169
+ // Queue IVC start with the number of circuits
170
+ this.api.chonkStart({ numCircuits: this.acirBuf.length });
171
+ // Queue load and accumulate for each circuit
172
+ for (let i = 0; i < this.acirBuf.length; i++) {
173
+ const bytecode = this.acirBuf[i];
174
+ const witness = witnessBuf[i] || new Uint8Array(0);
175
+ const vk = vksBuf[i] || new Uint8Array(0);
176
+ const functionName = `unknown_wasm_${i}`;
177
+ // Load the circuit
178
+ this.api.chonkLoad({
179
+ circuit: {
180
+ name: functionName,
181
+ bytecode: bytecode,
182
+ verificationKey: vk,
183
+ },
184
+ });
185
+ // Accumulate with witness
186
+ this.api.chonkAccumulate({
187
+ witness,
188
+ });
189
+ }
190
+ // Generate the proof (and wait for all previous steps to finish)
191
+ const proveResult = await this.api.chonkProve({});
192
+ // The API currently expects a msgpack-encoded API.
193
+ const proof = new Encoder({ useRecords: false }).encode(fromChonkProof(proveResult.proof));
194
+ // Generate the VK
195
+ const vkResult = await this.api.chonkComputeIvcVk({
196
+ circuit: {
197
+ name: 'hiding',
198
+ bytecode: this.acirBuf[this.acirBuf.length - 1],
199
+ },
200
+ });
201
+ const proofFields = [
202
+ proveResult.proof.megaProof,
203
+ proveResult.proof.goblinProof.mergeProof,
204
+ proveResult.proof.goblinProof.eccvmProof.preIpaProof,
205
+ proveResult.proof.goblinProof.eccvmProof.ipaProof,
206
+ proveResult.proof.goblinProof.translatorProof,
207
+ ].flat();
208
+ // Note: Verification may not work correctly until we properly serialize the proof
209
+ if (!(await this.verify(proof, vkResult.bytes))) {
210
+ throw new AztecClientBackendError('Failed to verify the private (Chonk) transaction proof!');
211
+ }
212
+ return [proofFields, proof, vkResult.bytes];
213
+ }
214
+ async verify(proof, vk) {
215
+ const result = await this.api.chonkVerify({
216
+ proof: toChonkProof(new Decoder({ useRecords: false }).decode(proof)),
217
+ vk,
218
+ });
219
+ return result.valid;
220
+ }
221
+ async gates() {
222
+ const circuitSizes = [];
223
+ for (const buf of this.acirBuf) {
224
+ const gates = await this.api.chonkStats({
225
+ circuit: {
226
+ name: 'circuit',
227
+ bytecode: buf,
228
+ },
229
+ includeGatesPerOpcode: false,
230
+ });
231
+ circuitSizes.push(gates.circuitSize);
232
+ }
233
+ return circuitSizes;
234
+ }
235
+ }
236
+ // Converts bytecode from a base64 string to a Uint8Array
237
+ function acirToUint8Array(base64EncodedBytecode) {
238
+ const compressedByteCode = base64Decode(base64EncodedBytecode);
239
+ return ungzip(compressedByteCode);
240
+ }
241
+ // Base64 decode using atob (works in both browser and Node.js 18+)
242
+ function base64Decode(input) {
243
+ if (typeof atob === 'function') {
244
+ return Uint8Array.from(atob(input), c => c.charCodeAt(0));
245
+ }
246
+ else {
247
+ throw new Error('atob is not available. Node.js 18+ or browser required.');
248
+ }
249
+ }
250
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFja2VuZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iYXJyZXRlbmJlcmcvYmFja2VuZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQWEsZUFBZSxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxjQUFjLEVBQUUsWUFBWSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDL0UsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM5QixPQUFPLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUU1QyxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsS0FBSztJQUNoRCxZQUFZLE9BQWUsRUFBRTtRQUMzQixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFBQSxDQUNoQjtDQUNGO0FBNEJELFNBQVMsMkJBQTJCLENBQUMsT0FBaUMsRUFLcEU7SUFDQSxPQUFPO1FBQ0wsZUFBZSxFQUFFLEtBQUs7UUFDdEIsY0FBYyxFQUNaLE9BQU8sRUFBRSxNQUFNLElBQUksT0FBTyxFQUFFLFFBQVE7WUFDbEMsQ0FBQyxDQUFDLFFBQVE7WUFDVixDQUFDLENBQUMsT0FBTyxFQUFFLFFBQVEsSUFBSSxPQUFPLEVBQUUsVUFBVTtnQkFDeEMsQ0FBQyxDQUFDLFVBQVU7Z0JBQ1osQ0FBQyxDQUFDLFdBQVc7UUFDbkIsc0RBQXNEO1FBQ3RELFNBQVMsRUFBRSxPQUFPLEVBQUUsTUFBTSxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSztRQUM5RCx5QkFBeUIsRUFBRSxLQUFLO0tBQ2pDLENBQUM7QUFBQSxDQUNIO0FBRUQsTUFBTSxPQUFPLHdCQUF3QjtJQUNmLEdBQUc7SUFBdkIsWUFBb0IsR0FBaUIsRUFBRTttQkFBbkIsR0FBRztJQUFpQixDQUFDO0lBRXpDLEtBQUssQ0FBQyxXQUFXLENB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
@@ -0,0 +1,65 @@
1
+ import { AsyncApi } from '../cbind/generated/async.js';
2
+ import { SyncApi } from '../cbind/generated/sync.js';
3
+ import { IMsgpackBackendSync, IMsgpackBackendAsync } from '../bb_backends/interface.js';
4
+ import { BackendOptions } from '../bb_backends/index.js';
5
+ export { UltraHonkBackend, UltraHonkVerifierBackend, AztecClientBackend } from './backend.js';
6
+ export * from '../bb_backends/index.js';
7
+ export type CircuitOptions = {
8
+ /** @description Whether to produce SNARK friendly proofs */
9
+ recursive: boolean;
10
+ };
11
+ /**
12
+ * The main class library consumers interact with.
13
+ * It extends the generated api, and provides a static constructor "new" to compose components.
14
+ */
15
+ export declare class Barretenberg extends AsyncApi {
16
+ private options;
17
+ constructor(backend: IMsgpackBackendAsync, options: BackendOptions);
18
+ /**
19
+ * Constructs an instance of Barretenberg.
20
+ *
21
+ * If options.backend is set: uses that specific backend (throws if unavailable)
22
+ * If options.backend is unset: tries backends in order with fallback:
23
+ * 1. NativeUnixSocket (if bb binary available)
24
+ * 2. WasmWorker (in browser) or Wasm (in Node.js)
25
+ */
26
+ static new(options?: BackendOptions): Promise<Barretenberg>;
27
+ initSRSChonk(srsSize?: number): Promise<void>;
28
+ getDefaultSrsSize(): number;
29
+ acirGetCircuitSizes(bytecode: Uint8Array, recursive: boolean, honkRecursion: boolean): Promise<[number, number]>;
30
+ destroy(): Promise<void>;
31
+ /**
32
+ * Initialize the singleton instance of Barretenberg.
33
+ * @param options Backend configuration options
34
+ */
35
+ static initSingleton(options?: BackendOptions): Promise<Barretenberg>;
36
+ static destroySingleton(): Promise<void>;
37
+ /**
38
+ * Get the singleton instance of Barretenberg.
39
+ * Must call initSingleton() first.
40
+ */
41
+ static getSingleton(): Barretenberg;
42
+ }
43
+ export declare class BarretenbergSync extends SyncApi {
44
+ constructor(backend: IMsgpackBackendSync);
45
+ /**
46
+ * Create a new BarretenbergSync instance.
47
+ *
48
+ * If options.backend is set: uses that specific backend (throws if unavailable)
49
+ * If options.backend is unset: tries backends in order with fallback:
50
+ * 1. NativeSharedMem (if bb binary + NAPI module available)
51
+ * 2. Wasm
52
+ *
53
+ * Supported backends: Wasm, NativeSharedMem
54
+ * Not supported: WasmWorker (no workers in sync), NativeUnixSocket (async only)
55
+ */
56
+ static new(options?: BackendOptions): Promise<BarretenbergSync>;
57
+ /**
58
+ * Initialize the singleton instance.
59
+ * @param options Backend configuration options
60
+ */
61
+ static initSingleton(options?: BackendOptions): Promise<BarretenbergSync>;
62
+ static destroySingleton(): void;
63
+ static getSingleton(): BarretenbergSync;
64
+ }
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iYXJyZXRlbmJlcmcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN4RixPQUFPLEVBQUUsY0FBYyxFQUFlLE1BQU0seUJBQXlCLENBQUM7QUFHdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLHdCQUF3QixFQUFFLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzlGLGNBQWMseUJBQXlCLENBQUM7QUFFeEMsTUFBTSxNQUFNLGNBQWMsR0FBRztJQUMzQiw0REFBNEQ7SUFDNUQsU0FBUyxFQUFFLE9BQU8sQ0FBQztDQUNwQixDQUFDO0FBRUY7OztHQUdHO0FBQ0gscUJBQWEsWUFBYSxTQUFRLFFBQVE7SUFDeEMsT0FBTyxDQUFDLE9BQU8sQ0FBaUI7SUFFaEMsWUFBWSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFHakU7SUFFRDs7Ozs7OztPQU9HO0lBQ0gsT0FBYSxHQUFHLENBQUMsT0FBTyxHQUFFLGNBQW1CLHlCQTJCNUM7SUFFSyxZQUFZLENBQUMsT0FBTyxTQUEyQixHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FTcEU7SUFFRCxpQkFBaUIsSUFBSSxNQUFNLENBTzFCO0lBRUssbUJBQW1CLENBQ3ZCLFFBQVEsRUFBRSxVQUFVLEVBQ3BCLFNBQVMsRUFBRSxPQUFPLEVBQ2xCLGFBQWEsRUFBRSxPQUFPLEdBQ3JCLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQyxDQVkzQjtJQUVLLE9BQU8sa0JBRVo7SUFFRDs7O09BR0c7SUFDSCxPQUFhLGFBQWEsQ0FBQyxPQUFPLEdBQUUsY0FBbUIseUJBYXREO0lBRUQsT0FBYSxnQkFBZ0Isa0JBTTVCO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLFlBQVksaUJBS2xCO0NBQ0Y7QUFRRCxxQkFBYSxnQkFBaUIsU0FBUSxPQUFPO0lBQzNDLFlBQVksT0FBTyxFQUFFLG1CQUFtQixFQUV2QztJQUVEOzs7Ozs7Ozs7O09BVUc7SUFDSCxPQUFhLEdBQUcsQ0FBQyxPQUFPLEdBQUUsY0FBbUIsNkJBZTVDO0lBRUQ7OztPQUdHO0lBQ0gsT0FBYSxhQUFhLENBQUMsT0FBTyxHQUFFLGNBQW1CLDZCQU90RDtJQUVELE1BQU0sQ0FBQyxnQkFBZ0IsU0FNdEI7SUFFRCxNQUFNLENBQUMsWUFBWSxxQkFLbEI7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/barretenberg/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACxF,OAAO,EAAE,cAAc,EAAe,MAAM,yBAAyB,CAAC;AAGtE,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAC9F,cAAc,yBAAyB,CAAC;AAExC,MAAM,MAAM,cAAc,GAAG;IAC3B,4DAA4D;IAC5D,SAAS,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF;;;GAGG;AACH,qBAAa,YAAa,SAAQ,QAAQ;IACxC,OAAO,CAAC,OAAO,CAAiB;IAEhC,YAAY,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,cAAc,EAGjE;IAED;;;;;;;OAOG;IACH,OAAa,GAAG,CAAC,OAAO,GAAE,cAAmB,yBA2B5C;IAEK,YAAY,CAAC,OAAO,SAA2B,GAAG,OAAO,CAAC,IAAI,CAAC,CASpE;IAED,iBAAiB,IAAI,MAAM,CAO1B;IAEK,mBAAmB,CACvB,QAAQ,EAAE,UAAU,EACpB,SAAS,EAAE,OAAO,EAClB,aAAa,EAAE,OAAO,GACrB,OAAO,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAY3B;IAEK,OAAO,kBAEZ;IAED;;;OAGG;IACH,OAAa,aAAa,CAAC,OAAO,GAAE,cAAmB,yBAatD;IAED,OAAa,gBAAgB,kBAM5B;IAED;;;OAGG;IACH,MAAM,CAAC,YAAY,iBAKlB;CACF;AAQD,qBAAa,gBAAiB,SAAQ,OAAO;IAC3C,YAAY,OAAO,EAAE,mBAAmB,EAEvC;IAED;;;;;;;;;;OAUG;IACH,OAAa,GAAG,CAAC,OAAO,GAAE,cAAmB,6BAe5C;IAED;;;OAGG;IACH,OAAa,aAAa,CAAC,OAAO,GAAE,cAAmB,6BAOtD;IAED,MAAM,CAAC,gBAAgB,SAMtB;IAED,MAAM,CAAC,YAAY,qBAKlB;CACF"}