@reclaimprotocol/attestor-core 4.0.3 → 5.0.1-beta.10

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 (474) hide show
  1. package/LICENSE +660 -660
  2. package/README.md +1 -2
  3. package/lib/avs/abis/avsDirectoryABI.js +341 -342
  4. package/lib/avs/abis/delegationABI.js +4 -5
  5. package/lib/avs/abis/registryABI.js +722 -723
  6. package/lib/avs/client/create-claim-on-avs.d.ts +5 -5
  7. package/lib/avs/client/create-claim-on-avs.js +160 -139
  8. package/lib/avs/config.d.ts +1 -1
  9. package/lib/avs/config.js +25 -23
  10. package/lib/avs/contracts/ReclaimServiceManager.d.ts +436 -532
  11. package/lib/avs/contracts/ReclaimServiceManager.js +0 -3
  12. package/lib/avs/contracts/common.d.ts +40 -11
  13. package/lib/avs/contracts/common.js +0 -3
  14. package/lib/avs/contracts/factories/ReclaimServiceManager__factory.d.ts +13 -11
  15. package/lib/avs/contracts/factories/ReclaimServiceManager__factory.js +1157 -1148
  16. package/lib/avs/contracts/factories/index.d.ts +1 -1
  17. package/lib/avs/contracts/factories/index.js +4 -9
  18. package/lib/avs/contracts/index.d.ts +3 -3
  19. package/lib/avs/contracts/index.js +6 -40
  20. package/lib/avs/types/index.d.ts +6 -6
  21. package/lib/avs/types/index.js +0 -3
  22. package/lib/avs/utils/contracts.d.ts +14 -14
  23. package/lib/avs/utils/contracts.js +50 -35
  24. package/lib/avs/utils/register.d.ts +3 -3
  25. package/lib/avs/utils/register.js +71 -79
  26. package/lib/avs/utils/tasks.d.ts +4 -4
  27. package/lib/avs/utils/tasks.js +44 -41
  28. package/lib/browser/avs/abis/avsDirectoryABI.d.ts +60 -0
  29. package/lib/browser/avs/abis/avsDirectoryABI.js +343 -0
  30. package/lib/browser/avs/abis/delegationABI.d.ts +126 -0
  31. package/lib/browser/avs/abis/delegationABI.js +4 -0
  32. package/lib/browser/avs/abis/registryABI.d.ts +136 -0
  33. package/lib/browser/avs/abis/registryABI.js +728 -0
  34. package/lib/browser/avs/client/create-claim-on-avs.d.ts +12 -0
  35. package/lib/browser/avs/client/create-claim-on-avs.js +168 -0
  36. package/lib/browser/avs/config.d.ts +7 -0
  37. package/lib/browser/avs/config.js +26 -0
  38. package/lib/browser/avs/contracts/ReclaimServiceManager.d.ts +601 -0
  39. package/lib/browser/avs/contracts/ReclaimServiceManager.js +0 -0
  40. package/lib/browser/avs/contracts/common.d.ts +50 -0
  41. package/lib/browser/avs/contracts/common.js +0 -0
  42. package/lib/browser/avs/contracts/factories/ReclaimServiceManager__factory.d.ts +890 -0
  43. package/lib/browser/avs/contracts/factories/ReclaimServiceManager__factory.js +1183 -0
  44. package/lib/browser/avs/contracts/factories/index.d.ts +1 -0
  45. package/lib/browser/avs/contracts/factories/index.js +4 -0
  46. package/lib/browser/avs/contracts/index.d.ts +3 -0
  47. package/lib/browser/avs/contracts/index.js +6 -0
  48. package/lib/browser/avs/types/index.d.ts +55 -0
  49. package/lib/browser/avs/types/index.js +0 -0
  50. package/lib/browser/avs/utils/contracts.d.ts +21 -0
  51. package/lib/browser/avs/utils/contracts.js +53 -0
  52. package/lib/browser/avs/utils/register.d.ts +27 -0
  53. package/lib/browser/avs/utils/register.js +74 -0
  54. package/lib/browser/avs/utils/tasks.d.ts +22 -0
  55. package/lib/browser/avs/utils/tasks.js +48 -0
  56. package/lib/browser/client/create-claim.d.ts +5 -0
  57. package/lib/browser/client/create-claim.js +461 -0
  58. package/lib/browser/client/index.d.ts +3 -0
  59. package/lib/browser/client/index.js +3 -0
  60. package/lib/browser/client/tunnels/make-rpc-tcp-tunnel.d.ts +16 -0
  61. package/lib/browser/client/tunnels/make-rpc-tcp-tunnel.js +53 -0
  62. package/lib/browser/client/tunnels/make-rpc-tls-tunnel.d.ts +26 -0
  63. package/lib/browser/client/tunnels/make-rpc-tls-tunnel.js +127 -0
  64. package/lib/browser/client/utils/attestor-pool.d.ts +8 -0
  65. package/lib/browser/client/utils/attestor-pool.js +24 -0
  66. package/lib/browser/client/utils/client-socket.d.ts +11 -0
  67. package/lib/browser/client/utils/client-socket.js +120 -0
  68. package/lib/browser/client/utils/message-handler.d.ts +4 -0
  69. package/lib/browser/client/utils/message-handler.js +97 -0
  70. package/lib/browser/config/index.d.ts +31 -0
  71. package/lib/browser/config/index.js +62 -0
  72. package/lib/browser/external-rpc/benchmark.d.ts +1 -0
  73. package/lib/browser/external-rpc/benchmark.js +82 -0
  74. package/lib/browser/external-rpc/event-bus.d.ts +7 -0
  75. package/lib/browser/external-rpc/event-bus.js +17 -0
  76. package/lib/browser/external-rpc/global.d.js +0 -0
  77. package/lib/browser/external-rpc/handle-incoming-msg.d.ts +2 -0
  78. package/lib/browser/external-rpc/handle-incoming-msg.js +241 -0
  79. package/lib/browser/external-rpc/index.d.ts +3 -0
  80. package/lib/browser/external-rpc/index.js +3 -0
  81. package/lib/browser/external-rpc/jsc-polyfills/1.d.ts +14 -0
  82. package/lib/browser/external-rpc/jsc-polyfills/1.js +80 -0
  83. package/lib/browser/external-rpc/jsc-polyfills/2.js +15 -0
  84. package/lib/browser/external-rpc/jsc-polyfills/event.d.ts +10 -0
  85. package/lib/browser/external-rpc/jsc-polyfills/event.js +19 -0
  86. package/lib/browser/external-rpc/jsc-polyfills/index.d.ts +2 -0
  87. package/lib/browser/external-rpc/jsc-polyfills/index.js +2 -0
  88. package/lib/browser/external-rpc/jsc-polyfills/ws.d.ts +21 -0
  89. package/lib/browser/external-rpc/jsc-polyfills/ws.js +83 -0
  90. package/lib/browser/external-rpc/setup-browser.d.ts +6 -0
  91. package/lib/browser/external-rpc/setup-browser.js +33 -0
  92. package/lib/browser/external-rpc/setup-jsc.d.ts +24 -0
  93. package/lib/browser/external-rpc/setup-jsc.js +22 -0
  94. package/lib/{window-rpc → browser/external-rpc}/types.d.ts +56 -35
  95. package/lib/browser/external-rpc/types.js +0 -0
  96. package/lib/browser/external-rpc/utils.d.ts +20 -0
  97. package/lib/browser/external-rpc/utils.js +100 -0
  98. package/lib/browser/external-rpc/zk.d.ts +14 -0
  99. package/lib/browser/external-rpc/zk.js +58 -0
  100. package/lib/browser/index.browser.js +13 -0
  101. package/lib/browser/index.d.ts +9 -0
  102. package/lib/browser/index.js +13 -0
  103. package/lib/browser/mechain/abis/governanceABI.d.ts +50 -0
  104. package/lib/browser/mechain/abis/governanceABI.js +461 -0
  105. package/lib/browser/mechain/abis/taskABI.d.ts +157 -0
  106. package/lib/browser/mechain/abis/taskABI.js +512 -0
  107. package/lib/browser/mechain/client/create-claim-on-mechain.d.ts +10 -0
  108. package/lib/browser/mechain/client/create-claim-on-mechain.js +33 -0
  109. package/lib/browser/mechain/client/index.d.ts +1 -0
  110. package/lib/browser/mechain/client/index.js +1 -0
  111. package/lib/browser/mechain/constants/index.d.ts +3 -0
  112. package/lib/browser/mechain/constants/index.js +8 -0
  113. package/lib/browser/mechain/index.d.ts +2 -0
  114. package/lib/browser/mechain/index.js +2 -0
  115. package/lib/browser/mechain/types/index.d.ts +23 -0
  116. package/lib/browser/mechain/types/index.js +0 -0
  117. package/lib/browser/proto/api.d.ts +651 -0
  118. package/lib/browser/proto/api.js +4250 -0
  119. package/lib/browser/proto/tee-bundle.d.ts +156 -0
  120. package/lib/browser/proto/tee-bundle.js +1296 -0
  121. package/lib/browser/providers/http/index.d.ts +18 -0
  122. package/lib/browser/providers/http/index.js +640 -0
  123. package/lib/browser/providers/http/patch-parse5-tree.d.ts +6 -0
  124. package/lib/browser/providers/http/patch-parse5-tree.js +34 -0
  125. package/lib/browser/providers/http/utils.d.ts +77 -0
  126. package/lib/browser/providers/http/utils.js +283 -0
  127. package/lib/browser/providers/index.d.ts +4 -0
  128. package/lib/browser/providers/index.js +7 -0
  129. package/lib/browser/scripts/fallbacks/crypto.js +4 -0
  130. package/lib/browser/scripts/fallbacks/empty.js +4 -0
  131. package/lib/browser/scripts/fallbacks/gnark.js +15 -0
  132. package/lib/browser/scripts/fallbacks/re2.js +7 -0
  133. package/lib/browser/scripts/fallbacks/snarkjs.js +10 -0
  134. package/lib/browser/scripts/fallbacks/stwo.js +159 -0
  135. package/lib/browser/types/bgp.d.ts +11 -0
  136. package/lib/browser/types/bgp.js +0 -0
  137. package/lib/browser/types/claims.d.ts +70 -0
  138. package/lib/browser/types/claims.js +0 -0
  139. package/lib/browser/types/client.d.ts +163 -0
  140. package/lib/browser/types/client.js +0 -0
  141. package/lib/browser/types/general.d.ts +77 -0
  142. package/lib/browser/types/general.js +0 -0
  143. package/lib/browser/types/handlers.d.ts +10 -0
  144. package/lib/browser/types/handlers.js +0 -0
  145. package/lib/browser/types/index.d.ts +10 -0
  146. package/lib/browser/types/index.js +10 -0
  147. package/lib/browser/types/providers.d.ts +161 -0
  148. package/lib/browser/types/providers.gen.d.ts +443 -0
  149. package/lib/browser/types/providers.gen.js +16 -0
  150. package/lib/browser/types/providers.js +0 -0
  151. package/lib/browser/types/rpc.d.ts +35 -0
  152. package/lib/browser/types/rpc.js +0 -0
  153. package/lib/browser/types/signatures.d.ts +28 -0
  154. package/lib/browser/types/signatures.js +0 -0
  155. package/lib/browser/types/tunnel.d.ts +18 -0
  156. package/lib/browser/types/tunnel.js +0 -0
  157. package/lib/browser/types/zk.d.ts +38 -0
  158. package/lib/browser/types/zk.js +0 -0
  159. package/lib/browser/utils/auth.d.ts +8 -0
  160. package/lib/browser/utils/auth.js +71 -0
  161. package/lib/browser/utils/b64-json.d.ts +2 -0
  162. package/lib/browser/utils/b64-json.js +17 -0
  163. package/lib/browser/utils/claims.d.ts +33 -0
  164. package/lib/browser/utils/claims.js +89 -0
  165. package/lib/browser/utils/env.d.ts +3 -0
  166. package/lib/browser/utils/env.js +19 -0
  167. package/lib/browser/utils/error.d.ts +26 -0
  168. package/lib/browser/utils/error.js +54 -0
  169. package/lib/browser/utils/generics.d.ts +119 -0
  170. package/lib/browser/utils/generics.js +272 -0
  171. package/lib/browser/utils/http-parser.d.ts +59 -0
  172. package/lib/browser/utils/http-parser.js +201 -0
  173. package/lib/browser/utils/index.browser.js +13 -0
  174. package/lib/browser/utils/index.d.ts +13 -0
  175. package/lib/browser/utils/index.js +13 -0
  176. package/lib/browser/utils/logger.browser.js +88 -0
  177. package/lib/browser/utils/logger.d.ts +14 -0
  178. package/lib/browser/utils/logger.js +88 -0
  179. package/lib/browser/utils/prepare-packets.d.ts +16 -0
  180. package/lib/browser/utils/prepare-packets.js +69 -0
  181. package/lib/browser/utils/redactions.d.ts +73 -0
  182. package/lib/browser/utils/redactions.js +135 -0
  183. package/lib/browser/utils/retries.d.ts +12 -0
  184. package/lib/browser/utils/retries.js +26 -0
  185. package/lib/browser/utils/signatures/eth.d.ts +2 -0
  186. package/lib/browser/utils/signatures/eth.js +31 -0
  187. package/lib/browser/utils/signatures/index.d.ts +5 -0
  188. package/lib/browser/utils/signatures/index.js +12 -0
  189. package/lib/browser/utils/socket-base.d.ts +23 -0
  190. package/lib/browser/utils/socket-base.js +96 -0
  191. package/lib/browser/utils/tls-imports.d.ts +21 -0
  192. package/lib/browser/utils/tls-imports.js +71 -0
  193. package/lib/browser/utils/tls.d.ts +2 -0
  194. package/lib/browser/utils/tls.js +58 -0
  195. package/lib/browser/utils/ws.d.ts +7 -0
  196. package/lib/browser/utils/ws.js +22 -0
  197. package/lib/browser/utils/zk.d.ts +71 -0
  198. package/lib/browser/utils/zk.js +625 -0
  199. package/lib/client/create-claim.d.ts +2 -2
  200. package/lib/client/create-claim.js +437 -400
  201. package/lib/client/index.d.ts +3 -3
  202. package/lib/client/index.js +3 -20
  203. package/lib/client/tunnels/make-rpc-tcp-tunnel.d.ts +2 -2
  204. package/lib/client/tunnels/make-rpc-tcp-tunnel.js +49 -56
  205. package/lib/client/tunnels/make-rpc-tls-tunnel.d.ts +4 -3
  206. package/lib/client/tunnels/make-rpc-tls-tunnel.js +123 -131
  207. package/lib/client/utils/attestor-pool.d.ts +3 -1
  208. package/lib/client/utils/attestor-pool.js +21 -25
  209. package/lib/client/utils/client-socket.d.ts +4 -4
  210. package/lib/client/utils/client-socket.js +114 -94
  211. package/lib/client/utils/message-handler.d.ts +2 -2
  212. package/lib/client/utils/message-handler.js +89 -86
  213. package/lib/config/index.d.ts +6 -3
  214. package/lib/config/index.js +60 -37
  215. package/lib/external-rpc/benchmark.d.ts +1 -0
  216. package/lib/external-rpc/benchmark.js +82 -0
  217. package/lib/external-rpc/event-bus.d.ts +7 -0
  218. package/lib/external-rpc/event-bus.js +17 -0
  219. package/lib/external-rpc/global.d.js +0 -0
  220. package/lib/external-rpc/handle-incoming-msg.d.ts +2 -0
  221. package/lib/external-rpc/handle-incoming-msg.js +241 -0
  222. package/lib/external-rpc/index.d.ts +3 -0
  223. package/lib/external-rpc/index.js +3 -0
  224. package/lib/external-rpc/jsc-polyfills/1.d.ts +14 -0
  225. package/lib/external-rpc/jsc-polyfills/1.js +80 -0
  226. package/lib/external-rpc/jsc-polyfills/2.js +15 -0
  227. package/lib/external-rpc/jsc-polyfills/event.d.ts +10 -0
  228. package/lib/external-rpc/jsc-polyfills/event.js +19 -0
  229. package/lib/external-rpc/jsc-polyfills/index.d.ts +2 -0
  230. package/lib/external-rpc/jsc-polyfills/index.js +2 -0
  231. package/lib/external-rpc/jsc-polyfills/ws.d.ts +21 -0
  232. package/lib/external-rpc/jsc-polyfills/ws.js +83 -0
  233. package/lib/external-rpc/setup-browser.d.ts +6 -0
  234. package/lib/external-rpc/setup-browser.js +33 -0
  235. package/lib/external-rpc/setup-jsc.d.ts +24 -0
  236. package/lib/external-rpc/setup-jsc.js +22 -0
  237. package/lib/external-rpc/types.d.ts +213 -0
  238. package/lib/external-rpc/types.js +0 -0
  239. package/lib/external-rpc/utils.d.ts +20 -0
  240. package/lib/external-rpc/utils.js +100 -0
  241. package/lib/external-rpc/zk.d.ts +14 -0
  242. package/lib/external-rpc/zk.js +58 -0
  243. package/lib/index.browser.d.ts +9 -0
  244. package/lib/index.d.ts +8 -9
  245. package/lib/index.js +12 -49
  246. package/lib/mechain/abis/governanceABI.js +460 -461
  247. package/lib/mechain/abis/taskABI.js +505 -506
  248. package/lib/mechain/client/create-claim-on-mechain.d.ts +3 -3
  249. package/lib/mechain/client/create-claim-on-mechain.js +31 -30
  250. package/lib/mechain/client/index.d.ts +1 -1
  251. package/lib/mechain/client/index.js +1 -18
  252. package/lib/mechain/constants/index.js +8 -7
  253. package/lib/mechain/index.d.ts +2 -2
  254. package/lib/mechain/index.js +2 -19
  255. package/lib/mechain/types/index.d.ts +2 -2
  256. package/lib/mechain/types/index.js +0 -3
  257. package/lib/proto/api.d.ts +182 -39
  258. package/lib/proto/api.js +4105 -3555
  259. package/lib/proto/tee-bundle.d.ts +156 -0
  260. package/lib/proto/tee-bundle.js +1296 -0
  261. package/lib/providers/http/index.d.ts +16 -1
  262. package/lib/providers/http/index.js +603 -576
  263. package/lib/providers/http/patch-parse5-tree.d.ts +6 -0
  264. package/lib/providers/http/patch-parse5-tree.js +34 -0
  265. package/lib/providers/http/utils.d.ts +7 -4
  266. package/lib/providers/http/utils.js +240 -317
  267. package/lib/providers/index.d.ts +1 -1
  268. package/lib/providers/index.js +5 -9
  269. package/lib/scripts/check-avs-registration.d.ts +1 -1
  270. package/lib/scripts/check-avs-registration.js +24 -25
  271. package/lib/scripts/fallbacks/crypto.d.ts +1 -0
  272. package/lib/scripts/fallbacks/crypto.js +4 -0
  273. package/lib/scripts/fallbacks/empty.d.ts +3 -0
  274. package/lib/scripts/fallbacks/empty.js +4 -0
  275. package/lib/scripts/fallbacks/gnark.d.ts +7 -0
  276. package/lib/scripts/fallbacks/gnark.js +15 -0
  277. package/lib/scripts/fallbacks/re2.d.ts +1 -0
  278. package/lib/scripts/fallbacks/re2.js +7 -0
  279. package/lib/scripts/fallbacks/snarkjs.d.ts +1 -0
  280. package/lib/scripts/fallbacks/snarkjs.js +10 -0
  281. package/lib/scripts/fallbacks/stwo.d.ts +6 -0
  282. package/lib/scripts/generate-provider-types.js +92 -73
  283. package/lib/scripts/generate-receipt.d.ts +2 -2
  284. package/lib/scripts/generate-receipt.js +94 -83
  285. package/lib/scripts/generate-toprf-keys.js +17 -16
  286. package/lib/scripts/jsc-cli-rpc.d.ts +1 -0
  287. package/lib/scripts/jsc-cli-rpc.js +35 -0
  288. package/lib/scripts/register-avs-operator.d.ts +1 -1
  289. package/lib/scripts/register-avs-operator.js +3 -7
  290. package/lib/scripts/start-server.d.ts +1 -1
  291. package/lib/scripts/start-server.js +9 -11
  292. package/lib/scripts/update-avs-metadata.d.ts +1 -1
  293. package/lib/scripts/update-avs-metadata.js +17 -19
  294. package/lib/scripts/utils.js +8 -9
  295. package/lib/scripts/whitelist-operator.d.ts +1 -1
  296. package/lib/scripts/whitelist-operator.js +13 -15
  297. package/lib/server/create-server.d.ts +3 -2
  298. package/lib/server/create-server.js +98 -85
  299. package/lib/server/handlers/claimTeeBundle.d.ts +6 -0
  300. package/lib/server/handlers/claimTeeBundle.js +232 -0
  301. package/lib/server/handlers/claimTunnel.d.ts +1 -1
  302. package/lib/server/handlers/claimTunnel.js +75 -73
  303. package/lib/server/handlers/completeClaimOnChain.d.ts +1 -1
  304. package/lib/server/handlers/completeClaimOnChain.js +27 -26
  305. package/lib/server/handlers/createClaimOnChain.d.ts +1 -1
  306. package/lib/server/handlers/createClaimOnChain.js +30 -29
  307. package/lib/server/handlers/createTaskOnMechain.d.ts +1 -1
  308. package/lib/server/handlers/createTaskOnMechain.js +54 -49
  309. package/lib/server/handlers/createTunnel.d.ts +1 -1
  310. package/lib/server/handlers/createTunnel.js +91 -94
  311. package/lib/server/handlers/disconnectTunnel.d.ts +1 -1
  312. package/lib/server/handlers/disconnectTunnel.js +6 -8
  313. package/lib/server/handlers/fetchCertificateBytes.d.ts +2 -0
  314. package/lib/server/handlers/fetchCertificateBytes.js +57 -0
  315. package/lib/server/handlers/index.d.ts +1 -1
  316. package/lib/server/handlers/index.js +24 -21
  317. package/lib/server/handlers/init.d.ts +1 -1
  318. package/lib/server/handlers/init.js +31 -34
  319. package/lib/server/handlers/toprf.d.ts +1 -1
  320. package/lib/server/handlers/toprf.js +17 -19
  321. package/lib/server/index.d.ts +4 -4
  322. package/lib/server/index.js +4 -21
  323. package/lib/server/socket.d.ts +7 -7
  324. package/lib/server/socket.js +104 -106
  325. package/lib/server/tunnels/make-tcp-tunnel.d.ts +5 -3
  326. package/lib/server/tunnels/make-tcp-tunnel.js +189 -162
  327. package/lib/server/utils/apm.d.ts +1 -1
  328. package/lib/server/utils/apm.js +26 -40
  329. package/lib/server/utils/assert-valid-claim-request.d.ts +6 -5
  330. package/lib/server/utils/assert-valid-claim-request.js +339 -185
  331. package/lib/server/utils/config-env.js +4 -7
  332. package/lib/server/utils/dns.js +18 -16
  333. package/lib/server/utils/gcp-attestation.d.ts +17 -0
  334. package/lib/server/utils/gcp-attestation.js +237 -0
  335. package/lib/server/utils/generics.d.ts +3 -3
  336. package/lib/server/utils/generics.js +37 -51
  337. package/lib/server/utils/iso.js +255 -256
  338. package/lib/server/utils/keep-alive.d.ts +2 -2
  339. package/lib/server/utils/keep-alive.js +36 -40
  340. package/lib/server/utils/nitro-attestation.d.ts +33 -0
  341. package/lib/server/utils/nitro-attestation.js +249 -0
  342. package/lib/server/utils/oprf-raw.d.ts +21 -0
  343. package/lib/server/utils/oprf-raw.js +61 -0
  344. package/lib/server/utils/process-handshake.d.ts +3 -3
  345. package/lib/server/utils/process-handshake.js +217 -175
  346. package/lib/server/utils/proxy-session.d.ts +1 -0
  347. package/lib/server/utils/proxy-session.js +4 -0
  348. package/lib/server/utils/tee-oprf-mpc-verification.d.ts +16 -0
  349. package/lib/server/utils/tee-oprf-mpc-verification.js +86 -0
  350. package/lib/server/utils/tee-oprf-verification.d.ts +24 -0
  351. package/lib/server/utils/tee-oprf-verification.js +151 -0
  352. package/lib/server/utils/tee-transcript-reconstruction.d.ts +24 -0
  353. package/lib/server/utils/tee-transcript-reconstruction.js +140 -0
  354. package/lib/server/utils/tee-verification.d.ts +28 -0
  355. package/lib/server/utils/tee-verification.js +358 -0
  356. package/lib/{utils → server/utils}/validation.d.ts +1 -1
  357. package/lib/server/utils/validation.js +45 -0
  358. package/lib/types/bgp.js +0 -3
  359. package/lib/types/claims.d.ts +7 -10
  360. package/lib/types/claims.js +0 -3
  361. package/lib/types/client.d.ts +5 -5
  362. package/lib/types/client.js +0 -3
  363. package/lib/types/general.d.ts +30 -4
  364. package/lib/types/general.js +0 -3
  365. package/lib/types/handlers.d.ts +3 -3
  366. package/lib/types/handlers.js +0 -3
  367. package/lib/types/index.d.ts +10 -10
  368. package/lib/types/index.js +10 -27
  369. package/lib/types/providers.d.ts +15 -4
  370. package/lib/types/providers.gen.d.ts +15 -1
  371. package/lib/types/providers.gen.js +15 -13
  372. package/lib/types/providers.js +0 -3
  373. package/lib/types/rpc.d.ts +2 -2
  374. package/lib/types/rpc.js +0 -3
  375. package/lib/types/signatures.js +0 -3
  376. package/lib/types/tunnel.d.ts +2 -2
  377. package/lib/types/tunnel.js +0 -3
  378. package/lib/types/zk.d.ts +17 -2
  379. package/lib/types/zk.js +0 -3
  380. package/lib/utils/auth.d.ts +2 -1
  381. package/lib/utils/auth.js +66 -59
  382. package/lib/utils/b64-json.js +13 -19
  383. package/lib/utils/bgp-listener.d.ts +1 -1
  384. package/lib/utils/bgp-listener.js +111 -114
  385. package/lib/utils/claims.d.ts +3 -3
  386. package/lib/utils/claims.js +78 -101
  387. package/lib/utils/env.js +15 -16
  388. package/lib/utils/error.d.ts +6 -7
  389. package/lib/utils/error.js +50 -39
  390. package/lib/utils/generics.d.ts +20 -13
  391. package/lib/utils/generics.js +221 -297
  392. package/lib/utils/http-parser.d.ts +1 -1
  393. package/lib/utils/http-parser.js +186 -237
  394. package/lib/utils/index.browser.d.ts +13 -0
  395. package/lib/utils/index.d.ts +14 -12
  396. package/lib/utils/index.js +14 -29
  397. package/lib/utils/logger.browser.d.ts +14 -0
  398. package/lib/utils/logger.d.ts +1 -1
  399. package/lib/utils/logger.js +69 -87
  400. package/lib/utils/prepare-packets.d.ts +3 -3
  401. package/lib/utils/prepare-packets.js +66 -58
  402. package/lib/utils/redactions.d.ts +20 -1
  403. package/lib/utils/redactions.js +116 -129
  404. package/lib/utils/retries.d.ts +1 -1
  405. package/lib/utils/retries.js +24 -26
  406. package/lib/utils/signatures/eth.d.ts +1 -1
  407. package/lib/utils/signatures/eth.js +28 -30
  408. package/lib/utils/signatures/index.d.ts +3 -3
  409. package/lib/utils/signatures/index.js +11 -10
  410. package/lib/utils/socket-base.d.ts +6 -5
  411. package/lib/utils/socket-base.js +89 -88
  412. package/lib/utils/tls-imports.d.ts +21 -0
  413. package/lib/utils/tls-imports.js +71 -0
  414. package/lib/utils/tls.d.ts +1 -1
  415. package/lib/utils/tls.js +54 -28
  416. package/lib/utils/ws.d.ts +1 -6
  417. package/lib/utils/ws.js +17 -33
  418. package/lib/utils/zk.d.ts +28 -12
  419. package/lib/utils/zk.js +587 -406
  420. package/package.json +79 -60
  421. package/lib/avs/tests/test.operator.d.ts +0 -11
  422. package/lib/avs/tests/test.operator.js +0 -313
  423. package/lib/avs/tests/utils.d.ts +0 -2
  424. package/lib/avs/tests/utils.js +0 -50
  425. package/lib/scripts/verify-root-ca.d.ts +0 -1
  426. package/lib/scripts/verify-root-ca.js +0 -51
  427. package/lib/tests/describe-with-server.d.ts +0 -20
  428. package/lib/tests/describe-with-server.js +0 -64
  429. package/lib/tests/mock-provider-server.d.ts +0 -13
  430. package/lib/tests/mock-provider-server.js +0 -65
  431. package/lib/tests/mocks.d.ts +0 -4
  432. package/lib/tests/mocks.js +0 -23
  433. package/lib/tests/test.auth.js +0 -75
  434. package/lib/tests/test.bgp-listener.js +0 -169
  435. package/lib/tests/test.claim-creation.js +0 -280
  436. package/lib/tests/test.http-parser.d.ts +0 -1
  437. package/lib/tests/test.http-parser.js +0 -120
  438. package/lib/tests/test.http-provider-utils.js +0 -2416
  439. package/lib/tests/test.http-provider.js +0 -114
  440. package/lib/tests/test.rpc-communication.d.ts +0 -1
  441. package/lib/tests/test.rpc-communication.js +0 -64
  442. package/lib/tests/test.rpc-tunnel.d.ts +0 -1
  443. package/lib/tests/test.rpc-tunnel.js +0 -172
  444. package/lib/tests/test.signatures.d.ts +0 -1
  445. package/lib/tests/test.signatures.js +0 -24
  446. package/lib/tests/test.tcp-tunnel.d.ts +0 -1
  447. package/lib/tests/test.tcp-tunnel.js +0 -64
  448. package/lib/tests/test.zk.d.ts +0 -1
  449. package/lib/tests/test.zk.js +0 -337
  450. package/lib/tests/utils.d.ts +0 -18
  451. package/lib/tests/utils.js +0 -64
  452. package/lib/utils/atomic-operations.d.ts +0 -24
  453. package/lib/utils/atomic-operations.js +0 -65
  454. package/lib/utils/benchmark.d.ts +0 -1
  455. package/lib/utils/benchmark.js +0 -70
  456. package/lib/utils/connection-state-machine.d.ts +0 -43
  457. package/lib/utils/connection-state-machine.js +0 -129
  458. package/lib/utils/resource-monitor.d.ts +0 -61
  459. package/lib/utils/resource-monitor.js +0 -107
  460. package/lib/utils/validation.js +0 -46
  461. package/lib/window-rpc/index.d.ts +0 -3
  462. package/lib/window-rpc/index.js +0 -20
  463. package/lib/window-rpc/setup-window-rpc.d.ts +0 -5
  464. package/lib/window-rpc/setup-window-rpc.js +0 -291
  465. package/lib/window-rpc/types.js +0 -3
  466. package/lib/window-rpc/utils.d.ts +0 -14
  467. package/lib/window-rpc/utils.js +0 -102
  468. package/lib/window-rpc/window-rpc-zk.d.ts +0 -15
  469. package/lib/window-rpc/window-rpc-zk.js +0 -85
  470. /package/lib/{tests/test.auth.d.ts → browser/external-rpc/jsc-polyfills/2.d.ts} +0 -0
  471. /package/lib/{tests/test.bgp-listener.d.ts → external-rpc/jsc-polyfills/2.d.ts} +0 -0
  472. /package/lib/{tests/test.claim-creation.d.ts → scripts/build-browser.d.ts} +0 -0
  473. /package/lib/{tests/test.http-provider-utils.d.ts → scripts/build-jsc.d.ts} +0 -0
  474. /package/lib/{tests/test.http-provider.d.ts → scripts/build-lib.d.ts} +0 -0
