@fdm-monster/server 2.0.10 → 2.0.11

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 (929) hide show
  1. package/.claude/CLAUDE.md +76 -0
  2. package/.vite-hooks/pre-commit +1 -0
  3. package/.yarn/install-state.gz +0 -0
  4. package/.yarn/releases/yarn-4.13.0.cjs +940 -0
  5. package/.yarnrc.yml +1 -1
  6. package/README.md +1 -1
  7. package/RELEASE_NOTES.MD +14 -0
  8. package/dist/_virtual/_@oxc-project_runtime@0.127.0/helpers/decorate.js +9 -0
  9. package/dist/_virtual/_@oxc-project_runtime@0.127.0/helpers/decorateMetadata.js +6 -0
  10. package/dist/_virtual/_rolldown/runtime.js +13 -0
  11. package/dist/_virtual/_virtual_controllers.js +43 -0
  12. package/dist/consoles/typeorm-create.js +51 -112
  13. package/dist/consoles/typeorm-create.js.map +1 -1
  14. package/dist/consoles/typeorm-generate.js +99 -165
  15. package/dist/consoles/typeorm-generate.js.map +1 -1
  16. package/dist/consoles/typeorm-migrate.js +35 -43
  17. package/dist/consoles/typeorm-migrate.js.map +1 -1
  18. package/dist/constants/authorization.constants.js +75 -97
  19. package/dist/constants/authorization.constants.js.map +1 -1
  20. package/dist/constants/event.constants.js +11 -41
  21. package/dist/constants/event.constants.js.map +1 -1
  22. package/dist/constants/http-status-codes.constants.js +319 -71
  23. package/dist/constants/http-status-codes.constants.js.map +1 -1
  24. package/dist/constants/server-settings.constants.js +45 -87
  25. package/dist/constants/server-settings.constants.js.map +1 -1
  26. package/dist/constants/service.constants.js +3 -21
  27. package/dist/constants/service.constants.js.map +1 -1
  28. package/dist/container.js +167 -181
  29. package/dist/container.js.map +1 -1
  30. package/dist/container.tokens.js +78 -85
  31. package/dist/container.tokens.js.map +1 -1
  32. package/dist/controllers/auth.controller.js +156 -225
  33. package/dist/controllers/auth.controller.js.map +1 -1
  34. package/dist/controllers/batch-call.controller.js +79 -116
  35. package/dist/controllers/batch-call.controller.js.map +1 -1
  36. package/dist/controllers/camera-stream.controller.js +74 -119
  37. package/dist/controllers/camera-stream.controller.js.map +1 -1
  38. package/dist/controllers/dto/update-client-dist.dto.js +8 -15
  39. package/dist/controllers/dto/update-client-dist.dto.js.map +1 -1
  40. package/dist/controllers/file-storage.controller.js +251 -312
  41. package/dist/controllers/file-storage.controller.js.map +1 -1
  42. package/dist/controllers/first-time-setup.controller.js +83 -135
  43. package/dist/controllers/first-time-setup.controller.js.map +1 -1
  44. package/dist/controllers/floor.controller.js +111 -175
  45. package/dist/controllers/floor.controller.js.map +1 -1
  46. package/dist/controllers/metrics.controller.js +27 -53
  47. package/dist/controllers/metrics.controller.js.map +1 -1
  48. package/dist/controllers/print-job.controller.js +366 -451
  49. package/dist/controllers/print-job.controller.js.map +1 -1
  50. package/dist/controllers/print-queue.controller.js +329 -427
  51. package/dist/controllers/print-queue.controller.js.map +1 -1
  52. package/dist/controllers/printer-files.controller.js +244 -305
  53. package/dist/controllers/printer-files.controller.js.map +1 -1
  54. package/dist/controllers/printer-maintenance-log.controller.js +109 -165
  55. package/dist/controllers/printer-maintenance-log.controller.js.map +1 -1
  56. package/dist/controllers/printer-settings.controller.js +50 -81
  57. package/dist/controllers/printer-settings.controller.js.map +1 -1
  58. package/dist/controllers/printer-tag.controller.js +104 -166
  59. package/dist/controllers/printer-tag.controller.js.map +1 -1
  60. package/dist/controllers/printer.controller.js +352 -469
  61. package/dist/controllers/printer.controller.js.map +1 -1
  62. package/dist/controllers/server-private.controller.js +182 -239
  63. package/dist/controllers/server-private.controller.js.map +1 -1
  64. package/dist/controllers/server-public.controller.js +104 -158
  65. package/dist/controllers/server-public.controller.js.map +1 -1
  66. package/dist/controllers/settings.controller.js +229 -364
  67. package/dist/controllers/settings.controller.js.map +1 -1
  68. package/dist/controllers/slicer-compat.controller.js +179 -206
  69. package/dist/controllers/slicer-compat.controller.js.map +1 -1
  70. package/dist/controllers/user.controller.js +226 -348
  71. package/dist/controllers/user.controller.js.map +1 -1
  72. package/dist/controllers/validation/auth-controller.validation.js +5 -14
  73. package/dist/controllers/validation/auth-controller.validation.js.map +1 -1
  74. package/dist/controllers/validation/batch-controller.validation.js +13 -35
  75. package/dist/controllers/validation/batch-controller.validation.js.map +1 -1
  76. package/dist/controllers/validation/generic.validation.js +6 -23
  77. package/dist/controllers/validation/generic.validation.js.map +1 -1
  78. package/dist/controllers/validation/printer-completion-controller.validation.js +5 -14
  79. package/dist/controllers/validation/printer-completion-controller.validation.js.map +1 -1
  80. package/dist/controllers/validation/printer-controller.validation.js +16 -48
  81. package/dist/controllers/validation/printer-controller.validation.js.map +1 -1
  82. package/dist/controllers/validation/printer-files-controller.validation.js +12 -47
  83. package/dist/controllers/validation/printer-files-controller.validation.js.map +1 -1
  84. package/dist/controllers/validation/printer-settings-controller.validation.js +5 -14
  85. package/dist/controllers/validation/printer-settings-controller.validation.js.map +1 -1
  86. package/dist/controllers/validation/server-private.validation.js +7 -14
  87. package/dist/controllers/validation/server-private.validation.js.map +1 -1
  88. package/dist/controllers/validation/setting.validation.js +12 -34
  89. package/dist/controllers/validation/setting.validation.js.map +1 -1
  90. package/dist/controllers/validation/user-controller.validation.js +27 -65
  91. package/dist/controllers/validation/user-controller.validation.js.map +1 -1
  92. package/dist/data-source.js +74 -79
  93. package/dist/data-source.js.map +1 -1
  94. package/dist/entities/camera-stream.entity.js +49 -91
  95. package/dist/entities/camera-stream.entity.js.map +1 -1
  96. package/dist/entities/floor-position.entity.js +38 -75
  97. package/dist/entities/floor-position.entity.js.map +1 -1
  98. package/dist/entities/floor.entity.js +18 -48
  99. package/dist/entities/floor.entity.js.map +1 -1
  100. package/dist/entities/index.js +14 -66
  101. package/dist/entities/print-job.entity.js +114 -196
  102. package/dist/entities/print-job.entity.js.map +1 -1
  103. package/dist/entities/printer-maintenance-log.entity.js +61 -140
  104. package/dist/entities/printer-maintenance-log.entity.js.map +1 -1
  105. package/dist/entities/printer-tag.entity.js +33 -66
  106. package/dist/entities/printer-tag.entity.js.map +1 -1
  107. package/dist/entities/printer.entity.js +67 -124
  108. package/dist/entities/printer.entity.js.map +1 -1
  109. package/dist/entities/refresh-token.entity.js +31 -66
  110. package/dist/entities/refresh-token.entity.js.map +1 -1
  111. package/dist/entities/role.entity.js +16 -45
  112. package/dist/entities/role.entity.js.map +1 -1
  113. package/dist/entities/settings.entity.js +38 -77
  114. package/dist/entities/settings.entity.js.map +1 -1
  115. package/dist/entities/tag.entity.js +19 -43
  116. package/dist/entities/tag.entity.js.map +1 -1
  117. package/dist/entities/user-role.entity.js +30 -67
  118. package/dist/entities/user-role.entity.js.map +1 -1
  119. package/dist/entities/user.entity.js +32 -87
  120. package/dist/entities/user.entity.js.map +1 -1
  121. package/dist/exceptions/failed-dependency.exception.js +11 -18
  122. package/dist/exceptions/failed-dependency.exception.js.map +1 -1
  123. package/dist/exceptions/job.exceptions.js +9 -16
  124. package/dist/exceptions/job.exceptions.js.map +1 -1
  125. package/dist/exceptions/runtime.exceptions.js +82 -121
  126. package/dist/exceptions/runtime.exceptions.js.map +1 -1
  127. package/dist/handlers/event-emitter.js +13 -20
  128. package/dist/handlers/event-emitter.js.map +1 -1
  129. package/dist/handlers/logger-factory.js +7 -14
  130. package/dist/handlers/logger-factory.js.map +1 -1
  131. package/dist/handlers/logger.js +26 -36
  132. package/dist/handlers/logger.js.map +1 -1
  133. package/dist/handlers/logging/file-logging.transport.js +17 -31
  134. package/dist/handlers/logging/file-logging.transport.js.map +1 -1
  135. package/dist/handlers/logging/loki-logging.transport.js +34 -50
  136. package/dist/handlers/logging/loki-logging.transport.js.map +1 -1
  137. package/dist/handlers/logging/static.logger.js +83 -124
  138. package/dist/handlers/logging/static.logger.js.map +1 -1
  139. package/dist/handlers/validators.js +8 -25
  140. package/dist/handlers/validators.js.map +1 -1
  141. package/dist/index.js +23 -26
  142. package/dist/index.js.map +1 -1
  143. package/dist/middleware/authenticate.js +26 -69
  144. package/dist/middleware/authenticate.js.map +1 -1
  145. package/dist/middleware/database.js +16 -22
  146. package/dist/middleware/database.js.map +1 -1
  147. package/dist/middleware/demo.middleware.js +19 -27
  148. package/dist/middleware/demo.middleware.js.map +1 -1
  149. package/dist/middleware/exception.filter.js +109 -133
  150. package/dist/middleware/exception.filter.js.map +1 -1
  151. package/dist/middleware/global.middleware.js +28 -47
  152. package/dist/middleware/global.middleware.js.map +1 -1
  153. package/dist/middleware/param-converter.middleware.js +31 -69
  154. package/dist/middleware/param-converter.middleware.js.map +1 -1
  155. package/dist/middleware/passport.js +38 -64
  156. package/dist/middleware/passport.js.map +1 -1
  157. package/dist/middleware/printer-resolver.js +26 -33
  158. package/dist/middleware/printer-resolver.js.map +1 -1
  159. package/dist/middleware/printer.js +56 -94
  160. package/dist/middleware/printer.js.map +1 -1
  161. package/dist/middleware/slicer-api-key.middleware.js +23 -26
  162. package/dist/middleware/slicer-api-key.middleware.js.map +1 -1
  163. package/dist/middleware/socketio.middleware.js +21 -32
  164. package/dist/middleware/socketio.middleware.js.map +1 -1
  165. package/dist/migrations/1706829146617-InitSqlite.js +84 -91
  166. package/dist/migrations/1706829146617-InitSqlite.js.map +1 -1
  167. package/dist/migrations/1707494762198-PrinterGroup.js +22 -29
  168. package/dist/migrations/1707494762198-PrinterGroup.js.map +1 -1
  169. package/dist/migrations/1708465930665-ChangePrintCompletionDeletePrinterCascade.js +26 -33
  170. package/dist/migrations/1708465930665-ChangePrintCompletionDeletePrinterCascade.js.map +1 -1
  171. package/dist/migrations/1713300747465-ChangeRoleNameUnique.js +27 -34
  172. package/dist/migrations/1713300747465-ChangeRoleNameUnique.js.map +1 -1
  173. package/dist/migrations/1713897879622-AddPrinterType.js +34 -41
  174. package/dist/migrations/1713897879622-AddPrinterType.js.map +1 -1
  175. package/dist/migrations/1720338804844-RemovePrinterFile.js +12 -19
  176. package/dist/migrations/1720338804844-RemovePrinterFile.js.map +1 -1
  177. package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js +26 -33
  178. package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js.map +1 -1
  179. package/dist/migrations/1766576698569-DropPermissions.js +11 -18
  180. package/dist/migrations/1766576698569-DropPermissions.js.map +1 -1
  181. package/dist/migrations/1767278216516-ChangeCameraPrinterOnDeleteSetNull.js +26 -33
  182. package/dist/migrations/1767278216516-ChangeCameraPrinterOnDeleteSetNull.js.map +1 -1
  183. package/dist/migrations/1767279607392-DropCustomGcode.js +12 -19
  184. package/dist/migrations/1767279607392-DropCustomGcode.js.map +1 -1
  185. package/dist/migrations/1767291804417-DropPrintCompletions.js +12 -19
  186. package/dist/migrations/1767291804417-DropPrintCompletions.js.map +1 -1
  187. package/dist/migrations/1767352862576-DropSettingsFileClean.js +18 -25
  188. package/dist/migrations/1767352862576-DropSettingsFileClean.js.map +1 -1
  189. package/dist/migrations/1767355639023-ChangeFloorLevelToOrder.js +26 -33
  190. package/dist/migrations/1767355639023-ChangeFloorLevelToOrder.js.map +1 -1
  191. package/dist/migrations/1767370191762-ChangeFloorNonUniqueOrder.js +18 -25
  192. package/dist/migrations/1767370191762-ChangeFloorNonUniqueOrder.js.map +1 -1
  193. package/dist/migrations/1767432108916-RenameGroupToTag.js +22 -29
  194. package/dist/migrations/1767432108916-RenameGroupToTag.js.map +1 -1
  195. package/dist/migrations/1767451444137-AddPrintJob.js +20 -27
  196. package/dist/migrations/1767451444137-AddPrintJob.js.map +1 -1
  197. package/dist/migrations/1767909428129-AddPrinterMaintenanceLog.js +14 -21
  198. package/dist/migrations/1767909428129-AddPrinterMaintenanceLog.js.map +1 -1
  199. package/dist/plugins/controllers-plugin.js +21 -0
  200. package/dist/plugins/controllers-plugin.js.map +1 -0
  201. package/dist/server.constants.js +79 -91
  202. package/dist/server.constants.js.map +1 -1
  203. package/dist/server.core.js +56 -122
  204. package/dist/server.core.js.map +1 -1
  205. package/dist/server.env.js +56 -121
  206. package/dist/server.env.js.map +1 -1
  207. package/dist/server.host.js +66 -99
  208. package/dist/server.host.js.map +1 -1
  209. package/dist/services/authentication/auth.service.js +103 -126
  210. package/dist/services/authentication/auth.service.js.map +1 -1
  211. package/dist/services/authentication/jwt.service.js +23 -32
  212. package/dist/services/authentication/jwt.service.js.map +1 -1
  213. package/dist/services/bambu/bambu-ftp.adapter.js +194 -236
  214. package/dist/services/bambu/bambu-ftp.adapter.js.map +1 -1
  215. package/dist/services/bambu/bambu-mqtt.adapter.js +394 -449
  216. package/dist/services/bambu/bambu-mqtt.adapter.js.map +1 -1
  217. package/dist/services/bambu/bambu.client.js +64 -65
  218. package/dist/services/bambu/bambu.client.js.map +1 -1
  219. package/dist/services/bambu/mqtt-message.types.js +1 -6
  220. package/dist/services/bambu.api.js +230 -247
  221. package/dist/services/bambu.api.js.map +1 -1
  222. package/dist/services/core/batch-call.service.js +139 -163
  223. package/dist/services/core/batch-call.service.js.map +1 -1
  224. package/dist/services/core/client-bundle.service.js +126 -165
  225. package/dist/services/core/client-bundle.service.js.map +1 -1
  226. package/dist/services/core/config.service.js +16 -26
  227. package/dist/services/core/config.service.js.map +1 -1
  228. package/dist/services/core/cradle.service.js +11 -19
  229. package/dist/services/core/cradle.service.js.map +1 -1
  230. package/dist/services/core/github.service.js +59 -79
  231. package/dist/services/core/github.service.js.map +1 -1
  232. package/dist/services/core/http-client.factory.js +30 -38
  233. package/dist/services/core/http-client.factory.js.map +1 -1
  234. package/dist/services/core/logs-manager.service.js +61 -84
  235. package/dist/services/core/logs-manager.service.js.map +1 -1
  236. package/dist/services/core/monsterpi.service.js +26 -36
  237. package/dist/services/core/monsterpi.service.js.map +1 -1
  238. package/dist/services/core/multer.service.js +69 -129
  239. package/dist/services/core/multer.service.js.map +1 -1
  240. package/dist/services/core/server-release.service.js +77 -99
  241. package/dist/services/core/server-release.service.js.map +1 -1
  242. package/dist/services/core/yaml.service.js +443 -573
  243. package/dist/services/core/yaml.service.js.map +1 -1
  244. package/dist/services/file-analysis.service.js +134 -144
  245. package/dist/services/file-analysis.service.js.map +1 -1
  246. package/dist/services/file-storage.service.js +324 -423
  247. package/dist/services/file-storage.service.js.map +1 -1
  248. package/dist/services/interfaces/auth.service.interface.js +1 -6
  249. package/dist/services/interfaces/camera-stream.dto.js +23 -41
  250. package/dist/services/interfaces/camera-stream.dto.js.map +1 -1
  251. package/dist/services/interfaces/camera-stream.service.interface.js +1 -6
  252. package/dist/services/interfaces/file-upload-tracker.interface.js +1 -6
  253. package/dist/services/interfaces/floor.dto.js +31 -55
  254. package/dist/services/interfaces/floor.dto.js.map +1 -1
  255. package/dist/services/interfaces/floor.service.interface.js +1 -6
  256. package/dist/services/interfaces/jwt.service.interface.js +1 -6
  257. package/dist/services/interfaces/login.dto.js +10 -17
  258. package/dist/services/interfaces/login.dto.js.map +1 -1
  259. package/dist/services/interfaces/page.interface.js +5 -12
  260. package/dist/services/interfaces/page.interface.js.map +1 -1
  261. package/dist/services/interfaces/permission.service.interface.js +1 -6
  262. package/dist/services/interfaces/printer-file.dto.js +1 -6
  263. package/dist/services/interfaces/printer-maintenance-log.dto.js +1 -6
  264. package/dist/services/interfaces/printer-tag.dto.js +11 -26
  265. package/dist/services/interfaces/printer-tag.dto.js.map +1 -1
  266. package/dist/services/interfaces/printer-tag.service.interface.js +1 -6
  267. package/dist/services/interfaces/printer.dto.js +21 -36
  268. package/dist/services/interfaces/printer.dto.js.map +1 -1
  269. package/dist/services/interfaces/printer.service.interface.js +1 -6
  270. package/dist/services/interfaces/refresh-token.dto.js +9 -16
  271. package/dist/services/interfaces/refresh-token.dto.js.map +1 -1
  272. package/dist/services/interfaces/refresh-token.service.interface.js +1 -6
  273. package/dist/services/interfaces/role-service.interface.js +1 -6
  274. package/dist/services/interfaces/role.dto.js +7 -14
  275. package/dist/services/interfaces/role.dto.js.map +1 -1
  276. package/dist/services/interfaces/settings.dto.js +10 -17
  277. package/dist/services/interfaces/settings.dto.js.map +1 -1
  278. package/dist/services/interfaces/settings.service.interface.js +1 -6
  279. package/dist/services/interfaces/tag.dto.js +1 -6
  280. package/dist/services/interfaces/task.interfaces.js +1 -6
  281. package/dist/services/interfaces/user-role.dto.js +9 -16
  282. package/dist/services/interfaces/user-role.dto.js.map +1 -1
  283. package/dist/services/interfaces/user-service.interface.js +1 -6
  284. package/dist/services/interfaces/user.dto.js +22 -37
  285. package/dist/services/interfaces/user.dto.js.map +1 -1
  286. package/dist/services/moonraker/constants/moonraker-event.dto.js +16 -31
  287. package/dist/services/moonraker/constants/moonraker-event.dto.js.map +1 -1
  288. package/dist/services/moonraker/constants/moonraker.constants.js +4 -11
  289. package/dist/services/moonraker/constants/moonraker.constants.js.map +1 -1
  290. package/dist/services/moonraker/dto/access/access-info.dto.js +1 -6
  291. package/dist/services/moonraker/dto/access/access-login-refresh.dto.js +1 -6
  292. package/dist/services/moonraker/dto/access/access-login-result.dto.js +1 -6
  293. package/dist/services/moonraker/dto/access/access-user-result.dto.js +1 -6
  294. package/dist/services/moonraker/dto/access/access-user.dto.js +1 -6
  295. package/dist/services/moonraker/dto/database/database-namespace-item.dto.js +1 -6
  296. package/dist/services/moonraker/dto/database/database-namespace-list.dto.js +1 -6
  297. package/dist/services/moonraker/dto/gcode-help.dto.js +1 -6
  298. package/dist/services/moonraker/dto/gcode-store.dto.js +1 -6
  299. package/dist/services/moonraker/dto/job-queue/enqueue-job.dto.js +1 -6
  300. package/dist/services/moonraker/dto/job-queue/job-queue-status.dto.js +1 -6
  301. package/dist/services/moonraker/dto/machine/machine-device-power-device-state.dto.js +1 -6
  302. package/dist/services/moonraker/dto/machine/machine-device-power-devices.dto.js +1 -6
  303. package/dist/services/moonraker/dto/machine/machine-peripherals-canbus.dto.js +1 -6
  304. package/dist/services/moonraker/dto/machine/machine-peripherals-serial.dto.js +1 -6
  305. package/dist/services/moonraker/dto/machine/machine-peripherals-usb.dto.js +1 -6
  306. package/dist/services/moonraker/dto/machine/machine-peripherals-video.dto.js +1 -6
  307. package/dist/services/moonraker/dto/machine/machine-system-info.dto.js +1 -6
  308. package/dist/services/moonraker/dto/machine/machine-update-status.dto.js +1 -6
  309. package/dist/services/moonraker/dto/machine/machine-wled-strips.dto.js +1 -6
  310. package/dist/services/moonraker/dto/notifier-list.dto.js +1 -6
  311. package/dist/services/moonraker/dto/objects/bed-mesh.dto.js +1 -6
  312. package/dist/services/moonraker/dto/objects/configfile.dto.js +1 -6
  313. package/dist/services/moonraker/dto/objects/display-status.dto.js +1 -6
  314. package/dist/services/moonraker/dto/objects/extruder.dto.js +1 -6
  315. package/dist/services/moonraker/dto/objects/fan.dto.js +1 -6
  316. package/dist/services/moonraker/dto/objects/filament-motion-sensor.dto.js +1 -6
  317. package/dist/services/moonraker/dto/objects/filament-switch-sensor.dto.js +1 -6
  318. package/dist/services/moonraker/dto/objects/gcode-move.dto.js +1 -6
  319. package/dist/services/moonraker/dto/objects/gcode.dto.js +1 -6
  320. package/dist/services/moonraker/dto/objects/heater-bed.dto.js +1 -6
  321. package/dist/services/moonraker/dto/objects/heaters.dto.js +1 -6
  322. package/dist/services/moonraker/dto/objects/idle-timeout.dto.js +6 -21
  323. package/dist/services/moonraker/dto/objects/idle-timeout.dto.js.map +1 -1
  324. package/dist/services/moonraker/dto/objects/mcu.dto.js +1 -6
  325. package/dist/services/moonraker/dto/objects/motion-report.dto.js +1 -6
  326. package/dist/services/moonraker/dto/objects/output-pin.dto.js +1 -6
  327. package/dist/services/moonraker/dto/objects/pause-resume.dto.js +1 -6
  328. package/dist/services/moonraker/dto/objects/print-stats.dto.js +9 -24
  329. package/dist/services/moonraker/dto/objects/print-stats.dto.js.map +1 -1
  330. package/dist/services/moonraker/dto/objects/printer-object.dto.js +1 -6
  331. package/dist/services/moonraker/dto/objects/printer-object.types.js +1 -6
  332. package/dist/services/moonraker/dto/objects/printer-objects-list.dto.js +28 -43
  333. package/dist/services/moonraker/dto/objects/printer-objects-list.dto.js.map +1 -1
  334. package/dist/services/moonraker/dto/objects/printer-objects-query.dto.js +1 -6
  335. package/dist/services/moonraker/dto/objects/stepper-enable.dto.js +1 -6
  336. package/dist/services/moonraker/dto/objects/system-stats.dto.js +1 -6
  337. package/dist/services/moonraker/dto/objects/temperature-fan.dto.js +1 -6
  338. package/dist/services/moonraker/dto/objects/temperature-sensor.dto.js +1 -6
  339. package/dist/services/moonraker/dto/objects/toolhead.dto.js +1 -6
  340. package/dist/services/moonraker/dto/objects/virtual-sdcard.dto.js +1 -6
  341. package/dist/services/moonraker/dto/objects/webhooks.dto.js +1 -6
  342. package/dist/services/moonraker/dto/octoprint-compat/api-job.dto.js +1 -6
  343. package/dist/services/moonraker/dto/octoprint-compat/api-login.dto.js +1 -6
  344. package/dist/services/moonraker/dto/octoprint-compat/api-printer.dto.js +1 -6
  345. package/dist/services/moonraker/dto/octoprint-compat/api-profiles.dto.js +1 -6
  346. package/dist/services/moonraker/dto/octoprint-compat/api-settings.dto.js +1 -6
  347. package/dist/services/moonraker/dto/octoprint-compat/api-version.dto.js +1 -6
  348. package/dist/services/moonraker/dto/octoprint-compat/server-version.dto.js +1 -6
  349. package/dist/services/moonraker/dto/printer-info.dto.js +7 -22
  350. package/dist/services/moonraker/dto/printer-info.dto.js.map +1 -1
  351. package/dist/services/moonraker/dto/printer-query-endstops.dto.js +1 -6
  352. package/dist/services/moonraker/dto/process-stats.dto.js +1 -6
  353. package/dist/services/moonraker/dto/rest/action-result.dto.js +1 -6
  354. package/dist/services/moonraker/dto/rest/error.dto.js +1 -6
  355. package/dist/services/moonraker/dto/rest/result.dto.js +6 -13
  356. package/dist/services/moonraker/dto/rest/result.dto.js.map +1 -1
  357. package/dist/services/moonraker/dto/rollover-logs.dto.js +1 -6
  358. package/dist/services/moonraker/dto/rpc/json-rpc-error.dto.js +1 -6
  359. package/dist/services/moonraker/dto/rpc/json-rpc-request.dto.js +1 -6
  360. package/dist/services/moonraker/dto/rpc/json-rpc-response.dto.js +1 -6
  361. package/dist/services/moonraker/dto/server/server-config.dto.js +1 -6
  362. package/dist/services/moonraker/dto/server/server-info.dto.js +7 -14
  363. package/dist/services/moonraker/dto/server/server-info.dto.js.map +1 -1
  364. package/dist/services/moonraker/dto/server-announcements/announcement-action.dto.js +1 -6
  365. package/dist/services/moonraker/dto/server-announcements/announcement-entry-id.dto.js +1 -6
  366. package/dist/services/moonraker/dto/server-announcements/announcement-feeds.dto.js +1 -6
  367. package/dist/services/moonraker/dto/server-announcements/announcement-list.dto.js +1 -6
  368. package/dist/services/moonraker/dto/server-files/server-file-directory-action.dto.js +1 -6
  369. package/dist/services/moonraker/dto/server-files/server-file-directory-info.dto.js +1 -6
  370. package/dist/services/moonraker/dto/server-files/server-file-metadata.dto.js +1 -6
  371. package/dist/services/moonraker/dto/server-files/server-file-root.dto.js +1 -6
  372. package/dist/services/moonraker/dto/server-files/server-file-thumbnail.dto.js +1 -6
  373. package/dist/services/moonraker/dto/server-files/server-file-zip-action.dto.js +1 -6
  374. package/dist/services/moonraker/dto/server-files/server-file.dto.js +1 -6
  375. package/dist/services/moonraker/dto/server-history/history-job.dto.js +1 -6
  376. package/dist/services/moonraker/dto/server-history/history-last-totals.dto.js +1 -6
  377. package/dist/services/moonraker/dto/server-history/history-list.dto.js +1 -6
  378. package/dist/services/moonraker/dto/server-history/history-totals.dto.js +1 -6
  379. package/dist/services/moonraker/dto/server-history/job.dto.js +6 -21
  380. package/dist/services/moonraker/dto/server-history/job.dto.js.map +1 -1
  381. package/dist/services/moonraker/dto/server-sensors/sensor-info.dto.js +1 -6
  382. package/dist/services/moonraker/dto/server-sensors/sensor-list.dto.js +1 -6
  383. package/dist/services/moonraker/dto/server-sensors/sensor-measurements.dto.js +1 -6
  384. package/dist/services/moonraker/dto/server-webcams/webcam-item.dto.js +1 -6
  385. package/dist/services/moonraker/dto/server-webcams/webcam-list.dto.js +1 -6
  386. package/dist/services/moonraker/dto/server-webcams/webcam-test.dto.js +1 -6
  387. package/dist/services/moonraker/dto/spoolman/spoolman-active-spool.dto.js +1 -6
  388. package/dist/services/moonraker/dto/spoolman/spoolman-proxy-request.dto.js +1 -6
  389. package/dist/services/moonraker/dto/spoolman/spoolman-response.dto.js +1 -6
  390. package/dist/services/moonraker/dto/spoolman/spoolman-status.dto.js +1 -6
  391. package/dist/services/moonraker/dto/sudo-info.dto.js +1 -6
  392. package/dist/services/moonraker/dto/sudo-response.dto.js +1 -6
  393. package/dist/services/moonraker/dto/temperature-store.dto.js +1 -6
  394. package/dist/services/moonraker/dto/websocket/connection-identify-response.dto.js +1 -6
  395. package/dist/services/moonraker/dto/websocket/connection-identify.dto.js +1 -6
  396. package/dist/services/moonraker/dto/websocket/json-rpc-event.dto.js +1 -6
  397. package/dist/services/moonraker/dto/websocket/message.types.js +1 -6
  398. package/dist/services/moonraker/dto/websocket/methods.js +29 -44
  399. package/dist/services/moonraker/dto/websocket/methods.js.map +1 -1
  400. package/dist/services/moonraker/dto/websocket/notify-active-spool-set.params.js +1 -6
  401. package/dist/services/moonraker/dto/websocket/notify-agent-event.params.js +1 -6
  402. package/dist/services/moonraker/dto/websocket/notify-announcement-update.params.js +1 -6
  403. package/dist/services/moonraker/dto/websocket/notify-announcement.params.js +1 -6
  404. package/dist/services/moonraker/dto/websocket/notify-button-event.params.js +1 -6
  405. package/dist/services/moonraker/dto/websocket/notify-filelist-changed.params.js +11 -18
  406. package/dist/services/moonraker/dto/websocket/notify-filelist-changed.params.js.map +1 -1
  407. package/dist/services/moonraker/dto/websocket/notify-history-changed.params.js +1 -6
  408. package/dist/services/moonraker/dto/websocket/notify-job-queue-changed.params.js +1 -6
  409. package/dist/services/moonraker/dto/websocket/notify-proc-stat-update.params.js +1 -6
  410. package/dist/services/moonraker/dto/websocket/notify-sensor-update.params.js +1 -6
  411. package/dist/services/moonraker/dto/websocket/notify-service-state-changed.params.js +1 -6
  412. package/dist/services/moonraker/dto/websocket/notify-spoolman-status-changed.js +1 -6
  413. package/dist/services/moonraker/dto/websocket/notify-sudo-alert.params.js +1 -6
  414. package/dist/services/moonraker/dto/websocket/notify-update-response.params.js +7 -22
  415. package/dist/services/moonraker/dto/websocket/notify-update-response.params.js.map +1 -1
  416. package/dist/services/moonraker/dto/websocket/notify-user-change.params.js +1 -6
  417. package/dist/services/moonraker/moonraker-websocket.adapter.js +313 -348
  418. package/dist/services/moonraker/moonraker-websocket.adapter.js.map +1 -1
  419. package/dist/services/moonraker/moonraker.client.js +536 -559
  420. package/dist/services/moonraker/moonraker.client.js.map +1 -1
  421. package/dist/services/moonraker.api.js +167 -192
  422. package/dist/services/moonraker.api.js.map +1 -1
  423. package/dist/services/octoprint/constants/firmware-update-settings.constants.js +19 -28
  424. package/dist/services/octoprint/constants/firmware-update-settings.constants.js.map +1 -1
  425. package/dist/services/octoprint/constants/octoprint-service.constants.js +3 -30
  426. package/dist/services/octoprint/constants/octoprint-service.constants.js.map +1 -1
  427. package/dist/services/octoprint/constants/octoprint-websocket.constants.js +41 -56
  428. package/dist/services/octoprint/constants/octoprint-websocket.constants.js.map +1 -1
  429. package/dist/services/octoprint/dto/access/user-list.dto.js +1 -6
  430. package/dist/services/octoprint/dto/access/user.dto.js +1 -6
  431. package/dist/services/octoprint/dto/auth/current-user.dto.js +1 -6
  432. package/dist/services/octoprint/dto/auth/login.dto.js +1 -6
  433. package/dist/services/octoprint/dto/connection/connection-state.type.js +23 -30
  434. package/dist/services/octoprint/dto/connection/connection-state.type.js.map +1 -1
  435. package/dist/services/octoprint/dto/connection/connection.dto.js +1 -6
  436. package/dist/services/octoprint/dto/events/client-authed.dto.js +1 -6
  437. package/dist/services/octoprint/dto/events/client-closed.dto.js +1 -6
  438. package/dist/services/octoprint/dto/events/client-opened.dto.js +1 -6
  439. package/dist/services/octoprint/dto/events/dwelling.dto.js +1 -6
  440. package/dist/services/octoprint/dto/events/file-added.dto.js +1 -6
  441. package/dist/services/octoprint/dto/events/file-deselected.dto.js +1 -6
  442. package/dist/services/octoprint/dto/events/file-removed.dto.js +1 -6
  443. package/dist/services/octoprint/dto/events/folder-added.dto.js +1 -6
  444. package/dist/services/octoprint/dto/events/home.dto.js +1 -6
  445. package/dist/services/octoprint/dto/events/metadata-analysis-finished.dto.js +1 -6
  446. package/dist/services/octoprint/dto/events/metadata-analysis-started.dto.js +1 -6
  447. package/dist/services/octoprint/dto/events/metadata-statistics-updated.dto.js +1 -6
  448. package/dist/services/octoprint/dto/events/position-update.dto.js +1 -6
  449. package/dist/services/octoprint/dto/events/print-cancelled.dto.js +1 -6
  450. package/dist/services/octoprint/dto/events/print-cancelling.dto.js +1 -6
  451. package/dist/services/octoprint/dto/events/print-done.dto.js +1 -6
  452. package/dist/services/octoprint/dto/events/print-failed.dto.js +1 -6
  453. package/dist/services/octoprint/dto/events/print-paused.dto.js +1 -6
  454. package/dist/services/octoprint/dto/events/print-resumed.dto.js +1 -6
  455. package/dist/services/octoprint/dto/events/print-started.dto.js +1 -6
  456. package/dist/services/octoprint/dto/events/printer-state-changed.dto.js +1 -6
  457. package/dist/services/octoprint/dto/events/transfer-done.dto.js +1 -6
  458. package/dist/services/octoprint/dto/events/transfer-started.dto.js +1 -6
  459. package/dist/services/octoprint/dto/events/updated-files.dto.js +1 -6
  460. package/dist/services/octoprint/dto/events/upload.dto.js +1 -6
  461. package/dist/services/octoprint/dto/events/user-logged-in.dto.js +1 -6
  462. package/dist/services/octoprint/dto/events/z-change.dto.js +1 -6
  463. package/dist/services/octoprint/dto/files/gcode-analysis.dto.js +1 -6
  464. package/dist/services/octoprint/dto/files/octoprint-file.dto.js +1 -6
  465. package/dist/services/octoprint/dto/files/octoprint-files-response.dto.js +1 -6
  466. package/dist/services/octoprint/dto/job/current-job.dto.js +8 -15
  467. package/dist/services/octoprint/dto/job/current-job.dto.js.map +1 -1
  468. package/dist/services/octoprint/dto/job/job.dto.js +1 -6
  469. package/dist/services/octoprint/dto/octoprint-event.dto.js +21 -39
  470. package/dist/services/octoprint/dto/octoprint-event.dto.js.map +1 -1
  471. package/dist/services/octoprint/dto/printer/busy-file.dto.js +1 -6
  472. package/dist/services/octoprint/dto/printer/current-printer-state.dto.js +1 -6
  473. package/dist/services/octoprint/dto/printer/flags.dto.js +1 -6
  474. package/dist/services/octoprint/dto/printer/markings.dto.js +1 -6
  475. package/dist/services/octoprint/dto/printer/progress.dto.js +1 -6
  476. package/dist/services/octoprint/dto/printer/resends.dto.js +1 -6
  477. package/dist/services/octoprint/dto/printer/state.dto.js +1 -6
  478. package/dist/services/octoprint/dto/printer/temps.dto.js +1 -6
  479. package/dist/services/octoprint/dto/rest/error.dto.js +1 -6
  480. package/dist/services/octoprint/dto/server/server.dto.js +1 -6
  481. package/dist/services/octoprint/dto/server/version.dto.js +1 -6
  482. package/dist/services/octoprint/dto/settings/serial-settings.dto.js +1 -6
  483. package/dist/services/octoprint/dto/settings/settings-parts.type.js +1 -6
  484. package/dist/services/octoprint/dto/settings/settings.dto.js +1 -6
  485. package/dist/services/octoprint/dto/settings/virtual-printer-settings.dto.js +1 -6
  486. package/dist/services/octoprint/dto/system/system-info.dto.js +32 -39
  487. package/dist/services/octoprint/dto/system/system-info.dto.js.map +1 -1
  488. package/dist/services/octoprint/dto/websocket/connection-message.dto.js +1 -6
  489. package/dist/services/octoprint/dto/websocket/current-message.dto.js +1 -6
  490. package/dist/services/octoprint/dto/websocket/event-message.dto.js +1 -6
  491. package/dist/services/octoprint/dto/websocket/event.type.js +42 -49
  492. package/dist/services/octoprint/dto/websocket/event.type.js.map +1 -1
  493. package/dist/services/octoprint/dto/websocket/history-message.dto.js +1 -6
  494. package/dist/services/octoprint/dto/websocket/plugin-message.dto.js +1 -6
  495. package/dist/services/octoprint/dto/websocket/timelapse-message.dto.js +1 -6
  496. package/dist/services/octoprint/octoprint-api.routes.js +77 -94
  497. package/dist/services/octoprint/octoprint-api.routes.js.map +1 -1
  498. package/dist/services/octoprint/octoprint-websocket.adapter.js +265 -315
  499. package/dist/services/octoprint/octoprint-websocket.adapter.js.map +1 -1
  500. package/dist/services/octoprint/octoprint.client.js +220 -261
  501. package/dist/services/octoprint/octoprint.client.js.map +1 -1
  502. package/dist/services/octoprint/utils/api.utils.js +15 -32
  503. package/dist/services/octoprint/utils/api.utils.js.map +1 -1
  504. package/dist/services/octoprint/utils/file.utils.js +44 -67
  505. package/dist/services/octoprint/utils/file.utils.js.map +1 -1
  506. package/dist/services/octoprint/utils/octoprint-http-client.builder.js +16 -29
  507. package/dist/services/octoprint/utils/octoprint-http-client.builder.js.map +1 -1
  508. package/dist/services/octoprint.api.js +113 -128
  509. package/dist/services/octoprint.api.js.map +1 -1
  510. package/dist/services/orm/base.interface.js +1 -6
  511. package/dist/services/orm/base.service.js +57 -73
  512. package/dist/services/orm/base.service.js.map +1 -1
  513. package/dist/services/orm/camera-stream.service.js +21 -27
  514. package/dist/services/orm/camera-stream.service.js.map +1 -1
  515. package/dist/services/orm/floor-position.service.js +42 -49
  516. package/dist/services/orm/floor-position.service.js.map +1 -1
  517. package/dist/services/orm/floor.service.js +110 -138
  518. package/dist/services/orm/floor.service.js.map +1 -1
  519. package/dist/services/orm/permission.service.js +16 -23
  520. package/dist/services/orm/permission.service.js.map +1 -1
  521. package/dist/services/orm/print-job.service.js +443 -545
  522. package/dist/services/orm/print-job.service.js.map +1 -1
  523. package/dist/services/orm/printer-maintenance-log.service.js +102 -149
  524. package/dist/services/orm/printer-maintenance-log.service.js.map +1 -1
  525. package/dist/services/orm/printer-tag.service.js +93 -118
  526. package/dist/services/orm/printer-tag.service.js.map +1 -1
  527. package/dist/services/orm/printer.service.js +110 -158
  528. package/dist/services/orm/printer.service.js.map +1 -1
  529. package/dist/services/orm/refresh-token.service.js +69 -99
  530. package/dist/services/orm/refresh-token.service.js.map +1 -1
  531. package/dist/services/orm/role.service.js +99 -116
  532. package/dist/services/orm/role.service.js.map +1 -1
  533. package/dist/services/orm/settings.service.js +84 -94
  534. package/dist/services/orm/settings.service.js.map +1 -1
  535. package/dist/services/orm/user-role.service.js +39 -53
  536. package/dist/services/orm/user-role.service.js.map +1 -1
  537. package/dist/services/orm/user.service.js +142 -189
  538. package/dist/services/orm/user.service.js.map +1 -1
  539. package/dist/services/print-file-downloader.service.js +153 -167
  540. package/dist/services/print-file-downloader.service.js.map +1 -1
  541. package/dist/services/print-queue.service.js +240 -326
  542. package/dist/services/print-queue.service.js.map +1 -1
  543. package/dist/services/printer-api.factory.js +26 -43
  544. package/dist/services/printer-api.factory.js.map +1 -1
  545. package/dist/services/printer-api.interface.js +23 -53
  546. package/dist/services/printer-api.interface.js.map +1 -1
  547. package/dist/services/prusa-link/constants/prusalink-event.dto.js +9 -16
  548. package/dist/services/prusa-link/constants/prusalink-event.dto.js.map +1 -1
  549. package/dist/services/prusa-link/constants/prusalink.constants.js +4 -11
  550. package/dist/services/prusa-link/constants/prusalink.constants.js.map +1 -1
  551. package/dist/services/prusa-link/dto/file-response.dto.js +1 -6
  552. package/dist/services/prusa-link/dto/file.dto.js +1 -6
  553. package/dist/services/prusa-link/dto/job-state.dto.js +1 -6
  554. package/dist/services/prusa-link/dto/printer-state.dto.js +1 -6
  555. package/dist/services/prusa-link/dto/status.dto.js +1 -6
  556. package/dist/services/prusa-link/dto/version.dto.js +1 -6
  557. package/dist/services/prusa-link/prusa-link-http-polling.adapter.js +141 -157
  558. package/dist/services/prusa-link/prusa-link-http-polling.adapter.js.map +1 -1
  559. package/dist/services/prusa-link/prusa-link.api.js +206 -240
  560. package/dist/services/prusa-link/prusa-link.api.js.map +1 -1
  561. package/dist/services/prusa-link/utils/digest-auth.params.js +1 -6
  562. package/dist/services/prusa-link/utils/digest-auth.util.js +17 -24
  563. package/dist/services/prusa-link/utils/digest-auth.util.js.map +1 -1
  564. package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js +92 -129
  565. package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js.map +1 -1
  566. package/dist/services/socket.factory.js +21 -36
  567. package/dist/services/socket.factory.js.map +1 -1
  568. package/dist/services/task-manager.service.js +190 -174
  569. package/dist/services/task-manager.service.js.map +1 -1
  570. package/dist/services/typeorm/typeorm.service.js +31 -46
  571. package/dist/services/typeorm/typeorm.service.js.map +1 -1
  572. package/dist/services/validators/floor-service.validation.js +26 -63
  573. package/dist/services/validators/floor-service.validation.js.map +1 -1
  574. package/dist/services/validators/print-job.validation.js +11 -26
  575. package/dist/services/validators/print-job.validation.js.map +1 -1
  576. package/dist/services/validators/printer-maintenance-log.validation.js +17 -37
  577. package/dist/services/validators/printer-maintenance-log.validation.js.map +1 -1
  578. package/dist/services/validators/printer-service.validation.js +60 -125
  579. package/dist/services/validators/printer-service.validation.js.map +1 -1
  580. package/dist/services/validators/settings-service.validation.js +46 -106
  581. package/dist/services/validators/settings-service.validation.js.map +1 -1
  582. package/dist/services/validators/user-service.validation.js +19 -36
  583. package/dist/services/validators/user-service.validation.js.map +1 -1
  584. package/dist/services/validators/yaml-service.validation.js +96 -132
  585. package/dist/services/validators/yaml-service.validation.js.map +1 -1
  586. package/dist/services/websocket-adapter.interface.js +1 -6
  587. package/dist/shared/default-http-client.builder.js +74 -92
  588. package/dist/shared/default-http-client.builder.js.map +1 -1
  589. package/dist/shared/dtos/api-state.type.js +8 -15
  590. package/dist/shared/dtos/api-state.type.js.map +1 -1
  591. package/dist/shared/dtos/socket-login.dto.js +1 -6
  592. package/dist/shared/dtos/socket-state.type.js +11 -18
  593. package/dist/shared/dtos/socket-state.type.js.map +1 -1
  594. package/dist/shared/load-controllers.js +41 -19
  595. package/dist/shared/load-controllers.js.map +1 -1
  596. package/dist/shared/runtime-settings.migration.js +43 -50
  597. package/dist/shared/runtime-settings.migration.js.map +1 -1
  598. package/dist/shared/websocket-rpc-extended.adapter.js +74 -75
  599. package/dist/shared/websocket-rpc-extended.adapter.js.map +1 -1
  600. package/dist/shared/websocket.adapter.js +78 -63
  601. package/dist/shared/websocket.adapter.js.map +1 -1
  602. package/dist/state/file-upload-tracker.cache.js +63 -75
  603. package/dist/state/file-upload-tracker.cache.js.map +1 -1
  604. package/dist/state/floor.store.js +77 -89
  605. package/dist/state/floor.store.js.map +1 -1
  606. package/dist/state/printer-events.cache.js +237 -295
  607. package/dist/state/printer-events.cache.js.map +1 -1
  608. package/dist/state/printer-socket.store.js +156 -174
  609. package/dist/state/printer-socket.store.js.map +1 -1
  610. package/dist/state/printer-thumbnail.cache.js +129 -130
  611. package/dist/state/printer-thumbnail.cache.js.map +1 -1
  612. package/dist/state/printer.cache.js +87 -102
  613. package/dist/state/printer.cache.js.map +1 -1
  614. package/dist/state/settings.store.js +211 -234
  615. package/dist/state/settings.store.js.map +1 -1
  616. package/dist/state/socket-io.gateway.js +58 -87
  617. package/dist/state/socket-io.gateway.js.map +1 -1
  618. package/dist/state/test-printer-socket.store.js +116 -137
  619. package/dist/state/test-printer-socket.store.js.map +1 -1
  620. package/dist/state/validation/create-test-printer.validation.js +14 -21
  621. package/dist/state/validation/create-test-printer.validation.js.map +1 -1
  622. package/dist/task.presets.js +30 -37
  623. package/dist/task.presets.js.map +1 -1
  624. package/dist/tasks/boot.task.js +100 -128
  625. package/dist/tasks/boot.task.js.map +1 -1
  626. package/dist/tasks/client-bundle.task.js +20 -28
  627. package/dist/tasks/client-bundle.task.js.map +1 -1
  628. package/dist/tasks/print-job-analysis.task.js +88 -113
  629. package/dist/tasks/print-job-analysis.task.js.map +1 -1
  630. package/dist/tasks/printer-websocket-restore.task.js +41 -54
  631. package/dist/tasks/printer-websocket-restore.task.js.map +1 -1
  632. package/dist/tasks/printer-websocket.task.js +11 -19
  633. package/dist/tasks/printer-websocket.task.js.map +1 -1
  634. package/dist/tasks/socketio.task.js +35 -53
  635. package/dist/tasks/socketio.task.js.map +1 -1
  636. package/dist/tasks/software-update.task.js +12 -20
  637. package/dist/tasks/software-update.task.js.map +1 -1
  638. package/dist/tasks.js +27 -41
  639. package/dist/tasks.js.map +1 -1
  640. package/dist/types/express/index.d.js +1 -6
  641. package/dist/types/virtual-modules.d.js +1 -0
  642. package/dist/utils/array.util.js +9 -24
  643. package/dist/utils/array.util.js.map +1 -1
  644. package/dist/utils/bgcode/bgcode-thumbnail.parser.js +26 -44
  645. package/dist/utils/bgcode/bgcode-thumbnail.parser.js.map +1 -1
  646. package/dist/utils/bgcode/bgcode.constants.js +9 -45
  647. package/dist/utils/bgcode/bgcode.constants.js.map +1 -1
  648. package/dist/utils/bgcode/bgcode.types.js +57 -106
  649. package/dist/utils/bgcode/bgcode.types.js.map +1 -1
  650. package/dist/utils/bgcode/bgcode.utils.js +167 -256
  651. package/dist/utils/bgcode/bgcode.utils.js.map +1 -1
  652. package/dist/utils/bgcode/heatshrink-decoder.js +130 -170
  653. package/dist/utils/bgcode/heatshrink-decoder.js.map +1 -1
  654. package/dist/utils/bgcode/png-encoder.js +53 -66
  655. package/dist/utils/bgcode/png-encoder.js.map +1 -1
  656. package/dist/utils/bgcode/qoi-decoder.js +116 -135
  657. package/dist/utils/bgcode/qoi-decoder.js.map +1 -1
  658. package/dist/utils/cache/key-diff.cache.js +56 -85
  659. package/dist/utils/cache/key-diff.cache.js.map +1 -1
  660. package/dist/utils/correlation-token.util.js +4 -11
  661. package/dist/utils/correlation-token.util.js.map +1 -1
  662. package/dist/utils/crypto.utils.js +7 -23
  663. package/dist/utils/crypto.utils.js.map +1 -1
  664. package/dist/utils/env.utils.js +14 -49
  665. package/dist/utils/env.utils.js.map +1 -1
  666. package/dist/utils/error.utils.js +4 -11
  667. package/dist/utils/error.utils.js.map +1 -1
  668. package/dist/utils/fs.utils.js +26 -49
  669. package/dist/utils/fs.utils.js.map +1 -1
  670. package/dist/utils/gcode.utils.js +30 -43
  671. package/dist/utils/gcode.utils.js.map +1 -1
  672. package/dist/utils/image-dimensions.js +39 -54
  673. package/dist/utils/image-dimensions.js.map +1 -1
  674. package/dist/utils/job-stats.util.js +41 -72
  675. package/dist/utils/job-stats.util.js.map +1 -1
  676. package/dist/utils/normalize-url.js +135 -203
  677. package/dist/utils/normalize-url.js.map +1 -1
  678. package/dist/utils/parsers/3mf.parser.js +298 -365
  679. package/dist/utils/parsers/3mf.parser.js.map +1 -1
  680. package/dist/utils/parsers/bgcode.parser.js +149 -202
  681. package/dist/utils/parsers/bgcode.parser.js.map +1 -1
  682. package/dist/utils/parsers/gcode.parser.js +200 -263
  683. package/dist/utils/parsers/gcode.parser.js.map +1 -1
  684. package/dist/utils/parsers/parser.types.js +1 -6
  685. package/dist/utils/pretty-print.utils.js +5 -20
  686. package/dist/utils/pretty-print.utils.js.map +1 -1
  687. package/dist/utils/semver.utils.js +10 -26
  688. package/dist/utils/semver.utils.js.map +1 -1
  689. package/dist/utils/swagger/decorators.js +14 -32
  690. package/dist/utils/swagger/decorators.js.map +1 -1
  691. package/dist/utils/swagger/generator.js +151 -194
  692. package/dist/utils/swagger/generator.js.map +1 -1
  693. package/dist/utils/swagger/swagger.js +40 -51
  694. package/dist/utils/swagger/swagger.js.map +1 -1
  695. package/dist/utils/thumbnail.util.js +11 -20
  696. package/dist/utils/thumbnail.util.js.map +1 -1
  697. package/dist/utils/time.utils.js +4 -12
  698. package/dist/utils/time.utils.js.map +1 -1
  699. package/dist/utils/url.utils.js +9 -27
  700. package/dist/utils/url.utils.js.map +1 -1
  701. package/package.json +79 -90
  702. package/packages/consoles/package.json +44 -0
  703. package/packages/consoles/tsconfig.json +23 -0
  704. package/packages/consoles/vite.config.ts +15 -0
  705. package/tsconfig.json +10 -6
  706. package/vite.config.ts +62 -0
  707. package/.swcrc +0 -33
  708. package/.yarn/releases/yarn-4.12.0.cjs +0 -942
  709. package/biome.json +0 -36
  710. package/dist/consoles/bambu-mqtt-diagnostic.console.js +0 -565
  711. package/dist/consoles/bambu-mqtt-diagnostic.console.js.map +0 -1
  712. package/dist/consoles/download-github-releases.js +0 -50
  713. package/dist/consoles/download-github-releases.js.map +0 -1
  714. package/dist/consoles/gcode-scanner-poc.console.js +0 -52
  715. package/dist/consoles/gcode-scanner-poc.console.js.map +0 -1
  716. package/dist/consoles/launch-http-servers.js +0 -31
  717. package/dist/consoles/launch-http-servers.js.map +0 -1
  718. package/dist/consoles/mock-bambu.server.js +0 -319
  719. package/dist/consoles/mock-bambu.server.js.map +0 -1
  720. package/dist/consoles/mock-camera/default-image.js +0 -13
  721. package/dist/consoles/mock-camera/default-image.js.map +0 -1
  722. package/dist/consoles/mock-camera/mock-camera.server.js +0 -160
  723. package/dist/consoles/mock-camera/mock-camera.server.js.map +0 -1
  724. package/dist/consoles/mock-octoprint.server.js +0 -499
  725. package/dist/consoles/mock-octoprint.server.js.map +0 -1
  726. package/dist/consoles/mock-prusalink.server.js +0 -57
  727. package/dist/consoles/mock-prusalink.server.js.map +0 -1
  728. package/dist/consoles/moonraker-test.console.js +0 -3
  729. package/dist/consoles/moonraker-test.console.js.map +0 -1
  730. package/dist/consoles/utils/api-messages.js +0 -856
  731. package/dist/consoles/utils/api-messages.js.map +0 -1
  732. package/dist/consoles/utils/delayed-memory.storage.js +0 -42
  733. package/dist/consoles/utils/delayed-memory.storage.js.map +0 -1
  734. package/dist/consoles/utils/ws-messages.js +0 -88
  735. package/dist/consoles/utils/ws-messages.js.map +0 -1
  736. package/dist/entities/index.js.map +0 -1
  737. package/dist/services/bambu/mqtt-message.types.js.map +0 -1
  738. package/dist/services/interfaces/auth.service.interface.js.map +0 -1
  739. package/dist/services/interfaces/camera-stream.service.interface.js.map +0 -1
  740. package/dist/services/interfaces/file-upload-tracker.interface.js.map +0 -1
  741. package/dist/services/interfaces/floor.service.interface.js.map +0 -1
  742. package/dist/services/interfaces/jwt.service.interface.js.map +0 -1
  743. package/dist/services/interfaces/permission.service.interface.js.map +0 -1
  744. package/dist/services/interfaces/printer-file.dto.js.map +0 -1
  745. package/dist/services/interfaces/printer-maintenance-log.dto.js.map +0 -1
  746. package/dist/services/interfaces/printer-tag.service.interface.js.map +0 -1
  747. package/dist/services/interfaces/printer.service.interface.js.map +0 -1
  748. package/dist/services/interfaces/refresh-token.service.interface.js.map +0 -1
  749. package/dist/services/interfaces/role-service.interface.js.map +0 -1
  750. package/dist/services/interfaces/settings.service.interface.js.map +0 -1
  751. package/dist/services/interfaces/tag.dto.js.map +0 -1
  752. package/dist/services/interfaces/task.interfaces.js.map +0 -1
  753. package/dist/services/interfaces/user-service.interface.js.map +0 -1
  754. package/dist/services/moonraker/dto/access/access-info.dto.js.map +0 -1
  755. package/dist/services/moonraker/dto/access/access-login-refresh.dto.js.map +0 -1
  756. package/dist/services/moonraker/dto/access/access-login-result.dto.js.map +0 -1
  757. package/dist/services/moonraker/dto/access/access-user-result.dto.js.map +0 -1
  758. package/dist/services/moonraker/dto/access/access-user.dto.js.map +0 -1
  759. package/dist/services/moonraker/dto/database/database-namespace-item.dto.js.map +0 -1
  760. package/dist/services/moonraker/dto/database/database-namespace-list.dto.js.map +0 -1
  761. package/dist/services/moonraker/dto/gcode-help.dto.js.map +0 -1
  762. package/dist/services/moonraker/dto/gcode-store.dto.js.map +0 -1
  763. package/dist/services/moonraker/dto/job-queue/enqueue-job.dto.js.map +0 -1
  764. package/dist/services/moonraker/dto/job-queue/job-queue-status.dto.js.map +0 -1
  765. package/dist/services/moonraker/dto/machine/machine-device-power-device-state.dto.js.map +0 -1
  766. package/dist/services/moonraker/dto/machine/machine-device-power-devices.dto.js.map +0 -1
  767. package/dist/services/moonraker/dto/machine/machine-peripherals-canbus.dto.js.map +0 -1
  768. package/dist/services/moonraker/dto/machine/machine-peripherals-serial.dto.js.map +0 -1
  769. package/dist/services/moonraker/dto/machine/machine-peripherals-usb.dto.js.map +0 -1
  770. package/dist/services/moonraker/dto/machine/machine-peripherals-video.dto.js.map +0 -1
  771. package/dist/services/moonraker/dto/machine/machine-system-info.dto.js.map +0 -1
  772. package/dist/services/moonraker/dto/machine/machine-update-status.dto.js.map +0 -1
  773. package/dist/services/moonraker/dto/machine/machine-wled-strips.dto.js.map +0 -1
  774. package/dist/services/moonraker/dto/notifier-list.dto.js.map +0 -1
  775. package/dist/services/moonraker/dto/objects/bed-mesh.dto.js.map +0 -1
  776. package/dist/services/moonraker/dto/objects/configfile.dto.js.map +0 -1
  777. package/dist/services/moonraker/dto/objects/display-status.dto.js.map +0 -1
  778. package/dist/services/moonraker/dto/objects/extruder.dto.js.map +0 -1
  779. package/dist/services/moonraker/dto/objects/fan.dto.js.map +0 -1
  780. package/dist/services/moonraker/dto/objects/filament-motion-sensor.dto.js.map +0 -1
  781. package/dist/services/moonraker/dto/objects/filament-switch-sensor.dto.js.map +0 -1
  782. package/dist/services/moonraker/dto/objects/gcode-move.dto.js.map +0 -1
  783. package/dist/services/moonraker/dto/objects/gcode.dto.js.map +0 -1
  784. package/dist/services/moonraker/dto/objects/heater-bed.dto.js.map +0 -1
  785. package/dist/services/moonraker/dto/objects/heaters.dto.js.map +0 -1
  786. package/dist/services/moonraker/dto/objects/mcu.dto.js.map +0 -1
  787. package/dist/services/moonraker/dto/objects/motion-report.dto.js.map +0 -1
  788. package/dist/services/moonraker/dto/objects/output-pin.dto.js.map +0 -1
  789. package/dist/services/moonraker/dto/objects/pause-resume.dto.js.map +0 -1
  790. package/dist/services/moonraker/dto/objects/printer-object.dto.js.map +0 -1
  791. package/dist/services/moonraker/dto/objects/printer-object.types.js.map +0 -1
  792. package/dist/services/moonraker/dto/objects/printer-objects-query.dto.js.map +0 -1
  793. package/dist/services/moonraker/dto/objects/stepper-enable.dto.js.map +0 -1
  794. package/dist/services/moonraker/dto/objects/system-stats.dto.js.map +0 -1
  795. package/dist/services/moonraker/dto/objects/temperature-fan.dto.js.map +0 -1
  796. package/dist/services/moonraker/dto/objects/temperature-sensor.dto.js.map +0 -1
  797. package/dist/services/moonraker/dto/objects/toolhead.dto.js.map +0 -1
  798. package/dist/services/moonraker/dto/objects/virtual-sdcard.dto.js.map +0 -1
  799. package/dist/services/moonraker/dto/objects/webhooks.dto.js.map +0 -1
  800. package/dist/services/moonraker/dto/octoprint-compat/api-job.dto.js.map +0 -1
  801. package/dist/services/moonraker/dto/octoprint-compat/api-login.dto.js.map +0 -1
  802. package/dist/services/moonraker/dto/octoprint-compat/api-printer.dto.js.map +0 -1
  803. package/dist/services/moonraker/dto/octoprint-compat/api-profiles.dto.js.map +0 -1
  804. package/dist/services/moonraker/dto/octoprint-compat/api-settings.dto.js.map +0 -1
  805. package/dist/services/moonraker/dto/octoprint-compat/api-version.dto.js.map +0 -1
  806. package/dist/services/moonraker/dto/octoprint-compat/server-version.dto.js.map +0 -1
  807. package/dist/services/moonraker/dto/printer-query-endstops.dto.js.map +0 -1
  808. package/dist/services/moonraker/dto/process-stats.dto.js.map +0 -1
  809. package/dist/services/moonraker/dto/rest/action-result.dto.js.map +0 -1
  810. package/dist/services/moonraker/dto/rest/error.dto.js.map +0 -1
  811. package/dist/services/moonraker/dto/rollover-logs.dto.js.map +0 -1
  812. package/dist/services/moonraker/dto/rpc/json-rpc-error.dto.js.map +0 -1
  813. package/dist/services/moonraker/dto/rpc/json-rpc-request.dto.js.map +0 -1
  814. package/dist/services/moonraker/dto/rpc/json-rpc-response.dto.js.map +0 -1
  815. package/dist/services/moonraker/dto/server/server-config.dto.js.map +0 -1
  816. package/dist/services/moonraker/dto/server-announcements/announcement-action.dto.js.map +0 -1
  817. package/dist/services/moonraker/dto/server-announcements/announcement-entry-id.dto.js.map +0 -1
  818. package/dist/services/moonraker/dto/server-announcements/announcement-feeds.dto.js.map +0 -1
  819. package/dist/services/moonraker/dto/server-announcements/announcement-list.dto.js.map +0 -1
  820. package/dist/services/moonraker/dto/server-files/server-file-directory-action.dto.js.map +0 -1
  821. package/dist/services/moonraker/dto/server-files/server-file-directory-info.dto.js.map +0 -1
  822. package/dist/services/moonraker/dto/server-files/server-file-metadata.dto.js.map +0 -1
  823. package/dist/services/moonraker/dto/server-files/server-file-root.dto.js.map +0 -1
  824. package/dist/services/moonraker/dto/server-files/server-file-thumbnail.dto.js.map +0 -1
  825. package/dist/services/moonraker/dto/server-files/server-file-zip-action.dto.js.map +0 -1
  826. package/dist/services/moonraker/dto/server-files/server-file.dto.js.map +0 -1
  827. package/dist/services/moonraker/dto/server-history/history-job.dto.js.map +0 -1
  828. package/dist/services/moonraker/dto/server-history/history-last-totals.dto.js.map +0 -1
  829. package/dist/services/moonraker/dto/server-history/history-list.dto.js.map +0 -1
  830. package/dist/services/moonraker/dto/server-history/history-totals.dto.js.map +0 -1
  831. package/dist/services/moonraker/dto/server-sensors/sensor-info.dto.js.map +0 -1
  832. package/dist/services/moonraker/dto/server-sensors/sensor-list.dto.js.map +0 -1
  833. package/dist/services/moonraker/dto/server-sensors/sensor-measurements.dto.js.map +0 -1
  834. package/dist/services/moonraker/dto/server-webcams/webcam-item.dto.js.map +0 -1
  835. package/dist/services/moonraker/dto/server-webcams/webcam-list.dto.js.map +0 -1
  836. package/dist/services/moonraker/dto/server-webcams/webcam-test.dto.js.map +0 -1
  837. package/dist/services/moonraker/dto/spoolman/spoolman-active-spool.dto.js.map +0 -1
  838. package/dist/services/moonraker/dto/spoolman/spoolman-proxy-request.dto.js.map +0 -1
  839. package/dist/services/moonraker/dto/spoolman/spoolman-response.dto.js.map +0 -1
  840. package/dist/services/moonraker/dto/spoolman/spoolman-status.dto.js.map +0 -1
  841. package/dist/services/moonraker/dto/sudo-info.dto.js.map +0 -1
  842. package/dist/services/moonraker/dto/sudo-response.dto.js.map +0 -1
  843. package/dist/services/moonraker/dto/temperature-store.dto.js.map +0 -1
  844. package/dist/services/moonraker/dto/websocket/connection-identify-response.dto.js.map +0 -1
  845. package/dist/services/moonraker/dto/websocket/connection-identify.dto.js.map +0 -1
  846. package/dist/services/moonraker/dto/websocket/json-rpc-event.dto.js.map +0 -1
  847. package/dist/services/moonraker/dto/websocket/message.types.js.map +0 -1
  848. package/dist/services/moonraker/dto/websocket/notify-active-spool-set.params.js.map +0 -1
  849. package/dist/services/moonraker/dto/websocket/notify-agent-event.params.js.map +0 -1
  850. package/dist/services/moonraker/dto/websocket/notify-announcement-update.params.js.map +0 -1
  851. package/dist/services/moonraker/dto/websocket/notify-announcement.params.js.map +0 -1
  852. package/dist/services/moonraker/dto/websocket/notify-button-event.params.js.map +0 -1
  853. package/dist/services/moonraker/dto/websocket/notify-history-changed.params.js.map +0 -1
  854. package/dist/services/moonraker/dto/websocket/notify-job-queue-changed.params.js.map +0 -1
  855. package/dist/services/moonraker/dto/websocket/notify-proc-stat-update.params.js.map +0 -1
  856. package/dist/services/moonraker/dto/websocket/notify-sensor-update.params.js.map +0 -1
  857. package/dist/services/moonraker/dto/websocket/notify-service-state-changed.params.js.map +0 -1
  858. package/dist/services/moonraker/dto/websocket/notify-spoolman-status-changed.js.map +0 -1
  859. package/dist/services/moonraker/dto/websocket/notify-sudo-alert.params.js.map +0 -1
  860. package/dist/services/moonraker/dto/websocket/notify-user-change.params.js.map +0 -1
  861. package/dist/services/octoprint/dto/access/user-list.dto.js.map +0 -1
  862. package/dist/services/octoprint/dto/access/user.dto.js.map +0 -1
  863. package/dist/services/octoprint/dto/auth/current-user.dto.js.map +0 -1
  864. package/dist/services/octoprint/dto/auth/login.dto.js.map +0 -1
  865. package/dist/services/octoprint/dto/connection/connection.dto.js.map +0 -1
  866. package/dist/services/octoprint/dto/events/client-authed.dto.js.map +0 -1
  867. package/dist/services/octoprint/dto/events/client-closed.dto.js.map +0 -1
  868. package/dist/services/octoprint/dto/events/client-opened.dto.js.map +0 -1
  869. package/dist/services/octoprint/dto/events/dwelling.dto.js.map +0 -1
  870. package/dist/services/octoprint/dto/events/file-added.dto.js.map +0 -1
  871. package/dist/services/octoprint/dto/events/file-deselected.dto.js.map +0 -1
  872. package/dist/services/octoprint/dto/events/file-removed.dto.js.map +0 -1
  873. package/dist/services/octoprint/dto/events/folder-added.dto.js.map +0 -1
  874. package/dist/services/octoprint/dto/events/home.dto.js.map +0 -1
  875. package/dist/services/octoprint/dto/events/metadata-analysis-finished.dto.js.map +0 -1
  876. package/dist/services/octoprint/dto/events/metadata-analysis-started.dto.js.map +0 -1
  877. package/dist/services/octoprint/dto/events/metadata-statistics-updated.dto.js.map +0 -1
  878. package/dist/services/octoprint/dto/events/position-update.dto.js.map +0 -1
  879. package/dist/services/octoprint/dto/events/print-cancelled.dto.js.map +0 -1
  880. package/dist/services/octoprint/dto/events/print-cancelling.dto.js.map +0 -1
  881. package/dist/services/octoprint/dto/events/print-done.dto.js.map +0 -1
  882. package/dist/services/octoprint/dto/events/print-failed.dto.js.map +0 -1
  883. package/dist/services/octoprint/dto/events/print-paused.dto.js.map +0 -1
  884. package/dist/services/octoprint/dto/events/print-resumed.dto.js.map +0 -1
  885. package/dist/services/octoprint/dto/events/print-started.dto.js.map +0 -1
  886. package/dist/services/octoprint/dto/events/printer-state-changed.dto.js.map +0 -1
  887. package/dist/services/octoprint/dto/events/transfer-done.dto.js.map +0 -1
  888. package/dist/services/octoprint/dto/events/transfer-started.dto.js.map +0 -1
  889. package/dist/services/octoprint/dto/events/updated-files.dto.js.map +0 -1
  890. package/dist/services/octoprint/dto/events/upload.dto.js.map +0 -1
  891. package/dist/services/octoprint/dto/events/user-logged-in.dto.js.map +0 -1
  892. package/dist/services/octoprint/dto/events/z-change.dto.js.map +0 -1
  893. package/dist/services/octoprint/dto/files/gcode-analysis.dto.js.map +0 -1
  894. package/dist/services/octoprint/dto/files/octoprint-file.dto.js.map +0 -1
  895. package/dist/services/octoprint/dto/files/octoprint-files-response.dto.js.map +0 -1
  896. package/dist/services/octoprint/dto/job/job.dto.js.map +0 -1
  897. package/dist/services/octoprint/dto/printer/busy-file.dto.js.map +0 -1
  898. package/dist/services/octoprint/dto/printer/current-printer-state.dto.js.map +0 -1
  899. package/dist/services/octoprint/dto/printer/flags.dto.js.map +0 -1
  900. package/dist/services/octoprint/dto/printer/markings.dto.js.map +0 -1
  901. package/dist/services/octoprint/dto/printer/progress.dto.js.map +0 -1
  902. package/dist/services/octoprint/dto/printer/resends.dto.js.map +0 -1
  903. package/dist/services/octoprint/dto/printer/state.dto.js.map +0 -1
  904. package/dist/services/octoprint/dto/printer/temps.dto.js.map +0 -1
  905. package/dist/services/octoprint/dto/rest/error.dto.js.map +0 -1
  906. package/dist/services/octoprint/dto/server/server.dto.js.map +0 -1
  907. package/dist/services/octoprint/dto/server/version.dto.js.map +0 -1
  908. package/dist/services/octoprint/dto/settings/serial-settings.dto.js.map +0 -1
  909. package/dist/services/octoprint/dto/settings/settings-parts.type.js.map +0 -1
  910. package/dist/services/octoprint/dto/settings/settings.dto.js.map +0 -1
  911. package/dist/services/octoprint/dto/settings/virtual-printer-settings.dto.js.map +0 -1
  912. package/dist/services/octoprint/dto/websocket/connection-message.dto.js.map +0 -1
  913. package/dist/services/octoprint/dto/websocket/current-message.dto.js.map +0 -1
  914. package/dist/services/octoprint/dto/websocket/event-message.dto.js.map +0 -1
  915. package/dist/services/octoprint/dto/websocket/history-message.dto.js.map +0 -1
  916. package/dist/services/octoprint/dto/websocket/plugin-message.dto.js.map +0 -1
  917. package/dist/services/octoprint/dto/websocket/timelapse-message.dto.js.map +0 -1
  918. package/dist/services/orm/base.interface.js.map +0 -1
  919. package/dist/services/prusa-link/dto/file-response.dto.js.map +0 -1
  920. package/dist/services/prusa-link/dto/file.dto.js.map +0 -1
  921. package/dist/services/prusa-link/dto/job-state.dto.js.map +0 -1
  922. package/dist/services/prusa-link/dto/printer-state.dto.js.map +0 -1
  923. package/dist/services/prusa-link/dto/status.dto.js.map +0 -1
  924. package/dist/services/prusa-link/dto/version.dto.js.map +0 -1
  925. package/dist/services/prusa-link/utils/digest-auth.params.js.map +0 -1
  926. package/dist/services/websocket-adapter.interface.js.map +0 -1
  927. package/dist/shared/dtos/socket-login.dto.js.map +0 -1
  928. package/dist/types/express/index.d.js.map +0 -1
  929. package/dist/utils/parsers/parser.types.js.map +0 -1
