@reclaimprotocol/attestor-core 5.0.1-beta.27 → 5.0.1-beta.29

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 (120) hide show
  1. package/browser/resources/attestor-browser.min.mjs +4513 -0
  2. package/browser/resources/attestor-browser.min.mjs.map +7 -0
  3. package/browser/resources/attestor-jsc.min.mjs +4511 -0
  4. package/lib/external-rpc/index.js +10400 -3
  5. package/lib/external-rpc/index.js.map +7 -0
  6. package/lib/index.js +8331 -11
  7. package/lib/index.js.map +7 -0
  8. package/package.json +9 -3
  9. package/lib/avs/abis/avsDirectoryABI.js +0 -340
  10. package/lib/avs/abis/delegationABI.js +0 -1
  11. package/lib/avs/abis/registryABI.js +0 -725
  12. package/lib/avs/client/create-claim-on-avs.js +0 -140
  13. package/lib/avs/config.js +0 -20
  14. package/lib/avs/contracts/ReclaimServiceManager.js +0 -1
  15. package/lib/avs/contracts/common.js +0 -1
  16. package/lib/avs/contracts/factories/ReclaimServiceManager__factory.js +0 -1166
  17. package/lib/avs/contracts/factories/index.js +0 -4
  18. package/lib/avs/contracts/index.js +0 -2
  19. package/lib/avs/types/index.js +0 -1
  20. package/lib/avs/utils/contracts.js +0 -33
  21. package/lib/avs/utils/register.js +0 -79
  22. package/lib/avs/utils/tasks.js +0 -41
  23. package/lib/client/create-claim.js +0 -432
  24. package/lib/client/index.js +0 -3
  25. package/lib/client/tunnels/make-rpc-tcp-tunnel.js +0 -51
  26. package/lib/client/tunnels/make-rpc-tls-tunnel.js +0 -131
  27. package/lib/client/utils/attestor-pool.js +0 -25
  28. package/lib/client/utils/client-socket.js +0 -97
  29. package/lib/client/utils/message-handler.js +0 -87
  30. package/lib/config/index.js +0 -44
  31. package/lib/external-rpc/benchmark.js +0 -69
  32. package/lib/external-rpc/event-bus.js +0 -14
  33. package/lib/external-rpc/handle-incoming-msg.js +0 -232
  34. package/lib/external-rpc/jsc-polyfills/1.js +0 -82
  35. package/lib/external-rpc/jsc-polyfills/2.js +0 -20
  36. package/lib/external-rpc/jsc-polyfills/event.js +0 -14
  37. package/lib/external-rpc/jsc-polyfills/index.js +0 -2
  38. package/lib/external-rpc/jsc-polyfills/ws.js +0 -81
  39. package/lib/external-rpc/setup-browser.js +0 -33
  40. package/lib/external-rpc/setup-jsc.js +0 -22
  41. package/lib/external-rpc/types.js +0 -1
  42. package/lib/external-rpc/utils.js +0 -100
  43. package/lib/external-rpc/zk.js +0 -63
  44. package/lib/mechain/abis/governanceABI.js +0 -458
  45. package/lib/mechain/abis/taskABI.js +0 -509
  46. package/lib/mechain/client/create-claim-on-mechain.js +0 -28
  47. package/lib/mechain/client/index.js +0 -1
  48. package/lib/mechain/constants/index.js +0 -3
  49. package/lib/mechain/index.js +0 -2
  50. package/lib/mechain/types/index.js +0 -1
  51. package/lib/proto/api.js +0 -4363
  52. package/lib/proto/tee-bundle.js +0 -1316
  53. package/lib/providers/http/index.js +0 -653
  54. package/lib/providers/http/patch-parse5-tree.js +0 -32
  55. package/lib/providers/http/utils.js +0 -324
  56. package/lib/providers/index.js +0 -4
  57. package/lib/server/create-server.js +0 -103
  58. package/lib/server/handlers/claimTeeBundle.js +0 -252
  59. package/lib/server/handlers/claimTunnel.js +0 -73
  60. package/lib/server/handlers/completeClaimOnChain.js +0 -24
  61. package/lib/server/handlers/createClaimOnChain.js +0 -26
  62. package/lib/server/handlers/createTaskOnMechain.js +0 -47
  63. package/lib/server/handlers/createTunnel.js +0 -93
  64. package/lib/server/handlers/disconnectTunnel.js +0 -5
  65. package/lib/server/handlers/fetchCertificateBytes.js +0 -41
  66. package/lib/server/handlers/index.js +0 -22
  67. package/lib/server/handlers/init.js +0 -32
  68. package/lib/server/handlers/toprf.js +0 -16
  69. package/lib/server/index.js +0 -4
  70. package/lib/server/socket.js +0 -109
  71. package/lib/server/tunnels/make-tcp-tunnel.js +0 -177
  72. package/lib/server/utils/apm.js +0 -36
  73. package/lib/server/utils/assert-valid-claim-request.js +0 -325
  74. package/lib/server/utils/config-env.js +0 -4
  75. package/lib/server/utils/dns.js +0 -18
  76. package/lib/server/utils/gcp-attestation.js +0 -289
  77. package/lib/server/utils/generics.js +0 -51
  78. package/lib/server/utils/iso.js +0 -256
  79. package/lib/server/utils/keep-alive.js +0 -38
  80. package/lib/server/utils/nitro-attestation.js +0 -324
  81. package/lib/server/utils/oprf-raw.js +0 -54
  82. package/lib/server/utils/process-handshake.js +0 -215
  83. package/lib/server/utils/proxy-session.js +0 -6
  84. package/lib/server/utils/tee-oprf-mpc-verification.js +0 -90
  85. package/lib/server/utils/tee-oprf-verification.js +0 -174
  86. package/lib/server/utils/tee-transcript-reconstruction.js +0 -187
  87. package/lib/server/utils/tee-verification.js +0 -421
  88. package/lib/server/utils/validation.js +0 -38
  89. package/lib/tls-exports.js +0 -5
  90. package/lib/types/bgp.js +0 -1
  91. package/lib/types/claims.js +0 -1
  92. package/lib/types/client.js +0 -1
  93. package/lib/types/general.js +0 -1
  94. package/lib/types/handlers.js +0 -1
  95. package/lib/types/index.js +0 -10
  96. package/lib/types/providers.gen.js +0 -10
  97. package/lib/types/providers.js +0 -1
  98. package/lib/types/rpc.js +0 -1
  99. package/lib/types/signatures.js +0 -1
  100. package/lib/types/tunnel.js +0 -1
  101. package/lib/types/zk.js +0 -1
  102. package/lib/utils/auth.js +0 -59
  103. package/lib/utils/b64-json.js +0 -17
  104. package/lib/utils/bgp-listener.js +0 -119
  105. package/lib/utils/claims.js +0 -98
  106. package/lib/utils/env.js +0 -15
  107. package/lib/utils/error.js +0 -50
  108. package/lib/utils/generics.js +0 -317
  109. package/lib/utils/http-parser.js +0 -246
  110. package/lib/utils/index.js +0 -13
  111. package/lib/utils/logger.js +0 -91
  112. package/lib/utils/prepare-packets.js +0 -71
  113. package/lib/utils/redactions.js +0 -177
  114. package/lib/utils/retries.js +0 -24
  115. package/lib/utils/signatures/eth.js +0 -32
  116. package/lib/utils/signatures/index.js +0 -7
  117. package/lib/utils/socket-base.js +0 -92
  118. package/lib/utils/tls.js +0 -58
  119. package/lib/utils/ws.js +0 -22
  120. package/lib/utils/zk.js +0 -585
