@fdm-monster/server 1.5.0-rc1
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 +19 -0
- package/.env.template +43 -0
- package/.gitattributes +1 -0
- package/.idea/codeStyles/Project.xml +85 -0
- package/.idea/codeStyles/codeStyleConfig.xml +5 -0
- package/.idea/dbnavigator.xml +574 -0
- package/.idea/fdm-monster.iml +16 -0
- package/.idea/inspectionProfiles/Project_Default.xml +22 -0
- package/.idea/jsLibraryMappings.xml +6 -0
- package/.idea/modules.xml +12 -0
- package/.idea/prettier.xml +6 -0
- package/.idea/vcs.xml +17 -0
- package/.swcrc +33 -0
- package/CODE_OF_CONDUCT.md +46 -0
- package/CONTRIBUTING.md +134 -0
- package/LICENSE +661 -0
- package/README.md +149 -0
- package/SECURITY.md +16 -0
- package/dist/@type/express/index.d.js +7 -0
- package/dist/@type/express/index.d.js.map +1 -0
- package/dist/constants/authorization.constants.js +99 -0
- package/dist/constants/authorization.constants.js.map +1 -0
- package/dist/constants/event.constants.js +55 -0
- package/dist/constants/event.constants.js.map +1 -0
- package/dist/constants/http-status-codes.constants.js +268 -0
- package/dist/constants/http-status-codes.constants.js.map +1 -0
- package/dist/constants/server-settings.constants.js +119 -0
- package/dist/constants/server-settings.constants.js.map +1 -0
- package/dist/constants/service.constants.js +48 -0
- package/dist/constants/service.constants.js.map +1 -0
- package/dist/container.js +161 -0
- package/dist/container.js.map +1 -0
- package/dist/container.tokens.js +83 -0
- package/dist/container.tokens.js.map +1 -0
- package/dist/controllers/auth.controller.js +143 -0
- package/dist/controllers/auth.controller.js.map +1 -0
- package/dist/controllers/batch-call.controller.js +59 -0
- package/dist/controllers/batch-call.controller.js.map +1 -0
- package/dist/controllers/camera-stream.controller.js +57 -0
- package/dist/controllers/camera-stream.controller.js.map +1 -0
- package/dist/controllers/custom-gcode.controller.js +76 -0
- package/dist/controllers/custom-gcode.controller.js.map +1 -0
- package/dist/controllers/first-time-setup.controller.js +65 -0
- package/dist/controllers/first-time-setup.controller.js.map +1 -0
- package/dist/controllers/floor.controller.js +78 -0
- package/dist/controllers/floor.controller.js.map +1 -0
- package/dist/controllers/plugin-firmware-update.controller.js +140 -0
- package/dist/controllers/plugin-firmware-update.controller.js.map +1 -0
- package/dist/controllers/print-completion.controller.js +58 -0
- package/dist/controllers/print-completion.controller.js.map +1 -0
- package/dist/controllers/printer-files.controller.js +208 -0
- package/dist/controllers/printer-files.controller.js.map +1 -0
- package/dist/controllers/printer-settings.controller.js +58 -0
- package/dist/controllers/printer-settings.controller.js.map +1 -0
- package/dist/controllers/printer.controller.js +287 -0
- package/dist/controllers/printer.controller.js.map +1 -0
- package/dist/controllers/server-private.controller.js +122 -0
- package/dist/controllers/server-private.controller.js.map +1 -0
- package/dist/controllers/server-public.controller.js +140 -0
- package/dist/controllers/server-public.controller.js.map +1 -0
- package/dist/controllers/settings.controller.js +89 -0
- package/dist/controllers/settings.controller.js.map +1 -0
- package/dist/controllers/user.controller.js +137 -0
- package/dist/controllers/user.controller.js.map +1 -0
- package/dist/controllers/validation/auth-controller.validation.js +15 -0
- package/dist/controllers/validation/auth-controller.validation.js.map +1 -0
- package/dist/controllers/validation/batch-controller.validation.js +29 -0
- package/dist/controllers/validation/batch-controller.validation.js.map +1 -0
- package/dist/controllers/validation/generic.validation.js +15 -0
- package/dist/controllers/validation/generic.validation.js.map +1 -0
- package/dist/controllers/validation/printer-controller.validation.js +66 -0
- package/dist/controllers/validation/printer-controller.validation.js.map +1 -0
- package/dist/controllers/validation/printer-files-controller.validation.js +66 -0
- package/dist/controllers/validation/printer-files-controller.validation.js.map +1 -0
- package/dist/controllers/validation/printer-settings-controller.validation.js +15 -0
- package/dist/controllers/validation/printer-settings-controller.validation.js.map +1 -0
- package/dist/controllers/validation/setting.validation.js +19 -0
- package/dist/controllers/validation/setting.validation.js.map +1 -0
- package/dist/controllers/validation/user-controller.validation.js +16 -0
- package/dist/controllers/validation/user-controller.validation.js.map +1 -0
- package/dist/exceptions/job.exceptions.js +18 -0
- package/dist/exceptions/job.exceptions.js.map +1 -0
- package/dist/exceptions/runtime.exceptions.js +108 -0
- package/dist/exceptions/runtime.exceptions.js.map +1 -0
- package/dist/handlers/cache-manager.js +25 -0
- package/dist/handlers/cache-manager.js.map +1 -0
- package/dist/handlers/event-emitter.js +31 -0
- package/dist/handlers/event-emitter.js.map +1 -0
- package/dist/handlers/logger-factory.js +18 -0
- package/dist/handlers/logger-factory.js.map +1 -0
- package/dist/handlers/logger.js +85 -0
- package/dist/handlers/logger.js.map +1 -0
- package/dist/handlers/validators.js +131 -0
- package/dist/handlers/validators.js.map +1 -0
- package/dist/index.js +19 -0
- package/dist/index.js.map +1 -0
- package/dist/middleware/authenticate.js +83 -0
- package/dist/middleware/authenticate.js.map +1 -0
- package/dist/middleware/database.js +26 -0
- package/dist/middleware/database.js.map +1 -0
- package/dist/middleware/exception.handler.js +96 -0
- package/dist/middleware/exception.handler.js.map +1 -0
- package/dist/middleware/global.middleware.js +58 -0
- package/dist/middleware/global.middleware.js.map +1 -0
- package/dist/middleware/passport.js +44 -0
- package/dist/middleware/passport.js.map +1 -0
- package/dist/middleware/printer.js +49 -0
- package/dist/middleware/printer.js.map +1 -0
- package/dist/migrations/1696187882312-PrinterFile.js +40 -0
- package/dist/migrations/1696187882312-PrinterFile.js.map +1 -0
- package/dist/models/Auth/Permission.js +20 -0
- package/dist/models/Auth/Permission.js.map +1 -0
- package/dist/models/Auth/RefreshToken.js +41 -0
- package/dist/models/Auth/RefreshToken.js.map +1 -0
- package/dist/models/Auth/Role.js +20 -0
- package/dist/models/Auth/Role.js.map +1 -0
- package/dist/models/Auth/User.js +51 -0
- package/dist/models/Auth/User.js.map +1 -0
- package/dist/models/CameraStream.js +59 -0
- package/dist/models/CameraStream.js.map +1 -0
- package/dist/models/CustomGcode.js +28 -0
- package/dist/models/CustomGcode.js.map +1 -0
- package/dist/models/Floor.js +33 -0
- package/dist/models/Floor.js.map +1 -0
- package/dist/models/FloorPrinter.js +29 -0
- package/dist/models/FloorPrinter.js.map +1 -0
- package/dist/models/PrintCompletion.js +40 -0
- package/dist/models/PrintCompletion.js.map +1 -0
- package/dist/models/Printer.js +113 -0
- package/dist/models/Printer.js.map +1 -0
- package/dist/models/ServerSettings.js +168 -0
- package/dist/models/ServerSettings.js.map +1 -0
- package/dist/models/Settings.js +168 -0
- package/dist/models/Settings.js.map +1 -0
- package/dist/models/index.js +54 -0
- package/dist/models/index.js.map +1 -0
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js +49 -0
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js.map +1 -0
- package/dist/mongo-migrations/20210907173950-printers-enabled.js +39 -0
- package/dist/mongo-migrations/20210907173950-printers-enabled.js.map +1 -0
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js +39 -0
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js.map +1 -0
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js +60 -0
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js.map +1 -0
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js +30 -0
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js.map +1 -0
- package/dist/mongo-migrations/20230716065316-user-remove-name.js +30 -0
- package/dist/mongo-migrations/20230716065316-user-remove-name.js.map +1 -0
- package/dist/nodemon_restart_trigger.js +4 -0
- package/dist/nodemon_restart_trigger.js.map +1 -0
- package/dist/server.constants.js +99 -0
- package/dist/server.constants.js.map +1 -0
- package/dist/server.core.js +91 -0
- package/dist/server.core.js.map +1 -0
- package/dist/server.env.js +225 -0
- package/dist/server.env.js.map +1 -0
- package/dist/server.host.js +106 -0
- package/dist/server.host.js.map +1 -0
- package/dist/services/authentication/auth.service.js +136 -0
- package/dist/services/authentication/auth.service.js.map +1 -0
- package/dist/services/authentication/jwt.service.js +34 -0
- package/dist/services/authentication/jwt.service.js.map +1 -0
- package/dist/services/authentication/permission.service.js +73 -0
- package/dist/services/authentication/permission.service.js.map +1 -0
- package/dist/services/authentication/refresh-token.service.js +99 -0
- package/dist/services/authentication/refresh-token.service.js.map +1 -0
- package/dist/services/authentication/role.service.js +120 -0
- package/dist/services/authentication/role.service.js.map +1 -0
- package/dist/services/authentication/user.service.js +154 -0
- package/dist/services/authentication/user.service.js.map +1 -0
- package/dist/services/batch-call.service.js +148 -0
- package/dist/services/batch-call.service.js.map +1 -0
- package/dist/services/camera-stream.service.js +80 -0
- package/dist/services/camera-stream.service.js.map +1 -0
- package/dist/services/core/client-bundle.service.js +156 -0
- package/dist/services/core/client-bundle.service.js.map +1 -0
- package/dist/services/core/config.service.js +26 -0
- package/dist/services/core/config.service.js.map +1 -0
- package/dist/services/core/github.service.js +74 -0
- package/dist/services/core/github.service.js.map +1 -0
- package/dist/services/core/logs-manager.service.js +87 -0
- package/dist/services/core/logs-manager.service.js.map +1 -0
- package/dist/services/core/monsterpi.service.js +38 -0
- package/dist/services/core/monsterpi.service.js.map +1 -0
- package/dist/services/core/multer.service.js +122 -0
- package/dist/services/core/multer.service.js.map +1 -0
- package/dist/services/core/server-release.service.js +116 -0
- package/dist/services/core/server-release.service.js.map +1 -0
- package/dist/services/core/server-update.service.js +73 -0
- package/dist/services/core/server-update.service.js.map +1 -0
- package/dist/services/core/task-manager.service.js +196 -0
- package/dist/services/core/task-manager.service.js.map +1 -0
- package/dist/services/core/yaml.service.js +278 -0
- package/dist/services/core/yaml.service.js.map +1 -0
- package/dist/services/custom-gcode.service.js +48 -0
- package/dist/services/custom-gcode.service.js.map +1 -0
- package/dist/services/floor.service.js +183 -0
- package/dist/services/floor.service.js.map +1 -0
- package/dist/services/influxdb-v2/influx-db-v2-base.service.js +45 -0
- package/dist/services/influxdb-v2/influx-db-v2-base.service.js.map +1 -0
- package/dist/services/interfaces/auth.service.interface.js +6 -0
- package/dist/services/interfaces/auth.service.interface.js.map +1 -0
- package/dist/services/interfaces/camera-stream.dto.js +109 -0
- package/dist/services/interfaces/camera-stream.dto.js.map +1 -0
- package/dist/services/interfaces/camera-stream.service.interface.js +6 -0
- package/dist/services/interfaces/camera-stream.service.interface.js.map +1 -0
- package/dist/services/interfaces/custom-gcode.dto.js +18 -0
- package/dist/services/interfaces/custom-gcode.dto.js.map +1 -0
- package/dist/services/interfaces/custom-gcode.service.interface.js +6 -0
- package/dist/services/interfaces/custom-gcode.service.interface.js.map +1 -0
- package/dist/services/interfaces/floor.dto.js +61 -0
- package/dist/services/interfaces/floor.dto.js.map +1 -0
- package/dist/services/interfaces/floor.service.interface.js +6 -0
- package/dist/services/interfaces/floor.service.interface.js.map +1 -0
- package/dist/services/interfaces/gcode-analysis.dto.js +6 -0
- package/dist/services/interfaces/gcode-analysis.dto.js.map +1 -0
- package/dist/services/interfaces/jwt.service.interface.js +6 -0
- package/dist/services/interfaces/jwt.service.interface.js.map +1 -0
- package/dist/services/interfaces/login.dto.js +16 -0
- package/dist/services/interfaces/login.dto.js.map +1 -0
- package/dist/services/interfaces/page.interface.js +16 -0
- package/dist/services/interfaces/page.interface.js.map +1 -0
- package/dist/services/interfaces/permission.dto.js +16 -0
- package/dist/services/interfaces/permission.dto.js.map +1 -0
- package/dist/services/interfaces/permission.service.interface.js +6 -0
- package/dist/services/interfaces/permission.service.interface.js.map +1 -0
- package/dist/services/interfaces/printer-file.dto.js +27 -0
- package/dist/services/interfaces/printer-file.dto.js.map +1 -0
- package/dist/services/interfaces/printer-files.service.interface.js +6 -0
- package/dist/services/interfaces/printer-files.service.interface.js.map +1 -0
- package/dist/services/interfaces/printer.dto.js +18 -0
- package/dist/services/interfaces/printer.dto.js.map +1 -0
- package/dist/services/interfaces/printer.service.interface.js +6 -0
- package/dist/services/interfaces/printer.service.interface.js.map +1 -0
- package/dist/services/interfaces/role-service.interface.js +6 -0
- package/dist/services/interfaces/role-service.interface.js.map +1 -0
- package/dist/services/interfaces/settings.dto.js +34 -0
- package/dist/services/interfaces/settings.dto.js.map +1 -0
- package/dist/services/interfaces/settings.service.interface.js +6 -0
- package/dist/services/interfaces/settings.service.interface.js.map +1 -0
- package/dist/services/interfaces/user-service.interface.js +6 -0
- package/dist/services/interfaces/user-service.interface.js.map +1 -0
- package/dist/services/interfaces/user.dto.js +39 -0
- package/dist/services/interfaces/user.dto.js.map +1 -0
- package/dist/services/octoprint/constants/firmware-update-settings.constants.js +32 -0
- package/dist/services/octoprint/constants/firmware-update-settings.constants.js.map +1 -0
- package/dist/services/octoprint/constants/octoprint-service.constants.js +101 -0
- package/dist/services/octoprint/constants/octoprint-service.constants.js.map +1 -0
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js +88 -0
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js.map +1 -0
- package/dist/services/octoprint/octoprint-api.routes.js +192 -0
- package/dist/services/octoprint/octoprint-api.routes.js.map +1 -0
- package/dist/services/octoprint/octoprint-api.service.js +402 -0
- package/dist/services/octoprint/octoprint-api.service.js.map +1 -0
- package/dist/services/octoprint/octoprint-sockio.adapter.js +309 -0
- package/dist/services/octoprint/octoprint-sockio.adapter.js.map +1 -0
- package/dist/services/octoprint/plugin-base.service.js +102 -0
- package/dist/services/octoprint/plugin-base.service.js.map +1 -0
- package/dist/services/octoprint/plugin-firmware-update.service.js +104 -0
- package/dist/services/octoprint/plugin-firmware-update.service.js.map +1 -0
- package/dist/services/octoprint/plugin-repository.cache.js +45 -0
- package/dist/services/octoprint/plugin-repository.cache.js.map +1 -0
- package/dist/services/octoprint/socket.factory.js +22 -0
- package/dist/services/octoprint/socket.factory.js.map +1 -0
- package/dist/services/octoprint/utils/api.utils.js +72 -0
- package/dist/services/octoprint/utils/api.utils.js.map +1 -0
- package/dist/services/orm/floor.service.interface.js +73 -0
- package/dist/services/orm/floor.service.interface.js.map +1 -0
- package/dist/services/orm/printer.service.interface.js +6 -0
- package/dist/services/orm/printer.service.interface.js.map +1 -0
- package/dist/services/print-completion.service.js +162 -0
- package/dist/services/print-completion.service.js.map +1 -0
- package/dist/services/printer-files.service.js +91 -0
- package/dist/services/printer-files.service.js.map +1 -0
- package/dist/services/printer.service.js +230 -0
- package/dist/services/printer.service.js.map +1 -0
- package/dist/services/settings.service.js +158 -0
- package/dist/services/settings.service.js.map +1 -0
- package/dist/services/validators/floor-service.validation.js +60 -0
- package/dist/services/validators/floor-service.validation.js.map +1 -0
- package/dist/services/validators/print-completion-service.validation.js +20 -0
- package/dist/services/validators/print-completion-service.validation.js.map +1 -0
- package/dist/services/validators/printer-service.validation.js +48 -0
- package/dist/services/validators/printer-service.validation.js.map +1 -0
- package/dist/services/validators/settings-service.validation.js +71 -0
- package/dist/services/validators/settings-service.validation.js.map +1 -0
- package/dist/services/validators/user-service.validation.js +33 -0
- package/dist/services/validators/user-service.validation.js.map +1 -0
- package/dist/services/validators/yaml-service.validation.js +63 -0
- package/dist/services/validators/yaml-service.validation.js.map +1 -0
- package/dist/services/yaml.service.js +278 -0
- package/dist/services/yaml.service.js.map +1 -0
- package/dist/shared.constants.js +15 -0
- package/dist/shared.constants.js.map +1 -0
- package/dist/state/file-upload-tracker.cache.js +88 -0
- package/dist/state/file-upload-tracker.cache.js.map +1 -0
- package/dist/state/file.cache.js +99 -0
- package/dist/state/file.cache.js.map +1 -0
- package/dist/state/files.store.js +132 -0
- package/dist/state/files.store.js.map +1 -0
- package/dist/state/floor.store.js +99 -0
- package/dist/state/floor.store.js.map +1 -0
- package/dist/state/printer-events.cache.js +97 -0
- package/dist/state/printer-events.cache.js.map +1 -0
- package/dist/state/printer-socket.store.js +217 -0
- package/dist/state/printer-socket.store.js.map +1 -0
- package/dist/state/printer.cache.js +112 -0
- package/dist/state/printer.cache.js.map +1 -0
- package/dist/state/settings.store.js +154 -0
- package/dist/state/settings.store.js.map +1 -0
- package/dist/state/socket-io.gateway.js +66 -0
- package/dist/state/socket-io.gateway.js.map +1 -0
- package/dist/state/test-printer-socket.store.js +91 -0
- package/dist/state/test-printer-socket.store.js.map +1 -0
- package/dist/state/validation/create-test-printer.validation.js +18 -0
- package/dist/state/validation/create-test-printer.validation.js.map +1 -0
- package/dist/task.presets.js +50 -0
- package/dist/task.presets.js.map +1 -0
- package/dist/tasks/boot.task.js +198 -0
- package/dist/tasks/boot.task.js.map +1 -0
- package/dist/tasks/client-bundle.task.js +32 -0
- package/dist/tasks/client-bundle.task.js.map +1 -0
- package/dist/tasks/print-completion.socketio.task.js +85 -0
- package/dist/tasks/print-completion.socketio.task.js.map +1 -0
- package/dist/tasks/printer-file-clean.task.js +72 -0
- package/dist/tasks/printer-file-clean.task.js.map +1 -0
- package/dist/tasks/printer-websocket-restore.task.js +64 -0
- package/dist/tasks/printer-websocket-restore.task.js.map +1 -0
- package/dist/tasks/printer-websocket.task.js +43 -0
- package/dist/tasks/printer-websocket.task.js.map +1 -0
- package/dist/tasks/socketio.task.js +83 -0
- package/dist/tasks/socketio.task.js.map +1 -0
- package/dist/tasks/software-update.task.js +22 -0
- package/dist/tasks/software-update.task.js.map +1 -0
- package/dist/tasks.js +48 -0
- package/dist/tasks.js.map +1 -0
- package/dist/types/express/index.d.js +7 -0
- package/dist/types/express/index.d.js.map +1 -0
- package/dist/utils/array.util.js +27 -0
- package/dist/utils/array.util.js.map +1 -0
- package/dist/utils/benchmark.util.js +39 -0
- package/dist/utils/benchmark.util.js.map +1 -0
- package/dist/utils/cache/key-diff.cache.js +128 -0
- package/dist/utils/cache/key-diff.cache.js.map +1 -0
- package/dist/utils/correlation-token.util.js +15 -0
- package/dist/utils/correlation-token.util.js.map +1 -0
- package/dist/utils/crypto.utils.js +29 -0
- package/dist/utils/crypto.utils.js.map +1 -0
- package/dist/utils/env.utils.js +98 -0
- package/dist/utils/env.utils.js.map +1 -0
- package/dist/utils/error.utils.js +15 -0
- package/dist/utils/error.utils.js.map +1 -0
- package/dist/utils/find-predicate.utils.js +18 -0
- package/dist/utils/find-predicate.utils.js.map +1 -0
- package/dist/utils/fs.utils.js +38 -0
- package/dist/utils/fs.utils.js.map +1 -0
- package/dist/utils/is-docker.js +40 -0
- package/dist/utils/is-docker.js.map +1 -0
- package/dist/utils/mapper.utils.js +33 -0
- package/dist/utils/mapper.utils.js.map +1 -0
- package/dist/utils/metric.utils.js +35 -0
- package/dist/utils/metric.utils.js.map +1 -0
- package/dist/utils/normalize-url.js +245 -0
- package/dist/utils/normalize-url.js.map +1 -0
- package/dist/utils/semver.utils.js +18 -0
- package/dist/utils/semver.utils.js.map +1 -0
- package/dist/utils/time.utils.js +26 -0
- package/dist/utils/time.utils.js.map +1 -0
- package/dist/utils/url.utils.js +33 -0
- package/dist/utils/url.utils.js.map +1 -0
- package/dist/utils/websocket.adapter.js +105 -0
- package/dist/utils/websocket.adapter.js.map +1 -0
- package/migrate-mongo-config.js +45 -0
- package/nodemon_restart_trigger.js +1 -0
- package/package.json +149 -0
- package/src/index.ts +19 -0
- package/tsconfig.json +28 -0
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "SettingsStore", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return SettingsStore;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _runtimeexceptions = require("../exceptions/runtime.exceptions");
|
|
12
|
+
const _serversettingsconstants = require("../constants/server-settings.constants");
|
|
13
|
+
const _node = require("@sentry/node");
|
|
14
|
+
const _envutils = require("../utils/env.utils");
|
|
15
|
+
const _serverconstants = require("../server.constants");
|
|
16
|
+
class SettingsStore {
|
|
17
|
+
settingsService;
|
|
18
|
+
logger;
|
|
19
|
+
settings = null;
|
|
20
|
+
constructor({ settingsService, loggerFactory }){
|
|
21
|
+
this.settingsService = settingsService;
|
|
22
|
+
this.logger = loggerFactory(SettingsStore.name);
|
|
23
|
+
}
|
|
24
|
+
getSettings() {
|
|
25
|
+
const settings = this.settings;
|
|
26
|
+
return Object.freeze({
|
|
27
|
+
// Credential settings are not shared with the client
|
|
28
|
+
[_serversettingsconstants.serverSettingsKey]: settings[_serversettingsconstants.serverSettingsKey],
|
|
29
|
+
[_serversettingsconstants.wizardSettingKey]: settings[_serversettingsconstants.wizardSettingKey],
|
|
30
|
+
[_serversettingsconstants.frontendSettingKey]: settings[_serversettingsconstants.frontendSettingKey],
|
|
31
|
+
[_serversettingsconstants.fileCleanSettingKey]: settings[_serversettingsconstants.fileCleanSettingKey],
|
|
32
|
+
[_serversettingsconstants.timeoutSettingKey]: settings[_serversettingsconstants.timeoutSettingKey]
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
async loadSettings() {
|
|
36
|
+
// Setup Settings as connection is established
|
|
37
|
+
this.settings = await this.settingsService.getOrCreate();
|
|
38
|
+
await this.processSentryEnabled();
|
|
39
|
+
}
|
|
40
|
+
async getCredentialSettings() {
|
|
41
|
+
return this.settings[_serversettingsconstants.credentialSettingsKey];
|
|
42
|
+
}
|
|
43
|
+
async getAnonymousDiagnosticsEnabled() {
|
|
44
|
+
return this.settings[_serversettingsconstants.serverSettingsKey].sentryDiagnosticsEnabled;
|
|
45
|
+
}
|
|
46
|
+
async persistOptionalCredentialSettings(overrideJwtSecret, overrideJwtExpiresIn) {
|
|
47
|
+
if (overrideJwtSecret) {
|
|
48
|
+
await this.updateCredentialSettings({
|
|
49
|
+
jwtSecret: overrideJwtSecret
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
if (overrideJwtExpiresIn) {
|
|
53
|
+
await this.updateCredentialSettings({
|
|
54
|
+
jwtExpiresIn: parseInt(overrideJwtExpiresIn)
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
getWizardState() {
|
|
59
|
+
return {
|
|
60
|
+
wizardCompleted: this.settings[_serversettingsconstants.wizardSettingKey].wizardCompleted,
|
|
61
|
+
wizardVersion: this.settings[_serversettingsconstants.wizardSettingKey].wizardVersion,
|
|
62
|
+
latestWizardVersion: _serverconstants.AppConstants.currentWizardVersion
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
isWizardCompleted() {
|
|
66
|
+
return this.settings[_serversettingsconstants.wizardSettingKey].wizardCompleted && this.settings[_serversettingsconstants.wizardSettingKey].wizardVersion === _serverconstants.AppConstants.currentWizardVersion;
|
|
67
|
+
}
|
|
68
|
+
getWizardSettings() {
|
|
69
|
+
return this.settings[_serversettingsconstants.wizardSettingKey];
|
|
70
|
+
}
|
|
71
|
+
isRegistrationEnabled() {
|
|
72
|
+
if (!this.settings) throw new _runtimeexceptions.InternalServerException("Could not check server settings (server settings not loaded");
|
|
73
|
+
return this.settings[_serversettingsconstants.serverSettingsKey].registration;
|
|
74
|
+
}
|
|
75
|
+
getServerSettings() {
|
|
76
|
+
return this.getSettings()[_serversettingsconstants.serverSettingsKey];
|
|
77
|
+
}
|
|
78
|
+
getFrontendSettings() {
|
|
79
|
+
return this.getSettings()[_serversettingsconstants.frontendSettingKey];
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Cross-cutting concern for file clean operation
|
|
83
|
+
*/ getFileCleanSettings() {
|
|
84
|
+
return this.getSettings()[_serversettingsconstants.fileCleanSettingKey];
|
|
85
|
+
}
|
|
86
|
+
isPreUploadFileCleanEnabled() {
|
|
87
|
+
return this.getSettings()[_serversettingsconstants.fileCleanSettingKey]?.autoRemoveOldFilesBeforeUpload;
|
|
88
|
+
}
|
|
89
|
+
async setWizardCompleted(version) {
|
|
90
|
+
this.settings = await this.settingsService.patchWizardSettings({
|
|
91
|
+
wizardCompleted: true,
|
|
92
|
+
wizardCompletedAt: new Date(),
|
|
93
|
+
wizardVersion: version
|
|
94
|
+
});
|
|
95
|
+
return this.getSettings();
|
|
96
|
+
}
|
|
97
|
+
async setRegistrationEnabled(registration = true) {
|
|
98
|
+
this.settings = await this.settingsService.patchServerSettings({
|
|
99
|
+
registration
|
|
100
|
+
});
|
|
101
|
+
return this.getSettings();
|
|
102
|
+
}
|
|
103
|
+
async getLoginRequired() {
|
|
104
|
+
return this.getServerSettings().loginRequired;
|
|
105
|
+
}
|
|
106
|
+
async setLoginRequired(loginRequired = true) {
|
|
107
|
+
this.settings = await this.settingsService.patchServerSettings({
|
|
108
|
+
loginRequired
|
|
109
|
+
});
|
|
110
|
+
return this.getSettings();
|
|
111
|
+
}
|
|
112
|
+
async setWhitelist(whitelistEnabled = true, whitelistedIpAddresses) {
|
|
113
|
+
this.settings = await this.settingsService.patchServerSettings({
|
|
114
|
+
whitelistEnabled,
|
|
115
|
+
whitelistedIpAddresses
|
|
116
|
+
});
|
|
117
|
+
return this.getSettings();
|
|
118
|
+
}
|
|
119
|
+
async updateServerSettings(serverSettings) {
|
|
120
|
+
this.settings = await this.settingsService.patchServerSettings(serverSettings);
|
|
121
|
+
return this.getSettings();
|
|
122
|
+
}
|
|
123
|
+
async patchFileCleanSettings(fileClean) {
|
|
124
|
+
this.settings = await this.settingsService.patchFileCleanSettings(fileClean);
|
|
125
|
+
return this.getSettings();
|
|
126
|
+
}
|
|
127
|
+
async updateCredentialSettings(credentialSettings) {
|
|
128
|
+
this.settings = await this.settingsService.patchCredentialSettings(credentialSettings);
|
|
129
|
+
return this.getSettings();
|
|
130
|
+
}
|
|
131
|
+
async setSentryDiagnosticsEnabled(sentryDiagnosticsEnabled) {
|
|
132
|
+
this.settings = await this.settingsService.patchServerSettings({
|
|
133
|
+
sentryDiagnosticsEnabled
|
|
134
|
+
});
|
|
135
|
+
await this.processSentryEnabled();
|
|
136
|
+
return this.getSettings();
|
|
137
|
+
}
|
|
138
|
+
async updateFrontendSettings(frontendSettings) {
|
|
139
|
+
this.settings = await this.settingsService.updateFrontendSettings(frontendSettings);
|
|
140
|
+
return this.getSettings();
|
|
141
|
+
}
|
|
142
|
+
async processSentryEnabled() {
|
|
143
|
+
if ((0, _envutils.isTestEnvironment)()) return;
|
|
144
|
+
const sentryEnabled = await this.getAnonymousDiagnosticsEnabled();
|
|
145
|
+
if (sentryEnabled) {
|
|
146
|
+
this.logger.log("Enabling Sentry for remote diagnostics");
|
|
147
|
+
} else {
|
|
148
|
+
this.logger.log("Disabling Sentry for remote diagnostics");
|
|
149
|
+
}
|
|
150
|
+
(0, _node.getCurrentHub)().getClient().getOptions().enabled = sentryEnabled;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
//# sourceMappingURL=settings.store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/state/settings.store.ts"],"names":["SettingsStore","settingsService","logger","settings","constructor","loggerFactory","name","getSettings","Object","freeze","serverSettingsKey","wizardSettingKey","frontendSettingKey","fileCleanSettingKey","timeoutSettingKey","loadSettings","getOrCreate","processSentryEnabled","getCredentialSettings","credentialSettingsKey","getAnonymousDiagnosticsEnabled","sentryDiagnosticsEnabled","persistOptionalCredentialSettings","overrideJwtSecret","overrideJwtExpiresIn","updateCredentialSettings","jwtSecret","jwtExpiresIn","parseInt","getWizardState","wizardCompleted","wizardVersion","latestWizardVersion","AppConstants","currentWizardVersion","isWizardCompleted","getWizardSettings","isRegistrationEnabled","InternalServerException","registration","getServerSettings","getFrontendSettings","getFileCleanSettings","isPreUploadFileCleanEnabled","autoRemoveOldFilesBeforeUpload","setWizardCompleted","version","patchWizardSettings","wizardCompletedAt","Date","setRegistrationEnabled","patchServerSettings","getLoginRequired","loginRequired","setLoginRequired","setWhitelist","whitelistEnabled","whitelistedIpAddresses","updateServerSettings","serverSettings","patchFileCleanSettings","fileClean","credentialSettings","patchCredentialSettings","setSentryDiagnosticsEnabled","updateFrontendSettings","frontendSettings","isTestEnvironment","sentryEnabled","log","getCurrentHub","getClient","getOptions","enabled"],"mappings":"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"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
IO_MESSAGES: function() {
|
|
13
|
+
return IO_MESSAGES;
|
|
14
|
+
},
|
|
15
|
+
SocketIoGateway: function() {
|
|
16
|
+
return SocketIoGateway;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
const _socketio = require("socket.io");
|
|
20
|
+
const _eventconstants = require("../constants/event.constants");
|
|
21
|
+
class SocketIoGateway {
|
|
22
|
+
logger;
|
|
23
|
+
eventEmitter2;
|
|
24
|
+
io;
|
|
25
|
+
settingsStore;
|
|
26
|
+
constructor({ loggerFactory, eventEmitter2, settingsStore }){
|
|
27
|
+
this.logger = loggerFactory(SocketIoGateway.name);
|
|
28
|
+
this.eventEmitter2 = eventEmitter2;
|
|
29
|
+
this.settingsStore = settingsStore;
|
|
30
|
+
}
|
|
31
|
+
attachServer(httpServer) {
|
|
32
|
+
this.io = new _socketio.Server(httpServer, {
|
|
33
|
+
cors: {
|
|
34
|
+
origin: "*"
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
const that = this;
|
|
38
|
+
this.io.on("connection", (socket)=>this.onConnect.bind(that)(socket));
|
|
39
|
+
}
|
|
40
|
+
onConnect(socket) {
|
|
41
|
+
this.logger.log("SocketIO Client connected", socket.id);
|
|
42
|
+
this.eventEmitter2.emit(_eventconstants.socketIoConnectedEvent, socket.id);
|
|
43
|
+
socket.on("disconnect", ()=>{
|
|
44
|
+
this.logger.log("SocketIO Client disconnected", socket.id);
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
send(event, data) {
|
|
48
|
+
if (!this.io) {
|
|
49
|
+
this.logger.debug("No io server setup yet");
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
if (this.settingsStore.getServerSettings().debugSettings?.debugSocketIoEvents) {
|
|
53
|
+
this.logger.log(`Sending event ${event}`);
|
|
54
|
+
}
|
|
55
|
+
this.io.emit(event, data);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
const IO_MESSAGES = {
|
|
59
|
+
LegacyUpdate: "legacy-update",
|
|
60
|
+
LegacyPrinterTest: "legacy-printer-test",
|
|
61
|
+
CompletionEvent: "completion-event",
|
|
62
|
+
HostState: "host-state",
|
|
63
|
+
ApiAccessibility: "api-accessibility"
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
//# sourceMappingURL=socket-io.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/state/socket-io.gateway.ts"],"names":["IO_MESSAGES","SocketIoGateway","logger","eventEmitter2","io","settingsStore","constructor","loggerFactory","name","attachServer","httpServer","Server","cors","origin","that","on","socket","onConnect","bind","log","id","emit","socketIoConnectedEvent","send","event","data","debug","getServerSettings","debugSettings","debugSocketIoEvents","LegacyUpdate","LegacyPrinterTest","CompletionEvent","HostState","ApiAccessibility"],"mappings":";;;;;;;;;;;IAyDaA,WAAW;eAAXA;;IAjDAC,eAAe;eAAfA;;;0BARkB;gCACQ;AAOhC,MAAMA;IACXC,OAAsB;IACtBC,cAA6B;IAC7BC,GAAW;IAEXC,cAA6B;IAE7BC,YAAY,EACVC,aAAa,EACbJ,aAAa,EACbE,aAAa,EAKd,CAAE;QACD,IAAI,CAACH,MAAM,GAAGK,cAAcN,gBAAgBO,IAAI;QAChD,IAAI,CAACL,aAAa,GAAGA;QACrB,IAAI,CAACE,aAAa,GAAGA;IACvB;IAEAI,aAAaC,UAAuB,EAAE;QACpC,IAAI,CAACN,EAAE,GAAG,IAAIO,gBAAM,CAACD,YAAY;YAAEE,MAAM;gBAAEC,QAAQ;YAAI;QAAE;QACzD,MAAMC,OAAO,IAAI;QACjB,IAAI,CAACV,EAAE,CAACW,EAAE,CAAC,cAAc,CAACC,SAAW,IAAI,CAACC,SAAS,CAACC,IAAI,CAACJ,MAAME;IACjE;IAEAC,UAAUD,MAAc,EAAE;QACxB,IAAI,CAACd,MAAM,CAACiB,GAAG,CAAC,6BAA6BH,OAAOI,EAAE;QACtD,IAAI,CAACjB,aAAa,CAACkB,IAAI,CAACC,sCAAsB,EAAEN,OAAOI,EAAE;QAEzDJ,OAAOD,EAAE,CAAC,cAAc;YACtB,IAAI,CAACb,MAAM,CAACiB,GAAG,CAAC,gCAAgCH,OAAOI,EAAE;QAC3D;IACF;IAEAG,KAAQC,KAAa,EAAEC,IAAO,EAAE;QAC9B,IAAI,CAAC,IAAI,CAACrB,EAAE,EAAE;YACZ,IAAI,CAACF,MAAM,CAACwB,KAAK,CAAC;YAClB;QACF;QAEA,IAAI,IAAI,CAACrB,aAAa,CAACsB,iBAAiB,GAAGC,aAAa,EAAEC,qBAAqB;YAC7E,IAAI,CAAC3B,MAAM,CAACiB,GAAG,CAAC,CAAC,cAAc,EAAEK,MAAM,CAAC;QAC1C;QACA,IAAI,CAACpB,EAAE,CAACiB,IAAI,CAACG,OAAOC;IACtB;AACF;AAEO,MAAMzB,cAAc;IACzB8B,cAAc;IACdC,mBAAmB;IACnBC,iBAAiB;IACjBC,WAAW;IACXC,kBAAkB;AACpB"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "TestPrinterSocketStore", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return TestPrinterSocketStore;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _promises = require("timers/promises");
|
|
12
|
+
const _validators = require("../handlers/validators");
|
|
13
|
+
const _createtestprintervalidation = require("./validation/create-test-printer.validation");
|
|
14
|
+
const _octoprintsockioadapter = require("../services/octoprint/octoprint-sockio.adapter");
|
|
15
|
+
const _serverconstants = require("../server.constants");
|
|
16
|
+
class TestPrinterSocketStore {
|
|
17
|
+
testSocket;
|
|
18
|
+
socketIoGateway;
|
|
19
|
+
socketFactory;
|
|
20
|
+
eventEmitter2;
|
|
21
|
+
constructor({ socketFactory, socketIoGateway, eventEmitter2 }){
|
|
22
|
+
this.socketFactory = socketFactory;
|
|
23
|
+
this.socketIoGateway = socketIoGateway;
|
|
24
|
+
this.eventEmitter2 = eventEmitter2;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Sets up/recreates a printer to be tested quickly by running the standard checks
|
|
28
|
+
* @param printer
|
|
29
|
+
* @returns {Promise<*>}
|
|
30
|
+
*/ async setupTestPrinter(printer) {
|
|
31
|
+
if (this.testSocket) {
|
|
32
|
+
this.testSocket.close();
|
|
33
|
+
this.testSocket = null;
|
|
34
|
+
}
|
|
35
|
+
const validatedData = await (0, _validators.validateInput)(printer, _createtestprintervalidation.createTestPrinterRules);
|
|
36
|
+
validatedData.enabled = true;
|
|
37
|
+
// Create a new socket if it doesn't exist
|
|
38
|
+
const { correlationToken } = printer;
|
|
39
|
+
this.testSocket = this.socketFactory.createInstance();
|
|
40
|
+
// Reset the socket credentials before (re-)connecting
|
|
41
|
+
this.testSocket.registerCredentials({
|
|
42
|
+
printerId: correlationToken,
|
|
43
|
+
loginDto: {
|
|
44
|
+
apiKey: printer.apiKey,
|
|
45
|
+
printerURL: printer.printerURL
|
|
46
|
+
},
|
|
47
|
+
protocol: "ws"
|
|
48
|
+
});
|
|
49
|
+
const testEvents = [
|
|
50
|
+
(0, _octoprintsockioadapter.octoPrintEvent)(_octoprintsockioadapter.Message.WS_STATE_UPDATED),
|
|
51
|
+
(0, _octoprintsockioadapter.octoPrintEvent)(_octoprintsockioadapter.Message.API_STATE_UPDATED),
|
|
52
|
+
(0, _octoprintsockioadapter.octoPrintEvent)(_octoprintsockioadapter.Message.WS_CLOSED),
|
|
53
|
+
(0, _octoprintsockioadapter.octoPrintEvent)(_octoprintsockioadapter.Message.WS_OPENED),
|
|
54
|
+
(0, _octoprintsockioadapter.octoPrintEvent)(_octoprintsockioadapter.Message.WS_ERROR)
|
|
55
|
+
];
|
|
56
|
+
const listener = ({ event, payload, printerId })=>{
|
|
57
|
+
if (printerId !== correlationToken) {
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
this.socketIoGateway.send("test-printer-state", {
|
|
61
|
+
event,
|
|
62
|
+
payload,
|
|
63
|
+
correlationToken
|
|
64
|
+
});
|
|
65
|
+
};
|
|
66
|
+
testEvents.forEach((te)=>{
|
|
67
|
+
this.eventEmitter2.on(te, listener);
|
|
68
|
+
});
|
|
69
|
+
await this.testSocket.setupSocketSession();
|
|
70
|
+
const promise = new Promise(async (resolve, reject)=>{
|
|
71
|
+
this.testSocket.open();
|
|
72
|
+
for await (const startTime of (0, _promises.setInterval)(100)){
|
|
73
|
+
if (this.testSocket.socketState === _octoprintsockioadapter.SOCKET_STATE.authenticated) {
|
|
74
|
+
resolve();
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
await Promise.race([
|
|
80
|
+
promise,
|
|
81
|
+
(0, _promises.setTimeout)(_serverconstants.AppConstants.defaultWebsocketHandshakeTimeout)
|
|
82
|
+
]);
|
|
83
|
+
this.testSocket.close();
|
|
84
|
+
delete this.testSocket;
|
|
85
|
+
testEvents.forEach((te)=>{
|
|
86
|
+
this.eventEmitter2.off(te, listener);
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
//# sourceMappingURL=test-printer-socket.store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/state/test-printer-socket.store.ts"],"names":["TestPrinterSocketStore","testSocket","socketIoGateway","socketFactory","eventEmitter2","constructor","setupTestPrinter","printer","close","validatedData","validateInput","createTestPrinterRules","enabled","correlationToken","createInstance","registerCredentials","printerId","loginDto","apiKey","printerURL","protocol","testEvents","octoPrintEvent","Message","WS_STATE_UPDATED","API_STATE_UPDATED","WS_CLOSED","WS_OPENED","WS_ERROR","listener","event","payload","send","forEach","te","on","setupSocketSession","promise","Promise","resolve","reject","open","startTime","setInterval","socketState","SOCKET_STATE","authenticated","race","setTimeout","AppConstants","defaultWebsocketHandshakeTimeout","off"],"mappings":";;;;+BASaA;;;eAAAA;;;0BAT2B;4BACV;6CACS;wCACuC;iCACjD;AAKtB,MAAMA;IACXC,WAAmC;IACnCC,gBAAiC;IACjCC,cAA6B;IAC7BC,cAA6B;IAC7BC,YAAY,EACVF,aAAa,EACbD,eAAe,EACfE,aAAa,EAKd,CAAE;QACD,IAAI,CAACD,aAAa,GAAGA;QACrB,IAAI,CAACD,eAAe,GAAGA;QACvB,IAAI,CAACE,aAAa,GAAGA;IACvB;IAEA;;;;GAIC,GACD,MAAME,iBAAiBC,OAAO,EAAE;QAC9B,IAAI,IAAI,CAACN,UAAU,EAAE;YACnB,IAAI,CAACA,UAAU,CAACO,KAAK;YACrB,IAAI,CAACP,UAAU,GAAG;QACpB;QAEA,MAAMQ,gBAAgB,MAAMC,IAAAA,yBAAa,EAACH,SAASI,mDAAsB;QACzEF,cAAcG,OAAO,GAAG;QAExB,0CAA0C;QAC1C,MAAM,EAAEC,gBAAgB,EAAE,GAAGN;QAC7B,IAAI,CAACN,UAAU,GAAG,IAAI,CAACE,aAAa,CAACW,cAAc;QAEnD,sDAAsD;QACtD,IAAI,CAACb,UAAU,CAACc,mBAAmB,CAAC;YAClCC,WAAWH;YACXI,UAAU;gBACRC,QAAQX,QAAQW,MAAM;gBACtBC,YAAYZ,QAAQY,UAAU;YAChC;YACAC,UAAU;QACZ;QAEA,MAAMC,aAAa;YACjBC,IAAAA,sCAAc,EAACC,+BAAO,CAACC,gBAAgB;YACvCF,IAAAA,sCAAc,EAACC,+BAAO,CAACE,iBAAiB;YACxCH,IAAAA,sCAAc,EAACC,+BAAO,CAACG,SAAS;YAChCJ,IAAAA,sCAAc,EAACC,+BAAO,CAACI,SAAS;YAChCL,IAAAA,sCAAc,EAACC,+BAAO,CAACK,QAAQ;SAChC;QACD,MAAMC,WAAW,CAAC,EAAEC,KAAK,EAAEC,OAAO,EAAEf,SAAS,EAAE;YAC7C,IAAIA,cAAcH,kBAAkB;gBAClC;YACF;YACA,IAAI,CAACX,eAAe,CAAC8B,IAAI,CAAC,sBAAsB;gBAC9CF;gBACAC;gBACAlB;YACF;QACF;QACAQ,WAAWY,OAAO,CAAC,CAACC;YAClB,IAAI,CAAC9B,aAAa,CAAC+B,EAAE,CAACD,IAAIL;QAC5B;QACA,MAAM,IAAI,CAAC5B,UAAU,CAACmC,kBAAkB;QAExC,MAAMC,UAAU,IAAIC,QAAQ,OAAOC,SAASC;YAC1C,IAAI,CAACvC,UAAU,CAACwC,IAAI;YACpB,WAAW,MAAMC,aAAaC,IAAAA,qBAAW,EAAC,KAAM;gBAC9C,IAAI,IAAI,CAAC1C,UAAU,CAAC2C,WAAW,KAAKC,oCAAY,CAACC,aAAa,EAAE;oBAC9DP;oBACA;gBACF;YACF;QACF;QAEA,MAAMD,QAAQS,IAAI,CAAC;YAACV;YAASW,IAAAA,oBAAU,EAACC,6BAAY,CAACC,gCAAgC;SAAE;QACvF,IAAI,CAACjD,UAAU,CAACO,KAAK;QACrB,OAAO,IAAI,CAACP,UAAU;QACtBoB,WAAWY,OAAO,CAAC,CAACC;YAClB,IAAI,CAAC9B,aAAa,CAAC+C,GAAG,CAACjB,IAAIL;QAC7B;IACF;AACF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "createTestPrinterRules", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return createTestPrinterRules;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _serviceconstants = require("../../constants/service.constants");
|
|
12
|
+
const createTestPrinterRules = {
|
|
13
|
+
correlationToken: "required|string",
|
|
14
|
+
apiKey: `required|length:${_serviceconstants.UUID_LENGTH},${_serviceconstants.UUID_LENGTH}|alphaNumeric`,
|
|
15
|
+
printerURL: "required|httpurl"
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=create-test-printer.validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/state/validation/create-test-printer.validation.ts"],"names":["createTestPrinterRules","correlationToken","apiKey","UUID_LENGTH","printerURL"],"mappings":";;;;+BAEaA;;;eAAAA;;;kCAFe;AAErB,MAAMA,yBAAyB;IACpCC,kBAAkB;IAClBC,QAAQ,CAAC,gBAAgB,EAAEC,6BAAW,CAAC,CAAC,EAAEA,6BAAW,CAAC,aAAa,CAAC;IACpEC,YAAY;AACd"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
// Test or example task
|
|
2
|
+
// TaskManager.registerPeriodicJob(
|
|
3
|
+
// "unique_test_task1",
|
|
4
|
+
// async () => {
|
|
5
|
+
// await new Promise((resolve) => {
|
|
6
|
+
// setTimeout(() => resolve(), 9000);
|
|
7
|
+
// });
|
|
8
|
+
// },
|
|
9
|
+
// {
|
|
10
|
+
// PERIODIC_TASK_PRESET_2500MS
|
|
11
|
+
// );
|
|
12
|
+
"use strict";
|
|
13
|
+
Object.defineProperty(exports, "__esModule", {
|
|
14
|
+
value: true
|
|
15
|
+
});
|
|
16
|
+
Object.defineProperty(exports, "TASK_PRESETS", {
|
|
17
|
+
enumerable: true,
|
|
18
|
+
get: function() {
|
|
19
|
+
return TASK_PRESETS;
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
class TASK_PRESETS {
|
|
23
|
+
static PERIODIC = {
|
|
24
|
+
periodic: true,
|
|
25
|
+
logFirstCompletion: true,
|
|
26
|
+
runImmediately: false
|
|
27
|
+
};
|
|
28
|
+
static PERIODIC_DISABLED = {
|
|
29
|
+
...this.PERIODIC,
|
|
30
|
+
runImmediately: true,
|
|
31
|
+
disabled: true
|
|
32
|
+
};
|
|
33
|
+
static PERIODIC_2500MS = {
|
|
34
|
+
...this.PERIODIC,
|
|
35
|
+
milliseconds: 2500
|
|
36
|
+
};
|
|
37
|
+
static RUNONCE = {
|
|
38
|
+
runOnce: true,
|
|
39
|
+
logFirstCompletion: true,
|
|
40
|
+
runImmediately: true
|
|
41
|
+
};
|
|
42
|
+
static RUNDELAYED = {
|
|
43
|
+
runDelayed: true,
|
|
44
|
+
logFirstCompletion: true,
|
|
45
|
+
runImmediately: false,
|
|
46
|
+
seconds: 0
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
//# sourceMappingURL=task.presets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/task.presets.ts"],"names":["TASK_PRESETS","PERIODIC","periodic","logFirstCompletion","runImmediately","PERIODIC_DISABLED","disabled","PERIODIC_2500MS","milliseconds","RUNONCE","runOnce","RUNDELAYED","runDelayed","seconds"],"mappings":"AAAA,uBAAuB;AACvB,mCAAmC;AACnC,yBAAyB;AACzB,kBAAkB;AAClB,uCAAuC;AACvC,2CAA2C;AAC3C,UAAU;AACV,OAAO;AACP,MAAM;AACN,gCAAgC;AAChC,KAAK;;;;;+BAEQA;;;eAAAA;;;AAAN,MAAMA;IACX,OAAOC,WAAW;QAChBC,UAAU;QACVC,oBAAoB;QACpBC,gBAAgB;IAClB,EAAE;IAEF,OAAOC,oBAAoB;QACzB,GAAG,IAAI,CAACJ,QAAQ;QAChBG,gBAAgB;QAChBE,UAAU;IACZ,EAAE;IAEF,OAAOC,kBAAkB;QACvB,GAAG,IAAI,CAACN,QAAQ;QAChBO,cAAc;IAChB,EAAE;IAEF,OAAOC,UAAU;QACfC,SAAS;QACTP,oBAAoB;QACpBC,gBAAgB;IAClB,EAAE;IAEF,OAAOO,aAAa;QAClBC,YAAY;QACZT,oBAAoB;QACpBC,gBAAgB;QAChBS,SAAS;IACX,EAAE;AACJ"}
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "BootTask", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return BootTask;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _mongoose = /*#__PURE__*/ _interop_require_wildcard(require("mongoose"));
|
|
12
|
+
const _serverenv = require("../server.env");
|
|
13
|
+
const _containertokens = require("../container.tokens");
|
|
14
|
+
const _serverconstants = require("../server.constants");
|
|
15
|
+
function _getRequireWildcardCache(nodeInterop) {
|
|
16
|
+
if (typeof WeakMap !== "function") return null;
|
|
17
|
+
var cacheBabelInterop = new WeakMap();
|
|
18
|
+
var cacheNodeInterop = new WeakMap();
|
|
19
|
+
return (_getRequireWildcardCache = function(nodeInterop) {
|
|
20
|
+
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
|
|
21
|
+
})(nodeInterop);
|
|
22
|
+
}
|
|
23
|
+
function _interop_require_wildcard(obj, nodeInterop) {
|
|
24
|
+
if (!nodeInterop && obj && obj.__esModule) {
|
|
25
|
+
return obj;
|
|
26
|
+
}
|
|
27
|
+
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
|
|
28
|
+
return {
|
|
29
|
+
default: obj
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
var cache = _getRequireWildcardCache(nodeInterop);
|
|
33
|
+
if (cache && cache.has(obj)) {
|
|
34
|
+
return cache.get(obj);
|
|
35
|
+
}
|
|
36
|
+
var newObj = {};
|
|
37
|
+
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
|
|
38
|
+
for(var key in obj){
|
|
39
|
+
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
40
|
+
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
|
|
41
|
+
if (desc && (desc.get || desc.set)) {
|
|
42
|
+
Object.defineProperty(newObj, key, desc);
|
|
43
|
+
} else {
|
|
44
|
+
newObj[key] = obj[key];
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
newObj.default = obj;
|
|
49
|
+
if (cache) {
|
|
50
|
+
cache.set(obj, newObj);
|
|
51
|
+
}
|
|
52
|
+
return newObj;
|
|
53
|
+
}
|
|
54
|
+
class BootTask {
|
|
55
|
+
logger;
|
|
56
|
+
taskManagerService;
|
|
57
|
+
serverTasks;
|
|
58
|
+
settingsStore;
|
|
59
|
+
settingsService;
|
|
60
|
+
multerService;
|
|
61
|
+
printerSocketStore;
|
|
62
|
+
filesStore;
|
|
63
|
+
permissionService;
|
|
64
|
+
roleService;
|
|
65
|
+
userService;
|
|
66
|
+
pluginRepositoryCache;
|
|
67
|
+
floorStore;
|
|
68
|
+
pluginFirmwareUpdateService;
|
|
69
|
+
clientBundleService;
|
|
70
|
+
configService;
|
|
71
|
+
constructor({ loggerFactory, serverTasks, settingsService, settingsStore, multerService, printerSocketStore, filesStore, permissionService, roleService, userService, taskManagerService, pluginRepositoryCache, floorStore, pluginFirmwareUpdateService, clientBundleService, configService }){
|
|
72
|
+
this.logger = loggerFactory(BootTask.name);
|
|
73
|
+
this.serverTasks = serverTasks;
|
|
74
|
+
this.settingsService = settingsService;
|
|
75
|
+
this.settingsStore = settingsStore;
|
|
76
|
+
this.multerService = multerService;
|
|
77
|
+
this.printerSocketStore = printerSocketStore;
|
|
78
|
+
this.filesStore = filesStore;
|
|
79
|
+
this.permissionService = permissionService;
|
|
80
|
+
this.roleService = roleService;
|
|
81
|
+
this.userService = userService;
|
|
82
|
+
this.taskManagerService = taskManagerService;
|
|
83
|
+
this.pluginRepositoryCache = pluginRepositoryCache;
|
|
84
|
+
this.floorStore = floorStore;
|
|
85
|
+
this.pluginFirmwareUpdateService = pluginFirmwareUpdateService;
|
|
86
|
+
this.clientBundleService = clientBundleService;
|
|
87
|
+
this.configService = configService;
|
|
88
|
+
}
|
|
89
|
+
async runOnce() {
|
|
90
|
+
// To cope with retries after failures we register this task - disabled
|
|
91
|
+
this.taskManagerService.registerJobOrTask(this.serverTasks.SERVER_BOOT_TASK);
|
|
92
|
+
this.logger.log("Running boot task once.");
|
|
93
|
+
await this.run();
|
|
94
|
+
}
|
|
95
|
+
async run() {
|
|
96
|
+
try {
|
|
97
|
+
await this.createConnection();
|
|
98
|
+
await this.migrateDatabase();
|
|
99
|
+
} catch (e) {
|
|
100
|
+
if (e instanceof _mongoose.default.Error) {
|
|
101
|
+
// Tests should just continue
|
|
102
|
+
if (!e.message.includes("Can't call `openUri()` on an active connection with different connection strings.")) {
|
|
103
|
+
// We are not in a test
|
|
104
|
+
if (e.message.includes("ECONNREFUSED")) {
|
|
105
|
+
this.logger.error("Database connection timed-out. Retrying in 5000.");
|
|
106
|
+
} else {
|
|
107
|
+
this.logger.error(`Database connection error: ${e.message}`);
|
|
108
|
+
}
|
|
109
|
+
this.taskManagerService.scheduleDisabledJob(_containertokens.DITokens.bootTask, false);
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
this.logger.log("Loading and synchronizing Server Settings");
|
|
115
|
+
await this.settingsStore.loadSettings();
|
|
116
|
+
this.logger.log("Synchronizing user permission and roles definition");
|
|
117
|
+
await this.permissionService.syncPermissions();
|
|
118
|
+
await this.roleService.syncRoles();
|
|
119
|
+
const isDemoMode = this.configService.get(_serverconstants.AppConstants.OVERRIDE_IS_DEMO_MODE, null) === "true";
|
|
120
|
+
if (isDemoMode) {
|
|
121
|
+
this.logger.warn(`Starting in demo mode due to ${_serverconstants.AppConstants.OVERRIDE_IS_DEMO_MODE}`);
|
|
122
|
+
await this.createOrUpdateDemoAccount();
|
|
123
|
+
}
|
|
124
|
+
const loginRequired = this.configService.get(_serverconstants.AppConstants.OVERRIDE_LOGIN_REQUIRED, null);
|
|
125
|
+
if (loginRequired !== null) {
|
|
126
|
+
this.logger.warn(`Setting login required due to ${_serverconstants.AppConstants.OVERRIDE_LOGIN_REQUIRED}`);
|
|
127
|
+
await this.settingsStore.setLoginRequired(loginRequired);
|
|
128
|
+
}
|
|
129
|
+
// If we are in demo mode, do not allow registration
|
|
130
|
+
if (!isDemoMode) {
|
|
131
|
+
const registrationEnabled = this.configService.get(_serverconstants.AppConstants.OVERRIDE_REGISTRATION_ENABLED, null);
|
|
132
|
+
if (registrationEnabled !== null) {
|
|
133
|
+
this.logger.warn(`Setting registration enabled due to ${_serverconstants.AppConstants.OVERRIDE_REGISTRATION_ENABLED}`);
|
|
134
|
+
await this.settingsStore.setRegistrationEnabled(registrationEnabled);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
const overrideJwtSecret = this.configService.get(_serverconstants.AppConstants.OVERRIDE_JWT_SECRET, undefined);
|
|
138
|
+
const overrideJwtExpiresIn = this.configService.get(_serverconstants.AppConstants.OVERRIDE_JWT_EXPIRES_IN, undefined);
|
|
139
|
+
await this.settingsStore.persistOptionalCredentialSettings(overrideJwtSecret, overrideJwtExpiresIn);
|
|
140
|
+
this.logger.log("Clearing upload folder");
|
|
141
|
+
this.multerService.clearUploadsFolder();
|
|
142
|
+
this.logger.log("Loading printer sockets");
|
|
143
|
+
await this.printerSocketStore.loadPrinterSockets(); // New sockets
|
|
144
|
+
this.logger.log("Loading files store");
|
|
145
|
+
await this.filesStore.loadFilesStore();
|
|
146
|
+
this.logger.log("Loading floor store");
|
|
147
|
+
await this.floorStore.loadStore();
|
|
148
|
+
if (process.env.SAFEMODE_ENABLED === "true") {
|
|
149
|
+
this.logger.warn("Starting in safe mode due to SAFEMODE_ENABLED");
|
|
150
|
+
} else {
|
|
151
|
+
this.serverTasks.BOOT_TASKS.forEach((task)=>{
|
|
152
|
+
this.taskManagerService.registerJobOrTask(task);
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
// Success so we disable this task
|
|
156
|
+
this.taskManagerService.disableJob(_containertokens.DITokens.bootTask, false);
|
|
157
|
+
}
|
|
158
|
+
async createOrUpdateDemoAccount() {
|
|
159
|
+
const demoUsername = this.configService.get(_serverconstants.AppConstants.OVERRIDE_DEMO_USERNAME, _serverconstants.AppConstants.DEFAULT_DEMO_USERNAME);
|
|
160
|
+
const demoPassword = this.configService.get(_serverconstants.AppConstants.OVERRIDE_DEMO_PASSWORD, _serverconstants.AppConstants.DEFAULT_DEMO_PASSWORD);
|
|
161
|
+
const demoRole = this.configService.get(_serverconstants.AppConstants.OVERRIDE_DEMO_ROLE, _serverconstants.AppConstants.DEFAULT_DEMO_ROLE);
|
|
162
|
+
const adminRole = this.roleService.getRoleByName(demoRole);
|
|
163
|
+
const demoUserId = await this.userService.getDemoUserId();
|
|
164
|
+
if (!demoUserId) {
|
|
165
|
+
await this.userService.register({
|
|
166
|
+
username: demoUsername,
|
|
167
|
+
password: demoPassword,
|
|
168
|
+
isDemoUser: true,
|
|
169
|
+
isVerified: true,
|
|
170
|
+
isRootUser: true,
|
|
171
|
+
needsPasswordChange: false,
|
|
172
|
+
roles: [
|
|
173
|
+
adminRole.id
|
|
174
|
+
]
|
|
175
|
+
});
|
|
176
|
+
this.logger.log("Created demo account");
|
|
177
|
+
} else {
|
|
178
|
+
await this.userService.setVerifiedById(demoUserId, true);
|
|
179
|
+
await this.userService.setIsRootUserById(demoUserId, true);
|
|
180
|
+
await this.userService.updatePasswordUnsafe(demoUsername, demoPassword);
|
|
181
|
+
await this.userService.setUserRoleIds(demoUserId, [
|
|
182
|
+
adminRole.id
|
|
183
|
+
]);
|
|
184
|
+
this.logger.log("Updated demo account");
|
|
185
|
+
}
|
|
186
|
+
await this.settingsStore.setWizardCompleted(1);
|
|
187
|
+
}
|
|
188
|
+
async createConnection() {
|
|
189
|
+
await (0, _mongoose.connect)((0, _serverenv.fetchMongoDBConnectionString)(), {
|
|
190
|
+
serverSelectionTimeoutMS: 1500
|
|
191
|
+
});
|
|
192
|
+
}
|
|
193
|
+
async migrateDatabase() {
|
|
194
|
+
await (0, _serverenv.runMigrations)(_mongoose.default.connection.db, _mongoose.default.connection.getClient());
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
//# sourceMappingURL=boot.task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tasks/boot.task.ts"],"names":["BootTask","logger","taskManagerService","serverTasks","settingsStore","settingsService","multerService","printerSocketStore","filesStore","permissionService","roleService","userService","pluginRepositoryCache","floorStore","pluginFirmwareUpdateService","clientBundleService","configService","constructor","loggerFactory","name","runOnce","registerJobOrTask","SERVER_BOOT_TASK","log","run","createConnection","migrateDatabase","e","mongoose","Error","message","includes","error","scheduleDisabledJob","DITokens","bootTask","loadSettings","syncPermissions","syncRoles","isDemoMode","get","AppConstants","OVERRIDE_IS_DEMO_MODE","warn","createOrUpdateDemoAccount","loginRequired","OVERRIDE_LOGIN_REQUIRED","setLoginRequired","registrationEnabled","OVERRIDE_REGISTRATION_ENABLED","setRegistrationEnabled","overrideJwtSecret","OVERRIDE_JWT_SECRET","undefined","overrideJwtExpiresIn","OVERRIDE_JWT_EXPIRES_IN","persistOptionalCredentialSettings","clearUploadsFolder","loadPrinterSockets","loadFilesStore","loadStore","process","env","SAFEMODE_ENABLED","BOOT_TASKS","forEach","task","disableJob","demoUsername","OVERRIDE_DEMO_USERNAME","DEFAULT_DEMO_USERNAME","demoPassword","OVERRIDE_DEMO_PASSWORD","DEFAULT_DEMO_PASSWORD","demoRole","OVERRIDE_DEMO_ROLE","DEFAULT_DEMO_ROLE","adminRole","getRoleByName","demoUserId","getDemoUserId","register","username","password","isDemoUser","isVerified","isRootUser","needsPasswordChange","roles","id","setVerifiedById","setIsRootUserById","updatePasswordUnsafe","setUserRoleIds","setWizardCompleted","connect","fetchMongoDBConnectionString","serverSelectionTimeoutMS","runMigrations","connection","db","getClient"],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "ClientDistDownloadTask", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return ClientDistDownloadTask;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _serverconstants = require("../server.constants");
|
|
12
|
+
class ClientDistDownloadTask {
|
|
13
|
+
clientBundleService;
|
|
14
|
+
githubService;
|
|
15
|
+
logger;
|
|
16
|
+
constructor({ clientBundleService, loggerFactory, githubService }){
|
|
17
|
+
this.githubService = githubService;
|
|
18
|
+
this.clientBundleService = clientBundleService;
|
|
19
|
+
this.logger = loggerFactory(ClientDistDownloadTask.name);
|
|
20
|
+
}
|
|
21
|
+
async run() {
|
|
22
|
+
const result = await this.clientBundleService.shouldUpdateWithReason(false, _serverconstants.AppConstants.defaultClientMinimum);
|
|
23
|
+
if (!result.shouldUpdate) {
|
|
24
|
+
this.logger.log(`Client bundle update skipped. Reason: ${result.reason}`);
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
this.logger.log(`Client bundle update required. Reason for updating: ${result.reason}`);
|
|
28
|
+
await this.clientBundleService.downloadClientUpdate(_serverconstants.AppConstants.defaultClientMinimum);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
//# sourceMappingURL=client-bundle.task.js.map
|