@@ -1,547 +1,445 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "PrintJobService", {
6
- enumerable: true,
7
- get: function() {
8
- return PrintJobService;
9
- }
10
- });
11
- const _printjobentity = require("../../entities/print-job.entity");
12
- const _runtimeexceptions = require("../../exceptions/runtime.exceptions");
13
- const _jobstatsutil = require("../../utils/job-stats.util");
14
- class PrintJobService {
15
- printJobRepository;
16
- eventEmitter2;
17
- logger;
18
- constructor(loggerFactory, typeormService, eventEmitter2){
19
- this.printJobRepository = typeormService.getDataSource().getRepository(_printjobentity.PrintJob);
20
- this.eventEmitter2 = eventEmitter2;
21
- this.logger = loggerFactory(PrintJobService.name);
22
- }
23
- async getJobByIdOrFail(id, relations) {
24
- const job = await this.printJobRepository.findOne({
25
- where: {
26
- id
27
- },
28
- relations
29
- });
30
- if (!job) {
31
- throw new _runtimeexceptions.NotFoundException(`Job ${id} not found`);
32
- }
33
- return job;
34
- }
35
- async handleFileAnalyzed(jobId, metadata, thumbnails) {
36
- const job = await this.printJobRepository.findOne({
37
- where: {
38
- id: jobId
39
- }
40
- });
41
- if (!job) {
42
- throw new Error(`Print job ${jobId} not found`);
43
- }
44
- job.metadata = metadata;
45
- job.analysisState = "ANALYZED";
46
- job.analyzedAt = new Date();
47
- job.fileFormat = metadata.fileFormat;
48
- await this.printJobRepository.save(job);
49
- this.eventEmitter2.emit("printJob.analyzed", {
50
- jobId: job.id,
51
- printerId: job.printerId,
52
- metadata
53
- });
54
- this.logger.log(`Print job ${jobId} analyzed: ${metadata.fileName}`);
55
- return job;
56
- }
57
- async handlePrintStarted(printerId, fileName, jobId, printerName) {
58
- const existingJob = await this.printJobRepository.findOne({
59
- where: {
60
- printerId,
61
- status: "PRINTING"
62
- },
63
- order: {
64
- startedAt: "DESC"
65
- }
66
- });
67
- if (existingJob?.fileName === fileName && !jobId) {
68
- return existingJob;
69
- }
70
- if (existingJob && existingJob.fileName !== fileName && !jobId) {
71
- existingJob.status = "UNKNOWN";
72
- existingJob.statusReason = "Print state unknown - printer started new job while previous job was still marked as printing. " + "This may indicate a disconnect, server restart, or manual printer control.";
73
- existingJob.endedAt = new Date();
74
- await this.printJobRepository.save(existingJob);
75
- this.logger.warn(`Printer ${printerId} started new print "${fileName}" while job ${existingJob.id} was PRINTING "${existingJob.fileName}". ` + `Marked job ${existingJob.id} as UNKNOWN.`);
76
- }
77
- let job;
78
- if (jobId) {
79
- job = await this.printJobRepository.findOne({
80
- where: {
81
- id: jobId
82
- }
83
- });
84
- if (!job) {
85
- throw new Error(`Print job ${jobId} not found`);
86
- }
87
- } else {
88
- job = await this.printJobRepository.findOne({
89
- where: {
90
- printerId,
91
- fileName,
92
- status: "PENDING"
93
- },
94
- order: {
95
- createdAt: "DESC"
96
- }
97
- });
98
- if (!job) {
99
- job = await this.printJobRepository.findOne({
100
- where: {
101
- printerId,
102
- fileName
103
- },
104
- order: {
105
- createdAt: "DESC"
106
- }
107
- });
108
- }
109
- if (!job) {
110
- this.logger.log(`Creating new job for ${fileName} - no pending or existing job found`);
111
- job = this.printJobRepository.create({
112
- printerId,
113
- printerName: printerName || null,
114
- fileName,
115
- status: "PRINTING",
116
- analysisState: "NOT_ANALYZED"
117
- });
118
- } else if (job.status === "PENDING") {
119
- this.logger.log(`Promoting pending job ${job.id} to PRINTING`);
120
- } else if (job.status === "COMPLETED" || job.status === "FAILED" || job.status === "CANCELLED") {
121
- this.logger.log(`Creating new job for re-print of ${fileName} (previous job ${job.id} was ${job.status})`);
122
- job = this.printJobRepository.create({
123
- printerId,
124
- printerName: printerName || job.printerName || null,
125
- fileName,
126
- status: "PRINTING",
127
- analysisState: job.analysisState,
128
- metadata: job.metadata,
129
- fileFormat: job.fileFormat
130
- });
131
- }
132
- }
133
- job.status = "PRINTING";
134
- job.startedAt = new Date();
135
- job.progress = 0;
136
- if (printerName && !job.printerName) {
137
- job.printerName = printerName;
138
- }
139
- if (!job.statistics) {
140
- job.statistics = {
141
- startedAt: new Date(),
142
- endedAt: null,
143
- actualPrintTimeSeconds: null,
144
- progress: 0
145
- };
146
- } else {
147
- job.statistics.startedAt = new Date();
148
- job.statistics.progress = 0;
149
- }
150
- await this.printJobRepository.save(job);
151
- this.eventEmitter2.emit("printJob.started", {
152
- jobId: job.id,
153
- printerId,
154
- fileName,
155
- startedAt: job.startedAt
156
- });
157
- this.logger.log(`Print job ${job.id} started on printer ${printerId}: ${fileName}`);
158
- return job;
159
- }
160
- async handlePrintProgress(printerId, progress, currentLayer, totalLayers) {
161
- const job = await this.printJobRepository.findOne({
162
- where: {
163
- printerId,
164
- status: "PRINTING"
165
- },
166
- order: {
167
- startedAt: "DESC"
168
- }
169
- });
170
- if (!job) {
171
- this.logger.warn(`No active print job found for printer ${printerId} during progress update`);
172
- return null;
173
- }
174
- job.progress = Math.min(100, Math.max(0, progress));
175
- if (!job.statistics) {
176
- job.statistics = {
177
- startedAt: job.startedAt,
178
- endedAt: null,
179
- actualPrintTimeSeconds: null,
180
- progress: job.progress
181
- };
182
- } else {
183
- job.statistics.progress = job.progress;
184
- }
185
- if (currentLayer !== undefined) {
186
- job.statistics.currentLayer = currentLayer;
187
- }
188
- if (totalLayers !== undefined) {
189
- job.statistics.totalLayers = totalLayers;
190
- }
191
- await this.printJobRepository.save(job);
192
- this.eventEmitter2.emit("printJob.progress", {
193
- jobId: job.id,
194
- printerId,
195
- progress: job.progress,
196
- currentLayer,
197
- totalLayers
198
- });
199
- return job;
200
- }
201
- async handlePrintCompleted(printerId, fileName) {
202
- const job = await this.printJobRepository.findOne({
203
- where: {
204
- printerId,
205
- status: "PRINTING"
206
- },
207
- order: {
208
- startedAt: "DESC"
209
- }
210
- });
211
- if (!job) {
212
- this.logger.warn(`No active print job found for printer ${printerId} on completion`);
213
- return null;
214
- }
215
- if (fileName && job.fileName !== fileName) {
216
- this.logger.warn(`Filename mismatch on completion: expected "${job.fileName}", got "${fileName}"`);
217
- }
218
- const endedAt = new Date();
219
- const actualTimeSeconds = (0, _jobstatsutil.calculateJobDuration)(job.startedAt, endedAt);
220
- job.status = "COMPLETED";
221
- (0, _jobstatsutil.updateStatisticsForCompletion)(job, endedAt);
222
- await this.printJobRepository.save(job);
223
- this.eventEmitter2.emit("printJob.completed", {
224
- jobId: job.id,
225
- printerId,
226
- fileName: job.fileName,
227
- actualTimeSeconds,
228
- estimatedTimeSeconds: job.metadata?.gcodePrintTimeSeconds
229
- });
230
- this.logger.log(`Print job ${job.id} completed on printer ${printerId}: ${job.fileName} ` + `(${actualTimeSeconds?.toFixed(0)}s actual, ${job.metadata?.gcodePrintTimeSeconds}s estimated)`);
231
- return job;
232
- }
233
- async handlePrintFailed(printerId, reason, fileName) {
234
- const job = await this.printJobRepository.findOne({
235
- where: {
236
- printerId,
237
- status: "PRINTING"
238
- },
239
- order: {
240
- startedAt: "DESC"
241
- }
242
- });
243
- if (!job) {
244
- this.logger.warn(`No active print job found for printer ${printerId} on failure`);
245
- return null;
246
- }
247
- const endedAt = new Date();
248
- job.status = "FAILED";
249
- (0, _jobstatsutil.updateStatisticsForFailure)(job, reason, endedAt);
250
- await this.printJobRepository.save(job);
251
- this.eventEmitter2.emit("printJob.failed", {
252
- jobId: job.id,
253
- printerId,
254
- fileName: job.fileName,
255
- reason,
256
- failedAt: endedAt
257
- });
258
- this.logger.log(`Print job ${job.id} failed on printer ${printerId}: ${job.fileName} - ${reason}`);
259
- return job;
260
- }
261
- async handlePrintCancelled(printerId, reason) {
262
- const job = await this.printJobRepository.findOne({
263
- where: {
264
- printerId,
265
- status: "PRINTING"
266
- },
267
- order: {
268
- startedAt: "DESC"
269
- }
270
- });
271
- if (!job) {
272
- this.logger.warn(`No active print job found for printer ${printerId} on cancellation`);
273
- return null;
274
- }
275
- const endedAt = new Date();
276
- job.status = "CANCELLED";
277
- (0, _jobstatsutil.updateStatisticsForCancellation)(job, reason, endedAt);
278
- await this.printJobRepository.save(job);
279
- this.eventEmitter2.emit("printJob.cancelled", {
280
- jobId: job.id,
281
- printerId,
282
- fileName: job.fileName,
283
- cancelledAt: endedAt
284
- });
285
- this.logger.log(`Print job ${job.id} cancelled on printer ${printerId}: ${job.fileName}`);
286
- return job;
287
- }
288
- async handlePrintPaused(printerId) {
289
- const job = await this.printJobRepository.findOne({
290
- where: {
291
- printerId,
292
- status: "PRINTING"
293
- },
294
- order: {
295
- startedAt: "DESC"
296
- }
297
- });
298
- if (!job) {
299
- this.logger.warn(`No active print job found for printer ${printerId} on pause`);
300
- return null;
301
- }
302
- job.status = "PAUSED";
303
- await this.printJobRepository.save(job);
304
- this.logger.log(`Print job ${job.id} paused on printer ${printerId}`);
305
- return job;
306
- }
307
- async handlePrintResumed(printerId) {
308
- const job = await this.printJobRepository.findOne({
309
- where: {
310
- printerId,
311
- status: "PAUSED"
312
- },
313
- order: {
314
- startedAt: "DESC"
315
- }
316
- });
317
- if (!job) {
318
- this.logger.warn(`No paused print job found for printer ${printerId} on resume`);
319
- return null;
320
- }
321
- job.status = "PRINTING";
322
- await this.printJobRepository.save(job);
323
- this.logger.log(`Print job ${job.id} resumed on printer ${printerId}`);
324
- return job;
325
- }
326
- async cleanupStaleJobs() {
327
- const staleJobs = await this.printJobRepository.find({
328
- where: {
329
- status: "PRINTING"
330
- }
331
- });
332
- for (const job of staleJobs){
333
- job.status = "UNKNOWN";
334
- job.statusReason = "Print state unknown after server restart. The print may have completed, " + "failed, or still be running. Check your printer for current status.";
335
- await this.printJobRepository.save(job);
336
- this.logger.warn(`Marked job ${job.id} (printer ${job.printerId}) as UNKNOWN after startup - ` + `was PRINTING before server stopped`);
337
- }
338
- if (staleJobs.length > 0) {
339
- this.logger.log(`Cleaned up ${staleJobs.length} stale print job(s) on startup`);
340
- }
341
- }
342
- async getActivePrintJob(printerId) {
343
- return this.printJobRepository.findOne({
344
- where: {
345
- printerId,
346
- status: "PRINTING"
347
- },
348
- order: {
349
- startedAt: "DESC"
350
- }
351
- });
352
- }
353
- async getPrintJobHistory(printerId, limit = 50) {
354
- return this.printJobRepository.find({
355
- where: {
356
- printerId
357
- },
358
- order: {
359
- createdAt: "DESC"
360
- },
361
- take: limit
362
- });
363
- }
364
- async markStarted(printerId, fileName, printerName) {
365
- return await this.handlePrintStarted(printerId, fileName, undefined, printerName);
366
- }
367
- async markProgress(printerId, fileName, progress, currentLayer, totalLayers) {
368
- return await this.handlePrintProgress(printerId, progress, currentLayer, totalLayers);
369
- }
370
- async markFinished(printerId, fileName) {
371
- return await this.handlePrintCompleted(printerId, fileName);
372
- }
373
- async markFailed(printerId, fileName, reason) {
374
- return await this.handlePrintFailed(printerId, reason, fileName);
375
- }
376
- async updateJobMetadata(printerId, fileName, partialMetadata) {
377
- const job = await this.printJobRepository.findOne({
378
- where: {
379
- printerId,
380
- fileName,
381
- status: "PRINTING"
382
- },
383
- order: {
384
- startedAt: "DESC"
385
- }
386
- });
387
- if (!job) {
388
- this.logger.debug(`No active job found for printer ${printerId}, file ${fileName} - skipping metadata update`);
389
- return;
390
- }
391
- if (job.analysisState === "ANALYZED" && job.metadata) {
392
- this.logger.debug(`Job ${job.id} already has analyzed metadata, merging only missing fields`);
393
- const updatedMetadata = {
394
- ...job.metadata
395
- };
396
- for (const [key, value] of Object.entries(partialMetadata)){
397
- if (value != null && (updatedMetadata[key] == null || updatedMetadata[key] === null)) {
398
- updatedMetadata[key] = value;
399
- }
400
- }
401
- job.metadata = updatedMetadata;
402
- } else if (job.metadata) {
403
- job.metadata = {
404
- ...job.metadata,
405
- ...partialMetadata
406
- };
407
- } else {
408
- const hasData = Object.values(partialMetadata).some((v)=>v != null && v !== null);
409
- if (!hasData) {
410
- this.logger.debug(`Skipping metadata creation for job ${job.id} - no meaningful data provided`);
411
- return;
412
- }
413
- job.metadata = {
414
- fileName,
415
- fileFormat: job.fileFormat || "gcode",
416
- ...partialMetadata
417
- };
418
- }
419
- await this.printJobRepository.save(job);
420
- this.logger.debug(`Updated metadata for job ${job.id}`);
421
- }
422
- async searchPrintJobs(searchPrinter, searchFile, startDate, endDate) {
423
- const query = this.printJobRepository.createQueryBuilder("job");
424
- if (searchPrinter) {
425
- query.andWhere("job.printerId = :printerId", {
426
- printerId: Number.parseInt(searchPrinter, 10)
427
- });
428
- }
429
- if (searchFile) {
430
- query.andWhere("job.fileName LIKE :fileName", {
431
- fileName: `%${searchFile}%`
432
- });
433
- }
434
- if (startDate) {
435
- query.andWhere("job.startedAt >= :startDate", {
436
- startDate
437
- });
438
- }
439
- if (endDate) {
440
- query.andWhere("job.startedAt <= :endDate", {
441
- endDate
442
- });
443
- }
444
- return await query.orderBy("job.startedAt", "DESC").getMany();
445
- }
446
- async searchPrintJobsPaged(searchPrinter, searchFile, startDate, endDate, page = 1, pageSize = 50) {
447
- const query = this.printJobRepository.createQueryBuilder("job");
448
- if (searchPrinter) {
449
- query.andWhere("job.printerId = :printerId", {
450
- printerId: Number.parseInt(searchPrinter, 10)
451
- });
452
- }
453
- if (searchFile) {
454
- query.andWhere("job.fileName LIKE :fileName", {
455
- fileName: `%${searchFile}%`
456
- });
457
- }
458
- if (startDate) {
459
- query.andWhere("job.startedAt >= :startDate", {
460
- startDate
461
- });
462
- }
463
- if (endDate) {
464
- query.andWhere("job.startedAt <= :endDate", {
465
- endDate
466
- });
467
- }
468
- return await query.orderBy("job.startedAt", "DESC").skip((page - 1) * pageSize).take(pageSize).getManyAndCount();
469
- }
470
- async createPendingJob(printerId, fileName, metadata, printerName) {
471
- const hasAnalysisData = metadata.gcodePrintTimeSeconds !== null || metadata.filamentUsedGrams !== null || metadata.totalFilamentUsedGrams !== null || metadata.layerHeight !== null || metadata.totalLayers !== null;
472
- const analysisState = hasAnalysisData ? "ANALYZED" : "NOT_ANALYZED";
473
- const status = "PENDING";
474
- const job = this.printJobRepository.create({
475
- printerId,
476
- printerName: printerName || null,
477
- fileName,
478
- status,
479
- analysisState,
480
- metadata,
481
- fileFormat: metadata.fileFormat,
482
- fileSize: metadata.fileSize,
483
- analyzedAt: hasAnalysisData ? new Date() : null
484
- });
485
- await this.printJobRepository.save(job);
486
- this.logger.log(`Created ${analysisState.toLowerCase()} print job ${job.id} for printer ${printerId}: ${fileName} (format: ${metadata.fileFormat})`);
487
- return job;
488
- }
489
- async triggerFileAnalysis(jobId) {
490
- this.eventEmitter2.emit("printJob.needsFileDownload", {
491
- jobId
492
- });
493
- this.logger.log(`Triggered file download and analysis for job ${jobId}`);
494
- }
495
- async markAsCompleted(jobId, reason) {
496
- const job = await this.getJobByIdOrFail(jobId);
497
- job.status = "COMPLETED";
498
- (0, _jobstatsutil.updateStatisticsForCompletion)(job);
499
- if (reason) {
500
- job.statusReason = reason;
501
- } else {
502
- job.statusReason = "Manually marked as completed by user";
503
- }
504
- await this.printJobRepository.save(job);
505
- this.logger.log(`Job ${jobId} manually marked as COMPLETED`);
506
- return job;
507
- }
508
- async markAsFailed(jobId, reason) {
509
- const job = await this.getJobByIdOrFail(jobId);
510
- job.status = "FAILED";
511
- (0, _jobstatsutil.updateStatisticsForFailure)(job, reason);
512
- await this.printJobRepository.save(job);
513
- this.logger.log(`Job ${jobId} manually marked as FAILED: ${reason}`);
514
- return job;
515
- }
516
- async markAsCancelled(jobId, reason) {
517
- const job = await this.getJobByIdOrFail(jobId);
518
- job.status = "CANCELLED";
519
- (0, _jobstatsutil.updateStatisticsForCancellation)(job, reason);
520
- await this.printJobRepository.save(job);
521
- this.logger.log(`Job ${jobId} manually marked as CANCELLED`);
522
- return job;
523
- }
524
- async markAsUnknown(jobId, reason) {
525
- const job = await this.getJobByIdOrFail(jobId);
526
- job.status = "UNKNOWN";
527
- job.statusReason = reason || "Manually marked as unknown by user (state uncertain)";
528
- await this.printJobRepository.save(job);
529
- this.logger.log(`Job ${jobId} manually marked as UNKNOWN`);
530
- return job;
531
- }
532
- async countJobsReferencingFile(fileStorageId) {
533
- return await this.printJobRepository.count({
534
- where: {
535
- fileStorageId
536
- }
537
- });
538
- }
539
- async updateJob(job) {
540
- return await this.printJobRepository.save(job);
541
- }
542
- async deleteJob(job) {
543
- await this.printJobRepository.remove(job);
544
- }
545
- }
1
+ import { NotFoundException } from "../../exceptions/runtime.exceptions.js";
2
+ import { PrintJob } from "../../entities/print-job.entity.js";
3
+ import { calculateJobDuration, updateStatisticsForCancellation, updateStatisticsForCompletion, updateStatisticsForFailure } from "../../utils/job-stats.util.js";
4
+ //#region src/services/orm/print-job.service.ts
5
+ var PrintJobService = class PrintJobService {
6
+ printJobRepository;
7
+ eventEmitter2;
8
+ logger;
9
+ constructor(loggerFactory, typeormService, eventEmitter2) {
10
+ this.printJobRepository = typeormService.getDataSource().getRepository(PrintJob);
11
+ this.eventEmitter2 = eventEmitter2;
12
+ this.logger = loggerFactory(PrintJobService.name);
13
+ }
14
+ async getJobByIdOrFail(id, relations) {
15
+ const job = await this.printJobRepository.findOne({
16
+ where: { id },
17
+ relations
18
+ });
19
+ if (!job) throw new NotFoundException(`Job ${id} not found`);
20
+ return job;
21
+ }
22
+ async handleFileAnalyzed(jobId, metadata, thumbnails) {
23
+ const job = await this.printJobRepository.findOne({ where: { id: jobId } });
24
+ if (!job) throw new Error(`Print job ${jobId} not found`);
25
+ job.metadata = metadata;
26
+ job.analysisState = "ANALYZED";
27
+ job.analyzedAt = /* @__PURE__ */ new Date();
28
+ job.fileFormat = metadata.fileFormat;
29
+ await this.printJobRepository.save(job);
30
+ this.eventEmitter2.emit("printJob.analyzed", {
31
+ jobId: job.id,
32
+ printerId: job.printerId,
33
+ metadata
34
+ });
35
+ this.logger.log(`Print job ${jobId} analyzed: ${metadata.fileName}`);
36
+ return job;
37
+ }
38
+ async handlePrintStarted(printerId, fileName, jobId, printerName) {
39
+ const existingJob = await this.printJobRepository.findOne({
40
+ where: {
41
+ printerId,
42
+ status: "PRINTING"
43
+ },
44
+ order: { startedAt: "DESC" }
45
+ });
46
+ if (existingJob?.fileName === fileName && !jobId) return existingJob;
47
+ if (existingJob && existingJob.fileName !== fileName && !jobId) {
48
+ existingJob.status = "UNKNOWN";
49
+ existingJob.statusReason = "Print state unknown - printer started new job while previous job was still marked as printing. This may indicate a disconnect, server restart, or manual printer control.";
50
+ existingJob.endedAt = /* @__PURE__ */ new Date();
51
+ await this.printJobRepository.save(existingJob);
52
+ this.logger.warn(`Printer ${printerId} started new print "${fileName}" while job ${existingJob.id} was PRINTING "${existingJob.fileName}". Marked job ${existingJob.id} as UNKNOWN.`);
53
+ }
54
+ let job;
55
+ if (jobId) {
56
+ job = await this.printJobRepository.findOne({ where: { id: jobId } });
57
+ if (!job) throw new Error(`Print job ${jobId} not found`);
58
+ } else {
59
+ job = await this.printJobRepository.findOne({
60
+ where: {
61
+ printerId,
62
+ fileName,
63
+ status: "PENDING"
64
+ },
65
+ order: { createdAt: "DESC" }
66
+ });
67
+ if (!job) job = await this.printJobRepository.findOne({
68
+ where: {
69
+ printerId,
70
+ fileName
71
+ },
72
+ order: { createdAt: "DESC" }
73
+ });
74
+ if (!job) {
75
+ this.logger.log(`Creating new job for ${fileName} - no pending or existing job found`);
76
+ job = this.printJobRepository.create({
77
+ printerId,
78
+ printerName: printerName || null,
79
+ fileName,
80
+ status: "PRINTING",
81
+ analysisState: "NOT_ANALYZED"
82
+ });
83
+ } else if (job.status === "PENDING") this.logger.log(`Promoting pending job ${job.id} to PRINTING`);
84
+ else if (job.status === "COMPLETED" || job.status === "FAILED" || job.status === "CANCELLED") {
85
+ this.logger.log(`Creating new job for re-print of ${fileName} (previous job ${job.id} was ${job.status})`);
86
+ job = this.printJobRepository.create({
87
+ printerId,
88
+ printerName: printerName || job.printerName || null,
89
+ fileName,
90
+ status: "PRINTING",
91
+ analysisState: job.analysisState,
92
+ metadata: job.metadata,
93
+ fileFormat: job.fileFormat
94
+ });
95
+ }
96
+ }
97
+ job.status = "PRINTING";
98
+ job.startedAt = /* @__PURE__ */ new Date();
99
+ job.progress = 0;
100
+ if (printerName && !job.printerName) job.printerName = printerName;
101
+ if (!job.statistics) job.statistics = {
102
+ startedAt: /* @__PURE__ */ new Date(),
103
+ endedAt: null,
104
+ actualPrintTimeSeconds: null,
105
+ progress: 0
106
+ };
107
+ else {
108
+ job.statistics.startedAt = /* @__PURE__ */ new Date();
109
+ job.statistics.progress = 0;
110
+ }
111
+ await this.printJobRepository.save(job);
112
+ this.eventEmitter2.emit("printJob.started", {
113
+ jobId: job.id,
114
+ printerId,
115
+ fileName,
116
+ startedAt: job.startedAt
117
+ });
118
+ this.logger.log(`Print job ${job.id} started on printer ${printerId}: ${fileName}`);
119
+ return job;
120
+ }
121
+ async handlePrintProgress(printerId, progress) {
122
+ const job = await this.printJobRepository.findOne({
123
+ where: {
124
+ printerId,
125
+ status: "PRINTING"
126
+ },
127
+ order: { startedAt: "DESC" }
128
+ });
129
+ if (!job) return null;
130
+ job.progress = Math.min(100, Math.max(0, progress));
131
+ if (job.statistics) job.statistics.progress = job.progress;
132
+ else job.statistics = {
133
+ startedAt: job.startedAt,
134
+ endedAt: null,
135
+ actualPrintTimeSeconds: null,
136
+ progress: job.progress
137
+ };
138
+ await this.printJobRepository.save(job);
139
+ this.eventEmitter2.emit("printJob.progress", {
140
+ jobId: job.id,
141
+ printerId,
142
+ progress: job.progress
143
+ });
144
+ return job;
145
+ }
146
+ async handlePrintCompleted(printerId, fileName) {
147
+ const job = await this.printJobRepository.findOne({
148
+ where: {
149
+ printerId,
150
+ status: "PRINTING"
151
+ },
152
+ order: { startedAt: "DESC" }
153
+ });
154
+ if (!job) {
155
+ this.logger.warn(`No active print job found for printer ${printerId} on completion`);
156
+ return null;
157
+ }
158
+ if (fileName && job.fileName !== fileName) this.logger.warn(`Filename mismatch on completion: expected "${job.fileName}", got "${fileName}"`);
159
+ const endedAt = /* @__PURE__ */ new Date();
160
+ const actualTimeSeconds = calculateJobDuration(job.startedAt, endedAt);
161
+ job.status = "COMPLETED";
162
+ updateStatisticsForCompletion(job, endedAt);
163
+ await this.printJobRepository.save(job);
164
+ this.eventEmitter2.emit("printJob.completed", {
165
+ jobId: job.id,
166
+ printerId,
167
+ fileName: job.fileName,
168
+ actualTimeSeconds,
169
+ estimatedTimeSeconds: job.metadata?.gcodePrintTimeSeconds
170
+ });
171
+ this.logger.log(`Print job ${job.id} completed on printer ${printerId}: ${job.fileName} (${actualTimeSeconds?.toFixed(0)}s actual, ${job.metadata?.gcodePrintTimeSeconds}s estimated)`);
172
+ return job;
173
+ }
174
+ async handlePrintFailed(printerId, reason, fileName) {
175
+ const job = await this.printJobRepository.findOne({
176
+ where: {
177
+ printerId,
178
+ status: "PRINTING"
179
+ },
180
+ order: { startedAt: "DESC" }
181
+ });
182
+ if (!job) {
183
+ this.logger.warn(`No active print job found for printer ${printerId} on failure`);
184
+ return null;
185
+ }
186
+ const endedAt = /* @__PURE__ */ new Date();
187
+ job.status = "FAILED";
188
+ updateStatisticsForFailure(job, reason, endedAt);
189
+ await this.printJobRepository.save(job);
190
+ this.eventEmitter2.emit("printJob.failed", {
191
+ jobId: job.id,
192
+ printerId,
193
+ fileName: job.fileName,
194
+ reason,
195
+ failedAt: endedAt
196
+ });
197
+ this.logger.log(`Print job ${job.id} failed on printer ${printerId}: ${job.fileName} - ${reason}`);
198
+ return job;
199
+ }
200
+ async handlePrintCancelled(printerId, reason) {
201
+ const job = await this.printJobRepository.findOne({
202
+ where: {
203
+ printerId,
204
+ status: "PRINTING"
205
+ },
206
+ order: { startedAt: "DESC" }
207
+ });
208
+ if (!job) {
209
+ this.logger.warn(`No active print job found for printer ${printerId} on cancellation`);
210
+ return null;
211
+ }
212
+ const endedAt = /* @__PURE__ */ new Date();
213
+ job.status = "CANCELLED";
214
+ updateStatisticsForCancellation(job, reason, endedAt);
215
+ await this.printJobRepository.save(job);
216
+ this.eventEmitter2.emit("printJob.cancelled", {
217
+ jobId: job.id,
218
+ printerId,
219
+ fileName: job.fileName,
220
+ cancelledAt: endedAt
221
+ });
222
+ this.logger.log(`Print job ${job.id} cancelled on printer ${printerId}: ${job.fileName}`);
223
+ return job;
224
+ }
225
+ async handlePrintPaused(printerId) {
226
+ const job = await this.printJobRepository.findOne({
227
+ where: {
228
+ printerId,
229
+ status: "PRINTING"
230
+ },
231
+ order: { startedAt: "DESC" }
232
+ });
233
+ if (!job) {
234
+ this.logger.warn(`No active print job found for printer ${printerId} on pause`);
235
+ return null;
236
+ }
237
+ job.status = "PAUSED";
238
+ await this.printJobRepository.save(job);
239
+ this.logger.log(`Print job ${job.id} paused on printer ${printerId}`);
240
+ return job;
241
+ }
242
+ async handlePrintResumed(printerId) {
243
+ const job = await this.printJobRepository.findOne({
244
+ where: {
245
+ printerId,
246
+ status: "PAUSED"
247
+ },
248
+ order: { startedAt: "DESC" }
249
+ });
250
+ if (!job) {
251
+ this.logger.warn(`No paused print job found for printer ${printerId} on resume`);
252
+ return null;
253
+ }
254
+ job.status = "PRINTING";
255
+ await this.printJobRepository.save(job);
256
+ this.logger.log(`Print job ${job.id} resumed on printer ${printerId}`);
257
+ return job;
258
+ }
259
+ async cleanupStaleJobs() {
260
+ const staleJobs = await this.printJobRepository.find({ where: { status: "PRINTING" } });
261
+ for (const job of staleJobs) {
262
+ job.status = "UNKNOWN";
263
+ job.statusReason = "Print state unknown after server restart. The print may have completed, failed, or still be running. Check your printer for current status.";
264
+ await this.printJobRepository.save(job);
265
+ this.logger.warn(`Marked job ${job.id} (printer ${job.printerId}) as UNKNOWN after startup - was PRINTING before server stopped`);
266
+ }
267
+ if (staleJobs.length > 0) this.logger.log(`Cleaned up ${staleJobs.length} stale print job(s) on startup`);
268
+ }
269
+ async getActivePrintJob(printerId) {
270
+ return this.printJobRepository.findOne({
271
+ where: {
272
+ printerId,
273
+ status: "PRINTING"
274
+ },
275
+ order: { startedAt: "DESC" }
276
+ });
277
+ }
278
+ async getPrintJobHistory(printerId, limit = 50) {
279
+ return this.printJobRepository.find({
280
+ where: { printerId },
281
+ order: { createdAt: "DESC" },
282
+ take: limit
283
+ });
284
+ }
285
+ async markStarted(printerId, fileName, printerName) {
286
+ return await this.handlePrintStarted(printerId, fileName, void 0, printerName);
287
+ }
288
+ async markProgress(printerId, fileName, progress) {
289
+ return await this.handlePrintProgress(printerId, progress);
290
+ }
291
+ /**
292
+ * Mark print as finished by fileName
293
+ * Used by printer middleware when print completes successfully
294
+ */
295
+ async markFinished(printerId, fileName) {
296
+ return await this.handlePrintCompleted(printerId, fileName);
297
+ }
298
+ /**
299
+ * Mark print as failed by fileName
300
+ * Used by printer middleware when print fails
301
+ */
302
+ async markFailed(printerId, fileName, reason) {
303
+ return await this.handlePrintFailed(printerId, reason, fileName);
304
+ }
305
+ /**
306
+ * Update job metadata with partial data from printer middleware
307
+ * Useful for updating estimates from OctoPrint/Moonraker during print
308
+ * Only updates if job has no metadata or to supplement existing metadata
309
+ */
310
+ async updateJobMetadata(printerId, fileName, partialMetadata) {
311
+ const job = await this.printJobRepository.findOne({
312
+ where: {
313
+ printerId,
314
+ fileName,
315
+ status: "PRINTING"
316
+ },
317
+ order: { startedAt: "DESC" }
318
+ });
319
+ if (!job) {
320
+ this.logger.debug(`No active job found for printer ${printerId}, file ${fileName} - skipping metadata update`);
321
+ return;
322
+ }
323
+ if (job.analysisState === "ANALYZED" && job.metadata) {
324
+ this.logger.debug(`Job ${job.id} already has analyzed metadata, merging only missing fields`);
325
+ const updatedMetadata = { ...job.metadata };
326
+ for (const [key, value] of Object.entries(partialMetadata)) if (value != null && (updatedMetadata[key] == null || updatedMetadata[key] === null)) updatedMetadata[key] = value;
327
+ job.metadata = updatedMetadata;
328
+ } else if (job.metadata) job.metadata = {
329
+ ...job.metadata,
330
+ ...partialMetadata
331
+ };
332
+ else {
333
+ if (!Object.values(partialMetadata).some((v) => v !== null)) {
334
+ this.logger.debug(`Skipping metadata creation for job ${job.id} - no meaningful data provided`);
335
+ return;
336
+ }
337
+ job.metadata = {
338
+ fileName,
339
+ fileFormat: job.fileFormat || "gcode",
340
+ ...partialMetadata
341
+ };
342
+ }
343
+ await this.printJobRepository.save(job);
344
+ this.logger.debug(`Updated metadata for job ${job.id}`);
345
+ }
346
+ /**
347
+ * Search print jobs with optional filters
348
+ */
349
+ async searchPrintJobs(searchPrinter, searchFile, startDate, endDate) {
350
+ const query = this.printJobRepository.createQueryBuilder("job");
351
+ if (searchPrinter) query.andWhere("job.printerId = :printerId", { printerId: Number.parseInt(searchPrinter, 10) });
352
+ if (searchFile) query.andWhere("job.fileName LIKE :fileName", { fileName: `%${searchFile}%` });
353
+ if (startDate) query.andWhere("job.startedAt >= :startDate", { startDate });
354
+ if (endDate) query.andWhere("job.startedAt <= :endDate", { endDate });
355
+ return await query.orderBy("job.startedAt", "DESC").getMany();
356
+ }
357
+ /**
358
+ * Search print jobs with pagination
359
+ */
360
+ async searchPrintJobsPaged(searchPrinter, searchFile, startDate, endDate, page = 1, pageSize = 50) {
361
+ const query = this.printJobRepository.createQueryBuilder("job");
362
+ if (searchPrinter) query.andWhere("job.printerId = :printerId", { printerId: Number.parseInt(searchPrinter, 10) });
363
+ if (searchFile) query.andWhere("job.fileName LIKE :fileName", { fileName: `%${searchFile}%` });
364
+ if (startDate) query.andWhere("job.startedAt >= :startDate", { startDate });
365
+ if (endDate) query.andWhere("job.startedAt <= :endDate", { endDate });
366
+ return await query.orderBy("job.startedAt", "DESC").skip((page - 1) * pageSize).take(pageSize).getManyAndCount();
367
+ }
368
+ /**
369
+ * Create a pending print job (typically called when file is uploaded)
370
+ * Used when a file is uploaded to a printer, creating a job ready for analysis
371
+ */
372
+ async createPendingJob(printerId, fileName, metadata, printerName) {
373
+ const hasAnalysisData = metadata.gcodePrintTimeSeconds !== null || metadata.filamentUsedGrams !== null || metadata.totalFilamentUsedGrams !== null || metadata.layerHeight !== null || metadata.totalLayers !== null;
374
+ const analysisState = hasAnalysisData ? "ANALYZED" : "NOT_ANALYZED";
375
+ const job = this.printJobRepository.create({
376
+ printerId,
377
+ printerName: printerName || null,
378
+ fileName,
379
+ status: "PENDING",
380
+ analysisState,
381
+ metadata,
382
+ fileFormat: metadata.fileFormat,
383
+ fileSize: metadata.fileSize,
384
+ analyzedAt: hasAnalysisData ? /* @__PURE__ */ new Date() : null
385
+ });
386
+ await this.printJobRepository.save(job);
387
+ this.logger.log(`Created ${analysisState.toLowerCase()} print job ${job.id} for printer ${printerId}: ${fileName} (format: ${metadata.fileFormat})`);
388
+ return job;
389
+ }
390
+ /**
391
+ * Trigger file analysis for a job (emits event for async processing)
392
+ * Used when a print starts from a file on the printer that we don't have locally
393
+ */
394
+ async triggerFileAnalysis(jobId) {
395
+ this.eventEmitter2.emit("printJob.needsFileDownload", { jobId });
396
+ this.logger.log(`Triggered file download and analysis for job ${jobId}`);
397
+ }
398
+ async markAsCompleted(jobId, reason) {
399
+ const job = await this.getJobByIdOrFail(jobId);
400
+ job.status = "COMPLETED";
401
+ updateStatisticsForCompletion(job);
402
+ if (reason) job.statusReason = reason;
403
+ else job.statusReason = "Manually marked as completed by user";
404
+ await this.printJobRepository.save(job);
405
+ this.logger.log(`Job ${jobId} manually marked as COMPLETED`);
406
+ return job;
407
+ }
408
+ async markAsFailed(jobId, reason) {
409
+ const job = await this.getJobByIdOrFail(jobId);
410
+ job.status = "FAILED";
411
+ updateStatisticsForFailure(job, reason);
412
+ await this.printJobRepository.save(job);
413
+ this.logger.log(`Job ${jobId} manually marked as FAILED: ${reason}`);
414
+ return job;
415
+ }
416
+ async markAsCancelled(jobId, reason) {
417
+ const job = await this.getJobByIdOrFail(jobId);
418
+ job.status = "CANCELLED";
419
+ updateStatisticsForCancellation(job, reason);
420
+ await this.printJobRepository.save(job);
421
+ this.logger.log(`Job ${jobId} manually marked as CANCELLED`);
422
+ return job;
423
+ }
424
+ async markAsUnknown(jobId, reason) {
425
+ const job = await this.getJobByIdOrFail(jobId);
426
+ job.status = "UNKNOWN";
427
+ job.statusReason = reason || "Manually marked as unknown by user (state uncertain)";
428
+ await this.printJobRepository.save(job);
429
+ this.logger.log(`Job ${jobId} manually marked as UNKNOWN`);
430
+ return job;
431
+ }
432
+ async countJobsReferencingFile(fileStorageId) {
433
+ return await this.printJobRepository.count({ where: { fileStorageId } });
434
+ }
435
+ async updateJob(job) {
436
+ return await this.printJobRepository.save(job);
437
+ }
438
+ async deleteJob(job) {
439
+ await this.printJobRepository.remove(job);
440
+ }
441
+ };
442
+ //#endregion
443
+ export { PrintJobService };
546
444
 
547
445
  //# sourceMappingURL=print-job.service.js.map