@fdm-monster/server 1.5.0-rc1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env +19 -0
- package/.env.template +43 -0
- package/.gitattributes +1 -0
- package/.idea/codeStyles/Project.xml +85 -0
- package/.idea/codeStyles/codeStyleConfig.xml +5 -0
- package/.idea/dbnavigator.xml +574 -0
- package/.idea/fdm-monster.iml +16 -0
- package/.idea/inspectionProfiles/Project_Default.xml +22 -0
- package/.idea/jsLibraryMappings.xml +6 -0
- package/.idea/modules.xml +12 -0
- package/.idea/prettier.xml +6 -0
- package/.idea/vcs.xml +17 -0
- package/.swcrc +33 -0
- package/CODE_OF_CONDUCT.md +46 -0
- package/CONTRIBUTING.md +134 -0
- package/LICENSE +661 -0
- package/README.md +149 -0
- package/SECURITY.md +16 -0
- package/dist/@type/express/index.d.js +7 -0
- package/dist/@type/express/index.d.js.map +1 -0
- package/dist/constants/authorization.constants.js +99 -0
- package/dist/constants/authorization.constants.js.map +1 -0
- package/dist/constants/event.constants.js +55 -0
- package/dist/constants/event.constants.js.map +1 -0
- package/dist/constants/http-status-codes.constants.js +268 -0
- package/dist/constants/http-status-codes.constants.js.map +1 -0
- package/dist/constants/server-settings.constants.js +119 -0
- package/dist/constants/server-settings.constants.js.map +1 -0
- package/dist/constants/service.constants.js +48 -0
- package/dist/constants/service.constants.js.map +1 -0
- package/dist/container.js +161 -0
- package/dist/container.js.map +1 -0
- package/dist/container.tokens.js +83 -0
- package/dist/container.tokens.js.map +1 -0
- package/dist/controllers/auth.controller.js +143 -0
- package/dist/controllers/auth.controller.js.map +1 -0
- package/dist/controllers/batch-call.controller.js +59 -0
- package/dist/controllers/batch-call.controller.js.map +1 -0
- package/dist/controllers/camera-stream.controller.js +57 -0
- package/dist/controllers/camera-stream.controller.js.map +1 -0
- package/dist/controllers/custom-gcode.controller.js +76 -0
- package/dist/controllers/custom-gcode.controller.js.map +1 -0
- package/dist/controllers/first-time-setup.controller.js +65 -0
- package/dist/controllers/first-time-setup.controller.js.map +1 -0
- package/dist/controllers/floor.controller.js +78 -0
- package/dist/controllers/floor.controller.js.map +1 -0
- package/dist/controllers/plugin-firmware-update.controller.js +140 -0
- package/dist/controllers/plugin-firmware-update.controller.js.map +1 -0
- package/dist/controllers/print-completion.controller.js +58 -0
- package/dist/controllers/print-completion.controller.js.map +1 -0
- package/dist/controllers/printer-files.controller.js +208 -0
- package/dist/controllers/printer-files.controller.js.map +1 -0
- package/dist/controllers/printer-settings.controller.js +58 -0
- package/dist/controllers/printer-settings.controller.js.map +1 -0
- package/dist/controllers/printer.controller.js +287 -0
- package/dist/controllers/printer.controller.js.map +1 -0
- package/dist/controllers/server-private.controller.js +122 -0
- package/dist/controllers/server-private.controller.js.map +1 -0
- package/dist/controllers/server-public.controller.js +140 -0
- package/dist/controllers/server-public.controller.js.map +1 -0
- package/dist/controllers/settings.controller.js +89 -0
- package/dist/controllers/settings.controller.js.map +1 -0
- package/dist/controllers/user.controller.js +137 -0
- package/dist/controllers/user.controller.js.map +1 -0
- package/dist/controllers/validation/auth-controller.validation.js +15 -0
- package/dist/controllers/validation/auth-controller.validation.js.map +1 -0
- package/dist/controllers/validation/batch-controller.validation.js +29 -0
- package/dist/controllers/validation/batch-controller.validation.js.map +1 -0
- package/dist/controllers/validation/generic.validation.js +15 -0
- package/dist/controllers/validation/generic.validation.js.map +1 -0
- package/dist/controllers/validation/printer-controller.validation.js +66 -0
- package/dist/controllers/validation/printer-controller.validation.js.map +1 -0
- package/dist/controllers/validation/printer-files-controller.validation.js +66 -0
- package/dist/controllers/validation/printer-files-controller.validation.js.map +1 -0
- package/dist/controllers/validation/printer-settings-controller.validation.js +15 -0
- package/dist/controllers/validation/printer-settings-controller.validation.js.map +1 -0
- package/dist/controllers/validation/setting.validation.js +19 -0
- package/dist/controllers/validation/setting.validation.js.map +1 -0
- package/dist/controllers/validation/user-controller.validation.js +16 -0
- package/dist/controllers/validation/user-controller.validation.js.map +1 -0
- package/dist/exceptions/job.exceptions.js +18 -0
- package/dist/exceptions/job.exceptions.js.map +1 -0
- package/dist/exceptions/runtime.exceptions.js +108 -0
- package/dist/exceptions/runtime.exceptions.js.map +1 -0
- package/dist/handlers/cache-manager.js +25 -0
- package/dist/handlers/cache-manager.js.map +1 -0
- package/dist/handlers/event-emitter.js +31 -0
- package/dist/handlers/event-emitter.js.map +1 -0
- package/dist/handlers/logger-factory.js +18 -0
- package/dist/handlers/logger-factory.js.map +1 -0
- package/dist/handlers/logger.js +85 -0
- package/dist/handlers/logger.js.map +1 -0
- package/dist/handlers/validators.js +131 -0
- package/dist/handlers/validators.js.map +1 -0
- package/dist/index.js +19 -0
- package/dist/index.js.map +1 -0
- package/dist/middleware/authenticate.js +83 -0
- package/dist/middleware/authenticate.js.map +1 -0
- package/dist/middleware/database.js +26 -0
- package/dist/middleware/database.js.map +1 -0
- package/dist/middleware/exception.handler.js +96 -0
- package/dist/middleware/exception.handler.js.map +1 -0
- package/dist/middleware/global.middleware.js +58 -0
- package/dist/middleware/global.middleware.js.map +1 -0
- package/dist/middleware/passport.js +44 -0
- package/dist/middleware/passport.js.map +1 -0
- package/dist/middleware/printer.js +49 -0
- package/dist/middleware/printer.js.map +1 -0
- package/dist/migrations/1696187882312-PrinterFile.js +40 -0
- package/dist/migrations/1696187882312-PrinterFile.js.map +1 -0
- package/dist/models/Auth/Permission.js +20 -0
- package/dist/models/Auth/Permission.js.map +1 -0
- package/dist/models/Auth/RefreshToken.js +41 -0
- package/dist/models/Auth/RefreshToken.js.map +1 -0
- package/dist/models/Auth/Role.js +20 -0
- package/dist/models/Auth/Role.js.map +1 -0
- package/dist/models/Auth/User.js +51 -0
- package/dist/models/Auth/User.js.map +1 -0
- package/dist/models/CameraStream.js +59 -0
- package/dist/models/CameraStream.js.map +1 -0
- package/dist/models/CustomGcode.js +28 -0
- package/dist/models/CustomGcode.js.map +1 -0
- package/dist/models/Floor.js +33 -0
- package/dist/models/Floor.js.map +1 -0
- package/dist/models/FloorPrinter.js +29 -0
- package/dist/models/FloorPrinter.js.map +1 -0
- package/dist/models/PrintCompletion.js +40 -0
- package/dist/models/PrintCompletion.js.map +1 -0
- package/dist/models/Printer.js +113 -0
- package/dist/models/Printer.js.map +1 -0
- package/dist/models/ServerSettings.js +168 -0
- package/dist/models/ServerSettings.js.map +1 -0
- package/dist/models/Settings.js +168 -0
- package/dist/models/Settings.js.map +1 -0
- package/dist/models/index.js +54 -0
- package/dist/models/index.js.map +1 -0
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js +49 -0
- package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js.map +1 -0
- package/dist/mongo-migrations/20210907173950-printers-enabled.js +39 -0
- package/dist/mongo-migrations/20210907173950-printers-enabled.js.map +1 -0
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js +39 -0
- package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js.map +1 -0
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js +60 -0
- package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js.map +1 -0
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js +30 -0
- package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js.map +1 -0
- package/dist/mongo-migrations/20230716065316-user-remove-name.js +30 -0
- package/dist/mongo-migrations/20230716065316-user-remove-name.js.map +1 -0
- package/dist/nodemon_restart_trigger.js +4 -0
- package/dist/nodemon_restart_trigger.js.map +1 -0
- package/dist/server.constants.js +99 -0
- package/dist/server.constants.js.map +1 -0
- package/dist/server.core.js +91 -0
- package/dist/server.core.js.map +1 -0
- package/dist/server.env.js +225 -0
- package/dist/server.env.js.map +1 -0
- package/dist/server.host.js +106 -0
- package/dist/server.host.js.map +1 -0
- package/dist/services/authentication/auth.service.js +136 -0
- package/dist/services/authentication/auth.service.js.map +1 -0
- package/dist/services/authentication/jwt.service.js +34 -0
- package/dist/services/authentication/jwt.service.js.map +1 -0
- package/dist/services/authentication/permission.service.js +73 -0
- package/dist/services/authentication/permission.service.js.map +1 -0
- package/dist/services/authentication/refresh-token.service.js +99 -0
- package/dist/services/authentication/refresh-token.service.js.map +1 -0
- package/dist/services/authentication/role.service.js +120 -0
- package/dist/services/authentication/role.service.js.map +1 -0
- package/dist/services/authentication/user.service.js +154 -0
- package/dist/services/authentication/user.service.js.map +1 -0
- package/dist/services/batch-call.service.js +148 -0
- package/dist/services/batch-call.service.js.map +1 -0
- package/dist/services/camera-stream.service.js +80 -0
- package/dist/services/camera-stream.service.js.map +1 -0
- package/dist/services/core/client-bundle.service.js +156 -0
- package/dist/services/core/client-bundle.service.js.map +1 -0
- package/dist/services/core/config.service.js +26 -0
- package/dist/services/core/config.service.js.map +1 -0
- package/dist/services/core/github.service.js +74 -0
- package/dist/services/core/github.service.js.map +1 -0
- package/dist/services/core/logs-manager.service.js +87 -0
- package/dist/services/core/logs-manager.service.js.map +1 -0
- package/dist/services/core/monsterpi.service.js +38 -0
- package/dist/services/core/monsterpi.service.js.map +1 -0
- package/dist/services/core/multer.service.js +122 -0
- package/dist/services/core/multer.service.js.map +1 -0
- package/dist/services/core/server-release.service.js +116 -0
- package/dist/services/core/server-release.service.js.map +1 -0
- package/dist/services/core/server-update.service.js +73 -0
- package/dist/services/core/server-update.service.js.map +1 -0
- package/dist/services/core/task-manager.service.js +196 -0
- package/dist/services/core/task-manager.service.js.map +1 -0
- package/dist/services/core/yaml.service.js +278 -0
- package/dist/services/core/yaml.service.js.map +1 -0
- package/dist/services/custom-gcode.service.js +48 -0
- package/dist/services/custom-gcode.service.js.map +1 -0
- package/dist/services/floor.service.js +183 -0
- package/dist/services/floor.service.js.map +1 -0
- package/dist/services/influxdb-v2/influx-db-v2-base.service.js +45 -0
- package/dist/services/influxdb-v2/influx-db-v2-base.service.js.map +1 -0
- package/dist/services/interfaces/auth.service.interface.js +6 -0
- package/dist/services/interfaces/auth.service.interface.js.map +1 -0
- package/dist/services/interfaces/camera-stream.dto.js +109 -0
- package/dist/services/interfaces/camera-stream.dto.js.map +1 -0
- package/dist/services/interfaces/camera-stream.service.interface.js +6 -0
- package/dist/services/interfaces/camera-stream.service.interface.js.map +1 -0
- package/dist/services/interfaces/custom-gcode.dto.js +18 -0
- package/dist/services/interfaces/custom-gcode.dto.js.map +1 -0
- package/dist/services/interfaces/custom-gcode.service.interface.js +6 -0
- package/dist/services/interfaces/custom-gcode.service.interface.js.map +1 -0
- package/dist/services/interfaces/floor.dto.js +61 -0
- package/dist/services/interfaces/floor.dto.js.map +1 -0
- package/dist/services/interfaces/floor.service.interface.js +6 -0
- package/dist/services/interfaces/floor.service.interface.js.map +1 -0
- package/dist/services/interfaces/gcode-analysis.dto.js +6 -0
- package/dist/services/interfaces/gcode-analysis.dto.js.map +1 -0
- package/dist/services/interfaces/jwt.service.interface.js +6 -0
- package/dist/services/interfaces/jwt.service.interface.js.map +1 -0
- package/dist/services/interfaces/login.dto.js +16 -0
- package/dist/services/interfaces/login.dto.js.map +1 -0
- package/dist/services/interfaces/page.interface.js +16 -0
- package/dist/services/interfaces/page.interface.js.map +1 -0
- package/dist/services/interfaces/permission.dto.js +16 -0
- package/dist/services/interfaces/permission.dto.js.map +1 -0
- package/dist/services/interfaces/permission.service.interface.js +6 -0
- package/dist/services/interfaces/permission.service.interface.js.map +1 -0
- package/dist/services/interfaces/printer-file.dto.js +27 -0
- package/dist/services/interfaces/printer-file.dto.js.map +1 -0
- package/dist/services/interfaces/printer-files.service.interface.js +6 -0
- package/dist/services/interfaces/printer-files.service.interface.js.map +1 -0
- package/dist/services/interfaces/printer.dto.js +18 -0
- package/dist/services/interfaces/printer.dto.js.map +1 -0
- package/dist/services/interfaces/printer.service.interface.js +6 -0
- package/dist/services/interfaces/printer.service.interface.js.map +1 -0
- package/dist/services/interfaces/role-service.interface.js +6 -0
- package/dist/services/interfaces/role-service.interface.js.map +1 -0
- package/dist/services/interfaces/settings.dto.js +34 -0
- package/dist/services/interfaces/settings.dto.js.map +1 -0
- package/dist/services/interfaces/settings.service.interface.js +6 -0
- package/dist/services/interfaces/settings.service.interface.js.map +1 -0
- package/dist/services/interfaces/user-service.interface.js +6 -0
- package/dist/services/interfaces/user-service.interface.js.map +1 -0
- package/dist/services/interfaces/user.dto.js +39 -0
- package/dist/services/interfaces/user.dto.js.map +1 -0
- package/dist/services/octoprint/constants/firmware-update-settings.constants.js +32 -0
- package/dist/services/octoprint/constants/firmware-update-settings.constants.js.map +1 -0
- package/dist/services/octoprint/constants/octoprint-service.constants.js +101 -0
- package/dist/services/octoprint/constants/octoprint-service.constants.js.map +1 -0
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js +88 -0
- package/dist/services/octoprint/constants/octoprint-websocket.constants.js.map +1 -0
- package/dist/services/octoprint/octoprint-api.routes.js +192 -0
- package/dist/services/octoprint/octoprint-api.routes.js.map +1 -0
- package/dist/services/octoprint/octoprint-api.service.js +402 -0
- package/dist/services/octoprint/octoprint-api.service.js.map +1 -0
- package/dist/services/octoprint/octoprint-sockio.adapter.js +309 -0
- package/dist/services/octoprint/octoprint-sockio.adapter.js.map +1 -0
- package/dist/services/octoprint/plugin-base.service.js +102 -0
- package/dist/services/octoprint/plugin-base.service.js.map +1 -0
- package/dist/services/octoprint/plugin-firmware-update.service.js +104 -0
- package/dist/services/octoprint/plugin-firmware-update.service.js.map +1 -0
- package/dist/services/octoprint/plugin-repository.cache.js +45 -0
- package/dist/services/octoprint/plugin-repository.cache.js.map +1 -0
- package/dist/services/octoprint/socket.factory.js +22 -0
- package/dist/services/octoprint/socket.factory.js.map +1 -0
- package/dist/services/octoprint/utils/api.utils.js +72 -0
- package/dist/services/octoprint/utils/api.utils.js.map +1 -0
- package/dist/services/orm/floor.service.interface.js +73 -0
- package/dist/services/orm/floor.service.interface.js.map +1 -0
- package/dist/services/orm/printer.service.interface.js +6 -0
- package/dist/services/orm/printer.service.interface.js.map +1 -0
- package/dist/services/print-completion.service.js +162 -0
- package/dist/services/print-completion.service.js.map +1 -0
- package/dist/services/printer-files.service.js +91 -0
- package/dist/services/printer-files.service.js.map +1 -0
- package/dist/services/printer.service.js +230 -0
- package/dist/services/printer.service.js.map +1 -0
- package/dist/services/settings.service.js +158 -0
- package/dist/services/settings.service.js.map +1 -0
- package/dist/services/validators/floor-service.validation.js +60 -0
- package/dist/services/validators/floor-service.validation.js.map +1 -0
- package/dist/services/validators/print-completion-service.validation.js +20 -0
- package/dist/services/validators/print-completion-service.validation.js.map +1 -0
- package/dist/services/validators/printer-service.validation.js +48 -0
- package/dist/services/validators/printer-service.validation.js.map +1 -0
- package/dist/services/validators/settings-service.validation.js +71 -0
- package/dist/services/validators/settings-service.validation.js.map +1 -0
- package/dist/services/validators/user-service.validation.js +33 -0
- package/dist/services/validators/user-service.validation.js.map +1 -0
- package/dist/services/validators/yaml-service.validation.js +63 -0
- package/dist/services/validators/yaml-service.validation.js.map +1 -0
- package/dist/services/yaml.service.js +278 -0
- package/dist/services/yaml.service.js.map +1 -0
- package/dist/shared.constants.js +15 -0
- package/dist/shared.constants.js.map +1 -0
- package/dist/state/file-upload-tracker.cache.js +88 -0
- package/dist/state/file-upload-tracker.cache.js.map +1 -0
- package/dist/state/file.cache.js +99 -0
- package/dist/state/file.cache.js.map +1 -0
- package/dist/state/files.store.js +132 -0
- package/dist/state/files.store.js.map +1 -0
- package/dist/state/floor.store.js +99 -0
- package/dist/state/floor.store.js.map +1 -0
- package/dist/state/printer-events.cache.js +97 -0
- package/dist/state/printer-events.cache.js.map +1 -0
- package/dist/state/printer-socket.store.js +217 -0
- package/dist/state/printer-socket.store.js.map +1 -0
- package/dist/state/printer.cache.js +112 -0
- package/dist/state/printer.cache.js.map +1 -0
- package/dist/state/settings.store.js +154 -0
- package/dist/state/settings.store.js.map +1 -0
- package/dist/state/socket-io.gateway.js +66 -0
- package/dist/state/socket-io.gateway.js.map +1 -0
- package/dist/state/test-printer-socket.store.js +91 -0
- package/dist/state/test-printer-socket.store.js.map +1 -0
- package/dist/state/validation/create-test-printer.validation.js +18 -0
- package/dist/state/validation/create-test-printer.validation.js.map +1 -0
- package/dist/task.presets.js +50 -0
- package/dist/task.presets.js.map +1 -0
- package/dist/tasks/boot.task.js +198 -0
- package/dist/tasks/boot.task.js.map +1 -0
- package/dist/tasks/client-bundle.task.js +32 -0
- package/dist/tasks/client-bundle.task.js.map +1 -0
- package/dist/tasks/print-completion.socketio.task.js +85 -0
- package/dist/tasks/print-completion.socketio.task.js.map +1 -0
- package/dist/tasks/printer-file-clean.task.js +72 -0
- package/dist/tasks/printer-file-clean.task.js.map +1 -0
- package/dist/tasks/printer-websocket-restore.task.js +64 -0
- package/dist/tasks/printer-websocket-restore.task.js.map +1 -0
- package/dist/tasks/printer-websocket.task.js +43 -0
- package/dist/tasks/printer-websocket.task.js.map +1 -0
- package/dist/tasks/socketio.task.js +83 -0
- package/dist/tasks/socketio.task.js.map +1 -0
- package/dist/tasks/software-update.task.js +22 -0
- package/dist/tasks/software-update.task.js.map +1 -0
- package/dist/tasks.js +48 -0
- package/dist/tasks.js.map +1 -0
- package/dist/types/express/index.d.js +7 -0
- package/dist/types/express/index.d.js.map +1 -0
- package/dist/utils/array.util.js +27 -0
- package/dist/utils/array.util.js.map +1 -0
- package/dist/utils/benchmark.util.js +39 -0
- package/dist/utils/benchmark.util.js.map +1 -0
- package/dist/utils/cache/key-diff.cache.js +128 -0
- package/dist/utils/cache/key-diff.cache.js.map +1 -0
- package/dist/utils/correlation-token.util.js +15 -0
- package/dist/utils/correlation-token.util.js.map +1 -0
- package/dist/utils/crypto.utils.js +29 -0
- package/dist/utils/crypto.utils.js.map +1 -0
- package/dist/utils/env.utils.js +98 -0
- package/dist/utils/env.utils.js.map +1 -0
- package/dist/utils/error.utils.js +15 -0
- package/dist/utils/error.utils.js.map +1 -0
- package/dist/utils/find-predicate.utils.js +18 -0
- package/dist/utils/find-predicate.utils.js.map +1 -0
- package/dist/utils/fs.utils.js +38 -0
- package/dist/utils/fs.utils.js.map +1 -0
- package/dist/utils/is-docker.js +40 -0
- package/dist/utils/is-docker.js.map +1 -0
- package/dist/utils/mapper.utils.js +33 -0
- package/dist/utils/mapper.utils.js.map +1 -0
- package/dist/utils/metric.utils.js +35 -0
- package/dist/utils/metric.utils.js.map +1 -0
- package/dist/utils/normalize-url.js +245 -0
- package/dist/utils/normalize-url.js.map +1 -0
- package/dist/utils/semver.utils.js +18 -0
- package/dist/utils/semver.utils.js.map +1 -0
- package/dist/utils/time.utils.js +26 -0
- package/dist/utils/time.utils.js.map +1 -0
- package/dist/utils/url.utils.js +33 -0
- package/dist/utils/url.utils.js.map +1 -0
- package/dist/utils/websocket.adapter.js +105 -0
- package/dist/utils/websocket.adapter.js.map +1 -0
- package/migrate-mongo-config.js +45 -0
- package/nodemon_restart_trigger.js +1 -0
- package/package.json +149 -0
- package/src/index.ts +19 -0
- package/tsconfig.json +28 -0
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "RefreshTokenService", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return RefreshTokenService;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _models = require("../../models");
|
|
12
|
+
const _uuid = require("uuid");
|
|
13
|
+
const _serverconstants = require("../../server.constants");
|
|
14
|
+
const _runtimeexceptions = require("../../exceptions/runtime.exceptions");
|
|
15
|
+
class RefreshTokenService {
|
|
16
|
+
settingsStore;
|
|
17
|
+
logger;
|
|
18
|
+
constructor({ loggerFactory, settingsStore }){
|
|
19
|
+
this.logger = loggerFactory(RefreshTokenService.name);
|
|
20
|
+
this.settingsStore = settingsStore;
|
|
21
|
+
}
|
|
22
|
+
async getRefreshToken(refreshToken, throwNotFoundError = true) {
|
|
23
|
+
const userRefreshToken = await _models.RefreshToken.findOne({
|
|
24
|
+
refreshToken
|
|
25
|
+
});
|
|
26
|
+
if (!userRefreshToken) {
|
|
27
|
+
if (throwNotFoundError) {
|
|
28
|
+
throw new _runtimeexceptions.AuthenticationError("The refresh token was not found");
|
|
29
|
+
}
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
return userRefreshToken;
|
|
33
|
+
}
|
|
34
|
+
async createRefreshTokenForUserId(userId) {
|
|
35
|
+
const { refreshTokenExpiry } = await this.settingsStore.getCredentialSettings();
|
|
36
|
+
const refreshToken = (0, _uuid.v4)();
|
|
37
|
+
if (!refreshTokenExpiry) {
|
|
38
|
+
this.logger.warn("Refresh token expiry not set in Settings:credentials, using default");
|
|
39
|
+
}
|
|
40
|
+
const timespan = refreshTokenExpiry ?? _serverconstants.AppConstants.DEFAULT_REFRESH_TOKEN_EXPIRY;
|
|
41
|
+
await _models.RefreshToken.create({
|
|
42
|
+
userId,
|
|
43
|
+
expiresAt: Date.now() + timespan,
|
|
44
|
+
refreshToken,
|
|
45
|
+
refreshAttemptsUsed: 0
|
|
46
|
+
});
|
|
47
|
+
return refreshToken;
|
|
48
|
+
}
|
|
49
|
+
async updateRefreshTokenAttempts(refreshToken, refreshAttemptsUsed) {
|
|
50
|
+
await this.getRefreshToken(refreshToken);
|
|
51
|
+
await _models.RefreshToken.updateOne({
|
|
52
|
+
refreshToken
|
|
53
|
+
}, {
|
|
54
|
+
refreshAttemptsUsed
|
|
55
|
+
}, {
|
|
56
|
+
new: true
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
async purgeOutdatedRefreshTokensByUserId(userId) {
|
|
60
|
+
const result = await _models.RefreshToken.deleteMany({
|
|
61
|
+
userId,
|
|
62
|
+
expiresAt: {
|
|
63
|
+
$lt: Date.now()
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
if (result.deletedCount) {
|
|
67
|
+
this.logger.debug(`Removed ${result.deletedCount} outdated login refresh tokens for user ${userId}`);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
async purgeAllOutdatedRefreshTokens() {
|
|
71
|
+
const result = await _models.RefreshToken.deleteMany({
|
|
72
|
+
expiresAt: {
|
|
73
|
+
$lt: Date.now()
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
if (result.deletedCount) {
|
|
77
|
+
this.logger.debug(`Removed ${result.deletedCount} outdated login refresh tokens`);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
async deleteRefreshTokenByUserId(userId) {
|
|
81
|
+
const result = await _models.RefreshToken.deleteMany({
|
|
82
|
+
userId
|
|
83
|
+
});
|
|
84
|
+
if (result.deletedCount) {
|
|
85
|
+
this.logger.debug(`Removed ${result.deletedCount} login refresh tokens`);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
async deleteRefreshToken(refreshToken) {
|
|
89
|
+
const result = await _models.RefreshToken.deleteOne({
|
|
90
|
+
refreshToken
|
|
91
|
+
});
|
|
92
|
+
// TODO audit result
|
|
93
|
+
if (result.deletedCount) {
|
|
94
|
+
this.logger.debug(`Removed ${result.deletedCount} login refresh tokens`);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
//# sourceMappingURL=refresh-token.service.js.map
|
|
@@ -0,0 +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","warn","timespan","AppConstants","DEFAULT_REFRESH_TOKEN_EXPIRY","create","expiresAt","Date","now","refreshAttemptsUsed","updateRefreshTokenAttempts","updateOne","new","purgeOutdatedRefreshTokensByUserId","result","deleteMany","$lt","deletedCount","debug","purgeAllOutdatedRefreshTokens","deleteRefreshTokenByUserId","deleteRefreshToken","deleteOne"],"mappings":";;;;+BAoBaA;;;eAAAA;;;wBAlBgB;sBACA;iCACA;mCAIO;AAY7B,MAAMA;IACHC,cAA6B;IAC7BC,OAAsB;IAC9BC,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;YAChC;YACA,OAAO;QACT;QACA,OAAOH;IACT;IAEA,MAAMI,4BAA4BC,MAAmB,EAAmB;QACtE,MAAM,EAAEC,kBAAkB,EAAE,GAAG,MAAM,IAAI,CAACd,aAAa,CAACe,qBAAqB;QAC7E,MAAMT,eAAeU,IAAAA,QAAM;QAE3B,IAAI,CAACF,oBAAoB;YACvB,IAAI,CAACb,MAAM,CAACgB,IAAI,CAAC;QACnB;QAEA,MAAMC,WAAWJ,sBAAsBK,6BAAY,CAACC,4BAA4B;QAChF,MAAMX,oBAAY,CAACY,MAAM,CAAC;YACxBR;YACAS,WAAWC,KAAKC,GAAG,KAAKN;YACxBZ;YACAmB,qBAAqB;QACvB;QAEA,OAAOnB;IACT;IAEA,MAAMoB,2BAA2BpB,YAAoB,EAAEmB,mBAA2B,EAAE;QAClF,MAAM,IAAI,CAACpB,eAAe,CAACC;QAE3B,MAAMG,oBAAY,CAACkB,SAAS,CAC1B;YACErB;QACF,GACA;YACEmB;QACF,GACA;YACEG,KAAK;QACP;IAEJ;IAEA,MAAMC,mCAAmChB,MAAmB,EAAE;QAC5D,MAAMiB,SAAS,MAAMrB,oBAAY,CAACsB,UAAU,CAAC;YAC3ClB;YACAS,WAAW;gBACTU,KAAKT,KAAKC,GAAG;YACf;QACF;QAEA,IAAIM,OAAOG,YAAY,EAAE;YACvB,IAAI,CAAChC,MAAM,CAACiC,KAAK,CAAC,CAAC,QAAQ,EAAEJ,OAAOG,YAAY,CAAC,wCAAwC,EAAEpB,OAAO,CAAC;QACrG;IACF;IAEA,MAAMsB,gCAAgC;QACpC,MAAML,SAAS,MAAMrB,oBAAY,CAACsB,UAAU,CAAC;YAC3CT,WAAW;gBACTU,KAAKT,KAAKC,GAAG;YACf;QACF;QAEA,IAAIM,OAAOG,YAAY,EAAE;YACvB,IAAI,CAAChC,MAAM,CAACiC,KAAK,CAAC,CAAC,QAAQ,EAAEJ,OAAOG,YAAY,CAAC,8BAA8B,CAAC;QAClF;IACF;IAEA,MAAMG,2BAA2BvB,MAAmB,EAAiB;QACnE,MAAMiB,SAAS,MAAMrB,oBAAY,CAACsB,UAAU,CAAC;YAC3ClB;QACF;QAEA,IAAIiB,OAAOG,YAAY,EAAE;YACvB,IAAI,CAAChC,MAAM,CAACiC,KAAK,CAAC,CAAC,QAAQ,EAAEJ,OAAOG,YAAY,CAAC,qBAAqB,CAAC;QACzE;IACF;IAEA,MAAMI,mBAAmB/B,YAAoB,EAAiB;QAC5D,MAAMwB,SAAS,MAAMrB,oBAAY,CAAC6B,SAAS,CAAC;YAC1ChC;QACF;QAEA,oBAAoB;QACpB,IAAIwB,OAAOG,YAAY,EAAE;YACvB,IAAI,CAAChC,MAAM,CAACiC,KAAK,CAAC,CAAC,QAAQ,EAAEJ,OAAOG,YAAY,CAAC,qBAAqB,CAAC;QACzE;IACF;AACF"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "RoleService", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return RoleService;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _lodash = require("lodash");
|
|
12
|
+
const _authorizationconstants = require("../../constants/authorization.constants");
|
|
13
|
+
const _models = require("../../models");
|
|
14
|
+
const _runtimeexceptions = require("../../exceptions/runtime.exceptions");
|
|
15
|
+
class RoleService {
|
|
16
|
+
logger;
|
|
17
|
+
settingsStore;
|
|
18
|
+
appDefaultRole;
|
|
19
|
+
appDefaultRoleNoLogin;
|
|
20
|
+
constructor({ loggerFactory, appDefaultRole, appDefaultRoleNoLogin, settingsStore }){
|
|
21
|
+
this.logger = loggerFactory(RoleService.name);
|
|
22
|
+
this.settingsStore = settingsStore;
|
|
23
|
+
this.appDefaultRole = appDefaultRole;
|
|
24
|
+
this.appDefaultRoleNoLogin = appDefaultRoleNoLogin;
|
|
25
|
+
}
|
|
26
|
+
_roles = [];
|
|
27
|
+
get roles() {
|
|
28
|
+
return this._roles;
|
|
29
|
+
}
|
|
30
|
+
async getAppDefaultRole() {
|
|
31
|
+
if (await this.settingsStore.getLoginRequired()) {
|
|
32
|
+
return this.appDefaultRole;
|
|
33
|
+
}
|
|
34
|
+
return this.appDefaultRoleNoLogin;
|
|
35
|
+
}
|
|
36
|
+
getRolesPermissions(roles) {
|
|
37
|
+
let permissions = [];
|
|
38
|
+
if (!roles?.length) return [];
|
|
39
|
+
for (let role of roles){
|
|
40
|
+
const normalizedRole = this.normalizeRoleIdOrName(role);
|
|
41
|
+
const rolePermissions = this.getRolePermissions(normalizedRole);
|
|
42
|
+
permissions = (0, _lodash.union)(permissions, rolePermissions);
|
|
43
|
+
}
|
|
44
|
+
return permissions;
|
|
45
|
+
}
|
|
46
|
+
getRolePermissions(role) {
|
|
47
|
+
const normalizedRole = this.normalizeRoleIdOrName(role);
|
|
48
|
+
return _authorizationconstants.ROLE_PERMS[normalizedRole];
|
|
49
|
+
}
|
|
50
|
+
async getAppDefaultRoleIds() {
|
|
51
|
+
if (!this._roles?.length) {
|
|
52
|
+
await this.syncRoles();
|
|
53
|
+
}
|
|
54
|
+
const guestRole = this.getRoleByName(await this.getAppDefaultRole());
|
|
55
|
+
return [
|
|
56
|
+
guestRole.id
|
|
57
|
+
];
|
|
58
|
+
}
|
|
59
|
+
async getSynchronizedRoleByName(roleName) {
|
|
60
|
+
if (!this._roles?.length) {
|
|
61
|
+
await this.syncRoles();
|
|
62
|
+
}
|
|
63
|
+
return this.getRoleByName(roleName);
|
|
64
|
+
}
|
|
65
|
+
authorizeRole(requiredRole, assignedRoles) {
|
|
66
|
+
return !!assignedRoles.find((ar)=>{
|
|
67
|
+
const normalizedRole = this.normalizeRoleIdOrName(ar);
|
|
68
|
+
if (!normalizedRole) return false;
|
|
69
|
+
return normalizedRole === requiredRole;
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
authorizeRoles(requiredRoles, assignedRoles, subset = true) {
|
|
73
|
+
let isAuthorized = false;
|
|
74
|
+
if (!requiredRoles?.length) return true;
|
|
75
|
+
requiredRoles.forEach((rr)=>{
|
|
76
|
+
const result = this.authorizeRole(rr, assignedRoles);
|
|
77
|
+
isAuthorized = subset ? isAuthorized || result : isAuthorized && result;
|
|
78
|
+
});
|
|
79
|
+
return isAuthorized;
|
|
80
|
+
}
|
|
81
|
+
getRoleByName(roleName) {
|
|
82
|
+
const role = this._roles.find((r)=>r.name === roleName);
|
|
83
|
+
if (!role) throw new _runtimeexceptions.NotFoundException(`Role by name ${roleName} not found`);
|
|
84
|
+
return role;
|
|
85
|
+
}
|
|
86
|
+
getManyRoles(roleIds) {
|
|
87
|
+
return roleIds.map((roleId)=>this.getRole(roleId));
|
|
88
|
+
}
|
|
89
|
+
getRole(roleId) {
|
|
90
|
+
const role = this._roles.find((r)=>r.id === roleId);
|
|
91
|
+
if (!role) throw new _runtimeexceptions.NotFoundException(`Role Id '${roleId}' not found`);
|
|
92
|
+
return role;
|
|
93
|
+
}
|
|
94
|
+
async syncRoles() {
|
|
95
|
+
this._roles = [];
|
|
96
|
+
for (let roleName of Object.values(_authorizationconstants.ROLES)){
|
|
97
|
+
const storedRole = await _models.Role.findOne({
|
|
98
|
+
name: roleName
|
|
99
|
+
});
|
|
100
|
+
if (!storedRole) {
|
|
101
|
+
const newRole = await _models.Role.create({
|
|
102
|
+
name: roleName
|
|
103
|
+
});
|
|
104
|
+
this._roles.push(newRole);
|
|
105
|
+
} else {
|
|
106
|
+
this._roles.push(storedRole);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
normalizeRoleIdOrName(assignedRole) {
|
|
111
|
+
const roleInstance = this.roles.find((r)=>r.id === assignedRole || r.name === assignedRole);
|
|
112
|
+
if (!roleInstance) {
|
|
113
|
+
console.warn(`The role by ID '${assignedRole}' did not exist in definition. Skipping.`);
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
return roleInstance.name;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
//# sourceMappingURL=role.service.js.map
|
|
@@ -0,0 +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","role","normalizedRole","normalizeRoleIdOrName","rolePermissions","getRolePermissions","union","ROLE_PERMS","getAppDefaultRoleIds","syncRoles","guestRole","getRoleByName","id","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":";;;;+BAWaA;;;eAAAA;;;wBAXS;wCACY;wBACb;mCACa;AAQ3B,MAAMA;IACHC,OAAsB;IAC9BC,cAA6B;IAC7BC,eAAwB;IACxBC,sBAA8B;IAE9BC,YAAY,EACVC,aAAa,EACbH,cAAc,EACdC,qBAAqB,EACrBF,aAAa,EAMd,CAAE;QACD,IAAI,CAACD,MAAM,GAAGK,cAAcN,YAAYO,IAAI;QAC5C,IAAI,CAACL,aAAa,GAAGA;QACrB,IAAI,CAACC,cAAc,GAAGA;QACtB,IAAI,CAACC,qBAAqB,GAAGA;IAC/B;IAEQI,SAAkB,EAAE,CAAC;IAE7B,IAAIC,QAAQ;QACV,OAAO,IAAI,CAACD,MAAM;IACpB;IAEA,MAAME,oBAAoB;QACxB,IAAI,MAAM,IAAI,CAACR,aAAa,CAACS,gBAAgB,IAAI;YAC/C,OAAO,IAAI,CAACR,cAAc;QAC5B;QACA,OAAO,IAAI,CAACC,qBAAqB;IACnC;IAEAQ,oBAAoBH,KAAe,EAAE;QACnC,IAAII,cAAwB,EAAE;QAC9B,IAAI,CAACJ,OAAOK,QAAQ,OAAO,EAAE;QAE7B,KAAK,IAAIC,QAAQN,MAAO;YACtB,MAAMO,iBAAiB,IAAI,CAACC,qBAAqB,CAACF;YAClD,MAAMG,kBAAkB,IAAI,CAACC,kBAAkB,CAACH;YAChDH,cAAcO,IAAAA,aAAK,EAACP,aAAaK;QACnC;QAEA,OAAOL;IACT;IAEAM,mBAAmBJ,IAAY,EAAE;QAC/B,MAAMC,iBAAiB,IAAI,CAACC,qBAAqB,CAACF;QAClD,OAAOM,kCAAU,CAACL,eAAe;IACnC;IAEA,MAAMM,uBAAuB;QAC3B,IAAI,CAAC,IAAI,CAACd,MAAM,EAAEM,QAAQ;YACxB,MAAM,IAAI,CAACS,SAAS;QACtB;QAEA,MAAMC,YAAY,IAAI,CAACC,aAAa,CAAC,MAAM,IAAI,CAACf,iBAAiB;QACjE,OAAO;YAACc,UAAUE,EAAE;SAAC;IACvB;IAEA,MAAMC,0BAA0BC,QAAgB,EAAE;QAChD,IAAI,CAAC,IAAI,CAACpB,MAAM,EAAEM,QAAQ;YACxB,MAAM,IAAI,CAACS,SAAS;QACtB;QAEA,OAAO,IAAI,CAACE,aAAa,CAACG;IAC5B;IAEAC,cAAcC,YAAoB,EAAEC,aAAuB,EAAE;QAC3D,OAAO,CAAC,CAACA,cAAcC,IAAI,CAAC,CAACC;YAC3B,MAAMjB,iBAAiB,IAAI,CAACC,qBAAqB,CAACgB;YAClD,IAAI,CAACjB,gBAAgB,OAAO;YAC5B,OAAOA,mBAAmBc;QAC5B;IACF;IAEAI,eAAeC,aAAuB,EAAEJ,aAAuB,EAAEK,SAAS,IAAI,EAAE;QAC9E,IAAIC,eAAe;QAEnB,IAAI,CAACF,eAAerB,QAAQ,OAAO;QACnCqB,cAAcG,OAAO,CAAC,CAACC;YACrB,MAAMC,SAAS,IAAI,CAACX,aAAa,CAACU,IAAIR;YACtCM,eAAeD,SAASC,gBAAgBG,SAASH,gBAAgBG;QACnE;QAEA,OAAOH;IACT;IAEAZ,cAAcG,QAAgB,EAAE;QAC9B,MAAMb,OAAO,IAAI,CAACP,MAAM,CAACwB,IAAI,CAAC,CAACS,IAAMA,EAAElC,IAAI,KAAKqB;QAChD,IAAI,CAACb,MAAM,MAAM,IAAI2B,oCAAiB,CAAC,CAAC,aAAa,EAAEd,SAAS,UAAU,CAAC;QAE3E,OAAOb;IACT;IAEA4B,aAAaC,OAAiB,EAAS;QACrC,OAAOA,QAAQC,GAAG,CAAC,CAACC,SAAW,IAAI,CAACC,OAAO,CAACD;IAC9C;IAEAC,QAAQD,MAAc,EAAE;QACtB,MAAM/B,OAAO,IAAI,CAACP,MAAM,CAACwB,IAAI,CAAC,CAACS,IAAMA,EAAEf,EAAE,KAAKoB;QAC9C,IAAI,CAAC/B,MAAM,MAAM,IAAI2B,oCAAiB,CAAC,CAAC,SAAS,EAAEI,OAAO,WAAW,CAAC;QAEtE,OAAO/B;IACT;IAEA,MAAMQ,YAAY;QAChB,IAAI,CAACf,MAAM,GAAG,EAAE;QAChB,KAAK,IAAIoB,YAAYoB,OAAOC,MAAM,CAACC,6BAAK,EAAG;YACzC,MAAMC,aAAa,MAAMC,YAAI,CAACC,OAAO,CAAC;gBAAE9C,MAAMqB;YAAS;YACvD,IAAI,CAACuB,YAAY;gBACf,MAAMG,UAAU,MAAMF,YAAI,CAACG,MAAM,CAAC;oBAChChD,MAAMqB;gBACR;gBACA,IAAI,CAACpB,MAAM,CAACgD,IAAI,CAACF;YACnB,OAAO;gBACL,IAAI,CAAC9C,MAAM,CAACgD,IAAI,CAACL;YACnB;QACF;IACF;IAEAlC,sBAAsBwC,YAAkC,EAAE;QACxD,MAAMC,eAAe,IAAI,CAACjD,KAAK,CAACuB,IAAI,CAAC,CAACS,IAAMA,EAAEf,EAAE,KAAK+B,gBAAgBhB,EAAElC,IAAI,KAAKkD;QAChF,IAAI,CAACC,cAAc;YACjBC,QAAQC,IAAI,CAAC,CAAC,gBAAgB,EAAEH,aAAa,wCAAwC,CAAC;YACtF;QACF;QAEA,OAAOC,aAAanD,IAAI;IAC1B;AACF"}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "UserService", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return UserService;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _models = require("../../models");
|
|
12
|
+
const _runtimeexceptions = require("../../exceptions/runtime.exceptions");
|
|
13
|
+
const _validators = require("../../handlers/validators");
|
|
14
|
+
const _userservicevalidation = require("../validators/user-service.validation");
|
|
15
|
+
const _authorizationconstants = require("../../constants/authorization.constants");
|
|
16
|
+
const _cryptoutils = require("../../utils/crypto.utils");
|
|
17
|
+
class UserService {
|
|
18
|
+
roleService;
|
|
19
|
+
constructor({ roleService }){
|
|
20
|
+
this.roleService = roleService;
|
|
21
|
+
}
|
|
22
|
+
toDto(user) {
|
|
23
|
+
return {
|
|
24
|
+
id: user.id,
|
|
25
|
+
createdAt: user.createdAt,
|
|
26
|
+
isVerified: user.isVerified,
|
|
27
|
+
isDemoUser: user.isDemoUser,
|
|
28
|
+
isRootUser: user.isRootUser,
|
|
29
|
+
username: user.username,
|
|
30
|
+
needsPasswordChange: user.needsPasswordChange,
|
|
31
|
+
roles: user.roles.map((r)=>r.toString())
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
async listUsers(limit = 10) {
|
|
35
|
+
return _models.User.find().limit(limit);
|
|
36
|
+
}
|
|
37
|
+
async findUserByRoleId(roleId) {
|
|
38
|
+
return _models.User.find({
|
|
39
|
+
roles: {
|
|
40
|
+
$in: [
|
|
41
|
+
roleId
|
|
42
|
+
]
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
async getDemoUserId() {
|
|
47
|
+
return (await _models.User.findOne({
|
|
48
|
+
isDemoUser: true
|
|
49
|
+
}))?.id;
|
|
50
|
+
}
|
|
51
|
+
async findRawByUsername(username) {
|
|
52
|
+
return _models.User.findOne({
|
|
53
|
+
username
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
async getUser(userId) {
|
|
57
|
+
const user = await _models.User.findById(userId);
|
|
58
|
+
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
59
|
+
return user;
|
|
60
|
+
}
|
|
61
|
+
async getUserRoles(userId) {
|
|
62
|
+
const user = await this.getUser(userId);
|
|
63
|
+
return user.roles?.map((r)=>r.toString());
|
|
64
|
+
}
|
|
65
|
+
async setUserRoleIds(userId, roleIds) {
|
|
66
|
+
const user = await _models.User.findById(userId);
|
|
67
|
+
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
68
|
+
const roles = this.roleService.getManyRoles(roleIds);
|
|
69
|
+
user.roles = roles.map((r)=>r.id);
|
|
70
|
+
user.roles = Array.from(new Set(user.roles));
|
|
71
|
+
return await user.save();
|
|
72
|
+
}
|
|
73
|
+
async deleteUser(userId) {
|
|
74
|
+
// Validate
|
|
75
|
+
const user = await this.getUser(userId);
|
|
76
|
+
// Check if the user is the last admin
|
|
77
|
+
const role = this.roleService.getRoleByName(_authorizationconstants.ROLES.ADMIN);
|
|
78
|
+
if (user.roles.includes(role.id)) {
|
|
79
|
+
const administrators = await this.findUserByRoleId(role.id);
|
|
80
|
+
if (administrators?.length === 1) {
|
|
81
|
+
throw new _runtimeexceptions.InternalServerException("Cannot delete the last user with ADMIN role.");
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
await _models.User.findByIdAndDelete(user.id);
|
|
85
|
+
}
|
|
86
|
+
async updateUsernameById(userId, newUsername) {
|
|
87
|
+
const user = await _models.User.findById(userId);
|
|
88
|
+
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
89
|
+
user.username = newUsername;
|
|
90
|
+
return await user.save();
|
|
91
|
+
}
|
|
92
|
+
async updatePasswordById(userId, oldPassword, newPassword) {
|
|
93
|
+
const user = await _models.User.findById(userId);
|
|
94
|
+
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
95
|
+
if (!(0, _cryptoutils.comparePasswordHash)(oldPassword, user.passwordHash)) {
|
|
96
|
+
throw new _runtimeexceptions.NotFoundException("User old password incorrect");
|
|
97
|
+
}
|
|
98
|
+
const { password } = await (0, _validators.validateInput)({
|
|
99
|
+
password: newPassword
|
|
100
|
+
}, _userservicevalidation.newPasswordRules);
|
|
101
|
+
user.passwordHash = (0, _cryptoutils.hashPassword)(password);
|
|
102
|
+
user.needsPasswordChange = false;
|
|
103
|
+
return await user.save();
|
|
104
|
+
}
|
|
105
|
+
async updatePasswordUnsafe(username, newPassword) {
|
|
106
|
+
const { password } = await (0, _validators.validateInput)({
|
|
107
|
+
password: newPassword
|
|
108
|
+
}, _userservicevalidation.newPasswordRules);
|
|
109
|
+
const passwordHash = (0, _cryptoutils.hashPassword)(password);
|
|
110
|
+
const user = await this.findRawByUsername(username);
|
|
111
|
+
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
112
|
+
user.passwordHash = passwordHash;
|
|
113
|
+
user.needsPasswordChange = false;
|
|
114
|
+
return await user.save();
|
|
115
|
+
}
|
|
116
|
+
async setIsRootUserById(userId, isRootUser) {
|
|
117
|
+
const user = await _models.User.findById(userId);
|
|
118
|
+
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
119
|
+
if (!isRootUser) {
|
|
120
|
+
const role = this.roleService.getRoleByName(_authorizationconstants.ROLES.ADMIN);
|
|
121
|
+
if (user.roles.includes(role.id)) {
|
|
122
|
+
throw new _runtimeexceptions.InternalServerException("Cannot set a root user with isRootUser: false as that makes no sense");
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
user.isRootUser = isRootUser;
|
|
126
|
+
await user.save();
|
|
127
|
+
}
|
|
128
|
+
async setVerifiedById(userId, isVerified) {
|
|
129
|
+
const user = await _models.User.findById(userId);
|
|
130
|
+
if (!user) throw new _runtimeexceptions.NotFoundException("User not found");
|
|
131
|
+
if (!isVerified) {
|
|
132
|
+
const role = this.roleService.getRoleByName(_authorizationconstants.ROLES.ADMIN);
|
|
133
|
+
if (user.roles.includes(role.id)) {
|
|
134
|
+
throw new _runtimeexceptions.InternalServerException("Cannot set a user with ADMIN role to unverified.");
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
user.isVerified = isVerified;
|
|
138
|
+
await user.save();
|
|
139
|
+
}
|
|
140
|
+
async register(input) {
|
|
141
|
+
const { username, password, roles, isDemoUser, isRootUser, needsPasswordChange } = await (0, _validators.validateInput)(input, _userservicevalidation.registerUserRules);
|
|
142
|
+
const passwordHash = (0, _cryptoutils.hashPassword)(password);
|
|
143
|
+
return await _models.User.create({
|
|
144
|
+
username,
|
|
145
|
+
passwordHash,
|
|
146
|
+
roles,
|
|
147
|
+
isDemoUser: isDemoUser ?? false,
|
|
148
|
+
isRootUser: isRootUser ?? false,
|
|
149
|
+
needsPasswordChange: needsPasswordChange ?? true
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
//# sourceMappingURL=user.service.js.map
|
|
@@ -0,0 +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","findUserByRoleId","roleId","$in","getDemoUserId","findOne","findRawByUsername","getUser","userId","findById","NotFoundException","getUserRoles","setUserRoleIds","roleIds","getManyRoles","Array","from","Set","save","deleteUser","role","getRoleByName","ROLES","ADMIN","includes","administrators","length","InternalServerException","findByIdAndDelete","updateUsernameById","newUsername","updatePasswordById","oldPassword","newPassword","comparePasswordHash","passwordHash","password","validateInput","newPasswordRules","hashPassword","updatePasswordUnsafe","setIsRootUserById","setVerifiedById","register","input","registerUserRules","create"],"mappings":"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"}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "BatchCallService", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return BatchCallService;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
class BatchCallService {
|
|
12
|
+
octoPrintApiService;
|
|
13
|
+
printerSocketStore;
|
|
14
|
+
printerCache;
|
|
15
|
+
printerEventsCache;
|
|
16
|
+
filesStore;
|
|
17
|
+
printerService;
|
|
18
|
+
constructor({ octoPrintApiService, printerCache, printerEventsCache, printerSocketStore, filesStore, printerService }){
|
|
19
|
+
this.octoPrintApiService = octoPrintApiService;
|
|
20
|
+
this.printerCache = printerCache;
|
|
21
|
+
this.printerEventsCache = printerEventsCache;
|
|
22
|
+
this.printerSocketStore = printerSocketStore;
|
|
23
|
+
this.filesStore = filesStore;
|
|
24
|
+
this.printerService = printerService;
|
|
25
|
+
}
|
|
26
|
+
async batchTogglePrintersEnabled(printerIds, enabled) {
|
|
27
|
+
const promises = [];
|
|
28
|
+
for (const printerId of printerIds){
|
|
29
|
+
let promise = Promise.resolve();
|
|
30
|
+
const printerDto = await this.printerCache.getValue(printerId);
|
|
31
|
+
if (!printerDto) continue;
|
|
32
|
+
const time = Date.now();
|
|
33
|
+
if (enabled) {
|
|
34
|
+
// If disabled, but not in maintenance, enable the printer
|
|
35
|
+
if (!printerDto.enabled && !printerDto.disabledReason?.length) {
|
|
36
|
+
promise = this.printerService.updateEnabled(printerId, true).then(()=>{
|
|
37
|
+
return {
|
|
38
|
+
success: true,
|
|
39
|
+
printerId,
|
|
40
|
+
time: Date.now() - time
|
|
41
|
+
};
|
|
42
|
+
}).catch((e)=>{
|
|
43
|
+
return {
|
|
44
|
+
failure: true,
|
|
45
|
+
error: e.message,
|
|
46
|
+
printerId,
|
|
47
|
+
time: Date.now() - time
|
|
48
|
+
};
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
} else {
|
|
52
|
+
// If enabled, disable the printer
|
|
53
|
+
if (printerDto.enabled) {
|
|
54
|
+
promise = this.printerService.updateEnabled(printerId, false).then(()=>{
|
|
55
|
+
return {
|
|
56
|
+
success: true,
|
|
57
|
+
printerId,
|
|
58
|
+
time: Date.now() - time
|
|
59
|
+
};
|
|
60
|
+
}).catch((e)=>{
|
|
61
|
+
return {
|
|
62
|
+
failure: true,
|
|
63
|
+
error: e.message,
|
|
64
|
+
printerId,
|
|
65
|
+
time: Date.now() - time
|
|
66
|
+
};
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
promises.push(promise);
|
|
71
|
+
}
|
|
72
|
+
return await Promise.all(promises);
|
|
73
|
+
}
|
|
74
|
+
batchConnectSocket(printerIds) {
|
|
75
|
+
for (const printerId of printerIds){
|
|
76
|
+
this.printerSocketStore.reconnectOctoPrint(printerId);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
async batchConnectUsb(printerIds) {
|
|
80
|
+
const promises = [];
|
|
81
|
+
for (const printerId of printerIds){
|
|
82
|
+
const printerLogin = await this.printerCache.getLoginDtoAsync(printerId);
|
|
83
|
+
const time = Date.now();
|
|
84
|
+
const command = this.octoPrintApiService.connectCommand;
|
|
85
|
+
const promise = this.octoPrintApiService.sendConnectionCommand(printerLogin, command).then(()=>{
|
|
86
|
+
return {
|
|
87
|
+
success: true,
|
|
88
|
+
printerId,
|
|
89
|
+
time: Date.now() - time
|
|
90
|
+
};
|
|
91
|
+
}).catch((e)=>{
|
|
92
|
+
return {
|
|
93
|
+
failure: true,
|
|
94
|
+
error: e.message,
|
|
95
|
+
printerId,
|
|
96
|
+
time: Date.now() - time
|
|
97
|
+
};
|
|
98
|
+
});
|
|
99
|
+
promises.push(promise);
|
|
100
|
+
}
|
|
101
|
+
return await Promise.all(promises);
|
|
102
|
+
}
|
|
103
|
+
async batchReprintCalls(printerIds) {
|
|
104
|
+
const promises = [];
|
|
105
|
+
for (const printerId of printerIds){
|
|
106
|
+
const printerLogin = await this.printerCache.getLoginDtoAsync(printerId);
|
|
107
|
+
// TODO test this
|
|
108
|
+
let reprintPath = await this.printerEventsCache.getPrinterSocketEvents(printerId)?.current?.job?.file?.path;
|
|
109
|
+
if (!reprintPath?.length) {
|
|
110
|
+
const files = await this.filesStore.getFiles(printerId)?.files;
|
|
111
|
+
if (files?.length) {
|
|
112
|
+
files.sort((f1, f2)=>{
|
|
113
|
+
// Sort by date, newest first
|
|
114
|
+
return f1.date < f2.date ? 1 : -1;
|
|
115
|
+
});
|
|
116
|
+
reprintPath = files[0].path;
|
|
117
|
+
}
|
|
118
|
+
if (!files?.length) {
|
|
119
|
+
promises.push(Promise.resolve({
|
|
120
|
+
failure: true,
|
|
121
|
+
error: "No file to reprint",
|
|
122
|
+
printerId
|
|
123
|
+
}));
|
|
124
|
+
continue;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
const time = Date.now();
|
|
128
|
+
const promise = this.octoPrintApiService.selectPrintFile(printerLogin, reprintPath, true).then(()=>{
|
|
129
|
+
return {
|
|
130
|
+
success: true,
|
|
131
|
+
printerId,
|
|
132
|
+
time: Date.now() - time
|
|
133
|
+
};
|
|
134
|
+
}).catch((e)=>{
|
|
135
|
+
return {
|
|
136
|
+
failure: true,
|
|
137
|
+
error: e.message,
|
|
138
|
+
printerId,
|
|
139
|
+
time: Date.now() - time
|
|
140
|
+
};
|
|
141
|
+
});
|
|
142
|
+
promises.push(promise);
|
|
143
|
+
}
|
|
144
|
+
return await Promise.all(promises);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
//# sourceMappingURL=batch-call.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/batch-call.service.ts"],"names":["BatchCallService","octoPrintApiService","printerSocketStore","printerCache","printerEventsCache","filesStore","printerService","constructor","batchTogglePrintersEnabled","printerIds","enabled","promises","printerId","promise","Promise","resolve","printerDto","getValue","time","Date","now","disabledReason","length","updateEnabled","then","success","catch","e","failure","error","message","push","all","batchConnectSocket","reconnectOctoPrint","batchConnectUsb","printerLogin","getLoginDtoAsync","command","connectCommand","sendConnectionCommand","batchReprintCalls","reprintPath","getPrinterSocketEvents","current","job","file","path","files","getFiles","sort","f1","f2","date","selectPrintFile"],"mappings":";;;;+BAoBaA;;;eAAAA;;;AAAN,MAAMA;IACXC,oBAAyC;IACzCC,mBAAuC;IACvCC,aAA2B;IAC3BC,mBAAuC;IACvCC,WAAuB;IACvBC,eAAwC;IAExCC,YAAY,EACVN,mBAAmB,EACnBE,YAAY,EACZC,kBAAkB,EAClBF,kBAAkB,EAClBG,UAAU,EACVC,cAAc,EAQf,CAAE;QACD,IAAI,CAACL,mBAAmB,GAAGA;QAC3B,IAAI,CAACE,YAAY,GAAGA;QACpB,IAAI,CAACC,kBAAkB,GAAGA;QAC1B,IAAI,CAACF,kBAAkB,GAAGA;QAC1B,IAAI,CAACG,UAAU,GAAGA;QAClB,IAAI,CAACC,cAAc,GAAGA;IACxB;IAEA,MAAME,2BAA2BC,UAAoB,EAAEC,OAAgB,EAAmB;QACxF,MAAMC,WAAW,EAAE;QACnB,KAAK,MAAMC,aAAaH,WAAY;YAClC,IAAII,UAAUC,QAAQC,OAAO;YAC7B,MAAMC,aAAa,MAAM,IAAI,CAACb,YAAY,CAACc,QAAQ,CAACL;YACpD,IAAI,CAACI,YAAY;YAEjB,MAAME,OAAOC,KAAKC,GAAG;YACrB,IAAIV,SAAS;gBACX,0DAA0D;gBAC1D,IAAI,CAACM,WAAWN,OAAO,IAAI,CAACM,WAAWK,cAAc,EAAEC,QAAQ;oBAC7DT,UAAU,IAAI,CAACP,cAAc,CAC1BiB,aAAa,CAACX,WAAW,MACzBY,IAAI,CAAC;wBACJ,OAAO;4BAAEC,SAAS;4BAAMb;4BAAWM,MAAMC,KAAKC,GAAG,KAAKF;wBAAK;oBAC7D,GACCQ,KAAK,CAAC,CAACC;wBACN,OAAO;4BAAEC,SAAS;4BAAMC,OAAOF,EAAEG,OAAO;4BAAElB;4BAAWM,MAAMC,KAAKC,GAAG,KAAKF;wBAAK;oBAC/E;gBACJ;YACF,OAAO;gBACL,kCAAkC;gBAClC,IAAIF,WAAWN,OAAO,EAAE;oBACtBG,UAAU,IAAI,CAACP,cAAc,CAC1BiB,aAAa,CAACX,WAAW,OACzBY,IAAI,CAAC;wBACJ,OAAO;4BAAEC,SAAS;4BAAMb;4BAAWM,MAAMC,KAAKC,GAAG,KAAKF;wBAAK;oBAC7D,GACCQ,KAAK,CAAC,CAACC;wBACN,OAAO;4BAAEC,SAAS;4BAAMC,OAAOF,EAAEG,OAAO;4BAAElB;4BAAWM,MAAMC,KAAKC,GAAG,KAAKF;wBAAK;oBAC/E;gBACJ;YACF;YACAP,SAASoB,IAAI,CAAClB;QAChB;QAEA,OAAO,MAAMC,QAAQkB,GAAG,CAACrB;IAC3B;IAEAsB,mBAAmBxB,UAAoB,EAAQ;QAC7C,KAAK,MAAMG,aAAaH,WAAY;YAClC,IAAI,CAACP,kBAAkB,CAACgC,kBAAkB,CAACtB;QAC7C;IACF;IAEA,MAAMuB,gBAAgB1B,UAAoB,EAAkC;QAC1E,MAAME,WAAW,EAAE;QACnB,KAAK,MAAMC,aAAaH,WAAY;YAClC,MAAM2B,eAAe,MAAM,IAAI,CAACjC,YAAY,CAACkC,gBAAgB,CAACzB;YAC9D,MAAMM,OAAOC,KAAKC,GAAG;YAErB,MAAMkB,UAAU,IAAI,CAACrC,mBAAmB,CAACsC,cAAc;YACvD,MAAM1B,UAAU,IAAI,CAACZ,mBAAmB,CACrCuC,qBAAqB,CAACJ,cAAcE,SACpCd,IAAI,CAAC;gBACJ,OAAO;oBAAEC,SAAS;oBAAMb;oBAAWM,MAAMC,KAAKC,GAAG,KAAKF;gBAAK;YAC7D,GACCQ,KAAK,CAAC,CAACC;gBACN,OAAO;oBAAEC,SAAS;oBAAMC,OAAOF,EAAEG,OAAO;oBAAElB;oBAAWM,MAAMC,KAAKC,GAAG,KAAKF;gBAAK;YAC/E;YAEFP,SAASoB,IAAI,CAAClB;QAChB;QACA,OAAO,MAAMC,QAAQkB,GAAG,CAACrB;IAC3B;IAEA,MAAM8B,kBAAkBhC,UAAoB,EAAkC;QAC5E,MAAME,WAAW,EAAE;QACnB,KAAK,MAAMC,aAAaH,WAAY;YAClC,MAAM2B,eAAe,MAAM,IAAI,CAACjC,YAAY,CAACkC,gBAAgB,CAACzB;YAE9D,iBAAiB;YACjB,IAAI8B,cAAc,MAAM,IAAI,CAACtC,kBAAkB,CAACuC,sBAAsB,CAAC/B,YAAYgC,SAASC,KAAKC,MAAMC;YACvG,IAAI,CAACL,aAAapB,QAAQ;gBACxB,MAAM0B,QAAQ,MAAM,IAAI,CAAC3C,UAAU,CAAC4C,QAAQ,CAACrC,YAAYoC;gBACzD,IAAIA,OAAO1B,QAAQ;oBACjB0B,MAAME,IAAI,CAAC,CAACC,IAAIC;wBACd,6BAA6B;wBAC7B,OAAOD,GAAGE,IAAI,GAAGD,GAAGC,IAAI,GAAG,IAAI,CAAC;oBAClC;oBAEAX,cAAcM,KAAK,CAAC,EAAE,CAACD,IAAI;gBAC7B;gBAEA,IAAI,CAACC,OAAO1B,QAAQ;oBAClBX,SAASoB,IAAI,CAACjB,QAAQC,OAAO,CAAC;wBAAEa,SAAS;wBAAMC,OAAO;wBAAsBjB;oBAAU;oBACtF;gBACF;YACF;YAEA,MAAMM,OAAOC,KAAKC,GAAG;YACrB,MAAMP,UAAU,IAAI,CAACZ,mBAAmB,CACrCqD,eAAe,CAAClB,cAAcM,aAAa,MAC3ClB,IAAI,CAAC;gBACJ,OAAO;oBAAEC,SAAS;oBAAMb;oBAAWM,MAAMC,KAAKC,GAAG,KAAKF;gBAAK;YAC7D,GACCQ,KAAK,CAAC,CAACC;gBACN,OAAO;oBAAEC,SAAS;oBAAMC,OAAOF,EAAEG,OAAO;oBAAElB;oBAAWM,MAAMC,KAAKC,GAAG,KAAKF;gBAAK;YAC/E;YAEFP,SAASoB,IAAI,CAAClB;QAChB;QACA,OAAO,MAAMC,QAAQkB,GAAG,CAACrB;IAC3B;AACF"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "CameraStreamService", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return CameraStreamService;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _models = require("../models");
|
|
12
|
+
const _validators = require("../handlers/validators");
|
|
13
|
+
const _runtimeexceptions = require("../exceptions/runtime.exceptions");
|
|
14
|
+
// TODO switch to class-validator DTO validation
|
|
15
|
+
const createCameraStreamRules = {
|
|
16
|
+
printerId: "mongoId",
|
|
17
|
+
streamURL: "required|httpurl",
|
|
18
|
+
settings: "required|object",
|
|
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"
|
|
32
|
+
};
|
|
33
|
+
class CameraStreamService {
|
|
34
|
+
model = _models.CameraStream;
|
|
35
|
+
printerCache;
|
|
36
|
+
constructor({ printerCache }){
|
|
37
|
+
this.printerCache = printerCache;
|
|
38
|
+
}
|
|
39
|
+
async list() {
|
|
40
|
+
return this.model.find();
|
|
41
|
+
}
|
|
42
|
+
async get(id, throwError = true) {
|
|
43
|
+
const cameraStream = await this.model.findById(id);
|
|
44
|
+
if (!cameraStream && throwError) {
|
|
45
|
+
throw new _runtimeexceptions.NotFoundException(`Floor with id ${id} does not exist.`, "CameraStream");
|
|
46
|
+
}
|
|
47
|
+
return cameraStream;
|
|
48
|
+
}
|
|
49
|
+
async create(data) {
|
|
50
|
+
const input = await (0, _validators.validateInput)(data, createCameraStreamRules);
|
|
51
|
+
if (input.printerId) {
|
|
52
|
+
await this.printerCache.getCachedPrinterOrThrow(input.printerId);
|
|
53
|
+
}
|
|
54
|
+
return this.model.create(input);
|
|
55
|
+
}
|
|
56
|
+
async delete(id) {
|
|
57
|
+
return this.model.findByIdAndDelete(id);
|
|
58
|
+
}
|
|
59
|
+
async update(id, input) {
|
|
60
|
+
await this.get(id);
|
|
61
|
+
const updateInput = await (0, _validators.validateInput)(input, createCameraStreamRules);
|
|
62
|
+
if (input.printerId) {
|
|
63
|
+
await this.printerCache.getCachedPrinterOrThrow(input.printerId);
|
|
64
|
+
}
|
|
65
|
+
await this.model.updateOne({
|
|
66
|
+
id
|
|
67
|
+
}, updateInput);
|
|
68
|
+
return this.get(id);
|
|
69
|
+
}
|
|
70
|
+
toDto(entity) {
|
|
71
|
+
return {
|
|
72
|
+
id: entity.id,
|
|
73
|
+
streamURL: entity.streamURL,
|
|
74
|
+
printerId: entity.printerId === null ? null : entity.printerId?.toString(),
|
|
75
|
+
settings: entity.settings
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
//# sourceMappingURL=camera-stream.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/camera-stream.service.ts"],"names":["CameraStreamService","createCameraStreamRules","printerId","streamURL","settings","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":";;;;+BAoBaA;;;eAAAA;;;wBApBgB;4BACC;mCACI;AAOlC,gDAAgD;AAChD,MAAMC,0BAA0B;IAC9BC,WAAW;IACXC,WAAW;IACXC,UAAU;IACV,wBAAwB;QAAC;QAAY;QAAU;YAAC;YAAM;YAAQ;YAAO;SAAM;KAAC;IAC5E,8BAA8B;IAC9B,2BAA2B;IAC3B,yBAAyB;AAC3B;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,UAAUwB,OAAOxB,QAAQ;QAC3B;IACF;AACF"}
|