@vlayer/react 0.1.0-nightly-20250213-df4a6a3 → 0.1.0-nightly-20250214-11fe464
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/dist/context.d.ts +20 -0
- package/dist/context.d.ts.map +1 -0
- package/dist/context.js +51 -0
- package/dist/context.js.map +1 -0
- package/dist/context.test.d.ts +2 -0
- package/dist/context.test.d.ts.map +1 -0
- package/dist/context.test.js +75 -0
- package/dist/context.test.js.map +1 -0
- package/dist/defaults.d.ts +20 -0
- package/dist/defaults.d.ts.map +1 -0
- package/dist/defaults.js +21 -0
- package/dist/defaults.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/types.d.ts +35 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +18 -0
- package/dist/types.js.map +1 -0
- package/dist/useCallProver/useCallProver.d.ts +19 -0
- package/dist/useCallProver/useCallProver.d.ts.map +1 -0
- package/dist/useCallProver/useCallProver.js +49 -0
- package/dist/useCallProver/useCallProver.js.map +1 -0
- package/dist/useWaitForProvingResult/useWaitForProvingResult.d.ts +18 -0
- package/dist/useWaitForProvingResult/useWaitForProvingResult.d.ts.map +1 -0
- package/dist/useWaitForProvingResult/useWaitForProvingResult.js +41 -0
- package/dist/useWaitForProvingResult/useWaitForProvingResult.js.map +1 -0
- package/dist/useWebproof/extension.mock.d.ts +25 -0
- package/dist/useWebproof/extension.mock.d.ts.map +1 -0
- package/dist/useWebproof/extension.mock.js +65 -0
- package/dist/useWebproof/extension.mock.js.map +1 -0
- package/dist/useWebproof/useWebProof.d.ts +16 -0
- package/dist/useWebproof/useWebProof.d.ts.map +1 -0
- package/dist/useWebproof/useWebProof.js +37 -0
- package/dist/useWebproof/useWebProof.js.map +1 -0
- package/dist/useWebproof/useWebProof.test.d.ts +2 -0
- package/dist/useWebproof/useWebProof.test.d.ts.map +1 -0
- package/dist/useWebproof/useWebProof.test.js +119 -0
- package/dist/useWebproof/useWebProof.test.js.map +1 -0
- package/package.json +5 -2
- package/bun.lockb +0 -0
- package/eslint.config.ts +0 -36
- package/src/context.test.tsx +0 -105
- package/src/context.tsx +0 -78
- package/src/defaults.ts +0 -22
- package/src/index.ts +0 -7
- package/src/interface.test.ts +0 -12
- package/src/types.ts +0 -47
- package/src/useCallProver/useCallProver.test.ts +0 -126
- package/src/useCallProver/useCallProver.ts +0 -60
- package/src/useWaitForProvingResult/useWaitForProvingResult.test.ts +0 -80
- package/src/useWaitForProvingResult/useWaitForProvingResult.ts +0 -48
- package/src/useWebproof/extension.mock.ts +0 -103
- package/src/useWebproof/useWebProof.test.tsx +0 -142
- package/src/useWebproof/useWebProof.ts +0 -52
- package/tsconfig.base.json +0 -26
- package/tsconfig.build.json +0 -12
- package/tsconfig.json +0 -6
- package/vitest.config.ts +0 -8
@@ -0,0 +1,20 @@
|
|
1
|
+
import { type PropsWithChildren } from "react";
|
2
|
+
import { type ProofContextType, type ProofConfig, type WebProofContextType, type ProverContextType } from "./types.js";
|
3
|
+
export declare const ProofContext: import("react").Context<ProofContextType | null>;
|
4
|
+
export declare const WebProofContext: import("react").Context<WebProofContextType | null>;
|
5
|
+
export declare const ProverContext: import("react").Context<ProverContextType | null>;
|
6
|
+
export declare const ProofProvider: ({ config, children, }: PropsWithChildren<{
|
7
|
+
config?: Partial<ProofConfig>;
|
8
|
+
}>) => import("react/jsx-runtime").JSX.Element;
|
9
|
+
export declare const useProofContext: () => {
|
10
|
+
config: {
|
11
|
+
proverUrl: string;
|
12
|
+
notaryUrl: string;
|
13
|
+
wsProxyUrl: string;
|
14
|
+
};
|
15
|
+
vlayerClient: import("@vlayer/sdk").VlayerClient;
|
16
|
+
webProofProvider: import("@vlayer/sdk").WebProofProvider;
|
17
|
+
};
|
18
|
+
export declare const useWebProofContext: () => WebProofContextType;
|
19
|
+
export declare const useProverContext: () => ProverContextType;
|
20
|
+
//# sourceMappingURL=context.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../src/context.tsx"],"names":[],"mappings":"AACA,OAAO,EAA6B,KAAK,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAE1E,OAAO,EACL,KAAK,gBAAgB,EACrB,KAAK,WAAW,EAChB,KAAK,mBAAmB,EACxB,KAAK,iBAAiB,EACvB,MAAM,SAAS,CAAC;AAGjB,eAAO,MAAM,YAAY,kDAA+C,CAAC;AACzE,eAAO,MAAM,eAAe,qDAAkD,CAAC;AAC/E,eAAO,MAAM,aAAa,mDAAgD,CAAC;AAE3E,eAAO,MAAM,aAAa,0BAGvB,iBAAiB,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;CAC/B,CAAC,4CAyBD,CAAC;AAEF,eAAO,MAAM,eAAe;;;;;;;;CAY3B,CAAC;AAEF,eAAO,MAAM,kBAAkB,2BAQ9B,CAAC;AAEF,eAAO,MAAM,gBAAgB,yBAM5B,CAAC"}
|
package/dist/context.js
ADDED
@@ -0,0 +1,51 @@
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
2
|
+
import { createVlayerClient } from "@vlayer/sdk";
|
3
|
+
import { createContext, useContext } from "react";
|
4
|
+
import { createExtensionWebProofProvider } from "@vlayer/sdk/web_proof";
|
5
|
+
import {} from "./types.js";
|
6
|
+
import { DEFAULT_CONFIG, DEFAULT_CONFIG_ENV } from "./defaults.js";
|
7
|
+
export const ProofContext = createContext(null);
|
8
|
+
export const WebProofContext = createContext(null);
|
9
|
+
export const ProverContext = createContext(null);
|
10
|
+
export const ProofProvider = ({ config, children, }) => {
|
11
|
+
const { proverUrl, notaryUrl, wsProxyUrl } = {
|
12
|
+
...DEFAULT_CONFIG[config?.env ?? DEFAULT_CONFIG_ENV],
|
13
|
+
...config,
|
14
|
+
};
|
15
|
+
const webProofProvider = createExtensionWebProofProvider({
|
16
|
+
notaryUrl: notaryUrl,
|
17
|
+
wsProxyUrl: wsProxyUrl,
|
18
|
+
});
|
19
|
+
const vlayerClient = createVlayerClient({
|
20
|
+
url: proverUrl,
|
21
|
+
webProofProvider,
|
22
|
+
});
|
23
|
+
return (_jsx(WebProofContext.Provider, { value: { webProofProvider, config: { notaryUrl, wsProxyUrl } }, children: _jsx(ProverContext.Provider, { value: { vlayerClient, config: { proverUrl } }, children: children }) }));
|
24
|
+
};
|
25
|
+
export const useProofContext = () => {
|
26
|
+
const webProofContext = useContext(WebProofContext);
|
27
|
+
const proverContext = useContext(ProverContext);
|
28
|
+
if (!webProofContext || !proverContext) {
|
29
|
+
throw new Error("useProofContext must be used within a ProofProvider");
|
30
|
+
}
|
31
|
+
return {
|
32
|
+
...webProofContext,
|
33
|
+
...proverContext,
|
34
|
+
config: { ...webProofContext.config, ...proverContext.config },
|
35
|
+
};
|
36
|
+
};
|
37
|
+
export const useWebProofContext = () => {
|
38
|
+
const webProofContext = useContext(WebProofContext);
|
39
|
+
if (!webProofContext) {
|
40
|
+
throw new Error("useWebProofContext must be used within a WebProofProvider");
|
41
|
+
}
|
42
|
+
return webProofContext;
|
43
|
+
};
|
44
|
+
export const useProverContext = () => {
|
45
|
+
const proverContext = useContext(ProverContext);
|
46
|
+
if (!proverContext) {
|
47
|
+
throw new Error("useProverContext must be used within a ProverProvider");
|
48
|
+
}
|
49
|
+
return proverContext;
|
50
|
+
};
|
51
|
+
//# sourceMappingURL=context.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../src/context.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,UAAU,EAA0B,MAAM,OAAO,CAAC;AAC1E,OAAO,EAAE,+BAA+B,EAAE,MAAM,uBAAuB,CAAC;AACxE,OAAO,EAKN,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAEhE,MAAM,CAAC,MAAM,YAAY,GAAG,aAAa,CAA0B,IAAI,CAAC,CAAC;AACzE,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAA6B,IAAI,CAAC,CAAC;AAC/E,MAAM,CAAC,MAAM,aAAa,GAAG,aAAa,CAA2B,IAAI,CAAC,CAAC;AAE3E,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,EAC5B,MAAM,EACN,QAAQ,GAGR,EAAE,EAAE;IACJ,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG;QAC3C,GAAG,cAAc,CAAC,MAAM,EAAE,GAAG,IAAI,kBAAkB,CAAC;QACpD,GAAG,MAAM;KACV,CAAC;IAEF,MAAM,gBAAgB,GAAG,+BAA+B,CAAC;QACvD,SAAS,EAAE,SAAS;QACpB,UAAU,EAAE,UAAU;KACvB,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,GAAG,EAAE,SAAS;QACd,gBAAgB;KACjB,CAAC,CAAC;IAEH,OAAO,CACL,KAAC,eAAe,CAAC,QAAQ,IACvB,KAAK,EAAE,EAAE,gBAAgB,EAAE,MAAM,EAAE,EAAE,SAAS,EAAE,UAAU,EAAE,EAAE,YAE9D,KAAC,aAAa,CAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,EAAE,SAAS,EAAE,EAAE,YACnE,QAAQ,GACc,GACA,CAC5B,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,GAAG,EAAE;IAClC,MAAM,eAAe,GAAG,UAAU,CAAC,eAAe,CAAC,CAAC;IACpD,MAAM,aAAa,GAAG,UAAU,CAAC,aAAa,CAAC,CAAC;IAEhD,IAAI,CAAC,eAAe,IAAI,CAAC,aAAa,EAAE,CAAC;QACvC,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;IACzE,CAAC;IACD,OAAO;QACL,GAAG,eAAe;QAClB,GAAG,aAAa;QAChB,MAAM,EAAE,EAAE,GAAG,eAAe,CAAC,MAAM,EAAE,GAAG,aAAa,CAAC,MAAM,EAAE;KAC/D,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAG,EAAE;IACrC,MAAM,eAAe,GAAG,UAAU,CAAC,eAAe,CAAC,CAAC;IACpD,IAAI,CAAC,eAAe,EAAE,CAAC;QACrB,MAAM,IAAI,KAAK,CACb,2DAA2D,CAC5D,CAAC;IACJ,CAAC;IACD,OAAO,eAAe,CAAC;AACzB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAAG,EAAE;IACnC,MAAM,aAAa,GAAG,UAAU,CAAC,aAAa,CAAC,CAAC;IAChD,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;IAC3E,CAAC;IACD,OAAO,aAAa,CAAC;AACvB,CAAC,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"context.test.d.ts","sourceRoot":"","sources":["../src/context.test.tsx"],"names":[],"mappings":""}
|
@@ -0,0 +1,75 @@
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
2
|
+
import { describe, it, expect } from "vitest";
|
3
|
+
import { renderHook } from "@testing-library/react";
|
4
|
+
import { ProofProvider, useProofContext, useProverContext, useWebProofContext, } from "./context.js";
|
5
|
+
import { DEFAULT_CONFIG, DEFAULT_CONFIG_ENV } from "./defaults.js";
|
6
|
+
import { ProofEnv } from "./types.js";
|
7
|
+
describe("Context Providers and Hooks", () => {
|
8
|
+
describe("useProofContext", () => {
|
9
|
+
it("should throw error when used outside ProofProvider", () => {
|
10
|
+
expect(() => {
|
11
|
+
renderHook(() => useProofContext());
|
12
|
+
}).toThrow("useProofContext must be used within a ProofProvider");
|
13
|
+
});
|
14
|
+
it("should provide both WebProof and Prover contexts", () => {
|
15
|
+
const config = {
|
16
|
+
proverUrl: "test-prover-url",
|
17
|
+
notaryUrl: "test-notary-url",
|
18
|
+
wsProxyUrl: "test-ws-url",
|
19
|
+
};
|
20
|
+
const wrapper = ({ children }) => (_jsx(ProofProvider, { config: config, children: children }));
|
21
|
+
const { result } = renderHook(() => useProofContext(), { wrapper });
|
22
|
+
expect(result.current.webProofProvider).toBeDefined();
|
23
|
+
expect(result.current.vlayerClient).toBeDefined();
|
24
|
+
expect(result.current.config).toEqual(config);
|
25
|
+
});
|
26
|
+
it("should use default config when env is provided", () => {
|
27
|
+
const config = {
|
28
|
+
env: ProofEnv.TESTNET,
|
29
|
+
wsProxyUrl: "test-ws-url",
|
30
|
+
};
|
31
|
+
const wrapper = ({ children }) => (_jsx(ProofProvider, { config: config, children: children }));
|
32
|
+
const { result } = renderHook(() => useProofContext(), { wrapper });
|
33
|
+
expect(result.current.config).toEqual({
|
34
|
+
...DEFAULT_CONFIG[ProofEnv.TESTNET],
|
35
|
+
...{ wsProxyUrl: config.wsProxyUrl },
|
36
|
+
});
|
37
|
+
});
|
38
|
+
it("should use proper default config when env is not provided", () => {
|
39
|
+
const config = {
|
40
|
+
proverUrl: "custom-url",
|
41
|
+
};
|
42
|
+
const wrapper = ({ children }) => (_jsx(ProofProvider, { config: config, children: children }));
|
43
|
+
const { result } = renderHook(() => useProofContext(), { wrapper });
|
44
|
+
expect(result.current.config).toEqual({
|
45
|
+
...DEFAULT_CONFIG[DEFAULT_CONFIG_ENV],
|
46
|
+
...config,
|
47
|
+
});
|
48
|
+
});
|
49
|
+
});
|
50
|
+
describe("useWebProofContext", () => {
|
51
|
+
it("should throw error when used outside WebProofProvider", () => {
|
52
|
+
expect(() => {
|
53
|
+
renderHook(() => useWebProofContext());
|
54
|
+
}).toThrow("useWebProofContext must be used within a WebProofProvider");
|
55
|
+
});
|
56
|
+
it("should return webProofContext when used within Provider", () => {
|
57
|
+
const wrapper = ({ children }) => (_jsx(ProofProvider, { children: children }));
|
58
|
+
const { result } = renderHook(() => useWebProofContext(), { wrapper });
|
59
|
+
expect(result.current.webProofProvider).toBeDefined();
|
60
|
+
});
|
61
|
+
});
|
62
|
+
describe("useProverContext", () => {
|
63
|
+
it("should throw error when used outside ProverProvider", () => {
|
64
|
+
expect(() => {
|
65
|
+
renderHook(() => useProverContext());
|
66
|
+
}).toThrow("useProverContext must be used within a ProverProvider");
|
67
|
+
});
|
68
|
+
it("should return proverContext when used within Provider", () => {
|
69
|
+
const wrapper = ({ children }) => (_jsx(ProofProvider, { children: children }));
|
70
|
+
const { result } = renderHook(() => useProverContext(), { wrapper });
|
71
|
+
expect(result.current.vlayerClient).toBeDefined();
|
72
|
+
});
|
73
|
+
});
|
74
|
+
});
|
75
|
+
//# sourceMappingURL=context.test.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"context.test.js","sourceRoot":"","sources":["../src/context.test.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { ProofEnv } from "./types.js";
|
2
|
+
export declare const DEFAULT_CONFIG: {
|
3
|
+
dev: {
|
4
|
+
proverUrl: string;
|
5
|
+
notaryUrl: string;
|
6
|
+
wsProxyUrl: string;
|
7
|
+
};
|
8
|
+
testnet: {
|
9
|
+
proverUrl: string;
|
10
|
+
notaryUrl: string;
|
11
|
+
wsProxyUrl: string;
|
12
|
+
};
|
13
|
+
prod: {
|
14
|
+
proverUrl: string;
|
15
|
+
notaryUrl: string;
|
16
|
+
wsProxyUrl: string;
|
17
|
+
};
|
18
|
+
};
|
19
|
+
export declare const DEFAULT_CONFIG_ENV = ProofEnv.TESTNET;
|
20
|
+
//# sourceMappingURL=defaults.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"defaults.d.ts","sourceRoot":"","sources":["../src/defaults.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;CAiB1B,CAAC;AAEF,eAAO,MAAM,kBAAkB,mBAAmB,CAAC"}
|
package/dist/defaults.js
ADDED
@@ -0,0 +1,21 @@
|
|
1
|
+
import { ProofEnv } from "./types.js";
|
2
|
+
export const DEFAULT_CONFIG = {
|
3
|
+
[ProofEnv.DEV]: {
|
4
|
+
proverUrl: "http://localhost:3000",
|
5
|
+
notaryUrl: "http://localhost:7047",
|
6
|
+
wsProxyUrl: "ws://localhost:55688",
|
7
|
+
},
|
8
|
+
//for now we use the same urls for testnet and prod
|
9
|
+
[ProofEnv.TESTNET]: {
|
10
|
+
proverUrl: "https://test-prover.vlayer.xyz",
|
11
|
+
notaryUrl: "https://test-notary.vlayer.xyz",
|
12
|
+
wsProxyUrl: "wss://test-wsproxy.vlayer.xyz",
|
13
|
+
},
|
14
|
+
[ProofEnv.PROD]: {
|
15
|
+
proverUrl: "https://test-prover.vlayer.xyz",
|
16
|
+
notaryUrl: "https://test-notary.vlayer.xyz",
|
17
|
+
wsProxyUrl: "wss://test-wsproxy.vlayer.xyz",
|
18
|
+
},
|
19
|
+
};
|
20
|
+
export const DEFAULT_CONFIG_ENV = ProofEnv.TESTNET;
|
21
|
+
//# sourceMappingURL=defaults.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"defaults.js","sourceRoot":"","sources":["../src/defaults.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;QACd,SAAS,EAAE,uBAAuB;QAClC,SAAS,EAAE,uBAAuB;QAClC,UAAU,EAAE,sBAAsB;KACnC;IACD,mDAAmD;IACnD,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;QAClB,SAAS,EAAE,gCAAgC;QAC3C,SAAS,EAAE,gCAAgC;QAC3C,UAAU,EAAE,+BAA+B;KAC5C;IACD,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;QACf,SAAS,EAAE,gCAAgC;QAC3C,SAAS,EAAE,gCAAgC;QAC3C,UAAU,EAAE,+BAA+B;KAC5C;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,QAAQ,CAAC,OAAO,CAAC"}
|
package/dist/index.d.ts
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
import { useWebProof } from "./useWebproof/useWebProof.js";
|
2
|
+
import { ProofProvider } from "./context.js";
|
3
|
+
import { useCallProver } from "./useCallProver/useCallProver.js";
|
4
|
+
import { useWaitForProvingResult } from "./useWaitForProvingResult/useWaitForProvingResult.js";
|
5
|
+
export { ProofProvider, useWebProof, useCallProver, useWaitForProvingResult };
|
6
|
+
export * from "./types.js";
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,uBAAuB,EAAE,MAAM,mDAAmD,CAAC;AAE5F,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,aAAa,EAAE,uBAAuB,EAAE,CAAC;AAC9E,cAAc,SAAS,CAAC"}
|
package/dist/index.js
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
import { useWebProof } from "./useWebproof/useWebProof.js";
|
2
|
+
import { ProofProvider } from "./context.js";
|
3
|
+
import { useCallProver } from "./useCallProver/useCallProver.js";
|
4
|
+
import { useWaitForProvingResult } from "./useWaitForProvingResult/useWaitForProvingResult.js";
|
5
|
+
export { ProofProvider, useWebProof, useCallProver, useWaitForProvingResult };
|
6
|
+
export * from "./types.js";
|
7
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,uBAAuB,EAAE,MAAM,mDAAmD,CAAC;AAE5F,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,aAAa,EAAE,uBAAuB,EAAE,CAAC;AAC9E,cAAc,SAAS,CAAC"}
|
package/dist/types.d.ts
ADDED
@@ -0,0 +1,35 @@
|
|
1
|
+
import { type VlayerClient, type WebProofProvider } from "@vlayer/sdk";
|
2
|
+
import { expectUrl, notarize, startPage } from "@vlayer/sdk/web_proof";
|
3
|
+
import { type WebProofRequestInput, type GetWebProofArgs } from "@vlayer/sdk";
|
4
|
+
export type ProofContextType = {
|
5
|
+
vlayerClient: VlayerClient;
|
6
|
+
webProofProvider: WebProofProvider;
|
7
|
+
config: ProofConfig;
|
8
|
+
};
|
9
|
+
export type WebProofContextType = {
|
10
|
+
webProofProvider: WebProofProvider;
|
11
|
+
config: Pick<ProofConfig, "notaryUrl" | "wsProxyUrl">;
|
12
|
+
};
|
13
|
+
export type ProverContextType = {
|
14
|
+
vlayerClient: VlayerClient;
|
15
|
+
config: Pick<ProofConfig, "proverUrl">;
|
16
|
+
};
|
17
|
+
export declare enum ProofEnv {
|
18
|
+
DEV = "dev",
|
19
|
+
TESTNET = "testnet",
|
20
|
+
PROD = "prod"
|
21
|
+
}
|
22
|
+
export type ProofConfig = {
|
23
|
+
proverUrl: string;
|
24
|
+
notaryUrl: string;
|
25
|
+
wsProxyUrl: string;
|
26
|
+
env?: ProofEnv;
|
27
|
+
};
|
28
|
+
export declare enum WebProofRequestStatus {
|
29
|
+
idle = "idle",
|
30
|
+
pending = "pending",
|
31
|
+
error = "error",
|
32
|
+
success = "success"
|
33
|
+
}
|
34
|
+
export { expectUrl, notarize, startPage, type WebProofRequestInput, type GetWebProofArgs, };
|
35
|
+
//# sourceMappingURL=types.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAAE,KAAK,gBAAgB,EAAE,MAAM,aAAa,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AACvE,OAAO,EAAE,KAAK,oBAAoB,EAAE,KAAK,eAAe,EAAE,MAAM,aAAa,CAAC;AAE9E,MAAM,MAAM,gBAAgB,GAAG;IAC7B,YAAY,EAAE,YAAY,CAAC;IAC3B,gBAAgB,EAAE,gBAAgB,CAAC;IACnC,MAAM,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,gBAAgB,EAAE,gBAAgB,CAAC;IACnC,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,YAAY,CAAC,CAAC;CACvD,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,YAAY,EAAE,YAAY,CAAC;IAC3B,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;CACxC,CAAC;AAEF,oBAAY,QAAQ;IAClB,GAAG,QAAQ;IACX,OAAO,YAAY;IACnB,IAAI,SAAS;CACd;AAED,MAAM,MAAM,WAAW,GAAG;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,QAAQ,CAAC;CAChB,CAAC;AAEF,oBAAY,qBAAqB;IAC/B,IAAI,SAAS;IACb,OAAO,YAAY;IACnB,KAAK,UAAU;IACf,OAAO,YAAY;CACpB;AAED,OAAO,EACL,SAAS,EACT,QAAQ,EACR,SAAS,EACT,KAAK,oBAAoB,EACzB,KAAK,eAAe,GACrB,CAAC"}
|
package/dist/types.js
ADDED
@@ -0,0 +1,18 @@
|
|
1
|
+
import {} from "@vlayer/sdk";
|
2
|
+
import { expectUrl, notarize, startPage } from "@vlayer/sdk/web_proof";
|
3
|
+
import {} from "@vlayer/sdk";
|
4
|
+
export var ProofEnv;
|
5
|
+
(function (ProofEnv) {
|
6
|
+
ProofEnv["DEV"] = "dev";
|
7
|
+
ProofEnv["TESTNET"] = "testnet";
|
8
|
+
ProofEnv["PROD"] = "prod";
|
9
|
+
})(ProofEnv || (ProofEnv = {}));
|
10
|
+
export var WebProofRequestStatus;
|
11
|
+
(function (WebProofRequestStatus) {
|
12
|
+
WebProofRequestStatus["idle"] = "idle";
|
13
|
+
WebProofRequestStatus["pending"] = "pending";
|
14
|
+
WebProofRequestStatus["error"] = "error";
|
15
|
+
WebProofRequestStatus["success"] = "success";
|
16
|
+
})(WebProofRequestStatus || (WebProofRequestStatus = {}));
|
17
|
+
export { expectUrl, notarize, startPage, };
|
18
|
+
//# sourceMappingURL=types.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4C,MAAM,aAAa,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AACvE,OAAO,EAAmD,MAAM,aAAa,CAAC;AAkB9E,MAAM,CAAN,IAAY,QAIX;AAJD,WAAY,QAAQ;IAClB,uBAAW,CAAA;IACX,+BAAmB,CAAA;IACnB,yBAAa,CAAA;AACf,CAAC,EAJW,QAAQ,KAAR,QAAQ,QAInB;AASD,MAAM,CAAN,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC/B,sCAAa,CAAA;IACb,4CAAmB,CAAA;IACnB,wCAAe,CAAA;IACf,4CAAmB,CAAA;AACrB,CAAC,EALW,qBAAqB,KAArB,qBAAqB,QAKhC;AAED,OAAO,EACL,SAAS,EACT,QAAQ,EACR,SAAS,GAGV,CAAC"}
|
@@ -0,0 +1,19 @@
|
|
1
|
+
import { type Abi, type AbiStateMutability, type ContractFunctionArgs, type ContractFunctionName } from "viem";
|
2
|
+
import { type BrandedHash, type ProveArgs } from "@vlayer/sdk";
|
3
|
+
export declare enum ProverStatus {
|
4
|
+
Idle = "Idle",
|
5
|
+
Pending = "Pending",
|
6
|
+
Ready = "Ready",
|
7
|
+
Error = "Error"
|
8
|
+
}
|
9
|
+
export declare const useCallProver: (proveArgs: Omit<ProveArgs<Abi, ContractFunctionName<Abi>>, "args">) => {
|
10
|
+
callProver: (args: ContractFunctionArgs<Abi, AbiStateMutability, string>) => Promise<void>;
|
11
|
+
status: ProverStatus;
|
12
|
+
error: Error | null;
|
13
|
+
data: BrandedHash<Abi, string> | null;
|
14
|
+
isIdle: boolean;
|
15
|
+
isPending: boolean;
|
16
|
+
isReady: boolean;
|
17
|
+
isError: boolean;
|
18
|
+
};
|
19
|
+
//# sourceMappingURL=useCallProver.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"useCallProver.d.ts","sourceRoot":"","sources":["../../src/useCallProver/useCallProver.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,GAAG,EACR,KAAK,kBAAkB,EACvB,KAAK,oBAAoB,EACzB,KAAK,oBAAoB,EAC1B,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,KAAK,WAAW,EAAE,KAAK,SAAS,EAAE,MAAM,aAAa,CAAC;AAI/D,oBAAY,YAAY;IACtB,IAAI,SAAS;IACb,OAAO,YAAY;IACnB,KAAK,UAAU;IACf,KAAK,UAAU;CAChB;AAED,eAAO,MAAM,aAAa,cACb,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,oBAAoB,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC;uBAa1D,oBAAoB,CAAC,GAAG,EAAE,kBAAkB,EAAE,MAAM,CAAC;;;;;;;;CA2B9D,CAAC"}
|
@@ -0,0 +1,49 @@
|
|
1
|
+
import { useState } from "react";
|
2
|
+
import {} from "viem";
|
3
|
+
import {} from "@vlayer/sdk";
|
4
|
+
import { useProofContext } from "../context.js";
|
5
|
+
import { useChainId } from "wagmi";
|
6
|
+
export var ProverStatus;
|
7
|
+
(function (ProverStatus) {
|
8
|
+
ProverStatus["Idle"] = "Idle";
|
9
|
+
ProverStatus["Pending"] = "Pending";
|
10
|
+
ProverStatus["Ready"] = "Ready";
|
11
|
+
ProverStatus["Error"] = "Error";
|
12
|
+
})(ProverStatus || (ProverStatus = {}));
|
13
|
+
export const useCallProver = (proveArgs) => {
|
14
|
+
// read vlayer client from context
|
15
|
+
const { vlayerClient } = useProofContext();
|
16
|
+
// read chainId from wagmi
|
17
|
+
const chainId = useChainId();
|
18
|
+
// state
|
19
|
+
const [status, setStatus] = useState(ProverStatus.Idle);
|
20
|
+
const [error, setError] = useState(null);
|
21
|
+
const [hash, setHash] = useState(null);
|
22
|
+
const callProver = async (args) => {
|
23
|
+
setStatus(ProverStatus.Pending);
|
24
|
+
try {
|
25
|
+
const hash = await vlayerClient.prove({
|
26
|
+
...proveArgs,
|
27
|
+
args,
|
28
|
+
chainId,
|
29
|
+
});
|
30
|
+
setHash(hash);
|
31
|
+
setStatus(ProverStatus.Ready);
|
32
|
+
}
|
33
|
+
catch (e) {
|
34
|
+
setError(e);
|
35
|
+
setStatus(ProverStatus.Error);
|
36
|
+
}
|
37
|
+
};
|
38
|
+
return {
|
39
|
+
callProver,
|
40
|
+
status,
|
41
|
+
error,
|
42
|
+
data: hash,
|
43
|
+
isIdle: status === ProverStatus.Idle,
|
44
|
+
isPending: status === ProverStatus.Pending,
|
45
|
+
isReady: status === ProverStatus.Ready,
|
46
|
+
isError: status === ProverStatus.Error,
|
47
|
+
};
|
48
|
+
};
|
49
|
+
//# sourceMappingURL=useCallProver.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"useCallProver.js","sourceRoot":"","sources":["../../src/useCallProver/useCallProver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAKN,MAAM,MAAM,CAAC;AACd,OAAO,EAAoC,MAAM,aAAa,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAEnC,MAAM,CAAN,IAAY,YAKX;AALD,WAAY,YAAY;IACtB,6BAAa,CAAA;IACb,mCAAmB,CAAA;IACnB,+BAAe,CAAA;IACf,+BAAe,CAAA;AACjB,CAAC,EALW,YAAY,KAAZ,YAAY,QAKvB;AAED,MAAM,CAAC,MAAM,aAAa,GAAG,CAC3B,SAAkE,EAClE,EAAE;IACF,kCAAkC;IAClC,MAAM,EAAE,YAAY,EAAE,GAAG,eAAe,EAAE,CAAC;IAC3C,0BAA0B;IAC1B,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAE7B,QAAQ;IACR,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAe,YAAY,CAAC,IAAI,CAAC,CAAC;IACtE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IACvD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAkC,IAAI,CAAC,CAAC;IAExE,MAAM,UAAU,GAAG,KAAK,EACtB,IAA2D,EAC3D,EAAE;QACF,SAAS,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAChC,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,YAAY,CAAC,KAAK,CAAC;gBACpC,GAAG,SAAS;gBACZ,IAAI;gBACJ,OAAO;aACR,CAAC,CAAC;YACH,OAAO,CAAC,IAAI,CAAC,CAAC;YACd,SAAS,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,QAAQ,CAAC,CAAU,CAAC,CAAC;YACrB,SAAS,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC;IACH,CAAC,CAAC;IAEF,OAAO;QACL,UAAU;QACV,MAAM;QACN,KAAK;QACL,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,MAAM,KAAK,YAAY,CAAC,IAAI;QACpC,SAAS,EAAE,MAAM,KAAK,YAAY,CAAC,OAAO;QAC1C,OAAO,EAAE,MAAM,KAAK,YAAY,CAAC,KAAK;QACtC,OAAO,EAAE,MAAM,KAAK,YAAY,CAAC,KAAK;KACvC,CAAC;AACJ,CAAC,CAAC"}
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import type { BrandedHash } from "@vlayer/sdk";
|
2
|
+
import type { Abi } from "viem";
|
3
|
+
export declare enum WaitForProvingResultStatus {
|
4
|
+
Idle = "Idle",
|
5
|
+
Pending = "Pending",
|
6
|
+
Ready = "Ready",
|
7
|
+
Error = "Error"
|
8
|
+
}
|
9
|
+
export declare const useWaitForProvingResult: (hash: BrandedHash<Abi, string> | null) => {
|
10
|
+
status: WaitForProvingResultStatus;
|
11
|
+
error: Error | null;
|
12
|
+
isIdle: boolean;
|
13
|
+
isPending: boolean;
|
14
|
+
isReady: boolean;
|
15
|
+
isError: boolean;
|
16
|
+
data: unknown;
|
17
|
+
};
|
18
|
+
//# sourceMappingURL=useWaitForProvingResult.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"useWaitForProvingResult.d.ts","sourceRoot":"","sources":["../../src/useWaitForProvingResult/useWaitForProvingResult.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG/C,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAEhC,oBAAY,0BAA0B;IACpC,IAAI,SAAS;IACb,OAAO,YAAY;IACnB,KAAK,UAAU;IACf,KAAK,UAAU;CAChB;AAED,eAAO,MAAM,uBAAuB,SAC5B,WAAW,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,IAAI;;;;;;;;CAkCtC,CAAC"}
|
@@ -0,0 +1,41 @@
|
|
1
|
+
import { useState, useEffect } from "react";
|
2
|
+
import { useProofContext } from "../context.js";
|
3
|
+
export var WaitForProvingResultStatus;
|
4
|
+
(function (WaitForProvingResultStatus) {
|
5
|
+
WaitForProvingResultStatus["Idle"] = "Idle";
|
6
|
+
WaitForProvingResultStatus["Pending"] = "Pending";
|
7
|
+
WaitForProvingResultStatus["Ready"] = "Ready";
|
8
|
+
WaitForProvingResultStatus["Error"] = "Error";
|
9
|
+
})(WaitForProvingResultStatus || (WaitForProvingResultStatus = {}));
|
10
|
+
export const useWaitForProvingResult = (hash) => {
|
11
|
+
const { vlayerClient } = useProofContext();
|
12
|
+
const [status, setStatus] = useState(WaitForProvingResultStatus.Idle);
|
13
|
+
const [error, setError] = useState(null);
|
14
|
+
const [result, setResult] = useState(null);
|
15
|
+
useEffect(() => {
|
16
|
+
if (!hash) {
|
17
|
+
return;
|
18
|
+
}
|
19
|
+
setStatus(WaitForProvingResultStatus.Pending);
|
20
|
+
vlayerClient
|
21
|
+
.waitForProvingResult({ hash })
|
22
|
+
.then((result) => {
|
23
|
+
setStatus(WaitForProvingResultStatus.Ready);
|
24
|
+
setResult(result);
|
25
|
+
})
|
26
|
+
.catch((e) => {
|
27
|
+
setError(e);
|
28
|
+
setStatus(WaitForProvingResultStatus.Error);
|
29
|
+
});
|
30
|
+
}, [JSON.stringify(hash)]);
|
31
|
+
return {
|
32
|
+
status,
|
33
|
+
error,
|
34
|
+
isIdle: status === WaitForProvingResultStatus.Idle,
|
35
|
+
isPending: status === WaitForProvingResultStatus.Pending,
|
36
|
+
isReady: status === WaitForProvingResultStatus.Ready,
|
37
|
+
isError: status === WaitForProvingResultStatus.Error,
|
38
|
+
data: result,
|
39
|
+
};
|
40
|
+
};
|
41
|
+
//# sourceMappingURL=useWaitForProvingResult.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"useWaitForProvingResult.js","sourceRoot":"","sources":["../../src/useWaitForProvingResult/useWaitForProvingResult.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAG7C,MAAM,CAAN,IAAY,0BAKX;AALD,WAAY,0BAA0B;IACpC,2CAAa,CAAA;IACb,iDAAmB,CAAA;IACnB,6CAAe,CAAA;IACf,6CAAe,CAAA;AACjB,CAAC,EALW,0BAA0B,KAA1B,0BAA0B,QAKrC;AAED,MAAM,CAAC,MAAM,uBAAuB,GAAG,CACrC,IAAqC,EACrC,EAAE;IACF,MAAM,EAAE,YAAY,EAAE,GAAG,eAAe,EAAE,CAAC;IAC3C,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAClC,0BAA0B,CAAC,IAAI,CAChC,CAAC;IACF,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IACvD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAU,IAAI,CAAC,CAAC;IACpD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,OAAO;QACT,CAAC;QACD,SAAS,CAAC,0BAA0B,CAAC,OAAO,CAAC,CAAC;QAC9C,YAAY;aACT,oBAAoB,CAAC,EAAE,IAAI,EAAE,CAAC;aAC9B,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;YACf,SAAS,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;YAC5C,SAAS,CAAC,MAAM,CAAC,CAAC;QACpB,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;YACX,QAAQ,CAAC,CAAU,CAAC,CAAC;YACrB,SAAS,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;IACP,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAE3B,OAAO;QACL,MAAM;QACN,KAAK;QACL,MAAM,EAAE,MAAM,KAAK,0BAA0B,CAAC,IAAI;QAClD,SAAS,EAAE,MAAM,KAAK,0BAA0B,CAAC,OAAO;QACxD,OAAO,EAAE,MAAM,KAAK,0BAA0B,CAAC,KAAK;QACpD,OAAO,EAAE,MAAM,KAAK,0BAA0B,CAAC,KAAK;QACpD,IAAI,EAAE,MAAM;KACb,CAAC;AACJ,CAAC,CAAC"}
|
@@ -0,0 +1,25 @@
|
|
1
|
+
import type { PresentationJSON, ZkProvingStatus } from "@vlayer/sdk";
|
2
|
+
import { ExtensionMessageType, type ExtensionMessage, type WebProofProvider } from "@vlayer/sdk";
|
3
|
+
export declare class MockExtensionWebProofProvider implements WebProofProvider {
|
4
|
+
private mockBehavior;
|
5
|
+
private listeners;
|
6
|
+
constructor(mockBehavior?: {
|
7
|
+
shouldSucceed?: boolean;
|
8
|
+
delayMs?: number;
|
9
|
+
mockProof?: PresentationJSON;
|
10
|
+
mockError?: string;
|
11
|
+
});
|
12
|
+
notifyZkProvingStatus(status: ZkProvingStatus): void;
|
13
|
+
addEventListeners<T extends ExtensionMessageType>(messageType: T, listener: (args: Extract<ExtensionMessage, {
|
14
|
+
type: T;
|
15
|
+
}>) => void): void;
|
16
|
+
requestWebProof(): void;
|
17
|
+
getWebProof(): Promise<{
|
18
|
+
presentationJson: PresentationJSON;
|
19
|
+
decodedTranscript: {
|
20
|
+
sent: string;
|
21
|
+
recv: string;
|
22
|
+
};
|
23
|
+
}>;
|
24
|
+
}
|
25
|
+
//# sourceMappingURL=extension.mock.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"extension.mock.d.ts","sourceRoot":"","sources":["../../src/useWebproof/extension.mock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAErE,OAAO,EACL,oBAAoB,EACpB,KAAK,gBAAgB,EACrB,KAAK,gBAAgB,EACtB,MAAM,aAAa,CAAC;AAErB,qBAAa,6BAA8B,YAAW,gBAAgB;IAWlE,OAAO,CAAC,YAAY;IAVtB,OAAO,CAAC,SAAS,CAOV;gBAGG,YAAY,GAAE;QACpB,aAAa,CAAC,EAAE,OAAO,CAAC;QACxB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,SAAS,CAAC,EAAE,gBAAgB,CAAC;QAC7B,SAAS,CAAC,EAAE,MAAM,CAAC;KACoB;IAGpC,qBAAqB,CAAC,MAAM,EAAE,eAAe,GAAG,IAAI;IAIpD,iBAAiB,CAAC,CAAC,SAAS,oBAAoB,EACrD,WAAW,EAAE,CAAC,EACd,QAAQ,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,gBAAgB,EAAE;QAAE,IAAI,EAAE,CAAC,CAAA;KAAE,CAAC,KAAK,IAAI,GAC/D,IAAI;IASA,eAAe,IAAI,IAAI;IAkCjB,WAAW,IAAI,OAAO,CAAC;QAClC,gBAAgB,EAAE,gBAAgB,CAAC;QACnC,iBAAiB,EAAE;YACjB,IAAI,EAAE,MAAM,CAAC;YACb,IAAI,EAAE,MAAM,CAAC;SACd,CAAC;KACH,CAAC;CAmBH"}
|
@@ -0,0 +1,65 @@
|
|
1
|
+
import { ExtensionMessageType, } from "@vlayer/sdk";
|
2
|
+
export class MockExtensionWebProofProvider {
|
3
|
+
mockBehavior;
|
4
|
+
listeners = {};
|
5
|
+
constructor(mockBehavior = { shouldSucceed: true, delayMs: 100 }) {
|
6
|
+
this.mockBehavior = mockBehavior;
|
7
|
+
}
|
8
|
+
notifyZkProvingStatus(status) {
|
9
|
+
console.log("Mock: ZK proving status notification", status);
|
10
|
+
}
|
11
|
+
addEventListeners(messageType, listener) {
|
12
|
+
if (!this.listeners[messageType]) {
|
13
|
+
this.listeners[messageType] = [];
|
14
|
+
}
|
15
|
+
this.listeners[messageType].push(listener);
|
16
|
+
}
|
17
|
+
requestWebProof() {
|
18
|
+
// Simulate async response
|
19
|
+
setTimeout(() => {
|
20
|
+
if (this.mockBehavior.shouldSucceed) {
|
21
|
+
const mockProofDoneMessage = {
|
22
|
+
type: ExtensionMessageType.ProofDone,
|
23
|
+
payload: {
|
24
|
+
presentationJson: this.mockBehavior.mockProof ||
|
25
|
+
{ mock: "proof" },
|
26
|
+
decodedTranscript: {
|
27
|
+
sent: "mock sent",
|
28
|
+
recv: "mock recv",
|
29
|
+
},
|
30
|
+
},
|
31
|
+
};
|
32
|
+
this.listeners[ExtensionMessageType.ProofDone]?.forEach((listener) => {
|
33
|
+
console.log("Mock: ProofDone message", mockProofDoneMessage);
|
34
|
+
listener(mockProofDoneMessage);
|
35
|
+
});
|
36
|
+
}
|
37
|
+
else {
|
38
|
+
const mockErrorMessage = {
|
39
|
+
type: ExtensionMessageType.ProofError,
|
40
|
+
payload: {
|
41
|
+
error: this.mockBehavior.mockError || "Mock error occurred",
|
42
|
+
},
|
43
|
+
};
|
44
|
+
this.listeners[ExtensionMessageType.ProofError]?.forEach((listener) => listener(mockErrorMessage));
|
45
|
+
}
|
46
|
+
}, this.mockBehavior.delayMs);
|
47
|
+
}
|
48
|
+
async getWebProof() {
|
49
|
+
await new Promise((resolve) => setTimeout(resolve, this.mockBehavior.delayMs));
|
50
|
+
if (this.mockBehavior.shouldSucceed) {
|
51
|
+
return {
|
52
|
+
presentationJson: this.mockBehavior.mockProof ||
|
53
|
+
{ mock: "proof" },
|
54
|
+
decodedTranscript: {
|
55
|
+
sent: "mock sent",
|
56
|
+
recv: "mock recv",
|
57
|
+
},
|
58
|
+
};
|
59
|
+
}
|
60
|
+
else {
|
61
|
+
throw new Error(this.mockBehavior.mockError || "Mock error occurred");
|
62
|
+
}
|
63
|
+
}
|
64
|
+
}
|
65
|
+
//# sourceMappingURL=extension.mock.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"extension.mock.js","sourceRoot":"","sources":["../../src/useWebproof/extension.mock.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,oBAAoB,GAGrB,MAAM,aAAa,CAAC;AAErB,MAAM,OAAO,6BAA6B;IAW9B;IAVF,SAAS,GAOb,EAAE,CAAC;IAEP,YACU,eAKJ,EAAE,aAAa,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,EAAE;QALjC,iBAAY,GAAZ,YAAY,CAKqB;IACxC,CAAC;IAEG,qBAAqB,CAAC,MAAuB;QAClD,OAAO,CAAC,GAAG,CAAC,sCAAsC,EAAE,MAAM,CAAC,CAAC;IAC9D,CAAC;IAEM,iBAAiB,CACtB,WAAc,EACd,QAAgE;QAEhE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,IAAI,CAC9B,QAA4C,CAC7C,CAAC;IACJ,CAAC;IAEM,eAAe;QACpB,0BAA0B;QAC1B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;gBACpC,MAAM,oBAAoB,GAAqB;oBAC7C,IAAI,EAAE,oBAAoB,CAAC,SAAS;oBACpC,OAAO,EAAE;wBACP,gBAAgB,EACd,IAAI,CAAC,YAAY,CAAC,SAAS;4BAC1B,EAAE,IAAI,EAAE,OAAO,EAAkC;wBACpD,iBAAiB,EAAE;4BACjB,IAAI,EAAE,WAAW;4BACjB,IAAI,EAAE,WAAW;yBAClB;qBACF;iBACF,CAAC;gBACF,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;oBACnE,OAAO,CAAC,GAAG,CAAC,yBAAyB,EAAE,oBAAoB,CAAC,CAAC;oBAC7D,QAAQ,CAAC,oBAAoB,CAAC,CAAC;gBACjC,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,MAAM,gBAAgB,GAAqB;oBACzC,IAAI,EAAE,oBAAoB,CAAC,UAAU;oBACrC,OAAO,EAAE;wBACP,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,SAAS,IAAI,qBAAqB;qBAC5D;iBACF,CAAC;gBACF,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,UAAU,CAAC,EAAE,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE,CACpE,QAAQ,CAAC,gBAAgB,CAAC,CAC3B,CAAC;YACJ,CAAC;QACH,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAEM,KAAK,CAAC,WAAW;QAOtB,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAC5B,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAC/C,CAAC;QAEF,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;YACpC,OAAO;gBACL,gBAAgB,EACd,IAAI,CAAC,YAAY,CAAC,SAAS;oBAC1B,EAAE,IAAI,EAAE,OAAO,EAAkC;gBACpD,iBAAiB,EAAE;oBACjB,IAAI,EAAE,WAAW;oBACjB,IAAI,EAAE,WAAW;iBAClB;aACF,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,IAAI,qBAAqB,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;CACF"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import { type Abi, type ContractFunctionName } from "viem";
|
2
|
+
import { WebProofRequestStatus } from "../types.js";
|
3
|
+
import { type GetWebProofArgs } from "@vlayer/sdk";
|
4
|
+
export declare const useWebProof: (webProofRequest: GetWebProofArgs<Abi, ContractFunctionName>) => {
|
5
|
+
webProof: {
|
6
|
+
webProofJson: string;
|
7
|
+
} | null;
|
8
|
+
error: Error | null;
|
9
|
+
status: WebProofRequestStatus;
|
10
|
+
isIdle: boolean;
|
11
|
+
isPending: boolean;
|
12
|
+
isError: boolean;
|
13
|
+
isSuccess: boolean;
|
14
|
+
requestWebProof: () => void;
|
15
|
+
};
|
16
|
+
//# sourceMappingURL=useWebProof.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"useWebProof.d.ts","sourceRoot":"","sources":["../../src/useWebproof/useWebProof.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,GAAG,EAAE,KAAK,oBAAoB,EAAE,MAAM,MAAM,CAAC;AAE3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAwB,KAAK,eAAe,EAAE,MAAM,aAAa,CAAC;AAEzE,eAAO,MAAM,WAAW,oBACL,eAAe,CAAC,GAAG,EAAE,oBAAoB,CAAC;;sBAI3C,MAAM;;;;;;;;;CAwCvB,CAAC"}
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { useEffect, useState } from "react";
|
2
|
+
import {} from "viem";
|
3
|
+
import { useProofContext } from "../context.js";
|
4
|
+
import { WebProofRequestStatus } from "../types.js";
|
5
|
+
import { ExtensionMessageType } from "@vlayer/sdk";
|
6
|
+
export const useWebProof = (webProofRequest) => {
|
7
|
+
const { webProofProvider } = useProofContext();
|
8
|
+
const [webProof, setWebProof] = useState(null);
|
9
|
+
const [error, setError] = useState(null);
|
10
|
+
const [status, setStatus] = useState(WebProofRequestStatus.idle);
|
11
|
+
useEffect(() => {
|
12
|
+
webProofProvider.addEventListeners(ExtensionMessageType.ProofDone, ({ payload: { presentationJson } }) => {
|
13
|
+
setWebProof({
|
14
|
+
webProofJson: JSON.stringify({ presentationJson: presentationJson }),
|
15
|
+
});
|
16
|
+
setStatus(WebProofRequestStatus.success);
|
17
|
+
});
|
18
|
+
webProofProvider.addEventListeners(ExtensionMessageType.ProofError, ({ payload: { error } }) => {
|
19
|
+
setError(new Error(error));
|
20
|
+
setStatus(WebProofRequestStatus.error);
|
21
|
+
});
|
22
|
+
}, []);
|
23
|
+
return {
|
24
|
+
webProof,
|
25
|
+
error,
|
26
|
+
status,
|
27
|
+
isIdle: status === WebProofRequestStatus.idle,
|
28
|
+
isPending: status === WebProofRequestStatus.pending,
|
29
|
+
isError: status === WebProofRequestStatus.error,
|
30
|
+
isSuccess: status === WebProofRequestStatus.success,
|
31
|
+
requestWebProof: () => {
|
32
|
+
setStatus(WebProofRequestStatus.pending);
|
33
|
+
webProofProvider.requestWebProof(webProofRequest);
|
34
|
+
},
|
35
|
+
};
|
36
|
+
};
|
37
|
+
//# sourceMappingURL=useWebProof.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"useWebProof.js","sourceRoot":"","sources":["../../src/useWebproof/useWebProof.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAuC,MAAM,MAAM,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAwB,MAAM,aAAa,CAAC;AAEzE,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,eAA2D,EAC3D,EAAE;IACF,MAAM,EAAE,gBAAgB,EAAE,GAAG,eAAe,EAAE,CAAC;IAC/C,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAE9B,IAAI,CAAC,CAAC;IAChB,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IACvD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAClC,qBAAqB,CAAC,IAAI,CAC3B,CAAC;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,gBAAgB,CAAC,iBAAiB,CAChC,oBAAoB,CAAC,SAAS,EAC9B,CAAC,EAAE,OAAO,EAAE,EAAE,gBAAgB,EAAE,EAAE,EAAE,EAAE;YACpC,WAAW,CAAC;gBACV,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,CAAC;aACrE,CAAC,CAAC;YACH,SAAS,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;QAC3C,CAAC,CACF,CAAC;QAEF,gBAAgB,CAAC,iBAAiB,CAChC,oBAAoB,CAAC,UAAU,EAC/B,CAAC,EAAE,OAAO,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE;YACzB,QAAQ,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;YAC3B,SAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QACzC,CAAC,CACF,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO;QACL,QAAQ;QACR,KAAK;QACL,MAAM;QACN,MAAM,EAAE,MAAM,KAAK,qBAAqB,CAAC,IAAI;QAC7C,SAAS,EAAE,MAAM,KAAK,qBAAqB,CAAC,OAAO;QACnD,OAAO,EAAE,MAAM,KAAK,qBAAqB,CAAC,KAAK;QAC/C,SAAS,EAAE,MAAM,KAAK,qBAAqB,CAAC,OAAO;QACnD,eAAe,EAAE,GAAG,EAAE;YACpB,SAAS,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;YACzC,gBAAgB,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;QACpD,CAAC;KACF,CAAC;AACJ,CAAC,CAAC"}
|