@workglow/cactus 0.3.4 → 0.3.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ai/common/Cactus_ModelInfo.browser.d.ts.map +1 -1
- package/dist/ai/common/Cactus_ModelInfo.d.ts.map +1 -1
- package/dist/ai/common/Cactus_Runtime.browser.d.ts +6 -0
- package/dist/ai/common/Cactus_Runtime.browser.d.ts.map +1 -1
- package/dist/ai/common/Cactus_Runtime.d.ts +6 -0
- package/dist/ai/common/Cactus_Runtime.d.ts.map +1 -1
- package/dist/ai-runtime.browser.js +67 -7
- package/dist/ai-runtime.browser.js.map +5 -5
- package/dist/ai-runtime.js +112 -9
- package/dist/ai-runtime.js.map +5 -5
- package/dist/ai.browser.js +66 -7
- package/dist/ai.browser.js.map +5 -5
- package/dist/ai.js +111 -9
- package/dist/ai.js.map +5 -5
- package/package.json +11 -11
package/dist/ai.js
CHANGED
|
@@ -138,6 +138,63 @@ function hasBrowserCacheStorage() {
|
|
|
138
138
|
function modelsDirOf(model) {
|
|
139
139
|
return model.provider_config.models_dir ?? CACTUS_DEFAULT_MODELS_DIR;
|
|
140
140
|
}
|
|
141
|
+
function resolveModelDir(models_dir, model_id) {
|
|
142
|
+
return models_dir.startsWith("~/") ? path.join(process.env.HOME ?? process.env.USERPROFILE ?? ".", models_dir.slice(2), model_id) : path.resolve(models_dir, model_id);
|
|
143
|
+
}
|
|
144
|
+
function assetFilenames(entry) {
|
|
145
|
+
return [entry.assets.weights, entry.assets.vocab, entry.assets.config];
|
|
146
|
+
}
|
|
147
|
+
async function getRemoteAssetSize(url, signal) {
|
|
148
|
+
try {
|
|
149
|
+
const response = await fetch(url, { method: "HEAD", signal });
|
|
150
|
+
if (!response.ok)
|
|
151
|
+
return;
|
|
152
|
+
const contentLength = response.headers.get("content-length");
|
|
153
|
+
if (!contentLength)
|
|
154
|
+
return;
|
|
155
|
+
const size = Number(contentLength);
|
|
156
|
+
return Number.isFinite(size) ? size : undefined;
|
|
157
|
+
} catch {
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
async function getNodeAssetCacheInfo(model, entry, detail, signal) {
|
|
162
|
+
const filenames = assetFilenames(entry);
|
|
163
|
+
const resolvedDir = resolveModelDir(modelsDirOf(model), entry.model_id);
|
|
164
|
+
const stats = await Promise.all(filenames.map(async (filename) => {
|
|
165
|
+
try {
|
|
166
|
+
const stat = await fs.stat(path.join(resolvedDir, filename));
|
|
167
|
+
return { filename, size: stat.size, cached: true };
|
|
168
|
+
} catch {
|
|
169
|
+
return { filename, size: undefined, cached: false };
|
|
170
|
+
}
|
|
171
|
+
}));
|
|
172
|
+
const allCached = stats.every((stat) => stat.cached);
|
|
173
|
+
if (detail === "files") {
|
|
174
|
+
return {
|
|
175
|
+
allCached,
|
|
176
|
+
file_sizes: Object.fromEntries(filenames.map((filename) => [filename, 0]))
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
if (detail !== "files_with_metadata") {
|
|
180
|
+
return { allCached, file_sizes: null };
|
|
181
|
+
}
|
|
182
|
+
const file_sizes = {};
|
|
183
|
+
await Promise.all(stats.map(async (stat) => {
|
|
184
|
+
if (stat.size !== undefined) {
|
|
185
|
+
file_sizes[stat.filename] = stat.size;
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
const remoteSize = await getRemoteAssetSize(cactusAssetUrl(entry, stat.filename), signal);
|
|
189
|
+
if (remoteSize !== undefined) {
|
|
190
|
+
file_sizes[stat.filename] = remoteSize;
|
|
191
|
+
}
|
|
192
|
+
}));
|
|
193
|
+
return {
|
|
194
|
+
allCached,
|
|
195
|
+
file_sizes: Object.keys(file_sizes).length > 0 ? file_sizes : null
|
|
196
|
+
};
|
|
197
|
+
}
|
|
141
198
|
async function fetchAssetBytesBrowser(url) {
|
|
142
199
|
const cachesApi = globalThis.caches;
|
|
143
200
|
const cache = await cachesApi.open(CACTUS_CACHE_NAME);
|
|
@@ -152,7 +209,7 @@ async function fetchAssetBytesBrowser(url) {
|
|
|
152
209
|
return new Uint8Array(await resp.arrayBuffer());
|
|
153
210
|
}
|
|
154
211
|
async function fetchAssetBytesNode(url, models_dir, model_id, filename) {
|
|
155
|
-
const resolvedDir =
|
|
212
|
+
const resolvedDir = resolveModelDir(models_dir, model_id);
|
|
156
213
|
const filePath = path.join(resolvedDir, filename);
|
|
157
214
|
try {
|
|
158
215
|
const buf = await fs.readFile(filePath);
|
|
@@ -229,6 +286,50 @@ function markModelCached(model_id) {
|
|
|
229
286
|
function isModelCached(model_id) {
|
|
230
287
|
return cactusEngines.has(model_id) || cactusCachedModelIds.has(model_id);
|
|
231
288
|
}
|
|
289
|
+
async function getCactusModelCacheInfo(model, entry, detail, signal) {
|
|
290
|
+
if (hasBrowserCacheStorage()) {
|
|
291
|
+
const cachesApi = globalThis.caches;
|
|
292
|
+
const cache = await cachesApi.open(CACTUS_CACHE_NAME);
|
|
293
|
+
const filenames = assetFilenames(entry);
|
|
294
|
+
const cacheHits = await Promise.all(filenames.map(async (filename) => {
|
|
295
|
+
const url = cactusAssetUrl(entry, filename);
|
|
296
|
+
const hit = await cache.match(url);
|
|
297
|
+
return { filename, url, hit };
|
|
298
|
+
}));
|
|
299
|
+
const allCached = cacheHits.every(({ hit }) => Boolean(hit));
|
|
300
|
+
if (detail === "files") {
|
|
301
|
+
return {
|
|
302
|
+
allCached,
|
|
303
|
+
file_sizes: Object.fromEntries(filenames.map((filename) => [filename, 0]))
|
|
304
|
+
};
|
|
305
|
+
}
|
|
306
|
+
if (detail !== "files_with_metadata") {
|
|
307
|
+
return { allCached, file_sizes: null };
|
|
308
|
+
}
|
|
309
|
+
const file_sizes = {};
|
|
310
|
+
await Promise.all(cacheHits.map(async ({ filename, url, hit }) => {
|
|
311
|
+
if (hit) {
|
|
312
|
+
const contentLength = hit.headers.get("content-length");
|
|
313
|
+
const contentLengthSize = contentLength ? Number(contentLength) : undefined;
|
|
314
|
+
if (contentLengthSize !== undefined && Number.isFinite(contentLengthSize)) {
|
|
315
|
+
file_sizes[filename] = contentLengthSize;
|
|
316
|
+
} else {
|
|
317
|
+
file_sizes[filename] = (await hit.clone().arrayBuffer()).byteLength;
|
|
318
|
+
}
|
|
319
|
+
return;
|
|
320
|
+
}
|
|
321
|
+
const remoteSize = await getRemoteAssetSize(url, signal);
|
|
322
|
+
if (remoteSize !== undefined) {
|
|
323
|
+
file_sizes[filename] = remoteSize;
|
|
324
|
+
}
|
|
325
|
+
}));
|
|
326
|
+
return {
|
|
327
|
+
allCached,
|
|
328
|
+
file_sizes: Object.keys(file_sizes).length > 0 ? file_sizes : null
|
|
329
|
+
};
|
|
330
|
+
}
|
|
331
|
+
return getNodeAssetCacheInfo(model, entry, detail, signal);
|
|
332
|
+
}
|
|
232
333
|
var cactusSessions = new Map;
|
|
233
334
|
async function deleteCactusSession(id) {
|
|
234
335
|
return cactusSessions.delete(id);
|
|
@@ -249,7 +350,7 @@ async function removeNodeCacheDir(model, model_id) {
|
|
|
249
350
|
if (hasBrowserCacheStorage())
|
|
250
351
|
return;
|
|
251
352
|
const models_dir = modelsDirOf(model);
|
|
252
|
-
const resolvedDir =
|
|
353
|
+
const resolvedDir = resolveModelDir(models_dir, model_id);
|
|
253
354
|
await fs.rm(resolvedDir, { recursive: true, force: true });
|
|
254
355
|
}
|
|
255
356
|
function disposeCactusEngine(model_id) {
|
|
@@ -361,7 +462,7 @@ var Cactus_DownloadRemove = async (input, model, _signal, emit) => {
|
|
|
361
462
|
};
|
|
362
463
|
|
|
363
464
|
// src/ai/common/Cactus_ModelInfo.ts
|
|
364
|
-
var Cactus_ModelInfo = async (input, model,
|
|
465
|
+
var Cactus_ModelInfo = async (input, model, signal, emit) => {
|
|
365
466
|
if (!model)
|
|
366
467
|
throw new Error("Model config is required for ModelInfoTask.");
|
|
367
468
|
const model_id = model.provider_config.model_id;
|
|
@@ -369,7 +470,8 @@ var Cactus_ModelInfo = async (input, model, _signal, emit) => {
|
|
|
369
470
|
if (!entry)
|
|
370
471
|
throw new Error(`Unknown Cactus model_id: ${model_id}`);
|
|
371
472
|
const is_loaded = isModelLoaded(model_id);
|
|
372
|
-
const
|
|
473
|
+
const cacheInfo = await getCactusModelCacheInfo(model, entry, input.detail, signal);
|
|
474
|
+
const is_cached = is_loaded || isModelCached(model_id) || cacheInfo.allCached;
|
|
373
475
|
emit({
|
|
374
476
|
type: "finish",
|
|
375
477
|
data: {
|
|
@@ -380,7 +482,7 @@ var Cactus_ModelInfo = async (input, model, _signal, emit) => {
|
|
|
380
482
|
supports_node: true,
|
|
381
483
|
is_cached,
|
|
382
484
|
is_loaded,
|
|
383
|
-
file_sizes:
|
|
485
|
+
file_sizes: cacheInfo.file_sizes
|
|
384
486
|
}
|
|
385
487
|
});
|
|
386
488
|
};
|
|
@@ -408,7 +510,7 @@ var Cactus_ModelSearch = async (input, _model, _signal, emit) => {
|
|
|
408
510
|
|
|
409
511
|
// src/ai/common/Cactus_ToolCalling.ts
|
|
410
512
|
import { extractMessageText } from "@workglow/ai/provider-utils";
|
|
411
|
-
import { filterValidToolCalls } from "@workglow/ai/worker";
|
|
513
|
+
import { filterValidToolCalls, sanitizeToolArgs } from "@workglow/ai/worker";
|
|
412
514
|
function buildToolsJson(tools) {
|
|
413
515
|
return JSON.stringify(tools.map((t) => ({
|
|
414
516
|
name: t.name,
|
|
@@ -436,7 +538,7 @@ function parseToolCalls(raw) {
|
|
|
436
538
|
return obj.map((o, i) => ({
|
|
437
539
|
id: `call_${i}`,
|
|
438
540
|
name: String(o.name ?? ""),
|
|
439
|
-
input: o.arguments ?? o.params ?? {}
|
|
541
|
+
input: sanitizeToolArgs(o.arguments ?? o.params ?? {})
|
|
440
542
|
}));
|
|
441
543
|
}
|
|
442
544
|
if (obj && typeof obj === "object" && typeof obj.name === "string") {
|
|
@@ -444,7 +546,7 @@ function parseToolCalls(raw) {
|
|
|
444
546
|
{
|
|
445
547
|
id: "call_0",
|
|
446
548
|
name: obj.name,
|
|
447
|
-
input: obj.arguments ?? obj.params ?? {}
|
|
549
|
+
input: sanitizeToolArgs(obj.arguments ?? obj.params ?? {})
|
|
448
550
|
}
|
|
449
551
|
];
|
|
450
552
|
}
|
|
@@ -514,4 +616,4 @@ export {
|
|
|
514
616
|
CACTUS_CACHE_NAME
|
|
515
617
|
};
|
|
516
618
|
|
|
517
|
-
//# debugId=
|
|
619
|
+
//# debugId=0F1861CAFC26D69864756E2164756E21
|
package/dist/ai.js.map
CHANGED
|
@@ -8,18 +8,18 @@
|
|
|
8
8
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type {\n AiProviderPreviewRunFn,\n AiProviderRunFnRegistration,\n Capability,\n ModelConfig,\n ModelRecord,\n} from \"@workglow/ai/worker\";\nimport { AiProvider } from \"@workglow/ai/worker\";\nimport { cactusWorkerRunFnSpecs, inferCactusCapabilities } from \"./common/Cactus_Capabilities\";\nimport { LOCAL_CACTUS } from \"./common/Cactus_Constants\";\nimport type { CactusModelConfig } from \"./common/Cactus_ModelSchema\";\nimport { deleteCactusSession } from \"./common/Cactus_Runtime\";\n\n/** Worker-server registration for Cactus (browser + Node/Bun via WASM). */\nexport class CactusProvider extends AiProvider<CactusModelConfig> {\n readonly name = LOCAL_CACTUS;\n readonly displayName = \"Cactus (Needle)\";\n readonly isLocal = true;\n readonly supportsBrowser = true;\n\n constructor(\n promiseRunFns?: readonly AiProviderRunFnRegistration<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n any,\n CactusModelConfig\n >[],\n previewTasks?: Record<\n string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n AiProviderPreviewRunFn<any, any, CactusModelConfig>\n >\n ) {\n super(promiseRunFns, previewTasks);\n }\n\n override inferCapabilities(model: ModelRecord): readonly Capability[] {\n return inferCactusCapabilities(model);\n }\n\n protected override workerRunFnSpecs(): readonly { serves: readonly Capability[] }[] {\n return cactusWorkerRunFnSpecs();\n }\n\n override createSession(_model: ModelConfig): string {\n return crypto.randomUUID();\n }\n\n override async disposeSession(sessionId: string): Promise<void> {\n await deleteCactusSession(sessionId);\n }\n}\n",
|
|
9
9
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { Capability } from \"@workglow/ai/worker\";\n\nexport const CACTUS_TOOL_USE = [\"tool-use\"] as const satisfies Capability[];\nexport const CACTUS_MODEL_DOWNLOAD = [\"model.download\"] as const satisfies Capability[];\nexport const CACTUS_MODEL_DOWNLOAD_REMOVE = [\n \"model.download-remove\",\n] as const satisfies Capability[];\nexport const CACTUS_MODEL_SEARCH = [\"model.search\"] as const satisfies Capability[];\nexport const CACTUS_MODEL_INFO = [\"model.info\"] as const satisfies Capability[];\n\nexport const CACTUS_CAPABILITY_SETS = [\n CACTUS_TOOL_USE,\n CACTUS_MODEL_DOWNLOAD,\n CACTUS_MODEL_DOWNLOAD_REMOVE,\n CACTUS_MODEL_SEARCH,\n CACTUS_MODEL_INFO,\n] as const;\n",
|
|
10
10
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { Capability, ModelRecord } from \"@workglow/ai/worker\";\nimport { CACTUS_CAPABILITY_SETS } from \"./Cactus_CapabilitySets\";\n\nexport const CACTUS_RUN_FN_SPECS = CACTUS_CAPABILITY_SETS.map((serves) => ({ serves }));\n\nexport function cactusWorkerRunFnSpecs(): readonly {\n readonly serves: readonly Capability[];\n}[] {\n return CACTUS_RUN_FN_SPECS;\n}\n\ntype CapabilityHints = Pick<ModelRecord, \"model_id\" | \"provider_config\" | \"capabilities\">;\n\n/**\n * needle-rs ships a single model architecture; capability inference is constant.\n */\nexport function inferCactusCapabilities(_model: CapabilityHints): readonly Capability[] {\n return [\"tool-use\", \"model.download\", \"model.download-remove\", \"model.search\", \"model.info\"];\n}\n",
|
|
11
|
-
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { CACTUS_CACHE_NAME, CACTUS_DEFAULT_MODELS_DIR } from \"./Cactus_Constants\";\nimport {\n cactusAssetUrl,\n getCactusCatalogEntry,\n type CactusCatalogEntry,\n} from \"./Cactus_ModelCatalog\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\n\ntype NeedleSdkModule = typeof import(\"needle-rs\");\n// `NeedleWasm` has a private constructor so `InstanceType<...>` cannot be used.\n// Recover the instance type from the static `load` method's non-undefined return.\ntype NeedleEngine = NonNullable<ReturnType<NeedleSdkModule[\"NeedleWasm\"][\"load\"]>>;\n\nlet _sdk: NeedleSdkModule | undefined;\nlet _sdkInitPromise: Promise<NeedleSdkModule> | undefined;\n\n/** Lazily load needle-rs and run its WASM `init()` exactly once. */\nexport async function loadSdk(): Promise<NeedleSdkModule> {\n _sdkInitPromise ??= import(\"needle-rs\")\n .then(async (mod) => {\n const init = (mod as unknown as { default?: () => Promise<unknown> }).default;\n if (typeof init === \"function\") {\n await init();\n }\n _sdk = mod;\n return mod;\n })\n .catch((err: unknown) => {\n _sdkInitPromise = undefined;\n _sdk = undefined;\n throw new Error(\n `needle-rs is required for LOCAL_CACTUS tasks. Install it with: bun add needle-rs (cause: ${String(err)})`\n );\n });\n return _sdkInitPromise;\n}\n\nexport function getCactusSdk(): NeedleSdkModule {\n if (!_sdk) throw new Error(\"Cactus SDK not loaded; call loadSdk() first\");\n return _sdk;\n}\n\n// ============================================================================\n// Asset fetch + cache\n// ============================================================================\n\nfunction hasBrowserCacheStorage(): boolean {\n return (\n typeof globalThis !== \"undefined\" &&\n \"caches\" in globalThis &&\n typeof (globalThis as unknown as { caches?: CacheStorage }).caches?.open === \"function\"\n );\n}\n\nfunction modelsDirOf(model: CactusModelConfig): string {\n return model.provider_config.models_dir ?? CACTUS_DEFAULT_MODELS_DIR;\n}\n\nasync function fetchAssetBytesBrowser(url: string): Promise<Uint8Array> {\n const cachesApi = (globalThis as unknown as { caches: CacheStorage }).caches;\n const cache = await cachesApi.open(CACTUS_CACHE_NAME);\n const hit = await cache.match(url);\n if (hit) {\n return new Uint8Array(await hit.arrayBuffer());\n }\n const resp = await fetch(url);\n if (!resp.ok) throw new Error(`Cactus asset fetch failed (${resp.status}) for ${url}`);\n // Clone first — Response bodies can only be consumed once.\n await cache.put(url, resp.clone());\n return new Uint8Array(await resp.arrayBuffer());\n}\n\nasync function fetchAssetBytesNode(\n url: string,\n models_dir: string,\n model_id: string,\n filename: string\n): Promise<Uint8Array> {\n const resolvedDir = models_dir.startsWith(\"~/\")\n ? path.join(process.env.HOME ?? process.env.USERPROFILE ?? \".\", models_dir.slice(2), model_id)\n : path.resolve(models_dir, model_id);\n const filePath = path.join(resolvedDir, filename);\n try {\n const buf = await fs.readFile(filePath);\n return new Uint8Array(buf);\n } catch {\n // fall through to fetch\n }\n const resp = await fetch(url);\n if (!resp.ok) throw new Error(`Cactus asset fetch failed (${resp.status}) for ${url}`);\n const bytes = new Uint8Array(await resp.arrayBuffer());\n await fs.mkdir(resolvedDir, { recursive: true });\n const tmpPath = `${filePath}.tmp`;\n await fs.writeFile(tmpPath, bytes);\n await fs.rename(tmpPath, filePath);\n return bytes;\n}\n\nexport async function fetchAssetBytes(\n model: CactusModelConfig,\n filename: string\n): Promise<Uint8Array> {\n const model_id = model.provider_config.model_id;\n const entry = getCactusCatalogEntry(model_id);\n if (!entry) throw new Error(`Unknown Cactus model_id: ${model_id}`);\n const url = cactusAssetUrl(entry, filename);\n if (hasBrowserCacheStorage()) {\n return fetchAssetBytesBrowser(url);\n }\n return fetchAssetBytesNode(url, modelsDirOf(model), model_id, filename);\n}\n\n// ============================================================================\n// Engine cache (in-memory, per worker/process)\n// ============================================================================\n\n/** @internal Exported for tests. */\nexport const cactusEngines: Map<string, NeedleEngine> = new Map();\n/** @internal Exported for tests. */\nexport const cactusConfigJson: Map<string, unknown> = new Map();\n/** Tracks models whose assets have been persisted (downloaded) but not necessarily loaded. */\nconst cactusCachedModelIds: Set<string> = new Set();\n\nconst cactusEngineLoadsInFlight = new Map<string, Promise<NeedleEngine>>();\n\nexport async function getOrLoadEngine(model: CactusModelConfig): Promise<NeedleEngine> {\n const model_id = model.provider_config.model_id;\n const cached = cactusEngines.get(model_id);\n if (cached) return cached;\n\n const inFlight = cactusEngineLoadsInFlight.get(model_id);\n if (inFlight) return inFlight;\n\n const loadPromise = (async (): Promise<NeedleEngine> => {\n const sdk = await loadSdk();\n const entry = getCactusCatalogEntry(model_id);\n if (!entry) throw new Error(`Unknown Cactus model_id: ${model_id}`);\n\n const [weightsBytes, vocabBytes, configBytes] = await Promise.all([\n fetchAssetBytes(model, entry.assets.weights),\n fetchAssetBytes(model, entry.assets.vocab),\n fetchAssetBytes(model, entry.assets.config),\n ]);\n\n try {\n const text = new TextDecoder().decode(configBytes);\n cactusConfigJson.set(model_id, JSON.parse(text));\n } catch {\n cactusConfigJson.set(model_id, null);\n }\n\n // needle-rs `NeedleWasm.load(weights_bytes: Uint8Array, vocab_text: string)` — vocab is a string.\n const vocabText = new TextDecoder().decode(vocabBytes);\n const engine = sdk.NeedleWasm.load(weightsBytes, vocabText);\n if (!engine) {\n throw new Error(`needle-rs NeedleWasm.load returned undefined for model ${model_id}`);\n }\n cactusEngines.set(model_id, engine);\n return engine;\n })().finally(() => {\n cactusEngineLoadsInFlight.delete(model_id);\n });\n\n cactusEngineLoadsInFlight.set(model_id, loadPromise);\n return loadPromise;\n}\n\nexport function isModelLoaded(model_id: string): boolean {\n return cactusEngines.has(model_id);\n}\n\n/** Mark a model_id as having its assets persisted on disk / in Cache Storage. */\nexport function markModelCached(model_id: string): void {\n cactusCachedModelIds.add(model_id);\n}\n\n/** Returns true if the model's assets have been downloaded or the engine is currently loaded. */\nexport function isModelCached(model_id: string): boolean {\n return cactusEngines.has(model_id) || cactusCachedModelIds.has(model_id);\n}\n\n// ============================================================================\n// Sessions (no-op — needle-rs is stateless across calls)\n// ============================================================================\n\n/** @internal Exported for tests. */\nexport const cactusSessions: Map<string, Record<string, never>> = new Map();\n\nexport async function deleteCactusSession(id: string): Promise<boolean> {\n return cactusSessions.delete(id);\n}\n\n// ============================================================================\n// Eviction\n// ============================================================================\n\nasync function removeBrowserCacheEntries(entry: CactusCatalogEntry): Promise<void> {\n if (!hasBrowserCacheStorage()) return;\n const cachesApi = (globalThis as unknown as { caches: CacheStorage }).caches;\n const cache = await cachesApi.open(CACTUS_CACHE_NAME);\n for (const filename of [entry.assets.weights, entry.assets.vocab, entry.assets.config]) {\n const url = cactusAssetUrl(entry, filename);\n try {\n await cache.delete(url);\n } catch {\n /* ignore */\n }\n }\n}\n\nasync function removeNodeCacheDir(model: CactusModelConfig, model_id: string): Promise<void> {\n if (hasBrowserCacheStorage()) return;\n const models_dir = modelsDirOf(model);\n const resolvedDir = models_dir.startsWith(\"~/\")\n ? path.join(process.env.HOME ?? process.env.USERPROFILE ?? \".\", models_dir.slice(2), model_id)\n : path.resolve(models_dir, model_id);\n await fs.rm(resolvedDir, { recursive: true, force: true });\n}\n\nfunction disposeCactusEngine(model_id: string): void {\n const engine = cactusEngines.get(model_id);\n if (engine) {\n try {\n (engine as unknown as { free?: () => void }).free?.();\n } catch {\n /* best effort */\n }\n }\n cactusEngines.delete(model_id);\n cactusConfigJson.delete(model_id);\n cactusCachedModelIds.delete(model_id);\n}\n\nexport async function removeCachedAssets(model: CactusModelConfig): Promise<void> {\n const model_id = model.provider_config.model_id;\n const entry = getCactusCatalogEntry(model_id);\n if (!entry) return;\n await Promise.all([removeBrowserCacheEntries(entry), removeNodeCacheDir(model, model_id)]);\n disposeCactusEngine(model_id);\n}\n\n/** Best-effort cleanup on shutdown. */\nexport async function disposeCactusResources(): Promise<void> {\n for (const id of Array.from(cactusEngines.keys())) {\n disposeCactusEngine(id);\n }\n cactusEngines.clear();\n cactusConfigJson.clear();\n cactusCachedModelIds.clear();\n cactusSessions.clear();\n}\n",
|
|
11
|
+
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { CACTUS_CACHE_NAME, CACTUS_DEFAULT_MODELS_DIR } from \"./Cactus_Constants\";\nimport {\n cactusAssetUrl,\n getCactusCatalogEntry,\n type CactusCatalogEntry,\n} from \"./Cactus_ModelCatalog\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\n\ntype NeedleSdkModule = typeof import(\"needle-rs\");\n// `NeedleWasm` has a private constructor so `InstanceType<...>` cannot be used.\n// Recover the instance type from the static `load` method's non-undefined return.\ntype NeedleEngine = NonNullable<ReturnType<NeedleSdkModule[\"NeedleWasm\"][\"load\"]>>;\n\nexport interface CactusModelCacheInfo {\n readonly allCached: boolean;\n readonly file_sizes: Record<string, number> | null;\n}\n\nlet _sdk: NeedleSdkModule | undefined;\nlet _sdkInitPromise: Promise<NeedleSdkModule> | undefined;\n\n/** Lazily load needle-rs and run its WASM `init()` exactly once. */\nexport async function loadSdk(): Promise<NeedleSdkModule> {\n _sdkInitPromise ??= import(\"needle-rs\")\n .then(async (mod) => {\n const init = (mod as unknown as { default?: () => Promise<unknown> }).default;\n if (typeof init === \"function\") {\n await init();\n }\n _sdk = mod;\n return mod;\n })\n .catch((err: unknown) => {\n _sdkInitPromise = undefined;\n _sdk = undefined;\n throw new Error(\n `needle-rs is required for LOCAL_CACTUS tasks. Install it with: bun add needle-rs (cause: ${String(err)})`\n );\n });\n return _sdkInitPromise;\n}\n\nexport function getCactusSdk(): NeedleSdkModule {\n if (!_sdk) throw new Error(\"Cactus SDK not loaded; call loadSdk() first\");\n return _sdk;\n}\n\n// ============================================================================\n// Asset fetch + cache\n// ============================================================================\n\nfunction hasBrowserCacheStorage(): boolean {\n return (\n typeof globalThis !== \"undefined\" &&\n \"caches\" in globalThis &&\n typeof (globalThis as unknown as { caches?: CacheStorage }).caches?.open === \"function\"\n );\n}\n\nfunction modelsDirOf(model: CactusModelConfig): string {\n return model.provider_config.models_dir ?? CACTUS_DEFAULT_MODELS_DIR;\n}\n\nfunction resolveModelDir(models_dir: string, model_id: string): string {\n return models_dir.startsWith(\"~/\")\n ? path.join(process.env.HOME ?? process.env.USERPROFILE ?? \".\", models_dir.slice(2), model_id)\n : path.resolve(models_dir, model_id);\n}\n\nfunction assetFilenames(entry: CactusCatalogEntry): string[] {\n return [entry.assets.weights, entry.assets.vocab, entry.assets.config];\n}\n\nasync function getRemoteAssetSize(\n url: string,\n signal: AbortSignal | undefined\n): Promise<number | undefined> {\n try {\n const response = await fetch(url, { method: \"HEAD\", signal });\n if (!response.ok) return undefined;\n const contentLength = response.headers.get(\"content-length\");\n if (!contentLength) return undefined;\n const size = Number(contentLength);\n return Number.isFinite(size) ? size : undefined;\n } catch {\n return undefined;\n }\n}\n\nasync function getNodeAssetCacheInfo(\n model: CactusModelConfig,\n entry: CactusCatalogEntry,\n detail: string | undefined,\n signal: AbortSignal | undefined\n): Promise<CactusModelCacheInfo> {\n const filenames = assetFilenames(entry);\n const resolvedDir = resolveModelDir(modelsDirOf(model), entry.model_id);\n const stats = await Promise.all(\n filenames.map(async (filename) => {\n try {\n const stat = await fs.stat(path.join(resolvedDir, filename));\n return { filename, size: stat.size, cached: true };\n } catch {\n return { filename, size: undefined, cached: false };\n }\n })\n );\n const allCached = stats.every((stat) => stat.cached);\n\n if (detail === \"files\") {\n return {\n allCached,\n file_sizes: Object.fromEntries(filenames.map((filename) => [filename, 0])),\n };\n }\n\n if (detail !== \"files_with_metadata\") {\n return { allCached, file_sizes: null };\n }\n\n const file_sizes: Record<string, number> = {};\n await Promise.all(\n stats.map(async (stat) => {\n if (stat.size !== undefined) {\n file_sizes[stat.filename] = stat.size;\n return;\n }\n const remoteSize = await getRemoteAssetSize(cactusAssetUrl(entry, stat.filename), signal);\n if (remoteSize !== undefined) {\n file_sizes[stat.filename] = remoteSize;\n }\n })\n );\n\n return {\n allCached,\n file_sizes: Object.keys(file_sizes).length > 0 ? file_sizes : null,\n };\n}\n\nasync function fetchAssetBytesBrowser(url: string): Promise<Uint8Array> {\n const cachesApi = (globalThis as unknown as { caches: CacheStorage }).caches;\n const cache = await cachesApi.open(CACTUS_CACHE_NAME);\n const hit = await cache.match(url);\n if (hit) {\n return new Uint8Array(await hit.arrayBuffer());\n }\n const resp = await fetch(url);\n if (!resp.ok) throw new Error(`Cactus asset fetch failed (${resp.status}) for ${url}`);\n // Clone first — Response bodies can only be consumed once.\n await cache.put(url, resp.clone());\n return new Uint8Array(await resp.arrayBuffer());\n}\n\nasync function fetchAssetBytesNode(\n url: string,\n models_dir: string,\n model_id: string,\n filename: string\n): Promise<Uint8Array> {\n const resolvedDir = resolveModelDir(models_dir, model_id);\n const filePath = path.join(resolvedDir, filename);\n try {\n const buf = await fs.readFile(filePath);\n return new Uint8Array(buf);\n } catch {\n // fall through to fetch\n }\n const resp = await fetch(url);\n if (!resp.ok) throw new Error(`Cactus asset fetch failed (${resp.status}) for ${url}`);\n const bytes = new Uint8Array(await resp.arrayBuffer());\n await fs.mkdir(resolvedDir, { recursive: true });\n const tmpPath = `${filePath}.tmp`;\n await fs.writeFile(tmpPath, bytes);\n await fs.rename(tmpPath, filePath);\n return bytes;\n}\n\nexport async function fetchAssetBytes(\n model: CactusModelConfig,\n filename: string\n): Promise<Uint8Array> {\n const model_id = model.provider_config.model_id;\n const entry = getCactusCatalogEntry(model_id);\n if (!entry) throw new Error(`Unknown Cactus model_id: ${model_id}`);\n const url = cactusAssetUrl(entry, filename);\n if (hasBrowserCacheStorage()) {\n return fetchAssetBytesBrowser(url);\n }\n return fetchAssetBytesNode(url, modelsDirOf(model), model_id, filename);\n}\n\n// ============================================================================\n// Engine cache (in-memory, per worker/process)\n// ============================================================================\n\n/** @internal Exported for tests. */\nexport const cactusEngines: Map<string, NeedleEngine> = new Map();\n/** @internal Exported for tests. */\nexport const cactusConfigJson: Map<string, unknown> = new Map();\n/** Tracks models whose assets have been persisted (downloaded) but not necessarily loaded. */\nconst cactusCachedModelIds: Set<string> = new Set();\n\nconst cactusEngineLoadsInFlight = new Map<string, Promise<NeedleEngine>>();\n\nexport async function getOrLoadEngine(model: CactusModelConfig): Promise<NeedleEngine> {\n const model_id = model.provider_config.model_id;\n const cached = cactusEngines.get(model_id);\n if (cached) return cached;\n\n const inFlight = cactusEngineLoadsInFlight.get(model_id);\n if (inFlight) return inFlight;\n\n const loadPromise = (async (): Promise<NeedleEngine> => {\n const sdk = await loadSdk();\n const entry = getCactusCatalogEntry(model_id);\n if (!entry) throw new Error(`Unknown Cactus model_id: ${model_id}`);\n\n const [weightsBytes, vocabBytes, configBytes] = await Promise.all([\n fetchAssetBytes(model, entry.assets.weights),\n fetchAssetBytes(model, entry.assets.vocab),\n fetchAssetBytes(model, entry.assets.config),\n ]);\n\n try {\n const text = new TextDecoder().decode(configBytes);\n cactusConfigJson.set(model_id, JSON.parse(text));\n } catch {\n cactusConfigJson.set(model_id, null);\n }\n\n // needle-rs `NeedleWasm.load(weights_bytes: Uint8Array, vocab_text: string)` — vocab is a string.\n const vocabText = new TextDecoder().decode(vocabBytes);\n const engine = sdk.NeedleWasm.load(weightsBytes, vocabText);\n if (!engine) {\n throw new Error(`needle-rs NeedleWasm.load returned undefined for model ${model_id}`);\n }\n cactusEngines.set(model_id, engine);\n return engine;\n })().finally(() => {\n cactusEngineLoadsInFlight.delete(model_id);\n });\n\n cactusEngineLoadsInFlight.set(model_id, loadPromise);\n return loadPromise;\n}\n\nexport function isModelLoaded(model_id: string): boolean {\n return cactusEngines.has(model_id);\n}\n\n/** Mark a model_id as having its assets persisted on disk / in Cache Storage. */\nexport function markModelCached(model_id: string): void {\n cactusCachedModelIds.add(model_id);\n}\n\n/** Returns true if the model's assets have been downloaded or the engine is currently loaded. */\nexport function isModelCached(model_id: string): boolean {\n return cactusEngines.has(model_id) || cactusCachedModelIds.has(model_id);\n}\n\nexport async function getCactusModelCacheInfo(\n model: CactusModelConfig,\n entry: CactusCatalogEntry,\n detail: string | undefined,\n signal: AbortSignal | undefined\n): Promise<CactusModelCacheInfo> {\n if (hasBrowserCacheStorage()) {\n const cachesApi = (globalThis as unknown as { caches: CacheStorage }).caches;\n const cache = await cachesApi.open(CACTUS_CACHE_NAME);\n const filenames = assetFilenames(entry);\n const cacheHits = await Promise.all(\n filenames.map(async (filename) => {\n const url = cactusAssetUrl(entry, filename);\n const hit = await cache.match(url);\n return { filename, url, hit };\n })\n );\n const allCached = cacheHits.every(({ hit }) => Boolean(hit));\n\n if (detail === \"files\") {\n return {\n allCached,\n file_sizes: Object.fromEntries(filenames.map((filename) => [filename, 0])),\n };\n }\n\n if (detail !== \"files_with_metadata\") {\n return { allCached, file_sizes: null };\n }\n\n const file_sizes: Record<string, number> = {};\n await Promise.all(\n cacheHits.map(async ({ filename, url, hit }) => {\n if (hit) {\n const contentLength = hit.headers.get(\"content-length\");\n const contentLengthSize = contentLength ? Number(contentLength) : undefined;\n if (contentLengthSize !== undefined && Number.isFinite(contentLengthSize)) {\n file_sizes[filename] = contentLengthSize;\n } else {\n file_sizes[filename] = (await hit.clone().arrayBuffer()).byteLength;\n }\n return;\n }\n const remoteSize = await getRemoteAssetSize(url, signal);\n if (remoteSize !== undefined) {\n file_sizes[filename] = remoteSize;\n }\n })\n );\n\n return {\n allCached,\n file_sizes: Object.keys(file_sizes).length > 0 ? file_sizes : null,\n };\n }\n\n return getNodeAssetCacheInfo(model, entry, detail, signal);\n}\n\n// ============================================================================\n// Sessions (no-op — needle-rs is stateless across calls)\n// ============================================================================\n\n/** @internal Exported for tests. */\nexport const cactusSessions: Map<string, Record<string, never>> = new Map();\n\nexport async function deleteCactusSession(id: string): Promise<boolean> {\n return cactusSessions.delete(id);\n}\n\n// ============================================================================\n// Eviction\n// ============================================================================\n\nasync function removeBrowserCacheEntries(entry: CactusCatalogEntry): Promise<void> {\n if (!hasBrowserCacheStorage()) return;\n const cachesApi = (globalThis as unknown as { caches: CacheStorage }).caches;\n const cache = await cachesApi.open(CACTUS_CACHE_NAME);\n for (const filename of [entry.assets.weights, entry.assets.vocab, entry.assets.config]) {\n const url = cactusAssetUrl(entry, filename);\n try {\n await cache.delete(url);\n } catch {\n /* ignore */\n }\n }\n}\n\nasync function removeNodeCacheDir(model: CactusModelConfig, model_id: string): Promise<void> {\n if (hasBrowserCacheStorage()) return;\n const models_dir = modelsDirOf(model);\n const resolvedDir = resolveModelDir(models_dir, model_id);\n await fs.rm(resolvedDir, { recursive: true, force: true });\n}\n\nfunction disposeCactusEngine(model_id: string): void {\n const engine = cactusEngines.get(model_id);\n if (engine) {\n try {\n (engine as unknown as { free?: () => void }).free?.();\n } catch {\n /* best effort */\n }\n }\n cactusEngines.delete(model_id);\n cactusConfigJson.delete(model_id);\n cactusCachedModelIds.delete(model_id);\n}\n\nexport async function removeCachedAssets(model: CactusModelConfig): Promise<void> {\n const model_id = model.provider_config.model_id;\n const entry = getCactusCatalogEntry(model_id);\n if (!entry) return;\n await Promise.all([removeBrowserCacheEntries(entry), removeNodeCacheDir(model, model_id)]);\n disposeCactusEngine(model_id);\n}\n\n/** Best-effort cleanup on shutdown. */\nexport async function disposeCactusResources(): Promise<void> {\n for (const id of Array.from(cactusEngines.keys())) {\n disposeCactusEngine(id);\n }\n cactusEngines.clear();\n cactusConfigJson.clear();\n cactusCachedModelIds.clear();\n cactusSessions.clear();\n}\n",
|
|
12
12
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type {\n AiProviderPreviewRunFn,\n AiProviderRunFnRegistration,\n Capability,\n ModelConfig,\n ModelRecord,\n} from \"@workglow/ai\";\nimport { QueuedAiProvider } from \"@workglow/ai\";\nimport { cactusWorkerRunFnSpecs, inferCactusCapabilities } from \"./common/Cactus_Capabilities\";\nimport { LOCAL_CACTUS } from \"./common/Cactus_Constants\";\nimport type { CactusModelConfig } from \"./common/Cactus_ModelSchema\";\nimport { deleteCactusSession } from \"./common/Cactus_Runtime\";\n\n/** Main-thread registration (inline or worker-backed); creates the default job queue. */\nexport class CactusQueuedProvider extends QueuedAiProvider<CactusModelConfig> {\n readonly name = LOCAL_CACTUS;\n readonly displayName = \"Cactus (Needle)\";\n readonly isLocal = true;\n readonly supportsBrowser = true;\n\n constructor(\n promiseRunFns?: readonly AiProviderRunFnRegistration<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n any,\n CactusModelConfig\n >[],\n previewTasks?: Record<\n string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n AiProviderPreviewRunFn<any, any, CactusModelConfig>\n >\n ) {\n super(promiseRunFns, previewTasks);\n }\n\n override inferCapabilities(model: ModelRecord): readonly Capability[] {\n return inferCactusCapabilities(model);\n }\n\n protected override workerRunFnSpecs(): readonly { serves: readonly Capability[] }[] {\n return cactusWorkerRunFnSpecs();\n }\n\n override createSession(_model: ModelConfig): string {\n return crypto.randomUUID();\n }\n\n override async disposeSession(sessionId: string): Promise<void> {\n await deleteCactusSession(sessionId);\n }\n}\n",
|
|
13
13
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { AiProviderRegisterOptions } from \"@workglow/ai\";\nimport { registerProviderWithWorker } from \"@workglow/ai/provider-utils\";\nimport { CactusQueuedProvider } from \"./CactusQueuedProvider\";\n\nexport async function registerCactus(\n options: AiProviderRegisterOptions & {\n worker: Worker | (() => Worker);\n }\n): Promise<void> {\n await registerProviderWithWorker(new CactusQueuedProvider(), \"Cactus\", options);\n}\n",
|
|
14
14
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type {\n AiProviderRunFn,\n ModelDownloadTaskRunInput,\n ModelDownloadTaskRunOutput,\n} from \"@workglow/ai\";\nimport { getCactusCatalogEntry } from \"./Cactus_ModelCatalog\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\nimport { fetchAssetBytes, markModelCached } from \"./Cactus_Runtime\";\n\nexport const Cactus_Download: AiProviderRunFn<\n ModelDownloadTaskRunInput,\n ModelDownloadTaskRunOutput,\n CactusModelConfig\n> = async (input, model, _signal, emit) => {\n if (!model) throw new Error(\"Model config is required for ModelDownloadTask.\");\n const model_id = model.provider_config.model_id;\n const entry = getCactusCatalogEntry(model_id);\n if (!entry) throw new Error(`Unknown Cactus model_id: ${model_id}`);\n\n const assets = [entry.assets.weights, entry.assets.vocab, entry.assets.config];\n for (let i = 0; i < assets.length; i++) {\n emit({\n type: \"phase\",\n message: `Downloading ${assets[i]}`,\n progress: Math.round(((i + 0.5) / assets.length) * 99),\n });\n await fetchAssetBytes(model, assets[i]);\n }\n markModelCached(model_id);\n emit({ type: \"finish\", data: { model: input.model! } });\n};\n",
|
|
15
15
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type {\n AiProviderRunFn,\n ModelDownloadRemoveTaskRunInput,\n ModelDownloadRemoveTaskRunOutput,\n} from \"@workglow/ai\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\nimport { removeCachedAssets } from \"./Cactus_Runtime\";\n\nexport const Cactus_DownloadRemove: AiProviderRunFn<\n ModelDownloadRemoveTaskRunInput,\n ModelDownloadRemoveTaskRunOutput,\n CactusModelConfig\n> = async (input, model, _signal, emit) => {\n if (!model) throw new Error(\"Model config is required for ModelDownloadRemoveTask.\");\n await removeCachedAssets(model);\n emit({ type: \"finish\", data: { model: input.model } });\n};\n",
|
|
16
|
-
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { AiProviderRunFn, ModelInfoTaskInput, ModelInfoTaskOutput } from \"@workglow/ai\";\nimport { getCactusCatalogEntry } from \"./Cactus_ModelCatalog\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\nimport { isModelCached, isModelLoaded } from \"./Cactus_Runtime\";\n\nexport const Cactus_ModelInfo: AiProviderRunFn<\n ModelInfoTaskInput,\n ModelInfoTaskOutput,\n CactusModelConfig\n> = async (input, model,
|
|
16
|
+
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { AiProviderRunFn, ModelInfoTaskInput, ModelInfoTaskOutput } from \"@workglow/ai\";\nimport { getCactusCatalogEntry } from \"./Cactus_ModelCatalog\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\nimport { getCactusModelCacheInfo, isModelCached, isModelLoaded } from \"./Cactus_Runtime\";\n\nexport const Cactus_ModelInfo: AiProviderRunFn<\n ModelInfoTaskInput,\n ModelInfoTaskOutput,\n CactusModelConfig\n> = async (input, model, signal, emit) => {\n if (!model) throw new Error(\"Model config is required for ModelInfoTask.\");\n const model_id = model.provider_config.model_id;\n const entry = getCactusCatalogEntry(model_id);\n if (!entry) throw new Error(`Unknown Cactus model_id: ${model_id}`);\n\n const is_loaded = isModelLoaded(model_id);\n const cacheInfo = await getCactusModelCacheInfo(model, entry, input.detail, signal);\n const is_cached = is_loaded || isModelCached(model_id) || cacheInfo.allCached;\n\n emit({\n type: \"finish\",\n data: {\n model: input.model,\n is_local: true,\n is_remote: false,\n supports_browser: true,\n supports_node: true,\n is_cached,\n is_loaded,\n file_sizes: cacheInfo.file_sizes,\n },\n });\n};\n",
|
|
17
17
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type {\n AiProviderRunFn,\n ModelSearchResultItem,\n ModelSearchTaskInput,\n ModelSearchTaskOutput,\n} from \"@workglow/ai\";\nimport { LOCAL_CACTUS } from \"./Cactus_Constants\";\nimport { CACTUS_CATALOG } from \"./Cactus_ModelCatalog\";\n\nexport const Cactus_ModelSearch: AiProviderRunFn<\n ModelSearchTaskInput,\n ModelSearchTaskOutput\n> = async (input, _model, _signal, emit) => {\n const query = (input.query ?? \"\").trim().toLowerCase();\n const results: ModelSearchResultItem[] = CACTUS_CATALOG.filter(\n (e) =>\n !query || e.model_id.toLowerCase().includes(query) || e.title.toLowerCase().includes(query)\n ).map((e) => ({\n id: e.model_id,\n label: e.title,\n description: e.description,\n record: {\n model_id: e.model_id,\n title: e.title,\n description: e.description,\n provider: LOCAL_CACTUS,\n provider_config: { model_id: e.model_id },\n capabilities: [...e.capabilities],\n metadata: {},\n },\n raw: e,\n }));\n emit({ type: \"finish\", data: { results } });\n};\n",
|
|
18
|
-
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type {\n AiProviderRunFn,\n ToolCallingTaskInput,\n ToolCallingTaskOutput,\n ToolCalls,\n ToolDefinition,\n} from \"@workglow/ai\";\nimport { extractMessageText } from \"@workglow/ai/provider-utils\";\nimport { filterValidToolCalls } from \"@workglow/ai/worker\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\nimport { getOrLoadEngine } from \"./Cactus_Runtime\";\n\nfunction buildToolsJson(tools: ReadonlyArray<ToolDefinition>): string {\n return JSON.stringify(\n tools.map((t) => ({\n name: t.name,\n ...(t.description ? { description: t.description } : {}),\n ...(t.inputSchema ? { parameters: t.inputSchema } : {}),\n }))\n );\n}\n\nfunction promptText(input: ToolCallingTaskInput): string {\n if (typeof input.prompt === \"string\") return input.prompt;\n if (input.prompt) return extractMessageText(input.prompt);\n if (input.messages && input.messages.length > 0) {\n const last = input.messages[input.messages.length - 1];\n return extractMessageText(last.content);\n }\n return \"\";\n}\n\nfunction parseToolCalls(raw: string): ToolCalls {\n if (!raw) return [];\n try {\n const obj = JSON.parse(raw);\n if (Array.isArray(obj)) {\n return obj.map((o, i) => ({\n id: `call_${i}`,\n name: String(o.name ?? \"\"),\n input: (o.arguments ?? o.params ?? {}) as Record<string, unknown>,\n }));\n }\n if (obj && typeof obj === \"object\" && typeof obj.name === \"string\") {\n return [\n {\n id: \"call_0\",\n name: obj.name,\n input: (obj.arguments ?? obj.params ?? {}) as Record<string, unknown>,\n },\n ];\n }\n } catch {\n /* fall through */\n }\n return [];\n}\n\nexport const Cactus_ToolCalling: AiProviderRunFn<\n ToolCallingTaskInput,\n ToolCallingTaskOutput,\n CactusModelConfig\n> = async (input, model, signal, emit) => {\n if (!model) throw new Error(\"Model config is required for ToolCallingTask.\");\n if (signal.aborted) throw signal.reason ?? new Error(\"The operation was aborted\");\n\n const engine = await getOrLoadEngine(model);\n const query = promptText(input);\n const toolsJson = buildToolsJson(input.tools);\n\n let raw = \"\";\n const engineWithStream = engine as unknown as {\n run_stream?: (q: string, t: string, cb: (chunk: string) => void) => Promise<string>;\n run: (q: string, t: string) => Promise<string> | string;\n };\n\n if (typeof engineWithStream.run_stream === \"function\") {\n raw = await engineWithStream.run_stream(query, toolsJson, (chunk) => {\n emit({ type: \"text-delta\", port: \"text\", textDelta: chunk });\n });\n } else {\n const out = await engineWithStream.run(query, toolsJson);\n raw = typeof out === \"string\" ? out : String(out);\n }\n\n const parsed: ToolCalls = parseToolCalls(raw);\n const validToolCalls = filterValidToolCalls(parsed, input.tools);\n if (validToolCalls.length > 0) {\n emit({ type: \"object-delta\", port: \"toolCalls\", objectDelta: [...validToolCalls] });\n }\n emit({ type: \"finish\", data: { text: raw, toolCalls: validToolCalls } });\n};\n",
|
|
18
|
+
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type {\n AiProviderRunFn,\n ToolCallingTaskInput,\n ToolCallingTaskOutput,\n ToolCalls,\n ToolDefinition,\n} from \"@workglow/ai\";\nimport { extractMessageText } from \"@workglow/ai/provider-utils\";\nimport { filterValidToolCalls, sanitizeToolArgs } from \"@workglow/ai/worker\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\nimport { getOrLoadEngine } from \"./Cactus_Runtime\";\n\nfunction buildToolsJson(tools: ReadonlyArray<ToolDefinition>): string {\n return JSON.stringify(\n tools.map((t) => ({\n name: t.name,\n ...(t.description ? { description: t.description } : {}),\n ...(t.inputSchema ? { parameters: t.inputSchema } : {}),\n }))\n );\n}\n\nfunction promptText(input: ToolCallingTaskInput): string {\n if (typeof input.prompt === \"string\") return input.prompt;\n if (input.prompt) return extractMessageText(input.prompt);\n if (input.messages && input.messages.length > 0) {\n const last = input.messages[input.messages.length - 1];\n return extractMessageText(last.content);\n }\n return \"\";\n}\n\nfunction parseToolCalls(raw: string): ToolCalls {\n if (!raw) return [];\n try {\n const obj = JSON.parse(raw);\n if (Array.isArray(obj)) {\n return obj.map((o, i) => ({\n id: `call_${i}`,\n name: String(o.name ?? \"\"),\n input: sanitizeToolArgs(o.arguments ?? o.params ?? {}) as Record<string, unknown>,\n }));\n }\n if (obj && typeof obj === \"object\" && typeof obj.name === \"string\") {\n return [\n {\n id: \"call_0\",\n name: obj.name,\n input: sanitizeToolArgs(obj.arguments ?? obj.params ?? {}) as Record<string, unknown>,\n },\n ];\n }\n } catch {\n /* fall through */\n }\n return [];\n}\n\nexport const Cactus_ToolCalling: AiProviderRunFn<\n ToolCallingTaskInput,\n ToolCallingTaskOutput,\n CactusModelConfig\n> = async (input, model, signal, emit) => {\n if (!model) throw new Error(\"Model config is required for ToolCallingTask.\");\n if (signal.aborted) throw signal.reason ?? new Error(\"The operation was aborted\");\n\n const engine = await getOrLoadEngine(model);\n const query = promptText(input);\n const toolsJson = buildToolsJson(input.tools);\n\n let raw = \"\";\n const engineWithStream = engine as unknown as {\n run_stream?: (q: string, t: string, cb: (chunk: string) => void) => Promise<string>;\n run: (q: string, t: string) => Promise<string> | string;\n };\n\n if (typeof engineWithStream.run_stream === \"function\") {\n raw = await engineWithStream.run_stream(query, toolsJson, (chunk) => {\n emit({ type: \"text-delta\", port: \"text\", textDelta: chunk });\n });\n } else {\n const out = await engineWithStream.run(query, toolsJson);\n raw = typeof out === \"string\" ? out : String(out);\n }\n\n const parsed: ToolCalls = parseToolCalls(raw);\n const validToolCalls = filterValidToolCalls(parsed, input.tools);\n if (validToolCalls.length > 0) {\n emit({ type: \"object-delta\", port: \"toolCalls\", objectDelta: [...validToolCalls] });\n }\n emit({ type: \"finish\", data: { text: raw, toolCalls: validToolCalls } });\n};\n",
|
|
19
19
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport type { AiProviderRunFnRegistration } from \"@workglow/ai\";\nimport {\n CACTUS_MODEL_DOWNLOAD,\n CACTUS_MODEL_DOWNLOAD_REMOVE,\n CACTUS_MODEL_INFO,\n CACTUS_MODEL_SEARCH,\n CACTUS_TOOL_USE,\n} from \"./Cactus_CapabilitySets\";\nimport { Cactus_Download } from \"./Cactus_Download\";\nimport { Cactus_DownloadRemove } from \"./Cactus_DownloadRemove\";\nimport { Cactus_ModelInfo } from \"./Cactus_ModelInfo\";\nimport type { CactusModelConfig } from \"./Cactus_ModelSchema\";\nimport { Cactus_ModelSearch } from \"./Cactus_ModelSearch\";\nimport { Cactus_ToolCalling } from \"./Cactus_ToolCalling\";\n\nexport {\n cactusConfigJson,\n cactusEngines,\n deleteCactusSession,\n disposeCactusResources,\n getOrLoadEngine,\n loadSdk,\n removeCachedAssets,\n} from \"./Cactus_Runtime\";\n\nexport const CACTUS_RUN_FNS: readonly AiProviderRunFnRegistration<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n any,\n CactusModelConfig\n>[] = [\n { serves: CACTUS_TOOL_USE, runFn: Cactus_ToolCalling },\n { serves: CACTUS_MODEL_DOWNLOAD, runFn: Cactus_Download },\n { serves: CACTUS_MODEL_DOWNLOAD_REMOVE, runFn: Cactus_DownloadRemove },\n { serves: CACTUS_MODEL_SEARCH, runFn: Cactus_ModelSearch },\n { serves: CACTUS_MODEL_INFO, runFn: Cactus_ModelInfo },\n];\n\n/** No preview-only tasks for Cactus today. */\nexport const CACTUS_PREVIEW_TASKS = {} as const;\n",
|
|
20
20
|
"/**\n * @license\n * Copyright 2026 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\n// organize-imports-ignore\n\nexport * from \"./ai/common/Cactus_Constants\";\nexport * from \"./ai/common/Cactus_ModelCatalog\";\nexport * from \"./ai/common/Cactus_ModelSchema\";\n// Mutable runtime state (e.g. cactusEngines, cactusEngineLoadsInFlight,\n// cactusConfigJson, cactusSessions) is intentionally NOT re-exported here.\n// The `./ai` and `./ai-runtime` entry points are bundled separately, so\n// re-exporting from both creates two distinct module instances — and reads\n// on one would not see writes from the other. Import runtime state from\n// `@workglow/cactus/ai-runtime` instead.\nexport * from \"./ai/CactusProvider\";\nexport * from \"./ai/CactusQueuedProvider\";\nexport * from \"./ai/registerCactus\";\n\nimport { CactusQueuedProvider } from \"./ai/CactusQueuedProvider\";\nimport { CACTUS_RUN_FN_SPECS } from \"./ai/common/Cactus_Capabilities\";\nimport { CACTUS_RUN_FNS } from \"./ai/common/Cactus_JobRunFns\";\nimport { cactusConfigJson, cactusEngines } from \"./ai/common/Cactus_Runtime\";\n\n/**\n * @internal Symbols exported only for use by `@workglow/test`. Not part of the stable public API.\n *\n * `cactusEngines` and `cactusConfigJson` are re-exported here so that tests can\n * seed and inspect the runtime state used by the run-fns bundled into the `./ai`\n * entry point. The `./ai` and `./ai-runtime` entry points are bundled separately\n * — their copies of `Cactus_Runtime.ts` are distinct module instances. Reading\n * the runtime state via `_testOnly` (rather than `@workglow/cactus/ai-runtime`)\n * guarantees the test observes the same Map that the run-fns mutate.\n */\nexport const _testOnly = {\n CactusQueuedProvider,\n CACTUS_RUN_FN_SPECS,\n CACTUS_RUN_FNS,\n cactusEngines,\n cactusConfigJson,\n} as const;\n"
|
|
21
21
|
],
|
|
22
|
-
"mappings": "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",
|
|
23
|
-
"debugId": "
|
|
22
|
+
"mappings": "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",
|
|
23
|
+
"debugId": "0F1861CAFC26D69864756E2164756E21",
|
|
24
24
|
"names": []
|
|
25
25
|
}
|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "@workglow/cactus",
|
|
3
3
|
"type": "module",
|
|
4
4
|
"sideEffects": false,
|
|
5
|
-
"version": "0.3.
|
|
5
|
+
"version": "0.3.5",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
8
8
|
"url": "https://github.com/workglow-dev/libs.git",
|
|
@@ -44,11 +44,11 @@
|
|
|
44
44
|
"needle-rs": "^0.1.0"
|
|
45
45
|
},
|
|
46
46
|
"peerDependencies": {
|
|
47
|
-
"@workglow/ai": "0.3.
|
|
48
|
-
"@workglow/job-queue": "0.3.
|
|
49
|
-
"@workglow/storage": "0.3.
|
|
50
|
-
"@workglow/task-graph": "0.3.
|
|
51
|
-
"@workglow/util": "0.3.
|
|
47
|
+
"@workglow/ai": "0.3.5",
|
|
48
|
+
"@workglow/job-queue": "0.3.5",
|
|
49
|
+
"@workglow/storage": "0.3.5",
|
|
50
|
+
"@workglow/task-graph": "0.3.5",
|
|
51
|
+
"@workglow/util": "0.3.5"
|
|
52
52
|
},
|
|
53
53
|
"peerDependenciesMeta": {
|
|
54
54
|
"@workglow/ai": {
|
|
@@ -68,11 +68,11 @@
|
|
|
68
68
|
}
|
|
69
69
|
},
|
|
70
70
|
"devDependencies": {
|
|
71
|
-
"@workglow/ai": "0.3.
|
|
72
|
-
"@workglow/job-queue": "0.3.
|
|
73
|
-
"@workglow/storage": "0.3.
|
|
74
|
-
"@workglow/task-graph": "0.3.
|
|
75
|
-
"@workglow/util": "0.3.
|
|
71
|
+
"@workglow/ai": "0.3.5",
|
|
72
|
+
"@workglow/job-queue": "0.3.5",
|
|
73
|
+
"@workglow/storage": "0.3.5",
|
|
74
|
+
"@workglow/task-graph": "0.3.5",
|
|
75
|
+
"@workglow/util": "0.3.5"
|
|
76
76
|
},
|
|
77
77
|
"files": [
|
|
78
78
|
"dist",
|