@fdm-monster/server 2.0.7 → 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.
Files changed (64) hide show
  1. package/.yarn/install-state.gz +0 -0
  2. package/RELEASE_NOTES.MD +23 -0
  3. package/dist/controllers/print-job.controller.js +12 -151
  4. package/dist/controllers/print-job.controller.js.map +1 -1
  5. package/dist/controllers/print-queue.controller.js +82 -17
  6. package/dist/controllers/print-queue.controller.js.map +1 -1
  7. package/dist/controllers/printer-files.controller.js +8 -2
  8. package/dist/controllers/printer-files.controller.js.map +1 -1
  9. package/dist/controllers/printer.controller.js +3 -3
  10. package/dist/controllers/printer.controller.js.map +1 -1
  11. package/dist/entities/print-job.entity.js.map +1 -1
  12. package/dist/server.constants.js +1 -1
  13. package/dist/services/bambu/bambu-ftp.adapter.js +3 -13
  14. package/dist/services/bambu/bambu-ftp.adapter.js.map +1 -1
  15. package/dist/services/bambu.api.js +7 -18
  16. package/dist/services/bambu.api.js.map +1 -1
  17. package/dist/services/file-storage.service.js +11 -2
  18. package/dist/services/file-storage.service.js.map +1 -1
  19. package/dist/services/moonraker/moonraker.client.js +5 -17
  20. package/dist/services/moonraker/moonraker.client.js.map +1 -1
  21. package/dist/services/moonraker.api.js +3 -2
  22. package/dist/services/moonraker.api.js.map +1 -1
  23. package/dist/services/octoprint/octoprint.client.js +5 -17
  24. package/dist/services/octoprint/octoprint.client.js.map +1 -1
  25. package/dist/services/octoprint.api.js +3 -2
  26. package/dist/services/octoprint.api.js.map +1 -1
  27. package/dist/services/orm/print-job.service.js +55 -47
  28. package/dist/services/orm/print-job.service.js.map +1 -1
  29. package/dist/services/print-queue.service.js +90 -30
  30. package/dist/services/print-queue.service.js.map +1 -1
  31. package/dist/services/printer-api.interface.js +13 -0
  32. package/dist/services/printer-api.interface.js.map +1 -1
  33. package/dist/services/prusa-link/prusa-link.api.js +12 -22
  34. package/dist/services/prusa-link/prusa-link.api.js.map +1 -1
  35. package/dist/tasks/print-job-analysis.task.js.map +1 -1
  36. package/dist/utils/bgcode/bgcode-thumbnail.parser.js +50 -0
  37. package/dist/utils/bgcode/bgcode-thumbnail.parser.js.map +1 -0
  38. package/dist/utils/bgcode/bgcode.constants.js +57 -0
  39. package/dist/utils/bgcode/bgcode.constants.js.map +1 -0
  40. package/dist/utils/bgcode/bgcode.types.js +132 -0
  41. package/dist/utils/bgcode/bgcode.types.js.map +1 -0
  42. package/dist/utils/bgcode/bgcode.utils.js +288 -0
  43. package/dist/utils/bgcode/bgcode.utils.js.map +1 -0
  44. package/dist/utils/bgcode/heatshrink-decoder.js +172 -0
  45. package/dist/utils/bgcode/heatshrink-decoder.js.map +1 -0
  46. package/dist/utils/bgcode/png-encoder.js +76 -0
  47. package/dist/utils/bgcode/png-encoder.js.map +1 -0
  48. package/dist/utils/bgcode/qoi-decoder.js +141 -0
  49. package/dist/utils/bgcode/qoi-decoder.js.map +1 -0
  50. package/dist/utils/image-dimensions.js +62 -0
  51. package/dist/utils/image-dimensions.js.map +1 -0
  52. package/dist/utils/job-stats.util.js +79 -0
  53. package/dist/utils/job-stats.util.js.map +1 -0
  54. package/dist/utils/parsers/3mf.parser.js +39 -9
  55. package/dist/utils/parsers/3mf.parser.js.map +1 -1
  56. package/dist/utils/parsers/bgcode.parser.js +125 -144
  57. package/dist/utils/parsers/bgcode.parser.js.map +1 -1
  58. package/dist/utils/parsers/gcode.parser.js +13 -2
  59. package/dist/utils/parsers/gcode.parser.js.map +1 -1
  60. package/dist/utils/parsers/parser.types.js +6 -0
  61. package/dist/utils/parsers/parser.types.js.map +1 -0
  62. package/dist/utils/thumbnail.util.js +24 -0
  63. package/dist/utils/thumbnail.util.js.map +1 -0
  64. package/package.json +5 -5
