@resolveio/server-lib 22.3.221 → 22.3.222

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