@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/tasks/print-job-analysis.task.ts"],"names":["PrintJobAnalysisTask","logger","printJobRepository","loggerFactory","printJobService","fileAnalysisService","fileStorageService","typeormService","name","getDataSource","getRepository","PrintJob","run","pendingJobs","find","where","analysisState","status","take","length","log","job","analyzeJob","error","id","fileName","statusReason","Error","message","save","fileStorageId","cachedMetadata","loadMetadata","metadata","thumbnails","filePath","resolveFilePath","exists","needsAnalysis","analysisResult","analyzeFile","thumbnailMetadata","saveThumbnails","fileHash","undefined","saveMetadata","handleFileAnalyzed","fileExists","warn","getFilePath","debug"],"mappings":"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"}
1
+ {"version":3,"file":"print-job-analysis.task.js","names":[],"sources":["../../src/tasks/print-job-analysis.task.ts"],"sourcesContent":["import { LoggerService } from \"@/handlers/logger\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\nimport { TaskService } from \"@/services/interfaces/task.interfaces\";\nimport { PrintJobService } from \"@/services/orm/print-job.service\";\nimport { FileAnalysisService } from \"@/services/file-analysis.service\";\nimport { FileStorageService } from \"@/services/file-storage.service\";\nimport { Repository } from \"typeorm\";\nimport { PrintJob } from \"@/entities/print-job.entity\";\nimport { TypeormService } from \"@/services/typeorm/typeorm.service\";\n\n/**\n * Background task to analyze pending print jobs\n * Runs periodically to extract metadata from uploaded files\n */\nexport class PrintJobAnalysisTask implements TaskService {\n logger: LoggerService;\n private readonly printJobRepository: Repository<PrintJob>;\n\n constructor(\n loggerFactory: ILoggerFactory,\n private readonly printJobService: PrintJobService,\n private readonly fileAnalysisService: FileAnalysisService,\n private readonly fileStorageService: FileStorageService,\n typeormService: TypeormService,\n ) {\n this.logger = loggerFactory(PrintJobAnalysisTask.name);\n this.printJobRepository = typeormService.getDataSource().getRepository(PrintJob);\n }\n\n async run() {\n try {\n // Find all jobs that need analysis\n const pendingJobs = await this.printJobRepository.find({\n where: [\n { analysisState: \"NOT_ANALYZED\", status: \"PENDING\" },\n { analysisState: \"ANALYZING\" }, // Retry stuck analyzing jobs\n ],\n take: 10, // Process up to 10 jobs per run\n });\n\n if (pendingJobs.length === 0) {\n return;\n }\n\n this.logger.log(`Found ${pendingJobs.length} print job(s) to analyze`);\n\n for (const job of pendingJobs) {\n try {\n await this.analyzeJob(job);\n } catch (error) {\n this.logger.error(`Failed to analyze job ${job.id}: ${job.fileName}`, error);\n\n // Mark as failed\n job.analysisState = \"FAILED\";\n job.statusReason = `Analysis failed: ${error instanceof Error ? error.message : \"Unknown error\"}`;\n await this.printJobRepository.save(job);\n }\n }\n\n this.logger.log(`Completed analysis of ${pendingJobs.length} print job(s)`);\n } catch (error) {\n this.logger.error(\"Failed to run print job analysis task\", error);\n }\n }\n\n private async analyzeJob(job: PrintJob): Promise<void> {\n this.logger.log(`Analyzing print job ${job.id}: ${job.fileName}`);\n\n // Mark as analyzing\n job.analysisState = \"ANALYZING\";\n await this.printJobRepository.save(job);\n\n if (!job.fileStorageId) {\n throw new Error(\"Job has no fileStorageId - cannot analyze\");\n }\n\n // Check if metadata JSON already exists (cached analysis)\n const cachedMetadata = await this.fileStorageService.loadMetadata(job.fileStorageId);\n\n let metadata;\n let thumbnails: any[] = [];\n\n if (cachedMetadata) {\n // Use cached metadata from JSON file (fast path - no re-analysis)\n this.logger.log(`Using cached metadata for job ${job.id} (storageId: ${job.fileStorageId})`);\n metadata = cachedMetadata;\n thumbnails = []; // Thumbnails not stored in JSON yet\n } else {\n // No cache - analyze the file\n const filePath = await this.resolveFilePath(job);\n\n if (!filePath) {\n throw new Error(\"File path could not be resolved\");\n }\n\n // Check if file exists\n const exists = await this.fileAnalysisService.needsAnalysis(filePath);\n if (!exists) {\n throw new Error(`File not found: ${filePath}`);\n }\n\n // Analyze the file\n const analysisResult = await this.fileAnalysisService.analyzeFile(filePath);\n metadata = analysisResult.metadata;\n thumbnails = analysisResult.thumbnails;\n\n // Save thumbnails\n let thumbnailMetadata: any[] = [];\n if (thumbnails && thumbnails.length > 0) {\n thumbnailMetadata = await this.fileStorageService.saveThumbnails(job.fileStorageId, thumbnails);\n this.logger.log(`Saved ${thumbnailMetadata.length} thumbnail(s) for job ${job.id}`);\n }\n\n // Cache metadata to JSON with thumbnail index\n const fileHash = job.fileHash || undefined;\n await this.fileStorageService.saveMetadata(\n job.fileStorageId,\n metadata,\n fileHash,\n job.fileName,\n thumbnailMetadata,\n );\n this.logger.log(`Cached metadata JSON for job ${job.id}`);\n }\n\n // Update job with metadata through service (emits events)\n await this.printJobService.handleFileAnalyzed(job.id, metadata, thumbnails);\n\n this.logger.log(`Successfully analyzed job ${job.id}: ${job.fileName}`);\n }\n\n private async resolveFilePath(job: PrintJob): Promise<string | null> {\n // If job has fileStorageId, get file from storage\n if (job.fileStorageId) {\n try {\n const exists = await this.fileStorageService.fileExists(job.fileStorageId);\n if (!exists) {\n this.logger.warn(`File ${job.fileStorageId} not found in storage for job ${job.id}`);\n return null;\n }\n\n return this.fileStorageService.getFilePath(job.fileStorageId);\n } catch (error) {\n this.logger.error(`Failed to resolve file path for job ${job.id}: ${error}`);\n return null;\n }\n }\n\n // If no fileStorageId, we can't analyze (file is on printer, not locally)\n this.logger.debug(`Job ${job.id} has no fileStorageId - cannot analyze remotely stored file`);\n return null;\n }\n}\n"],"mappings":"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"}
@@ -1,56 +1,43 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "PrinterWebsocketRestoreTask", {
6
- enumerable: true,
7
- get: function() {
8
- return PrinterWebsocketRestoreTask;
9
- }
10
- });
11
- const _errorutils = require("../utils/error.utils");
12
- const _node = require("@sentry/node");
13
- const _apistatetype = require("../shared/dtos/api-state.type");
14
- const _printerapiinterface = require("../services/printer-api.interface");
15
- class PrinterWebsocketRestoreTask {
16
- printerSocketStore;
17
- octoprintClient;
18
- logger;
19
- constructor(loggerFactory, printerSocketStore, octoprintClient){
20
- this.printerSocketStore = printerSocketStore;
21
- this.octoprintClient = octoprintClient;
22
- this.logger = loggerFactory(PrinterWebsocketRestoreTask.name);
23
- }
24
- async run() {
25
- const existingSockets = this.printerSocketStore.listPrinterSockets();
26
- for (const socket of existingSockets){
27
- if (socket.printerType !== _printerapiinterface.OctoprintType) {
28
- continue;
29
- }
30
- try {
31
- if (socket.isClosedOrAborted()) {
32
- socket.close();
33
- socket.resetSocketState();
34
- this.logger.warn("Socket was closed or aborted, manually removing it");
35
- continue;
36
- }
37
- } catch (e) {
38
- (0, _node.captureException)(e);
39
- this.logger.error(`Resetting WebSocket socket failed for printer with error '${(0, _errorutils.errorSummary)(e)}'`, e.stack);
40
- continue;
41
- }
42
- if (socket.apiState !== _apistatetype.API_STATE.unset && !socket.lastMessageReceivedTimestamp || socket.lastMessageReceivedTimestamp && Date.now() - socket.lastMessageReceivedTimestamp > 10 * 1000) {
43
- const result = await this.octoprintClient.getConnection(socket.login);
44
- try {
45
- if (result.data?.current?.state !== "Closed") {
46
- this.logger.warn(`Silence was detected, but the OctoPrint current connection was not closed. Connection state ${result.data?.current?.state}`);
47
- }
48
- } catch (e) {
49
- this.logger.error(`Silence was detected, but Websocket was not closed/aborted and API could not be called`);
50
- }
51
- }
52
- }
53
- }
54
- }
1
+ import "../services/printer-api.interface.js";
2
+ import { errorSummary } from "../utils/error.utils.js";
3
+ import { API_STATE } from "../shared/dtos/api-state.type.js";
4
+ import { captureException } from "@sentry/node";
5
+ //#region src/tasks/printer-websocket-restore.task.ts
6
+ var PrinterWebsocketRestoreTask = class PrinterWebsocketRestoreTask {
7
+ logger;
8
+ constructor(loggerFactory, printerSocketStore, octoprintClient) {
9
+ this.printerSocketStore = printerSocketStore;
10
+ this.octoprintClient = octoprintClient;
11
+ this.logger = loggerFactory(PrinterWebsocketRestoreTask.name);
12
+ }
13
+ async run() {
14
+ const existingSockets = this.printerSocketStore.listPrinterSockets();
15
+ for (const socket of existingSockets) {
16
+ if (socket.printerType !== 0) continue;
17
+ try {
18
+ if (socket.isClosedOrAborted()) {
19
+ socket.close();
20
+ socket.resetSocketState();
21
+ this.logger.warn("Socket was closed or aborted, manually removing it");
22
+ continue;
23
+ }
24
+ } catch (e) {
25
+ captureException(e);
26
+ this.logger.error(`Resetting WebSocket socket failed for printer with error '${errorSummary(e)}'`, e.stack);
27
+ continue;
28
+ }
29
+ if (socket.apiState !== API_STATE.unset && !socket.lastMessageReceivedTimestamp || socket.lastMessageReceivedTimestamp && Date.now() - socket.lastMessageReceivedTimestamp > 10 * 1e3) {
30
+ const result = await this.octoprintClient.getConnection(socket.login);
31
+ try {
32
+ if (result.data?.current?.state !== "Closed") this.logger.warn(`Silence was detected, but the OctoPrint current connection was not closed. Connection state ${result.data?.current?.state}`);
33
+ } catch (e) {
34
+ this.logger.error(`Silence was detected, but Websocket was not closed/aborted and API could not be called`);
35
+ }
36
+ }
37
+ }
38
+ }
39
+ };
40
+ //#endregion
41
+ export { PrinterWebsocketRestoreTask };
55
42
 
