@reclaimprotocol/attestor-core 5.0.3 → 5.0.4

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 (122) hide show
  1. package/LICENSE +660 -660
  2. package/browser/resources/attestor-browser.min.mjs +31 -31
  3. package/lib/avs/abis/avsDirectoryABI.js +340 -0
  4. package/lib/avs/abis/delegationABI.js +1 -0
  5. package/lib/avs/abis/registryABI.js +725 -0
  6. package/lib/avs/client/create-claim-on-avs.js +138 -0
  7. package/lib/avs/config.js +20 -0
  8. package/lib/avs/contracts/ReclaimServiceManager.js +1 -0
  9. package/lib/avs/contracts/common.js +1 -0
  10. package/lib/avs/contracts/factories/ReclaimServiceManager__factory.js +1169 -0
  11. package/lib/avs/contracts/factories/index.js +4 -0
  12. package/lib/avs/contracts/index.js +2 -0
  13. package/lib/avs/types/index.js +1 -0
  14. package/lib/avs/utils/contracts.js +33 -0
  15. package/lib/avs/utils/register.js +78 -0
  16. package/lib/avs/utils/tasks.js +40 -0
  17. package/lib/client/create-claim.js +433 -0
  18. package/lib/client/index.js +3 -0
  19. package/lib/client/tunnels/make-rpc-tcp-tunnel.js +51 -0
  20. package/lib/client/tunnels/make-rpc-tls-tunnel.js +131 -0
  21. package/lib/client/utils/attestor-pool.js +25 -0
  22. package/lib/client/utils/client-socket.js +98 -0
  23. package/lib/client/utils/message-handler.js +87 -0
  24. package/lib/config/index.d.ts +2 -2
  25. package/lib/config/index.js +44 -0
  26. package/lib/external-rpc/benchmark.js +69 -0
  27. package/lib/external-rpc/event-bus.js +14 -0
  28. package/lib/external-rpc/handle-incoming-msg.js +233 -0
  29. package/lib/external-rpc/index.js +101 -54
  30. package/lib/external-rpc/jsc-polyfills/1.js +82 -0
  31. package/lib/external-rpc/jsc-polyfills/2.js +20 -0
  32. package/lib/external-rpc/jsc-polyfills/event.js +14 -0
  33. package/lib/external-rpc/jsc-polyfills/index.js +2 -0
  34. package/lib/external-rpc/jsc-polyfills/ws.js +81 -0
  35. package/lib/external-rpc/setup-browser.js +33 -0
  36. package/lib/external-rpc/setup-jsc.js +22 -0
  37. package/lib/external-rpc/types.js +1 -0
  38. package/lib/external-rpc/utils.js +100 -0
  39. package/lib/external-rpc/zk.js +63 -0
  40. package/lib/index.js +121 -72
  41. package/lib/mechain/abis/governanceABI.js +458 -0
  42. package/lib/mechain/abis/taskABI.js +509 -0
  43. package/lib/mechain/client/create-claim-on-mechain.js +28 -0
  44. package/lib/mechain/client/index.js +1 -0
  45. package/lib/mechain/constants/index.js +3 -0
  46. package/lib/mechain/index.js +2 -0
  47. package/lib/mechain/types/index.js +1 -0
  48. package/lib/proto/api.d.ts +2 -0
  49. package/lib/proto/api.js +4273 -0
  50. package/lib/proto/tee-bundle.js +1316 -0
  51. package/lib/providers/http/index.js +658 -0
  52. package/lib/providers/http/patch-parse5-tree.js +33 -0
  53. package/lib/providers/http/utils.js +324 -0
  54. package/lib/providers/index.js +4 -0
  55. package/lib/scripts/fetch-ec2-metadata.d.ts +1 -0
  56. package/lib/server/create-server.js +103 -0
  57. package/lib/server/handlers/claimTeeBundle.js +252 -0
  58. package/lib/server/handlers/claimTunnel.js +73 -0
  59. package/lib/server/handlers/completeClaimOnChain.js +22 -0
  60. package/lib/server/handlers/createClaimOnChain.js +26 -0
  61. package/lib/server/handlers/createTaskOnMechain.js +47 -0
  62. package/lib/server/handlers/createTunnel.js +93 -0
  63. package/lib/server/handlers/disconnectTunnel.js +5 -0
  64. package/lib/server/handlers/fetchCertificateBytes.js +41 -0
  65. package/lib/server/handlers/index.js +22 -0
  66. package/lib/server/handlers/init.js +32 -0
  67. package/lib/server/handlers/toprf.js +16 -0
  68. package/lib/server/index.js +4 -0
  69. package/lib/server/socket.js +109 -0
  70. package/lib/server/tunnels/make-tcp-tunnel.js +177 -0
  71. package/lib/server/utils/apm.js +36 -0
  72. package/lib/server/utils/assert-valid-claim-request.d.ts +1 -1
  73. package/lib/server/utils/assert-valid-claim-request.js +204 -0
  74. package/lib/server/utils/config-env.js +4 -0
  75. package/lib/server/utils/dns.js +18 -0
  76. package/lib/server/utils/gcp-attestation.js +289 -0
  77. package/lib/server/utils/generics.d.ts +1 -0
  78. package/lib/server/utils/generics.js +51 -0
  79. package/lib/server/utils/iso.js +256 -0
  80. package/lib/server/utils/keep-alive.js +38 -0
  81. package/lib/server/utils/nitro-attestation.js +325 -0
  82. package/lib/server/utils/process-handshake.js +215 -0
  83. package/lib/server/utils/proxy-session.js +6 -0
  84. package/lib/server/utils/tee-oprf-mpc-verification.js +90 -0
  85. package/lib/server/utils/tee-oprf-verification.js +174 -0
  86. package/lib/server/utils/tee-transcript-reconstruction.js +187 -0
  87. package/lib/server/utils/tee-verification.js +421 -0
  88. package/lib/server/utils/validation.js +38 -0
  89. package/lib/types/bgp.js +1 -0
  90. package/lib/types/claims.js +1 -0
  91. package/lib/types/client.js +1 -0
  92. package/lib/types/general.js +1 -0
  93. package/lib/types/handlers.js +1 -0
  94. package/lib/types/index.js +10 -0
  95. package/lib/types/providers.d.ts +1 -0
  96. package/lib/types/providers.gen.js +10 -0
  97. package/lib/types/providers.js +1 -0
  98. package/lib/types/rpc.js +1 -0
  99. package/lib/types/signatures.js +1 -0
  100. package/lib/types/tunnel.js +1 -0
  101. package/lib/types/zk.js +1 -0
  102. package/lib/utils/auth.js +59 -0
  103. package/lib/utils/b64-json.js +17 -0
  104. package/lib/utils/bgp-listener.js +119 -0
  105. package/lib/utils/claims.js +99 -0
  106. package/lib/utils/env.js +15 -0
  107. package/lib/utils/error.js +50 -0
  108. package/lib/utils/generics.js +317 -0
  109. package/lib/utils/http-parser.d.ts +2 -1
  110. package/lib/utils/http-parser.js +246 -0
  111. package/lib/utils/index.js +13 -0
  112. package/lib/utils/logger.js +91 -0
  113. package/lib/utils/prepare-packets.js +62 -0
  114. package/lib/utils/redactions.js +148 -0
  115. package/lib/utils/retries.js +24 -0
  116. package/lib/utils/signatures/eth.js +29 -0
  117. package/lib/utils/signatures/index.js +7 -0
  118. package/lib/utils/socket-base.js +90 -0
  119. package/lib/utils/tls.js +58 -0
  120. package/lib/utils/ws.js +22 -0
  121. package/lib/utils/zk.js +577 -0
  122. package/package.json +3 -2