Binary file
package/RELEASE_NOTES.MD CHANGED
@@ -1,5 +1,28 @@
1
1
  # Develop
2
2
 
3
+ # FDM Monster 2.0.8
4
+
5
+ ## Features
6
+
7
+ - Enhanced BGCode parser with MMU (Multi-Material Unit) support
8
+ - Detects MMU configurations by analyzing metadata fields for multiple values
9
+ - Parses filament data as arrays for MMU prints (per-extruder values)
10
+ - Provides `totalFilamentUsedGrams` for sum of all extruders in MMU mode
11
+ - Extracts thumbnails from BGCode files with QOI and Heatshrink decompression
12
+ - Supports comprehensive metadata including print times, temperatures, and layer information
13
+
14
+ ## Refactor
15
+
16
+ - Refactored printer file upload system to use native streams across all printer API implementations (OctoPrint, Moonraker, PrusaLink, Bambu)
17
+ - Introduced Zod schema validation for upload file parameters with `UploadFileInput` type
18
+ - Added `getFileSize()` method to FileStorageService for consistent file size retrieval
19
+ - Improved memory efficiency for large file uploads by eliminating buffer conversions where possible
20
+ - OctoPrint: Native multipart/form-data streaming with `knownLength` optimization
21
+ - Moonraker: Native multipart/form-data streaming with `knownLength` optimization
22
+ - PrusaLink: Native streaming via `application/octet-stream` PUT requests
23
+ - Bambu: Native FTP streaming using basic-ftp's `uploadFrom()` with stream support
24
+ - Simplified print queue service by removing redundant comments and extracting printer assignment logic
25
+
3
26
  # FDM Monster 2.0.7
4
27
 
5
28
  ## Fixes