56
43
  //# sourceMappingURL=printer-websocket-restore.task.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tasks/printer-websocket-restore.task.ts"],"names":["PrinterWebsocketRestoreTask","logger","loggerFactory","printerSocketStore","octoprintClient","name","run","existingSockets","listPrinterSockets","socket","printerType","OctoprintType","isClosedOrAborted","close","resetSocketState","warn","e","captureException","error","errorSummary","stack","apiState","API_STATE","unset","lastMessageReceivedTimestamp","Date","now","result","getConnection","login","data","current","state"],"mappings":";;;;+BASaA;;;eAAAA;;;4BATgB;sBAKI;8BACP;qCACI;AAEvB,MAAMA;;;IACMC,OAAsB;IAEvC,YACEC,aAA6B,EAC7B,AAAiBC,kBAAsC,EACvD,AAAiBC,eAAgC,CACjD;aAFiBD,qBAAAA;aACAC,kBAAAA;QAEjB,IAAI,CAACH,MAAM,GAAGC,cAAcF,4BAA4BK,IAAI;IAC9D;IAEA,MAAMC,MAAM;QACV,MAAMC,kBAAkB,IAAI,CAACJ,kBAAkB,CAACK,kBAAkB;QAClE,KAAK,MAAMC,UAAUF,gBAAiB;YACpC,IAAIE,OAAOC,WAAW,KAAKC,kCAAa,EAAE;gBACxC;YACF;YAEA,IAAI;gBACF,IAAIF,OAAOG,iBAAiB,IAAI;oBAC9BH,OAAOI,KAAK;oBACZJ,OAAOK,gBAAgB;oBACvB,IAAI,CAACb,MAAM,CAACc,IAAI,CAAC;oBACjB;gBACF;YACF,EAAE,OAAOC,GAAQ;gBACfC,IAAAA,sBAAgB,EAACD;gBACjB,IAAI,CAACf,MAAM,CAACiB,KAAK,CAAC,CAAC,0DAA0D,EAAEC,IAAAA,wBAAY,EAACH,GAAG,CAAC,CAAC,EAAEA,EAAEI,KAAK;gBAC1G;YACF;YAGA,IACE,AAACX,OAAOY,QAAQ,KAAKC,uBAAS,CAACC,KAAK,IAAI,CAACd,OAAOe,4BAA4B,IAC3Ef,OAAOe,4BAA4B,IAAIC,KAAKC,GAAG,KAAKjB,OAAOe,4BAA4B,GAAG,KAAK,MAChG;gBACA,MAAMG,SAAS,MAAM,IAAI,CAACvB,eAAe,CAACwB,aAAa,CAACnB,OAAOoB,KAAK;gBAEpE,IAAI;oBACF,IAAIF,OAAOG,IAAI,EAAEC,SAASC,UAAU,UAAU;wBAC5C,IAAI,CAAC/B,MAAM,CAACc,IAAI,CACd,CAAC,4FAA4F,EAAEY,OAAOG,IAAI,EAAEC,SAASC,OAAO;oBAEhI;gBACF,EAAE,OAAOhB,GAAG;oBACV,IAAI,CAACf,MAAM,CAACiB,KAAK,CAAC,CAAC,sFAAsF,CAAC;gBAC5G;YACF;QACF;IACF;AACF"}
