@workglow/util 0.1.1 → 0.2.0

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 (51) hide show
  1. package/dist/browser.js +344 -80
  2. package/dist/browser.js.map +17 -13
  3. package/dist/bun.js +344 -80
  4. package/dist/bun.js.map +17 -13
  5. package/dist/credentials/CredentialProviderOptions.d.ts +38 -0
  6. package/dist/credentials/CredentialProviderOptions.d.ts.map +1 -0
  7. package/dist/credentials/CredentialPutInputSchema.d.ts +37 -0
  8. package/dist/credentials/CredentialPutInputSchema.d.ts.map +1 -0
  9. package/dist/credentials/CredentialStoreRegistry.d.ts.map +1 -1
  10. package/dist/credentials/OtpPassphraseCache.d.ts +73 -0
  11. package/dist/credentials/OtpPassphraseCache.d.ts.map +1 -0
  12. package/dist/credentials/index.d.ts +6 -3
  13. package/dist/credentials/index.d.ts.map +1 -1
  14. package/dist/di/Container.d.ts +15 -0
  15. package/dist/di/Container.d.ts.map +1 -1
  16. package/dist/di/InputCompactorRegistry.d.ts +46 -0
  17. package/dist/di/InputCompactorRegistry.d.ts.map +1 -0
  18. package/dist/di/InputResolverRegistry.d.ts.map +1 -1
  19. package/dist/di/ServiceRegistry.d.ts +11 -0
  20. package/dist/di/ServiceRegistry.d.ts.map +1 -1
  21. package/dist/di/index.d.ts +1 -0
  22. package/dist/di/index.d.ts.map +1 -1
  23. package/dist/events/EventEmitter.d.ts +16 -0
  24. package/dist/events/EventEmitter.d.ts.map +1 -1
  25. package/dist/graph/directedAcyclicGraph.d.ts.map +1 -1
  26. package/dist/graph/directedGraph.d.ts.map +1 -1
  27. package/dist/graph/graph.d.ts.map +1 -1
  28. package/dist/graph-entry.js +55 -18
  29. package/dist/graph-entry.js.map +6 -6
  30. package/dist/json-schema/SchemaValidation.d.ts +31 -0
  31. package/dist/json-schema/SchemaValidation.d.ts.map +1 -1
  32. package/dist/logging/LoggerRegistry.d.ts.map +1 -1
  33. package/dist/node.js +344 -80
  34. package/dist/node.js.map +17 -13
  35. package/dist/schema-entry.js +168 -1
  36. package/dist/schema-entry.js.map +4 -4
  37. package/dist/telemetry/ITelemetryProvider.d.ts.map +1 -1
  38. package/dist/telemetry/TelemetryRegistry.d.ts.map +1 -1
  39. package/dist/vector/Tensor.d.ts.map +1 -1
  40. package/dist/vector/TypedArray.d.ts.map +1 -1
  41. package/dist/worker/Worker.browser.d.ts +1 -1
  42. package/dist/worker/Worker.bun.d.ts +1 -1
  43. package/dist/worker/WorkerManager.d.ts +9 -0
  44. package/dist/worker/WorkerManager.d.ts.map +1 -1
  45. package/dist/worker-browser.js +110 -22
  46. package/dist/worker-browser.js.map +10 -9
  47. package/dist/worker-bun.js +110 -22
  48. package/dist/worker-bun.js.map +10 -9
  49. package/dist/worker-node.js +110 -22
  50. package/dist/worker-node.js.map +10 -9
  51. package/package.json +6 -1
