@reclaimprotocol/attestor-core 5.0.1-beta.9 → 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.
- package/browser/resources/attestor-browser.min.mjs +4512 -0
- package/lib/client/tunnels/make-rpc-tls-tunnel.d.ts +1 -1
- package/lib/external-rpc/index.js +10399 -3
- package/lib/index.js +8323 -10
- package/lib/server/utils/proxy-session.d.ts +1 -1
- package/lib/types/general.d.ts +0 -1
- package/lib/utils/generics.d.ts +1 -6
- package/lib/utils/index.d.ts +0 -1
- package/package.json +8 -10
- package/lib/avs/abis/avsDirectoryABI.js +0 -343
- package/lib/avs/abis/delegationABI.js +0 -4
- package/lib/avs/abis/registryABI.js +0 -728
- package/lib/avs/client/create-claim-on-avs.js +0 -168
- package/lib/avs/config.js +0 -26
- package/lib/avs/contracts/ReclaimServiceManager.js +0 -0
- package/lib/avs/contracts/common.js +0 -0
- package/lib/avs/contracts/factories/ReclaimServiceManager__factory.js +0 -1183
- package/lib/avs/contracts/factories/index.js +0 -4
- package/lib/avs/contracts/index.js +0 -6
- package/lib/avs/types/index.js +0 -0
- package/lib/avs/utils/contracts.js +0 -53
- package/lib/avs/utils/register.js +0 -74
- package/lib/avs/utils/tasks.js +0 -48
- package/lib/browser/avs/abis/avsDirectoryABI.d.ts +0 -60
- package/lib/browser/avs/abis/avsDirectoryABI.js +0 -343
- package/lib/browser/avs/abis/delegationABI.d.ts +0 -126
- package/lib/browser/avs/abis/delegationABI.js +0 -4
- package/lib/browser/avs/abis/registryABI.d.ts +0 -136
- package/lib/browser/avs/abis/registryABI.js +0 -728
- package/lib/browser/avs/client/create-claim-on-avs.d.ts +0 -12
- package/lib/browser/avs/client/create-claim-on-avs.js +0 -168
- package/lib/browser/avs/config.d.ts +0 -7
- package/lib/browser/avs/config.js +0 -26
- package/lib/browser/avs/contracts/ReclaimServiceManager.d.ts +0 -601
- package/lib/browser/avs/contracts/ReclaimServiceManager.js +0 -0
- package/lib/browser/avs/contracts/common.d.ts +0 -50
- package/lib/browser/avs/contracts/common.js +0 -0
- package/lib/browser/avs/contracts/factories/ReclaimServiceManager__factory.d.ts +0 -890
- package/lib/browser/avs/contracts/factories/ReclaimServiceManager__factory.js +0 -1183
- package/lib/browser/avs/contracts/factories/index.d.ts +0 -1
- package/lib/browser/avs/contracts/factories/index.js +0 -4
- package/lib/browser/avs/contracts/index.d.ts +0 -3
- package/lib/browser/avs/contracts/index.js +0 -6
- package/lib/browser/avs/types/index.d.ts +0 -55
- package/lib/browser/avs/types/index.js +0 -0
- package/lib/browser/avs/utils/contracts.d.ts +0 -21
- package/lib/browser/avs/utils/contracts.js +0 -53
- package/lib/browser/avs/utils/register.d.ts +0 -27
- package/lib/browser/avs/utils/register.js +0 -74
- package/lib/browser/avs/utils/tasks.d.ts +0 -22
- package/lib/browser/avs/utils/tasks.js +0 -48
- package/lib/browser/client/create-claim.d.ts +0 -5
- package/lib/browser/client/create-claim.js +0 -461
- package/lib/browser/client/index.d.ts +0 -3
- package/lib/browser/client/index.js +0 -3
- package/lib/browser/client/tunnels/make-rpc-tcp-tunnel.d.ts +0 -16
- package/lib/browser/client/tunnels/make-rpc-tcp-tunnel.js +0 -53
- package/lib/browser/client/tunnels/make-rpc-tls-tunnel.d.ts +0 -26
- package/lib/browser/client/tunnels/make-rpc-tls-tunnel.js +0 -127
- package/lib/browser/client/utils/attestor-pool.d.ts +0 -8
- package/lib/browser/client/utils/attestor-pool.js +0 -24
- package/lib/browser/client/utils/client-socket.d.ts +0 -11
- package/lib/browser/client/utils/client-socket.js +0 -120
- package/lib/browser/client/utils/message-handler.d.ts +0 -4
- package/lib/browser/client/utils/message-handler.js +0 -97
- package/lib/browser/config/index.d.ts +0 -31
- package/lib/browser/config/index.js +0 -62
- package/lib/browser/external-rpc/benchmark.d.ts +0 -1
- package/lib/browser/external-rpc/benchmark.js +0 -82
- package/lib/browser/external-rpc/event-bus.d.ts +0 -7
- package/lib/browser/external-rpc/event-bus.js +0 -17
- package/lib/browser/external-rpc/global.d.js +0 -0
- package/lib/browser/external-rpc/handle-incoming-msg.d.ts +0 -2
- package/lib/browser/external-rpc/handle-incoming-msg.js +0 -241
- package/lib/browser/external-rpc/index.d.ts +0 -3
- package/lib/browser/external-rpc/index.js +0 -3
- package/lib/browser/external-rpc/jsc-polyfills/1.d.ts +0 -14
- package/lib/browser/external-rpc/jsc-polyfills/1.js +0 -80
- package/lib/browser/external-rpc/jsc-polyfills/2.d.ts +0 -1
- package/lib/browser/external-rpc/jsc-polyfills/2.js +0 -15
- package/lib/browser/external-rpc/jsc-polyfills/event.d.ts +0 -10
- package/lib/browser/external-rpc/jsc-polyfills/event.js +0 -19
- package/lib/browser/external-rpc/jsc-polyfills/index.d.ts +0 -2
- package/lib/browser/external-rpc/jsc-polyfills/index.js +0 -2
- package/lib/browser/external-rpc/jsc-polyfills/ws.d.ts +0 -21
- package/lib/browser/external-rpc/jsc-polyfills/ws.js +0 -83
- package/lib/browser/external-rpc/setup-browser.d.ts +0 -6
- package/lib/browser/external-rpc/setup-browser.js +0 -33
- package/lib/browser/external-rpc/setup-jsc.d.ts +0 -24
- package/lib/browser/external-rpc/setup-jsc.js +0 -22
- package/lib/browser/external-rpc/types.d.ts +0 -213
- package/lib/browser/external-rpc/types.js +0 -0
- package/lib/browser/external-rpc/utils.d.ts +0 -20
- package/lib/browser/external-rpc/utils.js +0 -100
- package/lib/browser/external-rpc/zk.d.ts +0 -14
- package/lib/browser/external-rpc/zk.js +0 -58
- package/lib/browser/index.browser.js +0 -13
- package/lib/browser/index.d.ts +0 -9
- package/lib/browser/index.js +0 -13
- package/lib/browser/mechain/abis/governanceABI.d.ts +0 -50
- package/lib/browser/mechain/abis/governanceABI.js +0 -461
- package/lib/browser/mechain/abis/taskABI.d.ts +0 -157
- package/lib/browser/mechain/abis/taskABI.js +0 -512
- package/lib/browser/mechain/client/create-claim-on-mechain.d.ts +0 -10
- package/lib/browser/mechain/client/create-claim-on-mechain.js +0 -33
- package/lib/browser/mechain/client/index.d.ts +0 -1
- package/lib/browser/mechain/client/index.js +0 -1
- package/lib/browser/mechain/constants/index.d.ts +0 -3
- package/lib/browser/mechain/constants/index.js +0 -8
- package/lib/browser/mechain/index.d.ts +0 -2
- package/lib/browser/mechain/index.js +0 -2
- package/lib/browser/mechain/types/index.d.ts +0 -23
- package/lib/browser/mechain/types/index.js +0 -0
- package/lib/browser/proto/api.d.ts +0 -651
- package/lib/browser/proto/api.js +0 -4250
- package/lib/browser/proto/tee-bundle.d.ts +0 -156
- package/lib/browser/proto/tee-bundle.js +0 -1296
- package/lib/browser/providers/http/index.d.ts +0 -18
- package/lib/browser/providers/http/index.js +0 -640
- package/lib/browser/providers/http/patch-parse5-tree.d.ts +0 -6
- package/lib/browser/providers/http/patch-parse5-tree.js +0 -34
- package/lib/browser/providers/http/utils.d.ts +0 -77
- package/lib/browser/providers/http/utils.js +0 -283
- package/lib/browser/providers/index.d.ts +0 -4
- package/lib/browser/providers/index.js +0 -7
- package/lib/browser/types/bgp.d.ts +0 -11
- package/lib/browser/types/bgp.js +0 -0
- package/lib/browser/types/claims.d.ts +0 -70
- package/lib/browser/types/claims.js +0 -0
- package/lib/browser/types/client.d.ts +0 -163
- package/lib/browser/types/client.js +0 -0
- package/lib/browser/types/general.d.ts +0 -77
- package/lib/browser/types/general.js +0 -0
- package/lib/browser/types/handlers.d.ts +0 -10
- package/lib/browser/types/handlers.js +0 -0
- package/lib/browser/types/index.d.ts +0 -10
- package/lib/browser/types/index.js +0 -10
- package/lib/browser/types/providers.d.ts +0 -161
- package/lib/browser/types/providers.gen.d.ts +0 -443
- package/lib/browser/types/providers.gen.js +0 -16
- package/lib/browser/types/providers.js +0 -0
- package/lib/browser/types/rpc.d.ts +0 -35
- package/lib/browser/types/rpc.js +0 -0
- package/lib/browser/types/signatures.d.ts +0 -28
- package/lib/browser/types/signatures.js +0 -0
- package/lib/browser/types/tunnel.d.ts +0 -18
- package/lib/browser/types/tunnel.js +0 -0
- package/lib/browser/types/zk.d.ts +0 -38
- package/lib/browser/types/zk.js +0 -0
- package/lib/browser/utils/auth.d.ts +0 -8
- package/lib/browser/utils/auth.js +0 -71
- package/lib/browser/utils/b64-json.d.ts +0 -2
- package/lib/browser/utils/b64-json.js +0 -17
- package/lib/browser/utils/claims.d.ts +0 -33
- package/lib/browser/utils/claims.js +0 -89
- package/lib/browser/utils/env.d.ts +0 -3
- package/lib/browser/utils/env.js +0 -19
- package/lib/browser/utils/error.d.ts +0 -26
- package/lib/browser/utils/error.js +0 -54
- package/lib/browser/utils/generics.d.ts +0 -119
- package/lib/browser/utils/generics.js +0 -272
- package/lib/browser/utils/http-parser.d.ts +0 -59
- package/lib/browser/utils/http-parser.js +0 -201
- package/lib/browser/utils/index.browser.js +0 -13
- package/lib/browser/utils/index.d.ts +0 -13
- package/lib/browser/utils/index.js +0 -13
- package/lib/browser/utils/logger.browser.js +0 -88
- package/lib/browser/utils/logger.d.ts +0 -14
- package/lib/browser/utils/logger.js +0 -88
- package/lib/browser/utils/prepare-packets.d.ts +0 -16
- package/lib/browser/utils/prepare-packets.js +0 -69
- package/lib/browser/utils/redactions.d.ts +0 -73
- package/lib/browser/utils/redactions.js +0 -135
- package/lib/browser/utils/retries.d.ts +0 -12
- package/lib/browser/utils/retries.js +0 -26
- package/lib/browser/utils/signatures/eth.d.ts +0 -2
- package/lib/browser/utils/signatures/eth.js +0 -31
- package/lib/browser/utils/signatures/index.d.ts +0 -5
- package/lib/browser/utils/signatures/index.js +0 -12
- package/lib/browser/utils/socket-base.d.ts +0 -23
- package/lib/browser/utils/socket-base.js +0 -96
- package/lib/browser/utils/tls-imports.d.ts +0 -21
- package/lib/browser/utils/tls-imports.js +0 -71
- package/lib/browser/utils/tls.d.ts +0 -2
- package/lib/browser/utils/tls.js +0 -58
- package/lib/browser/utils/ws.d.ts +0 -7
- package/lib/browser/utils/ws.js +0 -22
- package/lib/browser/utils/zk.d.ts +0 -71
- package/lib/browser/utils/zk.js +0 -625
- package/lib/client/create-claim.js +0 -461
- package/lib/client/index.js +0 -3
- package/lib/client/tunnels/make-rpc-tcp-tunnel.js +0 -53
- package/lib/client/tunnels/make-rpc-tls-tunnel.js +0 -127
- package/lib/client/utils/attestor-pool.js +0 -24
- package/lib/client/utils/client-socket.js +0 -120
- package/lib/client/utils/message-handler.js +0 -97
- package/lib/config/index.js +0 -62
- package/lib/external-rpc/benchmark.js +0 -82
- package/lib/external-rpc/event-bus.js +0 -17
- package/lib/external-rpc/global.d.js +0 -0
- package/lib/external-rpc/handle-incoming-msg.js +0 -241
- package/lib/external-rpc/jsc-polyfills/1.js +0 -80
- package/lib/external-rpc/jsc-polyfills/2.js +0 -15
- package/lib/external-rpc/jsc-polyfills/event.js +0 -19
- package/lib/external-rpc/jsc-polyfills/index.js +0 -2
- package/lib/external-rpc/jsc-polyfills/ws.js +0 -83
- package/lib/external-rpc/setup-browser.js +0 -33
- package/lib/external-rpc/setup-jsc.js +0 -22
- package/lib/external-rpc/types.js +0 -0
- package/lib/external-rpc/utils.js +0 -100
- package/lib/external-rpc/zk.js +0 -58
- package/lib/index.browser.d.ts +0 -9
- package/lib/mechain/abis/governanceABI.js +0 -461
- package/lib/mechain/abis/taskABI.js +0 -512
- package/lib/mechain/client/create-claim-on-mechain.js +0 -33
- package/lib/mechain/client/index.js +0 -1
- package/lib/mechain/constants/index.js +0 -8
- package/lib/mechain/index.js +0 -2
- package/lib/mechain/types/index.js +0 -0
- package/lib/proto/api.js +0 -4250
- package/lib/proto/tee-bundle.js +0 -1296
- package/lib/providers/http/index.js +0 -640
- package/lib/providers/http/patch-parse5-tree.js +0 -34
- package/lib/providers/http/utils.js +0 -283
- package/lib/providers/index.js +0 -7
- package/lib/scripts/check-avs-registration.js +0 -28
- package/lib/scripts/fallbacks/crypto.js +0 -4
- package/lib/scripts/fallbacks/empty.js +0 -4
- package/lib/scripts/fallbacks/re2.js +0 -7
- package/lib/scripts/fallbacks/snarkjs.js +0 -10
- package/lib/scripts/fallbacks/stwo.js +0 -159
- package/lib/scripts/generate-provider-types.js +0 -101
- package/lib/scripts/generate-receipt.js +0 -101
- package/lib/scripts/generate-toprf-keys.js +0 -24
- package/lib/scripts/jsc-cli-rpc.js +0 -35
- package/lib/scripts/register-avs-operator.js +0 -3
- package/lib/scripts/start-server.js +0 -11
- package/lib/scripts/update-avs-metadata.js +0 -20
- package/lib/scripts/utils.js +0 -10
- package/lib/scripts/whitelist-operator.js +0 -16
- package/lib/server/create-server.js +0 -105
- package/lib/server/handlers/claimTeeBundle.js +0 -232
- package/lib/server/handlers/claimTunnel.js +0 -80
- package/lib/server/handlers/completeClaimOnChain.js +0 -29
- package/lib/server/handlers/createClaimOnChain.js +0 -32
- package/lib/server/handlers/createTaskOnMechain.js +0 -57
- package/lib/server/handlers/createTunnel.js +0 -98
- package/lib/server/handlers/disconnectTunnel.js +0 -8
- package/lib/server/handlers/fetchCertificateBytes.js +0 -57
- package/lib/server/handlers/index.js +0 -25
- package/lib/server/handlers/init.js +0 -33
- package/lib/server/handlers/toprf.js +0 -19
- package/lib/server/index.js +0 -4
- package/lib/server/socket.js +0 -112
- package/lib/server/tunnels/make-tcp-tunnel.js +0 -202
- package/lib/server/utils/apm.js +0 -29
- package/lib/server/utils/assert-valid-claim-request.js +0 -354
- package/lib/server/utils/config-env.js +0 -4
- package/lib/server/utils/dns.js +0 -24
- package/lib/server/utils/gcp-attestation.js +0 -237
- package/lib/server/utils/generics.js +0 -45
- package/lib/server/utils/iso.js +0 -259
- package/lib/server/utils/keep-alive.js +0 -38
- package/lib/server/utils/nitro-attestation.js +0 -249
- package/lib/server/utils/oprf-raw.js +0 -61
- package/lib/server/utils/process-handshake.js +0 -233
- package/lib/server/utils/proxy-session.js +0 -4
- package/lib/server/utils/tee-oprf-mpc-verification.js +0 -86
- package/lib/server/utils/tee-oprf-verification.js +0 -151
- package/lib/server/utils/tee-transcript-reconstruction.js +0 -140
- package/lib/server/utils/tee-verification.js +0 -358
- package/lib/server/utils/validation.js +0 -45
- package/lib/types/bgp.js +0 -0
- package/lib/types/claims.js +0 -0
- package/lib/types/client.js +0 -0
- package/lib/types/general.js +0 -0
- package/lib/types/handlers.js +0 -0
- package/lib/types/index.js +0 -10
- package/lib/types/providers.gen.js +0 -16
- package/lib/types/providers.js +0 -0
- package/lib/types/rpc.js +0 -0
- package/lib/types/signatures.js +0 -0
- package/lib/types/tunnel.js +0 -0
- package/lib/types/zk.js +0 -0
- package/lib/utils/auth.js +0 -71
- package/lib/utils/b64-json.js +0 -17
- package/lib/utils/bgp-listener.js +0 -123
- package/lib/utils/claims.js +0 -89
- package/lib/utils/env.js +0 -19
- package/lib/utils/error.js +0 -54
- package/lib/utils/generics.js +0 -272
- package/lib/utils/http-parser.js +0 -201
- package/lib/utils/index.browser.d.ts +0 -13
- package/lib/utils/index.js +0 -14
- package/lib/utils/logger.browser.d.ts +0 -14
- package/lib/utils/logger.js +0 -82
- package/lib/utils/prepare-packets.js +0 -69
- package/lib/utils/redactions.js +0 -135
- package/lib/utils/retries.js +0 -26
- package/lib/utils/signatures/eth.js +0 -31
- package/lib/utils/signatures/index.js +0 -12
- package/lib/utils/socket-base.js +0 -96
- package/lib/utils/tls-imports.d.ts +0 -21
- package/lib/utils/tls-imports.js +0 -71
- package/lib/utils/tls.js +0 -58
- package/lib/utils/ws.js +0 -22
- package/lib/utils/zk.js +0 -625
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { ReclaimServiceManager__factory } from "./ReclaimServiceManager__factory.ts";
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import type { NewTaskCreatedEvent } from '#src/avs/contracts/ReclaimServiceManager.ts';
|
|
2
|
-
import type { createClaimOnAttestor } from '#src/client/index.ts';
|
|
3
|
-
import type { ClaimTunnelResponse } from '#src/proto/api.ts';
|
|
4
|
-
import type { CreateClaimOnAttestorOpts, ProofGenerationStep, ProviderName } from '#src/types/index.ts';
|
|
5
|
-
export type ChainConfig = {
|
|
6
|
-
rpcUrl: string;
|
|
7
|
-
/**
|
|
8
|
-
* Reclaim AVS contract address
|
|
9
|
-
*/
|
|
10
|
-
contractAddress: string;
|
|
11
|
-
delegationManagerAddress: string;
|
|
12
|
-
stakeRegistryAddress: string;
|
|
13
|
-
avsDirectoryAddress: string;
|
|
14
|
-
};
|
|
15
|
-
export type CreateClaimOnAvsStep = {
|
|
16
|
-
type: 'taskCreated';
|
|
17
|
-
data: NewTaskCreatedEvent.OutputObject;
|
|
18
|
-
} | {
|
|
19
|
-
type: 'attestorStep';
|
|
20
|
-
data: {
|
|
21
|
-
operatorAddress: string;
|
|
22
|
-
step: ProofGenerationStep;
|
|
23
|
-
};
|
|
24
|
-
} | {
|
|
25
|
-
type: 'attestorDone';
|
|
26
|
-
data: {
|
|
27
|
-
task: NewTaskCreatedEvent.OutputObject;
|
|
28
|
-
/**
|
|
29
|
-
* Index of the operator in the task
|
|
30
|
-
* that has finished the proof generation
|
|
31
|
-
*/
|
|
32
|
-
responsesDone: ClaimTunnelResponse[];
|
|
33
|
-
};
|
|
34
|
-
};
|
|
35
|
-
export type CreateClaimOnAvsOpts<N extends ProviderName> = (Omit<CreateClaimOnAttestorOpts<N>, 'onStep' | 'client'>) & {
|
|
36
|
-
/**
|
|
37
|
-
* Chain ID to use for the claim
|
|
38
|
-
* @default -- env variable CHAIN_ID
|
|
39
|
-
*/
|
|
40
|
-
chainId?: string;
|
|
41
|
-
/**
|
|
42
|
-
* Who will pay for the claim creation, including gas
|
|
43
|
-
* costs. Note: the attestor can choose to reject the
|
|
44
|
-
* claim if 'attestor' is chosen.
|
|
45
|
-
* @default undefined (owner of the claim)
|
|
46
|
-
*/
|
|
47
|
-
payer?: {
|
|
48
|
-
attestor: string;
|
|
49
|
-
};
|
|
50
|
-
onStep?(step: CreateClaimOnAvsStep): void;
|
|
51
|
-
/**
|
|
52
|
-
* Override the default createClaimOnAttestor function
|
|
53
|
-
*/
|
|
54
|
-
createClaimOnAttestor?: typeof createClaimOnAttestor;
|
|
55
|
-
};
|
|
File without changes
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Contract, JsonRpcProvider, Wallet } from 'ethers';
|
|
2
|
-
import type { ChainConfig } from '#src/avs/types/index.ts';
|
|
3
|
-
/**
|
|
4
|
-
* get the contracts for the given chain ID
|
|
5
|
-
*/
|
|
6
|
-
export declare function getContracts(chainId?: string): {
|
|
7
|
-
provider: JsonRpcProvider;
|
|
8
|
-
wallet: Wallet | undefined;
|
|
9
|
-
delegationManager: Contract;
|
|
10
|
-
contract: import("#src/avs/contracts/index.ts").ReclaimServiceManager;
|
|
11
|
-
registryContract: Contract;
|
|
12
|
-
avsDirectory: Contract;
|
|
13
|
-
};
|
|
14
|
-
export declare function initialiseContracts({ rpcUrl, stakeRegistryAddress, avsDirectoryAddress, contractAddress, delegationManagerAddress, }: ChainConfig, privateKey?: string | undefined): {
|
|
15
|
-
provider: JsonRpcProvider;
|
|
16
|
-
wallet: Wallet | undefined;
|
|
17
|
-
delegationManager: Contract;
|
|
18
|
-
contract: import("#src/avs/contracts/index.ts").ReclaimServiceManager;
|
|
19
|
-
registryContract: Contract;
|
|
20
|
-
avsDirectory: Contract;
|
|
21
|
-
};
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { Contract, JsonRpcProvider, Wallet } from "ethers";
|
|
2
|
-
import { avsDirectoryABI } from "../../avs/abis/avsDirectoryABI.js";
|
|
3
|
-
import { delegationABI } from "../../avs/abis/delegationABI.js";
|
|
4
|
-
import { registryABI } from "../../avs/abis/registryABI.js";
|
|
5
|
-
import { CHAIN_CONFIGS, PRIVATE_KEY, SELECTED_CHAIN_ID } from "../../avs/config.js";
|
|
6
|
-
import { ReclaimServiceManager__factory } from "../../avs/contracts/index.js";
|
|
7
|
-
const configs = {};
|
|
8
|
-
function getContracts(chainId = SELECTED_CHAIN_ID) {
|
|
9
|
-
const config = CHAIN_CONFIGS[chainId];
|
|
10
|
-
if (!config) {
|
|
11
|
-
throw new Error(`No config found for chain ID: ${chainId}`);
|
|
12
|
-
}
|
|
13
|
-
configs[chainId] ||= initialiseContracts(config);
|
|
14
|
-
return configs[chainId];
|
|
15
|
-
}
|
|
16
|
-
function initialiseContracts({
|
|
17
|
-
rpcUrl,
|
|
18
|
-
stakeRegistryAddress,
|
|
19
|
-
avsDirectoryAddress,
|
|
20
|
-
contractAddress,
|
|
21
|
-
delegationManagerAddress
|
|
22
|
-
}, privateKey = PRIVATE_KEY) {
|
|
23
|
-
const provider = new JsonRpcProvider(rpcUrl);
|
|
24
|
-
const wallet = privateKey ? new Wallet(privateKey, provider) : void 0;
|
|
25
|
-
return {
|
|
26
|
-
provider,
|
|
27
|
-
wallet,
|
|
28
|
-
delegationManager: new Contract(
|
|
29
|
-
delegationManagerAddress,
|
|
30
|
-
delegationABI,
|
|
31
|
-
wallet || provider
|
|
32
|
-
),
|
|
33
|
-
// eslint-disable-next-line camelcase
|
|
34
|
-
contract: ReclaimServiceManager__factory.connect(
|
|
35
|
-
contractAddress,
|
|
36
|
-
wallet || provider
|
|
37
|
-
),
|
|
38
|
-
registryContract: new Contract(
|
|
39
|
-
stakeRegistryAddress,
|
|
40
|
-
registryABI,
|
|
41
|
-
wallet || provider
|
|
42
|
-
),
|
|
43
|
-
avsDirectory: new Contract(
|
|
44
|
-
avsDirectoryAddress,
|
|
45
|
-
avsDirectoryABI,
|
|
46
|
-
wallet || provider
|
|
47
|
-
)
|
|
48
|
-
};
|
|
49
|
-
}
|
|
50
|
-
export {
|
|
51
|
-
getContracts,
|
|
52
|
-
initialiseContracts
|
|
53
|
-
};
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import type { Wallet } from 'ethers';
|
|
2
|
-
import { logger as LOGGER } from '#src/utils/index.ts';
|
|
3
|
-
type RegisterOpts = {
|
|
4
|
-
logger?: typeof LOGGER;
|
|
5
|
-
/**
|
|
6
|
-
* What chain to register the operator on
|
|
7
|
-
* @default -- env variable CHAIN_ID
|
|
8
|
-
*/
|
|
9
|
-
chainId?: string;
|
|
10
|
-
/**
|
|
11
|
-
* wallet of the operator.
|
|
12
|
-
* @default -- wallet specified in the contracts
|
|
13
|
-
* fetched by the chainId
|
|
14
|
-
*/
|
|
15
|
-
wallet?: Wallet;
|
|
16
|
-
/**
|
|
17
|
-
* URL of the Reclaim RPC server.
|
|
18
|
-
* @default -- env variable RECLAIM_PUBLIC_URL
|
|
19
|
-
*/
|
|
20
|
-
reclaimRpcUrl?: string;
|
|
21
|
-
};
|
|
22
|
-
/**
|
|
23
|
-
* Registers the operator on the chain, if required.
|
|
24
|
-
* If already registered -- will just pass through
|
|
25
|
-
*/
|
|
26
|
-
export declare function registerOperator({ logger, chainId, wallet, reclaimRpcUrl }?: RegisterOpts): Promise<void>;
|
|
27
|
-
export {};
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import { hexlify, randomBytes, SigningKey } from "ethers";
|
|
2
|
-
import { RECLAIM_PUBLIC_URL, SELECTED_CHAIN_ID } from "../../avs/config.js";
|
|
3
|
-
import { getContracts } from "../../avs/utils/contracts.js";
|
|
4
|
-
import { logger as LOGGER } from "../../utils/index.js";
|
|
5
|
-
async function registerOperator({
|
|
6
|
-
logger = LOGGER,
|
|
7
|
-
chainId = SELECTED_CHAIN_ID,
|
|
8
|
-
wallet = getContracts(chainId).wallet,
|
|
9
|
-
reclaimRpcUrl = RECLAIM_PUBLIC_URL
|
|
10
|
-
} = {}) {
|
|
11
|
-
const contracts = getContracts(chainId);
|
|
12
|
-
const delegationManager = contracts.delegationManager.connect(wallet);
|
|
13
|
-
const avsDirectory = contracts.avsDirectory.connect(wallet);
|
|
14
|
-
const contract = contracts.contract.connect(wallet);
|
|
15
|
-
const registryContract = contracts.registryContract.connect(wallet);
|
|
16
|
-
const addr = wallet.address;
|
|
17
|
-
try {
|
|
18
|
-
const tx1 = await delegationManager.registerAsOperator({
|
|
19
|
-
earningsReceiver: addr,
|
|
20
|
-
delegationApprover: "0x0000000000000000000000000000000000000000",
|
|
21
|
-
stakerOptOutWindowBlocks: 0
|
|
22
|
-
}, "");
|
|
23
|
-
await tx1.wait();
|
|
24
|
-
logger.info("operator registered on DM successfully");
|
|
25
|
-
} catch (err) {
|
|
26
|
-
if (!err.message.includes("operator has already registered")) {
|
|
27
|
-
throw err;
|
|
28
|
-
}
|
|
29
|
-
logger.info("Operator already registered on EL");
|
|
30
|
-
}
|
|
31
|
-
const salt = hexlify(randomBytes(32));
|
|
32
|
-
const expiry = Math.floor(Date.now() / 1e3) + 3600;
|
|
33
|
-
const operatorSignature = {
|
|
34
|
-
expiry,
|
|
35
|
-
salt,
|
|
36
|
-
signature: ""
|
|
37
|
-
};
|
|
38
|
-
const contractAddress = await contract.getAddress();
|
|
39
|
-
const digestHash = await avsDirectory.calculateOperatorAVSRegistrationDigestHash(
|
|
40
|
-
addr,
|
|
41
|
-
contractAddress,
|
|
42
|
-
salt,
|
|
43
|
-
expiry
|
|
44
|
-
);
|
|
45
|
-
const signingKey = new SigningKey(
|
|
46
|
-
wallet.privateKey
|
|
47
|
-
);
|
|
48
|
-
const signature = signingKey.sign(digestHash);
|
|
49
|
-
operatorSignature.signature = signature.serialized;
|
|
50
|
-
logger.info("operator signature generated successfully");
|
|
51
|
-
if (!await registryContract.operatorRegistered(addr)) {
|
|
52
|
-
const tx2 = await registryContract.registerOperatorWithSignature(addr, operatorSignature);
|
|
53
|
-
await tx2.wait();
|
|
54
|
-
logger.info("operator registered on AVS successfully");
|
|
55
|
-
} else {
|
|
56
|
-
logger.info("Operator already registered on AVS");
|
|
57
|
-
}
|
|
58
|
-
const existingMetadata = await contract.getMetadataForOperator(addr).catch((err) => {
|
|
59
|
-
if (err.message.includes("Operator not found")) {
|
|
60
|
-
return void 0;
|
|
61
|
-
}
|
|
62
|
-
throw err;
|
|
63
|
-
});
|
|
64
|
-
const metadata = { addr, url: reclaimRpcUrl };
|
|
65
|
-
if (existingMetadata?.addr === metadata.addr && existingMetadata?.url === metadata.url) {
|
|
66
|
-
logger.info("operator metadata already up to date");
|
|
67
|
-
return;
|
|
68
|
-
}
|
|
69
|
-
await contract.updateOperatorMetadata(metadata);
|
|
70
|
-
logger.info({ metadata }, "operator metadata updated successfully");
|
|
71
|
-
}
|
|
72
|
-
export {
|
|
73
|
-
registerOperator
|
|
74
|
-
};
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { type Wallet } from 'ethers';
|
|
2
|
-
import type { IReclaimServiceManager, NewTaskCreatedEvent } from '#src/avs/contracts/ReclaimServiceManager.ts';
|
|
3
|
-
type CreateClaimWithoutOwner = Omit<IReclaimServiceManager.ClaimRequestStruct, 'owner'>;
|
|
4
|
-
type CreateNewClaimRequestOnChainOpts = {
|
|
5
|
-
request: CreateClaimWithoutOwner;
|
|
6
|
-
payer: Wallet;
|
|
7
|
-
chainId?: string;
|
|
8
|
-
} & ({
|
|
9
|
-
owner: Wallet;
|
|
10
|
-
} | {
|
|
11
|
-
/**
|
|
12
|
-
* Address of the owner of the claim
|
|
13
|
-
*/
|
|
14
|
-
owner: string;
|
|
15
|
-
requestSignature?: string | Uint8Array;
|
|
16
|
-
});
|
|
17
|
-
export declare function createNewClaimRequestOnChain({ request, payer, chainId, ...rest }: CreateNewClaimRequestOnChainOpts): Promise<{
|
|
18
|
-
task: NewTaskCreatedEvent.OutputObject;
|
|
19
|
-
tx: import("ethers").ContractTransactionReceipt | null;
|
|
20
|
-
}>;
|
|
21
|
-
export declare function signClaimRequest(request: IReclaimServiceManager.ClaimRequestStruct, owner: Wallet, chainId?: string): Promise<Uint8Array<ArrayBufferLike>>;
|
|
22
|
-
export {};
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
import { EventLog, getBytes } from "ethers";
|
|
2
|
-
import { getContracts } from "../../avs/utils/contracts.js";
|
|
3
|
-
async function createNewClaimRequestOnChain({
|
|
4
|
-
request,
|
|
5
|
-
payer,
|
|
6
|
-
chainId,
|
|
7
|
-
...rest
|
|
8
|
-
}) {
|
|
9
|
-
const contracts = getContracts(chainId);
|
|
10
|
-
const contract = contracts.contract.connect(payer);
|
|
11
|
-
const ownerAddress = typeof rest.owner === "string" ? rest.owner : rest.owner.address;
|
|
12
|
-
const fullRequest = {
|
|
13
|
-
...request,
|
|
14
|
-
owner: ownerAddress
|
|
15
|
-
};
|
|
16
|
-
const signature = await getSignature();
|
|
17
|
-
const task = await contract.createNewTask(fullRequest, signature || "0x00");
|
|
18
|
-
const rslt = await task.wait();
|
|
19
|
-
const logs = rslt?.logs ?? [];
|
|
20
|
-
const eventLogs = logs.filter((log) => log instanceof EventLog);
|
|
21
|
-
const ev = eventLogs[0];
|
|
22
|
-
const arg = ev?.args;
|
|
23
|
-
return { task: arg, tx: rslt };
|
|
24
|
-
function getSignature() {
|
|
25
|
-
if (ownerAddress.toLowerCase() === payer.address.toLowerCase()) {
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
if ("requestSignature" in rest) {
|
|
29
|
-
return rest.requestSignature;
|
|
30
|
-
}
|
|
31
|
-
if (typeof rest.owner !== "object") {
|
|
32
|
-
throw new Error(
|
|
33
|
-
"Owner wallet must be provided or requestSignature must be provided"
|
|
34
|
-
);
|
|
35
|
-
}
|
|
36
|
-
return signClaimRequest(fullRequest, rest.owner, chainId);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
async function signClaimRequest(request, owner, chainId) {
|
|
40
|
-
const contract = getContracts(chainId).contract;
|
|
41
|
-
const encoded = await contract.encodeClaimRequest(request);
|
|
42
|
-
const strSig = await owner.signMessage(getBytes(encoded));
|
|
43
|
-
return getBytes(strSig);
|
|
44
|
-
}
|
|
45
|
-
export {
|
|
46
|
-
createNewClaimRequestOnChain,
|
|
47
|
-
signClaimRequest
|
|
48
|
-
};
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import type { CreateClaimOnAttestorOpts, ProviderName } from '#src/types/index.ts';
|
|
2
|
-
/**
|
|
3
|
-
* Create a claim on the attestor
|
|
4
|
-
*/
|
|
5
|
-
export declare function createClaimOnAttestor<N extends ProviderName>({ logger: _logger, maxRetries, ...opts }: CreateClaimOnAttestorOpts<N>): Promise<import("#src/proto/api.ts").ClaimTunnelResponse>;
|