@@ -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);
@@ -56,13 +57,7 @@ class PrintJobController {
56
57
  if (job.fileStorageId) {
57
58
  try {
58
59
  const metadata = await this.fileStorageService.loadMetadata(job.fileStorageId);
59
- thumbnails = (metadata?._thumbnails || []).map((thumb)=>({
60
- index: thumb.index,
61
- width: thumb.width,
62
- height: thumb.height,
63
- format: thumb.format,
64
- size: thumb.size
65
- }));
60
+ thumbnails = (0, _thumbnailutil.extractThumbnailsFromMetadata)(metadata);
66
61
  } catch {}
67
62
  }
68
63
  return {
@@ -85,13 +80,7 @@ class PrintJobController {
85
80
  let thumbnails = [];
86
81
  if (job.fileStorageId) {
87
82
  const metadata = await this.fileStorageService.loadMetadata(job.fileStorageId);
88
- thumbnails = (metadata?._thumbnails || []).map((thumb)=>({
89
- index: thumb.index,
90
- width: thumb.width,
91
- height: thumb.height,
92
- format: thumb.format,
93
- size: thumb.size
94
- }));
83
+ thumbnails = (0, _thumbnailutil.extractThumbnailsFromMetadata)(metadata);
95
84
  }
96
85
  res.send({
97
86
  ...job,
@@ -119,28 +108,12 @@ class PrintJobController {
119
108
  });
120
109
  return;
121
110
  }
122
- this.logger.log(`Manually marking job ${jobId} as COMPLETED (was UNKNOWN)`);
123
- job.status = "COMPLETED";
124
- job.endedAt = new Date();
125
- job.progress = 100;
126
- job.statusReason = "Manually marked as completed by user";
127
- if (job.statistics) {
128
- job.statistics.endedAt = job.endedAt;
129
- job.statistics.progress = 100;
130
- } else {
131
- job.statistics = {
132
- startedAt: job.startedAt,
133
- endedAt: job.endedAt,
134
- actualPrintTimeSeconds: null,
135
- progress: 100
136
- };
137
- }
138
- await this.printJobService.printJobRepository.save(job);
139
- this.logger.log(`Job ${jobId} marked as COMPLETED`);
111
+ const previousStatus = job.status;
112
+ await this.printJobService.markAsCompleted(jobId);
140
113
  res.send({
141
114
  message: "Job marked as completed",
142
115
  jobId,
143
- previousStatus: "UNKNOWN",
116
+ previousStatus,
144
117
  newStatus: "COMPLETED"
145
118
  });
146
119
  } catch (error) {
@@ -168,29 +141,7 @@ class PrintJobController {
168
141
  return;
169
142
  }
170
143
  try {
171
- this.logger.log(`Manually marking job ${jobId} as FAILED (was ${previousStatus})`);
172
- const endedAt = new Date();
173
- const actualTimeSeconds = job.startedAt ? (endedAt.getTime() - job.startedAt.getTime()) / 1000 : null;
174
- job.status = "FAILED";
175
- job.endedAt = endedAt;
176
- job.statusReason = "Manually marked as failed by user";
177
- if (!job.statistics) {
178
- job.statistics = {
179
- startedAt: job.startedAt,
180
- endedAt,
181
- actualPrintTimeSeconds: actualTimeSeconds,
182
- progress: job.progress,
183
- failureReason: "Manually marked as failed by user",
184
- failureTime: endedAt
185
- };
186
- } else {
187
- job.statistics.endedAt = endedAt;
188
- job.statistics.actualPrintTimeSeconds = actualTimeSeconds;
189
- job.statistics.failureReason = "Manually marked as failed by user";
190
- job.statistics.failureTime = endedAt;
191
- }
192
- await this.printJobService.printJobRepository.save(job);
193
- this.logger.log(`Job ${jobId} marked as FAILED`);
144
+ await this.printJobService.markAsFailed(jobId, "Manually marked as failed by user");
194
145
  res.send({
195
146
  message: "Job marked as failed",
196
147
  jobId,
@@ -221,25 +172,7 @@ class PrintJobController {
221
172
  return;
222
173
  }
223
174
  try {
224
- this.logger.log(`Manually marking job ${jobId} as CANCELLED (was ${previousStatus})`);
225
- const endedAt = new Date();
226
- const actualTimeSeconds = job.startedAt ? (endedAt.getTime() - job.startedAt.getTime()) / 1000 : null;
227
- job.status = "CANCELLED";
228
- job.endedAt = endedAt;
229
- job.statusReason = "Manually marked as cancelled by user";
230
- if (!job.statistics) {
231
- job.statistics = {
232
- startedAt: job.startedAt,
233
- endedAt,
234
- actualPrintTimeSeconds: actualTimeSeconds,
235
- progress: job.progress
236
- };
237
- } else {
238
- job.statistics.endedAt = endedAt;
239
- job.statistics.actualPrintTimeSeconds = actualTimeSeconds;
240
- }
241
- await this.printJobService.printJobRepository.save(job);
242
- this.logger.log(`Job ${jobId} marked as CANCELLED`);
175
+ await this.printJobService.markAsCancelled(jobId, "Manually marked as cancelled by user");
243
176
  res.send({
244
177
  message: "Job marked as cancelled",
245
178
  jobId,
@@ -270,11 +203,7 @@ class PrintJobController {
270
203
  return;
271
204
  }
272
205
  try {
273
- this.logger.log(`Manually marking job ${jobId} as UNKNOWN (was ${previousStatus})`);
274
- job.status = "UNKNOWN";
275
- job.statusReason = "Manually marked as unknown by user (state uncertain)";
276
- await this.printJobService.printJobRepository.save(job);
277
- this.logger.log(`Job ${jobId} marked as UNKNOWN`);
206
+ await this.printJobService.markAsUnknown(jobId);
278
207
  res.send({
279
208
  message: "Job marked as unknown",
280
209
  jobId,
@@ -311,7 +240,7 @@ class PrintJobController {
311
240
  }
312
241
  this.logger.log(`Re-analyzing file for job ${jobId}: ${filePath}`);
313
242
  job.analysisState = "ANALYZING";
314
- await this.printJobService.printJobRepository.save(job);
243
+ await this.printJobService.updateJob(job);
315
244
  const { metadata, thumbnails } = await this.fileAnalysisService.analyzeFile(filePath);
316
245
  let thumbnailMetadata = [];
317
246
  if (thumbnails && thumbnails.length > 0) {
@@ -352,14 +281,10 @@ class PrintJobController {
352
281
  try {
353
282
  const fileStorageId = job.fileStorageId;
354
283
  const fileName = job.fileName;
355
- await this.printJobService.printJobRepository.remove(job);
284
+ await this.printJobService.deleteJob(job);
356
285
  this.logger.log(`Deleted job ${jobId}: ${fileName}`);
357
286
  if (fileStorageId && deleteFileParam) {
358
- const otherJobs = await this.printJobService.printJobRepository.count({
359
- where: {
360
- fileStorageId
361
- }
362
- });
287
+ const otherJobs = await this.printJobService.countJobsReferencingFile(fileStorageId);
363
288
  if (otherJobs === 0) {
364
289
  try {
365
290
  await this.fileStorageService.deleteFile(fileStorageId);
@@ -401,60 +326,6 @@ class PrintJobController {
401
326
  });
402
327
  }
403
328
  }
404
- async createJobFromFile(req, res) {
405
- const { fileStorageId, printerId } = req.body;
406
- if (!fileStorageId) {
407
- res.status(400).send({
408
- error: "fileStorageId is required"
409
- });
410
- return;
411
- }
412
- if (!printerId) {
413
- res.status(400).send({
414
- error: "printerId is required"
415
- });
416
- return;
417
- }
418
- try {
419
- const fileExists = await this.fileStorageService.fileExists(fileStorageId);
420
- if (!fileExists) {
421
- throw new _runtimeexceptions.NotFoundException("File not found in storage");
422
- }
423
- const metadata = await this.fileStorageService.loadMetadata(fileStorageId);
424
- if (!metadata) {
425
- res.status(400).send({
426
- error: "File has no metadata. Please analyze the file first."
427
- });
428
- return;
429
- }
430
- const printerName = `Printer ${printerId}`;
431
- const job = await this.printJobService.createPendingJob(printerId, metadata._originalFileName || metadata.fileName || "Unknown", metadata, printerName);
432
- job.fileStorageId = fileStorageId;
433
- job.fileHash = metadata._fileHash;
434
- job.analysisState = "ANALYZED";
435
- job.analyzedAt = new Date();
436
- if (metadata.fileFormat) {
437
- job.fileFormat = metadata.fileFormat;
438
- }
439
- await this.printJobService.printJobRepository.save(job);
440
- this.logger.log(`Created job ${job.id} from file storage ${fileStorageId} for printer ${printerId}`);
441
- res.send({
442
- id: job.id,
443
- printerId: job.printerId,
444
- printerName: job.printerName,
445
- fileName: job.fileName,
446
- fileStorageId: job.fileStorageId,
447
- status: job.status,
448
- analysisState: job.analysisState,
449
- createdAt: job.createdAt
450
- });
451
- } catch (error) {
452
- this.logger.error(`Failed to create job from file ${fileStorageId}: ${error}`);
453
- res.status(500).send({
454
- error: "Failed to create job from file"
455
- });
456
- }
457
- }
458
329
  toEndOfDay(date) {
459
330
  const endOfDay = new Date(date);
460
331
  endOfDay.setHours(23, 59, 59, 999);
@@ -572,16 +443,6 @@ _ts_decorate([
572
443
  ]),
573
444
  _ts_metadata("design:returntype", Promise)
574
445
  ], PrintJobController.prototype, "deleteJob", null);
575
- _ts_decorate([
576
- (0, _awilixexpress.POST)(),
577
- (0, _awilixexpress.route)("/from-file"),
578
- _ts_metadata("design:type", Function),
579
- _ts_metadata("design:paramtypes", [
580
- typeof _express.Request === "undefined" ? Object : _express.Request,
581
- typeof _express.Response === "undefined" ? Object : _express.Response
582
- ]),
583
- _ts_metadata("design:returntype", Promise)
584
- ], PrintJobController.prototype, "createJobFromFile", null);
585
446
  PrintJobController = _ts_decorate([
586
447
  (0, _awilixexpress.route)(_serverconstants.AppConstants.apiRoute + "/print-jobs"),
587
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","itemsWithThumbnails","Promise","all","map","job","thumbnails","fileStorageId","metadata","loadMetadata","_thumbnails","thumb","index","width","height","format","size","pages","Math","ceil","getJob","jobId","local","id","getJobByIdOrFail","error","status","setCompleted","includes","currentStatus","suggestion","log","endedAt","progress","statusReason","statistics","startedAt","actualPrintTimeSeconds","printJobRepository","save","message","previousStatus","newStatus","Error","setFailed","actualTimeSeconds","getTime","failureReason","failureTime","setCancelled","setUnknown","reAnalyzeJob","triggerFileAnalysis","filePath","getFilePath","exists","needsAnalysis","NotFoundException","analysisState","analyzeFile","thumbnailMetadata","length","saveThumbnails","handleFileAnalyzed","fileHash","saveMetadata","fileName","thumbnailCount","deleteJob","deleteFileParam","deleteFile","remove","otherJobs","where","fileDeleted","warn","remainingReferences","createJobFromFile","printerId","body","fileExists","printerName","createPendingJob","_originalFileName","_fileHash","analyzedAt","fileFormat","createdAt","date","endOfDay","setHours","ParamId","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 skip = (page - 1) * pageSize;
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","skip","jobs","totalCount","printJobRepository","findAndCount","where","order","printerId","queuePosition","relations","take","queueItems","map","job","jobId","id","fileName","printerName","printer","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","submitToPrinter","ParamId","AppConstants","apiRoute","authenticate","authorizeRoles","ROLES","ADMIN","OPERATOR"],"mappings":"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"}
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":"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"}
@@ -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(uploadedFile, startPrint, token).catch((e)=>{
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.printJobRepository.save(job);
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);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/controllers/printer-files.controller.ts"],"names":["PrinterFilesController","logger","loggerFactory","printerApi","printerFilesStore","printJobService","fileAnalysisService","fileStorageService","multerService","printerThumbnailCache","name","purgeIndexedFiles","req","res","purgeFiles","send","getThumbnails","thumbnails","getAllValues","getFiles","currentPrinterId","getScopedPrinter","log","files","loadFiles","startPrintFile","filePath","validateInput","body","startPrintFileSchema","encodedFilePath","encodeURIComponent","startPrint","getFilesCache","currentPrinter","id","downloadFile","params","path","downloadFileSchema","response","setHeader","headers","length","data","pipe","deleteFileOrFolder","query","getFileSchema","result","deleteFile","clearPrinterFiles","failedFiles","succeededFiles","nonRecursiveFiles","file","push","e","purgePrinterFiles","getPrinterThumbnail","printerThumbnail","getValue","uploadPrinterFile","acceptedExtensions","getAcceptedFileExtensions","printerType","multerLoadFileAsync","startPrintString","uploadFileSchema","ValidationException","error","join","uploadedFile","token","startTrackingSession","uploadFile","catch","clearUploadedFile","errorSummary","ext","extname","originalname","tempPathWithExt","existsSync","NotFoundException","copyFileSync","fileHash","calculateFileHash","substring","existingJob","findDuplicateByHash","metadata","fileStorageId","cachedMetadata","loadMetadata","fileName","analysisState","saveMetadata","existingFilePath","getFilePath","analysisResult","analyzeFile","fileFormat","totalLayers","gcodePrintTimeSeconds","filamentUsedGrams","saveFile","thumbnailMetadata","saveThumbnails","job","createPendingJob","printJobRepository","save","unlinkSync","captureException","BambuType","AppConstants","defaultAcceptedBambuExtensions","defaultAcceptedGcodeExtensions","PrinterFiles","Clear","Get","Actions","Delete","Upload","apiRoute","authenticate","authorizeRoles","ROLES","ADMIN","OPERATOR","printerResolveMiddleware"],"mappings":"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"}
1
+ {"version":3,"sources":["../../src/controllers/printer-files.controller.ts"],"names":["PrinterFilesController","logger","loggerFactory","printerApi","printerFilesStore","printJobService","fileAnalysisService","fileStorageService","multerService","printerThumbnailCache","name","purgeIndexedFiles","req","res","purgeFiles","send","getThumbnails","thumbnails","getAllValues","getFiles","currentPrinterId","getScopedPrinter","log","files","loadFiles","startPrintFile","filePath","validateInput","body","startPrintFileSchema","encodedFilePath","encodeURIComponent","startPrint","getFilesCache","currentPrinter","id","downloadFile","params","path","downloadFileSchema","response","setHeader","headers","length","data","pipe","deleteFileOrFolder","query","getFileSchema","result","deleteFile","clearPrinterFiles","failedFiles","succeededFiles","nonRecursiveFiles","file","push","e","purgePrinterFiles","getPrinterThumbnail","printerThumbnail","getValue","uploadPrinterFile","acceptedExtensions","getAcceptedFileExtensions","printerType","multerLoadFileAsync","startPrintString","uploadFileSchema","ValidationException","error","join","uploadedFile","token","startTrackingSession","uploadFile","stream","createReadStream","fileName","originalname","contentLength","size","uploadToken","catch","clearUploadedFile","errorSummary","ext","extname","tempPathWithExt","existsSync","NotFoundException","copyFileSync","fileHash","calculateFileHash","substring","existingJob","findDuplicateByHash","metadata","fileStorageId","cachedMetadata","loadMetadata","analysisState","saveMetadata","existingFilePath","getFilePath","analysisResult","analyzeFile","fileFormat","totalLayers","gcodePrintTimeSeconds","filamentUsedGrams","saveFile","thumbnailMetadata","saveThumbnails","job","createPendingJob","updateJob","unlinkSync","captureException","BambuType","AppConstants","defaultAcceptedBambuExtensions","defaultAcceptedGcodeExtensions","PrinterFiles","Clear","Get","Actions","Delete","Upload","apiRoute","authenticate","authorizeRoles","ROLES","ADMIN","OPERATOR","printerResolveMiddleware"],"mappings":"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"}
@@ -223,10 +223,10 @@ class PrinterController {
223
223
  }
224
224
  default:
225
225
  {
226
- if (!e.response?.status) {
227
- throw new _faileddependencyexception.FailedDependencyException(`Reaching Printer service failed without status (code ${e.code})`);
228
- } else {
226
+ if (e.response?.status) {
229
227
  throw new _faileddependencyexception.FailedDependencyException(`Reaching Printer service failed with status (code ${e.code})`, e.response?.status);
228
+ } else {
229
+ throw new _faileddependencyexception.FailedDependencyException(`Reaching Printer service failed without status (code ${e.code})`);
230
230
  }
231
231
  }
232
232
  }