@fdm-monster/server 1.9.4 → 2.0.0
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/.env.template +8 -7
- package/.yarn/install-state.gz +0 -0
- package/CONTRIBUTING.md +5 -5
- package/README.md +9 -8
- package/RELEASE_NOTES.MD +52 -0
- package/SECURITY.md +1 -1
- package/biome.json +8 -5
- package/dist/consoles/download-github-releases.js +3 -3
- package/dist/consoles/launch-http-servers.js +4 -4
- package/dist/consoles/launch-http-servers.js.map +1 -1
- package/dist/consoles/mock-bambu.server.js +50 -30
- package/dist/consoles/mock-bambu.server.js.map +1 -1
- package/dist/consoles/mock-camera/default-image.js +13 -0
- package/dist/consoles/mock-camera/default-image.js.map +1 -0
- package/dist/consoles/mock-camera/mock-camera.server.js +160 -0
- package/dist/consoles/mock-camera/mock-camera.server.js.map +1 -0
- package/dist/consoles/mock-octoprint.server.js +281 -73
- package/dist/consoles/mock-octoprint.server.js.map +1 -1
- package/dist/consoles/mock-prusalink.server.js +17 -17
- package/dist/consoles/mock-prusalink.server.js.map +1 -1
- package/dist/consoles/typeorm-create.js +135 -0
- package/dist/consoles/typeorm-create.js.map +1 -0
- package/dist/consoles/typeorm-generate.js +8 -8
- package/dist/consoles/typeorm-generate.js.map +1 -1
- package/dist/consoles/utils/api-messages.js.map +1 -1
- package/dist/constants/authorization.constants.js +25 -31
- package/dist/constants/authorization.constants.js.map +1 -1
- package/dist/constants/event.constants.js.map +1 -1
- package/dist/constants/server-settings.constants.js +3 -19
- package/dist/constants/server-settings.constants.js.map +1 -1
- package/dist/container.js +43 -59
- package/dist/container.js.map +1 -1
- package/dist/container.tokens.js +9 -6
- package/dist/container.tokens.js.map +1 -1
- package/dist/controllers/auth.controller.js +1 -1
- package/dist/controllers/auth.controller.js.map +1 -1
- package/dist/controllers/batch-call.controller.js +7 -25
- package/dist/controllers/batch-call.controller.js.map +1 -1
- package/dist/controllers/file-storage.controller.js +248 -0
- package/dist/controllers/file-storage.controller.js.map +1 -0
- package/dist/controllers/first-time-setup.controller.js +6 -5
- package/dist/controllers/first-time-setup.controller.js.map +1 -1
- package/dist/controllers/floor.controller.js +12 -12
- package/dist/controllers/floor.controller.js.map +1 -1
- package/dist/controllers/metrics.controller.js.map +1 -1
- package/dist/controllers/print-job.controller.js +666 -0
- package/dist/controllers/print-job.controller.js.map +1 -0
- package/dist/controllers/print-queue.controller.js +375 -0
- package/dist/controllers/print-queue.controller.js.map +1 -0
- package/dist/controllers/printer-files.controller.js +88 -59
- package/dist/controllers/printer-files.controller.js.map +1 -1
- package/dist/controllers/printer-settings.controller.js +0 -21
- package/dist/controllers/printer-settings.controller.js.map +1 -1
- package/dist/controllers/{printer-group.controller.js → printer-tag.controller.js} +51 -34
- package/dist/controllers/printer-tag.controller.js.map +1 -0
- package/dist/controllers/printer.controller.js +21 -7
- package/dist/controllers/printer.controller.js.map +1 -1
- package/dist/controllers/server-private.controller.js +2 -1
- package/dist/controllers/server-private.controller.js.map +1 -1
- package/dist/controllers/server-public.controller.js +11 -15
- package/dist/controllers/server-public.controller.js.map +1 -1
- package/dist/controllers/settings.controller.js +0 -68
- package/dist/controllers/settings.controller.js.map +1 -1
- package/dist/controllers/slicer-compat.controller.js +216 -0
- package/dist/controllers/slicer-compat.controller.js.map +1 -0
- package/dist/controllers/user.controller.js +8 -12
- package/dist/controllers/user.controller.js.map +1 -1
- package/dist/controllers/validation/batch-controller.validation.js +13 -13
- package/dist/controllers/validation/batch-controller.validation.js.map +1 -1
- package/dist/controllers/validation/generic.validation.js +4 -8
- package/dist/controllers/validation/generic.validation.js.map +1 -1
- package/dist/controllers/validation/printer-files-controller.validation.js +2 -2
- package/dist/controllers/validation/user-controller.validation.js +14 -9
- package/dist/controllers/validation/user-controller.validation.js.map +1 -1
- package/dist/data-source.js +25 -12
- package/dist/data-source.js.map +1 -1
- package/dist/entities/camera-stream.entity.js +2 -1
- package/dist/entities/camera-stream.entity.js.map +1 -1
- package/dist/entities/floor.entity.js +3 -5
- package/dist/entities/floor.entity.js.map +1 -1
- package/dist/entities/index.js +15 -11
- package/dist/entities/index.js.map +1 -1
- package/dist/entities/print-job.entity.js +195 -0
- package/dist/entities/print-job.entity.js.map +1 -0
- package/dist/entities/{printer-group.entity.js → printer-tag.entity.js} +17 -17
- package/dist/entities/printer-tag.entity.js.map +1 -0
- package/dist/entities/printer.entity.js +4 -10
- package/dist/entities/printer.entity.js.map +1 -1
- package/dist/entities/settings.entity.js +3 -12
- package/dist/entities/settings.entity.js.map +1 -1
- package/dist/entities/{group.entity.js → tag.entity.js} +15 -8
- package/dist/entities/tag.entity.js.map +1 -0
- package/dist/handlers/logging/file-logging.transport.js.map +1 -1
- package/dist/handlers/logging/static.logger.js.map +1 -1
- package/dist/index.js +8 -2
- package/dist/index.js.map +1 -1
- package/dist/middleware/authenticate.js +4 -4
- package/dist/middleware/authenticate.js.map +1 -1
- package/dist/middleware/database.js +1 -1
- package/dist/middleware/exception.filter.js +114 -90
- package/dist/middleware/exception.filter.js.map +1 -1
- package/dist/middleware/global.middleware.js +10 -18
- package/dist/middleware/global.middleware.js.map +1 -1
- package/dist/middleware/param-converter.middleware.js +5 -13
- package/dist/middleware/param-converter.middleware.js.map +1 -1
- package/dist/middleware/passport.js +2 -2
- package/dist/middleware/passport.js.map +1 -1
- package/dist/middleware/printer-resolver.js.map +1 -1
- package/dist/middleware/printer.js +3 -2
- package/dist/middleware/printer.js.map +1 -1
- package/dist/middleware/socketio.middleware.js.map +1 -1
- package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js +1 -1
- package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js.map +1 -1
- package/dist/migrations/1766576698569-DropPermissions.js +28 -0
- package/dist/migrations/1766576698569-DropPermissions.js.map +1 -0
- package/dist/migrations/1767278216516-ChangeCameraPrinterOnDeleteSetNull.js +186 -0
- package/dist/migrations/1767278216516-ChangeCameraPrinterOnDeleteSetNull.js.map +1 -0
- package/dist/migrations/1767279607392-DropCustomGcode.js +31 -0
- package/dist/migrations/1767279607392-DropCustomGcode.js.map +1 -0
- package/dist/migrations/1767291804417-DropPrintCompletions.js +37 -0
- package/dist/migrations/1767291804417-DropPrintCompletions.js.map +1 -0
- package/dist/migrations/1767352862576-DropSettingsFileClean.js +88 -0
- package/dist/migrations/1767352862576-DropSettingsFileClean.js.map +1 -0
- package/dist/migrations/1767355639023-ChangeFloorLevelToOrder.js +107 -0
- package/dist/migrations/1767355639023-ChangeFloorLevelToOrder.js.map +1 -0
- package/dist/migrations/1767370191762-ChangeFloorNonUniqueOrder.js +62 -0
- package/dist/migrations/1767370191762-ChangeFloorNonUniqueOrder.js.map +1 -0
- package/dist/migrations/1767432108916-RenameGroupToTag.js +86 -0
- package/dist/migrations/1767432108916-RenameGroupToTag.js.map +1 -0
- package/dist/migrations/1767451444137-AddPrintJob.js +207 -0
- package/dist/migrations/1767451444137-AddPrintJob.js.map +1 -0
- package/dist/server.constants.js +9 -17
- package/dist/server.constants.js.map +1 -1
- package/dist/server.core.js +3 -7
- package/dist/server.core.js.map +1 -1
- package/dist/server.env.js +4 -49
- package/dist/server.env.js.map +1 -1
- package/dist/server.host.js +26 -44
- package/dist/server.host.js.map +1 -1
- package/dist/services/authentication/auth.service.js.map +1 -1
- package/dist/services/authentication/jwt.service.js.map +1 -1
- package/dist/services/bambu/bambu-ftp.adapter.js +3 -3
- package/dist/services/bambu/bambu-ftp.adapter.js.map +1 -1
- package/dist/services/bambu/bambu-mqtt.adapter.js +74 -77
- package/dist/services/bambu/bambu-mqtt.adapter.js.map +1 -1
- package/dist/services/bambu/bambu.client.js.map +1 -1
- package/dist/services/bambu.api.js +11 -0
- package/dist/services/bambu.api.js.map +1 -1
- package/dist/services/core/batch-call.service.js +0 -25
- package/dist/services/core/batch-call.service.js.map +1 -1
- package/dist/services/core/multer.service.js +5 -9
- package/dist/services/core/multer.service.js.map +1 -1
- package/dist/services/core/yaml.service.js +219 -187
- package/dist/services/core/yaml.service.js.map +1 -1
- package/dist/services/file-analysis.service.js +146 -0
- package/dist/services/file-analysis.service.js.map +1 -0
- package/dist/services/file-storage.service.js +386 -0
- package/dist/services/file-storage.service.js.map +1 -0
- package/dist/services/interfaces/camera-stream.dto.js +2 -2
- package/dist/services/interfaces/camera-stream.dto.js.map +1 -1
- package/dist/services/interfaces/floor.dto.js +3 -3
- package/dist/services/interfaces/floor.dto.js.map +1 -1
- package/dist/services/interfaces/{printer-group.dto.js → printer-tag.dto.js} +9 -8
- package/dist/services/interfaces/printer-tag.dto.js.map +1 -0
- package/dist/services/interfaces/{print-completion.interface.js → printer-tag.service.interface.js} +1 -1
- package/dist/services/interfaces/{printer-group.service.interface.js.map → printer-tag.service.interface.js.map} +1 -1
- package/dist/services/interfaces/printer.dto.js +2 -2
- package/dist/services/interfaces/printer.dto.js.map +1 -1
- package/dist/services/interfaces/refresh-token.dto.js.map +1 -1
- package/dist/services/interfaces/role.dto.js.map +1 -1
- package/dist/services/interfaces/settings.dto.js +0 -1
- package/dist/services/interfaces/settings.dto.js.map +1 -1
- package/dist/services/interfaces/{group.dto.js → tag.dto.js} +1 -1
- package/dist/services/interfaces/tag.dto.js.map +1 -0
- package/dist/services/interfaces/user.dto.js.map +1 -1
- package/dist/services/moonraker/constants/moonraker-event.dto.js.map +1 -1
- package/dist/services/moonraker/moonraker-websocket.adapter.js.map +1 -1
- package/dist/services/moonraker/moonraker.client.js.map +1 -1
- package/dist/services/moonraker.api.js +3 -0
- package/dist/services/moonraker.api.js.map +1 -1
- package/dist/services/octoprint/dto/files/gcode-analysis.dto.js.map +1 -0
- package/dist/services/octoprint/dto/octoprint-event.dto.js.map +1 -1
- package/dist/services/octoprint/octoprint-api.routes.js +0 -7
- package/dist/services/octoprint/octoprint-api.routes.js.map +1 -1
- package/dist/services/octoprint/octoprint-websocket.adapter.js.map +1 -1
- package/dist/services/octoprint/octoprint.client.js +0 -4
- package/dist/services/octoprint/octoprint.client.js.map +1 -1
- package/dist/services/octoprint.api.js +3 -0
- package/dist/services/octoprint.api.js.map +1 -1
- package/dist/services/orm/base.service.js.map +1 -1
- package/dist/services/orm/camera-stream.service.js.map +1 -1
- package/dist/services/orm/floor-position.service.js.map +1 -1
- package/dist/services/orm/floor.service.js +12 -19
- package/dist/services/orm/floor.service.js.map +1 -1
- package/dist/services/orm/permission.service.js +3 -54
- package/dist/services/orm/permission.service.js.map +1 -1
- package/dist/services/orm/print-job.service.js +539 -0
- package/dist/services/orm/print-job.service.js.map +1 -0
- package/dist/services/orm/printer-tag.service.js +120 -0
- package/dist/services/orm/printer-tag.service.js.map +1 -0
- package/dist/services/orm/printer.service.js.map +1 -1
- package/dist/services/orm/refresh-token.service.js.map +1 -1
- package/dist/services/orm/role.service.js +25 -39
- package/dist/services/orm/role.service.js.map +1 -1
- package/dist/services/orm/settings.service.js +4 -15
- package/dist/services/orm/settings.service.js.map +1 -1
- package/dist/services/orm/user.service.js +17 -13
- package/dist/services/orm/user.service.js.map +1 -1
- package/dist/services/print-file-downloader.service.js +169 -0
- package/dist/services/print-file-downloader.service.js.map +1 -0
- package/dist/services/print-queue.service.js +268 -0
- package/dist/services/print-queue.service.js.map +1 -0
- package/dist/services/printer-api.factory.js +1 -1
- package/dist/services/printer-api.factory.js.map +1 -1
- package/dist/services/printer-api.interface.js.map +1 -1
- package/dist/services/prusa-link/constants/prusalink-event.dto.js.map +1 -1
- package/dist/services/prusa-link/prusa-link-http-polling.adapter.js +1 -3
- package/dist/services/prusa-link/prusa-link-http-polling.adapter.js.map +1 -1
- package/dist/services/prusa-link/prusa-link.api.js +4 -1
- package/dist/services/prusa-link/prusa-link.api.js.map +1 -1
- package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js.map +1 -1
- package/dist/services/validators/floor-service.validation.js +25 -31
- package/dist/services/validators/floor-service.validation.js.map +1 -1
- package/dist/services/validators/print-job.validation.js +31 -0
- package/dist/services/validators/print-job.validation.js.map +1 -0
- package/dist/services/validators/settings-service.validation.js +0 -22
- package/dist/services/validators/settings-service.validation.js.map +1 -1
- package/dist/services/validators/user-service.validation.js +15 -10
- package/dist/services/validators/user-service.validation.js.map +1 -1
- package/dist/services/validators/yaml-service.validation.js +8 -14
- package/dist/services/validators/yaml-service.validation.js.map +1 -1
- package/dist/shared/load-controllers.js +2 -1
- package/dist/shared/load-controllers.js.map +1 -1
- package/dist/shared/runtime-settings.migration.js +1 -11
- package/dist/shared/runtime-settings.migration.js.map +1 -1
- package/dist/shared/websocket-rpc-extended.adapter.js +13 -4
- package/dist/shared/websocket-rpc-extended.adapter.js.map +1 -1
- package/dist/shared/websocket.adapter.js.map +1 -1
- package/dist/state/file-upload-tracker.cache.js.map +1 -1
- package/dist/state/file.cache.js +6 -6
- package/dist/state/file.cache.js.map +1 -1
- package/dist/state/floor.store.js +3 -10
- package/dist/state/floor.store.js.map +1 -1
- package/dist/state/printer-events.cache.js +180 -20
- package/dist/state/printer-events.cache.js.map +1 -1
- package/dist/state/printer-files.store.js.map +1 -1
- package/dist/state/printer-socket.store.js +25 -20
- package/dist/state/printer-socket.store.js.map +1 -1
- package/dist/state/printer-thumbnail.cache.js +98 -188
- package/dist/state/printer-thumbnail.cache.js.map +1 -1
- package/dist/state/printer.cache.js +3 -13
- package/dist/state/printer.cache.js.map +1 -1
- package/dist/state/settings.store.js +4 -42
- package/dist/state/settings.store.js.map +1 -1
- package/dist/state/socket-io.gateway.js +1 -1
- package/dist/state/socket-io.gateway.js.map +1 -1
- package/dist/state/test-printer-socket.store.js +6 -3
- package/dist/state/test-printer-socket.store.js.map +1 -1
- package/dist/tasks/boot.task.js +11 -91
- package/dist/tasks/boot.task.js.map +1 -1
- package/dist/tasks/print-job-analysis.task.js +116 -0
- package/dist/tasks/print-job-analysis.task.js.map +1 -0
- package/dist/tasks/printer-files-load.task.js +29 -0
- package/dist/tasks/printer-files-load.task.js.map +1 -0
- package/dist/tasks/socketio.task.js +1 -1
- package/dist/tasks/socketio.task.js.map +1 -1
- package/dist/tasks.js +3 -2
- package/dist/tasks.js.map +1 -1
- package/dist/utils/cache/key-diff.cache.js +20 -61
- package/dist/utils/cache/key-diff.cache.js.map +1 -1
- package/dist/utils/parsers/3mf.parser.js +337 -0
- package/dist/utils/parsers/3mf.parser.js.map +1 -0
- package/dist/utils/parsers/bgcode.parser.js +223 -0
- package/dist/utils/parsers/bgcode.parser.js.map +1 -0
- package/dist/utils/parsers/gcode.parser.js +254 -0
- package/dist/utils/parsers/gcode.parser.js.map +1 -0
- package/dist/utils/swagger/decorators.js +39 -0
- package/dist/utils/swagger/decorators.js.map +1 -0
- package/dist/utils/swagger/generator.js +196 -0
- package/dist/utils/swagger/generator.js.map +1 -0
- package/dist/utils/swagger/swagger.js +93 -0
- package/dist/utils/swagger/swagger.js.map +1 -0
- package/package.json +24 -30
- package/dist/controllers/custom-gcode.controller.js +0 -150
- package/dist/controllers/custom-gcode.controller.js.map +0 -1
- package/dist/controllers/print-completion.controller.js +0 -118
- package/dist/controllers/print-completion.controller.js.map +0 -1
- package/dist/controllers/printer-group.controller.js.map +0 -1
- package/dist/entities/custom-gcode.entity.js +0 -49
- package/dist/entities/custom-gcode.entity.js.map +0 -1
- package/dist/entities/group.entity.js.map +0 -1
- package/dist/entities/permission.entity.js +0 -37
- package/dist/entities/permission.entity.js.map +0 -1
- package/dist/entities/print-completion.entity.js +0 -90
- package/dist/entities/print-completion.entity.js.map +0 -1
- package/dist/entities/printer-group.entity.js.map +0 -1
- package/dist/models/Auth/Permission.js +0 -20
- package/dist/models/Auth/Permission.js.map +0 -1
- package/dist/models/Auth/RefreshToken.js +0 -41
- package/dist/models/Auth/RefreshToken.js.map +0 -1
- package/dist/models/Auth/Role.js +0 -20
- package/dist/models/Auth/Role.js.map +0 -1
- package/dist/models/Auth/User.js +0 -49
- package/dist/models/Auth/User.js.map +0 -1
- package/dist/models/CameraStream.js +0 -49
- package/dist/models/CameraStream.js.map +0 -1
- package/dist/models/CustomGcode.js +0 -28
- package/dist/models/CustomGcode.js.map +0 -1
- package/dist/models/Floor.js +0 -33
- package/dist/models/Floor.js.map +0 -1
- package/dist/models/FloorPrinter.js +0 -38
- package/dist/models/FloorPrinter.js.map +0 -1
- package/dist/models/PrintCompletion.js +0 -40
- package/dist/models/PrintCompletion.js.map +0 -1
- package/dist/models/Printer.js +0 -78
- package/dist/models/Printer.js.map +0 -1
- package/dist/models/Settings.js +0 -150
- package/dist/models/Settings.js.map +0 -1
- package/dist/models/index.js +0 -54
- package/dist/models/index.js.map +0 -1
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js +0 -45
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js.map +0 -1
- package/dist/mongo-migrations/20210907173950-printers-enabled.js +0 -35
- package/dist/mongo-migrations/20210907173950-printers-enabled.js.map +0 -1
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js +0 -35
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js.map +0 -1
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js +0 -60
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js.map +0 -1
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js +0 -30
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js.map +0 -1
- package/dist/mongo-migrations/20230716065316-user-remove-name.js +0 -30
- package/dist/mongo-migrations/20230716065316-user-remove-name.js.map +0 -1
- package/dist/mongo-migrations/20231111081809-printer-flatten-name.js +0 -35
- package/dist/mongo-migrations/20231111081809-printer-flatten-name.js.map +0 -1
- package/dist/mongo-migrations/20231111082521-printer-remove-settingsappearance.js +0 -41
- package/dist/mongo-migrations/20231111082521-printer-remove-settingsappearance.js.map +0 -1
- package/dist/mongo-migrations/20231202183902-printer-files-simpler.js +0 -41
- package/dist/mongo-migrations/20231202183902-printer-files-simpler.js.map +0 -1
- package/dist/services/interfaces/custom-gcode.dto.js +0 -18
- package/dist/services/interfaces/custom-gcode.dto.js.map +0 -1
- package/dist/services/interfaces/custom-gcode.service.interface.js +0 -6
- package/dist/services/interfaces/custom-gcode.service.interface.js.map +0 -1
- package/dist/services/interfaces/gcode-analysis.dto.js.map +0 -1
- package/dist/services/interfaces/group.dto.js.map +0 -1
- package/dist/services/interfaces/permission.dto.js +0 -16
- package/dist/services/interfaces/permission.dto.js.map +0 -1
- package/dist/services/interfaces/print-completion-context.dto.js +0 -6
- package/dist/services/interfaces/print-completion-context.dto.js.map +0 -1
- package/dist/services/interfaces/print-completion.dto.js +0 -38
- package/dist/services/interfaces/print-completion.dto.js.map +0 -1
- package/dist/services/interfaces/print-completion.interface.js.map +0 -1
- package/dist/services/interfaces/printer-group.dto.js.map +0 -1
- package/dist/services/interfaces/printer-group.service.interface.js +0 -6
- package/dist/services/mongoose/camera-stream.service.js +0 -67
- package/dist/services/mongoose/camera-stream.service.js.map +0 -1
- package/dist/services/mongoose/custom-gcode.service.js +0 -50
- package/dist/services/mongoose/custom-gcode.service.js.map +0 -1
- package/dist/services/mongoose/floor.service.js +0 -139
- package/dist/services/mongoose/floor.service.js.map +0 -1
- package/dist/services/mongoose/permission.service.js +0 -73
- package/dist/services/mongoose/permission.service.js.map +0 -1
- package/dist/services/mongoose/print-completion.service.js +0 -134
- package/dist/services/mongoose/print-completion.service.js.map +0 -1
- package/dist/services/mongoose/print-completion.shared.js +0 -59
- package/dist/services/mongoose/print-completion.shared.js.map +0 -1
- package/dist/services/mongoose/printer.service.js +0 -216
- package/dist/services/mongoose/printer.service.js.map +0 -1
- package/dist/services/mongoose/refresh-token.service.js +0 -104
- package/dist/services/mongoose/refresh-token.service.js.map +0 -1
- package/dist/services/mongoose/role.service.js +0 -132
- package/dist/services/mongoose/role.service.js.map +0 -1
- package/dist/services/mongoose/settings.service.js +0 -124
- package/dist/services/mongoose/settings.service.js.map +0 -1
- package/dist/services/mongoose/user.service.js +0 -180
- package/dist/services/mongoose/user.service.js.map +0 -1
- package/dist/services/orm/custom-gcode.service.js +0 -42
- package/dist/services/orm/custom-gcode.service.js.map +0 -1
- package/dist/services/orm/print-completion.service.js +0 -87
- package/dist/services/orm/print-completion.service.js.map +0 -1
- package/dist/services/orm/printer-group.service.js +0 -109
- package/dist/services/orm/printer-group.service.js.map +0 -1
- package/dist/services/validators/camera-service.validation.js +0 -19
- package/dist/services/validators/camera-service.validation.js.map +0 -1
- package/dist/services/validators/print-completion-service.validation.js +0 -33
- package/dist/services/validators/print-completion-service.validation.js.map +0 -1
- package/dist/shared.constants.js +0 -15
- package/dist/shared.constants.js.map +0 -1
- package/dist/tasks/print-completion.socketio.task.js +0 -91
- package/dist/tasks/print-completion.socketio.task.js.map +0 -1
- package/dist/tasks/printer-file-clean.task.js +0 -74
- package/dist/tasks/printer-file-clean.task.js.map +0 -1
- package/migrate-mongo-config.js +0 -45
- /package/dist/services/{interfaces → octoprint/dto/files}/gcode-analysis.dto.js +0 -0
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "FileStorageController", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return FileStorageController;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _awilixexpress = require("awilix-express");
|
|
12
|
+
const _serverconstants = require("../server.constants");
|
|
13
|
+
const _express = require("express");
|
|
14
|
+
const _authenticate = require("../middleware/authenticate");
|
|
15
|
+
const _authorizationconstants = require("../constants/authorization.constants");
|
|
16
|
+
const _filestorageservice = require("../services/file-storage.service");
|
|
17
|
+
const _multerservice = require("../services/core/multer.service");
|
|
18
|
+
const _loggerfactory = require("../handlers/logger-factory");
|
|
19
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
20
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
21
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
22
|
+
else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
23
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
24
|
+
}
|
|
25
|
+
function _ts_metadata(k, v) {
|
|
26
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
27
|
+
}
|
|
28
|
+
class FileStorageController {
|
|
29
|
+
fileStorageService;
|
|
30
|
+
multerService;
|
|
31
|
+
logger;
|
|
32
|
+
constructor(loggerFactory, fileStorageService, multerService){
|
|
33
|
+
this.fileStorageService = fileStorageService;
|
|
34
|
+
this.multerService = multerService;
|
|
35
|
+
this.logger = loggerFactory(FileStorageController.name);
|
|
36
|
+
}
|
|
37
|
+
async listFiles(req, res) {
|
|
38
|
+
try {
|
|
39
|
+
const files = await this.fileStorageService.listAllFiles();
|
|
40
|
+
res.send({
|
|
41
|
+
files: files.map((file)=>({
|
|
42
|
+
fileStorageId: file.fileStorageId,
|
|
43
|
+
fileName: file.fileName,
|
|
44
|
+
fileFormat: file.fileFormat,
|
|
45
|
+
fileSize: file.fileSize,
|
|
46
|
+
fileHash: file.fileHash,
|
|
47
|
+
createdAt: file.createdAt,
|
|
48
|
+
thumbnailCount: file.thumbnailCount,
|
|
49
|
+
thumbnailsUrl: file.thumbnailCount > 0 ? `/api/file-storage/${file.fileStorageId}/thumbnail/0` : null,
|
|
50
|
+
metadata: file.metadata
|
|
51
|
+
})),
|
|
52
|
+
totalCount: files.length
|
|
53
|
+
});
|
|
54
|
+
} catch (error) {
|
|
55
|
+
this.logger.error(`Failed to list files: ${error}`);
|
|
56
|
+
res.status(500).send({
|
|
57
|
+
error: "Failed to list files"
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
async getFileMetadata(req, res) {
|
|
62
|
+
const { fileStorageId } = req.params;
|
|
63
|
+
try {
|
|
64
|
+
const file = await this.fileStorageService.getFileInfo(fileStorageId);
|
|
65
|
+
if (!file) {
|
|
66
|
+
res.status(404).send({
|
|
67
|
+
error: "File not found"
|
|
68
|
+
});
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
res.send({
|
|
72
|
+
fileStorageId: file.fileStorageId,
|
|
73
|
+
fileName: file.fileName,
|
|
74
|
+
fileFormat: file.fileFormat,
|
|
75
|
+
fileSize: file.fileSize,
|
|
76
|
+
fileHash: file.fileHash,
|
|
77
|
+
createdAt: file.createdAt,
|
|
78
|
+
thumbnailCount: file.thumbnailCount,
|
|
79
|
+
thumbnailsUrl: file.thumbnailCount > 0 ? `/api/file-storage/${file.fileStorageId}/thumbnail/0` : null,
|
|
80
|
+
metadata: file.metadata
|
|
81
|
+
});
|
|
82
|
+
} catch (error) {
|
|
83
|
+
this.logger.error(`Failed to get file metadata for ${fileStorageId}: ${error}`);
|
|
84
|
+
res.status(500).send({
|
|
85
|
+
error: "Failed to get file metadata"
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
async deleteFile(req, res) {
|
|
90
|
+
const { fileStorageId } = req.params;
|
|
91
|
+
try {
|
|
92
|
+
await this.fileStorageService.deleteFile(fileStorageId);
|
|
93
|
+
this.logger.log(`Deleted file ${fileStorageId}`);
|
|
94
|
+
res.send({
|
|
95
|
+
message: "File deleted successfully",
|
|
96
|
+
fileStorageId
|
|
97
|
+
});
|
|
98
|
+
} catch (error) {
|
|
99
|
+
this.logger.error(`Failed to delete file ${fileStorageId}: ${error}`);
|
|
100
|
+
res.status(500).send({
|
|
101
|
+
error: "Failed to delete file"
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
async getThumbnail(req, res) {
|
|
106
|
+
const { fileStorageId, index } = req.params;
|
|
107
|
+
const thumbnailIndex = parseInt(index);
|
|
108
|
+
if (isNaN(thumbnailIndex)) {
|
|
109
|
+
res.status(400).send({
|
|
110
|
+
error: "Invalid thumbnail index"
|
|
111
|
+
});
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
try {
|
|
115
|
+
const thumbnail = await this.fileStorageService.getThumbnail(fileStorageId, thumbnailIndex);
|
|
116
|
+
if (!thumbnail) {
|
|
117
|
+
res.status(404).send({
|
|
118
|
+
error: "Thumbnail not found"
|
|
119
|
+
});
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
const isPNG = thumbnail[0] === 0x89 && thumbnail[1] === 0x50 && thumbnail[2] === 0x4E && thumbnail[3] === 0x47;
|
|
123
|
+
const isJPG = thumbnail[0] === 0xFF && thumbnail[1] === 0xD8;
|
|
124
|
+
let contentType = 'image/png';
|
|
125
|
+
if (isJPG) contentType = 'image/jpeg';
|
|
126
|
+
res.setHeader('Content-Type', contentType);
|
|
127
|
+
res.setHeader('Cache-Control', 'public, max-age=3600');
|
|
128
|
+
res.setHeader('ETag', `"${fileStorageId}-${thumbnailIndex}"`);
|
|
129
|
+
res.send(thumbnail);
|
|
130
|
+
} catch (error) {
|
|
131
|
+
this.logger.error(`Failed to get thumbnail ${thumbnailIndex} for ${fileStorageId}: ${error}`);
|
|
132
|
+
res.status(500).send({
|
|
133
|
+
error: "Failed to get thumbnail"
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
async uploadFile(req, res) {
|
|
138
|
+
try {
|
|
139
|
+
const acceptedExtensions = [
|
|
140
|
+
'.gcode',
|
|
141
|
+
'.3mf',
|
|
142
|
+
'.bgcode'
|
|
143
|
+
];
|
|
144
|
+
const files = await this.multerService.multerLoadFileAsync(req, res, acceptedExtensions, true);
|
|
145
|
+
if (!files?.length) {
|
|
146
|
+
res.status(400).send({
|
|
147
|
+
error: "No file uploaded"
|
|
148
|
+
});
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
if (files.length > 1) {
|
|
152
|
+
res.status(400).send({
|
|
153
|
+
error: "Only 1 file can be uploaded at a time"
|
|
154
|
+
});
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
const file = files[0];
|
|
158
|
+
const fileHash = await this.fileStorageService.calculateFileHash(file.path);
|
|
159
|
+
const fileStorageId = await this.fileStorageService.saveFile(file, fileHash);
|
|
160
|
+
this.logger.log(`Uploaded file ${file.originalname} as ${fileStorageId}`);
|
|
161
|
+
try {
|
|
162
|
+
const filePath = this.fileStorageService.getFilePath(fileStorageId);
|
|
163
|
+
this.logger.log(`File uploaded successfully, analysis will be processed`);
|
|
164
|
+
} catch (analysisError) {
|
|
165
|
+
this.logger.warn(`Failed to trigger analysis: ${analysisError}`);
|
|
166
|
+
}
|
|
167
|
+
res.send({
|
|
168
|
+
message: "File uploaded successfully",
|
|
169
|
+
fileStorageId,
|
|
170
|
+
fileName: file.originalname,
|
|
171
|
+
fileSize: file.size,
|
|
172
|
+
fileHash
|
|
173
|
+
});
|
|
174
|
+
} catch (error) {
|
|
175
|
+
this.logger.error(`Failed to upload file: ${error}`);
|
|
176
|
+
res.status(500).send({
|
|
177
|
+
error: "Failed to upload file"
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
_ts_decorate([
|
|
183
|
+
(0, _awilixexpress.GET)(),
|
|
184
|
+
_ts_metadata("design:type", Function),
|
|
185
|
+
_ts_metadata("design:paramtypes", [
|
|
186
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
187
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
188
|
+
]),
|
|
189
|
+
_ts_metadata("design:returntype", Promise)
|
|
190
|
+
], FileStorageController.prototype, "listFiles", null);
|
|
191
|
+
_ts_decorate([
|
|
192
|
+
(0, _awilixexpress.GET)(),
|
|
193
|
+
(0, _awilixexpress.route)("/:fileStorageId"),
|
|
194
|
+
_ts_metadata("design:type", Function),
|
|
195
|
+
_ts_metadata("design:paramtypes", [
|
|
196
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
197
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
198
|
+
]),
|
|
199
|
+
_ts_metadata("design:returntype", Promise)
|
|
200
|
+
], FileStorageController.prototype, "getFileMetadata", null);
|
|
201
|
+
_ts_decorate([
|
|
202
|
+
(0, _awilixexpress.DELETE)(),
|
|
203
|
+
(0, _awilixexpress.route)("/:fileStorageId"),
|
|
204
|
+
_ts_metadata("design:type", Function),
|
|
205
|
+
_ts_metadata("design:paramtypes", [
|
|
206
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
207
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
208
|
+
]),
|
|
209
|
+
_ts_metadata("design:returntype", Promise)
|
|
210
|
+
], FileStorageController.prototype, "deleteFile", null);
|
|
211
|
+
_ts_decorate([
|
|
212
|
+
(0, _awilixexpress.GET)(),
|
|
213
|
+
(0, _awilixexpress.route)("/:fileStorageId/thumbnail/:index"),
|
|
214
|
+
_ts_metadata("design:type", Function),
|
|
215
|
+
_ts_metadata("design:paramtypes", [
|
|
216
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
217
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
218
|
+
]),
|
|
219
|
+
_ts_metadata("design:returntype", Promise)
|
|
220
|
+
], FileStorageController.prototype, "getThumbnail", null);
|
|
221
|
+
_ts_decorate([
|
|
222
|
+
(0, _awilixexpress.POST)(),
|
|
223
|
+
(0, _awilixexpress.route)("/upload"),
|
|
224
|
+
_ts_metadata("design:type", Function),
|
|
225
|
+
_ts_metadata("design:paramtypes", [
|
|
226
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
227
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
228
|
+
]),
|
|
229
|
+
_ts_metadata("design:returntype", Promise)
|
|
230
|
+
], FileStorageController.prototype, "uploadFile", null);
|
|
231
|
+
FileStorageController = _ts_decorate([
|
|
232
|
+
(0, _awilixexpress.route)(_serverconstants.AppConstants.apiRoute + "/file-storage"),
|
|
233
|
+
(0, _awilixexpress.before)([
|
|
234
|
+
(0, _authenticate.authenticate)(),
|
|
235
|
+
(0, _authenticate.authorizeRoles)([
|
|
236
|
+
_authorizationconstants.ROLES.ADMIN,
|
|
237
|
+
_authorizationconstants.ROLES.OPERATOR
|
|
238
|
+
])
|
|
239
|
+
]),
|
|
240
|
+
_ts_metadata("design:type", Function),
|
|
241
|
+
_ts_metadata("design:paramtypes", [
|
|
242
|
+
typeof _loggerfactory.ILoggerFactory === "undefined" ? Object : _loggerfactory.ILoggerFactory,
|
|
243
|
+
typeof _filestorageservice.FileStorageService === "undefined" ? Object : _filestorageservice.FileStorageService,
|
|
244
|
+
typeof _multerservice.MulterService === "undefined" ? Object : _multerservice.MulterService
|
|
245
|
+
])
|
|
246
|
+
], FileStorageController);
|
|
247
|
+
|
|
248
|
+
//# sourceMappingURL=file-storage.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/file-storage.controller.ts"],"names":["FileStorageController","logger","loggerFactory","fileStorageService","multerService","name","listFiles","req","res","files","listAllFiles","send","map","file","fileStorageId","fileName","fileFormat","fileSize","fileHash","createdAt","thumbnailCount","thumbnailsUrl","metadata","totalCount","length","error","status","getFileMetadata","params","getFileInfo","deleteFile","log","message","getThumbnail","index","thumbnailIndex","parseInt","isNaN","thumbnail","isPNG","isJPG","contentType","setHeader","uploadFile","acceptedExtensions","multerLoadFileAsync","calculateFileHash","path","saveFile","originalname","filePath","getFilePath","analysisError","warn","size","AppConstants","apiRoute","authenticate","authorizeRoles","ROLES","ADMIN","OPERATOR"],"mappings":"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"}
|
|
@@ -49,7 +49,7 @@ class FirstTimeSetupController {
|
|
|
49
49
|
throw new _runtimeexceptions.ForbiddenError("Wizard already completed");
|
|
50
50
|
}
|
|
51
51
|
const user = await this.userService.findRawByUsername(rootUsername?.toLowerCase());
|
|
52
|
-
if (
|
|
52
|
+
if (user) {
|
|
53
53
|
throw new _runtimeexceptions.BadRequestException("This user already exists");
|
|
54
54
|
}
|
|
55
55
|
return res.send();
|
|
@@ -59,16 +59,16 @@ class FirstTimeSetupController {
|
|
|
59
59
|
if (this.settingsStore.isWizardCompleted()) {
|
|
60
60
|
throw new _runtimeexceptions.ForbiddenError("Wizard already completed");
|
|
61
61
|
}
|
|
62
|
-
|
|
62
|
+
await this.roleService.getSynchronizedRoleByName(_authorizationconstants.ROLES.ADMIN);
|
|
63
63
|
const user = await this.userService.findRawByUsername(rootUsername?.toLowerCase());
|
|
64
|
-
if (
|
|
64
|
+
if (user) {
|
|
65
65
|
throw new _runtimeexceptions.BadRequestException("This user already exists");
|
|
66
66
|
}
|
|
67
67
|
await this.userService.register({
|
|
68
68
|
username: rootUsername,
|
|
69
69
|
password: rootPassword,
|
|
70
70
|
roles: [
|
|
71
|
-
|
|
71
|
+
_authorizationconstants.ROLES.ADMIN
|
|
72
72
|
],
|
|
73
73
|
isRootUser: true,
|
|
74
74
|
isVerified: true,
|
|
@@ -85,7 +85,8 @@ class FirstTimeSetupController {
|
|
|
85
85
|
throw new _runtimeexceptions.ForbiddenError("Wizard already completed. Cannot import during first-time setup once wizard is complete.");
|
|
86
86
|
}
|
|
87
87
|
const files = await this.multerService.multerLoadFileAsync(req, res, [
|
|
88
|
-
".yaml"
|
|
88
|
+
".yaml",
|
|
89
|
+
".yml"
|
|
89
90
|
], false);
|
|
90
91
|
const firstFile = files[0];
|
|
91
92
|
await this.yamlService.importYaml(firstFile.buffer.toString());
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controllers/first-time-setup.controller.ts"],"names":["FirstTimeSetupController","settingsStore","roleService","userService","yamlService","multerService","validateWizard","req","res","rootUsername","validateMiddleware","wizardSettingsSchema","getSynchronizedRoleByName","ROLES","ADMIN","isWizardCompleted","ForbiddenError","user","findRawByUsername","toLowerCase","BadRequestException","send","completeWizard","loginRequired","registration","rootPassword","
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/first-time-setup.controller.ts"],"names":["FirstTimeSetupController","settingsStore","roleService","userService","yamlService","multerService","validateWizard","req","res","rootUsername","validateMiddleware","wizardSettingsSchema","getSynchronizedRoleByName","ROLES","ADMIN","isWizardCompleted","ForbiddenError","user","findRawByUsername","toLowerCase","BadRequestException","send","completeWizard","loginRequired","registration","rootPassword","register","username","password","roles","isRootUser","isVerified","isDemoUser","needsPasswordChange","setLoginRequired","setRegistrationEnabled","setWizardCompleted","AppConstants","currentWizardVersion","importYamlFile","files","multerLoadFileAsync","firstFile","importYaml","buffer","toString","success","apiRoute"],"mappings":";;;;+BAcaA;;;eAAAA;;;+BAde;iCACC;4BACM;mCACE;mCACe;wCAC9B;+BACQ;yBACI;sCACL;sCACA;6BACD;+BACE;;;;;;;;;;AAGvB,MAAMA;;;;;;IACX,YACE,AAAiBC,aAA4B,EAC7C,AAAiBC,WAAyB,EAC1C,AAAiBC,WAAyB,EAC1C,AAAiBC,WAAwB,EACzC,AAAiBC,aAA4B,CAC7C;aALiBJ,gBAAAA;aACAC,cAAAA;aACAC,cAAAA;aACAC,cAAAA;aACAC,gBAAAA;IAChB;IAEH,MAEMC,eAAeC,GAAY,EAAEC,GAAa,EAAE;QAChD,MAAM,EAAEC,YAAY,EAAE,GAAG,MAAMC,IAAAA,8BAAkB,EAACH,KAAKI,uCAAoB;QAC3E,MAAM,IAAI,CAACT,WAAW,CAACU,yBAAyB,CAACC,6BAAK,CAACC,KAAK;QAE5D,IAAI,IAAI,CAACb,aAAa,CAACc,iBAAiB,IAAI;YAC1C,MAAM,IAAIC,iCAAc,CAAC;QAC3B;QAEA,MAAMC,OAAO,MAAM,IAAI,CAACd,WAAW,CAACe,iBAAiB,CAACT,cAAcU;QACpE,IAAIF,MAAM;YACR,MAAM,IAAIG,sCAAmB,CAAC;QAChC;QAEA,OAAOZ,IAAIa,IAAI;IACjB;IAEA,MAEMC,eAAef,GAAY,EAAEC,GAAa,EAAE;QAChD,MAAM,EAAEe,aAAa,EAAEC,YAAY,EAAEf,YAAY,EAAEgB,YAAY,EAAE,GAAG,MAAMf,IAAAA,8BAAkB,EAC1FH,KACAI,uCAAoB;QAGtB,IAAI,IAAI,CAACV,aAAa,CAACc,iBAAiB,IAAI;YAC1C,MAAM,IAAIC,iCAAc,CAAC;QAC3B;QAEA,MAAM,IAAI,CAACd,WAAW,CAACU,yBAAyB,CAACC,6BAAK,CAACC,KAAK;QAC5D,MAAMG,OAAO,MAAM,IAAI,CAACd,WAAW,CAACe,iBAAiB,CAACT,cAAcU;QACpE,IAAIF,MAAM;YACR,MAAM,IAAIG,sCAAmB,CAAC;QAChC;QAEA,MAAM,IAAI,CAACjB,WAAW,CAACuB,QAAQ,CAAC;YAC9BC,UAAUlB;YACVmB,UAAUH;YACVI,OAAO;gBAAChB,6BAAK,CAACC,KAAK;aAAC;YACpBgB,YAAY;YACZC,YAAY;YACZC,YAAY;YACZC,qBAAqB;QACvB;QACA,MAAM,IAAI,CAAChC,aAAa,CAACiC,gBAAgB,CAACX;QAC1C,MAAM,IAAI,CAACtB,aAAa,CAACkC,sBAAsB,CAACX;QAChD,MAAM,IAAI,CAACvB,aAAa,CAACmC,kBAAkB,CAACC,6BAAY,CAACC,oBAAoB;QAE7E,OAAO9B,IAAIa,IAAI;IACjB;IAEA,MAEMkB,eAAehC,GAAY,EAAEC,GAAa,EAAE;QAChD,IAAI,IAAI,CAACP,aAAa,CAACc,iBAAiB,IAAI;YAC1C,MAAM,IAAIC,iCAAc,CACtB;QAEJ;QAEA,MAAMwB,QAAQ,MAAM,IAAI,CAACnC,aAAa,CAACoC,mBAAmB,CAAClC,KAAKC,KAAK;YAAC;YAAS;SAAO,EAAE;QACxF,MAAMkC,YAAYF,KAAK,CAAC,EAAE;QAE1B,MAAM,IAAI,CAACpC,WAAW,CAACuC,UAAU,CAACD,UAAUE,MAAM,CAACC,QAAQ;QAE3D,OAAOrC,IAAIa,IAAI,CAAC;YACdyB,SAAS;QACX;IACF;AACF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAhFOT,6BAAY,CAACU,QAAQ,GAAG"}
|
|
@@ -49,8 +49,8 @@ class FloorController {
|
|
|
49
49
|
const floor = await this.floorStore.updateName(req.local.id, req.body.name);
|
|
50
50
|
res.send(floor);
|
|
51
51
|
}
|
|
52
|
-
async
|
|
53
|
-
const floor = await this.floorStore.
|
|
52
|
+
async updateFloorOrder(req, res) {
|
|
53
|
+
const floor = await this.floorStore.updateFloorOrder(req.local.id, req.body.order);
|
|
54
54
|
res.send(floor);
|
|
55
55
|
}
|
|
56
56
|
async addPrinterToFloor(req, res) {
|
|
@@ -66,7 +66,7 @@ _ts_decorate([
|
|
|
66
66
|
(0, _awilixexpress.GET)(),
|
|
67
67
|
(0, _awilixexpress.route)("/"),
|
|
68
68
|
(0, _awilixexpress.before)([
|
|
69
|
-
(0, _authenticate.permission)(_authorizationconstants.PERMS.
|
|
69
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.Floors.List)
|
|
70
70
|
]),
|
|
71
71
|
_ts_metadata("design:type", Function),
|
|
72
72
|
_ts_metadata("design:paramtypes", [
|
|
@@ -79,7 +79,7 @@ _ts_decorate([
|
|
|
79
79
|
(0, _awilixexpress.GET)(),
|
|
80
80
|
(0, _awilixexpress.route)("/:id"),
|
|
81
81
|
(0, _awilixexpress.before)([
|
|
82
|
-
(0, _authenticate.permission)(_authorizationconstants.PERMS.
|
|
82
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.Floors.Get),
|
|
83
83
|
(0, _paramconvertermiddleware.ParamId)("id")
|
|
84
84
|
]),
|
|
85
85
|
_ts_metadata("design:type", Function),
|
|
@@ -93,7 +93,7 @@ _ts_decorate([
|
|
|
93
93
|
(0, _awilixexpress.DELETE)(),
|
|
94
94
|
(0, _awilixexpress.route)("/:id"),
|
|
95
95
|
(0, _awilixexpress.before)([
|
|
96
|
-
(0, _authenticate.permission)(_authorizationconstants.PERMS.
|
|
96
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.Floors.Delete),
|
|
97
97
|
(0, _paramconvertermiddleware.ParamId)("id")
|
|
98
98
|
]),
|
|
99
99
|
_ts_metadata("design:type", Function),
|
|
@@ -107,7 +107,7 @@ _ts_decorate([
|
|
|
107
107
|
(0, _awilixexpress.POST)(),
|
|
108
108
|
(0, _awilixexpress.route)("/"),
|
|
109
109
|
(0, _awilixexpress.before)([
|
|
110
|
-
(0, _authenticate.permission)(_authorizationconstants.PERMS.
|
|
110
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.Floors.Create)
|
|
111
111
|
]),
|
|
112
112
|
_ts_metadata("design:type", Function),
|
|
113
113
|
_ts_metadata("design:paramtypes", [
|
|
@@ -120,7 +120,7 @@ _ts_decorate([
|
|
|
120
120
|
(0, _awilixexpress.PATCH)(),
|
|
121
121
|
(0, _awilixexpress.route)("/:id/name"),
|
|
122
122
|
(0, _awilixexpress.before)([
|
|
123
|
-
(0, _authenticate.permission)(_authorizationconstants.PERMS.
|
|
123
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.Floors.Update),
|
|
124
124
|
(0, _paramconvertermiddleware.ParamId)("id")
|
|
125
125
|
]),
|
|
126
126
|
_ts_metadata("design:type", Function),
|
|
@@ -132,9 +132,9 @@ _ts_decorate([
|
|
|
132
132
|
], FloorController.prototype, "updateName", null);
|
|
133
133
|
_ts_decorate([
|
|
134
134
|
(0, _awilixexpress.PATCH)(),
|
|
135
|
-
(0, _awilixexpress.route)("/:id/floor-
|
|
135
|
+
(0, _awilixexpress.route)("/:id/floor-order"),
|
|
136
136
|
(0, _awilixexpress.before)([
|
|
137
|
-
(0, _authenticate.permission)(_authorizationconstants.PERMS.
|
|
137
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.Floors.Update),
|
|
138
138
|
(0, _paramconvertermiddleware.ParamId)("id")
|
|
139
139
|
]),
|
|
140
140
|
_ts_metadata("design:type", Function),
|
|
@@ -143,12 +143,12 @@ _ts_decorate([
|
|
|
143
143
|
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
144
144
|
]),
|
|
145
145
|
_ts_metadata("design:returntype", Promise)
|
|
146
|
-
], FloorController.prototype, "
|
|
146
|
+
], FloorController.prototype, "updateFloorOrder", null);
|
|
147
147
|
_ts_decorate([
|
|
148
148
|
(0, _awilixexpress.POST)(),
|
|
149
149
|
(0, _awilixexpress.route)("/:id/printer"),
|
|
150
150
|
(0, _awilixexpress.before)([
|
|
151
|
-
(0, _authenticate.permission)(_authorizationconstants.PERMS.
|
|
151
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.Floors.Update),
|
|
152
152
|
(0, _paramconvertermiddleware.ParamId)("id")
|
|
153
153
|
]),
|
|
154
154
|
_ts_metadata("design:type", Function),
|
|
@@ -162,7 +162,7 @@ _ts_decorate([
|
|
|
162
162
|
(0, _awilixexpress.DELETE)(),
|
|
163
163
|
(0, _awilixexpress.route)("/:id/printer"),
|
|
164
164
|
(0, _awilixexpress.before)([
|
|
165
|
-
(0, _authenticate.permission)(_authorizationconstants.PERMS.
|
|
165
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.Floors.Update),
|
|
166
166
|
(0, _paramconvertermiddleware.ParamId)("id")
|
|
167
167
|
]),
|
|
168
168
|
_ts_metadata("design:type", Function),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controllers/floor.controller.ts"],"names":["FloorController","floorStore","list","req","res","floors","listCache","send","get","floor","getFloor","local","id","delete","create","body","updateName","name","
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/floor.controller.ts"],"names":["FloorController","floorStore","list","req","res","floors","listCache","send","get","floor","getFloor","local","id","delete","create","body","updateName","name","updateFloorOrder","order","addPrinterToFloor","addOrUpdatePrinter","removePrinterFromFloor","removePrinter","printerId","permission","PERMS","Floors","List","Get","ParamId","Delete","Create","Update","AppConstants","apiRoute","authenticate"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controllers/metrics.controller.ts"],"names":["MetricsController","configService","getMetrics","req","res","get","AppConstants","ENABLE_PROMETHEUS_METRICS","status","send","setHeader","register","contentType","end","metrics"],"mappings":";;;;+BAOaA;;;eAAAA;;;+BAPc;4BACF;yBACS;+BACH;iCACF;;;;;;;;;;AAGtB,MAAMA;;IACX,YAAY,AAAiBC,aAA6B,CAAE;aAA/BA,gBAAAA;
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/metrics.controller.ts"],"names":["MetricsController","configService","getMetrics","req","res","get","AppConstants","ENABLE_PROMETHEUS_METRICS","status","send","setHeader","register","contentType","end","metrics"],"mappings":";;;;+BAOaA;;;eAAAA;;;+BAPc;4BACF;yBACS;+BACH;iCACF;;;;;;;;;;AAGtB,MAAMA;;IACX,YAAY,AAAiBC,aAA6B,CAAE;aAA/BA,gBAAAA;IAAgC;IAE7D,MAEMC,WAAWC,GAAY,EAAEC,GAAa,EAAE;QAC5C,IAAI,IAAI,CAACH,aAAa,CAACI,GAAG,CAASC,6BAAY,CAACC,yBAAyB,MAAM,QAAQ;YACrF,OAAOH,IAAII,MAAM,CAAC,KAAKC,IAAI,CAAC;QAC9B;QACAL,IAAIM,SAAS,CAAC,gBAAgBC,oBAAQ,CAACC,WAAW;QAClDR,IAAIS,GAAG,CAAC,MAAMF,oBAAQ,CAACG,OAAO;IAChC;AACF"}
|