@@ -0,0 +1,138 @@
1
+ import { ethers, 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 = ethers.utils.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 } = initialiseContracts(CHAIN_CONFIGS[chainId], ownerPrivateKey);
14
+ logger.info({ owner: wallet.address, contract: contract.address }, '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 wallet = new Wallet(ownerPrivateKey, contract.provider);
80
+ const { task } = await createNewClaimRequestOnChain({
81
+ request,
82
+ payer: wallet,
83
+ owner: wallet,
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 => (ethers.utils.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 ev = rslt.events?.[0];
109
+ return {
110
+ object: ev?.args,
111
+ txHash: rslt.transactionHash
112
+ };
113
+ }
114
+ const client = getAttestorClientFromPool(payer.attestor);
115
+ await client.waitForInit();
116
+ const rslt = await client.rpc('completeClaimOnChain', {
117
+ chainId: +chainId,
118
+ taskIndex: arg.taskIndex,
119
+ completedTaskJson: JSON.stringify(data)
120
+ });
121
+ const object = JSON.parse(rslt.taskCompletedObjectJson);
122
+ return { object, txHash: rslt.txHash };
123
+ }
124
+ }
125
+ function getClaimRequestDifference(a, b) {
126
+ if (a.provider !== b.provider) {
127
+ return 'provider';
128
+ }
129
+ if (a.context !== b.context) {
130
+ return 'context';
131
+ }
132
+ if (a.parameters !== b.parameters) {
133
+ return 'parameters';
134
+ }
135
+ if (a.timestampS !== b.timestampS) {
136
+ return 'timestampS';
137
+ }
138
+ }
@@ -0,0 +1,20 @@
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');
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};