@reclaimprotocol/attestor-core 5.0.1-beta.7 → 5.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (307) hide show
  1. package/browser/resources/attestor-browser.min.mjs +4512 -0
  2. package/lib/client/tunnels/make-rpc-tls-tunnel.d.ts +1 -1
  3. package/lib/external-rpc/index.js +10399 -3
  4. package/lib/index.js +8323 -10
  5. package/lib/server/utils/proxy-session.d.ts +1 -1
  6. package/lib/types/general.d.ts +0 -1
  7. package/lib/utils/generics.d.ts +1 -6
  8. package/lib/utils/index.d.ts +0 -1
  9. package/package.json +8 -7
  10. package/lib/avs/abis/avsDirectoryABI.js +0 -343
  11. package/lib/avs/abis/delegationABI.js +0 -4
  12. package/lib/avs/abis/registryABI.js +0 -728
  13. package/lib/avs/client/create-claim-on-avs.js +0 -168
  14. package/lib/avs/config.js +0 -26
  15. package/lib/avs/contracts/ReclaimServiceManager.js +0 -0
  16. package/lib/avs/contracts/common.js +0 -0
  17. package/lib/avs/contracts/factories/ReclaimServiceManager__factory.js +0 -1183
  18. package/lib/avs/contracts/factories/index.js +0 -4
  19. package/lib/avs/contracts/index.js +0 -6
  20. package/lib/avs/types/index.js +0 -0
  21. package/lib/avs/utils/contracts.js +0 -53
  22. package/lib/avs/utils/register.js +0 -74
  23. package/lib/avs/utils/tasks.js +0 -48
  24. package/lib/browser/avs/abis/avsDirectoryABI.d.ts +0 -60
  25. package/lib/browser/avs/abis/avsDirectoryABI.js +0 -343
  26. package/lib/browser/avs/abis/delegationABI.d.ts +0 -126
  27. package/lib/browser/avs/abis/delegationABI.js +0 -4
  28. package/lib/browser/avs/abis/registryABI.d.ts +0 -136
  29. package/lib/browser/avs/abis/registryABI.js +0 -728
  30. package/lib/browser/avs/client/create-claim-on-avs.d.ts +0 -12
  31. package/lib/browser/avs/client/create-claim-on-avs.js +0 -168
  32. package/lib/browser/avs/config.d.ts +0 -7
  33. package/lib/browser/avs/config.js +0 -26
  34. package/lib/browser/avs/contracts/ReclaimServiceManager.d.ts +0 -601
  35. package/lib/browser/avs/contracts/ReclaimServiceManager.js +0 -0
  36. package/lib/browser/avs/contracts/common.d.ts +0 -50
  37. package/lib/browser/avs/contracts/common.js +0 -0
  38. package/lib/browser/avs/contracts/factories/ReclaimServiceManager__factory.d.ts +0 -890
  39. package/lib/browser/avs/contracts/factories/ReclaimServiceManager__factory.js +0 -1183
  40. package/lib/browser/avs/contracts/factories/index.d.ts +0 -1
  41. package/lib/browser/avs/contracts/factories/index.js +0 -4
  42. package/lib/browser/avs/contracts/index.d.ts +0 -3
  43. package/lib/browser/avs/contracts/index.js +0 -6
  44. package/lib/browser/avs/types/index.d.ts +0 -55
  45. package/lib/browser/avs/types/index.js +0 -0
  46. package/lib/browser/avs/utils/contracts.d.ts +0 -21
  47. package/lib/browser/avs/utils/contracts.js +0 -53
  48. package/lib/browser/avs/utils/register.d.ts +0 -27
  49. package/lib/browser/avs/utils/register.js +0 -74
  50. package/lib/browser/avs/utils/tasks.d.ts +0 -22
  51. package/lib/browser/avs/utils/tasks.js +0 -48
  52. package/lib/browser/client/create-claim.d.ts +0 -5
  53. package/lib/browser/client/create-claim.js +0 -461
  54. package/lib/browser/client/index.d.ts +0 -3
  55. package/lib/browser/client/index.js +0 -3
  56. package/lib/browser/client/tunnels/make-rpc-tcp-tunnel.d.ts +0 -16
  57. package/lib/browser/client/tunnels/make-rpc-tcp-tunnel.js +0 -53
  58. package/lib/browser/client/tunnels/make-rpc-tls-tunnel.d.ts +0 -26
  59. package/lib/browser/client/tunnels/make-rpc-tls-tunnel.js +0 -127
  60. package/lib/browser/client/utils/attestor-pool.d.ts +0 -8
  61. package/lib/browser/client/utils/attestor-pool.js +0 -24
  62. package/lib/browser/client/utils/client-socket.d.ts +0 -11
  63. package/lib/browser/client/utils/client-socket.js +0 -120
  64. package/lib/browser/client/utils/message-handler.d.ts +0 -4
  65. package/lib/browser/client/utils/message-handler.js +0 -97
  66. package/lib/browser/config/index.d.ts +0 -31
  67. package/lib/browser/config/index.js +0 -62
  68. package/lib/browser/external-rpc/benchmark.d.ts +0 -1
  69. package/lib/browser/external-rpc/benchmark.js +0 -82
  70. package/lib/browser/external-rpc/event-bus.d.ts +0 -7
  71. package/lib/browser/external-rpc/event-bus.js +0 -17
  72. package/lib/browser/external-rpc/global.d.js +0 -0
  73. package/lib/browser/external-rpc/handle-incoming-msg.d.ts +0 -2
  74. package/lib/browser/external-rpc/handle-incoming-msg.js +0 -241
  75. package/lib/browser/external-rpc/index.d.ts +0 -3
  76. package/lib/browser/external-rpc/index.js +0 -3
  77. package/lib/browser/external-rpc/jsc-polyfills/1.d.ts +0 -14
  78. package/lib/browser/external-rpc/jsc-polyfills/1.js +0 -80
  79. package/lib/browser/external-rpc/jsc-polyfills/2.d.ts +0 -1
  80. package/lib/browser/external-rpc/jsc-polyfills/2.js +0 -15
  81. package/lib/browser/external-rpc/jsc-polyfills/event.d.ts +0 -10
  82. package/lib/browser/external-rpc/jsc-polyfills/event.js +0 -19
  83. package/lib/browser/external-rpc/jsc-polyfills/index.d.ts +0 -2
  84. package/lib/browser/external-rpc/jsc-polyfills/index.js +0 -2
  85. package/lib/browser/external-rpc/jsc-polyfills/ws.d.ts +0 -21
  86. package/lib/browser/external-rpc/jsc-polyfills/ws.js +0 -83
  87. package/lib/browser/external-rpc/setup-browser.d.ts +0 -6
  88. package/lib/browser/external-rpc/setup-browser.js +0 -33
  89. package/lib/browser/external-rpc/setup-jsc.d.ts +0 -24
  90. package/lib/browser/external-rpc/setup-jsc.js +0 -22
  91. package/lib/browser/external-rpc/types.d.ts +0 -213
  92. package/lib/browser/external-rpc/types.js +0 -0
  93. package/lib/browser/external-rpc/utils.d.ts +0 -20
  94. package/lib/browser/external-rpc/utils.js +0 -100
  95. package/lib/browser/external-rpc/zk.d.ts +0 -14
  96. package/lib/browser/external-rpc/zk.js +0 -58
  97. package/lib/browser/index.browser.js +0 -13
  98. package/lib/browser/index.d.ts +0 -9
  99. package/lib/browser/index.js +0 -13
  100. package/lib/browser/mechain/abis/governanceABI.d.ts +0 -50
  101. package/lib/browser/mechain/abis/governanceABI.js +0 -461
  102. package/lib/browser/mechain/abis/taskABI.d.ts +0 -157
  103. package/lib/browser/mechain/abis/taskABI.js +0 -512
  104. package/lib/browser/mechain/client/create-claim-on-mechain.d.ts +0 -10
  105. package/lib/browser/mechain/client/create-claim-on-mechain.js +0 -33
  106. package/lib/browser/mechain/client/index.d.ts +0 -1
  107. package/lib/browser/mechain/client/index.js +0 -1
  108. package/lib/browser/mechain/constants/index.d.ts +0 -3
  109. package/lib/browser/mechain/constants/index.js +0 -8
  110. package/lib/browser/mechain/index.d.ts +0 -2
  111. package/lib/browser/mechain/index.js +0 -2
  112. package/lib/browser/mechain/types/index.d.ts +0 -23
  113. package/lib/browser/mechain/types/index.js +0 -0
  114. package/lib/browser/proto/api.d.ts +0 -651
  115. package/lib/browser/proto/api.js +0 -4250
  116. package/lib/browser/proto/tee-bundle.d.ts +0 -156
  117. package/lib/browser/proto/tee-bundle.js +0 -1296
  118. package/lib/browser/providers/http/index.d.ts +0 -18
  119. package/lib/browser/providers/http/index.js +0 -640
  120. package/lib/browser/providers/http/patch-parse5-tree.d.ts +0 -6
  121. package/lib/browser/providers/http/patch-parse5-tree.js +0 -34
  122. package/lib/browser/providers/http/utils.d.ts +0 -77
  123. package/lib/browser/providers/http/utils.js +0 -283
  124. package/lib/browser/providers/index.d.ts +0 -4
  125. package/lib/browser/providers/index.js +0 -7
  126. package/lib/browser/types/bgp.d.ts +0 -11
  127. package/lib/browser/types/bgp.js +0 -0
  128. package/lib/browser/types/claims.d.ts +0 -70
  129. package/lib/browser/types/claims.js +0 -0
  130. package/lib/browser/types/client.d.ts +0 -163
  131. package/lib/browser/types/client.js +0 -0
  132. package/lib/browser/types/general.d.ts +0 -77
  133. package/lib/browser/types/general.js +0 -0
  134. package/lib/browser/types/handlers.d.ts +0 -10
  135. package/lib/browser/types/handlers.js +0 -0
  136. package/lib/browser/types/index.d.ts +0 -10
  137. package/lib/browser/types/index.js +0 -10
  138. package/lib/browser/types/providers.d.ts +0 -161
  139. package/lib/browser/types/providers.gen.d.ts +0 -443
  140. package/lib/browser/types/providers.gen.js +0 -16
  141. package/lib/browser/types/providers.js +0 -0
  142. package/lib/browser/types/rpc.d.ts +0 -35
  143. package/lib/browser/types/rpc.js +0 -0
  144. package/lib/browser/types/signatures.d.ts +0 -28
  145. package/lib/browser/types/signatures.js +0 -0
  146. package/lib/browser/types/tunnel.d.ts +0 -18
  147. package/lib/browser/types/tunnel.js +0 -0
  148. package/lib/browser/types/zk.d.ts +0 -38
  149. package/lib/browser/types/zk.js +0 -0
  150. package/lib/browser/utils/auth.d.ts +0 -8
  151. package/lib/browser/utils/auth.js +0 -71
  152. package/lib/browser/utils/b64-json.d.ts +0 -2
  153. package/lib/browser/utils/b64-json.js +0 -17
  154. package/lib/browser/utils/claims.d.ts +0 -33
  155. package/lib/browser/utils/claims.js +0 -89
  156. package/lib/browser/utils/env.d.ts +0 -3
  157. package/lib/browser/utils/env.js +0 -19
  158. package/lib/browser/utils/error.d.ts +0 -26
  159. package/lib/browser/utils/error.js +0 -54
  160. package/lib/browser/utils/generics.d.ts +0 -119
  161. package/lib/browser/utils/generics.js +0 -272
  162. package/lib/browser/utils/http-parser.d.ts +0 -59
  163. package/lib/browser/utils/http-parser.js +0 -201
  164. package/lib/browser/utils/index.browser.js +0 -13
  165. package/lib/browser/utils/index.d.ts +0 -13
  166. package/lib/browser/utils/index.js +0 -13
  167. package/lib/browser/utils/logger.browser.js +0 -88
  168. package/lib/browser/utils/logger.d.ts +0 -14
  169. package/lib/browser/utils/logger.js +0 -88
  170. package/lib/browser/utils/prepare-packets.d.ts +0 -16
  171. package/lib/browser/utils/prepare-packets.js +0 -69
  172. package/lib/browser/utils/redactions.d.ts +0 -73
  173. package/lib/browser/utils/redactions.js +0 -135
  174. package/lib/browser/utils/retries.d.ts +0 -12
  175. package/lib/browser/utils/retries.js +0 -26
  176. package/lib/browser/utils/signatures/eth.d.ts +0 -2
  177. package/lib/browser/utils/signatures/eth.js +0 -31
  178. package/lib/browser/utils/signatures/index.d.ts +0 -5
  179. package/lib/browser/utils/signatures/index.js +0 -12
  180. package/lib/browser/utils/socket-base.d.ts +0 -23
  181. package/lib/browser/utils/socket-base.js +0 -96
  182. package/lib/browser/utils/tls-imports.d.ts +0 -1
  183. package/lib/browser/utils/tls-imports.js +0 -34
  184. package/lib/browser/utils/tls.d.ts +0 -2
  185. package/lib/browser/utils/tls.js +0 -58
  186. package/lib/browser/utils/ws.d.ts +0 -7
  187. package/lib/browser/utils/ws.js +0 -22
  188. package/lib/browser/utils/zk.d.ts +0 -71
  189. package/lib/browser/utils/zk.js +0 -625
  190. package/lib/client/create-claim.js +0 -461
  191. package/lib/client/index.js +0 -3
  192. package/lib/client/tunnels/make-rpc-tcp-tunnel.js +0 -53
  193. package/lib/client/tunnels/make-rpc-tls-tunnel.js +0 -127
  194. package/lib/client/utils/attestor-pool.js +0 -24
  195. package/lib/client/utils/client-socket.js +0 -120
  196. package/lib/client/utils/message-handler.js +0 -97
  197. package/lib/config/index.js +0 -62
  198. package/lib/external-rpc/benchmark.js +0 -82
  199. package/lib/external-rpc/event-bus.js +0 -17
  200. package/lib/external-rpc/global.d.js +0 -0
  201. package/lib/external-rpc/handle-incoming-msg.js +0 -241
  202. package/lib/external-rpc/jsc-polyfills/1.js +0 -80
  203. package/lib/external-rpc/jsc-polyfills/2.js +0 -15
  204. package/lib/external-rpc/jsc-polyfills/event.js +0 -19
  205. package/lib/external-rpc/jsc-polyfills/index.js +0 -2
  206. package/lib/external-rpc/jsc-polyfills/ws.js +0 -83
  207. package/lib/external-rpc/setup-browser.js +0 -33
  208. package/lib/external-rpc/setup-jsc.js +0 -22
  209. package/lib/external-rpc/types.js +0 -0
  210. package/lib/external-rpc/utils.js +0 -100
  211. package/lib/external-rpc/zk.js +0 -58
  212. package/lib/index.browser.d.ts +0 -9
  213. package/lib/mechain/abis/governanceABI.js +0 -461
  214. package/lib/mechain/abis/taskABI.js +0 -512
  215. package/lib/mechain/client/create-claim-on-mechain.js +0 -33
  216. package/lib/mechain/client/index.js +0 -1
  217. package/lib/mechain/constants/index.js +0 -8
  218. package/lib/mechain/index.js +0 -2
  219. package/lib/mechain/types/index.js +0 -0
  220. package/lib/proto/api.js +0 -4250
  221. package/lib/proto/tee-bundle.js +0 -1296
  222. package/lib/providers/http/index.js +0 -640
  223. package/lib/providers/http/patch-parse5-tree.js +0 -34
  224. package/lib/providers/http/utils.js +0 -283
  225. package/lib/providers/index.js +0 -7
  226. package/lib/scripts/check-avs-registration.js +0 -28
  227. package/lib/scripts/fallbacks/crypto.js +0 -4
  228. package/lib/scripts/fallbacks/empty.js +0 -4
  229. package/lib/scripts/fallbacks/re2.js +0 -7
  230. package/lib/scripts/fallbacks/snarkjs.js +0 -10
  231. package/lib/scripts/fallbacks/stwo.js +0 -159
  232. package/lib/scripts/generate-provider-types.js +0 -101
  233. package/lib/scripts/generate-receipt.js +0 -101
  234. package/lib/scripts/generate-toprf-keys.js +0 -24
  235. package/lib/scripts/jsc-cli-rpc.js +0 -35
  236. package/lib/scripts/register-avs-operator.js +0 -3
  237. package/lib/scripts/start-server.js +0 -11
  238. package/lib/scripts/update-avs-metadata.js +0 -20
  239. package/lib/scripts/utils.js +0 -10
  240. package/lib/scripts/whitelist-operator.js +0 -16
  241. package/lib/server/create-server.js +0 -105
  242. package/lib/server/handlers/claimTeeBundle.js +0 -232
  243. package/lib/server/handlers/claimTunnel.js +0 -80
  244. package/lib/server/handlers/completeClaimOnChain.js +0 -29
  245. package/lib/server/handlers/createClaimOnChain.js +0 -32
  246. package/lib/server/handlers/createTaskOnMechain.js +0 -57
  247. package/lib/server/handlers/createTunnel.js +0 -98
  248. package/lib/server/handlers/disconnectTunnel.js +0 -8
  249. package/lib/server/handlers/fetchCertificateBytes.js +0 -57
  250. package/lib/server/handlers/index.js +0 -25
  251. package/lib/server/handlers/init.js +0 -33
  252. package/lib/server/handlers/toprf.js +0 -19
  253. package/lib/server/index.js +0 -4
  254. package/lib/server/socket.js +0 -112
  255. package/lib/server/tunnels/make-tcp-tunnel.js +0 -202
  256. package/lib/server/utils/apm.js +0 -29
  257. package/lib/server/utils/assert-valid-claim-request.js +0 -354
  258. package/lib/server/utils/config-env.js +0 -4
  259. package/lib/server/utils/dns.js +0 -24
  260. package/lib/server/utils/gcp-attestation.js +0 -237
  261. package/lib/server/utils/generics.js +0 -45
  262. package/lib/server/utils/iso.js +0 -259
  263. package/lib/server/utils/keep-alive.js +0 -38
  264. package/lib/server/utils/nitro-attestation.js +0 -249
  265. package/lib/server/utils/oprf-raw.js +0 -61
  266. package/lib/server/utils/process-handshake.js +0 -233
  267. package/lib/server/utils/proxy-session.js +0 -4
  268. package/lib/server/utils/tee-oprf-mpc-verification.js +0 -86
  269. package/lib/server/utils/tee-oprf-verification.js +0 -151
  270. package/lib/server/utils/tee-transcript-reconstruction.js +0 -140
  271. package/lib/server/utils/tee-verification.js +0 -358
  272. package/lib/server/utils/validation.js +0 -45
  273. package/lib/types/bgp.js +0 -0
  274. package/lib/types/claims.js +0 -0
  275. package/lib/types/client.js +0 -0
  276. package/lib/types/general.js +0 -0
  277. package/lib/types/handlers.js +0 -0
  278. package/lib/types/index.js +0 -10
  279. package/lib/types/providers.gen.js +0 -16
  280. package/lib/types/providers.js +0 -0
  281. package/lib/types/rpc.js +0 -0
  282. package/lib/types/signatures.js +0 -0
  283. package/lib/types/tunnel.js +0 -0
  284. package/lib/types/zk.js +0 -0
  285. package/lib/utils/auth.js +0 -71
  286. package/lib/utils/b64-json.js +0 -17
  287. package/lib/utils/bgp-listener.js +0 -123
  288. package/lib/utils/claims.js +0 -89
  289. package/lib/utils/env.js +0 -19
  290. package/lib/utils/error.js +0 -54
  291. package/lib/utils/generics.js +0 -272
  292. package/lib/utils/http-parser.js +0 -201
  293. package/lib/utils/index.browser.d.ts +0 -13
  294. package/lib/utils/index.js +0 -14
  295. package/lib/utils/logger.browser.d.ts +0 -14
  296. package/lib/utils/logger.js +0 -82
  297. package/lib/utils/prepare-packets.js +0 -69
  298. package/lib/utils/redactions.js +0 -135
  299. package/lib/utils/retries.js +0 -26
  300. package/lib/utils/signatures/eth.js +0 -31
  301. package/lib/utils/signatures/index.js +0 -12
  302. package/lib/utils/socket-base.js +0 -96
  303. package/lib/utils/tls-imports.d.ts +0 -1
  304. package/lib/utils/tls-imports.js +0 -34
  305. package/lib/utils/tls.js +0 -58
  306. package/lib/utils/ws.js +0 -22
  307. package/lib/utils/zk.js +0 -625