package/lib/utils/zk.js CHANGED
@@ -1,444 +1,625 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.makeZkProofGenerator = makeZkProofGenerator;
4
- exports.verifyZkPacket = verifyZkPacket;
5
- exports.makeDefaultZkOperator = makeDefaultZkOperator;
6
- exports.makeDefaultOPRFOperator = makeDefaultOPRFOperator;
7
- exports.getEngineString = getEngineString;
8
- exports.getEngineProto = getEngineProto;
9
- const tls_1 = require("@reclaimprotocol/tls");
10
- const zk_symmetric_crypto_1 = require("@reclaimprotocol/zk-symmetric-crypto");
11
- const config_1 = require("../config");
12
- const api_1 = require("../proto/api");
13
- const env_1 = require("../utils/env");
14
- const error_1 = require("../utils/error");
15
- const generics_1 = require("../utils/generics");
16
- const logger_1 = require("../utils/logger");
17
- const redactions_1 = require("../utils/redactions");
18
- const ZK_CONCURRENCY = +((0, env_1.getEnvVariable)('ZK_CONCURRENCY')
19
- || config_1.DEFAULT_ZK_CONCURRENCY);
20
- async function makeZkProofGenerator({ zkOperators, oprfOperators, logger = logger_1.logger, zkProofConcurrency = ZK_CONCURRENCY, cipherSuite, zkEngine = 'snarkjs' }) {
21
- const { default: PQueue } = await import('p-queue');
22
- const zkQueue = new PQueue({
23
- concurrency: zkProofConcurrency,
24
- autoStart: true,
25
- });
26
- const packetsToProve = [];
27
- logger = (logger || logger_1.logger).child({ module: 'zk', zkEngine: zkEngine });
28
- let zkProofsToGen = 0;
29
- return {
30
- /**
31
- * Adds the given packet to the list of packets to
32
- * generate ZK proofs for.
33
- *
34
- * Call `generateProofs()` to finally generate the proofs
35
- */
36
- async addPacketToProve(packet, { redactedPlaintext, toprfs }, onGeneratedProofs) {
37
- if (packet.type === 'plaintext') {
38
- throw new Error('Cannot generate proof for plaintext');
39
- }
40
- const alg = (0, generics_1.getZkAlgorithmForCipherSuite)(cipherSuite);
41
- const chunkSizeBytes = getChunkSizeBytes(alg);
42
- const key = await tls_1.crypto.exportKey(packet.encKey);
43
- const iv = packet.iv;
44
- const ciphertext = (0, generics_1.getPureCiphertext)(packet.ciphertext, cipherSuite);
45
- const packetToProve = {
46
- onGeneratedProofs,
47
- algorithm: alg,
48
- proofsToGenerate: [],
49
- iv: packet.fixedIv,
50
- };
51
- const slicesDone = [];
52
- // first we'll handle all TOPRF blocks
53
- // we do these first, because they can span multiple chunks
54
- // & we need to be able to span the right chunks
55
- for (const toprf of toprfs || []) {
56
- const fromIndex = getIdealOffsetForToprfBlock(alg, toprf);
57
- const toIndex = Math.min(fromIndex + chunkSizeBytes, ciphertext.length);
58
- // ensure this OPRF block doesn't overlap with any other OPRF block
59
- const slice = { fromIndex, toIndex };
60
- assertNoOverlapOprf(slice);
61
- addProofsToGenerate(slice, {
62
- ...toprf,
63
- dataLocation: {
64
- ...toprf.dataLocation,
65
- fromIndex: toprf.dataLocation.fromIndex - fromIndex
66
- }
67
- });
68
- }
69
- // now we'll go through the rest of the ciphertext, and add proofs
70
- // for the sections that haven't been covered by the TOPRF blocks
71
- const slicesCp = sortSlices(slicesDone.slice());
72
- let fromIndex = 0;
73
- for (const done of slicesCp) {
74
- if (done.fromIndex > fromIndex) {
75
- addProofsToGenerate({
76
- fromIndex,
77
- toIndex: done.fromIndex
78
- });
79
- }
80
- fromIndex = done.toIndex;
81
- }
82
- if (fromIndex < ciphertext.length) {
83
- addProofsToGenerate({
84
- fromIndex,
85
- toIndex: ciphertext.length
86
- });
87
- }
88
- // generate proofs in order of start index
89
- packetToProve.proofsToGenerate
90
- .sort((a, b) => a.startIdx - b.startIdx);
91
- packetsToProve.push(packetToProve);
92
- function assertNoOverlapOprf(slice) {
93
- for (const done of slicesDone) {
94
- if (
95
- // 1d box overlap
96
- slice.fromIndex < done.toIndex
97
- && slice.toIndex > done.fromIndex) {
98
- throw new error_1.AttestorError('ERROR_BAD_REQUEST', 'Single chunk has multiple OPRFs');
99
- }
100
- }
101
- }
102
- function addProofsToGenerate({ fromIndex, toIndex }, toprf) {
103
- for (let i = fromIndex; i < toIndex; i += chunkSizeBytes) {
104
- const slice = {
105
- fromIndex: i,
106
- toIndex: Math.min(i + chunkSizeBytes, toIndex)
107
- };
108
- slicesDone.push(slice);
109
- const proofParams = getProofGenerationParamsForSlice({
110
- key,
111
- iv,
112
- ciphertext,
113
- redactedPlaintext,
114
- slice,
115
- toprf,
116
- });
117
- if (!proofParams) {
118
- continue;
119
- }
120
- packetToProve.proofsToGenerate.push(proofParams);
121
- zkProofsToGen += 1;
122
- }
123
- }
124
- },
125
- getTotalChunksToProve() {
126
- return zkProofsToGen;
127
- },
128
- async generateProofs(onChunkDone) {
129
- var _a;
130
- if (!packetsToProve.length) {
131
- return;
132
- }
133
- const start = Date.now();
134
- const tasks = [];
135
- for (const { onGeneratedProofs, algorithm, proofsToGenerate } of packetsToProve) {
136
- const proofs = [];
137
- let proofsLeft = proofsToGenerate.length;
138
- for (const proofToGen of proofsToGenerate) {
139
- tasks.push(zkQueue.add(async () => {
140
- const proof = await generateProofForChunk(algorithm, proofToGen);
141
- onChunkDone === null || onChunkDone === void 0 ? void 0 : onChunkDone();
142
- proofs.push(proof);
143
- proofsLeft -= 1;
144
- if (proofsLeft === 0) {
145
- onGeneratedProofs(proofs);
146
- }
147
- }, { throwOnTimeout: true }));
148
- }
149
- }
150
- await Promise.all(tasks);
151
- logger === null || logger === void 0 ? void 0 : logger.info({ durationMs: Date.now() - start, zkProofsToGen }, 'generated ZK proofs');
152
- // reset the packets to prove
153
- packetsToProve.splice(0, packetsToProve.length);
154
- zkProofsToGen = 0;
155
- // release ZK resources to free up memory
156
- const alg = (0, generics_1.getZkAlgorithmForCipherSuite)(cipherSuite);
157
- const zkOperator = await getZkOperatorForAlgorithm(alg);
158
- (_a = zkOperator.release) === null || _a === void 0 ? void 0 : _a.call(zkOperator);
159
- },
160
- };
161
- async function generateProofForChunk(algorithm, { startIdx, redactedPlaintext, privateInput, publicInput, toprf, }) {
162
- const operator = toprf
163
- ? getOprfOperatorForAlgorithm(algorithm)
164
- : getZkOperatorForAlgorithm(algorithm);
165
- const proof = await (0, zk_symmetric_crypto_1.generateProof)({
166
- algorithm,
167
- privateInput,
168
- publicInput,
169
- operator,
170
- logger,
171
- ...(toprf
172
- ? {
173
- toprf: {
174
- pos: toprf.dataLocation.fromIndex,
175
- len: toprf.dataLocation.length,
176
- output: toprf.nullifier,
177
- responses: toprf.responses,
178
- domainSeparator: config_1.TOPRF_DOMAIN_SEPARATOR
179
- },
180
- mask: toprf.mask,
181
- }
182
- : {})
183
- });
184
- logger === null || logger === void 0 ? void 0 : logger.debug({ startIdx }, 'generated proof for chunk');
185
- return {
186
- // backwards compatibility
187
- proofJson: '',
188
- proofData: typeof proof.proofData === 'string'
189
- ? (0, tls_1.strToUint8Array)(proof.proofData)
190
- : proof.proofData,
191
- toprf,
192
- decryptedRedactedCiphertext: proof.plaintext,
193
- redactedPlaintext,
194
- startIdx
195
- };
196
- }
197
- function getZkOperatorForAlgorithm(algorithm) {
198
- return (zkOperators === null || zkOperators === void 0 ? void 0 : zkOperators[algorithm])
199
- || makeDefaultZkOperator(algorithm, zkEngine, logger);
200
- }
201
- function getOprfOperatorForAlgorithm(algorithm) {
202
- return (oprfOperators === null || oprfOperators === void 0 ? void 0 : oprfOperators[algorithm])
203
- || makeDefaultOPRFOperator(algorithm, zkEngine, logger);
204
- }
205
- }
206
- /**
207
- * Verify the given ZK proof
208
- */
209
- async function verifyZkPacket({ cipherSuite, ciphertext, zkReveal, zkOperators, oprfOperators, logger = logger_1.logger, zkEngine = 'snarkjs', iv, recordNumber }) {
210
- if (!zkReveal) {
211
- throw new Error('No ZK reveal');
212
- }
213
- const { proofs } = zkReveal;
214
- const algorithm = (0, generics_1.getZkAlgorithmForCipherSuite)(cipherSuite);
215
- const recordIV = (0, generics_1.getRecordIV)(ciphertext, cipherSuite);
216
- ciphertext = (0, generics_1.getPureCiphertext)(ciphertext, cipherSuite);
1
+ import { concatenateUint8Arrays, crypto, generateIV } from "../utils/tls-imports.js";
2
+ import {
3
+ ceilToBlockSizeMultiple,
4
+ CONFIG as ZK_CONFIG,
5
+ generateProof,
6
+ getBlockSizeBytes,
7
+ makeLocalFileFetch,
8
+ makeRemoteFileFetch,
9
+ verifyProof
10
+ } from "@reclaimprotocol/zk-symmetric-crypto";
11
+ import { makeGnarkOPRFOperator, makeGnarkZkOperator } from "@reclaimprotocol/zk-symmetric-crypto/gnark";
12
+ import { makeSnarkJsZKOperator } from "@reclaimprotocol/zk-symmetric-crypto/snarkjs";
13
+ import { makeStwoZkOperator } from "@reclaimprotocol/zk-symmetric-crypto/stwo";
14
+ import PQueue from "p-queue";
15
+ import {
16
+ DEFAULT_REMOTE_FILE_FETCH_BASE_URL,
17
+ DEFAULT_ZK_CONCURRENCY,
18
+ TOPRF_DOMAIN_SEPARATOR
19
+ } from "../config/index.js";
20
+ import { ZKProofEngine } from "../proto/api.js";
21
+ import { detectEnvironment, getEnvVariable } from "../utils/env.js";
22
+ import { AttestorError } from "../utils/error.js";
23
+ import {
24
+ getPureCiphertext,
25
+ getRecordIV,
26
+ getZkAlgorithmForCipherSuite,
27
+ isTls13Suite,
28
+ strToUint8Array
29
+ } from "../utils/generics.js";
30
+ import { logger as LOGGER } from "../utils/logger.js";
31
+ import { binaryHashToStr, isFullyRedacted, isRedactionCongruent, REDACTION_CHAR_CODE } from "../utils/redactions.js";
32
+ const ZK_CONCURRENCY = +(getEnvVariable("ZK_CONCURRENCY") || DEFAULT_ZK_CONCURRENCY);
33
+ async function makeZkProofGenerator({
34
+ zkOperators,
35
+ oprfOperators,
36
+ logger = LOGGER,
37
+ zkProofConcurrency = ZK_CONCURRENCY,
38
+ cipherSuite,
39
+ zkEngine = "snarkjs"
40
+ }) {
41
+ const zkQueue = new PQueue({ concurrency: zkProofConcurrency, autoStart: true });
42
+ const packetsToProve = [];
43
+ logger = logger.child({ module: "zk", zkEngine });
44
+ let zkProofsToGen = 0;
45
+ return {
217
46
  /**
218
- * to verify if the user has given us the correct redacted plaintext,
219
- * and isn't providing plaintext that they haven't proven they have
220
- * we start with a fully redacted plaintext, and then replace the
221
- * redacted parts with the plaintext that the user has provided
222
- * in the proofs
47
+ * Adds the given packet to the list of packets to
48
+ * generate ZK proofs for.
49
+ *
50
+ * Call `generateProofs()` to finally generate the proofs
223
51
  */
224
- const realRedactedPlaintext = new Uint8Array(ciphertext.length).fill(redactions_1.REDACTION_CHAR_CODE);
225
- await Promise.all(proofs.map(async (proof, i) => {
226
- try {
227
- await verifyProofPacket(proof);
52
+ async addPacketToProve(packet, {
53
+ redactedPlaintext,
54
+ toprfs = [],
55
+ overshotToprfFromPrevBlock
56
+ }, onGeneratedProofs, getNextPacket) {
57
+ if (packet.type === "plaintext") {
58
+ throw new Error("Cannot generate proof for plaintext");
59
+ }
60
+ const alg = getZkAlgorithmForCipherSuite(cipherSuite);
61
+ const chunkSizeBytes = getChunkSizeBytes(alg);
62
+ const key = await crypto.exportKey(packet.encKey);
63
+ const iv = packet.iv;
64
+ const ciphertext = getPureCiphertext(packet.ciphertext, cipherSuite);
65
+ if (overshotToprfFromPrevBlock) {
66
+ redactedPlaintext.set(
67
+ new Uint8Array(overshotToprfFromPrevBlock.length).fill(REDACTION_CHAR_CODE)
68
+ );
69
+ }
70
+ const trueCiphertextLength = isTls13Suite(cipherSuite) ? ciphertext.length - 1 : ciphertext.length;
71
+ const packetToProve = {
72
+ onGeneratedProofs,
73
+ algorithm: alg,
74
+ proofsToGenerate: [],
75
+ toprfsToGenerate: [],
76
+ iv: packet.fixedIv
77
+ };
78
+ for (const toprf of toprfs) {
79
+ const toprfDistFromEnd = trueCiphertextLength - (toprf.dataLocation.fromIndex + toprf.dataLocation.length);
80
+ if (toprfDistFromEnd < 0) {
81
+ const nextPacket = getNextPacket();
82
+ if (nextPacket?.type !== "ciphertext") {
83
+ throw new AttestorError(
84
+ "ERROR_INTERNAL",
85
+ "TOPRF data overshoots ciphertext length, but no next ciphertext packet found"
86
+ );
87
+ }
88
+ if (nextPacket.encKey !== packet.encKey) {
89
+ throw new AttestorError(
90
+ "ERROR_INTERNAL",
91
+ "TOPRF data overshoots ciphertext length, but next packet has different encryption key"
92
+ );
93
+ }
94
+ const nextCiphertext = nextPacket.ciphertext.slice(0, Math.abs(toprfDistFromEnd));
95
+ const iv2 = nextPacket.iv;
96
+ toprf.overshoot = {
97
+ ciphertext: nextCiphertext,
98
+ iv: iv2,
99
+ recordNumber: nextPacket.recordNumber
100
+ };
228
101
  }
229
- catch (e) {
230
- e.message += ` (chunk ${i}, startIdx ${proof.startIdx})`;
231
- throw e;
232
- }
233
- }));
234
- return { redactedPlaintext: realRedactedPlaintext };
235
- async function verifyProofPacket({ proofData, proofJson, decryptedRedactedCiphertext, redactedPlaintext, startIdx, toprf, }) {
236
- var _a, _b, _c;
237
- // get the ciphertext chunk we received from the server
238
- // the ZK library, will verify that the decrypted redacted
239
- // ciphertext matches the ciphertext received from the server
240
- const ciphertextChunk = ciphertext.slice(startIdx, startIdx + redactedPlaintext.length);
241
- // redact ciphertext if plaintext is redacted
242
- // to prepare for decryption in ZK circuit
243
- // the ZK circuit will take in the redacted ciphertext,
244
- // which shall produce the redacted plaintext
245
- for (let i = 0; i < ciphertextChunk.length; i++) {
246
- if (redactedPlaintext[i] === redactions_1.REDACTION_CHAR_CODE) {
247
- ciphertextChunk[i] = redactions_1.REDACTION_CHAR_CODE;
102
+ const fromIndex = getIdealOffsetForToprfBlock(alg, toprf);
103
+ const toIndex = Math.min(fromIndex + chunkSizeBytes, ciphertext.length);
104
+ const slice = { fromIndex, toIndex };
105
+ packetToProve.toprfsToGenerate.push(getTOPRFProofGenerationParamsForSlice({
106
+ key,
107
+ iv,
108
+ ciphertext,
109
+ slice,
110
+ toprf: {
111
+ ...toprf,
112
+ dataLocation: {
113
+ ...toprf.dataLocation,
114
+ fromIndex: toprf.dataLocation.fromIndex - fromIndex
248
115
  }
116
+ }
117
+ }));
118
+ zkProofsToGen += 1;
119
+ const pktToIndex = Math.min(
120
+ trueCiphertextLength,
121
+ toprf.dataLocation.fromIndex + toprf.dataLocation.length
122
+ );
123
+ const pktFromIndex = toprf.dataLocation.fromIndex;
124
+ for (let i = pktFromIndex; i < pktToIndex; i++) {
125
+ redactedPlaintext[i] = REDACTION_CHAR_CODE;
249
126
  }
250
- // redact OPRF indices -- because they'll incorrectly
251
- // be marked as incongruent
252
- let comparePlaintext = redactedPlaintext;
253
- if (toprf) {
254
- comparePlaintext = new Uint8Array(redactedPlaintext);
255
- for (let i = 0; i < toprf.dataLocation.length; i++) {
256
- comparePlaintext[i + toprf.dataLocation.fromIndex] = redactions_1.REDACTION_CHAR_CODE;
257
- }
258
- // the transcript will contain only the stringified
259
- // nullifier. So here, we'll compare the provable
260
- // binary nullifier with the stringified nullifier
261
- // that the user has provided
262
- const nulliferStr = (0, redactions_1.binaryHashToStr)(toprf.nullifier, toprf.dataLocation.length);
263
- const txtHash = redactedPlaintext.slice((_a = toprf.dataLocation) === null || _a === void 0 ? void 0 : _a.fromIndex, ((_b = toprf.dataLocation) === null || _b === void 0 ? void 0 : _b.fromIndex)
264
- + ((_c = toprf.dataLocation) === null || _c === void 0 ? void 0 : _c.length));
265
- if ((0, generics_1.uint8ArrayToStr)(txtHash) !== nulliferStr
266
- .slice(0, txtHash.length)) {
267
- throw new Error('OPRF nullifier not congruent');
127
+ }
128
+ for (let i = 0; i < ciphertext.length; i += chunkSizeBytes) {
129
+ const slice = {
130
+ fromIndex: i,
131
+ toIndex: Math.min(i + chunkSizeBytes, ciphertext.length)
132
+ };
133
+ const proofParams = getProofGenerationParamsForSlice(
134
+ { key, iv, ciphertext, redactedPlaintext, slice }
135
+ );
136
+ if (!proofParams) {
137
+ continue;
138
+ }
139
+ packetToProve.proofsToGenerate.push(proofParams);
140
+ zkProofsToGen += 1;
141
+ }
142
+ packetsToProve.push(packetToProve);
143
+ },
144
+ getTotalChunksToProve() {
145
+ return zkProofsToGen;
146
+ },
147
+ async generateProofs(onChunkDone) {
148
+ if (!packetsToProve.length) {
149
+ return;
150
+ }
151
+ const start = Date.now();
152
+ const tasks = [];
153
+ for (const {
154
+ onGeneratedProofs,
155
+ algorithm,
156
+ proofsToGenerate,
157
+ toprfsToGenerate
158
+ } of packetsToProve) {
159
+ const proofs = [];
160
+ const toprfs = [];
161
+ let proofsLeft = proofsToGenerate.length + toprfsToGenerate.length;
162
+ for (const proofToGen of proofsToGenerate) {
163
+ tasks.push(zkQueue.add(async () => {
164
+ const proof = await generateZkProofForChunk(algorithm, proofToGen);
165
+ onChunkDone?.();
166
+ proofs.push(proof);
167
+ proofsLeft -= 1;
168
+ if (proofsLeft === 0) {
169
+ onGeneratedProofs(proofs, toprfs);
268
170
  }
171
+ }, { throwOnTimeout: true }));
269
172
  }
270
- if (!(0, redactions_1.isRedactionCongruent)(comparePlaintext, decryptedRedactedCiphertext)) {
271
- throw new Error('redacted ciphertext not congruent');
173
+ for (const toprfToGen of toprfsToGenerate) {
174
+ tasks.push(zkQueue.add(async () => {
175
+ const toprf = await generateOprfProofForChunk(algorithm, toprfToGen);
176
+ onChunkDone?.();
177
+ toprfs.push(toprf);
178
+ proofsLeft -= 1;
179
+ if (proofsLeft === 0) {
180
+ onGeneratedProofs(proofs, toprfs);
181
+ }
182
+ }, { throwOnTimeout: true }));
272
183
  }
273
- let nonce = (0, tls_1.concatenateUint8Arrays)([iv, recordIV]);
274
- if (!recordIV.length) {
275
- nonce = (0, tls_1.generateIV)(nonce, recordNumber);
184
+ }
185
+ await Promise.all(tasks);
186
+ logger?.info(
187
+ { durationMs: Date.now() - start, zkProofsToGen },
188
+ "generated ZK proofs"
189
+ );
190
+ packetsToProve.splice(0, packetsToProve.length);
191
+ zkProofsToGen = 0;
192
+ const alg = getZkAlgorithmForCipherSuite(cipherSuite);
193
+ const zkOperator = await getZkOperatorForAlgorithm(alg);
194
+ zkOperator.release?.();
195
+ }
196
+ };
197
+ async function generateZkProofForChunk(algorithm, {
198
+ startIdx,
199
+ redactedPlaintext,
200
+ privateInput,
201
+ publicInput
202
+ }) {
203
+ const operator = getZkOperatorForAlgorithm(algorithm);
204
+ const proof = await generateProof(
205
+ { algorithm, privateInput, publicInput, operator, logger }
206
+ );
207
+ logger?.debug({ startIdx }, "generated proof for chunk");
208
+ return {
209
+ proofData: typeof proof.proofData === "string" ? strToUint8Array(proof.proofData) : proof.proofData,
210
+ decryptedRedactedCiphertext: proof.plaintext || new Uint8Array(),
211
+ redactedPlaintext,
212
+ startIdx
213
+ };
214
+ }
215
+ async function generateOprfProofForChunk(algorithm, { startIdx, privateInput, publicInput, toprf }) {
216
+ const operator = getOprfOperatorForAlgorithm(algorithm);
217
+ const toprfLocations = [];
218
+ if (toprf?.overshoot) {
219
+ const { dataLocation, overshoot: { ciphertext } } = toprf;
220
+ toprfLocations.push(
221
+ {
222
+ pos: dataLocation.fromIndex,
223
+ len: dataLocation.length - ciphertext.length
224
+ },
225
+ {
226
+ pos: ceilToBlockSizeMultiple(
227
+ dataLocation.fromIndex + dataLocation.length,
228
+ algorithm
229
+ ),
230
+ len: ciphertext.length
276
231
  }
277
- await (0, zk_symmetric_crypto_1.verifyProof)({
278
- proof: {
279
- algorithm,
280
- proofData: proofData.length
281
- ? proofData
282
- : (0, tls_1.strToUint8Array)(proofJson),
283
- plaintext: decryptedRedactedCiphertext,
284
- },
285
- publicInput: {
286
- ciphertext: ciphertextChunk,
287
- iv: nonce,
288
- offsetBytes: startIdx
289
- },
290
- logger,
291
- ...(toprf
292
- ? {
293
- operator: getOprfOperator(),
294
- toprf: {
295
- pos: toprf.dataLocation.fromIndex,
296
- len: toprf.dataLocation.length,
297
- domainSeparator: config_1.TOPRF_DOMAIN_SEPARATOR,
298
- output: toprf.nullifier,
299
- responses: toprf.responses,
300
- }
301
- }
302
- : { operator: getZkOperator() })
303
- });
304
- logger === null || logger === void 0 ? void 0 : logger.debug({ startIdx, endIdx: startIdx + redactedPlaintext.length }, 'verified proof');
305
- realRedactedPlaintext.set(redactedPlaintext, startIdx);
232
+ );
233
+ } else if (toprf) {
234
+ toprfLocations.push({
235
+ pos: toprf.dataLocation.fromIndex,
236
+ len: toprf.dataLocation.length
237
+ });
306
238
  }
307
- function getZkOperator() {
308
- return (zkOperators === null || zkOperators === void 0 ? void 0 : zkOperators[algorithm])
309
- || makeDefaultZkOperator(algorithm, zkEngine, logger);
239
+ const proof = await generateProof(
240
+ {
241
+ algorithm,
242
+ privateInput,
243
+ publicInput,
244
+ operator,
245
+ logger,
246
+ ...toprf ? {
247
+ toprf: {
248
+ locations: toprfLocations,
249
+ output: toprf.nullifier,
250
+ responses: toprf.responses,
251
+ domainSeparator: TOPRF_DOMAIN_SEPARATOR
252
+ },
253
+ mask: toprf.mask
254
+ } : {}
255
+ }
256
+ );
257
+ logger?.debug({ toprfLocations }, "generated TOPRF proof for chunk");
258
+ return {
259
+ startIdx,
260
+ proofData: typeof proof.proofData === "string" ? strToUint8Array(proof.proofData) : proof.proofData,
261
+ payload: toprf
262
+ };
263
+ }
264
+ function getZkOperatorForAlgorithm(algorithm) {
265
+ return zkOperators?.[algorithm] || makeDefaultZkOperator(algorithm, zkEngine, logger);
266
+ }
267
+ function getOprfOperatorForAlgorithm(algorithm) {
268
+ return oprfOperators?.[algorithm] || makeDefaultOPRFOperator(algorithm, zkEngine, logger);
269
+ }
270
+ }
271
+ async function verifyZkPacket({
272
+ cipherSuite,
273
+ ciphertext,
274
+ zkReveal,
275
+ zkOperators,
276
+ oprfOperators,
277
+ logger = LOGGER,
278
+ zkEngine = "snarkjs",
279
+ iv,
280
+ recordNumber,
281
+ toprfOvershotNullifier,
282
+ getNextPacket
283
+ }) {
284
+ const { proofs, toprfs, oprfRawMarkers } = zkReveal;
285
+ const algorithm = getZkAlgorithmForCipherSuite(cipherSuite);
286
+ const recordIV = getRecordIV(ciphertext, cipherSuite);
287
+ ciphertext = new Uint8Array(getPureCiphertext(ciphertext, cipherSuite));
288
+ const realRedactedPlaintext = new Uint8Array(ciphertext.length).fill(REDACTION_CHAR_CODE);
289
+ const replacements = await Promise.all(toprfs.map(async (toprf, i) => {
290
+ try {
291
+ return await verifyToprfProofPacket(toprf);
292
+ } catch (e) {
293
+ e.message += ` (TOPRF proof ${i}, from ${toprf.payload?.dataLocation?.fromIndex}, record ${recordNumber})`;
294
+ throw e;
310
295
  }
311
- function getOprfOperator() {
312
- return (oprfOperators === null || oprfOperators === void 0 ? void 0 : oprfOperators[algorithm])
313
- || makeDefaultOPRFOperator(algorithm, zkEngine, logger);
296
+ }));
297
+ await Promise.all(proofs.map(async (proof, i) => {
298
+ try {
299
+ await verifyZkProofPacket(proof);
300
+ } catch (e) {
301
+ e.message += ` (ZK proof ${i}, startIdx ${proof.startIdx}, record ${recordNumber})`;
302
+ throw e;
314
303
  }
304
+ }));
305
+ for (const { set, startIdx } of replacements) {
306
+ realRedactedPlaintext.set(set, startIdx);
307
+ }
308
+ if (toprfOvershotNullifier) {
309
+ realRedactedPlaintext.set(toprfOvershotNullifier);
310
+ }
311
+ return { redactedPlaintext: realRedactedPlaintext, oprfRawMarkers };
312
+ async function verifyZkProofPacket({
313
+ proofData,
314
+ decryptedRedactedCiphertext,
315
+ redactedPlaintext,
316
+ startIdx
317
+ }) {
318
+ const ciphertextChunkEnd = startIdx + redactedPlaintext.length;
319
+ const ciphertextChunk = ciphertext.slice(startIdx, ciphertextChunkEnd);
320
+ for (let i = 0; i < ciphertextChunk.length; i++) {
321
+ if (redactedPlaintext[i] === REDACTION_CHAR_CODE) {
322
+ ciphertextChunk[i] = REDACTION_CHAR_CODE;
323
+ }
324
+ }
325
+ let nonce = concatenateUint8Arrays([iv, recordIV]);
326
+ if (!recordIV.length) {
327
+ nonce = generateIV(nonce, recordNumber);
328
+ }
329
+ const ciphertextInput = {
330
+ ciphertext: ciphertextChunk,
331
+ iv: nonce,
332
+ offsetBytes: startIdx
333
+ };
334
+ if (!isRedactionCongruent(redactedPlaintext, decryptedRedactedCiphertext)) {
335
+ throw new Error("redacted ciphertext not congruent");
336
+ }
337
+ await verifyProof(
338
+ {
339
+ proof: {
340
+ algorithm,
341
+ proofData,
342
+ plaintext: decryptedRedactedCiphertext
343
+ },
344
+ publicInput: ciphertextInput,
345
+ logger,
346
+ operator: getZkOperator()
347
+ }
348
+ );
349
+ logger?.debug(
350
+ { startIdx, endIdx: startIdx + redactedPlaintext.length },
351
+ "verified proof"
352
+ );
353
+ realRedactedPlaintext.set(redactedPlaintext, startIdx);
354
+ }
355
+ async function verifyToprfProofPacket({ startIdx, proofData, payload: toprf }) {
356
+ if (!toprf?.dataLocation || !toprf.responses || !toprf.nullifier) {
357
+ throw new Error("invalid TOPRF proof payload");
358
+ }
359
+ const { dataLocation, nullifier } = toprf;
360
+ const ciphertextChunkEnd = Math.min(ciphertext.length, getChunkSizeBytes(algorithm) + startIdx);
361
+ const isLastChunk = ciphertextChunkEnd >= ciphertext.length;
362
+ const ciphertextChunk = ciphertext.slice(startIdx, ciphertextChunkEnd);
363
+ let nonce = concatenateUint8Arrays([iv, recordIV]);
364
+ if (!recordIV.length) {
365
+ nonce = generateIV(nonce, recordNumber);
366
+ }
367
+ const ciphertextInput = {
368
+ ciphertext: ciphertextChunk,
369
+ iv: nonce,
370
+ offsetBytes: startIdx
371
+ };
372
+ let pubInput = ciphertextInput;
373
+ const nulliferStr = binaryHashToStr(nullifier, dataLocation.length);
374
+ const locations = [];
375
+ const toprfEndIdx = dataLocation.fromIndex + dataLocation.length;
376
+ const trueCiphLen = isLastChunk && isTls13Suite(cipherSuite) ? ciphertextChunk.length - 1 : ciphertextChunk.length;
377
+ const overshoot = toprfEndIdx - trueCiphLen;
378
+ if (overshoot > 0) {
379
+ const nextPkt = getNextPacket(
380
+ strToUint8Array(nulliferStr.slice(dataLocation.length - overshoot))
381
+ );
382
+ if (!nextPkt) {
383
+ throw new Error("OPRF data overshot, but no next packet found");
384
+ }
385
+ const nextRecordIV = getRecordIV(ciphertext, cipherSuite);
386
+ let nextNonce = concatenateUint8Arrays([iv, nextRecordIV]);
387
+ if (!nextRecordIV.length) {
388
+ nextNonce = generateIV(nextNonce, recordNumber + 1);
389
+ }
390
+ pubInput = [
391
+ ciphertextInput,
392
+ {
393
+ ciphertext: nextPkt.slice(0, overshoot),
394
+ iv: nextNonce,
395
+ offsetBytes: 0
396
+ }
397
+ ];
398
+ locations.push(
399
+ {
400
+ pos: dataLocation.fromIndex,
401
+ len: dataLocation.length - overshoot
402
+ },
403
+ {
404
+ pos: ceilToBlockSizeMultiple(
405
+ dataLocation.fromIndex + dataLocation.length,
406
+ algorithm
407
+ ),
408
+ len: overshoot
409
+ }
410
+ );
411
+ } else {
412
+ locations.push({
413
+ pos: dataLocation.fromIndex,
414
+ len: dataLocation.length
415
+ });
416
+ }
417
+ await verifyProof(
418
+ {
419
+ proof: { algorithm, proofData, plaintext: void 0 },
420
+ publicInput: pubInput,
421
+ logger,
422
+ operator: getOprfOperator(),
423
+ toprf: {
424
+ locations,
425
+ domainSeparator: TOPRF_DOMAIN_SEPARATOR,
426
+ output: nullifier,
427
+ responses: toprf.responses
428
+ }
429
+ }
430
+ );
431
+ logger?.debug({ locations }, "verified TOPRF proof");
432
+ return {
433
+ set: strToUint8Array(
434
+ nulliferStr.slice(0, locations[0].len)
435
+ ),
436
+ startIdx: locations[0].pos + startIdx
437
+ };
438
+ }
439
+ function getZkOperator() {
440
+ return zkOperators?.[algorithm] || makeDefaultZkOperator(algorithm, zkEngine, logger);
441
+ }
442
+ function getOprfOperator() {
443
+ return oprfOperators?.[algorithm] || makeDefaultOPRFOperator(algorithm, zkEngine, logger);
444
+ }
315
445
  }
316
- // the chunk size of the ZK circuit in bytes
317
- // this will be >= the block size
318
446
  function getChunkSizeBytes(alg) {
319
- const { chunkSize, bitsPerWord } = zk_symmetric_crypto_1.CONFIG[alg];
320
- return chunkSize * bitsPerWord / 8;
447
+ const { chunkSize, bitsPerWord } = ZK_CONFIG[alg];
448
+ return chunkSize * bitsPerWord / 8;
321
449
  }
322
450
  const zkEngines = {};
323
451
  const oprfEngines = {};
324
452
  const operatorMakers = {
325
- 'snarkjs': zk_symmetric_crypto_1.makeSnarkJsZKOperator,
326
- 'gnark': zk_symmetric_crypto_1.makeGnarkZkOperator,
453
+ "snarkjs": makeSnarkJsZKOperator,
454
+ "gnark": makeGnarkZkOperator,
455
+ "stwo": makeStwoZkOperator
327
456
  };
328
457
  const OPRF_OPERATOR_MAKERS = {
329
- 'gnark': zk_symmetric_crypto_1.makeGnarkOPRFOperator
458
+ "gnark": makeGnarkOPRFOperator
330
459
  };
331
460
  function makeDefaultZkOperator(algorithm, zkEngine, logger) {
332
- let zkOperators = zkEngines[zkEngine];
333
- if (!zkOperators) {
334
- zkEngines[zkEngine] = {};
335
- zkOperators = zkEngines[zkEngine];
336
- }
337
- if (!zkOperators[algorithm]) {
338
- const isNode = (0, env_1.detectEnvironment)() === 'node';
339
- const opType = isNode ? 'local' : 'remote';
340
- logger === null || logger === void 0 ? void 0 : logger.info({ type: opType, algorithm }, 'fetching zk operator');
341
- const fetcher = opType === 'local'
342
- ? (0, zk_symmetric_crypto_1.makeLocalFileFetch)()
343
- : (0, zk_symmetric_crypto_1.makeRemoteFileFetch)({
344
- baseUrl: config_1.DEFAULT_REMOTE_FILE_FETCH_BASE_URL,
345
- });
346
- const maker = operatorMakers[zkEngine];
347
- if (!maker) {
348
- throw new Error(`No ZK operator maker for ${zkEngine}`);
349
- }
350
- zkOperators[algorithm] = maker({ algorithm, fetcher });
461
+ let zkOperators = zkEngines[zkEngine];
462
+ if (!zkOperators) {
463
+ zkEngines[zkEngine] = {};
464
+ zkOperators = zkEngines[zkEngine];
465
+ }
466
+ if (!zkOperators[algorithm]) {
467
+ const opType = getOperatorType();
468
+ const zkBaseUrl = opType === "remote" ? getZkResourcesBaseUrl() : void 0;
469
+ logger?.info({ type: opType, algorithm, zkBaseUrl }, "fetching zk operator");
470
+ const fetcher = opType === "local" ? makeLocalFileFetch() : makeRemoteFileFetch({ baseUrl: zkBaseUrl, logger });
471
+ const maker = operatorMakers[zkEngine];
472
+ if (!maker) {
473
+ throw new Error(`No ZK operator maker for ${zkEngine}`);
351
474
  }
352
- return zkOperators[algorithm];
475
+ zkOperators[algorithm] = maker({ algorithm, fetcher });
476
+ }
477
+ return zkOperators[algorithm];
478
+ }
479
+ function getOperatorType() {
480
+ const envop = getEnvVariable("ZK_OPERATOR_TYPE");
481
+ if (envop === "local" || envop === "remote") {
482
+ return envop;
483
+ }
484
+ return detectEnvironment() === "node" ? "local" : "remote";
353
485
  }
354
486
  function makeDefaultOPRFOperator(algorithm, zkEngine, logger) {
355
- let operators = oprfEngines[zkEngine];
356
- if (!operators) {
357
- oprfEngines[zkEngine] = {};
358
- operators = oprfEngines[zkEngine];
359
- }
360
- if (!operators[algorithm]) {
361
- const isNode = (0, env_1.detectEnvironment)() === 'node';
362
- const type = isNode ? 'local' : 'remote';
363
- logger === null || logger === void 0 ? void 0 : logger.info({ type, algorithm }, 'fetching oprf operator');
364
- const fetcher = type === 'local'
365
- ? (0, zk_symmetric_crypto_1.makeLocalFileFetch)()
366
- : (0, zk_symmetric_crypto_1.makeRemoteFileFetch)({
367
- baseUrl: config_1.DEFAULT_REMOTE_FILE_FETCH_BASE_URL,
368
- });
369
- const maker = OPRF_OPERATOR_MAKERS[zkEngine];
370
- if (!maker) {
371
- throw new Error(`No OPRF operator maker for ${zkEngine}`);
372
- }
373
- operators[algorithm] = maker({ algorithm, fetcher });
487
+ let operators = oprfEngines[zkEngine];
488
+ if (!operators) {
489
+ oprfEngines[zkEngine] = {};
490
+ operators = oprfEngines[zkEngine];
491
+ }
492
+ if (!operators[algorithm]) {
493
+ const type = getOperatorType();
494
+ const zkBaseUrl = type === "remote" ? getZkResourcesBaseUrl() : void 0;
495
+ logger?.info({ type, algorithm, zkBaseUrl }, "fetching oprf operator");
496
+ const fetcher = type === "local" ? makeLocalFileFetch() : makeRemoteFileFetch({ baseUrl: zkBaseUrl, logger });
497
+ const maker = OPRF_OPERATOR_MAKERS[zkEngine];
498
+ if (!maker) {
499
+ throw new Error(`No OPRF operator maker for ${zkEngine}`);
374
500
  }
375
- return operators[algorithm];
501
+ operators[algorithm] = maker({ algorithm, fetcher });
502
+ }
503
+ return operators[algorithm];
376
504
  }
377
505
  function getEngineString(engine) {
378
- if (engine === api_1.ZKProofEngine.ZK_ENGINE_GNARK) {
379
- return 'gnark';
380
- }
381
- if (engine === api_1.ZKProofEngine.ZK_ENGINE_SNARKJS) {
382
- return 'snarkjs';
383
- }
384
- throw new Error(`Unknown ZK engine: ${engine}`);
506
+ if (engine === ZKProofEngine.ZK_ENGINE_GNARK) {
507
+ return "gnark";
508
+ }
509
+ if (engine === ZKProofEngine.ZK_ENGINE_SNARKJS) {
510
+ return "snarkjs";
511
+ }
512
+ if (engine === ZKProofEngine.ZK_ENGINE_STWO) {
513
+ return "stwo";
514
+ }
515
+ throw new Error(`Unknown ZK engine: ${engine}`);
385
516
  }
386
517
  function getEngineProto(engine) {
387
- if (engine === 'gnark') {
388
- return api_1.ZKProofEngine.ZK_ENGINE_GNARK;
389
- }
390
- if (engine === 'snarkjs') {
391
- return api_1.ZKProofEngine.ZK_ENGINE_SNARKJS;
392
- }
393
- throw new Error(`Unknown ZK engine: ${engine}`);
518
+ if (engine === "gnark") {
519
+ return ZKProofEngine.ZK_ENGINE_GNARK;
520
+ }
521
+ if (engine === "snarkjs") {
522
+ return ZKProofEngine.ZK_ENGINE_SNARKJS;
523
+ }
524
+ if (engine === "stwo") {
525
+ return ZKProofEngine.ZK_ENGINE_STWO;
526
+ }
527
+ throw new Error(`Unknown ZK engine: ${engine}`);
394
528
  }
395
- function getProofGenerationParamsForSlice({ key, iv, ciphertext, redactedPlaintext, slice: { fromIndex, toIndex }, toprf, }) {
396
- const ciphertextChunk = ciphertext.slice(fromIndex, toIndex);
397
- const plaintextChunk = redactedPlaintext.slice(fromIndex, toIndex);
398
- if ((0, redactions_1.isFullyRedacted)(plaintextChunk)) {
399
- return;
400
- }
401
- // redact ciphertext if plaintext is redacted
402
- // to prepare for decryption in ZK circuit
403
- // the ZK circuit will take in the redacted ciphertext,
404
- // which shall produce the redacted plaintext
405
- for (let i = 0; i < ciphertextChunk.length; i++) {
406
- if (plaintextChunk[i] === redactions_1.REDACTION_CHAR_CODE) {
407
- ciphertextChunk[i] = redactions_1.REDACTION_CHAR_CODE;
408
- }
529
+ function getProofGenerationParamsForSlice({
530
+ key,
531
+ iv,
532
+ ciphertext,
533
+ redactedPlaintext,
534
+ slice: { fromIndex, toIndex }
535
+ }) {
536
+ const ciphertextChunk = ciphertext.slice(fromIndex, toIndex);
537
+ const plaintextChunk = redactedPlaintext.slice(fromIndex, toIndex);
538
+ if (isFullyRedacted(plaintextChunk)) {
539
+ return;
540
+ }
541
+ for (let i = 0; i < ciphertextChunk.length; i++) {
542
+ if (plaintextChunk[i] === REDACTION_CHAR_CODE) {
543
+ ciphertextChunk[i] = REDACTION_CHAR_CODE;
409
544
  }
545
+ }
546
+ return {
547
+ startIdx: fromIndex,
548
+ redactedPlaintext: plaintextChunk,
549
+ privateInput: { key },
550
+ publicInput: { ciphertext: ciphertextChunk, iv, offsetBytes: fromIndex }
551
+ };
552
+ }
553
+ function getTOPRFProofGenerationParamsForSlice({
554
+ key,
555
+ iv,
556
+ ciphertext,
557
+ slice: { fromIndex, toIndex },
558
+ toprf
559
+ }) {
560
+ const ciphertextChunk = ciphertext.slice(fromIndex, toIndex);
561
+ if (toprf?.overshoot) {
562
+ const {
563
+ overshoot: { ciphertext: overshootCiphertext, iv: overshootIv }
564
+ } = toprf;
410
565
  return {
411
- startIdx: fromIndex,
412
- redactedPlaintext: plaintextChunk,
413
- privateInput: { key },
414
- publicInput: { ciphertext: ciphertextChunk, iv, offsetBytes: fromIndex },
415
- toprf
566
+ privateInput: { key },
567
+ publicInput: [
568
+ {
569
+ ciphertext: ciphertextChunk,
570
+ iv,
571
+ offsetBytes: fromIndex
572
+ },
573
+ { ciphertext: overshootCiphertext, iv: overshootIv }
574
+ ],
575
+ toprf,
576
+ startIdx: fromIndex
416
577
  };
578
+ }
579
+ return {
580
+ privateInput: { key },
581
+ publicInput: { ciphertext: ciphertextChunk, iv, offsetBytes: fromIndex },
582
+ toprf,
583
+ startIdx: fromIndex
584
+ };
417
585
  }
418
- /**
419
- * Get the ideal location to generate a ZK proof for a TOPRF block.
420
- * Ideally it should be put into a slice that's a divisor of the chunk size,
421
- * as that'll minimize the number of proofs that need to be generated.
422
- * @returns the offset in bytes
423
- */
424
- function getIdealOffsetForToprfBlock(alg, { dataLocation }) {
425
- const chunkSizeBytes = getChunkSizeBytes(alg);
426
- const offsetChunks = Math.floor(dataLocation.fromIndex / chunkSizeBytes) * chunkSizeBytes;
427
- const endOffsetChunks = Math.floor((dataLocation.fromIndex + dataLocation.length) / chunkSizeBytes);
428
- // happy case -- the OPRF block fits into a single chunk, that's a
429
- // divisor of the chunk size
430
- if (endOffsetChunks === offsetChunks) {
431
- return offsetChunks * chunkSizeBytes;
586
+ function getIdealOffsetForToprfBlock(alg, { dataLocation, overshoot }) {
587
+ const chunkSizeBytes = getChunkSizeBytes(alg);
588
+ const blockSizeBytes = getBlockSizeBytes(alg);
589
+ const offsetChunks = Math.floor(dataLocation.fromIndex / chunkSizeBytes);
590
+ const endOffsetChunks = Math.floor((dataLocation.fromIndex + dataLocation.length) / chunkSizeBytes);
591
+ if (endOffsetChunks === offsetChunks) {
592
+ const start = offsetChunks * chunkSizeBytes;
593
+ if (overshoot) {
594
+ const overshootBlocks = Math.ceil(overshoot.ciphertext.length / blockSizeBytes);
595
+ return start + overshootBlocks * blockSizeBytes;
432
596
  }
433
- const blockSizeBytes = (0, zk_symmetric_crypto_1.getBlockSizeBytes)(alg);
434
- const offsetBytes = Math.floor(dataLocation.fromIndex / blockSizeBytes) * blockSizeBytes;
435
- if ((dataLocation.fromIndex + dataLocation.length) - offsetBytes
436
- > chunkSizeBytes) {
437
- throw new error_1.AttestorError('ERROR_BAD_REQUEST', 'OPRF data cannot fit into a single chunk');
438
- }
439
- return offsetBytes;
597
+ return start;
598
+ }
599
+ const offsetBytes = Math.floor(dataLocation.fromIndex / blockSizeBytes) * blockSizeBytes;
600
+ const endOffsetBytes = Math.ceil((dataLocation.fromIndex + dataLocation.length) / blockSizeBytes);
601
+ if (endOffsetBytes - offsetBytes > chunkSizeBytes) {
602
+ throw new AttestorError(
603
+ "ERROR_BAD_REQUEST",
604
+ "OPRF data cannot fit into a single chunk"
605
+ );
606
+ }
607
+ return offsetBytes;
440
608
  }
441
- function sortSlices(slices) {
442
- return slices.sort((a, b) => a.fromIndex - b.fromIndex);
609
+ function getZkResourcesBaseUrl() {
610
+ if (typeof ATTESTOR_BASE_URL !== "string") {
611
+ return DEFAULT_REMOTE_FILE_FETCH_BASE_URL;
612
+ }
613
+ return new URL(
614
+ DEFAULT_REMOTE_FILE_FETCH_BASE_URL,
615
+ ATTESTOR_BASE_URL
616
+ ).toString();
443
617
  }
444
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiemsuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvemsudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUErRUEsb0RBZ1FDO0FBS0Qsd0NBc0tDO0FBMEJELHNEQThCQztBQUVELDBEQThCQztBQUVELDBDQVVDO0FBR0Qsd0NBVUM7QUEzbUJELDhDQUErRztBQUMvRyw4RUFleUQ7QUFDekQsdUNBQStHO0FBQy9HLHVDQUEwSDtBQUUxSCx1Q0FBaUU7QUFDakUsMkNBQStDO0FBQy9DLGlEQUFrSDtBQUNsSCw2Q0FBbUQ7QUFDbkQscURBQWtIO0FBa0RsSCxNQUFNLGNBQWMsR0FBRyxDQUFDLENBQ3ZCLElBQUEsb0JBQWMsRUFBQyxnQkFBZ0IsQ0FBQztPQUM3QiwrQkFBc0IsQ0FDekIsQ0FBQTtBQUVNLEtBQUssVUFBVSxvQkFBb0IsQ0FDekMsRUFDQyxXQUFXLEVBQ1gsYUFBYSxFQUNiLE1BQU0sR0FBRyxlQUFNLEVBQ2Ysa0JBQWtCLEdBQUcsY0FBYyxFQUNuQyxXQUFXLEVBQ1gsUUFBUSxHQUFHLFNBQVMsRUFDQztJQUd0QixNQUFNLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxHQUFHLE1BQU0sTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFBO0lBQ25ELE1BQU0sT0FBTyxHQUFHLElBQUksTUFBTSxDQUFDO1FBQzFCLFdBQVcsRUFBRSxrQkFBa0I7UUFDL0IsU0FBUyxFQUFFLElBQUk7S0FDZixDQUFDLENBQUE7SUFFRixNQUFNLGNBQWMsR0FBc0IsRUFBRSxDQUFBO0lBRTVDLE1BQU0sR0FBRyxDQUFDLE1BQU0sSUFBSSxlQUFNLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFBO0lBQ3ZFLElBQUksYUFBYSxHQUFHLENBQUMsQ0FBQTtJQUVyQixPQUFPO1FBQ047Ozs7O1dBS0c7UUFDSCxLQUFLLENBQUMsZ0JBQWdCLENBQ3JCLE1B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
618
+ export {
619
+ getEngineProto,
620
+ getEngineString,
621
+ makeDefaultOPRFOperator,
622
+ makeDefaultZkOperator,
623
+ makeZkProofGenerator,
624
+ verifyZkPacket
625
+ };