@fdm-monster/server 1.8.3 → 1.9.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 +6 -4
- package/.gitattributes +4 -2
- package/.yarn/install-state.gz +0 -0
- package/.yarn/releases/yarn-4.9.1.cjs +948 -0
- package/.yarnrc.yml +1 -1
- package/README.md +27 -28
- package/RELEASE_NOTES.MD +69 -1
- package/biome.json +33 -0
- package/dist/consoles/download-github-releases.js.map +1 -1
- package/dist/consoles/launch-http-servers.js +31 -0
- package/dist/consoles/launch-http-servers.js.map +1 -0
- package/dist/consoles/mock-octoprint.server.js +291 -0
- package/dist/consoles/mock-octoprint.server.js.map +1 -0
- package/dist/consoles/mock-prusalink.server.js +57 -0
- package/dist/consoles/mock-prusalink.server.js.map +1 -0
- package/dist/consoles/utils/api-messages.js +856 -0
- package/dist/consoles/utils/api-messages.js.map +1 -0
- package/dist/consoles/utils/delayed-memory.storage.js +42 -0
- package/dist/consoles/utils/delayed-memory.storage.js.map +1 -0
- package/dist/consoles/utils/ws-messages.js +88 -0
- package/dist/consoles/utils/ws-messages.js.map +1 -0
- package/dist/constants/event.constants.js +5 -21
- package/dist/constants/event.constants.js.map +1 -1
- package/dist/constants/server-settings.constants.js +8 -12
- package/dist/constants/server-settings.constants.js.map +1 -1
- package/dist/container.js +13 -14
- package/dist/container.js.map +1 -1
- package/dist/container.tokens.js +3 -4
- package/dist/container.tokens.js.map +1 -1
- package/dist/controllers/auth.controller.js +114 -24
- package/dist/controllers/auth.controller.js.map +1 -1
- package/dist/controllers/batch-call.controller.js +95 -24
- package/dist/controllers/batch-call.controller.js.map +1 -1
- package/dist/controllers/camera-stream.controller.js +16 -12
- package/dist/controllers/camera-stream.controller.js.map +1 -1
- package/dist/controllers/custom-gcode.controller.js +116 -40
- package/dist/controllers/custom-gcode.controller.js.map +1 -1
- package/dist/controllers/dto/update-client-dist.dto.js +0 -21
- package/dist/controllers/dto/update-client-dist.dto.js.map +1 -1
- package/dist/controllers/first-time-setup.controller.js +54 -18
- package/dist/controllers/first-time-setup.controller.js.map +1 -1
- package/dist/controllers/floor.controller.js +154 -43
- package/dist/controllers/floor.controller.js.map +1 -1
- package/dist/controllers/metrics.controller.js +56 -0
- package/dist/controllers/metrics.controller.js.map +1 -0
- package/dist/controllers/print-completion.controller.js +81 -18
- package/dist/controllers/print-completion.controller.js.map +1 -1
- package/dist/controllers/printer-files.controller.js +45 -29
- package/dist/controllers/printer-files.controller.js.map +1 -1
- package/dist/controllers/printer-group.controller.js +123 -33
- package/dist/controllers/printer-group.controller.js.map +1 -1
- package/dist/controllers/printer-settings.controller.js +73 -26
- package/dist/controllers/printer-settings.controller.js.map +1 -1
- package/dist/controllers/printer.controller.js +57 -198
- package/dist/controllers/printer.controller.js.map +1 -1
- package/dist/controllers/server-private.controller.js +153 -39
- package/dist/controllers/server-private.controller.js.map +1 -1
- package/dist/controllers/server-public.controller.js +87 -88
- package/dist/controllers/server-public.controller.js.map +1 -1
- package/dist/controllers/settings.controller.js +222 -79
- package/dist/controllers/settings.controller.js.map +1 -1
- package/dist/controllers/user.controller.js +67 -57
- package/dist/controllers/user.controller.js.map +1 -1
- package/dist/controllers/validation/auth-controller.validation.js +6 -5
- package/dist/controllers/validation/auth-controller.validation.js.map +1 -1
- package/dist/controllers/validation/batch-controller.validation.js +17 -18
- package/dist/controllers/validation/batch-controller.validation.js.map +1 -1
- package/dist/controllers/validation/generic.validation.js +8 -3
- package/dist/controllers/validation/generic.validation.js.map +1 -1
- package/dist/controllers/validation/printer-completion-controller.validation.js +16 -0
- package/dist/controllers/validation/printer-completion-controller.validation.js.map +1 -0
- package/dist/controllers/validation/printer-controller.validation.js +31 -50
- package/dist/controllers/validation/printer-controller.validation.js.map +1 -1
- package/dist/controllers/validation/printer-files-controller.validation.js +25 -15
- package/dist/controllers/validation/printer-files-controller.validation.js.map +1 -1
- package/dist/controllers/validation/printer-settings-controller.validation.js +6 -5
- package/dist/controllers/validation/printer-settings-controller.validation.js.map +1 -1
- package/dist/controllers/validation/server-private.validation.js +17 -0
- package/dist/controllers/validation/server-private.validation.js.map +1 -0
- package/dist/controllers/validation/setting.validation.js +28 -10
- package/dist/controllers/validation/setting.validation.js.map +1 -1
- package/dist/controllers/validation/user-controller.validation.js +44 -13
- package/dist/controllers/validation/user-controller.validation.js.map +1 -1
- package/dist/data-source.js +10 -6
- package/dist/data-source.js.map +1 -1
- package/dist/entities/camera-stream.entity.js +2 -3
- package/dist/entities/camera-stream.entity.js.map +1 -1
- package/dist/entities/custom-gcode.entity.js +1 -2
- package/dist/entities/custom-gcode.entity.js.map +1 -1
- package/dist/entities/floor-position.entity.js.map +1 -1
- package/dist/entities/floor.entity.js +1 -2
- package/dist/entities/floor.entity.js.map +1 -1
- package/dist/entities/group.entity.js +6 -2
- package/dist/entities/group.entity.js.map +1 -1
- package/dist/entities/permission.entity.js +1 -2
- package/dist/entities/permission.entity.js.map +1 -1
- package/dist/entities/print-completion.entity.js +1 -2
- package/dist/entities/print-completion.entity.js.map +1 -1
- package/dist/entities/printer-group.entity.js +6 -2
- package/dist/entities/printer-group.entity.js.map +1 -1
- package/dist/entities/printer.entity.js +22 -4
- package/dist/entities/printer.entity.js.map +1 -1
- package/dist/entities/refresh-token.entity.js +1 -2
- package/dist/entities/refresh-token.entity.js.map +1 -1
- package/dist/entities/role.entity.js +1 -2
- package/dist/entities/role.entity.js.map +1 -1
- package/dist/entities/settings.entity.js +1 -2
- package/dist/entities/settings.entity.js.map +1 -1
- package/dist/entities/user-role.entity.js +1 -2
- package/dist/entities/user-role.entity.js.map +1 -1
- package/dist/entities/user.entity.js +1 -2
- package/dist/entities/user.entity.js.map +1 -1
- package/dist/exceptions/runtime.exceptions.js.map +1 -1
- package/dist/handlers/logger-factory.js +2 -2
- package/dist/handlers/logger-factory.js.map +1 -1
- package/dist/handlers/logger.js +11 -58
- package/dist/handlers/logger.js.map +1 -1
- package/dist/handlers/logging/file-logging.transport.js +35 -0
- package/dist/handlers/logging/file-logging.transport.js.map +1 -0
- package/dist/handlers/logging/loki-logging.transport.js +55 -0
- package/dist/handlers/logging/loki-logging.transport.js.map +1 -0
- package/dist/handlers/logging/static.logger.js +134 -0
- package/dist/handlers/logging/static.logger.js.map +1 -0
- package/dist/handlers/validators.js +7 -116
- package/dist/handlers/validators.js.map +1 -1
- package/dist/index.js +13 -0
- package/dist/index.js.map +1 -1
- package/dist/middleware/authenticate.js +11 -22
- package/dist/middleware/authenticate.js.map +1 -1
- package/dist/middleware/database.js.map +1 -1
- package/dist/middleware/demo.middleware.js +4 -17
- package/dist/middleware/demo.middleware.js.map +1 -1
- package/dist/middleware/exception.filter.js +23 -23
- package/dist/middleware/exception.filter.js.map +1 -1
- package/dist/middleware/global.middleware.js +4 -4
- package/dist/middleware/global.middleware.js.map +1 -1
- package/dist/middleware/param-converter.middleware.js +81 -0
- package/dist/middleware/param-converter.middleware.js.map +1 -0
- package/dist/middleware/passport.js +3 -5
- package/dist/middleware/passport.js.map +1 -1
- package/dist/middleware/printer-resolver.js +37 -0
- package/dist/middleware/printer-resolver.js.map +1 -0
- package/dist/middleware/printer.js +22 -10
- package/dist/middleware/printer.js.map +1 -1
- package/dist/middleware/socketio.middleware.js +35 -0
- package/dist/middleware/socketio.middleware.js.map +1 -0
- package/dist/migrations/1706829146617-InitSqlite.js +1 -1
- package/dist/migrations/1706829146617-InitSqlite.js.map +1 -1
- package/dist/migrations/1707494762198-PrinterGroup.js +1 -1
- package/dist/migrations/1707494762198-PrinterGroup.js.map +1 -1
- package/dist/migrations/1708465930665-ChangePrintCompletionDeletePrinterCascade.js +1 -1
- package/dist/migrations/1708465930665-ChangePrintCompletionDeletePrinterCascade.js.map +1 -1
- package/dist/migrations/1713897879622-AddPrinterType.js +1 -1
- package/dist/migrations/1713897879622-AddPrinterType.js.map +1 -1
- package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js +229 -0
- package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js.map +1 -0
- package/dist/models/Auth/Permission.js.map +1 -1
- package/dist/models/Auth/RefreshToken.js +1 -1
- package/dist/models/Auth/RefreshToken.js.map +1 -1
- package/dist/models/Auth/Role.js.map +1 -1
- package/dist/models/Auth/User.js.map +1 -1
- package/dist/models/CameraStream.js +20 -0
- package/dist/models/CameraStream.js.map +1 -1
- package/dist/models/CustomGcode.js.map +1 -1
- package/dist/models/Floor.js.map +1 -1
- package/dist/models/FloorPrinter.js +10 -1
- package/dist/models/FloorPrinter.js.map +1 -1
- package/dist/models/PrintCompletion.js.map +1 -1
- package/dist/models/Printer.js +12 -5
- package/dist/models/Printer.js.map +1 -1
- package/dist/models/Settings.js +11 -43
- package/dist/models/Settings.js.map +1 -1
- package/dist/models/index.js +0 -4
- package/dist/models/index.js.map +1 -1
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js.map +1 -1
- package/dist/mongo-migrations/20210907173950-printers-enabled.js.map +1 -1
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js.map +1 -1
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js.map +1 -1
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js.map +1 -1
- package/dist/mongo-migrations/20230716065316-user-remove-name.js.map +1 -1
- package/dist/mongo-migrations/20231111081809-printer-flatten-name.js.map +1 -1
- package/dist/mongo-migrations/20231111082521-printer-remove-settingsappearance.js.map +1 -1
- package/dist/mongo-migrations/20231202183902-printer-files-simpler.js.map +1 -1
- package/dist/server.constants.js +8 -4
- package/dist/server.constants.js.map +1 -1
- package/dist/server.core.js +29 -2
- package/dist/server.core.js.map +1 -1
- package/dist/server.env.js +22 -18
- package/dist/server.env.js.map +1 -1
- package/dist/server.host.js +24 -33
- package/dist/server.host.js.map +1 -1
- package/dist/services/authentication/auth.service.js +15 -20
- package/dist/services/authentication/auth.service.js.map +1 -1
- package/dist/services/authentication/jwt.service.js +1 -1
- package/dist/services/authentication/jwt.service.js.map +1 -1
- package/dist/services/core/batch-call.service.js +23 -25
- package/dist/services/core/batch-call.service.js.map +1 -1
- package/dist/services/core/client-bundle.service.js +78 -136
- package/dist/services/core/client-bundle.service.js.map +1 -1
- package/dist/services/core/config.service.js.map +1 -1
- package/dist/services/core/cradle.service.js +21 -0
- package/dist/services/core/cradle.service.js.map +1 -0
- package/dist/services/core/github.service.js +2 -2
- package/dist/services/core/github.service.js.map +1 -1
- package/dist/services/core/http-client.factory.js +1 -1
- package/dist/services/core/http-client.factory.js.map +1 -1
- package/dist/services/core/logs-manager.service.js +3 -3
- package/dist/services/core/logs-manager.service.js.map +1 -1
- package/dist/services/core/monsterpi.service.js +1 -1
- package/dist/services/core/monsterpi.service.js.map +1 -1
- package/dist/services/core/multer.service.js +8 -7
- package/dist/services/core/multer.service.js.map +1 -1
- package/dist/services/core/server-release.service.js +14 -8
- package/dist/services/core/server-release.service.js.map +1 -1
- package/dist/services/core/yaml.service.js +16 -17
- package/dist/services/core/yaml.service.js.map +1 -1
- package/dist/services/interfaces/camera-stream.dto.js +4 -34
- package/dist/services/interfaces/camera-stream.dto.js.map +1 -1
- package/dist/services/interfaces/custom-gcode.dto.js.map +1 -1
- package/dist/services/interfaces/floor.dto.js +5 -47
- package/dist/services/interfaces/floor.dto.js.map +1 -1
- package/dist/services/interfaces/login.dto.js +2 -0
- package/dist/services/interfaces/login.dto.js.map +1 -1
- package/dist/services/interfaces/print-completion.dto.js.map +1 -1
- package/dist/services/interfaces/printer-group.dto.js +0 -14
- package/dist/services/interfaces/printer-group.dto.js.map +1 -1
- package/dist/services/interfaces/printer.dto.js +11 -11
- package/dist/services/interfaces/printer.dto.js.map +1 -1
- package/dist/services/interfaces/settings.dto.js.map +1 -1
- package/dist/services/interfaces/task.interfaces.js +6 -0
- package/dist/services/interfaces/task.interfaces.js.map +1 -0
- package/dist/services/mongoose/camera-stream.service.js +17 -15
- package/dist/services/mongoose/camera-stream.service.js.map +1 -1
- package/dist/services/mongoose/custom-gcode.service.js +4 -2
- package/dist/services/mongoose/custom-gcode.service.js.map +1 -1
- package/dist/services/mongoose/floor.service.js +37 -30
- package/dist/services/mongoose/floor.service.js.map +1 -1
- package/dist/services/mongoose/permission.service.js +1 -1
- package/dist/services/mongoose/permission.service.js.map +1 -1
- package/dist/services/mongoose/print-completion.service.js +2 -2
- package/dist/services/mongoose/print-completion.service.js.map +1 -1
- package/dist/services/mongoose/print-completion.shared.js +2 -2
- package/dist/services/mongoose/print-completion.shared.js.map +1 -1
- package/dist/services/mongoose/printer.service.js +33 -45
- package/dist/services/mongoose/printer.service.js.map +1 -1
- package/dist/services/mongoose/refresh-token.service.js +5 -8
- package/dist/services/mongoose/refresh-token.service.js.map +1 -1
- package/dist/services/mongoose/role.service.js +14 -5
- package/dist/services/mongoose/role.service.js.map +1 -1
- package/dist/services/mongoose/settings.service.js +35 -62
- package/dist/services/mongoose/settings.service.js.map +1 -1
- package/dist/services/mongoose/user.service.js +8 -7
- package/dist/services/mongoose/user.service.js.map +1 -1
- package/dist/services/moonraker/constants/{websocket.constants.js → moonraker.constants.js} +1 -1
- package/dist/services/moonraker/constants/{websocket.constants.js.map → moonraker.constants.js.map} +1 -1
- package/dist/services/moonraker/moonraker-websocket.adapter.js +109 -96
- package/dist/services/moonraker/moonraker-websocket.adapter.js.map +1 -1
- package/dist/services/moonraker/moonraker.client.js +25 -16
- package/dist/services/moonraker/moonraker.client.js.map +1 -1
- package/dist/services/moonraker.api.js +5 -7
- package/dist/services/moonraker.api.js.map +1 -1
- package/dist/services/octoprint/constants/octoprint-service.constants.js +7 -36
- package/dist/services/octoprint/constants/octoprint-service.constants.js.map +1 -1
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js +12 -3
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js.map +1 -1
- package/dist/services/octoprint/dto/octoprint-event.dto.js +2 -1
- package/dist/services/octoprint/dto/octoprint-event.dto.js.map +1 -1
- package/dist/services/octoprint/octoprint-api.routes.js +1 -38
- package/dist/services/octoprint/octoprint-api.routes.js.map +1 -1
- package/dist/services/octoprint/octoprint-websocket.adapter.js +66 -72
- package/dist/services/octoprint/octoprint-websocket.adapter.js.map +1 -1
- package/dist/services/octoprint/octoprint.client.js +19 -192
- package/dist/services/octoprint/octoprint.client.js.map +1 -1
- package/dist/services/octoprint/utils/octoprint-http-client.builder.js.map +1 -1
- package/dist/services/octoprint.api.js +10 -19
- package/dist/services/octoprint.api.js.map +1 -1
- package/dist/services/orm/base.service.js +11 -12
- package/dist/services/orm/base.service.js.map +1 -1
- package/dist/services/orm/camera-stream.service.js +5 -1
- package/dist/services/orm/camera-stream.service.js.map +1 -1
- package/dist/services/orm/custom-gcode.service.js +2 -2
- package/dist/services/orm/custom-gcode.service.js.map +1 -1
- package/dist/services/orm/floor-position.service.js +0 -5
- package/dist/services/orm/floor-position.service.js.map +1 -1
- package/dist/services/orm/floor.service.js +43 -39
- package/dist/services/orm/floor.service.js.map +1 -1
- package/dist/services/orm/permission.service.js +3 -4
- package/dist/services/orm/permission.service.js.map +1 -1
- package/dist/services/orm/print-completion.service.js +2 -4
- package/dist/services/orm/print-completion.service.js.map +1 -1
- package/dist/services/orm/printer-group.service.js +2 -7
- package/dist/services/orm/printer-group.service.js.map +1 -1
- package/dist/services/orm/printer.service.js +21 -36
- package/dist/services/orm/printer.service.js.map +1 -1
- package/dist/services/orm/refresh-token.service.js +5 -11
- package/dist/services/orm/refresh-token.service.js.map +1 -1
- package/dist/services/orm/role.service.js +11 -10
- package/dist/services/orm/role.service.js.map +1 -1
- package/dist/services/orm/settings.service.js +37 -133
- package/dist/services/orm/settings.service.js.map +1 -1
- package/dist/services/orm/user.service.js +13 -15
- package/dist/services/orm/user.service.js.map +1 -1
- package/dist/services/printer-api.factory.js +9 -6
- package/dist/services/printer-api.factory.js.map +1 -1
- package/dist/services/printer-api.interface.js +13 -6
- package/dist/services/printer-api.interface.js.map +1 -1
- package/dist/services/prusa-link/constants/prusalink-event.dto.js +18 -0
- package/dist/services/prusa-link/constants/prusalink-event.dto.js.map +1 -0
- package/dist/services/prusa-link/constants/prusalink.constants.js +13 -0
- package/dist/services/prusa-link/constants/prusalink.constants.js.map +1 -0
- package/dist/services/prusa-link/dto/file-response.dto.js +6 -0
- package/dist/services/prusa-link/dto/file-response.dto.js.map +1 -0
- package/dist/services/{octoprint/dto/plugin.dto.js → prusa-link/dto/file.dto.js} +1 -1
- package/dist/services/prusa-link/dto/file.dto.js.map +1 -0
- package/dist/services/prusa-link/dto/job-state.dto.js +6 -0
- package/dist/services/prusa-link/dto/job-state.dto.js.map +1 -0
- package/dist/services/prusa-link/dto/printer-state.dto.js +6 -0
- package/dist/services/prusa-link/dto/printer-state.dto.js.map +1 -0
- package/dist/services/prusa-link/dto/status.dto.js +6 -0
- package/dist/services/prusa-link/dto/status.dto.js.map +1 -0
- package/dist/services/prusa-link/dto/version.dto.js +6 -0
- package/dist/services/prusa-link/dto/version.dto.js.map +1 -0
- package/dist/services/prusa-link/prusa-link-http-polling.adapter.js +142 -0
- package/dist/services/prusa-link/prusa-link-http-polling.adapter.js.map +1 -0
- package/dist/services/prusa-link/prusa-link.api.js +235 -0
- package/dist/services/prusa-link/prusa-link.api.js.map +1 -0
- package/dist/services/prusa-link/utils/digest-auth.params.js +6 -0
- package/dist/services/prusa-link/utils/digest-auth.params.js.map +1 -0
- package/dist/services/prusa-link/utils/digest-auth.util.js +28 -0
- package/dist/services/prusa-link/utils/digest-auth.util.js.map +1 -0
- package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js +131 -0
- package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js.map +1 -0
- package/dist/services/socket.factory.js +9 -6
- package/dist/services/socket.factory.js.map +1 -1
- package/dist/services/{core/task-manager.service.js → task-manager.service.js} +72 -78
- package/dist/services/task-manager.service.js.map +1 -0
- package/dist/services/validators/camera-service.validation.js +19 -0
- package/dist/services/validators/camera-service.validation.js.map +1 -0
- package/dist/services/validators/floor-service.validation.js +47 -36
- package/dist/services/validators/floor-service.validation.js.map +1 -1
- package/dist/services/validators/print-completion-service.validation.js +22 -9
- package/dist/services/validators/print-completion-service.validation.js.map +1 -1
- package/dist/services/validators/printer-service.validation.js +112 -29
- package/dist/services/validators/printer-service.validation.js.map +1 -1
- package/dist/services/validators/settings-service.validation.js +79 -66
- package/dist/services/validators/settings-service.validation.js.map +1 -1
- package/dist/services/validators/user-service.validation.js +17 -16
- package/dist/services/validators/user-service.validation.js.map +1 -1
- package/dist/services/validators/yaml-service.validation.js +94 -51
- package/dist/services/validators/yaml-service.validation.js.map +1 -1
- package/dist/shared/default-http-client.builder.js.map +1 -1
- package/dist/shared/load-controllers.js +20 -0
- package/dist/shared/load-controllers.js.map +1 -0
- package/dist/shared/runtime-settings.migration.js +53 -0
- package/dist/shared/runtime-settings.migration.js.map +1 -0
- package/dist/shared/websocket-rpc-extended.adapter.js +15 -14
- package/dist/shared/websocket-rpc-extended.adapter.js.map +1 -1
- package/dist/shared/websocket.adapter.js +4 -5
- package/dist/shared/websocket.adapter.js.map +1 -1
- package/dist/state/file-upload-tracker.cache.js +5 -4
- package/dist/state/file-upload-tracker.cache.js.map +1 -1
- package/dist/state/file.cache.js +1 -1
- package/dist/state/file.cache.js.map +1 -1
- package/dist/state/floor.store.js +6 -6
- package/dist/state/floor.store.js.map +1 -1
- package/dist/state/printer-events.cache.js +21 -22
- package/dist/state/printer-events.cache.js.map +1 -1
- package/dist/state/printer-files.store.js +6 -8
- package/dist/state/printer-files.store.js.map +1 -1
- package/dist/state/printer-socket.store.js +27 -50
- package/dist/state/printer-socket.store.js.map +1 -1
- package/dist/state/printer-thumbnail.cache.js +5 -9
- package/dist/state/printer-thumbnail.cache.js.map +1 -1
- package/dist/state/printer.cache.js +14 -12
- package/dist/state/printer.cache.js.map +1 -1
- package/dist/state/settings.store.js +74 -50
- package/dist/state/settings.store.js.map +1 -1
- package/dist/state/socket-io.gateway.js +39 -36
- package/dist/state/socket-io.gateway.js.map +1 -1
- package/dist/state/test-printer-socket.store.js +20 -15
- package/dist/state/test-printer-socket.store.js.map +1 -1
- package/dist/state/validation/create-test-printer.validation.js +13 -11
- package/dist/state/validation/create-test-printer.validation.js.map +1 -1
- package/dist/task.presets.js.map +1 -1
- package/dist/tasks/boot.task.js +14 -19
- package/dist/tasks/boot.task.js.map +1 -1
- package/dist/tasks/client-bundle.task.js +1 -3
- package/dist/tasks/client-bundle.task.js.map +1 -1
- package/dist/tasks/print-completion.socketio.task.js +27 -28
- package/dist/tasks/print-completion.socketio.task.js.map +1 -1
- package/dist/tasks/printer-file-clean.task.js +6 -10
- package/dist/tasks/printer-file-clean.task.js.map +1 -1
- package/dist/tasks/printer-websocket-restore.task.js +3 -14
- package/dist/tasks/printer-websocket-restore.task.js.map +1 -1
- package/dist/tasks/printer-websocket.task.js +2 -14
- package/dist/tasks/printer-websocket.task.js.map +1 -1
- package/dist/tasks/socketio.task.js +6 -33
- package/dist/tasks/socketio.task.js.map +1 -1
- package/dist/tasks/software-update.task.js +1 -1
- package/dist/tasks/software-update.task.js.map +1 -1
- package/dist/tasks.js +3 -3
- package/dist/tasks.js.map +1 -1
- package/dist/utils/array.util.js.map +1 -1
- package/dist/utils/cache/key-diff.cache.js.map +1 -1
- package/dist/utils/env.utils.js +0 -2
- package/dist/utils/env.utils.js.map +1 -1
- package/dist/utils/normalize-url.js +3 -2
- package/dist/utils/normalize-url.js.map +1 -1
- package/dist/utils/printer-type.utils.js.map +1 -1
- package/dist/utils/time.utils.js +7 -17
- package/dist/utils/time.utils.js.map +1 -1
- package/dist/utils/url.utils.js +3 -4
- package/dist/utils/url.utils.js.map +1 -1
- package/package.json +46 -48
- package/tsconfig.json +2 -1
- package/.yarn/releases/yarn-4.7.0.cjs +0 -935
- package/dist/consoles/check-ports.js +0 -170
- package/dist/consoles/check-ports.js.map +0 -1
- package/dist/consoles/http-file-receiver.console.js +0 -81
- package/dist/consoles/http-file-receiver.console.js.map +0 -1
- package/dist/consoles/sqlite-torm.js +0 -31
- package/dist/consoles/sqlite-torm.js.map +0 -1
- package/dist/consoles/upload-test.js +0 -52
- package/dist/consoles/upload-test.js.map +0 -1
- package/dist/controllers/plugin-firmware-update.controller.js +0 -234
- package/dist/controllers/plugin-firmware-update.controller.js.map +0 -1
- package/dist/entities/base.entity.js +0 -29
- package/dist/entities/base.entity.js.map +0 -1
- package/dist/entities/printer-file.entity.js +0 -140
- package/dist/entities/printer-file.entity.js.map +0 -1
- package/dist/handlers/cache-manager.js +0 -18
- package/dist/handlers/cache-manager.js.map +0 -1
- package/dist/models/PrinterFile.js +0 -44
- package/dist/models/PrinterFile.js.map +0 -1
- package/dist/services/core/task-manager.service.js.map +0 -1
- package/dist/services/octoprint/dto/plugin.dto.js.map +0 -1
- package/dist/services/octoprint/plugin-base.service.js +0 -101
- package/dist/services/octoprint/plugin-base.service.js.map +0 -1
- package/dist/services/octoprint/plugin-firmware-update.service.js +0 -100
- package/dist/services/octoprint/plugin-firmware-update.service.js.map +0 -1
- package/dist/services/octoprint/plugin-repository.cache.js +0 -46
- package/dist/services/octoprint/plugin-repository.cache.js.map +0 -1
- package/dist/utils/benchmark.util.js +0 -39
- package/dist/utils/benchmark.util.js.map +0 -1
- package/dist/utils/is-docker.js +0 -40
- package/dist/utils/is-docker.js.map +0 -1
- package/dist/utils/metric.utils.js +0 -35
- package/dist/utils/metric.utils.js.map +0 -1
|
@@ -2,73 +2,149 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", {
|
|
3
3
|
value: true
|
|
4
4
|
});
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
get: all[name]
|
|
9
|
-
});
|
|
10
|
-
}
|
|
11
|
-
_export(exports, {
|
|
12
|
-
CustomGcodeController: function() {
|
|
5
|
+
Object.defineProperty(exports, "CustomGcodeController", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
13
8
|
return CustomGcodeController;
|
|
14
|
-
},
|
|
15
|
-
default: function() {
|
|
16
|
-
return _default;
|
|
17
9
|
}
|
|
18
10
|
});
|
|
19
11
|
const _awilixexpress = require("awilix-express");
|
|
20
12
|
const _authenticate = require("../middleware/authenticate");
|
|
21
13
|
const _serverconstants = require("../server.constants");
|
|
22
14
|
const _authorizationconstants = require("../constants/authorization.constants");
|
|
23
|
-
const _validators = require("../handlers/validators");
|
|
24
|
-
const _genericvalidation = require("./validation/generic.validation");
|
|
25
15
|
const _printer = require("../middleware/printer");
|
|
16
|
+
const _express = require("express");
|
|
17
|
+
const _customgcodeserviceinterface = require("../services/interfaces/custom-gcode.service.interface");
|
|
18
|
+
const _printerresolver = require("../middleware/printer-resolver");
|
|
19
|
+
const _paramconvertermiddleware = require("../middleware/param-converter.middleware");
|
|
20
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
21
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
22
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
23
|
+
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;
|
|
24
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
25
|
+
}
|
|
26
|
+
function _ts_metadata(k, v) {
|
|
27
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
28
|
+
}
|
|
26
29
|
class CustomGcodeController {
|
|
27
30
|
customGCodeService;
|
|
28
31
|
isTypeormMode;
|
|
29
|
-
constructor(
|
|
32
|
+
constructor(customGCodeService, isTypeormMode){
|
|
30
33
|
this.customGCodeService = customGCodeService;
|
|
31
34
|
this.isTypeormMode = isTypeormMode;
|
|
32
35
|
}
|
|
33
|
-
async list(req, res) {
|
|
34
|
-
const entities = await this.customGCodeService.list();
|
|
35
|
-
res.send(entities.map((e)=>this.customGCodeService.toDto(e)));
|
|
36
|
-
}
|
|
37
|
-
async get(req, res) {
|
|
38
|
-
const { id } = await (0, _validators.validateInput)(req.params, (0, _genericvalidation.idRulesV2)(this.isTypeormMode));
|
|
39
|
-
const entity = await this.customGCodeService.get(id);
|
|
40
|
-
res.send(this.customGCodeService.toDto(entity));
|
|
41
|
-
}
|
|
42
36
|
async sendEmergencyM112(req, res) {
|
|
43
|
-
const { printerApi } = (0,
|
|
37
|
+
const { printerApi } = (0, _printerresolver.getScopedPrinter)(req);
|
|
44
38
|
await printerApi.quickStop();
|
|
45
39
|
res.send();
|
|
46
40
|
}
|
|
41
|
+
async list(req, res) {
|
|
42
|
+
const entities = await this.customGCodeService.list();
|
|
43
|
+
res.send(entities.map((e)=>this.customGCodeService.toDto(e)));
|
|
44
|
+
}
|
|
47
45
|
async create(req, res) {
|
|
48
46
|
const entity = await this.customGCodeService.create(req.body);
|
|
49
47
|
res.send(this.customGCodeService.toDto(entity));
|
|
50
48
|
}
|
|
51
|
-
async
|
|
52
|
-
const
|
|
53
|
-
|
|
54
|
-
res.send();
|
|
49
|
+
async get(req, res) {
|
|
50
|
+
const entity = await this.customGCodeService.get(req.local.id);
|
|
51
|
+
res.send(this.customGCodeService.toDto(entity));
|
|
55
52
|
}
|
|
56
53
|
async update(req, res) {
|
|
57
|
-
const
|
|
58
|
-
const updatedScript = await this.customGCodeService.update(id, req.body);
|
|
54
|
+
const updatedScript = await this.customGCodeService.update(req.local.id, req.body);
|
|
59
55
|
res.send(this.customGCodeService.toDto(updatedScript));
|
|
60
56
|
}
|
|
57
|
+
async delete(req, res) {
|
|
58
|
+
await this.customGCodeService.delete(req.local.id);
|
|
59
|
+
res.send();
|
|
60
|
+
}
|
|
61
61
|
}
|
|
62
|
-
|
|
63
|
-
(0,
|
|
64
|
-
(0,
|
|
65
|
-
|
|
66
|
-
_authorizationconstants.ROLES.OPERATOR
|
|
67
|
-
])
|
|
68
|
-
]).get("/", "list").get("/:id", "get").post("/", "create").post("/send-emergency-m112/:printerId", "sendEmergencyM112", {
|
|
69
|
-
before: [
|
|
62
|
+
_ts_decorate([
|
|
63
|
+
(0, _awilixexpress.POST)(),
|
|
64
|
+
(0, _awilixexpress.route)("/send-emergency-m112/:printerId"),
|
|
65
|
+
(0, _awilixexpress.before)([
|
|
70
66
|
(0, _printer.printerResolveMiddleware)("printerId")
|
|
71
|
-
]
|
|
72
|
-
|
|
67
|
+
]),
|
|
68
|
+
_ts_metadata("design:type", Function),
|
|
69
|
+
_ts_metadata("design:paramtypes", [
|
|
70
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
71
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
72
|
+
]),
|
|
73
|
+
_ts_metadata("design:returntype", Promise)
|
|
74
|
+
], CustomGcodeController.prototype, "sendEmergencyM112", null);
|
|
75
|
+
_ts_decorate([
|
|
76
|
+
(0, _awilixexpress.GET)(),
|
|
77
|
+
(0, _awilixexpress.route)("/"),
|
|
78
|
+
_ts_metadata("design:type", Function),
|
|
79
|
+
_ts_metadata("design:paramtypes", [
|
|
80
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
81
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
82
|
+
]),
|
|
83
|
+
_ts_metadata("design:returntype", Promise)
|
|
84
|
+
], CustomGcodeController.prototype, "list", null);
|
|
85
|
+
_ts_decorate([
|
|
86
|
+
(0, _awilixexpress.POST)(),
|
|
87
|
+
(0, _awilixexpress.route)("/"),
|
|
88
|
+
_ts_metadata("design:type", Function),
|
|
89
|
+
_ts_metadata("design:paramtypes", [
|
|
90
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
91
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
92
|
+
]),
|
|
93
|
+
_ts_metadata("design:returntype", Promise)
|
|
94
|
+
], CustomGcodeController.prototype, "create", null);
|
|
95
|
+
_ts_decorate([
|
|
96
|
+
(0, _awilixexpress.GET)(),
|
|
97
|
+
(0, _awilixexpress.route)("/:id"),
|
|
98
|
+
(0, _awilixexpress.before)([
|
|
99
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
100
|
+
]),
|
|
101
|
+
_ts_metadata("design:type", Function),
|
|
102
|
+
_ts_metadata("design:paramtypes", [
|
|
103
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
104
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
105
|
+
]),
|
|
106
|
+
_ts_metadata("design:returntype", Promise)
|
|
107
|
+
], CustomGcodeController.prototype, "get", null);
|
|
108
|
+
_ts_decorate([
|
|
109
|
+
(0, _awilixexpress.PUT)(),
|
|
110
|
+
(0, _awilixexpress.route)("/:id"),
|
|
111
|
+
(0, _awilixexpress.before)([
|
|
112
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
113
|
+
]),
|
|
114
|
+
_ts_metadata("design:type", Function),
|
|
115
|
+
_ts_metadata("design:paramtypes", [
|
|
116
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
117
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
118
|
+
]),
|
|
119
|
+
_ts_metadata("design:returntype", Promise)
|
|
120
|
+
], CustomGcodeController.prototype, "update", null);
|
|
121
|
+
_ts_decorate([
|
|
122
|
+
(0, _awilixexpress.DELETE)(),
|
|
123
|
+
(0, _awilixexpress.route)("/:id"),
|
|
124
|
+
(0, _awilixexpress.before)([
|
|
125
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
126
|
+
]),
|
|
127
|
+
_ts_metadata("design:type", Function),
|
|
128
|
+
_ts_metadata("design:paramtypes", [
|
|
129
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
130
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
131
|
+
]),
|
|
132
|
+
_ts_metadata("design:returntype", Promise)
|
|
133
|
+
], CustomGcodeController.prototype, "delete", null);
|
|
134
|
+
CustomGcodeController = _ts_decorate([
|
|
135
|
+
(0, _awilixexpress.route)(`${_serverconstants.AppConstants.apiRoute}/custom-gcode`),
|
|
136
|
+
(0, _awilixexpress.before)([
|
|
137
|
+
(0, _authenticate.authenticate)(),
|
|
138
|
+
(0, _authenticate.authorizeRoles)([
|
|
139
|
+
_authorizationconstants.ROLES.ADMIN,
|
|
140
|
+
_authorizationconstants.ROLES.OPERATOR
|
|
141
|
+
])
|
|
142
|
+
]),
|
|
143
|
+
_ts_metadata("design:type", Function),
|
|
144
|
+
_ts_metadata("design:paramtypes", [
|
|
145
|
+
typeof _customgcodeserviceinterface.ICustomGcodeService === "undefined" ? Object : _customgcodeserviceinterface.ICustomGcodeService,
|
|
146
|
+
Boolean
|
|
147
|
+
])
|
|
148
|
+
], CustomGcodeController);
|
|
73
149
|
|
|
74
150
|
//# sourceMappingURL=custom-gcode.controller.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controllers/custom-gcode.controller.ts"],"names":["CustomGcodeController","
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/custom-gcode.controller.ts"],"names":["CustomGcodeController","constructor","customGCodeService","isTypeormMode","sendEmergencyM112","req","res","printerApi","getScopedPrinter","quickStop","send","list","entities","map","e","toDto","create","entity","body","get","local","id","update","updatedScript","delete","printerResolveMiddleware","ParamId","AppConstants","apiRoute","authenticate","authorizeRoles","ROLES","ADMIN","OPERATOR"],"mappings":";;;;+BAYaA;;;eAAAA;;;+BAZyC;8BACT;iCAChB;wCACP;yBACmB;yBACP;6CACE;iCACH;0CACT;;;;;;;;;;AAIjB,MAAMA;;;IACXC,YACE,AAAiBC,kBAAuC,EACxD,AAAiBC,aAAsB,CACvC;aAFiBD,qBAAAA;aACAC,gBAAAA;IAChB;IAIH,MAGMC,kBAAkBC,GAAY,EAAEC,GAAa,EAAE;QACnD,MAAM,EAAEC,UAAU,EAAE,GAAGC,IAAAA,iCAAgB,EAACH;QACxC,MAAME,WAAWE,SAAS;QAC1BH,IAAII,IAAI;IACV;IAEA,MAEMC,KAAKN,GAAY,EAAEC,GAAa,EAAE;QACtC,MAAMM,WAAW,MAAM,IAAI,CAACV,kBAAkB,CAACS,IAAI;QACnDL,IAAII,IAAI,CAACE,SAASC,GAAG,CAAC,CAACC,IAAM,IAAI,CAACZ,kBAAkB,CAACa,KAAK,CAACD;IAC7D;IAEA,MAEME,OAAOX,GAAY,EAAEC,GAAa,EAAE;QACxC,MAAMW,SAAS,MAAM,IAAI,CAACf,kBAAkB,CAACc,MAAM,CAACX,IAAIa,IAAI;QAC5DZ,IAAII,IAAI,CAAC,IAAI,CAACR,kBAAkB,CAACa,KAAK,CAACE;IACzC;IAEA,MAGME,IAAId,GAAY,EAAEC,GAAa,EAAE;QACrC,MAAMW,SAAS,MAAM,IAAI,CAACf,kBAAkB,CAACiB,GAAG,CAACd,IAAIe,KAAK,CAACC,EAAE;QAC7Df,IAAII,IAAI,CAAC,IAAI,CAACR,kBAAkB,CAACa,KAAK,CAACE;IACzC;IAEA,MAGMK,OAAOjB,GAAY,EAAEC,GAAa,EAAE;QACxC,MAAMiB,gBAAgB,MAAM,IAAI,CAACrB,kBAAkB,CAACoB,MAAM,CAACjB,IAAIe,KAAK,CAACC,EAAE,EAAEhB,IAAIa,IAAI;QACjFZ,IAAII,IAAI,CAAC,IAAI,CAACR,kBAAkB,CAACa,KAAK,CAACQ;IACzC;IAEA,MAGMC,OAAOnB,GAAY,EAAEC,GAAa,EAAE;QACxC,MAAM,IAAI,CAACJ,kBAAkB,CAACsB,MAAM,CAACnB,IAAIe,KAAK,CAACC,EAAE;QACjDf,IAAII,IAAI;IACV;AACF;;;;;QA5CWe,IAAAA,iCAAwB,EAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAuBzBC,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAQRA,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAQRA,IAAAA,iCAAO,EAAC;;;;;;;;;;iCAnDTC,6BAAY,CAACC,QAAQ,CAAC,aAAa;;QACpCC,IAAAA,0BAAY;QAAIC,IAAAA,4BAAc,EAAC;YAACC,6BAAK,CAACC,KAAK;YAAED,6BAAK,CAACE,QAAQ;SAAC"}
|
|
@@ -8,31 +8,10 @@ Object.defineProperty(exports, "UpdateClientDistDto", {
|
|
|
8
8
|
return UpdateClientDistDto;
|
|
9
9
|
}
|
|
10
10
|
});
|
|
11
|
-
const _classvalidator = require("class-validator");
|
|
12
11
|
const _serverconstants = require("../../server.constants");
|
|
13
|
-
function _ts_decorate(decorators, target, key, desc) {
|
|
14
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
15
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
16
|
-
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;
|
|
17
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
18
|
-
}
|
|
19
|
-
function _ts_metadata(k, v) {
|
|
20
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
21
|
-
}
|
|
22
12
|
class UpdateClientDistDto {
|
|
23
13
|
downloadRelease = _serverconstants.AppConstants.defaultClientMinimum;
|
|
24
14
|
allowDowngrade = false;
|
|
25
15
|
}
|
|
26
|
-
_ts_decorate([
|
|
27
|
-
(0, _classvalidator.IsOptional)(),
|
|
28
|
-
(0, _classvalidator.IsString)(),
|
|
29
|
-
(0, _classvalidator.IsSemVer)(),
|
|
30
|
-
_ts_metadata("design:type", String)
|
|
31
|
-
], UpdateClientDistDto.prototype, "downloadRelease", void 0);
|
|
32
|
-
_ts_decorate([
|
|
33
|
-
(0, _classvalidator.IsOptional)(),
|
|
34
|
-
(0, _classvalidator.IsBoolean)(),
|
|
35
|
-
_ts_metadata("design:type", Boolean)
|
|
36
|
-
], UpdateClientDistDto.prototype, "allowDowngrade", void 0);
|
|
37
16
|
|
|
38
17
|
//# sourceMappingURL=update-client-dist.dto.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/controllers/dto/update-client-dist.dto.ts"],"names":["UpdateClientDistDto","downloadRelease","AppConstants","defaultClientMinimum","allowDowngrade"],"mappings":";;;;+
|
|
1
|
+
{"version":3,"sources":["../../../src/controllers/dto/update-client-dist.dto.ts"],"names":["UpdateClientDistDto","downloadRelease","AppConstants","defaultClientMinimum","allowDowngrade"],"mappings":";;;;+BAEaA;;;eAAAA;;;iCAFgB;AAEtB,MAAMA;IACXC,kBAA2BC,6BAAY,CAACC,oBAAoB,CAAC;IAE7DC,iBAA2B,MAAM;AACnC"}
|
|
@@ -2,18 +2,10 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", {
|
|
3
3
|
value: true
|
|
4
4
|
});
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
get: all[name]
|
|
9
|
-
});
|
|
10
|
-
}
|
|
11
|
-
_export(exports, {
|
|
12
|
-
FirstTimeSetupController: function() {
|
|
5
|
+
Object.defineProperty(exports, "FirstTimeSetupController", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
13
8
|
return FirstTimeSetupController;
|
|
14
|
-
},
|
|
15
|
-
default: function() {
|
|
16
|
-
return _default;
|
|
17
9
|
}
|
|
18
10
|
});
|
|
19
11
|
const _awilixexpress = require("awilix-express");
|
|
@@ -22,18 +14,34 @@ const _validators = require("../handlers/validators");
|
|
|
22
14
|
const _settingvalidation = require("./validation/setting.validation");
|
|
23
15
|
const _runtimeexceptions = require("../exceptions/runtime.exceptions");
|
|
24
16
|
const _authorizationconstants = require("../constants/authorization.constants");
|
|
17
|
+
const _settingsstore = require("../state/settings.store");
|
|
18
|
+
const _express = require("express");
|
|
19
|
+
const _userserviceinterface = require("../services/interfaces/user-service.interface");
|
|
20
|
+
const _roleserviceinterface = require("../services/interfaces/role-service.interface");
|
|
21
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
22
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
23
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
24
|
+
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;
|
|
25
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
26
|
+
}
|
|
27
|
+
function _ts_metadata(k, v) {
|
|
28
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
29
|
+
}
|
|
25
30
|
class FirstTimeSetupController {
|
|
26
|
-
userService;
|
|
27
|
-
roleService;
|
|
28
31
|
settingsStore;
|
|
29
|
-
|
|
32
|
+
roleService;
|
|
33
|
+
userService;
|
|
34
|
+
constructor(settingsStore, roleService, userService){
|
|
30
35
|
this.settingsStore = settingsStore;
|
|
31
36
|
this.roleService = roleService;
|
|
32
37
|
this.userService = userService;
|
|
33
38
|
}
|
|
34
39
|
async validateWizard(req, res) {
|
|
35
|
-
const {
|
|
36
|
-
|
|
40
|
+
const { rootUsername } = await (0, _validators.validateMiddleware)(req, _settingvalidation.wizardSettingsSchema);
|
|
41
|
+
await this.roleService.getSynchronizedRoleByName(_authorizationconstants.ROLES.ADMIN);
|
|
42
|
+
if (this.settingsStore.isWizardCompleted()) {
|
|
43
|
+
throw new _runtimeexceptions.ForbiddenError("Wizard already completed");
|
|
44
|
+
}
|
|
37
45
|
const user = await this.userService.findRawByUsername(rootUsername?.toLowerCase());
|
|
38
46
|
if (!!user) {
|
|
39
47
|
throw new _runtimeexceptions.BadRequestException("This user already exists");
|
|
@@ -41,7 +49,7 @@ class FirstTimeSetupController {
|
|
|
41
49
|
return res.send();
|
|
42
50
|
}
|
|
43
51
|
async completeWizard(req, res) {
|
|
44
|
-
const { loginRequired, registration, rootUsername, rootPassword } = await (0, _validators.validateMiddleware)(req, _settingvalidation.
|
|
52
|
+
const { loginRequired, registration, rootUsername, rootPassword } = await (0, _validators.validateMiddleware)(req, _settingvalidation.wizardSettingsSchema);
|
|
45
53
|
if (this.settingsStore.isWizardCompleted()) {
|
|
46
54
|
throw new _runtimeexceptions.ForbiddenError("Wizard already completed");
|
|
47
55
|
}
|
|
@@ -67,6 +75,34 @@ class FirstTimeSetupController {
|
|
|
67
75
|
return res.send();
|
|
68
76
|
}
|
|
69
77
|
}
|
|
70
|
-
|
|
78
|
+
_ts_decorate([
|
|
79
|
+
(0, _awilixexpress.POST)(),
|
|
80
|
+
(0, _awilixexpress.route)("/validate"),
|
|
81
|
+
_ts_metadata("design:type", Function),
|
|
82
|
+
_ts_metadata("design:paramtypes", [
|
|
83
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
84
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
85
|
+
]),
|
|
86
|
+
_ts_metadata("design:returntype", Promise)
|
|
87
|
+
], FirstTimeSetupController.prototype, "validateWizard", null);
|
|
88
|
+
_ts_decorate([
|
|
89
|
+
(0, _awilixexpress.POST)(),
|
|
90
|
+
(0, _awilixexpress.route)("/complete"),
|
|
91
|
+
_ts_metadata("design:type", Function),
|
|
92
|
+
_ts_metadata("design:paramtypes", [
|
|
93
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
94
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
95
|
+
]),
|
|
96
|
+
_ts_metadata("design:returntype", Promise)
|
|
97
|
+
], FirstTimeSetupController.prototype, "completeWizard", null);
|
|
98
|
+
FirstTimeSetupController = _ts_decorate([
|
|
99
|
+
(0, _awilixexpress.route)(_serverconstants.AppConstants.apiRoute + "/first-time-setup"),
|
|
100
|
+
_ts_metadata("design:type", Function),
|
|
101
|
+
_ts_metadata("design:paramtypes", [
|
|
102
|
+
typeof _settingsstore.SettingsStore === "undefined" ? Object : _settingsstore.SettingsStore,
|
|
103
|
+
typeof _roleserviceinterface.IRoleService === "undefined" ? Object : _roleserviceinterface.IRoleService,
|
|
104
|
+
typeof _userserviceinterface.IUserService === "undefined" ? Object : _userserviceinterface.IUserService
|
|
105
|
+
])
|
|
106
|
+
], FirstTimeSetupController);
|
|
71
107
|
|
|
72
108
|
//# sourceMappingURL=first-time-setup.controller.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controllers/first-time-setup.controller.ts"],"names":["FirstTimeSetupController","
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/first-time-setup.controller.ts"],"names":["FirstTimeSetupController","constructor","settingsStore","roleService","userService","validateWizard","req","res","rootUsername","validateMiddleware","wizardSettingsSchema","getSynchronizedRoleByName","ROLES","ADMIN","isWizardCompleted","ForbiddenError","user","findRawByUsername","toLowerCase","BadRequestException","send","completeWizard","loginRequired","registration","rootPassword","role","register","username","password","roles","id","isRootUser","isVerified","isDemoUser","needsPasswordChange","setLoginRequired","setRegistrationEnabled","setWizardCompleted","AppConstants","currentWizardVersion","apiRoute"],"mappings":";;;;+BAYaA;;;eAAAA;;;+BAZe;iCACC;4BACM;mCACE;mCACe;wCAC9B;+BACQ;yBACI;sCACL;sCACA;;;;;;;;;;AAGtB,MAAMA;;;;IACXC,YACE,AAAiBC,aAA4B,EAC7C,AAAiBC,WAAyB,EAC1C,AAAiBC,WAAyB,CAC1C;aAHiBF,gBAAAA;aACAC,cAAAA;aACAC,cAAAA;IAChB;IAEH,MAEMC,eAAeC,GAAY,EAAEC,GAAa,EAAE;QAChD,MAAM,EAAEC,YAAY,EAAE,GAAG,MAAMC,IAAAA,8BAAkB,EAACH,KAAKI,uCAAoB;QAC3E,MAAM,IAAI,CAACP,WAAW,CAACQ,yBAAyB,CAACC,6BAAK,CAACC,KAAK;QAE5D,IAAI,IAAI,CAACX,aAAa,CAACY,iBAAiB,IAAI;YAC1C,MAAM,IAAIC,iCAAc,CAAC;QAC3B;QAEA,MAAMC,OAAO,MAAM,IAAI,CAACZ,WAAW,CAACa,iBAAiB,CAACT,cAAcU;QACpE,IAAI,CAAC,CAACF,MAAM;YACV,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,CAACR,aAAa,CAACY,iBAAiB,IAAI;YAC1C,MAAM,IAAIC,iCAAc,CAAC;QAC3B;QAEA,MAAMU,OAAO,MAAM,IAAI,CAACtB,WAAW,CAACQ,yBAAyB,CAACC,6BAAK,CAACC,KAAK;QACzE,MAAMG,OAAO,MAAM,IAAI,CAACZ,WAAW,CAACa,iBAAiB,CAACT,cAAcU;QACpE,IAAI,CAAC,CAACF,MAAM;YACV,MAAM,IAAIG,sCAAmB,CAAC;QAChC;QAEA,MAAM,IAAI,CAACf,WAAW,CAACsB,QAAQ,CAAC;YAC9BC,UAAUnB;YACVoB,UAAUJ;YACVK,OAAO;gBAACJ,KAAKK,EAAE;aAAC;YAChBC,YAAY;YACZC,YAAY;YACZC,YAAY;YACZC,qBAAqB;QACvB;QACA,MAAM,IAAI,CAAChC,aAAa,CAACiC,gBAAgB,CAACb;QAC1C,MAAM,IAAI,CAACpB,aAAa,CAACkC,sBAAsB,CAACb;QAChD,MAAM,IAAI,CAACrB,aAAa,CAACmC,kBAAkB,CAACC,6BAAY,CAACC,oBAAoB;QAE7E,OAAOhC,IAAIa,IAAI;IACjB;AACF;;;;;;;;;;;;;;;;;;;;;;8BA3DOkB,6BAAY,CAACE,QAAQ,GAAG"}
|
|
@@ -2,74 +2,185 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", {
|
|
3
3
|
value: true
|
|
4
4
|
});
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
get: all[name]
|
|
9
|
-
});
|
|
10
|
-
}
|
|
11
|
-
_export(exports, {
|
|
12
|
-
FloorController: function() {
|
|
5
|
+
Object.defineProperty(exports, "FloorController", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
13
8
|
return FloorController;
|
|
14
|
-
},
|
|
15
|
-
default: function() {
|
|
16
|
-
return _default;
|
|
17
9
|
}
|
|
18
10
|
});
|
|
11
|
+
const _express = require("express");
|
|
12
|
+
const _floorstore = require("../state/floor.store");
|
|
13
|
+
const _authorizationconstants = require("../constants/authorization.constants");
|
|
14
|
+
const _serverconstants = require("../server.constants");
|
|
19
15
|
const _awilixexpress = require("awilix-express");
|
|
20
16
|
const _authenticate = require("../middleware/authenticate");
|
|
21
|
-
const
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
17
|
+
const _paramconvertermiddleware = require("../middleware/param-converter.middleware");
|
|
18
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
19
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
20
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
21
|
+
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;
|
|
22
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
23
|
+
}
|
|
24
|
+
function _ts_metadata(k, v) {
|
|
25
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
26
|
+
}
|
|
25
27
|
class FloorController {
|
|
26
28
|
floorStore;
|
|
27
|
-
|
|
28
|
-
constructor({ floorStore, isTypeormMode }){
|
|
29
|
+
constructor(floorStore){
|
|
29
30
|
this.floorStore = floorStore;
|
|
30
|
-
|
|
31
|
+
}
|
|
32
|
+
async list(req, res) {
|
|
33
|
+
const floors = await this.floorStore.listCache();
|
|
34
|
+
res.send(floors);
|
|
35
|
+
}
|
|
36
|
+
async get(req, res) {
|
|
37
|
+
const floor = await this.floorStore.getFloor(req.local.id);
|
|
38
|
+
res.send(floor);
|
|
39
|
+
}
|
|
40
|
+
async delete(req, res) {
|
|
41
|
+
await this.floorStore.delete(req.local.id);
|
|
42
|
+
res.send();
|
|
31
43
|
}
|
|
32
44
|
async create(req, res) {
|
|
33
45
|
const floor = await this.floorStore.create(req.body);
|
|
34
46
|
res.send(floor);
|
|
35
47
|
}
|
|
36
48
|
async updateName(req, res) {
|
|
37
|
-
const
|
|
38
|
-
const floor = await this.floorStore.updateName(floorId, req.body.name);
|
|
49
|
+
const floor = await this.floorStore.updateName(req.local.id, req.body.name);
|
|
39
50
|
res.send(floor);
|
|
40
51
|
}
|
|
41
52
|
async updateFloorNumber(req, res) {
|
|
42
|
-
const
|
|
43
|
-
const floor = await this.floorStore.updateFloorNumber(floorId, req.body.floor);
|
|
53
|
+
const floor = await this.floorStore.updateFloorNumber(req.local.id, req.body.floor);
|
|
44
54
|
res.send(floor);
|
|
45
55
|
}
|
|
46
56
|
async addPrinterToFloor(req, res) {
|
|
47
|
-
const
|
|
48
|
-
const floor = await this.floorStore.addOrUpdatePrinter(floorId, req.body);
|
|
57
|
+
const floor = await this.floorStore.addOrUpdatePrinter(req.local.id, req.body);
|
|
49
58
|
res.send(floor);
|
|
50
59
|
}
|
|
51
60
|
async removePrinterFromFloor(req, res) {
|
|
52
|
-
const
|
|
53
|
-
const floor = await this.floorStore.removePrinter(floorId, req.body.printerId);
|
|
61
|
+
const floor = await this.floorStore.removePrinter(req.local.id, req.body.printerId);
|
|
54
62
|
res.send(floor);
|
|
55
63
|
}
|
|
56
|
-
async list(req, res) {
|
|
57
|
-
const floors = await this.floorStore.listCache();
|
|
58
|
-
res.send(floors);
|
|
59
|
-
}
|
|
60
|
-
async get(req, res) {
|
|
61
|
-
const { id: floorId } = await (0, _validators.validateInput)(req.params, (0, _genericvalidation.idRulesV2)(this.isTypeormMode));
|
|
62
|
-
const floor = await this.floorStore.getFloor(floorId);
|
|
63
|
-
res.send(floor);
|
|
64
|
-
}
|
|
65
|
-
async delete(req, res) {
|
|
66
|
-
const { id: floorId } = await (0, _validators.validateInput)(req.params, (0, _genericvalidation.idRulesV2)(this.isTypeormMode));
|
|
67
|
-
await this.floorStore.delete(floorId);
|
|
68
|
-
res.send();
|
|
69
|
-
}
|
|
70
64
|
}
|
|
71
|
-
|
|
72
|
-
(0,
|
|
73
|
-
|
|
65
|
+
_ts_decorate([
|
|
66
|
+
(0, _awilixexpress.GET)(),
|
|
67
|
+
(0, _awilixexpress.route)("/"),
|
|
68
|
+
(0, _awilixexpress.before)([
|
|
69
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.PrinterFloors.List)
|
|
70
|
+
]),
|
|
71
|
+
_ts_metadata("design:type", Function),
|
|
72
|
+
_ts_metadata("design:paramtypes", [
|
|
73
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
74
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
75
|
+
]),
|
|
76
|
+
_ts_metadata("design:returntype", Promise)
|
|
77
|
+
], FloorController.prototype, "list", null);
|
|
78
|
+
_ts_decorate([
|
|
79
|
+
(0, _awilixexpress.GET)(),
|
|
80
|
+
(0, _awilixexpress.route)("/:id"),
|
|
81
|
+
(0, _awilixexpress.before)([
|
|
82
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.PrinterFloors.Get),
|
|
83
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
84
|
+
]),
|
|
85
|
+
_ts_metadata("design:type", Function),
|
|
86
|
+
_ts_metadata("design:paramtypes", [
|
|
87
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
88
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
89
|
+
]),
|
|
90
|
+
_ts_metadata("design:returntype", Promise)
|
|
91
|
+
], FloorController.prototype, "get", null);
|
|
92
|
+
_ts_decorate([
|
|
93
|
+
(0, _awilixexpress.DELETE)(),
|
|
94
|
+
(0, _awilixexpress.route)("/:id"),
|
|
95
|
+
(0, _awilixexpress.before)([
|
|
96
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.PrinterFloors.Delete),
|
|
97
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
98
|
+
]),
|
|
99
|
+
_ts_metadata("design:type", Function),
|
|
100
|
+
_ts_metadata("design:paramtypes", [
|
|
101
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
102
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
103
|
+
]),
|
|
104
|
+
_ts_metadata("design:returntype", Promise)
|
|
105
|
+
], FloorController.prototype, "delete", null);
|
|
106
|
+
_ts_decorate([
|
|
107
|
+
(0, _awilixexpress.POST)(),
|
|
108
|
+
(0, _awilixexpress.route)("/"),
|
|
109
|
+
(0, _awilixexpress.before)([
|
|
110
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.PrinterFloors.Create)
|
|
111
|
+
]),
|
|
112
|
+
_ts_metadata("design:type", Function),
|
|
113
|
+
_ts_metadata("design:paramtypes", [
|
|
114
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
115
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
116
|
+
]),
|
|
117
|
+
_ts_metadata("design:returntype", Promise)
|
|
118
|
+
], FloorController.prototype, "create", null);
|
|
119
|
+
_ts_decorate([
|
|
120
|
+
(0, _awilixexpress.PATCH)(),
|
|
121
|
+
(0, _awilixexpress.route)("/:id/name"),
|
|
122
|
+
(0, _awilixexpress.before)([
|
|
123
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.PrinterFloors.Update),
|
|
124
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
125
|
+
]),
|
|
126
|
+
_ts_metadata("design:type", Function),
|
|
127
|
+
_ts_metadata("design:paramtypes", [
|
|
128
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
129
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
130
|
+
]),
|
|
131
|
+
_ts_metadata("design:returntype", Promise)
|
|
132
|
+
], FloorController.prototype, "updateName", null);
|
|
133
|
+
_ts_decorate([
|
|
134
|
+
(0, _awilixexpress.PATCH)(),
|
|
135
|
+
(0, _awilixexpress.route)("/:id/floor-number"),
|
|
136
|
+
(0, _awilixexpress.before)([
|
|
137
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.PrinterFloors.Update),
|
|
138
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
139
|
+
]),
|
|
140
|
+
_ts_metadata("design:type", Function),
|
|
141
|
+
_ts_metadata("design:paramtypes", [
|
|
142
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
143
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
144
|
+
]),
|
|
145
|
+
_ts_metadata("design:returntype", Promise)
|
|
146
|
+
], FloorController.prototype, "updateFloorNumber", null);
|
|
147
|
+
_ts_decorate([
|
|
148
|
+
(0, _awilixexpress.POST)(),
|
|
149
|
+
(0, _awilixexpress.route)("/:id/printer"),
|
|
150
|
+
(0, _awilixexpress.before)([
|
|
151
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.PrinterFloors.Update),
|
|
152
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
153
|
+
]),
|
|
154
|
+
_ts_metadata("design:type", Function),
|
|
155
|
+
_ts_metadata("design:paramtypes", [
|
|
156
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
157
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
158
|
+
]),
|
|
159
|
+
_ts_metadata("design:returntype", Promise)
|
|
160
|
+
], FloorController.prototype, "addPrinterToFloor", null);
|
|
161
|
+
_ts_decorate([
|
|
162
|
+
(0, _awilixexpress.DELETE)(),
|
|
163
|
+
(0, _awilixexpress.route)("/:id/printer"),
|
|
164
|
+
(0, _awilixexpress.before)([
|
|
165
|
+
(0, _authenticate.permission)(_authorizationconstants.PERMS.PrinterFloors.Update),
|
|
166
|
+
(0, _paramconvertermiddleware.ParamId)("id")
|
|
167
|
+
]),
|
|
168
|
+
_ts_metadata("design:type", Function),
|
|
169
|
+
_ts_metadata("design:paramtypes", [
|
|
170
|
+
typeof _express.Request === "undefined" ? Object : _express.Request,
|
|
171
|
+
typeof _express.Response === "undefined" ? Object : _express.Response
|
|
172
|
+
]),
|
|
173
|
+
_ts_metadata("design:returntype", Promise)
|
|
174
|
+
], FloorController.prototype, "removePrinterFromFloor", null);
|
|
175
|
+
FloorController = _ts_decorate([
|
|
176
|
+
(0, _awilixexpress.route)(_serverconstants.AppConstants.apiRoute + "/floor"),
|
|
177
|
+
(0, _awilixexpress.before)([
|
|
178
|
+
(0, _authenticate.authenticate)()
|
|
179
|
+
]),
|
|
180
|
+
_ts_metadata("design:type", Function),
|
|
181
|
+
_ts_metadata("design:paramtypes", [
|
|
182
|
+
typeof _floorstore.FloorStore === "undefined" ? Object : _floorstore.FloorStore
|
|
183
|
+
])
|
|
184
|
+
], FloorController);
|
|
74
185
|
|
|
75
186
|
//# sourceMappingURL=floor.controller.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controllers/floor.controller.ts"],"names":["FloorController","floorStore","
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/floor.controller.ts"],"names":["FloorController","constructor","floorStore","list","req","res","floors","listCache","send","get","floor","getFloor","local","id","delete","create","body","updateName","name","updateFloorNumber","addPrinterToFloor","addOrUpdatePrinter","removePrinterFromFloor","removePrinter","printerId","permission","PERMS","PrinterFloors","List","Get","ParamId","Delete","Create","Update","AppConstants","apiRoute","authenticate"],"mappings":";;;;+BAUaA;;;eAAAA;;;yBAVqB;4BACP;wCACL;iCACO;+BAC2B;8BACf;0CACjB;;;;;;;;;;AAIjB,MAAMA;;IACXC,YAAY,AAAiBC,UAAsB,CAAE;aAAxBA,aAAAA;IAAyB;IAEtD,MAGMC,KAAKC,GAAY,EAAEC,GAAa,EAAE;QACtC,MAAMC,SAAS,MAAM,IAAI,CAACJ,UAAU,CAACK,SAAS;QAC9CF,IAAIG,IAAI,CAACF;IACX;IAEA,MAGMG,IAAIL,GAAY,EAAEC,GAAa,EAAE;QACrC,MAAMK,QAAQ,MAAM,IAAI,CAACR,UAAU,CAACS,QAAQ,CAACP,IAAIQ,KAAK,CAACC,EAAE;QACzDR,IAAIG,IAAI,CAACE;IACX;IAEA,MAGMI,OAAOV,GAAY,EAAEC,GAAa,EAAE;QACxC,MAAM,IAAI,CAACH,UAAU,CAACY,MAAM,CAACV,IAAIQ,KAAK,CAACC,EAAE;QACzCR,IAAIG,IAAI;IACV;IAEA,MAGMO,OAAOX,GAAY,EAAEC,GAAa,EAAE;QACxC,MAAMK,QAAQ,MAAM,IAAI,CAACR,UAAU,CAACa,MAAM,CAACX,IAAIY,IAAI;QACnDX,IAAIG,IAAI,CAACE;IACX;IAEA,MAGMO,WAAWb,GAAY,EAAEC,GAAa,EAAE;QAC5C,MAAMK,QAAQ,MAAM,IAAI,CAACR,UAAU,CAACe,UAAU,CAACb,IAAIQ,KAAK,CAACC,EAAE,EAAET,IAAIY,IAAI,CAACE,IAAI;QAC1Eb,IAAIG,IAAI,CAACE;IACX;IAEA,MAGMS,kBAAkBf,GAAY,EAAEC,GAAa,EAAE;QACnD,MAAMK,QAAQ,MAAM,IAAI,CAACR,UAAU,CAACiB,iBAAiB,CAACf,IAAIQ,KAAK,CAACC,EAAE,EAAET,IAAIY,IAAI,CAACN,KAAK;QAClFL,IAAIG,IAAI,CAACE;IACX;IAEA,MAGMU,kBAAkBhB,GAAY,EAAEC,GAAa,EAAE;QACnD,MAAMK,QAAQ,MAAM,IAAI,CAACR,UAAU,CAACmB,kBAAkB,CAACjB,IAAIQ,KAAK,CAACC,EAAE,EAAET,IAAIY,IAAI;QAC7EX,IAAIG,IAAI,CAACE;IACX;IAEA,MAGMY,uBAAuBlB,GAAY,EAAEC,GAAa,EAAE;QACxD,MAAMK,QAAQ,MAAM,IAAI,CAACR,UAAU,CAACqB,aAAa,CAACnB,IAAIQ,KAAK,CAACC,EAAE,EAAET,IAAIY,IAAI,CAACQ,SAAS;QAClFnB,IAAIG,IAAI,CAACE;IACX;AACF;;;;;QA7DWe,IAAAA,wBAAU,EAACC,6BAAK,CAACC,aAAa,CAACC,IAAI;;;;;;;;;;;;;QAQnCH,IAAAA,wBAAU,EAACC,6BAAK,CAACC,aAAa,CAACE,GAAG;QAAGC,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAQ7CL,IAAAA,wBAAU,EAACC,6BAAK,CAACC,aAAa,CAACI,MAAM;QAAGD,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAQhDL,IAAAA,wBAAU,EAACC,6BAAK,CAACC,aAAa,CAACK,MAAM;;;;;;;;;;;;;QAQrCP,IAAAA,wBAAU,EAACC,6BAAK,CAACC,aAAa,CAACM,MAAM;QAAGH,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAQhDL,IAAAA,wBAAU,EAACC,6BAAK,CAACC,aAAa,CAACM,MAAM;QAAGH,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAQhDL,IAAAA,wBAAU,EAACC,6BAAK,CAACC,aAAa,CAACM,MAAM;QAAGH,IAAAA,iCAAO,EAAC;;;;;;;;;;;;;QAQhDL,IAAAA,wBAAU,EAACC,6BAAK,CAACC,aAAa,CAACM,MAAM;QAAGH,IAAAA,iCAAO,EAAC;;;;;;;;;;8BA/DpDI,6BAAY,CAACC,QAAQ,GAAG;;QACtBC,IAAAA,0BAAY"}
|