@tatchi-xyz/sdk 0.31.0 → 0.31.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/dist/cjs/core/IndexedDBManager/passkeyClientDB.js +2 -2
- package/dist/cjs/core/IndexedDBManager/passkeyClientDB.js.map +1 -1
- package/dist/cjs/core/TatchiPasskey/faucets/createAccountRelayServer.js +9 -8
- package/dist/cjs/core/TatchiPasskey/faucets/createAccountRelayServer.js.map +1 -1
- package/dist/cjs/core/TatchiPasskey/login.js +1 -1
- package/dist/cjs/core/TatchiPasskey/login.js.map +1 -1
- package/dist/cjs/core/TatchiPasskey/registration.js +67 -56
- package/dist/cjs/core/TatchiPasskey/registration.js.map +1 -1
- package/dist/cjs/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.js +1 -10
- package/dist/cjs/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.js.map +1 -1
- package/dist/cjs/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.js +58 -67
- package/dist/cjs/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.js.map +1 -1
- package/dist/cjs/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.js +74 -75
- package/dist/cjs/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.js.map +1 -1
- package/dist/cjs/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.js +17 -7
- package/dist/cjs/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.js.map +1 -1
- package/dist/cjs/core/WebAuthnManager/index.js +3 -3
- package/dist/cjs/core/WebAuthnManager/index.js.map +1 -1
- package/dist/cjs/core/defaultConfigs.js +3 -1
- package/dist/cjs/core/defaultConfigs.js.map +1 -1
- package/dist/cjs/react/components/AccountMenuButton/TransactionSettingsSection.js +3 -3
- package/dist/cjs/react/components/AccountMenuButton/TransactionSettingsSection.js.map +1 -1
- package/dist/cjs/react/components/PasskeyAuthMenu/{PasskeyAuthMenu-CRlobBrN.css → PasskeyAuthMenu-D2eRb2-S.css} +3 -1
- package/dist/cjs/react/components/PasskeyAuthMenu/PasskeyAuthMenu-D2eRb2-S.css.map +1 -0
- package/dist/cjs/react/components/PasskeyAuthMenu/preload.js +1 -1
- package/dist/cjs/react/components/PasskeyAuthMenu/preload.js.map +1 -1
- package/dist/cjs/react/components/PasskeyAuthMenu/shell.js +52 -13
- package/dist/cjs/react/components/PasskeyAuthMenu/shell.js.map +1 -1
- package/dist/cjs/react/components/PasskeyAuthMenu/skeleton.js +4 -2
- package/dist/cjs/react/components/PasskeyAuthMenu/skeleton.js.map +1 -1
- package/dist/cjs/react/components/PasskeyAuthMenu/ui/EmailRecoverySlide.js +5 -1
- package/dist/cjs/react/components/PasskeyAuthMenu/ui/EmailRecoverySlide.js.map +1 -1
- package/dist/cjs/react/index.js +1 -1
- package/dist/cjs/react/src/core/IndexedDBManager/passkeyClientDB.js +2 -2
- package/dist/cjs/react/src/core/IndexedDBManager/passkeyClientDB.js.map +1 -1
- package/dist/cjs/react/src/core/TatchiPasskey/faucets/createAccountRelayServer.js +9 -8
- package/dist/cjs/react/src/core/TatchiPasskey/faucets/createAccountRelayServer.js.map +1 -1
- package/dist/cjs/react/src/core/TatchiPasskey/login.js +1 -1
- package/dist/cjs/react/src/core/TatchiPasskey/login.js.map +1 -1
- package/dist/cjs/react/src/core/TatchiPasskey/registration.js +67 -56
- package/dist/cjs/react/src/core/TatchiPasskey/registration.js.map +1 -1
- package/dist/cjs/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.js +1 -10
- package/dist/cjs/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.js.map +1 -1
- package/dist/cjs/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.js +58 -67
- package/dist/cjs/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.js.map +1 -1
- package/dist/cjs/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.js +74 -75
- package/dist/cjs/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.js.map +1 -1
- package/dist/cjs/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.js +17 -7
- package/dist/cjs/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.js.map +1 -1
- package/dist/cjs/react/src/core/WebAuthnManager/index.js +3 -3
- package/dist/cjs/react/src/core/WebAuthnManager/index.js.map +1 -1
- package/dist/cjs/react/src/core/defaultConfigs.js +3 -1
- package/dist/cjs/react/src/core/defaultConfigs.js.map +1 -1
- package/dist/cjs/server/core/AuthService.js +49 -6
- package/dist/cjs/server/core/AuthService.js.map +1 -1
- package/dist/cjs/server/sdk/src/core/defaultConfigs.js.map +1 -1
- package/dist/esm/core/IndexedDBManager/passkeyClientDB.js +2 -2
- package/dist/esm/core/IndexedDBManager/passkeyClientDB.js.map +1 -1
- package/dist/esm/core/TatchiPasskey/faucets/createAccountRelayServer.js +9 -8
- package/dist/esm/core/TatchiPasskey/faucets/createAccountRelayServer.js.map +1 -1
- package/dist/esm/core/TatchiPasskey/login.js +1 -1
- package/dist/esm/core/TatchiPasskey/login.js.map +1 -1
- package/dist/esm/core/TatchiPasskey/registration.js +67 -56
- package/dist/esm/core/TatchiPasskey/registration.js.map +1 -1
- package/dist/esm/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.js +1 -10
- package/dist/esm/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.js.map +1 -1
- package/dist/esm/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.js +58 -67
- package/dist/esm/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.js.map +1 -1
- package/dist/esm/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.js +74 -75
- package/dist/esm/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.js.map +1 -1
- package/dist/esm/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.js +17 -7
- package/dist/esm/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.js.map +1 -1
- package/dist/esm/core/WebAuthnManager/index.js +3 -3
- package/dist/esm/core/WebAuthnManager/index.js.map +1 -1
- package/dist/esm/core/defaultConfigs.js +3 -1
- package/dist/esm/core/defaultConfigs.js.map +1 -1
- package/dist/esm/react/components/AccountMenuButton/TransactionSettingsSection.js +3 -3
- package/dist/esm/react/components/AccountMenuButton/TransactionSettingsSection.js.map +1 -1
- package/dist/esm/react/components/PasskeyAuthMenu/{PasskeyAuthMenu-D2VHZ04W.css → PasskeyAuthMenu-qTHAv58Z.css} +3 -1
- package/dist/esm/react/components/PasskeyAuthMenu/PasskeyAuthMenu-qTHAv58Z.css.map +1 -0
- package/dist/esm/react/components/PasskeyAuthMenu/preload.js +1 -1
- package/dist/esm/react/components/PasskeyAuthMenu/preload.js.map +1 -1
- package/dist/esm/react/components/PasskeyAuthMenu/shell.js +52 -13
- package/dist/esm/react/components/PasskeyAuthMenu/shell.js.map +1 -1
- package/dist/esm/react/components/PasskeyAuthMenu/skeleton.js +4 -2
- package/dist/esm/react/components/PasskeyAuthMenu/skeleton.js.map +1 -1
- package/dist/esm/react/components/PasskeyAuthMenu/ui/EmailRecoverySlide.js +5 -1
- package/dist/esm/react/components/PasskeyAuthMenu/ui/EmailRecoverySlide.js.map +1 -1
- package/dist/esm/react/index.js +1 -1
- package/dist/esm/react/src/core/IndexedDBManager/passkeyClientDB.js +2 -2
- package/dist/esm/react/src/core/IndexedDBManager/passkeyClientDB.js.map +1 -1
- package/dist/esm/react/src/core/TatchiPasskey/faucets/createAccountRelayServer.js +9 -8
- package/dist/esm/react/src/core/TatchiPasskey/faucets/createAccountRelayServer.js.map +1 -1
- package/dist/esm/react/src/core/TatchiPasskey/login.js +1 -1
- package/dist/esm/react/src/core/TatchiPasskey/login.js.map +1 -1
- package/dist/esm/react/src/core/TatchiPasskey/registration.js +67 -56
- package/dist/esm/react/src/core/TatchiPasskey/registration.js.map +1 -1
- package/dist/esm/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.js +1 -10
- package/dist/esm/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.js.map +1 -1
- package/dist/esm/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.js +58 -67
- package/dist/esm/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.js.map +1 -1
- package/dist/esm/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.js +74 -75
- package/dist/esm/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.js.map +1 -1
- package/dist/esm/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.js +17 -7
- package/dist/esm/react/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.js.map +1 -1
- package/dist/esm/react/src/core/WebAuthnManager/index.js +3 -3
- package/dist/esm/react/src/core/WebAuthnManager/index.js.map +1 -1
- package/dist/esm/react/src/core/defaultConfigs.js +3 -1
- package/dist/esm/react/src/core/defaultConfigs.js.map +1 -1
- package/dist/esm/react/styles/styles.css +2 -0
- package/dist/esm/sdk/{EmailRecovery-Dl8b4ONg.js → EmailRecovery-Y7rurd4B.js} +3 -3
- package/dist/esm/sdk/{EmailRecovery-v9oNO2Tc.js → EmailRecovery-lsjLWApQ.js} +1 -1
- package/dist/esm/sdk/{IndexedDBManager-B1cUvdyY.js → IndexedDBManager-CmdN7smS.js} +3 -3
- package/dist/esm/sdk/{createAdapters-Dv7ZJPf1.js → createAdapters-4c8mBiD5.js} +2 -11
- package/dist/esm/sdk/{createAdapters-Dv7ZJPf1.js.map → createAdapters-4c8mBiD5.js.map} +1 -1
- package/dist/esm/sdk/{createAdapters-1Hmc1vVC.js → createAdapters-DF32SIZa.js} +1 -10
- package/dist/esm/sdk/{defaultConfigs-BmCU1_qI.js → defaultConfigs-BQqiXif-.js} +3 -1
- package/dist/esm/sdk/{emailRecovery-4J-g9tlY.js → emailRecovery-C0LSDleV.js} +5 -5
- package/dist/esm/sdk/{getDeviceNumber-f8bfPB9U.js → getDeviceNumber-WiNzKx1x.js} +4 -2
- package/dist/esm/sdk/{getDeviceNumber-f8bfPB9U.js.map → getDeviceNumber-WiNzKx1x.js.map} +1 -1
- package/dist/esm/sdk/{linkDevice-C98klpcE.js → linkDevice-Ds1GNIDk.js} +4 -4
- package/dist/esm/sdk/{localOnly-40zxrBMm.js → localOnly-COpDBMkm.js} +2 -2
- package/dist/esm/sdk/{localOnly-40zxrBMm.js.map → localOnly-COpDBMkm.js.map} +1 -1
- package/dist/esm/sdk/{localOnly-BZPBj14l.js → localOnly-DQQuqgjJ.js} +1 -1
- package/dist/esm/sdk/{login-DnROv3eA.js → login-BKhTuGcy.js} +3 -3
- package/dist/esm/sdk/offline-export-app.js +29 -19
- package/dist/esm/sdk/offline-export-app.js.map +1 -1
- package/dist/esm/sdk/{registration-BP9M3tE1.js → registration-BR2G9tz_.js} +59 -68
- package/dist/esm/sdk/{registration-MrAOC8Ub.js → registration-R70lvG_o.js} +60 -69
- package/dist/esm/sdk/registration-R70lvG_o.js.map +1 -0
- package/dist/esm/sdk/{router-BEGGuWaB.js → router-2aGn-CTp.js} +1 -1
- package/dist/esm/sdk/{rpcCalls-CMzj_Va_.js → rpcCalls-BPI0icZG.js} +2 -2
- package/dist/esm/sdk/{rpcCalls-B44MZora.js → rpcCalls-BW3M_q3-.js} +1 -1
- package/dist/esm/sdk/{scanDevice-Cp-r-Z2T.js → scanDevice-BBSehlMx.js} +4 -4
- package/dist/esm/sdk/{syncAccount-CqWCmBVb.js → syncAccount-DEZHBiRa.js} +4 -4
- package/dist/esm/sdk/{syncAccount-Dt5jJbEB.js → syncAccount-DHKtl-xh.js} +2 -2
- package/dist/esm/sdk/{transactions-DAZrPW-6.js → transactions-Cg1TIUyK.js} +76 -77
- package/dist/esm/sdk/{transactions-CrjP8yPD.js → transactions-CxsklyCK.js} +77 -78
- package/dist/esm/sdk/transactions-CxsklyCK.js.map +1 -0
- package/dist/esm/sdk/wallet-iframe-host.js +116 -94
- package/dist/esm/server/core/AuthService.js +49 -6
- package/dist/esm/server/core/AuthService.js.map +1 -1
- package/dist/esm/server/sdk/src/core/defaultConfigs.js.map +1 -1
- package/dist/esm/wasm_vrf_worker/pkg/wasm_vrf_worker_bg.wasm +0 -0
- package/dist/types/src/__tests__/setup/bootstrap.d.ts.map +1 -1
- package/dist/types/src/core/IndexedDBManager/passkeyClientDB.d.ts +1 -1
- package/dist/types/src/core/IndexedDBManager/passkeyClientDB.d.ts.map +1 -1
- package/dist/types/src/core/TatchiPasskey/faucets/createAccountRelayServer.d.ts +6 -6
- package/dist/types/src/core/TatchiPasskey/faucets/createAccountRelayServer.d.ts.map +1 -1
- package/dist/types/src/core/TatchiPasskey/registration.d.ts.map +1 -1
- package/dist/types/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.d.ts +0 -5
- package/dist/types/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/adapters/session.d.ts.map +1 -1
- package/dist/types/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/registration.d.ts.map +1 -1
- package/dist/types/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/flows/transactions.d.ts.map +1 -1
- package/dist/types/src/core/WebAuthnManager/VrfWorkerManager/confirmTxFlow/handleSecureConfirmRequest.d.ts.map +1 -1
- package/dist/types/src/core/WebAuthnManager/index.d.ts +1 -1
- package/dist/types/src/core/WebAuthnManager/index.d.ts.map +1 -1
- package/dist/types/src/core/defaultConfigs.d.ts.map +1 -1
- package/dist/types/src/react/components/PasskeyAuthMenu/preload.d.ts.map +1 -1
- package/dist/types/src/react/components/PasskeyAuthMenu/shell.d.ts.map +1 -1
- package/dist/types/src/react/components/PasskeyAuthMenu/skeleton.d.ts +1 -1
- package/dist/types/src/react/components/PasskeyAuthMenu/skeleton.d.ts.map +1 -1
- package/dist/types/src/react/components/PasskeyAuthMenu/ui/EmailRecoverySlide.d.ts.map +1 -1
- package/dist/types/src/server/core/AuthService.d.ts.map +1 -1
- package/dist/workers/offline-export-sw.js +156 -1
- package/dist/workers/wasm_vrf_worker_bg.wasm +0 -0
- package/dist/workers/web3authn-signer.worker.js +1360 -2
- package/dist/workers/web3authn-vrf.worker.js +2857 -2
- package/package.json +1 -1
- package/dist/cjs/react/components/PasskeyAuthMenu/PasskeyAuthMenu-CRlobBrN.css.map +0 -1
- package/dist/esm/react/components/PasskeyAuthMenu/PasskeyAuthMenu-D2VHZ04W.css.map +0 -1
- package/dist/esm/sdk/registration-MrAOC8Ub.js.map +0 -1
- package/dist/esm/sdk/transactions-CrjP8yPD.js.map +0 -1
|
@@ -1 +1,156 @@
|
|
|
1
|
-
|
|
1
|
+
// src/core/OfflineExport/offline-export-sw.ts
|
|
2
|
+
var VERSION = "OFFLINE_EXPORT_v6";
|
|
3
|
+
var CACHE_NAME = `OFFLINE_EXPORT::${VERSION}`;
|
|
4
|
+
var SCOPE_PATH = (() => {
|
|
5
|
+
const scope = self.registration?.scope;
|
|
6
|
+
if (scope) {
|
|
7
|
+
const p = new URL(scope).pathname;
|
|
8
|
+
return p.endsWith("/") ? p : p + "/";
|
|
9
|
+
}
|
|
10
|
+
return "/offline-export/";
|
|
11
|
+
})();
|
|
12
|
+
var STABLE_PRECACHE = [
|
|
13
|
+
`${SCOPE_PATH}`,
|
|
14
|
+
`${SCOPE_PATH}index.html`,
|
|
15
|
+
`${SCOPE_PATH}manifest.webmanifest`,
|
|
16
|
+
`${SCOPE_PATH}precache.manifest.json`,
|
|
17
|
+
`${SCOPE_PATH}offline-export-app.js`,
|
|
18
|
+
`${SCOPE_PATH}workers/web3authn-signer.worker.js`,
|
|
19
|
+
`${SCOPE_PATH}workers/web3authn-vrf.worker.js`,
|
|
20
|
+
`${SCOPE_PATH}workers/wasm_signer_worker_bg.wasm`,
|
|
21
|
+
`${SCOPE_PATH}workers/wasm_vrf_worker_bg.wasm`,
|
|
22
|
+
`/sdk/wallet-service.css`,
|
|
23
|
+
`/sdk/w3a-components.css`,
|
|
24
|
+
`/sdk/drawer.css`,
|
|
25
|
+
`/sdk/tx-tree.css`,
|
|
26
|
+
`/sdk/tx-confirmer.css`,
|
|
27
|
+
`/sdk/export-viewer.css`,
|
|
28
|
+
`/sdk/export-iframe.css`,
|
|
29
|
+
`/sdk/wallet-shims.js`,
|
|
30
|
+
`/sdk/offline-export-app.js`,
|
|
31
|
+
`/sdk/export-private-key-viewer.js`,
|
|
32
|
+
`/sdk/iframe-export-bootstrap.js`,
|
|
33
|
+
`/sdk/workers/web3authn-signer.worker.js`,
|
|
34
|
+
`/sdk/workers/web3authn-vrf.worker.js`,
|
|
35
|
+
`/sdk/workers/wasm_signer_worker_bg.wasm`,
|
|
36
|
+
`/sdk/workers/wasm_vrf_worker_bg.wasm`
|
|
37
|
+
];
|
|
38
|
+
async function precacheAll(cache) {
|
|
39
|
+
const cacheAdd = async (url) => {
|
|
40
|
+
try {
|
|
41
|
+
await cache.add(new Request(url, { cache: "reload" }));
|
|
42
|
+
return;
|
|
43
|
+
} catch {}
|
|
44
|
+
try {
|
|
45
|
+
await cache.add(url);
|
|
46
|
+
} catch {}
|
|
47
|
+
};
|
|
48
|
+
for (const url of STABLE_PRECACHE) {
|
|
49
|
+
await cacheAdd(url);
|
|
50
|
+
}
|
|
51
|
+
try {
|
|
52
|
+
const res = await cache.match(`${SCOPE_PATH}precache.manifest.json`, { ignoreSearch: true });
|
|
53
|
+
if (res && res.ok) {
|
|
54
|
+
const list = await res.clone().json();
|
|
55
|
+
if (Array.isArray(list)) {
|
|
56
|
+
const urls = list.filter((x) => typeof x === "string" && (x.startsWith(SCOPE_PATH) || x.startsWith("/sdk/"))).map((x) => x);
|
|
57
|
+
if (urls.length) {
|
|
58
|
+
await Promise.allSettled(urls.map((u) => cacheAdd(u)));
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
} catch {}
|
|
63
|
+
}
|
|
64
|
+
self.addEventListener("install", (event) => {
|
|
65
|
+
event.waitUntil((async () => {
|
|
66
|
+
const cache = await caches.open(CACHE_NAME);
|
|
67
|
+
await precacheAll(cache);
|
|
68
|
+
self.skipWaiting?.();
|
|
69
|
+
})());
|
|
70
|
+
});
|
|
71
|
+
self.addEventListener("activate", (event) => {
|
|
72
|
+
event.waitUntil((async () => {
|
|
73
|
+
const keys = await caches.keys();
|
|
74
|
+
await Promise.all(keys.filter((k) => k.startsWith("OFFLINE_EXPORT::") && k !== CACHE_NAME).map((k) => caches.delete(k)));
|
|
75
|
+
self.clients?.claim?.();
|
|
76
|
+
})());
|
|
77
|
+
});
|
|
78
|
+
self.addEventListener("fetch", (event) => {
|
|
79
|
+
const req = event.request;
|
|
80
|
+
if (req.method !== "GET")
|
|
81
|
+
return;
|
|
82
|
+
const url = new URL(req.url);
|
|
83
|
+
const isOfflineScope = url.pathname.startsWith(SCOPE_PATH);
|
|
84
|
+
const isSdkAsset = url.pathname.startsWith("/sdk/");
|
|
85
|
+
if (!isOfflineScope && !isSdkAsset)
|
|
86
|
+
return;
|
|
87
|
+
event.respondWith((async () => {
|
|
88
|
+
const match = await caches.match(req, { ignoreSearch: true });
|
|
89
|
+
if (match)
|
|
90
|
+
return match;
|
|
91
|
+
if (isOfflineScope && url.pathname === `${SCOPE_PATH}offline-export-app.js`) {
|
|
92
|
+
const alt = await caches.match(`/sdk/offline-export-app.js`, { ignoreSearch: true });
|
|
93
|
+
if (alt)
|
|
94
|
+
return alt;
|
|
95
|
+
}
|
|
96
|
+
if (isOfflineScope && url.pathname.startsWith(`${SCOPE_PATH}workers/`)) {
|
|
97
|
+
const rest = url.pathname.slice(`${SCOPE_PATH}workers/`.length);
|
|
98
|
+
const altUrl = `/sdk/workers/${rest}`;
|
|
99
|
+
const alt = await caches.match(altUrl, { ignoreSearch: true });
|
|
100
|
+
if (alt)
|
|
101
|
+
return alt;
|
|
102
|
+
}
|
|
103
|
+
if (isOfflineScope && !url.pathname.startsWith(`${SCOPE_PATH}workers/`)) {
|
|
104
|
+
const isStaticAsset = /\.(?:js|css)(?:$|\?)/.test(url.pathname);
|
|
105
|
+
if (isStaticAsset) {
|
|
106
|
+
const base = url.pathname.split("/").pop() || "";
|
|
107
|
+
if (base) {
|
|
108
|
+
const alt = await caches.match(`/sdk/${base}`, { ignoreSearch: true });
|
|
109
|
+
if (alt)
|
|
110
|
+
return alt;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
if (isSdkAsset) {
|
|
115
|
+
try {
|
|
116
|
+
const res = await fetch(req);
|
|
117
|
+
if (res && res.ok) {
|
|
118
|
+
const cache = await caches.open(CACHE_NAME);
|
|
119
|
+
await cache.put(req, res.clone());
|
|
120
|
+
return res;
|
|
121
|
+
}
|
|
122
|
+
} catch {}
|
|
123
|
+
}
|
|
124
|
+
return new Response("Not cached", { status: 504, statusText: "Offline asset not pre-cached" });
|
|
125
|
+
})());
|
|
126
|
+
});
|
|
127
|
+
self.addEventListener("message", (event) => {
|
|
128
|
+
const data = event?.data;
|
|
129
|
+
if (!data || typeof data !== "object")
|
|
130
|
+
return;
|
|
131
|
+
const type = data.type || "";
|
|
132
|
+
switch (type) {
|
|
133
|
+
case "OFFLINE_EXPORT_PING":
|
|
134
|
+
event.source?.postMessage?.({ type: "OFFLINE_EXPORT_PONG", version: VERSION, scope: SCOPE_PATH, cacheName: CACHE_NAME });
|
|
135
|
+
break;
|
|
136
|
+
case "OFFLINE_EXPORT_PRIME": {
|
|
137
|
+
event.waitUntil((async () => {
|
|
138
|
+
try {
|
|
139
|
+
const cache = await caches.open(CACHE_NAME);
|
|
140
|
+
await precacheAll(cache);
|
|
141
|
+
event.source?.postMessage?.({ type: "OFFLINE_EXPORT_PRIMED", ok: true, version: VERSION });
|
|
142
|
+
} catch (e) {
|
|
143
|
+
event.source?.postMessage?.({
|
|
144
|
+
type: "OFFLINE_EXPORT_PRIMED",
|
|
145
|
+
ok: false,
|
|
146
|
+
version: VERSION,
|
|
147
|
+
error: String(e?.message || e || "failed")
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
})());
|
|
151
|
+
break;
|
|
152
|
+
}
|
|
153
|
+
default:
|
|
154
|
+
break;
|
|
155
|
+
}
|
|
156
|
+
});
|
|
Binary file
|