1
+ {"version":3,"file":"printer-websocket-restore.task.js","names":[],"sources":["../../src/tasks/printer-websocket-restore.task.ts"],"sourcesContent":["import { errorSummary } from \"@/utils/error.utils\";\nimport { PrinterSocketStore } from \"@/state/printer-socket.store\";\nimport { OctoprintClient } from \"@/services/octoprint/octoprint.client\";\nimport { LoggerService } from \"@/handlers/logger\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\nimport { captureException } from \"@sentry/node\";\nimport { API_STATE } from \"@/shared/dtos/api-state.type\";\nimport { OctoprintType } from \"@/services/printer-api.interface\";\n\nexport class PrinterWebsocketRestoreTask {\n private readonly logger: LoggerService;\n\n constructor(\n loggerFactory: ILoggerFactory,\n private readonly printerSocketStore: PrinterSocketStore,\n private readonly octoprintClient: OctoprintClient,\n ) {\n this.logger = loggerFactory(PrinterWebsocketRestoreTask.name);\n }\n\n async run() {\n const existingSockets = this.printerSocketStore.listPrinterSockets();\n for (const socket of existingSockets) {\n if (socket.printerType !== OctoprintType) {\n continue;\n }\n\n try {\n if (socket.isClosedOrAborted()) {\n socket.close();\n socket.resetSocketState();\n this.logger.warn(\"Socket was closed or aborted, manually removing it\");\n continue;\n }\n } catch (e: any) {\n captureException(e);\n this.logger.error(`Resetting WebSocket socket failed for printer with error '${errorSummary(e)}'`, e.stack);\n continue;\n }\n\n // Often due to USB disconnect, not interesting to reconnect unless we perform an API call for verification\n if (\n (socket.apiState !== API_STATE.unset && !socket.lastMessageReceivedTimestamp) ||\n (socket.lastMessageReceivedTimestamp && Date.now() - socket.lastMessageReceivedTimestamp > 10 * 1000)\n ) {\n const result = await this.octoprintClient.getConnection(socket.login);\n\n try {\n if (result.data?.current?.state !== \"Closed\") {\n this.logger.warn(\n `Silence was detected, but the OctoPrint current connection was not closed. Connection state ${result.data?.current?.state}`,\n );\n }\n } catch (e) {\n this.logger.error(`Silence was detected, but Websocket was not closed/aborted and API could not be called`);\n }\n }\n }\n }\n}\n"],"mappings":";;;;;AASA,IAAa,8BAAb,MAAa,4BAA4B;CACvC;CAEA,YACE,eACA,oBACA,iBACA;AAFiB,OAAA,qBAAA;AACA,OAAA,kBAAA;AAEjB,OAAK,SAAS,cAAc,4BAA4B,KAAK;;CAG/D,MAAM,MAAM;EACV,MAAM,kBAAkB,KAAK,mBAAmB,oBAAoB;AACpE,OAAK,MAAM,UAAU,iBAAiB;AACpC,OAAI,OAAO,gBAAA,EACT;AAGF,OAAI;AACF,QAAI,OAAO,mBAAmB,EAAE;AAC9B,YAAO,OAAO;AACd,YAAO,kBAAkB;AACzB,UAAK,OAAO,KAAK,qDAAqD;AACtE;;YAEK,GAAQ;AACf,qBAAiB,EAAE;AACnB,SAAK,OAAO,MAAM,6DAA6D,aAAa,EAAE,CAAC,IAAI,EAAE,MAAM;AAC3G;;AAIF,OACG,OAAO,aAAa,UAAU,SAAS,CAAC,OAAO,gCAC/C,OAAO,gCAAgC,KAAK,KAAK,GAAG,OAAO,+BAA+B,KAAK,KAChG;IACA,MAAM,SAAS,MAAM,KAAK,gBAAgB,cAAc,OAAO,MAAM;AAErE,QAAI;AACF,SAAI,OAAO,MAAM,SAAS,UAAU,SAClC,MAAK,OAAO,KACV,+FAA+F,OAAO,MAAM,SAAS,QACtH;aAEI,GAAG;AACV,UAAK,OAAO,MAAM,yFAAyF"}
@@ -1,21 +1,13 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "PrinterWebsocketTask", {
6
- enumerable: true,
7
- get: function() {
8
- return PrinterWebsocketTask;
9
- }
10
- });
11
- class PrinterWebsocketTask {
12
- printerSocketStore;
13
- constructor(printerSocketStore){
14
- this.printerSocketStore = printerSocketStore;
15
- }
16
- async run() {
17
- await this.printerSocketStore.reconnectPrinterSockets();
18
- }
19
- }
1
+ //#region src/tasks/printer-websocket.task.ts
2
+ var PrinterWebsocketTask = class {
3
+ constructor(printerSocketStore) {
4
+ this.printerSocketStore = printerSocketStore;
5
+ }
6
+ async run() {
7
+ await this.printerSocketStore.reconnectPrinterSockets();
8
+ }
9
+ };
10
+ //#endregion
11
+ export { PrinterWebsocketTask };
20
12
 
21
13
  //# sourceMappingURL=printer-websocket.task.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tasks/printer-websocket.task.ts"],"names":["PrinterWebsocketTask","printerSocketStore","run","reconnectPrinterSockets"],"mappings":";;;;+BAEaA;;;eAAAA;;;AAAN,MAAMA;;IACX,YAAY,AAAiBC,kBAAsC,CAAE;aAAxCA,qBAAAA;IAAyC;IAEtE,MAAMC,MAAM;QACV,MAAM,IAAI,CAACD,kBAAkB,CAACE,uBAAuB;IACvD;AACF"}
