@kodexa-ai/document-wasm-ts 8.0.0-develop-20665016781 → 8.0.0-develop-20666282928

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.
Files changed (38) hide show
  1. package/dist/KddbDocument.d.ts +0 -9
  2. package/dist/KddbDocument.d.ts.map +1 -1
  3. package/dist/KddbDocument.js +0 -19
  4. package/dist/KddbDocument.js.map +1 -1
  5. package/dist/kodexa-shared-worker.js +594 -0
  6. package/dist/kodexa-shared-worker.js.map +7 -0
  7. package/dist/kodexa-worker.js +80 -21
  8. package/dist/kodexa-worker.js.map +3 -3
  9. package/dist/kodexa.wasm +0 -0
  10. package/dist/worker/KodexaSharedWorker.d.ts +267 -0
  11. package/dist/worker/KodexaSharedWorker.d.ts.map +1 -0
  12. package/dist/worker/KodexaSharedWorker.js +475 -0
  13. package/dist/worker/KodexaSharedWorker.js.map +1 -0
  14. package/dist/worker/KodexaWorker.d.ts +110 -0
  15. package/dist/worker/KodexaWorker.d.ts.map +1 -1
  16. package/dist/worker/KodexaWorker.js +163 -0
  17. package/dist/worker/KodexaWorker.js.map +1 -1
  18. package/dist/worker/KodexaWorkerDocument.d.ts +183 -0
  19. package/dist/worker/KodexaWorkerDocument.d.ts.map +1 -1
  20. package/dist/worker/KodexaWorkerDocument.js +458 -0
  21. package/dist/worker/KodexaWorkerDocument.js.map +1 -1
  22. package/dist/worker/KodexaWorkerNode.d.ts +22 -0
  23. package/dist/worker/KodexaWorkerNode.d.ts.map +1 -1
  24. package/dist/worker/KodexaWorkerNode.js +64 -3
  25. package/dist/worker/KodexaWorkerNode.js.map +1 -1
  26. package/dist/worker/index.d.ts +23 -6
  27. package/dist/worker/index.d.ts.map +1 -1
  28. package/dist/worker/index.js +21 -5
  29. package/dist/worker/index.js.map +1 -1
  30. package/dist/worker/kodexa-shared-worker.d.ts +20 -0
  31. package/dist/worker/kodexa-shared-worker.d.ts.map +1 -0
  32. package/dist/worker/kodexa-shared-worker.js +460 -0
  33. package/dist/worker/kodexa-shared-worker.js.map +1 -0
  34. package/dist/worker/kodexa-worker.js +110 -22
  35. package/dist/worker/kodexa-worker.js.map +1 -1
  36. package/dist/worker/types.d.ts +76 -1
  37. package/dist/worker/types.d.ts.map +1 -1
  38. package/package.json +1 -1
