@fdm-monster/server 2.0.6 → 2.0.8
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/.yarn/install-state.gz +0 -0
- package/RELEASE_NOTES.MD +31 -0
- package/dist/consoles/bambu-mqtt-diagnostic.console.js +565 -0
- package/dist/consoles/bambu-mqtt-diagnostic.console.js.map +1 -0
- package/dist/consoles/mock-bambu.server.js +114 -88
- package/dist/consoles/mock-bambu.server.js.map +1 -1
- package/dist/controllers/file-storage.controller.js +34 -14
- package/dist/controllers/file-storage.controller.js.map +1 -1
- package/dist/controllers/print-job.controller.js +33 -236
- package/dist/controllers/print-job.controller.js.map +1 -1
- package/dist/controllers/print-queue.controller.js +82 -17
- package/dist/controllers/print-queue.controller.js.map +1 -1
- package/dist/controllers/printer-files.controller.js +8 -2
- package/dist/controllers/printer-files.controller.js.map +1 -1
- package/dist/controllers/printer.controller.js +3 -3
- package/dist/controllers/printer.controller.js.map +1 -1
- package/dist/entities/print-job.entity.js.map +1 -1
- package/dist/server.constants.js +1 -1
- package/dist/services/bambu/bambu-ftp.adapter.js +13 -21
- package/dist/services/bambu/bambu-ftp.adapter.js.map +1 -1
- package/dist/services/bambu/bambu-mqtt.adapter.js +86 -32
- package/dist/services/bambu/bambu-mqtt.adapter.js.map +1 -1
- package/dist/services/bambu/bambu.client.js.map +1 -1
- package/dist/services/bambu.api.js +12 -24
- package/dist/services/bambu.api.js.map +1 -1
- package/dist/services/file-storage.service.js +11 -2
- package/dist/services/file-storage.service.js.map +1 -1
- package/dist/services/moonraker/moonraker.client.js +5 -17
- package/dist/services/moonraker/moonraker.client.js.map +1 -1
- package/dist/services/moonraker.api.js +3 -2
- package/dist/services/moonraker.api.js.map +1 -1
- package/dist/services/octoprint/octoprint.client.js +5 -17
- package/dist/services/octoprint/octoprint.client.js.map +1 -1
- package/dist/services/octoprint.api.js +3 -2
- package/dist/services/octoprint.api.js.map +1 -1
- package/dist/services/orm/print-job.service.js +55 -47
- package/dist/services/orm/print-job.service.js.map +1 -1
- package/dist/services/print-queue.service.js +90 -30
- package/dist/services/print-queue.service.js.map +1 -1
- package/dist/services/printer-api.interface.js +13 -0
- package/dist/services/printer-api.interface.js.map +1 -1
- package/dist/services/prusa-link/prusa-link.api.js +12 -22
- package/dist/services/prusa-link/prusa-link.api.js.map +1 -1
- package/dist/tasks/print-job-analysis.task.js.map +1 -1
- package/dist/utils/bgcode/bgcode-thumbnail.parser.js +50 -0
- package/dist/utils/bgcode/bgcode-thumbnail.parser.js.map +1 -0
- package/dist/utils/bgcode/bgcode.constants.js +57 -0
- package/dist/utils/bgcode/bgcode.constants.js.map +1 -0
- package/dist/utils/bgcode/bgcode.types.js +132 -0
- package/dist/utils/bgcode/bgcode.types.js.map +1 -0
- package/dist/utils/bgcode/bgcode.utils.js +288 -0
- package/dist/utils/bgcode/bgcode.utils.js.map +1 -0
- package/dist/utils/bgcode/heatshrink-decoder.js +172 -0
- package/dist/utils/bgcode/heatshrink-decoder.js.map +1 -0
- package/dist/utils/bgcode/png-encoder.js +76 -0
- package/dist/utils/bgcode/png-encoder.js.map +1 -0
- package/dist/utils/bgcode/qoi-decoder.js +141 -0
- package/dist/utils/bgcode/qoi-decoder.js.map +1 -0
- package/dist/utils/image-dimensions.js +62 -0
- package/dist/utils/image-dimensions.js.map +1 -0
- package/dist/utils/job-stats.util.js +79 -0
- package/dist/utils/job-stats.util.js.map +1 -0
- package/dist/utils/parsers/3mf.parser.js +39 -9
- package/dist/utils/parsers/3mf.parser.js.map +1 -1
- package/dist/utils/parsers/bgcode.parser.js +125 -144
- package/dist/utils/parsers/bgcode.parser.js.map +1 -1
- package/dist/utils/parsers/gcode.parser.js +13 -2
- package/dist/utils/parsers/gcode.parser.js.map +1 -1
- package/dist/utils/parsers/parser.types.js +6 -0
- package/dist/utils/parsers/parser.types.js.map +1 -0
- package/dist/utils/thumbnail.util.js +24 -0
- package/dist/utils/thumbnail.util.js.map +1 -0
- package/package.json +13 -10
|
@@ -21,6 +21,7 @@ const _filestorageservice = require("../services/file-storage.service");
|
|
|
21
21
|
const _loggerfactory = require("../handlers/logger-factory");
|
|
22
22
|
const _paramconvertermiddleware = require("../middleware/param-converter.middleware");
|
|
23
23
|
const _runtimeexceptions = require("../exceptions/runtime.exceptions");
|
|
24
|
+
const _thumbnailutil = require("../utils/thumbnail.util");
|
|
24
25
|
function _ts_decorate(decorators, target, key, desc) {
|
|
25
26
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
26
27
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
@@ -51,8 +52,21 @@ class PrintJobController {
|
|
|
51
52
|
const { page, pageSize, searchPrinter, searchFile, startDate, endDate } = await (0, _validators.validateInput)(req.query, _printjobvalidation.searchJobsPagedSchema);
|
|
52
53
|
const endDateObj = endDate ? this.toEndOfDay(new Date(endDate)) : undefined;
|
|
53
54
|
const [items, count] = await this.printJobService.searchPrintJobsPaged(searchPrinter, searchFile, startDate ? new Date(startDate) : undefined, endDateObj, page, pageSize);
|
|
55
|
+
const itemsWithThumbnails = await Promise.all(items.map(async (job)=>{
|
|
56
|
+
let thumbnails = [];
|
|
57
|
+
if (job.fileStorageId) {
|
|
58
|
+
try {
|
|
59
|
+
const metadata = await this.fileStorageService.loadMetadata(job.fileStorageId);
|
|
60
|
+
thumbnails = (0, _thumbnailutil.extractThumbnailsFromMetadata)(metadata);
|
|
61
|
+
} catch {}
|
|
62
|
+
}
|
|
63
|
+
return {
|
|
64
|
+
...job,
|
|
65
|
+
thumbnails
|
|
66
|
+
};
|
|
67
|
+
}));
|
|
54
68
|
res.send({
|
|
55
|
-
items,
|
|
69
|
+
items: itemsWithThumbnails,
|
|
56
70
|
count,
|
|
57
71
|
pages: Math.ceil(count / pageSize)
|
|
58
72
|
});
|
|
@@ -63,15 +77,14 @@ class PrintJobController {
|
|
|
63
77
|
'printer'
|
|
64
78
|
]);
|
|
65
79
|
try {
|
|
66
|
-
let
|
|
80
|
+
let thumbnails = [];
|
|
67
81
|
if (job.fileStorageId) {
|
|
68
|
-
const
|
|
69
|
-
|
|
82
|
+
const metadata = await this.fileStorageService.loadMetadata(job.fileStorageId);
|
|
83
|
+
thumbnails = (0, _thumbnailutil.extractThumbnailsFromMetadata)(metadata);
|
|
70
84
|
}
|
|
71
85
|
res.send({
|
|
72
86
|
...job,
|
|
73
|
-
|
|
74
|
-
thumbnailsUrl: thumbnailCount > 0 ? `/api/print-jobs/${jobId}/thumbnails` : null
|
|
87
|
+
thumbnails
|
|
75
88
|
});
|
|
76
89
|
} catch (error) {
|
|
77
90
|
this.logger.error(`Failed to get job ${jobId}: ${error}`);
|
|
@@ -84,36 +97,23 @@ class PrintJobController {
|
|
|
84
97
|
const jobId = req.local.id;
|
|
85
98
|
const job = await this.printJobService.getJobByIdOrFail(jobId);
|
|
86
99
|
try {
|
|
87
|
-
if (
|
|
100
|
+
if ([
|
|
101
|
+
"PENDING",
|
|
102
|
+
"QUEUED"
|
|
103
|
+
].includes(job.status)) {
|
|
88
104
|
res.status(400).send({
|
|
89
|
-
error: "Can only mark
|
|
105
|
+
error: "Can only mark jobs which are not \"PENDING\" | \"QUEUED\" as completed",
|
|
90
106
|
currentStatus: job.status,
|
|
91
107
|
suggestion: "This endpoint is for resolving jobs with unknown state"
|
|
92
108
|
});
|
|
93
109
|
return;
|
|
94
110
|
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
job.endedAt = new Date();
|
|
98
|
-
job.progress = 100;
|
|
99
|
-
job.statusReason = "Manually marked as completed by user";
|
|
100
|
-
if (job.statistics) {
|
|
101
|
-
job.statistics.endedAt = job.endedAt;
|
|
102
|
-
job.statistics.progress = 100;
|
|
103
|
-
} else {
|
|
104
|
-
job.statistics = {
|
|
105
|
-
startedAt: job.startedAt,
|
|
106
|
-
endedAt: job.endedAt,
|
|
107
|
-
actualPrintTimeSeconds: null,
|
|
108
|
-
progress: 100
|
|
109
|
-
};
|
|
110
|
-
}
|
|
111
|
-
await this.printJobService.printJobRepository.save(job);
|
|
112
|
-
this.logger.log(`Job ${jobId} marked as COMPLETED`);
|
|
111
|
+
const previousStatus = job.status;
|
|
112
|
+
await this.printJobService.markAsCompleted(jobId);
|
|
113
113
|
res.send({
|
|
114
114
|
message: "Job marked as completed",
|
|
115
115
|
jobId,
|
|
116
|
-
previousStatus
|
|
116
|
+
previousStatus,
|
|
117
117
|
newStatus: "COMPLETED"
|
|
118
118
|
});
|
|
119
119
|
} catch (error) {
|
|
@@ -141,29 +141,7 @@ class PrintJobController {
|
|
|
141
141
|
return;
|
|
142
142
|
}
|
|
143
143
|
try {
|
|
144
|
-
this.
|
|
145
|
-
const endedAt = new Date();
|
|
146
|
-
const actualTimeSeconds = job.startedAt ? (endedAt.getTime() - job.startedAt.getTime()) / 1000 : null;
|
|
147
|
-
job.status = "FAILED";
|
|
148
|
-
job.endedAt = endedAt;
|
|
149
|
-
job.statusReason = "Manually marked as failed by user";
|
|
150
|
-
if (!job.statistics) {
|
|
151
|
-
job.statistics = {
|
|
152
|
-
startedAt: job.startedAt,
|
|
153
|
-
endedAt,
|
|
154
|
-
actualPrintTimeSeconds: actualTimeSeconds,
|
|
155
|
-
progress: job.progress,
|
|
156
|
-
failureReason: "Manually marked as failed by user",
|
|
157
|
-
failureTime: endedAt
|
|
158
|
-
};
|
|
159
|
-
} else {
|
|
160
|
-
job.statistics.endedAt = endedAt;
|
|
161
|
-
job.statistics.actualPrintTimeSeconds = actualTimeSeconds;
|
|
162
|
-
job.statistics.failureReason = "Manually marked as failed by user";
|
|
163
|
-
job.statistics.failureTime = endedAt;
|
|
164
|
-
}
|
|
165
|
-
await this.printJobService.printJobRepository.save(job);
|
|
166
|
-
this.logger.log(`Job ${jobId} marked as FAILED`);
|
|
144
|
+
await this.printJobService.markAsFailed(jobId, "Manually marked as failed by user");
|
|
167
145
|
res.send({
|
|
168
146
|
message: "Job marked as failed",
|
|
169
147
|
jobId,
|
|
@@ -194,25 +172,7 @@ class PrintJobController {
|
|
|
194
172
|
return;
|
|
195
173
|
}
|
|
196
174
|
try {
|
|
197
|
-
this.
|
|
198
|
-
const endedAt = new Date();
|
|
199
|
-
const actualTimeSeconds = job.startedAt ? (endedAt.getTime() - job.startedAt.getTime()) / 1000 : null;
|
|
200
|
-
job.status = "CANCELLED";
|
|
201
|
-
job.endedAt = endedAt;
|
|
202
|
-
job.statusReason = "Manually marked as cancelled by user";
|
|
203
|
-
if (!job.statistics) {
|
|
204
|
-
job.statistics = {
|
|
205
|
-
startedAt: job.startedAt,
|
|
206
|
-
endedAt,
|
|
207
|
-
actualPrintTimeSeconds: actualTimeSeconds,
|
|
208
|
-
progress: job.progress
|
|
209
|
-
};
|
|
210
|
-
} else {
|
|
211
|
-
job.statistics.endedAt = endedAt;
|
|
212
|
-
job.statistics.actualPrintTimeSeconds = actualTimeSeconds;
|
|
213
|
-
}
|
|
214
|
-
await this.printJobService.printJobRepository.save(job);
|
|
215
|
-
this.logger.log(`Job ${jobId} marked as CANCELLED`);
|
|
175
|
+
await this.printJobService.markAsCancelled(jobId, "Manually marked as cancelled by user");
|
|
216
176
|
res.send({
|
|
217
177
|
message: "Job marked as cancelled",
|
|
218
178
|
jobId,
|
|
@@ -243,11 +203,7 @@ class PrintJobController {
|
|
|
243
203
|
return;
|
|
244
204
|
}
|
|
245
205
|
try {
|
|
246
|
-
this.
|
|
247
|
-
job.status = "UNKNOWN";
|
|
248
|
-
job.statusReason = "Manually marked as unknown by user (state uncertain)";
|
|
249
|
-
await this.printJobService.printJobRepository.save(job);
|
|
250
|
-
this.logger.log(`Job ${jobId} marked as UNKNOWN`);
|
|
206
|
+
await this.printJobService.markAsUnknown(jobId);
|
|
251
207
|
res.send({
|
|
252
208
|
message: "Job marked as unknown",
|
|
253
209
|
jobId,
|
|
@@ -284,7 +240,7 @@ class PrintJobController {
|
|
|
284
240
|
}
|
|
285
241
|
this.logger.log(`Re-analyzing file for job ${jobId}: ${filePath}`);
|
|
286
242
|
job.analysisState = "ANALYZING";
|
|
287
|
-
await this.printJobService.
|
|
243
|
+
await this.printJobService.updateJob(job);
|
|
288
244
|
const { metadata, thumbnails } = await this.fileAnalysisService.analyzeFile(filePath);
|
|
289
245
|
let thumbnailMetadata = [];
|
|
290
246
|
if (thumbnails && thumbnails.length > 0) {
|
|
@@ -325,14 +281,10 @@ class PrintJobController {
|
|
|
325
281
|
try {
|
|
326
282
|
const fileStorageId = job.fileStorageId;
|
|
327
283
|
const fileName = job.fileName;
|
|
328
|
-
await this.printJobService.
|
|
284
|
+
await this.printJobService.deleteJob(job);
|
|
329
285
|
this.logger.log(`Deleted job ${jobId}: ${fileName}`);
|
|
330
286
|
if (fileStorageId && deleteFileParam) {
|
|
331
|
-
const otherJobs = await this.printJobService.
|
|
332
|
-
where: {
|
|
333
|
-
fileStorageId
|
|
334
|
-
}
|
|
335
|
-
});
|
|
287
|
+
const otherJobs = await this.printJobService.countJobsReferencingFile(fileStorageId);
|
|
336
288
|
if (otherJobs === 0) {
|
|
337
289
|
try {
|
|
338
290
|
await this.fileStorageService.deleteFile(fileStorageId);
|
|
@@ -374,124 +326,6 @@ class PrintJobController {
|
|
|
374
326
|
});
|
|
375
327
|
}
|
|
376
328
|
}
|
|
377
|
-
async getThumbnails(req, res) {
|
|
378
|
-
const jobId = req.local.id;
|
|
379
|
-
const job = await this.printJobService.getJobByIdOrFail(jobId);
|
|
380
|
-
if (!job.fileStorageId) {
|
|
381
|
-
res.send({
|
|
382
|
-
jobId,
|
|
383
|
-
thumbnails: []
|
|
384
|
-
});
|
|
385
|
-
return;
|
|
386
|
-
}
|
|
387
|
-
try {
|
|
388
|
-
const metadata = await this.fileStorageService.loadMetadata(job.fileStorageId);
|
|
389
|
-
const thumbnailMetadata = metadata?._thumbnails || [];
|
|
390
|
-
res.send({
|
|
391
|
-
jobId,
|
|
392
|
-
fileStorageId: job.fileStorageId,
|
|
393
|
-
thumbnails: thumbnailMetadata.map((thumb)=>({
|
|
394
|
-
index: thumb.index,
|
|
395
|
-
url: `/api/print-jobs/${jobId}/thumbnails/${thumb.index}`,
|
|
396
|
-
filename: thumb.filename,
|
|
397
|
-
width: thumb.width,
|
|
398
|
-
height: thumb.height,
|
|
399
|
-
format: thumb.format,
|
|
400
|
-
size: thumb.size
|
|
401
|
-
}))
|
|
402
|
-
});
|
|
403
|
-
} catch (error) {
|
|
404
|
-
this.logger.error(`Failed to get thumbnails for job ${jobId}: ${error}`);
|
|
405
|
-
res.status(500).send({
|
|
406
|
-
error: "Failed to get thumbnails"
|
|
407
|
-
});
|
|
408
|
-
}
|
|
409
|
-
}
|
|
410
|
-
async getThumbnail(req, res) {
|
|
411
|
-
const jobId = req.local.id;
|
|
412
|
-
const index = req.local.index;
|
|
413
|
-
const job = await this.printJobService.getJobByIdOrFail(jobId);
|
|
414
|
-
if (!job.fileStorageId) {
|
|
415
|
-
throw new _runtimeexceptions.NotFoundException("Job has no stored file");
|
|
416
|
-
}
|
|
417
|
-
try {
|
|
418
|
-
const thumbnail = await this.fileStorageService.getThumbnail(job.fileStorageId, index);
|
|
419
|
-
if (!thumbnail) {
|
|
420
|
-
throw new _runtimeexceptions.NotFoundException(`Thumbnail ${index} not found`);
|
|
421
|
-
}
|
|
422
|
-
const isPNG = thumbnail[0] === 0x89 && thumbnail[1] === 0x50 && thumbnail[2] === 0x4E && thumbnail[3] === 0x47;
|
|
423
|
-
const isJPG = thumbnail[0] === 0xFF && thumbnail[1] === 0xD8;
|
|
424
|
-
const isQOI = thumbnail[0] === 0x71 && thumbnail[1] === 0x6F && thumbnail[2] === 0x69 && thumbnail[3] === 0x66;
|
|
425
|
-
let contentType = 'image/png';
|
|
426
|
-
if (isPNG) contentType = 'image/png';
|
|
427
|
-
else if (isJPG) contentType = 'image/jpeg';
|
|
428
|
-
else if (isQOI) contentType = 'image/qoi';
|
|
429
|
-
res.setHeader('Content-Type', contentType);
|
|
430
|
-
res.setHeader('Cache-Control', 'public, max-age=3600');
|
|
431
|
-
res.setHeader('ETag', `"${job.fileStorageId}-${index}"`);
|
|
432
|
-
res.setHeader('Cross-Origin-Resource-Policy', 'cross-origin');
|
|
433
|
-
res.send(thumbnail);
|
|
434
|
-
} catch (error) {
|
|
435
|
-
this.logger.error(`Failed to get thumbnail ${index} for job ${jobId}: ${error}`);
|
|
436
|
-
res.status(500).send({
|
|
437
|
-
error: "Failed to get thumbnail"
|
|
438
|
-
});
|
|
439
|
-
}
|
|
440
|
-
}
|
|
441
|
-
async createJobFromFile(req, res) {
|
|
442
|
-
const { fileStorageId, printerId } = req.body;
|
|
443
|
-
if (!fileStorageId) {
|
|
444
|
-
res.status(400).send({
|
|
445
|
-
error: "fileStorageId is required"
|
|
446
|
-
});
|
|
447
|
-
return;
|
|
448
|
-
}
|
|
449
|
-
if (!printerId) {
|
|
450
|
-
res.status(400).send({
|
|
451
|
-
error: "printerId is required"
|
|
452
|
-
});
|
|
453
|
-
return;
|
|
454
|
-
}
|
|
455
|
-
try {
|
|
456
|
-
const fileExists = await this.fileStorageService.fileExists(fileStorageId);
|
|
457
|
-
if (!fileExists) {
|
|
458
|
-
throw new _runtimeexceptions.NotFoundException("File not found in storage");
|
|
459
|
-
}
|
|
460
|
-
const metadata = await this.fileStorageService.loadMetadata(fileStorageId);
|
|
461
|
-
if (!metadata) {
|
|
462
|
-
res.status(400).send({
|
|
463
|
-
error: "File has no metadata. Please analyze the file first."
|
|
464
|
-
});
|
|
465
|
-
return;
|
|
466
|
-
}
|
|
467
|
-
const printerName = `Printer ${printerId}`;
|
|
468
|
-
const job = await this.printJobService.createPendingJob(printerId, metadata._originalFileName || metadata.fileName || "Unknown", metadata, printerName);
|
|
469
|
-
job.fileStorageId = fileStorageId;
|
|
470
|
-
job.fileHash = metadata._fileHash;
|
|
471
|
-
job.analysisState = "ANALYZED";
|
|
472
|
-
job.analyzedAt = new Date();
|
|
473
|
-
if (metadata.fileFormat) {
|
|
474
|
-
job.fileFormat = metadata.fileFormat;
|
|
475
|
-
}
|
|
476
|
-
await this.printJobService.printJobRepository.save(job);
|
|
477
|
-
this.logger.log(`Created job ${job.id} from file storage ${fileStorageId} for printer ${printerId}`);
|
|
478
|
-
res.send({
|
|
479
|
-
id: job.id,
|
|
480
|
-
printerId: job.printerId,
|
|
481
|
-
printerName: job.printerName,
|
|
482
|
-
fileName: job.fileName,
|
|
483
|
-
fileStorageId: job.fileStorageId,
|
|
484
|
-
status: job.status,
|
|
485
|
-
analysisState: job.analysisState,
|
|
486
|
-
createdAt: job.createdAt
|
|
487
|
-
});
|
|
488
|
-
} catch (error) {
|
|
489
|
-
this.logger.error(`Failed to create job from file ${fileStorageId}: ${error}`);
|
|
490
|
-
res.status(500).send({
|
|
491
|
-
error: "Failed to create job from file"
|
|
492
|
-
});
|
|
493
|
-
}
|
|
494
|
-
}
|
|
495
329
|
toEndOfDay(date) {
|
|
496
330
|
const endOfDay = new Date(date);
|
|
497
331
|
endOfDay.setHours(23, 59, 59, 999);
|
|
@@ -609,43 +443,6 @@ _ts_decorate([
|
|
|
609
443
|
]),
|
|
610
444
|
_ts_metadata("design:returntype", Promise)
|
|
611
445
|
], PrintJobController.prototype, "deleteJob", null);
|
|
612
|
-
_ts_decorate([
|
|
613
|
-
(0, _awilixexpress.GET)(),
|
|
614
|
-
(0, _awilixexpress.route)("/:id/thumbnails"),
|
|
615
|
-
(0, _awilixexpress.before)([
|
|
616
|
-
(0, _paramconvertermiddleware.ParamId)("id")
|
|
617
|
-
]),
|
|
618
|
-
_ts_metadata("design:type", Function),
|
|
619
|
-
_ts_metadata("design:paramtypes", [
|
|
620
|
-
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
621
|
-
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
622
|
-
]),
|
|
623
|
-
_ts_metadata("design:returntype", Promise)
|
|
624
|
-
], PrintJobController.prototype, "getThumbnails", null);
|
|
625
|
-
_ts_decorate([
|
|
626
|
-
(0, _awilixexpress.GET)(),
|
|
627
|
-
(0, _awilixexpress.route)("/:id/thumbnails/:index"),
|
|
628
|
-
(0, _awilixexpress.before)([
|
|
629
|
-
(0, _paramconvertermiddleware.ParamId)("id"),
|
|
630
|
-
(0, _paramconvertermiddleware.ParamInt)("index")
|
|
631
|
-
]),
|
|
632
|
-
_ts_metadata("design:type", Function),
|
|
633
|
-
_ts_metadata("design:paramtypes", [
|
|
634
|
-
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
635
|
-
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
636
|
-
]),
|
|
637
|
-
_ts_metadata("design:returntype", Promise)
|
|
638
|
-
], PrintJobController.prototype, "getThumbnail", null);
|
|
639
|
-
_ts_decorate([
|
|
640
|
-
(0, _awilixexpress.POST)(),
|
|
641
|
-
(0, _awilixexpress.route)("/from-file"),
|
|
642
|
-
_ts_metadata("design:type", Function),
|
|
643
|
-
_ts_metadata("design:paramtypes", [
|
|
644
|
-
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
645
|
-
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
646
|
-
]),
|
|
647
|
-
_ts_metadata("design:returntype", Promise)
|
|
648
|
-
], PrintJobController.prototype, "createJobFromFile", null);
|
|
649
446
|
PrintJobController = _ts_decorate([
|
|
650
447
|
(0, _awilixexpress.route)(_serverconstants.AppConstants.apiRoute + "/print-jobs"),
|
|
651
448
|
(0, _awilixexpress.before)([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controllers/print-job.controller.ts"],"names":["PrintJobController","logger","loggerFactory","printJobService","fileAnalysisService","fileStorageService","name","searchJobs","req","res","searchPrinter","searchFile","startDate","endDate","validateInput","query","searchJobsSchema","endDateObj","toEndOfDay","Date","undefined","result","searchPrintJobs","send","searchJobsPaged","page","pageSize","searchJobsPagedSchema","items","count","searchPrintJobsPaged","pages","Math","ceil","getJob","jobId","local","id","job","getJobByIdOrFail","thumbnailCount","fileStorageId","thumbnails","listThumbnails","length","thumbnailsUrl","error","status","setCompleted","currentStatus","suggestion","log","endedAt","progress","statusReason","statistics","startedAt","actualPrintTimeSeconds","printJobRepository","save","message","previousStatus","newStatus","Error","setFailed","includes","actualTimeSeconds","getTime","failureReason","failureTime","setCancelled","setUnknown","reAnalyzeJob","triggerFileAnalysis","filePath","getFilePath","exists","needsAnalysis","NotFoundException","analysisState","metadata","analyzeFile","thumbnailMetadata","saveThumbnails","handleFileAnalyzed","fileHash","saveMetadata","fileName","deleteJob","deleteFileParam","deleteFile","remove","otherJobs","where","fileDeleted","warn","remainingReferences","getThumbnails","loadMetadata","_thumbnails","map","thumb","index","url","filename","width","height","format","size","getThumbnail","thumbnail","isPNG","isJPG","isQOI","contentType","setHeader","createJobFromFile","printerId","body","fileExists","printerName","createPendingJob","_originalFileName","_fileHash","analyzedAt","fileFormat","createdAt","date","endOfDay","setHours","ParamId","ParamInt","AppConstants","apiRoute","authenticate","authorizeRoles","ROLES","ADMIN"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/print-job.controller.ts"],"names":["PrintJobController","logger","loggerFactory","printJobService","fileAnalysisService","fileStorageService","name","searchJobs","req","res","searchPrinter","searchFile","startDate","endDate","validateInput","query","searchJobsSchema","endDateObj","toEndOfDay","Date","undefined","result","searchPrintJobs","send","searchJobsPaged","page","pageSize","searchJobsPagedSchema","items","count","searchPrintJobsPaged","itemsWithThumbnails","Promise","all","map","job","thumbnails","fileStorageId","metadata","loadMetadata","extractThumbnailsFromMetadata","pages","Math","ceil","getJob","jobId","local","id","getJobByIdOrFail","error","status","setCompleted","includes","currentStatus","suggestion","previousStatus","markAsCompleted","message","newStatus","Error","setFailed","markAsFailed","setCancelled","markAsCancelled","setUnknown","markAsUnknown","reAnalyzeJob","log","triggerFileAnalysis","filePath","getFilePath","exists","needsAnalysis","NotFoundException","analysisState","updateJob","analyzeFile","thumbnailMetadata","length","saveThumbnails","handleFileAnalyzed","fileHash","saveMetadata","fileName","thumbnailCount","deleteJob","deleteFileParam","deleteFile","otherJobs","countJobsReferencingFile","fileDeleted","warn","remainingReferences","date","endOfDay","setHours","ParamId","AppConstants","apiRoute","authenticate","authorizeRoles","ROLES","ADMIN"],"mappings":"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"}
|
|
@@ -14,8 +14,12 @@ const _express = require("express");
|
|
|
14
14
|
const _authenticate = require("../middleware/authenticate");
|
|
15
15
|
const _authorizationconstants = require("../constants/authorization.constants");
|
|
16
16
|
const _printqueueservice = require("../services/print-queue.service");
|
|
17
|
+
const _printjobservice = require("../services/orm/print-job.service");
|
|
18
|
+
const _filestorageservice = require("../services/file-storage.service");
|
|
19
|
+
const _printercache = require("../state/printer.cache");
|
|
17
20
|
const _loggerfactory = require("../handlers/logger-factory");
|
|
18
21
|
const _paramconvertermiddleware = require("../middleware/param-converter.middleware");
|
|
22
|
+
const _runtimeexceptions = require("../exceptions/runtime.exceptions");
|
|
19
23
|
function _ts_decorate(decorators, target, key, desc) {
|
|
20
24
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
21
25
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
@@ -27,9 +31,15 @@ function _ts_metadata(k, v) {
|
|
|
27
31
|
}
|
|
28
32
|
class PrintQueueController {
|
|
29
33
|
printQueueService;
|
|
34
|
+
printJobService;
|
|
35
|
+
fileStorageService;
|
|
36
|
+
printerCache;
|
|
30
37
|
logger;
|
|
31
|
-
constructor(loggerFactory, printQueueService){
|
|
38
|
+
constructor(loggerFactory, printQueueService, printJobService, fileStorageService, printerCache){
|
|
32
39
|
this.printQueueService = printQueueService;
|
|
40
|
+
this.printJobService = printJobService;
|
|
41
|
+
this.fileStorageService = fileStorageService;
|
|
42
|
+
this.printerCache = printerCache;
|
|
33
43
|
this.logger = loggerFactory(PrintQueueController.name);
|
|
34
44
|
}
|
|
35
45
|
async getGlobalQueue(req, res) {
|
|
@@ -42,21 +52,7 @@ class PrintQueueController {
|
|
|
42
52
|
});
|
|
43
53
|
return;
|
|
44
54
|
}
|
|
45
|
-
const
|
|
46
|
-
const [jobs, totalCount] = await this.printQueueService.printJobRepository.findAndCount({
|
|
47
|
-
where: {
|
|
48
|
-
status: "QUEUED"
|
|
49
|
-
},
|
|
50
|
-
order: {
|
|
51
|
-
printerId: "ASC",
|
|
52
|
-
queuePosition: "ASC"
|
|
53
|
-
},
|
|
54
|
-
relations: [
|
|
55
|
-
'printer'
|
|
56
|
-
],
|
|
57
|
-
take: pageSize,
|
|
58
|
-
skip: skip
|
|
59
|
-
});
|
|
55
|
+
const [jobs, totalCount] = await this.printQueueService.getGlobalQueuePaged(page, pageSize);
|
|
60
56
|
const queueItems = jobs.map((job)=>({
|
|
61
57
|
jobId: job.id,
|
|
62
58
|
fileName: job.fileName,
|
|
@@ -221,6 +217,59 @@ class PrintQueueController {
|
|
|
221
217
|
});
|
|
222
218
|
}
|
|
223
219
|
}
|
|
220
|
+
async createJobFromFile(req, res) {
|
|
221
|
+
const printerId = req.local.printerId;
|
|
222
|
+
const { fileStorageId, addToQueue = true, position } = req.body;
|
|
223
|
+
if (!fileStorageId) {
|
|
224
|
+
res.status(400).send({
|
|
225
|
+
error: "fileStorageId is required"
|
|
226
|
+
});
|
|
227
|
+
return;
|
|
228
|
+
}
|
|
229
|
+
try {
|
|
230
|
+
const fileExists = await this.fileStorageService.fileExists(fileStorageId);
|
|
231
|
+
if (!fileExists) {
|
|
232
|
+
throw new _runtimeexceptions.NotFoundException("File not found in storage");
|
|
233
|
+
}
|
|
234
|
+
const metadata = await this.fileStorageService.loadMetadata(fileStorageId);
|
|
235
|
+
if (!metadata) {
|
|
236
|
+
res.status(400).send({
|
|
237
|
+
error: "File has no metadata. Please analyze the file first."
|
|
238
|
+
});
|
|
239
|
+
return;
|
|
240
|
+
}
|
|
241
|
+
const printer = await this.printerCache.getCachedPrinterOrThrowAsync(printerId);
|
|
242
|
+
const job = await this.printJobService.createPendingJob(printerId, metadata._originalFileName || metadata.fileName || "Unknown", metadata, printer.name);
|
|
243
|
+
job.fileStorageId = fileStorageId;
|
|
244
|
+
job.fileHash = metadata._fileHash;
|
|
245
|
+
job.analysisState = "ANALYZED";
|
|
246
|
+
job.analyzedAt = new Date();
|
|
247
|
+
if (metadata.fileFormat) {
|
|
248
|
+
job.fileFormat = metadata.fileFormat;
|
|
249
|
+
}
|
|
250
|
+
await this.printJobService.updateJob(job);
|
|
251
|
+
if (addToQueue) {
|
|
252
|
+
await this.printQueueService.addToQueue(printerId, job.id, position);
|
|
253
|
+
}
|
|
254
|
+
this.logger.log(`Created job ${job.id} from file storage ${fileStorageId} for printer ${printerId}${addToQueue ? " and added to queue" : ""}`);
|
|
255
|
+
res.send({
|
|
256
|
+
id: job.id,
|
|
257
|
+
printerId: job.printerId,
|
|
258
|
+
printerName: job.printerName,
|
|
259
|
+
fileName: job.fileName,
|
|
260
|
+
fileStorageId: job.fileStorageId,
|
|
261
|
+
status: job.status,
|
|
262
|
+
analysisState: job.analysisState,
|
|
263
|
+
createdAt: job.createdAt,
|
|
264
|
+
addedToQueue: addToQueue
|
|
265
|
+
});
|
|
266
|
+
} catch (error) {
|
|
267
|
+
this.logger.error(`Failed to create job from file ${fileStorageId}: ${error}`);
|
|
268
|
+
res.status(500).send({
|
|
269
|
+
error: "Failed to create job from file"
|
|
270
|
+
});
|
|
271
|
+
}
|
|
272
|
+
}
|
|
224
273
|
async submitToPrinter(req, res) {
|
|
225
274
|
const printerId = req.local.printerId;
|
|
226
275
|
const jobId = req.local.jobId;
|
|
@@ -342,6 +391,19 @@ _ts_decorate([
|
|
|
342
391
|
]),
|
|
343
392
|
_ts_metadata("design:returntype", Promise)
|
|
344
393
|
], PrintQueueController.prototype, "processQueue", null);
|
|
394
|
+
_ts_decorate([
|
|
395
|
+
(0, _awilixexpress.POST)(),
|
|
396
|
+
(0, _awilixexpress.route)("/:printerId/from-file"),
|
|
397
|
+
(0, _awilixexpress.before)([
|
|
398
|
+
(0, _paramconvertermiddleware.ParamId)("printerId")
|
|
399
|
+
]),
|
|
400
|
+
_ts_metadata("design:type", Function),
|
|
401
|
+
_ts_metadata("design:paramtypes", [
|
|
402
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
403
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
404
|
+
]),
|
|
405
|
+
_ts_metadata("design:returntype", Promise)
|
|
406
|
+
], PrintQueueController.prototype, "createJobFromFile", null);
|
|
345
407
|
_ts_decorate([
|
|
346
408
|
(0, _awilixexpress.POST)(),
|
|
347
409
|
(0, _awilixexpress.route)("/:printerId/submit/:jobId"),
|
|
@@ -368,7 +430,10 @@ PrintQueueController = _ts_decorate([
|
|
|
368
430
|
_ts_metadata("design:type", Function),
|
|
369
431
|
_ts_metadata("design:paramtypes", [
|
|
370
432
|
typeof _loggerfactory.ILoggerFactory === "undefined" ? Object : _loggerfactory.ILoggerFactory,
|
|
371
|
-
typeof _printqueueservice.PrintQueueService === "undefined" ? Object : _printqueueservice.PrintQueueService
|
|
433
|
+
typeof _printqueueservice.PrintQueueService === "undefined" ? Object : _printqueueservice.PrintQueueService,
|
|
434
|
+
typeof _printjobservice.PrintJobService === "undefined" ? Object : _printjobservice.PrintJobService,
|
|
435
|
+
typeof _filestorageservice.FileStorageService === "undefined" ? Object : _filestorageservice.FileStorageService,
|
|
436
|
+
typeof _printercache.PrinterCache === "undefined" ? Object : _printercache.PrinterCache
|
|
372
437
|
])
|
|
373
438
|
], PrintQueueController);
|
|
374
439
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controllers/print-queue.controller.ts"],"names":["PrintQueueController","logger","loggerFactory","printQueueService","name","getGlobalQueue","req","res","page","Number","parseInt","query","pageSize","status","send","error","
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/print-queue.controller.ts"],"names":["PrintQueueController","logger","loggerFactory","printQueueService","printJobService","fileStorageService","printerCache","name","getGlobalQueue","req","res","page","Number","parseInt","query","pageSize","status","send","error","jobs","totalCount","getGlobalQueuePaged","queueItems","map","job","jobId","id","fileName","printerId","printerName","printer","queuePosition","createdAt","estimatedTimeSeconds","metadata","gcodePrintTimeSeconds","filamentGrams","filamentUsedGrams","items","totalPages","Math","ceil","getQueue","local","queue","count","length","addToQueue","position","body","undefined","message","Error","reorderQueue","jobIds","Array","isArray","clearQueue","removeFromQueue","getNextInQueue","nextJob","processQueue","createJobFromFile","fileStorageId","fileExists","NotFoundException","loadMetadata","getCachedPrinterOrThrowAsync","createPendingJob","_originalFileName","fileHash","_fileHash","analysisState","analyzedAt","Date","fileFormat","updateJob","log","addedToQueue","submitToPrinter","ParamId","AppConstants","apiRoute","authenticate","authorizeRoles","ROLES","ADMIN","OPERATOR"],"mappings":";;;;+BAgBaA;;;eAAAA;;;+BAhByC;iCACzB;yBACK;8BACW;wCACvB;mCACY;iCACF;oCACG;8BACN;+BACE;0CAEP;mCACU;;;;;;;;;;AAI3B,MAAMA;;;;;IACMC,OAAsB;IAEvC,YACEC,aAA6B,EAC7B,AAAiBC,iBAAoC,EACrD,AAAiBC,eAAgC,EACjD,AAAiBC,kBAAsC,EACvD,AAAiBC,YAA0B,CAC3C;aAJiBH,oBAAAA;aACAC,kBAAAA;aACAC,qBAAAA;aACAC,eAAAA;QAEjB,IAAI,CAACL,MAAM,GAAGC,cAAcF,qBAAqBO,IAAI;IACvD;IAEA,MACMC,eAAeC,GAAY,EAAEC,GAAa,EAAE;QAChD,IAAI;YACF,MAAMC,OAAOC,OAAOC,QAAQ,CAACJ,IAAIK,KAAK,CAACH,IAAI,KAAe;YAC1D,MAAMI,WAAWH,OAAOC,QAAQ,CAACJ,IAAIK,KAAK,CAACC,QAAQ,KAAe;YAElE,IAAIJ,OAAO,KAAKI,WAAW,KAAKA,WAAW,KAAK;gBAC9CL,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;oBAAEC,OAAO;gBAAsC;gBACpE;YACF;YAEA,MAAM,CAACC,MAAMC,WAAW,GAAG,MAAM,IAAI,CAACjB,iBAAiB,CAACkB,mBAAmB,CAACV,MAAMI;YAElF,MAAMO,aAAaH,KAAKI,GAAG,CAACC,CAAAA,MAAQ,CAAA;oBAClCC,OAAOD,IAAIE,EAAE;oBACbC,UAAUH,IAAIG,QAAQ;oBACtBC,WAAWJ,IAAII,SAAS;oBACxBC,aAAaL,IAAIK,WAAW,IAAIL,IAAIM,OAAO,EAAEvB;oBAC7CwB,eAAeP,IAAIO,aAAa;oBAChCf,QAAQQ,IAAIR,MAAM;oBAClBgB,WAAWR,IAAIQ,SAAS;oBACxBC,sBAAuBT,IAAIU,QAAQ,EAAUC;oBAC7CC,eAAgBZ,IAAIU,QAAQ,EAAUG;gBACxC,CAAA;YAEA3B,IAAIO,IAAI,CAAC;gBACPqB,OAAOhB;gBACPX;gBACAI;gBACAK;gBACAmB,YAAYC,KAAKC,IAAI,CAACrB,aAAaL;YACrC;QACF,EAAE,OAAOG,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,4BAA4B,EAAEA,OAAO;YACxDR,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBAAEC,OAAO;YAA6B;QAC7D;IACF;IAEA,MAGMwB,SAASjC,GAAY,EAAEC,GAAa,EAAE;QAC1C,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QAErC,IAAI;YACF,MAAMgB,QAAQ,MAAM,IAAI,CAACzC,iBAAiB,CAACuC,QAAQ,CAACd;YACpDlB,IAAIO,IAAI,CAAC;gBACPW;gBACAgB;gBACAC,OAAOD,MAAME,MAAM;YACrB;QACF,EAAE,OAAO5B,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,gCAAgC,EAAEU,UAAU,EAAE,EAAEV,OAAO;YAC1ER,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBAAEC,OAAO;YAAsB;QACtD;IACF;IAEA,MAGM6B,WAAWtC,GAAY,EAAEC,GAAa,EAAE;QAC5C,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QACrC,MAAMH,QAAQhB,IAAIkC,KAAK,CAAClB,KAAK;QAC7B,MAAMuB,WAAWvC,IAAIwC,IAAI,CAACD,QAAQ,KAAKE,YAAYA,YAAYtC,OAAOC,QAAQ,CAACJ,IAAIwC,IAAI,CAACD,QAAQ;QAEhG,IAAI;YACF,MAAM,IAAI,CAAC7C,iBAAiB,CAAC4C,UAAU,CAACnB,WAAWH,OAAOuB;YAC1D,MAAMJ,QAAQ,MAAM,IAAI,CAACzC,iBAAiB,CAACuC,QAAQ,CAACd;YAEpDlB,IAAIO,IAAI,CAAC;gBACPkC,SAAS;gBACTvB;gBACAH;gBACAuB;gBACAJ;YACF;QACF,EAAE,OAAO1B,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,kBAAkB,EAAEO,MAAM,WAAW,EAAEP,OAAO;YACjER,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBACnBC,OAAO;gBACPiC,SAASjC,iBAAiBkC,QAAQlC,MAAMiC,OAAO,GAAG;YACpD;QACF;IACF;IAEA,MAGME,aAAa5C,GAAY,EAAEC,GAAa,EAAE;QAC9C,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QACrC,MAAM0B,SAAS7C,IAAIwC,IAAI,CAACK,MAAM;QAE9B,IAAI,CAACC,MAAMC,OAAO,CAACF,SAAS;YAC1B5C,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBAAEC,OAAO;YAA0B;YACxD;QACF;QAEA,IAAI;YACF,MAAM,IAAI,CAACf,iBAAiB,CAACkD,YAAY,CAACzB,WAAW0B;YACrD,MAAMV,QAAQ,MAAM,IAAI,CAACzC,iBAAiB,CAACuC,QAAQ,CAACd;YAEpDlB,IAAIO,IAAI,CAAC;gBACPkC,SAAS;gBACTvB;gBACAgB;YACF;QACF,EAAE,OAAO1B,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,oCAAoC,EAAEU,UAAU,EAAE,EAAEV,OAAO;YAC9ER,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBACnBC,OAAO;gBACPiC,SAASjC,iBAAiBkC,QAAQlC,MAAMiC,OAAO,GAAG;YACpD;QACF;IACF;IAEA,MAGMM,WAAWhD,GAAY,EAAEC,GAAa,EAAE;QAC5C,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QAErC,IAAI;YACF,MAAM,IAAI,CAACzB,iBAAiB,CAACsD,UAAU,CAAC7B;YAExClB,IAAIO,IAAI,CAAC;gBACPkC,SAAS;gBACTvB;YACF;QACF,EAAE,OAAOV,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,kCAAkC,EAAEU,UAAU,EAAE,EAAEV,OAAO;YAC5ER,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBACnBC,OAAO;gBACPiC,SAASjC,iBAAiBkC,QAAQlC,MAAMiC,OAAO,GAAG;YACpD;QACF;IACF;IAEA,MAGMO,gBAAgBjD,GAAY,EAAEC,GAAa,EAAE;QACjD,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QACrC,MAAMH,QAAQhB,IAAIkC,KAAK,CAAClB,KAAK;QAE7B,IAAI;YACF,MAAM,IAAI,CAACtB,iBAAiB,CAACuD,eAAe,CAACjC;YAC7C,MAAMmB,QAAQ,MAAM,IAAI,CAACzC,iBAAiB,CAACuC,QAAQ,CAACd;YAEpDlB,IAAIO,IAAI,CAAC;gBACPkC,SAAS;gBACTvB;gBACAH;gBACAmB;YACF;QACF,EAAE,OAAO1B,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,qBAAqB,EAAEO,MAAM,aAAa,EAAEP,OAAO;YACtER,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBACnBC,OAAO;gBACPiC,SAASjC,iBAAiBkC,QAAQlC,MAAMiC,OAAO,GAAG;YACpD;QACF;IACF;IAEA,MAGMQ,eAAelD,GAAY,EAAEC,GAAa,EAAE;QAChD,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QAErC,IAAI;YACF,MAAMgC,UAAU,MAAM,IAAI,CAACzD,iBAAiB,CAACwD,cAAc,CAAC/B;YAE5DlB,IAAIO,IAAI,CAAC;gBACPW;gBACAgC;YACF;QACF,EAAE,OAAO1C,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,mCAAmC,EAAEU,UAAU,EAAE,EAAEV,OAAO;YAC7ER,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBAAEC,OAAO;YAAyB;QACzD;IACF;IAEA,MAGM2C,aAAapD,GAAY,EAAEC,GAAa,EAAE;QAC9C,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QAErC,IAAI;YACF,MAAMgC,UAAU,MAAM,IAAI,CAACzD,iBAAiB,CAAC0D,YAAY,CAACjC;YAE1D,IAAI,CAACgC,SAAS;gBACZlD,IAAIO,IAAI,CAAC;oBACPkC,SAAS;oBACTvB;oBACAgC,SAAS;gBACX;gBACA;YACF;YAEAlD,IAAIO,IAAI,CAAC;gBACPkC,SAAS;gBACTvB;gBACAgC;YACF;QACF,EAAE,OAAO1C,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,oCAAoC,EAAEU,UAAU,EAAE,EAAEV,OAAO;YAC9ER,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBACnBC,OAAO;gBACPiC,SAASjC,iBAAiBkC,QAAQlC,MAAMiC,OAAO,GAAG;YACpD;QACF;IACF;IAEA,MAGMW,kBAAkBrD,GAAY,EAAEC,GAAa,EAAE;QACnD,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QACrC,MAAM,EAAEmC,aAAa,EAAEhB,aAAa,IAAI,EAAEC,QAAQ,EAAE,GAAGvC,IAAIwC,IAAI;QAE/D,IAAI,CAACc,eAAe;YAClBrD,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBAAEC,OAAO;YAA4B;YAC1D;QACF;QAEA,IAAI;YACF,MAAM8C,aAAa,MAAM,IAAI,CAAC3D,kBAAkB,CAAC2D,UAAU,CAACD;YAC5D,IAAI,CAACC,YAAY;gBACf,MAAM,IAAIC,oCAAiB,CAAC;YAC9B;YAEA,MAAM/B,WAAW,MAAM,IAAI,CAAC7B,kBAAkB,CAAC6D,YAAY,CAACH;YAC5D,IAAI,CAAC7B,UAAU;gBACbxB,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;oBAAEC,OAAO;gBAAuD;gBACrF;YACF;YAEA,MAAMY,UAAU,MAAM,IAAI,CAACxB,YAAY,CAAC6D,4BAA4B,CAACvC;YAErE,MAAMJ,MAAM,MAAM,IAAI,CAACpB,eAAe,CAACgE,gBAAgB,CACrDxC,WACAM,SAASmC,iBAAiB,IAAInC,SAASP,QAAQ,IAAI,WACnDO,UACAJ,QAAQvB,IAAI;YAGdiB,IAAIuC,aAAa,GAAGA;YACpBvC,IAAI8C,QAAQ,GAAGpC,SAASqC,SAAS;YACjC/C,IAAIgD,aAAa,GAAG;YACpBhD,IAAIiD,UAAU,GAAG,IAAIC;YAErB,IAAIxC,SAASyC,UAAU,EAAE;gBACvBnD,IAAImD,UAAU,GAAGzC,SAASyC,UAAU;YACtC;YAEA,MAAM,IAAI,CAACvE,eAAe,CAACwE,SAAS,CAACpD;YAErC,IAAIuB,YAAY;gBACd,MAAM,IAAI,CAAC5C,iBAAiB,CAAC4C,UAAU,CAACnB,WAAWJ,IAAIE,EAAE,EAAEsB;YAC7D;YAEA,IAAI,CAAC/C,MAAM,CAAC4E,GAAG,CACb,CAAC,YAAY,EAAErD,IAAIE,EAAE,CAAC,mBAAmB,EAAEqC,cAAc,aAAa,EAAEnC,YAAYmB,aAAa,wBAAwB,IAAI;YAG/HrC,IAAIO,IAAI,CAAC;gBACPS,IAAIF,IAAIE,EAAE;gBACVE,WAAWJ,IAAII,SAAS;gBACxBC,aAAaL,IAAIK,WAAW;gBAC5BF,UAAUH,IAAIG,QAAQ;gBACtBoC,eAAevC,IAAIuC,aAAa;gBAChC/C,QAAQQ,IAAIR,MAAM;gBAClBwD,eAAehD,IAAIgD,aAAa;gBAChCxC,WAAWR,IAAIQ,SAAS;gBACxB8C,cAAc/B;YAChB;QACF,EAAE,OAAO7B,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,+BAA+B,EAAE6C,cAAc,EAAE,EAAE7C,OAAO;YAC7ER,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBAAEC,OAAO;YAAiC;QACjE;IACF;IAEA,MAGM6D,gBAAgBtE,GAAY,EAAEC,GAAa,EAAE;QACjD,MAAMkB,YAAYnB,IAAIkC,KAAK,CAACf,SAAS;QACrC,MAAMH,QAAQhB,IAAIkC,KAAK,CAAClB,KAAK;QAE7B,IAAI;YACF,MAAM,IAAI,CAACtB,iBAAiB,CAAC4E,eAAe,CAACnD,WAAWH;YAExDf,IAAIO,IAAI,CAAC;gBACPkC,SAAS;gBACTvB;gBACAH;YACF;QACF,EAAE,OAAOP,OAAO;YACd,IAAI,CAACjB,MAAM,CAACiB,KAAK,CAAC,CAAC,qBAAqB,EAAEO,MAAM,YAAY,EAAEG,UAAU,EAAE,EAAEV,OAAO;YACnFR,IAAIM,MAAM,CAAC,KAAKC,IAAI,CAAC;gBACnBC,OAAO;gBACPiC,SAASjC,iBAAiBkC,QAAQlC,MAAMiC,OAAO,GAAG;YACpD;QACF;IACF;AACF;;;;;;;;;;;;;;QA1QW6B,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAmBRA,IAAAA,iCAAO,EAAC;QAAcA,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QA4B9BA,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QA8BRA,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAsBRA,IAAAA,iCAAO,EAAC;QAAcA,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QA0B9BA,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAmBRA,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAgCRA,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAqERA,IAAAA,iCAAO,EAAC;QAAcA,IAAAA,iCAAO,EAAC;;;;;;;;;;8BA5SlCC,6BAAY,CAACC,QAAQ,GAAG;;QACtBC,IAAAA,0BAAY;QAAIC,IAAAA,4BAAc,EAAC;YAACC,6BAAK,CAACC,KAAK;YAAED,6BAAK,CAACE,QAAQ;SAAC"}
|
|
@@ -148,7 +148,13 @@ class PrinterFilesController {
|
|
|
148
148
|
}
|
|
149
149
|
const uploadedFile = files[0];
|
|
150
150
|
const token = this.multerService.startTrackingSession(uploadedFile, currentPrinterId);
|
|
151
|
-
await this.printerApi.uploadFile(
|
|
151
|
+
await this.printerApi.uploadFile({
|
|
152
|
+
stream: (0, _nodefs.createReadStream)(uploadedFile.path),
|
|
153
|
+
fileName: uploadedFile.originalname,
|
|
154
|
+
contentLength: uploadedFile.size,
|
|
155
|
+
startPrint,
|
|
156
|
+
uploadToken: token
|
|
157
|
+
}).catch((e)=>{
|
|
152
158
|
try {
|
|
153
159
|
this.multerService.clearUploadedFile(uploadedFile);
|
|
154
160
|
} catch (e) {
|
|
@@ -215,7 +221,7 @@ class PrinterFilesController {
|
|
|
215
221
|
const job = await this.printJobService.createPendingJob(currentPrinterId, uploadedFile.originalname, metadata, currentPrinter.name);
|
|
216
222
|
job.fileStorageId = fileStorageId;
|
|
217
223
|
job.fileHash = fileHash;
|
|
218
|
-
await this.printJobService.
|
|
224
|
+
await this.printJobService.updateJob(job);
|
|
219
225
|
this.logger.log(`Created job ${job.id}: format=${job.fileFormat}, ` + `state=${job.analysisState}, ` + `storageId=${fileStorageId}, ` + `hash=${fileHash.substring(0, 8)}...`);
|
|
220
226
|
if ((0, _nodefs.existsSync)(tempPathWithExt)) {
|
|
221
227
|
(0, _nodefs.unlinkSync)(tempPathWithExt);
|