@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
package/dist/server.host.js
CHANGED
|
@@ -13,7 +13,7 @@ const _mongoose = /*#__PURE__*/ _interop_require_default(require("mongoose"));
|
|
|
13
13
|
const _connecthistoryapifallback = /*#__PURE__*/ _interop_require_default(require("connect-history-api-fallback"));
|
|
14
14
|
const _awilixexpress = require("awilix-express");
|
|
15
15
|
const _path = require("path");
|
|
16
|
-
const
|
|
16
|
+
const _exceptionfilter = require("./middleware/exception.filter");
|
|
17
17
|
const _serverenv = require("./server.env");
|
|
18
18
|
const _runtimeexceptions = require("./exceptions/runtime.exceptions");
|
|
19
19
|
const _serverconstants = require("./server.constants");
|
|
@@ -63,7 +63,7 @@ class ServerHost {
|
|
|
63
63
|
}).use((0, _awilixexpress.loadControllers)(`${routePath}/*.controller.*`, {
|
|
64
64
|
cwd: __dirname,
|
|
65
65
|
ignore: "**/*.map"
|
|
66
|
-
})).use(
|
|
66
|
+
})).use(_exceptionfilter.exceptionFilter);
|
|
67
67
|
// Serve the files for our frontend - do this later than the controllers
|
|
68
68
|
const bundleDistPath = (0, _path.join)((0, _fsutils.superRootPath)(), _serverconstants.AppConstants.defaultClientBundleStorage, "dist");
|
|
69
69
|
app.use(_express.default.static(bundleDistPath));
|
|
@@ -82,7 +82,7 @@ class ServerHost {
|
|
|
82
82
|
if (!path.startsWith("/socket.io")) {
|
|
83
83
|
throw new _runtimeexceptions.NotFoundException(`${resource} resource was not found`, path);
|
|
84
84
|
}
|
|
85
|
-
}).use(
|
|
85
|
+
}).use(_exceptionfilter.exceptionFilter);
|
|
86
86
|
}
|
|
87
87
|
async httpListen() {
|
|
88
88
|
const port = (0, _serverenv.fetchServerPort)();
|
package/dist/server.host.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/server.host.ts"],"names":["ServerHost","bootTask","taskManagerService","socketIoGateway","appInstance","configService","logger","constructor","loggerFactory","name","boot","app","quick_boot","listenRequests","mongoose","set","serveControllerRoutes","runOnce","httpListen","hasConnected","connections","readyState","routePath","use","req","res","next","originalUrl","startsWith","history","loadControllers","cwd","__dirname","ignore","
|
|
1
|
+
{"version":3,"sources":["../src/server.host.ts"],"names":["ServerHost","bootTask","taskManagerService","socketIoGateway","appInstance","configService","logger","constructor","loggerFactory","name","boot","app","quick_boot","listenRequests","mongoose","set","serveControllerRoutes","runOnce","httpListen","hasConnected","connections","readyState","routePath","use","req","res","next","originalUrl","startsWith","history","loadControllers","cwd","__dirname","ignore","exceptionFilter","bundleDistPath","join","superRootPath","AppConstants","defaultClientBundleStorage","express","static","backupClientPath","clientPackageName","get","path","resource","endsWith","error","NotFoundException","port","fetchServerPort","isProductionEnvironment","debugRoutesKey","expressListRoutes","require","prefix","Number","isNaN","parseInt","Error","hostOrFqdn","server","listen","log","attachServer"],"mappings":"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"}
|
|
@@ -10,6 +10,7 @@ Object.defineProperty(exports, "AuthService", {
|
|
|
10
10
|
});
|
|
11
11
|
const _runtimeexceptions = require("../../exceptions/runtime.exceptions");
|
|
12
12
|
const _cryptoutils = require("../../utils/crypto.utils");
|
|
13
|
+
const _authorizationconstants = require("../../constants/authorization.constants");
|
|
13
14
|
class AuthService {
|
|
14
15
|
logger;
|
|
15
16
|
userService;
|
|
@@ -43,16 +44,16 @@ class AuthService {
|
|
|
43
44
|
async loginUser(username, password) {
|
|
44
45
|
const userDoc = await this.userService.findRawByUsername(username);
|
|
45
46
|
if (!userDoc) {
|
|
46
|
-
throw new _runtimeexceptions.AuthenticationError("Login incorrect");
|
|
47
|
+
throw new _runtimeexceptions.AuthenticationError("Login incorrect", _authorizationconstants.AUTH_ERROR_REASON.IncorrectCredentials);
|
|
47
48
|
}
|
|
48
49
|
const result = (0, _cryptoutils.comparePasswordHash)(password, userDoc.passwordHash);
|
|
49
50
|
if (!result) {
|
|
50
|
-
throw new _runtimeexceptions.AuthenticationError("Login incorrect");
|
|
51
|
+
throw new _runtimeexceptions.AuthenticationError("Login incorrect", _authorizationconstants.AUTH_ERROR_REASON.IncorrectCredentials);
|
|
51
52
|
}
|
|
52
53
|
const userId = userDoc.id.toString();
|
|
53
54
|
const token = await this.signJwtToken(userId);
|
|
54
55
|
await this.refreshTokenService.purgeOutdatedRefreshTokensByUserId(userId);
|
|
55
|
-
await this.
|
|
56
|
+
await this.purgeOutdatedBlacklistedJwtCache();
|
|
56
57
|
const refreshToken = await this.refreshTokenService.createRefreshTokenForUserId(userId);
|
|
57
58
|
return {
|
|
58
59
|
token,
|
|
@@ -66,10 +67,10 @@ class AuthService {
|
|
|
66
67
|
userId,
|
|
67
68
|
createdAt: Date.now()
|
|
68
69
|
};
|
|
69
|
-
await this.
|
|
70
|
+
await this.purgeOutdatedBlacklistedJwtCache();
|
|
70
71
|
}
|
|
71
72
|
}
|
|
72
|
-
async
|
|
73
|
+
async purgeOutdatedBlacklistedJwtCache() {
|
|
73
74
|
try {
|
|
74
75
|
const { jwtExpiresIn } = await this.settingsStore.getCredentialSettings();
|
|
75
76
|
const now = Date.now();
|
|
@@ -91,9 +92,15 @@ class AuthService {
|
|
|
91
92
|
async renewLoginByRefreshToken(refreshToken) {
|
|
92
93
|
const userRefreshToken = await this.getValidRefreshToken(refreshToken, false);
|
|
93
94
|
if (!userRefreshToken) {
|
|
94
|
-
throw new _runtimeexceptions.AuthenticationError("The refresh token was invalid or expired, could not refresh user token");
|
|
95
|
+
throw new _runtimeexceptions.AuthenticationError("The refresh token was invalid or expired, could not refresh user token", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
|
|
95
96
|
}
|
|
96
97
|
const userId = userRefreshToken.userId.toString();
|
|
98
|
+
const user = await this.userService.getUser(userId, false);
|
|
99
|
+
if (!user) {
|
|
100
|
+
await this.refreshTokenService.deleteRefreshToken(refreshToken);
|
|
101
|
+
throw new _runtimeexceptions.AuthenticationError("User not found", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
|
|
102
|
+
}
|
|
103
|
+
// If the user is not found at this point, then the user was deleted
|
|
97
104
|
const token = await this.signJwtToken(userId);
|
|
98
105
|
await this.increaseRefreshTokenAttemptsUsed(userRefreshToken.refreshToken);
|
|
99
106
|
return token;
|
|
@@ -103,31 +110,38 @@ class AuthService {
|
|
|
103
110
|
}
|
|
104
111
|
async getValidRefreshToken(refreshToken, throwNotFoundError = true) {
|
|
105
112
|
const userRefreshToken = await this.refreshTokenService.getRefreshToken(refreshToken, throwNotFoundError);
|
|
113
|
+
if (!userRefreshToken) {
|
|
114
|
+
return null;
|
|
115
|
+
}
|
|
106
116
|
if (Date.now() > userRefreshToken.expiresAt) {
|
|
107
117
|
await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId.toString());
|
|
108
|
-
throw new _runtimeexceptions.AuthenticationError("Refresh token expired, login required");
|
|
118
|
+
throw new _runtimeexceptions.AuthenticationError("Refresh token expired, login required", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
|
|
109
119
|
}
|
|
110
120
|
return userRefreshToken;
|
|
111
121
|
}
|
|
112
122
|
async increaseRefreshTokenAttemptsUsed(refreshToken) {
|
|
113
123
|
const { refreshTokenAttempts } = await this.settingsStore.getCredentialSettings();
|
|
114
124
|
const userRefreshToken = await this.getValidRefreshToken(refreshToken);
|
|
115
|
-
// If no attempts are set, then we don't care about attempts
|
|
116
|
-
if (refreshTokenAttempts < 0) return;
|
|
117
125
|
const attemptsUsed = userRefreshToken.refreshAttemptsUsed;
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
126
|
+
// If no attempts are set, then we don't care about attempts
|
|
127
|
+
if (refreshTokenAttempts !== -1) {
|
|
128
|
+
if (attemptsUsed >= refreshTokenAttempts) {
|
|
129
|
+
await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId.toString());
|
|
130
|
+
throw new _runtimeexceptions.AuthenticationError("Refresh token attempts exceeded, login required", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
|
|
131
|
+
}
|
|
121
132
|
}
|
|
122
133
|
await this.refreshTokenService.updateRefreshTokenAttempts(refreshToken, attemptsUsed + 1);
|
|
123
134
|
}
|
|
124
135
|
async signJwtToken(userId) {
|
|
125
|
-
const user = await this.userService.getUser(userId);
|
|
136
|
+
const user = await this.userService.getUser(userId, false);
|
|
137
|
+
if (!user) {
|
|
138
|
+
throw new _runtimeexceptions.AuthenticationError("User not found", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
|
|
139
|
+
}
|
|
126
140
|
if (user.needsPasswordChange) {
|
|
127
|
-
throw new _runtimeexceptions.
|
|
141
|
+
throw new _runtimeexceptions.AuthenticationError("Password change required", _authorizationconstants.AUTH_ERROR_REASON.PasswordChangeRequired);
|
|
128
142
|
}
|
|
129
143
|
if (!user.isVerified) {
|
|
130
|
-
throw new _runtimeexceptions.AuthenticationError("User is not verified yet");
|
|
144
|
+
throw new _runtimeexceptions.AuthenticationError("User is not verified yet", _authorizationconstants.AUTH_ERROR_REASON.AccountNotVerified);
|
|
131
145
|
}
|
|
132
146
|
return this.jwtService.signJwtToken(userId, user.username);
|
|
133
147
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/authentication/auth.service.ts"],"names":["AuthService","logger","userService","jwtService","settingsStore","refreshTokenService","blacklistedJwtCache","constructor","loggerFactory","name","loginUser","username","password","userDoc","findRawByUsername","AuthenticationError","result","comparePasswordHash","passwordHash","userId","id","toString","token","signJwtToken","purgeOutdatedRefreshTokensByUserId","
|
|
1
|
+
{"version":3,"sources":["../../../src/services/authentication/auth.service.ts"],"names":["AuthService","logger","userService","jwtService","settingsStore","refreshTokenService","blacklistedJwtCache","constructor","loggerFactory","name","loginUser","username","password","userDoc","findRawByUsername","AuthenticationError","AUTH_ERROR_REASON","IncorrectCredentials","result","comparePasswordHash","passwordHash","userId","id","toString","token","signJwtToken","purgeOutdatedRefreshTokensByUserId","purgeOutdatedBlacklistedJwtCache","refreshToken","createRefreshTokenForUserId","logoutUserId","jwtToken","deleteRefreshTokenByUserId","length","createdAt","Date","now","jwtExpiresIn","getCredentialSettings","keys","Object","key","err","error","logoutUserRefreshToken","userRefreshToken","getValidRefreshToken","renewLoginByRefreshToken","InvalidOrExpiredRefreshToken","user","getUser","deleteRefreshToken","increaseRefreshTokenAttemptsUsed","isJwtTokenBlacklisted","throwNotFoundError","getRefreshToken","expiresAt","refreshTokenAttempts","attemptsUsed","refreshAttemptsUsed","updateRefreshTokenAttempts","needsPasswordChange","PasswordChangeRequired","isVerified","AccountNotVerified"],"mappings":"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"}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
@@ -12,6 +12,7 @@ const _models = require("../../models");
|
|
|
12
12
|
const _uuid = require("uuid");
|
|
13
13
|
const _serverconstants = require("../../server.constants");
|
|
14
14
|
const _runtimeexceptions = require("../../exceptions/runtime.exceptions");
|
|
15
|
+
const _authorizationconstants = require("../../constants/authorization.constants");
|
|
15
16
|
class RefreshTokenService {
|
|
16
17
|
settingsStore;
|
|
17
18
|
logger;
|
|
@@ -25,7 +26,7 @@ class RefreshTokenService {
|
|
|
25
26
|
});
|
|
26
27
|
if (!userRefreshToken) {
|
|
27
28
|
if (throwNotFoundError) {
|
|
28
|
-
throw new _runtimeexceptions.AuthenticationError("The refresh token was not found");
|
|
29
|
+
throw new _runtimeexceptions.AuthenticationError("The refresh token was not found", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
|
|
29
30
|
}
|
|
30
31
|
return null;
|
|
31
32
|
}
|
|
@@ -34,20 +35,20 @@ class RefreshTokenService {
|
|
|
34
35
|
async createRefreshTokenForUserId(userId) {
|
|
35
36
|
const { refreshTokenExpiry } = await this.settingsStore.getCredentialSettings();
|
|
36
37
|
const refreshToken = (0, _uuid.v4)();
|
|
38
|
+
const timespan = refreshTokenExpiry ?? _serverconstants.AppConstants.DEFAULT_REFRESH_TOKEN_EXPIRY;
|
|
37
39
|
if (!refreshTokenExpiry) {
|
|
38
|
-
this.logger.warn(
|
|
40
|
+
this.logger.warn(`Refresh token expiry not set in Settings:credentials, using default ${timespan} seconds}`);
|
|
39
41
|
}
|
|
40
|
-
const timespan = refreshTokenExpiry ?? _serverconstants.AppConstants.DEFAULT_REFRESH_TOKEN_EXPIRY;
|
|
41
42
|
await _models.RefreshToken.create({
|
|
42
43
|
userId,
|
|
43
|
-
expiresAt: Date.now() + timespan,
|
|
44
|
+
expiresAt: Date.now() + timespan * 1000,
|
|
44
45
|
refreshToken,
|
|
45
46
|
refreshAttemptsUsed: 0
|
|
46
47
|
});
|
|
47
48
|
return refreshToken;
|
|
48
49
|
}
|
|
49
50
|
async updateRefreshTokenAttempts(refreshToken, refreshAttemptsUsed) {
|
|
50
|
-
await this.getRefreshToken(refreshToken);
|
|
51
|
+
await this.getRefreshToken(refreshToken, true);
|
|
51
52
|
await _models.RefreshToken.updateOne({
|
|
52
53
|
refreshToken
|
|
53
54
|
}, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/authentication/refresh-token.service.ts"],"names":["RefreshTokenService","settingsStore","logger","constructor","loggerFactory","name","getRefreshToken","refreshToken","throwNotFoundError","userRefreshToken","RefreshToken","findOne","AuthenticationError","createRefreshTokenForUserId","userId","refreshTokenExpiry","getCredentialSettings","uuidv4","
|
|
1
|
+
{"version":3,"sources":["../../../src/services/authentication/refresh-token.service.ts"],"names":["RefreshTokenService","settingsStore","logger","constructor","loggerFactory","name","getRefreshToken","refreshToken","throwNotFoundError","userRefreshToken","RefreshToken","findOne","AuthenticationError","AUTH_ERROR_REASON","InvalidOrExpiredRefreshToken","createRefreshTokenForUserId","userId","refreshTokenExpiry","getCredentialSettings","uuidv4","timespan","AppConstants","DEFAULT_REFRESH_TOKEN_EXPIRY","warn","create","expiresAt","Date","now","refreshAttemptsUsed","updateRefreshTokenAttempts","updateOne","new","purgeOutdatedRefreshTokensByUserId","result","deleteMany","$lt","deletedCount","debug","purgeAllOutdatedRefreshTokens","deleteRefreshTokenByUserId","deleteRefreshToken","deleteOne"],"mappings":";;;;+BAYaA;;;eAAAA;;;wBAVgB;sBACA;iCACA;mCAIO;wCAEF;AAE3B,MAAMA;IACHC,cAA6B;IAC7BC,OAAsB;IAE9BC,YAAY,EAAEC,aAAa,EAAEH,aAAa,EAAmE,CAAE;QAC7G,IAAI,CAACC,MAAM,GAAGE,cAAcJ,oBAAoBK,IAAI;QACpD,IAAI,CAACJ,aAAa,GAAGA;IACvB;IAEA,MAAMK,gBAAgBC,YAAoB,EAAEC,qBAAqB,IAAI,EAAiC;QACpG,MAAMC,mBAAmB,MAAMC,oBAAY,CAACC,OAAO,CAAC;YAClDJ;QACF;QACA,IAAI,CAACE,kBAAkB;YACrB,IAAID,oBAAoB;gBACtB,MAAM,IAAII,sCAAmB,CAAC,mCAAmCC,yCAAiB,CAACC,4BAA4B;YACjH;YACA,OAAO;QACT;QACA,OAAOL;IACT;IAEA,MAAMM,4BAA4BC,MAAmB,EAAmB;QACtE,MAAM,EAAEC,kBAAkB,EAAE,GAAG,MAAM,IAAI,CAAChB,aAAa,CAACiB,qBAAqB;QAC7E,MAAMX,eAAeY,IAAAA,QAAM;QAE3B,MAAMC,WAAWH,sBAAsBI,6BAAY,CAACC,4BAA4B;QAChF,IAAI,CAACL,oBAAoB;YACvB,IAAI,CAACf,MAAM,CAACqB,IAAI,CAAC,CAAC,oEAAoE,EAAEH,SAAS,SAAS,CAAC;QAC7G;QAEA,MAAMV,oBAAY,CAACc,MAAM,CAAC;YACxBR;YACAS,WAAWC,KAAKC,GAAG,KAAKP,WAAW;YACnCb;YACAqB,qBAAqB;QACvB;QAEA,OAAOrB;IACT;IAEA,MAAMsB,2BAA2BtB,YAAoB,EAAEqB,mBAA2B,EAAE;QAClF,MAAM,IAAI,CAACtB,eAAe,CAACC,cAAc;QAEzC,MAAMG,oBAAY,CAACoB,SAAS,CAC1B;YACEvB;QACF,GACA;YACEqB;QACF,GACA;YACEG,KAAK;QACP;IAEJ;IAEA,MAAMC,mCAAmChB,MAAmB,EAAE;QAC5D,MAAMiB,SAAS,MAAMvB,oBAAY,CAACwB,UAAU,CAAC;YAC3ClB;YACAS,WAAW;gBACTU,KAAKT,KAAKC,GAAG;YACf;QACF;QAEA,IAAIM,OAAOG,YAAY,EAAE;YACvB,IAAI,CAAClC,MAAM,CAACmC,KAAK,CAAC,CAAC,QAAQ,EAAEJ,OAAOG,YAAY,CAAC,wCAAwC,EAAEpB,OAAO,CAAC;QACrG;IACF;IAEA,MAAMsB,gCAAgC;QACpC,MAAML,SAAS,MAAMvB,oBAAY,CAACwB,UAAU,CAAC;YAC3CT,WAAW;gBACTU,KAAKT,KAAKC,GAAG;YACf;QACF;QAEA,IAAIM,OAAOG,YAAY,EAAE;YACvB,IAAI,CAAClC,MAAM,CAACmC,KAAK,CAAC,CAAC,QAAQ,EAAEJ,OAAOG,YAAY,CAAC,8BAA8B,CAAC;QAClF;IACF;IAEA,MAAMG,2BAA2BvB,MAAmB,EAAiB;QACnE,MAAMiB,SAAS,MAAMvB,oBAAY,CAACwB,UAAU,CAAC;YAC3ClB;QACF;QAEA,IAAIiB,OAAOG,YAAY,EAAE;YACvB,IAAI,CAAClC,MAAM,CAACmC,KAAK,CAAC,CAAC,QAAQ,EAAEJ,OAAOG,YAAY,CAAC,qBAAqB,CAAC;QACzE;IACF;IAEA,MAAMI,mBAAmBjC,YAAoB,EAAiB;QAC5D,MAAM0B,SAAS,MAAMvB,oBAAY,CAAC+B,SAAS,CAAC;YAC1ClC;QACF;QAEA,oBAAoB;QACpB,IAAI0B,OAAOG,YAAY,EAAE;YACvB,IAAI,CAAClC,MAAM,CAACmC,KAAK,CAAC,CAAC,QAAQ,EAAEJ,OAAOG,YAAY,CAAC,qBAAqB,CAAC;QACzE;IACF;AACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/authentication/role.service.ts"],"names":["RoleService","logger","settingsStore","appDefaultRole","appDefaultRoleNoLogin","constructor","loggerFactory","name","_roles","roles","getAppDefaultRole","getLoginRequired","getRolesPermissions","permissions","length","
|
|
1
|
+
{"version":3,"sources":["../../../src/services/authentication/role.service.ts"],"names":["RoleService","logger","settingsStore","appDefaultRole","appDefaultRoleNoLogin","constructor","loggerFactory","name","_roles","toDto","role","id","roles","getAppDefaultRole","getLoginRequired","getRolesPermissions","permissions","length","normalizedRole","normalizeRoleIdOrName","rolePermissions","getRolePermissions","union","ROLE_PERMS","getAppDefaultRoleIds","syncRoles","guestRole","getRoleByName","getSynchronizedRoleByName","roleName","authorizeRole","requiredRole","assignedRoles","find","ar","authorizeRoles","requiredRoles","subset","isAuthorized","forEach","rr","result","r","NotFoundException","getManyRoles","roleIds","map","roleId","getRole","Object","values","ROLES","storedRole","Role","findOne","newRole","create","push","assignedRole","roleInstance","console","warn"],"mappings":"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"}
|
|
@@ -34,7 +34,7 @@ class UserService {
|
|
|
34
34
|
async listUsers(limit = 10) {
|
|
35
35
|
return _models.User.find().limit(limit);
|
|
36
36
|
}
|
|
37
|
-
async
|
|
37
|
+
async findUsersByRoleId(roleId) {
|
|
38
38
|
return _models.User.find({
|
|
39
39
|
roles: {
|
|
40
40
|
$in: [
|
|
@@ -43,6 +43,19 @@ class UserService {
|
|
|
43
43
|
}
|
|
44
44
|
});
|
|
45
45
|
}
|
|
46
|
+
async findVerifiedUsers() {
|
|
47
|
+
return _models.User.find({
|
|
48
|
+
isVerified: true
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
async isUserRootUser(userId) {
|
|
52
|
+
return (await _models.User.findById(userId))?.isRootUser;
|
|
53
|
+
}
|
|
54
|
+
async findRootUsers() {
|
|
55
|
+
return _models.User.find({
|
|
56
|
+
isRootUser: true
|
|
57
|
+
});
|
|
58
|
+
}
|
|
46
59
|
async getDemoUserId() {
|
|
47
60
|
return (await _models.User.findOne({
|
|
48
61
|
isDemoUser: true
|
|
@@ -53,12 +66,12 @@ class UserService {
|
|
|
53
66
|
username
|
|
54
67
|
});
|
|
55
68
|
}
|
|
56
|
-
async getUser(userId) {
|
|
69
|
+
async getUser(userId, throwNotFoundError = true) {
|
|
57
70
|
const user = await _models.User.findById(userId);
|
|
58
|
-
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
71
|
+
if (!user && throwNotFoundError) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
59
72
|
return user;
|
|
60
73
|
}
|
|
61
|
-
async
|
|
74
|
+
async getUserRoleIds(userId) {
|
|
62
75
|
const user = await this.getUser(userId);
|
|
63
76
|
return user.roles?.map((r)=>r.toString());
|
|
64
77
|
}
|
|
@@ -73,10 +86,13 @@ class UserService {
|
|
|
73
86
|
async deleteUser(userId) {
|
|
74
87
|
// Validate
|
|
75
88
|
const user = await this.getUser(userId);
|
|
89
|
+
if (user.isRootUser) {
|
|
90
|
+
throw new _runtimeexceptions.InternalServerException("Cannot delete a root user.");
|
|
91
|
+
}
|
|
76
92
|
// Check if the user is the last admin
|
|
77
93
|
const role = this.roleService.getRoleByName(_authorizationconstants.ROLES.ADMIN);
|
|
78
94
|
if (user.roles.includes(role.id)) {
|
|
79
|
-
const administrators = await this.
|
|
95
|
+
const administrators = await this.findUsersByRoleId(role.id);
|
|
80
96
|
if (administrators?.length === 1) {
|
|
81
97
|
throw new _runtimeexceptions.InternalServerException("Cannot delete the last user with ADMIN role.");
|
|
82
98
|
}
|
|
@@ -102,7 +118,7 @@ class UserService {
|
|
|
102
118
|
user.needsPasswordChange = false;
|
|
103
119
|
return await user.save();
|
|
104
120
|
}
|
|
105
|
-
async
|
|
121
|
+
async updatePasswordUnsafeByUsername(username, newPassword) {
|
|
106
122
|
const { password } = await (0, _validators.validateInput)({
|
|
107
123
|
password: newPassword
|
|
108
124
|
}, _userservicevalidation.newPasswordRules);
|
|
@@ -117,9 +133,10 @@ class UserService {
|
|
|
117
133
|
const user = await _models.User.findById(userId);
|
|
118
134
|
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
119
135
|
if (!isRootUser) {
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
136
|
+
// Ensure at least one user is root user
|
|
137
|
+
const rootUsers = await this.findRootUsers();
|
|
138
|
+
if (rootUsers.length === 1) {
|
|
139
|
+
throw new _runtimeexceptions.InternalServerException("Cannot set the last root user to non-root user.");
|
|
123
140
|
}
|
|
124
141
|
}
|
|
125
142
|
user.isRootUser = isRootUser;
|
|
@@ -129,21 +146,26 @@ class UserService {
|
|
|
129
146
|
const user = await _models.User.findById(userId);
|
|
130
147
|
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
131
148
|
if (!isVerified) {
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
149
|
+
if (user.isRootUser) {
|
|
150
|
+
throw new _runtimeexceptions.InternalServerException("Cannot set a owner (root user) to unverified.");
|
|
151
|
+
}
|
|
152
|
+
// Ensure at least one user is verified
|
|
153
|
+
const verifiedUsers = await this.findVerifiedUsers();
|
|
154
|
+
if (verifiedUsers.length === 1) {
|
|
155
|
+
throw new _runtimeexceptions.InternalServerException("Cannot set the last user to unverified.");
|
|
135
156
|
}
|
|
136
157
|
}
|
|
137
158
|
user.isVerified = isVerified;
|
|
138
159
|
await user.save();
|
|
139
160
|
}
|
|
140
161
|
async register(input) {
|
|
141
|
-
const { username, password, roles, isDemoUser, isRootUser, needsPasswordChange } = await (0, _validators.validateInput)(input, _userservicevalidation.registerUserRules);
|
|
162
|
+
const { username, password, roles, isDemoUser, isRootUser, needsPasswordChange, isVerified } = await (0, _validators.validateInput)(input, _userservicevalidation.registerUserRules);
|
|
142
163
|
const passwordHash = (0, _cryptoutils.hashPassword)(password);
|
|
143
164
|
return await _models.User.create({
|
|
144
165
|
username,
|
|
145
166
|
passwordHash,
|
|
146
167
|
roles,
|
|
168
|
+
isVerified: isVerified ?? false,
|
|
147
169
|
isDemoUser: isDemoUser ?? false,
|
|
148
170
|
isRootUser: isRootUser ?? false,
|
|
149
171
|
needsPasswordChange: needsPasswordChange ?? true
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/authentication/user.service.ts"],"names":["UserService","roleService","constructor","toDto","user","id","createdAt","isVerified","isDemoUser","isRootUser","username","needsPasswordChange","roles","map","r","toString","listUsers","limit","User","find","
|
|
1
|
+
{"version":3,"sources":["../../../src/services/authentication/user.service.ts"],"names":["UserService","roleService","constructor","toDto","user","id","createdAt","isVerified","isDemoUser","isRootUser","username","needsPasswordChange","roles","map","r","toString","listUsers","limit","User","find","findUsersByRoleId","roleId","$in","findVerifiedUsers","isUserRootUser","userId","findById","findRootUsers","getDemoUserId","findOne","findRawByUsername","getUser","throwNotFoundError","NotFoundException","getUserRoleIds","setUserRoleIds","roleIds","getManyRoles","Array","from","Set","save","deleteUser","InternalServerException","role","getRoleByName","ROLES","ADMIN","includes","administrators","length","findByIdAndDelete","updateUsernameById","newUsername","updatePasswordById","oldPassword","newPassword","comparePasswordHash","passwordHash","password","validateInput","newPasswordRules","hashPassword","updatePasswordUnsafeByUsername","setIsRootUserById","rootUsers","setVerifiedById","verifiedUsers","register","input","registerUserRules","create"],"mappings":"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"}
|
|
File without changes
|
|
File without changes
|
|
@@ -15,20 +15,7 @@ const _runtimeexceptions = require("../exceptions/runtime.exceptions");
|
|
|
15
15
|
const createCameraStreamRules = {
|
|
16
16
|
printerId: "mongoId",
|
|
17
17
|
streamURL: "required|httpurl",
|
|
18
|
-
|
|
19
|
-
"settings.aspectRatio": [
|
|
20
|
-
"required",
|
|
21
|
-
"string",
|
|
22
|
-
[
|
|
23
|
-
"in",
|
|
24
|
-
"16:9",
|
|
25
|
-
"4:3",
|
|
26
|
-
"1:1"
|
|
27
|
-
]
|
|
28
|
-
],
|
|
29
|
-
"settings.rotationClockwise": "required|integer|in:0,90,180,270",
|
|
30
|
-
"settings.flipHorizontal": "required|boolean",
|
|
31
|
-
"settings.flipVertical": "required|boolean"
|
|
18
|
+
name: "required|string"
|
|
32
19
|
};
|
|
33
20
|
class CameraStreamService {
|
|
34
21
|
model = _models.CameraStream;
|
|
@@ -72,7 +59,7 @@ class CameraStreamService {
|
|
|
72
59
|
id: entity.id,
|
|
73
60
|
streamURL: entity.streamURL,
|
|
74
61
|
printerId: entity.printerId === null ? null : entity.printerId?.toString(),
|
|
75
|
-
|
|
62
|
+
name: entity.name
|
|
76
63
|
};
|
|
77
64
|
}
|
|
78
65
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/camera-stream.service.ts"],"names":["CameraStreamService","createCameraStreamRules","printerId","streamURL","
|
|
1
|
+
{"version":3,"sources":["../../src/services/camera-stream.service.ts"],"names":["CameraStreamService","createCameraStreamRules","printerId","streamURL","name","model","CameraStream","printerCache","constructor","list","find","get","id","throwError","cameraStream","findById","NotFoundException","create","data","input","validateInput","getCachedPrinterOrThrow","delete","findByIdAndDelete","update","updateInput","updateOne","toDto","entity","toString"],"mappings":";;;;+BAgBaA;;;eAAAA;;;wBAhBgB;4BACC;mCACI;AAOlC,gDAAgD;AAChD,MAAMC,0BAA0B;IAC9BC,WAAW;IACXC,WAAW;IACXC,MAAM;AACR;AAEO,MAAMJ;IACXK,QAAQC,oBAAY,CAAC;IACrBC,aAA2B;IAE3BC,YAAY,EAAED,YAAY,EAAkC,CAAE;QAC5D,IAAI,CAACA,YAAY,GAAGA;IACtB;IAEA,MAAME,OAAO;QACX,OAAO,IAAI,CAACJ,KAAK,CAACK,IAAI;IACxB;IAEA,MAAMC,IAAIC,EAAe,EAAEC,aAAa,IAAI,EAAE;QAC5C,MAAMC,eAAe,MAAM,IAAI,CAACT,KAAK,CAACU,QAAQ,CAACH;QAC/C,IAAI,CAACE,gBAAgBD,YAAY;YAC/B,MAAM,IAAIG,oCAAiB,CAAC,CAAC,cAAc,EAAEJ,GAAG,gBAAgB,CAAC,EAAE;QACrE;QAEA,OAAOE;IACT;IAEA,MAAMG,OAAOC,IAAwC,EAAE;QACrD,MAAMC,QAAQ,MAAMC,IAAAA,yBAAa,EAACF,MAAMjB;QACxC,IAAIkB,MAAMjB,SAAS,EAAE;YACnB,MAAM,IAAI,CAACK,YAAY,CAACc,uBAAuB,CAACF,MAAMjB,SAAS;QACjE;QACA,OAAO,IAAI,CAACG,KAAK,CAACY,MAAM,CAACE;IAC3B;IAEA,MAAMG,OAAOV,EAAe,EAAE;QAC5B,OAAO,IAAI,CAACP,KAAK,CAACkB,iBAAiB,CAACX;IACtC;IAEA,MAAMY,OAAOZ,EAAe,EAAEO,KAAyC,EAAE;QACvE,MAAM,IAAI,CAACR,GAAG,CAACC;QACf,MAAMa,cAAc,MAAML,IAAAA,yBAAa,EAACD,OAAOlB;QAC/C,IAAIkB,MAAMjB,SAAS,EAAE;YACnB,MAAM,IAAI,CAACK,YAAY,CAACc,uBAAuB,CAACF,MAAMjB,SAAS;QACjE;QACA,MAAM,IAAI,CAACG,KAAK,CAACqB,SAAS,CAAC;YAAEd;QAAG,GAAGa;QACnC,OAAO,IAAI,CAACd,GAAG,CAACC;IAClB;IAEAe,MAAMC,MAAqB,EAAgC;QACzD,OAAO;YACLhB,IAAIgB,OAAOhB,EAAE;YACbT,WAAWyB,OAAOzB,SAAS;YAC3BD,WAAW0B,OAAO1B,SAAS,KAAK,OAAO,OAAO0B,OAAO1B,SAAS,EAAE2B;YAChEzB,MAAMwB,OAAOxB,IAAI;QACnB;IACF;AACF"}
|
|
File without changes
|
|
File without changes
|
|
@@ -8,6 +8,7 @@ Object.defineProperty(exports, "ConfigService", {
|
|
|
8
8
|
return ConfigService;
|
|
9
9
|
}
|
|
10
10
|
});
|
|
11
|
+
const _serverconstants = require("../../server.constants");
|
|
11
12
|
class ConfigService {
|
|
12
13
|
get(key, defaultValue) {
|
|
13
14
|
if (!Object.keys(process.env).includes(key) || !process.env[key]?.length) {
|
|
@@ -21,6 +22,9 @@ class ConfigService {
|
|
|
21
22
|
throw Error(`Environment variable with key ${key} was not defined.`);
|
|
22
23
|
}
|
|
23
24
|
}
|
|
25
|
+
isDemoMode() {
|
|
26
|
+
return this.get(_serverconstants.AppConstants.OVERRIDE_IS_DEMO_MODE, "false") === "true";
|
|
27
|
+
}
|
|
24
28
|
}
|
|
25
29
|
|
|
26
30
|
//# sourceMappingURL=config.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/core/config.service.ts"],"names":["ConfigService","get","key","defaultValue","Object","keys","process","env","includes","length","getOrThrow","val","Error"],"mappings":";;;;+
|
|
1
|
+
{"version":3,"sources":["../../../src/services/core/config.service.ts"],"names":["ConfigService","get","key","defaultValue","Object","keys","process","env","includes","length","getOrThrow","val","Error","isDemoMode","AppConstants","OVERRIDE_IS_DEMO_MODE"],"mappings":";;;;+BAUaA;;;eAAAA;;;iCAVgB;AAUtB,MAAMA;IACXC,IAAIC,GAAW,EAAEC,YAAqB,EAAE;QACtC,IAAI,CAACC,OAAOC,IAAI,CAACC,QAAQC,GAAG,EAAEC,QAAQ,CAACN,QAAQ,CAACI,QAAQC,GAAG,CAACL,IAAI,EAAEO,QAAQ;YACxE,OAAON;QACT;QACA,OAAOG,QAAQC,GAAG,CAACL,IAAI;IACzB;IAEAQ,WAAWR,GAAW,EAAE;QACtB,MAAMS,MAAM,IAAI,CAACV,GAAG,CAACC;QACrB,IAAI,CAACS,KAAK;YACR,MAAMC,MAAM,CAAC,8BAA8B,EAAEV,IAAI,iBAAiB,CAAC;QACrE;IACF;IAEAW,aAAa;QACX,OAAO,IAAI,CAACZ,GAAG,CAACa,6BAAY,CAACC,qBAAqB,EAAE,aAAa;IACnE;AACF"}
|
|
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
|
|
File without changes
|
|
File without changes
|
|
File without changes
|