@@ -0,0 +1,594 @@
1
+ var __getOwnPropNames = Object.getOwnPropertyNames;
2
+ var __esm = (fn, res) => function __init() {
3
+ return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
4
+ };
5
+ var __commonJS = (cb, mod) => function __require() {
6
+ return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
7
+ };
8
+
9
+ // src/wasm/sqljs-core.ts
10
+ function uint8ArrayToBase64(bytes) {
11
+ if (bytes.length < 32768) {
12
+ let binary2 = "";
13
+ for (let i = 0; i < bytes.length; i++) {
14
+ binary2 += String.fromCharCode(bytes[i]);
15
+ }
16
+ return btoa(binary2);
17
+ }
18
+ const chunkSize = 32768;
19
+ let binary = "";
20
+ for (let i = 0; i < bytes.length; i += chunkSize) {
21
+ const chunk = bytes.subarray(i, Math.min(i + chunkSize, bytes.length));
22
+ binary += String.fromCharCode.apply(null, Array.from(chunk));
23
+ }
24
+ return btoa(binary);
25
+ }
26
+ function processRowForJson(obj) {
27
+ const result = {};
28
+ for (const key in obj) {
29
+ const value = obj[key];
30
+ if (value instanceof Uint8Array) {
31
+ try {
32
+ const base64 = uint8ArrayToBase64(value);
33
+ result[key] = "base64:" + base64;
34
+ } catch (err) {
35
+ console.error(`[sql.js] Failed to convert BLOB column '${key}' (${value.length} bytes):`, err);
36
+ result[key] = null;
37
+ }
38
+ } else {
39
+ result[key] = value;
40
+ }
41
+ }
42
+ return result;
43
+ }
44
+ function createDatabaseOp() {
45
+ if (!sqlInstance) {
46
+ console.error("[sql.js] Not initialized");
47
+ return 0;
48
+ }
49
+ try {
50
+ const db = new sqlInstance.Database();
51
+ const handle = nextHandle++;
52
+ databases.set(handle, db);
53
+ console.log(`[sql.js] Created database with handle ${handle}`);
54
+ return handle;
55
+ } catch (error) {
56
+ console.error("[sql.js] Failed to create database:", error);
57
+ return 0;
58
+ }
59
+ }
60
+ function execOp(handle, sql) {
61
+ const db = databases.get(handle);
62
+ if (!db) {
63
+ console.error(`[sql.js] Invalid database handle: ${handle}`);
64
+ return 0;
65
+ }
66
+ try {
67
+ db.run(sql);
68
+ return 1;
69
+ } catch (error) {
70
+ console.error("[sql.js] Exec failed:", error);
71
+ return 0;
72
+ }
73
+ }
74
+ function queryOp(handle, sql, paramsJson) {
75
+ const db = databases.get(handle);
76
+ if (!db) {
77
+ console.error(`[sql.js] Invalid database handle: ${handle}`);
78
+ return "[]";
79
+ }
80
+ try {
81
+ let params = [];
82
+ if (paramsJson && paramsJson !== "[]" && paramsJson !== "null") {
83
+ params = JSON.parse(paramsJson);
84
+ }
85
+ const stmt = db.prepare(sql);
86
+ if (params.length > 0) {
87
+ stmt.bind(params);
88
+ }
89
+ const results = [];
90
+ while (stmt.step()) {
91
+ results.push(processRowForJson(stmt.getAsObject()));
92
+ }
93
+ stmt.free();
94
+ return JSON.stringify(results);
95
+ } catch (error) {
96
+ console.error("[sql.js] Query failed:", sql, error);
97
+ return "[]";
98
+ }
99
+ }
100
+ function insertOp(handle, sql, paramsJson) {
101
+ const db = databases.get(handle);
102
+ if (!db) {
103
+ console.error(`[sql.js] Invalid database handle: ${handle}`);
104
+ return 0;
105
+ }
106
+ try {
107
+ let params = [];
108
+ if (paramsJson && paramsJson !== "[]" && paramsJson !== "null") {
109
+ params = JSON.parse(paramsJson);
110
+ }
111
+ if (params.length > 0) {
112
+ db.run(sql, params);
113
+ } else {
114
+ db.run(sql);
115
+ }
116
+ const result = db.exec("SELECT last_insert_rowid() as id");
117
+ if (result.length > 0 && result[0].values.length > 0) {
118
+ return result[0].values[0][0];
119
+ }
120
+ return 0;
121
+ } catch (error) {
122
+ console.error("[sql.js] Insert failed:", sql, error);
123
+ return 0;
124
+ }
125
+ }
126
+ function execParamsOp(handle, sql, paramsJson) {
127
+ const db = databases.get(handle);
128
+ if (!db) {
129
+ console.error(`[sql.js] Invalid database handle: ${handle}`);
130
+ return -1;
131
+ }
132
+ try {
133
+ let params = [];
134
+ if (paramsJson && paramsJson !== "[]" && paramsJson !== "null") {
135
+ params = JSON.parse(paramsJson);
136
+ }
137
+ if (params.length > 0) {
138
+ db.run(sql, params);
139
+ } else {
140
+ db.run(sql);
141
+ }
142
+ const result = db.exec("SELECT changes() as count");
143
+ if (result.length > 0 && result[0].values.length > 0) {
144
+ return result[0].values[0][0];
145
+ }
146
+ return 0;
147
+ } catch (error) {
148
+ console.error("[sql.js] ExecParams failed:", sql, error);
149
+ return -1;
150
+ }
151
+ }
152
+ function exportOp(handle) {
153
+ const db = databases.get(handle);
154
+ if (!db) {
155
+ console.error(`[sql.js] Invalid database handle: ${handle}`);
156
+ return "";
157
+ }
158
+ try {
159
+ const data = db.export();
160
+ return uint8ArrayToBase64(data);
161
+ } catch (error) {
162
+ console.error("[sql.js] Export failed:", error);
163
+ return "";
164
+ }
165
+ }
166
+ function importOp(base64Data) {
167
+ if (!sqlInstance) {
168
+ console.error("[sql.js] Not initialized");
169
+ return 0;
170
+ }
171
+ try {
172
+ const binary = atob(base64Data);
173
+ const data = new Uint8Array(binary.length);
174
+ for (let i = 0; i < binary.length; i++) {
175
+ data[i] = binary.charCodeAt(i);
176
+ }
177
+ const db = new sqlInstance.Database(data);
178
+ const handle = nextHandle++;
179
+ databases.set(handle, db);
180
+ console.log(`[sql.js] Imported database with handle ${handle}`);
181
+ return handle;
182
+ } catch (error) {
183
+ console.error("[sql.js] Import failed:", error);
184
+ return 0;
185
+ }
186
+ }
187
+ function loadDirectOp(bytes) {
188
+ if (!sqlInstance) {
189
+ console.error("[sql.js] Not initialized");
190
+ return 0;
191
+ }
192
+ try {
193
+ const db = new sqlInstance.Database(bytes);
194
+ const handle = nextHandle++;
195
+ databases.set(handle, db);
196
+ return handle;
197
+ } catch (error) {
198
+ console.error("[sql.js] Failed to load database directly:", error);
199
+ return 0;
200
+ }
201
+ }
202
+ function closeOp(handle) {
203
+ const db = databases.get(handle);
204
+ if (db) {
205
+ try {
206
+ db.close();
207
+ } catch (error) {
208
+ console.error("[sql.js] Close failed:", error);
209
+ }
210
+ databases.delete(handle);
211
+ console.log(`[sql.js] Closed database with handle ${handle}`);
212
+ }
213
+ }
214
+ function getErrorOp(_handle) {
215
+ return "";
216
+ }
217
+ function setSqlInstance(SQL2) {
218
+ sqlInstance = SQL2;
219
+ }
220
+ function exposeBridgeFunctions() {
221
+ const g = globalThis;
222
+ g.sqljsCreateDatabase = createDatabaseOp;
223
+ g.sqljsExec = execOp;
224
+ g.sqljsQuery = queryOp;
225
+ g.sqljsInsert = insertOp;
226
+ g.sqljsExecParams = execParamsOp;
227
+ g.sqljsExport = exportOp;
228
+ g.sqljsImport = importOp;
229
+ g.sqljsClose = closeOp;
230
+ g.sqljsGetError = getErrorOp;
231
+ g.sqljsLoadDirect = loadDirectOp;
232
+ g.sqljsDatabases = databases;
233
+ console.log("[sql.js] Bridge functions exposed to globalThis");
234
+ }
235
+ var databases, nextHandle, sqlInstance;
236
+ var init_sqljs_core = __esm({
237
+ "src/wasm/sqljs-core.ts"() {
238
+ "use strict";
239
+ databases = /* @__PURE__ */ new Map();
240
+ nextHandle = 1;
241
+ sqlInstance = null;
242
+ }
243
+ });
244
+
245
+ // src/worker/kodexa-shared-worker.ts
246
+ var require_kodexa_shared_worker = __commonJS({
247
+ "src/worker/kodexa-shared-worker.ts"(exports, module) {
248
+ init_sqljs_core();
249
+ var ports = /* @__PURE__ */ new Map();
250
+ var nextPortId = 1;
251
+ function generatePortId() {
252
+ return `port_${nextPortId++}_${Date.now()}`;
253
+ }
254
+ var documentSubscriptions = /* @__PURE__ */ new Map();
255
+ var documentUsers = /* @__PURE__ */ new Map();
256
+ function subscribeToDocument(docRef, portId) {
257
+ if (!documentSubscriptions.has(docRef)) {
258
+ documentSubscriptions.set(docRef, /* @__PURE__ */ new Set());
259
+ }
260
+ documentSubscriptions.get(docRef).add(portId);
261
+ console.log(`[shared-worker] Port ${portId} subscribed to document ${docRef}`);
262
+ }
263
+ function unsubscribeFromDocument(docRef, portId) {
264
+ const subscribers = documentSubscriptions.get(docRef);
265
+ if (subscribers) {
266
+ subscribers.delete(portId);
267
+ if (subscribers.size === 0) {
268
+ documentSubscriptions.delete(docRef);
269
+ }
270
+ console.log(`[shared-worker] Port ${portId} unsubscribed from document ${docRef}`);
271
+ }
272
+ }
273
+ function registerDocumentUser(docRef, portId) {
274
+ if (!documentUsers.has(docRef)) {
275
+ documentUsers.set(docRef, /* @__PURE__ */ new Set());
276
+ }
277
+ documentUsers.get(docRef).add(portId);
278
+ }
279
+ function unregisterDocumentUser(docRef, portId) {
280
+ const users = documentUsers.get(docRef);
281
+ if (users) {
282
+ users.delete(portId);
283
+ if (users.size === 0) {
284
+ documentUsers.delete(docRef);
285
+ return true;
286
+ }
287
+ }
288
+ return false;
289
+ }
290
+ function cleanupPort(portId) {
291
+ console.log(`[shared-worker] Cleaning up port ${portId}`);
292
+ for (const [docRef, subscribers] of documentSubscriptions) {
293
+ subscribers.delete(portId);
294
+ if (subscribers.size === 0) {
295
+ documentSubscriptions.delete(docRef);
296
+ }
297
+ }
298
+ for (const [docRef, users] of documentUsers) {
299
+ users.delete(portId);
300
+ if (users.size === 0) {
301
+ console.log(`[shared-worker] Freeing document ${docRef} - no more users`);
302
+ try {
303
+ const freeDocument = self.freeDocument;
304
+ if (typeof freeDocument === "function") {
305
+ freeDocument(docRef);
306
+ }
307
+ } catch (error) {
308
+ console.error(`[shared-worker] Error freeing document ${docRef}:`, error);
309
+ }
310
+ documentUsers.delete(docRef);
311
+ }
312
+ }
313
+ ports.delete(portId);
314
+ }
315
+ function broadcastToSubscribers(docRef, eventType, detail) {
316
+ const subscribers = documentSubscriptions.get(docRef);
317
+ if (!subscribers || subscribers.size === 0) {
318
+ return;
319
+ }
320
+ const message = {
321
+ type: "wasmEvent",
322
+ eventType,
323
+ detail,
324
+ documentRef: docRef
325
+ };
326
+ for (const portId of subscribers) {
327
+ const port = ports.get(portId);
328
+ if (port) {
329
+ try {
330
+ port.postMessage(message);
331
+ } catch (error) {
332
+ console.error(`[shared-worker] Error posting to port ${portId}:`, error);
333
+ }
334
+ }
335
+ }
336
+ }
337
+ function broadcastToAll(message) {
338
+ for (const [portId, port] of ports) {
339
+ try {
340
+ port.postMessage(message);
341
+ } catch (error) {
342
+ console.error(`[shared-worker] Error posting to port ${portId}:`, error);
343
+ }
344
+ }
345
+ }
346
+ var initialized = false;
347
+ var initPromise = null;
348
+ var config = {};
349
+ function setupEventForwarding() {
350
+ const documentShim = {
351
+ addEventListener: (type, handler) => {
352
+ console.log(`[shared-worker] Event listener registered for: ${type}`);
353
+ self.addEventListener(type, handler);
354
+ },
355
+ removeEventListener: (type, handler) => {
356
+ self.removeEventListener(type, handler);
357
+ },
358
+ dispatchEvent: (event) => {
359
+ self.dispatchEvent(event);
360
+ if (event instanceof CustomEvent) {
361
+ const detail = event.detail;
362
+ const docRef = detail?.docRef;
363
+ if (docRef !== void 0) {
364
+ broadcastToSubscribers(docRef, event.type, event.detail);
365
+ } else {
366
+ broadcastToAll({
367
+ type: "wasmEvent",
368
+ eventType: event.type,
369
+ detail: event.detail
370
+ });
371
+ }
372
+ }
373
+ return true;
374
+ },
375
+ createElement: () => null,
376
+ body: null,
377
+ documentElement: null
378
+ };
379
+ self.document = documentShim;
380
+ self.addEventListener("kodexaDataChange", (event) => {
381
+ if (event instanceof CustomEvent) {
382
+ const detail = event.detail;
383
+ const docRef = detail?.docRef;
384
+ if (docRef !== void 0) {
385
+ broadcastToSubscribers(docRef, "kodexaDataChange", event.detail);
386
+ } else {
387
+ broadcastToAll({
388
+ type: "wasmEvent",
389
+ eventType: "kodexaDataChange",
390
+ detail: event.detail
391
+ });
392
+ }
393
+ }
394
+ });
395
+ console.log("[shared-worker] Event forwarding configured");
396
+ }
397
+ async function initializeSqlJs() {
398
+ const sqlJsUrl = "https://sql.js.org/dist/sql-wasm.js";
399
+ const sqlWasmUrl = "https://sql.js.org/dist/sql-wasm.wasm";
400
+ try {
401
+ const response = await fetch(sqlJsUrl);
402
+ if (!response.ok) {
403
+ throw new Error(`Failed to fetch sql-wasm.js: ${response.statusText}`);
404
+ }
405
+ const code = await response.text();
406
+ const wrappedCode = `
407
+ (function(module, exports) {
408
+ ${code}
409
+ return module.exports;
410
+ })
411
+ `;
412
+ const moduleFactory = eval(wrappedCode);
413
+ const mockModule = { exports: {} };
414
+ const initSqlJs = moduleFactory(mockModule, mockModule.exports);
415
+ if (typeof initSqlJs !== "function") {
416
+ throw new Error("initSqlJs not found after loading sql-wasm.js");
417
+ }
418
+ const sqlConfig = {
419
+ locateFile: () => sqlWasmUrl
420
+ };
421
+ const SQL = await initSqlJs(sqlConfig);
422
+ setSqlInstance(SQL);
423
+ exposeBridgeFunctions();
424
+ self.loadDocument = (bytes) => {
425
+ const handle = loadDirectOp(bytes);
426
+ if (handle === 0) {
427
+ console.error("[shared-worker] Failed to load database");
428
+ return 0;
429
+ }
430
+ return self.createDocumentFromHandle(handle);
431
+ };
432
+ console.log("[shared-worker] sql.js initialized from official CDN");
433
+ } catch (error) {
434
+ console.error("[shared-worker] Failed to initialize sql.js:", error);
435
+ throw new Error(`Failed to initialize sql.js: ${error}`);
436
+ }
437
+ }
438
+ async function loadWasmExec() {
439
+ if (self.Go) {
440
+ return;
441
+ }
442
+ const baseUrl = config.wasmBaseUrl || self.location.origin;
443
+ const wasmExecUrl = `${baseUrl}/wasm_exec.js`;
444
+ try {
445
+ const response = await fetch(wasmExecUrl);
446
+ if (!response.ok) {
447
+ throw new Error(`Failed to fetch wasm_exec.js: ${response.statusText}`);
448
+ }
449
+ const code = await response.text();
450
+ eval(code);
451
+ console.log("[shared-worker] wasm_exec.js loaded");
452
+ } catch (error) {
453
+ throw new Error(`Failed to load wasm_exec.js: ${error}`);
454
+ }
455
+ }
456
+ async function loadGoWasm() {
457
+ const baseUrl2 = config.wasmBaseUrl || self.location.origin;
458
+ const wasmUrl = `${baseUrl2}/kodexa.wasm`;
459
+ const response2 = await fetch(wasmUrl);
460
+ if (!response2.ok) {
461
+ throw new Error(`Failed to fetch kodexa.wasm: ${response2.statusText}`);
462
+ }
463
+ const wasmBytes = await response2.arrayBuffer();
464
+ const go = new self.Go();
465
+ const result = await WebAssembly.instantiate(wasmBytes, go.importObject);
466
+ go.run(result.instance);
467
+ const logLevel = config.logLevel || "warn";
468
+ if (self.kodexa_setLogLevel) {
469
+ self.kodexa_setLogLevel(logLevel);
470
+ }
471
+ console.log("[shared-worker] Go WASM loaded");
472
+ }
473
+ async function initialize(workerConfig) {
474
+ if (initialized) {
475
+ return;
476
+ }
477
+ if (initPromise) {
478
+ return initPromise;
479
+ }
480
+ config = workerConfig || {};
481
+ initPromise = (async () => {
482
+ try {
483
+ setupEventForwarding();
484
+ await initializeSqlJs();
485
+ await loadWasmExec();
486
+ await loadGoWasm();
487
+ initialized = true;
488
+ console.log("[shared-worker] Kodexa WASM fully initialized");
489
+ } catch (error) {
490
+ console.error("[shared-worker] Initialization failed:", error);
491
+ throw error;
492
+ }
493
+ })();
494
+ return initPromise;
495
+ }
496
+ function handleCall(request) {
497
+ const { id, method, args, portId } = request;
498
+ try {
499
+ const fn = self[method];
500
+ if (typeof fn !== "function") {
501
+ return {
502
+ id,
503
+ portId,
504
+ success: false,
505
+ error: `Function '${method}' not found on globalThis`
506
+ };
507
+ }
508
+ const result = fn(...args || []);
509
+ if (method === "createDocument" || method === "createDocumentFromText" || method === "createDocumentFromJson" || method === "createDocumentFromKddbBytes" || method === "loadDocument") {
510
+ if (typeof result === "number" && result > 0) {
511
+ registerDocumentUser(result, portId);
512
+ }
513
+ }
514
+ if (method === "freeDocument" && args && args.length > 0) {
515
+ const docRef = args[0];
516
+ const shouldFree = unregisterDocumentUser(docRef, portId);
517
+ if (!shouldFree) {
518
+ return { id, portId, success: true, result: void 0 };
519
+ }
520
+ }
521
+ return { id, portId, success: true, result };
522
+ } catch (error) {
523
+ return {
524
+ id,
525
+ portId,
526
+ success: false,
527
+ error: error instanceof Error ? error.message : String(error)
528
+ };
529
+ }
530
+ }
531
+ function handlePortMessage(portId, port, event) {
532
+ const data = event.data;
533
+ if ("type" in data && data.type === "init") {
534
+ (async () => {
535
+ try {
536
+ await initialize(data.config);
537
+ const readyMessage = { type: "ready", portId };
538
+ port.postMessage(readyMessage);
539
+ } catch (error) {
540
+ const errorMessage = {
541
+ type: "error",
542
+ error: error instanceof Error ? error.message : String(error)
543
+ };
544
+ port.postMessage(errorMessage);
545
+ }
546
+ })();
547
+ return;
548
+ }
549
+ if ("type" in data && data.type === "subscribe") {
550
+ subscribeToDocument(data.docRef, portId);
551
+ return;
552
+ }
553
+ if ("type" in data && data.type === "unsubscribe") {
554
+ unsubscribeFromDocument(data.docRef, portId);
555
+ return;
556
+ }
557
+ if ("type" in data && data.type === "call") {
558
+ if (!initialized) {
559
+ const response3 = {
560
+ id: data.id,
561
+ portId,
562
+ success: false,
563
+ error: "Worker not initialized. Send init message first."
564
+ };
565
+ port.postMessage(response3);
566
+ return;
567
+ }
568
+ const request = { ...data, portId };
569
+ const response2 = handleCall(request);
570
+ port.postMessage(response2);
571
+ }
572
+ }
573
+ self.onconnect = (event) => {
574
+ const port = event.ports[0];
575
+ const portId = generatePortId();
576
+ console.log(`[shared-worker] New port connected: ${portId}`);
577
+ ports.set(portId, port);
578
+ port.onmessage = (e) => handlePortMessage(portId, port, e);
579
+ port.onmessageerror = () => {
580
+ console.log(`[shared-worker] Port ${portId} message error, cleaning up`);
581
+ cleanupPort(portId);
582
+ };
583
+ port.start();
584
+ if (initialized) {
585
+ const readyMessage = { type: "ready", portId };
586
+ port.postMessage(readyMessage);
587
+ }
588
+ port.postMessage({ type: "connected", portId });
589
+ };
590
+ console.log("[shared-worker] Kodexa SharedWorker ready for connections");
591
+ }
592
+ });
593
+ export default require_kodexa_shared_worker();
594
+ //# sourceMappingURL=kodexa-shared-worker.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/wasm/sqljs-core.ts", "../src/worker/kodexa-shared-worker.ts"],
4
+ "sourcesContent": ["/**\n * Core sql.js bridge operations - shared between environments\n *\n * This module contains all the database operations that are common between\n * the npm package (sqljs-bridge.ts) and browser CDN (browser-bridge.ts) implementations.\n *\n * The SQL instance is passed in from the wrapper modules, allowing them to\n * load sql.js in different ways (npm import vs CDN global).\n */\n\n// Database handle management\nconst databases = new Map<number, any>();\nlet nextHandle = 1;\n\n// Store SQL instance reference for operations that need it\nlet sqlInstance: any = null;\n\n/**\n * Convert Uint8Array to base64 string efficiently.\n * Uses chunked processing to handle large arrays without stack overflow.\n * @param bytes Uint8Array to convert\n * @returns Base64 encoded string\n */\nfunction uint8ArrayToBase64(bytes: Uint8Array): string {\n // For small arrays, use the simple method\n if (bytes.length < 32768) {\n let binary = '';\n for (let i = 0; i < bytes.length; i++) {\n binary += String.fromCharCode(bytes[i]);\n }\n return btoa(binary);\n }\n\n // For large arrays, process in chunks to avoid stack overflow\n const chunkSize = 32768;\n let binary = '';\n for (let i = 0; i < bytes.length; i += chunkSize) {\n const chunk = bytes.subarray(i, Math.min(i + chunkSize, bytes.length));\n binary += String.fromCharCode.apply(null, Array.from(chunk));\n }\n return btoa(binary);\n}\n\n/**\n * Convert a row object for JSON serialization.\n * Converts Uint8Array (BLOB) to base64-encoded string with \"base64:\" prefix.\n * @param obj Row object from sql.js\n * @returns Object safe for JSON.stringify\n */\nfunction processRowForJson(obj: Record<string, any>): Record<string, any> {\n const result: Record<string, any> = {};\n for (const key in obj) {\n const value = obj[key];\n if (value instanceof Uint8Array) {\n // Convert BLOB to base64 with prefix for Go to recognize\n try {\n const base64 = uint8ArrayToBase64(value);\n result[key] = 'base64:' + base64;\n } catch (err) {\n console.error(`[sql.js] Failed to convert BLOB column '${key}' (${value.length} bytes):`, err);\n result[key] = null;\n }\n } else {\n result[key] = value;\n }\n }\n return result;\n}\n\n// ============================================================================\n// Database Operations\n// ============================================================================\n\n/**\n * Create a new in-memory database\n * @returns Database handle (positive integer) or 0 on error\n */\nexport function createDatabaseOp(): number {\n if (!sqlInstance) {\n console.error('[sql.js] Not initialized');\n return 0;\n }\n\n try {\n const db = new sqlInstance.Database();\n const handle = nextHandle++;\n databases.set(handle, db);\n console.log(`[sql.js] Created database with handle ${handle}`);\n return handle;\n } catch (error) {\n console.error('[sql.js] Failed to create database:', error);\n return 0;\n }\n}\n\n/**\n * Execute SQL statement without returning results\n * @param handle Database handle\n * @param sql SQL statement\n * @returns 1 on success, 0 on error\n */\nexport function execOp(handle: number, sql: string): number {\n const db = databases.get(handle);\n if (!db) {\n console.error(`[sql.js] Invalid database handle: ${handle}`);\n return 0;\n }\n\n try {\n db.run(sql);\n return 1;\n } catch (error) {\n console.error('[sql.js] Exec failed:', error);\n return 0;\n }\n}\n\n/**\n * Execute SQL query with parameters and return results as JSON\n * @param handle Database handle\n * @param sql SQL query with ? placeholders\n * @param paramsJson JSON array of parameters\n * @returns JSON string of results (array of objects) or empty string on error\n */\nexport function queryOp(handle: number, sql: string, paramsJson: string): string {\n const db = databases.get(handle);\n if (!db) {\n console.error(`[sql.js] Invalid database handle: ${handle}`);\n return '[]';\n }\n\n try {\n // Parse parameters\n let params: any[] = [];\n if (paramsJson && paramsJson !== '[]' && paramsJson !== 'null') {\n params = JSON.parse(paramsJson);\n }\n\n // Execute query\n const stmt = db.prepare(sql);\n if (params.length > 0) {\n stmt.bind(params);\n }\n\n // Collect results - convert Uint8Array to base64 for Go\n const results: any[] = [];\n while (stmt.step()) {\n results.push(processRowForJson(stmt.getAsObject()));\n }\n stmt.free();\n\n return JSON.stringify(results);\n } catch (error) {\n console.error('[sql.js] Query failed:', sql, error);\n return '[]';\n }\n}\n\n/**\n * Execute INSERT statement and return the last inserted row ID\n * @param handle Database handle\n * @param sql INSERT statement with ? placeholders\n * @param paramsJson JSON array of parameters\n * @returns Last insert row ID or 0 on error\n */\nexport function insertOp(handle: number, sql: string, paramsJson: string): number {\n const db = databases.get(handle);\n if (!db) {\n console.error(`[sql.js] Invalid database handle: ${handle}`);\n return 0;\n }\n\n try {\n // Parse parameters\n let params: any[] = [];\n if (paramsJson && paramsJson !== '[]' && paramsJson !== 'null') {\n params = JSON.parse(paramsJson);\n }\n\n // Execute insert\n if (params.length > 0) {\n db.run(sql, params);\n } else {\n db.run(sql);\n }\n\n // Get last insert row ID\n const result = db.exec('SELECT last_insert_rowid() as id');\n if (result.length > 0 && result[0].values.length > 0) {\n return result[0].values[0][0] as number;\n }\n return 0;\n } catch (error) {\n console.error('[sql.js] Insert failed:', sql, error);\n return 0;\n }\n}\n\n/**\n * Execute UPDATE/DELETE statement and return rows affected\n * @param handle Database handle\n * @param sql UPDATE or DELETE statement with ? placeholders\n * @param paramsJson JSON array of parameters\n * @returns Number of rows affected or -1 on error\n */\nexport function execParamsOp(handle: number, sql: string, paramsJson: string): number {\n const db = databases.get(handle);\n if (!db) {\n console.error(`[sql.js] Invalid database handle: ${handle}`);\n return -1;\n }\n\n try {\n // Parse parameters\n let params: any[] = [];\n if (paramsJson && paramsJson !== '[]' && paramsJson !== 'null') {\n params = JSON.parse(paramsJson);\n }\n\n // Execute statement\n if (params.length > 0) {\n db.run(sql, params);\n } else {\n db.run(sql);\n }\n\n // Get rows affected\n const result = db.exec('SELECT changes() as count');\n if (result.length > 0 && result[0].values.length > 0) {\n return result[0].values[0][0] as number;\n }\n return 0;\n } catch (error) {\n console.error('[sql.js] ExecParams failed:', sql, error);\n return -1;\n }\n}\n\n/**\n * Export database to binary format\n * @param handle Database handle\n * @returns Base64-encoded database bytes or empty string on error\n */\nexport function exportOp(handle: number): string {\n const db = databases.get(handle);\n if (!db) {\n console.error(`[sql.js] Invalid database handle: ${handle}`);\n return '';\n }\n\n try {\n const data = db.export();\n // Use chunked base64 conversion for potentially large databases\n return uint8ArrayToBase64(data);\n } catch (error) {\n console.error('[sql.js] Export failed:', error);\n return '';\n }\n}\n\n/**\n * Import database from binary format\n * @param base64Data Base64-encoded database bytes\n * @returns Database handle or 0 on error\n */\nexport function importOp(base64Data: string): number {\n if (!sqlInstance) {\n console.error('[sql.js] Not initialized');\n return 0;\n }\n\n try {\n // Decode base64 to Uint8Array\n const binary = atob(base64Data);\n const data = new Uint8Array(binary.length);\n for (let i = 0; i < binary.length; i++) {\n data[i] = binary.charCodeAt(i);\n }\n\n const db = new sqlInstance.Database(data);\n const handle = nextHandle++;\n databases.set(handle, db);\n console.log(`[sql.js] Imported database with handle ${handle}`);\n return handle;\n } catch (error) {\n console.error('[sql.js] Import failed:', error);\n return 0;\n }\n}\n\n/**\n * Load database directly from bytes\n * @param bytes Raw database bytes\n * @returns Database handle or 0 on error\n */\nexport function loadDirectOp(bytes: Uint8Array): number {\n if (!sqlInstance) {\n console.error('[sql.js] Not initialized');\n return 0;\n }\n\n try {\n const db = new sqlInstance.Database(bytes);\n const handle = nextHandle++;\n databases.set(handle, db);\n return handle;\n } catch (error) {\n console.error('[sql.js] Failed to load database directly:', error);\n return 0;\n }\n}\n\n/**\n * Close a database\n * @param handle Database handle\n */\nexport function closeOp(handle: number): void {\n const db = databases.get(handle);\n if (db) {\n try {\n db.close();\n } catch (error) {\n console.error('[sql.js] Close failed:', error);\n }\n databases.delete(handle);\n console.log(`[sql.js] Closed database with handle ${handle}`);\n }\n}\n\n/**\n * Get last error message (for debugging)\n * @param _handle Database handle\n * @returns Error message or empty string\n */\nexport function getErrorOp(_handle: number): string {\n // sql.js throws exceptions rather than storing error messages\n // This is a placeholder for API compatibility\n return '';\n}\n\n/**\n * Cleanup all databases and reset state\n */\nexport function cleanupOp(): void {\n for (const [_handle, db] of databases) {\n try {\n db.close();\n } catch (_e) {\n // Ignore close errors during cleanup\n }\n }\n databases.clear();\n nextHandle = 1;\n console.log('[sql.js] Cleaned up all databases');\n}\n\n// ============================================================================\n// Bridge Exposure\n// ============================================================================\n\n/**\n * Set the SQL instance for database operations\n * Must be called before any database operations\n */\nexport function setSqlInstance(SQL: any): void {\n sqlInstance = SQL;\n}\n\n/**\n * Expose sql.js bridge functions to globalThis for Go WASM access\n */\nexport function exposeBridgeFunctions(): void {\n const g = globalThis as any;\n\n g.sqljsCreateDatabase = createDatabaseOp;\n g.sqljsExec = execOp;\n g.sqljsQuery = queryOp;\n g.sqljsInsert = insertOp;\n g.sqljsExecParams = execParamsOp;\n g.sqljsExport = exportOp;\n g.sqljsImport = importOp;\n g.sqljsClose = closeOp;\n g.sqljsGetError = getErrorOp;\n g.sqljsLoadDirect = loadDirectOp;\n\n // Also expose database map for debugging\n g.sqljsDatabases = databases;\n\n console.log('[sql.js] Bridge functions exposed to globalThis');\n}\n\n/**\n * Get a database by handle (for debugging from console)\n */\nexport function getDatabase(handle: number): any {\n return databases.get(handle);\n}\n", "/**\n * Kodexa SharedWorker Entry Point\n *\n * This SharedWorker owns the Go WASM instance and exposes an RPC-style API\n * via MessagePort. Multiple tabs/windows can connect and share the same\n * WASM instance and documents, with events broadcast to all interested ports.\n *\n * Key differences from dedicated worker:\n * - Uses onconnect to handle multiple port connections\n * - Tracks document subscriptions per port for event broadcasting\n * - Reference counts documents to know when to clean up\n *\n * Initialization order (critical):\n * 1. sql.js WASM loaded and bridge exposed to globalThis\n * 2. wasm_exec.js loaded (defines globalThis.Go)\n * 3. kodexa.wasm instantiated and Go runtime started\n * 4. Worker signals 'ready' to each connected port\n */\n\n/// <reference lib=\"webworker\" />\n\nimport type {\n WorkerConfig,\n WorkerErrorMessage,\n WorkerWasmEventMessage,\n SharedWorkerRequest,\n SharedWorkerResponse,\n SharedWorkerReadyMessage,\n SharedWorkerInboundMessage,\n} from './types';\nimport { setSqlInstance, exposeBridgeFunctions, loadDirectOp } from '../wasm/sqljs-core';\n\ndeclare const self: SharedWorkerGlobalScope;\n\n// ============================================================================\n// Port Management\n// ============================================================================\n\n/** Connected ports by ID */\nconst ports = new Map<string, MessagePort>();\n\n/** Counter for generating unique port IDs */\nlet nextPortId = 1;\n\n/** Generate a unique port ID */\nfunction generatePortId(): string {\n return `port_${nextPortId++}_${Date.now()}`;\n}\n\n// ============================================================================\n// Document State Management\n// ============================================================================\n\n/** Track which ports are subscribed to which documents for event broadcasting */\nconst documentSubscriptions = new Map<number, Set<string>>(); // docRef -> Set<portId>\n\n/** Track which ports are using which documents (for cleanup) */\nconst documentUsers = new Map<number, Set<string>>(); // docRef -> Set<portId>\n\n/**\n * Subscribe a port to document events.\n */\nfunction subscribeToDocument(docRef: number, portId: string): void {\n if (!documentSubscriptions.has(docRef)) {\n documentSubscriptions.set(docRef, new Set());\n }\n documentSubscriptions.get(docRef)!.add(portId);\n console.log(`[shared-worker] Port ${portId} subscribed to document ${docRef}`);\n}\n\n/**\n * Unsubscribe a port from document events.\n */\nfunction unsubscribeFromDocument(docRef: number, portId: string): void {\n const subscribers = documentSubscriptions.get(docRef);\n if (subscribers) {\n subscribers.delete(portId);\n if (subscribers.size === 0) {\n documentSubscriptions.delete(docRef);\n }\n console.log(`[shared-worker] Port ${portId} unsubscribed from document ${docRef}`);\n }\n}\n\n/**\n * Register a port as using a document (for reference counting).\n */\nfunction registerDocumentUser(docRef: number, portId: string): void {\n if (!documentUsers.has(docRef)) {\n documentUsers.set(docRef, new Set());\n }\n documentUsers.get(docRef)!.add(portId);\n}\n\n/**\n * Unregister a port from a document. Returns true if document should be freed.\n */\nfunction unregisterDocumentUser(docRef: number, portId: string): boolean {\n const users = documentUsers.get(docRef);\n if (users) {\n users.delete(portId);\n if (users.size === 0) {\n documentUsers.delete(docRef);\n return true; // No more users, safe to free\n }\n }\n return false;\n}\n\n/**\n * Cleanup all resources associated with a port.\n */\nfunction cleanupPort(portId: string): void {\n console.log(`[shared-worker] Cleaning up port ${portId}`);\n\n // Remove from all document subscriptions\n for (const [docRef, subscribers] of documentSubscriptions) {\n subscribers.delete(portId);\n if (subscribers.size === 0) {\n documentSubscriptions.delete(docRef);\n }\n }\n\n // Unregister from all document users\n for (const [docRef, users] of documentUsers) {\n users.delete(portId);\n if (users.size === 0) {\n // No ports using this document, free it\n console.log(`[shared-worker] Freeing document ${docRef} - no more users`);\n try {\n const freeDocument = (self as any).freeDocument;\n if (typeof freeDocument === 'function') {\n freeDocument(docRef);\n }\n } catch (error) {\n console.error(`[shared-worker] Error freeing document ${docRef}:`, error);\n }\n documentUsers.delete(docRef);\n }\n }\n\n // Remove port\n ports.delete(portId);\n}\n\n// ============================================================================\n// Event Broadcasting\n// ============================================================================\n\n/**\n * Broadcast an event to all ports subscribed to a document.\n */\nfunction broadcastToSubscribers(docRef: number, eventType: string, detail: unknown): void {\n const subscribers = documentSubscriptions.get(docRef);\n if (!subscribers || subscribers.size === 0) {\n return;\n }\n\n const message: WorkerWasmEventMessage = {\n type: 'wasmEvent',\n eventType,\n detail,\n documentRef: docRef,\n };\n\n for (const portId of subscribers) {\n const port = ports.get(portId);\n if (port) {\n try {\n port.postMessage(message);\n } catch (error) {\n console.error(`[shared-worker] Error posting to port ${portId}:`, error);\n }\n }\n }\n}\n\n/**\n * Broadcast an event to ALL connected ports.\n */\nfunction broadcastToAll(message: unknown): void {\n for (const [portId, port] of ports) {\n try {\n port.postMessage(message);\n } catch (error) {\n console.error(`[shared-worker] Error posting to port ${portId}:`, error);\n }\n }\n}\n\n// ============================================================================\n// Worker State\n// ============================================================================\n\nlet initialized = false;\nlet initPromise: Promise<void> | null = null;\nlet config: WorkerConfig = {};\n\n// ============================================================================\n// Event Forwarding from WASM\n// ============================================================================\n\n/**\n * Set up event forwarding from WASM to connected ports.\n */\nfunction setupEventForwarding(): void {\n // Create a document shim for Go WASM to dispatch events\n const documentShim = {\n addEventListener: (type: string, handler: EventListener) => {\n console.log(`[shared-worker] Event listener registered for: ${type}`);\n self.addEventListener(type, handler);\n },\n removeEventListener: (type: string, handler: EventListener) => {\n self.removeEventListener(type, handler);\n },\n dispatchEvent: (event: Event) => {\n // Dispatch locally first\n self.dispatchEvent(event);\n\n // Forward to interested ports\n if (event instanceof CustomEvent) {\n const detail = event.detail as { docRef?: number } | undefined;\n const docRef = detail?.docRef;\n\n if (docRef !== undefined) {\n // Document-specific event - broadcast to subscribers\n broadcastToSubscribers(docRef, event.type, event.detail);\n } else {\n // Global event - broadcast to all ports\n broadcastToAll({\n type: 'wasmEvent',\n eventType: event.type,\n detail: event.detail,\n } as WorkerWasmEventMessage);\n }\n }\n return true;\n },\n createElement: () => null,\n body: null,\n documentElement: null,\n };\n\n (self as any).document = documentShim;\n\n // Direct listener for kodexaDataChange events\n self.addEventListener('kodexaDataChange', (event: Event) => {\n if (event instanceof CustomEvent) {\n const detail = event.detail as { docRef?: number } | undefined;\n const docRef = detail?.docRef;\n\n if (docRef !== undefined) {\n broadcastToSubscribers(docRef, 'kodexaDataChange', event.detail);\n } else {\n broadcastToAll({\n type: 'wasmEvent',\n eventType: 'kodexaDataChange',\n detail: event.detail,\n } as WorkerWasmEventMessage);\n }\n }\n });\n\n console.log('[shared-worker] Event forwarding configured');\n}\n\n// ============================================================================\n// WASM Loading (same as dedicated worker)\n// ============================================================================\n\nasync function initializeSqlJs(): Promise<void> {\n const sqlJsUrl = 'https://sql.js.org/dist/sql-wasm.js';\n const sqlWasmUrl = 'https://sql.js.org/dist/sql-wasm.wasm';\n\n try {\n const response = await fetch(sqlJsUrl);\n if (!response.ok) {\n throw new Error(`Failed to fetch sql-wasm.js: ${response.statusText}`);\n }\n const code = await response.text();\n\n const wrappedCode = `\n (function(module, exports) {\n ${code}\n return module.exports;\n })\n `;\n\n // eslint-disable-next-line no-eval\n const moduleFactory = eval(wrappedCode);\n const mockModule = { exports: {} as any };\n const initSqlJs = moduleFactory(mockModule, mockModule.exports);\n\n if (typeof initSqlJs !== 'function') {\n throw new Error('initSqlJs not found after loading sql-wasm.js');\n }\n\n const sqlConfig = {\n locateFile: () => sqlWasmUrl,\n };\n\n const SQL = await initSqlJs(sqlConfig);\n setSqlInstance(SQL);\n exposeBridgeFunctions();\n\n // Expose loadDocument function\n (self as any).loadDocument = (bytes: Uint8Array): number => {\n const handle = loadDirectOp(bytes);\n if (handle === 0) {\n console.error('[shared-worker] Failed to load database');\n return 0;\n }\n return (self as any).createDocumentFromHandle(handle);\n };\n\n console.log('[shared-worker] sql.js initialized from official CDN');\n } catch (error) {\n console.error('[shared-worker] Failed to initialize sql.js:', error);\n throw new Error(`Failed to initialize sql.js: ${error}`);\n }\n}\n\nasync function loadWasmExec(): Promise<void> {\n if ((self as any).Go) {\n return;\n }\n\n const baseUrl = config.wasmBaseUrl || self.location.origin;\n const wasmExecUrl = `${baseUrl}/wasm_exec.js`;\n\n try {\n const response = await fetch(wasmExecUrl);\n if (!response.ok) {\n throw new Error(`Failed to fetch wasm_exec.js: ${response.statusText}`);\n }\n const code = await response.text();\n // eslint-disable-next-line no-eval\n eval(code);\n console.log('[shared-worker] wasm_exec.js loaded');\n } catch (error) {\n throw new Error(`Failed to load wasm_exec.js: ${error}`);\n }\n}\n\nasync function loadGoWasm(): Promise<void> {\n const baseUrl = config.wasmBaseUrl || self.location.origin;\n const wasmUrl = `${baseUrl}/kodexa.wasm`;\n\n const response = await fetch(wasmUrl);\n if (!response.ok) {\n throw new Error(`Failed to fetch kodexa.wasm: ${response.statusText}`);\n }\n const wasmBytes = await response.arrayBuffer();\n\n const go = new (self as any).Go();\n const result = await WebAssembly.instantiate(wasmBytes, go.importObject);\n go.run(result.instance);\n\n const logLevel = config.logLevel || 'warn';\n if ((self as any).kodexa_setLogLevel) {\n (self as any).kodexa_setLogLevel(logLevel);\n }\n\n console.log('[shared-worker] Go WASM loaded');\n}\n\nasync function initialize(workerConfig?: WorkerConfig): Promise<void> {\n if (initialized) {\n return;\n }\n\n if (initPromise) {\n return initPromise;\n }\n\n config = workerConfig || {};\n\n initPromise = (async () => {\n try {\n setupEventForwarding();\n await initializeSqlJs();\n await loadWasmExec();\n await loadGoWasm();\n initialized = true;\n console.log('[shared-worker] Kodexa WASM fully initialized');\n } catch (error) {\n console.error('[shared-worker] Initialization failed:', error);\n throw error;\n }\n })();\n\n return initPromise;\n}\n\n// ============================================================================\n// Message Handling\n// ============================================================================\n\n/**\n * Handle RPC call from a port.\n */\nfunction handleCall(request: SharedWorkerRequest): SharedWorkerResponse {\n const { id, method, args, portId } = request;\n\n try {\n const fn = (self as any)[method];\n if (typeof fn !== 'function') {\n return {\n id,\n portId,\n success: false,\n error: `Function '${method}' not found on globalThis`,\n };\n }\n\n const result = fn(...(args || []));\n\n // Track document usage when creating/loading documents\n if (method === 'createDocument' || method === 'createDocumentFromText' ||\n method === 'createDocumentFromJson' || method === 'createDocumentFromKddbBytes' ||\n method === 'loadDocument') {\n if (typeof result === 'number' && result > 0) {\n registerDocumentUser(result, portId);\n }\n }\n\n // Track document disposal\n if (method === 'freeDocument' && args && args.length > 0) {\n const docRef = args[0] as number;\n const shouldFree = unregisterDocumentUser(docRef, portId);\n if (!shouldFree) {\n // Other ports still using this document, don't actually free it\n return { id, portId, success: true, result: undefined };\n }\n }\n\n return { id, portId, success: true, result };\n } catch (error) {\n return {\n id,\n portId,\n success: false,\n error: error instanceof Error ? error.message : String(error),\n };\n }\n}\n\n/**\n * Handle messages from a connected port.\n */\nfunction handlePortMessage(portId: string, port: MessagePort, event: MessageEvent<SharedWorkerInboundMessage>): void {\n const data = event.data;\n\n // Handle init message\n if ('type' in data && data.type === 'init') {\n (async () => {\n try {\n await initialize(data.config);\n const readyMessage: SharedWorkerReadyMessage = { type: 'ready', portId };\n port.postMessage(readyMessage);\n } catch (error) {\n const errorMessage: WorkerErrorMessage = {\n type: 'error',\n error: error instanceof Error ? error.message : String(error),\n };\n port.postMessage(errorMessage);\n }\n })();\n return;\n }\n\n // Handle subscription messages\n if ('type' in data && data.type === 'subscribe') {\n subscribeToDocument(data.docRef, portId);\n return;\n }\n\n if ('type' in data && data.type === 'unsubscribe') {\n unsubscribeFromDocument(data.docRef, portId);\n return;\n }\n\n // Handle RPC call\n if ('type' in data && data.type === 'call') {\n if (!initialized) {\n const response: SharedWorkerResponse = {\n id: (data as SharedWorkerRequest).id,\n portId,\n success: false,\n error: 'Worker not initialized. Send init message first.',\n };\n port.postMessage(response);\n return;\n }\n\n // Add portId to the request\n const request = { ...data, portId } as SharedWorkerRequest;\n const response = handleCall(request);\n port.postMessage(response);\n }\n}\n\n// ============================================================================\n// SharedWorker Connection Handler\n// ============================================================================\n\nself.onconnect = (event: MessageEvent) => {\n const port = event.ports[0];\n const portId = generatePortId();\n\n console.log(`[shared-worker] New port connected: ${portId}`);\n ports.set(portId, port);\n\n // Set up message handler for this port\n port.onmessage = (e) => handlePortMessage(portId, port, e);\n\n // Handle port closure (tab closed)\n // Note: Not all browsers reliably fire this event\n port.onmessageerror = () => {\n console.log(`[shared-worker] Port ${portId} message error, cleaning up`);\n cleanupPort(portId);\n };\n\n // Start the port\n port.start();\n\n // If already initialized, send ready immediately\n if (initialized) {\n const readyMessage: SharedWorkerReadyMessage = { type: 'ready', portId };\n port.postMessage(readyMessage);\n }\n\n // Send connected message so port knows its ID\n port.postMessage({ type: 'connected', portId });\n};\n\n// Log that shared worker is ready for connections\nconsole.log('[shared-worker] Kodexa SharedWorker ready for connections');\n"],
5
+ "mappings": "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",
6
+ "names": ["binary", "SQL", "baseUrl", "response"]
7
+ }