@@ -1,120 +0,0 @@
1
- import { encodeBase64 } from "ethers";
2
- import { DEFAULT_METADATA, DEFAULT_RPC_TIMEOUT_MS } from "../../config/index.js";
3
- import { RPCMessages } from "../../proto/api.js";
4
- import { AttestorError, generateRpcMessageId, getRpcRequestType, logger as LOGGER, packRpcMessages } from "../../utils/index.js";
5
- import { AttestorSocket } from "../../utils/socket-base.js";
6
- import { makeWebSocket as defaultMakeWebSocket } from "../../utils/ws.js";
7
- class AttestorClient extends AttestorSocket {
8
- waitForInitPromise;
9
- initResponse;
10
- constructor({
11
- url,
12
- initMessages = [],
13
- signatureType = DEFAULT_METADATA.signatureType,
14
- logger = LOGGER,
15
- authRequest,
16
- makeWebSocket = defaultMakeWebSocket
17
- }) {
18
- const initRequest = {
19
- ...DEFAULT_METADATA,
20
- signatureType,
21
- auth: authRequest
22
- };
23
- const msg = packRpcMessages({ initRequest }, ...initMessages);
24
- const initRequestBytes = RPCMessages.encode(msg).finish();
25
- const initRequestB64 = encodeBase64(initRequestBytes);
26
- url = new URL(url.toString());
27
- url.searchParams.set("messages", initRequestB64);
28
- super(
29
- makeWebSocket(url),
30
- initRequest,
31
- logger
32
- );
33
- const initReqId = msg.messages[0].id;
34
- this.waitForInitPromise = this.waitForResponse(initReqId, DEFAULT_RPC_TIMEOUT_MS).then((res) => {
35
- logger.info("client initialised");
36
- this.isInitialised = true;
37
- this.initResponse = res;
38
- });
39
- this.waitForInitPromise.catch(() => {
40
- });
41
- this.addEventListener("connection-terminated", (ev) => logger.info({ err: ev.data }, "connection terminated"));
42
- }
43
- async rpc(type, request, timeoutMs = DEFAULT_RPC_TIMEOUT_MS) {
44
- const msgId = generateRpcMessageId();
45
- this.logger.debug({ type, id: msgId }, "sending rpc request");
46
- const now = Date.now();
47
- try {
48
- const rslt = this.waitForResponse(msgId, timeoutMs);
49
- await this.sendMessage({ id: msgId, [getRpcRequestType(type)]: request });
50
- return await rslt;
51
- } finally {
52
- const timeTakenMs = Date.now() - now;
53
- this.logger.debug({ type, timeTakenMs }, "received rpc response");
54
- }
55
- }
56
- waitForResponse(id, timeoutMs = DEFAULT_RPC_TIMEOUT_MS) {
57
- if (this.isClosed) {
58
- throw new AttestorError(
59
- "ERROR_NETWORK_ERROR",
60
- "Client connection already closed"
61
- );
62
- }
63
- return new Promise((resolve, reject) => {
64
- const handler = (event) => {
65
- if (event.data.id !== id) {
66
- return;
67
- }
68
- removeHandlers();
69
- if ("error" in event.data) {
70
- reject(event.data.error);
71
- return;
72
- }
73
- resolve(event.data.data);
74
- };
75
- const terminateHandler = (event) => {
76
- removeHandlers();
77
- if (event.data.code === "ERROR_NO_ERROR") {
78
- reject(
79
- new AttestorError(
80
- "ERROR_NETWORK_ERROR",
81
- event.data.message,
82
- event.data.data
83
- )
84
- );
85
- return;
86
- }
87
- reject(event.data);
88
- };
89
- const timeout = setTimeout(() => {
90
- removeHandlers();
91
- reject(
92
- new AttestorError(
93
- "ERROR_TIMEOUT",
94
- `RPC request timed out after ${timeoutMs}ms`,
95
- { id }
96
- )
97
- );
98
- }, timeoutMs);
99
- const removeHandlers = () => {
100
- clearTimeout(timeout);
101
- this.removeEventListener("rpc-response", handler);
102
- this.removeEventListener("connection-terminated", terminateHandler);
103
- };
104
- this.addEventListener("rpc-response", handler);
105
- this.addEventListener("connection-terminated", terminateHandler);
106
- });
107
- }
108
- waitForInit = () => {
109
- if (this.isClosed) {
110
- throw new AttestorError(
111
- "ERROR_NETWORK_ERROR",
112
- "Client connection already closed"
113
- );
114
- }
115
- return this.waitForInitPromise;
116
- };
117
- }
118
- export {
119
- AttestorClient
120
- };
@@ -1,97 +0,0 @@
1
- import { RPCMessages } from "../../proto/api.js";
2
- import { AttestorError, extractArrayBufferFromWsData, getRpcRequest, getRpcRequestType, getRpcResponseType } from "../../utils/index.js";
3
- async function wsMessageHandler(data) {
4
- const buff = await extractArrayBufferFromWsData(data);
5
- const { messages } = RPCMessages.decode(buff);
6
- for (const msg of messages) {
7
- await handleMessage.call(this, msg);
8
- }
9
- }
10
- function handleMessage(msg) {
11
- this.logger?.trace({ msg }, "received message");
12
- if (msg.connectionTerminationAlert) {
13
- const err = AttestorError.fromProto(
14
- msg.connectionTerminationAlert
15
- );
16
- this.logger?.warn(
17
- {
18
- err: err.code !== "ERROR_NO_ERROR" ? err : void 0
19
- },
20
- "received connection termination alert"
21
- );
22
- this.dispatchRPCEvent("connection-terminated", err);
23
- return;
24
- }
25
- const rpcRequest = getRpcRequest(msg);
26
- if (rpcRequest) {
27
- if (rpcRequest.direction === "response" && rpcRequest.type === "error") {
28
- this.dispatchRPCEvent("rpc-response", {
29
- id: msg.id,
30
- error: AttestorError.fromProto(msg.requestError)
31
- });
32
- return;
33
- }
34
- const resType = getRpcResponseType(rpcRequest.type);
35
- if (rpcRequest.direction === "response") {
36
- this.dispatchRPCEvent("rpc-response", {
37
- id: msg.id,
38
- type: rpcRequest.type,
39
- data: msg[resType]
40
- });
41
- return;
42
- }
43
- if (!this.isInitialised && rpcRequest.type !== "init") {
44
- this.logger.warn(
45
- { type: rpcRequest.type },
46
- "RPC request received before initialisation"
47
- );
48
- void this.sendMessage({
49
- id: msg.id,
50
- requestError: AttestorError.badRequest("Initialise connection first").toProto()
51
- });
52
- return;
53
- }
54
- return new Promise((resolve, reject) => {
55
- this.dispatchRPCEvent("rpc-request", {
56
- requestId: msg.id,
57
- type: rpcRequest.type,
58
- data: msg[getRpcRequestType(rpcRequest.type)],
59
- respond: (res) => {
60
- if (!this.isOpen) {
61
- this.logger?.debug(
62
- { type: rpcRequest.type, res },
63
- "connection closed before responding"
64
- );
65
- reject(new Error("connection closed"));
66
- return;
67
- }
68
- if ("code" in res) {
69
- reject(res);
70
- return this.sendMessage({
71
- id: msg.id,
72
- requestError: res.toProto()
73
- });
74
- }
75
- resolve();
76
- return this.sendMessage({ id: msg.id, [resType]: res });
77
- }
78
- });
79
- });
80
- }
81
- if (msg.tunnelMessage) {
82
- this.dispatchRPCEvent("tunnel-message", msg.tunnelMessage);
83
- return;
84
- }
85
- if (msg.tunnelDisconnectEvent) {
86
- this.dispatchRPCEvent(
87
- "tunnel-disconnect-event",
88
- msg.tunnelDisconnectEvent
89
- );
90
- return;
91
- }
92
- this.logger.warn({ msg }, "unhandled message");
93
- }
94
- export {
95
- handleMessage,
96
- wsMessageHandler
97
- };
@@ -1,62 +0,0 @@
1
- import { AttestorVersion, ServiceSignatureType } from "../proto/api.js";
2
- const DEFAULT_ZK_CONCURRENCY = 10;
3
- const RECLAIM_USER_AGENT = "reclaim/0.0.1";
4
- const DEFAULT_HTTPS_PORT = 443;
5
- const WS_PATHNAME = "/ws";
6
- const BROWSER_RPC_PATHNAME = "/browser-rpc";
7
- const ATTESTOR_ADDRESS_PATHNAME = "/address";
8
- const DEFAULT_REMOTE_FILE_FETCH_BASE_URL = `${BROWSER_RPC_PATHNAME}/resources`;
9
- const API_SERVER_PORT = 8001;
10
- const CONNECTION_TIMEOUT_MS = 1e4;
11
- const DNS_SERVERS = [
12
- "8.8.8.8",
13
- "8.8.4.4"
14
- ];
15
- const MAX_CLAIM_TIMESTAMP_DIFF_S = 10 * 60;
16
- const CURRENT_ATTESTOR_VERSION = AttestorVersion.ATTESTOR_VERSION_3_0_0;
17
- const DEFAULT_METADATA = {
18
- signatureType: ServiceSignatureType.SERVICE_SIGNATURE_TYPE_ETH,
19
- clientVersion: CURRENT_ATTESTOR_VERSION,
20
- auth: void 0
21
- };
22
- const PROVIDER_CTX = { version: CURRENT_ATTESTOR_VERSION };
23
- const PING_INTERVAL_MS = 1e4;
24
- const MAX_NO_DATA_INTERVAL_MS = 3e4;
25
- const MAX_PAYLOAD_SIZE = 512 * 1024 * 1024;
26
- const DEFAULT_AUTH_EXPIRY_S = 15 * 60;
27
- const DEFAULT_RPC_TIMEOUT_MS = 9e4;
28
- const TOPRF_DOMAIN_SEPARATOR = "reclaim-toprf";
29
- const MAX_CERT_SIZE_BYTES = 10 * 1024 * 1024 * 1024;
30
- const CERT_ALLOWED_MIMETYPES = [
31
- "application/x-x509-ca-cert",
32
- "application/x-x509-user-cert",
33
- "application/pkix-cert",
34
- "application/pkcs7-mime",
35
- "application/octet-stream"
36
- ];
37
- const BGP_WS_URL = "wss://ris-live.ripe.net/v1/ws/?client=reclaim-hijack-detector";
38
- export {
39
- API_SERVER_PORT,
40
- ATTESTOR_ADDRESS_PATHNAME,
41
- BGP_WS_URL,
42
- BROWSER_RPC_PATHNAME,
43
- CERT_ALLOWED_MIMETYPES,
44
- CONNECTION_TIMEOUT_MS,
45
- CURRENT_ATTESTOR_VERSION,
46
- DEFAULT_AUTH_EXPIRY_S,
47
- DEFAULT_HTTPS_PORT,
48
- DEFAULT_METADATA,
49
- DEFAULT_REMOTE_FILE_FETCH_BASE_URL,
50
- DEFAULT_RPC_TIMEOUT_MS,
51
- DEFAULT_ZK_CONCURRENCY,
52
- DNS_SERVERS,
53
- MAX_CERT_SIZE_BYTES,
54
- MAX_CLAIM_TIMESTAMP_DIFF_S,
55
- MAX_NO_DATA_INTERVAL_MS,
56
- MAX_PAYLOAD_SIZE,
57
- PING_INTERVAL_MS,
58
- PROVIDER_CTX,
59
- RECLAIM_USER_AGENT,
60
- TOPRF_DOMAIN_SEPARATOR,
61
- WS_PATHNAME
62
- };
@@ -1,82 +0,0 @@
1
- import {
2
- crypto,
3
- encryptWrappedRecord,
4
- SUPPORTED_CIPHER_SUITE_MAP
5
- } from "../utils/tls-imports.js";
6
- import { strToUint8Array } from "../utils/generics.js";
7
- import { logger } from "../utils/logger.js";
8
- import { makeZkProofGenerator } from "../utils/zk.js";
9
- const ZK_CIPHER_SUITES = [
10
- "TLS_CHACHA20_POLY1305_SHA256",
11
- "TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384",
12
- "TLS_AES_128_GCM_SHA256"
13
- ];
14
- async function benchmark() {
15
- let benchmarkRes = "";
16
- for (const cipherSuite of ZK_CIPHER_SUITES) {
17
- const now = Date.now();
18
- const alg = cipherSuite.includes("CHACHA20") ? "CHACHA20-POLY1305" : cipherSuite.includes("AES_256_GCM") ? "AES-256-GCM" : "AES-128-GCM";
19
- const keylength = alg === "AES-128-GCM" ? 16 : 32;
20
- const key = Buffer.alloc(keylength, 0);
21
- const {
22
- ivLength: fixedIvLength
23
- } = SUPPORTED_CIPHER_SUITE_MAP[cipherSuite];
24
- const fixedIv = Buffer.alloc(fixedIvLength, 0);
25
- const encKey = await crypto.importKey(alg, key);
26
- const vectors = [
27
- {
28
- plaintext: `My cool API secret is "my name jeff". Please don't reveal it`
29
- }
30
- ];
31
- const proofGenerator = await makeZkProofGenerator({
32
- logger,
33
- cipherSuite
34
- });
35
- for (const { plaintext } of vectors) {
36
- const plaintextArr = strToUint8Array(plaintext);
37
- const { ciphertext, iv } = await encryptWrappedRecord(
38
- plaintextArr,
39
- {
40
- key: encKey,
41
- iv: fixedIv,
42
- recordNumber: 0,
43
- recordHeaderOpts: {
44
- type: "WRAPPED_RECORD"
45
- },
46
- cipherSuite,
47
- version: cipherSuite.includes("ECDHE_") ? "TLS1_2" : "TLS1_3"
48
- }
49
- );
50
- const packet = {
51
- type: "ciphertext",
52
- encKey,
53
- iv,
54
- recordNumber: 0,
55
- plaintext: plaintextArr,
56
- ciphertext,
57
- fixedIv: new Uint8Array(0),
58
- data: ciphertext
59
- };
60
- await proofGenerator.addPacketToProve(
61
- packet,
62
- {
63
- type: "zk",
64
- redactedPlaintext: plaintextArr
65
- },
66
- () => {
67
- },
68
- () => {
69
- throw new Error("should not be called in benchmark");
70
- }
71
- );
72
- await proofGenerator.generateProofs();
73
- }
74
- benchmarkRes = benchmarkRes + `Benchmark ${alg} ok. Took ${Date.now() - now} ms
75
- `;
76
- }
77
- logger.info(benchmarkRes);
78
- return benchmarkRes;
79
- }
80
- export {
81
- benchmark
82
- };
@@ -1,17 +0,0 @@
1
- class EventBus {
2
- #listeners = [];
3
- addListener(fn) {
4
- this.#listeners.push(fn);
5
- return () => {
6
- this.#listeners = this.#listeners.filter((l) => l !== fn);
7
- };
8
- }
9
- dispatch(data) {
10
- for (const listener of this.#listeners) {
11
- listener(data);
12
- }
13
- }
14
- }
15
- export {
16
- EventBus
17
- };
File without changes
@@ -1,241 +0,0 @@
1
- import { hexlify } from "ethers";
2
- import { createClaimOnAvs } from "../avs/client/create-claim-on-avs.js";
3
- import { createClaimOnAttestor } from "../client/index.js";
4
- import { benchmark } from "../external-rpc/benchmark.js";
5
- import { generateRpcRequestId, getCurrentMemoryUsage, getWsApiUrlFromBaseUrl, RPC_MSG_BRIDGE, sendMessageToApp, waitForResponse } from "../external-rpc/utils.js";
6
- import { ALL_ENC_ALGORITHMS, makeExternalRpcOprfOperator, makeExternalRpcZkOperator } from "../external-rpc/zk.js";
7
- import { createClaimOnMechain } from "../mechain/client/create-claim-on-mechain.js";
8
- import { extractHTMLElement, extractJSONValueIndex, generateRequstAndResponseFromTranscript } from "../providers/http/utils.js";
9
- import { B64_JSON_REVIVER } from "../utils/b64-json.js";
10
- import { AttestorError, getIdentifierFromClaimInfo, logger, makeLogger, uint8ArrayToStr } from "../utils/index.js";
11
- async function handleIncomingMessage(data) {
12
- let id = "";
13
- try {
14
- const req = typeof data === "string" ? JSON.parse(data, B64_JSON_REVIVER) : data;
15
- id = req.id || "";
16
- const rslt = await _handleIncomingMessage(req);
17
- if (!rslt) {
18
- return;
19
- }
20
- respond(rslt);
21
- } catch (err) {
22
- console.error("Error in RPC", { id, error: err });
23
- respond({
24
- type: "error",
25
- data: {
26
- message: err.message,
27
- stack: err.stack
28
- }
29
- });
30
- }
31
- function respond(data2) {
32
- const res = {
33
- ...data2,
34
- id,
35
- isResponse: true
36
- };
37
- return sendMessageToApp(res);
38
- }
39
- }
40
- async function _handleIncomingMessage(req) {
41
- const { id: reqId, type: reqType } = req;
42
- if (!reqId || !reqType) {
43
- return;
44
- }
45
- RPC_MSG_BRIDGE.dispatch(req);
46
- if ("isResponse" in req && req.isResponse) {
47
- return;
48
- }
49
- if (!reqId) {
50
- logger.warn({ req }, "Window RPC request missing ID");
51
- return;
52
- }
53
- logger.info({ req }, "processing RPC request");
54
- switch (req.type) {
55
- case "createClaim":
56
- const claimTunnelRes = await createClaimOnAttestor({
57
- ...req.request,
58
- context: req.request.context ? JSON.parse(req.request.context) : void 0,
59
- zkOperators: getZkOperators(
60
- req.request.zkOperatorMode,
61
- req.request.zkEngine
62
- ),
63
- oprfOperators: getOprfOperators(
64
- req.request.zkOperatorMode,
65
- req.request.zkEngine
66
- ),
67
- client: {
68
- url: getWsApiUrlFromBaseUrl(),
69
- authRequest: req.request.authRequest
70
- },
71
- logger,
72
- onStep(step) {
73
- sendMessageToApp({
74
- type: "createClaimStep",
75
- step: { name: "attestor-progress", step },
76
- id: req.id
77
- });
78
- },
79
- updateProviderParams: req.request.updateProviderParams ? updateProviderParams : void 0
80
- });
81
- const response = mapToCreateClaimResponse(claimTunnelRes);
82
- return { type: "createClaimDone", response };
83
- case "createClaimOnAvs":
84
- const avsRes = await createClaimOnAvs({
85
- ...req.request,
86
- payer: req.request.payer === "attestor" ? { attestor: getWsApiUrlFromBaseUrl() } : void 0,
87
- context: req.request.context ? JSON.parse(req.request.context) : void 0,
88
- zkOperators: getZkOperators(
89
- req.request.zkOperatorMode,
90
- req.request.zkEngine
91
- ),
92
- oprfOperators: getOprfOperators(
93
- req.request.zkOperatorMode,
94
- req.request.zkEngine
95
- ),
96
- logger,
97
- onStep(step) {
98
- sendMessageToApp({
99
- type: "createClaimOnAvsStep",
100
- step,
101
- id: req.id
102
- });
103
- }
104
- });
105
- return {
106
- type: "createClaimOnAvsDone",
107
- response: avsRes
108
- };
109
- case "createClaimOnMechain":
110
- const mechainRes = await createClaimOnMechain({
111
- ...req.request,
112
- context: req.request.context ? JSON.parse(req.request.context) : void 0,
113
- zkOperators: getZkOperators(
114
- req.request.zkOperatorMode,
115
- req.request.zkEngine
116
- ),
117
- oprfOperators: getOprfOperators(
118
- req.request.zkOperatorMode,
119
- req.request.zkEngine
120
- ),
121
- client: { url: getWsApiUrlFromBaseUrl() },
122
- logger,
123
- onStep(step) {
124
- sendMessageToApp({
125
- type: "createClaimOnMechainStep",
126
- step,
127
- id: req.id
128
- });
129
- }
130
- });
131
- const claimResponses = [];
132
- for (let i = 0; i < mechainRes.responses.length; i++) {
133
- claimResponses[i] = mapToCreateClaimResponse(mechainRes.responses[i]);
134
- }
135
- return {
136
- type: "createClaimOnMechainDone",
137
- response: { taskId: mechainRes.taskId, data: claimResponses }
138
- };
139
- case "extractHtmlElement":
140
- return {
141
- type: "extractHtmlElementDone",
142
- response: extractHTMLElement(
143
- req.request.html,
144
- req.request.xpathExpression,
145
- req.request.contentsOnly
146
- )
147
- };
148
- case "extractJSONValueIndex":
149
- return {
150
- type: "extractJSONValueIndexDone",
151
- response: extractJSONValueIndex(
152
- req.request.json,
153
- req.request.jsonPath
154
- )
155
- };
156
- case "getCurrentMemoryUsage":
157
- return {
158
- type: "getCurrentMemoryUsageDone",
159
- response: await getCurrentMemoryUsage()
160
- };
161
- case "setLogLevel":
162
- makeLogger(
163
- true,
164
- req.request.logLevel,
165
- req.request.sendLogsToApp ? (level, message) => sendMessageToApp({
166
- type: "log",
167
- level,
168
- message,
169
- id: req.id
170
- }) : void 0
171
- );
172
- return { type: "setLogLevelDone", response: void 0 };
173
- case "benchmarkZK":
174
- return { type: "benchmarkZKDone", response: await benchmark() };
175
- case "ping":
176
- return { type: "pingDone", response: { pong: (/* @__PURE__ */ new Date()).toJSON() } };
177
- default:
178
- break;
179
- }
180
- }
181
- function getZkOperators(mode = "default", zkEngine = "snarkjs") {
182
- if (mode === "default") {
183
- return;
184
- }
185
- const operators = {};
186
- for (const alg of ALL_ENC_ALGORITHMS) {
187
- operators[alg] = makeExternalRpcZkOperator(alg, zkEngine);
188
- }
189
- return operators;
190
- }
191
- function getOprfOperators(mode = "default", zkEngine = "snarkjs") {
192
- if (mode === "default") {
193
- return;
194
- }
195
- const operators = {};
196
- for (const alg of ALL_ENC_ALGORITHMS) {
197
- operators[alg] = makeExternalRpcOprfOperator(alg, zkEngine);
198
- }
199
- return operators;
200
- }
201
- async function updateProviderParams(transcript, tlsVersion) {
202
- const { req, res } = generateRequstAndResponseFromTranscript(
203
- transcript,
204
- tlsVersion
205
- );
206
- const id = generateRpcRequestId();
207
- const waitForRes = waitForResponse("updateProviderParams", id);
208
- sendMessageToApp({
209
- type: "updateProviderParams",
210
- id,
211
- request: {
212
- request: {
213
- ...req,
214
- body: req.body ? uint8ArrayToStr(req.body) : void 0
215
- },
216
- response: { ...res, body: uint8ArrayToStr(res.body) }
217
- }
218
- });
219
- return waitForRes;
220
- }
221
- function mapToCreateClaimResponse(res) {
222
- if (!res.claim) {
223
- throw AttestorError.fromProto(res.error);
224
- }
225
- return {
226
- identifier: getIdentifierFromClaimInfo(res.claim),
227
- claimData: res.claim,
228
- witnesses: [
229
- {
230
- id: res.signatures.attestorAddress,
231
- url: getWsApiUrlFromBaseUrl()
232
- }
233
- ],
234
- signatures: [
235
- hexlify(res.signatures.claimSignature).toLowerCase()
236
- ]
237
- };
238
- }
239
- export {
240
- handleIncomingMessage
241
- };
@@ -1,80 +0,0 @@
1
- import { TextDecoder, TextEncoder } from "@kayahr/text-encoding";
2
- import { crypto, uint8ArrayToBinaryStr } from "../../utils/tls-imports.js";
3
- import { fromByteArray, toByteArray } from "base64-js";
4
- import { EventTarget } from "event-target-shim";
5
- if (typeof global === "undefined") {
6
- globalThis.global = globalThis;
7
- }
8
- if (typeof console === "undefined") {
9
- globalThis.console = {
10
- log: print,
11
- error: print,
12
- warn: print,
13
- info: print,
14
- debug: print
15
- };
16
- }
17
- if (typeof globalThis.crypto === "undefined") {
18
- globalThis.crypto = {
19
- // @ts-expect-error
20
- getRandomValues(arr) {
21
- const randVals = crypto.randomBytes(arr.length);
22
- for (let i = 0; i < arr.length; i++) {
23
- arr[i] = randVals[i];
24
- }
25
- return arr;
26
- },
27
- randomBytes(length) {
28
- return crypto.randomBytes(length);
29
- }
30
- };
31
- }
32
- if (typeof globalThis.TextEncoder === "undefined") {
33
- globalThis.TextEncoder = TextEncoder;
34
- }
35
- if (typeof globalThis.TextDecoder === "undefined") {
36
- globalThis.TextDecoder = TextDecoder;
37
- }
38
- if (typeof globalThis.EventTarget === "undefined") {
39
- globalThis.EventTarget = EventTarget;
40
- }
41
- if (typeof globalThis.atob === "undefined") {
42
- globalThis.atob = (a) => uint8ArrayToBinaryStr(toByteArray(a));
43
- }
44
- if (typeof globalThis.btoa === "undefined") {
45
- let binaryStringToUint8Array = function(binaryString) {
46
- const uint8Array = new Uint8Array(binaryString.length);
47
- for (let i = 0; i < binaryString.length; i++) {
48
- uint8Array[i] = binaryString.charCodeAt(i);
49
- }
50
- return uint8Array;
51
- };
52
- globalThis.btoa = (b) => fromByteArray(binaryStringToUint8Array(b));
53
- }
54
- if (typeof globalThis.clearTimeout === "undefined") {
55
- const ogSettimeout = globalThis.setTimeout;
56
- if (!ogSettimeout) {
57
- throw new Error("setTimeout is not defined, no polyfill yet");
58
- }
59
- globalThis.setTimeout = (fn, delayMs, ...args) => {
60
- let aborted = false;
61
- const abortableFn = (...args2) => {
62
- if (aborted) {
63
- return;
64
- }
65
- return fn(...args2);
66
- };
67
- const val = ogSettimeout(abortableFn, delayMs, ...args);
68
- return {
69
- original: val,
70
- abort() {
71
- aborted = true;
72
- }
73
- };
74
- };
75
- globalThis.clearTimeout = (id) => {
76
- if (typeof id === "object" && !!id && "abort" in id) {
77
- id.abort();
78
- }
79
- };
80
- }