@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 +1 @@
1
- {"version":3,"sources":["../../../src/services/orm/print-job.service.ts"],"names":["PrintJobService","printJobRepository","eventEmitter2","logger","loggerFactory","typeormService","getDataSource","getRepository","PrintJob","name","getJobByIdOrFail","id","relations","job","findOne","where","NotFoundException","handleFileAnalyzed","jobId","metadata","thumbnails","Error","analysisState","analyzedAt","Date","fileFormat","save","emit","printerId","log","fileName","handlePrintStarted","printerName","existingJob","status","order","startedAt","statusReason","endedAt","warn","createdAt","create","progress","statistics","actualPrintTimeSeconds","handlePrintProgress","currentLayer","totalLayers","Math","min","max","undefined","handlePrintCompleted","actualTimeSeconds","calculateJobDuration","updateStatisticsForCompletion","estimatedTimeSeconds","gcodePrintTimeSeconds","toFixed","handlePrintFailed","reason","updateStatisticsForFailure","failedAt","handlePrintCancelled","updateStatisticsForCancellation","cancelledAt","handlePrintPaused","handlePrintResumed","cleanupStaleJobs","staleJobs","find","length","getActivePrintJob","getPrintJobHistory","limit","take","markStarted","markProgress","markFinished","markFailed","updateJobMetadata","partialMetadata","debug","updatedMetadata","key","value","Object","entries","hasData","values","some","v","searchPrintJobs","searchPrinter","searchFile","startDate","endDate","query","createQueryBuilder","andWhere","Number","parseInt","orderBy","getMany","searchPrintJobsPaged","page","pageSize","skip","getManyAndCount","createPendingJob","hasAnalysisData","filamentUsedGrams","totalFilamentUsedGrams","layerHeight","fileSize","toLowerCase","triggerFileAnalysis","markAsCompleted","markAsFailed","markAsCancelled","markAsUnknown","countJobsReferencingFile","fileStorageId","count","updateJob","deleteJob","remove"],"mappings":"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"}
1
+ {"version":3,"file":"print-job.service.js","names":[],"sources":["../../../src/services/orm/print-job.service.ts"],"sourcesContent":["import { Repository } from \"typeorm\";\nimport { PrintJob, PrintJobMetadata } from \"@/entities/print-job.entity\";\nimport EventEmitter2 from \"eventemitter2\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\nimport { TypeormService } from \"@/services/typeorm/typeorm.service\";\nimport { NotFoundException } from \"@/exceptions/runtime.exceptions\";\nimport {\n updateStatisticsForCompletion,\n updateStatisticsForFailure,\n updateStatisticsForCancellation,\n calculateJobDuration,\n} from \"@/utils/job-stats.util\";\n\n// Events emitted by this service\nexport interface PrintJobAnalyzedEvent {\n jobId: number;\n printerId: number;\n metadata: PrintJobMetadata;\n}\n\nexport interface PrintJobStartedEvent {\n jobId: number;\n printerId: number;\n fileName: string;\n startedAt: Date;\n}\n\nexport interface PrintJobProgressEvent {\n jobId: number;\n printerId: number;\n progress: number;\n currentLayer?: number;\n totalLayers?: number;\n}\n\nexport interface PrintJobCompletedEvent {\n jobId: number;\n printerId: number;\n fileName: string;\n actualTimeSeconds: number;\n estimatedTimeSeconds?: number;\n}\n\nexport interface PrintJobFailedEvent {\n jobId: number;\n printerId: number;\n fileName: string;\n reason: string;\n failedAt: Date;\n}\n\nexport interface PrintJobCancelledEvent {\n jobId: number;\n printerId: number;\n fileName: string;\n cancelledAt: Date;\n}\n\nexport interface IPrintJobService {\n handleFileAnalyzed(jobId: number, metadata: PrintJobMetadata, thumbnails?: any[]): Promise<PrintJob>;\n handlePrintStarted(printerId: number, fileName: string, jobId?: number, printerName?: string): Promise<PrintJob>;\n handlePrintProgress(\n printerId: number,\n progress: number,\n currentLayer?: number,\n totalLayers?: number,\n ): Promise<PrintJob | null>;\n handlePrintCompleted(printerId: number, fileName?: string): Promise<PrintJob | null>;\n handlePrintFailed(printerId: number, reason: string, fileName?: string): Promise<PrintJob | null>;\n handlePrintCancelled(printerId: number, reason?: string): Promise<PrintJob | null>;\n handlePrintPaused(printerId: number): Promise<PrintJob | null>;\n handlePrintResumed(printerId: number): Promise<PrintJob | null>;\n cleanupStaleJobs(): Promise<void>;\n getActivePrintJob(printerId: number): Promise<PrintJob | null>;\n getPrintJobHistory(printerId: number, limit?: number): Promise<PrintJob[]>;\n\n // Helper methods for printer middleware\n markStarted(printerId: number, fileName: string, printerName?: string): Promise<PrintJob>;\n markProgress(\n printerId: number,\n fileName: string,\n progress: number,\n currentLayer?: number,\n totalLayers?: number,\n ): Promise<PrintJob | null>;\n markFinished(printerId: number, fileName: string): Promise<PrintJob | null>;\n markFailed(printerId: number, fileName: string, reason: string): Promise<PrintJob | null>;\n updateJobMetadata(printerId: number, fileName: string, partialMetadata: Partial<PrintJobMetadata>): Promise<void>;\n\n // Search methods for API\n searchPrintJobs(searchPrinter?: string, searchFile?: string, startDate?: Date, endDate?: Date): Promise<PrintJob[]>;\n searchPrintJobsPaged(\n searchPrinter?: string,\n searchFile?: string,\n startDate?: Date,\n endDate?: Date,\n page?: number,\n pageSize?: number,\n ): Promise<[PrintJob[], number]>;\n\n // Job creation\n createPendingJob(\n printerId: number,\n fileName: string,\n metadata: PrintJobMetadata,\n printerName?: string,\n ): Promise<PrintJob>;\n\n // File download and analysis\n triggerFileAnalysis(jobId: number): Promise<void>;\n\n // Manual status updates\n markAsCompleted(jobId: number, reason?: string): Promise<PrintJob>;\n markAsFailed(jobId: number, reason: string): Promise<PrintJob>;\n markAsCancelled(jobId: number, reason?: string): Promise<PrintJob>;\n markAsUnknown(jobId: number, reason?: string): Promise<PrintJob>;\n\n // File reference counting\n countJobsReferencingFile(fileStorageId: string): Promise<number>;\n\n // Job management\n updateJob(job: PrintJob): Promise<PrintJob>;\n deleteJob(job: PrintJob): Promise<void>;\n}\n\nexport class PrintJobService implements IPrintJobService {\n printJobRepository: Repository<PrintJob>;\n eventEmitter2: EventEmitter2;\n private readonly logger;\n\n constructor(loggerFactory: ILoggerFactory, typeormService: TypeormService, eventEmitter2: EventEmitter2) {\n this.printJobRepository = typeormService.getDataSource().getRepository(PrintJob);\n this.eventEmitter2 = eventEmitter2;\n this.logger = loggerFactory(PrintJobService.name);\n }\n\n async getJobByIdOrFail(id: number, relations?: string[]): Promise<PrintJob> {\n const job = await this.printJobRepository.findOne({\n where: { id },\n relations,\n });\n if (!job) {\n throw new NotFoundException(`Job ${id} not found`);\n }\n return job;\n }\n\n async handleFileAnalyzed(jobId: number, metadata: PrintJobMetadata, thumbnails?: any[]): Promise<PrintJob> {\n const job = await this.printJobRepository.findOne({ where: { id: jobId } });\n if (!job) {\n throw new Error(`Print job ${jobId} not found`);\n }\n\n job.metadata = metadata;\n job.analysisState = \"ANALYZED\";\n job.analyzedAt = new Date();\n // Status remains unchanged - analysis state is separate from job status\n job.fileFormat = metadata.fileFormat;\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.analyzed\", {\n jobId: job.id,\n printerId: job.printerId,\n metadata,\n } as PrintJobAnalyzedEvent);\n\n this.logger.log(`Print job ${jobId} analyzed: ${metadata.fileName}`);\n return job;\n }\n\n async handlePrintStarted(\n printerId: number,\n fileName: string,\n jobId?: number,\n printerName?: string,\n ): Promise<PrintJob> {\n const existingJob = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (existingJob?.fileName === fileName && !jobId) {\n return existingJob;\n }\n\n // Different file is printing - mark the old one as UNKNOWN\n if (existingJob && existingJob.fileName !== fileName && !jobId) {\n existingJob.status = \"UNKNOWN\";\n existingJob.statusReason =\n \"Print state unknown - printer started new job while previous job was still marked as printing. \" +\n \"This may indicate a disconnect, server restart, or manual printer control.\";\n existingJob.endedAt = new Date();\n await this.printJobRepository.save(existingJob);\n\n this.logger.warn(\n `Printer ${printerId} started new print \"${fileName}\" while job ${existingJob.id} was PRINTING \"${existingJob.fileName}\". ` +\n `Marked job ${existingJob.id} as UNKNOWN.`,\n );\n }\n\n let job: PrintJob | null;\n if (jobId) {\n job = await this.printJobRepository.findOne({ where: { id: jobId } });\n if (!job) {\n throw new Error(`Print job ${jobId} not found`);\n }\n } else {\n // First, look for a PENDING job (created during upload)\n job = await this.printJobRepository.findOne({\n where: { printerId, fileName, status: \"PENDING\" },\n order: { createdAt: \"DESC\" },\n });\n\n // If no pending/analyzed job, look for any recent job with this filename\n if (!job) {\n job = await this.printJobRepository.findOne({\n where: { printerId, fileName },\n order: { createdAt: \"DESC\" },\n });\n }\n\n // If still no job, create a new one\n if (!job) {\n this.logger.log(`Creating new job for ${fileName} - no pending or existing job found`);\n job = this.printJobRepository.create({\n printerId,\n printerName: printerName || null,\n fileName,\n status: \"PRINTING\",\n analysisState: \"NOT_ANALYZED\",\n });\n } else if (job.status === \"PENDING\") {\n this.logger.log(`Promoting pending job ${job.id} to PRINTING`);\n } else if (job.status === \"COMPLETED\" || job.status === \"FAILED\" || job.status === \"CANCELLED\") {\n // Don't reuse completed jobs - this is a re-print, create new job\n this.logger.log(`Creating new job for re-print of ${fileName} (previous job ${job.id} was ${job.status})`);\n job = this.printJobRepository.create({\n printerId,\n printerName: printerName || job.printerName || null,\n fileName,\n status: \"PRINTING\",\n analysisState: job.analysisState, // Keep analysis state from previous print\n metadata: job.metadata, // Reuse metadata from previous print\n fileFormat: job.fileFormat,\n });\n }\n }\n\n job.status = \"PRINTING\";\n job.startedAt = new Date();\n job.progress = 0;\n\n // Set/update printerName if provided\n if (printerName && !job.printerName) {\n job.printerName = printerName;\n }\n\n if (!job.statistics) {\n job.statistics = {\n startedAt: new Date(),\n endedAt: null,\n actualPrintTimeSeconds: null,\n progress: 0,\n };\n } else {\n job.statistics.startedAt = new Date();\n job.statistics.progress = 0;\n }\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.started\", {\n jobId: job.id,\n printerId,\n fileName,\n startedAt: job.startedAt,\n } as PrintJobStartedEvent);\n\n this.logger.log(`Print job ${job.id} started on printer ${printerId}: ${fileName}`);\n return job;\n }\n\n async handlePrintProgress(printerId: number, progress: number): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n return null;\n }\n\n job.progress = Math.min(100, Math.max(0, progress));\n\n if (job.statistics) {\n job.statistics.progress = job.progress;\n } else {\n job.statistics = {\n startedAt: job.startedAt,\n endedAt: null,\n actualPrintTimeSeconds: null,\n progress: job.progress,\n };\n }\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.progress\", {\n jobId: job.id,\n printerId,\n progress: job.progress,\n } as PrintJobProgressEvent);\n\n return job;\n }\n\n async handlePrintCompleted(printerId: number, fileName?: string): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No active print job found for printer ${printerId} on completion`);\n return null;\n }\n\n if (fileName && job.fileName !== fileName) {\n this.logger.warn(`Filename mismatch on completion: expected \"${job.fileName}\", got \"${fileName}\"`);\n }\n\n const endedAt = new Date();\n const actualTimeSeconds = calculateJobDuration(job.startedAt, endedAt);\n\n job.status = \"COMPLETED\";\n updateStatisticsForCompletion(job, endedAt);\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.completed\", {\n jobId: job.id,\n printerId,\n fileName: job.fileName,\n actualTimeSeconds,\n estimatedTimeSeconds: job.metadata?.gcodePrintTimeSeconds,\n } as PrintJobCompletedEvent);\n\n this.logger.log(\n `Print job ${job.id} completed on printer ${printerId}: ${job.fileName} ` +\n `(${actualTimeSeconds?.toFixed(0)}s actual, ${job.metadata?.gcodePrintTimeSeconds}s estimated)`,\n );\n\n return job;\n }\n\n async handlePrintFailed(printerId: number, reason: string, fileName?: string): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No active print job found for printer ${printerId} on failure`);\n return null;\n }\n\n const endedAt = new Date();\n\n job.status = \"FAILED\";\n updateStatisticsForFailure(job, reason, endedAt);\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.failed\", {\n jobId: job.id,\n printerId,\n fileName: job.fileName,\n reason,\n failedAt: endedAt,\n } as PrintJobFailedEvent);\n\n this.logger.log(`Print job ${job.id} failed on printer ${printerId}: ${job.fileName} - ${reason}`);\n\n return job;\n }\n\n async handlePrintCancelled(printerId: number, reason?: string): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No active print job found for printer ${printerId} on cancellation`);\n return null;\n }\n\n const endedAt = new Date();\n\n job.status = \"CANCELLED\";\n updateStatisticsForCancellation(job, reason, endedAt);\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.cancelled\", {\n jobId: job.id,\n printerId,\n fileName: job.fileName,\n cancelledAt: endedAt,\n } as PrintJobCancelledEvent);\n\n this.logger.log(`Print job ${job.id} cancelled on printer ${printerId}: ${job.fileName}`);\n return job;\n }\n\n async handlePrintPaused(printerId: number): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No active print job found for printer ${printerId} on pause`);\n return null;\n }\n\n job.status = \"PAUSED\";\n await this.printJobRepository.save(job);\n\n this.logger.log(`Print job ${job.id} paused on printer ${printerId}`);\n return job;\n }\n\n async handlePrintResumed(printerId: number): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PAUSED\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No paused print job found for printer ${printerId} on resume`);\n return null;\n }\n\n job.status = \"PRINTING\";\n await this.printJobRepository.save(job);\n\n this.logger.log(`Print job ${job.id} resumed on printer ${printerId}`);\n return job;\n }\n\n async cleanupStaleJobs(): Promise<void> {\n const staleJobs = await this.printJobRepository.find({\n where: { status: \"PRINTING\" },\n });\n\n for (const job of staleJobs) {\n job.status = \"UNKNOWN\";\n job.statusReason =\n \"Print state unknown after server restart. The print may have completed, \" +\n \"failed, or still be running. Check your printer for current status.\";\n await this.printJobRepository.save(job);\n\n this.logger.warn(\n `Marked job ${job.id} (printer ${job.printerId}) as UNKNOWN after startup - ` +\n `was PRINTING before server stopped`,\n );\n }\n\n if (staleJobs.length > 0) {\n this.logger.log(`Cleaned up ${staleJobs.length} stale print job(s) on startup`);\n }\n }\n\n async getActivePrintJob(printerId: number): Promise<PrintJob | null> {\n return this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n }\n\n async getPrintJobHistory(printerId: number, limit: number = 50): Promise<PrintJob[]> {\n return this.printJobRepository.find({\n where: { printerId },\n order: { createdAt: \"DESC\" },\n take: limit,\n });\n }\n\n async markStarted(printerId: number, fileName: string, printerName?: string): Promise<PrintJob> {\n return await this.handlePrintStarted(printerId, fileName, undefined, printerName);\n }\n\n async markProgress(printerId: number, fileName: string, progress: number): Promise<PrintJob | null> {\n return await this.handlePrintProgress(printerId, progress);\n }\n\n /**\n * Mark print as finished by fileName\n * Used by printer middleware when print completes successfully\n */\n async markFinished(printerId: number, fileName: string): Promise<PrintJob | null> {\n return await this.handlePrintCompleted(printerId, fileName);\n }\n\n /**\n * Mark print as failed by fileName\n * Used by printer middleware when print fails\n */\n async markFailed(printerId: number, fileName: string, reason: string): Promise<PrintJob | null> {\n return await this.handlePrintFailed(printerId, reason, fileName);\n }\n\n /**\n * Update job metadata with partial data from printer middleware\n * Useful for updating estimates from OctoPrint/Moonraker during print\n * Only updates if job has no metadata or to supplement existing metadata\n */\n async updateJobMetadata(\n printerId: number,\n fileName: string,\n partialMetadata: Partial<PrintJobMetadata>,\n ): Promise<void> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, fileName, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.debug(`No active job found for printer ${printerId}, file ${fileName} - skipping metadata update`);\n return;\n }\n\n // If job already has ANALYZED metadata, don't overwrite with incomplete data\n if (job.analysisState === \"ANALYZED\" && job.metadata) {\n this.logger.debug(`Job ${job.id} already has analyzed metadata, merging only missing fields`);\n // Only merge in fields that are currently null/undefined\n const updatedMetadata = { ...job.metadata } as Record<string, any>;\n for (const [key, value] of Object.entries(partialMetadata)) {\n if (value != null && (updatedMetadata[key] == null || updatedMetadata[key] === null)) {\n updatedMetadata[key] = value;\n }\n }\n job.metadata = updatedMetadata as PrintJobMetadata;\n } else if (job.metadata) {\n // Merge partial metadata with existing metadata\n job.metadata = {\n ...job.metadata,\n ...partialMetadata,\n } as PrintJobMetadata;\n } else {\n // No metadata exists - only create if we have meaningful data\n // Don't create metadata structure with mostly nulls\n const hasData = Object.values(partialMetadata).some((v) => v !== null);\n if (!hasData) {\n this.logger.debug(`Skipping metadata creation for job ${job.id} - no meaningful data provided`);\n return;\n }\n\n // Create minimal metadata structure\n job.metadata = {\n fileName,\n fileFormat: job.fileFormat || \"gcode\", // Use existing fileFormat or default\n ...partialMetadata,\n } as PrintJobMetadata;\n }\n\n await this.printJobRepository.save(job);\n this.logger.debug(`Updated metadata for job ${job.id}`);\n }\n\n // ========== Search methods for API ==========\n\n /**\n * Search print jobs with optional filters\n */\n async searchPrintJobs(\n searchPrinter?: string,\n searchFile?: string,\n startDate?: Date,\n endDate?: Date,\n ): Promise<PrintJob[]> {\n const query = this.printJobRepository.createQueryBuilder(\"job\");\n\n if (searchPrinter) {\n query.andWhere(\"job.printerId = :printerId\", { printerId: Number.parseInt(searchPrinter, 10) });\n }\n\n if (searchFile) {\n query.andWhere(\"job.fileName LIKE :fileName\", { fileName: `%${searchFile}%` });\n }\n\n if (startDate) {\n query.andWhere(\"job.startedAt >= :startDate\", { startDate });\n }\n\n if (endDate) {\n query.andWhere(\"job.startedAt <= :endDate\", { endDate });\n }\n\n return await query.orderBy(\"job.startedAt\", \"DESC\").getMany();\n }\n\n /**\n * Search print jobs with pagination\n */\n async searchPrintJobsPaged(\n searchPrinter?: string,\n searchFile?: string,\n startDate?: Date,\n endDate?: Date,\n page: number = 1,\n pageSize: number = 50,\n ): Promise<[PrintJob[], number]> {\n const query = this.printJobRepository.createQueryBuilder(\"job\");\n\n if (searchPrinter) {\n query.andWhere(\"job.printerId = :printerId\", { printerId: Number.parseInt(searchPrinter, 10) });\n }\n\n if (searchFile) {\n query.andWhere(\"job.fileName LIKE :fileName\", { fileName: `%${searchFile}%` });\n }\n\n if (startDate) {\n query.andWhere(\"job.startedAt >= :startDate\", { startDate });\n }\n\n if (endDate) {\n query.andWhere(\"job.startedAt <= :endDate\", { endDate });\n }\n\n return await query\n .orderBy(\"job.startedAt\", \"DESC\")\n .skip((page - 1) * pageSize)\n .take(pageSize)\n .getManyAndCount();\n }\n\n // ========== Job creation ==========\n\n /**\n * Create a pending print job (typically called when file is uploaded)\n * Used when a file is uploaded to a printer, creating a job ready for analysis\n */\n async createPendingJob(\n printerId: number,\n fileName: string,\n metadata: PrintJobMetadata,\n printerName?: string,\n ): Promise<PrintJob> {\n // Determine if metadata contains meaningful analysis data\n // (more than just basic file info)\n const hasAnalysisData =\n metadata.gcodePrintTimeSeconds !== null ||\n metadata.filamentUsedGrams !== null ||\n metadata.totalFilamentUsedGrams !== null ||\n metadata.layerHeight !== null ||\n metadata.totalLayers !== null;\n\n const analysisState = hasAnalysisData ? \"ANALYZED\" : \"NOT_ANALYZED\";\n // Status is always PENDING for newly created jobs (analysis state is separate)\n const status = \"PENDING\";\n\n const job = this.printJobRepository.create({\n printerId,\n printerName: printerName || null,\n fileName,\n status,\n analysisState,\n metadata,\n fileFormat: metadata.fileFormat,\n fileSize: metadata.fileSize,\n analyzedAt: hasAnalysisData ? new Date() : null,\n });\n\n await this.printJobRepository.save(job);\n\n this.logger.log(\n `Created ${analysisState.toLowerCase()} print job ${job.id} for printer ${printerId}: ${fileName} (format: ${metadata.fileFormat})`,\n );\n return job;\n }\n\n /**\n * Trigger file analysis for a job (emits event for async processing)\n * Used when a print starts from a file on the printer that we don't have locally\n */\n async triggerFileAnalysis(jobId: number): Promise<void> {\n this.eventEmitter2.emit(\"printJob.needsFileDownload\", { jobId });\n this.logger.log(`Triggered file download and analysis for job ${jobId}`);\n }\n\n async markAsCompleted(jobId: number, reason?: string): Promise<PrintJob> {\n const job = await this.getJobByIdOrFail(jobId);\n\n job.status = \"COMPLETED\";\n updateStatisticsForCompletion(job);\n\n if (reason) {\n job.statusReason = reason;\n } else {\n job.statusReason = \"Manually marked as completed by user\";\n }\n\n await this.printJobRepository.save(job);\n\n this.logger.log(`Job ${jobId} manually marked as COMPLETED`);\n\n return job;\n }\n\n async markAsFailed(jobId: number, reason: string): Promise<PrintJob> {\n const job = await this.getJobByIdOrFail(jobId);\n\n job.status = \"FAILED\";\n updateStatisticsForFailure(job, reason);\n\n await this.printJobRepository.save(job);\n\n this.logger.log(`Job ${jobId} manually marked as FAILED: ${reason}`);\n\n return job;\n }\n\n async markAsCancelled(jobId: number, reason?: string): Promise<PrintJob> {\n const job = await this.getJobByIdOrFail(jobId);\n\n job.status = \"CANCELLED\";\n updateStatisticsForCancellation(job, reason);\n\n await this.printJobRepository.save(job);\n\n this.logger.log(`Job ${jobId} manually marked as CANCELLED`);\n\n return job;\n }\n\n async markAsUnknown(jobId: number, reason?: string): Promise<PrintJob> {\n const job = await this.getJobByIdOrFail(jobId);\n\n job.status = \"UNKNOWN\";\n job.statusReason = reason || \"Manually marked as unknown by user (state uncertain)\";\n\n await this.printJobRepository.save(job);\n\n this.logger.log(`Job ${jobId} manually marked as UNKNOWN`);\n\n return job;\n }\n\n async countJobsReferencingFile(fileStorageId: string): Promise<number> {\n return await this.printJobRepository.count({\n where: { fileStorageId },\n });\n }\n\n async updateJob(job: PrintJob): Promise<PrintJob> {\n return await this.printJobRepository.save(job);\n }\n\n async deleteJob(job: PrintJob): Promise<void> {\n await this.printJobRepository.remove(job);\n }\n}\n"],"mappings":"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"}
@@ -1,151 +1,104 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "PrinterMaintenanceLogService", {
6
- enumerable: true,
7
- get: function() {
8
- return PrinterMaintenanceLogService;
9
- }
10
- });
11
- const _printermaintenancelogentity = require("../../entities/printer-maintenance-log.entity");
12
- const _runtimeexceptions = require("../../exceptions/runtime.exceptions");
13
- class PrinterMaintenanceLogService {
14
- printerService;
15
- logger;
16
- repository;
17
- constructor(loggerFactory, typeormService, printerService){
18
- this.printerService = printerService;
19
- this.logger = loggerFactory(PrinterMaintenanceLogService.name);
20
- this.repository = typeormService.getDataSource().getRepository(_printermaintenancelogentity.PrinterMaintenanceLog);
21
- }
22
- toDto(entity) {
23
- return {
24
- id: entity.id,
25
- createdAt: entity.createdAt,
26
- createdBy: entity.createdBy,
27
- createdByUserId: entity.createdByUserId,
28
- printerId: entity.printerId,
29
- printerName: entity.printerName,
30
- printerUrl: entity.printerUrl,
31
- metadata: entity.metadata,
32
- completed: entity.completed,
33
- completedAt: entity.completedAt,
34
- completedByUserId: entity.completedByUserId,
35
- completedBy: entity.completedBy
36
- };
37
- }
38
- async create(dto, userId, username) {
39
- const printer = await this.printerService.get(dto.printerId);
40
- const existingLog = await this.repository.findOne({
41
- where: {
42
- printerId: dto.printerId,
43
- completed: false
44
- }
45
- });
46
- if (existingLog) {
47
- throw new _runtimeexceptions.BadRequestException(`Printer ${printer.name} already has an active maintenance log`);
48
- }
49
- const log = this.repository.create({
50
- printerId: dto.printerId,
51
- printerName: printer.name,
52
- printerUrl: printer.printerURL,
53
- metadata: dto.metadata,
54
- createdBy: username,
55
- createdByUserId: userId,
56
- completed: false
57
- });
58
- await this.repository.save(log);
59
- await this.printerService.updateDisabledReason(dto.printerId, this.buildDisabledReasonFromMetadata(dto.metadata));
60
- return log;
61
- }
62
- async complete(logId, dto, userId, username) {
63
- const log = await this.repository.findOne({
64
- where: {
65
- id: logId
66
- }
67
- });
68
- if (!log) {
69
- throw new _runtimeexceptions.NotFoundException(`Maintenance log with id ${logId} not found`);
70
- }
71
- if (log.completed) {
72
- throw new _runtimeexceptions.BadRequestException(`Maintenance log ${logId} is already completed`);
73
- }
74
- log.metadata = {
75
- ...log.metadata,
76
- completionNotes: dto.completionNotes
77
- };
78
- log.completed = true;
79
- log.completedAt = new Date();
80
- log.completedBy = username;
81
- log.completedByUserId = userId;
82
- await this.repository.save(log);
83
- if (log.printerId) {
84
- await this.printerService.updateDisabledReason(log.printerId, null);
85
- }
86
- return log;
87
- }
88
- async get(logId) {
89
- const log = await this.repository.findOne({
90
- where: {
91
- id: logId
92
- }
93
- });
94
- if (!log) {
95
- throw new _runtimeexceptions.NotFoundException(`Maintenance log with id ${logId} not found`);
96
- }
97
- return log;
98
- }
99
- async getActiveByPrinterId(printerId) {
100
- return this.repository.findOne({
101
- where: {
102
- printerId,
103
- completed: false
104
- }
105
- });
106
- }
107
- async list(filters) {
108
- const { printerId, completed, page = 1, pageSize = 20 } = filters;
109
- const queryBuilder = this.repository.createQueryBuilder("log");
110
- if (printerId !== undefined) {
111
- queryBuilder.andWhere("log.printerId = :printerId", {
112
- printerId
113
- });
114
- }
115
- if (completed !== undefined) {
116
- queryBuilder.andWhere("log.completed = :completed", {
117
- completed
118
- });
119
- }
120
- queryBuilder.orderBy("log.createdAt", "DESC");
121
- queryBuilder.skip((page - 1) * pageSize);
122
- queryBuilder.take(pageSize);
123
- const [logs, total] = await queryBuilder.getManyAndCount();
124
- return {
125
- logs,
126
- total
127
- };
128
- }
129
- async delete(logId) {
130
- const log = await this.get(logId);
131
- if (!log.completed && log.printerId) {
132
- await this.printerService.updateDisabledReason(log.printerId, null);
133
- }
134
- await this.repository.delete(logId);
135
- }
136
- buildDisabledReasonFromMetadata(metadata) {
137
- const parts = [];
138
- if (metadata.cause) {
139
- parts.push(metadata.cause);
140
- }
141
- if (metadata.partsInvolved && metadata.partsInvolved.length > 0) {
142
- parts.push(`Parts: ${metadata.partsInvolved.join(", ")}`);
143
- }
144
- if (metadata.notes) {
145
- parts.push(metadata.notes);
146
- }
147
- return parts.join(" - ") || "Under maintenance";
148
- }
149
- }
1
+ import { BadRequestException, NotFoundException } from "../../exceptions/runtime.exceptions.js";
2
+ import { PrinterMaintenanceLog } from "../../entities/printer-maintenance-log.entity.js";
3
+ //#region src/services/orm/printer-maintenance-log.service.ts
4
+ var PrinterMaintenanceLogService = class PrinterMaintenanceLogService {
5
+ logger;
6
+ repository;
7
+ constructor(loggerFactory, typeormService, printerService) {
8
+ this.printerService = printerService;
9
+ this.logger = loggerFactory(PrinterMaintenanceLogService.name);
10
+ this.repository = typeormService.getDataSource().getRepository(PrinterMaintenanceLog);
11
+ }
12
+ toDto(entity) {
13
+ return {
14
+ id: entity.id,
15
+ createdAt: entity.createdAt,
16
+ createdBy: entity.createdBy,
17
+ createdByUserId: entity.createdByUserId,
18
+ printerId: entity.printerId,
19
+ printerName: entity.printerName,
20
+ printerUrl: entity.printerUrl,
21
+ metadata: entity.metadata,
22
+ completed: entity.completed,
23
+ completedAt: entity.completedAt,
24
+ completedByUserId: entity.completedByUserId,
25
+ completedBy: entity.completedBy
26
+ };
27
+ }
28
+ async create(dto, userId, username) {
29
+ const printer = await this.printerService.get(dto.printerId);
30
+ if (await this.repository.findOne({ where: {
31
+ printerId: dto.printerId,
32
+ completed: false
33
+ } })) throw new BadRequestException(`Printer ${printer.name} already has an active maintenance log`);
34
+ const log = this.repository.create({
35
+ printerId: dto.printerId,
36
+ printerName: printer.name,
37
+ printerUrl: printer.printerURL,
38
+ metadata: dto.metadata,
39
+ createdBy: username,
40
+ createdByUserId: userId,
41
+ completed: false
42
+ });
43
+ await this.repository.save(log);
44
+ await this.printerService.updateDisabledReason(dto.printerId, this.buildDisabledReasonFromMetadata(dto.metadata));
45
+ return log;
46
+ }
47
+ async complete(logId, dto, userId, username) {
48
+ const log = await this.repository.findOne({ where: { id: logId } });
49
+ if (!log) throw new NotFoundException(`Maintenance log with id ${logId} not found`);
50
+ if (log.completed) throw new BadRequestException(`Maintenance log ${logId} is already completed`);
51
+ log.metadata = {
52
+ ...log.metadata,
53
+ completionNotes: dto.completionNotes
54
+ };
55
+ log.completed = true;
56
+ log.completedAt = /* @__PURE__ */ new Date();
57
+ log.completedBy = username;
58
+ log.completedByUserId = userId;
59
+ await this.repository.save(log);
60
+ if (log.printerId) await this.printerService.updateDisabledReason(log.printerId, null);
61
+ return log;
62
+ }
63
+ async get(logId) {
64
+ const log = await this.repository.findOne({ where: { id: logId } });
65
+ if (!log) throw new NotFoundException(`Maintenance log with id ${logId} not found`);
66
+ return log;
67
+ }
68
+ async getActiveByPrinterId(printerId) {
69
+ return this.repository.findOne({ where: {
70
+ printerId,
71
+ completed: false
72
+ } });
73
+ }
74
+ async list(filters) {
75
+ const { printerId, completed, page = 1, pageSize = 20 } = filters;
76
+ const queryBuilder = this.repository.createQueryBuilder("log");
77
+ if (printerId !== void 0) queryBuilder.andWhere("log.printerId = :printerId", { printerId });
78
+ if (completed !== void 0) queryBuilder.andWhere("log.completed = :completed", { completed });
79
+ queryBuilder.orderBy("log.createdAt", "DESC");
80
+ queryBuilder.skip((page - 1) * pageSize);
81
+ queryBuilder.take(pageSize);
82
+ const [logs, total] = await queryBuilder.getManyAndCount();
83
+ return {
84
+ logs,
85
+ total
86
+ };
87
+ }
88
+ async delete(logId) {
89
+ const log = await this.get(logId);
90
+ if (!log.completed && log.printerId) await this.printerService.updateDisabledReason(log.printerId, null);
91
+ await this.repository.delete(logId);
92
+ }
93
+ buildDisabledReasonFromMetadata(metadata) {
94
+ const parts = [];
95
+ if (metadata.cause) parts.push(metadata.cause);
96
+ if (metadata.partsInvolved && metadata.partsInvolved.length > 0) parts.push(`Parts: ${metadata.partsInvolved.join(", ")}`);
97
+ if (metadata.notes) parts.push(metadata.notes);
98
+ return parts.join(" - ") || "Under maintenance";
99
+ }
100
+ };
101
+ //#endregion
102
+ export { PrinterMaintenanceLogService };
150
103
 
