@resolveio/server-lib 22.2.34 → 22.2.36

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 (649) hide show
  1. package/ai/assistant-core-heuristics.d.ts +11 -0
  2. package/ai/assistant-core-heuristics.js +531 -0
  3. package/ai/assistant-core-heuristics.js.map +1 -0
  4. package/client-server-app.d.ts +1 -0
  5. package/client-server-app.js +68 -0
  6. package/client-server-app.js.map +1 -0
  7. package/collections/ai-terminal-conversation.collection.d.ts +2 -0
  8. package/collections/ai-terminal-conversation.collection.js +140 -0
  9. package/collections/ai-terminal-conversation.collection.js.map +1 -0
  10. package/collections/ai-terminal-issue-report.collection.d.ts +2 -0
  11. package/collections/ai-terminal-issue-report.collection.js +148 -0
  12. package/collections/ai-terminal-issue-report.collection.js.map +1 -0
  13. package/collections/ai-terminal-message.collection.d.ts +2 -0
  14. package/collections/ai-terminal-message.collection.js +121 -0
  15. package/collections/ai-terminal-message.collection.js.map +1 -0
  16. package/collections/app-setting.collection.d.ts +3 -0
  17. package/collections/app-setting.collection.js +103 -0
  18. package/collections/app-setting.collection.js.map +1 -0
  19. package/collections/app-status.collection.d.ts +3 -0
  20. package/collections/app-status.collection.js +57 -0
  21. package/collections/app-status.collection.js.map +1 -0
  22. package/collections/communication-metric.collection.d.ts +2 -0
  23. package/collections/communication-metric.collection.js +133 -0
  24. package/collections/communication-metric.collection.js.map +1 -0
  25. package/collections/counter.collection.d.ts +3 -0
  26. package/collections/counter.collection.js +56 -0
  27. package/collections/counter.collection.js.map +1 -0
  28. package/collections/cron-job-history.collection.d.ts +3 -0
  29. package/collections/cron-job-history.collection.js +137 -0
  30. package/collections/cron-job-history.collection.js.map +1 -0
  31. package/collections/cron-job.collection.d.ts +3 -0
  32. package/collections/cron-job.collection.js +92 -0
  33. package/collections/cron-job.collection.js.map +1 -0
  34. package/collections/customer-notification.collection.d.ts +3 -0
  35. package/collections/customer-notification.collection.js +130 -0
  36. package/collections/customer-notification.collection.js.map +1 -0
  37. package/collections/customer-portal-password.collection.d.ts +3 -0
  38. package/collections/customer-portal-password.collection.js +75 -0
  39. package/collections/customer-portal-password.collection.js.map +1 -0
  40. package/collections/email-history.collection.d.ts +3 -0
  41. package/collections/email-history.collection.js +121 -0
  42. package/collections/email-history.collection.js.map +1 -0
  43. package/collections/email-verified.collection.d.ts +3 -0
  44. package/collections/email-verified.collection.js +61 -0
  45. package/collections/email-verified.collection.js.map +1 -0
  46. package/collections/file.collection.d.ts +3 -0
  47. package/collections/file.collection.js +74 -0
  48. package/collections/file.collection.js.map +1 -0
  49. package/collections/flag-update.collection.d.ts +3 -0
  50. package/collections/flag-update.collection.js +57 -0
  51. package/collections/flag-update.collection.js.map +1 -0
  52. package/collections/flag.collection.d.ts +3 -0
  53. package/collections/flag.collection.js +57 -0
  54. package/collections/flag.collection.js.map +1 -0
  55. package/collections/log-method-latency.collection.d.ts +3 -0
  56. package/collections/log-method-latency.collection.js +77 -0
  57. package/collections/log-method-latency.collection.js.map +1 -0
  58. package/collections/log-subscription.collection.d.ts +3 -0
  59. package/collections/log-subscription.collection.js +80 -0
  60. package/collections/log-subscription.collection.js.map +1 -0
  61. package/collections/log.collection.d.ts +3 -0
  62. package/collections/log.collection.js +93 -0
  63. package/collections/log.collection.js.map +1 -0
  64. package/collections/logged-in-users.collection.d.ts +3 -0
  65. package/collections/logged-in-users.collection.js +67 -0
  66. package/collections/logged-in-users.collection.js.map +1 -0
  67. package/collections/monitor-cpu.collection.d.ts +3 -0
  68. package/collections/monitor-cpu.collection.js +65 -0
  69. package/collections/monitor-cpu.collection.js.map +1 -0
  70. package/collections/monitor-function.collection.d.ts +3 -0
  71. package/collections/monitor-function.collection.js +74 -0
  72. package/collections/monitor-function.collection.js.map +1 -0
  73. package/collections/monitor-memory.collection.d.ts +3 -0
  74. package/collections/monitor-memory.collection.js +77 -0
  75. package/collections/monitor-memory.collection.js.map +1 -0
  76. package/collections/monitor-mongo.collection.d.ts +3 -0
  77. package/collections/monitor-mongo.collection.js +71 -0
  78. package/collections/monitor-mongo.collection.js.map +1 -0
  79. package/collections/notification.collection.d.ts +3 -0
  80. package/collections/notification.collection.js +57 -0
  81. package/collections/notification.collection.js.map +1 -0
  82. package/collections/openai-usage-ledger.collection.d.ts +2 -0
  83. package/collections/openai-usage-ledger.collection.js +124 -0
  84. package/collections/openai-usage-ledger.collection.js.map +1 -0
  85. package/collections/report-builder-dashboard-builder.collection.d.ts +3 -0
  86. package/collections/report-builder-dashboard-builder.collection.js +109 -0
  87. package/collections/report-builder-dashboard-builder.collection.js.map +1 -0
  88. package/collections/report-builder-library.collection.d.ts +3 -0
  89. package/collections/report-builder-library.collection.js +87 -0
  90. package/collections/report-builder-library.collection.js.map +1 -0
  91. package/collections/report-builder-report.collection.d.ts +4 -0
  92. package/collections/report-builder-report.collection.js +180 -0
  93. package/collections/report-builder-report.collection.js.map +1 -0
  94. package/collections/user-group.collection.d.ts +4 -0
  95. package/collections/user-group.collection.js +89 -0
  96. package/collections/user-group.collection.js.map +1 -0
  97. package/collections/user-guide.collection.d.ts +3 -0
  98. package/collections/user-guide.collection.js +57 -0
  99. package/collections/user-guide.collection.js.map +1 -0
  100. package/collections/user.collection.d.ts +4 -0
  101. package/collections/user.collection.js +180 -0
  102. package/collections/user.collection.js.map +1 -0
  103. package/cron/cron.d.ts +14 -0
  104. package/cron/cron.js +216 -0
  105. package/cron/cron.js.map +1 -0
  106. package/fixtures/cron-jobs.d.ts +1 -0
  107. package/fixtures/cron-jobs.js +150 -0
  108. package/fixtures/cron-jobs.js.map +1 -0
  109. package/fixtures/init.d.ts +1 -0
  110. package/fixtures/init.js +91 -0
  111. package/fixtures/init.js.map +1 -0
  112. package/http/auth.d.ts +2 -0
  113. package/http/auth.js +903 -0
  114. package/http/auth.js.map +1 -0
  115. package/http/health.d.ts +1 -0
  116. package/http/health.js +11 -0
  117. package/http/health.js.map +1 -0
  118. package/http/home.d.ts +1 -0
  119. package/http/home.js +134 -0
  120. package/http/home.js.map +1 -0
  121. package/http/slow-query-publication.d.ts +2 -0
  122. package/http/slow-query-publication.js +99 -0
  123. package/http/slow-query-publication.js.map +1 -0
  124. package/index.d.ts +1 -0
  125. package/index.js +19 -0
  126. package/index.js.map +1 -0
  127. package/managers/communication-metric.manager.d.ts +16 -0
  128. package/managers/communication-metric.manager.js +134 -0
  129. package/managers/communication-metric.manager.js.map +1 -0
  130. package/managers/cron.manager.d.ts +20 -0
  131. package/managers/cron.manager.js +534 -0
  132. package/managers/cron.manager.js.map +1 -0
  133. package/managers/customer-notification-content.manager.d.ts +55 -0
  134. package/managers/customer-notification-content.manager.js +158 -0
  135. package/managers/customer-notification-content.manager.js.map +1 -0
  136. package/managers/diagnostic-manager-bootstrap.d.ts +9 -0
  137. package/managers/diagnostic-manager-bootstrap.js +260 -0
  138. package/managers/diagnostic-manager-bootstrap.js.map +1 -0
  139. package/managers/error-auto-fix.manager.d.ts +149 -0
  140. package/managers/error-auto-fix.manager.js +3064 -0
  141. package/managers/error-auto-fix.manager.js.map +1 -0
  142. package/managers/local-log.manager.d.ts +18 -0
  143. package/managers/local-log.manager.js +88 -0
  144. package/managers/local-log.manager.js.map +1 -0
  145. package/managers/method.manager.d.ts +77 -0
  146. package/managers/method.manager.js +1701 -0
  147. package/managers/method.manager.js.map +1 -0
  148. package/managers/mongo.manager.d.ts +222 -0
  149. package/managers/mongo.manager.js +4984 -0
  150. package/managers/mongo.manager.js.map +1 -0
  151. package/managers/monitor.manager.d.ts +69 -0
  152. package/managers/monitor.manager.js +534 -0
  153. package/managers/monitor.manager.js.map +1 -0
  154. package/managers/openai-usage-ledger.manager.d.ts +15 -0
  155. package/managers/openai-usage-ledger.manager.js +144 -0
  156. package/managers/openai-usage-ledger.manager.js.map +1 -0
  157. package/managers/slow-query-verifier.manager.d.ts +144 -0
  158. package/managers/slow-query-verifier.manager.js +3857 -0
  159. package/managers/slow-query-verifier.manager.js.map +1 -0
  160. package/managers/slow-query.manager.d.ts +28 -0
  161. package/managers/slow-query.manager.js +468 -0
  162. package/managers/slow-query.manager.js.map +1 -0
  163. package/managers/subscription.manager.d.ts +169 -0
  164. package/managers/subscription.manager.js +3422 -0
  165. package/managers/subscription.manager.js.map +1 -0
  166. package/managers/websocket.manager.d.ts +73 -0
  167. package/managers/websocket.manager.js +673 -0
  168. package/managers/websocket.manager.js.map +1 -0
  169. package/managers/worker-dispatcher.manager.d.ts +117 -0
  170. package/managers/worker-dispatcher.manager.js +1210 -0
  171. package/managers/worker-dispatcher.manager.js.map +1 -0
  172. package/managers/worker-server.manager.d.ts +16 -0
  173. package/managers/worker-server.manager.js +530 -0
  174. package/managers/worker-server.manager.js.map +1 -0
  175. package/methods/accounts.d.ts +2 -0
  176. package/methods/accounts.js +624 -0
  177. package/methods/accounts.js.map +1 -0
  178. package/methods/ai-terminal.d.ts +304 -0
  179. package/methods/ai-terminal.js +25096 -0
  180. package/methods/ai-terminal.js.map +1 -0
  181. package/methods/app-settings.d.ts +2 -0
  182. package/methods/app-settings.js +169 -0
  183. package/methods/app-settings.js.map +1 -0
  184. package/methods/aws.d.ts +2 -0
  185. package/methods/aws.js +874 -0
  186. package/methods/aws.js.map +1 -0
  187. package/methods/collections.d.ts +2 -0
  188. package/methods/collections.js +626 -0
  189. package/methods/collections.js.map +1 -0
  190. package/methods/counters.d.ts +2 -0
  191. package/methods/counters.js +111 -0
  192. package/methods/counters.js.map +1 -0
  193. package/methods/cron-jobs.d.ts +2 -0
  194. package/methods/cron-jobs.js +2471 -0
  195. package/methods/cron-jobs.js.map +1 -0
  196. package/methods/customer-notifications.d.ts +2 -0
  197. package/methods/customer-notifications.js +528 -0
  198. package/methods/customer-notifications.js.map +1 -0
  199. package/methods/diagnostics.d.ts +2 -0
  200. package/methods/diagnostics.js +514 -0
  201. package/methods/diagnostics.js.map +1 -0
  202. package/methods/flag-updates.d.ts +2 -0
  203. package/methods/flag-updates.js +8 -0
  204. package/methods/flag-updates.js.map +1 -0
  205. package/methods/flags.d.ts +2 -0
  206. package/methods/flags.js +8 -0
  207. package/methods/flags.js.map +1 -0
  208. package/methods/logs.d.ts +2 -0
  209. package/methods/logs.js +750 -0
  210. package/methods/logs.js.map +1 -0
  211. package/methods/mongo-explorer.d.ts +2 -0
  212. package/methods/mongo-explorer.js +1811 -0
  213. package/methods/mongo-explorer.js.map +1 -0
  214. package/methods/monitor.d.ts +2 -0
  215. package/methods/monitor.js +543 -0
  216. package/methods/monitor.js.map +1 -0
  217. package/methods/pdf.d.ts +2 -0
  218. package/methods/pdf.js +1195 -0
  219. package/methods/pdf.js.map +1 -0
  220. package/methods/publications.d.ts +1 -0
  221. package/methods/publications.js +183 -0
  222. package/methods/publications.js.map +1 -0
  223. package/methods/report-builder.d.ts +2 -0
  224. package/methods/report-builder.js +3099 -0
  225. package/methods/report-builder.js.map +1 -0
  226. package/methods/support.d.ts +2 -0
  227. package/methods/support.js +322 -0
  228. package/methods/support.js.map +1 -0
  229. package/models/ai-terminal-conversation.model.d.ts +17 -0
  230. package/models/ai-terminal-conversation.model.js +4 -0
  231. package/models/ai-terminal-conversation.model.js.map +1 -0
  232. package/models/ai-terminal-issue-report.model.d.ts +19 -0
  233. package/models/ai-terminal-issue-report.model.js +4 -0
  234. package/models/ai-terminal-issue-report.model.js.map +1 -0
  235. package/models/ai-terminal-message.model.d.ts +22 -0
  236. package/models/ai-terminal-message.model.js +4 -0
  237. package/models/ai-terminal-message.model.js.map +1 -0
  238. package/models/app-setting.model.d.ts +16 -0
  239. package/models/app-setting.model.js +4 -0
  240. package/models/app-setting.model.js.map +1 -0
  241. package/{src/models/app-status.model.ts → models/app-status.model.d.ts} +2 -3
  242. package/models/app-status.model.js +4 -0
  243. package/models/app-status.model.js.map +1 -0
  244. package/{src/models/billing-logged-in-users.model.ts → models/billing-logged-in-users.model.d.ts} +4 -5
  245. package/models/billing-logged-in-users.model.js +4 -0
  246. package/models/billing-logged-in-users.model.js.map +1 -0
  247. package/models/collection-document.model.d.ts +21 -0
  248. package/models/collection-document.model.js +4 -0
  249. package/models/collection-document.model.js.map +1 -0
  250. package/models/communication-metric.model.d.ts +20 -0
  251. package/models/communication-metric.model.js +4 -0
  252. package/models/communication-metric.model.js.map +1 -0
  253. package/{src/models/counter.model.ts → models/counter.model.d.ts} +3 -4
  254. package/models/counter.model.js +4 -0
  255. package/models/counter.model.js.map +1 -0
  256. package/models/cron-job-history.model.d.ts +15 -0
  257. package/models/cron-job-history.model.js +4 -0
  258. package/models/cron-job-history.model.js.map +1 -0
  259. package/models/cron-job.model.d.ts +14 -0
  260. package/models/cron-job.model.js +4 -0
  261. package/models/cron-job.model.js.map +1 -0
  262. package/models/customer-notification.model.d.ts +26 -0
  263. package/models/customer-notification.model.js +4 -0
  264. package/models/customer-notification.model.js.map +1 -0
  265. package/models/customer-portal-password.model.d.ts +11 -0
  266. package/models/customer-portal-password.model.js +4 -0
  267. package/models/customer-portal-password.model.js.map +1 -0
  268. package/models/dialog.model.d.ts +23 -0
  269. package/models/dialog.model.js +4 -0
  270. package/models/dialog.model.js.map +1 -0
  271. package/models/email-history.model.d.ts +30 -0
  272. package/{src/models/email-history.model.ts → models/email-history.model.js} +4 -34
  273. package/models/email-history.model.js.map +1 -0
  274. package/{src/models/email-verified.model.ts → models/email-verified.model.d.ts} +5 -6
  275. package/models/email-verified.model.js +4 -0
  276. package/models/email-verified.model.js.map +1 -0
  277. package/{src/models/file.model.ts → models/file.model.d.ts} +7 -8
  278. package/models/file.model.js +4 -0
  279. package/models/file.model.js.map +1 -0
  280. package/{src/models/flag-update.model.ts → models/flag-update.model.d.ts} +3 -4
  281. package/models/flag-update.model.js +4 -0
  282. package/models/flag-update.model.js.map +1 -0
  283. package/{src/models/flag.model.ts → models/flag.model.d.ts} +3 -4
  284. package/models/flag.model.js +4 -0
  285. package/models/flag.model.js.map +1 -0
  286. package/models/log-method-latency.model.d.ts +10 -0
  287. package/models/log-method-latency.model.js +4 -0
  288. package/models/log-method-latency.model.js.map +1 -0
  289. package/{src/models/log-subscription.model.ts → models/log-subscription.model.d.ts} +9 -11
  290. package/models/log-subscription.model.js +4 -0
  291. package/models/log-subscription.model.js.map +1 -0
  292. package/models/log.model.d.ts +17 -0
  293. package/models/log.model.js +4 -0
  294. package/models/log.model.js.map +1 -0
  295. package/{src/models/logged-in-users.model.ts → models/logged-in-users.model.d.ts} +5 -6
  296. package/models/logged-in-users.model.js +4 -0
  297. package/models/logged-in-users.model.js.map +1 -0
  298. package/{src/models/method-response.model.ts → models/method-response.model.d.ts} +6 -7
  299. package/models/method-response.model.js +4 -0
  300. package/models/method-response.model.js.map +1 -0
  301. package/models/method.model.d.ts +24 -0
  302. package/models/method.model.js +4 -0
  303. package/models/method.model.js.map +1 -0
  304. package/{src/models/monitor-cpu.model.ts → models/monitor-cpu.model.d.ts} +7 -9
  305. package/models/monitor-cpu.model.js +4 -0
  306. package/models/monitor-cpu.model.js.map +1 -0
  307. package/models/monitor-function.model.d.ts +14 -0
  308. package/models/monitor-function.model.js +4 -0
  309. package/models/monitor-function.model.js.map +1 -0
  310. package/models/monitor-memory.model.d.ts +15 -0
  311. package/models/monitor-memory.model.js +4 -0
  312. package/models/monitor-memory.model.js.map +1 -0
  313. package/models/monitor-mongo.model.d.ts +13 -0
  314. package/models/monitor-mongo.model.js +4 -0
  315. package/models/monitor-mongo.model.js.map +1 -0
  316. package/{src/models/notification.model.ts → models/notification.model.d.ts} +4 -6
  317. package/models/notification.model.js +4 -0
  318. package/models/notification.model.js.map +1 -0
  319. package/models/openai-usage-ledger.model.d.ts +15 -0
  320. package/models/openai-usage-ledger.model.js +4 -0
  321. package/models/openai-usage-ledger.model.js.map +1 -0
  322. package/models/pagination.model.d.ts +11 -0
  323. package/models/pagination.model.js +28 -0
  324. package/models/pagination.model.js.map +1 -0
  325. package/models/permission.model.d.ts +12 -0
  326. package/models/permission.model.js +4 -0
  327. package/models/permission.model.js.map +1 -0
  328. package/models/report-builder-dashboard-builder.model.d.ts +25 -0
  329. package/models/report-builder-dashboard-builder.model.js +4 -0
  330. package/models/report-builder-dashboard-builder.model.js.map +1 -0
  331. package/models/report-builder-library.model.d.ts +17 -0
  332. package/models/report-builder-library.model.js +4 -0
  333. package/models/report-builder-library.model.js.map +1 -0
  334. package/models/report-builder-report.model.d.ts +120 -0
  335. package/models/report-builder-report.model.js +4 -0
  336. package/models/report-builder-report.model.js.map +1 -0
  337. package/models/report-builder.model.d.ts +61 -0
  338. package/models/report-builder.model.js +4 -0
  339. package/models/report-builder.model.js.map +1 -0
  340. package/models/select-data-label.model.d.ts +9 -0
  341. package/models/select-data-label.model.js +4 -0
  342. package/models/select-data-label.model.js.map +1 -0
  343. package/models/server-message.model.d.ts +32 -0
  344. package/models/server-message.model.js +4 -0
  345. package/models/server-message.model.js.map +1 -0
  346. package/models/slow-query-report.model.d.ts +23 -0
  347. package/models/slow-query-report.model.js +4 -0
  348. package/models/slow-query-report.model.js.map +1 -0
  349. package/models/subscription.model.d.ts +31 -0
  350. package/models/subscription.model.js +4 -0
  351. package/models/subscription.model.js.map +1 -0
  352. package/models/support-ticket.model.d.ts +87 -0
  353. package/models/support-ticket.model.js +4 -0
  354. package/models/support-ticket.model.js.map +1 -0
  355. package/models/user-group.model.d.ts +20 -0
  356. package/models/user-group.model.js +4 -0
  357. package/models/user-group.model.js.map +1 -0
  358. package/{src/models/user-guide.model.ts → models/user-guide.model.d.ts} +4 -5
  359. package/models/user-guide.model.js +4 -0
  360. package/models/user-guide.model.js.map +1 -0
  361. package/models/user.model.d.ts +84 -0
  362. package/models/user.model.js +4 -0
  363. package/models/user.model.js.map +1 -0
  364. package/package.json +1 -1
  365. package/private/images/ResolveIO.png +0 -0
  366. package/public_api.js +107 -0
  367. package/public_api.js.map +1 -0
  368. package/publications/ai-terminal.d.ts +1 -0
  369. package/publications/ai-terminal.js +122 -0
  370. package/publications/ai-terminal.js.map +1 -0
  371. package/publications/app-settings.d.ts +2 -0
  372. package/publications/app-settings.js +28 -0
  373. package/publications/app-settings.js.map +1 -0
  374. package/publications/app-status.d.ts +2 -0
  375. package/publications/app-status.js +16 -0
  376. package/publications/app-status.js.map +1 -0
  377. package/publications/cron-jobs.d.ts +2 -0
  378. package/publications/cron-jobs.js +32 -0
  379. package/publications/cron-jobs.js.map +1 -0
  380. package/publications/customer-notifications.d.ts +2 -0
  381. package/publications/customer-notifications.js +161 -0
  382. package/publications/customer-notifications.js.map +1 -0
  383. package/publications/files.d.ts +2 -0
  384. package/publications/files.js +36 -0
  385. package/publications/files.js.map +1 -0
  386. package/publications/flags-update.d.ts +2 -0
  387. package/publications/flags-update.js +22 -0
  388. package/publications/flags-update.js.map +1 -0
  389. package/publications/flags.d.ts +2 -0
  390. package/publications/flags.js +22 -0
  391. package/publications/flags.js.map +1 -0
  392. package/publications/logs.d.ts +2 -0
  393. package/publications/logs.js +164 -0
  394. package/publications/logs.js.map +1 -0
  395. package/publications/notifications.d.ts +2 -0
  396. package/publications/notifications.js +16 -0
  397. package/publications/notifications.js.map +1 -0
  398. package/publications/report-builder-dashboard-builders.d.ts +2 -0
  399. package/publications/report-builder-dashboard-builders.js +42 -0
  400. package/publications/report-builder-dashboard-builders.js.map +1 -0
  401. package/publications/report-builder-libraries.d.ts +2 -0
  402. package/publications/report-builder-libraries.js +90 -0
  403. package/publications/report-builder-libraries.js.map +1 -0
  404. package/publications/report-builder-reports.d.ts +2 -0
  405. package/publications/report-builder-reports.js +50 -0
  406. package/publications/report-builder-reports.js.map +1 -0
  407. package/publications/super-admin.d.ts +2 -0
  408. package/publications/super-admin.js +16 -0
  409. package/publications/super-admin.js.map +1 -0
  410. package/publications/user-groups.d.ts +1 -0
  411. package/publications/user-groups.js +16 -0
  412. package/publications/user-groups.js.map +1 -0
  413. package/publications/user-guides.d.ts +1 -0
  414. package/publications/user-guides.js +16 -0
  415. package/publications/user-guides.js.map +1 -0
  416. package/resolveio-server-app.d.ts +70 -0
  417. package/resolveio-server-app.js +801 -0
  418. package/resolveio-server-app.js.map +1 -0
  419. package/server-app.d.ts +167 -0
  420. package/server-app.js +2784 -0
  421. package/server-app.js.map +1 -0
  422. package/services/codex-client.d.ts +119 -0
  423. package/services/codex-client.js +1470 -0
  424. package/services/codex-client.js.map +1 -0
  425. package/services/openai-client.d.ts +46 -0
  426. package/services/openai-client.js +318 -0
  427. package/services/openai-client.js.map +1 -0
  428. package/types/error-report.d.ts +25 -0
  429. package/types/error-report.js +4 -0
  430. package/types/error-report.js.map +1 -0
  431. package/types/slow-query-report.d.ts +27 -0
  432. package/types/slow-query-report.js +6 -0
  433. package/types/slow-query-report.js.map +1 -0
  434. package/util/common.d.ts +31 -0
  435. package/util/common.js +683 -0
  436. package/util/common.js.map +1 -0
  437. package/util/customer-portal-password.d.ts +13 -0
  438. package/util/customer-portal-password.js +209 -0
  439. package/util/customer-portal-password.js.map +1 -0
  440. package/util/error-reporter.d.ts +52 -0
  441. package/util/error-reporter.js +326 -0
  442. package/util/error-reporter.js.map +1 -0
  443. package/util/error-tracking.d.ts +13 -0
  444. package/util/error-tracking.js +120 -0
  445. package/util/error-tracking.js.map +1 -0
  446. package/util/report-builder-unwinds.d.ts +15 -0
  447. package/util/report-builder-unwinds.js +156 -0
  448. package/util/report-builder-unwinds.js.map +1 -0
  449. package/util/schema-report-builder.d.ts +6 -0
  450. package/util/schema-report-builder.js +481 -0
  451. package/util/schema-report-builder.js.map +1 -0
  452. package/util/slow-query-reporter.d.ts +28 -0
  453. package/util/slow-query-reporter.js +226 -0
  454. package/util/slow-query-reporter.js.map +1 -0
  455. package/util/subscription-dependency-context.d.ts +34 -0
  456. package/util/subscription-dependency-context.js +1283 -0
  457. package/util/subscription-dependency-context.js.map +1 -0
  458. package/util/tokenizer.d.ts +5 -0
  459. package/util/tokenizer.js +41 -0
  460. package/util/tokenizer.js.map +1 -0
  461. package/workers/codex-runner.worker.d.ts +1 -0
  462. package/workers/codex-runner.worker.js +192 -0
  463. package/workers/codex-runner.worker.js.map +1 -0
  464. package/.github/workflows/ai-assistant-nightly-eval.yml +0 -224
  465. package/.github/workflows/ai-assistant-pr-guardrails.yml +0 -60
  466. package/.nodemon.json +0 -5
  467. package/.vscode/settings.json +0 -21
  468. package/AGENTS.md +0 -179
  469. package/README.md +0 -22
  470. package/build_package.sh +0 -5
  471. package/compileDTS.pl +0 -64
  472. package/docs/ai-assistant-nightly-eval.md +0 -65
  473. package/docs/ai-assistant-preflight-checklist.md +0 -23
  474. package/docs/ai-assistant-report-builder-bridge-playbook.md +0 -115
  475. package/eslint-plugin-custom/index.js +0 -7
  476. package/eslint-plugin-custom/rules/no-filter-zero-index.js +0 -44
  477. package/eslint.config.js +0 -103
  478. package/gulpfile.js +0 -216
  479. package/methodAndPublicationListGenerator.py +0 -319
  480. package/mongodbensurers.js +0 -2
  481. package/mongostop.js +0 -3
  482. package/settings.development.json +0 -25
  483. package/settings.development.redacted.json +0 -25
  484. package/src/.env +0 -12
  485. package/src/ai/assistant-core-heuristics.ts +0 -577
  486. package/src/client-server-app.ts +0 -12
  487. package/src/collections/ai-terminal-conversation.collection.ts +0 -91
  488. package/src/collections/ai-terminal-issue-report.collection.ts +0 -99
  489. package/src/collections/ai-terminal-message.collection.ts +0 -77
  490. package/src/collections/app-setting.collection.ts +0 -104
  491. package/src/collections/app-status.collection.ts +0 -58
  492. package/src/collections/communication-metric.collection.ts +0 -84
  493. package/src/collections/counter.collection.ts +0 -56
  494. package/src/collections/cron-job-history.collection.ts +0 -94
  495. package/src/collections/cron-job.collection.ts +0 -92
  496. package/src/collections/customer-notification.collection.ts +0 -131
  497. package/src/collections/customer-portal-password.collection.ts +0 -76
  498. package/src/collections/email-history.collection.ts +0 -121
  499. package/src/collections/email-verified.collection.ts +0 -61
  500. package/src/collections/file.collection.ts +0 -74
  501. package/src/collections/flag-update.collection.ts +0 -57
  502. package/src/collections/flag.collection.ts +0 -57
  503. package/src/collections/log-method-latency.collection.ts +0 -77
  504. package/src/collections/log-subscription.collection.ts +0 -80
  505. package/src/collections/log.collection.ts +0 -93
  506. package/src/collections/logged-in-users.collection.ts +0 -67
  507. package/src/collections/monitor-cpu.collection.ts +0 -65
  508. package/src/collections/monitor-function.collection.ts +0 -74
  509. package/src/collections/monitor-memory.collection.ts +0 -77
  510. package/src/collections/monitor-mongo.collection.ts +0 -71
  511. package/src/collections/notification.collection.ts +0 -57
  512. package/src/collections/openai-usage-ledger.collection.ts +0 -77
  513. package/src/collections/report-builder-dashboard-builder.collection.ts +0 -109
  514. package/src/collections/report-builder-library.collection.ts +0 -89
  515. package/src/collections/report-builder-report.collection.ts +0 -180
  516. package/src/collections/user-group.collection.ts +0 -89
  517. package/src/collections/user-guide.collection.ts +0 -57
  518. package/src/collections/user.collection.ts +0 -181
  519. package/src/cron/cron.ts +0 -117
  520. package/src/fixtures/cron-jobs.ts +0 -95
  521. package/src/fixtures/init.ts +0 -35
  522. package/src/http/auth.ts +0 -764
  523. package/src/http/health.ts +0 -7
  524. package/src/http/home.ts +0 -90
  525. package/src/http/slow-query-publication.ts +0 -49
  526. package/src/index.ts +0 -1
  527. package/src/managers/communication-metric.manager.ts +0 -82
  528. package/src/managers/cron.manager.ts +0 -333
  529. package/src/managers/customer-notification-content.manager.ts +0 -236
  530. package/src/managers/diagnostic-manager-bootstrap.ts +0 -165
  531. package/src/managers/error-auto-fix.manager.ts +0 -2767
  532. package/src/managers/local-log.manager.ts +0 -113
  533. package/src/managers/method.manager.ts +0 -1557
  534. package/src/managers/mongo.manager.ts +0 -4566
  535. package/src/managers/monitor.manager.ts +0 -489
  536. package/src/managers/openai-usage-ledger.manager.ts +0 -116
  537. package/src/managers/slow-query-verifier.manager.ts +0 -3590
  538. package/src/managers/slow-query.manager.ts +0 -519
  539. package/src/managers/subscription.manager.ts +0 -3120
  540. package/src/managers/websocket.manager.ts +0 -746
  541. package/src/managers/worker-dispatcher.manager.ts +0 -1318
  542. package/src/managers/worker-server.manager.ts +0 -468
  543. package/src/methods/accounts.ts +0 -532
  544. package/src/methods/ai-terminal.ts +0 -25505
  545. package/src/methods/app-settings.ts +0 -114
  546. package/src/methods/aws.ts +0 -646
  547. package/src/methods/collections.ts +0 -544
  548. package/src/methods/counters.ts +0 -67
  549. package/src/methods/cron-jobs.ts +0 -2610
  550. package/src/methods/customer-notifications.ts +0 -458
  551. package/src/methods/diagnostics.ts +0 -447
  552. package/src/methods/flag-updates.ts +0 -7
  553. package/src/methods/flags.ts +0 -7
  554. package/src/methods/logs.ts +0 -656
  555. package/src/methods/mongo-explorer.ts +0 -1883
  556. package/src/methods/monitor.ts +0 -540
  557. package/src/methods/pdf.ts +0 -1210
  558. package/src/methods/publications.ts +0 -128
  559. package/src/methods/report-builder.ts +0 -3305
  560. package/src/methods/support.ts +0 -210
  561. package/src/models/ai-terminal-conversation.model.ts +0 -19
  562. package/src/models/ai-terminal-issue-report.model.ts +0 -21
  563. package/src/models/ai-terminal-message.model.ts +0 -24
  564. package/src/models/app-setting.model.ts +0 -17
  565. package/src/models/collection-document.model.ts +0 -24
  566. package/src/models/communication-metric.model.ts +0 -23
  567. package/src/models/cron-job-history.model.ts +0 -16
  568. package/src/models/cron-job.model.ts +0 -15
  569. package/src/models/customer-notification.model.ts +0 -28
  570. package/src/models/customer-portal-password.model.ts +0 -12
  571. package/src/models/dialog.model.ts +0 -25
  572. package/src/models/log-method-latency.model.ts +0 -11
  573. package/src/models/log.model.ts +0 -19
  574. package/src/models/method.model.ts +0 -23
  575. package/src/models/monitor-function.model.ts +0 -16
  576. package/src/models/monitor-memory.model.ts +0 -17
  577. package/src/models/monitor-mongo.model.ts +0 -15
  578. package/src/models/openai-usage-ledger.model.ts +0 -16
  579. package/src/models/pagination.model.ts +0 -35
  580. package/src/models/permission.model.ts +0 -14
  581. package/src/models/report-builder-dashboard-builder.model.ts +0 -29
  582. package/src/models/report-builder-library.model.ts +0 -20
  583. package/src/models/report-builder-report.model.ts +0 -135
  584. package/src/models/report-builder.model.ts +0 -68
  585. package/src/models/select-data-label.model.ts +0 -9
  586. package/src/models/server-message.model.ts +0 -31
  587. package/src/models/slow-query-report.model.ts +0 -23
  588. package/src/models/subscription.model.ts +0 -73
  589. package/src/models/support-ticket.model.ts +0 -96
  590. package/src/models/user-group.model.ts +0 -24
  591. package/src/models/user.model.ts +0 -96
  592. package/src/private/images/ResolveIO.png +0 -0
  593. package/src/publications/ai-terminal.ts +0 -73
  594. package/src/publications/app-settings.ts +0 -25
  595. package/src/publications/app-status.ts +0 -13
  596. package/src/publications/cron-jobs.ts +0 -29
  597. package/src/publications/customer-notifications.ts +0 -101
  598. package/src/publications/files.ts +0 -33
  599. package/src/publications/flags-update.ts +0 -19
  600. package/src/publications/flags.ts +0 -19
  601. package/src/publications/logs.ts +0 -163
  602. package/src/publications/notifications.ts +0 -13
  603. package/src/publications/report-builder-dashboard-builders.ts +0 -39
  604. package/src/publications/report-builder-libraries.ts +0 -41
  605. package/src/publications/report-builder-reports.ts +0 -47
  606. package/src/publications/super-admin.ts +0 -13
  607. package/src/publications/user-groups.ts +0 -12
  608. package/src/publications/user-guides.ts +0 -12
  609. package/src/resolveio-server-app.ts +0 -617
  610. package/src/server-app.ts +0 -2616
  611. package/src/services/codex-client.ts +0 -1117
  612. package/src/services/openai-client.ts +0 -265
  613. package/src/types/error-report.ts +0 -26
  614. package/src/types/js-tiktoken.d.ts +0 -11
  615. package/src/types/slow-query-report.ts +0 -28
  616. package/src/util/common.ts +0 -649
  617. package/src/util/customer-portal-password.ts +0 -183
  618. package/src/util/error-reporter.ts +0 -332
  619. package/src/util/error-tracking.ts +0 -79
  620. package/src/util/report-builder-unwinds.ts +0 -180
  621. package/src/util/schema-report-builder.ts +0 -448
  622. package/src/util/slow-query-reporter.ts +0 -216
  623. package/src/util/subscription-dependency-context.ts +0 -1096
  624. package/src/util/tokenizer.ts +0 -38
  625. package/src/workers/codex-runner.worker.ts +0 -142
  626. package/start_server.sh +0 -5
  627. package/tests/ai-assistant-corpus-build.ts +0 -484
  628. package/tests/ai-assistant-corpus-replay-e2e.ts +0 -773
  629. package/tests/ai-assistant-data-parity-e2e.ts +0 -2018
  630. package/tests/ai-assistant-eval-triage.ts +0 -831
  631. package/tests/ai-assistant-openai-e2e.ts +0 -1061
  632. package/tests/ai-assistant-openai-git-e2e.ts +0 -155
  633. package/tests/ai-assistant-preflight-matrix.ts +0 -215
  634. package/tests/ai-assistant-routing-eval.test.ts +0 -560
  635. package/tests/ai-assistant-snf-live-eval.ts +0 -921
  636. package/tests/ai-assistant-utils.test.ts +0 -2165
  637. package/tests/error-reporter.test.ts +0 -145
  638. package/tests/report-builder-linking.test.ts +0 -79
  639. package/tests/subscription-connect-race.test.ts +0 -157
  640. package/tests/subscription-dependency-context.test.ts +0 -324
  641. package/tests/subscription-manager-collection-tracking.test.ts +0 -86
  642. package/tests/subscription-manager-invalidation.test.ts +0 -85
  643. package/tsconfig.json +0 -34
  644. /package/{src/private → private}/email-templates/enrollment.html +0 -0
  645. /package/{src/private → private}/email-templates/forgot-password.html +0 -0
  646. /package/{src/private → private}/email-templates/support-ticket-deleted.html +0 -0
  647. /package/{src/private → private}/email-templates/support-ticket-modified.html +0 -0
  648. /package/{src/private → private}/email-templates/support-ticket.html +0 -0
  649. /package/{src/public_api.ts → public_api.d.ts} +0 -0
