@zerodev/wallet-core 0.0.1-alpha.10
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/README.md +310 -0
- package/dist/_cjs/actions/auth/authenticateWithEmail.js +17 -0
- package/dist/_cjs/actions/auth/authenticateWithEmail.js.map +1 -0
- package/dist/_cjs/actions/auth/authenticateWithOAuth.js +13 -0
- package/dist/_cjs/actions/auth/authenticateWithOAuth.js.map +1 -0
- package/dist/_cjs/actions/auth/getAuthProxyConfigId.js +10 -0
- package/dist/_cjs/actions/auth/getAuthProxyConfigId.js.map +1 -0
- package/dist/_cjs/actions/auth/getUserEmail.js +19 -0
- package/dist/_cjs/actions/auth/getUserEmail.js.map +1 -0
- package/dist/_cjs/actions/auth/getWhoami.js +15 -0
- package/dist/_cjs/actions/auth/getWhoami.js.map +1 -0
- package/dist/_cjs/actions/auth/index.js +22 -0
- package/dist/_cjs/actions/auth/index.js.map +1 -0
- package/dist/_cjs/actions/auth/loginWithOTP.js +15 -0
- package/dist/_cjs/actions/auth/loginWithOTP.js.map +1 -0
- package/dist/_cjs/actions/auth/loginWithStamp.js +39 -0
- package/dist/_cjs/actions/auth/loginWithStamp.js.map +1 -0
- package/dist/_cjs/actions/auth/registerWithOTP.js +16 -0
- package/dist/_cjs/actions/auth/registerWithOTP.js.map +1 -0
- package/dist/_cjs/actions/auth/registerWithPasskey.js +17 -0
- package/dist/_cjs/actions/auth/registerWithPasskey.js.map +1 -0
- package/dist/_cjs/actions/index.js +17 -0
- package/dist/_cjs/actions/index.js.map +1 -0
- package/dist/_cjs/actions/wallet/getUserWallet.js +18 -0
- package/dist/_cjs/actions/wallet/getUserWallet.js.map +1 -0
- package/dist/_cjs/actions/wallet/index.js +10 -0
- package/dist/_cjs/actions/wallet/index.js.map +1 -0
- package/dist/_cjs/actions/wallet/signRawPayload.js +27 -0
- package/dist/_cjs/actions/wallet/signRawPayload.js.map +1 -0
- package/dist/_cjs/actions/wallet/signTransaction.js +26 -0
- package/dist/_cjs/actions/wallet/signTransaction.js.map +1 -0
- package/dist/_cjs/adapters/viem.js +92 -0
- package/dist/_cjs/adapters/viem.js.map +1 -0
- package/dist/_cjs/client/authProxy.js +31 -0
- package/dist/_cjs/client/authProxy.js.map +1 -0
- package/dist/_cjs/client/createClient.js +49 -0
- package/dist/_cjs/client/createClient.js.map +1 -0
- package/dist/_cjs/client/decorators/client.js +23 -0
- package/dist/_cjs/client/decorators/client.js.map +1 -0
- package/dist/_cjs/client/index.js +11 -0
- package/dist/_cjs/client/index.js.map +1 -0
- package/dist/_cjs/client/transports/createTransport.js +31 -0
- package/dist/_cjs/client/transports/createTransport.js.map +1 -0
- package/dist/_cjs/client/transports/rest.js +104 -0
- package/dist/_cjs/client/transports/rest.js.map +1 -0
- package/dist/_cjs/client/types.js +3 -0
- package/dist/_cjs/client/types.js.map +1 -0
- package/dist/_cjs/constants.js +9 -0
- package/dist/_cjs/constants.js.map +1 -0
- package/dist/_cjs/core/createZeroDevWallet.js +302 -0
- package/dist/_cjs/core/createZeroDevWallet.js.map +1 -0
- package/dist/_cjs/errors/request.js +61 -0
- package/dist/_cjs/errors/request.js.map +1 -0
- package/dist/_cjs/index.js +35 -0
- package/dist/_cjs/index.js.map +1 -0
- package/dist/_cjs/package.json +1 -0
- package/dist/_cjs/polyfills/window.js +26 -0
- package/dist/_cjs/polyfills/window.js.map +1 -0
- package/dist/_cjs/stampers/iframeStamper.js +35 -0
- package/dist/_cjs/stampers/iframeStamper.js.map +1 -0
- package/dist/_cjs/stampers/index.js +10 -0
- package/dist/_cjs/stampers/index.js.map +1 -0
- package/dist/_cjs/stampers/indexedDbStamper.js +23 -0
- package/dist/_cjs/stampers/indexedDbStamper.js.map +1 -0
- package/dist/_cjs/stampers/types.js +3 -0
- package/dist/_cjs/stampers/types.js.map +1 -0
- package/dist/_cjs/stampers/webauthnStamper.js +17 -0
- package/dist/_cjs/stampers/webauthnStamper.js.map +1 -0
- package/dist/_cjs/storage/adapters.js +18 -0
- package/dist/_cjs/storage/adapters.js.map +1 -0
- package/dist/_cjs/storage/manager.js +108 -0
- package/dist/_cjs/storage/manager.js.map +1 -0
- package/dist/_cjs/types/session.js +9 -0
- package/dist/_cjs/types/session.js.map +1 -0
- package/dist/_cjs/utils/buildClientSignature.js +39 -0
- package/dist/_cjs/utils/buildClientSignature.js.map +1 -0
- package/dist/_cjs/utils/derToRawSignature.js +63 -0
- package/dist/_cjs/utils/derToRawSignature.js.map +1 -0
- package/dist/_cjs/utils/exportPrivateKey.js +55 -0
- package/dist/_cjs/utils/exportPrivateKey.js.map +1 -0
- package/dist/_cjs/utils/exportWallet.js +70 -0
- package/dist/_cjs/utils/exportWallet.js.map +1 -0
- package/dist/_cjs/utils/utils.js +75 -0
- package/dist/_cjs/utils/utils.js.map +1 -0
- package/dist/_esm/actions/auth/authenticateWithEmail.js +18 -0
- package/dist/_esm/actions/auth/authenticateWithEmail.js.map +1 -0
- package/dist/_esm/actions/auth/authenticateWithOAuth.js +29 -0
- package/dist/_esm/actions/auth/authenticateWithOAuth.js.map +1 -0
- package/dist/_esm/actions/auth/getAuthProxyConfigId.js +13 -0
- package/dist/_esm/actions/auth/getAuthProxyConfigId.js.map +1 -0
- package/dist/_esm/actions/auth/getUserEmail.js +33 -0
- package/dist/_esm/actions/auth/getUserEmail.js.map +1 -0
- package/dist/_esm/actions/auth/getWhoami.js +28 -0
- package/dist/_esm/actions/auth/getWhoami.js.map +1 -0
- package/dist/_esm/actions/auth/index.js +10 -0
- package/dist/_esm/actions/auth/index.js.map +1 -0
- package/dist/_esm/actions/auth/loginWithOTP.js +38 -0
- package/dist/_esm/actions/auth/loginWithOTP.js.map +1 -0
- package/dist/_esm/actions/auth/loginWithStamp.js +52 -0
- package/dist/_esm/actions/auth/loginWithStamp.js.map +1 -0
- package/dist/_esm/actions/auth/registerWithOTP.js +35 -0
- package/dist/_esm/actions/auth/registerWithOTP.js.map +1 -0
- package/dist/_esm/actions/auth/registerWithPasskey.js +36 -0
- package/dist/_esm/actions/auth/registerWithPasskey.js.map +1 -0
- package/dist/_esm/actions/index.js +5 -0
- package/dist/_esm/actions/index.js.map +1 -0
- package/dist/_esm/actions/wallet/getUserWallet.js +31 -0
- package/dist/_esm/actions/wallet/getUserWallet.js.map +1 -0
- package/dist/_esm/actions/wallet/index.js +4 -0
- package/dist/_esm/actions/wallet/index.js.map +1 -0
- package/dist/_esm/actions/wallet/signRawPayload.js +42 -0
- package/dist/_esm/actions/wallet/signRawPayload.js.map +1 -0
- package/dist/_esm/actions/wallet/signTransaction.js +41 -0
- package/dist/_esm/actions/wallet/signTransaction.js.map +1 -0
- package/dist/_esm/adapters/viem.js +94 -0
- package/dist/_esm/adapters/viem.js.map +1 -0
- package/dist/_esm/client/authProxy.js +41 -0
- package/dist/_esm/client/authProxy.js.map +1 -0
- package/dist/_esm/client/createClient.js +60 -0
- package/dist/_esm/client/createClient.js.map +1 -0
- package/dist/_esm/client/decorators/client.js +44 -0
- package/dist/_esm/client/decorators/client.js.map +1 -0
- package/dist/_esm/client/index.js +4 -0
- package/dist/_esm/client/index.js.map +1 -0
- package/dist/_esm/client/transports/createTransport.js +33 -0
- package/dist/_esm/client/transports/createTransport.js.map +1 -0
- package/dist/_esm/client/transports/rest.js +103 -0
- package/dist/_esm/client/transports/rest.js.map +1 -0
- package/dist/_esm/client/types.js +2 -0
- package/dist/_esm/client/types.js.map +1 -0
- package/dist/_esm/constants.js +6 -0
- package/dist/_esm/constants.js.map +1 -0
- package/dist/_esm/core/createZeroDevWallet.js +308 -0
- package/dist/_esm/core/createZeroDevWallet.js.map +1 -0
- package/dist/_esm/errors/request.js +60 -0
- package/dist/_esm/errors/request.js.map +1 -0
- package/dist/_esm/index.js +23 -0
- package/dist/_esm/index.js.map +1 -0
- package/dist/_esm/package.json +1 -0
- package/dist/_esm/polyfills/window.js +24 -0
- package/dist/_esm/polyfills/window.js.map +1 -0
- package/dist/_esm/stampers/iframeStamper.js +32 -0
- package/dist/_esm/stampers/iframeStamper.js.map +1 -0
- package/dist/_esm/stampers/index.js +4 -0
- package/dist/_esm/stampers/index.js.map +1 -0
- package/dist/_esm/stampers/indexedDbStamper.js +20 -0
- package/dist/_esm/stampers/indexedDbStamper.js.map +1 -0
- package/dist/_esm/stampers/types.js +2 -0
- package/dist/_esm/stampers/types.js.map +1 -0
- package/dist/_esm/stampers/webauthnStamper.js +15 -0
- package/dist/_esm/stampers/webauthnStamper.js.map +1 -0
- package/dist/_esm/storage/adapters.js +15 -0
- package/dist/_esm/storage/adapters.js.map +1 -0
- package/dist/_esm/storage/manager.js +118 -0
- package/dist/_esm/storage/manager.js.map +1 -0
- package/dist/_esm/types/session.js +6 -0
- package/dist/_esm/types/session.js.map +1 -0
- package/dist/_esm/utils/buildClientSignature.js +64 -0
- package/dist/_esm/utils/buildClientSignature.js.map +1 -0
- package/dist/_esm/utils/derToRawSignature.js +89 -0
- package/dist/_esm/utils/derToRawSignature.js.map +1 -0
- package/dist/_esm/utils/exportPrivateKey.js +83 -0
- package/dist/_esm/utils/exportPrivateKey.js.map +1 -0
- package/dist/_esm/utils/exportWallet.js +98 -0
- package/dist/_esm/utils/exportWallet.js.map +1 -0
- package/dist/_esm/utils/utils.js +105 -0
- package/dist/_esm/utils/utils.js.map +1 -0
- package/dist/_types/actions/auth/authenticateWithEmail.d.ts +33 -0
- package/dist/_types/actions/auth/authenticateWithEmail.d.ts.map +1 -0
- package/dist/_types/actions/auth/authenticateWithOAuth.d.ts +38 -0
- package/dist/_types/actions/auth/authenticateWithOAuth.d.ts.map +1 -0
- package/dist/_types/actions/auth/getAuthProxyConfigId.d.ts +12 -0
- package/dist/_types/actions/auth/getAuthProxyConfigId.d.ts.map +1 -0
- package/dist/_types/actions/auth/getUserEmail.d.ts +32 -0
- package/dist/_types/actions/auth/getUserEmail.d.ts.map +1 -0
- package/dist/_types/actions/auth/getWhoami.d.ts +35 -0
- package/dist/_types/actions/auth/getWhoami.d.ts.map +1 -0
- package/dist/_types/actions/auth/index.d.ts +10 -0
- package/dist/_types/actions/auth/index.d.ts.map +1 -0
- package/dist/_types/actions/auth/loginWithOTP.d.ts +41 -0
- package/dist/_types/actions/auth/loginWithOTP.d.ts.map +1 -0
- package/dist/_types/actions/auth/loginWithStamp.d.ts +37 -0
- package/dist/_types/actions/auth/loginWithStamp.d.ts.map +1 -0
- package/dist/_types/actions/auth/registerWithOTP.d.ts +46 -0
- package/dist/_types/actions/auth/registerWithOTP.d.ts.map +1 -0
- package/dist/_types/actions/auth/registerWithPasskey.d.ts +53 -0
- package/dist/_types/actions/auth/registerWithPasskey.d.ts.map +1 -0
- package/dist/_types/actions/index.d.ts +3 -0
- package/dist/_types/actions/index.d.ts.map +1 -0
- package/dist/_types/actions/wallet/getUserWallet.d.ts +34 -0
- package/dist/_types/actions/wallet/getUserWallet.d.ts.map +1 -0
- package/dist/_types/actions/wallet/index.d.ts +4 -0
- package/dist/_types/actions/wallet/index.d.ts.map +1 -0
- package/dist/_types/actions/wallet/signRawPayload.d.ts +39 -0
- package/dist/_types/actions/wallet/signRawPayload.d.ts.map +1 -0
- package/dist/_types/actions/wallet/signTransaction.d.ts +35 -0
- package/dist/_types/actions/wallet/signTransaction.d.ts.map +1 -0
- package/dist/_types/adapters/viem.d.ts +10 -0
- package/dist/_types/adapters/viem.d.ts.map +1 -0
- package/dist/_types/client/authProxy.d.ts +36 -0
- package/dist/_types/client/authProxy.d.ts.map +1 -0
- package/dist/_types/client/createClient.d.ts +17 -0
- package/dist/_types/client/createClient.d.ts.map +1 -0
- package/dist/_types/client/decorators/client.d.ts +81 -0
- package/dist/_types/client/decorators/client.d.ts.map +1 -0
- package/dist/_types/client/index.d.ts +5 -0
- package/dist/_types/client/index.d.ts.map +1 -0
- package/dist/_types/client/transports/createTransport.d.ts +17 -0
- package/dist/_types/client/transports/createTransport.d.ts.map +1 -0
- package/dist/_types/client/transports/rest.d.ts +35 -0
- package/dist/_types/client/transports/rest.d.ts.map +1 -0
- package/dist/_types/client/types.d.ts +59 -0
- package/dist/_types/client/types.d.ts.map +1 -0
- package/dist/_types/constants.d.ts +6 -0
- package/dist/_types/constants.d.ts.map +1 -0
- package/dist/_types/core/createZeroDevWallet.d.ts +52 -0
- package/dist/_types/core/createZeroDevWallet.d.ts.map +1 -0
- package/dist/_types/errors/request.d.ts +12 -0
- package/dist/_types/errors/request.d.ts.map +1 -0
- package/dist/_types/index.d.ts +20 -0
- package/dist/_types/index.d.ts.map +1 -0
- package/dist/_types/polyfills/window.d.ts +15 -0
- package/dist/_types/polyfills/window.d.ts.map +1 -0
- package/dist/_types/stampers/iframeStamper.d.ts +7 -0
- package/dist/_types/stampers/iframeStamper.d.ts.map +1 -0
- package/dist/_types/stampers/index.d.ts +5 -0
- package/dist/_types/stampers/index.d.ts.map +1 -0
- package/dist/_types/stampers/indexedDbStamper.d.ts +3 -0
- package/dist/_types/stampers/indexedDbStamper.d.ts.map +1 -0
- package/dist/_types/stampers/types.d.ts +25 -0
- package/dist/_types/stampers/types.d.ts.map +1 -0
- package/dist/_types/stampers/webauthnStamper.d.ts +5 -0
- package/dist/_types/stampers/webauthnStamper.d.ts.map +1 -0
- package/dist/_types/storage/adapters.d.ts +3 -0
- package/dist/_types/storage/adapters.d.ts.map +1 -0
- package/dist/_types/storage/manager.d.ts +19 -0
- package/dist/_types/storage/manager.d.ts.map +1 -0
- package/dist/_types/types/session.d.ts +17 -0
- package/dist/_types/types/session.d.ts.map +1 -0
- package/dist/_types/utils/buildClientSignature.d.ts +25 -0
- package/dist/_types/utils/buildClientSignature.d.ts.map +1 -0
- package/dist/_types/utils/derToRawSignature.d.ts +11 -0
- package/dist/_types/utils/derToRawSignature.d.ts.map +1 -0
- package/dist/_types/utils/exportPrivateKey.d.ts +47 -0
- package/dist/_types/utils/exportPrivateKey.d.ts.map +1 -0
- package/dist/_types/utils/exportWallet.d.ts +44 -0
- package/dist/_types/utils/exportWallet.d.ts.map +1 -0
- package/dist/_types/utils/utils.d.ts +52 -0
- package/dist/_types/utils/utils.d.ts.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +74 -0
- package/src/actions/auth/authenticateWithEmail.ts +52 -0
- package/src/actions/auth/authenticateWithOAuth.ts +52 -0
- package/src/actions/auth/getAuthProxyConfigId.ts +20 -0
- package/src/actions/auth/getUserEmail.ts +52 -0
- package/src/actions/auth/getWhoami.ts +51 -0
- package/src/actions/auth/index.ts +47 -0
- package/src/actions/auth/loginWithOTP.ts +57 -0
- package/src/actions/auth/loginWithStamp.ts +79 -0
- package/src/actions/auth/registerWithOTP.ts +64 -0
- package/src/actions/auth/registerWithPasskey.ts +72 -0
- package/src/actions/index.ts +41 -0
- package/src/actions/wallet/getUserWallet.ts +53 -0
- package/src/actions/wallet/index.ts +17 -0
- package/src/actions/wallet/signRawPayload.ts +75 -0
- package/src/actions/wallet/signTransaction.ts +64 -0
- package/src/adapters/viem.ts +162 -0
- package/src/client/authProxy.ts +78 -0
- package/src/client/createClient.ts +90 -0
- package/src/client/decorators/client.ts +171 -0
- package/src/client/index.ts +19 -0
- package/src/client/transports/createTransport.ts +54 -0
- package/src/client/transports/rest.ts +138 -0
- package/src/client/types.ts +64 -0
- package/src/constants.ts +5 -0
- package/src/core/createZeroDevWallet.ts +447 -0
- package/src/errors/request.ts +36 -0
- package/src/index.ts +79 -0
- package/src/polyfills/window.ts +24 -0
- package/src/stampers/iframeStamper.ts +49 -0
- package/src/stampers/index.ts +8 -0
- package/src/stampers/indexedDbStamper.ts +22 -0
- package/src/stampers/types.ts +35 -0
- package/src/stampers/webauthnStamper.ts +21 -0
- package/src/storage/adapters.ts +20 -0
- package/src/storage/manager.ts +170 -0
- package/src/types/session.ts +18 -0
- package/src/utils/buildClientSignature.ts +86 -0
- package/src/utils/derToRawSignature.ts +103 -0
- package/src/utils/exportPrivateKey.ts +116 -0
- package/src/utils/exportWallet.ts +130 -0
- package/src/utils/utils.ts +136 -0
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { canonicalizeEx } from 'json-canonicalize';
|
|
2
|
+
import { RestRequestError, RestTimeoutError } from '../../errors/request.js';
|
|
3
|
+
export function rest(url, cfg) {
|
|
4
|
+
const timeoutMs = cfg.timeoutMs ?? 10_000;
|
|
5
|
+
const key = cfg.key ?? 'rest';
|
|
6
|
+
const name = cfg.name ?? 'HTTP REST';
|
|
7
|
+
const request = async (args) => {
|
|
8
|
+
const fullUrl = `${url}/${args.path}`;
|
|
9
|
+
const controller = new AbortController();
|
|
10
|
+
const timer = setTimeout(() => controller.abort(), timeoutMs);
|
|
11
|
+
try {
|
|
12
|
+
let requestBody = args.body;
|
|
13
|
+
let requestHeaders = {
|
|
14
|
+
'content-type': 'application/json',
|
|
15
|
+
...(args.headers ?? {}),
|
|
16
|
+
...(cfg.fetchOptions?.headers ?? {}),
|
|
17
|
+
};
|
|
18
|
+
// Handle stamping if requested
|
|
19
|
+
if (args.stamp) {
|
|
20
|
+
let stamper;
|
|
21
|
+
if (args.stampWith === 'indexedDb') {
|
|
22
|
+
stamper = cfg.indexedDbStamper;
|
|
23
|
+
}
|
|
24
|
+
else if (args.stampWith === 'webAuthn') {
|
|
25
|
+
stamper = cfg.webauthnStamper;
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
stamper = cfg.indexedDbStamper;
|
|
29
|
+
}
|
|
30
|
+
const { body, apiUrl } = args.body;
|
|
31
|
+
const bodyString = canonicalizeEx(body ?? args.body);
|
|
32
|
+
const stamp = await stamper.stamp(bodyString);
|
|
33
|
+
// Restructure request body to match backend expectation
|
|
34
|
+
if (args.stampPostion === 'headers') {
|
|
35
|
+
requestHeaders = {
|
|
36
|
+
...requestHeaders,
|
|
37
|
+
[stamp.stampHeaderName]: stamp.stampHeaderValue,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
else if (body) {
|
|
41
|
+
requestBody = {
|
|
42
|
+
body: bodyString,
|
|
43
|
+
stamp: {
|
|
44
|
+
stampHeaderName: stamp.stampHeaderName,
|
|
45
|
+
stampHeaderValue: stamp.stampHeaderValue,
|
|
46
|
+
},
|
|
47
|
+
apiUrl: apiUrl,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
requestBody = {
|
|
52
|
+
...args.body,
|
|
53
|
+
stamp: {
|
|
54
|
+
stampHeaderName: stamp.stampHeaderName,
|
|
55
|
+
stampHeaderValue: stamp.stampHeaderValue,
|
|
56
|
+
},
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
const init = {
|
|
61
|
+
...cfg.fetchOptions,
|
|
62
|
+
method: args.method ?? 'POST',
|
|
63
|
+
headers: requestHeaders,
|
|
64
|
+
body: requestBody != null ? JSON.stringify(requestBody) : null,
|
|
65
|
+
signal: controller.signal,
|
|
66
|
+
...(args.credentials && { credentials: args.credentials }),
|
|
67
|
+
};
|
|
68
|
+
const finalInit = (await cfg.onRequest?.(fullUrl, init)) ?? init;
|
|
69
|
+
const res = await fetch(fullUrl, finalInit);
|
|
70
|
+
await cfg.onResponse?.(res);
|
|
71
|
+
let data;
|
|
72
|
+
const ct = res.headers.get('content-type') ?? '';
|
|
73
|
+
if (ct.startsWith('application/json'))
|
|
74
|
+
data = await res.json();
|
|
75
|
+
else {
|
|
76
|
+
const text = await res.text();
|
|
77
|
+
try {
|
|
78
|
+
data = text ? JSON.parse(text) : {};
|
|
79
|
+
}
|
|
80
|
+
catch {
|
|
81
|
+
data = text;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
if (!res.ok)
|
|
85
|
+
throw new RestRequestError(fullUrl, res.status, data);
|
|
86
|
+
return data;
|
|
87
|
+
}
|
|
88
|
+
catch (err) {
|
|
89
|
+
if (err.name === 'AbortError')
|
|
90
|
+
throw new RestTimeoutError(fullUrl);
|
|
91
|
+
throw err;
|
|
92
|
+
}
|
|
93
|
+
finally {
|
|
94
|
+
clearTimeout(timer);
|
|
95
|
+
}
|
|
96
|
+
};
|
|
97
|
+
return {
|
|
98
|
+
config: { key, name, url, timeoutMs },
|
|
99
|
+
request,
|
|
100
|
+
value: {},
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=rest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rest.js","sourceRoot":"","sources":["../../../../src/client/transports/rest.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/client/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export const DEFAULT_SESSION_EXPIRATION_IN_SECONDS = '900'; // default to 15 minutes
|
|
2
|
+
export const DEFAULT_IFRAME_CONTAINER_ID = 'turnkey-auth-iframe-container-id';
|
|
3
|
+
export const DEFAULT_IFRAME_ELEMENT_ID = 'turnkey-default-iframe-element-id';
|
|
4
|
+
export const DEFAULT_ORGANIZATION_ID = '0d98e826-dd8f-44ca-a585-3afcd27d4002';
|
|
5
|
+
export const KMS_SERVER_URL = 'https://kms.staging.zerodev.app';
|
|
6
|
+
//# sourceMappingURL=constants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,qCAAqC,GAAG,KAAK,CAAA,CAAC,wBAAwB;AACnF,MAAM,CAAC,MAAM,2BAA2B,GAAG,kCAAkC,CAAA;AAC7E,MAAM,CAAC,MAAM,yBAAyB,GAAG,mCAAmC,CAAA;AAC5E,MAAM,CAAC,MAAM,uBAAuB,GAAG,sCAAsC,CAAA;AAC7E,MAAM,CAAC,MAAM,cAAc,GAAG,iCAAiC,CAAA"}
|
|
@@ -0,0 +1,308 @@
|
|
|
1
|
+
import { getWebAuthnAttestation } from '@turnkey/http';
|
|
2
|
+
import { toViemAccount } from '../adapters/viem.js';
|
|
3
|
+
import { createAuthProxyClient, createClient, zeroDevWalletTransport, } from '../client/index.js';
|
|
4
|
+
import { DEFAULT_ORGANIZATION_ID, DEFAULT_SESSION_EXPIRATION_IN_SECONDS, KMS_SERVER_URL, } from '../constants.js';
|
|
5
|
+
import { createIndexedDbStamper } from '../stampers/indexedDbStamper.js';
|
|
6
|
+
import { createWebauthnStamper } from '../stampers/webauthnStamper.js';
|
|
7
|
+
import { createWebStorageAdapter } from '../storage/adapters.js';
|
|
8
|
+
import { createStorageManager, } from '../storage/manager.js';
|
|
9
|
+
import { SessionType } from '../types/session.js';
|
|
10
|
+
import { buildClientSignature } from '../utils/buildClientSignature.js';
|
|
11
|
+
import { base64UrlEncode, generateCompressedPublicKeyFromKeyPair, generateRandomBuffer, humanReadableDateTime, parseSession, } from '../utils/utils.js';
|
|
12
|
+
export async function createZeroDevWallet(config) {
|
|
13
|
+
const { projectId, sessionStorage, rpId = window.location.hostname, organizationId = DEFAULT_ORGANIZATION_ID, } = config;
|
|
14
|
+
const sessionStorageManager = createStorageManager(sessionStorage || createWebStorageAdapter());
|
|
15
|
+
const indexedDbStamper = await createIndexedDbStamper();
|
|
16
|
+
const webauthnStamper = await createWebauthnStamper({ rpId });
|
|
17
|
+
const client = createClient({
|
|
18
|
+
indexedDbStamper,
|
|
19
|
+
webauthnStamper,
|
|
20
|
+
transport: zeroDevWalletTransport({
|
|
21
|
+
baseUrl: config.proxyBaseUrl || `${KMS_SERVER_URL}/api/v1`,
|
|
22
|
+
}),
|
|
23
|
+
});
|
|
24
|
+
let cachedAuthProxyConfigId;
|
|
25
|
+
return {
|
|
26
|
+
client,
|
|
27
|
+
async getPublicKey() {
|
|
28
|
+
await client.indexedDbStamper.resetKeyPair();
|
|
29
|
+
const compressedPublicKey = await client.indexedDbStamper.getPublicKey();
|
|
30
|
+
return compressedPublicKey;
|
|
31
|
+
},
|
|
32
|
+
async getSession() {
|
|
33
|
+
return sessionStorageManager.getActiveSession();
|
|
34
|
+
},
|
|
35
|
+
async getAllSessions() {
|
|
36
|
+
const sessions = await sessionStorageManager.listSessions();
|
|
37
|
+
const sessionMap = {};
|
|
38
|
+
for (const session of sessions) {
|
|
39
|
+
sessionMap[session.id] = session;
|
|
40
|
+
}
|
|
41
|
+
return sessionMap;
|
|
42
|
+
},
|
|
43
|
+
async switchSession(sessionId) {
|
|
44
|
+
await sessionStorageManager.setActiveSession(sessionId);
|
|
45
|
+
const session = await sessionStorageManager.getActiveSession();
|
|
46
|
+
return session;
|
|
47
|
+
},
|
|
48
|
+
async clearSession(sessionId) {
|
|
49
|
+
await sessionStorageManager.clearSession(sessionId);
|
|
50
|
+
},
|
|
51
|
+
async clearAllSessions() {
|
|
52
|
+
await sessionStorageManager.clearAllSessions();
|
|
53
|
+
},
|
|
54
|
+
async refreshSession(sessionId) {
|
|
55
|
+
const activeSession = sessionId
|
|
56
|
+
? await sessionStorageManager.getSession(sessionId)
|
|
57
|
+
: await sessionStorageManager.getActiveSession();
|
|
58
|
+
if (!activeSession) {
|
|
59
|
+
throw new Error('No active session');
|
|
60
|
+
}
|
|
61
|
+
if (activeSession.stamperType === 'indexedDb') {
|
|
62
|
+
const newKeyPair = await crypto.subtle.generateKey({
|
|
63
|
+
name: 'ECDSA',
|
|
64
|
+
namedCurve: 'P-256',
|
|
65
|
+
}, false, ['sign', 'verify']);
|
|
66
|
+
const compressedPublicKeyHex = await generateCompressedPublicKeyFromKeyPair(newKeyPair);
|
|
67
|
+
const data = await client.loginWithStamp({
|
|
68
|
+
targetPublicKey: compressedPublicKeyHex,
|
|
69
|
+
projectId,
|
|
70
|
+
organizationId: activeSession.organizationId,
|
|
71
|
+
stampWith: 'indexedDb',
|
|
72
|
+
});
|
|
73
|
+
await client.indexedDbStamper.resetKeyPair(newKeyPair);
|
|
74
|
+
const parsedSession = parseSession(data.session);
|
|
75
|
+
const session = {
|
|
76
|
+
id: `session_indexedDb_${Date.now()}`,
|
|
77
|
+
userId: parsedSession.userId,
|
|
78
|
+
organizationId: parsedSession.organizationId,
|
|
79
|
+
stamperType: 'indexedDb',
|
|
80
|
+
sessionType: SessionType.READ_WRITE,
|
|
81
|
+
token: data.session,
|
|
82
|
+
expiry: parsedSession.expiry,
|
|
83
|
+
createdAt: Date.now(),
|
|
84
|
+
};
|
|
85
|
+
await sessionStorageManager.clearSession(activeSession.id);
|
|
86
|
+
await sessionStorageManager.storeSession(session, session.id);
|
|
87
|
+
return session;
|
|
88
|
+
}
|
|
89
|
+
throw new Error('Invalid session type');
|
|
90
|
+
},
|
|
91
|
+
// [TODO] refactor to smaller utils/actions
|
|
92
|
+
async auth(params) {
|
|
93
|
+
switch (params.type) {
|
|
94
|
+
case 'oauth': {
|
|
95
|
+
// Backend OAuth flow - the backend reads the OAuth session from a cookie
|
|
96
|
+
// set during the OAuth popup flow via /oauth/google/login
|
|
97
|
+
const data = await client.authenticateWithOAuth({
|
|
98
|
+
provider: params.provider,
|
|
99
|
+
projectId,
|
|
100
|
+
});
|
|
101
|
+
if (data.session) {
|
|
102
|
+
// Parse the JWT to get session data
|
|
103
|
+
const parsedSession = parseSession(data.session);
|
|
104
|
+
const publicKey = await client.indexedDbStamper.getPublicKey();
|
|
105
|
+
const session = {
|
|
106
|
+
id: `session_oauth_${Date.now()}`,
|
|
107
|
+
userId: parsedSession.userId,
|
|
108
|
+
organizationId: parsedSession.organizationId,
|
|
109
|
+
stamperType: 'indexedDb',
|
|
110
|
+
sessionType: parsedSession.sessionType || SessionType.READ_WRITE,
|
|
111
|
+
token: data.session,
|
|
112
|
+
expiry: parsedSession.expiry,
|
|
113
|
+
createdAt: Date.now(),
|
|
114
|
+
publicKey: publicKey || '',
|
|
115
|
+
};
|
|
116
|
+
await sessionStorageManager.storeSession(session, session.id);
|
|
117
|
+
}
|
|
118
|
+
return data;
|
|
119
|
+
}
|
|
120
|
+
case 'passkey': {
|
|
121
|
+
const { type } = params;
|
|
122
|
+
if (type === 'passkey' &&
|
|
123
|
+
'mode' in params &&
|
|
124
|
+
params.mode === 'register') {
|
|
125
|
+
const { email } = params;
|
|
126
|
+
await client.indexedDbStamper.resetKeyPair();
|
|
127
|
+
const tempPublicKey = await client.indexedDbStamper.getPublicKey();
|
|
128
|
+
if (!tempPublicKey) {
|
|
129
|
+
throw new Error('Failed to get public key');
|
|
130
|
+
}
|
|
131
|
+
const challenge = generateRandomBuffer();
|
|
132
|
+
const encodedChallenge = base64UrlEncode(challenge);
|
|
133
|
+
const authenticatorUserId = generateRandomBuffer();
|
|
134
|
+
const name = `ZeroDevWallet-${humanReadableDateTime()}-${email}`;
|
|
135
|
+
const attestation = await getWebAuthnAttestation({
|
|
136
|
+
publicKey: {
|
|
137
|
+
rp: { id: rpId, name: '' },
|
|
138
|
+
challenge,
|
|
139
|
+
pubKeyCredParams: [
|
|
140
|
+
{
|
|
141
|
+
type: 'public-key',
|
|
142
|
+
alg: -7,
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
type: 'public-key',
|
|
146
|
+
alg: -257,
|
|
147
|
+
},
|
|
148
|
+
],
|
|
149
|
+
user: {
|
|
150
|
+
id: authenticatorUserId,
|
|
151
|
+
name,
|
|
152
|
+
displayName: name,
|
|
153
|
+
},
|
|
154
|
+
},
|
|
155
|
+
});
|
|
156
|
+
const data = await client.registerWithPasskey({
|
|
157
|
+
email,
|
|
158
|
+
attestation,
|
|
159
|
+
challenge: encodedChallenge,
|
|
160
|
+
projectId,
|
|
161
|
+
encodedPublicKey: tempPublicKey,
|
|
162
|
+
});
|
|
163
|
+
const newKeyPair = await crypto.subtle.generateKey({
|
|
164
|
+
name: 'ECDSA',
|
|
165
|
+
namedCurve: 'P-256',
|
|
166
|
+
}, false, ['sign', 'verify']);
|
|
167
|
+
const compressedPublicKeyHex = await generateCompressedPublicKeyFromKeyPair(newKeyPair);
|
|
168
|
+
const loginData = await client.loginWithStamp({
|
|
169
|
+
projectId,
|
|
170
|
+
targetPublicKey: compressedPublicKeyHex,
|
|
171
|
+
organizationId: data.subOrganizationId,
|
|
172
|
+
});
|
|
173
|
+
await client.indexedDbStamper.resetKeyPair(newKeyPair);
|
|
174
|
+
const parsedSession = parseSession(loginData.session);
|
|
175
|
+
const session = {
|
|
176
|
+
id: `session_indexedDb_${Date.now()}`,
|
|
177
|
+
stamperType: 'indexedDb',
|
|
178
|
+
createdAt: Date.now(),
|
|
179
|
+
sessionType: SessionType.READ_WRITE,
|
|
180
|
+
userId: parsedSession.userId,
|
|
181
|
+
organizationId: parsedSession.organizationId,
|
|
182
|
+
expiry: Date.now() +
|
|
183
|
+
Number(DEFAULT_SESSION_EXPIRATION_IN_SECONDS) * 1000,
|
|
184
|
+
token: loginData.session,
|
|
185
|
+
};
|
|
186
|
+
await sessionStorageManager.storeSession(session, session.id);
|
|
187
|
+
return data;
|
|
188
|
+
}
|
|
189
|
+
if (type === 'passkey' &&
|
|
190
|
+
'mode' in params &&
|
|
191
|
+
params.mode === 'login') {
|
|
192
|
+
await client.indexedDbStamper.resetKeyPair();
|
|
193
|
+
const generatedPublicKey = await client.indexedDbStamper.getPublicKey();
|
|
194
|
+
if (!generatedPublicKey) {
|
|
195
|
+
throw new Error('Failed to get public key');
|
|
196
|
+
}
|
|
197
|
+
const loginData = await client.loginWithStamp({
|
|
198
|
+
targetPublicKey: generatedPublicKey,
|
|
199
|
+
projectId,
|
|
200
|
+
organizationId,
|
|
201
|
+
stampWith: 'webauthn',
|
|
202
|
+
});
|
|
203
|
+
const parsedSession = parseSession(loginData.session);
|
|
204
|
+
const session = {
|
|
205
|
+
id: `session_indexedDb_${Date.now()}`,
|
|
206
|
+
stamperType: 'indexedDb',
|
|
207
|
+
createdAt: Date.now(),
|
|
208
|
+
sessionType: SessionType.READ_WRITE,
|
|
209
|
+
userId: parsedSession.userId,
|
|
210
|
+
organizationId: parsedSession.organizationId,
|
|
211
|
+
expiry: Date.now() +
|
|
212
|
+
Number(DEFAULT_SESSION_EXPIRATION_IN_SECONDS) * 1000,
|
|
213
|
+
token: loginData.session,
|
|
214
|
+
};
|
|
215
|
+
await sessionStorageManager.storeSession(session, session.id);
|
|
216
|
+
return loginData;
|
|
217
|
+
}
|
|
218
|
+
throw new Error('Passkey authentication requires passkey parameter');
|
|
219
|
+
}
|
|
220
|
+
case 'otp': {
|
|
221
|
+
const { type, mode } = params;
|
|
222
|
+
if (type === 'otp' && mode === 'sendOtp') {
|
|
223
|
+
const { email, contact, emailCustomization } = params;
|
|
224
|
+
const data = await client.registerWithOTP({
|
|
225
|
+
email,
|
|
226
|
+
contact,
|
|
227
|
+
projectId,
|
|
228
|
+
...(emailCustomization && { emailCustomization }),
|
|
229
|
+
});
|
|
230
|
+
return data;
|
|
231
|
+
}
|
|
232
|
+
if (type === 'otp' && mode === 'verifyOtp') {
|
|
233
|
+
const { otpId, otpCode } = params;
|
|
234
|
+
// Step 1: Generate new key pair
|
|
235
|
+
await client.indexedDbStamper.resetKeyPair();
|
|
236
|
+
const targetPublicKey = await client.indexedDbStamper.getPublicKey();
|
|
237
|
+
if (!targetPublicKey) {
|
|
238
|
+
throw new Error('Failed to get public key');
|
|
239
|
+
}
|
|
240
|
+
// Step 2: Verify OTP via Auth Proxy
|
|
241
|
+
if (!cachedAuthProxyConfigId) {
|
|
242
|
+
const { authProxyConfigId } = await client.getAuthProxyConfigId();
|
|
243
|
+
cachedAuthProxyConfigId = authProxyConfigId;
|
|
244
|
+
}
|
|
245
|
+
const authProxyClient = createAuthProxyClient({
|
|
246
|
+
authProxyConfigId: cachedAuthProxyConfigId,
|
|
247
|
+
});
|
|
248
|
+
const { verificationToken } = await authProxyClient.verifyOtp({
|
|
249
|
+
otpId,
|
|
250
|
+
otpCode,
|
|
251
|
+
public_key: targetPublicKey,
|
|
252
|
+
});
|
|
253
|
+
// Step 3: Build client signature
|
|
254
|
+
const clientSignature = await buildClientSignature({
|
|
255
|
+
verificationToken,
|
|
256
|
+
publicKey: targetPublicKey,
|
|
257
|
+
stamper: client.indexedDbStamper,
|
|
258
|
+
});
|
|
259
|
+
// Step 4: Login via backend (not Auth Proxy!)
|
|
260
|
+
const data = await client.loginWithOTP({
|
|
261
|
+
verificationToken,
|
|
262
|
+
clientSignature,
|
|
263
|
+
projectId,
|
|
264
|
+
});
|
|
265
|
+
if (data.session) {
|
|
266
|
+
// Parse the JWT to get session data
|
|
267
|
+
const parsedSession = parseSession(data.session);
|
|
268
|
+
const session = {
|
|
269
|
+
id: `session_otp_${Date.now()}`,
|
|
270
|
+
userId: parsedSession.userId,
|
|
271
|
+
organizationId: parsedSession.organizationId,
|
|
272
|
+
stamperType: 'indexedDb',
|
|
273
|
+
sessionType: parsedSession.sessionType || SessionType.READ_WRITE,
|
|
274
|
+
token: data.session,
|
|
275
|
+
expiry: parsedSession.expiry,
|
|
276
|
+
createdAt: Date.now(),
|
|
277
|
+
publicKey: targetPublicKey,
|
|
278
|
+
};
|
|
279
|
+
await sessionStorageManager.storeSession(session, session.id);
|
|
280
|
+
}
|
|
281
|
+
return data;
|
|
282
|
+
}
|
|
283
|
+
throw new Error('OTP authentication requires mode parameter');
|
|
284
|
+
}
|
|
285
|
+
default:
|
|
286
|
+
throw new Error(`Unknown auth type: ${params.type}`);
|
|
287
|
+
}
|
|
288
|
+
},
|
|
289
|
+
async logout() {
|
|
290
|
+
await sessionStorageManager.clearAllSessions();
|
|
291
|
+
await client.indexedDbStamper.resetKeyPair();
|
|
292
|
+
return true;
|
|
293
|
+
},
|
|
294
|
+
async toAccount() {
|
|
295
|
+
const session = await sessionStorageManager.getActiveSession();
|
|
296
|
+
if (!session) {
|
|
297
|
+
throw new Error('No active session');
|
|
298
|
+
}
|
|
299
|
+
return toViemAccount({
|
|
300
|
+
client,
|
|
301
|
+
organizationId: session.organizationId,
|
|
302
|
+
projectId,
|
|
303
|
+
token: session.token ?? '',
|
|
304
|
+
});
|
|
305
|
+
},
|
|
306
|
+
};
|
|
307
|
+
}
|
|
308
|
+
//# sourceMappingURL=createZeroDevWallet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createZeroDevWallet.js","sourceRoot":"","sources":["../../../src/core/createZeroDevWallet.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
export class RestRequestError extends Error {
|
|
2
|
+
constructor(url, status, body, cause) {
|
|
3
|
+
// Extract error message from backend response format
|
|
4
|
+
// Backend format: { error: "error_code", message: "human readable message" }
|
|
5
|
+
let errorMessage = `Request failed (${status || 'unknown'}): `;
|
|
6
|
+
if (body && typeof body === 'object') {
|
|
7
|
+
const errorBody = body;
|
|
8
|
+
// Prefer message (detailed), fallback to error (code)
|
|
9
|
+
if (errorBody.message && errorBody.error) {
|
|
10
|
+
// Both present: show error code + message
|
|
11
|
+
errorMessage += `${errorBody.error} - ${errorBody.message}`;
|
|
12
|
+
}
|
|
13
|
+
else if (errorBody.message) {
|
|
14
|
+
errorMessage += `${errorBody.message}`;
|
|
15
|
+
}
|
|
16
|
+
else if (errorBody.error) {
|
|
17
|
+
errorMessage += `${errorBody.error}`;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
super(errorMessage);
|
|
21
|
+
Object.defineProperty(this, "url", {
|
|
22
|
+
enumerable: true,
|
|
23
|
+
configurable: true,
|
|
24
|
+
writable: true,
|
|
25
|
+
value: url
|
|
26
|
+
});
|
|
27
|
+
Object.defineProperty(this, "status", {
|
|
28
|
+
enumerable: true,
|
|
29
|
+
configurable: true,
|
|
30
|
+
writable: true,
|
|
31
|
+
value: status
|
|
32
|
+
});
|
|
33
|
+
Object.defineProperty(this, "body", {
|
|
34
|
+
enumerable: true,
|
|
35
|
+
configurable: true,
|
|
36
|
+
writable: true,
|
|
37
|
+
value: body
|
|
38
|
+
});
|
|
39
|
+
Object.defineProperty(this, "cause", {
|
|
40
|
+
enumerable: true,
|
|
41
|
+
configurable: true,
|
|
42
|
+
writable: true,
|
|
43
|
+
value: cause
|
|
44
|
+
});
|
|
45
|
+
this.name = 'RestRequestError';
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
export class RestTimeoutError extends Error {
|
|
49
|
+
constructor(url) {
|
|
50
|
+
super(`Request timed out: ${url}`);
|
|
51
|
+
Object.defineProperty(this, "url", {
|
|
52
|
+
enumerable: true,
|
|
53
|
+
configurable: true,
|
|
54
|
+
writable: true,
|
|
55
|
+
value: url
|
|
56
|
+
});
|
|
57
|
+
this.name = 'RestTimeoutError';
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=request.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request.js","sourceRoot":"","sources":["../../../src/errors/request.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,gBAAiB,SAAQ,KAAK;IACzC,YACS,GAAW,EACX,MAAe,EACf,IAAc,EACL,KAAe;QAE/B,qDAAqD;QACrD,6EAA6E;QAC7E,IAAI,YAAY,GAAG,mBAAmB,MAAM,IAAI,SAAS,KAAK,CAAA;QAE9D,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YACrC,MAAM,SAAS,GAAG,IAAW,CAAA;YAE7B,sDAAsD;YACtD,IAAI,SAAS,CAAC,OAAO,IAAI,SAAS,CAAC,KAAK,EAAE,CAAC;gBACzC,0CAA0C;gBAC1C,YAAY,IAAI,GAAG,SAAS,CAAC,KAAK,MAAM,SAAS,CAAC,OAAO,EAAE,CAAA;YAC7D,CAAC;iBAAM,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;gBAC7B,YAAY,IAAI,GAAG,SAAS,CAAC,OAAO,EAAE,CAAA;YACxC,CAAC;iBAAM,IAAI,SAAS,CAAC,KAAK,EAAE,CAAC;gBAC3B,YAAY,IAAI,GAAG,SAAS,CAAC,KAAK,EAAE,CAAA;YACtC,CAAC;QACH,CAAC;QAED,KAAK,CAAC,YAAY,CAAC,CAAA;QAvBnB;;;;mBAAO,GAAG;WAAQ;QAClB;;;;mBAAO,MAAM;WAAS;QACtB;;;;mBAAO,IAAI;WAAU;QACrB;;;;mBAAgB,KAAK;WAAU;QAqB/B,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAA;IAChC,CAAC;CACF;AAED,MAAM,OAAO,gBAAiB,SAAQ,KAAK;IACzC,YAAmB,GAAW;QAC5B,KAAK,CAAC,sBAAsB,GAAG,EAAE,CAAC,CAAA;QADxB;;;;mBAAO,GAAG;WAAQ;QAE5B,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAA;IAChC,CAAC;CACF"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// Actions
|
|
2
|
+
export {
|
|
3
|
+
// Auth actions
|
|
4
|
+
authenticateWithEmail, authenticateWithOAuth,
|
|
5
|
+
// Wallet actions
|
|
6
|
+
getUserWallet, getWhoami, loginWithOTP, registerWithOTP, signRawPayload, signTransaction, } from './actions/index.js';
|
|
7
|
+
// Adapters
|
|
8
|
+
export { toViemAccount } from './adapters/viem.js';
|
|
9
|
+
// Client decorators
|
|
10
|
+
export { zeroDevWalletActions } from './client/decorators/client.js';
|
|
11
|
+
// Client
|
|
12
|
+
export { createBaseClient, createClient, zeroDevWalletTransport, } from './client/index.js';
|
|
13
|
+
// Constants
|
|
14
|
+
export { KMS_SERVER_URL } from './constants.js';
|
|
15
|
+
// Core
|
|
16
|
+
export { createZeroDevWallet } from './core/createZeroDevWallet.js';
|
|
17
|
+
// Stampers
|
|
18
|
+
export { createIframeStamper, createIndexedDbStamper, createWebauthnStamper, } from './stampers/index.js';
|
|
19
|
+
export { exportPrivateKey } from './utils/exportPrivateKey.js';
|
|
20
|
+
export { exportWallet } from './utils/exportWallet.js';
|
|
21
|
+
// Utils
|
|
22
|
+
export { normalizeTimestamp } from './utils/utils.js';
|
|
23
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAuBA,UAAU;AACV,OAAO;AACL,eAAe;AACf,qBAAqB,EACrB,qBAAqB;AACrB,iBAAiB;AACjB,aAAa,EACb,SAAS,EACT,YAAY,EACZ,eAAe,EACf,cAAc,EACd,eAAe,GAChB,MAAM,oBAAoB,CAAA;AAE3B,WAAW;AACX,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAElD,oBAAoB;AACpB,OAAO,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAA;AAEpE,SAAS;AACT,OAAO,EACL,gBAAgB,EAChB,YAAY,EAEZ,sBAAsB,GACvB,MAAM,mBAAmB,CAAA;AAC1B,YAAY;AACZ,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAM/C,OAAO;AACP,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAA;AACnE,WAAW;AACX,OAAO,EACL,mBAAmB,EACnB,sBAAsB,EACtB,qBAAqB,GACtB,MAAM,qBAAqB,CAAA;AAW5B,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAA;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AACtD,QAAQ;AACR,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"type": "module","sideEffects":false}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
const loadWindow = () => {
|
|
2
|
+
if (typeof window !== 'undefined') {
|
|
3
|
+
return window;
|
|
4
|
+
}
|
|
5
|
+
return {
|
|
6
|
+
localStorage: {
|
|
7
|
+
getItem: (_key) => {
|
|
8
|
+
return null;
|
|
9
|
+
},
|
|
10
|
+
setItem: (_key, _value) => { },
|
|
11
|
+
removeItem: (_key) => { },
|
|
12
|
+
clear: () => { },
|
|
13
|
+
key: (_index) => {
|
|
14
|
+
return null;
|
|
15
|
+
},
|
|
16
|
+
length: 0,
|
|
17
|
+
},
|
|
18
|
+
location: {
|
|
19
|
+
hostname: '',
|
|
20
|
+
},
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
export default loadWindow();
|
|
24
|
+
//# sourceMappingURL=window.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"window.js","sourceRoot":"","sources":["../../../src/polyfills/window.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,GAAG,GAAG,EAAE;IACtB,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;QAClC,OAAO,MAAM,CAAA;IACf,CAAC;IACD,OAAO;QACL,YAAY,EAAE;YACZ,OAAO,EAAE,CAAC,IAAY,EAAiB,EAAE;gBACvC,OAAO,IAAI,CAAA;YACb,CAAC;YACD,OAAO,EAAE,CAAC,IAAY,EAAE,MAAc,EAAE,EAAE,GAAE,CAAC;YAC7C,UAAU,EAAE,CAAC,IAAY,EAAE,EAAE,GAAE,CAAC;YAChC,KAAK,EAAE,GAAG,EAAE,GAAE,CAAC;YACf,GAAG,EAAE,CAAC,MAAc,EAAiB,EAAE;gBACrC,OAAO,IAAI,CAAA;YACb,CAAC;YACD,MAAM,EAAE,CAAC;SACV;QACD,QAAQ,EAAE;YACR,QAAQ,EAAE,EAAE;SACb;KACF,CAAA;AACH,CAAC,CAAA;AAED,eAAe,UAAU,EAAE,CAAA"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { KeyFormat, IframeStamper as TurnkeyIframeStamper, } from '@turnkey/iframe-stamper';
|
|
2
|
+
export async function createIframeStamper(cfg) {
|
|
3
|
+
const inner = new TurnkeyIframeStamper({
|
|
4
|
+
iframeUrl: cfg.iframeUrl,
|
|
5
|
+
iframeContainer: cfg.iframeContainer,
|
|
6
|
+
iframeElementId: cfg.iframeElementId,
|
|
7
|
+
});
|
|
8
|
+
return {
|
|
9
|
+
async init() {
|
|
10
|
+
return await inner.init();
|
|
11
|
+
},
|
|
12
|
+
async injectCredentialBundle(bundle) {
|
|
13
|
+
return await inner.injectCredentialBundle(bundle);
|
|
14
|
+
},
|
|
15
|
+
async getPublicKey() {
|
|
16
|
+
return await inner.getEmbeddedPublicKey();
|
|
17
|
+
},
|
|
18
|
+
async stamp(payload) {
|
|
19
|
+
return await inner.stamp(payload);
|
|
20
|
+
},
|
|
21
|
+
async clear() {
|
|
22
|
+
await inner.clear();
|
|
23
|
+
},
|
|
24
|
+
async injectWalletExportBundle(bundle, organizationId) {
|
|
25
|
+
return await inner.injectWalletExportBundle(bundle, organizationId);
|
|
26
|
+
},
|
|
27
|
+
async injectKeyExportBundle(bundle, organizationId, keyFormat) {
|
|
28
|
+
return await inner.injectKeyExportBundle(bundle, organizationId, keyFormat ? KeyFormat[keyFormat] : KeyFormat.Hexadecimal);
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=iframeStamper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"iframeStamper.js","sourceRoot":"","sources":["../../../src/stampers/iframeStamper.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,aAAa,IAAI,oBAAoB,GACtC,MAAM,yBAAyB,CAAA;AAGhC,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,GAIzC;IACC,MAAM,KAAK,GAAG,IAAI,oBAAoB,CAAC;QACrC,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,eAAe,EAAE,GAAG,CAAC,eAAe;QACpC,eAAe,EAAE,GAAG,CAAC,eAAe;KACrC,CAAC,CAAA;IAEF,OAAO;QACL,KAAK,CAAC,IAAI;YACR,OAAO,MAAM,KAAK,CAAC,IAAI,EAAE,CAAA;QAC3B,CAAC;QACD,KAAK,CAAC,sBAAsB,CAAC,MAAc;YACzC,OAAO,MAAM,KAAK,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAA;QACnD,CAAC;QACD,KAAK,CAAC,YAAY;YAChB,OAAO,MAAM,KAAK,CAAC,oBAAoB,EAAE,CAAA;QAC3C,CAAC;QACD,KAAK,CAAC,KAAK,CAAC,OAAe;YACzB,OAAO,MAAM,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QACnC,CAAC;QACD,KAAK,CAAC,KAAK;YACT,MAAM,KAAK,CAAC,KAAK,EAAE,CAAA;QACrB,CAAC;QACD,KAAK,CAAC,wBAAwB,CAAC,MAAc,EAAE,cAAsB;YACnE,OAAO,MAAM,KAAK,CAAC,wBAAwB,CAAC,MAAM,EAAE,cAAc,CAAC,CAAA;QACrE,CAAC;QACD,KAAK,CAAC,qBAAqB,CACzB,MAAc,EACd,cAAsB,EACtB,SAAyB;YAEzB,OAAO,MAAM,KAAK,CAAC,qBAAqB,CACtC,MAAM,EACN,cAAc,EACd,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,WAAW,CACzD,CAAA;QACH,CAAC;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/stampers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAA;AACxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAA;AAM9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAA"}
|