151
104
  //# sourceMappingURL=printer-maintenance-log.service.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/services/orm/printer-maintenance-log.service.ts"],"names":["PrinterMaintenanceLogService","logger","repository","loggerFactory","typeormService","printerService","name","getDataSource","getRepository","PrinterMaintenanceLog","toDto","entity","id","createdAt","createdBy","createdByUserId","printerId","printerName","printerUrl","metadata","completed","completedAt","completedByUserId","completedBy","create","dto","userId","username","printer","get","existingLog","findOne","where","BadRequestException","log","printerURL","save","updateDisabledReason","buildDisabledReasonFromMetadata","complete","logId","NotFoundException","completionNotes","Date","getActiveByPrinterId","list","filters","page","pageSize","queryBuilder","createQueryBuilder","undefined","andWhere","orderBy","skip","take","logs","total","getManyAndCount","delete","parts","cause","push","partsInvolved","length","join","notes"],"mappings":"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"}
1
+ {"version":3,"file":"printer-maintenance-log.service.js","names":[],"sources":["../../../src/services/orm/printer-maintenance-log.service.ts"],"sourcesContent":["import { Repository } from \"typeorm\";\nimport { PrinterMaintenanceLog } from \"@/entities/printer-maintenance-log.entity\";\nimport { TypeormService } from \"@/services/typeorm/typeorm.service\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\nimport { LoggerService } from \"@/handlers/logger\";\nimport {\n CreateMaintenanceLogDto,\n PrinterMaintenanceLogDto,\n CompleteMaintenanceLogDto,\n} from \"@/services/interfaces/printer-maintenance-log.dto\";\nimport { BadRequestException, NotFoundException } from \"@/exceptions/runtime.exceptions\";\nimport type { IPrinterService } from \"@/services/interfaces/printer.service.interface\";\n\nexport class PrinterMaintenanceLogService {\n private readonly logger: LoggerService;\n private readonly repository: Repository<PrinterMaintenanceLog>;\n\n constructor(\n loggerFactory: ILoggerFactory,\n typeormService: TypeormService,\n private readonly printerService: IPrinterService,\n ) {\n this.logger = loggerFactory(PrinterMaintenanceLogService.name);\n this.repository = typeormService.getDataSource().getRepository(PrinterMaintenanceLog);\n }\n\n toDto(entity: PrinterMaintenanceLog): PrinterMaintenanceLogDto {\n return {\n id: entity.id,\n createdAt: entity.createdAt,\n createdBy: entity.createdBy,\n createdByUserId: entity.createdByUserId,\n printerId: entity.printerId,\n printerName: entity.printerName,\n printerUrl: entity.printerUrl,\n metadata: entity.metadata,\n completed: entity.completed,\n completedAt: entity.completedAt,\n completedByUserId: entity.completedByUserId,\n completedBy: entity.completedBy,\n };\n }\n\n async create(dto: CreateMaintenanceLogDto, userId: number | null, username: string): Promise<PrinterMaintenanceLog> {\n // Get printer details\n const printer = await this.printerService.get(dto.printerId);\n\n // Check if there's already an active maintenance log for this printer\n const existingLog = await this.repository.findOne({\n where: {\n printerId: dto.printerId,\n completed: false,\n },\n });\n\n if (existingLog) {\n throw new BadRequestException(`Printer ${printer.name} already has an active maintenance log`);\n }\n\n const log = this.repository.create({\n printerId: dto.printerId,\n printerName: printer.name,\n printerUrl: printer.printerURL,\n metadata: dto.metadata,\n createdBy: username,\n createdByUserId: userId,\n completed: false,\n });\n\n await this.repository.save(log);\n\n // Update printer disabled reason for backwards compatibility\n await this.printerService.updateDisabledReason(dto.printerId, this.buildDisabledReasonFromMetadata(dto.metadata));\n\n return log;\n }\n\n async complete(\n logId: number,\n dto: CompleteMaintenanceLogDto,\n userId: number | null,\n username: string,\n ): Promise<PrinterMaintenanceLog> {\n const log = await this.repository.findOne({ where: { id: logId } });\n\n if (!log) {\n throw new NotFoundException(`Maintenance log with id ${logId} not found`);\n }\n\n if (log.completed) {\n throw new BadRequestException(`Maintenance log ${logId} is already completed`);\n }\n\n // Update metadata with completion notes\n log.metadata = {\n ...log.metadata,\n completionNotes: dto.completionNotes,\n };\n\n log.completed = true;\n log.completedAt = new Date();\n log.completedBy = username;\n log.completedByUserId = userId;\n\n await this.repository.save(log);\n\n // Clear printer disabled reason\n if (log.printerId) {\n await this.printerService.updateDisabledReason(log.printerId, null);\n }\n\n return log;\n }\n\n async get(logId: number): Promise<PrinterMaintenanceLog> {\n const log = await this.repository.findOne({ where: { id: logId } });\n\n if (!log) {\n throw new NotFoundException(`Maintenance log with id ${logId} not found`);\n }\n\n return log;\n }\n\n async getActiveByPrinterId(printerId: number): Promise<PrinterMaintenanceLog | null> {\n return this.repository.findOne({\n where: {\n printerId,\n completed: false,\n },\n });\n }\n\n async list(filters: {\n printerId?: number;\n completed?: boolean;\n page?: number;\n pageSize?: number;\n }): Promise<{ logs: PrinterMaintenanceLog[]; total: number }> {\n const { printerId, completed, page = 1, pageSize = 20 } = filters;\n\n const queryBuilder = this.repository.createQueryBuilder(\"log\");\n\n if (printerId !== undefined) {\n queryBuilder.andWhere(\"log.printerId = :printerId\", { printerId });\n }\n\n if (completed !== undefined) {\n queryBuilder.andWhere(\"log.completed = :completed\", { completed });\n }\n\n queryBuilder.orderBy(\"log.createdAt\", \"DESC\");\n queryBuilder.skip((page - 1) * pageSize);\n queryBuilder.take(pageSize);\n\n const [logs, total] = await queryBuilder.getManyAndCount();\n\n return { logs, total };\n }\n\n async delete(logId: number): Promise<void> {\n const log = await this.get(logId);\n\n // Clear printer disabled reason if log is active\n if (!log.completed && log.printerId) {\n await this.printerService.updateDisabledReason(log.printerId, null);\n }\n\n await this.repository.delete(logId);\n }\n\n private buildDisabledReasonFromMetadata(metadata: {\n cause?: string;\n notes?: string;\n partsInvolved?: string[];\n }): string {\n const parts: string[] = [];\n\n if (metadata.cause) {\n parts.push(metadata.cause);\n }\n\n if (metadata.partsInvolved && metadata.partsInvolved.length > 0) {\n parts.push(`Parts: ${metadata.partsInvolved.join(\", \")}`);\n }\n\n if (metadata.notes) {\n parts.push(metadata.notes);\n }\n\n return parts.join(\" - \") || \"Under maintenance\";\n }\n}\n"],"mappings":"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"}