@kodexa-ai/document-wasm-ts 8.0.0-develop-20665016781 → 8.0.0-develop-20666055921
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/KddbDocument.d.ts +0 -9
- package/dist/KddbDocument.d.ts.map +1 -1
- package/dist/KddbDocument.js +0 -19
- package/dist/KddbDocument.js.map +1 -1
- package/dist/kodexa-shared-worker.js +594 -0
- package/dist/kodexa-shared-worker.js.map +7 -0
- package/dist/kodexa-worker.js +80 -21
- package/dist/kodexa-worker.js.map +3 -3
- package/dist/kodexa.wasm +0 -0
- package/dist/worker/KodexaSharedWorker.d.ts +267 -0
- package/dist/worker/KodexaSharedWorker.d.ts.map +1 -0
- package/dist/worker/KodexaSharedWorker.js +475 -0
- package/dist/worker/KodexaSharedWorker.js.map +1 -0
- package/dist/worker/KodexaWorker.d.ts +110 -0
- package/dist/worker/KodexaWorker.d.ts.map +1 -1
- package/dist/worker/KodexaWorker.js +163 -0
- package/dist/worker/KodexaWorker.js.map +1 -1
- package/dist/worker/KodexaWorkerDocument.d.ts +183 -0
- package/dist/worker/KodexaWorkerDocument.d.ts.map +1 -1
- package/dist/worker/KodexaWorkerDocument.js +458 -0
- package/dist/worker/KodexaWorkerDocument.js.map +1 -1
- package/dist/worker/KodexaWorkerNode.d.ts +22 -0
- package/dist/worker/KodexaWorkerNode.d.ts.map +1 -1
- package/dist/worker/KodexaWorkerNode.js +64 -3
- package/dist/worker/KodexaWorkerNode.js.map +1 -1
- package/dist/worker/index.d.ts +23 -6
- package/dist/worker/index.d.ts.map +1 -1
- package/dist/worker/index.js +21 -5
- package/dist/worker/index.js.map +1 -1
- package/dist/worker/kodexa-shared-worker.d.ts +20 -0
- package/dist/worker/kodexa-shared-worker.d.ts.map +1 -0
- package/dist/worker/kodexa-shared-worker.js +460 -0
- package/dist/worker/kodexa-shared-worker.js.map +1 -0
- package/dist/worker/kodexa-worker.js +110 -22
- package/dist/worker/kodexa-worker.js.map +1 -1
- package/dist/worker/types.d.ts +76 -1
- package/dist/worker/types.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/kodexa-worker.js
CHANGED
|
@@ -214,8 +214,8 @@ function closeOp(handle) {
|
|
|
214
214
|
function getErrorOp(_handle) {
|
|
215
215
|
return "";
|
|
216
216
|
}
|
|
217
|
-
function setSqlInstance(
|
|
218
|
-
sqlInstance =
|
|
217
|
+
function setSqlInstance(SQL2) {
|
|
218
|
+
sqlInstance = SQL2;
|
|
219
219
|
}
|
|
220
220
|
function exposeBridgeFunctions() {
|
|
221
221
|
const g = globalThis;
|
|
@@ -249,27 +249,85 @@ var require_kodexa_worker = __commonJS({
|
|
|
249
249
|
var initialized = false;
|
|
250
250
|
var initPromise = null;
|
|
251
251
|
var config = {};
|
|
252
|
+
function setupEventForwarding() {
|
|
253
|
+
const documentShim = {
|
|
254
|
+
addEventListener: (type, handler) => {
|
|
255
|
+
console.log(`[worker] Event listener registered for: ${type}`);
|
|
256
|
+
self.addEventListener(type, handler);
|
|
257
|
+
},
|
|
258
|
+
removeEventListener: (type, handler) => {
|
|
259
|
+
self.removeEventListener(type, handler);
|
|
260
|
+
},
|
|
261
|
+
dispatchEvent: (event) => {
|
|
262
|
+
self.dispatchEvent(event);
|
|
263
|
+
if (event instanceof CustomEvent) {
|
|
264
|
+
const message = {
|
|
265
|
+
type: "wasmEvent",
|
|
266
|
+
eventType: event.type,
|
|
267
|
+
detail: event.detail
|
|
268
|
+
};
|
|
269
|
+
self.postMessage(message);
|
|
270
|
+
}
|
|
271
|
+
return true;
|
|
272
|
+
},
|
|
273
|
+
createElement: () => null,
|
|
274
|
+
// No-op for worker
|
|
275
|
+
body: null,
|
|
276
|
+
documentElement: null
|
|
277
|
+
};
|
|
278
|
+
self.document = documentShim;
|
|
279
|
+
self.addEventListener("kodexaDataChange", (event) => {
|
|
280
|
+
if (event instanceof CustomEvent) {
|
|
281
|
+
const message = {
|
|
282
|
+
type: "wasmEvent",
|
|
283
|
+
eventType: "kodexaDataChange",
|
|
284
|
+
detail: event.detail
|
|
285
|
+
};
|
|
286
|
+
self.postMessage(message);
|
|
287
|
+
}
|
|
288
|
+
});
|
|
289
|
+
console.log("[worker] Event forwarding configured");
|
|
290
|
+
}
|
|
252
291
|
async function initializeSqlJs() {
|
|
253
|
-
const sqlJsUrl = "https://
|
|
254
|
-
const
|
|
255
|
-
|
|
256
|
-
sqlJsUrl
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
const sqlConfig = {};
|
|
260
|
-
sqlConfig.locateFile = () => "https://sql.js.org/dist/sql-wasm.wasm";
|
|
261
|
-
const SQL = await initSqlJs(sqlConfig);
|
|
262
|
-
setSqlInstance(SQL);
|
|
263
|
-
exposeBridgeFunctions();
|
|
264
|
-
self.loadDocument = (bytes) => {
|
|
265
|
-
const handle = loadDirectOp(bytes);
|
|
266
|
-
if (handle === 0) {
|
|
267
|
-
console.error("[worker] Failed to load database");
|
|
268
|
-
return 0;
|
|
292
|
+
const sqlJsUrl = "https://sql.js.org/dist/sql-wasm.js";
|
|
293
|
+
const sqlWasmUrl = "https://sql.js.org/dist/sql-wasm.wasm";
|
|
294
|
+
try {
|
|
295
|
+
const response = await fetch(sqlJsUrl);
|
|
296
|
+
if (!response.ok) {
|
|
297
|
+
throw new Error(`Failed to fetch sql-wasm.js: ${response.statusText}`);
|
|
269
298
|
}
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
299
|
+
const code = await response.text();
|
|
300
|
+
const wrappedCode = `
|
|
301
|
+
(function(module, exports) {
|
|
302
|
+
${code}
|
|
303
|
+
return module.exports;
|
|
304
|
+
})
|
|
305
|
+
`;
|
|
306
|
+
const moduleFactory = eval(wrappedCode);
|
|
307
|
+
const mockModule = { exports: {} };
|
|
308
|
+
const initSqlJs = moduleFactory(mockModule, mockModule.exports);
|
|
309
|
+
if (typeof initSqlJs !== "function") {
|
|
310
|
+
throw new Error("initSqlJs not found after loading sql-wasm.js");
|
|
311
|
+
}
|
|
312
|
+
const sqlConfig = {
|
|
313
|
+
locateFile: () => sqlWasmUrl
|
|
314
|
+
};
|
|
315
|
+
const SQL = await initSqlJs(sqlConfig);
|
|
316
|
+
setSqlInstance(SQL);
|
|
317
|
+
exposeBridgeFunctions();
|
|
318
|
+
self.loadDocument = (bytes) => {
|
|
319
|
+
const handle = loadDirectOp(bytes);
|
|
320
|
+
if (handle === 0) {
|
|
321
|
+
console.error("[worker] Failed to load database");
|
|
322
|
+
return 0;
|
|
323
|
+
}
|
|
324
|
+
return self.createDocumentFromHandle(handle);
|
|
325
|
+
};
|
|
326
|
+
console.log("[worker] sql.js initialized from official CDN");
|
|
327
|
+
} catch (error) {
|
|
328
|
+
console.error("[worker] Failed to initialize sql.js:", error);
|
|
329
|
+
throw new Error(`Failed to initialize sql.js: ${error}`);
|
|
330
|
+
}
|
|
273
331
|
}
|
|
274
332
|
async function loadWasmExec() {
|
|
275
333
|
if (self.Go) {
|
|
@@ -316,6 +374,7 @@ var require_kodexa_worker = __commonJS({
|
|
|
316
374
|
config = workerConfig || {};
|
|
317
375
|
initPromise = (async () => {
|
|
318
376
|
try {
|
|
377
|
+
setupEventForwarding();
|
|
319
378
|
await initializeSqlJs();
|
|
320
379
|
await loadWasmExec();
|
|
321
380
|
await loadGoWasm();
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/wasm/sqljs-core.ts", "../src/worker/kodexa-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 Web Worker Entry Point\n *\n * This worker owns the Go WASM instance and exposes an RPC-style API\n * via postMessage. All heavy document processing happens here,\n * keeping the main thread responsive.\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 main thread\n */\n\n/// <reference lib=\"webworker\" />\n\nimport type { WorkerRequest, WorkerResponse, WorkerReadyMessage, WorkerErrorMessage, WorkerConfig } from './types';\nimport { setSqlInstance, exposeBridgeFunctions, loadDirectOp } from '../wasm/sqljs-core';\n\ndeclare const self: DedicatedWorkerGlobalScope;\n\n// Worker state\nlet initialized = false;\nlet initPromise: Promise<void> | null = null;\nlet config: WorkerConfig = {};\n\n/**\n * Initialize sql.js in the worker context.\n * Uses dynamic import from ESM CDN for browser workers.\n */\nasync function initializeSqlJs(): Promise<void> {\n // For browser workers, we need to load sql.js from a CDN that supports ESM\n // We use the esm.sh CDN which provides ESM versions of npm packages\n const sqlJsUrl = 'https://esm.sh/sql.js@1.11.0';\n\n // Dynamic import from CDN\n const sqlJsModule = await import(/* webpackIgnore: true */ sqlJsUrl);\n const initSqlJs = sqlJsModule.default;\n\n // Configure sql.js WASM location\n const sqlConfig: { locateFile?: (file: string) => string } = {};\n sqlConfig.locateFile = () => 'https://sql.js.org/dist/sql-wasm.wasm';\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('[worker] Failed to load database');\n return 0;\n }\n return (self as any).createDocumentFromHandle(handle);\n };\n\n console.log('[worker] sql.js initialized');\n}\n\n/**\n * Load wasm_exec.js in the worker context.\n * We use fetch + eval since workers don't have document.createElement.\n */\nasync function loadWasmExec(): Promise<void> {\n if ((self as any).Go) {\n return; // Already loaded\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('[worker] wasm_exec.js loaded');\n } catch (error) {\n throw new Error(`Failed to load wasm_exec.js: ${error}`);\n }\n}\n\n/**\n * Load and instantiate the Go WASM module.\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 // Create Go runtime and instantiate WASM\n const go = new (self as any).Go();\n const result = await WebAssembly.instantiate(wasmBytes, go.importObject);\n\n // Start the Go program (registers functions on globalThis)\n go.run(result.instance);\n\n // Configure log level\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('[worker] Go WASM loaded');\n}\n\n/**\n * Initialize the worker with all WASM components.\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 // Step 1: Initialize sql.js (MUST be first)\n await initializeSqlJs();\n\n // Step 2: Load wasm_exec.js\n await loadWasmExec();\n\n // Step 3: Load Go WASM\n await loadGoWasm();\n\n initialized = true;\n console.log('[worker] Kodexa WASM fully initialized');\n } catch (error) {\n console.error('[worker] Initialization failed:', error);\n throw error;\n }\n })();\n\n return initPromise;\n}\n\n/**\n * Handle RPC call from main thread.\n */\nfunction handleCall(request: WorkerRequest): WorkerResponse {\n const { id, method, args } = request;\n\n try {\n const fn = (self as any)[method];\n if (typeof fn !== 'function') {\n return {\n id,\n success: false,\n error: `Function '${method}' not found on globalThis`,\n };\n }\n\n const result = fn(...(args || []));\n return { id, success: true, result };\n } catch (error) {\n return {\n id,\n success: false,\n error: error instanceof Error ? error.message : String(error),\n };\n }\n}\n\n/**\n * Main message handler.\n */\nself.onmessage = async (event: MessageEvent<WorkerRequest | { type: 'init'; config?: WorkerConfig }>) => {\n const data = event.data;\n\n // Handle init message\n if ('type' in data && data.type === 'init') {\n try {\n await initialize(data.config);\n const readyMessage: WorkerReadyMessage = { type: 'ready' };\n self.postMessage(readyMessage);\n } catch (error) {\n const errorMessage: WorkerErrorMessage = {\n type: 'error',\n error: error instanceof Error ? error.message : String(error),\n };\n self.postMessage(errorMessage);\n }\n return;\n }\n\n // Handle RPC call\n if ('type' in data && data.type === 'call') {\n // Ensure initialized\n if (!initialized) {\n const response: WorkerResponse = {\n id: (data as WorkerRequest).id,\n success: false,\n error: 'Worker not initialized. Send init message first.',\n };\n self.postMessage(response);\n return;\n }\n\n const response = handleCall(data as WorkerRequest);\n self.postMessage(response);\n }\n};\n\n// Auto-initialize on load if config is in URL params\n// This allows the worker to be used without explicit init message\nconst urlParams = new URLSearchParams(self.location.search);\nconst autoInit = urlParams.get('autoInit');\nif (autoInit === 'true') {\n const wasmBaseUrl = urlParams.get('wasmBaseUrl') || undefined;\n const logLevel = (urlParams.get('logLevel') as WorkerConfig['logLevel']) || undefined;\n initialize({ wasmBaseUrl, logLevel }).then(() => {\n const readyMessage: WorkerReadyMessage = { type: 'ready' };\n self.postMessage(readyMessage);\n }).catch((error) => {\n const errorMessage: WorkerErrorMessage = {\n type: 'error',\n error: error instanceof Error ? error.message : String(error),\n };\n self.postMessage(errorMessage);\n });\n}\n"],
|
|
5
|
-
"mappings": "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
|
|
6
|
-
"names": ["binary", "baseUrl", "response"]
|
|
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 Web Worker Entry Point\n *\n * This worker owns the Go WASM instance and exposes an RPC-style API\n * via postMessage. All heavy document processing happens here,\n * keeping the main thread responsive.\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 main thread\n */\n\n/// <reference lib=\"webworker\" />\n\nimport type { WorkerRequest, WorkerResponse, WorkerReadyMessage, WorkerErrorMessage, WorkerConfig, WorkerWasmEventMessage } from './types';\nimport { setSqlInstance, exposeBridgeFunctions, loadDirectOp } from '../wasm/sqljs-core';\n\ndeclare const self: DedicatedWorkerGlobalScope;\n\n// Worker state\nlet initialized = false;\nlet initPromise: Promise<void> | null = null;\nlet config: WorkerConfig = {};\n\n/**\n * Set up event forwarding from WASM to main thread.\n * The Go WASM runtime dispatches events using CustomEvent on a document-like object.\n * In worker context, we create a shim that captures these events and forwards them.\n */\nfunction setupEventForwarding(): void {\n // Create a document shim that the Go WASM can use to dispatch events\n // This allows the existing Go code to work unchanged in worker context\n const documentShim = {\n addEventListener: (type: string, handler: EventListener) => {\n console.log(`[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 // When Go dispatches an event, forward it to both:\n // 1. Local listeners in the worker (for any worker-side handling)\n // 2. Main thread via postMessage\n self.dispatchEvent(event);\n\n // Forward to main thread\n if (event instanceof CustomEvent) {\n const message: WorkerWasmEventMessage = {\n type: 'wasmEvent',\n eventType: event.type,\n detail: event.detail,\n };\n self.postMessage(message);\n }\n return true;\n },\n createElement: () => null, // No-op for worker\n body: null,\n documentElement: null,\n };\n\n // Expose the shim as 'document' in worker global scope\n // This allows Go WASM code that uses document.dispatchEvent to work\n (self as any).document = documentShim;\n\n // Also set up a direct listener on self for kodexaDataChange events\n // in case Go uses a different mechanism\n self.addEventListener('kodexaDataChange', (event: Event) => {\n if (event instanceof CustomEvent) {\n const message: WorkerWasmEventMessage = {\n type: 'wasmEvent',\n eventType: 'kodexaDataChange',\n detail: event.detail,\n };\n self.postMessage(message);\n }\n });\n\n console.log('[worker] Event forwarding configured');\n}\n\n/**\n * Initialize sql.js in the worker context.\n * Uses the official sql.js CDN which provides proper browser-only builds.\n *\n * NOTE: We use fetch + eval instead of importScripts because:\n * - The worker is loaded as a module worker (type: \"module\")\n * - Module workers don't support importScripts()\n * - esm.sh bundles Node.js polyfills that break in browser workers\n * - The official CDN provides a pure browser UMD build\n */\nasync function initializeSqlJs(): Promise<void> {\n // Use the official sql.js CDN which has proper browser builds\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 // Load sql.js using fetch + eval (since module workers don't support importScripts)\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 // The UMD build checks for CommonJS (module.exports) before global assignment.\n // We wrap the code to provide module/exports in scope for the UMD detection.\n // UMD pattern: if (typeof exports === 'object' && typeof module === 'object') module.exports = initSqlJs;\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 // Configure sql.js WASM location\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('[worker] Failed to load database');\n return 0;\n }\n return (self as any).createDocumentFromHandle(handle);\n };\n\n console.log('[worker] sql.js initialized from official CDN');\n } catch (error) {\n console.error('[worker] Failed to initialize sql.js:', error);\n throw new Error(`Failed to initialize sql.js: ${error}`);\n }\n}\n\n/**\n * Load wasm_exec.js in the worker context.\n * We use fetch + eval since workers don't have document.createElement.\n */\nasync function loadWasmExec(): Promise<void> {\n if ((self as any).Go) {\n return; // Already loaded\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('[worker] wasm_exec.js loaded');\n } catch (error) {\n throw new Error(`Failed to load wasm_exec.js: ${error}`);\n }\n}\n\n/**\n * Load and instantiate the Go WASM module.\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 // Create Go runtime and instantiate WASM\n const go = new (self as any).Go();\n const result = await WebAssembly.instantiate(wasmBytes, go.importObject);\n\n // Start the Go program (registers functions on globalThis)\n go.run(result.instance);\n\n // Configure log level\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('[worker] Go WASM loaded');\n}\n\n/**\n * Initialize the worker with all WASM components.\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 // Step 0: Set up event forwarding BEFORE loading WASM\n // This ensures the document shim is in place when Go initializes\n setupEventForwarding();\n\n // Step 1: Initialize sql.js (MUST be first)\n await initializeSqlJs();\n\n // Step 2: Load wasm_exec.js\n await loadWasmExec();\n\n // Step 3: Load Go WASM\n await loadGoWasm();\n\n initialized = true;\n console.log('[worker] Kodexa WASM fully initialized');\n } catch (error) {\n console.error('[worker] Initialization failed:', error);\n throw error;\n }\n })();\n\n return initPromise;\n}\n\n/**\n * Handle RPC call from main thread.\n */\nfunction handleCall(request: WorkerRequest): WorkerResponse {\n const { id, method, args } = request;\n\n try {\n const fn = (self as any)[method];\n if (typeof fn !== 'function') {\n return {\n id,\n success: false,\n error: `Function '${method}' not found on globalThis`,\n };\n }\n\n const result = fn(...(args || []));\n return { id, success: true, result };\n } catch (error) {\n return {\n id,\n success: false,\n error: error instanceof Error ? error.message : String(error),\n };\n }\n}\n\n/**\n * Main message handler.\n */\nself.onmessage = async (event: MessageEvent<WorkerRequest | { type: 'init'; config?: WorkerConfig }>) => {\n const data = event.data;\n\n // Handle init message\n if ('type' in data && data.type === 'init') {\n try {\n await initialize(data.config);\n const readyMessage: WorkerReadyMessage = { type: 'ready' };\n self.postMessage(readyMessage);\n } catch (error) {\n const errorMessage: WorkerErrorMessage = {\n type: 'error',\n error: error instanceof Error ? error.message : String(error),\n };\n self.postMessage(errorMessage);\n }\n return;\n }\n\n // Handle RPC call\n if ('type' in data && data.type === 'call') {\n // Ensure initialized\n if (!initialized) {\n const response: WorkerResponse = {\n id: (data as WorkerRequest).id,\n success: false,\n error: 'Worker not initialized. Send init message first.',\n };\n self.postMessage(response);\n return;\n }\n\n const response = handleCall(data as WorkerRequest);\n self.postMessage(response);\n }\n};\n\n// Auto-initialize on load if config is in URL params\n// This allows the worker to be used without explicit init message\nconst urlParams = new URLSearchParams(self.location.search);\nconst autoInit = urlParams.get('autoInit');\nif (autoInit === 'true') {\n const wasmBaseUrl = urlParams.get('wasmBaseUrl') || undefined;\n const logLevel = (urlParams.get('logLevel') as WorkerConfig['logLevel']) || undefined;\n initialize({ wasmBaseUrl, logLevel }).then(() => {\n const readyMessage: WorkerReadyMessage = { type: 'ready' };\n self.postMessage(readyMessage);\n }).catch((error) => {\n const errorMessage: WorkerErrorMessage = {\n type: 'error',\n error: error instanceof Error ? error.message : String(error),\n };\n self.postMessage(errorMessage);\n });\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["binary", "SQL", "baseUrl", "response"]
|
|
7
7
|
}
|
package/dist/kodexa.wasm
CHANGED
|
Binary file
|
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* KodexaSharedWorker - Main Thread Proxy for SharedWorker WASM
|
|
3
|
+
*
|
|
4
|
+
* This class manages a SharedWorker that runs the Go WASM module.
|
|
5
|
+
* Multiple tabs/windows can share the same worker instance, enabling
|
|
6
|
+
* shared document state and cross-tab event synchronization.
|
|
7
|
+
*
|
|
8
|
+
* API is compatible with KodexaWorker - same methods, same return types.
|
|
9
|
+
*
|
|
10
|
+
* Usage:
|
|
11
|
+
* ```typescript
|
|
12
|
+
* const kodexa = new KodexaSharedWorker();
|
|
13
|
+
* await kodexa.init();
|
|
14
|
+
*
|
|
15
|
+
* const doc = await kodexa.createDocument();
|
|
16
|
+
* const root = await doc.getRoot();
|
|
17
|
+
*
|
|
18
|
+
* await doc.dispose();
|
|
19
|
+
* kodexa.disconnect();
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
import type { WorkerConfig } from './types';
|
|
23
|
+
import { KodexaWorkerDocument } from './KodexaWorkerDocument';
|
|
24
|
+
/**
|
|
25
|
+
* Callback for WASM events forwarded from the worker.
|
|
26
|
+
*/
|
|
27
|
+
export type WasmEventCallback = (eventType: string, detail: unknown) => void;
|
|
28
|
+
/**
|
|
29
|
+
* Options for creating a KodexaSharedWorker instance.
|
|
30
|
+
*/
|
|
31
|
+
export interface KodexaSharedWorkerOptions extends WorkerConfig {
|
|
32
|
+
/**
|
|
33
|
+
* URL to the shared worker script.
|
|
34
|
+
* If not provided, uses the bundled shared worker from the package.
|
|
35
|
+
*/
|
|
36
|
+
workerUrl?: string | URL;
|
|
37
|
+
/**
|
|
38
|
+
* Whether to dispatch forwarded WASM events as DOM CustomEvents on document.
|
|
39
|
+
* Defaults to true for backwards compatibility with main-thread WASM code.
|
|
40
|
+
*/
|
|
41
|
+
dispatchDomEvents?: boolean;
|
|
42
|
+
/**
|
|
43
|
+
* Name for the SharedWorker (for debugging).
|
|
44
|
+
* Defaults to 'kodexa'.
|
|
45
|
+
*/
|
|
46
|
+
name?: string;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Main thread proxy for Kodexa SharedWorker.
|
|
50
|
+
*
|
|
51
|
+
* Creates and manages a connection to a SharedWorker that runs the Go WASM module.
|
|
52
|
+
* Multiple KodexaSharedWorker instances in different tabs will share the same
|
|
53
|
+
* underlying SharedWorker process.
|
|
54
|
+
*/
|
|
55
|
+
export declare class KodexaSharedWorker {
|
|
56
|
+
private worker;
|
|
57
|
+
private port;
|
|
58
|
+
private ready;
|
|
59
|
+
private readyResolve;
|
|
60
|
+
private readyReject;
|
|
61
|
+
private pending;
|
|
62
|
+
private nextId;
|
|
63
|
+
private disconnected;
|
|
64
|
+
private config;
|
|
65
|
+
private dispatchDomEvents;
|
|
66
|
+
private eventListeners;
|
|
67
|
+
private portId;
|
|
68
|
+
/**
|
|
69
|
+
* Create a new KodexaSharedWorker instance.
|
|
70
|
+
*
|
|
71
|
+
* @param options Configuration options
|
|
72
|
+
*/
|
|
73
|
+
constructor(options?: KodexaSharedWorkerOptions);
|
|
74
|
+
/**
|
|
75
|
+
* Handle messages from the worker.
|
|
76
|
+
*/
|
|
77
|
+
private handleMessage;
|
|
78
|
+
/**
|
|
79
|
+
* Handle WASM events forwarded from the worker.
|
|
80
|
+
*/
|
|
81
|
+
private handleWasmEvent;
|
|
82
|
+
/**
|
|
83
|
+
* Handle worker errors.
|
|
84
|
+
*/
|
|
85
|
+
private handleError;
|
|
86
|
+
/**
|
|
87
|
+
* Initialize the worker and load WASM.
|
|
88
|
+
* Must be called before any other methods.
|
|
89
|
+
*/
|
|
90
|
+
init(): Promise<void>;
|
|
91
|
+
/**
|
|
92
|
+
* Get the port ID assigned by the SharedWorker.
|
|
93
|
+
*/
|
|
94
|
+
getPortId(): string | null;
|
|
95
|
+
/**
|
|
96
|
+
* Call a Go WASM function in the worker.
|
|
97
|
+
*
|
|
98
|
+
* @param method Function name (e.g., 'createDocument', 'documentGetRoot')
|
|
99
|
+
* @param args Arguments to pass to the function
|
|
100
|
+
* @returns Promise that resolves with the function result
|
|
101
|
+
*/
|
|
102
|
+
call<T = unknown>(method: string, ...args: unknown[]): Promise<T>;
|
|
103
|
+
/**
|
|
104
|
+
* Create a new empty document.
|
|
105
|
+
*/
|
|
106
|
+
createDocument(): Promise<KodexaWorkerDocument>;
|
|
107
|
+
/**
|
|
108
|
+
* Create a document from text content.
|
|
109
|
+
*
|
|
110
|
+
* @param text Text content for the document
|
|
111
|
+
*/
|
|
112
|
+
fromText(text: string): Promise<KodexaWorkerDocument>;
|
|
113
|
+
/**
|
|
114
|
+
* Create a document from JSON.
|
|
115
|
+
*
|
|
116
|
+
* @param json JSON string representing the document
|
|
117
|
+
*/
|
|
118
|
+
fromJson(json: string): Promise<KodexaWorkerDocument>;
|
|
119
|
+
/**
|
|
120
|
+
* Create a document from KDDB bytes.
|
|
121
|
+
*
|
|
122
|
+
* @param bytes KDDB file contents as Uint8Array
|
|
123
|
+
*/
|
|
124
|
+
fromKddb(bytes: Uint8Array): Promise<KodexaWorkerDocument>;
|
|
125
|
+
/**
|
|
126
|
+
* Create a document from KDDB bytes (raw, no migration).
|
|
127
|
+
*
|
|
128
|
+
* @param bytes KDDB file contents as Uint8Array
|
|
129
|
+
*/
|
|
130
|
+
fromKddbBytes(bytes: Uint8Array): Promise<KodexaWorkerDocument>;
|
|
131
|
+
/**
|
|
132
|
+
* Get library version information.
|
|
133
|
+
*/
|
|
134
|
+
getLibraryVersion(): Promise<string>;
|
|
135
|
+
/**
|
|
136
|
+
* Get build information.
|
|
137
|
+
*/
|
|
138
|
+
getBuildInfo(): Promise<string>;
|
|
139
|
+
/**
|
|
140
|
+
* Cleanup all resources in the worker.
|
|
141
|
+
*/
|
|
142
|
+
cleanup(): Promise<void>;
|
|
143
|
+
/**
|
|
144
|
+
* Get active handle count (for debugging).
|
|
145
|
+
*/
|
|
146
|
+
getActiveHandles(): Promise<unknown>;
|
|
147
|
+
/**
|
|
148
|
+
* Set the log level for Go WASM logging.
|
|
149
|
+
*
|
|
150
|
+
* @param level Log level ('debug', 'info', 'warn', 'error')
|
|
151
|
+
*/
|
|
152
|
+
setLogLevel(level: 'debug' | 'info' | 'warn' | 'error'): Promise<string>;
|
|
153
|
+
/**
|
|
154
|
+
* Subscribe to WASM events forwarded from the worker.
|
|
155
|
+
* These events include data change events, validation events, etc.
|
|
156
|
+
*
|
|
157
|
+
* @param callback Function to call when an event is received
|
|
158
|
+
* @returns Unsubscribe function
|
|
159
|
+
*/
|
|
160
|
+
onWasmEvent(callback: WasmEventCallback): () => void;
|
|
161
|
+
/**
|
|
162
|
+
* Remove a WASM event listener.
|
|
163
|
+
*
|
|
164
|
+
* @param callback The callback to remove
|
|
165
|
+
*/
|
|
166
|
+
offWasmEvent(callback: WasmEventCallback): void;
|
|
167
|
+
/**
|
|
168
|
+
* Enable or disable automatic DOM event dispatching.
|
|
169
|
+
*
|
|
170
|
+
* @param enabled Whether to dispatch DOM events
|
|
171
|
+
*/
|
|
172
|
+
setDispatchDomEvents(enabled: boolean): void;
|
|
173
|
+
/**
|
|
174
|
+
* Subscribe to events for a specific document.
|
|
175
|
+
* This tells the SharedWorker to forward events for this document to this port.
|
|
176
|
+
*
|
|
177
|
+
* @param docRef Document reference
|
|
178
|
+
* @param pattern Event pattern to subscribe to (e.g., '*' for all events)
|
|
179
|
+
*/
|
|
180
|
+
subscribeToDocument(docRef: number, pattern?: string): Promise<void>;
|
|
181
|
+
/**
|
|
182
|
+
* Unsubscribe from events for a specific document.
|
|
183
|
+
*
|
|
184
|
+
* @param docRef Document reference
|
|
185
|
+
*/
|
|
186
|
+
unsubscribeFromDocument(docRef: number): Promise<void>;
|
|
187
|
+
/**
|
|
188
|
+
* Initialize the recalculation service in the worker.
|
|
189
|
+
*
|
|
190
|
+
* @param docRef Document reference
|
|
191
|
+
* @param taxonomiesJson JSON string of taxonomies map
|
|
192
|
+
*/
|
|
193
|
+
initializeRecalculationService(docRef: number, taxonomiesJson: string): Promise<unknown>;
|
|
194
|
+
/**
|
|
195
|
+
* Subscribe to WASM events for a document.
|
|
196
|
+
*
|
|
197
|
+
* @param docRef Document reference
|
|
198
|
+
* @param pattern Event pattern to subscribe to
|
|
199
|
+
*/
|
|
200
|
+
subscribe(docRef: number, pattern: string): Promise<unknown>;
|
|
201
|
+
/**
|
|
202
|
+
* Unsubscribe from WASM events for a document.
|
|
203
|
+
*
|
|
204
|
+
* @param docRef Document reference
|
|
205
|
+
* @param pattern Event pattern to unsubscribe from
|
|
206
|
+
*/
|
|
207
|
+
unsubscribe(docRef: number, pattern: string): Promise<unknown>;
|
|
208
|
+
/**
|
|
209
|
+
* Free the recalculation service for a document.
|
|
210
|
+
*
|
|
211
|
+
* @param docRef Document reference
|
|
212
|
+
*/
|
|
213
|
+
freeRecalculationService(docRef: number): Promise<unknown>;
|
|
214
|
+
/**
|
|
215
|
+
* Create an extraction engine for a document.
|
|
216
|
+
*
|
|
217
|
+
* @param docRef Document reference
|
|
218
|
+
* @param taxonomiesJson JSON string of taxonomies array
|
|
219
|
+
* @returns Engine reference (0 on error)
|
|
220
|
+
*/
|
|
221
|
+
createExtractionEngine(docRef: number, taxonomiesJson: string): Promise<number>;
|
|
222
|
+
/**
|
|
223
|
+
* Run extraction and save results to the document.
|
|
224
|
+
*
|
|
225
|
+
* @param engineRef Extraction engine reference
|
|
226
|
+
* @returns Count of data objects extracted (-1 on error)
|
|
227
|
+
*/
|
|
228
|
+
processAndSaveExtraction(engineRef: number): Promise<number>;
|
|
229
|
+
/**
|
|
230
|
+
* Get content exceptions from the extraction.
|
|
231
|
+
*
|
|
232
|
+
* @param engineRef Extraction engine reference
|
|
233
|
+
* @returns JSON array of content exceptions
|
|
234
|
+
*/
|
|
235
|
+
getExtractionContentExceptions(engineRef: number): Promise<string>;
|
|
236
|
+
/**
|
|
237
|
+
* Get document taxon validations from the extraction.
|
|
238
|
+
*
|
|
239
|
+
* @param engineRef Extraction engine reference
|
|
240
|
+
* @returns JSON array of validations
|
|
241
|
+
*/
|
|
242
|
+
getExtractionValidations(engineRef: number): Promise<string>;
|
|
243
|
+
/**
|
|
244
|
+
* Free an extraction engine and release its resources.
|
|
245
|
+
*
|
|
246
|
+
* @param engineRef Extraction engine reference
|
|
247
|
+
*/
|
|
248
|
+
freeExtractionEngine(engineRef: number): Promise<void>;
|
|
249
|
+
/**
|
|
250
|
+
* Disconnect from the SharedWorker.
|
|
251
|
+
* This closes the port but doesn't terminate the worker (other tabs may still use it).
|
|
252
|
+
*/
|
|
253
|
+
disconnect(): void;
|
|
254
|
+
/**
|
|
255
|
+
* Alias for disconnect() for API compatibility with KodexaWorker.
|
|
256
|
+
*/
|
|
257
|
+
terminate(): void;
|
|
258
|
+
/**
|
|
259
|
+
* Check if the worker has been disconnected.
|
|
260
|
+
*/
|
|
261
|
+
isDisconnected(): boolean;
|
|
262
|
+
/**
|
|
263
|
+
* Alias for isDisconnected() for API compatibility with KodexaWorker.
|
|
264
|
+
*/
|
|
265
|
+
isTerminated(): boolean;
|
|
266
|
+
}
|
|
267
|
+
//# sourceMappingURL=KodexaSharedWorker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KodexaSharedWorker.d.ts","sourceRoot":"","sources":["../../src/worker/KodexaSharedWorker.ts"],"names":[],"mappings":"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"}
|