@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 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tasks/client-bundle.task.ts"],"names":["ClientDistDownloadTask","clientBundleService","githubService","logger","constructor","loggerFactory","name","run","result","shouldUpdateWithReason","AppConstants","defaultClientMinimum","shouldUpdate","log","reason","downloadClientUpdate"],"mappings":";;;;+BAMaA;;;eAAAA;;;iCANgB;AAMtB,MAAMA;IACXC,oBAAyC;IACzCC,cAA6B;IAC7BC,OAAsB;IAEtBC,YAAY,EACVH,mBAAmB,EACnBI,aAAa,EACbH,aAAa,EAKd,CAAE;QACD,IAAI,CAACA,aAAa,GAAGA;QACrB,IAAI,CAACD,mBAAmB,GAAGA;QAC3B,IAAI,CAACE,MAAM,GAAGE,cAAcL,uBAAuBM,IAAI;IACzD;IAEA,MAAMC,MAAM;QACV,MAAMC,SAAS,MAAM,IAAI,CAACP,mBAAmB,CAACQ,sBAAsB,CAAC,OAAOC,6BAAY,CAACC,oBAAoB;QAC7G,IAAI,CAACH,OAAOI,YAAY,EAAE;YACxB,IAAI,CAACT,MAAM,CAACU,GAAG,CAAC,CAAC,sCAAsC,EAAEL,OAAOM,MAAM,CAAC,CAAC;YACxE;QACF;QAEA,IAAI,CAACX,MAAM,CAACU,GAAG,CAAC,CAAC,oDAAoD,EAAEL,OAAOM,MAAM,CAAC,CAAC;QAEtF,MAAM,IAAI,CAACb,mBAAmB,CAACc,oBAAoB,CAACL,6BAAY,CAACC,oBAAoB;IACvF;AACF"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "PrintCompletionSocketIoTask", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return PrintCompletionSocketIoTask;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _eventconstants = require("../constants/event.constants");
|
|
12
|
+
const _octoprintwebsocketconstants = require("../services/octoprint/constants/octoprint-websocket.constants");
|
|
13
|
+
const _correlationtokenutil = require("../utils/correlation-token.util");
|
|
14
|
+
const _socketiogateway = require("../state/socket-io.gateway");
|
|
15
|
+
class PrintCompletionSocketIoTask {
|
|
16
|
+
eventEmitter2;
|
|
17
|
+
socketIoGateway;
|
|
18
|
+
logger;
|
|
19
|
+
printCompletionService;
|
|
20
|
+
contextCache = {};
|
|
21
|
+
constructor({ eventEmitter2, socketIoGateway, printCompletionService, loggerFactory }){
|
|
22
|
+
this.eventEmitter2 = eventEmitter2;
|
|
23
|
+
this.socketIoGateway = socketIoGateway;
|
|
24
|
+
this.printCompletionService = printCompletionService;
|
|
25
|
+
this.logger = loggerFactory(PrintCompletionSocketIoTask.name);
|
|
26
|
+
let that = this;
|
|
27
|
+
this.eventEmitter2.on((0, _eventconstants.octoPrintWebsocketEvent)("*"), async function(octoPrintEvent, data) {
|
|
28
|
+
await that.handleMessage(this.event, octoPrintEvent, data);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
get contexts() {
|
|
32
|
+
return this.contextCache;
|
|
33
|
+
}
|
|
34
|
+
async handleMessage(fdmEvent, octoPrintEvent, data) {
|
|
35
|
+
// If not parsed well, skip log
|
|
36
|
+
const printerId = fdmEvent.replace("octoprint.", "");
|
|
37
|
+
if (!printerId) {
|
|
38
|
+
this.logger.log(`Skipping print completion log for FDM event ${fdmEvent}`);
|
|
39
|
+
}
|
|
40
|
+
if (octoPrintEvent !== "event") {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const completion = {
|
|
44
|
+
status: data.type,
|
|
45
|
+
fileName: data.payload?.name,
|
|
46
|
+
createdAt: Date.now(),
|
|
47
|
+
completionLog: data.payload?.error,
|
|
48
|
+
printerId: printerId
|
|
49
|
+
};
|
|
50
|
+
this.socketIoGateway.send(_socketiogateway.IO_MESSAGES.CompletionEvent, JSON.stringify({
|
|
51
|
+
fdmEvent,
|
|
52
|
+
octoPrintEvent,
|
|
53
|
+
data
|
|
54
|
+
}));
|
|
55
|
+
if (data.type === _octoprintwebsocketconstants.EVENT_TYPES.EStop || data.type === _octoprintwebsocketconstants.EVENT_TYPES.PrintCancelling || data.type === _octoprintwebsocketconstants.EVENT_TYPES.PrintCancelled || data.type === _octoprintwebsocketconstants.EVENT_TYPES.Home || data.type === _octoprintwebsocketconstants.EVENT_TYPES.TransferStarted || data.type === _octoprintwebsocketconstants.EVENT_TYPES.TransferDone || data.type === _octoprintwebsocketconstants.EVENT_TYPES.Disconnecting || data.type === _octoprintwebsocketconstants.EVENT_TYPES.Disconnected || data.type === _octoprintwebsocketconstants.EVENT_TYPES.MetadataAnalysisStarted || data.type === _octoprintwebsocketconstants.EVENT_TYPES.MetadataAnalysisFinished || data.type === _octoprintwebsocketconstants.EVENT_TYPES.Error) {
|
|
56
|
+
this.contextCache[printerId] = {
|
|
57
|
+
...this.contextCache[printerId],
|
|
58
|
+
[data.type]: completion
|
|
59
|
+
};
|
|
60
|
+
const corrId = this.contextCache[printerId].correlationId;
|
|
61
|
+
await this.printCompletionService.updateContext(corrId, this.contextCache[printerId]);
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
if (data.type === _octoprintwebsocketconstants.EVENT_TYPES.PrintStarted) {
|
|
65
|
+
// Clear the context now with association id
|
|
66
|
+
this.contextCache[printerId] = {
|
|
67
|
+
correlationId: (0, _correlationtokenutil.generateCorrelationToken)()
|
|
68
|
+
};
|
|
69
|
+
completion.context = this.contextCache[printerId];
|
|
70
|
+
await this.printCompletionService.create(completion);
|
|
71
|
+
} else if (data.type === _octoprintwebsocketconstants.EVENT_TYPES.PrintFailed || data.type === _octoprintwebsocketconstants.EVENT_TYPES.PrintDone) {
|
|
72
|
+
completion.context = this.contextCache[printerId] || {};
|
|
73
|
+
await this.printCompletionService.create(completion);
|
|
74
|
+
this.eventEmitter2.emit((0, _eventconstants.fdmMonsterPrinterStoppedEvent)(printerId));
|
|
75
|
+
// Clear the context now
|
|
76
|
+
this.contextCache[printerId] = {};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
async run() {
|
|
80
|
+
// Run once to bind event handler and reload the cache
|
|
81
|
+
this.contextCache = await this.printCompletionService.loadPrintContexts();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
//# sourceMappingURL=print-completion.socketio.task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tasks/print-completion.socketio.task.ts"],"names":["PrintCompletionSocketIoTask","eventEmitter2","socketIoGateway","logger","printCompletionService","contextCache","constructor","loggerFactory","name","that","on","octoPrintWebsocketEvent","octoPrintEvent","data","handleMessage","event","contexts","fdmEvent","printerId","replace","log","completion","status","type","fileName","payload","createdAt","Date","now","completionLog","error","send","IO_MESSAGES","CompletionEvent","JSON","stringify","EVENT_TYPES","EStop","PrintCancelling","PrintCancelled","Home","TransferStarted","TransferDone","Disconnecting","Disconnected","MetadataAnalysisStarted","MetadataAnalysisFinished","Error","corrId","correlationId","updateContext","PrintStarted","generateCorrelationToken","context","create","PrintFailed","PrintDone","emit","fdmMonsterPrinterStoppedEvent","run","loadPrintContexts"],"mappings":"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"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "PrinterFileCleanTask", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return PrinterFileCleanTask;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
class PrinterFileCleanTask {
|
|
12
|
+
logger;
|
|
13
|
+
filesStore;
|
|
14
|
+
printerCache;
|
|
15
|
+
settingsStore;
|
|
16
|
+
taskManagerService;
|
|
17
|
+
octoPrintApiService;
|
|
18
|
+
constructor({ printerCache, filesStore, octoPrintApiService, taskManagerService, settingsStore, loggerFactory }){
|
|
19
|
+
this.printerCache = printerCache;
|
|
20
|
+
this.filesStore = filesStore;
|
|
21
|
+
this.taskManagerService = taskManagerService;
|
|
22
|
+
this.octoPrintApiService = octoPrintApiService;
|
|
23
|
+
this.settingsStore = settingsStore;
|
|
24
|
+
this.logger = loggerFactory(PrinterFileCleanTask.name);
|
|
25
|
+
}
|
|
26
|
+
get #ageDaysMaxSetting() {
|
|
27
|
+
return this.#getSettings().autoRemoveOldFilesCriteriumDays;
|
|
28
|
+
}
|
|
29
|
+
async run() {
|
|
30
|
+
// TODO filter disconnected printers
|
|
31
|
+
const printers = await this.printerCache.listCachedPrinters(false);
|
|
32
|
+
const fileCleanSettings = this.#getSettings();
|
|
33
|
+
const autoCleanAtBootEnabled = fileCleanSettings.autoRemoveOldFilesAtBoot;
|
|
34
|
+
try {
|
|
35
|
+
if (autoCleanAtBootEnabled) {
|
|
36
|
+
this.logger.log(`Cleaning files of ${printers.length} active printers [printerFileClean:autoRemoveOldFilesAtBoot].`);
|
|
37
|
+
} else {
|
|
38
|
+
this.logger.log(`Reporting about old files of ${printers.length} printers.`);
|
|
39
|
+
}
|
|
40
|
+
// Filter printer states - cant clean unconnected OctoPrint instances
|
|
41
|
+
for (let printer of printers){
|
|
42
|
+
const outdatedFiles = this.getPrinterOutdatedFiles(printer);
|
|
43
|
+
if (!outdatedFiles?.length) continue;
|
|
44
|
+
// Report
|
|
45
|
+
this.logger.log(`Found ${outdatedFiles?.length} old files of ${printer.printerName}`);
|
|
46
|
+
if (autoCleanAtBootEnabled) {
|
|
47
|
+
await this.cleanPrinterFiles(printer.id);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
} finally{
|
|
51
|
+
this.logger.log(`Printer old file analysis job ended`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
async cleanPrinterFiles(printerId) {
|
|
55
|
+
// Act
|
|
56
|
+
await this.filesStore.deleteOutdatedFiles(printerId, this.#ageDaysMaxSetting);
|
|
57
|
+
// Update printer files
|
|
58
|
+
await this.filesStore.eagerLoadPrinterFiles(printerId, false);
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Scans the printers files and checks the outdated ones based on settings
|
|
62
|
+
* @param printer
|
|
63
|
+
*/ getPrinterOutdatedFiles(printer) {
|
|
64
|
+
const ageDaysMax = this.#ageDaysMaxSetting;
|
|
65
|
+
return this.filesStore.getOutdatedFiles(printer.id, ageDaysMax);
|
|
66
|
+
}
|
|
67
|
+
#getSettings() {
|
|
68
|
+
return this.settingsStore.getFileCleanSettings();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
//# sourceMappingURL=printer-file-clean.task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tasks/printer-file-clean.task.ts"],"names":["PrinterFileCleanTask","logger","filesStore","printerCache","settingsStore","taskManagerService","octoPrintApiService","constructor","loggerFactory","name","ageDaysMaxSetting","getSettings","autoRemoveOldFilesCriteriumDays","run","printers","listCachedPrinters","fileCleanSettings","autoCleanAtBootEnabled","autoRemoveOldFilesAtBoot","log","length","printer","outdatedFiles","getPrinterOutdatedFiles","printerName","cleanPrinterFiles","id","printerId","deleteOutdatedFiles","eagerLoadPrinterFiles","ageDaysMax","getOutdatedFiles","getFileCleanSettings"],"mappings":";;;;+BAYaA;;;eAAAA;;;AAAN,MAAMA;IACXC,OAAsB;IACtBC,WAAuB;IACvBC,aAA2B;IAC3BC,cAA6B;IAC7BC,mBAAuC;IACvCC,oBAAyC;IAEzCC,YAAY,EACVJ,YAAY,EACZD,UAAU,EACVI,mBAAmB,EACnBD,kBAAkB,EAClBD,aAAa,EACbI,aAAa,EAQd,CAAE;QACD,IAAI,CAACL,YAAY,GAAGA;QACpB,IAAI,CAACD,UAAU,GAAGA;QAClB,IAAI,CAACG,kBAAkB,GAAGA;QAC1B,IAAI,CAACC,mBAAmB,GAAGA;QAC3B,IAAI,CAACF,aAAa,GAAGA;QACrB,IAAI,CAACH,MAAM,GAAGO,cAAcR,qBAAqBS,IAAI;IACvD;IAEA,IAAI,CAACC,iBAAiB;QACpB,OAAO,IAAI,CAAC,CAACC,WAAW,GAAGC,+BAA+B;IAC5D;IAEA,MAAMC,MAAM;QACV,oCAAoC;QACpC,MAAMC,WAAW,MAAM,IAAI,CAACX,YAAY,CAACY,kBAAkB,CAAC;QAC5D,MAAMC,oBAAoB,IAAI,CAAC,CAACL,WAAW;QAC3C,MAAMM,yBAAyBD,kBAAkBE,wBAAwB;QAEzE,IAAI;YACF,IAAID,wBAAwB;gBAC1B,IAAI,CAAChB,MAAM,CAACkB,GAAG,CAAC,CAAC,kBAAkB,EAAEL,SAASM,MAAM,CAAC,6DAA6D,CAAC;YACrH,OAAO;gBACL,IAAI,CAACnB,MAAM,CAACkB,GAAG,CAAC,CAAC,6BAA6B,EAAEL,SAASM,MAAM,CAAC,UAAU,CAAC;YAC7E;YAEA,qEAAqE;YACrE,KAAK,IAAIC,WAAWP,SAAU;gBAC5B,MAAMQ,gBAAgB,IAAI,CAACC,uBAAuB,CAACF;gBACnD,IAAI,CAACC,eAAeF,QAAQ;gBAE5B,SAAS;gBACT,IAAI,CAACnB,MAAM,CAACkB,GAAG,CAAC,CAAC,MAAM,EAAEG,eAAeF,OAAO,cAAc,EAAEC,QAAQG,WAAW,CAAC,CAAC;gBAEpF,IAAIP,wBAAwB;oBAC1B,MAAM,IAAI,CAACQ,iBAAiB,CAACJ,QAAQK,EAAE;gBACzC;YACF;QACF,SAAU;YACR,IAAI,CAACzB,MAAM,CAACkB,GAAG,CAAC,CAAC,mCAAmC,CAAC;QACvD;IACF;IAEA,MAAMM,kBAAkBE,SAAS,EAAE;QACjC,MAAM;QACN,MAAM,IAAI,CAACzB,UAAU,CAAC0B,mBAAmB,CAACD,WAAW,IAAI,CAAC,CAACjB,iBAAiB;QAE5E,uBAAuB;QACvB,MAAM,IAAI,CAACR,UAAU,CAAC2B,qBAAqB,CAACF,WAAW;IACzD;IAEA;;;GAGC,GACDJ,wBAAwBF,OAAO,EAAE;QAC/B,MAAMS,aAAa,IAAI,CAAC,CAACpB,iBAAiB;QAC1C,OAAO,IAAI,CAACR,UAAU,CAAC6B,gBAAgB,CAACV,QAAQK,EAAE,EAAEI;IACtD;IAEA,CAACnB,WAAW;QACV,OAAO,IAAI,CAACP,aAAa,CAAC4B,oBAAoB;IAChD;AACF"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "PrinterWebsocketRestoreTask", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return PrinterWebsocketRestoreTask;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _errorutils = require("../utils/error.utils");
|
|
12
|
+
const _octoprintsockioadapter = require("../services/octoprint/octoprint-sockio.adapter");
|
|
13
|
+
class PrinterWebsocketRestoreTask {
|
|
14
|
+
settingsStore;
|
|
15
|
+
printerSocketStore;
|
|
16
|
+
octoPrintApiService;
|
|
17
|
+
logger;
|
|
18
|
+
constructor({ printerSocketStore, octoPrintApiService, settingsStore, loggerFactory }){
|
|
19
|
+
this.printerSocketStore = printerSocketStore;
|
|
20
|
+
this.octoPrintApiService = octoPrintApiService;
|
|
21
|
+
this.settingsStore = settingsStore;
|
|
22
|
+
this.logger = loggerFactory(PrinterWebsocketRestoreTask.name);
|
|
23
|
+
}
|
|
24
|
+
async run() {
|
|
25
|
+
const startTime = Date.now();
|
|
26
|
+
/**
|
|
27
|
+
* @type {OctoPrintSockIoAdapter[]}
|
|
28
|
+
*/ const existingSockets = this.printerSocketStore.listPrinterSockets();
|
|
29
|
+
const resetAdapterIds = [];
|
|
30
|
+
const silentSocketIds = [];
|
|
31
|
+
for (const socket of existingSockets){
|
|
32
|
+
try {
|
|
33
|
+
if (socket.isClosedOrAborted()) {
|
|
34
|
+
socket.close();
|
|
35
|
+
socket.resetSocketState();
|
|
36
|
+
resetAdapterIds.push(socket.printerId);
|
|
37
|
+
continue;
|
|
38
|
+
}
|
|
39
|
+
} catch (e) {
|
|
40
|
+
this.logger.error(`WebSocket authentication command failed for '${socket.printerId}' with error '${(0, _errorutils.errorSummary)(e)}'`, e.stack);
|
|
41
|
+
continue;
|
|
42
|
+
}
|
|
43
|
+
// Often due to USB disconnect, not interesting to reconnect unless we perform an API call for verification
|
|
44
|
+
if (socket.apiState !== _octoprintsockioadapter.API_STATE.unset && !socket.lastMessageReceivedTimestamp || Date.now() - socket.lastMessageReceivedTimestamp > 10 * 1000) {
|
|
45
|
+
silentSocketIds.push(socket.printerId);
|
|
46
|
+
// Produce logs for silent sockets
|
|
47
|
+
try {
|
|
48
|
+
const result = await this.octoPrintApiService.getConnection(socket.loginDto);
|
|
49
|
+
if (result?.current?.state !== "Closed") {
|
|
50
|
+
this.logger.warn(`Silence was detected, but the OctoPrint current connection was not closed. Connection state ${result?.current?.state}, printerId: ${socket.printerId}.`);
|
|
51
|
+
}
|
|
52
|
+
} catch (e) {
|
|
53
|
+
this.logger.error(`Silence was detected, but Websocket was not closed/aborted and API could not be called ${socket.printerId}.`);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
const duration = Date.now() - startTime;
|
|
58
|
+
if (this.settingsStore.getServerSettings()?.debugSettings?.debugSocketRetries) {
|
|
59
|
+
this.logger.log(`Reset ${resetAdapterIds.length} closed/aborted sockets and detected ${silentSocketIds.length} silent sockets (duration ${duration}ms)`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
//# sourceMappingURL=printer-websocket-restore.task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tasks/printer-websocket-restore.task.ts"],"names":["PrinterWebsocketRestoreTask","settingsStore","printerSocketStore","octoPrintApiService","logger","constructor","loggerFactory","name","run","startTime","Date","now","existingSockets","listPrinterSockets","resetAdapterIds","silentSocketIds","socket","isClosedOrAborted","close","resetSocketState","push","printerId","e","error","errorSummary","stack","apiState","API_STATE","unset","lastMessageReceivedTimestamp","result","getConnection","loginDto","current","state","warn","duration","getServerSettings","debugSettings","debugSocketRetries","log","length"],"mappings":";;;;+BAQaA;;;eAAAA;;;4BARgB;wCACH;AAOnB,MAAMA;IACXC,cAA6B;IAC7BC,mBAAuC;IACvCC,oBAAyC;IACzCC,OAAsB;IAEtBC,YAAY,EACVH,kBAAkB,EAClBC,mBAAmB,EACnBF,aAAa,EACbK,aAAa,EAMd,CAAE;QACD,IAAI,CAACJ,kBAAkB,GAAGA;QAC1B,IAAI,CAACC,mBAAmB,GAAGA;QAC3B,IAAI,CAACF,aAAa,GAAGA;QACrB,IAAI,CAACG,MAAM,GAAGE,cAAcN,4BAA4BO,IAAI;IAC9D;IAEA,MAAMC,MAAM;QACV,MAAMC,YAAYC,KAAKC,GAAG;QAE1B;;KAEC,GACD,MAAMC,kBAAkB,IAAI,CAACV,kBAAkB,CAACW,kBAAkB;QAClE,MAAMC,kBAAkB,EAAE;QAC1B,MAAMC,kBAAkB,EAAE;QAC1B,KAAK,MAAMC,UAAUJ,gBAAiB;YACpC,IAAI;gBACF,IAAII,OAAOC,iBAAiB,IAAI;oBAC9BD,OAAOE,KAAK;oBACZF,OAAOG,gBAAgB;oBACvBL,gBAAgBM,IAAI,CAACJ,OAAOK,SAAS;oBACrC;gBACF;YACF,EAAE,OAAOC,GAAG;gBACV,IAAI,CAAClB,MAAM,CAACmB,KAAK,CACf,CAAC,6CAA6C,EAAEP,OAAOK,SAAS,CAAC,cAAc,EAAEG,IAAAA,wBAAY,EAACF,GAAG,CAAC,CAAC,EACnGA,EAAEG,KAAK;gBAET;YACF;YAEA,2GAA2G;YAC3G,IACE,AAACT,OAAOU,QAAQ,KAAKC,iCAAS,CAACC,KAAK,IAAI,CAACZ,OAAOa,4BAA4B,IAC5EnB,KAAKC,GAAG,KAAKK,OAAOa,4BAA4B,GAAG,KAAK,MACxD;gBACAd,gBAAgBK,IAAI,CAACJ,OAAOK,SAAS;gBACrC,kCAAkC;gBAClC,IAAI;oBACF,MAAMS,SAAS,MAAM,IAAI,CAAC3B,mBAAmB,CAAC4B,aAAa,CAACf,OAAOgB,QAAQ;oBAC3E,IAAIF,QAAQG,SAASC,UAAU,UAAU;wBACvC,IAAI,CAAC9B,MAAM,CAAC+B,IAAI,CACd,CAAC,4FAA4F,EAAEL,QAAQG,SAASC,MAAM,aAAa,EAAElB,OAAOK,SAAS,CAAC,CAAC,CAAC;oBAE5J;gBACF,EAAE,OAAOC,GAAG;oBACV,IAAI,CAAClB,MAAM,CAACmB,KAAK,CACf,CAAC,uFAAuF,EAAEP,OAAOK,SAAS,CAAC,CAAC,CAAC;gBAEjH;YACF;QACF;QAEA,MAAMe,WAAW1B,KAAKC,GAAG,KAAKF;QAC9B,IAAI,IAAI,CAACR,aAAa,CAACoC,iBAAiB,IAAIC,eAAeC,oBAAoB;YAC7E,IAAI,CAACnC,MAAM,CAACoC,GAAG,CACb,CAAC,MAAM,EAAE1B,gBAAgB2B,MAAM,CAAC,qCAAqC,EAAE1B,gBAAgB0B,MAAM,CAAC,0BAA0B,EAAEL,SAAS,GAAG,CAAC;QAE3I;IACF;AACF"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "PrinterWebsocketTask", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return PrinterWebsocketTask;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
class PrinterWebsocketTask {
|
|
12
|
+
/**
|
|
13
|
+
* @type {PrinterSocketStore}
|
|
14
|
+
*/ printerSocketStore;
|
|
15
|
+
/**
|
|
16
|
+
* @type {SettingsStore}
|
|
17
|
+
*/ settingsStore;
|
|
18
|
+
/**
|
|
19
|
+
* @type {OctoPrintApiService}
|
|
20
|
+
*/ octoPrintApiService;
|
|
21
|
+
/**
|
|
22
|
+
* @type {TaskManagerService}
|
|
23
|
+
*/ taskManagerService;
|
|
24
|
+
/**
|
|
25
|
+
* @type {LoggerService}
|
|
26
|
+
*/ logger;
|
|
27
|
+
constructor({ printerSocketStore, octoPrintApiService, settingsStore, taskManagerService, loggerFactory }){
|
|
28
|
+
this.printerSocketStore = printerSocketStore;
|
|
29
|
+
this.settingsStore = settingsStore;
|
|
30
|
+
this.octoPrintApiService = octoPrintApiService;
|
|
31
|
+
this.taskManagerService = taskManagerService;
|
|
32
|
+
this.logger = loggerFactory(PrinterWebsocketTask.name);
|
|
33
|
+
}
|
|
34
|
+
async run() {
|
|
35
|
+
const startTime = Date.now();
|
|
36
|
+
const result = await this.printerSocketStore.reconnectPrinterSockets();
|
|
37
|
+
if (this.settingsStore.getServerSettings().debugSettings?.debugSocketReconnect) {
|
|
38
|
+
this.logger.log(`Socket reconnect (${Date.now() - startTime}ms)`, result);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
//# sourceMappingURL=printer-websocket.task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tasks/printer-websocket.task.ts"],"names":["PrinterWebsocketTask","printerSocketStore","settingsStore","octoPrintApiService","taskManagerService","logger","constructor","loggerFactory","name","run","startTime","Date","now","result","reconnectPrinterSockets","getServerSettings","debugSettings","debugSocketReconnect","log"],"mappings":";;;;+BAAaA;;;eAAAA;;;AAAN,MAAMA;IACX;;GAEC,GACDC,mBAAmB;IACnB;;GAEC,GACDC,cAAc;IACd;;GAEC,GACDC,oBAAoB;IACpB;;GAEC,GACDC,mBAAmB;IAEnB;;GAEC,GACDC,OAAO;IAEPC,YAAY,EAAEL,kBAAkB,EAAEE,mBAAmB,EAAED,aAAa,EAAEE,kBAAkB,EAAEG,aAAa,EAAE,CAAE;QACzG,IAAI,CAACN,kBAAkB,GAAGA;QAC1B,IAAI,CAACC,aAAa,GAAGA;QACrB,IAAI,CAACC,mBAAmB,GAAGA;QAC3B,IAAI,CAACC,kBAAkB,GAAGA;QAC1B,IAAI,CAACC,MAAM,GAAGE,cAAcP,qBAAqBQ,IAAI;IACvD;IAEA,MAAMC,MAAM;QACV,MAAMC,YAAYC,KAAKC,GAAG;QAC1B,MAAMC,SAAS,MAAM,IAAI,CAACZ,kBAAkB,CAACa,uBAAuB;QACpE,IAAI,IAAI,CAACZ,aAAa,CAACa,iBAAiB,GAAGC,aAAa,EAAEC,sBAAsB;YAC9E,IAAI,CAACZ,MAAM,CAACa,GAAG,CAAC,CAAC,kBAAkB,EAAEP,KAAKC,GAAG,KAAKF,UAAU,GAAG,CAAC,EAAEG;QACpE;IACF;AACF"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "SocketIoTask", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return SocketIoTask;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _socketiogateway = require("../state/socket-io.gateway");
|
|
12
|
+
const _eventconstants = require("../constants/event.constants");
|
|
13
|
+
const _metricutils = require("../utils/metric.utils");
|
|
14
|
+
class SocketIoTask {
|
|
15
|
+
socketIoGateway;
|
|
16
|
+
printerSocketStore;
|
|
17
|
+
printerEventsCache;
|
|
18
|
+
floorStore;
|
|
19
|
+
fileUploadTrackerCache;
|
|
20
|
+
eventEmitter2;
|
|
21
|
+
printerCache;
|
|
22
|
+
logger;
|
|
23
|
+
settingsStore;
|
|
24
|
+
aggregateSizeCounter = 0;
|
|
25
|
+
aggregateWindowLength = 100;
|
|
26
|
+
aggregateSizes = [];
|
|
27
|
+
rounding = 2;
|
|
28
|
+
constructor({ socketIoGateway, floorStore, printerSocketStore, printerEventsCache, printerCache, loggerFactory, fileUploadTrackerCache, settingsStore, eventEmitter2 }){
|
|
29
|
+
this.socketIoGateway = socketIoGateway;
|
|
30
|
+
this.printerSocketStore = printerSocketStore;
|
|
31
|
+
this.printerEventsCache = printerEventsCache;
|
|
32
|
+
this.fileUploadTrackerCache = fileUploadTrackerCache;
|
|
33
|
+
this.floorStore = floorStore;
|
|
34
|
+
this.logger = loggerFactory(SocketIoTask.name);
|
|
35
|
+
this.eventEmitter2 = eventEmitter2;
|
|
36
|
+
this.printerCache = printerCache;
|
|
37
|
+
this.settingsStore = settingsStore;
|
|
38
|
+
this.eventEmitter2.on(_eventconstants.socketIoConnectedEvent, async ()=>{
|
|
39
|
+
await this.sendUpdate();
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
async run() {
|
|
43
|
+
await this.sendUpdate();
|
|
44
|
+
}
|
|
45
|
+
async sendUpdate() {
|
|
46
|
+
const floors = await this.floorStore.listCache();
|
|
47
|
+
const printers = await this.printerCache.listCachedPrinters(true);
|
|
48
|
+
const socketStates = this.printerSocketStore.getSocketStatesById();
|
|
49
|
+
const printerEvents = await this.printerEventsCache.getAllKeyValues();
|
|
50
|
+
const trackedUploads = this.fileUploadTrackerCache.getUploads(true);
|
|
51
|
+
const socketIoData = {
|
|
52
|
+
printers,
|
|
53
|
+
floors,
|
|
54
|
+
socketStates,
|
|
55
|
+
printerEvents,
|
|
56
|
+
trackedUploads
|
|
57
|
+
};
|
|
58
|
+
// Precise debugging
|
|
59
|
+
if (this.settingsStore.getServerSettings().debugSettings?.debugSocketIoBandwidth) {
|
|
60
|
+
const kbDataString = Object.entries(socketIoData).map(([id, state])=>{
|
|
61
|
+
return `${id} ${(0, _metricutils.formatKB)(state)}`;
|
|
62
|
+
}).join(" ");
|
|
63
|
+
this.logger.log(kbDataString);
|
|
64
|
+
}
|
|
65
|
+
const serializedData = JSON.stringify(socketIoData);
|
|
66
|
+
const transportDataSize = (0, _metricutils.sizeKB)(serializedData);
|
|
67
|
+
this.updateAggregator(transportDataSize);
|
|
68
|
+
this.socketIoGateway.send(_socketiogateway.IO_MESSAGES.LegacyUpdate, serializedData);
|
|
69
|
+
}
|
|
70
|
+
updateAggregator(transportDataLength) {
|
|
71
|
+
if (this.aggregateSizeCounter >= this.aggregateWindowLength) {
|
|
72
|
+
const summedPayloadSize = this.aggregateSizes.reduce((t, n)=>t += n);
|
|
73
|
+
const averagePayloadSize = summedPayloadSize / this.aggregateWindowLength;
|
|
74
|
+
this.logger.log(`Printer SocketIO metrics ${averagePayloadSize.toFixed(this.rounding)}kB [${this.aggregateWindowLength} TX avg].`);
|
|
75
|
+
this.aggregateSizeCounter = 0;
|
|
76
|
+
this.aggregateSizes = [];
|
|
77
|
+
}
|
|
78
|
+
this.aggregateSizes.push(transportDataLength);
|
|
79
|
+
++this.aggregateSizeCounter;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
//# sourceMappingURL=socketio.task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tasks/socketio.task.ts"],"names":["SocketIoTask","socketIoGateway","printerSocketStore","printerEventsCache","floorStore","fileUploadTrackerCache","eventEmitter2","printerCache","logger","settingsStore","aggregateSizeCounter","aggregateWindowLength","aggregateSizes","rounding","constructor","loggerFactory","name","on","socketIoConnectedEvent","sendUpdate","run","floors","listCache","printers","listCachedPrinters","socketStates","getSocketStatesById","printerEvents","getAllKeyValues","trackedUploads","getUploads","socketIoData","getServerSettings","debugSettings","debugSocketIoBandwidth","kbDataString","Object","entries","map","id","state","formatKB","join","log","serializedData","JSON","stringify","transportDataSize","sizeKB","updateAggregator","send","IO_MESSAGES","LegacyUpdate","transportDataLength","summedPayloadSize","reduce","t","n","averagePayloadSize","toFixed","push"],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "SoftwareUpdateTask", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return SoftwareUpdateTask;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
class SoftwareUpdateTask {
|
|
12
|
+
serverReleaseService;
|
|
13
|
+
constructor({ serverReleaseService }){
|
|
14
|
+
this.serverReleaseService = serverReleaseService;
|
|
15
|
+
}
|
|
16
|
+
async run() {
|
|
17
|
+
await this.serverReleaseService.syncLatestRelease();
|
|
18
|
+
this.serverReleaseService.logServerVersionState();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
//# sourceMappingURL=software-update.task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tasks/software-update.task.ts"],"names":["SoftwareUpdateTask","serverReleaseService","constructor","run","syncLatestRelease","logServerVersionState"],"mappings":";;;;+BAEaA;;;eAAAA;;;AAAN,MAAMA;IACXC,qBAA2C;IAE3CC,YAAY,EAAED,oBAAoB,EAAkD,CAAE;QACpF,IAAI,CAACA,oBAAoB,GAAGA;IAC9B;IAEA,MAAME,MAAM;QACV,MAAM,IAAI,CAACF,oBAAoB,CAACG,iBAAiB;QACjD,IAAI,CAACH,oBAAoB,CAACI,qBAAqB;IACjD;AACF"}
|
package/dist/tasks.js
ADDED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
ServerTasks: function() {
|
|
13
|
+
return ServerTasks;
|
|
14
|
+
},
|
|
15
|
+
registerTask: function() {
|
|
16
|
+
return registerTask;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
const _taskpresets = require("./task.presets");
|
|
20
|
+
const _containertokens = require("./container.tokens");
|
|
21
|
+
function registerTask(task, preset, milliseconds = 0, runImmediately = false) {
|
|
22
|
+
let timingPreset = {
|
|
23
|
+
...preset
|
|
24
|
+
};
|
|
25
|
+
timingPreset.milliseconds = preset.milliseconds || milliseconds;
|
|
26
|
+
timingPreset.runImmediately = runImmediately | false;
|
|
27
|
+
return {
|
|
28
|
+
id: task.name || task,
|
|
29
|
+
task,
|
|
30
|
+
preset: timingPreset
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
class ServerTasks {
|
|
34
|
+
static SERVER_BOOT_TASK = registerTask(_containertokens.DITokens.bootTask, _taskpresets.TASK_PRESETS.PERIODIC_DISABLED, 5000, false);
|
|
35
|
+
static BOOT_TASKS = [
|
|
36
|
+
registerTask(_containertokens.DITokens.softwareUpdateTask, _taskpresets.TASK_PRESETS.RUNDELAYED, 1500),
|
|
37
|
+
registerTask(_containertokens.DITokens.clientDistDownloadTask, _taskpresets.TASK_PRESETS.RUNONCE),
|
|
38
|
+
registerTask(_containertokens.DITokens.socketIoTask, _taskpresets.TASK_PRESETS.PERIODIC, 500),
|
|
39
|
+
registerTask(_containertokens.DITokens.printCompletionSocketIoTask, _taskpresets.TASK_PRESETS.RUNONCE),
|
|
40
|
+
registerTask(_containertokens.DITokens.printerFileCleanTask, _taskpresets.TASK_PRESETS.RUNONCE, 60 * 1000, true),
|
|
41
|
+
// Every 2 seconds
|
|
42
|
+
registerTask(_containertokens.DITokens.printerWebsocketTask, _taskpresets.TASK_PRESETS.PERIODIC, 2000, true),
|
|
43
|
+
// Every 15 seconds
|
|
44
|
+
registerTask(_containertokens.DITokens.printerWebsocketRestoreTask, _taskpresets.TASK_PRESETS.PERIODIC, 15 * 1000, false)
|
|
45
|
+
];
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
//# sourceMappingURL=tasks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/tasks.ts"],"names":["ServerTasks","registerTask","task","preset","milliseconds","runImmediately","timingPreset","id","name","SERVER_BOOT_TASK","DITokens","bootTask","TaskPresets","PERIODIC_DISABLED","BOOT_TASKS","softwareUpdateTask","RUNDELAYED","clientDistDownloadTask","RUNONCE","socketIoTask","PERIODIC","printCompletionSocketIoTask","printerFileCleanTask","printerWebsocketTask","printerWebsocketRestoreTask"],"mappings":";;;;;;;;;;;IAsBaA,WAAW;eAAXA;;IAXGC,YAAY;eAAZA;;;6BAX4B;iCACnB;AAUlB,SAASA,aAAaC,IAAI,EAAEC,MAAM,EAAEC,eAAe,CAAC,EAAEC,iBAAiB,KAAK;IACjF,IAAIC,eAAe;QAAE,GAAGH,MAAM;IAAC;IAC/BG,aAAaF,YAAY,GAAGD,OAAOC,YAAY,IAAIA;IACnDE,aAAaD,cAAc,GAAGA,iBAAiB;IAC/C,OAAO;QACLE,IAAIL,KAAKM,IAAI,IAAIN;QACjBA;QACAC,QAAQG;IACV;AACF;AAEO,MAAMN;IACX,OAAOS,mBAAmBR,aAAaS,yBAAQ,CAACC,QAAQ,EAAEC,yBAAW,CAACC,iBAAiB,EAAE,MAAM,OAAO;IACtG,OAAOC,aAAa;QAClBb,aAAaS,yBAAQ,CAACK,kBAAkB,EAAEH,yBAAW,CAACI,UAAU,EAAE;QAClEf,aAAaS,yBAAQ,CAACO,sBAAsB,EAAEL,yBAAW,CAACM,OAAO;QACjEjB,aAAaS,yBAAQ,CAACS,YAAY,EAAEP,yBAAW,CAACQ,QAAQ,EAAE;QAC1DnB,aAAaS,yBAAQ,CAACW,2BAA2B,EAAET,yBAAW,CAACM,OAAO;QACtEjB,aAAaS,yBAAQ,CAACY,oBAAoB,EAAEV,yBAAW,CAACM,OAAO,EAAE,KAAK,MAAM;QAC5E,kBAAkB;QAClBjB,aAAaS,yBAAQ,CAACa,oBAAoB,EAAEX,yBAAW,CAACQ,QAAQ,EAAE,MAAM;QACxE,mBAAmB;QACnBnB,aAAaS,yBAAQ,CAACc,2BAA2B,EAAEZ,yBAAW,CAACQ,QAAQ,EAAE,KAAK,MAAM;KACrF,CAAC;AACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/types/express/index.d.ts"],"names":[],"mappings":"AAAA,2DAA2D"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
distinct: function() {
|
|
13
|
+
return distinct;
|
|
14
|
+
},
|
|
15
|
+
groupArrayBy: function() {
|
|
16
|
+
return groupArrayBy;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
const groupArrayBy = (array, predicate)=>array.reduce((acc, value, index, array)=>{
|
|
20
|
+
(acc[predicate(value, index, array)] ||= []).push(value);
|
|
21
|
+
return acc;
|
|
22
|
+
}, {});
|
|
23
|
+
const distinct = (value, index, self)=>{
|
|
24
|
+
return self.indexOf(value) === index;
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
//# sourceMappingURL=array.util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/utils/array.util.ts"],"names":["distinct","groupArrayBy","array","predicate","reduce","acc","value","index","push","self","indexOf"],"mappings":";;;;;;;;;;;IAMaA,QAAQ;eAARA;;IANAC,YAAY;eAAZA;;;AAAN,MAAMA,eAAe,CAAIC,OAAYC,YAC1CD,MAAME,MAAM,CAAC,CAACC,KAAKC,OAAOC,OAAOL;QAC9BG,CAAAA,GAAG,CAACF,UAAUG,OAAOC,OAAOL,OAAO,KAAK,EAAE,AAAD,EAAGM,IAAI,CAACF;QAClD,OAAOD;IACT,GAAG,CAAC;AAEC,MAAML,WAAW,CAACM,OAAYC,OAAeE;IAClD,OAAOA,KAAKC,OAAO,CAACJ,WAAWC;AACjC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
bench: function() {
|
|
13
|
+
return bench;
|
|
14
|
+
},
|
|
15
|
+
noop: function() {
|
|
16
|
+
return noop;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
const _logger = require("../handlers/logger");
|
|
20
|
+
const logger = new _logger.LoggerService("BenchmarkUtil");
|
|
21
|
+
async function bench(cb, report = false) {
|
|
22
|
+
const beforeTime = Date.now();
|
|
23
|
+
let result;
|
|
24
|
+
try {
|
|
25
|
+
result = await cb();
|
|
26
|
+
} catch (e) {
|
|
27
|
+
logger.error(e);
|
|
28
|
+
}
|
|
29
|
+
const afterTime = Date.now();
|
|
30
|
+
if (!!report) {
|
|
31
|
+
return {
|
|
32
|
+
result,
|
|
33
|
+
time: afterTime - beforeTime
|
|
34
|
+
};
|
|
35
|
+
} else return result;
|
|
36
|
+
}
|
|
37
|
+
function noop() {}
|
|
38
|
+
|
|
39
|
+
//# sourceMappingURL=benchmark.util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/utils/benchmark.util.ts"],"names":["bench","noop","logger","LoggerService","cb","report","beforeTime","Date","now","result","e","error","afterTime","time"],"mappings":";;;;;;;;;;;IAWsBA,KAAK;eAALA;;IAkBNC,IAAI;eAAJA;;;wBA7Bc;AAE9B,MAAMC,SAAS,IAAIC,qBAAa,CAAC;AAS1B,eAAeH,MAAMI,EAAE,EAAEC,SAAS,KAAK;IAC5C,MAAMC,aAAaC,KAAKC,GAAG;IAC3B,IAAIC;IACJ,IAAI;QACFA,SAAS,MAAML;IACjB,EAAE,OAAOM,GAAG;QACVR,OAAOS,KAAK,CAACD;IACf;IACA,MAAME,YAAYL,KAAKC,GAAG;IAE1B,IAAI,CAAC,CAACH,QAAQ;QACZ,OAAO;YACLI;YACAI,MAAMD,YAAYN;QACpB;IACF,OAAO,OAAOG;AAChB;AAEO,SAASR,QAAQ"}
|