1
+ {"version":3,"file":"printer-websocket.task.js","names":[],"sources":["../../src/tasks/printer-websocket.task.ts"],"sourcesContent":["import { PrinterSocketStore } from \"@/state/printer-socket.store\";\n\nexport class PrinterWebsocketTask {\n constructor(private readonly printerSocketStore: PrinterSocketStore) {}\n\n async run() {\n await this.printerSocketStore.reconnectPrinterSockets();\n }\n}\n"],"mappings":";AAEA,IAAa,uBAAb,MAAkC;CAChC,YAAY,oBAAyD;AAAxC,OAAA,qBAAA;;CAE7B,MAAM,MAAM;AACV,QAAM,KAAK,mBAAmB,yBAAyB"}
@@ -1,55 +1,37 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "SocketIoTask", {
6
- enumerable: true,
7
- get: function() {
8
- return SocketIoTask;
9
- }
10
- });
11
- const _socketiogateway = require("../state/socket-io.gateway");
12
- const _eventconstants = require("../constants/event.constants");
13
- class SocketIoTask {
14
- socketIoGateway;
15
- floorStore;
16
- printerSocketStore;
17
- printerEventsCache;
18
- printerCache;
19
- fileUploadTrackerCache;
20
- eventEmitter2;
21
- logger;
22
- constructor(loggerFactory, socketIoGateway, floorStore, printerSocketStore, printerEventsCache, printerCache, fileUploadTrackerCache, eventEmitter2){
23
- this.socketIoGateway = socketIoGateway;
24
- this.floorStore = floorStore;
25
- this.printerSocketStore = printerSocketStore;
26
- this.printerEventsCache = printerEventsCache;
27
- this.printerCache = printerCache;
28
- this.fileUploadTrackerCache = fileUploadTrackerCache;
29
- this.eventEmitter2 = eventEmitter2;
30
- this.logger = loggerFactory(SocketIoTask.name);
31
- this.eventEmitter2.on(_eventconstants.socketIoConnectedEvent, async ()=>{
32
- await this.sendUpdate();
33
- });
34
- }
35
- async run() {
36
- await this.sendUpdate();
37
- }
38
- async sendUpdate() {
39
- const floors = await this.floorStore.listCache();
40
- const printers = await this.printerCache.listCachedPrinters(true);
41
- const socketStates = this.printerSocketStore.getSocketStatesById();
42
- const printerEvents = await this.printerEventsCache.getAllKeyValues();
43
- const trackedUploads = this.fileUploadTrackerCache.getUploads();
44
- const socketIoData = {
45
- printers,
46
- floors,
47
- socketStates,
48
- printerEvents,
49
- trackedUploads
50
- };
51
- this.socketIoGateway.send(_socketiogateway.IO_MESSAGES.Update, socketIoData);
52
- }
53
- }
1
+ import { socketIoConnectedEvent } from "../constants/event.constants.js";
2
+ import { IO_MESSAGES } from "../state/socket-io.gateway.js";
3
+ //#region src/tasks/socketio.task.ts
4
+ var SocketIoTask = class SocketIoTask {
5
+ logger;
6
+ constructor(loggerFactory, socketIoGateway, floorStore, printerSocketStore, printerEventsCache, printerCache, fileUploadTrackerCache, eventEmitter2) {
7
+ this.socketIoGateway = socketIoGateway;
8
+ this.floorStore = floorStore;
9
+ this.printerSocketStore = printerSocketStore;
10
+ this.printerEventsCache = printerEventsCache;
11
+ this.printerCache = printerCache;
12
+ this.fileUploadTrackerCache = fileUploadTrackerCache;
13
+ this.eventEmitter2 = eventEmitter2;
14
+ this.logger = loggerFactory(SocketIoTask.name);
15
+ this.eventEmitter2.on(socketIoConnectedEvent, async () => {
16
+ await this.sendUpdate();
17
+ });
18
+ }
19
+ async run() {
20
+ await this.sendUpdate();
21
+ }
22
+ async sendUpdate() {
23
+ const floors = await this.floorStore.listCache();
24
+ const socketIoData = {
25
+ printers: await this.printerCache.listCachedPrinters(true),
26
+ floors,
27
+ socketStates: this.printerSocketStore.getSocketStatesById(),
28
+ printerEvents: await this.printerEventsCache.getAllKeyValues(),
29
+ trackedUploads: this.fileUploadTrackerCache.getUploads()
30
+ };
31
+ this.socketIoGateway.send(IO_MESSAGES.Update, socketIoData);
32
+ }
33
+ };
34
+ //#endregion
35
+ export { SocketIoTask };
54
36
 
55
37
  //# sourceMappingURL=socketio.task.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tasks/socketio.task.ts"],"names":["SocketIoTask","logger","loggerFactory","socketIoGateway","floorStore","printerSocketStore","printerEventsCache","printerCache","fileUploadTrackerCache","eventEmitter2","name","on","socketIoConnectedEvent","sendUpdate","run","floors","listCache","printers","listCachedPrinters","socketStates","getSocketStatesById","printerEvents","getAllKeyValues","trackedUploads","getUploads","socketIoData","send","IO_MESSAGES","Update"],"mappings":";;;;+BAWaA;;;eAAAA;;;iCAXgC;gCACN;AAUhC,MAAMA;;;;;;;;IACXC,OAAsB;IAEtB,YACEC,aAA6B,EAC7B,AAAiBC,eAAgC,EACjD,AAAiBC,UAAsB,EACvC,AAAiBC,kBAAsC,EACvD,AAAiBC,kBAAsC,EACvD,AAAiBC,YAA0B,EAC3C,AAAiBC,sBAA8C,EAC/D,AAAiBC,aAA4B,CAC7C;aAPiBN,kBAAAA;aACAC,aAAAA;aACAC,qBAAAA;aACAC,qBAAAA;aACAC,eAAAA;aACAC,yBAAAA;aACAC,gBAAAA;QAEjB,IAAI,CAACR,MAAM,GAAGC,cAAcF,aAAaU,IAAI;QAE7C,IAAI,CAACD,aAAa,CAACE,EAAE,CAACC,sCAAsB,EAAE;YAC5C,MAAM,IAAI,CAACC,UAAU;QACvB;IACF;IAEA,MAAMC,MAAM;QACV,MAAM,IAAI,CAACD,UAAU;IACvB;IAEA,MAAMA,aAAa;QACjB,MAAME,SAAS,MAAM,IAAI,CAACX,UAAU,CAACY,SAAS;QAC9C,MAAMC,WAAW,MAAM,IAAI,CAACV,YAAY,CAACW,kBAAkB,CAAC;QAC5D,MAAMC,eAAe,IAAI,CAACd,kBAAkB,CAACe,mBAAmB;QAChE,MAAMC,gBAAgB,MAAM,IAAI,CAACf,kBAAkB,CAACgB,eAAe;QACnE,MAAMC,iBAAiB,IAAI,CAACf,sBAAsB,CAACgB,UAAU;QAE7D,MAAMC,eAAe;YACnBR;YACAF;YACAI;YACAE;YACAE;QACF;QAEA,IAAI,CAACpB,eAAe,CAACuB,IAAI,CAACC,4BAAW,CAACC,MAAM,EAAEH;IAChD;AACF"}
