@reclaimprotocol/attestor-core 3.1.1 → 4.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/lib/avs/contracts/index.js +18 -8
- package/lib/avs/tests/test.operator.js +4 -4
- package/lib/avs/utils/tasks.d.ts +1 -1
- package/lib/client/create-claim.d.ts +2 -2
- package/lib/client/create-claim.js +100 -34
- package/lib/client/tunnels/make-rpc-tcp-tunnel.js +3 -3
- package/lib/client/tunnels/make-rpc-tls-tunnel.js +3 -3
- package/lib/client/utils/client-socket.d.ts +3 -1
- package/lib/client/utils/client-socket.js +25 -8
- package/lib/client/utils/message-handler.js +2 -2
- package/lib/config/index.d.ts +9 -2
- package/lib/config/index.js +10 -4
- package/lib/index.js +18 -8
- package/lib/proto/api.d.ts +81 -2
- package/lib/proto/api.js +859 -101
- package/lib/providers/http/index.js +220 -116
- package/lib/providers/http/utils.d.ts +3 -6
- package/lib/providers/http/utils.js +13 -11
- package/lib/providers/index.js +1 -3
- package/lib/scripts/check-avs-registration.js +2 -2
- package/lib/scripts/generate-provider-types.js +2 -2
- package/lib/scripts/generate-receipt.js +6 -3
- package/lib/scripts/generate-toprf-keys.d.ts +1 -0
- package/lib/scripts/generate-toprf-keys.js +23 -0
- package/lib/scripts/register-avs-operator.js +2 -2
- package/lib/scripts/start-server.js +10 -3
- package/lib/scripts/update-avs-metadata.js +2 -2
- package/lib/scripts/verify-root-ca.js +2 -2
- package/lib/scripts/whitelist-operator.js +2 -2
- package/lib/server/create-server.js +14 -7
- package/lib/server/handlers/claimTunnel.js +34 -11
- package/lib/server/handlers/createTunnel.js +45 -9
- package/lib/server/handlers/disconnectTunnel.js +2 -2
- package/lib/server/handlers/index.js +4 -2
- package/lib/server/handlers/init.js +17 -2
- package/lib/server/handlers/toprf.d.ts +2 -0
- package/lib/server/handlers/toprf.js +21 -0
- package/lib/server/socket.d.ts +5 -3
- package/lib/server/socket.js +28 -8
- package/lib/server/tunnels/make-tcp-tunnel.js +22 -29
- package/lib/server/utils/apm.js +9 -5
- package/lib/server/utils/assert-valid-claim-request.d.ts +3 -3
- package/lib/server/utils/assert-valid-claim-request.js +27 -16
- package/lib/server/utils/dns.d.ts +1 -0
- package/lib/server/utils/dns.js +22 -0
- package/lib/server/utils/generics.d.ts +1 -1
- package/lib/tests/describe-with-server.d.ts +0 -2
- package/lib/tests/describe-with-server.js +1 -4
- package/lib/tests/mock-provider-server.d.ts +1 -1
- package/lib/tests/test.auth.d.ts +1 -0
- package/lib/tests/test.auth.js +75 -0
- package/lib/tests/test.bgp-listener.d.ts +1 -0
- package/lib/tests/test.bgp-listener.js +169 -0
- package/lib/tests/test.claim-creation.js +101 -8
- package/lib/tests/test.http-parser.d.ts +1 -1
- package/lib/tests/test.http-parser.js +7 -5
- package/lib/tests/test.http-provider-utils.js +489 -211
- package/lib/tests/test.http-provider.js +77 -6
- package/lib/tests/test.rpc-tunnel.js +10 -6
- package/lib/tests/test.zk.d.ts +1 -1
- package/lib/tests/test.zk.js +180 -12
- package/lib/tests/utils.d.ts +6 -0
- package/lib/tests/utils.js +16 -1
- package/lib/types/bgp.d.ts +11 -0
- package/lib/types/bgp.js +3 -0
- package/lib/types/claims.d.ts +14 -5
- package/lib/types/client.d.ts +30 -3
- package/lib/types/general.d.ts +12 -0
- package/lib/types/handlers.d.ts +4 -4
- package/lib/types/index.d.ts +1 -0
- package/lib/types/index.js +2 -1
- package/lib/types/providers.d.ts +25 -10
- package/lib/types/providers.gen.d.ts +14 -155
- package/lib/types/providers.gen.js +2 -6
- package/lib/types/tunnel.d.ts +2 -2
- package/lib/types/zk.d.ts +11 -3
- package/lib/utils/auth.d.ts +7 -0
- package/lib/utils/auth.js +64 -0
- package/lib/utils/b64-json.d.ts +2 -0
- package/lib/utils/b64-json.js +23 -0
- package/lib/utils/bgp-listener.d.ts +7 -0
- package/lib/utils/bgp-listener.js +126 -0
- package/lib/utils/claims.js +3 -3
- package/lib/utils/generics.d.ts +5 -5
- package/lib/utils/generics.js +3 -3
- package/lib/utils/http-parser.d.ts +4 -0
- package/lib/utils/http-parser.js +4 -2
- package/lib/utils/index.d.ts +2 -0
- package/lib/utils/index.js +3 -1
- package/lib/utils/redactions.d.ts +19 -6
- package/lib/utils/redactions.js +41 -4
- package/lib/utils/socket-base.d.ts +3 -2
- package/lib/utils/socket-base.js +7 -2
- package/lib/utils/ws.d.ts +5 -5
- package/lib/utils/ws.js +27 -10
- package/lib/utils/zk.d.ts +12 -7
- package/lib/utils/zk.js +261 -67
- package/lib/window-rpc/setup-window-rpc.js +29 -8
- package/lib/window-rpc/types.d.ts +16 -21
- package/lib/window-rpc/utils.d.ts +2 -1
- package/lib/window-rpc/utils.js +28 -2
- package/lib/window-rpc/window-rpc-zk.d.ts +8 -3
- package/lib/window-rpc/window-rpc-zk.js +58 -45
- package/package.json +25 -22
- package/lib/providers/httpb64/index.d.ts +0 -3
- package/lib/providers/httpb64/index.js +0 -209
- package/lib/providers/httpb64/utils.d.ts +0 -77
- package/lib/providers/httpb64/utils.js +0 -358
- package/lib/server/utils/verify-server-certificates.d.ts +0 -7
- package/lib/server/utils/verify-server-certificates.js +0 -101
|
@@ -6,6 +6,7 @@ const create_claim_on_avs_1 = require("../avs/client/create-claim-on-avs");
|
|
|
6
6
|
const client_1 = require("../client");
|
|
7
7
|
const utils_1 = require("../providers/http/utils");
|
|
8
8
|
const utils_2 = require("../utils");
|
|
9
|
+
const b64_json_1 = require("../utils/b64-json");
|
|
9
10
|
const benchmark_1 = require("../utils/benchmark");
|
|
10
11
|
const utils_3 = require("../window-rpc/utils");
|
|
11
12
|
const window_rpc_zk_1 = require("../window-rpc/window-rpc-zk");
|
|
@@ -19,12 +20,13 @@ const VALID_MODULES = [
|
|
|
19
20
|
'attestor-core',
|
|
20
21
|
'witness-sdk'
|
|
21
22
|
];
|
|
22
|
-
let logger =
|
|
23
|
+
let logger = utils_2.logger;
|
|
23
24
|
/**
|
|
24
25
|
* Sets up the current window to listen for RPC requests
|
|
25
26
|
* from React Native or other windows
|
|
26
27
|
*/
|
|
27
28
|
function setupWindowRpc() {
|
|
29
|
+
logger = (0, utils_2.makeLogger)(true);
|
|
28
30
|
window.addEventListener('message', handleMessage, false);
|
|
29
31
|
const windowMsgs = new EventTarget();
|
|
30
32
|
const defaultUrl = (0, utils_3.getWsApiUrlFromLocation)();
|
|
@@ -37,8 +39,9 @@ function setupWindowRpc() {
|
|
|
37
39
|
return;
|
|
38
40
|
}
|
|
39
41
|
const req = (typeof event.data === 'string'
|
|
40
|
-
? JSON.parse(event.data)
|
|
42
|
+
? JSON.parse(event.data, b64_json_1.B64_JSON_REVIVER)
|
|
41
43
|
: event.data);
|
|
44
|
+
logger.debug({ req, origin: event.origin }, 'recv RPC message');
|
|
42
45
|
// ignore any messages not for us
|
|
43
46
|
if (!VALID_MODULES.includes(req.module)) {
|
|
44
47
|
return;
|
|
@@ -63,7 +66,11 @@ function setupWindowRpc() {
|
|
|
63
66
|
? JSON.parse(req.request.context)
|
|
64
67
|
: undefined,
|
|
65
68
|
zkOperators: getZkOperators(req.request.zkOperatorMode, req.request.zkEngine),
|
|
66
|
-
|
|
69
|
+
oprfOperators: getOprfOperators(req.request.zkOperatorMode, req.request.zkEngine),
|
|
70
|
+
client: {
|
|
71
|
+
url: defaultUrl,
|
|
72
|
+
authRequest: req.request.authRequest
|
|
73
|
+
},
|
|
67
74
|
logger,
|
|
68
75
|
onStep(step) {
|
|
69
76
|
sendMessage({
|
|
@@ -99,6 +106,7 @@ function setupWindowRpc() {
|
|
|
99
106
|
? JSON.parse(req.request.context)
|
|
100
107
|
: undefined,
|
|
101
108
|
zkOperators: getZkOperators(req.request.zkOperatorMode, req.request.zkEngine),
|
|
109
|
+
oprfOperators: getOprfOperators(req.request.zkOperatorMode, req.request.zkEngine),
|
|
102
110
|
logger,
|
|
103
111
|
onStep(step) {
|
|
104
112
|
sendMessage({
|
|
@@ -167,9 +175,9 @@ function setupWindowRpc() {
|
|
|
167
175
|
}
|
|
168
176
|
});
|
|
169
177
|
}
|
|
170
|
-
function getZkOperators(
|
|
178
|
+
function getZkOperators(mode = 'default', zkEngine = 'snarkjs') {
|
|
171
179
|
// use default snarkJS ops
|
|
172
|
-
if (
|
|
180
|
+
if (mode === 'default') {
|
|
173
181
|
return;
|
|
174
182
|
}
|
|
175
183
|
// the native app/window calling implements
|
|
@@ -180,6 +188,19 @@ function setupWindowRpc() {
|
|
|
180
188
|
}
|
|
181
189
|
return operators;
|
|
182
190
|
}
|
|
191
|
+
function getOprfOperators(mode = 'default', zkEngine = 'snarkjs') {
|
|
192
|
+
// use default webview ops
|
|
193
|
+
if (mode === 'default') {
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
// the native app/window calling implements
|
|
197
|
+
// a ZK operator & wants to use it
|
|
198
|
+
const operators = {};
|
|
199
|
+
for (const alg of window_rpc_zk_1.ALL_ENC_ALGORITHMS) {
|
|
200
|
+
operators[alg] = (0, window_rpc_zk_1.makeWindowRpcOprfOperator)(alg, makeCommunicationBridge(), zkEngine);
|
|
201
|
+
}
|
|
202
|
+
return operators;
|
|
203
|
+
}
|
|
183
204
|
function makeCommunicationBridge() {
|
|
184
205
|
return {
|
|
185
206
|
send: sendMessage,
|
|
@@ -205,7 +226,7 @@ function setupWindowRpc() {
|
|
|
205
226
|
}
|
|
206
227
|
function sendMessage(data) {
|
|
207
228
|
var _a;
|
|
208
|
-
const str = JSON.stringify(data);
|
|
229
|
+
const str = JSON.stringify(data, b64_json_1.B64_JSON_REPLACER);
|
|
209
230
|
if (channel) {
|
|
210
231
|
(_a = window[channel]) === null || _a === void 0 ? void 0 : _a.postMessage(str);
|
|
211
232
|
}
|
|
@@ -217,7 +238,7 @@ function setupWindowRpc() {
|
|
|
217
238
|
const { req, res } = (0, utils_1.generateRequstAndResponseFromTranscript)(transcript, tlsVersion);
|
|
218
239
|
const bridge = makeCommunicationBridge();
|
|
219
240
|
const id = (0, utils_3.generateRpcRequestId)();
|
|
220
|
-
const waitForRes = (0,
|
|
241
|
+
const waitForRes = (0, utils_3.waitForResponse)('updateProviderParams', id, bridge);
|
|
221
242
|
bridge.send({
|
|
222
243
|
type: 'updateProviderParams',
|
|
223
244
|
id,
|
|
@@ -236,4 +257,4 @@ function setupWindowRpc() {
|
|
|
236
257
|
}
|
|
237
258
|
}
|
|
238
259
|
}
|
|
239
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
260
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"setup-window-rpc.js","sourceRoot":"","sources":["../../src/window-rpc/setup-window-rpc.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { OPRFOperator, ZKEngine, ZKOperator } from '@reclaimprotocol/zk-symmetric-crypto';
|
|
2
2
|
import type { TaskCompletedEventObject } from '../avs/contracts/ReclaimServiceManager';
|
|
3
3
|
import type { CreateClaimOnAvsOpts, CreateClaimOnAvsStep } from '../avs/types';
|
|
4
|
+
import { AuthenticationRequest } from '../proto/api';
|
|
4
5
|
import type { extractHTMLElement, extractJSONValueIndex } from '../providers/http/utils';
|
|
5
6
|
import type { AttestorData, CompleteClaimData, CreateClaimOnAttestorOpts, LogLevel, ProofGenerationStep, ProviderName, ProviderParams, ProviderSecretParams } from '../types';
|
|
6
7
|
import { HttpRequest, HttpResponse } from '../utils';
|
|
@@ -16,7 +17,7 @@ type IdentifiedMessage = {
|
|
|
16
17
|
};
|
|
17
18
|
type CreateClaimRPCBaseOpts = {
|
|
18
19
|
/**
|
|
19
|
-
* Specify the mode for the ZK operator,
|
|
20
|
+
* Specify the mode for the ZK & OPRF operator,
|
|
20
21
|
* 'default' -> will use the default ZK operator included in the SDK
|
|
21
22
|
* (presently that's SnarkJS supported by FFs running on WASM)
|
|
22
23
|
* 'rpc' -> if you've access to a native ZK operator, you can use this mode
|
|
@@ -26,8 +27,9 @@ type CreateClaimRPCBaseOpts = {
|
|
|
26
27
|
context?: string;
|
|
27
28
|
zkEngine?: ZKEngine;
|
|
28
29
|
updateProviderParams?: boolean;
|
|
30
|
+
authRequest?: AuthenticationRequest;
|
|
29
31
|
};
|
|
30
|
-
export type RPCCreateClaimOptions<N extends ProviderName = any> = Omit<CreateClaimOnAttestorOpts<N>, 'zkOperators' | 'context'> & CreateClaimRPCBaseOpts;
|
|
32
|
+
export type RPCCreateClaimOptions<N extends ProviderName = any> = Omit<CreateClaimOnAttestorOpts<N>, 'zkOperators' | 'context' | 'client'> & CreateClaimRPCBaseOpts;
|
|
31
33
|
export type RPCCreateClaimOnAvsOptions<N extends ProviderName = any> = Omit<CreateClaimOnAvsOpts<N>, 'zkOperators' | 'context' | 'payer'> & {
|
|
32
34
|
payer?: 'attestor';
|
|
33
35
|
} & CreateClaimRPCBaseOpts;
|
|
@@ -40,13 +42,6 @@ type ExtractJSONValueIndexOptions = {
|
|
|
40
42
|
json: string;
|
|
41
43
|
jsonPath: string;
|
|
42
44
|
};
|
|
43
|
-
type ZKProveOpts = {
|
|
44
|
-
algorithm: EncryptionAlgorithm;
|
|
45
|
-
input: {
|
|
46
|
-
/** Base64 encoded attestor */
|
|
47
|
-
witnessB64: string;
|
|
48
|
-
};
|
|
49
|
-
};
|
|
50
45
|
type UpdateProviderParamsOpts = {
|
|
51
46
|
request: Omit<HttpRequest, 'body'> & {
|
|
52
47
|
body: string | undefined;
|
|
@@ -55,13 +50,6 @@ type UpdateProviderParamsOpts = {
|
|
|
55
50
|
body: string | undefined;
|
|
56
51
|
};
|
|
57
52
|
};
|
|
58
|
-
type ZKVerifyOpts = {
|
|
59
|
-
algorithm: EncryptionAlgorithm;
|
|
60
|
-
publicSignals: number[];
|
|
61
|
-
proof: {
|
|
62
|
-
[key: string]: unknown;
|
|
63
|
-
} | string;
|
|
64
|
-
};
|
|
65
53
|
type LogLevelOptions = {
|
|
66
54
|
logLevel: LogLevel;
|
|
67
55
|
/**
|
|
@@ -116,12 +104,19 @@ export type WindowRPCClient = {
|
|
|
116
104
|
setLogLevel(options: LogLevelOptions): Promise<void>;
|
|
117
105
|
benchmarkZK(): Promise<string>;
|
|
118
106
|
};
|
|
107
|
+
type AsFunction<K> = K extends (...args: any[]) => any ? K : never;
|
|
108
|
+
type FunctionalOperator<T, K extends keyof T> = {
|
|
109
|
+
fn: K;
|
|
110
|
+
args: Parameters<AsFunction<T[K]>>;
|
|
111
|
+
};
|
|
112
|
+
export type ExecuteZKOpts<T extends keyof ZKOperator = keyof ZKOperator> = FunctionalOperator<ZKOperator, T>;
|
|
113
|
+
export type ExecuteOPRFOpts<T extends keyof OPRFOperator = keyof OPRFOperator> = FunctionalOperator<OPRFOperator, T>;
|
|
119
114
|
/**
|
|
120
115
|
* Fns the attestor calls on the app
|
|
121
116
|
*/
|
|
122
117
|
export type WindowRPCAppClient = {
|
|
123
|
-
|
|
124
|
-
|
|
118
|
+
executeZkFunctionV3(opts: ExecuteZKOpts): Promise<any>;
|
|
119
|
+
executeOprfFunctionV3(opts: ExecuteOPRFOpts): Promise<any>;
|
|
125
120
|
updateProviderParams(opts: UpdateProviderParamsOpts): Promise<{
|
|
126
121
|
params: Partial<ProviderParams<'http'>>;
|
|
127
122
|
secretParams: Partial<ProviderSecretParams<'http'>>;
|
|
@@ -151,12 +146,12 @@ type AsResponse<T> = T & {
|
|
|
151
146
|
/**
|
|
152
147
|
* Data sent to the attestor from the window/application
|
|
153
148
|
*/
|
|
154
|
-
export type WindowRPCIncomingMsg = (WindowRPCRequest<WindowRPCClient, 'createClaim'> | WindowRPCRequest<WindowRPCClient, 'createClaimOnAvs'> | WindowRPCRequest<WindowRPCClient, 'extractHtmlElement'> | WindowRPCRequest<WindowRPCClient, 'extractJSONValueIndex'> | WindowRPCRequest<WindowRPCClient, 'getCurrentMemoryUsage'> | WindowRPCRequest<WindowRPCClient, 'setLogLevel'> | WindowRPCRequest<WindowRPCClient, 'benchmarkZK'> | AsResponse<WindowRPCResponse<WindowRPCAppClient, '
|
|
149
|
+
export type WindowRPCIncomingMsg = (WindowRPCRequest<WindowRPCClient, 'createClaim'> | WindowRPCRequest<WindowRPCClient, 'createClaimOnAvs'> | WindowRPCRequest<WindowRPCClient, 'extractHtmlElement'> | WindowRPCRequest<WindowRPCClient, 'extractJSONValueIndex'> | WindowRPCRequest<WindowRPCClient, 'getCurrentMemoryUsage'> | WindowRPCRequest<WindowRPCClient, 'setLogLevel'> | WindowRPCRequest<WindowRPCClient, 'benchmarkZK'> | AsResponse<WindowRPCResponse<WindowRPCAppClient, 'executeZkFunctionV3'>> | AsResponse<WindowRPCResponse<WindowRPCAppClient, 'executeOprfFunctionV3'>> | AsResponse<WindowRPCResponse<WindowRPCAppClient, 'updateProviderParams'>> | AsResponse<WindowRPCErrorResponse>) & IdentifiedMessage;
|
|
155
150
|
/**
|
|
156
151
|
* Data sent back from the attestor to
|
|
157
152
|
* the window/application containing the attestor
|
|
158
153
|
*/
|
|
159
|
-
export type WindowRPCOutgoingMsg = (AsResponse<WindowRPCResponse<WindowRPCClient, 'createClaim'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'createClaimOnAvs'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'extractHtmlElement'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'extractJSONValueIndex'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'getCurrentMemoryUsage'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'setLogLevel'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'benchmarkZK'>> | WindowRPCRequest<WindowRPCAppClient, '
|
|
154
|
+
export type WindowRPCOutgoingMsg = (AsResponse<WindowRPCResponse<WindowRPCClient, 'createClaim'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'createClaimOnAvs'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'extractHtmlElement'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'extractJSONValueIndex'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'getCurrentMemoryUsage'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'setLogLevel'>> | AsResponse<WindowRPCResponse<WindowRPCClient, 'benchmarkZK'>> | WindowRPCRequest<WindowRPCAppClient, 'executeZkFunctionV3'> | WindowRPCRequest<WindowRPCAppClient, 'executeOprfFunctionV3'> | WindowRPCRequest<WindowRPCAppClient, 'updateProviderParams'> | ({
|
|
160
155
|
type: 'createClaimStep';
|
|
161
156
|
step: {
|
|
162
157
|
name: 'attestor-progress' | 'witness-progress';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ClaimTunnelResponse } from '../proto/api';
|
|
2
|
-
import { CreateClaimResponse } from '../window-rpc/types';
|
|
2
|
+
import { CommunicationBridge, CreateClaimResponse, WindowRPCAppClient } from '../window-rpc/types';
|
|
3
3
|
export declare function getCurrentMemoryUsage(): Promise<{
|
|
4
4
|
available: boolean;
|
|
5
5
|
content: string;
|
|
@@ -11,3 +11,4 @@ export declare function generateRpcRequestId(): string;
|
|
|
11
11
|
*/
|
|
12
12
|
export declare function getWsApiUrlFromLocation(): string;
|
|
13
13
|
export declare function mapToCreateClaimResponse(res: ClaimTunnelResponse): CreateClaimResponse;
|
|
14
|
+
export declare function waitForResponse<T extends keyof WindowRPCAppClient>(type: T, requestId: string, bridge: CommunicationBridge, timeoutMs?: number): Promise<Awaited<ReturnType<WindowRPCAppClient[T]>>>;
|
package/lib/window-rpc/utils.js
CHANGED
|
@@ -4,6 +4,7 @@ exports.getCurrentMemoryUsage = getCurrentMemoryUsage;
|
|
|
4
4
|
exports.generateRpcRequestId = generateRpcRequestId;
|
|
5
5
|
exports.getWsApiUrlFromLocation = getWsApiUrlFromLocation;
|
|
6
6
|
exports.mapToCreateClaimResponse = mapToCreateClaimResponse;
|
|
7
|
+
exports.waitForResponse = waitForResponse;
|
|
7
8
|
const ethers_1 = require("ethers");
|
|
8
9
|
const config_1 = require("../config");
|
|
9
10
|
const utils_1 = require("../utils");
|
|
@@ -23,7 +24,7 @@ async function getCurrentMemoryUsage() {
|
|
|
23
24
|
}
|
|
24
25
|
else {
|
|
25
26
|
try {
|
|
26
|
-
const result =
|
|
27
|
+
const result = performance.measureUserAgentSpecificMemory();
|
|
27
28
|
const totalmb = Math.round(result.bytes / 1024 / 1024);
|
|
28
29
|
return {
|
|
29
30
|
available: true,
|
|
@@ -73,4 +74,29 @@ function mapToCreateClaimResponse(res) {
|
|
|
73
74
|
]
|
|
74
75
|
};
|
|
75
76
|
}
|
|
76
|
-
|
|
77
|
+
function waitForResponse(type, requestId, bridge, timeoutMs = 60000) {
|
|
78
|
+
const returnType = `${type}Done`;
|
|
79
|
+
return new Promise((resolve, reject) => {
|
|
80
|
+
const timeout = setTimeout(() => {
|
|
81
|
+
reject(new utils_1.AttestorError('ERROR_INTERNAL', `Timeout waiting for response: ${type}`, { requestId }));
|
|
82
|
+
cancel();
|
|
83
|
+
}, timeoutMs);
|
|
84
|
+
const cancel = bridge.onMessage(msg => {
|
|
85
|
+
if (msg.id !== requestId) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
if (msg.type === 'error') {
|
|
89
|
+
reject(new Error(msg.data.message));
|
|
90
|
+
}
|
|
91
|
+
else if (msg.type === returnType) {
|
|
92
|
+
resolve(msg.response);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
clearTimeout(timeout);
|
|
98
|
+
cancel();
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvd2luZG93LXJwYy91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQU9BLHNEQStCQztBQUVELG9EQUVDO0FBTUQsMERBSUM7QUFFRCw0REFzQkM7QUFFRCwwQ0FxQ0M7QUFuSEQsbUNBQStCO0FBQy9CLHVDQUF3QztBQUV4QyxxQ0FBcUU7QUFHckUscUJBQXFCO0FBQ2QsS0FBSyxVQUFVLHFCQUFxQjtJQUMxQyxJQUFHLENBQUMsTUFBTSxDQUFDLG1CQUFtQixFQUFFLENBQUM7UUFDaEMsT0FBTztZQUNOLFNBQVMsRUFBRSxLQUFLO1lBQ2hCLE9BQU8sRUFBRSxzQ0FBc0M7U0FDL0MsQ0FBQTtJQUNGLENBQUM7U0FBTSxJQUFHLENBQUMsV0FBVyxDQUFDLDhCQUE4QixFQUFFLENBQUM7UUFDdkQsT0FBTztZQUNOLFNBQVMsRUFBRSxLQUFLO1lBQ2hCLE9BQU8sRUFBRSxxRUFBcUU7U0FDOUUsQ0FBQTtJQUNGLENBQUM7U0FBTSxDQUFDO1FBQ1AsSUFBSSxDQUFDO1lBQ0osTUFBTSxNQUFNLEdBQUcsV0FBVyxDQUFDLDhCQUE4QixFQUFFLENBQUE7WUFDM0QsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxHQUFHLElBQUksR0FBRyxJQUFJLENBQUMsQ0FBQTtZQUV0RCxPQUFPO2dCQUNOLFNBQVMsRUFBRSxJQUFJO2dCQUNmLE9BQU8sRUFBRSxHQUFHLE9BQU8sSUFBSTthQUN2QixDQUFBO1FBQ0YsQ0FBQztRQUFDLE9BQU0sS0FBSyxFQUFFLENBQUM7WUFDZixJQUFHLEtBQUssWUFBWSxZQUFZLElBQUksS0FBSyxDQUFDLElBQUksS0FBSyxlQUFlLEVBQUUsQ0FBQztnQkFDcEUsT0FBTztvQkFDTixTQUFTLEVBQUUsS0FBSztvQkFDaEIsT0FBTyxFQUFFLFFBQVEsS0FBSyxDQUFDLE9BQU8sR0FBRztpQkFDakMsQ0FB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
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { EncryptionAlgorithm, ZKEngine, ZKOperator } from '@reclaimprotocol/zk-symmetric-crypto';
|
|
2
|
-
import { CommunicationBridge
|
|
1
|
+
import { EncryptionAlgorithm, OPRFOperator, ZKEngine, ZKOperator } from '@reclaimprotocol/zk-symmetric-crypto';
|
|
2
|
+
import { CommunicationBridge } from '../window-rpc/types';
|
|
3
3
|
export declare const ALL_ENC_ALGORITHMS: EncryptionAlgorithm[];
|
|
4
4
|
/**
|
|
5
5
|
* The goal of this RPC operator is if the attestor client
|
|
@@ -7,4 +7,9 @@ export declare const ALL_ENC_ALGORITHMS: EncryptionAlgorithm[];
|
|
|
7
7
|
* application to perform the ZK operations
|
|
8
8
|
*/
|
|
9
9
|
export declare function makeWindowRpcZkOperator(algorithm: EncryptionAlgorithm, bridge: CommunicationBridge, zkEngine?: ZKEngine): ZKOperator;
|
|
10
|
-
|
|
10
|
+
/**
|
|
11
|
+
* The goal of this RPC operator is if the attestor client
|
|
12
|
+
* is running in a WebView, it can call the native
|
|
13
|
+
* application to perform the OPRF operations
|
|
14
|
+
*/
|
|
15
|
+
export declare function makeWindowRpcOprfOperator(algorithm: EncryptionAlgorithm, bridge: CommunicationBridge, zkEngine?: ZKEngine): OPRFOperator;
|
|
@@ -2,10 +2,9 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ALL_ENC_ALGORITHMS = void 0;
|
|
4
4
|
exports.makeWindowRpcZkOperator = makeWindowRpcZkOperator;
|
|
5
|
-
exports.
|
|
6
|
-
const utils_1 = require("
|
|
7
|
-
const utils_2 = require("../utils");
|
|
8
|
-
const utils_3 = require("../window-rpc/utils");
|
|
5
|
+
exports.makeWindowRpcOprfOperator = makeWindowRpcOprfOperator;
|
|
6
|
+
const utils_1 = require("../utils");
|
|
7
|
+
const utils_2 = require("../window-rpc/utils");
|
|
9
8
|
exports.ALL_ENC_ALGORITHMS = [
|
|
10
9
|
'aes-256-ctr',
|
|
11
10
|
'aes-128-ctr',
|
|
@@ -19,54 +18,68 @@ exports.ALL_ENC_ALGORITHMS = [
|
|
|
19
18
|
function makeWindowRpcZkOperator(algorithm, bridge, zkEngine = 'snarkjs') {
|
|
20
19
|
return {
|
|
21
20
|
async generateWitness(input) {
|
|
22
|
-
const operator = await (0,
|
|
21
|
+
const operator = await (0, utils_1.makeDefaultZkOperator)(algorithm, zkEngine, utils_1.logger);
|
|
23
22
|
return operator.generateWitness(input);
|
|
24
23
|
},
|
|
25
24
|
groth16Prove(input) {
|
|
26
|
-
|
|
27
|
-
const waitForRes = waitForResponse('zkProve', id, bridge);
|
|
28
|
-
bridge.send({
|
|
29
|
-
type: 'zkProve',
|
|
30
|
-
id,
|
|
31
|
-
request: {
|
|
32
|
-
algorithm,
|
|
33
|
-
input: { witnessB64: utils_1.base64.encode(input) },
|
|
34
|
-
},
|
|
35
|
-
module: 'attestor-core'
|
|
36
|
-
});
|
|
37
|
-
return waitForRes;
|
|
25
|
+
return callFn({ fn: 'groth16Prove', args: [input] });
|
|
38
26
|
},
|
|
39
27
|
groth16Verify(publicSignals, proof) {
|
|
40
|
-
|
|
41
|
-
const waitForRes = waitForResponse('zkVerify', id, bridge);
|
|
42
|
-
bridge.send({
|
|
43
|
-
type: 'zkVerify',
|
|
44
|
-
id,
|
|
45
|
-
request: {
|
|
46
|
-
algorithm,
|
|
47
|
-
publicSignals,
|
|
48
|
-
proof,
|
|
49
|
-
},
|
|
50
|
-
module: 'attestor-core'
|
|
51
|
-
});
|
|
52
|
-
return waitForRes;
|
|
28
|
+
return callFn({ fn: 'groth16Verify', args: [publicSignals, proof] });
|
|
53
29
|
},
|
|
54
30
|
};
|
|
31
|
+
function callFn(opts) {
|
|
32
|
+
const id = (0, utils_2.generateRpcRequestId)();
|
|
33
|
+
const waitForRes = (0, utils_2.waitForResponse)('executeZkFunctionV3', id, bridge);
|
|
34
|
+
bridge.send({
|
|
35
|
+
type: 'executeZkFunctionV3',
|
|
36
|
+
id,
|
|
37
|
+
request: opts,
|
|
38
|
+
module: 'attestor-core'
|
|
39
|
+
});
|
|
40
|
+
return waitForRes;
|
|
41
|
+
}
|
|
55
42
|
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
}
|
|
43
|
+
/**
|
|
44
|
+
* The goal of this RPC operator is if the attestor client
|
|
45
|
+
* is running in a WebView, it can call the native
|
|
46
|
+
* application to perform the OPRF operations
|
|
47
|
+
*/
|
|
48
|
+
function makeWindowRpcOprfOperator(algorithm, bridge, zkEngine = 'snarkjs') {
|
|
49
|
+
return {
|
|
50
|
+
async generateWitness(input) {
|
|
51
|
+
const operator = await (0, utils_1.makeDefaultZkOperator)(algorithm, zkEngine, utils_1.logger);
|
|
52
|
+
return operator.generateWitness(input);
|
|
53
|
+
},
|
|
54
|
+
groth16Prove(input) {
|
|
55
|
+
return callFn({ fn: 'groth16Prove', args: [input] });
|
|
56
|
+
},
|
|
57
|
+
groth16Verify(publicSignals, proof) {
|
|
58
|
+
return callFn({ fn: 'groth16Verify', args: [publicSignals, proof] });
|
|
59
|
+
},
|
|
60
|
+
generateThresholdKeys(total, threshold) {
|
|
61
|
+
return callFn({ fn: 'generateThresholdKeys', args: [total, threshold] });
|
|
62
|
+
},
|
|
63
|
+
generateOPRFRequestData(data, domainSeparator) {
|
|
64
|
+
return callFn({ fn: 'generateOPRFRequestData', args: [data, domainSeparator] });
|
|
65
|
+
},
|
|
66
|
+
finaliseOPRF(serverPublicKey, request, responses) {
|
|
67
|
+
return callFn({ fn: 'finaliseOPRF', args: [serverPublicKey, request, responses] });
|
|
68
|
+
},
|
|
69
|
+
evaluateOPRF(serverPrivateKey, request) {
|
|
70
|
+
return callFn({ fn: 'evaluateOPRF', args: [serverPrivateKey, request] });
|
|
71
|
+
},
|
|
72
|
+
};
|
|
73
|
+
function callFn(opts) {
|
|
74
|
+
const id = (0, utils_2.generateRpcRequestId)();
|
|
75
|
+
const waitForRes = (0, utils_2.waitForResponse)('executeOprfFunctionV3', id, bridge);
|
|
76
|
+
bridge.send({
|
|
77
|
+
type: 'executeOprfFunctionV3',
|
|
78
|
+
id,
|
|
79
|
+
request: opts,
|
|
80
|
+
module: 'attestor-core'
|
|
69
81
|
});
|
|
70
|
-
|
|
82
|
+
return waitForRes;
|
|
83
|
+
}
|
|
71
84
|
}
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2luZG93LXJwYy16ay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy93aW5kb3ctcnBjL3dpbmRvdy1ycGMtemsudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBZ0JBLDBEQWlDQztBQVFELDhEQTZDQztBQXJHRCxxQ0FBeUQ7QUFFekQsZ0RBQTRFO0FBRS9ELFFBQUEsa0JBQWtCLEdBQTBCO0lBQ3hELGFBQWE7SUFDYixhQUFhO0lBQ2IsVUFBVTtDQUNWLENBQUE7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsdUJBQXVCLENBQ3RDLFNBQThCLEVBQzlCLE1BQTJCLEVBQzNCLFdBQXFCLFNBQVM7SUFFOUIsT0FBTztRQUNOLEtBQUssQ0FBQyxlQUFlLENBQUMsS0FBSztZQUMxQixNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUEsNkJBQXFCLEVBQUMsU0FBUyxFQUFFLFFBQVEsRUFBRSxjQUFNLENBQUMsQ0FBQTtZQUN6RSxPQUFPLFFBQVEsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDdkMsQ0FBQztRQUNELFlBQVksQ0FBQyxLQUFLO1lBQ2pCLE9BQU8sTUFBTSxDQUFDLEVBQUUsRUFBRSxFQUFFLGNBQWMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUE7UUFDckQsQ0FBQztRQUNELGFBQWEsQ0FBQyxhQUFhLEVBQUUsS0FBSztZQUNqQyxPQUFPLE1BQU0sQ0FBQyxFQUFFLEVBQUUsRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFLENBQUMsYUFBYSxFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQTtRQUNyRSxDQUFDO0tBQ0QsQ0FBQTtJQUVELFNBQVMsTUFBTSxDQUFDLElBQW1CO1FBQ2xDLE1BQU0sRUFBRSxHQUFHLElBQUEsNEJBQW9CLEdBQUUsQ0FBQTtRQUNqQyxNQUFNLFVBQVUsR0FBRyxJQUFBLHVCQUFlLEVBQ2pDLHFCQUFxQixFQUFFLEVBQUUsRUFBRSxNQUFNLENBQ2pDLENBQUE7UUFFRCxNQUFNLENBQUMsSUFBSSxDQUFDO1lBQ1gsSUFBSSxFQUFFLHFCQUFxQjtZQUMzQixFQUFFO1lBQ0YsT0FBTyxFQUFFLElBQUk7WUFDYixNQUFNLEVBQUUsZUFBZTtTQUN2QixDQUFDLENBQUE7UUFFRixPQUFPLFVBQVUsQ0FBQTtJQUNsQixDQUFDO0FBQ0YsQ0FBQztBQUdEOzs7O0dBSUc7QUFDSCxTQUFnQix5QkFBeUIsQ0FDeEMsU0FBOEIsRUFDOUIsTUFBMkIsRUFDM0IsV0FBcUIsU0FBUztJQUU5QixPQUFPO1FBQ04sS0FBSyxDQUFDLGVBQWUsQ0FBQyxLQUFLO1lBQzFCLE1BQU0sUUFBUSxHQUFHLE1BQU0sSUFBQSw2QkFBcUIsRUFBQyxTQUFTLEVBQUUsUUFBUSxFQUFFLGNBQU0sQ0FBQyxDQUFBO1lBQ3pFLE9BQU8sUUFBUSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUN2QyxDQUFDO1FBQ0QsWUFBWSxDQUFDLEtBQUs7WUFDakIsT0FBTyxNQUFNLENBQUMsRUFBRSxFQUFFLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQTtRQUNyRCxDQUFDO1FBQ0QsYUFBYSxDQUFDLGFBQWEsRUFBRSxLQUFLO1lBQ2pDLE9BQU8sTUFBTSxDQUFDLEVBQUUsRUFBRSxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxhQUFhLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFBO1FBQ3JFLENBQUM7UUFDRCxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsU0FBUztZQUNyQyxPQUFPLE1BQU0sQ0FBQyxFQUFFLEVBQUUsRUFBRSx1QkFBdUIsRUFBRSxJQUFJLEVBQUUsQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLEVBQUUsQ0FBQyxDQUFBO1FBQ3pFLENBQUM7UUFDRCx1QkFBdUIsQ0FBQyxJQUFJLEVBQUUsZUFBZTtZQUM1QyxPQUFPLE1BQU0sQ0FBQyxFQUFFLEVBQUUsRUFBRSx5QkFBeUIsRUFBRSxJQUFJLEVBQUUsQ0FBQyxJQUFJLEVBQUUsZUFBZSxDQUFDLEVBQUUsQ0FBQyxDQUFBO1FBQ2hGLENBQUM7UUFDRCxZQUFZLENBQUMsZUFBZSxFQUFFLE9BQU8sRUFBRSxTQUFTO1lBQy9DLE9BQU8sTUFBTSxDQUFDLEVBQUUsRUFBRSxFQUFFLGNBQWMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxlQUFlLEVBQUUsT0FBTyxFQUFFLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQTtRQUNuRixDQUFDO1FBQ0QsWUFBWSxDQUFDLGdCQUFnQixFQUFFLE9BQU87WUFDckMsT0FBTyxNQUFNLENBQUMsRUFBRSxFQUFFLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxDQUFDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FBQTtRQUN6RSxDQUFDO0tBQ0QsQ0FBQTtJQUVELFNBQVMsTUFBTSxDQUFDLElBQXFCO1FBQ3BDLE1BQU0sRUFBRSxHQUFHLElBQUEsNEJBQW9CLEdBQUUsQ0FBQTtRQUNqQyxNQUFNLFVBQVUsR0FBRyxJQUFBLHVCQUFlLEVBQ2pDLHVCQUF1QixFQUFFLEVBQUUsRUFBRSxNQUFNLENBQ25DLENBQUE7UUFFRCxNQUFNLENBQUMsSUFBSSxDQUFDO1lBQ1gsSUFBSSxFQUFFLHVCQUF1QjtZQUM3QixFQUFFO1lBQ0YsT0FBTyxFQUFFLElBQUk7WUFDYixNQUFNLEVBQUUsZUFBZTtTQUN2QixDQUFDLENBQUE7UUFFRixPQUFPLFVBQVUsQ0FBQTtJQUNsQixDQUFDO0FBQ0YsQ0FBQyJ9
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@reclaimprotocol/attestor-core",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "4.0.1",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "lib/index",
|
|
6
6
|
"scripts": {
|
|
@@ -29,7 +29,9 @@
|
|
|
29
29
|
"generate:avs": "typechain -- --target ethers-v5 --out-dir src/avs/contracts avs/contracts/out/ReclaimServiceManager.sol/*.json",
|
|
30
30
|
"start:chain": "bash ./avs/utils/anvil/start-anvil-chain-with-el-and-avs-deployed.sh",
|
|
31
31
|
"commitlint": "commitlint --edit",
|
|
32
|
-
"download:zk-files": "node node_modules/@reclaimprotocol/zk-symmetric-crypto/lib/scripts/download-files"
|
|
32
|
+
"download:zk-files": "node node_modules/@reclaimprotocol/zk-symmetric-crypto/lib/scripts/download-files",
|
|
33
|
+
"generate:toprf-keys": "npm run run:tsc -- src/scripts/generate-toprf-keys.ts",
|
|
34
|
+
"publish:pkg": "npm publish --access public"
|
|
33
35
|
},
|
|
34
36
|
"files": [
|
|
35
37
|
"lib/*"
|
|
@@ -61,54 +63,55 @@
|
|
|
61
63
|
"author": "Adhiraj Singh",
|
|
62
64
|
"license": "AGPL-3.0-only",
|
|
63
65
|
"dependencies": {
|
|
64
|
-
"@bufbuild/protobuf": "^2.2.
|
|
66
|
+
"@bufbuild/protobuf": "^2.2.2",
|
|
65
67
|
"@commitlint/cli": "^17.8.1",
|
|
66
68
|
"@commitlint/config-conventional": "^17.8.1",
|
|
67
|
-
"@reclaimprotocol/zk-symmetric-crypto": "^2.0.0",
|
|
68
69
|
"@reclaimprotocol/tls": "github:reclaimprotocol/tls",
|
|
70
|
+
"@reclaimprotocol/zk-symmetric-crypto": "^3.0.5",
|
|
69
71
|
"ajv": "^8.17.1",
|
|
70
72
|
"canonicalize": "^2.0.0",
|
|
71
|
-
"dotenv": "^16.4.
|
|
72
|
-
"elastic-apm-node": "^4.8.
|
|
73
|
+
"dotenv": "^16.4.6",
|
|
74
|
+
"elastic-apm-node": "^4.8.1",
|
|
73
75
|
"esprima-next": "^5.8.4",
|
|
74
76
|
"ethers": "^5.7.2",
|
|
75
77
|
"https-proxy-agent": "^7.0.5",
|
|
78
|
+
"ip-cidr": "^3.0.0",
|
|
76
79
|
"jsdom": "^24.1.3",
|
|
77
|
-
"jsonpath-plus": "^10.
|
|
80
|
+
"jsonpath-plus": "^10.2.0",
|
|
78
81
|
"p-queue": "^8.0.1",
|
|
79
|
-
"pino": "^9.
|
|
82
|
+
"pino": "^9.5.0",
|
|
80
83
|
"protobufjs": "^7.4.0",
|
|
81
84
|
"re2": "^1.21.4",
|
|
82
85
|
"serve-static": "^1.16.2",
|
|
83
|
-
"snarkjs": "^0.7.
|
|
86
|
+
"snarkjs": "^0.7.5",
|
|
84
87
|
"ws": "^8.18.0"
|
|
85
88
|
},
|
|
86
89
|
"devDependencies": {
|
|
87
90
|
"@adiwajshing/eslint-config": "github:adiwajshing/eslint-config",
|
|
88
91
|
"@swc-node/register": "^1.10.9",
|
|
89
|
-
"@swc/core": "^1.
|
|
90
|
-
"@swc/jest": "^0.2.
|
|
92
|
+
"@swc/core": "^1.9.3",
|
|
93
|
+
"@swc/jest": "^0.2.37",
|
|
91
94
|
"@typechain/ethers-v5": "^11.1.2",
|
|
92
95
|
"@types/chance": "^1.1.6",
|
|
93
|
-
"@types/jest": "^29.5.
|
|
96
|
+
"@types/jest": "^29.5.14",
|
|
94
97
|
"@types/jsdom": "^21.1.7",
|
|
95
|
-
"@types/node": "^20.
|
|
98
|
+
"@types/node": "^20.17.9",
|
|
96
99
|
"@types/serve-static": "^1.15.7",
|
|
97
|
-
"@types/ws": "^8.5.
|
|
100
|
+
"@types/ws": "^8.5.13",
|
|
98
101
|
"chance": "^1.1.12",
|
|
99
102
|
"eslint": "^8.57.1",
|
|
100
103
|
"eslint-plugin-no-relative-import-paths": "^1.5.5",
|
|
101
104
|
"jest": "^29.7.0",
|
|
102
|
-
"json-schema-to-typescript": "^15.0.
|
|
105
|
+
"json-schema-to-typescript": "^15.0.3",
|
|
103
106
|
"ts-loader": "^9.5.1",
|
|
104
|
-
"ts-proto": "^2.
|
|
107
|
+
"ts-proto": "^2.5.0",
|
|
105
108
|
"tsc-alias": "^1.8.10",
|
|
106
|
-
"tsconfig-paths-webpack-plugin": "^4.
|
|
109
|
+
"tsconfig-paths-webpack-plugin": "^4.2.0",
|
|
107
110
|
"typechain": "^8.3.2",
|
|
108
|
-
"typescript": "^5.
|
|
109
|
-
"webpack": "^5.
|
|
111
|
+
"typescript": "^5.7.2",
|
|
112
|
+
"webpack": "^5.97.0",
|
|
110
113
|
"webpack-cli": "^5.1.4",
|
|
111
|
-
"yaml": "^2.6.
|
|
114
|
+
"yaml": "^2.6.1"
|
|
112
115
|
},
|
|
113
116
|
"overrides": {
|
|
114
117
|
"@ethersproject/providers": {
|
|
@@ -117,6 +120,6 @@
|
|
|
117
120
|
"elliptic": "^v6.5.7"
|
|
118
121
|
},
|
|
119
122
|
"optionalDependencies": {
|
|
120
|
-
"koffi": "^2.9.
|
|
123
|
+
"koffi": "^2.9.2"
|
|
121
124
|
}
|
|
122
|
-
}
|
|
125
|
+
}
|