@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.
Files changed (377) hide show
  1. package/.env +19 -0
  2. package/.env.template +43 -0
  3. package/.gitattributes +1 -0
  4. package/.idea/codeStyles/Project.xml +85 -0
  5. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  6. package/.idea/dbnavigator.xml +574 -0
  7. package/.idea/fdm-monster.iml +16 -0
  8. package/.idea/inspectionProfiles/Project_Default.xml +22 -0
  9. package/.idea/jsLibraryMappings.xml +6 -0
  10. package/.idea/modules.xml +12 -0
  11. package/.idea/prettier.xml +6 -0
  12. package/.idea/vcs.xml +17 -0
  13. package/.swcrc +33 -0
  14. package/CODE_OF_CONDUCT.md +46 -0
  15. package/CONTRIBUTING.md +134 -0
  16. package/LICENSE +661 -0
  17. package/README.md +149 -0
  18. package/SECURITY.md +16 -0
  19. package/dist/@type/express/index.d.js +7 -0
  20. package/dist/@type/express/index.d.js.map +1 -0
  21. package/dist/constants/authorization.constants.js +99 -0
  22. package/dist/constants/authorization.constants.js.map +1 -0
  23. package/dist/constants/event.constants.js +55 -0
  24. package/dist/constants/event.constants.js.map +1 -0
  25. package/dist/constants/http-status-codes.constants.js +268 -0
  26. package/dist/constants/http-status-codes.constants.js.map +1 -0
  27. package/dist/constants/server-settings.constants.js +119 -0
  28. package/dist/constants/server-settings.constants.js.map +1 -0
  29. package/dist/constants/service.constants.js +48 -0
  30. package/dist/constants/service.constants.js.map +1 -0
  31. package/dist/container.js +161 -0
  32. package/dist/container.js.map +1 -0
  33. package/dist/container.tokens.js +83 -0
  34. package/dist/container.tokens.js.map +1 -0
  35. package/dist/controllers/auth.controller.js +143 -0
  36. package/dist/controllers/auth.controller.js.map +1 -0
  37. package/dist/controllers/batch-call.controller.js +59 -0
  38. package/dist/controllers/batch-call.controller.js.map +1 -0
  39. package/dist/controllers/camera-stream.controller.js +57 -0
  40. package/dist/controllers/camera-stream.controller.js.map +1 -0
  41. package/dist/controllers/custom-gcode.controller.js +76 -0
  42. package/dist/controllers/custom-gcode.controller.js.map +1 -0
  43. package/dist/controllers/first-time-setup.controller.js +65 -0
  44. package/dist/controllers/first-time-setup.controller.js.map +1 -0
  45. package/dist/controllers/floor.controller.js +78 -0
  46. package/dist/controllers/floor.controller.js.map +1 -0
  47. package/dist/controllers/plugin-firmware-update.controller.js +140 -0
  48. package/dist/controllers/plugin-firmware-update.controller.js.map +1 -0
  49. package/dist/controllers/print-completion.controller.js +58 -0
  50. package/dist/controllers/print-completion.controller.js.map +1 -0
  51. package/dist/controllers/printer-files.controller.js +208 -0
  52. package/dist/controllers/printer-files.controller.js.map +1 -0
  53. package/dist/controllers/printer-settings.controller.js +58 -0
  54. package/dist/controllers/printer-settings.controller.js.map +1 -0
  55. package/dist/controllers/printer.controller.js +287 -0
  56. package/dist/controllers/printer.controller.js.map +1 -0
  57. package/dist/controllers/server-private.controller.js +122 -0
  58. package/dist/controllers/server-private.controller.js.map +1 -0
  59. package/dist/controllers/server-public.controller.js +140 -0
  60. package/dist/controllers/server-public.controller.js.map +1 -0
  61. package/dist/controllers/settings.controller.js +89 -0
  62. package/dist/controllers/settings.controller.js.map +1 -0
  63. package/dist/controllers/user.controller.js +137 -0
  64. package/dist/controllers/user.controller.js.map +1 -0
  65. package/dist/controllers/validation/auth-controller.validation.js +15 -0
  66. package/dist/controllers/validation/auth-controller.validation.js.map +1 -0
  67. package/dist/controllers/validation/batch-controller.validation.js +29 -0
  68. package/dist/controllers/validation/batch-controller.validation.js.map +1 -0
  69. package/dist/controllers/validation/generic.validation.js +15 -0
  70. package/dist/controllers/validation/generic.validation.js.map +1 -0
  71. package/dist/controllers/validation/printer-controller.validation.js +66 -0
  72. package/dist/controllers/validation/printer-controller.validation.js.map +1 -0
  73. package/dist/controllers/validation/printer-files-controller.validation.js +66 -0
  74. package/dist/controllers/validation/printer-files-controller.validation.js.map +1 -0
  75. package/dist/controllers/validation/printer-settings-controller.validation.js +15 -0
  76. package/dist/controllers/validation/printer-settings-controller.validation.js.map +1 -0
  77. package/dist/controllers/validation/setting.validation.js +19 -0
  78. package/dist/controllers/validation/setting.validation.js.map +1 -0
  79. package/dist/controllers/validation/user-controller.validation.js +16 -0
  80. package/dist/controllers/validation/user-controller.validation.js.map +1 -0
  81. package/dist/exceptions/job.exceptions.js +18 -0
  82. package/dist/exceptions/job.exceptions.js.map +1 -0
  83. package/dist/exceptions/runtime.exceptions.js +108 -0
  84. package/dist/exceptions/runtime.exceptions.js.map +1 -0
  85. package/dist/handlers/cache-manager.js +25 -0
  86. package/dist/handlers/cache-manager.js.map +1 -0
  87. package/dist/handlers/event-emitter.js +31 -0
  88. package/dist/handlers/event-emitter.js.map +1 -0
  89. package/dist/handlers/logger-factory.js +18 -0
  90. package/dist/handlers/logger-factory.js.map +1 -0
  91. package/dist/handlers/logger.js +85 -0
  92. package/dist/handlers/logger.js.map +1 -0
  93. package/dist/handlers/validators.js +131 -0
  94. package/dist/handlers/validators.js.map +1 -0
  95. package/dist/index.js +19 -0
  96. package/dist/index.js.map +1 -0
  97. package/dist/middleware/authenticate.js +83 -0
  98. package/dist/middleware/authenticate.js.map +1 -0
  99. package/dist/middleware/database.js +26 -0
  100. package/dist/middleware/database.js.map +1 -0
  101. package/dist/middleware/exception.handler.js +96 -0
  102. package/dist/middleware/exception.handler.js.map +1 -0
  103. package/dist/middleware/global.middleware.js +58 -0
  104. package/dist/middleware/global.middleware.js.map +1 -0
  105. package/dist/middleware/passport.js +44 -0
  106. package/dist/middleware/passport.js.map +1 -0
  107. package/dist/middleware/printer.js +49 -0
  108. package/dist/middleware/printer.js.map +1 -0
  109. package/dist/migrations/1696187882312-PrinterFile.js +40 -0
  110. package/dist/migrations/1696187882312-PrinterFile.js.map +1 -0
  111. package/dist/models/Auth/Permission.js +20 -0
  112. package/dist/models/Auth/Permission.js.map +1 -0
  113. package/dist/models/Auth/RefreshToken.js +41 -0
  114. package/dist/models/Auth/RefreshToken.js.map +1 -0
  115. package/dist/models/Auth/Role.js +20 -0
  116. package/dist/models/Auth/Role.js.map +1 -0
  117. package/dist/models/Auth/User.js +51 -0
  118. package/dist/models/Auth/User.js.map +1 -0
  119. package/dist/models/CameraStream.js +59 -0
  120. package/dist/models/CameraStream.js.map +1 -0
  121. package/dist/models/CustomGcode.js +28 -0
  122. package/dist/models/CustomGcode.js.map +1 -0
  123. package/dist/models/Floor.js +33 -0
  124. package/dist/models/Floor.js.map +1 -0
  125. package/dist/models/FloorPrinter.js +29 -0
  126. package/dist/models/FloorPrinter.js.map +1 -0
  127. package/dist/models/PrintCompletion.js +40 -0
  128. package/dist/models/PrintCompletion.js.map +1 -0
  129. package/dist/models/Printer.js +113 -0
  130. package/dist/models/Printer.js.map +1 -0
  131. package/dist/models/ServerSettings.js +168 -0
  132. package/dist/models/ServerSettings.js.map +1 -0
  133. package/dist/models/Settings.js +168 -0
  134. package/dist/models/Settings.js.map +1 -0
  135. package/dist/models/index.js +54 -0
  136. package/dist/models/index.js.map +1 -0
  137. package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js +49 -0
  138. package/dist/mongo-migrations/20210713120034-printers-settingsapperance-apikey.js.map +1 -0
  139. package/dist/mongo-migrations/20210907173950-printers-enabled.js +39 -0
  140. package/dist/mongo-migrations/20210907173950-printers-enabled.js.map +1 -0
  141. package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js +39 -0
  142. package/dist/mongo-migrations/20211029110742-user-password-passwordhash.js.map +1 -0
  143. package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js +60 -0
  144. package/dist/mongo-migrations/20230414141005-floor-remove-groupinfloor.js.map +1 -0
  145. package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js +30 -0
  146. package/dist/mongo-migrations/20230427202911-printer-remove-sortindex.js.map +1 -0
  147. package/dist/mongo-migrations/20230716065316-user-remove-name.js +30 -0
  148. package/dist/mongo-migrations/20230716065316-user-remove-name.js.map +1 -0
  149. package/dist/nodemon_restart_trigger.js +4 -0
  150. package/dist/nodemon_restart_trigger.js.map +1 -0
  151. package/dist/server.constants.js +99 -0
  152. package/dist/server.constants.js.map +1 -0
  153. package/dist/server.core.js +91 -0
  154. package/dist/server.core.js.map +1 -0
  155. package/dist/server.env.js +225 -0
  156. package/dist/server.env.js.map +1 -0
  157. package/dist/server.host.js +106 -0
  158. package/dist/server.host.js.map +1 -0
  159. package/dist/services/authentication/auth.service.js +136 -0
  160. package/dist/services/authentication/auth.service.js.map +1 -0
  161. package/dist/services/authentication/jwt.service.js +34 -0
  162. package/dist/services/authentication/jwt.service.js.map +1 -0
  163. package/dist/services/authentication/permission.service.js +73 -0
  164. package/dist/services/authentication/permission.service.js.map +1 -0
  165. package/dist/services/authentication/refresh-token.service.js +99 -0
  166. package/dist/services/authentication/refresh-token.service.js.map +1 -0
  167. package/dist/services/authentication/role.service.js +120 -0
  168. package/dist/services/authentication/role.service.js.map +1 -0
  169. package/dist/services/authentication/user.service.js +154 -0
  170. package/dist/services/authentication/user.service.js.map +1 -0
  171. package/dist/services/batch-call.service.js +148 -0
  172. package/dist/services/batch-call.service.js.map +1 -0
  173. package/dist/services/camera-stream.service.js +80 -0
  174. package/dist/services/camera-stream.service.js.map +1 -0
  175. package/dist/services/core/client-bundle.service.js +156 -0
  176. package/dist/services/core/client-bundle.service.js.map +1 -0
  177. package/dist/services/core/config.service.js +26 -0
  178. package/dist/services/core/config.service.js.map +1 -0
  179. package/dist/services/core/github.service.js +74 -0
  180. package/dist/services/core/github.service.js.map +1 -0
  181. package/dist/services/core/logs-manager.service.js +87 -0
  182. package/dist/services/core/logs-manager.service.js.map +1 -0
  183. package/dist/services/core/monsterpi.service.js +38 -0
  184. package/dist/services/core/monsterpi.service.js.map +1 -0
  185. package/dist/services/core/multer.service.js +122 -0
  186. package/dist/services/core/multer.service.js.map +1 -0
  187. package/dist/services/core/server-release.service.js +116 -0
  188. package/dist/services/core/server-release.service.js.map +1 -0
  189. package/dist/services/core/server-update.service.js +73 -0
  190. package/dist/services/core/server-update.service.js.map +1 -0
  191. package/dist/services/core/task-manager.service.js +196 -0
  192. package/dist/services/core/task-manager.service.js.map +1 -0
  193. package/dist/services/core/yaml.service.js +278 -0
  194. package/dist/services/core/yaml.service.js.map +1 -0
  195. package/dist/services/custom-gcode.service.js +48 -0
  196. package/dist/services/custom-gcode.service.js.map +1 -0
  197. package/dist/services/floor.service.js +183 -0
  198. package/dist/services/floor.service.js.map +1 -0
  199. package/dist/services/influxdb-v2/influx-db-v2-base.service.js +45 -0
  200. package/dist/services/influxdb-v2/influx-db-v2-base.service.js.map +1 -0
  201. package/dist/services/interfaces/auth.service.interface.js +6 -0
  202. package/dist/services/interfaces/auth.service.interface.js.map +1 -0
  203. package/dist/services/interfaces/camera-stream.dto.js +109 -0
  204. package/dist/services/interfaces/camera-stream.dto.js.map +1 -0
  205. package/dist/services/interfaces/camera-stream.service.interface.js +6 -0
  206. package/dist/services/interfaces/camera-stream.service.interface.js.map +1 -0
  207. package/dist/services/interfaces/custom-gcode.dto.js +18 -0
  208. package/dist/services/interfaces/custom-gcode.dto.js.map +1 -0
  209. package/dist/services/interfaces/custom-gcode.service.interface.js +6 -0
  210. package/dist/services/interfaces/custom-gcode.service.interface.js.map +1 -0
  211. package/dist/services/interfaces/floor.dto.js +61 -0
  212. package/dist/services/interfaces/floor.dto.js.map +1 -0
  213. package/dist/services/interfaces/floor.service.interface.js +6 -0
  214. package/dist/services/interfaces/floor.service.interface.js.map +1 -0
  215. package/dist/services/interfaces/gcode-analysis.dto.js +6 -0
  216. package/dist/services/interfaces/gcode-analysis.dto.js.map +1 -0
  217. package/dist/services/interfaces/jwt.service.interface.js +6 -0
  218. package/dist/services/interfaces/jwt.service.interface.js.map +1 -0
  219. package/dist/services/interfaces/login.dto.js +16 -0
  220. package/dist/services/interfaces/login.dto.js.map +1 -0
  221. package/dist/services/interfaces/page.interface.js +16 -0
  222. package/dist/services/interfaces/page.interface.js.map +1 -0
  223. package/dist/services/interfaces/permission.dto.js +16 -0
  224. package/dist/services/interfaces/permission.dto.js.map +1 -0
  225. package/dist/services/interfaces/permission.service.interface.js +6 -0
  226. package/dist/services/interfaces/permission.service.interface.js.map +1 -0
  227. package/dist/services/interfaces/printer-file.dto.js +27 -0
  228. package/dist/services/interfaces/printer-file.dto.js.map +1 -0
  229. package/dist/services/interfaces/printer-files.service.interface.js +6 -0
  230. package/dist/services/interfaces/printer-files.service.interface.js.map +1 -0
  231. package/dist/services/interfaces/printer.dto.js +18 -0
  232. package/dist/services/interfaces/printer.dto.js.map +1 -0
  233. package/dist/services/interfaces/printer.service.interface.js +6 -0
  234. package/dist/services/interfaces/printer.service.interface.js.map +1 -0
  235. package/dist/services/interfaces/role-service.interface.js +6 -0
  236. package/dist/services/interfaces/role-service.interface.js.map +1 -0
  237. package/dist/services/interfaces/settings.dto.js +34 -0
  238. package/dist/services/interfaces/settings.dto.js.map +1 -0
  239. package/dist/services/interfaces/settings.service.interface.js +6 -0
  240. package/dist/services/interfaces/settings.service.interface.js.map +1 -0
  241. package/dist/services/interfaces/user-service.interface.js +6 -0
  242. package/dist/services/interfaces/user-service.interface.js.map +1 -0
  243. package/dist/services/interfaces/user.dto.js +39 -0
  244. package/dist/services/interfaces/user.dto.js.map +1 -0
  245. package/dist/services/octoprint/constants/firmware-update-settings.constants.js +32 -0
  246. package/dist/services/octoprint/constants/firmware-update-settings.constants.js.map +1 -0
  247. package/dist/services/octoprint/constants/octoprint-service.constants.js +101 -0
  248. package/dist/services/octoprint/constants/octoprint-service.constants.js.map +1 -0
  249. package/dist/services/octoprint/constants/octoprint-websocket.constants.js +88 -0
  250. package/dist/services/octoprint/constants/octoprint-websocket.constants.js.map +1 -0
  251. package/dist/services/octoprint/octoprint-api.routes.js +192 -0
  252. package/dist/services/octoprint/octoprint-api.routes.js.map +1 -0
  253. package/dist/services/octoprint/octoprint-api.service.js +402 -0
  254. package/dist/services/octoprint/octoprint-api.service.js.map +1 -0
  255. package/dist/services/octoprint/octoprint-sockio.adapter.js +309 -0
  256. package/dist/services/octoprint/octoprint-sockio.adapter.js.map +1 -0
  257. package/dist/services/octoprint/plugin-base.service.js +102 -0
  258. package/dist/services/octoprint/plugin-base.service.js.map +1 -0
  259. package/dist/services/octoprint/plugin-firmware-update.service.js +104 -0
  260. package/dist/services/octoprint/plugin-firmware-update.service.js.map +1 -0
  261. package/dist/services/octoprint/plugin-repository.cache.js +45 -0
  262. package/dist/services/octoprint/plugin-repository.cache.js.map +1 -0
  263. package/dist/services/octoprint/socket.factory.js +22 -0
  264. package/dist/services/octoprint/socket.factory.js.map +1 -0
  265. package/dist/services/octoprint/utils/api.utils.js +72 -0
  266. package/dist/services/octoprint/utils/api.utils.js.map +1 -0
  267. package/dist/services/orm/floor.service.interface.js +73 -0
  268. package/dist/services/orm/floor.service.interface.js.map +1 -0
  269. package/dist/services/orm/printer.service.interface.js +6 -0
  270. package/dist/services/orm/printer.service.interface.js.map +1 -0
  271. package/dist/services/print-completion.service.js +162 -0
  272. package/dist/services/print-completion.service.js.map +1 -0
  273. package/dist/services/printer-files.service.js +91 -0
  274. package/dist/services/printer-files.service.js.map +1 -0
  275. package/dist/services/printer.service.js +230 -0
  276. package/dist/services/printer.service.js.map +1 -0
  277. package/dist/services/settings.service.js +158 -0
  278. package/dist/services/settings.service.js.map +1 -0
  279. package/dist/services/validators/floor-service.validation.js +60 -0
  280. package/dist/services/validators/floor-service.validation.js.map +1 -0
  281. package/dist/services/validators/print-completion-service.validation.js +20 -0
  282. package/dist/services/validators/print-completion-service.validation.js.map +1 -0
  283. package/dist/services/validators/printer-service.validation.js +48 -0
  284. package/dist/services/validators/printer-service.validation.js.map +1 -0
  285. package/dist/services/validators/settings-service.validation.js +71 -0
  286. package/dist/services/validators/settings-service.validation.js.map +1 -0
  287. package/dist/services/validators/user-service.validation.js +33 -0
  288. package/dist/services/validators/user-service.validation.js.map +1 -0
  289. package/dist/services/validators/yaml-service.validation.js +63 -0
  290. package/dist/services/validators/yaml-service.validation.js.map +1 -0
  291. package/dist/services/yaml.service.js +278 -0
  292. package/dist/services/yaml.service.js.map +1 -0
  293. package/dist/shared.constants.js +15 -0
  294. package/dist/shared.constants.js.map +1 -0
  295. package/dist/state/file-upload-tracker.cache.js +88 -0
  296. package/dist/state/file-upload-tracker.cache.js.map +1 -0
  297. package/dist/state/file.cache.js +99 -0
  298. package/dist/state/file.cache.js.map +1 -0
  299. package/dist/state/files.store.js +132 -0
  300. package/dist/state/files.store.js.map +1 -0
  301. package/dist/state/floor.store.js +99 -0
  302. package/dist/state/floor.store.js.map +1 -0
  303. package/dist/state/printer-events.cache.js +97 -0
  304. package/dist/state/printer-events.cache.js.map +1 -0
  305. package/dist/state/printer-socket.store.js +217 -0
  306. package/dist/state/printer-socket.store.js.map +1 -0
  307. package/dist/state/printer.cache.js +112 -0
  308. package/dist/state/printer.cache.js.map +1 -0
  309. package/dist/state/settings.store.js +154 -0
  310. package/dist/state/settings.store.js.map +1 -0
  311. package/dist/state/socket-io.gateway.js +66 -0
  312. package/dist/state/socket-io.gateway.js.map +1 -0
  313. package/dist/state/test-printer-socket.store.js +91 -0
  314. package/dist/state/test-printer-socket.store.js.map +1 -0
  315. package/dist/state/validation/create-test-printer.validation.js +18 -0
  316. package/dist/state/validation/create-test-printer.validation.js.map +1 -0
  317. package/dist/task.presets.js +50 -0
  318. package/dist/task.presets.js.map +1 -0
  319. package/dist/tasks/boot.task.js +198 -0
  320. package/dist/tasks/boot.task.js.map +1 -0
  321. package/dist/tasks/client-bundle.task.js +32 -0
  322. package/dist/tasks/client-bundle.task.js.map +1 -0
  323. package/dist/tasks/print-completion.socketio.task.js +85 -0
  324. package/dist/tasks/print-completion.socketio.task.js.map +1 -0
  325. package/dist/tasks/printer-file-clean.task.js +72 -0
  326. package/dist/tasks/printer-file-clean.task.js.map +1 -0
  327. package/dist/tasks/printer-websocket-restore.task.js +64 -0
  328. package/dist/tasks/printer-websocket-restore.task.js.map +1 -0
  329. package/dist/tasks/printer-websocket.task.js +43 -0
  330. package/dist/tasks/printer-websocket.task.js.map +1 -0
  331. package/dist/tasks/socketio.task.js +83 -0
  332. package/dist/tasks/socketio.task.js.map +1 -0
  333. package/dist/tasks/software-update.task.js +22 -0
  334. package/dist/tasks/software-update.task.js.map +1 -0
  335. package/dist/tasks.js +48 -0
  336. package/dist/tasks.js.map +1 -0
  337. package/dist/types/express/index.d.js +7 -0
  338. package/dist/types/express/index.d.js.map +1 -0
  339. package/dist/utils/array.util.js +27 -0
  340. package/dist/utils/array.util.js.map +1 -0
  341. package/dist/utils/benchmark.util.js +39 -0
  342. package/dist/utils/benchmark.util.js.map +1 -0
  343. package/dist/utils/cache/key-diff.cache.js +128 -0
  344. package/dist/utils/cache/key-diff.cache.js.map +1 -0
  345. package/dist/utils/correlation-token.util.js +15 -0
  346. package/dist/utils/correlation-token.util.js.map +1 -0
  347. package/dist/utils/crypto.utils.js +29 -0
  348. package/dist/utils/crypto.utils.js.map +1 -0
  349. package/dist/utils/env.utils.js +98 -0
  350. package/dist/utils/env.utils.js.map +1 -0
  351. package/dist/utils/error.utils.js +15 -0
  352. package/dist/utils/error.utils.js.map +1 -0
  353. package/dist/utils/find-predicate.utils.js +18 -0
  354. package/dist/utils/find-predicate.utils.js.map +1 -0
  355. package/dist/utils/fs.utils.js +38 -0
  356. package/dist/utils/fs.utils.js.map +1 -0
  357. package/dist/utils/is-docker.js +40 -0
  358. package/dist/utils/is-docker.js.map +1 -0
  359. package/dist/utils/mapper.utils.js +33 -0
  360. package/dist/utils/mapper.utils.js.map +1 -0
  361. package/dist/utils/metric.utils.js +35 -0
  362. package/dist/utils/metric.utils.js.map +1 -0
  363. package/dist/utils/normalize-url.js +245 -0
  364. package/dist/utils/normalize-url.js.map +1 -0
  365. package/dist/utils/semver.utils.js +18 -0
  366. package/dist/utils/semver.utils.js.map +1 -0
  367. package/dist/utils/time.utils.js +26 -0
  368. package/dist/utils/time.utils.js.map +1 -0
  369. package/dist/utils/url.utils.js +33 -0
  370. package/dist/utils/url.utils.js.map +1 -0
  371. package/dist/utils/websocket.adapter.js +105 -0
  372. package/dist/utils/websocket.adapter.js.map +1 -0
  373. package/migrate-mongo-config.js +45 -0
  374. package/nodemon_restart_trigger.js +1 -0
  375. package/package.json +149 -0
  376. package/src/index.ts +19 -0
  377. 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":";;;;+BASaA;;;eAAAA;;;gCAT0D;6CAC3C;sCACa;iCACI;AAMtC,MAAMA;IACXC,cAA6B;IAC7BC,gBAAiC;IACjCC,OAAsB;IACtBC,uBAA+C;IAE/CC,eAAe,CAAC,EAAE;IAElBC,YAAY,EACVL,aAAa,EACbC,eAAe,EACfE,sBAAsB,EACtBG,aAAa,EAMd,CAAE;QACD,IAAI,CAACN,aAAa,GAAGA;QACrB,IAAI,CAACC,eAAe,GAAGA;QACvB,IAAI,CAACE,sBAAsB,GAAGA;QAC9B,IAAI,CAACD,MAAM,GAAGI,cAAcP,4BAA4BQ,IAAI;QAE5D,IAAIC,OAAO,IAAI;QACf,IAAI,CAACR,aAAa,CAACS,EAAE,CAACC,IAAAA,uCAAuB,EAAC,MAAM,eAAgBC,cAAc,EAAEC,IAAI;YACtF,MAAMJ,KAAKK,aAAa,CAAC,IAAI,CAACC,KAAK,EAAEH,gBAAgBC;QACvD;IACF;IAEA,IAAIG,WAAW;QACb,OAAO,IAAI,CAACX,YAAY;IAC1B;IAEA,MAAMS,cAAcG,QAAQ,EAAEL,cAAc,EAAEC,IAAI,EAAE;QAClD,+BAA+B;QAC/B,MAAMK,YAAYD,SAASE,OAAO,CAAC,cAAc;QACjD,IAAI,CAACD,WAAW;YACd,IAAI,CAACf,MAAM,CAACiB,GAAG,CAAC,CAAC,4CAA4C,EAAEH,SAAS,CAAC;QAC3E;QAEA,IAAIL,mBAAmB,SAAS;YAC9B;QACF;QAEA,MAAMS,aAAa;YACjBC,QAAQT,KAAKU,IAAI;YACjBC,UAAUX,KAAKY,OAAO,EAAEjB;YACxBkB,WAAWC,KAAKC,GAAG;YACnBC,eAAehB,KAAKY,OAAO,EAAEK;YAC7BZ,WAAWA;QACb;QAEA,IAAI,CAAChB,eAAe,CAAC6B,IAAI,CAACC,4BAAW,CAACC,eAAe,EAAEC,KAAKC,SAAS,CAAC;YAAElB;YAAUL;YAAgBC;QAAK;QAEvG,IACEA,KAAKU,IAAI,KAAKa,wCAAW,CAACC,KAAK,IAC/BxB,KAAKU,IAAI,KAAKa,wCAAW,CAACE,eAAe,IACzCzB,KAAKU,IAAI,KAAKa,wCAAW,CAACG,cAAc,IACxC1B,KAAKU,IAAI,KAAKa,wCAAW,CAACI,IAAI,IAC9B3B,KAAKU,IAAI,KAAKa,wCAAW,CAACK,eAAe,IACzC5B,KAAKU,IAAI,KAAKa,wCAAW,CAACM,YAAY,IACtC7B,KAAKU,IAAI,KAAKa,wCAAW,CAACO,aAAa,IACvC9B,KAAKU,IAAI,KAAKa,wCAAW,CAACQ,YAAY,IACtC/B,KAAKU,IAAI,KAAKa,wCAAW,CAACS,uBAAuB,IACjDhC,KAAKU,IAAI,KAAKa,wCAAW,CAACU,wBAAwB,IAClDjC,KAAKU,IAAI,KAAKa,wCAAW,CAACW,KAAK,EAC/B;YACA,IAAI,CAAC1C,YAAY,CAACa,UAAU,GAAG;gBAC7B,GAAG,IAAI,CAACb,YAAY,CAACa,UAAU;gBAC/B,CAACL,KAAKU,IAAI,CAAC,EAAEF;YACf;YAEA,MAAM2B,SAAS,IAAI,CAAC3C,YAAY,CAACa,UAAU,CAAC+B,aAAa;YACzD,MAAM,IAAI,CAAC7C,sBAAsB,CAAC8C,aAAa,CAACF,QAAQ,IAAI,CAAC3C,YAAY,CAACa,UAAU;YACpF;QACF;QAEA,IAAIL,KAAKU,IAAI,KAAKa,wCAAW,CAACe,YAAY,EAAE;YAC1C,4CAA4C;YAC5C,IAAI,CAAC9C,YAAY,CAACa,UAAU,GAAG;gBAC7B+B,eAAeG,IAAAA,8CAAwB;YACzC;YACA/B,WAAWgC,OAAO,GAAG,IAAI,CAAChD,YAAY,CAACa,UAAU;YACjD,MAAM,IAAI,CAACd,sBAAsB,CAACkD,MAAM,CAACjC;QAC3C,OAAO,IAAIR,KAAKU,IAAI,KAAKa,wCAAW,CAACmB,WAAW,IAAI1C,KAAKU,IAAI,KAAKa,wCAAW,CAACoB,SAAS,EAAE;YACvFnC,WAAWgC,OAAO,GAAG,IAAI,CAAChD,YAAY,CAACa,UAAU,IAAI,CAAC;YACtD,MAAM,IAAI,CAACd,sBAAsB,CAACkD,MAAM,CAACjC;YAEzC,IAAI,CAACpB,aAAa,CAACwD,IAAI,CAACC,IAAAA,6CAA6B,EAACxC;YAEtD,wBAAwB;YACxB,IAAI,CAACb,YAAY,CAACa,UAAU,GAAG,CAAC;QAClC;IACF;IAEA,MAAMyC,MAAM;QACV,sDAAsD;QACtD,IAAI,CAACtD,YAAY,GAAG,MAAM,IAAI,CAACD,sBAAsB,CAACwD,iBAAiB;IACzE;AACF"}
@@ -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,7 @@
1
+ // to make the file a module and avoid the TypeScript error
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+
7
+ //# sourceMappingURL=index.d.js.map
@@ -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"}