@fdm-monster/server 2.0.9 → 2.0.11

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 (929) hide show
  1. package/.claude/CLAUDE.md +76 -0
  2. package/.vite-hooks/pre-commit +1 -0
  3. package/.yarn/install-state.gz +0 -0
  4. package/.yarn/releases/yarn-4.13.0.cjs +940 -0
  5. package/.yarnrc.yml +1 -1
  6. package/README.md +1 -1
  7. package/RELEASE_NOTES.MD +24 -0
  8. package/dist/_virtual/_@oxc-project_runtime@0.127.0/helpers/decorate.js +9 -0
  9. package/dist/_virtual/_@oxc-project_runtime@0.127.0/helpers/decorateMetadata.js +6 -0
  10. package/dist/_virtual/_rolldown/runtime.js +13 -0
  11. package/dist/_virtual/_virtual_controllers.js +43 -0
  12. package/dist/consoles/typeorm-create.js +51 -112
  13. package/dist/consoles/typeorm-create.js.map +1 -1
  14. package/dist/consoles/typeorm-generate.js +99 -165
  15. package/dist/consoles/typeorm-generate.js.map +1 -1
  16. package/dist/consoles/typeorm-migrate.js +35 -43
  17. package/dist/consoles/typeorm-migrate.js.map +1 -1
  18. package/dist/constants/authorization.constants.js +75 -97
  19. package/dist/constants/authorization.constants.js.map +1 -1
  20. package/dist/constants/event.constants.js +11 -41
  21. package/dist/constants/event.constants.js.map +1 -1
  22. package/dist/constants/http-status-codes.constants.js +319 -71
  23. package/dist/constants/http-status-codes.constants.js.map +1 -1
  24. package/dist/constants/server-settings.constants.js +45 -87
  25. package/dist/constants/server-settings.constants.js.map +1 -1
  26. package/dist/constants/service.constants.js +3 -21
  27. package/dist/constants/service.constants.js.map +1 -1
  28. package/dist/container.js +167 -181
  29. package/dist/container.js.map +1 -1
  30. package/dist/container.tokens.js +78 -86
  31. package/dist/container.tokens.js.map +1 -1
  32. package/dist/controllers/auth.controller.js +156 -225
  33. package/dist/controllers/auth.controller.js.map +1 -1
  34. package/dist/controllers/batch-call.controller.js +79 -116
  35. package/dist/controllers/batch-call.controller.js.map +1 -1
  36. package/dist/controllers/camera-stream.controller.js +74 -119
  37. package/dist/controllers/camera-stream.controller.js.map +1 -1
  38. package/dist/controllers/dto/update-client-dist.dto.js +8 -15
  39. package/dist/controllers/dto/update-client-dist.dto.js.map +1 -1
  40. package/dist/controllers/file-storage.controller.js +251 -330
  41. package/dist/controllers/file-storage.controller.js.map +1 -1
  42. package/dist/controllers/first-time-setup.controller.js +83 -135
  43. package/dist/controllers/first-time-setup.controller.js.map +1 -1
  44. package/dist/controllers/floor.controller.js +111 -175
  45. package/dist/controllers/floor.controller.js.map +1 -1
  46. package/dist/controllers/metrics.controller.js +27 -53
  47. package/dist/controllers/metrics.controller.js.map +1 -1
  48. package/dist/controllers/print-job.controller.js +366 -451
  49. package/dist/controllers/print-job.controller.js.map +1 -1
  50. package/dist/controllers/print-queue.controller.js +329 -427
  51. package/dist/controllers/print-queue.controller.js.map +1 -1
  52. package/dist/controllers/printer-files.controller.js +244 -305
  53. package/dist/controllers/printer-files.controller.js.map +1 -1
  54. package/dist/controllers/printer-maintenance-log.controller.js +109 -165
  55. package/dist/controllers/printer-maintenance-log.controller.js.map +1 -1
  56. package/dist/controllers/printer-settings.controller.js +50 -81
  57. package/dist/controllers/printer-settings.controller.js.map +1 -1
  58. package/dist/controllers/printer-tag.controller.js +104 -166
  59. package/dist/controllers/printer-tag.controller.js.map +1 -1
  60. package/dist/controllers/printer.controller.js +352 -469
  61. package/dist/controllers/printer.controller.js.map +1 -1
  62. package/dist/controllers/server-private.controller.js +182 -239
  63. package/dist/controllers/server-private.controller.js.map +1 -1
  64. package/dist/controllers/server-public.controller.js +104 -158
  65. package/dist/controllers/server-public.controller.js.map +1 -1
  66. package/dist/controllers/settings.controller.js +229 -364
  67. package/dist/controllers/settings.controller.js.map +1 -1
  68. package/dist/controllers/slicer-compat.controller.js +179 -213
  69. package/dist/controllers/slicer-compat.controller.js.map +1 -1
  70. package/dist/controllers/user.controller.js +226 -348
  71. package/dist/controllers/user.controller.js.map +1 -1
  72. package/dist/controllers/validation/auth-controller.validation.js +5 -14
  73. package/dist/controllers/validation/auth-controller.validation.js.map +1 -1
  74. package/dist/controllers/validation/batch-controller.validation.js +13 -35
  75. package/dist/controllers/validation/batch-controller.validation.js.map +1 -1
  76. package/dist/controllers/validation/generic.validation.js +6 -23
  77. package/dist/controllers/validation/generic.validation.js.map +1 -1
  78. package/dist/controllers/validation/printer-completion-controller.validation.js +5 -14
  79. package/dist/controllers/validation/printer-completion-controller.validation.js.map +1 -1
  80. package/dist/controllers/validation/printer-controller.validation.js +16 -48
  81. package/dist/controllers/validation/printer-controller.validation.js.map +1 -1
  82. package/dist/controllers/validation/printer-files-controller.validation.js +12 -47
  83. package/dist/controllers/validation/printer-files-controller.validation.js.map +1 -1
  84. package/dist/controllers/validation/printer-settings-controller.validation.js +5 -14
  85. package/dist/controllers/validation/printer-settings-controller.validation.js.map +1 -1
  86. package/dist/controllers/validation/server-private.validation.js +7 -14
  87. package/dist/controllers/validation/server-private.validation.js.map +1 -1
  88. package/dist/controllers/validation/setting.validation.js +12 -34
  89. package/dist/controllers/validation/setting.validation.js.map +1 -1
  90. package/dist/controllers/validation/user-controller.validation.js +27 -65
  91. package/dist/controllers/validation/user-controller.validation.js.map +1 -1
  92. package/dist/data-source.js +74 -79
  93. package/dist/data-source.js.map +1 -1
  94. package/dist/entities/camera-stream.entity.js +49 -91
  95. package/dist/entities/camera-stream.entity.js.map +1 -1
  96. package/dist/entities/floor-position.entity.js +38 -75
  97. package/dist/entities/floor-position.entity.js.map +1 -1
  98. package/dist/entities/floor.entity.js +18 -48
  99. package/dist/entities/floor.entity.js.map +1 -1
  100. package/dist/entities/index.js +14 -66
  101. package/dist/entities/print-job.entity.js +114 -196
  102. package/dist/entities/print-job.entity.js.map +1 -1
  103. package/dist/entities/printer-maintenance-log.entity.js +61 -140
  104. package/dist/entities/printer-maintenance-log.entity.js.map +1 -1
  105. package/dist/entities/printer-tag.entity.js +33 -66
  106. package/dist/entities/printer-tag.entity.js.map +1 -1
  107. package/dist/entities/printer.entity.js +67 -124
  108. package/dist/entities/printer.entity.js.map +1 -1
  109. package/dist/entities/refresh-token.entity.js +31 -66
  110. package/dist/entities/refresh-token.entity.js.map +1 -1
  111. package/dist/entities/role.entity.js +16 -45
  112. package/dist/entities/role.entity.js.map +1 -1
  113. package/dist/entities/settings.entity.js +38 -77
  114. package/dist/entities/settings.entity.js.map +1 -1
  115. package/dist/entities/tag.entity.js +19 -43
  116. package/dist/entities/tag.entity.js.map +1 -1
  117. package/dist/entities/user-role.entity.js +30 -67
  118. package/dist/entities/user-role.entity.js.map +1 -1
  119. package/dist/entities/user.entity.js +32 -87
  120. package/dist/entities/user.entity.js.map +1 -1
  121. package/dist/exceptions/failed-dependency.exception.js +11 -18
  122. package/dist/exceptions/failed-dependency.exception.js.map +1 -1
  123. package/dist/exceptions/job.exceptions.js +9 -16
  124. package/dist/exceptions/job.exceptions.js.map +1 -1
  125. package/dist/exceptions/runtime.exceptions.js +82 -110
  126. package/dist/exceptions/runtime.exceptions.js.map +1 -1
  127. package/dist/handlers/event-emitter.js +13 -20
  128. package/dist/handlers/event-emitter.js.map +1 -1
  129. package/dist/handlers/logger-factory.js +7 -14
  130. package/dist/handlers/logger-factory.js.map +1 -1
  131. package/dist/handlers/logger.js +26 -36
  132. package/dist/handlers/logger.js.map +1 -1
  133. package/dist/handlers/logging/file-logging.transport.js +17 -31
  134. package/dist/handlers/logging/file-logging.transport.js.map +1 -1
  135. package/dist/handlers/logging/loki-logging.transport.js +34 -50
  136. package/dist/handlers/logging/loki-logging.transport.js.map +1 -1
  137. package/dist/handlers/logging/static.logger.js +83 -124
  138. package/dist/handlers/logging/static.logger.js.map +1 -1
  139. package/dist/handlers/validators.js +8 -25
  140. package/dist/handlers/validators.js.map +1 -1
  141. package/dist/index.js +23 -26
  142. package/dist/index.js.map +1 -1
  143. package/dist/middleware/authenticate.js +26 -69
  144. package/dist/middleware/authenticate.js.map +1 -1
  145. package/dist/middleware/database.js +16 -22
  146. package/dist/middleware/database.js.map +1 -1
  147. package/dist/middleware/demo.middleware.js +19 -27
  148. package/dist/middleware/demo.middleware.js.map +1 -1
  149. package/dist/middleware/exception.filter.js +109 -126
  150. package/dist/middleware/exception.filter.js.map +1 -1
  151. package/dist/middleware/global.middleware.js +28 -47
  152. package/dist/middleware/global.middleware.js.map +1 -1
  153. package/dist/middleware/param-converter.middleware.js +31 -69
  154. package/dist/middleware/param-converter.middleware.js.map +1 -1
  155. package/dist/middleware/passport.js +38 -64
  156. package/dist/middleware/passport.js.map +1 -1
  157. package/dist/middleware/printer-resolver.js +26 -33
  158. package/dist/middleware/printer-resolver.js.map +1 -1
  159. package/dist/middleware/printer.js +56 -94
  160. package/dist/middleware/printer.js.map +1 -1
  161. package/dist/middleware/slicer-api-key.middleware.js +23 -26
  162. package/dist/middleware/slicer-api-key.middleware.js.map +1 -1
  163. package/dist/middleware/socketio.middleware.js +21 -32
  164. package/dist/middleware/socketio.middleware.js.map +1 -1
  165. package/dist/migrations/1706829146617-InitSqlite.js +84 -91
  166. package/dist/migrations/1706829146617-InitSqlite.js.map +1 -1
  167. package/dist/migrations/1707494762198-PrinterGroup.js +22 -29
  168. package/dist/migrations/1707494762198-PrinterGroup.js.map +1 -1
  169. package/dist/migrations/1708465930665-ChangePrintCompletionDeletePrinterCascade.js +26 -33
  170. package/dist/migrations/1708465930665-ChangePrintCompletionDeletePrinterCascade.js.map +1 -1
  171. package/dist/migrations/1713300747465-ChangeRoleNameUnique.js +27 -34
  172. package/dist/migrations/1713300747465-ChangeRoleNameUnique.js.map +1 -1
  173. package/dist/migrations/1713897879622-AddPrinterType.js +34 -41
  174. package/dist/migrations/1713897879622-AddPrinterType.js.map +1 -1
  175. package/dist/migrations/1720338804844-RemovePrinterFile.js +12 -19
  176. package/dist/migrations/1720338804844-RemovePrinterFile.js.map +1 -1
  177. package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js +26 -33
  178. package/dist/migrations/1745141688926-AddPrinterUsernamePassword.js.map +1 -1
  179. package/dist/migrations/1766576698569-DropPermissions.js +11 -18
  180. package/dist/migrations/1766576698569-DropPermissions.js.map +1 -1
  181. package/dist/migrations/1767278216516-ChangeCameraPrinterOnDeleteSetNull.js +26 -33
  182. package/dist/migrations/1767278216516-ChangeCameraPrinterOnDeleteSetNull.js.map +1 -1
  183. package/dist/migrations/1767279607392-DropCustomGcode.js +12 -19
  184. package/dist/migrations/1767279607392-DropCustomGcode.js.map +1 -1
  185. package/dist/migrations/1767291804417-DropPrintCompletions.js +12 -19
  186. package/dist/migrations/1767291804417-DropPrintCompletions.js.map +1 -1
  187. package/dist/migrations/1767352862576-DropSettingsFileClean.js +18 -25
  188. package/dist/migrations/1767352862576-DropSettingsFileClean.js.map +1 -1
  189. package/dist/migrations/1767355639023-ChangeFloorLevelToOrder.js +26 -33
  190. package/dist/migrations/1767355639023-ChangeFloorLevelToOrder.js.map +1 -1
  191. package/dist/migrations/1767370191762-ChangeFloorNonUniqueOrder.js +18 -25
  192. package/dist/migrations/1767370191762-ChangeFloorNonUniqueOrder.js.map +1 -1
  193. package/dist/migrations/1767432108916-RenameGroupToTag.js +22 -29
  194. package/dist/migrations/1767432108916-RenameGroupToTag.js.map +1 -1
  195. package/dist/migrations/1767451444137-AddPrintJob.js +20 -27
  196. package/dist/migrations/1767451444137-AddPrintJob.js.map +1 -1
  197. package/dist/migrations/1767909428129-AddPrinterMaintenanceLog.js +14 -21
  198. package/dist/migrations/1767909428129-AddPrinterMaintenanceLog.js.map +1 -1
  199. package/dist/plugins/controllers-plugin.js +21 -0
  200. package/dist/plugins/controllers-plugin.js.map +1 -0
  201. package/dist/server.constants.js +79 -91
  202. package/dist/server.constants.js.map +1 -1
  203. package/dist/server.core.js +56 -122
  204. package/dist/server.core.js.map +1 -1
  205. package/dist/server.env.js +56 -121
  206. package/dist/server.env.js.map +1 -1
  207. package/dist/server.host.js +66 -99
  208. package/dist/server.host.js.map +1 -1
  209. package/dist/services/authentication/auth.service.js +103 -126
  210. package/dist/services/authentication/auth.service.js.map +1 -1
  211. package/dist/services/authentication/jwt.service.js +23 -32
  212. package/dist/services/authentication/jwt.service.js.map +1 -1
  213. package/dist/services/bambu/bambu-ftp.adapter.js +194 -236
  214. package/dist/services/bambu/bambu-ftp.adapter.js.map +1 -1
  215. package/dist/services/bambu/bambu-mqtt.adapter.js +394 -449
  216. package/dist/services/bambu/bambu-mqtt.adapter.js.map +1 -1
  217. package/dist/services/bambu/bambu.client.js +64 -65
  218. package/dist/services/bambu/bambu.client.js.map +1 -1
  219. package/dist/services/bambu/mqtt-message.types.js +1 -6
  220. package/dist/services/bambu.api.js +230 -247
  221. package/dist/services/bambu.api.js.map +1 -1
  222. package/dist/services/core/batch-call.service.js +139 -163
  223. package/dist/services/core/batch-call.service.js.map +1 -1
  224. package/dist/services/core/client-bundle.service.js +126 -165
  225. package/dist/services/core/client-bundle.service.js.map +1 -1
  226. package/dist/services/core/config.service.js +16 -26
  227. package/dist/services/core/config.service.js.map +1 -1
  228. package/dist/services/core/cradle.service.js +11 -19
  229. package/dist/services/core/cradle.service.js.map +1 -1
  230. package/dist/services/core/github.service.js +59 -79
  231. package/dist/services/core/github.service.js.map +1 -1
  232. package/dist/services/core/http-client.factory.js +30 -38
  233. package/dist/services/core/http-client.factory.js.map +1 -1
  234. package/dist/services/core/logs-manager.service.js +61 -84
  235. package/dist/services/core/logs-manager.service.js.map +1 -1
  236. package/dist/services/core/monsterpi.service.js +26 -36
  237. package/dist/services/core/monsterpi.service.js.map +1 -1
  238. package/dist/services/core/multer.service.js +69 -129
  239. package/dist/services/core/multer.service.js.map +1 -1
  240. package/dist/services/core/server-release.service.js +77 -99
  241. package/dist/services/core/server-release.service.js.map +1 -1
  242. package/dist/services/core/yaml.service.js +443 -573
  243. package/dist/services/core/yaml.service.js.map +1 -1
  244. package/dist/services/file-analysis.service.js +134 -144
  245. package/dist/services/file-analysis.service.js.map +1 -1
  246. package/dist/services/file-storage.service.js +324 -394
  247. package/dist/services/file-storage.service.js.map +1 -1
  248. package/dist/services/interfaces/auth.service.interface.js +1 -6
  249. package/dist/services/interfaces/camera-stream.dto.js +23 -41
  250. package/dist/services/interfaces/camera-stream.dto.js.map +1 -1
  251. package/dist/services/interfaces/camera-stream.service.interface.js +1 -6
  252. package/dist/services/interfaces/file-upload-tracker.interface.js +1 -6
  253. package/dist/services/interfaces/floor.dto.js +31 -55
  254. package/dist/services/interfaces/floor.dto.js.map +1 -1
  255. package/dist/services/interfaces/floor.service.interface.js +1 -6
  256. package/dist/services/interfaces/jwt.service.interface.js +1 -6
  257. package/dist/services/interfaces/login.dto.js +10 -17
  258. package/dist/services/interfaces/login.dto.js.map +1 -1
  259. package/dist/services/interfaces/page.interface.js +5 -12
  260. package/dist/services/interfaces/page.interface.js.map +1 -1
  261. package/dist/services/interfaces/permission.service.interface.js +1 -6
  262. package/dist/services/interfaces/printer-file.dto.js +1 -6
  263. package/dist/services/interfaces/printer-maintenance-log.dto.js +1 -6
  264. package/dist/services/interfaces/printer-tag.dto.js +11 -26
  265. package/dist/services/interfaces/printer-tag.dto.js.map +1 -1
  266. package/dist/services/interfaces/printer-tag.service.interface.js +1 -6
  267. package/dist/services/interfaces/printer.dto.js +21 -36
  268. package/dist/services/interfaces/printer.dto.js.map +1 -1
  269. package/dist/services/interfaces/printer.service.interface.js +1 -6
  270. package/dist/services/interfaces/refresh-token.dto.js +9 -16
  271. package/dist/services/interfaces/refresh-token.dto.js.map +1 -1
  272. package/dist/services/interfaces/refresh-token.service.interface.js +1 -6
  273. package/dist/services/interfaces/role-service.interface.js +1 -6
  274. package/dist/services/interfaces/role.dto.js +7 -14
  275. package/dist/services/interfaces/role.dto.js.map +1 -1
  276. package/dist/services/interfaces/settings.dto.js +10 -17
  277. package/dist/services/interfaces/settings.dto.js.map +1 -1
  278. package/dist/services/interfaces/settings.service.interface.js +1 -6
  279. package/dist/services/interfaces/tag.dto.js +1 -6
  280. package/dist/services/interfaces/task.interfaces.js +1 -6
  281. package/dist/services/interfaces/user-role.dto.js +9 -16
  282. package/dist/services/interfaces/user-role.dto.js.map +1 -1
  283. package/dist/services/interfaces/user-service.interface.js +1 -6
  284. package/dist/services/interfaces/user.dto.js +22 -37
  285. package/dist/services/interfaces/user.dto.js.map +1 -1
  286. package/dist/services/moonraker/constants/moonraker-event.dto.js +16 -31
  287. package/dist/services/moonraker/constants/moonraker-event.dto.js.map +1 -1
  288. package/dist/services/moonraker/constants/moonraker.constants.js +4 -11
  289. package/dist/services/moonraker/constants/moonraker.constants.js.map +1 -1
  290. package/dist/services/moonraker/dto/access/access-info.dto.js +1 -6
  291. package/dist/services/moonraker/dto/access/access-login-refresh.dto.js +1 -6
  292. package/dist/services/moonraker/dto/access/access-login-result.dto.js +1 -6
  293. package/dist/services/moonraker/dto/access/access-user-result.dto.js +1 -6
  294. package/dist/services/moonraker/dto/access/access-user.dto.js +1 -6
  295. package/dist/services/moonraker/dto/database/database-namespace-item.dto.js +1 -6
  296. package/dist/services/moonraker/dto/database/database-namespace-list.dto.js +1 -6
  297. package/dist/services/moonraker/dto/gcode-help.dto.js +1 -6
  298. package/dist/services/moonraker/dto/gcode-store.dto.js +1 -6
  299. package/dist/services/moonraker/dto/job-queue/enqueue-job.dto.js +1 -6
  300. package/dist/services/moonraker/dto/job-queue/job-queue-status.dto.js +1 -6
  301. package/dist/services/moonraker/dto/machine/machine-device-power-device-state.dto.js +1 -6
  302. package/dist/services/moonraker/dto/machine/machine-device-power-devices.dto.js +1 -6
  303. package/dist/services/moonraker/dto/machine/machine-peripherals-canbus.dto.js +1 -6
  304. package/dist/services/moonraker/dto/machine/machine-peripherals-serial.dto.js +1 -6
  305. package/dist/services/moonraker/dto/machine/machine-peripherals-usb.dto.js +1 -6
  306. package/dist/services/moonraker/dto/machine/machine-peripherals-video.dto.js +1 -6
  307. package/dist/services/moonraker/dto/machine/machine-system-info.dto.js +1 -6
  308. package/dist/services/moonraker/dto/machine/machine-update-status.dto.js +1 -6
  309. package/dist/services/moonraker/dto/machine/machine-wled-strips.dto.js +1 -6
  310. package/dist/services/moonraker/dto/notifier-list.dto.js +1 -6
  311. package/dist/services/moonraker/dto/objects/bed-mesh.dto.js +1 -6
  312. package/dist/services/moonraker/dto/objects/configfile.dto.js +1 -6
  313. package/dist/services/moonraker/dto/objects/display-status.dto.js +1 -6
  314. package/dist/services/moonraker/dto/objects/extruder.dto.js +1 -6
  315. package/dist/services/moonraker/dto/objects/fan.dto.js +1 -6
  316. package/dist/services/moonraker/dto/objects/filament-motion-sensor.dto.js +1 -6
  317. package/dist/services/moonraker/dto/objects/filament-switch-sensor.dto.js +1 -6
  318. package/dist/services/moonraker/dto/objects/gcode-move.dto.js +1 -6
  319. package/dist/services/moonraker/dto/objects/gcode.dto.js +1 -6
  320. package/dist/services/moonraker/dto/objects/heater-bed.dto.js +1 -6
  321. package/dist/services/moonraker/dto/objects/heaters.dto.js +1 -6
  322. package/dist/services/moonraker/dto/objects/idle-timeout.dto.js +6 -21
  323. package/dist/services/moonraker/dto/objects/idle-timeout.dto.js.map +1 -1
  324. package/dist/services/moonraker/dto/objects/mcu.dto.js +1 -6
  325. package/dist/services/moonraker/dto/objects/motion-report.dto.js +1 -6
  326. package/dist/services/moonraker/dto/objects/output-pin.dto.js +1 -6
  327. package/dist/services/moonraker/dto/objects/pause-resume.dto.js +1 -6
  328. package/dist/services/moonraker/dto/objects/print-stats.dto.js +9 -24
  329. package/dist/services/moonraker/dto/objects/print-stats.dto.js.map +1 -1
  330. package/dist/services/moonraker/dto/objects/printer-object.dto.js +1 -6
  331. package/dist/services/moonraker/dto/objects/printer-object.types.js +1 -6
  332. package/dist/services/moonraker/dto/objects/printer-objects-list.dto.js +28 -43
  333. package/dist/services/moonraker/dto/objects/printer-objects-list.dto.js.map +1 -1
  334. package/dist/services/moonraker/dto/objects/printer-objects-query.dto.js +1 -6
  335. package/dist/services/moonraker/dto/objects/stepper-enable.dto.js +1 -6
  336. package/dist/services/moonraker/dto/objects/system-stats.dto.js +1 -6
  337. package/dist/services/moonraker/dto/objects/temperature-fan.dto.js +1 -6
  338. package/dist/services/moonraker/dto/objects/temperature-sensor.dto.js +1 -6
  339. package/dist/services/moonraker/dto/objects/toolhead.dto.js +1 -6
  340. package/dist/services/moonraker/dto/objects/virtual-sdcard.dto.js +1 -6
  341. package/dist/services/moonraker/dto/objects/webhooks.dto.js +1 -6
  342. package/dist/services/moonraker/dto/octoprint-compat/api-job.dto.js +1 -6
  343. package/dist/services/moonraker/dto/octoprint-compat/api-login.dto.js +1 -6
  344. package/dist/services/moonraker/dto/octoprint-compat/api-printer.dto.js +1 -6
  345. package/dist/services/moonraker/dto/octoprint-compat/api-profiles.dto.js +1 -6
  346. package/dist/services/moonraker/dto/octoprint-compat/api-settings.dto.js +1 -6
  347. package/dist/services/moonraker/dto/octoprint-compat/api-version.dto.js +1 -6
  348. package/dist/services/moonraker/dto/octoprint-compat/server-version.dto.js +1 -6
  349. package/dist/services/moonraker/dto/printer-info.dto.js +7 -22
  350. package/dist/services/moonraker/dto/printer-info.dto.js.map +1 -1
  351. package/dist/services/moonraker/dto/printer-query-endstops.dto.js +1 -6
  352. package/dist/services/moonraker/dto/process-stats.dto.js +1 -6
  353. package/dist/services/moonraker/dto/rest/action-result.dto.js +1 -6
  354. package/dist/services/moonraker/dto/rest/error.dto.js +1 -6
  355. package/dist/services/moonraker/dto/rest/result.dto.js +6 -13
  356. package/dist/services/moonraker/dto/rest/result.dto.js.map +1 -1
  357. package/dist/services/moonraker/dto/rollover-logs.dto.js +1 -6
  358. package/dist/services/moonraker/dto/rpc/json-rpc-error.dto.js +1 -6
  359. package/dist/services/moonraker/dto/rpc/json-rpc-request.dto.js +1 -6
  360. package/dist/services/moonraker/dto/rpc/json-rpc-response.dto.js +1 -6
  361. package/dist/services/moonraker/dto/server/server-config.dto.js +1 -6
  362. package/dist/services/moonraker/dto/server/server-info.dto.js +7 -14
  363. package/dist/services/moonraker/dto/server/server-info.dto.js.map +1 -1
  364. package/dist/services/moonraker/dto/server-announcements/announcement-action.dto.js +1 -6
  365. package/dist/services/moonraker/dto/server-announcements/announcement-entry-id.dto.js +1 -6
  366. package/dist/services/moonraker/dto/server-announcements/announcement-feeds.dto.js +1 -6
  367. package/dist/services/moonraker/dto/server-announcements/announcement-list.dto.js +1 -6
  368. package/dist/services/moonraker/dto/server-files/server-file-directory-action.dto.js +1 -6
  369. package/dist/services/moonraker/dto/server-files/server-file-directory-info.dto.js +1 -6
  370. package/dist/services/moonraker/dto/server-files/server-file-metadata.dto.js +1 -6
  371. package/dist/services/moonraker/dto/server-files/server-file-root.dto.js +1 -6
  372. package/dist/services/moonraker/dto/server-files/server-file-thumbnail.dto.js +1 -6
  373. package/dist/services/moonraker/dto/server-files/server-file-zip-action.dto.js +1 -6
  374. package/dist/services/moonraker/dto/server-files/server-file.dto.js +1 -6
  375. package/dist/services/moonraker/dto/server-history/history-job.dto.js +1 -6
  376. package/dist/services/moonraker/dto/server-history/history-last-totals.dto.js +1 -6
  377. package/dist/services/moonraker/dto/server-history/history-list.dto.js +1 -6
  378. package/dist/services/moonraker/dto/server-history/history-totals.dto.js +1 -6
  379. package/dist/services/moonraker/dto/server-history/job.dto.js +6 -21
  380. package/dist/services/moonraker/dto/server-history/job.dto.js.map +1 -1
  381. package/dist/services/moonraker/dto/server-sensors/sensor-info.dto.js +1 -6
  382. package/dist/services/moonraker/dto/server-sensors/sensor-list.dto.js +1 -6
  383. package/dist/services/moonraker/dto/server-sensors/sensor-measurements.dto.js +1 -6
  384. package/dist/services/moonraker/dto/server-webcams/webcam-item.dto.js +1 -6
  385. package/dist/services/moonraker/dto/server-webcams/webcam-list.dto.js +1 -6
  386. package/dist/services/moonraker/dto/server-webcams/webcam-test.dto.js +1 -6
  387. package/dist/services/moonraker/dto/spoolman/spoolman-active-spool.dto.js +1 -6
  388. package/dist/services/moonraker/dto/spoolman/spoolman-proxy-request.dto.js +1 -6
  389. package/dist/services/moonraker/dto/spoolman/spoolman-response.dto.js +1 -6
  390. package/dist/services/moonraker/dto/spoolman/spoolman-status.dto.js +1 -6
  391. package/dist/services/moonraker/dto/sudo-info.dto.js +1 -6
  392. package/dist/services/moonraker/dto/sudo-response.dto.js +1 -6
  393. package/dist/services/moonraker/dto/temperature-store.dto.js +1 -6
  394. package/dist/services/moonraker/dto/websocket/connection-identify-response.dto.js +1 -6
  395. package/dist/services/moonraker/dto/websocket/connection-identify.dto.js +1 -6
  396. package/dist/services/moonraker/dto/websocket/json-rpc-event.dto.js +1 -6
  397. package/dist/services/moonraker/dto/websocket/message.types.js +1 -6
  398. package/dist/services/moonraker/dto/websocket/methods.js +29 -44
  399. package/dist/services/moonraker/dto/websocket/methods.js.map +1 -1
  400. package/dist/services/moonraker/dto/websocket/notify-active-spool-set.params.js +1 -6
  401. package/dist/services/moonraker/dto/websocket/notify-agent-event.params.js +1 -6
  402. package/dist/services/moonraker/dto/websocket/notify-announcement-update.params.js +1 -6
  403. package/dist/services/moonraker/dto/websocket/notify-announcement.params.js +1 -6
  404. package/dist/services/moonraker/dto/websocket/notify-button-event.params.js +1 -6
  405. package/dist/services/moonraker/dto/websocket/notify-filelist-changed.params.js +11 -18
  406. package/dist/services/moonraker/dto/websocket/notify-filelist-changed.params.js.map +1 -1
  407. package/dist/services/moonraker/dto/websocket/notify-history-changed.params.js +1 -6
  408. package/dist/services/moonraker/dto/websocket/notify-job-queue-changed.params.js +1 -6
  409. package/dist/services/moonraker/dto/websocket/notify-proc-stat-update.params.js +1 -6
  410. package/dist/services/moonraker/dto/websocket/notify-sensor-update.params.js +1 -6
  411. package/dist/services/moonraker/dto/websocket/notify-service-state-changed.params.js +1 -6
  412. package/dist/services/moonraker/dto/websocket/notify-spoolman-status-changed.js +1 -6
  413. package/dist/services/moonraker/dto/websocket/notify-sudo-alert.params.js +1 -6
  414. package/dist/services/moonraker/dto/websocket/notify-update-response.params.js +7 -22
  415. package/dist/services/moonraker/dto/websocket/notify-update-response.params.js.map +1 -1
  416. package/dist/services/moonraker/dto/websocket/notify-user-change.params.js +1 -6
  417. package/dist/services/moonraker/moonraker-websocket.adapter.js +313 -348
  418. package/dist/services/moonraker/moonraker-websocket.adapter.js.map +1 -1
  419. package/dist/services/moonraker/moonraker.client.js +536 -559
  420. package/dist/services/moonraker/moonraker.client.js.map +1 -1
  421. package/dist/services/moonraker.api.js +167 -192
  422. package/dist/services/moonraker.api.js.map +1 -1
  423. package/dist/services/octoprint/constants/firmware-update-settings.constants.js +19 -28
  424. package/dist/services/octoprint/constants/firmware-update-settings.constants.js.map +1 -1
  425. package/dist/services/octoprint/constants/octoprint-service.constants.js +3 -30
  426. package/dist/services/octoprint/constants/octoprint-service.constants.js.map +1 -1
  427. package/dist/services/octoprint/constants/octoprint-websocket.constants.js +41 -56
  428. package/dist/services/octoprint/constants/octoprint-websocket.constants.js.map +1 -1
  429. package/dist/services/octoprint/dto/access/user-list.dto.js +1 -6
  430. package/dist/services/octoprint/dto/access/user.dto.js +1 -6
  431. package/dist/services/octoprint/dto/auth/current-user.dto.js +1 -6
  432. package/dist/services/octoprint/dto/auth/login.dto.js +1 -6
  433. package/dist/services/octoprint/dto/connection/connection-state.type.js +23 -30
  434. package/dist/services/octoprint/dto/connection/connection-state.type.js.map +1 -1
  435. package/dist/services/octoprint/dto/connection/connection.dto.js +1 -6
  436. package/dist/services/octoprint/dto/events/client-authed.dto.js +1 -6
  437. package/dist/services/octoprint/dto/events/client-closed.dto.js +1 -6
  438. package/dist/services/octoprint/dto/events/client-opened.dto.js +1 -6
  439. package/dist/services/octoprint/dto/events/dwelling.dto.js +1 -6
  440. package/dist/services/octoprint/dto/events/file-added.dto.js +1 -6
  441. package/dist/services/octoprint/dto/events/file-deselected.dto.js +1 -6
  442. package/dist/services/octoprint/dto/events/file-removed.dto.js +1 -6
  443. package/dist/services/octoprint/dto/events/folder-added.dto.js +1 -6
  444. package/dist/services/octoprint/dto/events/home.dto.js +1 -6
  445. package/dist/services/octoprint/dto/events/metadata-analysis-finished.dto.js +1 -6
  446. package/dist/services/octoprint/dto/events/metadata-analysis-started.dto.js +1 -6
  447. package/dist/services/octoprint/dto/events/metadata-statistics-updated.dto.js +1 -6
  448. package/dist/services/octoprint/dto/events/position-update.dto.js +1 -6
  449. package/dist/services/octoprint/dto/events/print-cancelled.dto.js +1 -6
  450. package/dist/services/octoprint/dto/events/print-cancelling.dto.js +1 -6
  451. package/dist/services/octoprint/dto/events/print-done.dto.js +1 -6
  452. package/dist/services/octoprint/dto/events/print-failed.dto.js +1 -6
  453. package/dist/services/octoprint/dto/events/print-paused.dto.js +1 -6
  454. package/dist/services/octoprint/dto/events/print-resumed.dto.js +1 -6
  455. package/dist/services/octoprint/dto/events/print-started.dto.js +1 -6
  456. package/dist/services/octoprint/dto/events/printer-state-changed.dto.js +1 -6
  457. package/dist/services/octoprint/dto/events/transfer-done.dto.js +1 -6
  458. package/dist/services/octoprint/dto/events/transfer-started.dto.js +1 -6
  459. package/dist/services/octoprint/dto/events/updated-files.dto.js +1 -6
  460. package/dist/services/octoprint/dto/events/upload.dto.js +1 -6
  461. package/dist/services/octoprint/dto/events/user-logged-in.dto.js +1 -6
  462. package/dist/services/octoprint/dto/events/z-change.dto.js +1 -6
  463. package/dist/services/octoprint/dto/files/gcode-analysis.dto.js +1 -6
  464. package/dist/services/octoprint/dto/files/octoprint-file.dto.js +1 -6
  465. package/dist/services/octoprint/dto/files/octoprint-files-response.dto.js +1 -6
  466. package/dist/services/octoprint/dto/job/current-job.dto.js +8 -15
  467. package/dist/services/octoprint/dto/job/current-job.dto.js.map +1 -1
  468. package/dist/services/octoprint/dto/job/job.dto.js +1 -6
  469. package/dist/services/octoprint/dto/octoprint-event.dto.js +21 -39
  470. package/dist/services/octoprint/dto/octoprint-event.dto.js.map +1 -1
  471. package/dist/services/octoprint/dto/printer/busy-file.dto.js +1 -6
  472. package/dist/services/octoprint/dto/printer/current-printer-state.dto.js +1 -6
  473. package/dist/services/octoprint/dto/printer/flags.dto.js +1 -6
  474. package/dist/services/octoprint/dto/printer/markings.dto.js +1 -6
  475. package/dist/services/octoprint/dto/printer/progress.dto.js +1 -6
  476. package/dist/services/octoprint/dto/printer/resends.dto.js +1 -6
  477. package/dist/services/octoprint/dto/printer/state.dto.js +1 -6
  478. package/dist/services/octoprint/dto/printer/temps.dto.js +1 -6
  479. package/dist/services/octoprint/dto/rest/error.dto.js +1 -6
  480. package/dist/services/octoprint/dto/server/server.dto.js +1 -6
  481. package/dist/services/octoprint/dto/server/version.dto.js +1 -6
  482. package/dist/services/octoprint/dto/settings/serial-settings.dto.js +1 -6
  483. package/dist/services/octoprint/dto/settings/settings-parts.type.js +1 -6
  484. package/dist/services/octoprint/dto/settings/settings.dto.js +1 -6
  485. package/dist/services/octoprint/dto/settings/virtual-printer-settings.dto.js +1 -6
  486. package/dist/services/octoprint/dto/system/system-info.dto.js +32 -39
  487. package/dist/services/octoprint/dto/system/system-info.dto.js.map +1 -1
  488. package/dist/services/octoprint/dto/websocket/connection-message.dto.js +1 -6
  489. package/dist/services/octoprint/dto/websocket/current-message.dto.js +1 -6
  490. package/dist/services/octoprint/dto/websocket/event-message.dto.js +1 -6
  491. package/dist/services/octoprint/dto/websocket/event.type.js +42 -49
  492. package/dist/services/octoprint/dto/websocket/event.type.js.map +1 -1
  493. package/dist/services/octoprint/dto/websocket/history-message.dto.js +1 -6
  494. package/dist/services/octoprint/dto/websocket/plugin-message.dto.js +1 -6
  495. package/dist/services/octoprint/dto/websocket/timelapse-message.dto.js +1 -6
  496. package/dist/services/octoprint/octoprint-api.routes.js +77 -94
  497. package/dist/services/octoprint/octoprint-api.routes.js.map +1 -1
  498. package/dist/services/octoprint/octoprint-websocket.adapter.js +265 -315
  499. package/dist/services/octoprint/octoprint-websocket.adapter.js.map +1 -1
  500. package/dist/services/octoprint/octoprint.client.js +220 -261
  501. package/dist/services/octoprint/octoprint.client.js.map +1 -1
  502. package/dist/services/octoprint/utils/api.utils.js +15 -32
  503. package/dist/services/octoprint/utils/api.utils.js.map +1 -1
  504. package/dist/services/octoprint/utils/file.utils.js +44 -67
  505. package/dist/services/octoprint/utils/file.utils.js.map +1 -1
  506. package/dist/services/octoprint/utils/octoprint-http-client.builder.js +16 -29
  507. package/dist/services/octoprint/utils/octoprint-http-client.builder.js.map +1 -1
  508. package/dist/services/octoprint.api.js +113 -128
  509. package/dist/services/octoprint.api.js.map +1 -1
  510. package/dist/services/orm/base.interface.js +1 -6
  511. package/dist/services/orm/base.service.js +57 -73
  512. package/dist/services/orm/base.service.js.map +1 -1
  513. package/dist/services/orm/camera-stream.service.js +21 -27
  514. package/dist/services/orm/camera-stream.service.js.map +1 -1
  515. package/dist/services/orm/floor-position.service.js +42 -49
  516. package/dist/services/orm/floor-position.service.js.map +1 -1
  517. package/dist/services/orm/floor.service.js +110 -138
  518. package/dist/services/orm/floor.service.js.map +1 -1
  519. package/dist/services/orm/permission.service.js +16 -23
  520. package/dist/services/orm/permission.service.js.map +1 -1
  521. package/dist/services/orm/print-job.service.js +443 -545
  522. package/dist/services/orm/print-job.service.js.map +1 -1
  523. package/dist/services/orm/printer-maintenance-log.service.js +102 -149
  524. package/dist/services/orm/printer-maintenance-log.service.js.map +1 -1
  525. package/dist/services/orm/printer-tag.service.js +93 -118
  526. package/dist/services/orm/printer-tag.service.js.map +1 -1
  527. package/dist/services/orm/printer.service.js +110 -158
  528. package/dist/services/orm/printer.service.js.map +1 -1
  529. package/dist/services/orm/refresh-token.service.js +69 -99
  530. package/dist/services/orm/refresh-token.service.js.map +1 -1
  531. package/dist/services/orm/role.service.js +99 -116
  532. package/dist/services/orm/role.service.js.map +1 -1
  533. package/dist/services/orm/settings.service.js +84 -94
  534. package/dist/services/orm/settings.service.js.map +1 -1
  535. package/dist/services/orm/user-role.service.js +39 -53
  536. package/dist/services/orm/user-role.service.js.map +1 -1
  537. package/dist/services/orm/user.service.js +142 -189
  538. package/dist/services/orm/user.service.js.map +1 -1
  539. package/dist/services/print-file-downloader.service.js +153 -167
  540. package/dist/services/print-file-downloader.service.js.map +1 -1
  541. package/dist/services/print-queue.service.js +240 -326
  542. package/dist/services/print-queue.service.js.map +1 -1
  543. package/dist/services/printer-api.factory.js +26 -43
  544. package/dist/services/printer-api.factory.js.map +1 -1
  545. package/dist/services/printer-api.interface.js +23 -53
  546. package/dist/services/printer-api.interface.js.map +1 -1
  547. package/dist/services/prusa-link/constants/prusalink-event.dto.js +9 -16
  548. package/dist/services/prusa-link/constants/prusalink-event.dto.js.map +1 -1
  549. package/dist/services/prusa-link/constants/prusalink.constants.js +4 -11
  550. package/dist/services/prusa-link/constants/prusalink.constants.js.map +1 -1
  551. package/dist/services/prusa-link/dto/file-response.dto.js +1 -6
  552. package/dist/services/prusa-link/dto/file.dto.js +1 -6
  553. package/dist/services/prusa-link/dto/job-state.dto.js +1 -6
  554. package/dist/services/prusa-link/dto/printer-state.dto.js +1 -6
  555. package/dist/services/prusa-link/dto/status.dto.js +1 -6
  556. package/dist/services/prusa-link/dto/version.dto.js +1 -6
  557. package/dist/services/prusa-link/prusa-link-http-polling.adapter.js +141 -157
  558. package/dist/services/prusa-link/prusa-link-http-polling.adapter.js.map +1 -1
  559. package/dist/services/prusa-link/prusa-link.api.js +206 -240
  560. package/dist/services/prusa-link/prusa-link.api.js.map +1 -1
  561. package/dist/services/prusa-link/utils/digest-auth.params.js +1 -6
  562. package/dist/services/prusa-link/utils/digest-auth.util.js +17 -24
  563. package/dist/services/prusa-link/utils/digest-auth.util.js.map +1 -1
  564. package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js +92 -129
  565. package/dist/services/prusa-link/utils/prusa-link-http-client.builder.js.map +1 -1
  566. package/dist/services/socket.factory.js +21 -36
  567. package/dist/services/socket.factory.js.map +1 -1
  568. package/dist/services/task-manager.service.js +190 -174
  569. package/dist/services/task-manager.service.js.map +1 -1
  570. package/dist/services/typeorm/typeorm.service.js +31 -46
  571. package/dist/services/typeorm/typeorm.service.js.map +1 -1
  572. package/dist/services/validators/floor-service.validation.js +26 -63
  573. package/dist/services/validators/floor-service.validation.js.map +1 -1
  574. package/dist/services/validators/print-job.validation.js +11 -26
  575. package/dist/services/validators/print-job.validation.js.map +1 -1
  576. package/dist/services/validators/printer-maintenance-log.validation.js +17 -37
  577. package/dist/services/validators/printer-maintenance-log.validation.js.map +1 -1
  578. package/dist/services/validators/printer-service.validation.js +60 -125
  579. package/dist/services/validators/printer-service.validation.js.map +1 -1
  580. package/dist/services/validators/settings-service.validation.js +46 -106
  581. package/dist/services/validators/settings-service.validation.js.map +1 -1
  582. package/dist/services/validators/user-service.validation.js +19 -36
  583. package/dist/services/validators/user-service.validation.js.map +1 -1
  584. package/dist/services/validators/yaml-service.validation.js +96 -132
  585. package/dist/services/validators/yaml-service.validation.js.map +1 -1
  586. package/dist/services/websocket-adapter.interface.js +1 -6
  587. package/dist/shared/default-http-client.builder.js +74 -92
  588. package/dist/shared/default-http-client.builder.js.map +1 -1
  589. package/dist/shared/dtos/api-state.type.js +8 -15
  590. package/dist/shared/dtos/api-state.type.js.map +1 -1
  591. package/dist/shared/dtos/socket-login.dto.js +1 -6
  592. package/dist/shared/dtos/socket-state.type.js +11 -18
  593. package/dist/shared/dtos/socket-state.type.js.map +1 -1
  594. package/dist/shared/load-controllers.js +41 -19
  595. package/dist/shared/load-controllers.js.map +1 -1
  596. package/dist/shared/runtime-settings.migration.js +43 -50
  597. package/dist/shared/runtime-settings.migration.js.map +1 -1
  598. package/dist/shared/websocket-rpc-extended.adapter.js +74 -75
  599. package/dist/shared/websocket-rpc-extended.adapter.js.map +1 -1
  600. package/dist/shared/websocket.adapter.js +78 -63
  601. package/dist/shared/websocket.adapter.js.map +1 -1
  602. package/dist/state/file-upload-tracker.cache.js +63 -75
  603. package/dist/state/file-upload-tracker.cache.js.map +1 -1
  604. package/dist/state/floor.store.js +77 -89
  605. package/dist/state/floor.store.js.map +1 -1
  606. package/dist/state/printer-events.cache.js +237 -295
  607. package/dist/state/printer-events.cache.js.map +1 -1
  608. package/dist/state/printer-socket.store.js +156 -174
  609. package/dist/state/printer-socket.store.js.map +1 -1
  610. package/dist/state/printer-thumbnail.cache.js +129 -130
  611. package/dist/state/printer-thumbnail.cache.js.map +1 -1
  612. package/dist/state/printer.cache.js +87 -102
  613. package/dist/state/printer.cache.js.map +1 -1
  614. package/dist/state/settings.store.js +211 -234
  615. package/dist/state/settings.store.js.map +1 -1
  616. package/dist/state/socket-io.gateway.js +58 -87
  617. package/dist/state/socket-io.gateway.js.map +1 -1
  618. package/dist/state/test-printer-socket.store.js +116 -137
  619. package/dist/state/test-printer-socket.store.js.map +1 -1
  620. package/dist/state/validation/create-test-printer.validation.js +14 -21
  621. package/dist/state/validation/create-test-printer.validation.js.map +1 -1
  622. package/dist/task.presets.js +30 -37
  623. package/dist/task.presets.js.map +1 -1
  624. package/dist/tasks/boot.task.js +100 -128
  625. package/dist/tasks/boot.task.js.map +1 -1
  626. package/dist/tasks/client-bundle.task.js +20 -28
  627. package/dist/tasks/client-bundle.task.js.map +1 -1
  628. package/dist/tasks/print-job-analysis.task.js +88 -113
  629. package/dist/tasks/print-job-analysis.task.js.map +1 -1
  630. package/dist/tasks/printer-websocket-restore.task.js +41 -54
  631. package/dist/tasks/printer-websocket-restore.task.js.map +1 -1
  632. package/dist/tasks/printer-websocket.task.js +11 -19
  633. package/dist/tasks/printer-websocket.task.js.map +1 -1
  634. package/dist/tasks/socketio.task.js +35 -53
  635. package/dist/tasks/socketio.task.js.map +1 -1
  636. package/dist/tasks/software-update.task.js +12 -20
  637. package/dist/tasks/software-update.task.js.map +1 -1
  638. package/dist/tasks.js +27 -42
  639. package/dist/tasks.js.map +1 -1
  640. package/dist/types/express/index.d.js +1 -6
  641. package/dist/types/virtual-modules.d.js +1 -0
  642. package/dist/utils/array.util.js +9 -24
  643. package/dist/utils/array.util.js.map +1 -1
  644. package/dist/utils/bgcode/bgcode-thumbnail.parser.js +26 -44
  645. package/dist/utils/bgcode/bgcode-thumbnail.parser.js.map +1 -1
  646. package/dist/utils/bgcode/bgcode.constants.js +9 -45
  647. package/dist/utils/bgcode/bgcode.constants.js.map +1 -1
  648. package/dist/utils/bgcode/bgcode.types.js +57 -106
  649. package/dist/utils/bgcode/bgcode.types.js.map +1 -1
  650. package/dist/utils/bgcode/bgcode.utils.js +167 -256
  651. package/dist/utils/bgcode/bgcode.utils.js.map +1 -1
  652. package/dist/utils/bgcode/heatshrink-decoder.js +130 -170
  653. package/dist/utils/bgcode/heatshrink-decoder.js.map +1 -1
  654. package/dist/utils/bgcode/png-encoder.js +53 -66
  655. package/dist/utils/bgcode/png-encoder.js.map +1 -1
  656. package/dist/utils/bgcode/qoi-decoder.js +116 -135
  657. package/dist/utils/bgcode/qoi-decoder.js.map +1 -1
  658. package/dist/utils/cache/key-diff.cache.js +56 -85
  659. package/dist/utils/cache/key-diff.cache.js.map +1 -1
  660. package/dist/utils/correlation-token.util.js +4 -11
  661. package/dist/utils/correlation-token.util.js.map +1 -1
  662. package/dist/utils/crypto.utils.js +7 -23
  663. package/dist/utils/crypto.utils.js.map +1 -1
  664. package/dist/utils/env.utils.js +14 -49
  665. package/dist/utils/env.utils.js.map +1 -1
  666. package/dist/utils/error.utils.js +4 -11
  667. package/dist/utils/error.utils.js.map +1 -1
  668. package/dist/utils/fs.utils.js +26 -49
  669. package/dist/utils/fs.utils.js.map +1 -1
  670. package/dist/utils/gcode.utils.js +30 -43
  671. package/dist/utils/gcode.utils.js.map +1 -1
  672. package/dist/utils/image-dimensions.js +39 -54
  673. package/dist/utils/image-dimensions.js.map +1 -1
  674. package/dist/utils/job-stats.util.js +41 -72
  675. package/dist/utils/job-stats.util.js.map +1 -1
  676. package/dist/utils/normalize-url.js +135 -203
  677. package/dist/utils/normalize-url.js.map +1 -1
  678. package/dist/utils/parsers/3mf.parser.js +298 -365
  679. package/dist/utils/parsers/3mf.parser.js.map +1 -1
  680. package/dist/utils/parsers/bgcode.parser.js +149 -202
  681. package/dist/utils/parsers/bgcode.parser.js.map +1 -1
  682. package/dist/utils/parsers/gcode.parser.js +200 -263
  683. package/dist/utils/parsers/gcode.parser.js.map +1 -1
  684. package/dist/utils/parsers/parser.types.js +1 -6
  685. package/dist/utils/pretty-print.utils.js +5 -20
  686. package/dist/utils/pretty-print.utils.js.map +1 -1
  687. package/dist/utils/semver.utils.js +10 -26
  688. package/dist/utils/semver.utils.js.map +1 -1
  689. package/dist/utils/swagger/decorators.js +14 -32
  690. package/dist/utils/swagger/decorators.js.map +1 -1
  691. package/dist/utils/swagger/generator.js +151 -194
  692. package/dist/utils/swagger/generator.js.map +1 -1
  693. package/dist/utils/swagger/swagger.js +40 -51
  694. package/dist/utils/swagger/swagger.js.map +1 -1
  695. package/dist/utils/thumbnail.util.js +11 -20
  696. package/dist/utils/thumbnail.util.js.map +1 -1
  697. package/dist/utils/time.utils.js +4 -12
  698. package/dist/utils/time.utils.js.map +1 -1
  699. package/dist/utils/url.utils.js +9 -27
  700. package/dist/utils/url.utils.js.map +1 -1
  701. package/package.json +79 -90
  702. package/packages/consoles/package.json +44 -0
  703. package/packages/consoles/tsconfig.json +23 -0
  704. package/packages/consoles/vite.config.ts +15 -0
  705. package/tsconfig.json +10 -6
  706. package/vite.config.ts +62 -0
  707. package/.swcrc +0 -33
  708. package/.yarn/releases/yarn-4.12.0.cjs +0 -942
  709. package/biome.json +0 -36
  710. package/dist/consoles/bambu-mqtt-diagnostic.console.js +0 -565
  711. package/dist/consoles/bambu-mqtt-diagnostic.console.js.map +0 -1
  712. package/dist/consoles/download-github-releases.js +0 -50
  713. package/dist/consoles/download-github-releases.js.map +0 -1
  714. package/dist/consoles/gcode-scanner-poc.console.js +0 -52
  715. package/dist/consoles/gcode-scanner-poc.console.js.map +0 -1
  716. package/dist/consoles/launch-http-servers.js +0 -31
  717. package/dist/consoles/launch-http-servers.js.map +0 -1
  718. package/dist/consoles/mock-bambu.server.js +0 -319
  719. package/dist/consoles/mock-bambu.server.js.map +0 -1
  720. package/dist/consoles/mock-camera/default-image.js +0 -13
  721. package/dist/consoles/mock-camera/default-image.js.map +0 -1
  722. package/dist/consoles/mock-camera/mock-camera.server.js +0 -160
  723. package/dist/consoles/mock-camera/mock-camera.server.js.map +0 -1
  724. package/dist/consoles/mock-octoprint.server.js +0 -499
  725. package/dist/consoles/mock-octoprint.server.js.map +0 -1
  726. package/dist/consoles/mock-prusalink.server.js +0 -57
  727. package/dist/consoles/mock-prusalink.server.js.map +0 -1
  728. package/dist/consoles/moonraker-test.console.js +0 -3
  729. package/dist/consoles/moonraker-test.console.js.map +0 -1
  730. package/dist/consoles/utils/api-messages.js +0 -856
  731. package/dist/consoles/utils/api-messages.js.map +0 -1
  732. package/dist/consoles/utils/delayed-memory.storage.js +0 -42
  733. package/dist/consoles/utils/delayed-memory.storage.js.map +0 -1
  734. package/dist/consoles/utils/ws-messages.js +0 -88
  735. package/dist/consoles/utils/ws-messages.js.map +0 -1
  736. package/dist/entities/index.js.map +0 -1
  737. package/dist/services/bambu/mqtt-message.types.js.map +0 -1
  738. package/dist/services/interfaces/auth.service.interface.js.map +0 -1
  739. package/dist/services/interfaces/camera-stream.service.interface.js.map +0 -1
  740. package/dist/services/interfaces/file-upload-tracker.interface.js.map +0 -1
  741. package/dist/services/interfaces/floor.service.interface.js.map +0 -1
  742. package/dist/services/interfaces/jwt.service.interface.js.map +0 -1
  743. package/dist/services/interfaces/permission.service.interface.js.map +0 -1
  744. package/dist/services/interfaces/printer-file.dto.js.map +0 -1
  745. package/dist/services/interfaces/printer-maintenance-log.dto.js.map +0 -1
  746. package/dist/services/interfaces/printer-tag.service.interface.js.map +0 -1
  747. package/dist/services/interfaces/printer.service.interface.js.map +0 -1
  748. package/dist/services/interfaces/refresh-token.service.interface.js.map +0 -1
  749. package/dist/services/interfaces/role-service.interface.js.map +0 -1
  750. package/dist/services/interfaces/settings.service.interface.js.map +0 -1
  751. package/dist/services/interfaces/tag.dto.js.map +0 -1
  752. package/dist/services/interfaces/task.interfaces.js.map +0 -1
  753. package/dist/services/interfaces/user-service.interface.js.map +0 -1
  754. package/dist/services/moonraker/dto/access/access-info.dto.js.map +0 -1
  755. package/dist/services/moonraker/dto/access/access-login-refresh.dto.js.map +0 -1
  756. package/dist/services/moonraker/dto/access/access-login-result.dto.js.map +0 -1
  757. package/dist/services/moonraker/dto/access/access-user-result.dto.js.map +0 -1
  758. package/dist/services/moonraker/dto/access/access-user.dto.js.map +0 -1
  759. package/dist/services/moonraker/dto/database/database-namespace-item.dto.js.map +0 -1
  760. package/dist/services/moonraker/dto/database/database-namespace-list.dto.js.map +0 -1
  761. package/dist/services/moonraker/dto/gcode-help.dto.js.map +0 -1
  762. package/dist/services/moonraker/dto/gcode-store.dto.js.map +0 -1
  763. package/dist/services/moonraker/dto/job-queue/enqueue-job.dto.js.map +0 -1
  764. package/dist/services/moonraker/dto/job-queue/job-queue-status.dto.js.map +0 -1
  765. package/dist/services/moonraker/dto/machine/machine-device-power-device-state.dto.js.map +0 -1
  766. package/dist/services/moonraker/dto/machine/machine-device-power-devices.dto.js.map +0 -1
  767. package/dist/services/moonraker/dto/machine/machine-peripherals-canbus.dto.js.map +0 -1
  768. package/dist/services/moonraker/dto/machine/machine-peripherals-serial.dto.js.map +0 -1
  769. package/dist/services/moonraker/dto/machine/machine-peripherals-usb.dto.js.map +0 -1
  770. package/dist/services/moonraker/dto/machine/machine-peripherals-video.dto.js.map +0 -1
  771. package/dist/services/moonraker/dto/machine/machine-system-info.dto.js.map +0 -1
  772. package/dist/services/moonraker/dto/machine/machine-update-status.dto.js.map +0 -1
  773. package/dist/services/moonraker/dto/machine/machine-wled-strips.dto.js.map +0 -1
  774. package/dist/services/moonraker/dto/notifier-list.dto.js.map +0 -1
  775. package/dist/services/moonraker/dto/objects/bed-mesh.dto.js.map +0 -1
  776. package/dist/services/moonraker/dto/objects/configfile.dto.js.map +0 -1
  777. package/dist/services/moonraker/dto/objects/display-status.dto.js.map +0 -1
  778. package/dist/services/moonraker/dto/objects/extruder.dto.js.map +0 -1
  779. package/dist/services/moonraker/dto/objects/fan.dto.js.map +0 -1
  780. package/dist/services/moonraker/dto/objects/filament-motion-sensor.dto.js.map +0 -1
  781. package/dist/services/moonraker/dto/objects/filament-switch-sensor.dto.js.map +0 -1
  782. package/dist/services/moonraker/dto/objects/gcode-move.dto.js.map +0 -1
  783. package/dist/services/moonraker/dto/objects/gcode.dto.js.map +0 -1
  784. package/dist/services/moonraker/dto/objects/heater-bed.dto.js.map +0 -1
  785. package/dist/services/moonraker/dto/objects/heaters.dto.js.map +0 -1
  786. package/dist/services/moonraker/dto/objects/mcu.dto.js.map +0 -1
  787. package/dist/services/moonraker/dto/objects/motion-report.dto.js.map +0 -1
  788. package/dist/services/moonraker/dto/objects/output-pin.dto.js.map +0 -1
  789. package/dist/services/moonraker/dto/objects/pause-resume.dto.js.map +0 -1
  790. package/dist/services/moonraker/dto/objects/printer-object.dto.js.map +0 -1
  791. package/dist/services/moonraker/dto/objects/printer-object.types.js.map +0 -1
  792. package/dist/services/moonraker/dto/objects/printer-objects-query.dto.js.map +0 -1
  793. package/dist/services/moonraker/dto/objects/stepper-enable.dto.js.map +0 -1
  794. package/dist/services/moonraker/dto/objects/system-stats.dto.js.map +0 -1
  795. package/dist/services/moonraker/dto/objects/temperature-fan.dto.js.map +0 -1
  796. package/dist/services/moonraker/dto/objects/temperature-sensor.dto.js.map +0 -1
  797. package/dist/services/moonraker/dto/objects/toolhead.dto.js.map +0 -1
  798. package/dist/services/moonraker/dto/objects/virtual-sdcard.dto.js.map +0 -1
  799. package/dist/services/moonraker/dto/objects/webhooks.dto.js.map +0 -1
  800. package/dist/services/moonraker/dto/octoprint-compat/api-job.dto.js.map +0 -1
  801. package/dist/services/moonraker/dto/octoprint-compat/api-login.dto.js.map +0 -1
  802. package/dist/services/moonraker/dto/octoprint-compat/api-printer.dto.js.map +0 -1
  803. package/dist/services/moonraker/dto/octoprint-compat/api-profiles.dto.js.map +0 -1
  804. package/dist/services/moonraker/dto/octoprint-compat/api-settings.dto.js.map +0 -1
  805. package/dist/services/moonraker/dto/octoprint-compat/api-version.dto.js.map +0 -1
  806. package/dist/services/moonraker/dto/octoprint-compat/server-version.dto.js.map +0 -1
  807. package/dist/services/moonraker/dto/printer-query-endstops.dto.js.map +0 -1
  808. package/dist/services/moonraker/dto/process-stats.dto.js.map +0 -1
  809. package/dist/services/moonraker/dto/rest/action-result.dto.js.map +0 -1
  810. package/dist/services/moonraker/dto/rest/error.dto.js.map +0 -1
  811. package/dist/services/moonraker/dto/rollover-logs.dto.js.map +0 -1
  812. package/dist/services/moonraker/dto/rpc/json-rpc-error.dto.js.map +0 -1
  813. package/dist/services/moonraker/dto/rpc/json-rpc-request.dto.js.map +0 -1
  814. package/dist/services/moonraker/dto/rpc/json-rpc-response.dto.js.map +0 -1
  815. package/dist/services/moonraker/dto/server/server-config.dto.js.map +0 -1
  816. package/dist/services/moonraker/dto/server-announcements/announcement-action.dto.js.map +0 -1
  817. package/dist/services/moonraker/dto/server-announcements/announcement-entry-id.dto.js.map +0 -1
  818. package/dist/services/moonraker/dto/server-announcements/announcement-feeds.dto.js.map +0 -1
  819. package/dist/services/moonraker/dto/server-announcements/announcement-list.dto.js.map +0 -1
  820. package/dist/services/moonraker/dto/server-files/server-file-directory-action.dto.js.map +0 -1
  821. package/dist/services/moonraker/dto/server-files/server-file-directory-info.dto.js.map +0 -1
  822. package/dist/services/moonraker/dto/server-files/server-file-metadata.dto.js.map +0 -1
  823. package/dist/services/moonraker/dto/server-files/server-file-root.dto.js.map +0 -1
  824. package/dist/services/moonraker/dto/server-files/server-file-thumbnail.dto.js.map +0 -1
  825. package/dist/services/moonraker/dto/server-files/server-file-zip-action.dto.js.map +0 -1
  826. package/dist/services/moonraker/dto/server-files/server-file.dto.js.map +0 -1
  827. package/dist/services/moonraker/dto/server-history/history-job.dto.js.map +0 -1
  828. package/dist/services/moonraker/dto/server-history/history-last-totals.dto.js.map +0 -1
  829. package/dist/services/moonraker/dto/server-history/history-list.dto.js.map +0 -1
  830. package/dist/services/moonraker/dto/server-history/history-totals.dto.js.map +0 -1
  831. package/dist/services/moonraker/dto/server-sensors/sensor-info.dto.js.map +0 -1
  832. package/dist/services/moonraker/dto/server-sensors/sensor-list.dto.js.map +0 -1
  833. package/dist/services/moonraker/dto/server-sensors/sensor-measurements.dto.js.map +0 -1
  834. package/dist/services/moonraker/dto/server-webcams/webcam-item.dto.js.map +0 -1
  835. package/dist/services/moonraker/dto/server-webcams/webcam-list.dto.js.map +0 -1
  836. package/dist/services/moonraker/dto/server-webcams/webcam-test.dto.js.map +0 -1
  837. package/dist/services/moonraker/dto/spoolman/spoolman-active-spool.dto.js.map +0 -1
  838. package/dist/services/moonraker/dto/spoolman/spoolman-proxy-request.dto.js.map +0 -1
  839. package/dist/services/moonraker/dto/spoolman/spoolman-response.dto.js.map +0 -1
  840. package/dist/services/moonraker/dto/spoolman/spoolman-status.dto.js.map +0 -1
  841. package/dist/services/moonraker/dto/sudo-info.dto.js.map +0 -1
  842. package/dist/services/moonraker/dto/sudo-response.dto.js.map +0 -1
  843. package/dist/services/moonraker/dto/temperature-store.dto.js.map +0 -1
  844. package/dist/services/moonraker/dto/websocket/connection-identify-response.dto.js.map +0 -1
  845. package/dist/services/moonraker/dto/websocket/connection-identify.dto.js.map +0 -1
  846. package/dist/services/moonraker/dto/websocket/json-rpc-event.dto.js.map +0 -1
  847. package/dist/services/moonraker/dto/websocket/message.types.js.map +0 -1
  848. package/dist/services/moonraker/dto/websocket/notify-active-spool-set.params.js.map +0 -1
  849. package/dist/services/moonraker/dto/websocket/notify-agent-event.params.js.map +0 -1
  850. package/dist/services/moonraker/dto/websocket/notify-announcement-update.params.js.map +0 -1
  851. package/dist/services/moonraker/dto/websocket/notify-announcement.params.js.map +0 -1
  852. package/dist/services/moonraker/dto/websocket/notify-button-event.params.js.map +0 -1
  853. package/dist/services/moonraker/dto/websocket/notify-history-changed.params.js.map +0 -1
  854. package/dist/services/moonraker/dto/websocket/notify-job-queue-changed.params.js.map +0 -1
  855. package/dist/services/moonraker/dto/websocket/notify-proc-stat-update.params.js.map +0 -1
  856. package/dist/services/moonraker/dto/websocket/notify-sensor-update.params.js.map +0 -1
  857. package/dist/services/moonraker/dto/websocket/notify-service-state-changed.params.js.map +0 -1
  858. package/dist/services/moonraker/dto/websocket/notify-spoolman-status-changed.js.map +0 -1
  859. package/dist/services/moonraker/dto/websocket/notify-sudo-alert.params.js.map +0 -1
  860. package/dist/services/moonraker/dto/websocket/notify-user-change.params.js.map +0 -1
  861. package/dist/services/octoprint/dto/access/user-list.dto.js.map +0 -1
  862. package/dist/services/octoprint/dto/access/user.dto.js.map +0 -1
  863. package/dist/services/octoprint/dto/auth/current-user.dto.js.map +0 -1
  864. package/dist/services/octoprint/dto/auth/login.dto.js.map +0 -1
  865. package/dist/services/octoprint/dto/connection/connection.dto.js.map +0 -1
  866. package/dist/services/octoprint/dto/events/client-authed.dto.js.map +0 -1
  867. package/dist/services/octoprint/dto/events/client-closed.dto.js.map +0 -1
  868. package/dist/services/octoprint/dto/events/client-opened.dto.js.map +0 -1
  869. package/dist/services/octoprint/dto/events/dwelling.dto.js.map +0 -1
  870. package/dist/services/octoprint/dto/events/file-added.dto.js.map +0 -1
  871. package/dist/services/octoprint/dto/events/file-deselected.dto.js.map +0 -1
  872. package/dist/services/octoprint/dto/events/file-removed.dto.js.map +0 -1
  873. package/dist/services/octoprint/dto/events/folder-added.dto.js.map +0 -1
  874. package/dist/services/octoprint/dto/events/home.dto.js.map +0 -1
  875. package/dist/services/octoprint/dto/events/metadata-analysis-finished.dto.js.map +0 -1
  876. package/dist/services/octoprint/dto/events/metadata-analysis-started.dto.js.map +0 -1
  877. package/dist/services/octoprint/dto/events/metadata-statistics-updated.dto.js.map +0 -1
  878. package/dist/services/octoprint/dto/events/position-update.dto.js.map +0 -1
  879. package/dist/services/octoprint/dto/events/print-cancelled.dto.js.map +0 -1
  880. package/dist/services/octoprint/dto/events/print-cancelling.dto.js.map +0 -1
  881. package/dist/services/octoprint/dto/events/print-done.dto.js.map +0 -1
  882. package/dist/services/octoprint/dto/events/print-failed.dto.js.map +0 -1
  883. package/dist/services/octoprint/dto/events/print-paused.dto.js.map +0 -1
  884. package/dist/services/octoprint/dto/events/print-resumed.dto.js.map +0 -1
  885. package/dist/services/octoprint/dto/events/print-started.dto.js.map +0 -1
  886. package/dist/services/octoprint/dto/events/printer-state-changed.dto.js.map +0 -1
  887. package/dist/services/octoprint/dto/events/transfer-done.dto.js.map +0 -1
  888. package/dist/services/octoprint/dto/events/transfer-started.dto.js.map +0 -1
  889. package/dist/services/octoprint/dto/events/updated-files.dto.js.map +0 -1
  890. package/dist/services/octoprint/dto/events/upload.dto.js.map +0 -1
  891. package/dist/services/octoprint/dto/events/user-logged-in.dto.js.map +0 -1
  892. package/dist/services/octoprint/dto/events/z-change.dto.js.map +0 -1
  893. package/dist/services/octoprint/dto/files/gcode-analysis.dto.js.map +0 -1
  894. package/dist/services/octoprint/dto/files/octoprint-file.dto.js.map +0 -1
  895. package/dist/services/octoprint/dto/files/octoprint-files-response.dto.js.map +0 -1
  896. package/dist/services/octoprint/dto/job/job.dto.js.map +0 -1
  897. package/dist/services/octoprint/dto/printer/busy-file.dto.js.map +0 -1
  898. package/dist/services/octoprint/dto/printer/current-printer-state.dto.js.map +0 -1
  899. package/dist/services/octoprint/dto/printer/flags.dto.js.map +0 -1
  900. package/dist/services/octoprint/dto/printer/markings.dto.js.map +0 -1
  901. package/dist/services/octoprint/dto/printer/progress.dto.js.map +0 -1
  902. package/dist/services/octoprint/dto/printer/resends.dto.js.map +0 -1
  903. package/dist/services/octoprint/dto/printer/state.dto.js.map +0 -1
  904. package/dist/services/octoprint/dto/printer/temps.dto.js.map +0 -1
  905. package/dist/services/octoprint/dto/rest/error.dto.js.map +0 -1
  906. package/dist/services/octoprint/dto/server/server.dto.js.map +0 -1
  907. package/dist/services/octoprint/dto/server/version.dto.js.map +0 -1
  908. package/dist/services/octoprint/dto/settings/serial-settings.dto.js.map +0 -1
  909. package/dist/services/octoprint/dto/settings/settings-parts.type.js.map +0 -1
  910. package/dist/services/octoprint/dto/settings/settings.dto.js.map +0 -1
  911. package/dist/services/octoprint/dto/settings/virtual-printer-settings.dto.js.map +0 -1
  912. package/dist/services/octoprint/dto/websocket/connection-message.dto.js.map +0 -1
  913. package/dist/services/octoprint/dto/websocket/current-message.dto.js.map +0 -1
  914. package/dist/services/octoprint/dto/websocket/event-message.dto.js.map +0 -1
  915. package/dist/services/octoprint/dto/websocket/history-message.dto.js.map +0 -1
  916. package/dist/services/octoprint/dto/websocket/plugin-message.dto.js.map +0 -1
  917. package/dist/services/octoprint/dto/websocket/timelapse-message.dto.js.map +0 -1
  918. package/dist/services/orm/base.interface.js.map +0 -1
  919. package/dist/services/prusa-link/dto/file-response.dto.js.map +0 -1
  920. package/dist/services/prusa-link/dto/file.dto.js.map +0 -1
  921. package/dist/services/prusa-link/dto/job-state.dto.js.map +0 -1
  922. package/dist/services/prusa-link/dto/printer-state.dto.js.map +0 -1
  923. package/dist/services/prusa-link/dto/status.dto.js.map +0 -1
  924. package/dist/services/prusa-link/dto/version.dto.js.map +0 -1
  925. package/dist/services/prusa-link/utils/digest-auth.params.js.map +0 -1
  926. package/dist/services/websocket-adapter.interface.js.map +0 -1
  927. package/dist/shared/dtos/socket-login.dto.js.map +0 -1
  928. package/dist/types/express/index.d.js.map +0 -1
  929. package/dist/utils/parsers/parser.types.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/server.env.ts"],"names":["ensurePortSet","fetchServerPort","setupEnvConfig","setupSentry","logger","Logger","environment","process","env","AppConstants","NODE_ENV_KEY","knownEnvNames","includes","newEnvName","defaultProductionEnv","warn","log","ensurePackageVersionSet","ENABLE_PROMETHEUS_METRICS","collectDefaultMetrics","register","removeSingleMetric","packageJsonVersion","require","packageJsonPath","version","VERSION_KEY","port","SERVER_PORT_KEY","Number","isNaN","parseInt","defaultServerPort","toString","sentryDsnToken","getEnvOrDefault","sentryCustomDsnToken","sentryCustomDsnDefault","Sentry","init","dsn","NODE_ENV","release","npm_package_version","enabled","isTestEnvironment","tracesSampleRate","isProductionEnvironment","on","e","message","errorSummary","error","captureException","docsUrl"],"mappings":"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"}