@@ -3,12 +3,19 @@ class Container {
3
3
  services = new Map;
4
4
  factories = new Map;
5
5
  singletons = new Set;
6
+ resolving = [];
6
7
  register(token, factory, singleton = true) {
7
8
  this.factories.set(token, factory);
8
9
  if (singleton) {
9
10
  this.singletons.add(token);
10
11
  }
11
12
  }
13
+ registerIfAbsent(token, factory, singleton = true) {
14
+ if (this.factories.has(token) || this.services.has(token)) {
15
+ return;
16
+ }
17
+ this.register(token, factory, singleton);
18
+ }
12
19
  registerInstance(token, instance) {
13
20
  this.services.set(token, instance);
14
21
  this.singletons.add(token);
@@ -21,11 +28,20 @@ class Container {
21
28
  if (!factory) {
22
29
  throw new Error(`Service not registered: ${String(token)}`);
23
30
  }
24
- const instance = factory();
25
- if (this.singletons.has(token)) {
26
- this.services.set(token, instance);
31
+ if (this.resolving.includes(token)) {
32
+ const cycle = [...this.resolving.slice(this.resolving.indexOf(token)), token];
33
+ throw new Error(`Circular dependency detected: ${cycle.join(" -> ")}`);
34
+ }
35
+ this.resolving.push(token);
36
+ try {
37
+ const instance = factory();
38
+ if (this.singletons.has(token)) {
39
+ this.services.set(token, instance);
40
+ }
41
+ return instance;
42
+ } finally {
43
+ this.resolving.pop();
27
44
  }
28
- return instance;
29
45
  }
30
46
  has(token) {
31
47
  return this.services.has(token) || this.factories.has(token);
@@ -35,6 +51,36 @@ class Container {
35
51
  this.factories.delete(token);
36
52
  this.singletons.delete(token);
37
53
  }
54
+ async dispose() {
55
+ const errors = [];
56
+ try {
57
+ for (const service of this.services.values()) {
58
+ if (service == null)
59
+ continue;
60
+ try {
61
+ if (typeof service[Symbol.asyncDispose] === "function") {
62
+ await service[Symbol.asyncDispose]();
63
+ } else if (typeof service[Symbol.dispose] === "function") {
64
+ service[Symbol.dispose]();
65
+ } else if (typeof service.dispose === "function") {
66
+ await service.dispose();
67
+ }
68
+ } catch (err) {
69
+ errors.push(err);
70
+ }
71
+ }
72
+ } finally {
73
+ this.services.clear();
74
+ this.factories.clear();
75
+ this.singletons.clear();
76
+ }
77
+ if (errors.length > 0) {
78
+ throw new AggregateError(errors, "One or more services failed to dispose");
79
+ }
80
+ }
81
+ async[Symbol.asyncDispose]() {
82
+ await this.dispose();
83
+ }
38
84
  createChildContainer() {
39
85
  const child = new Container;
40
86
  this.factories.forEach((factory, token) => {
@@ -66,6 +112,9 @@ class ServiceRegistry {
66
112
  register(token, factory, singleton = true) {
67
113
  this.container.register(token.id, factory, singleton);
68
114
  }
115
+ registerIfAbsent(token, factory, singleton = true) {
116
+ this.container.registerIfAbsent(token.id, factory, singleton);
117
+ }
69
118
  registerInstance(token, instance) {
70
119
  this.container.registerInstance(token.id, instance);
71
120
  }
@@ -75,14 +124,25 @@ class ServiceRegistry {
75
124
  has(token) {
76
125
  return this.container.has(token.id);
77
126
  }
127
+ async dispose() {
128
+ await this.container.dispose();
129
+ }
78
130
  }
79
131
  var globalServiceRegistry = new ServiceRegistry(globalContainer);
80
132
 
133
+ // src/di/InputCompactorRegistry.ts
134
+ var INPUT_COMPACTORS = createServiceToken("task.input.compactors");
135
+ globalServiceRegistry.registerIfAbsent(INPUT_COMPACTORS, () => new Map, true);
136
+ function getInputCompactors() {
137
+ return globalServiceRegistry.get(INPUT_COMPACTORS);
138
+ }
139
+ function registerInputCompactor(formatPrefix, compactor) {
140
+ const compactors = getInputCompactors();
141
+ compactors.set(formatPrefix, compactor);
142
+ }
81
143
  // src/di/InputResolverRegistry.ts
82
144
  var INPUT_RESOLVERS = createServiceToken("task.input.resolvers");
83
- if (!globalServiceRegistry.has(INPUT_RESOLVERS)) {
84
- globalServiceRegistry.register(INPUT_RESOLVERS, () => new Map, true);
85
- }
145
+ globalServiceRegistry.registerIfAbsent(INPUT_RESOLVERS, () => new Map, true);
86
146
  function getInputResolvers() {
87
147
  return globalServiceRegistry.get(INPUT_RESOLVERS);
88
148
  }
@@ -257,9 +317,7 @@ function createDefaultLogger() {
257
317
  }
258
318
  return new NullLogger;
259
319
  }
260
- if (!globalServiceRegistry.has(LOGGER)) {
261
- globalServiceRegistry.register(LOGGER, createDefaultLogger, true);
262
- }
320
+ globalServiceRegistry.registerIfAbsent(LOGGER, createDefaultLogger, true);
263
321
  function getLogger() {
264
322
  return globalServiceRegistry.get(LOGGER);
265
323
  }
@@ -458,9 +516,9 @@ class WorkerServerBase {
458
516
  setTimeout(() => {
459
517
  this.completedRequests.delete(id);
460
518
  }, 5000);
461
- if (this.completedRequests.size > 1e4) {
519
+ if (this.completedRequests.size > 1000) {
462
520
  const iter = this.completedRequests.values();
463
- for (let i = 0;i < 5000; i++) {
521
+ for (let i = 0;i < 500; i++) {
464
522
  const entry = iter.next();
465
523
  if (entry.done)
466
524
  break;
@@ -539,16 +597,19 @@ class WorkerManager {
539
597
  let init = this.lazyInitPromises.get(name);
540
598
  if (!init) {
541
599
  init = (async () => {
542
- const f = this.lazyFactories.get(name);
543
- this.lazyFactories.delete(name);
544
- const worker = f();
545
- this.attachWorkerInstance(name, worker);
600
+ try {
601
+ const f = this.lazyFactories.get(name);
602
+ this.lazyFactories.delete(name);
603
+ const worker = f();
604
+ this.attachWorkerInstance(name, worker);
605
+ await this.readyWorkers.get(name);
606
+ } finally {
607
+ this.lazyInitPromises.delete(name);
608
+ }
546
609
  })();
547
610
  this.lazyInitPromises.set(name, init);
548
611
  }
549
612
  await init;
550
- await this.readyWorkers.get(name);
551
- this.lazyInitPromises.delete(name);
552
613
  }
553
614
  getWorker(name) {
554
615
  const worker = this.workers.get(name);
@@ -561,7 +622,6 @@ class WorkerManager {
561
622
  const worker = this.workers.get(workerName);
562
623
  if (!worker)
563
624
  throw new Error(`Worker ${workerName} not found.`);
564
- await this.readyWorkers.get(workerName);
565
625
  const knownFunctions = this.workerFunctions.get(workerName);
566
626
  if (knownFunctions && !knownFunctions.has(functionName)) {
567
627
  throw new Error(`Function "${functionName}" is not registered on worker "${workerName}".`);
@@ -610,7 +670,6 @@ class WorkerManager {
610
670
  const worker = this.workers.get(workerName);
611
671
  if (!worker)
612
672
  return;
613
- await this.readyWorkers.get(workerName);
614
673
  const knownReactive = this.workerReactiveFunctions.get(workerName);
615
674
  if (knownReactive && !knownReactive.has(functionName))
616
675
  return;
@@ -625,6 +684,9 @@ class WorkerManager {
625
684
  resolve(data);
626
685
  } else if (type === "error") {
627
686
  cleanup();
687
+ getLogger().warn(`Worker ${workerName} reactive function ${functionName} error:`, {
688
+ error: data
689
+ });
628
690
  resolve(undefined);
629
691
  }
630
692
  };
@@ -637,12 +699,35 @@ class WorkerManager {
637
699
  getLogger().info(`Worker ${workerName} reactive function ${functionName} called.`);
638
700
  });
639
701
  }
702
+ async terminateWorker(name) {
703
+ const worker = this.workers.get(name);
704
+ this.workers.delete(name);
705
+ this.readyWorkers.delete(name);
706
+ this.workerFunctions.delete(name);
707
+ this.workerStreamFunctions.delete(name);
708
+ this.workerReactiveFunctions.delete(name);
709
+ this.lazyFactories.delete(name);
710
+ this.lazyInitPromises.delete(name);
711
+ try {
712
+ if (worker && "terminate" in worker && typeof worker.terminate === "function") {
713
+ await worker.terminate();
714
+ }
715
+ } catch {}
716
+ }
717
+ async dispose() {
718
+ const names = [...this.workers.keys(), ...this.lazyFactories.keys()];
719
+ for (const name of names) {
720
+ await this.terminateWorker(name);
721
+ }
722
+ }
723
+ async[Symbol.asyncDispose]() {
724
+ await this.dispose();
725
+ }
640
726
  async* callWorkerStreamFunction(workerName, functionName, args, options) {
641
727
  await this.ensureWorkerReady(workerName);
642
728
  const worker = this.workers.get(workerName);
643
729
  if (!worker)
644
730
  throw new Error(`Worker ${workerName} not found.`);
645
- await this.readyWorkers.get(workerName);
646
731
  const knownStream = this.workerStreamFunctions.get(workerName);
647
732
  const knownFns = this.workerFunctions.get(workerName);
648
733
  if (knownStream && knownFns && !knownStream.has(functionName) && !knownFns.has(functionName)) {
@@ -924,12 +1009,14 @@ globalServiceRegistry.register(WORKER_SERVER, () => new WorkerServer, true);
924
1009
  export {
925
1010
  setLogger,
926
1011
  registerInputResolver,
1012
+ registerInputCompactor,
927
1013
  parsePartialJson,
928
1014
  parentPort,
929
1015
  globalServiceRegistry,
930
1016
  globalContainer,
931
1017
  getLogger,
932
1018
  getInputResolvers,
1019
+ getInputCompactors,
933
1020
  createServiceToken,
934
1021
  WorkerServerBase,
935
1022
  WorkerServer,
@@ -941,8 +1028,9 @@ export {
941
1028
  NullLogger,
942
1029
  LOGGER,
943
1030
  INPUT_RESOLVERS,
1031
+ INPUT_COMPACTORS,
944
1032
  Container,
945
1033
  ConsoleLogger
946
1034
  };
947
1035
 
948
- //# debugId=F33C75360B6E735864756E2164756E21
1036
+ //# debugId=D50270F8EE79338864756E2164756E21
@@ -1,19 +1,20 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../src/di/Container.ts", "../src/di/ServiceRegistry.ts", "../src/di/InputResolverRegistry.ts", "../src/logging/ConsoleLogger.ts", "../src/logging/NullLogger.ts", "../src/logging/LoggerRegistry.ts", "../src/worker/WorkerServerBase.ts", "../src/worker/WorkerManager.ts", "../src/json-schema/parsePartialJson.ts", "../src/worker/Worker.node.ts"],
3
+ "sources": ["../src/di/Container.ts", "../src/di/ServiceRegistry.ts", "../src/di/InputCompactorRegistry.ts", "../src/di/InputResolverRegistry.ts", "../src/logging/ConsoleLogger.ts", "../src/logging/NullLogger.ts", "../src/logging/LoggerRegistry.ts", "../src/worker/WorkerServerBase.ts", "../src/worker/WorkerManager.ts", "../src/json-schema/parsePartialJson.ts", "../src/worker/Worker.node.ts"],
4
4
  "sourcesContent": [
5
- "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\n/**\n * Simple dependency injection container for managing service instances and dependencies\n */\nexport class Container {\n private services: Map<string, any> = new Map();\n private factories: Map<string, () => any> = new Map();\n private singletons: Set<string> = new Set();\n\n /**\n * Register a service factory\n * @param token The identifier token for the service\n * @param factory A factory function that creates the service\n * @param singleton Whether the service should be a singleton (created once)\n */\n register<T>(token: string, factory: () => T, singleton = true): void {\n this.factories.set(token, factory);\n if (singleton) {\n this.singletons.add(token);\n }\n }\n\n /**\n * Register an instance as a service\n * @param token The identifier token for the service\n * @param instance The instance to register\n */\n registerInstance<T>(token: string, instance: T): void {\n this.services.set(token, instance);\n this.singletons.add(token);\n }\n\n /**\n * Get a service by its token\n * @param token The identifier token for the service\n * @returns The service instance\n */\n get<T>(token: string): T {\n if (this.services.has(token)) {\n return this.services.get(token) as T;\n }\n\n const factory = this.factories.get(token);\n if (!factory) {\n throw new Error(`Service not registered: ${String(token)}`);\n }\n\n const instance = factory();\n\n if (this.singletons.has(token)) {\n this.services.set(token, instance);\n }\n\n return instance as T;\n }\n\n /**\n * Check if a service is registered\n * @param token The identifier token for the service\n * @returns True if the service is registered\n */\n has(token: string): boolean {\n return this.services.has(token) || this.factories.has(token);\n }\n\n /**\n * Remove a service registration\n * @param token The identifier token for the service\n */\n remove(token: string): void {\n this.services.delete(token);\n this.factories.delete(token);\n this.singletons.delete(token);\n }\n\n /**\n * Create a child container that inherits registrations from the parent\n * @returns A new child container\n */\n createChildContainer(): Container {\n const child = new Container();\n\n // Copy all registrations to the child\n this.factories.forEach((factory, token) => {\n child.factories.set(token, factory);\n if (this.singletons.has(token)) {\n child.singletons.add(token);\n }\n });\n\n // Copy all singleton instances to the child\n this.services.forEach((service, token) => {\n if (this.singletons.has(token)) {\n child.services.set(token, service);\n child.singletons.add(token);\n }\n });\n\n return child;\n }\n}\n\n/**\n * Global container instance\n */\nexport const globalContainer = new Container();\n",
6
- "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Container, globalContainer } from \"./Container\";\n\n/**\n * Service token type for type-safe dependency injection\n */\nexport interface ServiceToken<T> {\n readonly _type: T;\n readonly id: string;\n}\n\n/**\n * Create a typed service token\n * @param id Unique identifier for the service\n * @returns A typed service token\n */\nexport function createServiceToken<T>(id: string): ServiceToken<T> {\n return { id, _type: null as any };\n}\n\n/**\n * Service registry for managing and accessing services\n */\nexport class ServiceRegistry {\n public container: Container;\n\n /**\n * Create a new service registry\n * @param container Optional container to use (defaults to global container)\n */\n constructor(container: Container = globalContainer) {\n this.container = container;\n }\n\n /**\n * Register a service factory\n * @param token Service token\n * @param factory Factory function to create the service\n * @param singleton Whether the service should be a singleton\n */\n register<T>(token: ServiceToken<T>, factory: () => T, singleton = true): void {\n this.container.register(token.id, factory, singleton);\n }\n\n /**\n * Register a service instance\n * @param token Service token\n * @param instance Service instance to register\n */\n registerInstance<T>(token: ServiceToken<T>, instance: T): void {\n this.container.registerInstance(token.id, instance);\n }\n\n /**\n * Get a service by its token\n * @param token Service token\n * @returns The service instance\n */\n get<T>(token: ServiceToken<T>): T {\n return this.container.get<T>(token.id);\n }\n\n /**\n * Check if a service is registered\n * @param token Service token\n * @returns True if the service is registered\n */\n has<T>(token: ServiceToken<T>): boolean {\n return this.container.has(token.id);\n }\n}\n\n/**\n * Global service registry instance\n */\nexport const globalServiceRegistry = new ServiceRegistry(globalContainer);\n",
7
- "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { ServiceRegistry } from \"./ServiceRegistry\";\nimport { createServiceToken, globalServiceRegistry } from \"./ServiceRegistry\";\n\n/**\n * A resolver function that converts a string ID to an instance.\n * Returns undefined if the resolver cannot handle this format.\n * Throws an error if the ID is not found.\n *\n * @param id The string ID to resolve\n * @param format The full format string (e.g., \"model:TextEmbedding\", \"storage:tabular\")\n * @param registry The service registry to use for lookups\n */\nexport type InputResolverFn = (\n id: string,\n format: string,\n registry: ServiceRegistry\n) => unknown | Promise<unknown>;\n\n/**\n * Service token for the input resolver registry.\n * Maps format prefixes to resolver functions.\n */\nexport const INPUT_RESOLVERS =\n createServiceToken<Map<string, InputResolverFn>>(\"task.input.resolvers\");\n\n// Register default factory if not already registered\nif (!globalServiceRegistry.has(INPUT_RESOLVERS)) {\n globalServiceRegistry.register(\n INPUT_RESOLVERS,\n (): Map<string, InputResolverFn> => new Map(),\n true\n );\n}\n\n/**\n * Gets the global input resolver registry\n * @returns Map of format prefix to resolver function\n */\nexport function getInputResolvers(): Map<string, InputResolverFn> {\n return globalServiceRegistry.get(INPUT_RESOLVERS);\n}\n\n/**\n * Registers an input resolver for a format prefix.\n * The resolver will be called for any format that starts with this prefix.\n *\n * @param formatPrefix The format prefix to match (e.g., \"model\", \"dataset\")\n * @param resolver The resolver function\n *\n * @example\n * ```typescript\n * // Register model resolver\n * registerInputResolver(\"model\", async (id, format, registry) => {\n * const modelRepo = registry.get(MODEL_REPOSITORY);\n * const model = await modelRepo.findByName(id);\n * if (!model) throw new Error(`Model \"${id}\" not found`);\n * return model;\n * });\n *\n * // Register dataset resolver\n * registerInputResolver(\"dataset\", (id, format, registry) => {\n * const datasetType = format.split(\":\")[1]; // \"tabular\", \"vector\", etc.\n * if (datasetType === \"tabular\") {\n * const datasets = registry.get(TABULAR_DATASETS);\n * const dataset = datasets.get(id);\n * if (!dataset) throw new Error(`Dataset \"${id}\" not found`);\n * return dataset;\n * }\n * throw new Error(`Unknown dataset type: ${datasetType}`);\n * });\n * ```\n */\nexport function registerInputResolver(formatPrefix: string, resolver: InputResolverFn): void {\n const resolvers = getInputResolvers();\n resolvers.set(formatPrefix, resolver);\n}\n",
5
+ "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\n/**\n * Simple dependency injection container for managing service instances and dependencies\n */\nexport class Container {\n private services: Map<string, any> = new Map();\n private factories: Map<string, () => any> = new Map();\n private singletons: Set<string> = new Set();\n private resolving: string[] = [];\n\n /**\n * Register a service factory\n * @param token The identifier token for the service\n * @param factory A factory function that creates the service\n * @param singleton Whether the service should be a singleton (created once)\n */\n register<T>(token: string, factory: () => T, singleton = true): void {\n this.factories.set(token, factory);\n if (singleton) {\n this.singletons.add(token);\n }\n }\n\n /**\n * Register a service factory only if the token is not already registered.\n * This is an atomic check-and-register to avoid TOCTOU races.\n * @param token The identifier token for the service\n * @param factory A factory function that creates the service\n * @param singleton Whether the service should be a singleton (created once)\n */\n registerIfAbsent<T>(token: string, factory: () => T, singleton = true): void {\n if (this.factories.has(token) || this.services.has(token)) {\n return;\n }\n this.register(token, factory, singleton);\n }\n\n /**\n * Register an instance as a service\n * @param token The identifier token for the service\n * @param instance The instance to register\n */\n registerInstance<T>(token: string, instance: T): void {\n this.services.set(token, instance);\n this.singletons.add(token);\n }\n\n /**\n * Get a service by its token\n * @param token The identifier token for the service\n * @returns The service instance\n */\n get<T>(token: string): T {\n if (this.services.has(token)) {\n return this.services.get(token) as T;\n }\n\n const factory = this.factories.get(token);\n if (!factory) {\n throw new Error(`Service not registered: ${String(token)}`);\n }\n\n if (this.resolving.includes(token)) {\n const cycle = [...this.resolving.slice(this.resolving.indexOf(token)), token];\n throw new Error(`Circular dependency detected: ${cycle.join(\" -> \")}`);\n }\n\n this.resolving.push(token);\n try {\n const instance = factory();\n\n if (this.singletons.has(token)) {\n this.services.set(token, instance);\n }\n\n return instance as T;\n } finally {\n this.resolving.pop();\n }\n }\n\n /**\n * Check if a service is registered\n * @param token The identifier token for the service\n * @returns True if the service is registered\n */\n has(token: string): boolean {\n return this.services.has(token) || this.factories.has(token);\n }\n\n /**\n * Remove a service registration\n * @param token The identifier token for the service\n */\n remove(token: string): void {\n this.services.delete(token);\n this.factories.delete(token);\n this.singletons.delete(token);\n }\n\n /**\n * Dispose all instantiated singleton services and clear registrations.\n * Services implementing dispose(), Symbol.asyncDispose, or Symbol.dispose will be cleaned up.\n */\n async dispose(): Promise<void> {\n const errors: unknown[] = [];\n try {\n for (const service of this.services.values()) {\n if (service == null) continue;\n try {\n if (typeof service[Symbol.asyncDispose] === \"function\") {\n await service[Symbol.asyncDispose]();\n } else if (typeof service[Symbol.dispose] === \"function\") {\n service[Symbol.dispose]();\n } else if (typeof service.dispose === \"function\") {\n await service.dispose();\n }\n } catch (err) {\n errors.push(err);\n }\n }\n } finally {\n this.services.clear();\n this.factories.clear();\n this.singletons.clear();\n }\n if (errors.length > 0) {\n throw new AggregateError(errors, \"One or more services failed to dispose\");\n }\n }\n\n async [Symbol.asyncDispose](): Promise<void> {\n await this.dispose();\n }\n\n /**\n * Create a child container that inherits registrations from the parent\n * @returns A new child container\n */\n createChildContainer(): Container {\n const child = new Container();\n\n // Copy all registrations to the child\n this.factories.forEach((factory, token) => {\n child.factories.set(token, factory);\n if (this.singletons.has(token)) {\n child.singletons.add(token);\n }\n });\n\n // Copy all singleton instances to the child\n this.services.forEach((service, token) => {\n if (this.singletons.has(token)) {\n child.services.set(token, service);\n child.singletons.add(token);\n }\n });\n\n return child;\n }\n}\n\n/**\n * Global container instance\n */\nexport const globalContainer = new Container();\n",
6
+ "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Container, globalContainer } from \"./Container\";\n\n/**\n * Service token type for type-safe dependency injection\n */\nexport interface ServiceToken<T> {\n readonly _type: T;\n readonly id: string;\n}\n\n/**\n * Create a typed service token\n * @param id Unique identifier for the service\n * @returns A typed service token\n */\nexport function createServiceToken<T>(id: string): ServiceToken<T> {\n return { id, _type: null as any };\n}\n\n/**\n * Service registry for managing and accessing services\n */\nexport class ServiceRegistry {\n public container: Container;\n\n /**\n * Create a new service registry\n * @param container Optional container to use (defaults to global container)\n */\n constructor(container: Container = globalContainer) {\n this.container = container;\n }\n\n /**\n * Register a service factory\n * @param token Service token\n * @param factory Factory function to create the service\n * @param singleton Whether the service should be a singleton\n */\n register<T>(token: ServiceToken<T>, factory: () => T, singleton = true): void {\n this.container.register(token.id, factory, singleton);\n }\n\n /**\n * Register a service factory only if the token is not already registered.\n * @param token Service token\n * @param factory Factory function to create the service\n * @param singleton Whether the service should be a singleton\n */\n registerIfAbsent<T>(token: ServiceToken<T>, factory: () => T, singleton = true): void {\n this.container.registerIfAbsent(token.id, factory, singleton);\n }\n\n /**\n * Register a service instance\n * @param token Service token\n * @param instance Service instance to register\n */\n registerInstance<T>(token: ServiceToken<T>, instance: T): void {\n this.container.registerInstance(token.id, instance);\n }\n\n /**\n * Get a service by its token\n * @param token Service token\n * @returns The service instance\n */\n get<T>(token: ServiceToken<T>): T {\n return this.container.get<T>(token.id);\n }\n\n /**\n * Check if a service is registered\n * @param token Service token\n * @returns True if the service is registered\n */\n has<T>(token: ServiceToken<T>): boolean {\n return this.container.has(token.id);\n }\n\n /**\n * Dispose all instantiated services and clear registrations.\n */\n async dispose(): Promise<void> {\n await this.container.dispose();\n }\n}\n\n/**\n * Global service registry instance\n */\nexport const globalServiceRegistry = new ServiceRegistry(globalContainer);\n",
7
+ "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { ServiceRegistry } from \"./ServiceRegistry\";\nimport { createServiceToken, globalServiceRegistry } from \"./ServiceRegistry\";\n\n/**\n * A compactor function that converts a resolved instance back to its string ID.\n * Returns undefined if the value cannot be compacted (e.g., missing ID field).\n *\n * @param value The resolved instance to compact\n * @param format The full format string (e.g., \"model:TextEmbedding\", \"storage:tabular\")\n * @param registry The service registry to use for lookups\n */\nexport type InputCompactorFn = (\n value: unknown,\n format: string,\n registry: ServiceRegistry\n) => string | undefined | Promise<string | undefined>;\n\n/**\n * Service token for the input compactor registry.\n * Maps format prefixes to compactor functions.\n */\nexport const INPUT_COMPACTORS =\n createServiceToken<Map<string, InputCompactorFn>>(\"task.input.compactors\");\n\n// Register default factory if not already registered\nglobalServiceRegistry.registerIfAbsent(\n INPUT_COMPACTORS,\n (): Map<string, InputCompactorFn> => new Map(),\n true\n);\n\n/**\n * Gets the global input compactor registry\n * @returns Map of format prefix to compactor function\n */\nexport function getInputCompactors(): Map<string, InputCompactorFn> {\n return globalServiceRegistry.get(INPUT_COMPACTORS);\n}\n\n/**\n * Registers an input compactor for a format prefix.\n * The compactor will be called to convert resolved instances back to string IDs.\n *\n * @param formatPrefix The format prefix to match (e.g., \"model\", \"knowledge-base\")\n * @param compactor The compactor function\n *\n * @example\n * ```typescript\n * // Register model compactor — extracts model_id from a ModelConfig\n * registerInputCompactor(\"model\", (value) => {\n * if (typeof value === \"object\" && value !== null && \"model_id\" in value) {\n * const id = (value as Record<string, unknown>).model_id;\n * return typeof id === \"string\" ? id : undefined;\n * }\n * return undefined;\n * });\n * ```\n */\nexport function registerInputCompactor(formatPrefix: string, compactor: InputCompactorFn): void {\n const compactors = getInputCompactors();\n compactors.set(formatPrefix, compactor);\n}\n",
8
+ "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { ServiceRegistry } from \"./ServiceRegistry\";\nimport { createServiceToken, globalServiceRegistry } from \"./ServiceRegistry\";\n\n/**\n * A resolver function that converts a string ID to an instance.\n * Returns undefined if the resolver cannot handle this format.\n * Throws an error if the ID is not found.\n *\n * @param id The string ID to resolve\n * @param format The full format string (e.g., \"model:TextEmbedding\", \"storage:tabular\")\n * @param registry The service registry to use for lookups\n */\nexport type InputResolverFn = (\n id: string,\n format: string,\n registry: ServiceRegistry\n) => unknown | Promise<unknown>;\n\n/**\n * Service token for the input resolver registry.\n * Maps format prefixes to resolver functions.\n */\nexport const INPUT_RESOLVERS =\n createServiceToken<Map<string, InputResolverFn>>(\"task.input.resolvers\");\n\n// Register default factory if not already registered\nglobalServiceRegistry.registerIfAbsent(\n INPUT_RESOLVERS,\n (): Map<string, InputResolverFn> => new Map(),\n true\n);\n\n/**\n * Gets the global input resolver registry\n * @returns Map of format prefix to resolver function\n */\nexport function getInputResolvers(): Map<string, InputResolverFn> {\n return globalServiceRegistry.get(INPUT_RESOLVERS);\n}\n\n/**\n * Registers an input resolver for a format prefix.\n * The resolver will be called for any format that starts with this prefix.\n *\n * @param formatPrefix The format prefix to match (e.g., \"model\", \"dataset\")\n * @param resolver The resolver function\n *\n * @example\n * ```typescript\n * // Register model resolver\n * registerInputResolver(\"model\", async (id, format, registry) => {\n * const modelRepo = registry.get(MODEL_REPOSITORY);\n * const model = await modelRepo.findByName(id);\n * if (!model) throw new Error(`Model \"${id}\" not found`);\n * return model;\n * });\n *\n * // Register dataset resolver\n * registerInputResolver(\"dataset\", (id, format, registry) => {\n * const datasetType = format.split(\":\")[1]; // \"tabular\", \"vector\", etc.\n * if (datasetType === \"tabular\") {\n * const datasets = registry.get(TABULAR_DATASETS);\n * const dataset = datasets.get(id);\n * if (!dataset) throw new Error(`Dataset \"${id}\" not found`);\n * return dataset;\n * }\n * throw new Error(`Unknown dataset type: ${datasetType}`);\n * });\n * ```\n */\nexport function registerInputResolver(formatPrefix: string, resolver: InputResolverFn): void {\n const resolvers = getInputResolvers();\n resolvers.set(formatPrefix, resolver);\n}\n",
8
9
  "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { ILogger } from \"./ILogger\";\n\n/**\n * Log-level names in ascending severity order.\n */\nexport type LogLevel = \"debug\" | \"info\" | \"warn\" | \"error\" | \"fatal\";\n\nconst LOG_LEVEL_ORDER: Record<LogLevel, number> = {\n debug: 0,\n info: 1,\n warn: 2,\n error: 3,\n fatal: 4,\n};\n\nexport interface ConsoleLoggerOptions {\n readonly bindings?: Record<string, unknown>;\n readonly level?: LogLevel;\n readonly timings?: boolean;\n}\n\n/**\n * Logger that delegates to the global `console` object.\n * When created via {@link child}, accumulated bindings are passed\n * as a second argument to every console call.\n *\n * Supports optional level filtering (messages below the configured\n * level are silently discarded) and an opt-in `timings` flag that\n * controls whether {@link time}/{@link timeEnd} produce output.\n */\nexport class ConsoleLogger implements ILogger {\n private readonly bindings: Record<string, unknown>;\n private readonly level: LogLevel;\n private readonly timings: boolean;\n\n constructor(options: ConsoleLoggerOptions = {}) {\n this.bindings = options.bindings ?? {};\n this.level = options.level ?? \"debug\";\n this.timings = options.timings ?? false;\n }\n\n private enabled(level: LogLevel): boolean {\n return LOG_LEVEL_ORDER[level] >= LOG_LEVEL_ORDER[this.level];\n }\n\n info(message: string, meta?: Record<string, unknown>): void {\n if (!this.enabled(\"info\")) return;\n const merged = this.merge(meta);\n if (merged) {\n console.info(message, merged);\n } else {\n console.info(message);\n }\n }\n\n warn(message: string, meta?: Record<string, unknown>): void {\n if (!this.enabled(\"warn\")) return;\n const merged = this.merge(meta);\n if (merged) {\n console.warn(message, merged);\n } else {\n console.warn(message);\n }\n }\n\n error(message: string, meta?: Record<string, unknown>): void {\n if (!this.enabled(\"error\")) return;\n const merged = this.merge(meta);\n if (merged) {\n console.error(message, merged);\n } else {\n console.error(message);\n }\n }\n\n debug(message: string, meta?: Record<string, unknown>): void {\n if (!this.enabled(\"debug\")) return;\n const merged = this.merge(meta);\n if (merged) {\n console.debug(message, merged);\n } else {\n console.debug(message);\n }\n }\n\n fatal(err: Error, message: string, meta?: Record<string, unknown>): void {\n if (!this.enabled(\"fatal\")) return;\n const merged = this.merge(meta);\n if (merged) {\n console.error(message, { ...merged, error: err });\n } else {\n console.error(message, { error: err });\n }\n }\n\n time(label: string, meta?: Record<string, unknown>): void {\n if (!this.timings) return;\n const merged = this.merge(meta);\n if (merged) {\n console.info(`[time] ${label}`, merged);\n }\n console.time(label);\n }\n\n timeEnd(label: string, meta?: Record<string, unknown>): void {\n if (!this.timings) return;\n console.timeEnd(label);\n const merged = this.merge(meta);\n if (merged) {\n console.info(`[timeEnd] ${label}`, merged);\n }\n }\n\n group(label: string, meta?: Record<string, unknown>): void {\n const merged = this.merge(meta);\n if (merged) {\n console.group(label, merged);\n } else {\n console.group(label);\n }\n }\n\n groupEnd(): void {\n console.groupEnd();\n }\n\n child(bindings: Record<string, unknown>): ILogger {\n return new ConsoleLogger({\n bindings: { ...this.bindings, ...bindings },\n level: this.level,\n timings: this.timings,\n });\n }\n\n private merge(meta: Record<string, unknown> | undefined): Record<string, unknown> | undefined {\n const hasBindings = Object.keys(this.bindings).length > 0;\n if (!hasBindings && !meta) return undefined;\n if (!hasBindings) return meta;\n if (!meta) return this.bindings;\n return { ...this.bindings, ...meta };\n }\n}\n",
9
10
  "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { ILogger } from \"./ILogger\";\n\n/**\n * Silent logger that discards all output.\n * Useful for suppressing log noise in tests.\n */\nexport class NullLogger implements ILogger {\n info(_message: string, _meta?: Record<string, unknown>): void {}\n error(_message: string, _meta?: Record<string, unknown>): void {}\n warn(_message: string, _meta?: Record<string, unknown>): void {}\n debug(_message: string, _meta?: Record<string, unknown>): void {}\n fatal(_err: Error, _message: string, _meta?: Record<string, unknown>): void {}\n time(_label: string, _meta?: Record<string, unknown>): void {}\n timeEnd(_label: string, _meta?: Record<string, unknown>): void {}\n group(_label: string, _meta?: Record<string, unknown>): void {}\n groupEnd(): void {}\n child(_bindings: Record<string, unknown>): ILogger {\n return this;\n }\n}\n",
10
- "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { createServiceToken, globalServiceRegistry } from \"../di/ServiceRegistry\";\nimport type { LogLevel } from \"./ConsoleLogger\";\nimport { ConsoleLogger } from \"./ConsoleLogger\";\nimport type { ILogger } from \"./ILogger\";\nimport { NullLogger } from \"./NullLogger\";\n\n/**\n * Service token for the global logger instance.\n */\nexport const LOGGER = createServiceToken<ILogger>(\"logger\");\n\nconst VALID_LOG_LEVELS: ReadonlySet<string> = new Set<string>([\n \"debug\",\n \"info\",\n \"warn\",\n \"error\",\n \"fatal\",\n]);\n\nfunction getEnv(name: string): string | undefined {\n if (typeof process !== \"undefined\" && process.env) {\n return process.env[name];\n }\n return import.meta.env[name];\n}\n\nfunction isTruthy(value: string | undefined): boolean {\n return value !== undefined && value !== \"\" && value !== \"0\" && value !== \"false\";\n}\n\nfunction createDefaultLogger(): ILogger {\n const levelEnv = getEnv(\"LOGGER_LEVEL\")?.toLowerCase();\n if (levelEnv && VALID_LOG_LEVELS.has(levelEnv)) {\n return new ConsoleLogger({\n level: levelEnv as LogLevel,\n timings: isTruthy(getEnv(\"LOGGER_TIMINGS\")),\n });\n }\n if (getEnv(\"DEV\")) {\n return new ConsoleLogger({\n level: \"debug\" as LogLevel,\n timings: true,\n });\n }\n return new NullLogger();\n}\n\n// Register default logger: NullLogger unless LOGGER_LEVEL env var is set.\nif (!globalServiceRegistry.has(LOGGER)) {\n globalServiceRegistry.register(LOGGER, createDefaultLogger, true);\n}\n\n/**\n * Returns the current global logger.\n */\nexport function getLogger(): ILogger {\n return globalServiceRegistry.get(LOGGER);\n}\n\n/**\n * Replaces the global logger instance.\n */\nexport function setLogger(logger: ILogger): void {\n globalServiceRegistry.registerInstance(LOGGER, logger);\n}\n",
11
- "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { createServiceToken } from \"../di\";\n\n/** Service token for the platform-specific WorkerServer instance. */\nexport const WORKER_SERVER = createServiceToken<WorkerServerBase>(\"worker.server\");\n\n/**\n * Extracts transferables from an object.\n * @param obj - The object to extract transferables from.\n * @returns An array of transferables.\n */\nfunction extractTransferables(obj: any) {\n const transferables: Transferable[] = [];\n const seen = new WeakSet();\n\n function findTransferables(value: any) {\n // Avoid infinite recursion\n if (value && typeof value === \"object\" && seen.has(value)) {\n return;\n }\n if (value && typeof value === \"object\") {\n seen.add(value);\n }\n\n // Handle TypedArrays\n if (value instanceof Float32Array || value instanceof Int16Array) {\n transferables.push(value.buffer);\n }\n // Handle other TypedArrays\n else if (\n value instanceof Uint8Array ||\n value instanceof Uint8ClampedArray ||\n value instanceof Int8Array ||\n value instanceof Uint16Array ||\n value instanceof Int32Array ||\n value instanceof Uint32Array ||\n value instanceof Float64Array ||\n value instanceof BigInt64Array ||\n value instanceof BigUint64Array\n ) {\n transferables.push(value.buffer);\n }\n // Handle OffscreenCanvas\n else if (typeof OffscreenCanvas !== \"undefined\" && value instanceof OffscreenCanvas) {\n transferables.push(value);\n }\n // Handle ImageBitmap\n else if (typeof ImageBitmap !== \"undefined\" && value instanceof ImageBitmap) {\n transferables.push(value);\n }\n // Handle VideoFrame\n else if (typeof VideoFrame !== \"undefined\" && value instanceof VideoFrame) {\n transferables.push(value);\n }\n // Handle MessagePort\n else if (typeof MessagePort !== \"undefined\" && value instanceof MessagePort) {\n transferables.push(value);\n }\n // Handle ArrayBuffer\n else if (value instanceof ArrayBuffer) {\n transferables.push(value);\n }\n // Recursively search arrays and objects\n else if (Array.isArray(value)) {\n value.forEach(findTransferables);\n } else if (value && typeof value === \"object\") {\n Object.values(value).forEach(findTransferables);\n }\n }\n\n findTransferables(obj);\n return transferables;\n}\n\n/**\n * WorkerServerBase is a class that handles messages from the main thread to the worker.\n * It is used to register functions that can be called from the main thread.\n * It also handles the transfer of transferables to the main thread.\n */\nexport class WorkerServerBase {\n constructor() {} // overridden in subclasses\n\n private functions: Record<string, (...args: any[]) => Promise<any>> = {};\n private streamFunctions: Record<string, (...args: any[]) => AsyncIterable<any>> = {};\n private reactiveFunctions: Record<string, (input: any, output: any, model: any) => Promise<any>> =\n {};\n\n // Keep track of each request's AbortController\n private requestControllers = new Map<string, AbortController>();\n // Keep track of requests that have already been responded to\n private completedRequests = new Set<string>();\n\n private postResult = (id: string, result: any) => {\n if (this.completedRequests.has(id)) {\n return; // Already responded to this request\n }\n this.completedRequests.add(id);\n const transferables = extractTransferables(result);\n const uniqueTransferables = [...new Set(transferables)];\n // @ts-ignore - Ignore type mismatch between standard Transferable and Bun.Transferable\n postMessage({ id, type: \"complete\", data: result }, uniqueTransferables);\n };\n\n private postError = (id: string, error: unknown) => {\n if (this.completedRequests.has(id)) {\n return; // Already responded to this request\n }\n this.completedRequests.add(id);\n let data: { message: string; name: string };\n if (typeof error === \"string\") {\n data = { message: error, name: \"Error\" };\n } else if (error instanceof Error) {\n data = { message: error.message, name: error.name };\n } else {\n data = { message: String(error), name: \"Error\" };\n }\n postMessage({ id, type: \"error\", data });\n };\n\n private postStreamChunk = (id: string, event: any) => {\n if (this.completedRequests.has(id)) {\n return;\n }\n postMessage({ id, type: \"stream_chunk\", data: event });\n };\n\n /**\n * Send the ready message to the main thread, advertising which functions are\n * registered in each category. Call this after all functions have been registered\n * so WorkerManager can skip unnecessary roundtrips for unregistered calls.\n */\n sendReady() {\n // @ts-ignore\n postMessage({\n type: \"ready\",\n functions: Object.keys(this.functions),\n streamFunctions: Object.keys(this.streamFunctions),\n reactiveFunctions: Object.keys(this.reactiveFunctions),\n });\n }\n\n registerFunction(name: string, fn: (...args: any[]) => Promise<any>) {\n this.functions[name] = fn;\n }\n\n /**\n * Register a reactive function for lightweight preview execution.\n * Reactive functions receive (input, output, model) and return a fast preview\n * without progress tracking or abort signals.\n *\n * @param name - The function name (e.g., task type identifier)\n * @param fn - Async function: (input, output, model) => Promise<output | undefined>\n */\n registerReactiveFunction(\n name: string,\n fn: (input: any, output: any, model: any) => Promise<any>\n ) {\n this.reactiveFunctions[name] = fn;\n }\n\n /**\n * Register an async generator function for streaming execution.\n * When called via the worker protocol with `stream: true`, the server\n * iterates the generator and sends each yielded value as a `stream_chunk`\n * message, followed by a `complete` message when the generator finishes.\n *\n * @param name - The function name (e.g., task type identifier)\n * @param fn - Async generator function: (input, model, signal) => AsyncIterable\n */\n registerStreamFunction(name: string, fn: (...args: any[]) => AsyncIterable<any>) {\n this.streamFunctions[name] = fn;\n }\n\n // Handle messages from the main thread\n async handleMessage(event: { type: string; data: any }) {\n const { id, type, functionName, args, stream, reactive } = event.data;\n if (type === \"abort\") {\n return await this.handleAbort(id);\n }\n if (type === \"call\") {\n if (stream) {\n return await this.handleStreamCall(id, functionName, args);\n }\n if (reactive) {\n return await this.handleReactiveCall(id, functionName, args);\n }\n return await this.handleCall(id, functionName, args);\n }\n }\n\n async handleAbort(id: string) {\n if (this.requestControllers.has(id)) {\n const controller = this.requestControllers.get(id);\n controller?.abort();\n this.requestControllers.delete(id);\n // Send error response back to main thread so the promise rejects\n this.postError(id, \"Operation aborted\");\n this.scheduleCompletedRequestCleanup(id);\n }\n }\n\n /**\n * Handle a reactive call. Returns undefined (non-error) if the reactive\n * function is not registered, since not all task types expose a reactive fn.\n */\n async handleReactiveCall(\n id: string,\n functionName: string,\n [input, output, model]: [any, any, any]\n ) {\n if (!(functionName in this.reactiveFunctions)) {\n this.postResult(id, undefined);\n return;\n }\n try {\n const fn = this.reactiveFunctions[functionName];\n const result = await fn(input, output, model);\n this.postResult(id, result);\n } catch (error) {\n this.postError(id, error);\n }\n }\n\n async handleCall(id: string, functionName: string, [input, model]: [any, any]) {\n if (!(functionName in this.functions)) {\n this.postError(id, `Function ${functionName} not found`);\n return;\n }\n\n try {\n const abortController = new AbortController();\n this.requestControllers.set(id, abortController);\n\n const fn = this.functions[functionName];\n const postProgress = (progress: number, message?: string, details?: any) => {\n // Don't send progress updates after the request is completed/aborted\n if (!this.completedRequests.has(id)) {\n postMessage({ id, type: \"progress\", data: { progress, message, details } });\n }\n };\n const result = await fn(input, model, postProgress, abortController.signal);\n this.postResult(id, result);\n } catch (error) {\n this.postError(id, error);\n } finally {\n this.requestControllers.delete(id);\n this.scheduleCompletedRequestCleanup(id);\n }\n }\n\n /**\n * Handle a streaming call. If a stream function is registered for the given name,\n * iterate it and send each yielded event as a `stream_chunk` message. If only a\n * regular function is registered, run it and wrap the result as a single `finish`\n * stream event (graceful fallback for providers that don't implement streaming).\n */\n async handleStreamCall(id: string, functionName: string, [input, model]: [any, any]) {\n if (functionName in this.streamFunctions) {\n try {\n const abortController = new AbortController();\n this.requestControllers.set(id, abortController);\n\n const fn = this.streamFunctions[functionName];\n const iterable = fn(input, model, abortController.signal);\n\n for await (const event of iterable) {\n if (this.completedRequests.has(id)) break;\n this.postStreamChunk(id, event);\n }\n\n this.postResult(id, undefined);\n } catch (error) {\n this.postError(id, error);\n } finally {\n this.requestControllers.delete(id);\n this.scheduleCompletedRequestCleanup(id);\n }\n } else if (functionName in this.functions) {\n // Fallback: run regular function and wrap result as a finish stream event\n try {\n const abortController = new AbortController();\n this.requestControllers.set(id, abortController);\n\n const fn = this.functions[functionName];\n const noopProgress = () => {};\n const result = await fn(input, model, noopProgress, abortController.signal);\n\n this.postStreamChunk(id, { type: \"finish\", data: result });\n this.postResult(id, undefined);\n } catch (error) {\n this.postError(id, error);\n } finally {\n this.requestControllers.delete(id);\n this.scheduleCompletedRequestCleanup(id);\n }\n } else {\n this.postError(id, `Function ${functionName} not found`);\n }\n }\n\n /**\n * Schedule cleanup of a completed request ID. Uses a 5-second delay to\n * handle late-arriving abort messages, and caps the completed set size\n * to prevent unbounded growth.\n */\n private scheduleCompletedRequestCleanup(id: string): void {\n setTimeout(() => {\n this.completedRequests.delete(id);\n }, 5000);\n\n // Safety cap: if the set grows too large, clear the oldest entries\n if (this.completedRequests.size > 10000) {\n const iter = this.completedRequests.values();\n for (let i = 0; i < 5000; i++) {\n const entry = iter.next();\n if (entry.done) break;\n this.completedRequests.delete(entry.value);\n }\n }\n }\n}\n",
12
- "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { createServiceToken, globalServiceRegistry } from \"../di\";\nimport { getLogger } from \"../logging\";\n\nexport class WorkerManager {\n private workers: Map<string, Worker> = new Map();\n private readyWorkers: Map<string, Promise<void>> = new Map();\n /** Function names registered on each worker, populated from the ready message. */\n private workerFunctions: Map<string, Set<string>> = new Map();\n private workerStreamFunctions: Map<string, Set<string>> = new Map();\n private workerReactiveFunctions: Map<string, Set<string>> = new Map();\n /** Pending lazy factories (worker not yet constructed). */\n private lazyFactories: Map<string, () => Worker> = new Map();\n /** Single-flight init promise per name (lazy path). */\n private lazyInitPromises: Map<string, Promise<void>> = new Map();\n\n registerWorker(name: string, workerOrFactory: Worker | (() => Worker)): void {\n if (this.workers.has(name)) {\n throw new Error(`Worker ${name} is already registered.`);\n }\n if (this.lazyFactories.has(name)) {\n throw new Error(`Worker ${name} is already registered.`);\n }\n if (typeof workerOrFactory === \"function\") {\n this.lazyFactories.set(name, workerOrFactory);\n } else {\n this.attachWorkerInstance(name, workerOrFactory);\n }\n }\n\n private attachWorkerInstance(name: string, worker: Worker): void {\n this.workers.set(name, worker);\n worker.addEventListener(\"error\", (event) => {\n console.error(\"Worker Error:\", event.message, \"at\", event.filename, \"line:\", event.lineno);\n });\n worker.addEventListener(\"messageerror\", (event) => {\n console.error(\"Worker message error:\", event);\n });\n\n const readyPromise = new Promise<void>((resolve, reject) => {\n const timeout = setTimeout(() => {\n worker.removeEventListener(\"message\", handleReady);\n worker.removeEventListener(\"error\", handleError);\n reject(new Error(`Worker \"${name}\" did not become ready within 10s`));\n }, 10_000);\n\n const handleError = (event: ErrorEvent) => {\n clearTimeout(timeout);\n worker.removeEventListener(\"message\", handleReady);\n worker.removeEventListener(\"error\", handleError);\n reject(\n new Error(\n `Worker \"${name}\" initialization error: ${event.message ?? \"unknown error\"}`\n )\n );\n };\n\n const handleReady = (event: MessageEvent) => {\n if (event.data?.type === \"ready\") {\n clearTimeout(timeout);\n worker.removeEventListener(\"message\", handleReady);\n worker.removeEventListener(\"error\", handleError);\n this.workerFunctions.set(name, new Set(event.data.functions ?? []));\n this.workerStreamFunctions.set(name, new Set(event.data.streamFunctions ?? []));\n this.workerReactiveFunctions.set(name, new Set(event.data.reactiveFunctions ?? []));\n resolve();\n }\n };\n\n worker.addEventListener(\"message\", handleReady);\n worker.addEventListener(\"error\", handleError);\n });\n\n this.readyWorkers.set(name, readyPromise);\n }\n\n /**\n * Ensures a lazy worker is constructed and ready. No-op if already\n * registered eagerly.\n */\n private async ensureWorkerReady(name: string): Promise<void> {\n if (this.workers.has(name)) {\n await this.readyWorkers.get(name)!;\n return;\n }\n const factory = this.lazyFactories.get(name);\n if (!factory) {\n throw new Error(`Worker ${name} not found.`);\n }\n let init = this.lazyInitPromises.get(name);\n if (!init) {\n init = (async () => {\n const f = this.lazyFactories.get(name)!;\n this.lazyFactories.delete(name);\n const worker = f();\n this.attachWorkerInstance(name, worker);\n })();\n this.lazyInitPromises.set(name, init);\n }\n await init;\n await this.readyWorkers.get(name)!;\n this.lazyInitPromises.delete(name);\n }\n\n getWorker(name: string): Worker {\n const worker = this.workers.get(name);\n if (!worker) throw new Error(`Worker ${name} not found.`);\n return worker;\n }\n\n async callWorkerFunction<T>(\n workerName: string,\n functionName: string,\n args: any[],\n options?: {\n signal?: AbortSignal;\n onProgress?: (progress: number, message?: string, details?: any) => void;\n }\n ): Promise<T> {\n await this.ensureWorkerReady(workerName);\n const worker = this.workers.get(workerName);\n if (!worker) throw new Error(`Worker ${workerName} not found.`);\n await this.readyWorkers.get(workerName);\n\n const knownFunctions = this.workerFunctions.get(workerName);\n if (knownFunctions && !knownFunctions.has(functionName)) {\n throw new Error(`Function \"${functionName}\" is not registered on worker \"${workerName}\".`);\n }\n\n return new Promise((resolve, reject) => {\n const requestId = crypto.randomUUID();\n\n const handleMessage = (event: MessageEvent) => {\n const { id, type, data } = event.data;\n if (id !== requestId) return;\n if (type === \"progress\" && options?.onProgress) {\n options.onProgress(data.progress, data.message, data.details);\n getLogger().debug(\n `Worker ${workerName} function ${functionName} progress: ${data.progress}, `,\n { data }\n );\n } else if (type === \"complete\") {\n cleanup();\n getLogger().debug(`Worker ${workerName} function ${functionName} complete.`, { data });\n resolve(data);\n } else if (type === \"error\") {\n cleanup();\n getLogger().debug(`Worker ${workerName} function ${functionName} error.`, { data });\n const err =\n typeof data === \"object\" && data !== null\n ? Object.assign(new Error(data.message ?? String(data)), {\n name: data.name ?? \"Error\",\n })\n : new Error(String(data));\n reject(err);\n }\n };\n\n const handleAbort = () => {\n worker.postMessage({ id: requestId, type: \"abort\" });\n getLogger().info(`Worker ${workerName} function ${functionName} aborted.`);\n };\n\n const cleanup = () => {\n worker.removeEventListener(\"message\", handleMessage);\n options?.signal?.removeEventListener(\"abort\", handleAbort);\n };\n\n worker.addEventListener(\"message\", handleMessage);\n\n if (options?.signal) {\n options.signal.addEventListener(\"abort\", handleAbort, { once: true });\n }\n\n // Note: We intentionally do NOT transfer TypedArrays from the main thread to the worker.\n // Transferring detaches the buffers on the main thread, which breaks downstream tasks\n // that still need those TypedArrays (e.g., the embedding vectors flowing through the\n // task graph). Workers send results back with transferables (zero-copy), but the\n // main thread always clones data going to workers to preserve its own references.\n const message = { id: requestId, type: \"call\", functionName, args };\n worker.postMessage(message);\n getLogger().info(`Worker ${workerName} function ${functionName} called.`);\n });\n }\n\n /**\n * Call a reactive function on a worker. Returns undefined (rather than throwing)\n * if the worker has no reactive function registered for the given name, so callers\n * can treat the result as an optional preview.\n *\n * @param workerName - Registered worker name\n * @param functionName - Name of the reactive function registered on the worker\n * @param args - Arguments to pass: [input, output, model]\n * @returns The reactive result, or undefined if not registered / on error\n */\n async callWorkerReactiveFunction<T>(\n workerName: string,\n functionName: string,\n args: any[]\n ): Promise<T | undefined> {\n await this.ensureWorkerReady(workerName);\n const worker = this.workers.get(workerName);\n if (!worker) return undefined;\n await this.readyWorkers.get(workerName);\n\n // Skip the roundtrip if the worker didn't register a reactive function for this name.\n const knownReactive = this.workerReactiveFunctions.get(workerName);\n if (knownReactive && !knownReactive.has(functionName)) return undefined;\n\n return new Promise((resolve) => {\n const requestId = crypto.randomUUID();\n\n const handleMessage = (event: MessageEvent) => {\n const { id, type, data } = event.data;\n if (id !== requestId) return;\n if (type === \"complete\") {\n cleanup();\n resolve(data as T | undefined);\n } else if (type === \"error\") {\n cleanup();\n resolve(undefined);\n }\n };\n\n const cleanup = () => {\n worker.removeEventListener(\"message\", handleMessage);\n };\n\n worker.addEventListener(\"message\", handleMessage);\n\n const message = { id: requestId, type: \"call\", functionName, args, reactive: true };\n // Note: No transferables — same reasoning as callWorkerFunction above.\n worker.postMessage(message);\n getLogger().info(`Worker ${workerName} reactive function ${functionName} called.`);\n });\n }\n\n /**\n * Call a streaming function on a worker and return an AsyncGenerator that\n * yields each stream chunk sent by the worker. The worker sends `stream_chunk`\n * messages for each yielded event and a `complete` message when the generator\n * finishes. An `error` message from the worker causes the iterator to throw.\n *\n * @param workerName - Registered worker name\n * @param functionName - Name of the stream function registered on the worker\n * @param args - Arguments to pass to the stream function\n * @param options - Optional abort signal\n * @returns AsyncGenerator yielding stream events from the worker\n */\n async *callWorkerStreamFunction<T>(\n workerName: string,\n functionName: string,\n args: any[],\n options?: { signal?: AbortSignal }\n ): AsyncGenerator<T> {\n await this.ensureWorkerReady(workerName);\n const worker = this.workers.get(workerName);\n if (!worker) throw new Error(`Worker ${workerName} not found.`);\n await this.readyWorkers.get(workerName);\n\n // The worker falls back to regular functions for stream calls, so either counts.\n const knownStream = this.workerStreamFunctions.get(workerName);\n const knownFns = this.workerFunctions.get(workerName);\n if (knownStream && knownFns && !knownStream.has(functionName) && !knownFns.has(functionName)) {\n throw new Error(`Function \"${functionName}\" is not registered on worker \"${workerName}\".`);\n }\n\n const requestId = crypto.randomUUID();\n\n // Push-queue pattern: messages push items, async generator pulls them\n type QueueItem =\n | { kind: \"event\"; data: T }\n | { kind: \"done\" }\n | { kind: \"error\"; error: Error };\n\n const queue: QueueItem[] = [];\n let waiting: ((value: void) => void) | null = null;\n\n const notify = () => {\n if (waiting) {\n const resolve = waiting;\n waiting = null;\n resolve();\n }\n };\n\n const handleMessage = (event: MessageEvent) => {\n const { id, type, data } = event.data;\n if (id !== requestId) return;\n\n if (type === \"stream_chunk\") {\n queue.push({ kind: \"event\", data });\n notify();\n } else if (type === \"complete\") {\n queue.push({ kind: \"done\" });\n notify();\n } else if (type === \"error\") {\n queue.push({ kind: \"error\", error: new Error(data) });\n notify();\n }\n };\n\n const handleAbort = () => {\n worker.postMessage({ id: requestId, type: \"abort\" });\n getLogger().info(`Worker ${workerName} stream function ${functionName} aborted.`);\n };\n\n const cleanup = () => {\n worker.removeEventListener(\"message\", handleMessage);\n options?.signal?.removeEventListener(\"abort\", handleAbort);\n };\n\n worker.addEventListener(\"message\", handleMessage);\n\n if (options?.signal) {\n if (options.signal.aborted) {\n cleanup();\n throw new Error(\"Operation aborted\");\n }\n options.signal.addEventListener(\"abort\", handleAbort, { once: true });\n }\n\n // Send call message with stream flag\n // Note: No transferables — same reasoning as callWorkerFunction above.\n const message = { id: requestId, type: \"call\", functionName, args, stream: true };\n worker.postMessage(message);\n getLogger().info(`Worker ${workerName} stream function ${functionName} called.`);\n\n let completedNormally = false;\n try {\n while (true) {\n while (queue.length > 0) {\n const item = queue.shift()!;\n if (item.kind === \"event\") {\n yield item.data;\n } else if (item.kind === \"done\") {\n completedNormally = true;\n return;\n } else if (item.kind === \"error\") {\n completedNormally = true;\n throw item.error;\n }\n }\n\n // Wait for the next message to arrive\n await new Promise<void>((resolve) => {\n waiting = resolve;\n });\n }\n } finally {\n // If the consumer stopped iterating early (break/return), notify\n // the worker to abort so it doesn't continue generating tokens.\n if (!completedNormally) {\n worker.postMessage({ id: requestId, type: \"abort\" });\n getLogger().info(`Worker ${workerName} stream function ${functionName} aborted.`);\n }\n cleanup();\n }\n }\n}\n\nexport const WORKER_MANAGER = createServiceToken<WorkerManager>(\"worker.manager\");\n\nglobalServiceRegistry.register(WORKER_MANAGER, () => new WorkerManager(), true);\n",
11
+ "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { createServiceToken, globalServiceRegistry } from \"../di/ServiceRegistry\";\nimport type { LogLevel } from \"./ConsoleLogger\";\nimport { ConsoleLogger } from \"./ConsoleLogger\";\nimport type { ILogger } from \"./ILogger\";\nimport { NullLogger } from \"./NullLogger\";\n\n/**\n * Service token for the global logger instance.\n */\nexport const LOGGER = createServiceToken<ILogger>(\"logger\");\n\nconst VALID_LOG_LEVELS: ReadonlySet<string> = new Set<string>([\n \"debug\",\n \"info\",\n \"warn\",\n \"error\",\n \"fatal\",\n]);\n\nfunction getEnv(name: string): string | undefined {\n if (typeof process !== \"undefined\" && process.env) {\n return process.env[name];\n }\n return import.meta.env[name];\n}\n\nfunction isTruthy(value: string | undefined): boolean {\n return value !== undefined && value !== \"\" && value !== \"0\" && value !== \"false\";\n}\n\nfunction createDefaultLogger(): ILogger {\n const levelEnv = getEnv(\"LOGGER_LEVEL\")?.toLowerCase();\n if (levelEnv && VALID_LOG_LEVELS.has(levelEnv)) {\n return new ConsoleLogger({\n level: levelEnv as LogLevel,\n timings: isTruthy(getEnv(\"LOGGER_TIMINGS\")),\n });\n }\n if (getEnv(\"DEV\")) {\n return new ConsoleLogger({\n level: \"debug\" as LogLevel,\n timings: true,\n });\n }\n return new NullLogger();\n}\n\n// Register default logger: NullLogger unless LOGGER_LEVEL env var is set.\nglobalServiceRegistry.registerIfAbsent(LOGGER, createDefaultLogger, true);\n\n/**\n * Returns the current global logger.\n */\nexport function getLogger(): ILogger {\n return globalServiceRegistry.get(LOGGER);\n}\n\n/**\n * Replaces the global logger instance.\n */\nexport function setLogger(logger: ILogger): void {\n globalServiceRegistry.registerInstance(LOGGER, logger);\n}\n",
12
+ "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { createServiceToken } from \"../di\";\n\n/** Service token for the platform-specific WorkerServer instance. */\nexport const WORKER_SERVER = createServiceToken<WorkerServerBase>(\"worker.server\");\n\n/**\n * Extracts transferables from an object.\n * @param obj - The object to extract transferables from.\n * @returns An array of transferables.\n */\nfunction extractTransferables(obj: any) {\n const transferables: Transferable[] = [];\n const seen = new WeakSet();\n\n function findTransferables(value: any) {\n // Avoid infinite recursion\n if (value && typeof value === \"object\" && seen.has(value)) {\n return;\n }\n if (value && typeof value === \"object\") {\n seen.add(value);\n }\n\n // Handle TypedArrays\n if (value instanceof Float32Array || value instanceof Int16Array) {\n transferables.push(value.buffer);\n }\n // Handle other TypedArrays\n else if (\n value instanceof Uint8Array ||\n value instanceof Uint8ClampedArray ||\n value instanceof Int8Array ||\n value instanceof Uint16Array ||\n value instanceof Int32Array ||\n value instanceof Uint32Array ||\n value instanceof Float64Array ||\n value instanceof BigInt64Array ||\n value instanceof BigUint64Array\n ) {\n transferables.push(value.buffer);\n }\n // Handle OffscreenCanvas\n else if (typeof OffscreenCanvas !== \"undefined\" && value instanceof OffscreenCanvas) {\n transferables.push(value);\n }\n // Handle ImageBitmap\n else if (typeof ImageBitmap !== \"undefined\" && value instanceof ImageBitmap) {\n transferables.push(value);\n }\n // Handle VideoFrame\n else if (typeof VideoFrame !== \"undefined\" && value instanceof VideoFrame) {\n transferables.push(value);\n }\n // Handle MessagePort\n else if (typeof MessagePort !== \"undefined\" && value instanceof MessagePort) {\n transferables.push(value);\n }\n // Handle ArrayBuffer\n else if (value instanceof ArrayBuffer) {\n transferables.push(value);\n }\n // Recursively search arrays and objects\n else if (Array.isArray(value)) {\n value.forEach(findTransferables);\n } else if (value && typeof value === \"object\") {\n Object.values(value).forEach(findTransferables);\n }\n }\n\n findTransferables(obj);\n return transferables;\n}\n\n/**\n * WorkerServerBase is a class that handles messages from the main thread to the worker.\n * It is used to register functions that can be called from the main thread.\n * It also handles the transfer of transferables to the main thread.\n */\nexport class WorkerServerBase {\n constructor() {} // overridden in subclasses\n\n private functions: Record<string, (...args: any[]) => Promise<any>> = {};\n private streamFunctions: Record<string, (...args: any[]) => AsyncIterable<any>> = {};\n private reactiveFunctions: Record<string, (input: any, output: any, model: any) => Promise<any>> =\n {};\n\n // Keep track of each request's AbortController\n private requestControllers = new Map<string, AbortController>();\n // Keep track of requests that have already been responded to\n private completedRequests = new Set<string>();\n\n private postResult = (id: string, result: any) => {\n if (this.completedRequests.has(id)) {\n return; // Already responded to this request\n }\n this.completedRequests.add(id);\n const transferables = extractTransferables(result);\n const uniqueTransferables = [...new Set(transferables)];\n // @ts-ignore - Ignore type mismatch between standard Transferable and Bun.Transferable\n postMessage({ id, type: \"complete\", data: result }, uniqueTransferables);\n };\n\n private postError = (id: string, error: unknown) => {\n if (this.completedRequests.has(id)) {\n return; // Already responded to this request\n }\n this.completedRequests.add(id);\n let data: { message: string; name: string };\n if (typeof error === \"string\") {\n data = { message: error, name: \"Error\" };\n } else if (error instanceof Error) {\n data = { message: error.message, name: error.name };\n } else {\n data = { message: String(error), name: \"Error\" };\n }\n postMessage({ id, type: \"error\", data });\n };\n\n private postStreamChunk = (id: string, event: any) => {\n if (this.completedRequests.has(id)) {\n return;\n }\n postMessage({ id, type: \"stream_chunk\", data: event });\n };\n\n /**\n * Send the ready message to the main thread, advertising which functions are\n * registered in each category. Call this after all functions have been registered\n * so WorkerManager can skip unnecessary roundtrips for unregistered calls.\n */\n sendReady() {\n // @ts-ignore\n postMessage({\n type: \"ready\",\n functions: Object.keys(this.functions),\n streamFunctions: Object.keys(this.streamFunctions),\n reactiveFunctions: Object.keys(this.reactiveFunctions),\n });\n }\n\n registerFunction(name: string, fn: (...args: any[]) => Promise<any>) {\n this.functions[name] = fn;\n }\n\n /**\n * Register a reactive function for lightweight preview execution.\n * Reactive functions receive (input, output, model) and return a fast preview\n * without progress tracking or abort signals.\n *\n * @param name - The function name (e.g., task type identifier)\n * @param fn - Async function: (input, output, model) => Promise<output | undefined>\n */\n registerReactiveFunction(\n name: string,\n fn: (input: any, output: any, model: any) => Promise<any>\n ) {\n this.reactiveFunctions[name] = fn;\n }\n\n /**\n * Register an async generator function for streaming execution.\n * When called via the worker protocol with `stream: true`, the server\n * iterates the generator and sends each yielded value as a `stream_chunk`\n * message, followed by a `complete` message when the generator finishes.\n *\n * @param name - The function name (e.g., task type identifier)\n * @param fn - Async generator function: (input, model, signal) => AsyncIterable\n */\n registerStreamFunction(name: string, fn: (...args: any[]) => AsyncIterable<any>) {\n this.streamFunctions[name] = fn;\n }\n\n // Handle messages from the main thread\n async handleMessage(event: { type: string; data: any }) {\n const { id, type, functionName, args, stream, reactive } = event.data;\n if (type === \"abort\") {\n return await this.handleAbort(id);\n }\n if (type === \"call\") {\n if (stream) {\n return await this.handleStreamCall(id, functionName, args);\n }\n if (reactive) {\n return await this.handleReactiveCall(id, functionName, args);\n }\n return await this.handleCall(id, functionName, args);\n }\n }\n\n async handleAbort(id: string) {\n if (this.requestControllers.has(id)) {\n const controller = this.requestControllers.get(id);\n controller?.abort();\n this.requestControllers.delete(id);\n // Send error response back to main thread so the promise rejects\n this.postError(id, \"Operation aborted\");\n this.scheduleCompletedRequestCleanup(id);\n }\n }\n\n /**\n * Handle a reactive call. Returns undefined (non-error) if the reactive\n * function is not registered, since not all task types expose a reactive fn.\n */\n async handleReactiveCall(\n id: string,\n functionName: string,\n [input, output, model]: [any, any, any]\n ) {\n if (!(functionName in this.reactiveFunctions)) {\n this.postResult(id, undefined);\n return;\n }\n try {\n const fn = this.reactiveFunctions[functionName];\n const result = await fn(input, output, model);\n this.postResult(id, result);\n } catch (error) {\n this.postError(id, error);\n }\n }\n\n async handleCall(id: string, functionName: string, [input, model]: [any, any]) {\n if (!(functionName in this.functions)) {\n this.postError(id, `Function ${functionName} not found`);\n return;\n }\n\n try {\n const abortController = new AbortController();\n this.requestControllers.set(id, abortController);\n\n const fn = this.functions[functionName];\n const postProgress = (progress: number, message?: string, details?: any) => {\n // Don't send progress updates after the request is completed/aborted\n if (!this.completedRequests.has(id)) {\n postMessage({ id, type: \"progress\", data: { progress, message, details } });\n }\n };\n const result = await fn(input, model, postProgress, abortController.signal);\n this.postResult(id, result);\n } catch (error) {\n this.postError(id, error);\n } finally {\n this.requestControllers.delete(id);\n this.scheduleCompletedRequestCleanup(id);\n }\n }\n\n /**\n * Handle a streaming call. If a stream function is registered for the given name,\n * iterate it and send each yielded event as a `stream_chunk` message. If only a\n * regular function is registered, run it and wrap the result as a single `finish`\n * stream event (graceful fallback for providers that don't implement streaming).\n */\n async handleStreamCall(id: string, functionName: string, [input, model]: [any, any]) {\n if (functionName in this.streamFunctions) {\n try {\n const abortController = new AbortController();\n this.requestControllers.set(id, abortController);\n\n const fn = this.streamFunctions[functionName];\n const iterable = fn(input, model, abortController.signal);\n\n for await (const event of iterable) {\n if (this.completedRequests.has(id)) break;\n this.postStreamChunk(id, event);\n }\n\n this.postResult(id, undefined);\n } catch (error) {\n this.postError(id, error);\n } finally {\n this.requestControllers.delete(id);\n this.scheduleCompletedRequestCleanup(id);\n }\n } else if (functionName in this.functions) {\n // Fallback: run regular function and wrap result as a finish stream event\n try {\n const abortController = new AbortController();\n this.requestControllers.set(id, abortController);\n\n const fn = this.functions[functionName];\n const noopProgress = () => {};\n const result = await fn(input, model, noopProgress, abortController.signal);\n\n this.postStreamChunk(id, { type: \"finish\", data: result });\n this.postResult(id, undefined);\n } catch (error) {\n this.postError(id, error);\n } finally {\n this.requestControllers.delete(id);\n this.scheduleCompletedRequestCleanup(id);\n }\n } else {\n this.postError(id, `Function ${functionName} not found`);\n }\n }\n\n /**\n * Schedule cleanup of a completed request ID. Uses a 5-second delay to\n * handle late-arriving abort messages, and caps the completed set size\n * to prevent unbounded growth.\n */\n private scheduleCompletedRequestCleanup(id: string): void {\n setTimeout(() => {\n this.completedRequests.delete(id);\n }, 5000);\n\n // Safety cap: if the set grows too large, clear the oldest entries\n if (this.completedRequests.size > 1000) {\n const iter = this.completedRequests.values();\n for (let i = 0; i < 500; i++) {\n const entry = iter.next();\n if (entry.done) break;\n this.completedRequests.delete(entry.value);\n }\n }\n }\n}\n",
13
+ "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { createServiceToken, globalServiceRegistry } from \"../di\";\nimport { getLogger } from \"../logging\";\n\nexport class WorkerManager {\n private workers: Map<string, Worker> = new Map();\n private readyWorkers: Map<string, Promise<void>> = new Map();\n /** Function names registered on each worker, populated from the ready message. */\n private workerFunctions: Map<string, Set<string>> = new Map();\n private workerStreamFunctions: Map<string, Set<string>> = new Map();\n private workerReactiveFunctions: Map<string, Set<string>> = new Map();\n /** Pending lazy factories (worker not yet constructed). */\n private lazyFactories: Map<string, () => Worker> = new Map();\n /** Single-flight init promise per name (lazy path). */\n private lazyInitPromises: Map<string, Promise<void>> = new Map();\n\n registerWorker(name: string, workerOrFactory: Worker | (() => Worker)): void {\n if (this.workers.has(name)) {\n throw new Error(`Worker ${name} is already registered.`);\n }\n if (this.lazyFactories.has(name)) {\n throw new Error(`Worker ${name} is already registered.`);\n }\n if (typeof workerOrFactory === \"function\") {\n this.lazyFactories.set(name, workerOrFactory);\n } else {\n this.attachWorkerInstance(name, workerOrFactory);\n }\n }\n\n private attachWorkerInstance(name: string, worker: Worker): void {\n this.workers.set(name, worker);\n worker.addEventListener(\"error\", (event) => {\n console.error(\"Worker Error:\", event.message, \"at\", event.filename, \"line:\", event.lineno);\n });\n worker.addEventListener(\"messageerror\", (event) => {\n console.error(\"Worker message error:\", event);\n });\n\n const readyPromise = new Promise<void>((resolve, reject) => {\n const timeout = setTimeout(() => {\n worker.removeEventListener(\"message\", handleReady);\n worker.removeEventListener(\"error\", handleError);\n reject(new Error(`Worker \"${name}\" did not become ready within 10s`));\n }, 10_000);\n\n const handleError = (event: ErrorEvent) => {\n clearTimeout(timeout);\n worker.removeEventListener(\"message\", handleReady);\n worker.removeEventListener(\"error\", handleError);\n reject(\n new Error(`Worker \"${name}\" initialization error: ${event.message ?? \"unknown error\"}`)\n );\n };\n\n const handleReady = (event: MessageEvent) => {\n if (event.data?.type === \"ready\") {\n clearTimeout(timeout);\n worker.removeEventListener(\"message\", handleReady);\n worker.removeEventListener(\"error\", handleError);\n this.workerFunctions.set(name, new Set(event.data.functions ?? []));\n this.workerStreamFunctions.set(name, new Set(event.data.streamFunctions ?? []));\n this.workerReactiveFunctions.set(name, new Set(event.data.reactiveFunctions ?? []));\n resolve();\n }\n };\n\n worker.addEventListener(\"message\", handleReady);\n worker.addEventListener(\"error\", handleError);\n });\n\n this.readyWorkers.set(name, readyPromise);\n }\n\n /**\n * Ensures a lazy worker is constructed and ready. No-op if already\n * registered eagerly.\n */\n private async ensureWorkerReady(name: string): Promise<void> {\n if (this.workers.has(name)) {\n await this.readyWorkers.get(name)!;\n return;\n }\n const factory = this.lazyFactories.get(name);\n if (!factory) {\n throw new Error(`Worker ${name} not found.`);\n }\n let init = this.lazyInitPromises.get(name);\n if (!init) {\n init = (async () => {\n try {\n const f = this.lazyFactories.get(name)!;\n this.lazyFactories.delete(name);\n const worker = f();\n this.attachWorkerInstance(name, worker);\n await this.readyWorkers.get(name)!;\n } finally {\n this.lazyInitPromises.delete(name);\n }\n })();\n this.lazyInitPromises.set(name, init);\n }\n await init;\n }\n\n getWorker(name: string): Worker {\n const worker = this.workers.get(name);\n if (!worker) throw new Error(`Worker ${name} not found.`);\n return worker;\n }\n\n async callWorkerFunction<T>(\n workerName: string,\n functionName: string,\n args: any[],\n options?: {\n signal?: AbortSignal;\n onProgress?: (progress: number, message?: string, details?: any) => void;\n }\n ): Promise<T> {\n await this.ensureWorkerReady(workerName);\n const worker = this.workers.get(workerName);\n if (!worker) throw new Error(`Worker ${workerName} not found.`);\n\n const knownFunctions = this.workerFunctions.get(workerName);\n if (knownFunctions && !knownFunctions.has(functionName)) {\n throw new Error(`Function \"${functionName}\" is not registered on worker \"${workerName}\".`);\n }\n\n return new Promise((resolve, reject) => {\n const requestId = crypto.randomUUID();\n\n const handleMessage = (event: MessageEvent) => {\n const { id, type, data } = event.data;\n if (id !== requestId) return;\n if (type === \"progress\" && options?.onProgress) {\n options.onProgress(data.progress, data.message, data.details);\n getLogger().debug(\n `Worker ${workerName} function ${functionName} progress: ${data.progress}, `,\n { data }\n );\n } else if (type === \"complete\") {\n cleanup();\n getLogger().debug(`Worker ${workerName} function ${functionName} complete.`, { data });\n resolve(data);\n } else if (type === \"error\") {\n cleanup();\n getLogger().debug(`Worker ${workerName} function ${functionName} error.`, { data });\n const err =\n typeof data === \"object\" && data !== null\n ? Object.assign(new Error(data.message ?? String(data)), {\n name: data.name ?? \"Error\",\n })\n : new Error(String(data));\n reject(err);\n }\n };\n\n const handleAbort = () => {\n worker.postMessage({ id: requestId, type: \"abort\" });\n getLogger().info(`Worker ${workerName} function ${functionName} aborted.`);\n };\n\n const cleanup = () => {\n worker.removeEventListener(\"message\", handleMessage);\n options?.signal?.removeEventListener(\"abort\", handleAbort);\n };\n\n worker.addEventListener(\"message\", handleMessage);\n\n if (options?.signal) {\n options.signal.addEventListener(\"abort\", handleAbort, { once: true });\n }\n\n // Note: We intentionally do NOT transfer TypedArrays from the main thread to the worker.\n // Transferring detaches the buffers on the main thread, which breaks downstream tasks\n // that still need those TypedArrays (e.g., the embedding vectors flowing through the\n // task graph). Workers send results back with transferables (zero-copy), but the\n // main thread always clones data going to workers to preserve its own references.\n const message = { id: requestId, type: \"call\", functionName, args };\n worker.postMessage(message);\n getLogger().info(`Worker ${workerName} function ${functionName} called.`);\n });\n }\n\n /**\n * Call a reactive function on a worker. Returns undefined (rather than throwing)\n * if the worker has no reactive function registered for the given name, so callers\n * can treat the result as an optional preview.\n *\n * @param workerName - Registered worker name\n * @param functionName - Name of the reactive function registered on the worker\n * @param args - Arguments to pass: [input, output, model]\n * @returns The reactive result, or undefined if not registered / on error\n */\n async callWorkerReactiveFunction<T>(\n workerName: string,\n functionName: string,\n args: any[]\n ): Promise<T | undefined> {\n await this.ensureWorkerReady(workerName);\n const worker = this.workers.get(workerName);\n if (!worker) return undefined;\n\n // Skip the roundtrip if the worker didn't register a reactive function for this name.\n const knownReactive = this.workerReactiveFunctions.get(workerName);\n if (knownReactive && !knownReactive.has(functionName)) return undefined;\n\n return new Promise((resolve) => {\n const requestId = crypto.randomUUID();\n\n const handleMessage = (event: MessageEvent) => {\n const { id, type, data } = event.data;\n if (id !== requestId) return;\n if (type === \"complete\") {\n cleanup();\n resolve(data as T | undefined);\n } else if (type === \"error\") {\n cleanup();\n getLogger().warn(`Worker ${workerName} reactive function ${functionName} error:`, {\n error: data,\n });\n resolve(undefined);\n }\n };\n\n const cleanup = () => {\n worker.removeEventListener(\"message\", handleMessage);\n };\n\n worker.addEventListener(\"message\", handleMessage);\n\n const message = { id: requestId, type: \"call\", functionName, args, reactive: true };\n // Note: No transferables — same reasoning as callWorkerFunction above.\n worker.postMessage(message);\n getLogger().info(`Worker ${workerName} reactive function ${functionName} called.`);\n });\n }\n\n /**\n * Terminate a single worker and clean up all associated state.\n */\n async terminateWorker(name: string): Promise<void> {\n const worker = this.workers.get(name);\n this.workers.delete(name);\n this.readyWorkers.delete(name);\n this.workerFunctions.delete(name);\n this.workerStreamFunctions.delete(name);\n this.workerReactiveFunctions.delete(name);\n this.lazyFactories.delete(name);\n this.lazyInitPromises.delete(name);\n try {\n if (worker && \"terminate\" in worker && typeof worker.terminate === \"function\") {\n await worker.terminate();\n }\n } catch {\n // Best-effort termination; state is already cleaned up above.\n }\n }\n\n /**\n * Terminate all workers and release resources.\n */\n async dispose(): Promise<void> {\n const names = [...this.workers.keys(), ...this.lazyFactories.keys()];\n for (const name of names) {\n await this.terminateWorker(name);\n }\n }\n\n async [Symbol.asyncDispose](): Promise<void> {\n await this.dispose();\n }\n\n /**\n * Call a streaming function on a worker and return an AsyncGenerator that\n * yields each stream chunk sent by the worker. The worker sends `stream_chunk`\n * messages for each yielded event and a `complete` message when the generator\n * finishes. An `error` message from the worker causes the iterator to throw.\n *\n * @param workerName - Registered worker name\n * @param functionName - Name of the stream function registered on the worker\n * @param args - Arguments to pass to the stream function\n * @param options - Optional abort signal\n * @returns AsyncGenerator yielding stream events from the worker\n */\n async *callWorkerStreamFunction<T>(\n workerName: string,\n functionName: string,\n args: any[],\n options?: { signal?: AbortSignal }\n ): AsyncGenerator<T> {\n await this.ensureWorkerReady(workerName);\n const worker = this.workers.get(workerName);\n if (!worker) throw new Error(`Worker ${workerName} not found.`);\n\n // The worker falls back to regular functions for stream calls, so either counts.\n const knownStream = this.workerStreamFunctions.get(workerName);\n const knownFns = this.workerFunctions.get(workerName);\n if (knownStream && knownFns && !knownStream.has(functionName) && !knownFns.has(functionName)) {\n throw new Error(`Function \"${functionName}\" is not registered on worker \"${workerName}\".`);\n }\n\n const requestId = crypto.randomUUID();\n\n // Push-queue pattern: messages push items, async generator pulls them\n type QueueItem =\n | { kind: \"event\"; data: T }\n | { kind: \"done\" }\n | { kind: \"error\"; error: Error };\n\n const queue: QueueItem[] = [];\n let waiting: ((value: void) => void) | null = null;\n\n const notify = () => {\n if (waiting) {\n const resolve = waiting;\n waiting = null;\n resolve();\n }\n };\n\n const handleMessage = (event: MessageEvent) => {\n const { id, type, data } = event.data;\n if (id !== requestId) return;\n\n if (type === \"stream_chunk\") {\n queue.push({ kind: \"event\", data });\n notify();\n } else if (type === \"complete\") {\n queue.push({ kind: \"done\" });\n notify();\n } else if (type === \"error\") {\n queue.push({ kind: \"error\", error: new Error(data) });\n notify();\n }\n };\n\n const handleAbort = () => {\n worker.postMessage({ id: requestId, type: \"abort\" });\n getLogger().info(`Worker ${workerName} stream function ${functionName} aborted.`);\n };\n\n const cleanup = () => {\n worker.removeEventListener(\"message\", handleMessage);\n options?.signal?.removeEventListener(\"abort\", handleAbort);\n };\n\n worker.addEventListener(\"message\", handleMessage);\n\n if (options?.signal) {\n if (options.signal.aborted) {\n cleanup();\n throw new Error(\"Operation aborted\");\n }\n options.signal.addEventListener(\"abort\", handleAbort, { once: true });\n }\n\n // Send call message with stream flag\n // Note: No transferables — same reasoning as callWorkerFunction above.\n const message = { id: requestId, type: \"call\", functionName, args, stream: true };\n worker.postMessage(message);\n getLogger().info(`Worker ${workerName} stream function ${functionName} called.`);\n\n let completedNormally = false;\n try {\n while (true) {\n while (queue.length > 0) {\n const item = queue.shift()!;\n if (item.kind === \"event\") {\n yield item.data;\n } else if (item.kind === \"done\") {\n completedNormally = true;\n return;\n } else if (item.kind === \"error\") {\n completedNormally = true;\n throw item.error;\n }\n }\n\n // Wait for the next message to arrive\n await new Promise<void>((resolve) => {\n waiting = resolve;\n });\n }\n } finally {\n // If the consumer stopped iterating early (break/return), notify\n // the worker to abort so it doesn't continue generating tokens.\n if (!completedNormally) {\n worker.postMessage({ id: requestId, type: \"abort\" });\n getLogger().info(`Worker ${workerName} stream function ${functionName} aborted.`);\n }\n cleanup();\n }\n }\n}\n\nexport const WORKER_MANAGER = createServiceToken<WorkerManager>(\"worker.manager\");\n\nglobalServiceRegistry.register(WORKER_MANAGER, () => new WorkerManager(), true);\n",
13
14
  "/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\n/**\n * Attempts to parse a potentially incomplete JSON string into a partial object.\n *\n * Useful for progressive rendering of streamed JSON output from AI providers.\n * Each call returns the most complete object that can be parsed from the\n * accumulated text so far.\n *\n * Strategy:\n * 1. Try JSON.parse directly (handles complete JSON)\n * 2. If that fails, attempt to close open delimiters and re-parse\n *\n * @param text - The (possibly incomplete) JSON string\n * @returns The parsed partial object, or undefined if text is too incomplete\n */\nexport function parsePartialJson(text: string): Record<string, unknown> | undefined {\n const trimmed = text.trim();\n if (!trimmed) return undefined;\n\n // Fast path: try parsing as-is\n try {\n const result = JSON.parse(trimmed);\n if (typeof result === \"object\" && result !== null && !Array.isArray(result)) {\n return result as Record<string, unknown>;\n }\n return undefined;\n } catch {\n // Fall through to repair logic\n }\n\n // Must start with '{' for an object\n if (trimmed[0] !== \"{\") return undefined;\n\n const repaired = repairJson(trimmed);\n if (repaired === undefined) return undefined;\n\n try {\n const result = JSON.parse(repaired);\n if (typeof result === \"object\" && result !== null && !Array.isArray(result)) {\n return result as Record<string, unknown>;\n }\n return undefined;\n } catch {\n return undefined;\n }\n}\n\n/**\n * Attempts to repair incomplete JSON by closing open structures.\n * Returns the repaired string, or undefined if the text is too malformed.\n */\nfunction repairJson(text: string): string | undefined {\n let result = \"\";\n let i = 0;\n const len = text.length;\n\n // Track open delimiters for closing\n const stack: string[] = [];\n let inString = false;\n let escaped = false;\n // Track position of last structurally complete point\n let lastSafeEnd = 0;\n\n while (i < len) {\n const ch = text[i];\n\n if (escaped) {\n escaped = false;\n result += ch;\n i++;\n continue;\n }\n\n if (ch === \"\\\\\") {\n escaped = true;\n result += ch;\n i++;\n continue;\n }\n\n if (inString) {\n if (ch === '\"') {\n inString = false;\n result += ch;\n i++;\n lastSafeEnd = result.length;\n continue;\n }\n result += ch;\n i++;\n continue;\n }\n\n // Not in a string\n switch (ch) {\n case '\"':\n inString = true;\n result += ch;\n i++;\n break;\n case \"{\":\n stack.push(\"}\");\n result += ch;\n i++;\n break;\n case \"[\":\n stack.push(\"]\");\n result += ch;\n i++;\n break;\n case \"}\":\n if (stack.length > 0 && stack[stack.length - 1] === \"}\") {\n stack.pop();\n result += ch;\n i++;\n lastSafeEnd = result.length;\n } else {\n // Mismatched brace, truncate here\n return closeStack(result, stack);\n }\n break;\n case \"]\":\n if (stack.length > 0 && stack[stack.length - 1] === \"]\") {\n stack.pop();\n result += ch;\n i++;\n lastSafeEnd = result.length;\n } else {\n return closeStack(result, stack);\n }\n break;\n default:\n result += ch;\n i++;\n break;\n }\n }\n\n // Reached the end with unclosed structures\n if (inString) {\n // Close the unclosed string, then close the stack\n result += '\"';\n }\n\n if (stack.length === 0) {\n // Already valid\n return result;\n }\n\n return closeStack(cleanTrailing(result), stack);\n}\n\n/**\n * Removes trailing incomplete tokens that would prevent JSON parsing.\n * Strips trailing commas, colons, and incomplete key/value fragments.\n */\nfunction cleanTrailing(text: string): string {\n // Remove trailing whitespace\n let s = text.trimEnd();\n\n // Repeatedly strip trailing problematic characters\n let changed = true;\n while (changed) {\n changed = false;\n const trimmed = s.trimEnd();\n\n // Trailing comma\n if (trimmed.endsWith(\",\")) {\n s = trimmed.slice(0, -1);\n changed = true;\n continue;\n }\n\n // Trailing colon (incomplete key-value pair)\n if (trimmed.endsWith(\":\")) {\n // Remove the colon and the preceding key\n const withoutColon = trimmed.slice(0, -1).trimEnd();\n // Remove the key (should be a string ending with \")\n if (withoutColon.endsWith('\"')) {\n const keyStart = withoutColon.lastIndexOf('\"', withoutColon.length - 2);\n if (keyStart >= 0) {\n // Also remove any preceding comma\n let before = withoutColon.slice(0, keyStart).trimEnd();\n if (before.endsWith(\",\")) {\n before = before.slice(0, -1);\n }\n s = before;\n changed = true;\n continue;\n }\n }\n // Can't find the key, just remove the colon\n s = withoutColon;\n changed = true;\n continue;\n }\n\n // Trailing incomplete value after a colon (e.g., `\"key\": tru` or `\"key\": 12`)\n // Check if there's an incomplete bare token at the end\n const bareTokenMatch = trimmed.match(\n /,\\s*\"[^\"]*\"\\s*:\\s*(?:tru|fal|nul|true|false|null|[\\d.eE+-]+)$/\n );\n if (bareTokenMatch) {\n // Check if the bare value is complete\n const valueStr = trimmed.slice(trimmed.lastIndexOf(\":\") + 1).trim();\n try {\n JSON.parse(valueStr);\n // Value is complete, keep it\n } catch {\n // Value is incomplete, remove the whole key-value pair\n s = trimmed.slice(0, bareTokenMatch.index!).trimEnd();\n if (s.endsWith(\",\")) s = s.slice(0, -1);\n changed = true;\n continue;\n }\n }\n }\n\n return s;\n}\n\n/**\n * Closes all open delimiters in the stack.\n */\nfunction closeStack(text: string, stack: string[]): string {\n let result = text;\n for (let i = stack.length - 1; i >= 0; i--) {\n result += stack[i];\n }\n return result;\n}\n",
14
15
  "import { Worker as NodeWorker, isMainThread, parentPort } from \"worker_threads\";\nimport type { WorkerOptions } from \"worker_threads\";\nimport { pathToFileURL } from \"url\";\nimport { URL as NodeURL } from \"url\";\n\nclass WorkerPolyfill extends NodeWorker {\n constructor(scriptUrl: string | NodeURL, options?: WorkerOptions) {\n const resolved: string =\n scriptUrl instanceof NodeURL ? scriptUrl.toString() : pathToFileURL(scriptUrl).toString();\n super(resolved, options);\n }\n\n addEventListener(event: \"message\" | \"error\", listener: (...args: any[]) => void) {\n if (event === \"message\") this.on(\"message\", listener);\n if (event === \"error\") this.on(\"error\", listener);\n }\n\n removeEventListener(event: \"message\" | \"error\", listener: (...args: any[]) => void) {\n if (event === \"message\") this.off(\"message\", listener);\n if (event === \"error\") this.off(\"error\", listener);\n }\n}\n\nconst Worker = isMainThread ? WorkerPolyfill : parentPort;\nexport { Worker, parentPort };\n\nimport { WorkerServerBase, WORKER_SERVER } from \"./WorkerServerBase\";\nimport { globalServiceRegistry } from \"../di\";\nexport { WORKER_SERVER };\nexport class WorkerServer extends WorkerServerBase {\n constructor() {\n parentPort?.addEventListener(\"message\", async (event) => {\n const msg = {\n type: event.type,\n // @ts-ignore - Ignore type mismatch between standard MessageEvent and our message type\n data: event.data,\n };\n await this.handleMessage(msg);\n });\n super();\n }\n}\n\nglobalServiceRegistry.register(WORKER_SERVER, () => new WorkerServer(), true);\n"
15
16
  ],
16
- "mappings": "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",
17
- "debugId": "F33C75360B6E735864756E2164756E21",
17
+ "mappings": "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",
18
+ "debugId": "D50270F8EE79338864756E2164756E21",
18
19
  "names": []
19
20
  }
package/package.json CHANGED
@@ -1,7 +1,12 @@
1
1
  {
2
2
  "name": "@workglow/util",
3
3
  "type": "module",
4
- "version": "0.1.1",
4
+ "version": "0.2.0",
5
+ "repository": {
6
+ "type": "git",
7
+ "url": "https://github.com/workglow-dev/workglow.git",
8
+ "directory": "packages/util"
9
+ },
5
10
  "description": "Utility functions and shared types for Workglow, providing common functionality across all packages.",
6
11
  "scripts": {
7
12
  "watch": "concurrently -c 'auto' 'bun:watch-*'",