@fdm-monster/server 1.5.0-rc1 → 1.5.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 -3
- package/.gitattributes +1 -1
- package/.swcrc +0 -0
- package/CODE_OF_CONDUCT.md +0 -0
- package/CONTRIBUTING.md +0 -0
- package/LICENSE +0 -0
- package/README.md +0 -0
- package/SECURITY.md +0 -0
- package/dist/constants/authorization.constants.js +12 -0
- package/dist/constants/authorization.constants.js.map +1 -1
- package/dist/constants/event.constants.js +0 -0
- package/dist/constants/event.constants.js.map +0 -0
- package/dist/constants/http-status-codes.constants.js +0 -0
- package/dist/constants/http-status-codes.constants.js.map +0 -0
- package/dist/constants/server-settings.constants.js +0 -0
- package/dist/constants/server-settings.constants.js.map +1 -1
- package/dist/constants/service.constants.js +0 -0
- package/dist/constants/service.constants.js.map +0 -0
- package/dist/container.js +2 -1
- package/dist/container.js.map +1 -1
- package/dist/container.tokens.js +3 -1
- package/dist/container.tokens.js.map +1 -1
- package/dist/controllers/auth.controller.js +11 -6
- package/dist/controllers/auth.controller.js.map +1 -1
- package/dist/controllers/batch-call.controller.js +0 -0
- package/dist/controllers/batch-call.controller.js.map +0 -0
- package/dist/controllers/camera-stream.controller.js +0 -0
- package/dist/controllers/camera-stream.controller.js.map +0 -0
- package/dist/controllers/custom-gcode.controller.js +0 -0
- package/dist/controllers/custom-gcode.controller.js.map +0 -0
- package/dist/controllers/first-time-setup.controller.js +11 -4
- package/dist/controllers/first-time-setup.controller.js.map +1 -1
- package/dist/controllers/floor.controller.js +0 -0
- package/dist/controllers/floor.controller.js.map +0 -0
- package/dist/controllers/plugin-firmware-update.controller.js +0 -0
- package/dist/controllers/plugin-firmware-update.controller.js.map +0 -0
- package/dist/controllers/print-completion.controller.js +0 -0
- package/dist/controllers/print-completion.controller.js.map +0 -0
- package/dist/controllers/printer-files.controller.js +0 -0
- package/dist/controllers/printer-files.controller.js.map +0 -0
- package/dist/controllers/printer-settings.controller.js +0 -0
- package/dist/controllers/printer-settings.controller.js.map +0 -0
- package/dist/controllers/printer.controller.js +0 -0
- package/dist/controllers/printer.controller.js.map +1 -1
- package/dist/controllers/server-private.controller.js +3 -1
- package/dist/controllers/server-private.controller.js.map +1 -1
- package/dist/controllers/server-public.controller.js +0 -0
- package/dist/controllers/server-public.controller.js.map +0 -0
- package/dist/controllers/settings.controller.js +91 -7
- package/dist/controllers/settings.controller.js.map +1 -1
- package/dist/controllers/user.controller.js +79 -20
- package/dist/controllers/user.controller.js.map +1 -1
- package/dist/controllers/validation/auth-controller.validation.js +0 -0
- package/dist/controllers/validation/auth-controller.validation.js.map +0 -0
- package/dist/controllers/validation/batch-controller.validation.js +0 -0
- package/dist/controllers/validation/batch-controller.validation.js.map +0 -0
- package/dist/controllers/validation/generic.validation.js +0 -0
- package/dist/controllers/validation/generic.validation.js.map +0 -0
- package/dist/controllers/validation/printer-controller.validation.js +0 -0
- package/dist/controllers/validation/printer-controller.validation.js.map +0 -0
- package/dist/controllers/validation/printer-files-controller.validation.js +0 -0
- package/dist/controllers/validation/printer-files-controller.validation.js.map +0 -0
- package/dist/controllers/validation/printer-settings-controller.validation.js +0 -0
- package/dist/controllers/validation/printer-settings-controller.validation.js.map +0 -0
- package/dist/controllers/validation/setting.validation.js +1 -1
- package/dist/controllers/validation/setting.validation.js.map +0 -0
- package/dist/controllers/validation/user-controller.validation.js +3 -2
- package/dist/controllers/validation/user-controller.validation.js.map +1 -1
- package/dist/exceptions/job.exceptions.js +0 -0
- package/dist/exceptions/job.exceptions.js.map +1 -1
- package/dist/exceptions/runtime.exceptions.js +10 -8
- package/dist/exceptions/runtime.exceptions.js.map +1 -1
- package/dist/handlers/cache-manager.js +0 -0
- package/dist/handlers/cache-manager.js.map +0 -0
- package/dist/handlers/event-emitter.js +0 -0
- package/dist/handlers/event-emitter.js.map +0 -0
- package/dist/handlers/logger-factory.js +0 -0
- package/dist/handlers/logger-factory.js.map +0 -0
- package/dist/handlers/logger.js +0 -0
- package/dist/handlers/logger.js.map +0 -0
- package/dist/handlers/validators.js +6 -1
- package/dist/handlers/validators.js.map +1 -1
- package/dist/index.js +0 -0
- package/dist/index.js.map +0 -0
- package/dist/middleware/authenticate.js +7 -4
- package/dist/middleware/authenticate.js.map +1 -1
- package/dist/middleware/database.js +0 -0
- package/dist/middleware/database.js.map +0 -0
- package/dist/middleware/demo.middleware.js +43 -0
- package/dist/middleware/demo.middleware.js.map +1 -0
- package/dist/middleware/{exception.handler.js → exception.filter.js} +9 -8
- package/dist/middleware/exception.filter.js.map +1 -0
- package/dist/middleware/global.middleware.js +27 -3
- package/dist/middleware/global.middleware.js.map +1 -1
- package/dist/middleware/passport.js +45 -16
- package/dist/middleware/passport.js.map +1 -1
- package/dist/middleware/printer.js +0 -0
- package/dist/middleware/printer.js.map +0 -0
- package/dist/models/Auth/Permission.js +0 -0
- package/dist/models/Auth/Permission.js.map +0 -0
- package/dist/models/Auth/RefreshToken.js +0 -0
- package/dist/models/Auth/RefreshToken.js.map +0 -0
- package/dist/models/Auth/Role.js +0 -0
- package/dist/models/Auth/Role.js.map +0 -0
- package/dist/models/Auth/User.js +0 -0
- package/dist/models/Auth/User.js.map +0 -0
- package/dist/models/CameraStream.js +5 -35
- package/dist/models/CameraStream.js.map +1 -1
- package/dist/models/CustomGcode.js +0 -0
- package/dist/models/CustomGcode.js.map +0 -0
- package/dist/models/Floor.js +0 -0
- package/dist/models/Floor.js.map +0 -0
- package/dist/models/FloorPrinter.js +0 -0
- package/dist/models/FloorPrinter.js.map +0 -0
- package/dist/models/PrintCompletion.js +0 -0
- package/dist/models/PrintCompletion.js.map +0 -0
- package/dist/models/Printer.js +0 -0
- package/dist/models/Printer.js.map +0 -0
- package/dist/models/Settings.js +0 -0
- package/dist/models/Settings.js.map +0 -0
- package/dist/models/index.js +0 -0
- package/dist/models/index.js.map +0 -0
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js +0 -0
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js.map +0 -0
- package/dist/mongo-migrations/20210907173950-printers-enabled.js +0 -0
- package/dist/mongo-migrations/20210907173950-printers-enabled.js.map +0 -0
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js +0 -0
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js.map +0 -0
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js +0 -0
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js.map +0 -0
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js +0 -0
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js.map +0 -0
- package/dist/mongo-migrations/20230716065316-user-remove-name.js +0 -0
- package/dist/mongo-migrations/20230716065316-user-remove-name.js.map +0 -0
- package/dist/server.constants.js +14 -5
- package/dist/server.constants.js.map +1 -1
- package/dist/server.core.js +4 -2
- package/dist/server.core.js.map +1 -1
- package/dist/server.env.js +3 -1
- package/dist/server.env.js.map +1 -1
- package/dist/server.host.js +3 -3
- package/dist/server.host.js.map +1 -1
- package/dist/services/authentication/auth.service.js +29 -15
- package/dist/services/authentication/auth.service.js.map +1 -1
- package/dist/services/authentication/jwt.service.js +0 -0
- package/dist/services/authentication/jwt.service.js.map +0 -0
- package/dist/services/authentication/permission.service.js +0 -0
- package/dist/services/authentication/permission.service.js.map +0 -0
- package/dist/services/authentication/refresh-token.service.js +6 -5
- package/dist/services/authentication/refresh-token.service.js.map +1 -1
- package/dist/services/authentication/role.service.js +6 -0
- package/dist/services/authentication/role.service.js.map +1 -1
- package/dist/services/authentication/user.service.js +35 -13
- package/dist/services/authentication/user.service.js.map +1 -1
- package/dist/services/batch-call.service.js +0 -0
- package/dist/services/batch-call.service.js.map +0 -0
- package/dist/services/camera-stream.service.js +2 -15
- package/dist/services/camera-stream.service.js.map +1 -1
- package/dist/services/core/client-bundle.service.js +0 -0
- package/dist/services/core/client-bundle.service.js.map +0 -0
- package/dist/services/core/config.service.js +4 -0
- package/dist/services/core/config.service.js.map +1 -1
- package/dist/services/core/github.service.js +0 -0
- package/dist/services/core/github.service.js.map +0 -0
- package/dist/services/core/logs-manager.service.js +0 -0
- package/dist/services/core/logs-manager.service.js.map +0 -0
- package/dist/services/core/monsterpi.service.js +0 -0
- package/dist/services/core/monsterpi.service.js.map +0 -0
- package/dist/services/core/multer.service.js +0 -0
- package/dist/services/core/multer.service.js.map +0 -0
- package/dist/services/core/server-release.service.js +0 -0
- package/dist/services/core/server-release.service.js.map +0 -0
- package/dist/services/core/server-update.service.js +0 -0
- package/dist/services/core/server-update.service.js.map +0 -0
- package/dist/services/core/task-manager.service.js +0 -0
- package/dist/services/core/task-manager.service.js.map +0 -0
- package/dist/services/core/yaml.service.js +0 -0
- package/dist/services/core/yaml.service.js.map +1 -1
- package/dist/services/custom-gcode.service.js +0 -0
- package/dist/services/custom-gcode.service.js.map +0 -0
- package/dist/services/floor.service.js +0 -0
- package/dist/services/floor.service.js.map +0 -0
- package/dist/services/influxdb-v2/influx-db-v2-base.service.js +4 -8
- package/dist/services/influxdb-v2/influx-db-v2-base.service.js.map +1 -1
- package/dist/services/interfaces/auth.service.interface.js +0 -0
- package/dist/services/interfaces/auth.service.interface.js.map +0 -0
- package/dist/services/interfaces/camera-stream.dto.js +11 -47
- package/dist/services/interfaces/camera-stream.dto.js.map +1 -1
- package/dist/services/interfaces/camera-stream.service.interface.js +0 -0
- package/dist/services/interfaces/camera-stream.service.interface.js.map +0 -0
- package/dist/services/interfaces/custom-gcode.dto.js +0 -0
- package/dist/services/interfaces/custom-gcode.dto.js.map +0 -0
- package/dist/services/interfaces/custom-gcode.service.interface.js +0 -0
- package/dist/services/interfaces/custom-gcode.service.interface.js.map +0 -0
- package/dist/services/interfaces/floor.dto.js +0 -0
- package/dist/services/interfaces/floor.dto.js.map +0 -0
- package/dist/services/interfaces/floor.service.interface.js +0 -0
- package/dist/services/interfaces/floor.service.interface.js.map +0 -0
- package/dist/services/interfaces/gcode-analysis.dto.js +0 -0
- package/dist/services/interfaces/gcode-analysis.dto.js.map +0 -0
- package/dist/services/interfaces/jwt.service.interface.js +0 -0
- package/dist/services/interfaces/jwt.service.interface.js.map +0 -0
- package/dist/services/interfaces/login.dto.js +0 -0
- package/dist/services/interfaces/login.dto.js.map +0 -0
- package/dist/services/interfaces/page.interface.js +0 -0
- package/dist/services/interfaces/page.interface.js.map +0 -0
- package/dist/services/interfaces/permission.dto.js +0 -0
- package/dist/services/interfaces/permission.dto.js.map +0 -0
- package/dist/services/interfaces/permission.service.interface.js +0 -0
- package/dist/services/interfaces/permission.service.interface.js.map +0 -0
- package/dist/services/interfaces/printer-file.dto.js +0 -0
- package/dist/services/interfaces/printer-file.dto.js.map +0 -0
- package/dist/services/interfaces/printer-files.service.interface.js +0 -0
- package/dist/services/interfaces/printer-files.service.interface.js.map +0 -0
- package/dist/services/interfaces/printer.dto.js +0 -0
- package/dist/services/interfaces/printer.dto.js.map +0 -0
- package/dist/services/interfaces/printer.service.interface.js +0 -0
- package/dist/services/interfaces/printer.service.interface.js.map +0 -0
- package/dist/services/interfaces/refresh-token.dto.js +20 -0
- package/dist/services/interfaces/refresh-token.dto.js.map +1 -0
- package/dist/services/{orm/printer.service.interface.js → interfaces/refresh-token.service.interface.js} +1 -1
- package/dist/services/interfaces/refresh-token.service.interface.js.map +1 -0
- package/dist/services/interfaces/role-service.interface.js +0 -0
- package/dist/services/interfaces/role-service.interface.js.map +0 -0
- package/dist/services/interfaces/role.dto.js +16 -0
- package/dist/services/interfaces/role.dto.js.map +1 -0
- package/dist/services/interfaces/settings.dto.js +2 -3
- package/dist/services/interfaces/settings.dto.js.map +1 -1
- package/dist/services/interfaces/settings.service.interface.js +0 -0
- package/dist/services/interfaces/settings.service.interface.js.map +0 -0
- package/dist/services/interfaces/user-service.interface.js +0 -0
- package/dist/services/interfaces/user-service.interface.js.map +0 -0
- package/dist/services/interfaces/user.dto.js +0 -0
- package/dist/services/interfaces/user.dto.js.map +0 -0
- package/dist/services/octoprint/constants/firmware-update-settings.constants.js +0 -0
- package/dist/services/octoprint/constants/firmware-update-settings.constants.js.map +0 -0
- package/dist/services/octoprint/constants/octoprint-service.constants.js +0 -0
- package/dist/services/octoprint/constants/octoprint-service.constants.js.map +0 -0
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js +0 -0
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js.map +0 -0
- package/dist/services/octoprint/octoprint-api.routes.js +0 -0
- package/dist/services/octoprint/octoprint-api.routes.js.map +0 -0
- package/dist/services/octoprint/octoprint-api.service.js +0 -0
- package/dist/services/octoprint/octoprint-api.service.js.map +0 -0
- package/dist/services/octoprint/octoprint-sockio.adapter.js +7 -11
- package/dist/services/octoprint/octoprint-sockio.adapter.js.map +1 -1
- package/dist/services/octoprint/plugin-base.service.js +0 -0
- package/dist/services/octoprint/plugin-base.service.js.map +0 -0
- package/dist/services/octoprint/plugin-firmware-update.service.js +0 -0
- package/dist/services/octoprint/plugin-firmware-update.service.js.map +0 -0
- package/dist/services/octoprint/plugin-repository.cache.js +0 -0
- package/dist/services/octoprint/plugin-repository.cache.js.map +0 -0
- package/dist/services/octoprint/socket.factory.js +0 -0
- package/dist/services/octoprint/socket.factory.js.map +0 -0
- package/dist/services/octoprint/utils/api.utils.js +0 -0
- package/dist/services/octoprint/utils/api.utils.js.map +0 -0
- package/dist/services/print-completion.service.js +0 -0
- package/dist/services/print-completion.service.js.map +0 -0
- package/dist/services/printer-files.service.js +0 -0
- package/dist/services/printer-files.service.js.map +0 -0
- package/dist/services/printer.service.js +0 -0
- package/dist/services/printer.service.js.map +0 -0
- package/dist/services/settings.service.js +40 -31
- package/dist/services/settings.service.js.map +1 -1
- package/dist/services/validators/floor-service.validation.js +0 -0
- package/dist/services/validators/floor-service.validation.js.map +0 -0
- package/dist/services/validators/print-completion-service.validation.js +0 -0
- package/dist/services/validators/print-completion-service.validation.js.map +0 -0
- package/dist/services/validators/printer-service.validation.js +1 -1
- package/dist/services/validators/printer-service.validation.js.map +1 -1
- package/dist/services/validators/settings-service.validation.js +18 -8
- package/dist/services/validators/settings-service.validation.js.map +1 -1
- package/dist/services/validators/user-service.validation.js +3 -2
- package/dist/services/validators/user-service.validation.js.map +1 -1
- package/dist/services/validators/yaml-service.validation.js +0 -0
- package/dist/services/validators/yaml-service.validation.js.map +0 -0
- package/dist/shared.constants.js +0 -0
- package/dist/shared.constants.js.map +0 -0
- package/dist/state/file-upload-tracker.cache.js +0 -0
- package/dist/state/file-upload-tracker.cache.js.map +0 -0
- package/dist/state/file.cache.js +0 -0
- package/dist/state/file.cache.js.map +0 -0
- package/dist/state/files.store.js +0 -0
- package/dist/state/files.store.js.map +0 -0
- package/dist/state/floor.store.js +0 -0
- package/dist/state/floor.store.js.map +0 -0
- package/dist/state/printer-events.cache.js +0 -0
- package/dist/state/printer-events.cache.js.map +0 -0
- package/dist/state/printer-socket.store.js +0 -0
- package/dist/state/printer-socket.store.js.map +0 -0
- package/dist/state/printer.cache.js +0 -0
- package/dist/state/printer.cache.js.map +0 -0
- package/dist/state/settings.store.js +28 -5
- package/dist/state/settings.store.js.map +1 -1
- package/dist/state/socket-io.gateway.js +30 -3
- package/dist/state/socket-io.gateway.js.map +1 -1
- package/dist/state/test-printer-socket.store.js +3 -0
- package/dist/state/test-printer-socket.store.js.map +1 -1
- package/dist/state/validation/create-test-printer.validation.js +0 -0
- package/dist/state/validation/create-test-printer.validation.js.map +0 -0
- package/dist/task.presets.js +0 -0
- package/dist/task.presets.js.map +0 -0
- package/dist/tasks/boot.task.js +18 -14
- package/dist/tasks/boot.task.js.map +1 -1
- package/dist/tasks/client-bundle.task.js +0 -0
- package/dist/tasks/client-bundle.task.js.map +0 -0
- package/dist/tasks/print-completion.socketio.task.js +0 -0
- package/dist/tasks/print-completion.socketio.task.js.map +0 -0
- package/dist/tasks/printer-file-clean.task.js +0 -0
- package/dist/tasks/printer-file-clean.task.js.map +0 -0
- package/dist/tasks/printer-websocket-restore.task.js +0 -0
- package/dist/tasks/printer-websocket-restore.task.js.map +0 -0
- package/dist/tasks/printer-websocket.task.js +0 -0
- package/dist/tasks/printer-websocket.task.js.map +0 -0
- package/dist/tasks/socketio.task.js +0 -0
- package/dist/tasks/socketio.task.js.map +0 -0
- package/dist/tasks/software-update.task.js +0 -0
- package/dist/tasks/software-update.task.js.map +0 -0
- package/dist/tasks.js +0 -0
- package/dist/tasks.js.map +0 -0
- package/dist/types/express/index.d.js +0 -0
- package/dist/types/express/index.d.js.map +0 -0
- package/dist/utils/array.util.js +0 -0
- package/dist/utils/array.util.js.map +0 -0
- package/dist/utils/benchmark.util.js +0 -0
- package/dist/utils/benchmark.util.js.map +0 -0
- package/dist/utils/cache/key-diff.cache.js +0 -0
- package/dist/utils/cache/key-diff.cache.js.map +0 -0
- package/dist/utils/correlation-token.util.js +0 -0
- package/dist/utils/correlation-token.util.js.map +0 -0
- package/dist/utils/crypto.utils.js +0 -0
- package/dist/utils/crypto.utils.js.map +0 -0
- package/dist/utils/env.utils.js +6 -0
- package/dist/utils/env.utils.js.map +1 -1
- package/dist/utils/error.utils.js +0 -0
- package/dist/utils/error.utils.js.map +0 -0
- package/dist/utils/find-predicate.utils.js +0 -0
- package/dist/utils/find-predicate.utils.js.map +0 -0
- package/dist/utils/fs.utils.js +0 -0
- package/dist/utils/fs.utils.js.map +0 -0
- package/dist/utils/is-docker.js +0 -0
- package/dist/utils/is-docker.js.map +0 -0
- package/dist/utils/mapper.utils.js +0 -0
- package/dist/utils/mapper.utils.js.map +0 -0
- package/dist/utils/metric.utils.js +0 -0
- package/dist/utils/metric.utils.js.map +0 -0
- package/dist/utils/normalize-url.js +0 -0
- package/dist/utils/normalize-url.js.map +0 -0
- package/dist/utils/semver.utils.js +0 -0
- package/dist/utils/semver.utils.js.map +0 -0
- package/dist/utils/time.utils.js +0 -0
- package/dist/utils/time.utils.js.map +0 -0
- package/dist/utils/url.utils.js +0 -0
- package/dist/utils/url.utils.js.map +0 -0
- package/dist/utils/websocket.adapter.js +0 -0
- package/dist/utils/websocket.adapter.js.map +0 -0
- package/migrate-mongo-config.js +0 -0
- package/package.json +21 -16
- package/src/index.ts +0 -0
- package/tsconfig.json +0 -0
- package/.env +0 -19
- package/.idea/codeStyles/Project.xml +0 -85
- package/.idea/codeStyles/codeStyleConfig.xml +0 -5
- package/.idea/dbnavigator.xml +0 -574
- package/.idea/fdm-monster.iml +0 -16
- package/.idea/inspectionProfiles/Project_Default.xml +0 -22
- package/.idea/jsLibraryMappings.xml +0 -6
- package/.idea/modules.xml +0 -12
- package/.idea/prettier.xml +0 -6
- package/.idea/vcs.xml +0 -17
- package/dist/@type/express/index.d.js +0 -7
- package/dist/@type/express/index.d.js.map +0 -1
- package/dist/middleware/exception.handler.js.map +0 -1
- package/dist/migrations/1696187882312-PrinterFile.js +0 -40
- package/dist/migrations/1696187882312-PrinterFile.js.map +0 -1
- package/dist/models/ServerSettings.js +0 -168
- package/dist/models/ServerSettings.js.map +0 -1
- package/dist/nodemon_restart_trigger.js +0 -4
- package/dist/nodemon_restart_trigger.js.map +0 -1
- package/dist/services/orm/floor.service.interface.js +0 -73
- package/dist/services/orm/floor.service.interface.js.map +0 -1
- package/dist/services/orm/printer.service.interface.js.map +0 -1
- package/dist/services/yaml.service.js +0 -278
- package/dist/services/yaml.service.js.map +0 -1
- package/nodemon_restart_trigger.js +0 -1
|
@@ -12,7 +12,23 @@ const _models = require("../models");
|
|
|
12
12
|
const _serversettingsconstants = require("../constants/server-settings.constants");
|
|
13
13
|
const _validators = require("../handlers/validators");
|
|
14
14
|
const _settingsservicevalidation = require("./validators/settings-service.validation");
|
|
15
|
+
const _serverconstants = require("../server.constants");
|
|
16
|
+
const _runtimeexceptions = require("../exceptions/runtime.exceptions");
|
|
15
17
|
class SettingsService {
|
|
18
|
+
configService;
|
|
19
|
+
constructor({ configService }){
|
|
20
|
+
this.configService = configService;
|
|
21
|
+
}
|
|
22
|
+
toDto(entity) {
|
|
23
|
+
return {
|
|
24
|
+
// Credential settings are not shared with the client
|
|
25
|
+
[_serversettingsconstants.serverSettingsKey]: entity[_serversettingsconstants.serverSettingsKey],
|
|
26
|
+
[_serversettingsconstants.wizardSettingKey]: entity[_serversettingsconstants.wizardSettingKey],
|
|
27
|
+
[_serversettingsconstants.frontendSettingKey]: entity[_serversettingsconstants.frontendSettingKey],
|
|
28
|
+
[_serversettingsconstants.fileCleanSettingKey]: entity[_serversettingsconstants.fileCleanSettingKey],
|
|
29
|
+
[_serversettingsconstants.timeoutSettingKey]: entity[_serversettingsconstants.timeoutSettingKey]
|
|
30
|
+
};
|
|
31
|
+
}
|
|
16
32
|
async getOrCreate() {
|
|
17
33
|
let settings = await _models.Settings.findOne();
|
|
18
34
|
if (!settings) {
|
|
@@ -50,7 +66,10 @@ class SettingsService {
|
|
|
50
66
|
if (!doc[_serversettingsconstants.credentialSettingsKey]) {
|
|
51
67
|
doc[_serversettingsconstants.credentialSettingsKey] = (0, _serversettingsconstants.getDefaultCredentialSettings)();
|
|
52
68
|
}
|
|
53
|
-
if (!
|
|
69
|
+
if (!this.isWhiteListSettingEnabled()) {
|
|
70
|
+
doc.server.whitelistEnabled = false;
|
|
71
|
+
doc.server.whitelistedIpAddresses = (0, _serversettingsconstants.getDefaultWhitelistIpAddresses)();
|
|
72
|
+
} else if (!doc.server.whitelistedIpAddresses?.length) {
|
|
54
73
|
doc.server.whitelistedIpAddresses = (0, _serversettingsconstants.getDefaultWhitelistIpAddresses)();
|
|
55
74
|
}
|
|
56
75
|
if (!doc[_serversettingsconstants.frontendSettingKey]) {
|
|
@@ -58,15 +77,6 @@ class SettingsService {
|
|
|
58
77
|
}
|
|
59
78
|
return knownSettings;
|
|
60
79
|
}
|
|
61
|
-
async setSentryDiagnosticsEnabled(enabled) {
|
|
62
|
-
const settingsDoc = await this.getOrCreate();
|
|
63
|
-
settingsDoc[_serversettingsconstants.serverSettingsKey].sentryDiagnosticsEnabled = enabled;
|
|
64
|
-
return _models.Settings.findOneAndUpdate({
|
|
65
|
-
_id: settingsDoc.id
|
|
66
|
-
}, settingsDoc, {
|
|
67
|
-
new: true
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
80
|
async patchFileCleanSettings(patchUpdate) {
|
|
71
81
|
const validatedInput = await (0, _validators.validateInput)(patchUpdate, _settingsservicevalidation.fileCleanSettingsUpdateRules);
|
|
72
82
|
const settingsDoc = await this.getOrCreate();
|
|
@@ -87,28 +97,13 @@ class SettingsService {
|
|
|
87
97
|
new: true
|
|
88
98
|
});
|
|
89
99
|
}
|
|
90
|
-
async setRegistrationEnabled(enabled = true) {
|
|
91
|
-
const settingsDoc = await this.getOrCreate();
|
|
92
|
-
settingsDoc[_serversettingsconstants.serverSettingsKey].registration = enabled;
|
|
93
|
-
return _models.Settings.findOneAndUpdate({
|
|
94
|
-
_id: settingsDoc.id
|
|
95
|
-
}, settingsDoc, {
|
|
96
|
-
new: true
|
|
97
|
-
});
|
|
98
|
-
}
|
|
99
|
-
async setLoginRequired(enabled = true) {
|
|
100
|
-
const settingsDoc = await this.getOrCreate();
|
|
101
|
-
settingsDoc[_serversettingsconstants.serverSettingsKey].loginRequired = enabled;
|
|
102
|
-
return _models.Settings.findOneAndUpdate({
|
|
103
|
-
_id: settingsDoc.id
|
|
104
|
-
}, settingsDoc, {
|
|
105
|
-
new: true
|
|
106
|
-
});
|
|
107
|
-
}
|
|
108
100
|
async setWhitelist(enabled, ipAddresses) {
|
|
101
|
+
if (!this.isWhiteListSettingEnabled()) {
|
|
102
|
+
throw new _runtimeexceptions.BadRequestException("Whitelist settings are not enabled");
|
|
103
|
+
}
|
|
109
104
|
await (0, _validators.validateInput)({
|
|
110
|
-
enabled,
|
|
111
|
-
ipAddresses
|
|
105
|
+
whitelistEnabled: enabled,
|
|
106
|
+
whitelistedIpAddresses: ipAddresses
|
|
112
107
|
}, _settingsservicevalidation.whitelistSettingUpdateRules);
|
|
113
108
|
const settingsDoc = await this.getOrCreate();
|
|
114
109
|
const settings = settingsDoc[_serversettingsconstants.serverSettingsKey];
|
|
@@ -143,7 +138,7 @@ class SettingsService {
|
|
|
143
138
|
});
|
|
144
139
|
}
|
|
145
140
|
async patchServerSettings(patchUpdate) {
|
|
146
|
-
const validatedInput = await (0, _validators.validateInput)(patchUpdate, _settingsservicevalidation.serverSettingsUpdateRules);
|
|
141
|
+
const validatedInput = await (0, _validators.validateInput)(patchUpdate, (0, _settingsservicevalidation.serverSettingsUpdateRules)(this.isWhiteListSettingEnabled()));
|
|
147
142
|
const settingsDoc = await this.getOrCreate();
|
|
148
143
|
const serverSettings = settingsDoc[_serversettingsconstants.serverSettingsKey];
|
|
149
144
|
Object.assign(serverSettings, validatedInput);
|
|
@@ -153,6 +148,20 @@ class SettingsService {
|
|
|
153
148
|
new: true
|
|
154
149
|
});
|
|
155
150
|
}
|
|
151
|
+
async updateTimeoutSettings(patchUpdate) {
|
|
152
|
+
const validatedInput = await (0, _validators.validateInput)(patchUpdate, _settingsservicevalidation.timeoutSettingsUpdateRules);
|
|
153
|
+
const settingsDoc = await this.getOrCreate();
|
|
154
|
+
const timeoutSettings = settingsDoc[_serversettingsconstants.timeoutSettingKey];
|
|
155
|
+
Object.assign(timeoutSettings, validatedInput);
|
|
156
|
+
return _models.Settings.findOneAndUpdate({
|
|
157
|
+
_id: settingsDoc.id
|
|
158
|
+
}, settingsDoc, {
|
|
159
|
+
new: true
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
isWhiteListSettingEnabled() {
|
|
163
|
+
return this.configService.get(_serverconstants.AppConstants.ENABLE_EXPERIMENTAL_WHITELIST_SETTINGS, "false") === "true";
|
|
164
|
+
}
|
|
156
165
|
}
|
|
157
166
|
|
|
158
167
|
//# sourceMappingURL=settings.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/settings.service.ts"],"names":["SettingsService","getOrCreate","settings","Settings","findOne","defaultSettings","getDefaultSettings","save","migrateSettingsRuntime","findOneAndUpdate","_id","id","new","knownSettings","doc","
|
|
1
|
+
{"version":3,"sources":["../../src/services/settings.service.ts"],"names":["SettingsService","configService","constructor","toDto","entity","serverSettingsKey","wizardSettingKey","frontendSettingKey","fileCleanSettingKey","timeoutSettingKey","getOrCreate","settings","Settings","findOne","defaultSettings","getDefaultSettings","save","migrateSettingsRuntime","findOneAndUpdate","_id","id","new","knownSettings","doc","getDefaultFileCleanSettings","getDefaultWizardSettings","getDefaultTimeout","getDefaultServerSettings","credentialSettingsKey","getDefaultCredentialSettings","isWhiteListSettingEnabled","server","whitelistEnabled","whitelistedIpAddresses","getDefaultWhitelistIpAddresses","length","getDefaultFrontendSettings","patchFileCleanSettings","patchUpdate","validatedInput","validateInput","fileCleanSettingsUpdateRules","settingsDoc","Object","assign","patchWizardSettings","wizardUpdateRules","setWhitelist","enabled","ipAddresses","BadRequestException","whitelistSettingUpdateRules","updateFrontendSettings","frontendSettingsUpdateRules","frontendSettings","patchCredentialSettings","credentialSettingPatchRules","credentialSettings","patchServerSettings","serverSettingsUpdateRules","serverSettings","updateTimeoutSettings","timeoutSettingsUpdateRules","timeoutSettings","get","AppConstants","ENABLE_EXPERIMENTAL_WHITELIST_SETTINGS"],"mappings":"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"}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
@@ -33,7 +33,7 @@ const createMongoPrinterRules = {
|
|
|
33
33
|
};
|
|
34
34
|
const createPrinterRules = {
|
|
35
35
|
apiKey: `required|length:${_serviceconstants.UUID_LENGTH},${_serviceconstants.UUID_LENGTH}|alphaNumeric`,
|
|
36
|
-
|
|
36
|
+
printerURL: "required|httpurl",
|
|
37
37
|
enabled: "boolean",
|
|
38
38
|
name: "required|string"
|
|
39
39
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/validators/printer-service.validation.ts"],"names":["createMongoPrinterRules","createPrinterRules","updatePrinterDisabledReasonRule","updatePrinterEnabledRule","_id","apiKey","UUID_LENGTH","printerURL","enabled","settingsAppearance","
|
|
1
|
+
{"version":3,"sources":["../../../src/services/validators/printer-service.validation.ts"],"names":["createMongoPrinterRules","createPrinterRules","updatePrinterDisabledReasonRule","updatePrinterEnabledRule","_id","apiKey","UUID_LENGTH","printerURL","enabled","settingsAppearance","name","disabledReason"],"mappings":";;;;;;;;;;;IAEaA,uBAAuB;eAAvBA;;IASAC,kBAAkB;eAAlBA;;IAWAC,+BAA+B;eAA/BA;;IAJAC,wBAAwB;eAAxBA;;;kCAlBe;AAErB,MAAMH,0BAA0B;IACrCI,KAAK;IACLC,QAAQ,CAAC,gBAAgB,EAAEC,6BAAW,CAAC,CAAC,EAAEA,6BAAW,CAAC,aAAa,CAAC;IACpEC,YAAY;IACZC,SAAS;IACTC,oBAAoB;IACpB,2BAA2B;AAC7B;AAEO,MAAMR,qBAAqB;IAChCI,QAAQ,CAAC,gBAAgB,EAAEC,6BAAW,CAAC,CAAC,EAAEA,6BAAW,CAAC,aAAa,CAAC;IACpEC,YAAY;IACZC,SAAS;IACTE,MAAM;AACR;AAEO,MAAMP,2BAA2B;IACtCK,SAAS;AACX;AAEO,MAAMN,kCAAkC;IAC7CS,gBAAgB;IAChBH,SAAS;AACX"}
|
|
@@ -24,6 +24,9 @@ _export(exports, {
|
|
|
24
24
|
serverSettingsUpdateRules: function() {
|
|
25
25
|
return serverSettingsUpdateRules;
|
|
26
26
|
},
|
|
27
|
+
timeoutSettingsUpdateRules: function() {
|
|
28
|
+
return timeoutSettingsUpdateRules;
|
|
29
|
+
},
|
|
27
30
|
whitelistSettingUpdateRules: function() {
|
|
28
31
|
return whitelistSettingUpdateRules;
|
|
29
32
|
},
|
|
@@ -31,12 +34,19 @@ _export(exports, {
|
|
|
31
34
|
return wizardUpdateRules;
|
|
32
35
|
}
|
|
33
36
|
});
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
37
|
+
const _envutils = require("../../utils/env.utils");
|
|
38
|
+
const serverSettingsUpdateRules = (whitelistFeatureEnabled)=>({
|
|
39
|
+
registration: "boolean",
|
|
40
|
+
loginRequired: "boolean",
|
|
41
|
+
debugSettings: "object",
|
|
42
|
+
"debugSettings.debugSocketEvents": "boolean",
|
|
43
|
+
"debugSettings.debugSocketReconnect": "boolean",
|
|
44
|
+
whitelistEnabled: whitelistFeatureEnabled ? "boolean" : "not",
|
|
45
|
+
whitelistedIpAddresses: whitelistFeatureEnabled ? "array|minLength:1" : "not",
|
|
46
|
+
"whitelistedIpAddresses.*": whitelistFeatureEnabled ? "required|string" : "not"
|
|
47
|
+
});
|
|
48
|
+
const timeoutSettingsUpdateRules = {
|
|
49
|
+
apiTimeout: "integer|min:1000"
|
|
40
50
|
};
|
|
41
51
|
const frontendSettingsUpdateRules = {
|
|
42
52
|
gridCols: "integer|min:1",
|
|
@@ -45,9 +55,9 @@ const frontendSettingsUpdateRules = {
|
|
|
45
55
|
};
|
|
46
56
|
const credentialSettingPatchRules = {
|
|
47
57
|
jwtSecret: "string",
|
|
48
|
-
jwtExpiresIn: "integer|min:120",
|
|
58
|
+
jwtExpiresIn: (0, _envutils.isProductionEnvironment)() ? "integer|min:120|max:7200" : "integer|min:0",
|
|
49
59
|
refreshTokenAttempts: "integer|min:-1",
|
|
50
|
-
refreshTokenExpiry: "integer|min:0"
|
|
60
|
+
refreshTokenExpiry: (0, _envutils.isProductionEnvironment)() ? "integer|min:240" : "integer|min:0"
|
|
51
61
|
};
|
|
52
62
|
const whitelistSettingUpdateRules = {
|
|
53
63
|
whitelistedIpAddresses: "required|array|minLength:1",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/validators/settings-service.validation.ts"],"names":["credentialSettingPatchRules","fileCleanSettingsUpdateRules","frontendSettingsUpdateRules","sentryDiagnosticsEnabledRules","serverSettingsUpdateRules","whitelistSettingUpdateRules","wizardUpdateRules","registration","loginRequired","debugSettings","gridCols","gridRows","largeTiles","jwtSecret","jwtExpiresIn","
|
|
1
|
+
{"version":3,"sources":["../../../src/services/validators/settings-service.validation.ts"],"names":["credentialSettingPatchRules","fileCleanSettingsUpdateRules","frontendSettingsUpdateRules","sentryDiagnosticsEnabledRules","serverSettingsUpdateRules","timeoutSettingsUpdateRules","whitelistSettingUpdateRules","wizardUpdateRules","whitelistFeatureEnabled","registration","loginRequired","debugSettings","whitelistEnabled","whitelistedIpAddresses","apiTimeout","gridCols","gridRows","largeTiles","jwtSecret","jwtExpiresIn","isProductionEnvironment","refreshTokenAttempts","refreshTokenExpiry","wizardCompleted","wizardCompletedAt","wizardVersion","autoRemoveOldFilesBeforeUpload","autoRemoveOldFilesAtBoot","autoRemoveOldFilesCriteriumDays","enabled"],"mappings":";;;;;;;;;;;IAuBaA,2BAA2B;eAA3BA;;IAmBAC,4BAA4B;eAA5BA;;IAzBAC,2BAA2B;eAA3BA;;IA+BAC,6BAA6B;eAA7BA;;IA9CAC,yBAAyB;eAAzBA;;IAWAC,0BAA0B;eAA1BA;;IAiBAC,2BAA2B;eAA3BA;;IAMAC,iBAAiB;eAAjBA;;;0BApC2B;AAEjC,MAAMH,4BAA4B,CAACI,0BAAsC,CAAA;QAC9EC,cAAc;QACdC,eAAe;QACfC,eAAe;QACf,mCAAmC;QACnC,sCAAsC;QACtCC,kBAAkBJ,0BAA0B,YAAY;QACxDK,wBAAwBL,0BAA0B,sBAAsB;QACxE,4BAA4BA,0BAA0B,oBAAoB;IAC5E,CAAA;AAEO,MAAMH,6BAA6B;IACxCS,YAAY;AACd;AAEO,MAAMZ,8BAA8B;IACzCa,UAAU;IACVC,UAAU;IACVC,YAAY;AACd;AAEO,MAAMjB,8BAA8B;IACzCkB,WAAW;IACXC,cAAcC,IAAAA,iCAAuB,MAAK,6BAA6B;IACvEC,sBAAsB;IACtBC,oBAAoBF,IAAAA,iCAAuB,MAAK,oBAAoB;AACtE;AAEO,MAAMd,8BAA8B;IACzCO,wBAAwB;IACxB,4BAA4B;IAC5BD,kBAAkB;AACpB;AAEO,MAAML,oBAAoB;IAC/BgB,iBAAiB;IACjBC,mBAAmB;IACnBC,eAAe;AACjB;AAEO,MAAMxB,+BAA+B;IAC1CyB,gCAAgC;IAChCC,0BAA0B;IAC1BC,iCAAiC;AACnC;AAEO,MAAMzB,gCAAgC;IAC3C0B,SAAS;AACX"}
|
|
@@ -18,13 +18,14 @@ _export(exports, {
|
|
|
18
18
|
});
|
|
19
19
|
const _serverconstants = require("../../server.constants");
|
|
20
20
|
const registerUserRules = {
|
|
21
|
-
username:
|
|
21
|
+
username: `required|string|minLength:${_serverconstants.AppConstants.DEFAULT_USERNAME_MINLEN}`,
|
|
22
22
|
password: `required|string|minLength:${_serverconstants.AppConstants.DEFAULT_PASSWORD_MINLEN}`,
|
|
23
23
|
needsPasswordChange: "boolean",
|
|
24
24
|
roles: "required|array",
|
|
25
25
|
isDemoUser: "boolean",
|
|
26
26
|
isRootUser: "boolean",
|
|
27
|
-
"roles.*": "required|mongoId"
|
|
27
|
+
"roles.*": "required|mongoId",
|
|
28
|
+
isVerified: "boolean"
|
|
28
29
|
};
|
|
29
30
|
const newPasswordRules = {
|
|
30
31
|
password: `required|string|minLength:${_serverconstants.AppConstants.DEFAULT_PASSWORD_MINLEN}`
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/validators/user-service.validation.ts"],"names":["newPasswordRules","registerUserRules","username","
|
|
1
|
+
{"version":3,"sources":["../../../src/services/validators/user-service.validation.ts"],"names":["newPasswordRules","registerUserRules","username","AppConstants","DEFAULT_USERNAME_MINLEN","password","DEFAULT_PASSWORD_MINLEN","needsPasswordChange","roles","isDemoUser","isRootUser","isVerified"],"mappings":";;;;;;;;;;;IAaaA,gBAAgB;eAAhBA;;IAXAC,iBAAiB;eAAjBA;;;iCAFgB;AAEtB,MAAMA,oBAAoB;IAC/BC,UAAU,CAAC,0BAA0B,EAAEC,6BAAY,CAACC,uBAAuB,CAAC,CAAC;IAC7EC,UAAU,CAAC,0BAA0B,EAAEF,6BAAY,CAACG,uBAAuB,CAAC,CAAC;IAC7EC,qBAAqB;IACrBC,OAAO;IACPC,YAAY;IACZC,YAAY;IACZ,WAAW;IACXC,YAAY;AACd;AAEO,MAAMX,mBAAmB;IAC9BK,UAAU,CAAC,0BAA0B,EAAEF,6BAAY,CAACG,uBAAuB,CAAC,CAAC;AAC/E"}
|
|
File without changes
|
|
File without changes
|
package/dist/shared.constants.js
CHANGED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
package/dist/state/file.cache.js
CHANGED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
@@ -23,15 +23,36 @@ class SettingsStore {
|
|
|
23
23
|
}
|
|
24
24
|
getSettings() {
|
|
25
25
|
const settings = this.settings;
|
|
26
|
+
if (!settings) throw new _runtimeexceptions.InternalServerException("Could not check server settings (server settings not loaded");
|
|
26
27
|
return Object.freeze({
|
|
27
28
|
// Credential settings are not shared with the client
|
|
28
|
-
[_serversettingsconstants.serverSettingsKey]:
|
|
29
|
+
[_serversettingsconstants.serverSettingsKey]: {
|
|
30
|
+
loginRequired: settings[_serversettingsconstants.serverSettingsKey].loginRequired,
|
|
31
|
+
registration: settings[_serversettingsconstants.serverSettingsKey].registration,
|
|
32
|
+
sentryDiagnosticsEnabled: settings[_serversettingsconstants.serverSettingsKey].sentryDiagnosticsEnabled
|
|
33
|
+
},
|
|
29
34
|
[_serversettingsconstants.wizardSettingKey]: settings[_serversettingsconstants.wizardSettingKey],
|
|
30
35
|
[_serversettingsconstants.frontendSettingKey]: settings[_serversettingsconstants.frontendSettingKey],
|
|
31
36
|
[_serversettingsconstants.fileCleanSettingKey]: settings[_serversettingsconstants.fileCleanSettingKey],
|
|
32
37
|
[_serversettingsconstants.timeoutSettingKey]: settings[_serversettingsconstants.timeoutSettingKey]
|
|
33
38
|
});
|
|
34
39
|
}
|
|
40
|
+
getSettingsSensitive() {
|
|
41
|
+
const settings = this.settings;
|
|
42
|
+
if (!settings) throw new _runtimeexceptions.InternalServerException("Could not check server settings (server settings not loaded");
|
|
43
|
+
return Object.freeze({
|
|
44
|
+
[_serversettingsconstants.credentialSettingsKey]: {
|
|
45
|
+
jwtExpiresIn: settings[_serversettingsconstants.credentialSettingsKey].jwtExpiresIn,
|
|
46
|
+
refreshTokenAttempts: settings[_serversettingsconstants.credentialSettingsKey].refreshTokenAttempts,
|
|
47
|
+
refreshTokenExpiry: settings[_serversettingsconstants.credentialSettingsKey].refreshTokenExpiry
|
|
48
|
+
},
|
|
49
|
+
[_serversettingsconstants.serverSettingsKey]: {
|
|
50
|
+
debugSettings: settings[_serversettingsconstants.serverSettingsKey].debugSettings,
|
|
51
|
+
whitelistEnabled: settings[_serversettingsconstants.serverSettingsKey].whitelistEnabled,
|
|
52
|
+
whitelistedIpAddresses: settings[_serversettingsconstants.serverSettingsKey].whitelistedIpAddresses
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
35
56
|
async loadSettings() {
|
|
36
57
|
// Setup Settings as connection is established
|
|
37
58
|
this.settings = await this.settingsService.getOrCreate();
|
|
@@ -78,9 +99,7 @@ class SettingsStore {
|
|
|
78
99
|
getFrontendSettings() {
|
|
79
100
|
return this.getSettings()[_serversettingsconstants.frontendSettingKey];
|
|
80
101
|
}
|
|
81
|
-
|
|
82
|
-
* Cross-cutting concern for file clean operation
|
|
83
|
-
*/ getFileCleanSettings() {
|
|
102
|
+
getFileCleanSettings() {
|
|
84
103
|
return this.getSettings()[_serversettingsconstants.fileCleanSettingKey];
|
|
85
104
|
}
|
|
86
105
|
isPreUploadFileCleanEnabled() {
|
|
@@ -120,6 +139,10 @@ class SettingsStore {
|
|
|
120
139
|
this.settings = await this.settingsService.patchServerSettings(serverSettings);
|
|
121
140
|
return this.getSettings();
|
|
122
141
|
}
|
|
142
|
+
async updateTimeoutSettings(timeoutSettings) {
|
|
143
|
+
this.settings = await this.settingsService.updateTimeoutSettings(timeoutSettings);
|
|
144
|
+
return this.getSettings();
|
|
145
|
+
}
|
|
123
146
|
async patchFileCleanSettings(fileClean) {
|
|
124
147
|
this.settings = await this.settingsService.patchFileCleanSettings(fileClean);
|
|
125
148
|
return this.getSettings();
|
|
@@ -140,13 +163,13 @@ class SettingsStore {
|
|
|
140
163
|
return this.getSettings();
|
|
141
164
|
}
|
|
142
165
|
async processSentryEnabled() {
|
|
143
|
-
if ((0, _envutils.isTestEnvironment)()) return;
|
|
144
166
|
const sentryEnabled = await this.getAnonymousDiagnosticsEnabled();
|
|
145
167
|
if (sentryEnabled) {
|
|
146
168
|
this.logger.log("Enabling Sentry for remote diagnostics");
|
|
147
169
|
} else {
|
|
148
170
|
this.logger.log("Disabling Sentry for remote diagnostics");
|
|
149
171
|
}
|
|
172
|
+
if ((0, _envutils.isTestEnvironment)()) return;
|
|
150
173
|
(0, _node.getCurrentHub)().getClient().getOptions().enabled = sentryEnabled;
|
|
151
174
|
}
|
|
152
175
|
}
|
|
@@ -1 +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","
|
|
1
|
+
{"version":3,"sources":["../../src/state/settings.store.ts"],"names":["SettingsStore","settingsService","logger","settings","constructor","loggerFactory","name","getSettings","InternalServerException","Object","freeze","serverSettingsKey","loginRequired","registration","sentryDiagnosticsEnabled","wizardSettingKey","frontendSettingKey","fileCleanSettingKey","timeoutSettingKey","getSettingsSensitive","credentialSettingsKey","jwtExpiresIn","refreshTokenAttempts","refreshTokenExpiry","debugSettings","whitelistEnabled","whitelistedIpAddresses","loadSettings","getOrCreate","processSentryEnabled","getCredentialSettings","getAnonymousDiagnosticsEnabled","persistOptionalCredentialSettings","overrideJwtSecret","overrideJwtExpiresIn","updateCredentialSettings","jwtSecret","parseInt","getWizardState","wizardCompleted","wizardVersion","latestWizardVersion","AppConstants","currentWizardVersion","isWizardCompleted","getWizardSettings","isRegistrationEnabled","getServerSettings","getFrontendSettings","getFileCleanSettings","isPreUploadFileCleanEnabled","autoRemoveOldFilesBeforeUpload","setWizardCompleted","version","patchWizardSettings","wizardCompletedAt","Date","setRegistrationEnabled","patchServerSettings","getLoginRequired","setLoginRequired","setWhitelist","updateServerSettings","serverSettings","updateTimeoutSettings","timeoutSettings","patchFileCleanSettings","fileClean","credentialSettings","patchCredentialSettings","setSentryDiagnosticsEnabled","updateFrontendSettings","frontendSettings","sentryEnabled","log","isTestEnvironment","getCurrentHub","getClient","getOptions","enabled"],"mappings":"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"}
|
|
@@ -18,15 +18,40 @@ _export(exports, {
|
|
|
18
18
|
});
|
|
19
19
|
const _socketio = require("socket.io");
|
|
20
20
|
const _eventconstants = require("../constants/event.constants");
|
|
21
|
+
const _passport = require("../middleware/passport");
|
|
22
|
+
const _passportjwt = require("passport-jwt");
|
|
23
|
+
const authorize = (settingsStore, options, verify)=>{
|
|
24
|
+
const strategy = new _passportjwt.Strategy(options, verify);
|
|
25
|
+
return async function authorizeCallback(socket, next) {
|
|
26
|
+
if (!await settingsStore.getLoginRequired()) {
|
|
27
|
+
// No login required, so we can skip the authentication
|
|
28
|
+
return next();
|
|
29
|
+
}
|
|
30
|
+
// --- Begin strategy augmentation ala passport
|
|
31
|
+
strategy.success = function success(user) {
|
|
32
|
+
socket.handshake.user = user;
|
|
33
|
+
next();
|
|
34
|
+
};
|
|
35
|
+
strategy.fail = (info)=>next(new Error(info));
|
|
36
|
+
strategy.error = (error)=>next(error);
|
|
37
|
+
strategy.authenticate(socket, {});
|
|
38
|
+
};
|
|
39
|
+
};
|
|
21
40
|
class SocketIoGateway {
|
|
22
41
|
logger;
|
|
23
42
|
eventEmitter2;
|
|
24
43
|
io;
|
|
44
|
+
authService;
|
|
25
45
|
settingsStore;
|
|
26
|
-
|
|
46
|
+
configService;
|
|
47
|
+
userService;
|
|
48
|
+
constructor({ loggerFactory, eventEmitter2, settingsStore, authService, configService, userService }){
|
|
27
49
|
this.logger = loggerFactory(SocketIoGateway.name);
|
|
28
50
|
this.eventEmitter2 = eventEmitter2;
|
|
29
51
|
this.settingsStore = settingsStore;
|
|
52
|
+
this.authService = authService;
|
|
53
|
+
this.userService = userService;
|
|
54
|
+
this.configService = configService;
|
|
30
55
|
}
|
|
31
56
|
attachServer(httpServer) {
|
|
32
57
|
this.io = new _socketio.Server(httpServer, {
|
|
@@ -34,8 +59,10 @@ class SocketIoGateway {
|
|
|
34
59
|
origin: "*"
|
|
35
60
|
}
|
|
36
61
|
});
|
|
37
|
-
const
|
|
38
|
-
|
|
62
|
+
const opts = (0, _passport.getPassportJwtOptions)(this.settingsStore, this.configService, (value)=>value.handshake.auth.token);
|
|
63
|
+
const verify = (0, _passport.verifyUserCallback)(this.userService);
|
|
64
|
+
this.io.use(authorize(this.settingsStore, opts, verify));
|
|
65
|
+
this.io.on("connection", (socket)=>this.onConnect.bind(this)(socket));
|
|
39
66
|
}
|
|
40
67
|
onConnect(socket) {
|
|
41
68
|
this.logger.log("SocketIO Client connected", socket.id);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/state/socket-io.gateway.ts"],"names":["IO_MESSAGES","SocketIoGateway","logger","eventEmitter2","io","
|
|
1
|
+
{"version":3,"sources":["../../src/state/socket-io.gateway.ts"],"names":["IO_MESSAGES","SocketIoGateway","authorize","settingsStore","options","verify","strategy","JwtStrategy","authorizeCallback","socket","next","getLoginRequired","success","user","handshake","fail","info","Error","error","authenticate","logger","eventEmitter2","io","authService","configService","userService","constructor","loggerFactory","name","attachServer","httpServer","Server","cors","origin","opts","getPassportJwtOptions","value","auth","token","verifyUserCallback","use","on","onConnect","bind","log","id","emit","socketIoConnectedEvent","send","event","data","debug","getServerSettings","debugSettings","debugSocketIoEvents","LegacyUpdate","LegacyPrinterTest","CompletionEvent","HostState","ApiAccessibility"],"mappings":"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"}
|
|
@@ -70,6 +70,9 @@ class TestPrinterSocketStore {
|
|
|
70
70
|
const promise = new Promise(async (resolve, reject)=>{
|
|
71
71
|
this.testSocket.open();
|
|
72
72
|
for await (const startTime of (0, _promises.setInterval)(100)){
|
|
73
|
+
if (!this.testSocket) {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
73
76
|
if (this.testSocket.socketState === _octoprintsockioadapter.SOCKET_STATE.authenticated) {
|
|
74
77
|
resolve();
|
|
75
78
|
break;
|
|
@@ -1 +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"}
|
|
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,CAAC,IAAI,CAAC1C,UAAU,EAAE;oBACpB;gBACF;gBACA,IAAI,IAAI,CAACA,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"}
|
|
File without changes
|
|
File without changes
|
package/dist/task.presets.js
CHANGED
|
File without changes
|
package/dist/task.presets.js.map
CHANGED
|
File without changes
|
package/dist/tasks/boot.task.js
CHANGED
|
@@ -33,7 +33,9 @@ function _interop_require_wildcard(obj, nodeInterop) {
|
|
|
33
33
|
if (cache && cache.has(obj)) {
|
|
34
34
|
return cache.get(obj);
|
|
35
35
|
}
|
|
36
|
-
var newObj = {
|
|
36
|
+
var newObj = {
|
|
37
|
+
__proto__: null
|
|
38
|
+
};
|
|
37
39
|
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
|
|
38
40
|
for(var key in obj){
|
|
39
41
|
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
@@ -116,22 +118,23 @@ class BootTask {
|
|
|
116
118
|
this.logger.log("Synchronizing user permission and roles definition");
|
|
117
119
|
await this.permissionService.syncPermissions();
|
|
118
120
|
await this.roleService.syncRoles();
|
|
119
|
-
const isDemoMode = this.configService.
|
|
121
|
+
const isDemoMode = this.configService.isDemoMode();
|
|
120
122
|
if (isDemoMode) {
|
|
121
123
|
this.logger.warn(`Starting in demo mode due to ${_serverconstants.AppConstants.OVERRIDE_IS_DEMO_MODE}`);
|
|
122
124
|
await this.createOrUpdateDemoAccount();
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
125
|
+
this.logger.warn(`Setting loginRequired=true and registration=false due to ${_serverconstants.AppConstants.OVERRIDE_IS_DEMO_MODE}`);
|
|
126
|
+
await this.settingsStore.setLoginRequired(true);
|
|
127
|
+
await this.settingsStore.setRegistrationEnabled(false);
|
|
128
|
+
} else {
|
|
129
|
+
const loginRequired = this.configService.get(_serverconstants.AppConstants.OVERRIDE_LOGIN_REQUIRED, null);
|
|
130
|
+
if (loginRequired !== null) {
|
|
131
|
+
this.logger.warn(`Setting login required due to ${_serverconstants.AppConstants.OVERRIDE_LOGIN_REQUIRED}`);
|
|
132
|
+
await this.settingsStore.setLoginRequired(loginRequired === "true");
|
|
133
|
+
}
|
|
131
134
|
const registrationEnabled = this.configService.get(_serverconstants.AppConstants.OVERRIDE_REGISTRATION_ENABLED, null);
|
|
132
135
|
if (registrationEnabled !== null) {
|
|
133
136
|
this.logger.warn(`Setting registration enabled due to ${_serverconstants.AppConstants.OVERRIDE_REGISTRATION_ENABLED}`);
|
|
134
|
-
await this.settingsStore.setRegistrationEnabled(registrationEnabled);
|
|
137
|
+
await this.settingsStore.setRegistrationEnabled(registrationEnabled === "true");
|
|
135
138
|
}
|
|
136
139
|
}
|
|
137
140
|
const overrideJwtSecret = this.configService.get(_serverconstants.AppConstants.OVERRIDE_JWT_SECRET, undefined);
|
|
@@ -167,7 +170,7 @@ class BootTask {
|
|
|
167
170
|
password: demoPassword,
|
|
168
171
|
isDemoUser: true,
|
|
169
172
|
isVerified: true,
|
|
170
|
-
isRootUser:
|
|
173
|
+
isRootUser: false,
|
|
171
174
|
needsPasswordChange: false,
|
|
172
175
|
roles: [
|
|
173
176
|
adminRole.id
|
|
@@ -176,8 +179,8 @@ class BootTask {
|
|
|
176
179
|
this.logger.log("Created demo account");
|
|
177
180
|
} else {
|
|
178
181
|
await this.userService.setVerifiedById(demoUserId, true);
|
|
179
|
-
await this.userService.setIsRootUserById(demoUserId,
|
|
180
|
-
await this.userService.
|
|
182
|
+
await this.userService.setIsRootUserById(demoUserId, false);
|
|
183
|
+
await this.userService.updatePasswordUnsafeByUsername(demoUsername, demoPassword);
|
|
181
184
|
await this.userService.setUserRoleIds(demoUserId, [
|
|
182
185
|
adminRole.id
|
|
183
186
|
]);
|
|
@@ -189,6 +192,7 @@ class BootTask {
|
|
|
189
192
|
await (0, _mongoose.connect)((0, _serverenv.fetchMongoDBConnectionString)(), {
|
|
190
193
|
serverSelectionTimeoutMS: 1500
|
|
191
194
|
});
|
|
195
|
+
await (0, _mongoose.syncIndexes)();
|
|
192
196
|
}
|
|
193
197
|
async migrateDatabase() {
|
|
194
198
|
await (0, _serverenv.runMigrations)(_mongoose.default.connection.db, _mongoose.default.connection.getClient());
|