@@ -1,1318 +0,0 @@
1
- import * as WebSocket from 'ws';
2
- import { ServerResponseModel, TaskPayload, TaskResponse } from '../models/server-message.model';
3
- import { dateReviver, objectIdHexString, round } from '../util/common';
4
- import { MethodManager } from './method.manager';
5
- import { WebSocketManager } from './websocket.manager';
6
- import { pack, unpack } from 'msgpackr';
7
-
8
- export interface WorkerConnection {
9
- id: string;
10
- ws: WebSocket.WebSocket;
11
- activeTasks: {
12
- taskId: string;
13
- weight: number;
14
- method?: string;
15
- startedAt?: number;
16
- messageId?: number;
17
- userContext?: { id_user?: string; user?: string; id_ws?: string };
18
- }[];
19
- workerIndex?: string;
20
- workerInstance?: string;
21
- }
22
-
23
- interface PendingTask {
24
- timeout: NodeJS.Timeout;
25
- promise?: {
26
- // eslint-disable-next-line no-unused-vars
27
- resolve: (value: any) => void;
28
- // eslint-disable-next-line no-unused-vars
29
- reject: (reason?: any) => void;
30
- };
31
- method?: string;
32
- resolveRaw?: boolean;
33
- }
34
-
35
- // eslint-disable-next-line no-unused-vars
36
- type TaskMatcher = (task: TaskPayload) => boolean;
37
-
38
- export class WorkerDispatcherManager {
39
- private _websocketManager: WebSocketManager;
40
- private _methodManager: MethodManager;
41
- private _workers: WorkerConnection[] = [];
42
- private _taskQueue: TaskPayload[] = [];
43
- private _clientRequests: { [taskId: string]: string } = {};
44
- private _pendingTasks: Map<string, PendingTask> = new Map();
45
- private _debugNoWorkerTaskIds: Set<string> = new Set();
46
- private _debugCodexTaskIds: Set<string> = new Set();
47
- private _taskTimings: Map<string, {
48
- queuedAt: number;
49
- dispatchedAt?: number;
50
- method?: string;
51
- messageId?: number;
52
- userContext?: { id_user?: string; user?: string; id_ws?: string };
53
- params?: any[];
54
- }> = new Map();
55
- private _dispatchRetryTimer: NodeJS.Timeout | null = null;
56
- private _dispatchRetryDelayMs = 25;
57
- private _nonCodexReserve = 0;
58
- private _publicationWorkerIndexes: Set<string> | null = null;
59
- private _publicationWorkerInstances: Set<string> | null = null;
60
- private _codexWorkerIndexes: Set<string> | null = null;
61
- private _codexWorkerInstances: Set<string> | null = null;
62
-
63
- private MAX_CONCURRENCY = 10;
64
- private WORKER_TASK_LOG_THRESHOLD_MS = 200;
65
- private WORKER_PUBLICATION_SLOW_MS = 20000;
66
- private _workerTaskDebug = false;
67
- private _aiWorkerDebug = false;
68
-
69
- constructor() {}
70
-
71
- static create(websocketManager: WebSocketManager, methodManager: MethodManager) {
72
- const workerDispatcherManager = new WorkerDispatcherManager();
73
- workerDispatcherManager.initialize(websocketManager, methodManager);
74
- return workerDispatcherManager;
75
- }
76
-
77
- public initialize(websocketManager: WebSocketManager, methodManager: MethodManager) {
78
- this._websocketManager = websocketManager;
79
- this._methodManager = methodManager;
80
- this._workerTaskDebug = this.parseDebugFlag(process.env.WORKER_TASK_DEBUG ?? process.env.WORKER_DISPATCH_DEBUG);
81
- this._aiWorkerDebug = this.parseDebugFlag(process.env.AI_ASSISTANT_WORKER_DEBUG);
82
- const slowPublicationMs = parseInt(process.env.WORKER_PUBLICATION_SLOW_MS ?? '', 10);
83
- if (!Number.isNaN(slowPublicationMs) && slowPublicationMs > 0) {
84
- this.WORKER_PUBLICATION_SLOW_MS = slowPublicationMs;
85
- }
86
- this._nonCodexReserve = this.parsePositiveInt(
87
- process.env.WORKER_NON_CODEX_RESERVE ?? process.env.WORKER_RESERVED_SLOTS,
88
- 0
89
- );
90
- this._publicationWorkerIndexes = this.parseWorkerSelector(
91
- process.env.PUBLICATION_WORKER_INDEX
92
- || process.env.SUBSCRIPTION_WORKER_INDEX
93
- || process.env.WORKER_PUBLICATION_INDEX
94
- );
95
- this._publicationWorkerInstances = this.parseWorkerSelector(
96
- process.env.PUBLICATION_WORKER_INSTANCE
97
- || process.env.SUBSCRIPTION_WORKER_INSTANCE
98
- || process.env.WORKER_PUBLICATION_INSTANCE
99
- );
100
- this._codexWorkerIndexes = this.parseWorkerSelector(
101
- process.env.AI_ASSISTANT_CODEX_WORKER_INDEX
102
- || process.env.CODEX_WORKER_INDEX
103
- || process.env.WORKER_CODEX_INDEX
104
- );
105
- this._codexWorkerInstances = this.parseWorkerSelector(
106
- process.env.AI_ASSISTANT_CODEX_WORKER_INSTANCE
107
- || process.env.CODEX_WORKER_INSTANCE
108
- || process.env.WORKER_CODEX_INSTANCE
109
- );
110
- }
111
-
112
- private parseDebugFlag(value: any): boolean {
113
- if (value === true) {
114
- return true;
115
- }
116
-
117
- if (value === false || value === null || value === undefined) {
118
- return false;
119
- }
120
-
121
- if (typeof value === 'number') {
122
- return value === 1;
123
- }
124
-
125
- if (typeof value === 'string') {
126
- const normalized = value.trim().toLowerCase();
127
- return ['1', 'true', 'yes', 'y', 'on'].includes(normalized);
128
- }
129
-
130
- return false;
131
- }
132
-
133
- private parsePositiveInt(value: any, fallback: number): number {
134
- const parsed = parseInt(value ?? '', 10);
135
- if (Number.isNaN(parsed) || parsed < 0) {
136
- return fallback;
137
- }
138
- return parsed;
139
- }
140
-
141
- private parseWorkerSelector(value: any): Set<string> | null {
142
- if (value === null || value === undefined) {
143
- return null;
144
- }
145
-
146
- const parts: string[] = [];
147
-
148
- if (Array.isArray(value)) {
149
- for (const item of value) {
150
- const entry = String(item ?? '').split(',');
151
- for (const chunk of entry) {
152
- const trimmed = String(chunk ?? '').trim();
153
- if (trimmed) {
154
- parts.push(trimmed);
155
- }
156
- }
157
- }
158
- }
159
- else {
160
- const entry = String(value ?? '').split(',');
161
- for (const chunk of entry) {
162
- const trimmed = String(chunk ?? '').trim();
163
- if (trimmed) {
164
- parts.push(trimmed);
165
- }
166
- }
167
- }
168
-
169
- if (!parts.length) {
170
- return null;
171
- }
172
-
173
- return new Set(parts);
174
- }
175
-
176
- private selectorToArray(value: Set<string> | null): string[] | null {
177
- if (!value) {
178
- return null;
179
- }
180
- return Array.from(value.values());
181
- }
182
-
183
- private hasWorkerSelector(indexes: Set<string> | null, instances: Set<string> | null): boolean {
184
- return !!(indexes && indexes.size) || !!(instances && instances.size);
185
- }
186
-
187
- private workerMatchesSelector(worker: WorkerConnection, indexes: Set<string> | null, instances: Set<string> | null): boolean {
188
- if (!this.hasWorkerSelector(indexes, instances)) {
189
- return false;
190
- }
191
-
192
- const normalizedIndex = this.normalizeWorkerIndex(worker.workerIndex);
193
- const normalizedInstance = this.normalizeWorkerIndex(worker.workerInstance);
194
- const indexMatch = indexes ? (normalizedIndex ? indexes.has(normalizedIndex) : false) : true;
195
- const instanceMatch = instances ? (normalizedInstance ? instances.has(normalizedInstance) : false) : true;
196
-
197
- return indexMatch && instanceMatch;
198
- }
199
-
200
- private resolveTaskQueue(methodName: string): 'publication' | 'codex' | 'default' {
201
- const method = this._methodManager?.getMethod(methodName);
202
- const queue = method?.workerQueue;
203
- if (queue === 'publication' || queue === 'codex') {
204
- return queue;
205
- }
206
- return 'default';
207
- }
208
-
209
- private summarizePublicationValue(value: any): any {
210
- if (value === null || value === undefined) {
211
- return value;
212
- }
213
-
214
- const valueType = typeof value;
215
- if (valueType === 'string' || valueType === 'number' || valueType === 'boolean') {
216
- return value;
217
- }
218
-
219
- if (Array.isArray(value)) {
220
- return `[Array(${value.length})]`;
221
- }
222
-
223
- if (valueType === 'object') {
224
- return `[Object keys=${Object.keys(value).length}]`;
225
- }
226
-
227
- return `[${valueType}]`;
228
- }
229
-
230
- private getPublicationLogInfo(method?: string, params?: any[]): Record<string, any> | null {
231
- if (method !== 'runPublication' || !Array.isArray(params)) {
232
- return null;
233
- }
234
-
235
- const publication = typeof params[0] === 'string' ? params[0] : null;
236
- const subscriptionData = Array.isArray(params[1]) ? params[1] : [];
237
- const userId = typeof params[2] === 'string' ? params[2] : null;
238
- const subscriptionDataPreview = subscriptionData.slice(0, 3).map((item) => this.summarizePublicationValue(item));
239
-
240
- return {
241
- publication,
242
- subscriptionDataCount: subscriptionData.length,
243
- subscriptionDataPreview,
244
- userId
245
- };
246
- }
247
-
248
- public isSafeShutdown() {
249
- return !this._taskQueue.length && !this._pendingTasks.size;
250
- }
251
-
252
- public addWorker(ws: WebSocket.WebSocket) {
253
- this._workers.push({
254
- id: ws['id_worker'],
255
- ws: ws,
256
- activeTasks: [],
257
- workerIndex: ws['workerIndex'],
258
- workerInstance: ws['workerInstance']
259
- });
260
-
261
- setInterval(() => {
262
- if (this._methodManager.getEnableDebug()) {
263
- console.log(JSON.stringify(this._workers.map(a => {
264
- return {
265
- id: a.id,
266
- activeTasks: a.activeTasks
267
- }
268
- }), null, 2));
269
- }
270
- }, 5000);
271
-
272
- if (this._taskQueue.length) {
273
- this.dispatchQueue();
274
- }
275
- }
276
-
277
- public disconnectWorker(workerId: string) {
278
- this._workers = this._workers.filter(w => w.id !== workerId);
279
- }
280
-
281
- public hasWorkers() {
282
- return this._workers.length > 0;
283
- }
284
-
285
- public getQueueSnapshot() {
286
- const activeTasks = this._workers.reduce((total, worker) => total + (worker.activeTasks ? worker.activeTasks.length : 0), 0);
287
- return {
288
- queueDepth: this._taskQueue.length,
289
- pendingTasks: this._pendingTasks.size,
290
- workerCount: this._workers.length,
291
- activeTasks,
292
- workers: this._workers.map(worker => ({
293
- id: worker.id,
294
- index: worker.workerIndex,
295
- instance: worker.workerInstance,
296
- activeTasks: worker.activeTasks ? worker.activeTasks.length : 0
297
- }))
298
- };
299
- }
300
-
301
- public hasWorkersForMethod(methodName: string) {
302
- if (!this._workers.length) {
303
- return false;
304
- }
305
-
306
- const method = this._methodManager.getMethod(methodName);
307
- const taskQueue = this.resolveTaskQueue(methodName);
308
- const targetWorkerIndex = this.normalizeWorkerIndex(method?.targetWorkerIndex);
309
- const targetWorkerInstance = this.normalizeWorkerIndex(method?.targetWorkerInstance);
310
- const hasExplicitTarget = !!targetWorkerIndex || !!targetWorkerInstance;
311
-
312
- let candidates = [...this._workers];
313
-
314
- const hasPublicationSelector = this.hasWorkerSelector(this._publicationWorkerIndexes, this._publicationWorkerInstances);
315
- if (hasPublicationSelector && !hasExplicitTarget) {
316
- if (taskQueue === 'publication') {
317
- candidates = candidates.filter(worker =>
318
- this.workerMatchesSelector(worker, this._publicationWorkerIndexes, this._publicationWorkerInstances)
319
- );
320
- }
321
- else {
322
- candidates = candidates.filter(worker =>
323
- !this.workerMatchesSelector(worker, this._publicationWorkerIndexes, this._publicationWorkerInstances)
324
- );
325
- }
326
- }
327
-
328
- const hasCodexSelector = this.hasWorkerSelector(this._codexWorkerIndexes, this._codexWorkerInstances);
329
- if (hasCodexSelector) {
330
- if (taskQueue === 'codex') {
331
- candidates = candidates.filter(worker =>
332
- this.workerMatchesSelector(worker, this._codexWorkerIndexes, this._codexWorkerInstances)
333
- );
334
- }
335
- else if (!hasExplicitTarget) {
336
- candidates = candidates.filter(worker =>
337
- !this.workerMatchesSelector(worker, this._codexWorkerIndexes, this._codexWorkerInstances)
338
- );
339
- }
340
- }
341
-
342
- if (targetWorkerIndex) {
343
- candidates = candidates.filter(worker => this.normalizeWorkerIndex(worker.workerIndex) === targetWorkerIndex);
344
- }
345
- if (targetWorkerInstance) {
346
- candidates = candidates.filter(worker => this.normalizeWorkerIndex(worker.workerInstance) === targetWorkerInstance);
347
- }
348
-
349
- return candidates.length > 0;
350
- }
351
-
352
- /**
353
- * Add a new task to our in-memory queue and try to dispatch.
354
- */
355
- public sendClientTask(messageId: number, method: string, params: any[], userContext?: { id_user?: string; user?: string; id_ws?: string }) {
356
- let taskId = 'task-' + objectIdHexString();
357
- const queuedAt = Date.now();
358
-
359
- this._taskQueue.push({
360
- type: 'task',
361
- taskId,
362
- messageId,
363
- method,
364
- params,
365
- userContext,
366
- queuedAt
367
- });
368
-
369
- this._taskTimings.set(taskId, {
370
- queuedAt,
371
- method,
372
- messageId,
373
- userContext,
374
- params
375
- });
376
-
377
- if (userContext && userContext.id_ws) {
378
- this._clientRequests[taskId] = userContext.id_ws;
379
- }
380
-
381
- if (this.shouldDebug()) {
382
- const publicationInfo = this.getPublicationLogInfo(method, params);
383
- const logPayload: Record<string, any> = {
384
- taskId,
385
- method,
386
- messageId,
387
- priority: method === 'runPublication' ? 'publication' : 'method',
388
- queueDepth: this._taskQueue.length,
389
- userContext
390
- };
391
- if (publicationInfo) {
392
- Object.assign(logPayload, publicationInfo);
393
- }
394
- this.logWorkerEvent('workerTaskQueued', logPayload);
395
- }
396
-
397
- this.dispatchQueue();
398
- }
399
-
400
- /**
401
- * Same as sendInternalTask but returns a Promise so you can `await` it.
402
- */
403
- public sendInternalPromise(method: string, params: any[] = []): Promise<any> {
404
- if (!Array.isArray(params)) {
405
- params = [params];
406
- }
407
-
408
- // eslint-disable-next-line no-restricted-syntax
409
- return new Promise((resolve, reject) => {
410
- let taskId = 'task-' + objectIdHexString();
411
- const queuedAt = Date.now();
412
-
413
- this._taskQueue.push({
414
- type: 'task',
415
- taskId,
416
- method,
417
- params,
418
- messageId: 0,
419
- userContext: {
420
- user: 'Internal System'
421
- },
422
- queuedAt
423
- });
424
-
425
- this._taskTimings.set(taskId, {
426
- queuedAt,
427
- method,
428
- messageId: 0,
429
- userContext: { user: 'Internal System' },
430
- params
431
- });
432
-
433
- this._pendingTasks.set(taskId, {
434
- timeout: null,
435
- promise: { resolve, reject }
436
- });
437
-
438
- if (this._methodManager.getEnableDebug()) {
439
- console.log(new Date(), 'Send Internal Promise', this._taskQueue);
440
- }
441
-
442
- if (this.shouldDebug()) {
443
- const publicationInfo = this.getPublicationLogInfo(method, params);
444
- const logPayload: Record<string, any> = {
445
- taskId,
446
- method,
447
- messageId: 0,
448
- priority: method === 'runPublication' ? 'publication' : 'method',
449
- queueDepth: this._taskQueue.length,
450
- userContext: { user: 'Internal System' }
451
- };
452
- if (publicationInfo) {
453
- Object.assign(logPayload, publicationInfo);
454
- }
455
- this.logWorkerEvent('workerTaskQueued', logPayload);
456
- }
457
-
458
- this.dispatchQueue();
459
- });
460
- }
461
-
462
- /**
463
- * Send a task internally and resolve with the raw TaskResponse (includes packedResult/meta).
464
- */
465
- public sendInternalPromiseRaw(method: string, params: any[] = []): Promise<TaskResponse> {
466
- if (!Array.isArray(params)) {
467
- params = [params];
468
- }
469
-
470
- // eslint-disable-next-line no-restricted-syntax
471
- return new Promise((resolve, reject) => {
472
- let taskId = 'task-' + objectIdHexString();
473
- const queuedAt = Date.now();
474
-
475
- this._taskQueue.push({
476
- type: 'task',
477
- taskId,
478
- method,
479
- params,
480
- messageId: 0,
481
- userContext: {
482
- user: 'Internal System'
483
- },
484
- queuedAt
485
- });
486
-
487
- this._taskTimings.set(taskId, {
488
- queuedAt,
489
- method,
490
- messageId: 0,
491
- userContext: { user: 'Internal System' },
492
- params
493
- });
494
-
495
- this._pendingTasks.set(taskId, {
496
- timeout: null,
497
- promise: { resolve, reject },
498
- resolveRaw: true
499
- });
500
-
501
- if (this._methodManager.getEnableDebug()) {
502
- console.log(new Date(), 'Send Internal Raw Promise', this._taskQueue);
503
- }
504
-
505
- if (this.shouldDebug()) {
506
- const publicationInfo = this.getPublicationLogInfo(method, params);
507
- const logPayload: Record<string, any> = {
508
- taskId,
509
- method,
510
- messageId: 0,
511
- priority: method === 'runPublication' ? 'publication' : 'method',
512
- queueDepth: this._taskQueue.length,
513
- userContext: { user: 'Internal System' }
514
- };
515
- if (publicationInfo) {
516
- Object.assign(logPayload, publicationInfo);
517
- }
518
- this.logWorkerEvent('workerTaskQueued', logPayload);
519
- }
520
-
521
- this.dispatchQueue();
522
- });
523
- }
524
-
525
- /**
526
- * Send a task internally without returning a promise.
527
- */
528
- public sendInternalTask(method: string, params = []) {
529
- if (!Array.isArray(params)) {
530
- params = [params];
531
- }
532
-
533
- let taskId = 'task-' + objectIdHexString();
534
- const queuedAt = Date.now();
535
-
536
- this._taskQueue.push({
537
- type: 'task',
538
- taskId,
539
- method,
540
- params,
541
- messageId: 0,
542
- userContext: {
543
- user: 'Internal System'
544
- },
545
- queuedAt
546
- });
547
-
548
- this._taskTimings.set(taskId, {
549
- queuedAt,
550
- method,
551
- messageId: 0,
552
- userContext: { user: 'Internal System' },
553
- params
554
- });
555
-
556
- if (this._methodManager.getEnableDebug()) {
557
- console.log(new Date(), 'Send Internal Task', this._taskQueue);
558
- }
559
-
560
- if (this.shouldDebug()) {
561
- const publicationInfo = this.getPublicationLogInfo(method, params);
562
- const logPayload: Record<string, any> = {
563
- taskId,
564
- method,
565
- messageId: 0,
566
- priority: method === 'runPublication' ? 'publication' : 'method',
567
- queueDepth: this._taskQueue.length,
568
- userContext: { user: 'Internal System' }
569
- };
570
- if (publicationInfo) {
571
- Object.assign(logPayload, publicationInfo);
572
- }
573
- this.logWorkerEvent('workerTaskQueued', logPayload);
574
- }
575
-
576
- this.dispatchQueue();
577
- }
578
-
579
- /**
580
- * The main loop that assigns tasks from _taskQueue to any worker that has capacity.
581
- */
582
- private dispatchQueue() {
583
- if (!this._taskQueue.length) {
584
- return;
585
- }
586
- if (!this._workers.length) {
587
- return;
588
- }
589
-
590
- const priorityMatchers: TaskMatcher[] = [
591
- (task) => this.resolveTaskQueue(task.method) === 'publication',
592
- (task) => this.resolveTaskQueue(task.method) === 'default',
593
- (task) => this.resolveTaskQueue(task.method) === 'codex'
594
- ];
595
-
596
- const tryAssignTask = (matcher: TaskMatcher): boolean => {
597
- for (let i = 0; i < this._taskQueue.length; i++) {
598
- let task = this._taskQueue[i];
599
- if (!matcher(task)) {
600
- continue;
601
- }
602
- let targetWorker = this.findWorkerForTask(task);
603
-
604
- if (targetWorker) {
605
- this._taskQueue.splice(i, 1);
606
- this.assignTaskToWorker(targetWorker, task);
607
- return true;
608
- }
609
- }
610
- return false;
611
- };
612
-
613
- while (this._taskQueue.length > 0) {
614
- let assigned = false;
615
- for (const matcher of priorityMatchers) {
616
- if (tryAssignTask(matcher)) {
617
- assigned = true;
618
- break;
619
- }
620
- }
621
-
622
- if (!assigned) {
623
- this.logNoWorkerAvailability();
624
- this.scheduleDispatchRetry();
625
-
626
- if (this._methodManager.getEnableDebug()) {
627
- console.log(new Date(), 'No Worker Available', JSON.stringify(this._workers, null, 2));
628
- }
629
-
630
- return; // nothing can run right now due to per-worker limits
631
- }
632
- }
633
- }
634
-
635
- private scheduleDispatchRetry(delayMs: number = this._dispatchRetryDelayMs) {
636
- if (this._dispatchRetryTimer) {
637
- return;
638
- }
639
-
640
- this._dispatchRetryTimer = setTimeout(() => {
641
- this._dispatchRetryTimer = null;
642
- this.dispatchQueue();
643
- }, delayMs);
644
- }
645
-
646
- /**
647
- * Returns the worker with the fewest activeTasks that is under maxConcurrency and per-method limit.
648
- */
649
- private findWorkerForTask(task: TaskPayload): WorkerConnection | null {
650
- let method = this._methodManager.getMethod(task.method);
651
- const taskQueue = this.resolveTaskQueue(task.method);
652
- let methodLimit = method && method.maxConcurrency && method.maxConcurrency > 0 ? method.maxConcurrency : null;
653
- let methodLimitPerInstance = method && method.maxConcurrencyPerInstance && method.maxConcurrencyPerInstance > 0
654
- ? method.maxConcurrencyPerInstance
655
- : null;
656
- let targetWorkerIndex = this.normalizeWorkerIndex(method?.targetWorkerIndex);
657
- let targetWorkerInstance = this.normalizeWorkerIndex(method?.targetWorkerInstance);
658
- const hasExplicitTarget = !!targetWorkerIndex || !!targetWorkerInstance;
659
- const preferNonZero = !targetWorkerIndex;
660
- const debugCodex = this._aiWorkerDebug && taskQueue === 'codex';
661
- const debugState: Record<string, any> | null = debugCodex ? {
662
- taskId: task.taskId,
663
- method: task.method,
664
- queueDepth: this._taskQueue.length,
665
- targetWorkerIndex: targetWorkerIndex || null,
666
- targetWorkerInstance: targetWorkerInstance || null,
667
- workerCount: this._workers.length,
668
- publicationSelector: {
669
- indexes: this.selectorToArray(this._publicationWorkerIndexes),
670
- instances: this.selectorToArray(this._publicationWorkerInstances)
671
- },
672
- codexSelector: {
673
- indexes: this.selectorToArray(this._codexWorkerIndexes),
674
- instances: this.selectorToArray(this._codexWorkerInstances)
675
- },
676
- maxConcurrency: this.MAX_CONCURRENCY,
677
- nonCodexReserve: this._nonCodexReserve
678
- } : null;
679
-
680
- let candidates = this._workers.filter(x => x.activeTasks.length < this.MAX_CONCURRENCY);
681
- if (debugState) {
682
- debugState.candidatesInitial = candidates.length;
683
- }
684
- const hasPublicationSelector = this.hasWorkerSelector(this._publicationWorkerIndexes, this._publicationWorkerInstances);
685
- if (hasPublicationSelector && !hasExplicitTarget) {
686
- if (taskQueue === 'publication') {
687
- candidates = candidates.filter(worker =>
688
- this.workerMatchesSelector(worker, this._publicationWorkerIndexes, this._publicationWorkerInstances)
689
- );
690
- }
691
- else {
692
- candidates = candidates.filter(worker =>
693
- !this.workerMatchesSelector(worker, this._publicationWorkerIndexes, this._publicationWorkerInstances)
694
- );
695
- }
696
- }
697
- if (debugState) {
698
- debugState.candidatesAfterPublicationFilter = candidates.length;
699
- debugState.hasPublicationSelector = hasPublicationSelector;
700
- }
701
-
702
- const hasCodexSelector = this.hasWorkerSelector(this._codexWorkerIndexes, this._codexWorkerInstances);
703
- if (hasCodexSelector) {
704
- if (taskQueue === 'codex') {
705
- candidates = candidates.filter(worker =>
706
- this.workerMatchesSelector(worker, this._codexWorkerIndexes, this._codexWorkerInstances)
707
- );
708
- }
709
- else if (!hasExplicitTarget) {
710
- candidates = candidates.filter(worker =>
711
- !this.workerMatchesSelector(worker, this._codexWorkerIndexes, this._codexWorkerInstances)
712
- );
713
- }
714
- }
715
- if (debugState) {
716
- debugState.candidatesAfterCodexFilter = candidates.length;
717
- debugState.hasCodexSelector = hasCodexSelector;
718
- }
719
- if (targetWorkerIndex) {
720
- candidates = candidates.filter(worker => this.normalizeWorkerIndex(worker.workerIndex) === targetWorkerIndex);
721
- }
722
- if (targetWorkerInstance) {
723
- candidates = candidates.filter(worker => this.normalizeWorkerIndex(worker.workerInstance) === targetWorkerInstance);
724
- }
725
- if (debugState) {
726
- debugState.candidatesAfterTargetFilter = candidates.length;
727
- }
728
- if (!candidates.length) {
729
- this.logCodexSelection(debugState, 'noCandidates');
730
- return null;
731
- }
732
-
733
- let eligible = candidates.filter((worker) => {
734
- if (!methodLimit) {
735
- if (!methodLimitPerInstance) {
736
- return true;
737
- }
738
- }
739
-
740
- if (methodLimitPerInstance) {
741
- const currentInstance = worker.activeTasks.filter(a => a.method === task.method).length;
742
- if (currentInstance >= methodLimitPerInstance) {
743
- return false;
744
- }
745
- }
746
-
747
- if (!methodLimit) {
748
- return true;
749
- }
750
-
751
- let idx = worker.workerIndex || 'unknown';
752
- let current = 0;
753
-
754
- this._workers.forEach((w) => {
755
- if ((w.workerIndex || 'unknown') === idx) {
756
- current += w.activeTasks.filter(a => a.method === task.method).length;
757
- }
758
- });
759
-
760
- return current < methodLimit;
761
- });
762
-
763
- if (debugState) {
764
- debugState.eligibleAfterLimits = eligible.length;
765
- }
766
- if (!eligible.length) {
767
- this.logCodexSelection(debugState, 'limitsExceeded');
768
- return null;
769
- }
770
-
771
- if (taskQueue === 'codex' && this._nonCodexReserve > 0) {
772
- eligible = eligible.filter(worker => (this.MAX_CONCURRENCY - worker.activeTasks.length) > this._nonCodexReserve);
773
- }
774
-
775
- if (debugState) {
776
- debugState.eligibleAfterReserve = eligible.length;
777
- }
778
- if (!eligible.length) {
779
- this.logCodexSelection(debugState, 'reserveBlocked');
780
- return null;
781
- }
782
-
783
- eligible.sort((x, y) => {
784
- const totalX = this.getWorkerLoad(x);
785
- const totalY = this.getWorkerLoad(y);
786
- if (totalX !== totalY) {
787
- return totalX - totalY;
788
- }
789
-
790
- if (preferNonZero) {
791
- const xZero = this.isWorkerZero(x) ? 1 : 0;
792
- const yZero = this.isWorkerZero(y) ? 1 : 0;
793
- if (xZero !== yZero) {
794
- return xZero - yZero;
795
- }
796
- }
797
-
798
- const idxX = this.normalizeWorkerIndex(x.workerIndex) || '';
799
- const idxY = this.normalizeWorkerIndex(y.workerIndex) || '';
800
- const idxCompare = idxX.localeCompare(idxY, undefined, { numeric: true, sensitivity: 'base' });
801
- if (idxCompare !== 0) {
802
- return idxCompare;
803
- }
804
-
805
- const instX = this.normalizeWorkerIndex(x.workerInstance) || '';
806
- const instY = this.normalizeWorkerIndex(y.workerInstance) || '';
807
- return instX.localeCompare(instY, undefined, { numeric: true, sensitivity: 'base' });
808
- });
809
-
810
- const selected = eligible[0];
811
- if (this._aiWorkerDebug && taskQueue === 'codex') {
812
- console.log(new Date(), '[AI Worker Debug] AI worker selected', {
813
- taskId: task.taskId,
814
- method: task.method,
815
- workerIndex: selected?.workerIndex || null,
816
- workerInstance: selected?.workerInstance || null,
817
- activeTasks: selected?.activeTasks ? selected.activeTasks.length : 0,
818
- queueDepth: this._taskQueue.length
819
- });
820
- }
821
- return selected;
822
- }
823
-
824
- private logCodexSelection(debugState: Record<string, any> | null, reason: string): void {
825
- if (!debugState || !this._aiWorkerDebug) {
826
- return;
827
- }
828
- const taskId = String(debugState.taskId || '');
829
- if (!taskId || this._debugCodexTaskIds.has(taskId)) {
830
- return;
831
- }
832
- this._debugCodexTaskIds.add(taskId);
833
- console.warn(new Date(), '[AI Worker Debug] AI worker selection issue', {
834
- reason,
835
- ...debugState
836
- });
837
- }
838
-
839
- private normalizeWorkerIndex(value?: string | number | null): string | null {
840
- if (value === null || value === undefined) {
841
- return null;
842
- }
843
-
844
- const normalized = String(value).trim();
845
- return normalized.length ? normalized : null;
846
- }
847
-
848
- private getWorkerLoad(worker: WorkerConnection): number {
849
- return worker.activeTasks.reduce((sum, task) => sum + task.weight, 0);
850
- }
851
-
852
- private isWorkerZero(worker: WorkerConnection): boolean {
853
- return this.normalizeWorkerIndex(worker.workerIndex) === '0';
854
- }
855
-
856
- private assignTaskToWorker(worker: WorkerConnection, task: TaskPayload) {
857
- let method = this._methodManager.getMethod(task.method);
858
-
859
- if (!method) {
860
- console.error('Failed to send task to worker - Could not find method:', task.method);
861
- this._taskTimings.delete(task.taskId);
862
- return;
863
- }
864
-
865
- const dispatchedAt = Date.now();
866
- const timing = this._taskTimings.get(task.taskId) || { queuedAt: dispatchedAt };
867
- timing.dispatchedAt = dispatchedAt;
868
- timing.method = task.method;
869
- timing.messageId = task.messageId;
870
- timing.userContext = task.userContext;
871
- if (!timing.params) {
872
- timing.params = task.params;
873
- }
874
- this._taskTimings.set(task.taskId, timing);
875
-
876
- worker.activeTasks.push({
877
- taskId: task.taskId,
878
- weight: method && method.workerTaskWeight ? method.workerTaskWeight : 1,
879
- method: task.method,
880
- startedAt: dispatchedAt,
881
- messageId: task.messageId,
882
- userContext: task.userContext
883
- });
884
- this._debugNoWorkerTaskIds.delete(task.taskId);
885
-
886
- let payload: TaskPayload = {
887
- type: 'task',
888
- taskId: task.taskId,
889
- messageId: task.messageId,
890
- method: task.method,
891
- params: task.params,
892
- userContext: task.userContext || {},
893
- queuedAt: timing.queuedAt,
894
- dispatchedAt
895
- };
896
-
897
- if (this.shouldDebug()) {
898
- const publicationInfo = this.getPublicationLogInfo(task.method, task.params);
899
- const logPayload: Record<string, any> = {
900
- taskId: task.taskId,
901
- method: task.method,
902
- messageId: task.messageId,
903
- priority: task.method === 'runPublication' ? 'publication' : 'method',
904
- worker: {
905
- id: worker.id,
906
- index: worker.workerIndex,
907
- instance: worker.workerInstance
908
- },
909
- queueDepth: this._taskQueue.length
910
- };
911
- if (publicationInfo) {
912
- Object.assign(logPayload, publicationInfo);
913
- }
914
- this.logWorkerEvent('workerTaskAssigned', logPayload);
915
- }
916
-
917
- let timeoutHandle = setTimeout(() => {
918
- let pending = this._pendingTasks.get(task.taskId);
919
- const timeoutAt = Date.now();
920
- const queuedAt = timing.queuedAt;
921
- const queueWaitMs = queuedAt ? round(dispatchedAt - queuedAt) : null;
922
- const dispatchToTimeoutMs = round(timeoutAt - dispatchedAt);
923
-
924
- if (pending) {
925
- if (pending.promise) {
926
- pending.promise.reject('Task timed out after 2m in WorkerDispatcherManager for method: ' + task.method);
927
- }
928
-
929
- this._pendingTasks.delete(task.taskId);
930
- }
931
-
932
- const publicationInfo = this.getPublicationLogInfo(task.method, task.params);
933
- const logPayload: Record<string, any> = {
934
- taskId: task.taskId,
935
- method: task.method,
936
- messageId: task.messageId,
937
- queueWaitMs,
938
- dispatchToTimeoutMs,
939
- userContext: task.userContext,
940
- worker: {
941
- id: worker.id,
942
- index: worker.workerIndex,
943
- instance: worker.workerInstance
944
- },
945
- workers: this._workers.map(a => a.activeTasks)
946
- };
947
- if (publicationInfo) {
948
- Object.assign(logPayload, publicationInfo);
949
- }
950
- this.logWorkerEvent('workerTaskTimeout', logPayload);
951
-
952
- worker.activeTasks = worker.activeTasks.filter(a => a.taskId !== task.taskId);
953
- this._taskTimings.delete(task.taskId);
954
-
955
- if (task.userContext && task.userContext.id_ws) {
956
- let timeoutRes: ServerResponseModel = {
957
- messageId: task.messageId,
958
- hasError: true,
959
- data: 'Task timed out after 2m in WorkerDispatcherManager for method: ' + task.method
960
- };
961
-
962
- let clientWS = this._websocketManager.getWebSocket(task.userContext.id_ws);
963
-
964
- if (clientWS) {
965
- this._websocketManager.send(clientWS, timeoutRes);
966
- }
967
- }
968
- }, method.timeoutOverride || (1000 * 60 * 2));
969
-
970
- // If we already stored a promise for this task (from sendInternalPromise), add the timeout now
971
- let existing = this._pendingTasks.get(task.taskId);
972
- if (!existing) {
973
- existing = { timeout: null, method: task.method };
974
- }
975
- else {
976
- existing.method = task.method;
977
- }
978
-
979
- existing.timeout = timeoutHandle;
980
- this._pendingTasks.set(task.taskId, existing);
981
-
982
- try {
983
- this.sendWorkerPayload(worker.ws, payload);
984
- }
985
- catch (err) {
986
- console.error('Failed to send task to worker:', err);
987
-
988
- clearTimeout(timeoutHandle);
989
- worker.activeTasks = worker.activeTasks.filter(a => a.taskId !== task.taskId);
990
-
991
- // Put task back in front
992
- this._taskQueue.unshift(task);
993
- this.dispatchQueue();
994
- }
995
- }
996
-
997
- private logNoWorkerAvailability() {
998
- if (!this.shouldDebug()) {
999
- return;
1000
- }
1001
-
1002
- const workers = this._workers.map(worker => ({
1003
- id: worker.id,
1004
- index: this.normalizeWorkerIndex(worker.workerIndex),
1005
- instance: this.normalizeWorkerIndex(worker.workerInstance),
1006
- activeTasks: worker.activeTasks.length
1007
- }));
1008
-
1009
- for (const task of this._taskQueue) {
1010
- const method = this._methodManager.getMethod(task.method);
1011
- const targetWorkerIndex = this.normalizeWorkerIndex(method?.targetWorkerIndex);
1012
- const targetWorkerInstance = this.normalizeWorkerIndex(method?.targetWorkerInstance);
1013
-
1014
- if (!targetWorkerIndex && !targetWorkerInstance) {
1015
- continue;
1016
- }
1017
-
1018
- if (this._debugNoWorkerTaskIds.has(task.taskId)) {
1019
- continue;
1020
- }
1021
-
1022
- const hasMatch = this._workers.some(worker =>
1023
- (!targetWorkerIndex || this.normalizeWorkerIndex(worker.workerIndex) === targetWorkerIndex) &&
1024
- (!targetWorkerInstance || this.normalizeWorkerIndex(worker.workerInstance) === targetWorkerInstance)
1025
- );
1026
-
1027
- if (!hasMatch) {
1028
- this._debugNoWorkerTaskIds.add(task.taskId);
1029
- console.warn(new Date(), '[WorkerDispatcher] No matching worker for task', {
1030
- taskId: task.taskId,
1031
- method: task.method,
1032
- targetWorkerIndex,
1033
- targetWorkerInstance,
1034
- workers
1035
- });
1036
- }
1037
- }
1038
- }
1039
-
1040
- private shouldDebug(): boolean {
1041
- if (this._methodManager.getEnableDebug()) {
1042
- return true;
1043
- }
1044
-
1045
- if (this._workerTaskDebug) {
1046
- return true;
1047
- }
1048
-
1049
- return this.parseDebugFlag(process.env.WORKER_TASK_DEBUG ?? process.env.WORKER_DISPATCH_DEBUG);
1050
- }
1051
-
1052
- private logWorkerEvent(event: string, details: Record<string, any>) {
1053
- console.log(this.safeStringify({
1054
- ts: new Date().toISOString(),
1055
- event,
1056
- ...details
1057
- }));
1058
- }
1059
-
1060
- private safeStringify(value: any): string {
1061
- try {
1062
- const seen = new WeakSet();
1063
- return JSON.stringify(value, (key, val) => {
1064
- if (key === '__proto__') {
1065
- return undefined;
1066
- }
1067
- if (typeof val === 'bigint') {
1068
- return val.toString();
1069
- }
1070
- if (val instanceof Error) {
1071
- return {
1072
- name: val.name,
1073
- message: val.message,
1074
- stack: val.stack
1075
- };
1076
- }
1077
- if (val && typeof val === 'object') {
1078
- if (seen.has(val)) {
1079
- return '[Circular]';
1080
- }
1081
- seen.add(val);
1082
- }
1083
- return val;
1084
- });
1085
- }
1086
- catch (err) {
1087
- return JSON.stringify({
1088
- error: 'safeStringifyFailed',
1089
- message: err?.message || String(err)
1090
- });
1091
- }
1092
- }
1093
-
1094
- /**
1095
- * Handle messages coming back from a worker (like 'taskComplete').
1096
- */
1097
- public handleWorkerMessage(workerId: string, rawMessage: WebSocket.RawData) {
1098
- let data: TaskResponse;
1099
-
1100
- try {
1101
- if (typeof rawMessage === 'string') {
1102
- data = JSON.parse(rawMessage, dateReviver);
1103
- }
1104
- else if (Buffer.isBuffer(rawMessage)) {
1105
- data = unpack(rawMessage);
1106
- }
1107
- else if (Array.isArray(rawMessage)) {
1108
- const chunks = rawMessage as unknown as ReadonlyArray<Uint8Array>;
1109
- data = unpack(Buffer.concat(chunks));
1110
- }
1111
- else if (rawMessage instanceof ArrayBuffer) {
1112
- data = unpack(Buffer.from(rawMessage));
1113
- }
1114
- else if (ArrayBuffer.isView(rawMessage)) {
1115
- const view = rawMessage as NodeJS.ArrayBufferView;
1116
- data = unpack(Buffer.from(view.buffer, view.byteOffset, view.byteLength));
1117
- }
1118
- else {
1119
- console.error('Unsupported worker message type received:', typeof rawMessage);
1120
- return;
1121
- }
1122
- }
1123
- catch (err) {
1124
- console.error('Failed to parse worker message:', err);
1125
- return;
1126
- }
1127
-
1128
- if (data.type === 'taskComplete') {
1129
- let worker = this._workers.find(x => x.id === workerId);
1130
-
1131
- if (!worker) {
1132
- console.error('Unknown worker for taskComplete:', workerId);
1133
- return;
1134
- }
1135
-
1136
- let { taskId, messageId, error, result } = data;
1137
- const timing = this._taskTimings.get(taskId);
1138
- const methodName = timing?.method;
1139
- const isAiMethod = !!methodName && methodName.startsWith('ai');
1140
- let unpackedResult = result;
1141
- let pendingTask = this._pendingTasks.get(taskId);
1142
- const resolveRaw = !!pendingTask?.resolveRaw;
1143
-
1144
- if (!error && !resolveRaw && unpackedResult === null && data['packedResult']) {
1145
- try {
1146
- unpackedResult = unpack(data['packedResult']);
1147
- }
1148
- catch (err) {
1149
- console.error('Failed to unpack worker result', err);
1150
- }
1151
- }
1152
- worker.activeTasks = worker.activeTasks.filter(a => a.taskId !== taskId);
1153
- this._taskTimings.delete(taskId);
1154
-
1155
- if (this._aiWorkerDebug && isAiMethod) {
1156
- const packedBytes = data['packedResult'] && data['packedResult'].byteLength
1157
- ? data['packedResult'].byteLength
1158
- : null;
1159
- let resultBytes: number | null = null;
1160
- if (!packedBytes) {
1161
- try {
1162
- resultBytes = Buffer.byteLength(JSON.stringify(result));
1163
- }
1164
- catch {
1165
- resultBytes = null;
1166
- }
1167
- }
1168
- console.log(new Date(), '[AI Worker Debug] worker result', {
1169
- taskId,
1170
- method: methodName,
1171
- messageId,
1172
- hasError: !!error,
1173
- packedBytes,
1174
- resultBytes,
1175
- workerIndex: worker?.workerIndex || null,
1176
- workerInstance: worker?.workerInstance || null,
1177
- queueDepth: this._taskQueue.length
1178
- });
1179
- }
1180
-
1181
-
1182
- if (pendingTask) {
1183
- if (pendingTask.promise) {
1184
- if (error) {
1185
- pendingTask.promise.reject(unpackedResult);
1186
- }
1187
- else {
1188
- pendingTask.promise.resolve(resolveRaw ? data : unpackedResult);
1189
- }
1190
- }
1191
-
1192
- clearTimeout(pendingTask.timeout);
1193
- this._pendingTasks.delete(taskId);
1194
- }
1195
-
1196
- // Look up original request if it came from a client
1197
- let clientReqId = this._clientRequests[taskId];
1198
-
1199
- if (clientReqId) {
1200
- let res: ServerResponseModel = {
1201
- messageId: messageId,
1202
- hasError: false,
1203
- data: result
1204
- };
1205
-
1206
- if (error) {
1207
- res.hasError = true;
1208
- res.data = result;
1209
- }
1210
-
1211
- let clientReqWS = this._websocketManager.getWebSocket(clientReqId);
1212
-
1213
- if (clientReqWS) {
1214
- if (!error && data['packedResult']) {
1215
- this._websocketManager.sendPackedBuffer(
1216
- clientReqWS,
1217
- messageId,
1218
- false,
1219
- data['packedResult'],
1220
- data['encoding'] || 'msgpack',
1221
- { passThrough: true }
1222
- );
1223
- }
1224
- else {
1225
- this._websocketManager.send(clientReqWS, res);
1226
- }
1227
- }
1228
-
1229
- if (this._clientRequests[taskId]) {
1230
- delete this._clientRequests[taskId];
1231
- }
1232
- }
1233
-
1234
- // Try to dispatch more from the queue
1235
- if (this._taskQueue.length) {
1236
- this.dispatchQueue();
1237
- }
1238
- }
1239
- }
1240
-
1241
- public sendWorkerPayload(ws: WebSocket.WebSocket, payload: TaskPayload | string) {
1242
- if (!ws) {
1243
- return;
1244
- }
1245
-
1246
- if (ws.readyState !== WebSocket.OPEN) {
1247
- if (typeof payload !== 'string') {
1248
- const task = payload;
1249
-
1250
- this._taskQueue.unshift(task);
1251
- this.dispatchQueue();
1252
-
1253
- this.disconnectWorker(ws['id_worker']);
1254
- ws.close();
1255
-
1256
- let pendingTask = this._pendingTasks.get(task.taskId);
1257
-
1258
- if (pendingTask) {
1259
- clearTimeout(pendingTask.timeout);
1260
- this._pendingTasks.delete(task.taskId);
1261
-
1262
- if (pendingTask.promise) {
1263
- pendingTask.promise.reject('Worker socket not open.');
1264
- }
1265
- }
1266
- }
1267
- else {
1268
- this.disconnectWorker(ws['id_worker']);
1269
- ws.close();
1270
- }
1271
-
1272
- return;
1273
- }
1274
-
1275
- if (typeof payload === 'string') {
1276
- try {
1277
- ws.send(payload);
1278
- }
1279
- catch (err) {
1280
- this.disconnectWorker(ws['id_worker']);
1281
- ws.close();
1282
- console.error('Failed to send worker payload:', err);
1283
- }
1284
-
1285
- return;
1286
- }
1287
-
1288
- const task = payload;
1289
- const payloadBuffer = pack(task);
1290
-
1291
- try {
1292
- ws.send(payloadBuffer);
1293
- }
1294
- catch (err) {
1295
- this._taskQueue.unshift(task);
1296
- this.dispatchQueue();
1297
-
1298
- if (this._methodManager.getEnableDebug()) {
1299
- console.log(new Date(), 'Sending to Server', task);
1300
- }
1301
-
1302
- this.disconnectWorker(ws['id_worker']);
1303
- ws.close();
1304
- console.error('Failed to send worker response:', err);
1305
-
1306
- let pendingTask = this._pendingTasks.get(task.taskId);
1307
-
1308
- if (pendingTask) {
1309
- clearTimeout(pendingTask.timeout);
1310
- this._pendingTasks.delete(task.taskId);
1311
-
1312
- if (pendingTask.promise) {
1313
- pendingTask.promise.reject('Failed to send worker response: ' + err?.toString());
1314
- }
1315
- }
1316
- }
1317
- }
1318
- }