1
+ {"version":3,"file":"socketio.task.js","names":[],"sources":["../../src/tasks/socketio.task.ts"],"sourcesContent":["import { SocketIoGateway, IO_MESSAGES } from \"@/state/socket-io.gateway\";\nimport { socketIoConnectedEvent } from \"@/constants/event.constants\";\nimport { PrinterSocketStore } from \"@/state/printer-socket.store\";\nimport { PrinterEventsCache } from \"@/state/printer-events.cache\";\nimport { FloorStore } from \"@/state/floor.store\";\nimport { FileUploadTrackerCache } from \"@/state/file-upload-tracker.cache\";\nimport EventEmitter2 from \"eventemitter2\";\nimport { PrinterCache } from \"@/state/printer.cache\";\nimport { LoggerService } from \"@/handlers/logger\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\n\nexport class SocketIoTask {\n logger: LoggerService;\n\n constructor(\n loggerFactory: ILoggerFactory,\n private readonly socketIoGateway: SocketIoGateway,\n private readonly floorStore: FloorStore,\n private readonly printerSocketStore: PrinterSocketStore,\n private readonly printerEventsCache: PrinterEventsCache,\n private readonly printerCache: PrinterCache,\n private readonly fileUploadTrackerCache: FileUploadTrackerCache,\n private readonly eventEmitter2: EventEmitter2,\n ) {\n this.logger = loggerFactory(SocketIoTask.name);\n\n this.eventEmitter2.on(socketIoConnectedEvent, async () => {\n await this.sendUpdate();\n });\n }\n\n async run() {\n await this.sendUpdate();\n }\n\n async sendUpdate() {\n const floors = await this.floorStore.listCache();\n const printers = await this.printerCache.listCachedPrinters(true);\n const socketStates = this.printerSocketStore.getSocketStatesById();\n const printerEvents = await this.printerEventsCache.getAllKeyValues();\n const trackedUploads = this.fileUploadTrackerCache.getUploads();\n\n const socketIoData = {\n printers,\n floors,\n socketStates,\n printerEvents,\n trackedUploads,\n };\n\n this.socketIoGateway.send(IO_MESSAGES.Update, socketIoData);\n }\n}\n"],"mappings":";;;AAWA,IAAa,eAAb,MAAa,aAAa;CACxB;CAEA,YACE,eACA,iBACA,YACA,oBACA,oBACA,cACA,wBACA,eACA;AAPiB,OAAA,kBAAA;AACA,OAAA,aAAA;AACA,OAAA,qBAAA;AACA,OAAA,qBAAA;AACA,OAAA,eAAA;AACA,OAAA,yBAAA;AACA,OAAA,gBAAA;AAEjB,OAAK,SAAS,cAAc,aAAa,KAAK;AAE9C,OAAK,cAAc,GAAG,wBAAwB,YAAY;AACxD,SAAM,KAAK,YAAY;IACvB;;CAGJ,MAAM,MAAM;AACV,QAAM,KAAK,YAAY;;CAGzB,MAAM,aAAa;EACjB,MAAM,SAAS,MAAM,KAAK,WAAW,WAAW;EAMhD,MAAM,eAAe;GACnB,UAAA,MANqB,KAAK,aAAa,mBAAmB,KAAK;GAO/D;GACA,cAPmB,KAAK,mBAAmB,qBAO/B;GACZ,eAAA,MAP0B,KAAK,mBAAmB,iBAAiB;GAQnE,gBAPqB,KAAK,uBAAuB,YAOnC;GACf;AAED,OAAK,gBAAgB,KAAK,YAAY,QAAQ,aAAa"}
@@ -1,22 +1,14 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "SoftwareUpdateTask", {
6
- enumerable: true,
7
- get: function() {
8
- return SoftwareUpdateTask;
9
- }
10
- });
11
- class SoftwareUpdateTask {
12
- serverReleaseService;
13
- constructor(serverReleaseService){
14
- this.serverReleaseService = serverReleaseService;
15
- }
16
- async run() {
17
- await this.serverReleaseService.syncLatestRelease();
18
- this.serverReleaseService.logServerVersionState();
19
- }
20
- }
1
+ //#region src/tasks/software-update.task.ts
2
+ var SoftwareUpdateTask = class {
3
+ constructor(serverReleaseService) {
4
+ this.serverReleaseService = serverReleaseService;
5
+ }
6
+ async run() {
7
+ await this.serverReleaseService.syncLatestRelease();
8
+ this.serverReleaseService.logServerVersionState();
9
+ }
10
+ };
11
+ //#endregion
12
+ export { SoftwareUpdateTask };
21
13
 
22
14
  //# sourceMappingURL=software-update.task.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/tasks/software-update.task.ts"],"names":["SoftwareUpdateTask","serverReleaseService","run","syncLatestRelease","logServerVersionState"],"mappings":";;;;+BAEaA;;;eAAAA;;;AAAN,MAAMA;;IACX,YAAY,AAAiBC,oBAA0C,CAAE;aAA5CA,uBAAAA;IAA6C;IAE1E,MAAMC,MAAM;QACV,MAAM,IAAI,CAACD,oBAAoB,CAACE,iBAAiB;QACjD,IAAI,CAACF,oBAAoB,CAACG,qBAAqB;IACjD;AACF"}