1
+ {"version":3,"file":"server.env.js","names":["Logger"],"sources":["../src/server.env.ts"],"sourcesContent":["import * as Sentry from \"@sentry/node\";\nimport { readFileSync } from \"node:fs\";\nimport { AppConstants } from \"./server.constants\";\nimport { LoggerService as Logger } from \"./handlers/logger\";\nimport { getEnvOrDefault, isProductionEnvironment, isTestEnvironment } from \"./utils/env.utils\";\nimport { errorSummary } from \"./utils/error.utils\";\nimport { packageJsonPath } from \"@/utils/fs.utils\";\nimport { collectDefaultMetrics, register } from \"prom-client\";\n\nexport function setupEnvConfig() {\n const logger = new Logger(\"FDM-Environment\");\n const environment = process.env[AppConstants.NODE_ENV_KEY];\n if (!environment || !AppConstants.knownEnvNames.includes(environment)) {\n const newEnvName = AppConstants.defaultProductionEnv;\n process.env[AppConstants.NODE_ENV_KEY] = newEnvName;\n logger.warn(`NODE_ENV=${environment} was not set, or not known. Defaulting to NODE_ENV=${newEnvName}`);\n } else {\n logger.log(`✓ NODE_ENV variable correctly set (${environment})`);\n }\n\n ensurePackageVersionSet();\n setupSentry();\n ensurePortSet();\n\n // Optional: Enable collection of default metrics like memory, CPU, etc.\n if (process.env[AppConstants.ENABLE_PROMETHEUS_METRICS] === \"true\") {\n collectDefaultMetrics({ register });\n register.removeSingleMetric(\"nodejs_version_info\");\n }\n}\n\nfunction ensurePackageVersionSet() {\n const logger = new Logger(\"FDM-Environment\");\n const packageJson = JSON.parse(readFileSync(packageJsonPath(), \"utf-8\"));\n const packageJsonVersion = packageJson.version;\n process.env[AppConstants.VERSION_KEY] ??= packageJsonVersion;\n\n logger.log(`✓ Running server version ${process.env[AppConstants.VERSION_KEY]}`);\n}\n\nexport function fetchServerPort() {\n let port = process.env[AppConstants.SERVER_PORT_KEY];\n if (Number.isNaN(Number.parseInt(port!))) {\n // Update config immediately\n process.env[AppConstants.SERVER_PORT_KEY] = AppConstants.defaultServerPort.toString();\n port = process.env[AppConstants.SERVER_PORT_KEY];\n }\n return port;\n}\n\nexport function setupSentry() {\n const logger = new Logger(\"FDM-Environment\");\n const sentryDsnToken = getEnvOrDefault(AppConstants.sentryCustomDsnToken, AppConstants.sentryCustomDsnDefault);\n\n Sentry.init({\n dsn: sentryDsnToken,\n environment: process.env.NODE_ENV,\n release: process.env.npm_package_version,\n enabled: !isTestEnvironment(),\n tracesSampleRate: isProductionEnvironment() ? 0.25 : 1,\n });\n\n process.on(\"unhandledRejection\", (e) => {\n const message = `Unhandled rejection error - ${errorSummary(e)}`;\n logger.error(message);\n\n // The server must not crash\n Sentry.captureException(e);\n });\n}\n\nexport function ensurePortSet() {\n const logger = new Logger(\"FDM-Environment\");\n fetchServerPort();\n\n if (!process.env[AppConstants.SERVER_PORT_KEY]) {\n logger.log(`~ ${AppConstants.SERVER_PORT_KEY} environment variable is not set`);\n logger.log(`Please make sure to read ${AppConstants.docsUrl} for more information.`);\n process.env[AppConstants.SERVER_PORT_KEY] = AppConstants.defaultServerPort.toString();\n }\n}\n"],"mappings":";;;;;;;;;AASA,SAAgB,iBAAiB;CAC/B,MAAM,SAAS,IAAIA,cAAO,kBAAkB;CAC5C,MAAM,cAAc,QAAQ,IAAI,aAAa;AAC7C,KAAI,CAAC,eAAe,CAAC,aAAa,cAAc,SAAS,YAAY,EAAE;EACrE,MAAM,aAAa,aAAa;AAChC,UAAQ,IAAI,aAAa,gBAAgB;AACzC,SAAO,KAAK,YAAY,YAAY,qDAAqD,aAAa;OAEtG,QAAO,IAAI,sCAAsC,YAAY,GAAG;AAGlE,0BAAyB;AACzB,cAAa;AACb,gBAAe;AAGf,KAAI,QAAQ,IAAI,aAAa,+BAA+B,QAAQ;AAClE,wBAAsB,EAAE,UAAU,CAAC;AACnC,WAAS,mBAAmB,sBAAsB;;;AAItD,SAAS,0BAA0B;CACjC,MAAM,SAAS,IAAIA,cAAO,kBAAkB;CAE5C,MAAM,qBADc,KAAK,MAAM,aAAa,iBAAiB,EAAE,QAAQ,CACjC,CAAC;AACvC,SAAQ,IAAI,aAAa,iBAAiB;AAE1C,QAAO,IAAI,4BAA4B,QAAQ,IAAI,aAAa,eAAe;;AAGjF,SAAgB,kBAAkB;CAChC,IAAI,OAAO,QAAQ,IAAI,aAAa;AACpC,KAAI,OAAO,MAAM,OAAO,SAAS,KAAM,CAAC,EAAE;AAExC,UAAQ,IAAI,aAAa,mBAAmB,aAAa,kBAAkB,UAAU;AACrF,SAAO,QAAQ,IAAI,aAAa;;AAElC,QAAO;;AAGT,SAAgB,cAAc;CAC5B,MAAM,SAAS,IAAIA,cAAO,kBAAkB;CAC5C,MAAM,iBAAiB,gBAAgB,aAAa,sBAAsB,aAAa,uBAAuB;AAE9G,QAAO,KAAK;EACV,KAAK;EACL,aAAa,QAAQ,IAAI;EACzB,SAAS,QAAQ,IAAI;EACrB,SAAS,CAAC,mBAAmB;EAC7B,kBAAkB,yBAAyB,GAAG,MAAO;EACtD,CAAC;AAEF,SAAQ,GAAG,uBAAuB,MAAM;EACtC,MAAM,UAAU,+BAA+B,aAAa,EAAE;AAC9D,SAAO,MAAM,QAAQ;AAGrB,SAAO,iBAAiB,EAAE;GAC1B;;AAGJ,SAAgB,gBAAgB;CAC9B,MAAM,SAAS,IAAIA,cAAO,kBAAkB;AAC5C,kBAAiB;AAEjB,KAAI,CAAC,QAAQ,IAAI,aAAa,kBAAkB;AAC9C,SAAO,IAAI,KAAK,aAAa,gBAAgB,kCAAkC;AAC/E,SAAO,IAAI,4BAA4B,aAAa,QAAQ,wBAAwB;AACpF,UAAQ,IAAI,aAAa,mBAAmB,aAAa,kBAAkB,UAAU"}
@@ -1,101 +1,68 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "ServerHost", {
6
- enumerable: true,
7
- get: function() {
8
- return ServerHost;
9
- }
10
- });
11
- const _express = /*#__PURE__*/ _interop_require_default(require("express"));
12
- const _connecthistoryapifallback = /*#__PURE__*/ _interop_require_default(require("connect-history-api-fallback"));
13
- const _nodepath = require("node:path");
14
- const _serverenv = require("./server.env");
15
- const _runtimeexceptions = require("./exceptions/runtime.exceptions");
16
- const _serverconstants = require("./server.constants");
17
- const _fsutils = require("./utils/fs.utils");
18
- const _loadcontrollers = require("./shared/load-controllers");
19
- const _swagger = require("./utils/swagger/swagger");
20
- function _interop_require_default(obj) {
21
- return obj && obj.__esModule ? obj : {
22
- default: obj
23
- };
24
- }
25
- class ServerHost {
26
- configService;
27
- bootTask;
28
- socketIoGateway;
29
- typeormService;
30
- exceptionFilter;
31
- logger;
32
- constructor(loggerFactory, configService, bootTask, socketIoGateway, typeormService, exceptionFilter){
33
- this.configService = configService;
34
- this.bootTask = bootTask;
35
- this.socketIoGateway = socketIoGateway;
36
- this.typeormService = typeormService;
37
- this.exceptionFilter = exceptionFilter;
38
- this.logger = loggerFactory(ServerHost.name);
39
- }
40
- async boot(app, quick_boot = false, listenRequests = true) {
41
- await this.serveControllerRoutes(app);
42
- if (!quick_boot) {
43
- await this.bootTask.runOnce();
44
- }
45
- if (listenRequests) return this.httpListen(app);
46
- }
47
- hasConnected() {
48
- return this.typeormService.hasConnected();
49
- }
50
- async serveControllerRoutes(app) {
51
- const swaggerDisabled = process.env[_serverconstants.AppConstants.DISABLE_SWAGGER_OPENAPI] === "true";
52
- app.use((req, res, next)=>{
53
- if (!req.originalUrl.startsWith("/metrics") && !req.originalUrl.startsWith("/api") && !req.originalUrl.startsWith("/api-docs") && !req.originalUrl.startsWith("/socket.io")) {
54
- (0, _connecthistoryapifallback.default)()(req, res, next);
55
- } else {
56
- next();
57
- }
58
- }).use((0, _loadcontrollers.loadControllersFunc)());
59
- if (swaggerDisabled) {
60
- this.logger.log("Swagger/OpenAPI documentation disabled");
61
- } else {
62
- await (0, _swagger.setupSwagger)(app, this.logger);
63
- this.logger.log("Swagger/OpenAPI documentation enabled");
64
- }
65
- const bundleDistPath = (0, _nodepath.join)((0, _fsutils.getMediaPath)(), _serverconstants.AppConstants.defaultClientBundleStorage, "dist");
66
- const backupClientPath = (0, _nodepath.join)((0, _fsutils.superRootPath)(), "node_modules", _serverconstants.AppConstants.clientPackageName, "dist");
67
- app.use(_express.default.static(bundleDistPath));
68
- app.use(_express.default.static(backupClientPath));
69
- app.get("*", (req, _)=>{
70
- const path = req.originalUrl;
71
- let resource = "MVC";
72
- if (path.startsWith("/socket.io") || path.startsWith("/api") || path.startsWith("/metrics") || path.startsWith("/api-docs")) {
73
- resource = "API";
74
- } else if (path.endsWith(".min.js")) {
75
- resource = "client-bundle";
76
- }
77
- this.logger.error(`${resource} resource at '${path}' was not found`);
78
- if (!path.startsWith("/socket.io")) {
79
- throw new _runtimeexceptions.NotFoundException(`${resource} resource was not found`, path);
80
- }
81
- });
82
- app.use(this.exceptionFilter.handle.bind(this.exceptionFilter));
83
- }
84
- async httpListen(app) {
85
- const port = (0, _serverenv.fetchServerPort)();
86
- if (!port || Number.isNaN(Number.parseInt(port))) {
87
- throw new Error("The FDM Server requires a numeric port input argument to run");
88
- }
89
- const swaggerDisabled = process.env[_serverconstants.AppConstants.DISABLE_SWAGGER_OPENAPI] === "true";
90
- const hostOrFqdn = "0.0.0.0";
91
- const server = app.listen(Number.parseInt(port), hostOrFqdn, ()=>{
92
- this.logger.log(`Server started... open it at http://127.0.0.1:${port}`);
93
- if (!swaggerDisabled) {
94
- this.logger.log(`API Documentation available at http://127.0.0.1:${port}/api-docs`);
95
- }
96
- });
97
- this.socketIoGateway.attachServer(server);
98
- }
99
- }
1
+ import { NotFoundException } from "./exceptions/runtime.exceptions.js";
2
+ import { AppConstants } from "./server.constants.js";
3
+ import { getMediaPath, superRootPath } from "./utils/fs.utils.js";
4
+ import { fetchServerPort } from "./server.env.js";
5
+ import { loadControllersFunc } from "./shared/load-controllers.js";
6
+ import { setupSwagger } from "./utils/swagger/swagger.js";
7
+ import { join } from "node:path";
8
+ import express from "express";
9
+ import history from "connect-history-api-fallback";
10
+ //#region src/server.host.ts
11
+ var ServerHost = class ServerHost {
12
+ logger;
13
+ constructor(loggerFactory, configService, bootTask, socketIoGateway, typeormService, exceptionFilter) {
14
+ this.configService = configService;
15
+ this.bootTask = bootTask;
16
+ this.socketIoGateway = socketIoGateway;
17
+ this.typeormService = typeormService;
18
+ this.exceptionFilter = exceptionFilter;
19
+ this.logger = loggerFactory(ServerHost.name);
20
+ }
21
+ async boot(app, quick_boot = false, listenRequests = true) {
22
+ await this.serveControllerRoutes(app);
23
+ if (!quick_boot) await this.bootTask.runOnce();
24
+ if (listenRequests) return this.httpListen(app);
25
+ }
26
+ hasConnected() {
27
+ return this.typeormService.hasConnected();
28
+ }
29
+ async serveControllerRoutes(app) {
30
+ const swaggerDisabled = process.env[AppConstants.DISABLE_SWAGGER_OPENAPI] === "true";
31
+ app.use((req, res, next) => {
32
+ if (!req.originalUrl.startsWith("/metrics") && !req.originalUrl.startsWith("/api") && !req.originalUrl.startsWith("/api-docs") && !req.originalUrl.startsWith("/socket.io")) history()(req, res, next);
33
+ else next();
34
+ }).use(await loadControllersFunc());
35
+ if (swaggerDisabled) this.logger.log("Swagger/OpenAPI documentation disabled");
36
+ else {
37
+ await setupSwagger(app, this.logger);
38
+ this.logger.log("Swagger/OpenAPI documentation enabled");
39
+ }
40
+ const bundleDistPath = join(getMediaPath(), AppConstants.defaultClientBundleStorage, "dist");
41
+ const backupClientPath = join(superRootPath(), "node_modules", AppConstants.clientPackageName, "dist");
42
+ app.use(express.static(bundleDistPath));
43
+ app.use(express.static(backupClientPath));
44
+ app.get("*", (req, _) => {
45
+ const path = req.originalUrl;
46
+ let resource = "MVC";
47
+ if (path.startsWith("/socket.io") || path.startsWith("/api") || path.startsWith("/metrics") || path.startsWith("/api-docs")) resource = "API";
48
+ else if (path.endsWith(".min.js")) resource = "client-bundle";
49
+ this.logger.error(`${resource} resource at '${path}' was not found`);
50
+ if (!path.startsWith("/socket.io")) throw new NotFoundException(`${resource} resource was not found`, path);
51
+ });
52
+ app.use(this.exceptionFilter.handle.bind(this.exceptionFilter));
53
+ }
54
+ async httpListen(app) {
55
+ const port = fetchServerPort();
56
+ if (!port || Number.isNaN(Number.parseInt(port))) throw new Error("The FDM Server requires a numeric port input argument to run");
57
+ const swaggerDisabled = process.env[AppConstants.DISABLE_SWAGGER_OPENAPI] === "true";
58
+ const server = app.listen(Number.parseInt(port), "0.0.0.0", () => {
59
+ this.logger.log(`Server started... open it at http://127.0.0.1:${port}`);
60
+ if (!swaggerDisabled) this.logger.log(`API Documentation available at http://127.0.0.1:${port}/api-docs`);
61
+ });
62
+ this.socketIoGateway.attachServer(server);
63
+ }
64
+ };
65
+ //#endregion
66
+ export { ServerHost };
100
67
 