@@ -1,140 +0,0 @@
1
- import { EventLog, hexlify, Wallet } from 'ethers';
2
- import { CHAIN_CONFIGS, SELECTED_CHAIN_ID } from "../config.js";
3
- import { initialiseContracts } from "../utils/contracts.js";
4
- import { createNewClaimRequestOnChain, signClaimRequest } from "../utils/tasks.js";
5
- import { createClaimOnAttestor as _createClaimOnAttestor, getAttestorClientFromPool } from "../../client/index.js";
6
- import { AttestorError, canonicalStringify, getIdentifierFromClaimInfo, logger as LOGGER, unixTimestampSeconds } from "../../utils/index.js";
7
- const EMPTY_CLAIM_USER_ID = hexlify(new Uint8Array(32));
8
- /**
9
- * Creates a Reclaim claim on the AVS chain.
10
- */
11
- export async function createClaimOnAvs({ onStep, createClaimOnAttestor = _createClaimOnAttestor, chainId = SELECTED_CHAIN_ID, payer, ...opts }) {
12
- const { logger = LOGGER, ownerPrivateKey, name, params, context, } = opts;
13
- const { contract, wallet, provider } = initialiseContracts(CHAIN_CONFIGS[chainId], ownerPrivateKey);
14
- logger.info({ owner: wallet.address, contract: await contract.getAddress() }, 'creating claim');
15
- const arg = await requestClaimCreation();
16
- logger.info({
17
- index: arg.taskIndex,
18
- operators: arg.task.operators.length,
19
- }, 'task created, collecting claim signatures...');
20
- onStep?.({ type: 'taskCreated', data: arg });
21
- const responses = [];
22
- const timestampS = +arg.task.createdAt.toString();
23
- for (const op of arg.task.operators) {
24
- const res = await createClaimOnAttestor({
25
- ...opts,
26
- client: { url: op.url },
27
- timestampS,
28
- onStep: (step) => (onStep?.({
29
- type: 'attestorStep',
30
- data: {
31
- operatorAddress: op.addr,
32
- step,
33
- },
34
- })),
35
- logger: logger.child({ operator: op.addr }),
36
- });
37
- const signature = res.signatures?.claimSignature;
38
- if (!signature) {
39
- throw new Error('INTERNAL: Claim signature not generated');
40
- }
41
- const diff = getClaimRequestDifference(res.request?.data, res.claim);
42
- if (diff) {
43
- throw new AttestorError('ERROR_INVALID_CLAIM', `Claim request does not match the claim res data: ${diff}`, {
44
- diff,
45
- request: res.request?.data?.[diff],
46
- claim: res.claim?.[diff]
47
- });
48
- }
49
- responses.push(res);
50
- logger.info({ operator: op.addr }, 'signature generated');
51
- onStep?.({
52
- type: 'attestorDone',
53
- data: {
54
- task: arg,
55
- responsesDone: responses,
56
- },
57
- });
58
- }
59
- const rslt = await completeTask();
60
- logger.info({ tx: rslt.txHash, task: arg.taskIndex }, 'claim submitted & validated');
61
- return { ...rslt, claimData: responses[0].claim };
62
- async function requestClaimCreation() {
63
- const request = {
64
- provider: name,
65
- // blank for now -- till we figure out the right
66
- // algorithm for this
67
- claimUserId: EMPTY_CLAIM_USER_ID,
68
- claimHash: getIdentifierFromClaimInfo({
69
- provider: name,
70
- parameters: canonicalStringify(params),
71
- context: context
72
- ? canonicalStringify(context)
73
- : '',
74
- }),
75
- owner: wallet.address,
76
- requestedAt: unixTimestampSeconds()
77
- };
78
- if (!payer) {
79
- const payerWallet = new Wallet(ownerPrivateKey, provider);
80
- const { task } = await createNewClaimRequestOnChain({
81
- request,
82
- payer: payerWallet,
83
- owner: payerWallet,
84
- chainId
85
- });
86
- return task;
87
- }
88
- const requestSignature = await signClaimRequest(request, wallet, chainId);
89
- const client = getAttestorClientFromPool(payer.attestor);
90
- await client.waitForInit();
91
- const rslt = await client.rpc('createClaimOnChain', {
92
- chainId: +chainId,
93
- jsonCreateClaimRequest: JSON.stringify(request),
94
- requestSignature
95
- });
96
- return JSON.parse(rslt.jsonTask);
97
- }
98
- async function completeTask() {
99
- const data = {
100
- task: arg.task,
101
- signatures: responses
102
- .map(res => (hexlify(res.signatures?.claimSignature))),
103
- };
104
- if (!payer) {
105
- const tx = await contract.taskCompleted(data, arg.taskIndex);
106
- const rslt = await tx.wait();
107
- // check task created event was emitted
108
- const logs = rslt?.logs ?? [];
109
- const eventLogs = logs.filter((log) => log instanceof EventLog);
110
- const ev = eventLogs[0];
111
- return {
112
- object: ev?.args,
113
- txHash: rslt.hash
114
- };
115
- }
116
- const client = getAttestorClientFromPool(payer.attestor);
117
- await client.waitForInit();
118
- const rslt = await client.rpc('completeClaimOnChain', {
119
- chainId: +chainId,
120
- taskIndex: Number(arg.taskIndex),
121
- completedTaskJson: JSON.stringify(data)
122
- });
123
- const object = JSON.parse(rslt.taskCompletedObjectJson);
124
- return { object, txHash: rslt.txHash };
125
- }
126
- }
127
- function getClaimRequestDifference(a, b) {
128
- if (a.provider !== b.provider) {
129
- return 'provider';
130
- }
131
- if (a.context !== b.context) {
132
- return 'context';
133
- }
134
- if (a.parameters !== b.parameters) {
135
- return 'parameters';
136
- }
137
- if (a.timestampS !== b.timestampS) {
138
- return 'timestampS';
139
- }
140
- }
package/lib/avs/config.js DELETED
@@ -1,20 +0,0 @@
1
- import { getEnvVariable } from "../utils/env.js";
2
- export const CHAIN_CONFIGS = {
3
- '31337': {
4
- rpcUrl: 'http://localhost:8545',
5
- contractAddress: '0x84eA74d481Ee0A5332c457a4d796187F6Ba67fEB',
6
- delegationManagerAddress: '0xCf7Ed3AccA5a467e9e704C703E8D87F634fB0Fc9',
7
- stakeRegistryAddress: '0x9E545E3C0baAB3E08CdfD552C960A1050f373042',
8
- avsDirectoryAddress: '0x5FC8d32690cc91D4c39d9d3abcBD16989F875707'
9
- },
10
- '17000': {
11
- rpcUrl: getEnvVariable('RPC_URL') || 'https://rpc.holesky.ethpandaops.io',
12
- contractAddress: '0x0861afc305999bfD3028dB66145395BdD7299366',
13
- delegationManagerAddress: '0xA44151489861Fe9e3055d95adC98FbD462B948e7',
14
- stakeRegistryAddress: '0xDa11C9Da04Ab02C4AF9374B27A5E727944D3E1dD',
15
- avsDirectoryAddress: '0x055733000064333CaDDbC92763c58BF0192fFeBf'
16
- }
17
- };
18
- export const PRIVATE_KEY = getEnvVariable('PRIVATE_KEY');
19
- export const SELECTED_CHAIN_ID = getEnvVariable('CHAIN_ID');
20
- export const RECLAIM_PUBLIC_URL = getEnvVariable('RECLAIM_PUBLIC_URL');
@@ -1 +0,0 @@
1
- export {};
@@ -1 +0,0 @@
1
- export {};