1
+ {"version":3,"file":"software-update.task.js","names":[],"sources":["../../src/tasks/software-update.task.ts"],"sourcesContent":["import { ServerReleaseService } from \"@/services/core/server-release.service\";\n\nexport class SoftwareUpdateTask {\n constructor(private readonly serverReleaseService: ServerReleaseService) {}\n\n async run() {\n await this.serverReleaseService.syncLatestRelease();\n this.serverReleaseService.logServerVersionState();\n }\n}\n"],"mappings":";AAEA,IAAa,qBAAb,MAAgC;CAC9B,YAAY,sBAA6D;AAA5C,OAAA,uBAAA;;CAE7B,MAAM,MAAM;AACV,QAAM,KAAK,qBAAqB,mBAAmB;AACnD,OAAK,qBAAqB,uBAAuB"}
package/dist/tasks.js CHANGED
@@ -1,45 +1,31 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- function _export(target, all) {
6
- for(var name in all)Object.defineProperty(target, name, {
7
- enumerable: true,
8
- get: Object.getOwnPropertyDescriptor(all, name).get
9
- });
10
- }
11
- _export(exports, {
12
- get ServerTasks () {
13
- return ServerTasks;
14
- },
15
- get registerTask () {
16
- return registerTask;
17
- }
18
- });
19
- const _taskpresets = require("./task.presets");
20
- const _containertokens = require("./container.tokens");
1
+ import { DITokens } from "./container.tokens.js";
2
+ import { TASK_PRESETS } from "./task.presets.js";
3
+ //#region src/tasks.ts
4
+ /**
5
+ * Register a task with a preset and timing (run immediate does not retry in case of failure)
6
+ */
21
7
  function registerTask(task, preset, milliseconds = 0, runImmediately = false) {
22
- let timingPreset = {
23
- ...preset
24
- };
25
- timingPreset.milliseconds = preset.milliseconds ?? milliseconds;
26
- timingPreset.runImmediately = runImmediately ?? false;
27
- return {
28
- id: task.name ?? task,
29
- task,
30
- preset: timingPreset
31
- };
32
- }
33
- class ServerTasks {
34
- static SERVER_BOOT_TASK = registerTask(_containertokens.DITokens.bootTask, _taskpresets.TASK_PRESETS.PERIODIC_DISABLED, 5000, false);
35
- static BOOT_TASKS = [
36
- registerTask(_containertokens.DITokens.softwareUpdateTask, _taskpresets.TASK_PRESETS.RUNDELAYED, 1500),
37
- registerTask(_containertokens.DITokens.clientDistDownloadTask, _taskpresets.TASK_PRESETS.RUNONCE),
38
- registerTask(_containertokens.DITokens.socketIoTask, _taskpresets.TASK_PRESETS.PERIODIC, 500),
39
- registerTask(_containertokens.DITokens.printerWebsocketTask, _taskpresets.TASK_PRESETS.PERIODIC, 2000, true),
40
- registerTask(_containertokens.DITokens.printerWebsocketRestoreTask, _taskpresets.TASK_PRESETS.PERIODIC, 15 * 1000, false),
41
- registerTask(_containertokens.DITokens.printJobAnalysisTask, _taskpresets.TASK_PRESETS.PERIODIC, 30 * 1000, false)
42
- ];
8
+ let timingPreset = { ...preset };
9
+ timingPreset.milliseconds = preset.milliseconds ?? milliseconds;
10
+ timingPreset.runImmediately = runImmediately ?? false;
11
+ return {
12
+ id: task.name ?? task,
13
+ task,
14
+ preset: timingPreset
15
+ };
43
16
  }
17
+ var ServerTasks = class {
18
+ static SERVER_BOOT_TASK = registerTask(DITokens.bootTask, TASK_PRESETS.PERIODIC_DISABLED, 5e3, false);
19
+ static BOOT_TASKS = [
20
+ registerTask(DITokens.softwareUpdateTask, TASK_PRESETS.RUNDELAYED, 1500),
21
+ registerTask(DITokens.clientDistDownloadTask, TASK_PRESETS.RUNONCE),
22
+ registerTask(DITokens.socketIoTask, TASK_PRESETS.PERIODIC, 500),
23
+ registerTask(DITokens.printerWebsocketTask, TASK_PRESETS.PERIODIC, 2e3, true),
24
+ registerTask(DITokens.printerWebsocketRestoreTask, TASK_PRESETS.PERIODIC, 15 * 1e3, false),
25
+ registerTask(DITokens.printJobAnalysisTask, TASK_PRESETS.PERIODIC, 30 * 1e3, false)
26
+ ];
27
+ };
28
+ //#endregion
29
+ export { ServerTasks, registerTask };
44
30
 
45
31
  //# sourceMappingURL=tasks.js.map
