@reclaimprotocol/attestor-core 5.0.1-beta.28 → 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 (117) hide show
  1. package/lib/external-rpc/index.js +10400 -3
  2. package/lib/external-rpc/index.js.map +7 -0
  3. package/lib/index.js +8331 -11
  4. package/lib/index.js.map +7 -0
  5. package/package.json +2 -2
  6. package/lib/avs/abis/avsDirectoryABI.js +0 -340
  7. package/lib/avs/abis/delegationABI.js +0 -1
  8. package/lib/avs/abis/registryABI.js +0 -725
  9. package/lib/avs/client/create-claim-on-avs.js +0 -140
  10. package/lib/avs/config.js +0 -20
  11. package/lib/avs/contracts/ReclaimServiceManager.js +0 -1
  12. package/lib/avs/contracts/common.js +0 -1
  13. package/lib/avs/contracts/factories/ReclaimServiceManager__factory.js +0 -1166
  14. package/lib/avs/contracts/factories/index.js +0 -4
  15. package/lib/avs/contracts/index.js +0 -2
  16. package/lib/avs/types/index.js +0 -1
  17. package/lib/avs/utils/contracts.js +0 -33
  18. package/lib/avs/utils/register.js +0 -79
  19. package/lib/avs/utils/tasks.js +0 -41
  20. package/lib/client/create-claim.js +0 -432
  21. package/lib/client/index.js +0 -3
  22. package/lib/client/tunnels/make-rpc-tcp-tunnel.js +0 -51
  23. package/lib/client/tunnels/make-rpc-tls-tunnel.js +0 -131
  24. package/lib/client/utils/attestor-pool.js +0 -25
  25. package/lib/client/utils/client-socket.js +0 -97
  26. package/lib/client/utils/message-handler.js +0 -87
  27. package/lib/config/index.js +0 -44
  28. package/lib/external-rpc/benchmark.js +0 -69
  29. package/lib/external-rpc/event-bus.js +0 -14
  30. package/lib/external-rpc/handle-incoming-msg.js +0 -232
  31. package/lib/external-rpc/jsc-polyfills/1.js +0 -82
  32. package/lib/external-rpc/jsc-polyfills/2.js +0 -20
  33. package/lib/external-rpc/jsc-polyfills/event.js +0 -14
  34. package/lib/external-rpc/jsc-polyfills/index.js +0 -2
  35. package/lib/external-rpc/jsc-polyfills/ws.js +0 -81
  36. package/lib/external-rpc/setup-browser.js +0 -33
  37. package/lib/external-rpc/setup-jsc.js +0 -22
  38. package/lib/external-rpc/types.js +0 -1
  39. package/lib/external-rpc/utils.js +0 -100
  40. package/lib/external-rpc/zk.js +0 -63
  41. package/lib/mechain/abis/governanceABI.js +0 -458
  42. package/lib/mechain/abis/taskABI.js +0 -509
  43. package/lib/mechain/client/create-claim-on-mechain.js +0 -28
  44. package/lib/mechain/client/index.js +0 -1
  45. package/lib/mechain/constants/index.js +0 -3
  46. package/lib/mechain/index.js +0 -2
  47. package/lib/mechain/types/index.js +0 -1
  48. package/lib/proto/api.js +0 -4363
  49. package/lib/proto/tee-bundle.js +0 -1316
  50. package/lib/providers/http/index.js +0 -653
  51. package/lib/providers/http/patch-parse5-tree.js +0 -32
  52. package/lib/providers/http/utils.js +0 -324
  53. package/lib/providers/index.js +0 -4
  54. package/lib/server/create-server.js +0 -103
  55. package/lib/server/handlers/claimTeeBundle.js +0 -252
  56. package/lib/server/handlers/claimTunnel.js +0 -73
  57. package/lib/server/handlers/completeClaimOnChain.js +0 -24
  58. package/lib/server/handlers/createClaimOnChain.js +0 -26
  59. package/lib/server/handlers/createTaskOnMechain.js +0 -47
  60. package/lib/server/handlers/createTunnel.js +0 -93
  61. package/lib/server/handlers/disconnectTunnel.js +0 -5
  62. package/lib/server/handlers/fetchCertificateBytes.js +0 -41
  63. package/lib/server/handlers/index.js +0 -22
  64. package/lib/server/handlers/init.js +0 -32
  65. package/lib/server/handlers/toprf.js +0 -16
  66. package/lib/server/index.js +0 -4
  67. package/lib/server/socket.js +0 -109
  68. package/lib/server/tunnels/make-tcp-tunnel.js +0 -177
  69. package/lib/server/utils/apm.js +0 -36
  70. package/lib/server/utils/assert-valid-claim-request.js +0 -325
  71. package/lib/server/utils/config-env.js +0 -4
  72. package/lib/server/utils/dns.js +0 -18
  73. package/lib/server/utils/gcp-attestation.js +0 -289
  74. package/lib/server/utils/generics.js +0 -51
  75. package/lib/server/utils/iso.js +0 -256
  76. package/lib/server/utils/keep-alive.js +0 -38
  77. package/lib/server/utils/nitro-attestation.js +0 -324
  78. package/lib/server/utils/oprf-raw.js +0 -54
  79. package/lib/server/utils/process-handshake.js +0 -215
  80. package/lib/server/utils/proxy-session.js +0 -6
  81. package/lib/server/utils/tee-oprf-mpc-verification.js +0 -90
  82. package/lib/server/utils/tee-oprf-verification.js +0 -174
  83. package/lib/server/utils/tee-transcript-reconstruction.js +0 -187
  84. package/lib/server/utils/tee-verification.js +0 -421
  85. package/lib/server/utils/validation.js +0 -38
  86. package/lib/tls-exports.js +0 -5
  87. package/lib/types/bgp.js +0 -1
  88. package/lib/types/claims.js +0 -1
  89. package/lib/types/client.js +0 -1
  90. package/lib/types/general.js +0 -1
  91. package/lib/types/handlers.js +0 -1
  92. package/lib/types/index.js +0 -10
  93. package/lib/types/providers.gen.js +0 -10
  94. package/lib/types/providers.js +0 -1
  95. package/lib/types/rpc.js +0 -1
  96. package/lib/types/signatures.js +0 -1
  97. package/lib/types/tunnel.js +0 -1
  98. package/lib/types/zk.js +0 -1
  99. package/lib/utils/auth.js +0 -59
  100. package/lib/utils/b64-json.js +0 -17
  101. package/lib/utils/bgp-listener.js +0 -119
  102. package/lib/utils/claims.js +0 -98
  103. package/lib/utils/env.js +0 -15
  104. package/lib/utils/error.js +0 -50
  105. package/lib/utils/generics.js +0 -317
  106. package/lib/utils/http-parser.js +0 -246
  107. package/lib/utils/index.js +0 -13
  108. package/lib/utils/logger.js +0 -91
  109. package/lib/utils/prepare-packets.js +0 -71
  110. package/lib/utils/redactions.js +0 -177
  111. package/lib/utils/retries.js +0 -24
  112. package/lib/utils/signatures/eth.js +0 -32
  113. package/lib/utils/signatures/index.js +0 -7
  114. package/lib/utils/socket-base.js +0 -92
  115. package/lib/utils/tls.js +0 -58
  116. package/lib/utils/ws.js +0 -22
  117. 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 {};