101
68
  //# sourceMappingURL=server.host.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/server.host.ts"],"names":["ServerHost","logger","loggerFactory","configService","bootTask","socketIoGateway","typeormService","exceptionFilter","name","boot","app","quick_boot","listenRequests","serveControllerRoutes","runOnce","httpListen","hasConnected","swaggerDisabled","process","env","AppConstants","DISABLE_SWAGGER_OPENAPI","use","req","res","next","originalUrl","startsWith","history","loadControllersFunc","log","setupSwagger","bundleDistPath","join","getMediaPath","defaultClientBundleStorage","backupClientPath","superRootPath","clientPackageName","express","static","get","_","path","resource","endsWith","error","NotFoundException","handle","bind","port","fetchServerPort","Number","isNaN","parseInt","Error","hostOrFqdn","server","listen","attachServer"],"mappings":";;;;+BAiBaA;;;eAAAA;;;gEAjBwB;kFACjB;0BAEC;2BAEW;mCACE;iCACL;yBACe;iCAMR;yBACP;;;;;;AAEtB,MAAMA;;;;;;IACMC,OAAsB;IAEvC,YACEC,aAA6B,EAC7B,AAAiBC,aAA6B,EAC9C,AAAiBC,QAAkB,EACnC,AAAiBC,eAAgC,EACjD,AAAiBC,cAA8B,EAC/C,AAAiBC,eAAgC,CACjD;aALiBJ,gBAAAA;aACAC,WAAAA;aACAC,kBAAAA;aACAC,iBAAAA;aACAC,kBAAAA;QAEjB,IAAI,CAACN,MAAM,GAAGC,cAAcF,WAAWQ,IAAI;IAC7C;IAEA,MAAMC,KAAKC,GAAgB,EAAEC,aAAa,KAAK,EAAEC,iBAAiB,IAAI,EAAE;QACtE,MAAM,IAAI,CAACC,qBAAqB,CAACH;QAEjC,IAAI,CAACC,YAAY;YACf,MAAM,IAAI,CAACP,QAAQ,CAACU,OAAO;QAC7B;QAEA,IAAIF,gBAAgB,OAAO,IAAI,CAACG,UAAU,CAACL;IAC7C;IAEAM,eAAe;QACb,OAAO,IAAI,CAACV,cAAc,CAACU,YAAY;IACzC;IAEA,MAAMH,sBAAsBH,GAAgB,EAAE;QAC5C,MAAMO,kBAAkBC,QAAQC,GAAG,CAACC,6BAAY,CAACC,uBAAuB,CAAC,KAAK;QAG9EX,IACGY,GAAG,CAAC,CAACC,KAAKC,KAAKC;YACd,IACE,CAACF,IAAIG,WAAW,CAACC,UAAU,CAAC,eAC5B,CAACJ,IAAIG,WAAW,CAACC,UAAU,CAAC,WAC5B,CAACJ,IAAIG,WAAW,CAACC,UAAU,CAAC,gBAC5B,CAACJ,IAAIG,WAAW,CAACC,UAAU,CAAC,eAC5B;gBACAC,IAAAA,kCAAO,IAAGL,KAAKC,KAAKC;YACtB,OAAO;gBACLA;YACF;QACF,GACCH,GAAG,CAACO,IAAAA,oCAAmB;QAG1B,IAAIZ,iBAAiB;YACnB,IAAI,CAAChB,MAAM,CAAC6B,GAAG,CAAC;QAClB,OAAO;YACL,MAAMC,IAAAA,qBAAY,EAACrB,KAAK,IAAI,CAACT,MAAM;YACnC,IAAI,CAACA,MAAM,CAAC6B,GAAG,CAAC;QAClB;QAEA,MAAME,iBAAiBC,IAAAA,cAAI,EAACC,IAAAA,qBAAY,KAAId,6BAAY,CAACe,0BAA0B,EAAE;QACrF,MAAMC,mBAAmBH,IAAAA,cAAI,EAACI,IAAAA,sBAAa,KAAI,gBAAgBjB,6BAAY,CAACkB,iBAAiB,EAAE;QAG/F5B,IAAIY,GAAG,CAACiB,gBAAO,CAACC,MAAM,CAACR;QAGvBtB,IAAIY,GAAG,CAACiB,gBAAO,CAACC,MAAM,CAACJ;QAEvB1B,IAAI+B,GAAG,CAAC,KAAK,CAAClB,KAAKmB;YACjB,MAAMC,OAAOpB,IAAIG,WAAW;YAE5B,IAAIkB,WAAW;YACf,IAAID,KAAKhB,UAAU,CAAC,iBAAiBgB,KAAKhB,UAAU,CAAC,WAAWgB,KAAKhB,UAAU,CAAC,eAAegB,KAAKhB,UAAU,CAAC,cAAc;gBAC3HiB,WAAW;YACb,OAAO,IAAID,KAAKE,QAAQ,CAAC,YAAY;gBACnCD,WAAW;YACb;YAEA,IAAI,CAAC3C,MAAM,CAAC6C,KAAK,CAAC,GAAGF,SAAS,cAAc,EAAED,KAAK,eAAe,CAAC;YAEnE,IAAI,CAACA,KAAKhB,UAAU,CAAC,eAAe;gBAClC,MAAM,IAAIoB,oCAAiB,CAAC,GAAGH,SAAS,uBAAuB,CAAC,EAAED;YACpE;QACF;QAEAjC,IAAIY,GAAG,CAAC,IAAI,CAACf,eAAe,CAACyC,MAAM,CAACC,IAAI,CAAC,IAAI,CAAC1C,eAAe;IAC/D;IAEA,MAAMQ,WAAWL,GAAgB,EAAE;QACjC,MAAMwC,OAAOC,IAAAA,0BAAe;QAE5B,IAAI,CAACD,QAAQE,OAAOC,KAAK,CAACD,OAAOE,QAAQ,CAACJ,QAAQ;YAChD,MAAM,IAAIK,MAAM;QAClB;QAEA,MAAMtC,kBAAkBC,QAAQC,GAAG,CAACC,6BAAY,CAACC,uBAAuB,CAAC,KAAK;QAC9E,MAAMmC,aAAa;QACnB,MAAMC,SAAS/C,IAAIgD,MAAM,CAACN,OAAOE,QAAQ,CAACJ,OAAOM,YAAY;YAC3D,IAAI,CAACvD,MAAM,CAAC6B,GAAG,CAAC,CAAC,8CAA8C,EAAEoB,MAAM;YACvE,IAAI,CAACjC,iBAAiB;gBACpB,IAAI,CAAChB,MAAM,CAAC6B,GAAG,CAAC,CAAC,gDAAgD,EAAEoB,KAAK,SAAS,CAAC;YACpF;QACF;QACA,IAAI,CAAC7C,eAAe,CAACsD,YAAY,CAACF;IACpC;AACF"}
