@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.
- package/.claude/CLAUDE.md +76 -0
- package/.vite-hooks/pre-commit +1 -0
- package/.yarn/install-state.gz +0 -0
- package/.yarn/releases/yarn-4.13.0.cjs +940 -0
- package/.yarnrc.yml +1 -1
- package/README.md +1 -1
- package/RELEASE_NOTES.MD +14 -0
- package/dist/_virtual/_@oxc-project_runtime@0.127.0/helpers/decorate.js +9 -0
- package/dist/_virtual/_@oxc-project_runtime@0.127.0/helpers/decorateMetadata.js +6 -0
- package/dist/_virtual/_rolldown/runtime.js +13 -0
- package/dist/_virtual/_virtual_controllers.js +43 -0
- package/dist/consoles/typeorm-create.js +51 -112
- package/dist/consoles/typeorm-create.js.map +1 -1
- package/dist/consoles/typeorm-generate.js +99 -165
- package/dist/consoles/typeorm-generate.js.map +1 -1
- package/dist/consoles/typeorm-migrate.js +35 -43
- package/dist/consoles/typeorm-migrate.js.map +1 -1
- package/dist/constants/authorization.constants.js +75 -97
- package/dist/constants/authorization.constants.js.map +1 -1
- package/dist/constants/event.constants.js +11 -41
- package/dist/constants/event.constants.js.map +1 -1
- package/dist/constants/http-status-codes.constants.js +319 -71
- package/dist/constants/http-status-codes.constants.js.map +1 -1
- package/dist/constants/server-settings.constants.js +45 -87
- package/dist/constants/server-settings.constants.js.map +1 -1
- package/dist/constants/service.constants.js +3 -21
- package/dist/constants/service.constants.js.map +1 -1
- package/dist/container.js +167 -181
- package/dist/container.js.map +1 -1
- package/dist/container.tokens.js +78 -85
- package/dist/container.tokens.js.map +1 -1
- package/dist/controllers/auth.controller.js +156 -225
- package/dist/controllers/auth.controller.js.map +1 -1
- package/dist/controllers/batch-call.controller.js +79 -116
- package/dist/controllers/batch-call.controller.js.map +1 -1
- package/dist/controllers/camera-stream.controller.js +74 -119
- package/dist/controllers/camera-stream.controller.js.map +1 -1
- package/dist/controllers/dto/update-client-dist.dto.js +8 -15
- package/dist/controllers/dto/update-client-dist.dto.js.map +1 -1
- package/dist/controllers/file-storage.controller.js +251 -312
- package/dist/controllers/file-storage.controller.js.map +1 -1
- package/dist/controllers/first-time-setup.controller.js +83 -135
- package/dist/controllers/first-time-setup.controller.js.map +1 -1
- package/dist/controllers/floor.controller.js +111 -175
- package/dist/controllers/floor.controller.js.map +1 -1
- package/dist/controllers/metrics.controller.js +27 -53
- package/dist/controllers/metrics.controller.js.map +1 -1
- package/dist/controllers/print-job.controller.js +366 -451
- package/dist/controllers/print-job.controller.js.map +1 -1
- package/dist/controllers/print-queue.controller.js +329 -427
- package/dist/controllers/print-queue.controller.js.map +1 -1
- package/dist/controllers/printer-files.controller.js +244 -305
- package/dist/controllers/printer-files.controller.js.map +1 -1
- package/dist/controllers/printer-maintenance-log.controller.js +109 -165
- package/dist/controllers/printer-maintenance-log.controller.js.map +1 -1
- package/dist/controllers/printer-settings.controller.js +50 -81
- package/dist/controllers/printer-settings.controller.js.map +1 -1
- package/dist/controllers/printer-tag.controller.js +104 -166
- package/dist/controllers/printer-tag.controller.js.map +1 -1
- package/dist/controllers/printer.controller.js +352 -469
- package/dist/controllers/printer.controller.js.map +1 -1
- package/dist/controllers/server-private.controller.js +182 -239
- package/dist/controllers/server-private.controller.js.map +1 -1
- package/dist/controllers/server-public.controller.js +104 -158
- package/dist/controllers/server-public.controller.js.map +1 -1
- package/dist/controllers/settings.controller.js +229 -364
- package/dist/controllers/settings.controller.js.map +1 -1
- package/dist/controllers/slicer-compat.controller.js +179 -206
- package/dist/controllers/slicer-compat.controller.js.map +1 -1
- package/dist/controllers/user.controller.js +226 -348
- package/dist/controllers/user.controller.js.map +1 -1
- package/dist/controllers/validation/auth-controller.validation.js +5 -14
- package/dist/controllers/validation/auth-controller.validation.js.map +1 -1
- package/dist/controllers/validation/batch-controller.validation.js +13 -35
- package/dist/controllers/validation/batch-controller.validation.js.map +1 -1
- package/dist/controllers/validation/generic.validation.js +6 -23
- package/dist/controllers/validation/generic.validation.js.map +1 -1
- package/dist/controllers/validation/printer-completion-controller.validation.js +5 -14
- package/dist/controllers/validation/printer-completion-controller.validation.js.map +1 -1
- package/dist/controllers/validation/printer-controller.validation.js +16 -48
- package/dist/controllers/validation/printer-controller.validation.js.map +1 -1
- package/dist/controllers/validation/printer-files-controller.validation.js +12 -47
- package/dist/controllers/validation/printer-files-controller.validation.js.map +1 -1
- package/dist/controllers/validation/printer-settings-controller.validation.js +5 -14
- package/dist/controllers/validation/printer-settings-controller.validation.js.map +1 -1
- package/dist/controllers/validation/server-private.validation.js +7 -14
- package/dist/controllers/validation/server-private.validation.js.map +1 -1
- package/dist/controllers/validation/setting.validation.js +12 -34
- package/dist/controllers/validation/setting.validation.js.map +1 -1
- package/dist/controllers/validation/user-controller.validation.js +27 -65
- package/dist/controllers/validation/user-controller.validation.js.map +1 -1
- package/dist/data-source.js +74 -79
- package/dist/data-source.js.map +1 -1
- package/dist/entities/camera-stream.entity.js +49 -91
- package/dist/entities/camera-stream.entity.js.map +1 -1
- package/dist/entities/floor-position.entity.js +38 -75
- package/dist/entities/floor-position.entity.js.map +1 -1
- package/dist/entities/floor.entity.js +18 -48
- package/dist/entities/floor.entity.js.map +1 -1
- package/dist/entities/index.js +14 -66
- package/dist/entities/print-job.entity.js +114 -196
- package/dist/entities/print-job.entity.js.map +1 -1
- package/dist/entities/printer-maintenance-log.entity.js +61 -140
- package/dist/entities/printer-maintenance-log.entity.js.map +1 -1
- package/dist/entities/printer-tag.entity.js +33 -66
- package/dist/entities/printer-tag.entity.js.map +1 -1
- package/dist/entities/printer.entity.js +67 -124
- package/dist/entities/printer.entity.js.map +1 -1
- package/dist/entities/refresh-token.entity.js +31 -66
- package/dist/entities/refresh-token.entity.js.map +1 -1
- package/dist/entities/role.entity.js +16 -45
- package/dist/entities/role.entity.js.map +1 -1
- package/dist/entities/settings.entity.js +38 -77
- package/dist/entities/settings.entity.js.map +1 -1
- package/dist/entities/tag.entity.js +19 -43
- package/dist/entities/tag.entity.js.map +1 -1
- package/dist/entities/user-role.entity.js +30 -67
- package/dist/entities/user-role.entity.js.map +1 -1
- package/dist/entities/user.entity.js +32 -87
- package/dist/entities/user.entity.js.map +1 -1
- package/dist/exceptions/failed-dependency.exception.js +11 -18
- package/dist/exceptions/failed-dependency.exception.js.map +1 -1
- package/dist/exceptions/job.exceptions.js +9 -16
- package/dist/exceptions/job.exceptions.js.map +1 -1
- package/dist/exceptions/runtime.exceptions.js +82 -121
- package/dist/exceptions/runtime.exceptions.js.map +1 -1
- package/dist/handlers/event-emitter.js +13 -20
- package/dist/handlers/event-emitter.js.map +1 -1
- package/dist/handlers/logger-factory.js +7 -14
- package/dist/handlers/logger-factory.js.map +1 -1
- package/dist/handlers/logger.js +26 -36
- package/dist/handlers/logger.js.map +1 -1
- package/dist/handlers/logging/file-logging.transport.js +17 -31
- package/dist/handlers/logging/file-logging.transport.js.map +1 -1
- package/dist/handlers/logging/loki-logging.transport.js +34 -50
- package/dist/handlers/logging/loki-logging.transport.js.map +1 -1
- package/dist/handlers/logging/static.logger.js +83 -124
- package/dist/handlers/logging/static.logger.js.map +1 -1
- package/dist/handlers/validators.js +8 -25
- package/dist/handlers/validators.js.map +1 -1
- package/dist/index.js +23 -26
- package/dist/index.js.map +1 -1
- package/dist/middleware/authenticate.js +26 -69
- package/dist/middleware/authenticate.js.map +1 -1
- package/dist/middleware/database.js +16 -22
- package/dist/middleware/database.js.map +1 -1
- package/dist/middleware/demo.middleware.js +19 -27
- package/dist/middleware/demo.middleware.js.map +1 -1
- package/dist/middleware/exception.filter.js +109 -133
- package/dist/middleware/exception.filter.js.map +1 -1
- package/dist/middleware/global.middleware.js +28 -47
- package/dist/middleware/global.middleware.js.map +1 -1
- package/dist/middleware/param-converter.middleware.js +31 -69
- package/dist/middleware/param-converter.middleware.js.map +1 -1
- package/dist/middleware/passport.js +38 -64
- package/dist/middleware/passport.js.map +1 -1
- package/dist/middleware/printer-resolver.js +26 -33
- package/dist/middleware/printer-resolver.js.map +1 -1
- package/dist/middleware/printer.js +56 -94
- package/dist/middleware/printer.js.map +1 -1
- package/dist/middleware/slicer-api-key.middleware.js +23 -26
- package/dist/middleware/slicer-api-key.middleware.js.map +1 -1
- package/dist/middleware/socketio.middleware.js +21 -32
- package/dist/middleware/socketio.middleware.js.map +1 -1
- package/dist/migrations/1706829146617-InitSqlite.js +84 -91
- package/dist/migrations/1706829146617-InitSqlite.js.map +1 -1
- package/dist/migrations/1707494762198-PrinterGroup.js +22 -29
- package/dist/migrations/1707494762198-PrinterGroup.js.map +1 -1
- package/dist/migrations/1708465930665-ChangePrintCompletionDeletePrinterCascade.js +26 -33
- package/dist/migrations/1708465930665-ChangePrintCompletionDeletePrinterCascade.js.map +1 -1
- package/dist/migrations/1713300747465-ChangeRoleNameUnique.js +27 -34
- package/dist/migrations/1713300747465-ChangeRoleNameUnique.js.map +1 -1
- package/dist/migrations/1713897879622-AddPrinterType.js +34 -41
- package/dist/migrations/1713897879622-AddPrinterType.js.map +1 -1
- package/dist/migrations/1720338804844-RemovePrinterFile.js +12 -19
- package/dist/migrations/1720338804844-RemovePrinterFile.js.map +1 -1
- package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js +26 -33
- package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js.map +1 -1
- package/dist/migrations/1766576698569-DropPermissions.js +11 -18
- package/dist/migrations/1766576698569-DropPermissions.js.map +1 -1
- package/dist/migrations/1767278216516-ChangeCameraPrinterOnDeleteSetNull.js +26 -33
- package/dist/migrations/1767278216516-ChangeCameraPrinterOnDeleteSetNull.js.map +1 -1
- package/dist/migrations/1767279607392-DropCustomGcode.js +12 -19
- package/dist/migrations/1767279607392-DropCustomGcode.js.map +1 -1
- package/dist/migrations/1767291804417-DropPrintCompletions.js +12 -19
- package/dist/migrations/1767291804417-DropPrintCompletions.js.map +1 -1
- package/dist/migrations/1767352862576-DropSettingsFileClean.js +18 -25
- package/dist/migrations/1767352862576-DropSettingsFileClean.js.map +1 -1
- package/dist/migrations/1767355639023-ChangeFloorLevelToOrder.js +26 -33
- package/dist/migrations/1767355639023-ChangeFloorLevelToOrder.js.map +1 -1
- package/dist/migrations/1767370191762-ChangeFloorNonUniqueOrder.js +18 -25
- package/dist/migrations/1767370191762-ChangeFloorNonUniqueOrder.js.map +1 -1
- package/dist/migrations/1767432108916-RenameGroupToTag.js +22 -29
- package/dist/migrations/1767432108916-RenameGroupToTag.js.map +1 -1
- package/dist/migrations/1767451444137-AddPrintJob.js +20 -27
- package/dist/migrations/1767451444137-AddPrintJob.js.map +1 -1
- package/dist/migrations/1767909428129-AddPrinterMaintenanceLog.js +14 -21
- package/dist/migrations/1767909428129-AddPrinterMaintenanceLog.js.map +1 -1
- package/dist/plugins/controllers-plugin.js +21 -0
- package/dist/plugins/controllers-plugin.js.map +1 -0
- package/dist/server.constants.js +79 -91
- package/dist/server.constants.js.map +1 -1
- package/dist/server.core.js +56 -122
- package/dist/server.core.js.map +1 -1
- package/dist/server.env.js +56 -121
- package/dist/server.env.js.map +1 -1
- package/dist/server.host.js +66 -99
- package/dist/server.host.js.map +1 -1
- package/dist/services/authentication/auth.service.js +103 -126
- package/dist/services/authentication/auth.service.js.map +1 -1
- package/dist/services/authentication/jwt.service.js +23 -32
- package/dist/services/authentication/jwt.service.js.map +1 -1
- package/dist/services/bambu/bambu-ftp.adapter.js +194 -236
- package/dist/services/bambu/bambu-ftp.adapter.js.map +1 -1
- package/dist/services/bambu/bambu-mqtt.adapter.js +394 -449
- package/dist/services/bambu/bambu-mqtt.adapter.js.map +1 -1
- package/dist/services/bambu/bambu.client.js +64 -65
- package/dist/services/bambu/bambu.client.js.map +1 -1
- package/dist/services/bambu/mqtt-message.types.js +1 -6
- package/dist/services/bambu.api.js +230 -247
- package/dist/services/bambu.api.js.map +1 -1
- package/dist/services/core/batch-call.service.js +139 -163
- package/dist/services/core/batch-call.service.js.map +1 -1
- package/dist/services/core/client-bundle.service.js +126 -165
- package/dist/services/core/client-bundle.service.js.map +1 -1
- package/dist/services/core/config.service.js +16 -26
- package/dist/services/core/config.service.js.map +1 -1
- package/dist/services/core/cradle.service.js +11 -19
- package/dist/services/core/cradle.service.js.map +1 -1
- package/dist/services/core/github.service.js +59 -79
- package/dist/services/core/github.service.js.map +1 -1
- package/dist/services/core/http-client.factory.js +30 -38
- package/dist/services/core/http-client.factory.js.map +1 -1
- package/dist/services/core/logs-manager.service.js +61 -84
- package/dist/services/core/logs-manager.service.js.map +1 -1
- package/dist/services/core/monsterpi.service.js +26 -36
- package/dist/services/core/monsterpi.service.js.map +1 -1
- package/dist/services/core/multer.service.js +69 -129
- package/dist/services/core/multer.service.js.map +1 -1
- package/dist/services/core/server-release.service.js +77 -99
- package/dist/services/core/server-release.service.js.map +1 -1
- package/dist/services/core/yaml.service.js +443 -573
- package/dist/services/core/yaml.service.js.map +1 -1
- package/dist/services/file-analysis.service.js +134 -144
- package/dist/services/file-analysis.service.js.map +1 -1
- package/dist/services/file-storage.service.js +324 -423
- package/dist/services/file-storage.service.js.map +1 -1
- package/dist/services/interfaces/auth.service.interface.js +1 -6
- package/dist/services/interfaces/camera-stream.dto.js +23 -41
- package/dist/services/interfaces/camera-stream.dto.js.map +1 -1
- package/dist/services/interfaces/camera-stream.service.interface.js +1 -6
- package/dist/services/interfaces/file-upload-tracker.interface.js +1 -6
- package/dist/services/interfaces/floor.dto.js +31 -55
- package/dist/services/interfaces/floor.dto.js.map +1 -1
- package/dist/services/interfaces/floor.service.interface.js +1 -6
- package/dist/services/interfaces/jwt.service.interface.js +1 -6
- package/dist/services/interfaces/login.dto.js +10 -17
- package/dist/services/interfaces/login.dto.js.map +1 -1
- package/dist/services/interfaces/page.interface.js +5 -12
- package/dist/services/interfaces/page.interface.js.map +1 -1
- package/dist/services/interfaces/permission.service.interface.js +1 -6
- package/dist/services/interfaces/printer-file.dto.js +1 -6
- package/dist/services/interfaces/printer-maintenance-log.dto.js +1 -6
- package/dist/services/interfaces/printer-tag.dto.js +11 -26
- package/dist/services/interfaces/printer-tag.dto.js.map +1 -1
- package/dist/services/interfaces/printer-tag.service.interface.js +1 -6
- package/dist/services/interfaces/printer.dto.js +21 -36
- package/dist/services/interfaces/printer.dto.js.map +1 -1
- package/dist/services/interfaces/printer.service.interface.js +1 -6
- package/dist/services/interfaces/refresh-token.dto.js +9 -16
- package/dist/services/interfaces/refresh-token.dto.js.map +1 -1
- package/dist/services/interfaces/refresh-token.service.interface.js +1 -6
- package/dist/services/interfaces/role-service.interface.js +1 -6
- package/dist/services/interfaces/role.dto.js +7 -14
- package/dist/services/interfaces/role.dto.js.map +1 -1
- package/dist/services/interfaces/settings.dto.js +10 -17
- package/dist/services/interfaces/settings.dto.js.map +1 -1
- package/dist/services/interfaces/settings.service.interface.js +1 -6
- package/dist/services/interfaces/tag.dto.js +1 -6
- package/dist/services/interfaces/task.interfaces.js +1 -6
- package/dist/services/interfaces/user-role.dto.js +9 -16
- package/dist/services/interfaces/user-role.dto.js.map +1 -1
- package/dist/services/interfaces/user-service.interface.js +1 -6
- package/dist/services/interfaces/user.dto.js +22 -37
- package/dist/services/interfaces/user.dto.js.map +1 -1
- package/dist/services/moonraker/constants/moonraker-event.dto.js +16 -31
- package/dist/services/moonraker/constants/moonraker-event.dto.js.map +1 -1
- package/dist/services/moonraker/constants/moonraker.constants.js +4 -11
- package/dist/services/moonraker/constants/moonraker.constants.js.map +1 -1
- package/dist/services/moonraker/dto/access/access-info.dto.js +1 -6
- package/dist/services/moonraker/dto/access/access-login-refresh.dto.js +1 -6
- package/dist/services/moonraker/dto/access/access-login-result.dto.js +1 -6
- package/dist/services/moonraker/dto/access/access-user-result.dto.js +1 -6
- package/dist/services/moonraker/dto/access/access-user.dto.js +1 -6
- package/dist/services/moonraker/dto/database/database-namespace-item.dto.js +1 -6
- package/dist/services/moonraker/dto/database/database-namespace-list.dto.js +1 -6
- package/dist/services/moonraker/dto/gcode-help.dto.js +1 -6
- package/dist/services/moonraker/dto/gcode-store.dto.js +1 -6
- package/dist/services/moonraker/dto/job-queue/enqueue-job.dto.js +1 -6
- package/dist/services/moonraker/dto/job-queue/job-queue-status.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-device-power-device-state.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-device-power-devices.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-peripherals-canbus.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-peripherals-serial.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-peripherals-usb.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-peripherals-video.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-system-info.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-update-status.dto.js +1 -6
- package/dist/services/moonraker/dto/machine/machine-wled-strips.dto.js +1 -6
- package/dist/services/moonraker/dto/notifier-list.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/bed-mesh.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/configfile.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/display-status.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/extruder.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/fan.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/filament-motion-sensor.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/filament-switch-sensor.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/gcode-move.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/gcode.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/heater-bed.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/heaters.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/idle-timeout.dto.js +6 -21
- package/dist/services/moonraker/dto/objects/idle-timeout.dto.js.map +1 -1
- package/dist/services/moonraker/dto/objects/mcu.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/motion-report.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/output-pin.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/pause-resume.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/print-stats.dto.js +9 -24
- package/dist/services/moonraker/dto/objects/print-stats.dto.js.map +1 -1
- package/dist/services/moonraker/dto/objects/printer-object.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/printer-object.types.js +1 -6
- package/dist/services/moonraker/dto/objects/printer-objects-list.dto.js +28 -43
- package/dist/services/moonraker/dto/objects/printer-objects-list.dto.js.map +1 -1
- package/dist/services/moonraker/dto/objects/printer-objects-query.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/stepper-enable.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/system-stats.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/temperature-fan.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/temperature-sensor.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/toolhead.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/virtual-sdcard.dto.js +1 -6
- package/dist/services/moonraker/dto/objects/webhooks.dto.js +1 -6
- package/dist/services/moonraker/dto/octoprint-compat/api-job.dto.js +1 -6
- package/dist/services/moonraker/dto/octoprint-compat/api-login.dto.js +1 -6
- package/dist/services/moonraker/dto/octoprint-compat/api-printer.dto.js +1 -6
- package/dist/services/moonraker/dto/octoprint-compat/api-profiles.dto.js +1 -6
- package/dist/services/moonraker/dto/octoprint-compat/api-settings.dto.js +1 -6
- package/dist/services/moonraker/dto/octoprint-compat/api-version.dto.js +1 -6
- package/dist/services/moonraker/dto/octoprint-compat/server-version.dto.js +1 -6
- package/dist/services/moonraker/dto/printer-info.dto.js +7 -22
- package/dist/services/moonraker/dto/printer-info.dto.js.map +1 -1
- package/dist/services/moonraker/dto/printer-query-endstops.dto.js +1 -6
- package/dist/services/moonraker/dto/process-stats.dto.js +1 -6
- package/dist/services/moonraker/dto/rest/action-result.dto.js +1 -6
- package/dist/services/moonraker/dto/rest/error.dto.js +1 -6
- package/dist/services/moonraker/dto/rest/result.dto.js +6 -13
- package/dist/services/moonraker/dto/rest/result.dto.js.map +1 -1
- package/dist/services/moonraker/dto/rollover-logs.dto.js +1 -6
- package/dist/services/moonraker/dto/rpc/json-rpc-error.dto.js +1 -6
- package/dist/services/moonraker/dto/rpc/json-rpc-request.dto.js +1 -6
- package/dist/services/moonraker/dto/rpc/json-rpc-response.dto.js +1 -6
- package/dist/services/moonraker/dto/server/server-config.dto.js +1 -6
- package/dist/services/moonraker/dto/server/server-info.dto.js +7 -14
- package/dist/services/moonraker/dto/server/server-info.dto.js.map +1 -1
- package/dist/services/moonraker/dto/server-announcements/announcement-action.dto.js +1 -6
- package/dist/services/moonraker/dto/server-announcements/announcement-entry-id.dto.js +1 -6
- package/dist/services/moonraker/dto/server-announcements/announcement-feeds.dto.js +1 -6
- package/dist/services/moonraker/dto/server-announcements/announcement-list.dto.js +1 -6
- package/dist/services/moonraker/dto/server-files/server-file-directory-action.dto.js +1 -6
- package/dist/services/moonraker/dto/server-files/server-file-directory-info.dto.js +1 -6
- package/dist/services/moonraker/dto/server-files/server-file-metadata.dto.js +1 -6
- package/dist/services/moonraker/dto/server-files/server-file-root.dto.js +1 -6
- package/dist/services/moonraker/dto/server-files/server-file-thumbnail.dto.js +1 -6
- package/dist/services/moonraker/dto/server-files/server-file-zip-action.dto.js +1 -6
- package/dist/services/moonraker/dto/server-files/server-file.dto.js +1 -6
- package/dist/services/moonraker/dto/server-history/history-job.dto.js +1 -6
- package/dist/services/moonraker/dto/server-history/history-last-totals.dto.js +1 -6
- package/dist/services/moonraker/dto/server-history/history-list.dto.js +1 -6
- package/dist/services/moonraker/dto/server-history/history-totals.dto.js +1 -6
- package/dist/services/moonraker/dto/server-history/job.dto.js +6 -21
- package/dist/services/moonraker/dto/server-history/job.dto.js.map +1 -1
- package/dist/services/moonraker/dto/server-sensors/sensor-info.dto.js +1 -6
- package/dist/services/moonraker/dto/server-sensors/sensor-list.dto.js +1 -6
- package/dist/services/moonraker/dto/server-sensors/sensor-measurements.dto.js +1 -6
- package/dist/services/moonraker/dto/server-webcams/webcam-item.dto.js +1 -6
- package/dist/services/moonraker/dto/server-webcams/webcam-list.dto.js +1 -6
- package/dist/services/moonraker/dto/server-webcams/webcam-test.dto.js +1 -6
- package/dist/services/moonraker/dto/spoolman/spoolman-active-spool.dto.js +1 -6
- package/dist/services/moonraker/dto/spoolman/spoolman-proxy-request.dto.js +1 -6
- package/dist/services/moonraker/dto/spoolman/spoolman-response.dto.js +1 -6
- package/dist/services/moonraker/dto/spoolman/spoolman-status.dto.js +1 -6
- package/dist/services/moonraker/dto/sudo-info.dto.js +1 -6
- package/dist/services/moonraker/dto/sudo-response.dto.js +1 -6
- package/dist/services/moonraker/dto/temperature-store.dto.js +1 -6
- package/dist/services/moonraker/dto/websocket/connection-identify-response.dto.js +1 -6
- package/dist/services/moonraker/dto/websocket/connection-identify.dto.js +1 -6
- package/dist/services/moonraker/dto/websocket/json-rpc-event.dto.js +1 -6
- package/dist/services/moonraker/dto/websocket/message.types.js +1 -6
- package/dist/services/moonraker/dto/websocket/methods.js +29 -44
- package/dist/services/moonraker/dto/websocket/methods.js.map +1 -1
- package/dist/services/moonraker/dto/websocket/notify-active-spool-set.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-agent-event.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-announcement-update.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-announcement.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-button-event.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-filelist-changed.params.js +11 -18
- package/dist/services/moonraker/dto/websocket/notify-filelist-changed.params.js.map +1 -1
- package/dist/services/moonraker/dto/websocket/notify-history-changed.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-job-queue-changed.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-proc-stat-update.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-sensor-update.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-service-state-changed.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-spoolman-status-changed.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-sudo-alert.params.js +1 -6
- package/dist/services/moonraker/dto/websocket/notify-update-response.params.js +7 -22
- package/dist/services/moonraker/dto/websocket/notify-update-response.params.js.map +1 -1
- package/dist/services/moonraker/dto/websocket/notify-user-change.params.js +1 -6
- package/dist/services/moonraker/moonraker-websocket.adapter.js +313 -348
- package/dist/services/moonraker/moonraker-websocket.adapter.js.map +1 -1
- package/dist/services/moonraker/moonraker.client.js +536 -559
- package/dist/services/moonraker/moonraker.client.js.map +1 -1
- package/dist/services/moonraker.api.js +167 -192
- package/dist/services/moonraker.api.js.map +1 -1
- package/dist/services/octoprint/constants/firmware-update-settings.constants.js +19 -28
- package/dist/services/octoprint/constants/firmware-update-settings.constants.js.map +1 -1
- package/dist/services/octoprint/constants/octoprint-service.constants.js +3 -30
- package/dist/services/octoprint/constants/octoprint-service.constants.js.map +1 -1
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js +41 -56
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js.map +1 -1
- package/dist/services/octoprint/dto/access/user-list.dto.js +1 -6
- package/dist/services/octoprint/dto/access/user.dto.js +1 -6
- package/dist/services/octoprint/dto/auth/current-user.dto.js +1 -6
- package/dist/services/octoprint/dto/auth/login.dto.js +1 -6
- package/dist/services/octoprint/dto/connection/connection-state.type.js +23 -30
- package/dist/services/octoprint/dto/connection/connection-state.type.js.map +1 -1
- package/dist/services/octoprint/dto/connection/connection.dto.js +1 -6
- package/dist/services/octoprint/dto/events/client-authed.dto.js +1 -6
- package/dist/services/octoprint/dto/events/client-closed.dto.js +1 -6
- package/dist/services/octoprint/dto/events/client-opened.dto.js +1 -6
- package/dist/services/octoprint/dto/events/dwelling.dto.js +1 -6
- package/dist/services/octoprint/dto/events/file-added.dto.js +1 -6
- package/dist/services/octoprint/dto/events/file-deselected.dto.js +1 -6
- package/dist/services/octoprint/dto/events/file-removed.dto.js +1 -6
- package/dist/services/octoprint/dto/events/folder-added.dto.js +1 -6
- package/dist/services/octoprint/dto/events/home.dto.js +1 -6
- package/dist/services/octoprint/dto/events/metadata-analysis-finished.dto.js +1 -6
- package/dist/services/octoprint/dto/events/metadata-analysis-started.dto.js +1 -6
- package/dist/services/octoprint/dto/events/metadata-statistics-updated.dto.js +1 -6
- package/dist/services/octoprint/dto/events/position-update.dto.js +1 -6
- package/dist/services/octoprint/dto/events/print-cancelled.dto.js +1 -6
- package/dist/services/octoprint/dto/events/print-cancelling.dto.js +1 -6
- package/dist/services/octoprint/dto/events/print-done.dto.js +1 -6
- package/dist/services/octoprint/dto/events/print-failed.dto.js +1 -6
- package/dist/services/octoprint/dto/events/print-paused.dto.js +1 -6
- package/dist/services/octoprint/dto/events/print-resumed.dto.js +1 -6
- package/dist/services/octoprint/dto/events/print-started.dto.js +1 -6
- package/dist/services/octoprint/dto/events/printer-state-changed.dto.js +1 -6
- package/dist/services/octoprint/dto/events/transfer-done.dto.js +1 -6
- package/dist/services/octoprint/dto/events/transfer-started.dto.js +1 -6
- package/dist/services/octoprint/dto/events/updated-files.dto.js +1 -6
- package/dist/services/octoprint/dto/events/upload.dto.js +1 -6
- package/dist/services/octoprint/dto/events/user-logged-in.dto.js +1 -6
- package/dist/services/octoprint/dto/events/z-change.dto.js +1 -6
- package/dist/services/octoprint/dto/files/gcode-analysis.dto.js +1 -6
- package/dist/services/octoprint/dto/files/octoprint-file.dto.js +1 -6
- package/dist/services/octoprint/dto/files/octoprint-files-response.dto.js +1 -6
- package/dist/services/octoprint/dto/job/current-job.dto.js +8 -15
- package/dist/services/octoprint/dto/job/current-job.dto.js.map +1 -1
- package/dist/services/octoprint/dto/job/job.dto.js +1 -6
- package/dist/services/octoprint/dto/octoprint-event.dto.js +21 -39
- package/dist/services/octoprint/dto/octoprint-event.dto.js.map +1 -1
- package/dist/services/octoprint/dto/printer/busy-file.dto.js +1 -6
- package/dist/services/octoprint/dto/printer/current-printer-state.dto.js +1 -6
- package/dist/services/octoprint/dto/printer/flags.dto.js +1 -6
- package/dist/services/octoprint/dto/printer/markings.dto.js +1 -6
- package/dist/services/octoprint/dto/printer/progress.dto.js +1 -6
- package/dist/services/octoprint/dto/printer/resends.dto.js +1 -6
- package/dist/services/octoprint/dto/printer/state.dto.js +1 -6
- package/dist/services/octoprint/dto/printer/temps.dto.js +1 -6
- package/dist/services/octoprint/dto/rest/error.dto.js +1 -6
- package/dist/services/octoprint/dto/server/server.dto.js +1 -6
- package/dist/services/octoprint/dto/server/version.dto.js +1 -6
- package/dist/services/octoprint/dto/settings/serial-settings.dto.js +1 -6
- package/dist/services/octoprint/dto/settings/settings-parts.type.js +1 -6
- package/dist/services/octoprint/dto/settings/settings.dto.js +1 -6
- package/dist/services/octoprint/dto/settings/virtual-printer-settings.dto.js +1 -6
- package/dist/services/octoprint/dto/system/system-info.dto.js +32 -39
- package/dist/services/octoprint/dto/system/system-info.dto.js.map +1 -1
- package/dist/services/octoprint/dto/websocket/connection-message.dto.js +1 -6
- package/dist/services/octoprint/dto/websocket/current-message.dto.js +1 -6
- package/dist/services/octoprint/dto/websocket/event-message.dto.js +1 -6
- package/dist/services/octoprint/dto/websocket/event.type.js +42 -49
- package/dist/services/octoprint/dto/websocket/event.type.js.map +1 -1
- package/dist/services/octoprint/dto/websocket/history-message.dto.js +1 -6
- package/dist/services/octoprint/dto/websocket/plugin-message.dto.js +1 -6
- package/dist/services/octoprint/dto/websocket/timelapse-message.dto.js +1 -6
- package/dist/services/octoprint/octoprint-api.routes.js +77 -94
- package/dist/services/octoprint/octoprint-api.routes.js.map +1 -1
- package/dist/services/octoprint/octoprint-websocket.adapter.js +265 -315
- package/dist/services/octoprint/octoprint-websocket.adapter.js.map +1 -1
- package/dist/services/octoprint/octoprint.client.js +220 -261
- package/dist/services/octoprint/octoprint.client.js.map +1 -1
- package/dist/services/octoprint/utils/api.utils.js +15 -32
- package/dist/services/octoprint/utils/api.utils.js.map +1 -1
- package/dist/services/octoprint/utils/file.utils.js +44 -67
- package/dist/services/octoprint/utils/file.utils.js.map +1 -1
- package/dist/services/octoprint/utils/octoprint-http-client.builder.js +16 -29
- package/dist/services/octoprint/utils/octoprint-http-client.builder.js.map +1 -1
- package/dist/services/octoprint.api.js +113 -128
- package/dist/services/octoprint.api.js.map +1 -1
- package/dist/services/orm/base.interface.js +1 -6
- package/dist/services/orm/base.service.js +57 -73
- package/dist/services/orm/base.service.js.map +1 -1
- package/dist/services/orm/camera-stream.service.js +21 -27
- package/dist/services/orm/camera-stream.service.js.map +1 -1
- package/dist/services/orm/floor-position.service.js +42 -49
- package/dist/services/orm/floor-position.service.js.map +1 -1
- package/dist/services/orm/floor.service.js +110 -138
- package/dist/services/orm/floor.service.js.map +1 -1
- package/dist/services/orm/permission.service.js +16 -23
- package/dist/services/orm/permission.service.js.map +1 -1
- package/dist/services/orm/print-job.service.js +443 -545
- package/dist/services/orm/print-job.service.js.map +1 -1
- package/dist/services/orm/printer-maintenance-log.service.js +102 -149
- package/dist/services/orm/printer-maintenance-log.service.js.map +1 -1
- package/dist/services/orm/printer-tag.service.js +93 -118
- package/dist/services/orm/printer-tag.service.js.map +1 -1
- package/dist/services/orm/printer.service.js +110 -158
- package/dist/services/orm/printer.service.js.map +1 -1
- package/dist/services/orm/refresh-token.service.js +69 -99
- package/dist/services/orm/refresh-token.service.js.map +1 -1
- package/dist/services/orm/role.service.js +99 -116
- package/dist/services/orm/role.service.js.map +1 -1
- package/dist/services/orm/settings.service.js +84 -94
- package/dist/services/orm/settings.service.js.map +1 -1
- package/dist/services/orm/user-role.service.js +39 -53
- package/dist/services/orm/user-role.service.js.map +1 -1
- package/dist/services/orm/user.service.js +142 -189
- package/dist/services/orm/user.service.js.map +1 -1
- package/dist/services/print-file-downloader.service.js +153 -167
- package/dist/services/print-file-downloader.service.js.map +1 -1
- package/dist/services/print-queue.service.js +240 -326
- package/dist/services/print-queue.service.js.map +1 -1
- package/dist/services/printer-api.factory.js +26 -43
- package/dist/services/printer-api.factory.js.map +1 -1
- package/dist/services/printer-api.interface.js +23 -53
- package/dist/services/printer-api.interface.js.map +1 -1
- package/dist/services/prusa-link/constants/prusalink-event.dto.js +9 -16
- package/dist/services/prusa-link/constants/prusalink-event.dto.js.map +1 -1
- package/dist/services/prusa-link/constants/prusalink.constants.js +4 -11
- package/dist/services/prusa-link/constants/prusalink.constants.js.map +1 -1
- package/dist/services/prusa-link/dto/file-response.dto.js +1 -6
- package/dist/services/prusa-link/dto/file.dto.js +1 -6
- package/dist/services/prusa-link/dto/job-state.dto.js +1 -6
- package/dist/services/prusa-link/dto/printer-state.dto.js +1 -6
- package/dist/services/prusa-link/dto/status.dto.js +1 -6
- package/dist/services/prusa-link/dto/version.dto.js +1 -6
- package/dist/services/prusa-link/prusa-link-http-polling.adapter.js +141 -157
- package/dist/services/prusa-link/prusa-link-http-polling.adapter.js.map +1 -1
- package/dist/services/prusa-link/prusa-link.api.js +206 -240
- package/dist/services/prusa-link/prusa-link.api.js.map +1 -1
- package/dist/services/prusa-link/utils/digest-auth.params.js +1 -6
- package/dist/services/prusa-link/utils/digest-auth.util.js +17 -24
- package/dist/services/prusa-link/utils/digest-auth.util.js.map +1 -1
- package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js +92 -129
- package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js.map +1 -1
- package/dist/services/socket.factory.js +21 -36
- package/dist/services/socket.factory.js.map +1 -1
- package/dist/services/task-manager.service.js +190 -174
- package/dist/services/task-manager.service.js.map +1 -1
- package/dist/services/typeorm/typeorm.service.js +31 -46
- package/dist/services/typeorm/typeorm.service.js.map +1 -1
- package/dist/services/validators/floor-service.validation.js +26 -63
- package/dist/services/validators/floor-service.validation.js.map +1 -1
- package/dist/services/validators/print-job.validation.js +11 -26
- package/dist/services/validators/print-job.validation.js.map +1 -1
- package/dist/services/validators/printer-maintenance-log.validation.js +17 -37
- package/dist/services/validators/printer-maintenance-log.validation.js.map +1 -1
- package/dist/services/validators/printer-service.validation.js +60 -125
- package/dist/services/validators/printer-service.validation.js.map +1 -1
- package/dist/services/validators/settings-service.validation.js +46 -106
- package/dist/services/validators/settings-service.validation.js.map +1 -1
- package/dist/services/validators/user-service.validation.js +19 -36
- package/dist/services/validators/user-service.validation.js.map +1 -1
- package/dist/services/validators/yaml-service.validation.js +96 -132
- package/dist/services/validators/yaml-service.validation.js.map +1 -1
- package/dist/services/websocket-adapter.interface.js +1 -6
- package/dist/shared/default-http-client.builder.js +74 -92
- package/dist/shared/default-http-client.builder.js.map +1 -1
- package/dist/shared/dtos/api-state.type.js +8 -15
- package/dist/shared/dtos/api-state.type.js.map +1 -1
- package/dist/shared/dtos/socket-login.dto.js +1 -6
- package/dist/shared/dtos/socket-state.type.js +11 -18
- package/dist/shared/dtos/socket-state.type.js.map +1 -1
- package/dist/shared/load-controllers.js +41 -19
- package/dist/shared/load-controllers.js.map +1 -1
- package/dist/shared/runtime-settings.migration.js +43 -50
- package/dist/shared/runtime-settings.migration.js.map +1 -1
- package/dist/shared/websocket-rpc-extended.adapter.js +74 -75
- package/dist/shared/websocket-rpc-extended.adapter.js.map +1 -1
- package/dist/shared/websocket.adapter.js +78 -63
- package/dist/shared/websocket.adapter.js.map +1 -1
- package/dist/state/file-upload-tracker.cache.js +63 -75
- package/dist/state/file-upload-tracker.cache.js.map +1 -1
- package/dist/state/floor.store.js +77 -89
- package/dist/state/floor.store.js.map +1 -1
- package/dist/state/printer-events.cache.js +237 -295
- package/dist/state/printer-events.cache.js.map +1 -1
- package/dist/state/printer-socket.store.js +156 -174
- package/dist/state/printer-socket.store.js.map +1 -1
- package/dist/state/printer-thumbnail.cache.js +129 -130
- package/dist/state/printer-thumbnail.cache.js.map +1 -1
- package/dist/state/printer.cache.js +87 -102
- package/dist/state/printer.cache.js.map +1 -1
- package/dist/state/settings.store.js +211 -234
- package/dist/state/settings.store.js.map +1 -1
- package/dist/state/socket-io.gateway.js +58 -87
- package/dist/state/socket-io.gateway.js.map +1 -1
- package/dist/state/test-printer-socket.store.js +116 -137
- package/dist/state/test-printer-socket.store.js.map +1 -1
- package/dist/state/validation/create-test-printer.validation.js +14 -21
- package/dist/state/validation/create-test-printer.validation.js.map +1 -1
- package/dist/task.presets.js +30 -37
- package/dist/task.presets.js.map +1 -1
- package/dist/tasks/boot.task.js +100 -128
- package/dist/tasks/boot.task.js.map +1 -1
- package/dist/tasks/client-bundle.task.js +20 -28
- package/dist/tasks/client-bundle.task.js.map +1 -1
- package/dist/tasks/print-job-analysis.task.js +88 -113
- package/dist/tasks/print-job-analysis.task.js.map +1 -1
- package/dist/tasks/printer-websocket-restore.task.js +41 -54
- package/dist/tasks/printer-websocket-restore.task.js.map +1 -1
- package/dist/tasks/printer-websocket.task.js +11 -19
- package/dist/tasks/printer-websocket.task.js.map +1 -1
- package/dist/tasks/socketio.task.js +35 -53
- package/dist/tasks/socketio.task.js.map +1 -1
- package/dist/tasks/software-update.task.js +12 -20
- package/dist/tasks/software-update.task.js.map +1 -1
- package/dist/tasks.js +27 -41
- package/dist/tasks.js.map +1 -1
- package/dist/types/express/index.d.js +1 -6
- package/dist/types/virtual-modules.d.js +1 -0
- package/dist/utils/array.util.js +9 -24
- package/dist/utils/array.util.js.map +1 -1
- package/dist/utils/bgcode/bgcode-thumbnail.parser.js +26 -44
- package/dist/utils/bgcode/bgcode-thumbnail.parser.js.map +1 -1
- package/dist/utils/bgcode/bgcode.constants.js +9 -45
- package/dist/utils/bgcode/bgcode.constants.js.map +1 -1
- package/dist/utils/bgcode/bgcode.types.js +57 -106
- package/dist/utils/bgcode/bgcode.types.js.map +1 -1
- package/dist/utils/bgcode/bgcode.utils.js +167 -256
- package/dist/utils/bgcode/bgcode.utils.js.map +1 -1
- package/dist/utils/bgcode/heatshrink-decoder.js +130 -170
- package/dist/utils/bgcode/heatshrink-decoder.js.map +1 -1
- package/dist/utils/bgcode/png-encoder.js +53 -66
- package/dist/utils/bgcode/png-encoder.js.map +1 -1
- package/dist/utils/bgcode/qoi-decoder.js +116 -135
- package/dist/utils/bgcode/qoi-decoder.js.map +1 -1
- package/dist/utils/cache/key-diff.cache.js +56 -85
- package/dist/utils/cache/key-diff.cache.js.map +1 -1
- package/dist/utils/correlation-token.util.js +4 -11
- package/dist/utils/correlation-token.util.js.map +1 -1
- package/dist/utils/crypto.utils.js +7 -23
- package/dist/utils/crypto.utils.js.map +1 -1
- package/dist/utils/env.utils.js +14 -49
- package/dist/utils/env.utils.js.map +1 -1
- package/dist/utils/error.utils.js +4 -11
- package/dist/utils/error.utils.js.map +1 -1
- package/dist/utils/fs.utils.js +26 -49
- package/dist/utils/fs.utils.js.map +1 -1
- package/dist/utils/gcode.utils.js +30 -43
- package/dist/utils/gcode.utils.js.map +1 -1
- package/dist/utils/image-dimensions.js +39 -54
- package/dist/utils/image-dimensions.js.map +1 -1
- package/dist/utils/job-stats.util.js +41 -72
- package/dist/utils/job-stats.util.js.map +1 -1
- package/dist/utils/normalize-url.js +135 -203
- package/dist/utils/normalize-url.js.map +1 -1
- package/dist/utils/parsers/3mf.parser.js +298 -365
- package/dist/utils/parsers/3mf.parser.js.map +1 -1
- package/dist/utils/parsers/bgcode.parser.js +149 -202
- package/dist/utils/parsers/bgcode.parser.js.map +1 -1
- package/dist/utils/parsers/gcode.parser.js +200 -263
- package/dist/utils/parsers/gcode.parser.js.map +1 -1
- package/dist/utils/parsers/parser.types.js +1 -6
- package/dist/utils/pretty-print.utils.js +5 -20
- package/dist/utils/pretty-print.utils.js.map +1 -1
- package/dist/utils/semver.utils.js +10 -26
- package/dist/utils/semver.utils.js.map +1 -1
- package/dist/utils/swagger/decorators.js +14 -32
- package/dist/utils/swagger/decorators.js.map +1 -1
- package/dist/utils/swagger/generator.js +151 -194
- package/dist/utils/swagger/generator.js.map +1 -1
- package/dist/utils/swagger/swagger.js +40 -51
- package/dist/utils/swagger/swagger.js.map +1 -1
- package/dist/utils/thumbnail.util.js +11 -20
- package/dist/utils/thumbnail.util.js.map +1 -1
- package/dist/utils/time.utils.js +4 -12
- package/dist/utils/time.utils.js.map +1 -1
- package/dist/utils/url.utils.js +9 -27
- package/dist/utils/url.utils.js.map +1 -1
- package/package.json +79 -90
- package/packages/consoles/package.json +44 -0
- package/packages/consoles/tsconfig.json +23 -0
- package/packages/consoles/vite.config.ts +15 -0
- package/tsconfig.json +10 -6
- package/vite.config.ts +62 -0
- package/.swcrc +0 -33
- package/.yarn/releases/yarn-4.12.0.cjs +0 -942
- package/biome.json +0 -36
- package/dist/consoles/bambu-mqtt-diagnostic.console.js +0 -565
- package/dist/consoles/bambu-mqtt-diagnostic.console.js.map +0 -1
- package/dist/consoles/download-github-releases.js +0 -50
- package/dist/consoles/download-github-releases.js.map +0 -1
- package/dist/consoles/gcode-scanner-poc.console.js +0 -52
- package/dist/consoles/gcode-scanner-poc.console.js.map +0 -1
- package/dist/consoles/launch-http-servers.js +0 -31
- package/dist/consoles/launch-http-servers.js.map +0 -1
- package/dist/consoles/mock-bambu.server.js +0 -319
- package/dist/consoles/mock-bambu.server.js.map +0 -1
- package/dist/consoles/mock-camera/default-image.js +0 -13
- package/dist/consoles/mock-camera/default-image.js.map +0 -1
- package/dist/consoles/mock-camera/mock-camera.server.js +0 -160
- package/dist/consoles/mock-camera/mock-camera.server.js.map +0 -1
- package/dist/consoles/mock-octoprint.server.js +0 -499
- package/dist/consoles/mock-octoprint.server.js.map +0 -1
- package/dist/consoles/mock-prusalink.server.js +0 -57
- package/dist/consoles/mock-prusalink.server.js.map +0 -1
- package/dist/consoles/moonraker-test.console.js +0 -3
- package/dist/consoles/moonraker-test.console.js.map +0 -1
- package/dist/consoles/utils/api-messages.js +0 -856
- package/dist/consoles/utils/api-messages.js.map +0 -1
- package/dist/consoles/utils/delayed-memory.storage.js +0 -42
- package/dist/consoles/utils/delayed-memory.storage.js.map +0 -1
- package/dist/consoles/utils/ws-messages.js +0 -88
- package/dist/consoles/utils/ws-messages.js.map +0 -1
- package/dist/entities/index.js.map +0 -1
- package/dist/services/bambu/mqtt-message.types.js.map +0 -1
- package/dist/services/interfaces/auth.service.interface.js.map +0 -1
- package/dist/services/interfaces/camera-stream.service.interface.js.map +0 -1
- package/dist/services/interfaces/file-upload-tracker.interface.js.map +0 -1
- package/dist/services/interfaces/floor.service.interface.js.map +0 -1
- package/dist/services/interfaces/jwt.service.interface.js.map +0 -1
- package/dist/services/interfaces/permission.service.interface.js.map +0 -1
- package/dist/services/interfaces/printer-file.dto.js.map +0 -1
- package/dist/services/interfaces/printer-maintenance-log.dto.js.map +0 -1
- package/dist/services/interfaces/printer-tag.service.interface.js.map +0 -1
- package/dist/services/interfaces/printer.service.interface.js.map +0 -1
- package/dist/services/interfaces/refresh-token.service.interface.js.map +0 -1
- package/dist/services/interfaces/role-service.interface.js.map +0 -1
- package/dist/services/interfaces/settings.service.interface.js.map +0 -1
- package/dist/services/interfaces/tag.dto.js.map +0 -1
- package/dist/services/interfaces/task.interfaces.js.map +0 -1
- package/dist/services/interfaces/user-service.interface.js.map +0 -1
- package/dist/services/moonraker/dto/access/access-info.dto.js.map +0 -1
- package/dist/services/moonraker/dto/access/access-login-refresh.dto.js.map +0 -1
- package/dist/services/moonraker/dto/access/access-login-result.dto.js.map +0 -1
- package/dist/services/moonraker/dto/access/access-user-result.dto.js.map +0 -1
- package/dist/services/moonraker/dto/access/access-user.dto.js.map +0 -1
- package/dist/services/moonraker/dto/database/database-namespace-item.dto.js.map +0 -1
- package/dist/services/moonraker/dto/database/database-namespace-list.dto.js.map +0 -1
- package/dist/services/moonraker/dto/gcode-help.dto.js.map +0 -1
- package/dist/services/moonraker/dto/gcode-store.dto.js.map +0 -1
- package/dist/services/moonraker/dto/job-queue/enqueue-job.dto.js.map +0 -1
- package/dist/services/moonraker/dto/job-queue/job-queue-status.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-device-power-device-state.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-device-power-devices.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-peripherals-canbus.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-peripherals-serial.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-peripherals-usb.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-peripherals-video.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-system-info.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-update-status.dto.js.map +0 -1
- package/dist/services/moonraker/dto/machine/machine-wled-strips.dto.js.map +0 -1
- package/dist/services/moonraker/dto/notifier-list.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/bed-mesh.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/configfile.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/display-status.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/extruder.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/fan.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/filament-motion-sensor.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/filament-switch-sensor.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/gcode-move.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/gcode.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/heater-bed.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/heaters.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/mcu.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/motion-report.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/output-pin.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/pause-resume.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/printer-object.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/printer-object.types.js.map +0 -1
- package/dist/services/moonraker/dto/objects/printer-objects-query.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/stepper-enable.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/system-stats.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/temperature-fan.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/temperature-sensor.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/toolhead.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/virtual-sdcard.dto.js.map +0 -1
- package/dist/services/moonraker/dto/objects/webhooks.dto.js.map +0 -1
- package/dist/services/moonraker/dto/octoprint-compat/api-job.dto.js.map +0 -1
- package/dist/services/moonraker/dto/octoprint-compat/api-login.dto.js.map +0 -1
- package/dist/services/moonraker/dto/octoprint-compat/api-printer.dto.js.map +0 -1
- package/dist/services/moonraker/dto/octoprint-compat/api-profiles.dto.js.map +0 -1
- package/dist/services/moonraker/dto/octoprint-compat/api-settings.dto.js.map +0 -1
- package/dist/services/moonraker/dto/octoprint-compat/api-version.dto.js.map +0 -1
- package/dist/services/moonraker/dto/octoprint-compat/server-version.dto.js.map +0 -1
- package/dist/services/moonraker/dto/printer-query-endstops.dto.js.map +0 -1
- package/dist/services/moonraker/dto/process-stats.dto.js.map +0 -1
- package/dist/services/moonraker/dto/rest/action-result.dto.js.map +0 -1
- package/dist/services/moonraker/dto/rest/error.dto.js.map +0 -1
- package/dist/services/moonraker/dto/rollover-logs.dto.js.map +0 -1
- package/dist/services/moonraker/dto/rpc/json-rpc-error.dto.js.map +0 -1
- package/dist/services/moonraker/dto/rpc/json-rpc-request.dto.js.map +0 -1
- package/dist/services/moonraker/dto/rpc/json-rpc-response.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server/server-config.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-announcements/announcement-action.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-announcements/announcement-entry-id.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-announcements/announcement-feeds.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-announcements/announcement-list.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-files/server-file-directory-action.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-files/server-file-directory-info.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-files/server-file-metadata.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-files/server-file-root.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-files/server-file-thumbnail.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-files/server-file-zip-action.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-files/server-file.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-history/history-job.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-history/history-last-totals.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-history/history-list.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-history/history-totals.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-sensors/sensor-info.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-sensors/sensor-list.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-sensors/sensor-measurements.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-webcams/webcam-item.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-webcams/webcam-list.dto.js.map +0 -1
- package/dist/services/moonraker/dto/server-webcams/webcam-test.dto.js.map +0 -1
- package/dist/services/moonraker/dto/spoolman/spoolman-active-spool.dto.js.map +0 -1
- package/dist/services/moonraker/dto/spoolman/spoolman-proxy-request.dto.js.map +0 -1
- package/dist/services/moonraker/dto/spoolman/spoolman-response.dto.js.map +0 -1
- package/dist/services/moonraker/dto/spoolman/spoolman-status.dto.js.map +0 -1
- package/dist/services/moonraker/dto/sudo-info.dto.js.map +0 -1
- package/dist/services/moonraker/dto/sudo-response.dto.js.map +0 -1
- package/dist/services/moonraker/dto/temperature-store.dto.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/connection-identify-response.dto.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/connection-identify.dto.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/json-rpc-event.dto.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/message.types.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-active-spool-set.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-agent-event.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-announcement-update.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-announcement.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-button-event.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-history-changed.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-job-queue-changed.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-proc-stat-update.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-sensor-update.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-service-state-changed.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-spoolman-status-changed.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-sudo-alert.params.js.map +0 -1
- package/dist/services/moonraker/dto/websocket/notify-user-change.params.js.map +0 -1
- package/dist/services/octoprint/dto/access/user-list.dto.js.map +0 -1
- package/dist/services/octoprint/dto/access/user.dto.js.map +0 -1
- package/dist/services/octoprint/dto/auth/current-user.dto.js.map +0 -1
- package/dist/services/octoprint/dto/auth/login.dto.js.map +0 -1
- package/dist/services/octoprint/dto/connection/connection.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/client-authed.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/client-closed.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/client-opened.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/dwelling.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/file-added.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/file-deselected.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/file-removed.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/folder-added.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/home.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/metadata-analysis-finished.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/metadata-analysis-started.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/metadata-statistics-updated.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/position-update.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/print-cancelled.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/print-cancelling.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/print-done.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/print-failed.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/print-paused.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/print-resumed.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/print-started.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/printer-state-changed.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/transfer-done.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/transfer-started.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/updated-files.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/upload.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/user-logged-in.dto.js.map +0 -1
- package/dist/services/octoprint/dto/events/z-change.dto.js.map +0 -1
- package/dist/services/octoprint/dto/files/gcode-analysis.dto.js.map +0 -1
- package/dist/services/octoprint/dto/files/octoprint-file.dto.js.map +0 -1
- package/dist/services/octoprint/dto/files/octoprint-files-response.dto.js.map +0 -1
- package/dist/services/octoprint/dto/job/job.dto.js.map +0 -1
- package/dist/services/octoprint/dto/printer/busy-file.dto.js.map +0 -1
- package/dist/services/octoprint/dto/printer/current-printer-state.dto.js.map +0 -1
- package/dist/services/octoprint/dto/printer/flags.dto.js.map +0 -1
- package/dist/services/octoprint/dto/printer/markings.dto.js.map +0 -1
- package/dist/services/octoprint/dto/printer/progress.dto.js.map +0 -1
- package/dist/services/octoprint/dto/printer/resends.dto.js.map +0 -1
- package/dist/services/octoprint/dto/printer/state.dto.js.map +0 -1
- package/dist/services/octoprint/dto/printer/temps.dto.js.map +0 -1
- package/dist/services/octoprint/dto/rest/error.dto.js.map +0 -1
- package/dist/services/octoprint/dto/server/server.dto.js.map +0 -1
- package/dist/services/octoprint/dto/server/version.dto.js.map +0 -1
- package/dist/services/octoprint/dto/settings/serial-settings.dto.js.map +0 -1
- package/dist/services/octoprint/dto/settings/settings-parts.type.js.map +0 -1
- package/dist/services/octoprint/dto/settings/settings.dto.js.map +0 -1
- package/dist/services/octoprint/dto/settings/virtual-printer-settings.dto.js.map +0 -1
- package/dist/services/octoprint/dto/websocket/connection-message.dto.js.map +0 -1
- package/dist/services/octoprint/dto/websocket/current-message.dto.js.map +0 -1
- package/dist/services/octoprint/dto/websocket/event-message.dto.js.map +0 -1
- package/dist/services/octoprint/dto/websocket/history-message.dto.js.map +0 -1
- package/dist/services/octoprint/dto/websocket/plugin-message.dto.js.map +0 -1
- package/dist/services/octoprint/dto/websocket/timelapse-message.dto.js.map +0 -1
- package/dist/services/orm/base.interface.js.map +0 -1
- package/dist/services/prusa-link/dto/file-response.dto.js.map +0 -1
- package/dist/services/prusa-link/dto/file.dto.js.map +0 -1
- package/dist/services/prusa-link/dto/job-state.dto.js.map +0 -1
- package/dist/services/prusa-link/dto/printer-state.dto.js.map +0 -1
- package/dist/services/prusa-link/dto/status.dto.js.map +0 -1
- package/dist/services/prusa-link/dto/version.dto.js.map +0 -1
- package/dist/services/prusa-link/utils/digest-auth.params.js.map +0 -1
- package/dist/services/websocket-adapter.interface.js.map +0 -1
- package/dist/shared/dtos/socket-login.dto.js.map +0 -1
- package/dist/types/express/index.d.js.map +0 -1
- package/dist/utils/parsers/parser.types.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/orm/print-job.service.ts"],"names":["PrintJobService","printJobRepository","eventEmitter2","logger","loggerFactory","typeormService","getDataSource","getRepository","PrintJob","name","getJobByIdOrFail","id","relations","job","findOne","where","NotFoundException","handleFileAnalyzed","jobId","metadata","thumbnails","Error","analysisState","analyzedAt","Date","fileFormat","save","emit","printerId","log","fileName","handlePrintStarted","printerName","existingJob","status","order","startedAt","statusReason","endedAt","warn","createdAt","create","progress","statistics","actualPrintTimeSeconds","handlePrintProgress","currentLayer","totalLayers","Math","min","max","undefined","handlePrintCompleted","actualTimeSeconds","calculateJobDuration","updateStatisticsForCompletion","estimatedTimeSeconds","gcodePrintTimeSeconds","toFixed","handlePrintFailed","reason","updateStatisticsForFailure","failedAt","handlePrintCancelled","updateStatisticsForCancellation","cancelledAt","handlePrintPaused","handlePrintResumed","cleanupStaleJobs","staleJobs","find","length","getActivePrintJob","getPrintJobHistory","limit","take","markStarted","markProgress","markFinished","markFailed","updateJobMetadata","partialMetadata","debug","updatedMetadata","key","value","Object","entries","hasData","values","some","v","searchPrintJobs","searchPrinter","searchFile","startDate","endDate","query","createQueryBuilder","andWhere","Number","parseInt","orderBy","getMany","searchPrintJobsPaged","page","pageSize","skip","getManyAndCount","createPendingJob","hasAnalysisData","filamentUsedGrams","totalFilamentUsedGrams","layerHeight","fileSize","toLowerCase","triggerFileAnalysis","markAsCompleted","markAsFailed","markAsCancelled","markAsUnknown","countJobsReferencingFile","fileStorageId","count","updateJob","deleteJob","remove"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"print-job.service.js","names":[],"sources":["../../../src/services/orm/print-job.service.ts"],"sourcesContent":["import { Repository } from \"typeorm\";\nimport { PrintJob, PrintJobMetadata } from \"@/entities/print-job.entity\";\nimport EventEmitter2 from \"eventemitter2\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\nimport { TypeormService } from \"@/services/typeorm/typeorm.service\";\nimport { NotFoundException } from \"@/exceptions/runtime.exceptions\";\nimport {\n updateStatisticsForCompletion,\n updateStatisticsForFailure,\n updateStatisticsForCancellation,\n calculateJobDuration,\n} from \"@/utils/job-stats.util\";\n\n// Events emitted by this service\nexport interface PrintJobAnalyzedEvent {\n jobId: number;\n printerId: number;\n metadata: PrintJobMetadata;\n}\n\nexport interface PrintJobStartedEvent {\n jobId: number;\n printerId: number;\n fileName: string;\n startedAt: Date;\n}\n\nexport interface PrintJobProgressEvent {\n jobId: number;\n printerId: number;\n progress: number;\n currentLayer?: number;\n totalLayers?: number;\n}\n\nexport interface PrintJobCompletedEvent {\n jobId: number;\n printerId: number;\n fileName: string;\n actualTimeSeconds: number;\n estimatedTimeSeconds?: number;\n}\n\nexport interface PrintJobFailedEvent {\n jobId: number;\n printerId: number;\n fileName: string;\n reason: string;\n failedAt: Date;\n}\n\nexport interface PrintJobCancelledEvent {\n jobId: number;\n printerId: number;\n fileName: string;\n cancelledAt: Date;\n}\n\nexport interface IPrintJobService {\n handleFileAnalyzed(jobId: number, metadata: PrintJobMetadata, thumbnails?: any[]): Promise<PrintJob>;\n handlePrintStarted(printerId: number, fileName: string, jobId?: number, printerName?: string): Promise<PrintJob>;\n handlePrintProgress(\n printerId: number,\n progress: number,\n currentLayer?: number,\n totalLayers?: number,\n ): Promise<PrintJob | null>;\n handlePrintCompleted(printerId: number, fileName?: string): Promise<PrintJob | null>;\n handlePrintFailed(printerId: number, reason: string, fileName?: string): Promise<PrintJob | null>;\n handlePrintCancelled(printerId: number, reason?: string): Promise<PrintJob | null>;\n handlePrintPaused(printerId: number): Promise<PrintJob | null>;\n handlePrintResumed(printerId: number): Promise<PrintJob | null>;\n cleanupStaleJobs(): Promise<void>;\n getActivePrintJob(printerId: number): Promise<PrintJob | null>;\n getPrintJobHistory(printerId: number, limit?: number): Promise<PrintJob[]>;\n\n // Helper methods for printer middleware\n markStarted(printerId: number, fileName: string, printerName?: string): Promise<PrintJob>;\n markProgress(\n printerId: number,\n fileName: string,\n progress: number,\n currentLayer?: number,\n totalLayers?: number,\n ): Promise<PrintJob | null>;\n markFinished(printerId: number, fileName: string): Promise<PrintJob | null>;\n markFailed(printerId: number, fileName: string, reason: string): Promise<PrintJob | null>;\n updateJobMetadata(printerId: number, fileName: string, partialMetadata: Partial<PrintJobMetadata>): Promise<void>;\n\n // Search methods for API\n searchPrintJobs(searchPrinter?: string, searchFile?: string, startDate?: Date, endDate?: Date): Promise<PrintJob[]>;\n searchPrintJobsPaged(\n searchPrinter?: string,\n searchFile?: string,\n startDate?: Date,\n endDate?: Date,\n page?: number,\n pageSize?: number,\n ): Promise<[PrintJob[], number]>;\n\n // Job creation\n createPendingJob(\n printerId: number,\n fileName: string,\n metadata: PrintJobMetadata,\n printerName?: string,\n ): Promise<PrintJob>;\n\n // File download and analysis\n triggerFileAnalysis(jobId: number): Promise<void>;\n\n // Manual status updates\n markAsCompleted(jobId: number, reason?: string): Promise<PrintJob>;\n markAsFailed(jobId: number, reason: string): Promise<PrintJob>;\n markAsCancelled(jobId: number, reason?: string): Promise<PrintJob>;\n markAsUnknown(jobId: number, reason?: string): Promise<PrintJob>;\n\n // File reference counting\n countJobsReferencingFile(fileStorageId: string): Promise<number>;\n\n // Job management\n updateJob(job: PrintJob): Promise<PrintJob>;\n deleteJob(job: PrintJob): Promise<void>;\n}\n\nexport class PrintJobService implements IPrintJobService {\n printJobRepository: Repository<PrintJob>;\n eventEmitter2: EventEmitter2;\n private readonly logger;\n\n constructor(loggerFactory: ILoggerFactory, typeormService: TypeormService, eventEmitter2: EventEmitter2) {\n this.printJobRepository = typeormService.getDataSource().getRepository(PrintJob);\n this.eventEmitter2 = eventEmitter2;\n this.logger = loggerFactory(PrintJobService.name);\n }\n\n async getJobByIdOrFail(id: number, relations?: string[]): Promise<PrintJob> {\n const job = await this.printJobRepository.findOne({\n where: { id },\n relations,\n });\n if (!job) {\n throw new NotFoundException(`Job ${id} not found`);\n }\n return job;\n }\n\n async handleFileAnalyzed(jobId: number, metadata: PrintJobMetadata, thumbnails?: any[]): Promise<PrintJob> {\n const job = await this.printJobRepository.findOne({ where: { id: jobId } });\n if (!job) {\n throw new Error(`Print job ${jobId} not found`);\n }\n\n job.metadata = metadata;\n job.analysisState = \"ANALYZED\";\n job.analyzedAt = new Date();\n // Status remains unchanged - analysis state is separate from job status\n job.fileFormat = metadata.fileFormat;\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.analyzed\", {\n jobId: job.id,\n printerId: job.printerId,\n metadata,\n } as PrintJobAnalyzedEvent);\n\n this.logger.log(`Print job ${jobId} analyzed: ${metadata.fileName}`);\n return job;\n }\n\n async handlePrintStarted(\n printerId: number,\n fileName: string,\n jobId?: number,\n printerName?: string,\n ): Promise<PrintJob> {\n const existingJob = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (existingJob?.fileName === fileName && !jobId) {\n return existingJob;\n }\n\n // Different file is printing - mark the old one as UNKNOWN\n if (existingJob && existingJob.fileName !== fileName && !jobId) {\n existingJob.status = \"UNKNOWN\";\n existingJob.statusReason =\n \"Print state unknown - printer started new job while previous job was still marked as printing. \" +\n \"This may indicate a disconnect, server restart, or manual printer control.\";\n existingJob.endedAt = new Date();\n await this.printJobRepository.save(existingJob);\n\n this.logger.warn(\n `Printer ${printerId} started new print \"${fileName}\" while job ${existingJob.id} was PRINTING \"${existingJob.fileName}\". ` +\n `Marked job ${existingJob.id} as UNKNOWN.`,\n );\n }\n\n let job: PrintJob | null;\n if (jobId) {\n job = await this.printJobRepository.findOne({ where: { id: jobId } });\n if (!job) {\n throw new Error(`Print job ${jobId} not found`);\n }\n } else {\n // First, look for a PENDING job (created during upload)\n job = await this.printJobRepository.findOne({\n where: { printerId, fileName, status: \"PENDING\" },\n order: { createdAt: \"DESC\" },\n });\n\n // If no pending/analyzed job, look for any recent job with this filename\n if (!job) {\n job = await this.printJobRepository.findOne({\n where: { printerId, fileName },\n order: { createdAt: \"DESC\" },\n });\n }\n\n // If still no job, create a new one\n if (!job) {\n this.logger.log(`Creating new job for ${fileName} - no pending or existing job found`);\n job = this.printJobRepository.create({\n printerId,\n printerName: printerName || null,\n fileName,\n status: \"PRINTING\",\n analysisState: \"NOT_ANALYZED\",\n });\n } else if (job.status === \"PENDING\") {\n this.logger.log(`Promoting pending job ${job.id} to PRINTING`);\n } else if (job.status === \"COMPLETED\" || job.status === \"FAILED\" || job.status === \"CANCELLED\") {\n // Don't reuse completed jobs - this is a re-print, create new job\n this.logger.log(`Creating new job for re-print of ${fileName} (previous job ${job.id} was ${job.status})`);\n job = this.printJobRepository.create({\n printerId,\n printerName: printerName || job.printerName || null,\n fileName,\n status: \"PRINTING\",\n analysisState: job.analysisState, // Keep analysis state from previous print\n metadata: job.metadata, // Reuse metadata from previous print\n fileFormat: job.fileFormat,\n });\n }\n }\n\n job.status = \"PRINTING\";\n job.startedAt = new Date();\n job.progress = 0;\n\n // Set/update printerName if provided\n if (printerName && !job.printerName) {\n job.printerName = printerName;\n }\n\n if (!job.statistics) {\n job.statistics = {\n startedAt: new Date(),\n endedAt: null,\n actualPrintTimeSeconds: null,\n progress: 0,\n };\n } else {\n job.statistics.startedAt = new Date();\n job.statistics.progress = 0;\n }\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.started\", {\n jobId: job.id,\n printerId,\n fileName,\n startedAt: job.startedAt,\n } as PrintJobStartedEvent);\n\n this.logger.log(`Print job ${job.id} started on printer ${printerId}: ${fileName}`);\n return job;\n }\n\n async handlePrintProgress(printerId: number, progress: number): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n return null;\n }\n\n job.progress = Math.min(100, Math.max(0, progress));\n\n if (job.statistics) {\n job.statistics.progress = job.progress;\n } else {\n job.statistics = {\n startedAt: job.startedAt,\n endedAt: null,\n actualPrintTimeSeconds: null,\n progress: job.progress,\n };\n }\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.progress\", {\n jobId: job.id,\n printerId,\n progress: job.progress,\n } as PrintJobProgressEvent);\n\n return job;\n }\n\n async handlePrintCompleted(printerId: number, fileName?: string): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No active print job found for printer ${printerId} on completion`);\n return null;\n }\n\n if (fileName && job.fileName !== fileName) {\n this.logger.warn(`Filename mismatch on completion: expected \"${job.fileName}\", got \"${fileName}\"`);\n }\n\n const endedAt = new Date();\n const actualTimeSeconds = calculateJobDuration(job.startedAt, endedAt);\n\n job.status = \"COMPLETED\";\n updateStatisticsForCompletion(job, endedAt);\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.completed\", {\n jobId: job.id,\n printerId,\n fileName: job.fileName,\n actualTimeSeconds,\n estimatedTimeSeconds: job.metadata?.gcodePrintTimeSeconds,\n } as PrintJobCompletedEvent);\n\n this.logger.log(\n `Print job ${job.id} completed on printer ${printerId}: ${job.fileName} ` +\n `(${actualTimeSeconds?.toFixed(0)}s actual, ${job.metadata?.gcodePrintTimeSeconds}s estimated)`,\n );\n\n return job;\n }\n\n async handlePrintFailed(printerId: number, reason: string, fileName?: string): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No active print job found for printer ${printerId} on failure`);\n return null;\n }\n\n const endedAt = new Date();\n\n job.status = \"FAILED\";\n updateStatisticsForFailure(job, reason, endedAt);\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.failed\", {\n jobId: job.id,\n printerId,\n fileName: job.fileName,\n reason,\n failedAt: endedAt,\n } as PrintJobFailedEvent);\n\n this.logger.log(`Print job ${job.id} failed on printer ${printerId}: ${job.fileName} - ${reason}`);\n\n return job;\n }\n\n async handlePrintCancelled(printerId: number, reason?: string): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No active print job found for printer ${printerId} on cancellation`);\n return null;\n }\n\n const endedAt = new Date();\n\n job.status = \"CANCELLED\";\n updateStatisticsForCancellation(job, reason, endedAt);\n\n await this.printJobRepository.save(job);\n\n this.eventEmitter2.emit(\"printJob.cancelled\", {\n jobId: job.id,\n printerId,\n fileName: job.fileName,\n cancelledAt: endedAt,\n } as PrintJobCancelledEvent);\n\n this.logger.log(`Print job ${job.id} cancelled on printer ${printerId}: ${job.fileName}`);\n return job;\n }\n\n async handlePrintPaused(printerId: number): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No active print job found for printer ${printerId} on pause`);\n return null;\n }\n\n job.status = \"PAUSED\";\n await this.printJobRepository.save(job);\n\n this.logger.log(`Print job ${job.id} paused on printer ${printerId}`);\n return job;\n }\n\n async handlePrintResumed(printerId: number): Promise<PrintJob | null> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, status: \"PAUSED\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.warn(`No paused print job found for printer ${printerId} on resume`);\n return null;\n }\n\n job.status = \"PRINTING\";\n await this.printJobRepository.save(job);\n\n this.logger.log(`Print job ${job.id} resumed on printer ${printerId}`);\n return job;\n }\n\n async cleanupStaleJobs(): Promise<void> {\n const staleJobs = await this.printJobRepository.find({\n where: { status: \"PRINTING\" },\n });\n\n for (const job of staleJobs) {\n job.status = \"UNKNOWN\";\n job.statusReason =\n \"Print state unknown after server restart. The print may have completed, \" +\n \"failed, or still be running. Check your printer for current status.\";\n await this.printJobRepository.save(job);\n\n this.logger.warn(\n `Marked job ${job.id} (printer ${job.printerId}) as UNKNOWN after startup - ` +\n `was PRINTING before server stopped`,\n );\n }\n\n if (staleJobs.length > 0) {\n this.logger.log(`Cleaned up ${staleJobs.length} stale print job(s) on startup`);\n }\n }\n\n async getActivePrintJob(printerId: number): Promise<PrintJob | null> {\n return this.printJobRepository.findOne({\n where: { printerId, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n }\n\n async getPrintJobHistory(printerId: number, limit: number = 50): Promise<PrintJob[]> {\n return this.printJobRepository.find({\n where: { printerId },\n order: { createdAt: \"DESC\" },\n take: limit,\n });\n }\n\n async markStarted(printerId: number, fileName: string, printerName?: string): Promise<PrintJob> {\n return await this.handlePrintStarted(printerId, fileName, undefined, printerName);\n }\n\n async markProgress(printerId: number, fileName: string, progress: number): Promise<PrintJob | null> {\n return await this.handlePrintProgress(printerId, progress);\n }\n\n /**\n * Mark print as finished by fileName\n * Used by printer middleware when print completes successfully\n */\n async markFinished(printerId: number, fileName: string): Promise<PrintJob | null> {\n return await this.handlePrintCompleted(printerId, fileName);\n }\n\n /**\n * Mark print as failed by fileName\n * Used by printer middleware when print fails\n */\n async markFailed(printerId: number, fileName: string, reason: string): Promise<PrintJob | null> {\n return await this.handlePrintFailed(printerId, reason, fileName);\n }\n\n /**\n * Update job metadata with partial data from printer middleware\n * Useful for updating estimates from OctoPrint/Moonraker during print\n * Only updates if job has no metadata or to supplement existing metadata\n */\n async updateJobMetadata(\n printerId: number,\n fileName: string,\n partialMetadata: Partial<PrintJobMetadata>,\n ): Promise<void> {\n const job = await this.printJobRepository.findOne({\n where: { printerId, fileName, status: \"PRINTING\" },\n order: { startedAt: \"DESC\" },\n });\n\n if (!job) {\n this.logger.debug(`No active job found for printer ${printerId}, file ${fileName} - skipping metadata update`);\n return;\n }\n\n // If job already has ANALYZED metadata, don't overwrite with incomplete data\n if (job.analysisState === \"ANALYZED\" && job.metadata) {\n this.logger.debug(`Job ${job.id} already has analyzed metadata, merging only missing fields`);\n // Only merge in fields that are currently null/undefined\n const updatedMetadata = { ...job.metadata } as Record<string, any>;\n for (const [key, value] of Object.entries(partialMetadata)) {\n if (value != null && (updatedMetadata[key] == null || updatedMetadata[key] === null)) {\n updatedMetadata[key] = value;\n }\n }\n job.metadata = updatedMetadata as PrintJobMetadata;\n } else if (job.metadata) {\n // Merge partial metadata with existing metadata\n job.metadata = {\n ...job.metadata,\n ...partialMetadata,\n } as PrintJobMetadata;\n } else {\n // No metadata exists - only create if we have meaningful data\n // Don't create metadata structure with mostly nulls\n const hasData = Object.values(partialMetadata).some((v) => v !== null);\n if (!hasData) {\n this.logger.debug(`Skipping metadata creation for job ${job.id} - no meaningful data provided`);\n return;\n }\n\n // Create minimal metadata structure\n job.metadata = {\n fileName,\n fileFormat: job.fileFormat || \"gcode\", // Use existing fileFormat or default\n ...partialMetadata,\n } as PrintJobMetadata;\n }\n\n await this.printJobRepository.save(job);\n this.logger.debug(`Updated metadata for job ${job.id}`);\n }\n\n // ========== Search methods for API ==========\n\n /**\n * Search print jobs with optional filters\n */\n async searchPrintJobs(\n searchPrinter?: string,\n searchFile?: string,\n startDate?: Date,\n endDate?: Date,\n ): Promise<PrintJob[]> {\n const query = this.printJobRepository.createQueryBuilder(\"job\");\n\n if (searchPrinter) {\n query.andWhere(\"job.printerId = :printerId\", { printerId: Number.parseInt(searchPrinter, 10) });\n }\n\n if (searchFile) {\n query.andWhere(\"job.fileName LIKE :fileName\", { fileName: `%${searchFile}%` });\n }\n\n if (startDate) {\n query.andWhere(\"job.startedAt >= :startDate\", { startDate });\n }\n\n if (endDate) {\n query.andWhere(\"job.startedAt <= :endDate\", { endDate });\n }\n\n return await query.orderBy(\"job.startedAt\", \"DESC\").getMany();\n }\n\n /**\n * Search print jobs with pagination\n */\n async searchPrintJobsPaged(\n searchPrinter?: string,\n searchFile?: string,\n startDate?: Date,\n endDate?: Date,\n page: number = 1,\n pageSize: number = 50,\n ): Promise<[PrintJob[], number]> {\n const query = this.printJobRepository.createQueryBuilder(\"job\");\n\n if (searchPrinter) {\n query.andWhere(\"job.printerId = :printerId\", { printerId: Number.parseInt(searchPrinter, 10) });\n }\n\n if (searchFile) {\n query.andWhere(\"job.fileName LIKE :fileName\", { fileName: `%${searchFile}%` });\n }\n\n if (startDate) {\n query.andWhere(\"job.startedAt >= :startDate\", { startDate });\n }\n\n if (endDate) {\n query.andWhere(\"job.startedAt <= :endDate\", { endDate });\n }\n\n return await query\n .orderBy(\"job.startedAt\", \"DESC\")\n .skip((page - 1) * pageSize)\n .take(pageSize)\n .getManyAndCount();\n }\n\n // ========== Job creation ==========\n\n /**\n * Create a pending print job (typically called when file is uploaded)\n * Used when a file is uploaded to a printer, creating a job ready for analysis\n */\n async createPendingJob(\n printerId: number,\n fileName: string,\n metadata: PrintJobMetadata,\n printerName?: string,\n ): Promise<PrintJob> {\n // Determine if metadata contains meaningful analysis data\n // (more than just basic file info)\n const hasAnalysisData =\n metadata.gcodePrintTimeSeconds !== null ||\n metadata.filamentUsedGrams !== null ||\n metadata.totalFilamentUsedGrams !== null ||\n metadata.layerHeight !== null ||\n metadata.totalLayers !== null;\n\n const analysisState = hasAnalysisData ? \"ANALYZED\" : \"NOT_ANALYZED\";\n // Status is always PENDING for newly created jobs (analysis state is separate)\n const status = \"PENDING\";\n\n const job = this.printJobRepository.create({\n printerId,\n printerName: printerName || null,\n fileName,\n status,\n analysisState,\n metadata,\n fileFormat: metadata.fileFormat,\n fileSize: metadata.fileSize,\n analyzedAt: hasAnalysisData ? new Date() : null,\n });\n\n await this.printJobRepository.save(job);\n\n this.logger.log(\n `Created ${analysisState.toLowerCase()} print job ${job.id} for printer ${printerId}: ${fileName} (format: ${metadata.fileFormat})`,\n );\n return job;\n }\n\n /**\n * Trigger file analysis for a job (emits event for async processing)\n * Used when a print starts from a file on the printer that we don't have locally\n */\n async triggerFileAnalysis(jobId: number): Promise<void> {\n this.eventEmitter2.emit(\"printJob.needsFileDownload\", { jobId });\n this.logger.log(`Triggered file download and analysis for job ${jobId}`);\n }\n\n async markAsCompleted(jobId: number, reason?: string): Promise<PrintJob> {\n const job = await this.getJobByIdOrFail(jobId);\n\n job.status = \"COMPLETED\";\n updateStatisticsForCompletion(job);\n\n if (reason) {\n job.statusReason = reason;\n } else {\n job.statusReason = \"Manually marked as completed by user\";\n }\n\n await this.printJobRepository.save(job);\n\n this.logger.log(`Job ${jobId} manually marked as COMPLETED`);\n\n return job;\n }\n\n async markAsFailed(jobId: number, reason: string): Promise<PrintJob> {\n const job = await this.getJobByIdOrFail(jobId);\n\n job.status = \"FAILED\";\n updateStatisticsForFailure(job, reason);\n\n await this.printJobRepository.save(job);\n\n this.logger.log(`Job ${jobId} manually marked as FAILED: ${reason}`);\n\n return job;\n }\n\n async markAsCancelled(jobId: number, reason?: string): Promise<PrintJob> {\n const job = await this.getJobByIdOrFail(jobId);\n\n job.status = \"CANCELLED\";\n updateStatisticsForCancellation(job, reason);\n\n await this.printJobRepository.save(job);\n\n this.logger.log(`Job ${jobId} manually marked as CANCELLED`);\n\n return job;\n }\n\n async markAsUnknown(jobId: number, reason?: string): Promise<PrintJob> {\n const job = await this.getJobByIdOrFail(jobId);\n\n job.status = \"UNKNOWN\";\n job.statusReason = reason || \"Manually marked as unknown by user (state uncertain)\";\n\n await this.printJobRepository.save(job);\n\n this.logger.log(`Job ${jobId} manually marked as UNKNOWN`);\n\n return job;\n }\n\n async countJobsReferencingFile(fileStorageId: string): Promise<number> {\n return await this.printJobRepository.count({\n where: { fileStorageId },\n });\n }\n\n async updateJob(job: PrintJob): Promise<PrintJob> {\n return await this.printJobRepository.save(job);\n }\n\n async deleteJob(job: PrintJob): Promise<void> {\n await this.printJobRepository.remove(job);\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,151 +1,104 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
completed: false
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
async list(filters) {
|
|
108
|
-
const { printerId, completed, page = 1, pageSize = 20 } = filters;
|
|
109
|
-
const queryBuilder = this.repository.createQueryBuilder("log");
|
|
110
|
-
if (printerId !== undefined) {
|
|
111
|
-
queryBuilder.andWhere("log.printerId = :printerId", {
|
|
112
|
-
printerId
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
if (completed !== undefined) {
|
|
116
|
-
queryBuilder.andWhere("log.completed = :completed", {
|
|
117
|
-
completed
|
|
118
|
-
});
|
|
119
|
-
}
|
|
120
|
-
queryBuilder.orderBy("log.createdAt", "DESC");
|
|
121
|
-
queryBuilder.skip((page - 1) * pageSize);
|
|
122
|
-
queryBuilder.take(pageSize);
|
|
123
|
-
const [logs, total] = await queryBuilder.getManyAndCount();
|
|
124
|
-
return {
|
|
125
|
-
logs,
|
|
126
|
-
total
|
|
127
|
-
};
|
|
128
|
-
}
|
|
129
|
-
async delete(logId) {
|
|
130
|
-
const log = await this.get(logId);
|
|
131
|
-
if (!log.completed && log.printerId) {
|
|
132
|
-
await this.printerService.updateDisabledReason(log.printerId, null);
|
|
133
|
-
}
|
|
134
|
-
await this.repository.delete(logId);
|
|
135
|
-
}
|
|
136
|
-
buildDisabledReasonFromMetadata(metadata) {
|
|
137
|
-
const parts = [];
|
|
138
|
-
if (metadata.cause) {
|
|
139
|
-
parts.push(metadata.cause);
|
|
140
|
-
}
|
|
141
|
-
if (metadata.partsInvolved && metadata.partsInvolved.length > 0) {
|
|
142
|
-
parts.push(`Parts: ${metadata.partsInvolved.join(", ")}`);
|
|
143
|
-
}
|
|
144
|
-
if (metadata.notes) {
|
|
145
|
-
parts.push(metadata.notes);
|
|
146
|
-
}
|
|
147
|
-
return parts.join(" - ") || "Under maintenance";
|
|
148
|
-
}
|
|
149
|
-
}
|
|
1
|
+
import { BadRequestException, NotFoundException } from "../../exceptions/runtime.exceptions.js";
|
|
2
|
+
import { PrinterMaintenanceLog } from "../../entities/printer-maintenance-log.entity.js";
|
|
3
|
+
//#region src/services/orm/printer-maintenance-log.service.ts
|
|
4
|
+
var PrinterMaintenanceLogService = class PrinterMaintenanceLogService {
|
|
5
|
+
logger;
|
|
6
|
+
repository;
|
|
7
|
+
constructor(loggerFactory, typeormService, printerService) {
|
|
8
|
+
this.printerService = printerService;
|
|
9
|
+
this.logger = loggerFactory(PrinterMaintenanceLogService.name);
|
|
10
|
+
this.repository = typeormService.getDataSource().getRepository(PrinterMaintenanceLog);
|
|
11
|
+
}
|
|
12
|
+
toDto(entity) {
|
|
13
|
+
return {
|
|
14
|
+
id: entity.id,
|
|
15
|
+
createdAt: entity.createdAt,
|
|
16
|
+
createdBy: entity.createdBy,
|
|
17
|
+
createdByUserId: entity.createdByUserId,
|
|
18
|
+
printerId: entity.printerId,
|
|
19
|
+
printerName: entity.printerName,
|
|
20
|
+
printerUrl: entity.printerUrl,
|
|
21
|
+
metadata: entity.metadata,
|
|
22
|
+
completed: entity.completed,
|
|
23
|
+
completedAt: entity.completedAt,
|
|
24
|
+
completedByUserId: entity.completedByUserId,
|
|
25
|
+
completedBy: entity.completedBy
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
async create(dto, userId, username) {
|
|
29
|
+
const printer = await this.printerService.get(dto.printerId);
|
|
30
|
+
if (await this.repository.findOne({ where: {
|
|
31
|
+
printerId: dto.printerId,
|
|
32
|
+
completed: false
|
|
33
|
+
} })) throw new BadRequestException(`Printer ${printer.name} already has an active maintenance log`);
|
|
34
|
+
const log = this.repository.create({
|
|
35
|
+
printerId: dto.printerId,
|
|
36
|
+
printerName: printer.name,
|
|
37
|
+
printerUrl: printer.printerURL,
|
|
38
|
+
metadata: dto.metadata,
|
|
39
|
+
createdBy: username,
|
|
40
|
+
createdByUserId: userId,
|
|
41
|
+
completed: false
|
|
42
|
+
});
|
|
43
|
+
await this.repository.save(log);
|
|
44
|
+
await this.printerService.updateDisabledReason(dto.printerId, this.buildDisabledReasonFromMetadata(dto.metadata));
|
|
45
|
+
return log;
|
|
46
|
+
}
|
|
47
|
+
async complete(logId, dto, userId, username) {
|
|
48
|
+
const log = await this.repository.findOne({ where: { id: logId } });
|
|
49
|
+
if (!log) throw new NotFoundException(`Maintenance log with id ${logId} not found`);
|
|
50
|
+
if (log.completed) throw new BadRequestException(`Maintenance log ${logId} is already completed`);
|
|
51
|
+
log.metadata = {
|
|
52
|
+
...log.metadata,
|
|
53
|
+
completionNotes: dto.completionNotes
|
|
54
|
+
};
|
|
55
|
+
log.completed = true;
|
|
56
|
+
log.completedAt = /* @__PURE__ */ new Date();
|
|
57
|
+
log.completedBy = username;
|
|
58
|
+
log.completedByUserId = userId;
|
|
59
|
+
await this.repository.save(log);
|
|
60
|
+
if (log.printerId) await this.printerService.updateDisabledReason(log.printerId, null);
|
|
61
|
+
return log;
|
|
62
|
+
}
|
|
63
|
+
async get(logId) {
|
|
64
|
+
const log = await this.repository.findOne({ where: { id: logId } });
|
|
65
|
+
if (!log) throw new NotFoundException(`Maintenance log with id ${logId} not found`);
|
|
66
|
+
return log;
|
|
67
|
+
}
|
|
68
|
+
async getActiveByPrinterId(printerId) {
|
|
69
|
+
return this.repository.findOne({ where: {
|
|
70
|
+
printerId,
|
|
71
|
+
completed: false
|
|
72
|
+
} });
|
|
73
|
+
}
|
|
74
|
+
async list(filters) {
|
|
75
|
+
const { printerId, completed, page = 1, pageSize = 20 } = filters;
|
|
76
|
+
const queryBuilder = this.repository.createQueryBuilder("log");
|
|
77
|
+
if (printerId !== void 0) queryBuilder.andWhere("log.printerId = :printerId", { printerId });
|
|
78
|
+
if (completed !== void 0) queryBuilder.andWhere("log.completed = :completed", { completed });
|
|
79
|
+
queryBuilder.orderBy("log.createdAt", "DESC");
|
|
80
|
+
queryBuilder.skip((page - 1) * pageSize);
|
|
81
|
+
queryBuilder.take(pageSize);
|
|
82
|
+
const [logs, total] = await queryBuilder.getManyAndCount();
|
|
83
|
+
return {
|
|
84
|
+
logs,
|
|
85
|
+
total
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
async delete(logId) {
|
|
89
|
+
const log = await this.get(logId);
|
|
90
|
+
if (!log.completed && log.printerId) await this.printerService.updateDisabledReason(log.printerId, null);
|
|
91
|
+
await this.repository.delete(logId);
|
|
92
|
+
}
|
|
93
|
+
buildDisabledReasonFromMetadata(metadata) {
|
|
94
|
+
const parts = [];
|
|
95
|
+
if (metadata.cause) parts.push(metadata.cause);
|
|
96
|
+
if (metadata.partsInvolved && metadata.partsInvolved.length > 0) parts.push(`Parts: ${metadata.partsInvolved.join(", ")}`);
|
|
97
|
+
if (metadata.notes) parts.push(metadata.notes);
|
|
98
|
+
return parts.join(" - ") || "Under maintenance";
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
//#endregion
|
|
102
|
+
export { PrinterMaintenanceLogService };
|
|
150
103
|
|
|
151
104
|
//# sourceMappingURL=printer-maintenance-log.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/orm/printer-maintenance-log.service.ts"],"
|
|
1
|
+
{"version":3,"file":"printer-maintenance-log.service.js","names":[],"sources":["../../../src/services/orm/printer-maintenance-log.service.ts"],"sourcesContent":["import { Repository } from \"typeorm\";\nimport { PrinterMaintenanceLog } from \"@/entities/printer-maintenance-log.entity\";\nimport { TypeormService } from \"@/services/typeorm/typeorm.service\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\nimport { LoggerService } from \"@/handlers/logger\";\nimport {\n CreateMaintenanceLogDto,\n PrinterMaintenanceLogDto,\n CompleteMaintenanceLogDto,\n} from \"@/services/interfaces/printer-maintenance-log.dto\";\nimport { BadRequestException, NotFoundException } from \"@/exceptions/runtime.exceptions\";\nimport type { IPrinterService } from \"@/services/interfaces/printer.service.interface\";\n\nexport class PrinterMaintenanceLogService {\n private readonly logger: LoggerService;\n private readonly repository: Repository<PrinterMaintenanceLog>;\n\n constructor(\n loggerFactory: ILoggerFactory,\n typeormService: TypeormService,\n private readonly printerService: IPrinterService,\n ) {\n this.logger = loggerFactory(PrinterMaintenanceLogService.name);\n this.repository = typeormService.getDataSource().getRepository(PrinterMaintenanceLog);\n }\n\n toDto(entity: PrinterMaintenanceLog): PrinterMaintenanceLogDto {\n return {\n id: entity.id,\n createdAt: entity.createdAt,\n createdBy: entity.createdBy,\n createdByUserId: entity.createdByUserId,\n printerId: entity.printerId,\n printerName: entity.printerName,\n printerUrl: entity.printerUrl,\n metadata: entity.metadata,\n completed: entity.completed,\n completedAt: entity.completedAt,\n completedByUserId: entity.completedByUserId,\n completedBy: entity.completedBy,\n };\n }\n\n async create(dto: CreateMaintenanceLogDto, userId: number | null, username: string): Promise<PrinterMaintenanceLog> {\n // Get printer details\n const printer = await this.printerService.get(dto.printerId);\n\n // Check if there's already an active maintenance log for this printer\n const existingLog = await this.repository.findOne({\n where: {\n printerId: dto.printerId,\n completed: false,\n },\n });\n\n if (existingLog) {\n throw new BadRequestException(`Printer ${printer.name} already has an active maintenance log`);\n }\n\n const log = this.repository.create({\n printerId: dto.printerId,\n printerName: printer.name,\n printerUrl: printer.printerURL,\n metadata: dto.metadata,\n createdBy: username,\n createdByUserId: userId,\n completed: false,\n });\n\n await this.repository.save(log);\n\n // Update printer disabled reason for backwards compatibility\n await this.printerService.updateDisabledReason(dto.printerId, this.buildDisabledReasonFromMetadata(dto.metadata));\n\n return log;\n }\n\n async complete(\n logId: number,\n dto: CompleteMaintenanceLogDto,\n userId: number | null,\n username: string,\n ): Promise<PrinterMaintenanceLog> {\n const log = await this.repository.findOne({ where: { id: logId } });\n\n if (!log) {\n throw new NotFoundException(`Maintenance log with id ${logId} not found`);\n }\n\n if (log.completed) {\n throw new BadRequestException(`Maintenance log ${logId} is already completed`);\n }\n\n // Update metadata with completion notes\n log.metadata = {\n ...log.metadata,\n completionNotes: dto.completionNotes,\n };\n\n log.completed = true;\n log.completedAt = new Date();\n log.completedBy = username;\n log.completedByUserId = userId;\n\n await this.repository.save(log);\n\n // Clear printer disabled reason\n if (log.printerId) {\n await this.printerService.updateDisabledReason(log.printerId, null);\n }\n\n return log;\n }\n\n async get(logId: number): Promise<PrinterMaintenanceLog> {\n const log = await this.repository.findOne({ where: { id: logId } });\n\n if (!log) {\n throw new NotFoundException(`Maintenance log with id ${logId} not found`);\n }\n\n return log;\n }\n\n async getActiveByPrinterId(printerId: number): Promise<PrinterMaintenanceLog | null> {\n return this.repository.findOne({\n where: {\n printerId,\n completed: false,\n },\n });\n }\n\n async list(filters: {\n printerId?: number;\n completed?: boolean;\n page?: number;\n pageSize?: number;\n }): Promise<{ logs: PrinterMaintenanceLog[]; total: number }> {\n const { printerId, completed, page = 1, pageSize = 20 } = filters;\n\n const queryBuilder = this.repository.createQueryBuilder(\"log\");\n\n if (printerId !== undefined) {\n queryBuilder.andWhere(\"log.printerId = :printerId\", { printerId });\n }\n\n if (completed !== undefined) {\n queryBuilder.andWhere(\"log.completed = :completed\", { completed });\n }\n\n queryBuilder.orderBy(\"log.createdAt\", \"DESC\");\n queryBuilder.skip((page - 1) * pageSize);\n queryBuilder.take(pageSize);\n\n const [logs, total] = await queryBuilder.getManyAndCount();\n\n return { logs, total };\n }\n\n async delete(logId: number): Promise<void> {\n const log = await this.get(logId);\n\n // Clear printer disabled reason if log is active\n if (!log.completed && log.printerId) {\n await this.printerService.updateDisabledReason(log.printerId, null);\n }\n\n await this.repository.delete(logId);\n }\n\n private buildDisabledReasonFromMetadata(metadata: {\n cause?: string;\n notes?: string;\n partsInvolved?: string[];\n }): string {\n const parts: string[] = [];\n\n if (metadata.cause) {\n parts.push(metadata.cause);\n }\n\n if (metadata.partsInvolved && metadata.partsInvolved.length > 0) {\n parts.push(`Parts: ${metadata.partsInvolved.join(\", \")}`);\n }\n\n if (metadata.notes) {\n parts.push(metadata.notes);\n }\n\n return parts.join(\" - \") || \"Under maintenance\";\n }\n}\n"],"mappings":"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"}
|