package/dist/tasks.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/tasks.ts"],"names":["ServerTasks","registerTask","task","preset","milliseconds","runImmediately","timingPreset","id","name","SERVER_BOOT_TASK","DITokens","bootTask","TaskPresets","PERIODIC_DISABLED","BOOT_TASKS","softwareUpdateTask","RUNDELAYED","clientDistDownloadTask","RUNONCE","socketIoTask","PERIODIC","printerWebsocketTask","printerWebsocketRestoreTask","printJobAnalysisTask"],"mappings":";;;;;;;;;;;QAkBaA;eAAAA;;QAXGC;eAAAA;;;6BAP4B;iCACnB;AAMlB,SAASA,aAAaC,IAAS,EAAEC,MAAoB,EAAEC,eAAe,CAAC,EAAEC,iBAAiB,KAAK;IACpG,IAAIC,eAAe;QAAE,GAAGH,MAAM;IAAC;IAC/BG,aAAaF,YAAY,GAAGD,OAAOC,YAAY,IAAIA;IACnDE,aAAaD,cAAc,GAAGA,kBAAkB;IAChD,OAAO;QACLE,IAAIL,KAAKM,IAAI,IAAIN;QACjBA;QACAC,QAAQG;IACV;AACF;AAEO,MAAMN;IACX,OAAuBS,mBAAmBR,aAAaS,yBAAQ,CAACC,QAAQ,EAAEC,yBAAW,CAACC,iBAAiB,EAAE,MAAM,OAAO;IACtH,OAAuBC,aAAa;QAClCb,aAAaS,yBAAQ,CAACK,kBAAkB,EAAEH,yBAAW,CAACI,UAAU,EAAE;QAClEf,aAAaS,yBAAQ,CAACO,sBAAsB,EAAEL,yBAAW,CAACM,OAAO;QACjEjB,aAAaS,yBAAQ,CAACS,YAAY,EAAEP,yBAAW,CAACQ,QAAQ,EAAE;QAE1DnB,aAAaS,yBAAQ,CAACW,oBAAoB,EAAET,yBAAW,CAACQ,QAAQ,EAAE,MAAM;QAExEnB,aAAaS,yBAAQ,CAACY,2BAA2B,EAAEV,yBAAW,CAACQ,QAAQ,EAAE,KAAK,MAAM;QAEpFnB,aAAaS,yBAAQ,CAACa,oBAAoB,EAAEX,yBAAW,CAACQ,QAAQ,EAAE,KAAK,MAAM;KAC9E,CAAC;AACJ"}
1
+ {"version":3,"file":"tasks.js","names":["TaskPresets"],"sources":["../src/tasks.ts"],"sourcesContent":["import { TASK_PRESETS as TaskPresets } from \"./task.presets\";\nimport { DITokens } from \"./container.tokens\";\nimport { TimingPreset } from \"@/services/interfaces/task.interfaces\";\n\n/**\n * Register a task with a preset and timing (run immediate does not retry in case of failure)\n */\nexport function registerTask(task: any, preset: TimingPreset, milliseconds = 0, runImmediately = false) {\n let timingPreset = { ...preset };\n timingPreset.milliseconds = preset.milliseconds ?? milliseconds;\n timingPreset.runImmediately = runImmediately ?? false;\n return {\n id: task.name ?? task,\n task,\n preset: timingPreset,\n };\n}\n\nexport class ServerTasks {\n public static readonly SERVER_BOOT_TASK = registerTask(DITokens.bootTask, TaskPresets.PERIODIC_DISABLED, 5000, false);\n public static readonly BOOT_TASKS = [\n registerTask(DITokens.softwareUpdateTask, TaskPresets.RUNDELAYED, 1500),\n registerTask(DITokens.clientDistDownloadTask, TaskPresets.RUNONCE),\n registerTask(DITokens.socketIoTask, TaskPresets.PERIODIC, 500),\n // Every 2 seconds\n registerTask(DITokens.printerWebsocketTask, TaskPresets.PERIODIC, 2000, true),\n // Every 15 seconds\n registerTask(DITokens.printerWebsocketRestoreTask, TaskPresets.PERIODIC, 15 * 1000, false),\n // Analyze pending print jobs every 30 seconds\n registerTask(DITokens.printJobAnalysisTask, TaskPresets.PERIODIC, 30 * 1000, false),\n ];\n}\n"],"mappings":";;;;;;AAOA,SAAgB,aAAa,MAAW,QAAsB,eAAe,GAAG,iBAAiB,OAAO;CACtG,IAAI,eAAe,EAAE,GAAG,QAAQ;AAChC,cAAa,eAAe,OAAO,gBAAgB;AACnD,cAAa,iBAAiB,kBAAkB;AAChD,QAAO;EACL,IAAI,KAAK,QAAQ;EACjB;EACA,QAAQ;EACT;;AAGH,IAAa,cAAb,MAAyB;CACvB,OAAuB,mBAAmB,aAAa,SAAS,UAAUA,aAAY,mBAAmB,KAAM,MAAM;CACrH,OAAuB,aAAa;EAClC,aAAa,SAAS,oBAAoBA,aAAY,YAAY,KAAK;EACvE,aAAa,SAAS,wBAAwBA,aAAY,QAAQ;EAClE,aAAa,SAAS,cAAcA,aAAY,UAAU,IAAI;EAE9D,aAAa,SAAS,sBAAsBA,aAAY,UAAU,KAAM,KAAK;EAE7E,aAAa,SAAS,6BAA6BA,aAAY,UAAU,KAAK,KAAM,MAAM;EAE1F,aAAa,SAAS,sBAAsBA,aAAY,UAAU,KAAK,KAAM,MAAM;EACpF"}
@@ -1,6 +1 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
-
6
- //# sourceMappingURL=index.d.js.map
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -1,27 +1,12 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- function _export(target, all) {
6
- for(var name in all)Object.defineProperty(target, name, {
7
- enumerable: true,
8
- get: Object.getOwnPropertyDescriptor(all, name).get
9
- });
10
- }
11
- _export(exports, {
12
- get distinct () {
13
- return distinct;
14
- },
15
- get groupArrayBy () {
16
- return groupArrayBy;
17
- }
18
- });
19
- const groupArrayBy = (array, predicate)=>array.reduce((acc, value, index, array)=>{
20
- (acc[predicate(value, index, array)] ||= []).push(value);
21
- return acc;
22
- }, {});
23
- const distinct = (value, index, self)=>{
24
- return self.indexOf(value) === index;
1
+ //#region src/utils/array.util.ts
2
+ const groupArrayBy = (array, predicate) => array.reduce((acc, value, index, array) => {
3
+ (acc[predicate(value, index, array)] ||= []).push(value);
4
+ return acc;
5
+ }, {});
6
+ const distinct = (value, index, self) => {
7
+ return self.indexOf(value) === index;
25
8
  };
9
+ //#endregion
10
+ export { distinct, groupArrayBy };
26
11
 
27
12
  //# sourceMappingURL=array.util.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utils/array.util.ts"],"names":["distinct","groupArrayBy","array","predicate","reduce","acc","value","index","push","self","indexOf"],"mappings":";;;;;;;;;;;QASaA;eAAAA;;QATAC;eAAAA;;;AAAN,MAAMA,eAAe,CAAIC,OAAYC,YAC1CD,MAAME,MAAM,CACV,CAACC,KAAKC,OAAOC,OAAOL;QACjBG,CAAAA,GAAG,CAACF,UAAUG,OAAOC,OAAOL,OAAO,KAAK,EAAE,AAAD,EAAGM,IAAI,CAACF;QAClD,OAAOD;IACT,GACA,CAAC;AAGE,MAAML,WAAW,CAACM,OAAYC,OAAeE;IAClD,OAAOA,KAAKC,OAAO,CAACJ,WAAWC;AACjC"}
1
+ {"version":3,"file":"array.util.js","names":[],"sources":["../../src/utils/array.util.ts"],"sourcesContent":["export const groupArrayBy = <T>(array: T[], predicate: (value: T, index: number, array: T[]) => string) =>\n array.reduce(\n (acc, value, index, array) => {\n (acc[predicate(value, index, array)] ||= []).push(value);\n return acc;\n },\n {} as { [key: string]: T[] },\n );\n\nexport const distinct = (value: any, index: number, self: any) => {\n return self.indexOf(value) === index;\n};\n"],"mappings":";AAAA,MAAa,gBAAmB,OAAY,cAC1C,MAAM,QACH,KAAK,OAAO,OAAO,UAAU;AAC5B,EAAC,IAAI,UAAU,OAAO,OAAO,MAAM,MAAM,EAAE,EAAE,KAAK,MAAM;AACxD,QAAO;GAET,EAAE,CACH;AAEH,MAAa,YAAY,OAAY,OAAe,SAAc;AAChE,QAAO,KAAK,QAAQ,MAAM,KAAK"}
@@ -1,50 +1,32 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- function _export(target, all) {
6
- for(var name in all)Object.defineProperty(target, name, {
7
- enumerable: true,
8
- get: Object.getOwnPropertyDescriptor(all, name).get
9
- });
10
- }
11
- _export(exports, {
12
- get convertQoiToPng () {
13
- return convertQoiToPng;
14
- },
15
- get processThumbnail () {
16
- return processThumbnail;
17
- }
18
- });
19
- const _bgcodetypes = require("./bgcode.types");
20
- const _qoidecoder = require("./qoi-decoder");
21
- const _pngencoder = require("./png-encoder");
1
+ import { BgCodeThumbnailFormatExtension, BgCodeThumbnailFormats } from "./bgcode.types.js";
2
+ import { decodeQOI } from "./qoi-decoder.js";
3
+ import { encodePNG } from "./png-encoder.js";
4
+ //#region src/utils/bgcode/bgcode-thumbnail.parser.ts
22
5
  function convertQoiToPng(qoiBuffer) {
23
- const decoded = (0, _qoidecoder.decodeQOI)(qoiBuffer);
24
- return (0, _pngencoder.encodePNG)(decoded.width, decoded.height, decoded.data);
6
+ const decoded = decodeQOI(qoiBuffer);
7
+ return encodePNG(decoded.width, decoded.height, decoded.data);
25
8
  }
26
9
  function processThumbnail(data, parameters) {
27
- switch(parameters.format){
28
- case _bgcodetypes.BgCodeThumbnailFormats.PNG:
29
- return {
30
- extension: _bgcodetypes.BgCodeThumbnailFormatExtension[_bgcodetypes.BgCodeThumbnailFormats.PNG],
31
- data: data
32
- };
33
- case _bgcodetypes.BgCodeThumbnailFormats.JPG:
34
- return {
35
- extension: _bgcodetypes.BgCodeThumbnailFormatExtension[_bgcodetypes.BgCodeThumbnailFormats.JPG],
36
- data: data
37
- };
38
- case _bgcodetypes.BgCodeThumbnailFormats.QOI:
39
- const pngData = convertQoiToPng(data);
40
- return {
41
- extension: _bgcodetypes.BgCodeThumbnailFormatExtension[_bgcodetypes.BgCodeThumbnailFormats.PNG],
42
- data: pngData,
43
- converted: true
44
- };
45
- default:
46
- throw new Error(`Unsupported thumbnail format: ${parameters.format}`);
47
- }
10
+ switch (parameters.format) {
11
+ case BgCodeThumbnailFormats.PNG: return {
12
+ extension: BgCodeThumbnailFormatExtension[BgCodeThumbnailFormats.PNG],
13
+ data
14
+ };
15
+ case BgCodeThumbnailFormats.JPG: return {
16
+ extension: BgCodeThumbnailFormatExtension[BgCodeThumbnailFormats.JPG],
17
+ data
18
+ };
19
+ case BgCodeThumbnailFormats.QOI:
20
+ const pngData = convertQoiToPng(data);
21
+ return {
22
+ extension: BgCodeThumbnailFormatExtension[BgCodeThumbnailFormats.PNG],
23
+ data: pngData,
24
+ converted: true
25
+ };
26
+ default: throw new Error(`Unsupported thumbnail format: ${parameters.format}`);
27
+ }
48
28
  }
29
+ //#endregion
30
+ export { convertQoiToPng, processThumbnail };
49
31
 
50
32
  //# sourceMappingURL=bgcode-thumbnail.parser.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/utils/bgcode/bgcode-thumbnail.parser.ts"],"names":["convertQoiToPng","processThumbnail","qoiBuffer","decoded","decodeQOI","encodePNG","width","height","data","parameters","format","BgCodeThumbnailFormats","PNG","extension","BgCodeThumbnailFormatExtension","JPG","QOI","pngData","converted","Error"],"mappings":";;;;;;;;;;;QAcgBA;eAAAA;;QAKAC;eAAAA;;;6BAfT;4BACmB;4BACA;AAQnB,SAASD,gBAAgBE,SAAiB;IAC/C,MAAMC,UAAUC,IAAAA,qBAAS,EAACF;IAC1B,OAAOG,IAAAA,qBAAS,EAACF,QAAQG,KAAK,EAAEH,QAAQI,MAAM,EAAEJ,QAAQK,IAAI;AAC9D;AAEO,SAASP,iBAAiBO,IAAY,EAAEC,UAAqC;IAClF,OAAQA,WAAWC,MAAM;QACvB,KAAKC,mCAAsB,CAACC,GAAG;YAC7B,OAAO;gBACLC,WAAWC,2CAA8B,CAACH,mCAAsB,CAACC,GAAG,CAAC;gBACrEJ,MAAMA;YACR;QAEF,KAAKG,mCAAsB,CAACI,GAAG;YAC7B,OAAO;gBACLF,WAAWC,2CAA8B,CAACH,mCAAsB,CAACI,GAAG,CAAC;gBACrEP,MAAMA;YACR;QAEF,KAAKG,mCAAsB,CAACK,GAAG;YAC7B,MAAMC,UAAUjB,gBAAgBQ;YAChC,OAAO;gBACLK,WAAWC,2CAA8B,CAACH,mCAAsB,CAACC,GAAG,CAAC;gBACrEJ,MAAMS;gBACNC,WAAW;YACb;QAEF;YACE,MAAM,IAAIC,MAAM,CAAC,8BAA8B,EAAEV,WAAWC,MAAM,EAAE;IACxE;AACF"}
1
+ {"version":3,"file":"bgcode-thumbnail.parser.js","names":[],"sources":["../../../src/utils/bgcode/bgcode-thumbnail.parser.ts"],"sourcesContent":["import { BgCodeThumbnailFormats, BgCodeThumbnailParameters, BgCodeThumbnailFormatExtension } from \"./bgcode.types\";\nimport { decodeQOI } from \"./qoi-decoder\";\nimport { encodePNG } from \"./png-encoder\";\n\nexport interface ThumbnailProcessResult {\n extension: string;\n data: Buffer;\n converted?: boolean;\n}\n\nexport function convertQoiToPng(qoiBuffer: Buffer): Buffer {\n const decoded = decodeQOI(qoiBuffer);\n return encodePNG(decoded.width, decoded.height, decoded.data);\n}\n\nexport function processThumbnail(data: Buffer, parameters: BgCodeThumbnailParameters): ThumbnailProcessResult {\n switch (parameters.format) {\n case BgCodeThumbnailFormats.PNG:\n return {\n extension: BgCodeThumbnailFormatExtension[BgCodeThumbnailFormats.PNG],\n data: data,\n };\n\n case BgCodeThumbnailFormats.JPG:\n return {\n extension: BgCodeThumbnailFormatExtension[BgCodeThumbnailFormats.JPG],\n data: data,\n };\n\n case BgCodeThumbnailFormats.QOI:\n const pngData = convertQoiToPng(data);\n return {\n extension: BgCodeThumbnailFormatExtension[BgCodeThumbnailFormats.PNG],\n data: pngData,\n converted: true,\n };\n\n default:\n throw new Error(`Unsupported thumbnail format: ${parameters.format}`);\n }\n}\n"],"mappings":";;;;AAUA,SAAgB,gBAAgB,WAA2B;CACzD,MAAM,UAAU,UAAU,UAAU;AACpC,QAAO,UAAU,QAAQ,OAAO,QAAQ,QAAQ,QAAQ,KAAK;;AAG/D,SAAgB,iBAAiB,MAAc,YAA+D;AAC5G,SAAQ,WAAW,QAAnB;EACE,KAAK,uBAAuB,IAC1B,QAAO;GACL,WAAW,+BAA+B,uBAAuB;GAC3D;GACP;EAEH,KAAK,uBAAuB,IAC1B,QAAO;GACL,WAAW,+BAA+B,uBAAuB;GAC3D;GACP;EAEH,KAAK,uBAAuB;GAC1B,MAAM,UAAU,gBAAgB,KAAK;AACrC,UAAO;IACL,WAAW,+BAA+B,uBAAuB;IACjE,MAAM;IACN,WAAW;IACZ;EAEH,QACE,OAAM,IAAI,MAAM,iCAAiC,WAAW,SAAS"}