@workglow/test 0.0.57 → 0.0.59
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/binding/IndexedDbModelRepository.d.ts +17 -0
- package/dist/binding/IndexedDbModelRepository.d.ts.map +1 -0
- package/dist/binding/PostgresModelRepository.d.ts +18 -0
- package/dist/binding/PostgresModelRepository.d.ts.map +1 -0
- package/dist/binding/SqliteModelRepository.d.ts +17 -0
- package/dist/binding/SqliteModelRepository.d.ts.map +1 -0
- package/dist/browser.d.ts +0 -2
- package/dist/browser.d.ts.map +1 -1
- package/dist/browser.js +207 -189
- package/dist/browser.js.map +7 -9
- package/dist/bun.js +203 -213
- package/dist/bun.js.map +7 -11
- package/dist/common-server.d.ts +0 -4
- package/dist/common-server.d.ts.map +1 -1
- package/dist/node.js +203 -213
- package/dist/node.js.map +7 -11
- package/dist/samples/MediaPipeModelSamples.d.ts.map +1 -1
- package/dist/samples/ONNXModelSamples.d.ts +0 -2
- package/dist/samples/ONNXModelSamples.d.ts.map +1 -1
- package/dist/samples/index.d.ts.map +1 -1
- package/dist/test/ai-model/IndexedDbModelRepository.test.d.ts.map +1 -1
- package/dist/test/helpers/SupabaseMockClient.d.ts.map +1 -1
- package/dist/test/job-queue/InMemoryPrefixedQueueStorage.test.d.ts +7 -0
- package/dist/test/job-queue/InMemoryPrefixedQueueStorage.test.d.ts.map +1 -0
- package/dist/test/job-queue/IndexedDbPrefixedQueueStorage.test.d.ts +7 -0
- package/dist/test/job-queue/IndexedDbPrefixedQueueStorage.test.d.ts.map +1 -0
- package/dist/test/job-queue/PostgresPrefixedQueueStorage.test.d.ts +7 -0
- package/dist/test/job-queue/PostgresPrefixedQueueStorage.test.d.ts.map +1 -0
- package/dist/test/job-queue/SqlitePrefixedQueueStorage.test.d.ts +7 -0
- package/dist/test/job-queue/SqlitePrefixedQueueStorage.test.d.ts.map +1 -0
- package/dist/test/job-queue/SupabasePrefixedQueueStorage.test.d.ts +7 -0
- package/dist/test/job-queue/SupabasePrefixedQueueStorage.test.d.ts.map +1 -0
- package/dist/test/job-queue/genericJobQueueTests.d.ts +8 -4
- package/dist/test/job-queue/genericJobQueueTests.d.ts.map +1 -1
- package/dist/test/job-queue/genericPrefixedQueueStorageTests.d.ts +18 -0
- package/dist/test/job-queue/genericPrefixedQueueStorageTests.d.ts.map +1 -0
- package/dist/test/job-queue/genericQueueStorageSubscriptionTests.d.ts +29 -0
- package/dist/test/job-queue/genericQueueStorageSubscriptionTests.d.ts.map +1 -0
- package/dist/test/storage-tabular/genericTabularRepositorySubscriptionTests.d.ts +17 -0
- package/dist/test/storage-tabular/genericTabularRepositorySubscriptionTests.d.ts.map +1 -0
- package/dist/test/storage-tabular/genericTabularRepositoryTests.d.ts +38 -1
- package/dist/test/storage-tabular/genericTabularRepositoryTests.d.ts.map +1 -1
- package/dist/test/task-graph-job-queue/IndexedDbTaskGraphJobQueue.test.d.ts.map +1 -1
- package/dist/test/task-graph-job-queue/genericTaskGraphJobQueueTests.d.ts +3 -3
- package/dist/test/task-graph-job-queue/genericTaskGraphJobQueueTests.d.ts.map +1 -1
- package/package.json +17 -17
- package/dist/binding/InMemoryJobQueue.d.ts +0 -11
- package/dist/binding/InMemoryJobQueue.d.ts.map +0 -1
- package/dist/binding/IndexedDbJobQueue.d.ts +0 -11
- package/dist/binding/IndexedDbJobQueue.d.ts.map +0 -1
- package/dist/binding/PostgresJobQueue.d.ts +0 -11
- package/dist/binding/PostgresJobQueue.d.ts.map +0 -1
- package/dist/binding/SqliteJobQueue.d.ts +0 -11
- package/dist/binding/SqliteJobQueue.d.ts.map +0 -1
package/dist/node.js
CHANGED
|
@@ -35,182 +35,229 @@ class InMemoryTaskOutputRepository extends TaskOutputTabularRepository {
|
|
|
35
35
|
// src/samples/index.ts
|
|
36
36
|
import { AiJob } from "@workglow/ai";
|
|
37
37
|
import { TENSORFLOW_MEDIAPIPE as TENSORFLOW_MEDIAPIPE2 } from "@workglow/ai-provider";
|
|
38
|
-
import { ConcurrencyLimiter,
|
|
38
|
+
import { ConcurrencyLimiter, JobQueueClient, JobQueueServer } from "@workglow/job-queue";
|
|
39
39
|
import { InMemoryQueueStorage } from "@workglow/storage";
|
|
40
40
|
import { getTaskQueueRegistry } from "@workglow/task-graph";
|
|
41
41
|
|
|
42
42
|
// src/samples/MediaPipeModelSamples.ts
|
|
43
43
|
import { getGlobalModelRepository } from "@workglow/ai";
|
|
44
44
|
import { TENSORFLOW_MEDIAPIPE } from "@workglow/ai-provider";
|
|
45
|
-
async function addMediaPipeModel(info, tasks) {
|
|
46
|
-
const name = "mediapipe:" + info.name;
|
|
47
|
-
const model = Object.assign({
|
|
48
|
-
provider: TENSORFLOW_MEDIAPIPE,
|
|
49
|
-
quantization: null,
|
|
50
|
-
normalize: true,
|
|
51
|
-
contextWindow: 4096,
|
|
52
|
-
availableOnBrowser: true,
|
|
53
|
-
availableOnServer: false,
|
|
54
|
-
parameters: null,
|
|
55
|
-
languageStyle: null,
|
|
56
|
-
usingDimensions: info.nativeDimensions ?? null
|
|
57
|
-
}, info, { name });
|
|
58
|
-
await getGlobalModelRepository().addModel(model);
|
|
59
|
-
await Promise.allSettled(tasks.map((task) => getGlobalModelRepository().connectTaskToModel(task, name)));
|
|
60
|
-
}
|
|
61
45
|
async function registerMediaPipeTfJsLocalModels() {
|
|
62
|
-
await
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
46
|
+
await getGlobalModelRepository().addModel({
|
|
47
|
+
model_id: "media-pipe:Universal Sentence Encoder",
|
|
48
|
+
title: "Universal Sentence Encoder",
|
|
49
|
+
description: "Universal Sentence Encoder",
|
|
50
|
+
tasks: ["TextEmbeddingTask"],
|
|
51
|
+
provider: TENSORFLOW_MEDIAPIPE,
|
|
52
|
+
providerConfig: {
|
|
53
|
+
modelPath: "https://storage.googleapis.com/mediapipe-tasks/text_embedder/universal_sentence_encoder.tflite"
|
|
54
|
+
},
|
|
55
|
+
metadata: {}
|
|
56
|
+
});
|
|
57
|
+
await getGlobalModelRepository().addModel({
|
|
58
|
+
model_id: "media-pipe:Text Encoder",
|
|
59
|
+
title: "Text Encoder",
|
|
60
|
+
description: "Text Encoder",
|
|
61
|
+
tasks: ["TextEmbeddingTask"],
|
|
62
|
+
provider: TENSORFLOW_MEDIAPIPE,
|
|
63
|
+
providerConfig: {
|
|
64
|
+
modelPath: "https://huggingface.co/keras-sd/text-encoder-tflite/resolve/main/text_encoder.tflite?download=true"
|
|
65
|
+
},
|
|
66
|
+
metadata: {}
|
|
67
|
+
});
|
|
74
68
|
}
|
|
75
69
|
// src/samples/ONNXModelSamples.ts
|
|
76
70
|
import { getGlobalModelRepository as getGlobalModelRepository2 } from "@workglow/ai";
|
|
77
|
-
import { HF_TRANSFORMERS_ONNX
|
|
78
|
-
async function addONNXModel(info, tasks) {
|
|
79
|
-
const model = Object.assign({
|
|
80
|
-
name: "onnx:" + info.url + ":" + (info.quantization ?? QUANTIZATION_DATA_TYPES.q8),
|
|
81
|
-
provider: HF_TRANSFORMERS_ONNX,
|
|
82
|
-
quantization: QUANTIZATION_DATA_TYPES.q8,
|
|
83
|
-
normalize: true,
|
|
84
|
-
contextWindow: 4096,
|
|
85
|
-
availableOnBrowser: true,
|
|
86
|
-
availableOnServer: true,
|
|
87
|
-
parameters: null,
|
|
88
|
-
languageStyle: null,
|
|
89
|
-
usingDimensions: info.nativeDimensions ?? null
|
|
90
|
-
}, info);
|
|
91
|
-
await getGlobalModelRepository2().addModel(model);
|
|
92
|
-
await Promise.allSettled(tasks.map((task) => getGlobalModelRepository2().connectTaskToModel(task, model.name)));
|
|
93
|
-
}
|
|
71
|
+
import { HF_TRANSFORMERS_ONNX } from "@workglow/ai-provider";
|
|
94
72
|
async function registerHuggingfaceLocalModels() {
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
73
|
+
const onnxModels = [
|
|
74
|
+
{
|
|
75
|
+
model_id: "onnx:Supabase/gte-small",
|
|
76
|
+
title: "gte-small",
|
|
77
|
+
description: "Supabase/gte-small",
|
|
78
|
+
tasks: ["TextEmbeddingTask"],
|
|
79
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
80
|
+
providerConfig: {
|
|
81
|
+
pipeline: "feature-extraction",
|
|
82
|
+
modelPath: "Supabase/gte-small"
|
|
83
|
+
},
|
|
84
|
+
metadata: {}
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
model_id: "onnx:Xenova/bge-base-en-v1.5",
|
|
88
|
+
title: "bge-base-en-v1.5",
|
|
89
|
+
description: "Xenova/bge-base-en-v1.5",
|
|
90
|
+
tasks: ["TextEmbeddingTask"],
|
|
91
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
92
|
+
providerConfig: {
|
|
93
|
+
pipeline: "feature-extraction",
|
|
94
|
+
modelPath: "Xenova/bge-base-en-v1.5"
|
|
95
|
+
},
|
|
96
|
+
metadata: {}
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
model_id: "onnx:Xenova/distilbert-base-uncased-distilled-squad",
|
|
100
|
+
title: "distilbert-base-uncased-distilled-squad",
|
|
101
|
+
description: "Xenova/distilbert-base-uncased-distilled-squad",
|
|
102
|
+
tasks: ["TextQuestionAnsweringTask"],
|
|
103
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
104
|
+
providerConfig: {
|
|
105
|
+
pipeline: "question-answering",
|
|
106
|
+
modelPath: "Xenova/distilbert-base-uncased-distilled-squad"
|
|
107
|
+
},
|
|
108
|
+
metadata: {}
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
model_id: "onnx:answerdotai/ModernBERT-base",
|
|
112
|
+
title: "ModernBERT-base",
|
|
113
|
+
description: "answerdotai/ModernBERT-base",
|
|
114
|
+
tasks: ["TextClassificationTask"],
|
|
115
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
116
|
+
providerConfig: {
|
|
117
|
+
pipeline: "feature-extraction",
|
|
118
|
+
modelPath: "Xenova/multi-qa-mpnet-base-dot-v1"
|
|
119
|
+
},
|
|
120
|
+
metadata: {}
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
model_id: "onnx:Xenova/gpt2",
|
|
124
|
+
title: "gpt2",
|
|
125
|
+
description: "Xenova/gpt2",
|
|
126
|
+
tasks: ["TextGenerationTask"],
|
|
127
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
128
|
+
providerConfig: {
|
|
129
|
+
pipeline: "text-generation",
|
|
130
|
+
modelPath: "Xenova/gpt2"
|
|
131
|
+
},
|
|
132
|
+
metadata: {}
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
model_id: "onnx:Xenova/Phi-3-mini-4k-instruct:q4f16",
|
|
136
|
+
title: "Phi-3-mini-4k-instruct:q4f16",
|
|
137
|
+
description: "Xenova/Phi-3-mini-4k-instruct:q4f16",
|
|
138
|
+
tasks: ["TextGenerationTask"],
|
|
139
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
140
|
+
providerConfig: {
|
|
141
|
+
pipeline: "text-generation",
|
|
142
|
+
modelPath: "onnx-community/DeepSeek-R1-Distill-Qwen-1.5B-ONNX"
|
|
143
|
+
},
|
|
144
|
+
metadata: {}
|
|
145
|
+
},
|
|
146
|
+
{
|
|
147
|
+
model_id: "onnx:Xenova/distilgpt2",
|
|
148
|
+
title: "distilgpt2",
|
|
149
|
+
description: "Xenova/distilgpt2",
|
|
150
|
+
tasks: ["TextGenerationTask"],
|
|
151
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
152
|
+
providerConfig: {
|
|
153
|
+
pipeline: "text-generation",
|
|
154
|
+
modelPath: "Xenova/distilgpt2"
|
|
155
|
+
},
|
|
156
|
+
metadata: {}
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
model_id: "onnx:Xenova/LaMini-Flan-T5-783M",
|
|
160
|
+
title: "LaMini-Flan-T5-783M",
|
|
161
|
+
description: "Xenova/LaMini-Flan-T5-783M",
|
|
162
|
+
tasks: ["TextGenerationTask", "TextRewriterTask"],
|
|
163
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
164
|
+
providerConfig: {
|
|
165
|
+
pipeline: "text2text-generation",
|
|
166
|
+
modelPath: "Xenova/LaMini-Flan-T5-783M"
|
|
167
|
+
},
|
|
168
|
+
metadata: {}
|
|
169
|
+
},
|
|
170
|
+
{
|
|
171
|
+
model_id: "onnx:Falconsai/text_summarization",
|
|
172
|
+
title: "text_summarization",
|
|
173
|
+
description: "Falconsai/text_summarization",
|
|
174
|
+
tasks: ["TextSummaryTask"],
|
|
175
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
176
|
+
providerConfig: {
|
|
177
|
+
pipeline: "summarization",
|
|
178
|
+
modelPath: "Falconsai/text_summarization"
|
|
179
|
+
},
|
|
180
|
+
metadata: {}
|
|
181
|
+
},
|
|
182
|
+
{
|
|
183
|
+
model_id: "onnx:Xenova/nllb-200-distilled-600M",
|
|
184
|
+
title: "nllb-200-distilled-600M",
|
|
185
|
+
description: "Xenova/nllb-200-distilled-600M",
|
|
186
|
+
tasks: ["TextTranslationTask"],
|
|
187
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
188
|
+
providerConfig: {
|
|
189
|
+
pipeline: "translation",
|
|
190
|
+
modelPath: "Xenova/nllb-200-distilled-600M",
|
|
191
|
+
languageStyle: "FLORES-200"
|
|
192
|
+
},
|
|
193
|
+
metadata: {}
|
|
194
|
+
},
|
|
195
|
+
{
|
|
196
|
+
model_id: "onnx:Xenova/m2m100_418M",
|
|
197
|
+
title: "m2m100_418M",
|
|
198
|
+
description: "Xenova/m2m100_418M",
|
|
199
|
+
tasks: ["TextTranslationTask"],
|
|
200
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
201
|
+
providerConfig: {
|
|
202
|
+
pipeline: "translation",
|
|
203
|
+
modelPath: "Xenova/m2m100_418M",
|
|
204
|
+
languageStyle: "ISO-639"
|
|
205
|
+
},
|
|
206
|
+
metadata: {}
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
model_id: "onnx:Xenova/mbart-large-50-many-to-many-mmt",
|
|
210
|
+
title: "mbart-large-50-many-to-many-mmt",
|
|
211
|
+
description: "Xenova/mbart-large-50-many-to-many-mmt",
|
|
212
|
+
tasks: ["TextTranslationTask"],
|
|
213
|
+
provider: HF_TRANSFORMERS_ONNX,
|
|
214
|
+
providerConfig: {
|
|
215
|
+
pipeline: "translation",
|
|
216
|
+
modelPath: "Xenova/mbart-large-50-many-to-many-mmt",
|
|
217
|
+
languageStyle: "ISO-639_ISO-3166-1-alpha-2"
|
|
218
|
+
},
|
|
219
|
+
metadata: {}
|
|
220
|
+
}
|
|
221
|
+
];
|
|
222
|
+
for (const model of onnxModels) {
|
|
223
|
+
await getGlobalModelRepository2().addModel(model);
|
|
224
|
+
}
|
|
196
225
|
}
|
|
197
226
|
|
|
198
227
|
// src/samples/index.ts
|
|
199
228
|
async function register_HFT_InMemoryQueue() {
|
|
200
|
-
const
|
|
201
|
-
|
|
229
|
+
const queueName = "HF_TRANSFORMERS_ONNX";
|
|
230
|
+
const storage = new InMemoryQueueStorage(queueName);
|
|
231
|
+
await storage.setupDatabase();
|
|
232
|
+
const server = new JobQueueServer(AiJob, {
|
|
233
|
+
storage,
|
|
234
|
+
queueName,
|
|
202
235
|
limiter: new ConcurrencyLimiter(1, 10)
|
|
203
236
|
});
|
|
204
|
-
|
|
205
|
-
|
|
237
|
+
const client = new JobQueueClient({
|
|
238
|
+
storage,
|
|
239
|
+
queueName
|
|
240
|
+
});
|
|
241
|
+
client.attach(server);
|
|
242
|
+
getTaskQueueRegistry().registerQueue({ server, client, storage });
|
|
243
|
+
await server.start();
|
|
206
244
|
}
|
|
207
245
|
async function register_TFMP_InMemoryQueue() {
|
|
208
|
-
const
|
|
209
|
-
|
|
246
|
+
const queueName = TENSORFLOW_MEDIAPIPE2;
|
|
247
|
+
const storage = new InMemoryQueueStorage(queueName);
|
|
248
|
+
await storage.setupDatabase();
|
|
249
|
+
const server = new JobQueueServer(AiJob, {
|
|
250
|
+
storage,
|
|
251
|
+
queueName,
|
|
210
252
|
limiter: new ConcurrencyLimiter(1, 10)
|
|
211
253
|
});
|
|
212
|
-
|
|
213
|
-
|
|
254
|
+
const client = new JobQueueClient({
|
|
255
|
+
storage,
|
|
256
|
+
queueName
|
|
257
|
+
});
|
|
258
|
+
client.attach(server);
|
|
259
|
+
getTaskQueueRegistry().registerQueue({ server, client, storage });
|
|
260
|
+
await server.start();
|
|
214
261
|
}
|
|
215
262
|
// src/binding/FsFolderTaskGraphRepository.ts
|
|
216
263
|
import { FsFolderTabularRepository } from "@workglow/storage";
|
|
@@ -348,82 +395,25 @@ class SqliteTaskOutputRepository extends TaskOutputTabularRepository5 {
|
|
|
348
395
|
});
|
|
349
396
|
}
|
|
350
397
|
}
|
|
351
|
-
// src/binding/IndexedDbJobQueue.ts
|
|
352
|
-
import { JobQueue as JobQueue2 } from "@workglow/job-queue";
|
|
353
|
-
import { IndexedDbQueueStorage } from "@workglow/storage";
|
|
354
|
-
import { createServiceToken as createServiceToken11 } from "@workglow/util";
|
|
355
|
-
var INDEXED_DB_JOB_QUEUE = createServiceToken11("jobQueue.indexedDb");
|
|
356
|
-
|
|
357
|
-
class IndexedDbJobQueue extends JobQueue2 {
|
|
358
|
-
constructor(queueName, jobCls, options) {
|
|
359
|
-
options.storage ??= new IndexedDbQueueStorage(queueName);
|
|
360
|
-
super(queueName, jobCls, options);
|
|
361
|
-
}
|
|
362
|
-
}
|
|
363
|
-
// src/binding/InMemoryJobQueue.ts
|
|
364
|
-
import { JobQueue as JobQueue3 } from "@workglow/job-queue";
|
|
365
|
-
import { InMemoryQueueStorage as InMemoryQueueStorage2 } from "@workglow/storage";
|
|
366
|
-
import { createServiceToken as createServiceToken12 } from "@workglow/util";
|
|
367
|
-
var IN_MEMORY_JOB_QUEUE = createServiceToken12("jobQueue.inMemory");
|
|
368
|
-
|
|
369
|
-
class InMemoryJobQueue extends JobQueue3 {
|
|
370
|
-
constructor(queueName, jobCls, options) {
|
|
371
|
-
options.storage ??= new InMemoryQueueStorage2(queueName);
|
|
372
|
-
super(queueName, jobCls, options);
|
|
373
|
-
}
|
|
374
|
-
}
|
|
375
|
-
// src/binding/PostgresJobQueue.ts
|
|
376
|
-
import { JobQueue as JobQueue4 } from "@workglow/job-queue";
|
|
377
|
-
import { PostgresQueueStorage } from "@workglow/storage";
|
|
378
|
-
import { createServiceToken as createServiceToken13 } from "@workglow/util";
|
|
379
|
-
var POSTGRES_JOB_QUEUE = createServiceToken13("jobQueue.postgres");
|
|
380
|
-
|
|
381
|
-
class PostgresJobQueue extends JobQueue4 {
|
|
382
|
-
constructor(db, queueName, jobCls, options) {
|
|
383
|
-
options.storage = new PostgresQueueStorage(db, queueName);
|
|
384
|
-
super(queueName, jobCls, options);
|
|
385
|
-
}
|
|
386
|
-
}
|
|
387
|
-
// src/binding/SqliteJobQueue.ts
|
|
388
|
-
import { JobQueue as JobQueue5 } from "@workglow/job-queue";
|
|
389
|
-
import { SqliteQueueStorage } from "@workglow/storage";
|
|
390
|
-
import { createServiceToken as createServiceToken14 } from "@workglow/util";
|
|
391
|
-
var SQLITE_JOB_QUEUE = createServiceToken14("jobQueue.sqlite");
|
|
392
|
-
|
|
393
|
-
class SqliteJobQueue extends JobQueue5 {
|
|
394
|
-
constructor(db, queueName, jobCls, options) {
|
|
395
|
-
options.storage = new SqliteQueueStorage(db, queueName);
|
|
396
|
-
super(queueName, jobCls, options);
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
398
|
export {
|
|
400
399
|
register_TFMP_InMemoryQueue,
|
|
401
400
|
register_HFT_InMemoryQueue,
|
|
402
401
|
registerMediaPipeTfJsLocalModels,
|
|
403
402
|
registerHuggingfaceLocalModels,
|
|
404
|
-
addONNXModel,
|
|
405
403
|
SqliteTaskOutputRepository,
|
|
406
404
|
SqliteTaskGraphRepository,
|
|
407
|
-
SqliteJobQueue,
|
|
408
405
|
SQLITE_TASK_OUTPUT_REPOSITORY,
|
|
409
406
|
SQLITE_TASK_GRAPH_REPOSITORY,
|
|
410
|
-
SQLITE_JOB_QUEUE,
|
|
411
407
|
PostgresTaskOutputRepository,
|
|
412
408
|
PostgresTaskGraphRepository,
|
|
413
|
-
PostgresJobQueue,
|
|
414
409
|
POSTGRES_TASK_OUTPUT_REPOSITORY,
|
|
415
410
|
POSTGRES_TASK_GRAPH_REPOSITORY,
|
|
416
|
-
POSTGRES_JOB_QUEUE,
|
|
417
411
|
MEMORY_TASK_OUTPUT_REPOSITORY,
|
|
418
412
|
MEMORY_TASK_GRAPH_REPOSITORY,
|
|
419
413
|
IndexedDbTaskOutputRepository,
|
|
420
414
|
IndexedDbTaskGraphRepository,
|
|
421
|
-
IndexedDbJobQueue,
|
|
422
415
|
InMemoryTaskOutputRepository,
|
|
423
416
|
InMemoryTaskGraphRepository,
|
|
424
|
-
InMemoryJobQueue,
|
|
425
|
-
IN_MEMORY_JOB_QUEUE,
|
|
426
|
-
INDEXED_DB_JOB_QUEUE,
|
|
427
417
|
IDB_TASK_OUTPUT_REPOSITORY,
|
|
428
418
|
IDB_TASK_GRAPH_REPOSITORY,
|
|
429
419
|
FsFolderTaskOutputRepository,
|
|
@@ -432,4 +422,4 @@ export {
|
|
|
432
422
|
FS_FOLDER_TASK_GRAPH_REPOSITORY
|
|
433
423
|
};
|
|
434
424
|
|
|
435
|
-
//# debugId=
|
|
425
|
+
//# debugId=61727D658F5B46C964756E2164756E21
|
package/dist/node.js.map
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/binding/InMemoryTaskGraphRepository.ts", "../src/binding/InMemoryTaskOutputRepository.ts", "../src/samples/index.ts", "../src/samples/MediaPipeModelSamples.ts", "../src/samples/ONNXModelSamples.ts", "../src/binding/FsFolderTaskGraphRepository.ts", "../src/binding/IndexedDbTaskGraphRepository.ts", "../src/binding/PostgresTaskGraphRepository.ts", "../src/binding/SqliteTaskGraphRepository.ts", "../src/binding/FsFolderTaskOutputRepository.ts", "../src/binding/IndexedDbTaskOutputRepository.ts", "../src/binding/PostgresTaskOutputRepository.ts", "../src/binding/SqliteTaskOutputRepository.ts"
|
|
3
|
+
"sources": ["../src/binding/InMemoryTaskGraphRepository.ts", "../src/binding/InMemoryTaskOutputRepository.ts", "../src/samples/index.ts", "../src/samples/MediaPipeModelSamples.ts", "../src/samples/ONNXModelSamples.ts", "../src/binding/FsFolderTaskGraphRepository.ts", "../src/binding/IndexedDbTaskGraphRepository.ts", "../src/binding/PostgresTaskGraphRepository.ts", "../src/binding/SqliteTaskGraphRepository.ts", "../src/binding/FsFolderTaskOutputRepository.ts", "../src/binding/IndexedDbTaskOutputRepository.ts", "../src/binding/PostgresTaskOutputRepository.ts", "../src/binding/SqliteTaskOutputRepository.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { InMemoryTabularRepository } from \"@workglow/storage\";\nimport {\n TaskGraphPrimaryKeyNames,\n TaskGraphSchema,\n TaskGraphTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const MEMORY_TASK_GRAPH_REPOSITORY = createServiceToken<TaskGraphTabularRepository>(\n \"taskgraph.taskGraphRepository.inMemory\"\n);\n\n/**\n * In-memory implementation of a task graph repository.\n * Provides storage and retrieval for task graphs.\n */\nexport class InMemoryTaskGraphRepository extends TaskGraphTabularRepository {\n constructor() {\n super({\n tabularRepository: new InMemoryTabularRepository(TaskGraphSchema, TaskGraphPrimaryKeyNames),\n });\n }\n}\n",
|
|
6
6
|
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { InMemoryTabularRepository } from \"@workglow/storage\";\nimport {\n TaskOutputPrimaryKeyNames,\n TaskOutputSchema,\n TaskOutputTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const MEMORY_TASK_OUTPUT_REPOSITORY = createServiceToken<InMemoryTaskOutputRepository>(\n \"taskgraph.taskOutputRepository.inMemory\"\n);\n\n/**\n * In-memory implementation of a task output repository.\n * Provides storage and retrieval for task outputs.\n */\nexport class InMemoryTaskOutputRepository extends TaskOutputTabularRepository {\n constructor() {\n super({\n tabularRepository: new InMemoryTabularRepository(\n TaskOutputSchema,\n TaskOutputPrimaryKeyNames,\n [\"createdAt\"]\n ),\n });\n }\n}\n",
|
|
7
|
-
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { AiJob, AiJobInput } from \"@workglow/ai\";\nimport { TENSORFLOW_MEDIAPIPE } from \"@workglow/ai-provider\";\nimport { ConcurrencyLimiter,
|
|
8
|
-
"import { getGlobalModelRepository
|
|
9
|
-
"import { getGlobalModelRepository
|
|
7
|
+
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { AiJob, AiJobInput } from \"@workglow/ai\";\nimport { TENSORFLOW_MEDIAPIPE } from \"@workglow/ai-provider\";\nimport { ConcurrencyLimiter, JobQueueClient, JobQueueServer } from \"@workglow/job-queue\";\nimport { InMemoryQueueStorage } from \"@workglow/storage\";\nimport { getTaskQueueRegistry, TaskInput, TaskOutput } from \"@workglow/task-graph\";\nexport * from \"./MediaPipeModelSamples\";\nexport * from \"./ONNXModelSamples\";\n\nexport async function register_HFT_InMemoryQueue(): Promise<void> {\n const queueName = \"HF_TRANSFORMERS_ONNX\";\n const storage = new InMemoryQueueStorage<AiJobInput<TaskInput>, TaskOutput>(queueName);\n await storage.setupDatabase();\n\n const server = new JobQueueServer<AiJobInput<TaskInput>, TaskOutput>(\n AiJob<AiJobInput<TaskInput>, TaskOutput>,\n {\n storage,\n queueName,\n limiter: new ConcurrencyLimiter(1, 10),\n }\n );\n\n const client = new JobQueueClient<AiJobInput<TaskInput>, TaskOutput>({\n storage,\n queueName,\n });\n\n client.attach(server);\n\n getTaskQueueRegistry().registerQueue({ server, client, storage });\n await server.start();\n}\n\nexport async function register_TFMP_InMemoryQueue(): Promise<void> {\n const queueName = TENSORFLOW_MEDIAPIPE;\n const storage = new InMemoryQueueStorage<AiJobInput<TaskInput>, TaskOutput>(queueName);\n await storage.setupDatabase();\n\n const server = new JobQueueServer<AiJobInput<TaskInput>, TaskOutput>(\n AiJob<AiJobInput<TaskInput>, TaskOutput>,\n {\n storage,\n queueName,\n limiter: new ConcurrencyLimiter(1, 10),\n }\n );\n\n const client = new JobQueueClient<AiJobInput<TaskInput>, TaskOutput>({\n storage,\n queueName,\n });\n\n client.attach(server);\n\n getTaskQueueRegistry().registerQueue({ server, client, storage });\n await server.start();\n}\n",
|
|
8
|
+
"import { getGlobalModelRepository } from \"@workglow/ai\";\nimport { TENSORFLOW_MEDIAPIPE } from \"@workglow/ai-provider\";\n\nexport async function registerMediaPipeTfJsLocalModels(): Promise<void> {\n await getGlobalModelRepository().addModel({\n model_id: \"media-pipe:Universal Sentence Encoder\",\n title: \"Universal Sentence Encoder\",\n description: \"Universal Sentence Encoder\",\n tasks: [\"TextEmbeddingTask\"],\n provider: TENSORFLOW_MEDIAPIPE,\n providerConfig: {\n modelPath:\n \"https://storage.googleapis.com/mediapipe-tasks/text_embedder/universal_sentence_encoder.tflite\",\n },\n metadata: {},\n });\n\n await getGlobalModelRepository().addModel({\n model_id: \"media-pipe:Text Encoder\",\n title: \"Text Encoder\",\n description: \"Text Encoder\",\n tasks: [\"TextEmbeddingTask\"],\n provider: TENSORFLOW_MEDIAPIPE,\n providerConfig: {\n modelPath:\n \"https://huggingface.co/keras-sd/text-encoder-tflite/resolve/main/text_encoder.tflite?download=true\",\n },\n metadata: {},\n });\n}\n",
|
|
9
|
+
"import { getGlobalModelRepository } from \"@workglow/ai\";\nimport { HF_TRANSFORMERS_ONNX, HfTransformersOnnxModelRecord } from \"@workglow/ai-provider\";\n\nexport async function registerHuggingfaceLocalModels(): Promise<void> {\n const onnxModels: HfTransformersOnnxModelRecord[] = [\n {\n model_id: \"onnx:Supabase/gte-small\",\n title: \"gte-small\",\n description: \"Supabase/gte-small\",\n tasks: [\"TextEmbeddingTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"feature-extraction\",\n modelPath: \"Supabase/gte-small\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/bge-base-en-v1.5\",\n title: \"bge-base-en-v1.5\",\n description: \"Xenova/bge-base-en-v1.5\",\n tasks: [\"TextEmbeddingTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"feature-extraction\",\n modelPath: \"Xenova/bge-base-en-v1.5\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/distilbert-base-uncased-distilled-squad\",\n title: \"distilbert-base-uncased-distilled-squad\",\n description: \"Xenova/distilbert-base-uncased-distilled-squad\",\n tasks: [\"TextQuestionAnsweringTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"question-answering\",\n modelPath: \"Xenova/distilbert-base-uncased-distilled-squad\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:answerdotai/ModernBERT-base\",\n title: \"ModernBERT-base\",\n description: \"answerdotai/ModernBERT-base\",\n tasks: [\"TextClassificationTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"feature-extraction\",\n modelPath: \"Xenova/multi-qa-mpnet-base-dot-v1\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/gpt2\",\n title: \"gpt2\",\n description: \"Xenova/gpt2\",\n tasks: [\"TextGenerationTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"text-generation\",\n modelPath: \"Xenova/gpt2\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/Phi-3-mini-4k-instruct:q4f16\",\n title: \"Phi-3-mini-4k-instruct:q4f16\",\n description: \"Xenova/Phi-3-mini-4k-instruct:q4f16\",\n tasks: [\"TextGenerationTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"text-generation\",\n modelPath: \"onnx-community/DeepSeek-R1-Distill-Qwen-1.5B-ONNX\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/distilgpt2\",\n title: \"distilgpt2\",\n description: \"Xenova/distilgpt2\",\n tasks: [\"TextGenerationTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"text-generation\",\n modelPath: \"Xenova/distilgpt2\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/LaMini-Flan-T5-783M\",\n title: \"LaMini-Flan-T5-783M\",\n description: \"Xenova/LaMini-Flan-T5-783M\",\n tasks: [\"TextGenerationTask\", \"TextRewriterTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"text2text-generation\",\n modelPath: \"Xenova/LaMini-Flan-T5-783M\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Falconsai/text_summarization\",\n title: \"text_summarization\",\n description: \"Falconsai/text_summarization\",\n tasks: [\"TextSummaryTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"summarization\",\n modelPath: \"Falconsai/text_summarization\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/nllb-200-distilled-600M\",\n title: \"nllb-200-distilled-600M\",\n description: \"Xenova/nllb-200-distilled-600M\",\n tasks: [\"TextTranslationTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"translation\",\n modelPath: \"Xenova/nllb-200-distilled-600M\",\n languageStyle: \"FLORES-200\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/m2m100_418M\",\n title: \"m2m100_418M\",\n description: \"Xenova/m2m100_418M\",\n tasks: [\"TextTranslationTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"translation\",\n modelPath: \"Xenova/m2m100_418M\",\n languageStyle: \"ISO-639\",\n },\n metadata: {},\n },\n {\n model_id: \"onnx:Xenova/mbart-large-50-many-to-many-mmt\",\n title: \"mbart-large-50-many-to-many-mmt\",\n description: \"Xenova/mbart-large-50-many-to-many-mmt\",\n tasks: [\"TextTranslationTask\"],\n provider: HF_TRANSFORMERS_ONNX,\n providerConfig: {\n pipeline: \"translation\",\n modelPath: \"Xenova/mbart-large-50-many-to-many-mmt\",\n languageStyle: \"ISO-639_ISO-3166-1-alpha-2\",\n },\n metadata: {},\n },\n ];\n\n for (const model of onnxModels) {\n await getGlobalModelRepository().addModel(model);\n }\n}\n",
|
|
10
10
|
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { FsFolderTabularRepository } from \"@workglow/storage\";\nimport {\n TaskGraphPrimaryKeyNames,\n TaskGraphSchema,\n TaskGraphTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const FS_FOLDER_TASK_GRAPH_REPOSITORY = createServiceToken<TaskGraphTabularRepository>(\n \"taskgraph.taskGraphRepository.fsFolder\"\n);\n\n/**\n * File-based implementation of a task graph repository.\n * Provides storage and retrieval for task graphs using a file system.\n */\nexport class FsFolderTaskGraphRepository extends TaskGraphTabularRepository {\n constructor(folderPath: string) {\n super({\n tabularRepository: new FsFolderTabularRepository(\n folderPath,\n TaskGraphSchema,\n TaskGraphPrimaryKeyNames\n ),\n });\n }\n}\n",
|
|
11
11
|
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { IndexedDbTabularRepository } from \"@workglow/storage\";\nimport {\n TaskGraphPrimaryKeyNames,\n TaskGraphSchema,\n TaskGraphTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const IDB_TASK_GRAPH_REPOSITORY = createServiceToken<TaskGraphTabularRepository>(\n \"taskgraph.taskGraphRepository.indexedDb\"\n);\n\n/**\n * IndexedDB implementation of a task graph repository.\n * Provides storage and retrieval for task graphs using IndexedDB.\n */\nexport class IndexedDbTaskGraphRepository extends TaskGraphTabularRepository {\n constructor(table: string = \"task_graphs\") {\n super({\n tabularRepository: new IndexedDbTabularRepository(\n table,\n TaskGraphSchema,\n TaskGraphPrimaryKeyNames\n ),\n });\n }\n}\n",
|
|
12
12
|
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { PostgresTabularRepository } from \"@workglow/storage\";\nimport {\n TaskGraphPrimaryKeyNames,\n TaskGraphSchema,\n TaskGraphTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\nimport type { Pool } from \"pg\";\n\nexport const POSTGRES_TASK_GRAPH_REPOSITORY = createServiceToken<TaskGraphTabularRepository>(\n \"taskgraph.taskGraphRepository.postgres\"\n);\n\n/**\n * PostgreSQL implementation of a task graph repository.\n * Provides storage and retrieval for task graphs using PostgreSQL.\n */\nexport class PostgresTaskGraphRepository extends TaskGraphTabularRepository {\n constructor(db: Pool, table: string = \"task_graphs\") {\n super({\n tabularRepository: new PostgresTabularRepository(\n db,\n table,\n TaskGraphSchema,\n TaskGraphPrimaryKeyNames\n ),\n });\n }\n}\n",
|
|
@@ -14,13 +14,9 @@
|
|
|
14
14
|
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { FsFolderTabularRepository } from \"@workglow/storage\";\nimport {\n TaskOutputPrimaryKeyNames,\n TaskOutputSchema,\n TaskOutputTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const FS_FOLDER_TASK_OUTPUT_REPOSITORY = createServiceToken<FsFolderTaskOutputRepository>(\n \"taskgraph.taskOutputRepository.fsFolder\"\n);\n\n/**\n * File system folder implementation of a task output repository.\n * Provides storage and retrieval for task outputs using the file system.\n */\nexport class FsFolderTaskOutputRepository extends TaskOutputTabularRepository {\n constructor(folderPath: string) {\n super({\n tabularRepository: new FsFolderTabularRepository(\n folderPath,\n TaskOutputSchema,\n TaskOutputPrimaryKeyNames\n ),\n });\n }\n}\n",
|
|
15
15
|
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { IndexedDbTabularRepository } from \"@workglow/storage\";\nimport {\n TaskOutputPrimaryKeyNames,\n TaskOutputSchema,\n TaskOutputTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const IDB_TASK_OUTPUT_REPOSITORY = createServiceToken<IndexedDbTaskOutputRepository>(\n \"taskgraph.taskOutputRepository.indexedDb\"\n);\n\n/**\n * IndexedDB implementation of a task output repository.\n * Provides storage and retrieval for task outputs using IndexedDB.\n */\nexport class IndexedDbTaskOutputRepository extends TaskOutputTabularRepository {\n constructor(table: string = \"task_outputs\") {\n super({\n tabularRepository: new IndexedDbTabularRepository(\n table,\n TaskOutputSchema,\n TaskOutputPrimaryKeyNames,\n [\"createdAt\"]\n ),\n });\n }\n}\n",
|
|
16
16
|
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { PostgresTabularRepository } from \"@workglow/storage\";\nimport {\n TaskOutputPrimaryKeyNames,\n TaskOutputSchema,\n TaskOutputTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\nimport type { Pool } from \"pg\";\n\nexport const POSTGRES_TASK_OUTPUT_REPOSITORY = createServiceToken<PostgresTaskOutputRepository>(\n \"taskgraph.taskOutputRepository.postgres\"\n);\n\n/**\n * PostgreSQL implementation of a task output repository.\n * Provides storage and retrieval for task outputs using PostgreSQL.\n */\nexport class PostgresTaskOutputRepository extends TaskOutputTabularRepository {\n constructor(db: Pool, table: string = \"task_outputs\") {\n super({\n tabularRepository: new PostgresTabularRepository(\n db,\n table,\n TaskOutputSchema,\n TaskOutputPrimaryKeyNames,\n [\"createdAt\"]\n ),\n });\n }\n}\n",
|
|
17
|
-
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { SqliteTabularRepository } from \"@workglow/storage\";\nimport {\n TaskOutputPrimaryKeyNames,\n TaskOutputSchema,\n TaskOutputTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const SQLITE_TASK_OUTPUT_REPOSITORY = createServiceToken<SqliteTaskOutputRepository>(\n \"taskgraph.taskOutputRepository.sqlite\"\n);\n\n/**\n * SQLite implementation of a task output repository.\n * Provides storage and retrieval for task outputs using SQLite.\n */\nexport class SqliteTaskOutputRepository extends TaskOutputTabularRepository {\n constructor(dbOrPath: string, table: string = \"task_outputs\") {\n super({\n tabularRepository: new SqliteTabularRepository(\n dbOrPath,\n table,\n TaskOutputSchema,\n TaskOutputPrimaryKeyNames,\n [\"createdAt\"]\n ),\n });\n }\n}\n"
|
|
18
|
-
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Job, JobConstructorParam, JobQueue, JobQueueOptions } from \"@workglow/job-queue\";\nimport { IndexedDbQueueStorage } from \"@workglow/storage\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const INDEXED_DB_JOB_QUEUE =\n createServiceToken<JobQueue<any, any, any>>(\"jobQueue.indexedDb\");\n\nexport class IndexedDbJobQueue<I, O, C extends Job<I, O>> extends JobQueue<I, O, C> {\n constructor(\n queueName: string,\n jobCls: new (param: JobConstructorParam<I, O>) => C,\n options: JobQueueOptions<I, O>\n ) {\n options.storage ??= new IndexedDbQueueStorage<I, O>(queueName);\n super(queueName, jobCls, options);\n }\n}\n",
|
|
19
|
-
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Job, JobConstructorParam, JobQueue, JobQueueOptions } from \"@workglow/job-queue\";\nimport { InMemoryQueueStorage } from \"@workglow/storage\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const IN_MEMORY_JOB_QUEUE = createServiceToken<JobQueue<any, any, any>>(\"jobQueue.inMemory\");\n\nexport class InMemoryJobQueue<I, O, C extends Job<I, O>> extends JobQueue<I, O, C> {\n constructor(\n queueName: string,\n jobCls: new (param: JobConstructorParam<I, O>) => C,\n options: JobQueueOptions<I, O>\n ) {\n options.storage ??= new InMemoryQueueStorage<I, O>(queueName);\n super(queueName, jobCls, options);\n }\n}\n",
|
|
20
|
-
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Job, JobConstructorParam, JobQueue, JobQueueOptions } from \"@workglow/job-queue\";\nimport { PostgresQueueStorage } from \"@workglow/storage\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const POSTGRES_JOB_QUEUE = createServiceToken<JobQueue<any, any, any>>(\"jobQueue.postgres\");\n\nexport class PostgresJobQueue<I, O, C extends Job<I, O>> extends JobQueue<I, O, C> {\n constructor(\n db: any,\n queueName: string,\n jobCls: new (param: JobConstructorParam<I, O>) => C,\n options: JobQueueOptions<I, O>\n ) {\n options.storage = new PostgresQueueStorage<I, O>(db, queueName);\n super(queueName, jobCls, options);\n }\n}\n",
|
|
21
|
-
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Job, JobConstructorParam, JobQueue, JobQueueOptions } from \"@workglow/job-queue\";\nimport { SqliteQueueStorage } from \"@workglow/storage\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const SQLITE_JOB_QUEUE = createServiceToken<JobQueue<any, any, any>>(\"jobQueue.sqlite\");\n\nexport class SqliteJobQueue<I, O, C extends Job<I, O>> extends JobQueue<I, O, C> {\n constructor(\n db: any,\n queueName: string,\n jobCls: new (param: JobConstructorParam<I, O>) => C,\n options: JobQueueOptions<I, O>\n ) {\n options.storage = new SqliteQueueStorage<I, O>(db, queueName);\n super(queueName, jobCls, options);\n }\n}\n"
|
|
17
|
+
"/**\n * @license\n * Copyright 2025 Steven Roussey <sroussey@gmail.com>\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { SqliteTabularRepository } from \"@workglow/storage\";\nimport {\n TaskOutputPrimaryKeyNames,\n TaskOutputSchema,\n TaskOutputTabularRepository,\n} from \"@workglow/task-graph\";\nimport { createServiceToken } from \"@workglow/util\";\n\nexport const SQLITE_TASK_OUTPUT_REPOSITORY = createServiceToken<SqliteTaskOutputRepository>(\n \"taskgraph.taskOutputRepository.sqlite\"\n);\n\n/**\n * SQLite implementation of a task output repository.\n * Provides storage and retrieval for task outputs using SQLite.\n */\nexport class SqliteTaskOutputRepository extends TaskOutputTabularRepository {\n constructor(dbOrPath: string, table: string = \"task_outputs\") {\n super({\n tabularRepository: new SqliteTabularRepository(\n dbOrPath,\n table,\n TaskOutputSchema,\n TaskOutputPrimaryKeyNames,\n [\"createdAt\"]\n ),\n });\n }\n}\n"
|
|
22
18
|
],
|
|
23
|
-
"mappings": ";AAMA;AACA;AAAA;AAAA;AAAA;AAAA;AAKA;AAEO,IAAM,+BAA+B,mBAC1C,wCACF;AAAA;AAMO,MAAM,oCAAoC,2BAA2B;AAAA,EAC1E,WAAW,GAAG;AAAA,IACZ,MAAM;AAAA,MACJ,mBAAmB,IAAI,0BAA0B,iBAAiB,wBAAwB;AAAA,IAC5F,CAAC;AAAA;AAEL;;ACtBA,sCAAS;AACT;AAAA;AAAA;AAAA;AAAA;AAKA,+BAAS;AAEF,IAAM,gCAAgC,oBAC3C,yCACF;AAAA;AAMO,MAAM,qCAAqC,4BAA4B;AAAA,EAC5E,WAAW,GAAG;AAAA,IACZ,MAAM;AAAA,MACJ,mBAAmB,IAAI,2BACrB,kBACA,2BACA,CAAC,WAAW,CACd;AAAA,IACF,CAAC;AAAA;AAEL;;AC1BA;AACA,iCAAS;AACT;AACA;AACA;;;ACVA;AACA;AAEA,
|
|
24
|
-
"debugId": "
|
|
19
|
+
"mappings": "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",
|
|
20
|
+
"debugId": "61727D658F5B46C964756E2164756E21",
|
|
25
21
|
"names": []
|
|
26
22
|
}
|