1
+ {"version":3,"file":"server.host.js","names":[],"sources":["../src/server.host.ts"],"sourcesContent":["import express, { Application } from \"express\";\nimport history from \"connect-history-api-fallback\";\nimport { LoggerService } from \"./handlers/logger\";\nimport { join } from \"node:path\";\nimport { ExceptionFilter } from \"./middleware/exception.filter\";\nimport { fetchServerPort } from \"./server.env\";\nimport { NotFoundException } from \"./exceptions/runtime.exceptions\";\nimport { AppConstants } from \"./server.constants\";\nimport { getMediaPath, superRootPath } from \"./utils/fs.utils\";\nimport { SocketIoGateway } from \"@/state/socket-io.gateway\";\nimport { BootTask } from \"./tasks/boot.task\";\nimport type { IConfigService } from \"@/services/core/config.service\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\nimport { TypeormService } from \"@/services/typeorm/typeorm.service\";\nimport { loadControllersFunc } from \"@/shared/load-controllers\";\nimport { setupSwagger } from \"@/utils/swagger/swagger\";\n\nexport class ServerHost {\n private readonly logger: LoggerService;\n\n constructor(\n loggerFactory: ILoggerFactory,\n private readonly configService: IConfigService,\n private readonly bootTask: BootTask,\n private readonly socketIoGateway: SocketIoGateway,\n private readonly typeormService: TypeormService,\n private readonly exceptionFilter: ExceptionFilter,\n ) {\n this.logger = loggerFactory(ServerHost.name);\n }\n\n async boot(app: Application, quick_boot = false, listenRequests = true) {\n await this.serveControllerRoutes(app);\n\n if (!quick_boot) {\n await this.bootTask.runOnce();\n }\n\n if (listenRequests) return this.httpListen(app);\n }\n\n hasConnected() {\n return this.typeormService.hasConnected();\n }\n\n async serveControllerRoutes(app: Application) {\n const swaggerDisabled = process.env[AppConstants.DISABLE_SWAGGER_OPENAPI] === \"true\";\n\n // Catches any HTML request to paths like / or file/ as long as its text/html\n app\n .use((req, res, next) => {\n if (\n !req.originalUrl.startsWith(\"/metrics\") &&\n !req.originalUrl.startsWith(\"/api\") &&\n !req.originalUrl.startsWith(\"/api-docs\") &&\n !req.originalUrl.startsWith(\"/socket.io\")\n ) {\n history()(req, res, next);\n } else {\n next();\n }\n })\n .use(await loadControllersFunc());\n\n // Setup Swagger documentation (if enabled)\n if (swaggerDisabled) {\n this.logger.log(\"Swagger/OpenAPI documentation disabled\");\n } else {\n await setupSwagger(app, this.logger);\n this.logger.log(\"Swagger/OpenAPI documentation enabled\");\n }\n\n const bundleDistPath = join(getMediaPath(), AppConstants.defaultClientBundleStorage, \"dist\");\n const backupClientPath = join(superRootPath(), \"node_modules\", AppConstants.clientPackageName, \"dist\");\n\n // Serve the main bundle\n app.use(express.static(bundleDistPath));\n\n // Serve the backup client\n app.use(express.static(backupClientPath));\n\n app.get(\"*\", (req, _) => {\n const path = req.originalUrl;\n\n let resource = \"MVC\";\n if (\n path.startsWith(\"/socket.io\") ||\n path.startsWith(\"/api\") ||\n path.startsWith(\"/metrics\") ||\n path.startsWith(\"/api-docs\")\n ) {\n resource = \"API\";\n } else if (path.endsWith(\".min.js\")) {\n resource = \"client-bundle\";\n }\n\n this.logger.error(`${resource} resource at '${path}' was not found`);\n\n if (!path.startsWith(\"/socket.io\")) {\n throw new NotFoundException(`${resource} resource was not found`, path);\n }\n });\n\n app.use(this.exceptionFilter.handle.bind(this.exceptionFilter));\n }\n\n async httpListen(app: Application) {\n const port = fetchServerPort();\n\n if (!port || Number.isNaN(Number.parseInt(port))) {\n throw new Error(\"The FDM Server requires a numeric port input argument to run\");\n }\n\n const swaggerDisabled = process.env[AppConstants.DISABLE_SWAGGER_OPENAPI] === \"true\";\n const hostOrFqdn = \"0.0.0.0\";\n const server = app.listen(Number.parseInt(port), hostOrFqdn, () => {\n this.logger.log(`Server started... open it at http://127.0.0.1:${port}`);\n if (!swaggerDisabled) {\n this.logger.log(`API Documentation available at http://127.0.0.1:${port}/api-docs`);\n }\n });\n this.socketIoGateway.attachServer(server);\n }\n}\n"],"mappings":";;;;;;;;;;AAiBA,IAAa,aAAb,MAAa,WAAW;CACtB;CAEA,YACE,eACA,eACA,UACA,iBACA,gBACA,iBACA;AALiB,OAAA,gBAAA;AACA,OAAA,WAAA;AACA,OAAA,kBAAA;AACA,OAAA,iBAAA;AACA,OAAA,kBAAA;AAEjB,OAAK,SAAS,cAAc,WAAW,KAAK;;CAG9C,MAAM,KAAK,KAAkB,aAAa,OAAO,iBAAiB,MAAM;AACtE,QAAM,KAAK,sBAAsB,IAAI;AAErC,MAAI,CAAC,WACH,OAAM,KAAK,SAAS,SAAS;AAG/B,MAAI,eAAgB,QAAO,KAAK,WAAW,IAAI;;CAGjD,eAAe;AACb,SAAO,KAAK,eAAe,cAAc;;CAG3C,MAAM,sBAAsB,KAAkB;EAC5C,MAAM,kBAAkB,QAAQ,IAAI,aAAa,6BAA6B;AAG9E,MACG,KAAK,KAAK,KAAK,SAAS;AACvB,OACE,CAAC,IAAI,YAAY,WAAW,WAAW,IACvC,CAAC,IAAI,YAAY,WAAW,OAAO,IACnC,CAAC,IAAI,YAAY,WAAW,YAAY,IACxC,CAAC,IAAI,YAAY,WAAW,aAAa,CAEzC,UAAS,CAAC,KAAK,KAAK,KAAK;OAEzB,OAAM;IAER,CACD,IAAI,MAAM,qBAAqB,CAAC;AAGnC,MAAI,gBACF,MAAK,OAAO,IAAI,yCAAyC;OACpD;AACL,SAAM,aAAa,KAAK,KAAK,OAAO;AACpC,QAAK,OAAO,IAAI,wCAAwC;;EAG1D,MAAM,iBAAiB,KAAK,cAAc,EAAE,aAAa,4BAA4B,OAAO;EAC5F,MAAM,mBAAmB,KAAK,eAAe,EAAE,gBAAgB,aAAa,mBAAmB,OAAO;AAGtG,MAAI,IAAI,QAAQ,OAAO,eAAe,CAAC;AAGvC,MAAI,IAAI,QAAQ,OAAO,iBAAiB,CAAC;AAEzC,MAAI,IAAI,MAAM,KAAK,MAAM;GACvB,MAAM,OAAO,IAAI;GAEjB,IAAI,WAAW;AACf,OACE,KAAK,WAAW,aAAa,IAC7B,KAAK,WAAW,OAAO,IACvB,KAAK,WAAW,WAAW,IAC3B,KAAK,WAAW,YAAY,CAE5B,YAAW;YACF,KAAK,SAAS,UAAU,CACjC,YAAW;AAGb,QAAK,OAAO,MAAM,GAAG,SAAS,gBAAgB,KAAK,iBAAiB;AAEpE,OAAI,CAAC,KAAK,WAAW,aAAa,CAChC,OAAM,IAAI,kBAAkB,GAAG,SAAS,0BAA0B,KAAK;IAEzE;AAEF,MAAI,IAAI,KAAK,gBAAgB,OAAO,KAAK,KAAK,gBAAgB,CAAC;;CAGjE,MAAM,WAAW,KAAkB;EACjC,MAAM,OAAO,iBAAiB;AAE9B,MAAI,CAAC,QAAQ,OAAO,MAAM,OAAO,SAAS,KAAK,CAAC,CAC9C,OAAM,IAAI,MAAM,+DAA+D;EAGjF,MAAM,kBAAkB,QAAQ,IAAI,aAAa,6BAA6B;EAE9E,MAAM,SAAS,IAAI,OAAO,OAAO,SAAS,KAAK,EAAE,iBAAkB;AACjE,QAAK,OAAO,IAAI,iDAAiD,OAAO;AACxE,OAAI,CAAC,gBACH,MAAK,OAAO,IAAI,mDAAmD,KAAK,WAAW;IAErF;AACF,OAAK,gBAAgB,aAAa,OAAO"}
@@ -1,128 +1,105 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "AuthService", {
6
- enumerable: true,
7
- get: function() {
8
- return AuthService;
9
- }
10
- });
11
- const _runtimeexceptions = require("../../exceptions/runtime.exceptions");
12
- const _cryptoutils = require("../../utils/crypto.utils");
13
- const _authorizationconstants = require("../../constants/authorization.constants");
14
- const _node = require("@sentry/node");
15
- class AuthService {
16
- userService;
17
- jwtService;
18
- settingsStore;
19
- refreshTokenService;
20
- logger;
21
- blacklistedJwtCache = {};
22
- constructor(loggerFactory, userService, jwtService, settingsStore, refreshTokenService){
23
- this.userService = userService;
24
- this.jwtService = jwtService;
25
- this.settingsStore = settingsStore;
26
- this.refreshTokenService = refreshTokenService;
27
- this.logger = loggerFactory(AuthService.name);
28
- }
29
- async loginUser(username, password) {
30
- const userDoc = await this.userService.findRawByUsername(username);
31
- if (!userDoc) {
32
- throw new _runtimeexceptions.AuthenticationError("Login incorrect", _authorizationconstants.AUTH_ERROR_REASON.IncorrectCredentials);
33
- }
34
- const result = (0, _cryptoutils.comparePasswordHash)(password, userDoc.passwordHash);
35
- if (!result) {
36
- throw new _runtimeexceptions.AuthenticationError("Login incorrect", _authorizationconstants.AUTH_ERROR_REASON.IncorrectCredentials);
37
- }
38
- const userId = userDoc.id;
39
- const token = await this.signJwtToken(userId);
40
- await this.refreshTokenService.purgeOutdatedRefreshTokensByUserId(userId);
41
- await this.purgeOutdatedBlacklistedJwtCache();
42
- const refreshToken = await this.refreshTokenService.createRefreshTokenForUserId(userId);
43
- return {
44
- token,
45
- refreshToken
46
- };
47
- }
48
- async logoutUserId(userId, jwtToken) {
49
- await this.refreshTokenService.deleteRefreshTokenByUserId(userId);
50
- if (jwtToken?.length) {
51
- this.blacklistedJwtCache[jwtToken] = {
52
- userId,
53
- createdAt: Date.now()
54
- };
55
- await this.purgeOutdatedBlacklistedJwtCache();
56
- }
57
- }
58
- async purgeOutdatedBlacklistedJwtCache() {
59
- try {
60
- const { jwtExpiresIn } = await this.settingsStore.getCredentialSettings();
61
- const now = Date.now();
62
- const keys = Object.keys(this.blacklistedJwtCache);
63
- for (const key of keys){
64
- const { createdAt } = this.blacklistedJwtCache[key];
65
- if (now - createdAt > jwtExpiresIn) {
66
- delete this.blacklistedJwtCache[key];
67
- }
68
- }
69
- } catch (err) {
70
- this.logger.error("Failed to purge blacklisted jwt cache", err);
71
- (0, _node.captureException)(err);
72
- }
73
- }
74
- async logoutUserRefreshToken(refreshToken) {
75
- const userRefreshToken = await this.getValidRefreshToken(refreshToken);
76
- await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);
77
- }
78
- async renewLoginByRefreshToken(refreshToken) {
79
- const userRefreshToken = await this.getValidRefreshToken(refreshToken);
80
- const userId = userRefreshToken.userId;
81
- const user = await this.userService.getUser(userId);
82
- if (!user) {
83
- await this.refreshTokenService.deleteRefreshToken(refreshToken);
84
- throw new _runtimeexceptions.AuthenticationError("User not found", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
85
- }
86
- const token = await this.signJwtToken(userId);
87
- await this.increaseRefreshTokenAttemptsUsed(userRefreshToken.refreshToken);
88
- return token;
89
- }
90
- isJwtTokenBlacklisted(jwtToken) {
91
- return this.blacklistedJwtCache[jwtToken];
92
- }
93
- async getValidRefreshToken(refreshToken) {
94
- const userRefreshToken = await this.refreshTokenService.getRefreshToken(refreshToken);
95
- if (Date.now() > userRefreshToken.expiresAt) {
96
- await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);
97
- throw new _runtimeexceptions.AuthenticationError("Refresh token expired, login required", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
98
- }
99
- return userRefreshToken;
100
- }
101
- async increaseRefreshTokenAttemptsUsed(refreshToken) {
102
- const { refreshTokenAttempts } = await this.settingsStore.getCredentialSettings();
103
- const userRefreshToken = await this.getValidRefreshToken(refreshToken);
104
- const attemptsUsed = userRefreshToken.refreshAttemptsUsed;
105
- if (refreshTokenAttempts !== -1) {
106
- if (attemptsUsed >= refreshTokenAttempts) {
107
- await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);
108
- throw new _runtimeexceptions.AuthenticationError("Refresh token attempts exceeded, login required", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
109
- }
110
- }
111
- await this.refreshTokenService.updateRefreshTokenAttempts(refreshToken, attemptsUsed + 1);
112
- }
113
- async signJwtToken(userId) {
114
- const user = await this.userService.getUser(userId);
115
- if (!user) {
116
- throw new _runtimeexceptions.AuthenticationError("User not found", _authorizationconstants.AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
117
- }
118
- if (user.needsPasswordChange) {
119
- throw new _runtimeexceptions.AuthenticationError("Password change required", _authorizationconstants.AUTH_ERROR_REASON.PasswordChangeRequired);
120
- }
121
- if (!user.isVerified) {
122
- throw new _runtimeexceptions.AuthenticationError("User is not verified yet", _authorizationconstants.AUTH_ERROR_REASON.AccountNotVerified);
123
- }
124
- return this.jwtService.signJwtToken(userId, user.username);
125
- }
126
- }
1
+ import { AuthenticationError } from "../../exceptions/runtime.exceptions.js";
2
+ import { AUTH_ERROR_REASON } from "../../constants/authorization.constants.js";
3
+ import { comparePasswordHash } from "../../utils/crypto.utils.js";
4
+ import { captureException } from "@sentry/node";
5
+ //#region src/services/authentication/auth.service.ts
6
+ var AuthService = class AuthService {
7
+ logger;
8
+ /**
9
+ * When users are blacklisted at runtime, this cache can make quick work of rejecting them
10
+ */
11
+ blacklistedJwtCache = {};
12
+ constructor(loggerFactory, userService, jwtService, settingsStore, refreshTokenService) {
13
+ this.userService = userService;
14
+ this.jwtService = jwtService;
15
+ this.settingsStore = settingsStore;
16
+ this.refreshTokenService = refreshTokenService;
17
+ this.logger = loggerFactory(AuthService.name);
18
+ }
19
+ async loginUser(username, password) {
20
+ const userDoc = await this.userService.findRawByUsername(username);
21
+ if (!userDoc) throw new AuthenticationError("Login incorrect", AUTH_ERROR_REASON.IncorrectCredentials);
22
+ if (!comparePasswordHash(password, userDoc.passwordHash)) throw new AuthenticationError("Login incorrect", AUTH_ERROR_REASON.IncorrectCredentials);
23
+ const userId = userDoc.id;
24
+ const token = await this.signJwtToken(userId);
25
+ await this.refreshTokenService.purgeOutdatedRefreshTokensByUserId(userId);
26
+ await this.purgeOutdatedBlacklistedJwtCache();
27
+ return {
28
+ token,
29
+ refreshToken: await this.refreshTokenService.createRefreshTokenForUserId(userId)
30
+ };
31
+ }
32
+ async logoutUserId(userId, jwtToken) {
33
+ await this.refreshTokenService.deleteRefreshTokenByUserId(userId);
34
+ if (jwtToken?.length) {
35
+ this.blacklistedJwtCache[jwtToken] = {
36
+ userId,
37
+ createdAt: Date.now()
38
+ };
39
+ await this.purgeOutdatedBlacklistedJwtCache();
40
+ }
41
+ }
42
+ async purgeOutdatedBlacklistedJwtCache() {
43
+ try {
44
+ const { jwtExpiresIn } = await this.settingsStore.getCredentialSettings();
45
+ const now = Date.now();
46
+ const keys = Object.keys(this.blacklistedJwtCache);
47
+ for (const key of keys) {
48
+ const { createdAt } = this.blacklistedJwtCache[key];
49
+ if (now - createdAt > jwtExpiresIn) delete this.blacklistedJwtCache[key];
50
+ }
51
+ } catch (err) {
52
+ this.logger.error("Failed to purge blacklisted jwt cache", err);
53
+ captureException(err);
54
+ }
55
+ }
56
+ async logoutUserRefreshToken(refreshToken) {
57
+ const userRefreshToken = await this.getValidRefreshToken(refreshToken);
58
+ await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);
59
+ }
60
+ async renewLoginByRefreshToken(refreshToken) {
61
+ const userRefreshToken = await this.getValidRefreshToken(refreshToken);
62
+ const userId = userRefreshToken.userId;
63
+ if (!await this.userService.getUser(userId)) {
64
+ await this.refreshTokenService.deleteRefreshToken(refreshToken);
65
+ throw new AuthenticationError("User not found", AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
66
+ }
67
+ const token = await this.signJwtToken(userId);
68
+ await this.increaseRefreshTokenAttemptsUsed(userRefreshToken.refreshToken);
69
+ return token;
70
+ }
71
+ isJwtTokenBlacklisted(jwtToken) {
72
+ return this.blacklistedJwtCache[jwtToken];
73
+ }
74
+ async getValidRefreshToken(refreshToken) {
75
+ const userRefreshToken = await this.refreshTokenService.getRefreshToken(refreshToken);
76
+ if (Date.now() > userRefreshToken.expiresAt) {
77
+ await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);
78
+ throw new AuthenticationError("Refresh token expired, login required", AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
79
+ }
80
+ return userRefreshToken;
81
+ }
82
+ async increaseRefreshTokenAttemptsUsed(refreshToken) {
83
+ const { refreshTokenAttempts } = await this.settingsStore.getCredentialSettings();
84
+ const userRefreshToken = await this.getValidRefreshToken(refreshToken);
85
+ const attemptsUsed = userRefreshToken.refreshAttemptsUsed;
86
+ if (refreshTokenAttempts !== -1) {
87
+ if (attemptsUsed >= refreshTokenAttempts) {
88
+ await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);
89
+ throw new AuthenticationError("Refresh token attempts exceeded, login required", AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
90
+ }
91
+ }
92
+ await this.refreshTokenService.updateRefreshTokenAttempts(refreshToken, attemptsUsed + 1);
93
+ }
94
+ async signJwtToken(userId) {
95
+ const user = await this.userService.getUser(userId);
96
+ if (!user) throw new AuthenticationError("User not found", AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);
97
+ if (user.needsPasswordChange) throw new AuthenticationError("Password change required", AUTH_ERROR_REASON.PasswordChangeRequired);
98
+ if (!user.isVerified) throw new AuthenticationError("User is not verified yet", AUTH_ERROR_REASON.AccountNotVerified);
99
+ return this.jwtService.signJwtToken(userId, user.username);
100
+ }
101
+ };
102
+ //#endregion
103
+ export { AuthService };
127
104
 
128
105
  //# sourceMappingURL=auth.service.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/services/authentication/auth.service.ts"],"names":["AuthService","logger","blacklistedJwtCache","loggerFactory","userService","jwtService","settingsStore","refreshTokenService","name","loginUser","username","password","userDoc","findRawByUsername","AuthenticationError","AUTH_ERROR_REASON","IncorrectCredentials","result","comparePasswordHash","passwordHash","userId","id","token","signJwtToken","purgeOutdatedRefreshTokensByUserId","purgeOutdatedBlacklistedJwtCache","refreshToken","createRefreshTokenForUserId","logoutUserId","jwtToken","deleteRefreshTokenByUserId","length","createdAt","Date","now","jwtExpiresIn","getCredentialSettings","keys","Object","key","err","error","captureException","logoutUserRefreshToken","userRefreshToken","getValidRefreshToken","renewLoginByRefreshToken","user","getUser","deleteRefreshToken","InvalidOrExpiredRefreshToken","increaseRefreshTokenAttemptsUsed","isJwtTokenBlacklisted","getRefreshToken","expiresAt","refreshTokenAttempts","attemptsUsed","refreshAttemptsUsed","updateRefreshTokenAttempts","needsPasswordChange","PasswordChangeRequired","isVerified","AccountNotVerified"],"mappings":";;;;+BAaaA;;;eAAAA;;;mCAbuB;6BACA;wCAQF;sBACD;AAG1B,MAAMA;;;;;IACMC,OAAsB;IAI/BC,sBAA6E,CAAC,EAAE;IAExF,YACEC,aAA6B,EAC7B,AAAiBC,WAA+B,EAChD,AAAiBC,UAAuB,EACxC,AAAiBC,aAA4B,EAC7C,AAAiBC,mBAAyC,CAC1D;aAJiBH,cAAAA;aACAC,aAAAA;aACAC,gBAAAA;aACAC,sBAAAA;QAEjB,IAAI,CAACN,MAAM,GAAGE,cAAcH,YAAYQ,IAAI;IAC9C;IAEA,MAAMC,UAAUC,QAAgB,EAAEC,QAAgB,EAAE;QAClD,MAAMC,UAAU,MAAM,IAAI,CAACR,WAAW,CAACS,iBAAiB,CAACH;QACzD,IAAI,CAACE,SAAS;YACZ,MAAM,IAAIE,sCAAmB,CAAC,mBAAmBC,yCAAiB,CAACC,oBAAoB;QACzF;QACA,MAAMC,SAASC,IAAAA,gCAAmB,EAACP,UAAUC,QAAQO,YAAY;QACjE,IAAI,CAACF,QAAQ;YACX,MAAM,IAAIH,sCAAmB,CAAC,mBAAmBC,yCAAiB,CAACC,oBAAoB;QACzF;QAEA,MAAMI,SAASR,QAAQS,EAAE;QACzB,MAAMC,QAAQ,MAAM,IAAI,CAACC,YAAY,CAACH;QACtC,MAAM,IAAI,CAACb,mBAAmB,CAACiB,kCAAkC,CAACJ;QAClE,MAAM,IAAI,CAACK,gCAAgC;QAE3C,MAAMC,eAAe,MAAM,IAAI,CAACnB,mBAAmB,CAACoB,2BAA2B,CAACP;QAChF,OAAO;YACLE;YACAI;QACF;IACF;IAEA,MAAME,aAAaR,MAAc,EAAES,QAAiB,EAAE;QACpD,MAAM,IAAI,CAACtB,mBAAmB,CAACuB,0BAA0B,CAACV;QAC1D,IAAIS,UAAUE,QAAQ;YACpB,IAAI,CAAC7B,mBAAmB,CAAC2B,SAAS,GAAG;gBAAET;gBAAQY,WAAWC,KAAKC,GAAG;YAAG;YACrE,MAAM,IAAI,CAACT,gCAAgC;QAC7C;IACF;IAEA,MAAMA,mCAAmC;QACvC,IAAI;YACF,MAAM,EAAEU,YAAY,EAAE,GAAG,MAAM,IAAI,CAAC7B,aAAa,CAAC8B,qBAAqB;YACvE,MAAMF,MAAMD,KAAKC,GAAG;YACpB,MAAMG,OAAOC,OAAOD,IAAI,CAAC,IAAI,CAACnC,mBAAmB;YACjD,KAAK,MAAMqC,OAAOF,KAAM;gBACtB,MAAM,EAAEL,SAAS,EAAE,GAAG,IAAI,CAAC9B,mBAAmB,CAACqC,IAAI;gBACnD,IAAIL,MAAMF,YAAYG,cAAc;oBAClC,OAAO,IAAI,CAACjC,mBAAmB,CAACqC,IAAI;gBACtC;YACF;QACF,EAAE,OAAOC,KAAK;YACZ,IAAI,CAACvC,MAAM,CAACwC,KAAK,CAAC,yCAAyCD;YAC3DE,IAAAA,sBAAgB,EAACF;QACnB;IACF;IAEA,MAAMG,uBAAuBjB,YAAoB,EAAE;QACjD,MAAMkB,mBAAmB,MAAM,IAAI,CAACC,oBAAoB,CAACnB;QACzD,MAAM,IAAI,CAACnB,mBAAmB,CAACuB,0BAA0B,CAACc,iBAAiBxB,MAAM;IACnF;IAEA,MAAM0B,yBAAyBpB,YAAoB,EAAmB;QACpE,MAAMkB,mBAAmB,MAAM,IAAI,CAACC,oBAAoB,CAACnB;QAEzD,MAAMN,SAASwB,iBAAiBxB,MAAM;QACtC,MAAM2B,OAAO,MAAM,IAAI,CAAC3C,WAAW,CAAC4C,OAAO,CAAC5B;QAC5C,IAAI,CAAC2B,MAAM;YACT,MAAM,IAAI,CAACxC,mBAAmB,CAAC0C,kBAAkB,CAACvB;YAClD,MAAM,IAAIZ,sCAAmB,CAAC,kBAAkBC,yCAAiB,CAACmC,4BAA4B;QAChG;QAGA,MAAM5B,QAAQ,MAAM,IAAI,CAACC,YAAY,CAACH;QACtC,MAAM,IAAI,CAAC+B,gCAAgC,CAACP,iBAAiBlB,YAAY;QACzE,OAAOJ;IACT;IAEA8B,sBAAsBvB,QAAgB,EAAE;QACtC,OAAO,IAAI,CAAC3B,mBAAmB,CAAC2B,SAAS;IAC3C;IAEA,MAAMgB,qBAAqBnB,YAAoB,EAAE;QAC/C,MAAMkB,mBAAmB,MAAM,IAAI,CAACrC,mBAAmB,CAAC8C,eAAe,CAAC3B;QACxE,IAAIO,KAAKC,GAAG,KAAKU,iBAAiBU,SAAS,EAAE;YAC3C,MAAM,IAAI,CAAC/C,mBAAmB,CAACuB,0BAA0B,CAACc,iBAAiBxB,MAAM;YACjF,MAAM,IAAIN,sCAAmB,CAC3B,yCACAC,yCAAiB,CAACmC,4BAA4B;QAElD;QACA,OAAON;IACT;IAEA,MAAMO,iCAAiCzB,YAAoB,EAAiB;QAC1E,MAAM,EAAE6B,oBAAoB,EAAE,GAAG,MAAM,IAAI,CAACjD,aAAa,CAAC8B,qBAAqB;QAC/E,MAAMQ,mBAAmB,MAAM,IAAI,CAACC,oBAAoB,CAACnB;QACzD,MAAM8B,eAAeZ,iBAAiBa,mBAAmB;QAGzD,IAAIF,yBAAyB,CAAC,GAAG;YAC/B,IAAIC,gBAAgBD,sBAAsB;gBACxC,MAAM,IAAI,CAAChD,mBAAmB,CAACuB,0BAA0B,CAACc,iBAAiBxB,MAAM;gBACjF,MAAM,IAAIN,sCAAmB,CAC3B,mDACAC,yCAAiB,CAACmC,4BAA4B;YAElD;QACF;QAEA,MAAM,IAAI,CAAC3C,mBAAmB,CAACmD,0BAA0B,CAAChC,cAAc8B,eAAe;IACzF;IAEA,MAAMjC,aAAaH,MAAc,EAAE;QACjC,MAAM2B,OAAO,MAAM,IAAI,CAAC3C,WAAW,CAAC4C,OAAO,CAAC5B;QAC5C,IAAI,CAAC2B,MAAM;YACT,MAAM,IAAIjC,sCAAmB,CAAC,kBAAkBC,yCAAiB,CAACmC,4BAA4B;QAChG;QACA,IAAIH,KAAKY,mBAAmB,EAAE;YAC5B,MAAM,IAAI7C,sCAAmB,CAAC,4BAA4BC,yCAAiB,CAAC6C,sBAAsB;QACpG;QACA,IAAI,CAACb,KAAKc,UAAU,EAAE;YACpB,MAAM,IAAI/C,sCAAmB,CAAC,4BAA4BC,yCAAiB,CAAC+C,kBAAkB;QAChG;QACA,OAAO,IAAI,CAACzD,UAAU,CAACkB,YAAY,CAACH,QAAQ2B,KAAKrC,QAAQ;IAC3D;AACF"}
1
+ {"version":3,"file":"auth.service.js","names":[],"sources":["../../../src/services/authentication/auth.service.ts"],"sourcesContent":["import { AuthenticationError } from \"@/exceptions/runtime.exceptions\";\nimport { comparePasswordHash } from \"@/utils/crypto.utils\";\nimport { SettingsStore } from \"@/state/settings.store\";\nimport { LoggerService } from \"@/handlers/logger\";\nimport type { ILoggerFactory } from \"@/handlers/logger-factory\";\nimport type { IUserService } from \"@/services/interfaces/user-service.interface\";\nimport type { IJwtService } from \"@/services/interfaces/jwt.service.interface\";\nimport type { IAuthService } from \"@/services/interfaces/auth.service.interface\";\nimport type { IRefreshTokenService } from \"@/services/interfaces/refresh-token.service.interface\";\nimport { AUTH_ERROR_REASON } from \"@/constants/authorization.constants\";\nimport { captureException } from \"@sentry/node\";\nimport { User } from \"@/entities\";\n\nexport class AuthService implements IAuthService {\n private readonly logger: LoggerService;\n /**\n * When users are blacklisted at runtime, this cache can make quick work of rejecting them\n */\n private blacklistedJwtCache: Record<string, { userId: number; createdAt: number }> = {};\n\n constructor(\n loggerFactory: ILoggerFactory,\n private readonly userService: IUserService<User>,\n private readonly jwtService: IJwtService,\n private readonly settingsStore: SettingsStore,\n private readonly refreshTokenService: IRefreshTokenService,\n ) {\n this.logger = loggerFactory(AuthService.name);\n }\n\n async loginUser(username: string, password: string) {\n const userDoc = await this.userService.findRawByUsername(username);\n if (!userDoc) {\n throw new AuthenticationError(\"Login incorrect\", AUTH_ERROR_REASON.IncorrectCredentials);\n }\n const result = comparePasswordHash(password, userDoc.passwordHash);\n if (!result) {\n throw new AuthenticationError(\"Login incorrect\", AUTH_ERROR_REASON.IncorrectCredentials);\n }\n\n const userId = userDoc.id;\n const token = await this.signJwtToken(userId);\n await this.refreshTokenService.purgeOutdatedRefreshTokensByUserId(userId);\n await this.purgeOutdatedBlacklistedJwtCache();\n\n const refreshToken = await this.refreshTokenService.createRefreshTokenForUserId(userId);\n return {\n token,\n refreshToken,\n };\n }\n\n async logoutUserId(userId: number, jwtToken?: string) {\n await this.refreshTokenService.deleteRefreshTokenByUserId(userId);\n if (jwtToken?.length) {\n this.blacklistedJwtCache[jwtToken] = { userId, createdAt: Date.now() };\n await this.purgeOutdatedBlacklistedJwtCache();\n }\n }\n\n async purgeOutdatedBlacklistedJwtCache() {\n try {\n const { jwtExpiresIn } = await this.settingsStore.getCredentialSettings();\n const now = Date.now();\n const keys = Object.keys(this.blacklistedJwtCache);\n for (const key of keys) {\n const { createdAt } = this.blacklistedJwtCache[key];\n if (now - createdAt > jwtExpiresIn) {\n delete this.blacklistedJwtCache[key];\n }\n }\n } catch (err) {\n this.logger.error(\"Failed to purge blacklisted jwt cache\", err);\n captureException(err);\n }\n }\n\n async logoutUserRefreshToken(refreshToken: string) {\n const userRefreshToken = await this.getValidRefreshToken(refreshToken);\n await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);\n }\n\n async renewLoginByRefreshToken(refreshToken: string): Promise<string> {\n const userRefreshToken = await this.getValidRefreshToken(refreshToken);\n\n const userId = userRefreshToken.userId;\n const user = await this.userService.getUser(userId);\n if (!user) {\n await this.refreshTokenService.deleteRefreshToken(refreshToken);\n throw new AuthenticationError(\"User not found\", AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);\n }\n\n // If the user is not found at this point, then the user was deleted\n const token = await this.signJwtToken(userId);\n await this.increaseRefreshTokenAttemptsUsed(userRefreshToken.refreshToken);\n return token;\n }\n\n isJwtTokenBlacklisted(jwtToken: string) {\n return this.blacklistedJwtCache[jwtToken];\n }\n\n async getValidRefreshToken(refreshToken: string) {\n const userRefreshToken = await this.refreshTokenService.getRefreshToken(refreshToken);\n if (Date.now() > userRefreshToken.expiresAt) {\n await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);\n throw new AuthenticationError(\n \"Refresh token expired, login required\",\n AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken,\n );\n }\n return userRefreshToken;\n }\n\n async increaseRefreshTokenAttemptsUsed(refreshToken: string): Promise<void> {\n const { refreshTokenAttempts } = await this.settingsStore.getCredentialSettings();\n const userRefreshToken = await this.getValidRefreshToken(refreshToken);\n const attemptsUsed = userRefreshToken.refreshAttemptsUsed;\n\n // If no attempts are set, then we don't care about attempts\n if (refreshTokenAttempts !== -1) {\n if (attemptsUsed >= refreshTokenAttempts) {\n await this.refreshTokenService.deleteRefreshTokenByUserId(userRefreshToken.userId);\n throw new AuthenticationError(\n \"Refresh token attempts exceeded, login required\",\n AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken,\n );\n }\n }\n\n await this.refreshTokenService.updateRefreshTokenAttempts(refreshToken, attemptsUsed + 1);\n }\n\n async signJwtToken(userId: number) {\n const user = await this.userService.getUser(userId);\n if (!user) {\n throw new AuthenticationError(\"User not found\", AUTH_ERROR_REASON.InvalidOrExpiredRefreshToken);\n }\n if (user.needsPasswordChange) {\n throw new AuthenticationError(\"Password change required\", AUTH_ERROR_REASON.PasswordChangeRequired);\n }\n if (!user.isVerified) {\n throw new AuthenticationError(\"User is not verified yet\", AUTH_ERROR_REASON.AccountNotVerified);\n }\n return this.jwtService.signJwtToken(userId, user.username);\n }\n}\n"],"mappings":"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"}
@@ -1,34 +1,25 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "JwtService", {
6
- enumerable: true,
7
- get: function() {
8
- return JwtService;
9
- }
10
- });
11
- const _jsonwebtoken = require("jsonwebtoken");
12
- const _serverconstants = require("../../server.constants");
13
- class JwtService {
14
- settingsStore;
15
- configService;
16
- constructor(settingsStore, configService){
17
- this.settingsStore = settingsStore;
18
- this.configService = configService;
19
- }
20
- async signJwtToken(userId, username) {
21
- const { jwtSecret, jwtExpiresIn } = await this.settingsStore.getCredentialSettings();
22
- return (0, _jsonwebtoken.sign)({
23
- userId,
24
- username
25
- }, jwtSecret, {
26
- expiresIn: jwtExpiresIn,
27
- subject: userId.toString(),
28
- audience: this.configService.get(_serverconstants.AppConstants.OVERRIDE_JWT_AUDIENCE, _serverconstants.AppConstants.DEFAULT_JWT_AUDIENCE),
29
- issuer: this.configService.get(_serverconstants.AppConstants.OVERRIDE_JWT_ISSUER, _serverconstants.AppConstants.DEFAULT_JWT_ISSUER)
30
- });
31
- }
32
- }
1
+ import { AppConstants } from "../../server.constants.js";
2
+ import jwt from "jsonwebtoken";
3
+ //#region src/services/authentication/jwt.service.ts
4
+ var JwtService = class {
5
+ constructor(settingsStore, configService) {
6
+ this.settingsStore = settingsStore;
7
+ this.configService = configService;
8
+ }
9
+ async signJwtToken(userId, username) {
10
+ const { jwtSecret, jwtExpiresIn } = await this.settingsStore.getCredentialSettings();
11
+ return jwt.sign({
12
+ userId,
13
+ username
14
+ }, jwtSecret, {
15
+ expiresIn: jwtExpiresIn,
16
+ subject: userId.toString(),
17
+ audience: this.configService.get(AppConstants.OVERRIDE_JWT_AUDIENCE, AppConstants.DEFAULT_JWT_AUDIENCE),
18
+ issuer: this.configService.get(AppConstants.OVERRIDE_JWT_ISSUER, AppConstants.DEFAULT_JWT_ISSUER)
19
+ });
20
+ }
21
+ };
22
+ //#endregion
23
+ export { JwtService };
33
24
 
34
25
  //# sourceMappingURL=jwt.service.js.map