@resolveio/server-lib 22.3.124 → 22.3.126

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 (711) hide show
  1. package/.nodemon.json +5 -0
  2. package/.vscode/settings.json +21 -0
  3. package/AGENTS.md +195 -0
  4. package/README.md +22 -0
  5. package/build_package.sh +5 -0
  6. package/compileDTS.pl +64 -0
  7. package/docs/ai-assistant-nightly-eval.md +65 -0
  8. package/docs/ai-assistant-preflight-checklist.md +23 -0
  9. package/docs/ai-assistant-report-builder-bridge-playbook.md +115 -0
  10. package/eslint-plugin-custom/index.js +7 -0
  11. package/eslint-plugin-custom/rules/no-filter-zero-index.js +44 -0
  12. package/eslint.config.js +103 -0
  13. package/gulpfile.js +216 -0
  14. package/methodAndPublicationListGenerator.py +375 -0
  15. package/mongodbensurers.js +2 -0
  16. package/mongostop.js +3 -0
  17. package/package.json +3 -1
  18. package/scripts/cleanup-bypassed-callmethod-logs.js +616 -0
  19. package/settings.development.json +25 -0
  20. package/settings.development.redacted.json +25 -0
  21. package/src/.env +12 -0
  22. package/src/ai/assistant-core-heuristics.ts +379 -0
  23. package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +185 -0
  24. package/src/ai/resolveio-platform-intelligence-memory.ts +325 -0
  25. package/{ai/resolveio-platform-intelligence-types.d.ts → src/ai/resolveio-platform-intelligence-types.ts} +20 -15
  26. package/src/ai/resolveio-platform-intelligence.ts +462 -0
  27. package/src/client-server-app.ts +12 -0
  28. package/src/collections/ai-run.collection.ts +117 -0
  29. package/src/collections/ai-terminal-conversation.collection.ts +91 -0
  30. package/src/collections/ai-terminal-issue-report.collection.ts +99 -0
  31. package/src/collections/ai-terminal-message.collection.ts +77 -0
  32. package/src/collections/app-setting.collection.ts +104 -0
  33. package/src/collections/app-status.collection.ts +58 -0
  34. package/src/collections/communication-metric.collection.ts +84 -0
  35. package/src/collections/counter.collection.ts +56 -0
  36. package/src/collections/cron-job-history.collection.ts +94 -0
  37. package/src/collections/cron-job.collection.ts +92 -0
  38. package/src/collections/customer-notification.collection.ts +131 -0
  39. package/src/collections/customer-portal-password.collection.ts +76 -0
  40. package/src/collections/email-history.collection.ts +134 -0
  41. package/src/collections/email-verified.collection.ts +62 -0
  42. package/src/collections/file.collection.ts +74 -0
  43. package/src/collections/flag-update.collection.ts +57 -0
  44. package/src/collections/flag.collection.ts +57 -0
  45. package/src/collections/log-method-latency.collection.ts +77 -0
  46. package/src/collections/log-subscription.collection.ts +80 -0
  47. package/src/collections/log.collection.ts +93 -0
  48. package/src/collections/logged-in-users.collection.ts +67 -0
  49. package/src/collections/monitor-cpu.collection.ts +65 -0
  50. package/src/collections/monitor-function.collection.ts +74 -0
  51. package/src/collections/monitor-memory.collection.ts +77 -0
  52. package/src/collections/monitor-mongo.collection.ts +71 -0
  53. package/src/collections/notification.collection.ts +57 -0
  54. package/src/collections/openai-usage-ledger.collection.ts +77 -0
  55. package/src/collections/report-builder-dashboard-builder.collection.ts +109 -0
  56. package/src/collections/report-builder-library.collection.ts +89 -0
  57. package/src/collections/report-builder-report.collection.ts +184 -0
  58. package/src/collections/user-group.collection.ts +89 -0
  59. package/src/collections/user-guide.collection.ts +57 -0
  60. package/src/collections/user.collection.ts +181 -0
  61. package/src/cron/cron.ts +117 -0
  62. package/src/fixtures/cron-jobs.ts +95 -0
  63. package/src/fixtures/init.ts +35 -0
  64. package/src/http/auth.ts +818 -0
  65. package/src/http/health.ts +7 -0
  66. package/src/http/home.ts +90 -0
  67. package/src/http/slow-query-publication.ts +49 -0
  68. package/src/index.ts +1 -0
  69. package/src/managers/ai-assistant-codex-manager.manager.ts +1131 -0
  70. package/src/managers/ai-run-evidence.manager.ts +264 -0
  71. package/src/managers/communication-metric.manager.ts +82 -0
  72. package/src/managers/cron.manager.ts +333 -0
  73. package/src/managers/customer-notification-content.manager.ts +236 -0
  74. package/src/managers/diagnostic-manager-bootstrap.ts +165 -0
  75. package/src/managers/error-auto-fix.manager.ts +2767 -0
  76. package/src/managers/local-log.manager.ts +113 -0
  77. package/src/managers/method.manager.ts +1857 -0
  78. package/src/managers/mongo.manager.ts +4575 -0
  79. package/src/managers/monitor.manager.ts +507 -0
  80. package/src/managers/openai-usage-ledger.manager.ts +57 -0
  81. package/src/managers/slow-query-verifier.manager.ts +3590 -0
  82. package/src/managers/slow-query.manager.ts +519 -0
  83. package/src/managers/subscription.manager.ts +3128 -0
  84. package/src/managers/websocket.manager.ts +746 -0
  85. package/src/managers/worker-dispatcher.manager.ts +1360 -0
  86. package/src/managers/worker-server.manager.ts +536 -0
  87. package/src/methods/accounts.ts +532 -0
  88. package/src/methods/ai-terminal.ts +23497 -0
  89. package/src/methods/app-settings.ts +114 -0
  90. package/src/methods/aws.ts +649 -0
  91. package/src/methods/collections.ts +641 -0
  92. package/src/methods/counters.ts +69 -0
  93. package/src/methods/cron-jobs.ts +2614 -0
  94. package/src/methods/customer-notifications.ts +458 -0
  95. package/src/methods/diagnostics.ts +616 -0
  96. package/src/methods/flag-updates.ts +7 -0
  97. package/src/methods/flags.ts +7 -0
  98. package/src/methods/logs.ts +657 -0
  99. package/src/methods/mongo-explorer.ts +1880 -0
  100. package/src/methods/monitor.ts +540 -0
  101. package/src/methods/pdf.ts +1236 -0
  102. package/src/methods/publications.ts +129 -0
  103. package/src/methods/report-builder.ts +3300 -0
  104. package/src/methods/support.ts +335 -0
  105. package/src/models/ai-run.model.ts +27 -0
  106. package/src/models/ai-terminal-conversation.model.ts +19 -0
  107. package/src/models/ai-terminal-issue-report.model.ts +21 -0
  108. package/src/models/ai-terminal-message.model.ts +24 -0
  109. package/src/models/app-setting.model.ts +17 -0
  110. package/{models/app-status.model.d.ts → src/models/app-status.model.ts} +3 -2
  111. package/{models/billing-logged-in-users.model.d.ts → src/models/billing-logged-in-users.model.ts} +5 -4
  112. package/src/models/collection-document.model.ts +24 -0
  113. package/src/models/communication-metric.model.ts +23 -0
  114. package/{models/counter.model.d.ts → src/models/counter.model.ts} +4 -3
  115. package/src/models/cron-job-history.model.ts +16 -0
  116. package/src/models/cron-job.model.ts +15 -0
  117. package/src/models/customer-notification.model.ts +28 -0
  118. package/src/models/customer-portal-password.model.ts +12 -0
  119. package/src/models/dialog.model.ts +25 -0
  120. package/{models/email-history.model.js → src/models/email-history.model.ts} +36 -4
  121. package/{models/email-verified.model.d.ts → src/models/email-verified.model.ts} +6 -5
  122. package/{models/file.model.d.ts → src/models/file.model.ts} +8 -7
  123. package/{models/flag-update.model.d.ts → src/models/flag-update.model.ts} +4 -3
  124. package/{models/flag.model.d.ts → src/models/flag.model.ts} +4 -3
  125. package/src/models/log-method-latency.model.ts +11 -0
  126. package/{models/log-subscription.model.d.ts → src/models/log-subscription.model.ts} +11 -9
  127. package/src/models/log.model.ts +19 -0
  128. package/{models/logged-in-users.model.d.ts → src/models/logged-in-users.model.ts} +6 -5
  129. package/{models/method-response.model.d.ts → src/models/method-response.model.ts} +7 -6
  130. package/src/models/method.model.ts +25 -0
  131. package/{models/monitor-cpu.model.d.ts → src/models/monitor-cpu.model.ts} +9 -7
  132. package/src/models/monitor-function.model.ts +16 -0
  133. package/src/models/monitor-memory.model.ts +17 -0
  134. package/src/models/monitor-mongo.model.ts +15 -0
  135. package/{models/notification.model.d.ts → src/models/notification.model.ts} +6 -4
  136. package/src/models/openai-usage-ledger.model.ts +16 -0
  137. package/src/models/pagination.model.ts +35 -0
  138. package/src/models/permission.model.ts +14 -0
  139. package/src/models/report-builder-dashboard-builder.model.ts +29 -0
  140. package/src/models/report-builder-library.model.ts +20 -0
  141. package/src/models/report-builder-report.model.ts +136 -0
  142. package/src/models/report-builder.model.ts +68 -0
  143. package/src/models/select-data-label.model.ts +9 -0
  144. package/src/models/server-message.model.ts +31 -0
  145. package/src/models/slow-query-report.model.ts +23 -0
  146. package/src/models/subscription.model.ts +73 -0
  147. package/src/models/support-ticket.model.ts +104 -0
  148. package/src/models/user-group.model.ts +24 -0
  149. package/{models/user-guide.model.d.ts → src/models/user-guide.model.ts} +5 -4
  150. package/src/models/user.model.ts +96 -0
  151. package/src/private/images/ResolveIO.png +0 -0
  152. package/{public_api.d.ts → src/public_api.ts} +7 -0
  153. package/src/publications/ai-terminal.ts +73 -0
  154. package/src/publications/app-settings.ts +25 -0
  155. package/src/publications/app-status.ts +13 -0
  156. package/src/publications/cron-jobs.ts +40 -0
  157. package/src/publications/customer-notifications.ts +101 -0
  158. package/src/publications/files.ts +33 -0
  159. package/src/publications/flags-update.ts +19 -0
  160. package/src/publications/flags.ts +19 -0
  161. package/src/publications/logs.ts +163 -0
  162. package/src/publications/notifications.ts +13 -0
  163. package/src/publications/report-builder-dashboard-builders.ts +39 -0
  164. package/src/publications/report-builder-libraries.ts +41 -0
  165. package/src/publications/report-builder-reports.ts +47 -0
  166. package/src/publications/super-admin.ts +13 -0
  167. package/src/publications/user-groups.ts +12 -0
  168. package/src/publications/user-guides.ts +12 -0
  169. package/src/resolveio-server-app.ts +617 -0
  170. package/src/server-app.ts +3354 -0
  171. package/src/services/codex-client.ts +1231 -0
  172. package/src/services/openai-client.ts +265 -0
  173. package/src/types/error-report.ts +26 -0
  174. package/src/types/js-tiktoken.d.ts +11 -0
  175. package/src/types/slow-query-report.ts +28 -0
  176. package/src/util/ai-qa-policy.ts +925 -0
  177. package/src/util/ai-run-evidence-adapters.ts +521 -0
  178. package/src/util/ai-run-evidence-dashboard.ts +271 -0
  179. package/src/util/ai-run-evidence-eval.ts +885 -0
  180. package/src/util/ai-run-evidence.ts +964 -0
  181. package/src/util/ai-runner-artifacts.ts +586 -0
  182. package/src/util/ai-runner-qa-auth.ts +821 -0
  183. package/src/util/ai-runner-qa-tools.ts +3045 -0
  184. package/src/util/aicoder-runner-v6.ts +526 -0
  185. package/src/util/common.ts +649 -0
  186. package/src/util/customer-portal-password.ts +183 -0
  187. package/src/util/error-reporter.ts +332 -0
  188. package/src/util/error-tracking.ts +79 -0
  189. package/src/util/openai-usage-cost.ts +114 -0
  190. package/src/util/report-builder-unwinds.ts +180 -0
  191. package/src/util/runner-process-janitor.ts +219 -0
  192. package/src/util/schema-report-builder.ts +448 -0
  193. package/src/util/slow-query-reporter.ts +216 -0
  194. package/src/util/subscription-dependency-context.ts +1096 -0
  195. package/src/util/support-runner-v5.ts +897 -0
  196. package/src/util/tokenizer.ts +38 -0
  197. package/src/workers/codex-runner.worker.ts +142 -0
  198. package/start_server.sh +5 -0
  199. package/tests/ai-assistant-corpus-build.ts +484 -0
  200. package/tests/ai-assistant-corpus-replay-e2e.ts +774 -0
  201. package/tests/ai-assistant-data-parity-e2e.ts +1989 -0
  202. package/tests/ai-assistant-eval-triage.ts +831 -0
  203. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  204. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  205. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  206. package/tests/ai-assistant-routing-eval.test.ts +560 -0
  207. package/tests/ai-assistant-snf-live-eval.ts +975 -0
  208. package/tests/ai-assistant-utils.test.ts +2968 -0
  209. package/tests/ai-run-eval.test.ts +88 -0
  210. package/tests/ai-run-evidence.test.ts +232 -0
  211. package/tests/ai-runner-contract.test.ts +488 -0
  212. package/tests/aicoder-runner-v6.test.ts +92 -0
  213. package/tests/error-reporter.test.ts +145 -0
  214. package/tests/method-publication-generator.test.ts +46 -0
  215. package/tests/report-builder-linking.test.ts +79 -0
  216. package/tests/resolveio-platform-intelligence.test.ts +352 -0
  217. package/tests/server-app-cron-owner.test.ts +127 -0
  218. package/tests/subscription-connect-race.test.ts +158 -0
  219. package/tests/subscription-dependency-context.test.ts +324 -0
  220. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  221. package/tests/subscription-manager-invalidation.test.ts +86 -0
  222. package/tests/support-runner-v5.test.ts +191 -0
  223. package/tsconfig.json +34 -0
  224. package/ai/assistant-core-heuristics.d.ts +0 -11
  225. package/ai/assistant-core-heuristics.js +0 -356
  226. package/ai/assistant-core-heuristics.js.map +0 -1
  227. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +0 -3
  228. package/ai/resolveio-platform-intelligence-memory-corpus.js +0 -214
  229. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +0 -1
  230. package/ai/resolveio-platform-intelligence-memory.d.ts +0 -20
  231. package/ai/resolveio-platform-intelligence-memory.js +0 -341
  232. package/ai/resolveio-platform-intelligence-memory.js.map +0 -1
  233. package/ai/resolveio-platform-intelligence-types.js +0 -4
  234. package/ai/resolveio-platform-intelligence-types.js.map +0 -1
  235. package/ai/resolveio-platform-intelligence.d.ts +0 -6
  236. package/ai/resolveio-platform-intelligence.js +0 -463
  237. package/ai/resolveio-platform-intelligence.js.map +0 -1
  238. package/client-server-app.d.ts +0 -1
  239. package/client-server-app.js +0 -68
  240. package/client-server-app.js.map +0 -1
  241. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  242. package/collections/ai-terminal-conversation.collection.js +0 -140
  243. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  244. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  245. package/collections/ai-terminal-issue-report.collection.js +0 -148
  246. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  247. package/collections/ai-terminal-message.collection.d.ts +0 -2
  248. package/collections/ai-terminal-message.collection.js +0 -121
  249. package/collections/ai-terminal-message.collection.js.map +0 -1
  250. package/collections/app-setting.collection.d.ts +0 -3
  251. package/collections/app-setting.collection.js +0 -103
  252. package/collections/app-setting.collection.js.map +0 -1
  253. package/collections/app-status.collection.d.ts +0 -3
  254. package/collections/app-status.collection.js +0 -57
  255. package/collections/app-status.collection.js.map +0 -1
  256. package/collections/communication-metric.collection.d.ts +0 -2
  257. package/collections/communication-metric.collection.js +0 -133
  258. package/collections/communication-metric.collection.js.map +0 -1
  259. package/collections/counter.collection.d.ts +0 -3
  260. package/collections/counter.collection.js +0 -56
  261. package/collections/counter.collection.js.map +0 -1
  262. package/collections/cron-job-history.collection.d.ts +0 -3
  263. package/collections/cron-job-history.collection.js +0 -137
  264. package/collections/cron-job-history.collection.js.map +0 -1
  265. package/collections/cron-job.collection.d.ts +0 -3
  266. package/collections/cron-job.collection.js +0 -92
  267. package/collections/cron-job.collection.js.map +0 -1
  268. package/collections/customer-notification.collection.d.ts +0 -3
  269. package/collections/customer-notification.collection.js +0 -130
  270. package/collections/customer-notification.collection.js.map +0 -1
  271. package/collections/customer-portal-password.collection.d.ts +0 -3
  272. package/collections/customer-portal-password.collection.js +0 -75
  273. package/collections/customer-portal-password.collection.js.map +0 -1
  274. package/collections/email-history.collection.d.ts +0 -3
  275. package/collections/email-history.collection.js +0 -134
  276. package/collections/email-history.collection.js.map +0 -1
  277. package/collections/email-verified.collection.d.ts +0 -3
  278. package/collections/email-verified.collection.js +0 -62
  279. package/collections/email-verified.collection.js.map +0 -1
  280. package/collections/file.collection.d.ts +0 -3
  281. package/collections/file.collection.js +0 -74
  282. package/collections/file.collection.js.map +0 -1
  283. package/collections/flag-update.collection.d.ts +0 -3
  284. package/collections/flag-update.collection.js +0 -57
  285. package/collections/flag-update.collection.js.map +0 -1
  286. package/collections/flag.collection.d.ts +0 -3
  287. package/collections/flag.collection.js +0 -57
  288. package/collections/flag.collection.js.map +0 -1
  289. package/collections/log-method-latency.collection.d.ts +0 -3
  290. package/collections/log-method-latency.collection.js +0 -77
  291. package/collections/log-method-latency.collection.js.map +0 -1
  292. package/collections/log-subscription.collection.d.ts +0 -3
  293. package/collections/log-subscription.collection.js +0 -80
  294. package/collections/log-subscription.collection.js.map +0 -1
  295. package/collections/log.collection.d.ts +0 -3
  296. package/collections/log.collection.js +0 -93
  297. package/collections/log.collection.js.map +0 -1
  298. package/collections/logged-in-users.collection.d.ts +0 -3
  299. package/collections/logged-in-users.collection.js +0 -67
  300. package/collections/logged-in-users.collection.js.map +0 -1
  301. package/collections/monitor-cpu.collection.d.ts +0 -3
  302. package/collections/monitor-cpu.collection.js +0 -65
  303. package/collections/monitor-cpu.collection.js.map +0 -1
  304. package/collections/monitor-function.collection.d.ts +0 -3
  305. package/collections/monitor-function.collection.js +0 -74
  306. package/collections/monitor-function.collection.js.map +0 -1
  307. package/collections/monitor-memory.collection.d.ts +0 -3
  308. package/collections/monitor-memory.collection.js +0 -77
  309. package/collections/monitor-memory.collection.js.map +0 -1
  310. package/collections/monitor-mongo.collection.d.ts +0 -3
  311. package/collections/monitor-mongo.collection.js +0 -71
  312. package/collections/monitor-mongo.collection.js.map +0 -1
  313. package/collections/notification.collection.d.ts +0 -3
  314. package/collections/notification.collection.js +0 -57
  315. package/collections/notification.collection.js.map +0 -1
  316. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  317. package/collections/openai-usage-ledger.collection.js +0 -124
  318. package/collections/openai-usage-ledger.collection.js.map +0 -1
  319. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  320. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  321. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  322. package/collections/report-builder-library.collection.d.ts +0 -3
  323. package/collections/report-builder-library.collection.js +0 -87
  324. package/collections/report-builder-library.collection.js.map +0 -1
  325. package/collections/report-builder-report.collection.d.ts +0 -4
  326. package/collections/report-builder-report.collection.js +0 -184
  327. package/collections/report-builder-report.collection.js.map +0 -1
  328. package/collections/user-group.collection.d.ts +0 -4
  329. package/collections/user-group.collection.js +0 -89
  330. package/collections/user-group.collection.js.map +0 -1
  331. package/collections/user-guide.collection.d.ts +0 -3
  332. package/collections/user-guide.collection.js +0 -57
  333. package/collections/user-guide.collection.js.map +0 -1
  334. package/collections/user.collection.d.ts +0 -4
  335. package/collections/user.collection.js +0 -180
  336. package/collections/user.collection.js.map +0 -1
  337. package/cron/cron.d.ts +0 -14
  338. package/cron/cron.js +0 -216
  339. package/cron/cron.js.map +0 -1
  340. package/fixtures/cron-jobs.d.ts +0 -1
  341. package/fixtures/cron-jobs.js +0 -150
  342. package/fixtures/cron-jobs.js.map +0 -1
  343. package/fixtures/init.d.ts +0 -1
  344. package/fixtures/init.js +0 -91
  345. package/fixtures/init.js.map +0 -1
  346. package/http/auth.d.ts +0 -2
  347. package/http/auth.js +0 -951
  348. package/http/auth.js.map +0 -1
  349. package/http/health.d.ts +0 -1
  350. package/http/health.js +0 -11
  351. package/http/health.js.map +0 -1
  352. package/http/home.d.ts +0 -1
  353. package/http/home.js +0 -134
  354. package/http/home.js.map +0 -1
  355. package/http/slow-query-publication.d.ts +0 -2
  356. package/http/slow-query-publication.js +0 -99
  357. package/http/slow-query-publication.js.map +0 -1
  358. package/index.d.ts +0 -1
  359. package/index.js +0 -19
  360. package/index.js.map +0 -1
  361. package/managers/ai-assistant-codex-manager.manager.d.ts +0 -67
  362. package/managers/ai-assistant-codex-manager.manager.js +0 -1113
  363. package/managers/ai-assistant-codex-manager.manager.js.map +0 -1
  364. package/managers/communication-metric.manager.d.ts +0 -16
  365. package/managers/communication-metric.manager.js +0 -134
  366. package/managers/communication-metric.manager.js.map +0 -1
  367. package/managers/cron.manager.d.ts +0 -20
  368. package/managers/cron.manager.js +0 -534
  369. package/managers/cron.manager.js.map +0 -1
  370. package/managers/customer-notification-content.manager.d.ts +0 -55
  371. package/managers/customer-notification-content.manager.js +0 -158
  372. package/managers/customer-notification-content.manager.js.map +0 -1
  373. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  374. package/managers/diagnostic-manager-bootstrap.js +0 -260
  375. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  376. package/managers/error-auto-fix.manager.d.ts +0 -149
  377. package/managers/error-auto-fix.manager.js +0 -3064
  378. package/managers/error-auto-fix.manager.js.map +0 -1
  379. package/managers/local-log.manager.d.ts +0 -18
  380. package/managers/local-log.manager.js +0 -88
  381. package/managers/local-log.manager.js.map +0 -1
  382. package/managers/method.manager.d.ts +0 -84
  383. package/managers/method.manager.js +0 -1964
  384. package/managers/method.manager.js.map +0 -1
  385. package/managers/mongo.manager.d.ts +0 -224
  386. package/managers/mongo.manager.js +0 -5000
  387. package/managers/mongo.manager.js.map +0 -1
  388. package/managers/monitor.manager.d.ts +0 -70
  389. package/managers/monitor.manager.js +0 -550
  390. package/managers/monitor.manager.js.map +0 -1
  391. package/managers/openai-usage-ledger.manager.d.ts +0 -15
  392. package/managers/openai-usage-ledger.manager.js +0 -144
  393. package/managers/openai-usage-ledger.manager.js.map +0 -1
  394. package/managers/slow-query-verifier.manager.d.ts +0 -144
  395. package/managers/slow-query-verifier.manager.js +0 -3857
  396. package/managers/slow-query-verifier.manager.js.map +0 -1
  397. package/managers/slow-query.manager.d.ts +0 -28
  398. package/managers/slow-query.manager.js +0 -468
  399. package/managers/slow-query.manager.js.map +0 -1
  400. package/managers/subscription.manager.d.ts +0 -169
  401. package/managers/subscription.manager.js +0 -3434
  402. package/managers/subscription.manager.js.map +0 -1
  403. package/managers/websocket.manager.d.ts +0 -73
  404. package/managers/websocket.manager.js +0 -673
  405. package/managers/websocket.manager.js.map +0 -1
  406. package/managers/worker-dispatcher.manager.d.ts +0 -120
  407. package/managers/worker-dispatcher.manager.js +0 -1266
  408. package/managers/worker-dispatcher.manager.js.map +0 -1
  409. package/managers/worker-server.manager.d.ts +0 -35
  410. package/managers/worker-server.manager.js +0 -582
  411. package/managers/worker-server.manager.js.map +0 -1
  412. package/methods/accounts.d.ts +0 -2
  413. package/methods/accounts.js +0 -624
  414. package/methods/accounts.js.map +0 -1
  415. package/methods/ai-terminal.d.ts +0 -337
  416. package/methods/ai-terminal.js +0 -23166
  417. package/methods/ai-terminal.js.map +0 -1
  418. package/methods/app-settings.d.ts +0 -2
  419. package/methods/app-settings.js +0 -169
  420. package/methods/app-settings.js.map +0 -1
  421. package/methods/aws.d.ts +0 -2
  422. package/methods/aws.js +0 -877
  423. package/methods/aws.js.map +0 -1
  424. package/methods/collections.d.ts +0 -2
  425. package/methods/collections.js +0 -719
  426. package/methods/collections.js.map +0 -1
  427. package/methods/counters.d.ts +0 -2
  428. package/methods/counters.js +0 -113
  429. package/methods/counters.js.map +0 -1
  430. package/methods/cron-jobs.d.ts +0 -2
  431. package/methods/cron-jobs.js +0 -2475
  432. package/methods/cron-jobs.js.map +0 -1
  433. package/methods/customer-notifications.d.ts +0 -2
  434. package/methods/customer-notifications.js +0 -528
  435. package/methods/customer-notifications.js.map +0 -1
  436. package/methods/diagnostics.d.ts +0 -2
  437. package/methods/diagnostics.js +0 -703
  438. package/methods/diagnostics.js.map +0 -1
  439. package/methods/flag-updates.d.ts +0 -2
  440. package/methods/flag-updates.js +0 -8
  441. package/methods/flag-updates.js.map +0 -1
  442. package/methods/flags.d.ts +0 -2
  443. package/methods/flags.js +0 -8
  444. package/methods/flags.js.map +0 -1
  445. package/methods/logs.d.ts +0 -2
  446. package/methods/logs.js +0 -751
  447. package/methods/logs.js.map +0 -1
  448. package/methods/mongo-explorer.d.ts +0 -2
  449. package/methods/mongo-explorer.js +0 -1808
  450. package/methods/mongo-explorer.js.map +0 -1
  451. package/methods/monitor.d.ts +0 -2
  452. package/methods/monitor.js +0 -543
  453. package/methods/monitor.js.map +0 -1
  454. package/methods/pdf.d.ts +0 -2
  455. package/methods/pdf.js +0 -1216
  456. package/methods/pdf.js.map +0 -1
  457. package/methods/publications.d.ts +0 -1
  458. package/methods/publications.js +0 -183
  459. package/methods/publications.js.map +0 -1
  460. package/methods/report-builder.d.ts +0 -2
  461. package/methods/report-builder.js +0 -3094
  462. package/methods/report-builder.js.map +0 -1
  463. package/methods/support.d.ts +0 -2
  464. package/methods/support.js +0 -430
  465. package/methods/support.js.map +0 -1
  466. package/models/ai-terminal-conversation.model.d.ts +0 -17
  467. package/models/ai-terminal-conversation.model.js +0 -4
  468. package/models/ai-terminal-conversation.model.js.map +0 -1
  469. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  470. package/models/ai-terminal-issue-report.model.js +0 -4
  471. package/models/ai-terminal-issue-report.model.js.map +0 -1
  472. package/models/ai-terminal-message.model.d.ts +0 -22
  473. package/models/ai-terminal-message.model.js +0 -4
  474. package/models/ai-terminal-message.model.js.map +0 -1
  475. package/models/app-setting.model.d.ts +0 -16
  476. package/models/app-setting.model.js +0 -4
  477. package/models/app-setting.model.js.map +0 -1
  478. package/models/app-status.model.js +0 -4
  479. package/models/app-status.model.js.map +0 -1
  480. package/models/billing-logged-in-users.model.js +0 -4
  481. package/models/billing-logged-in-users.model.js.map +0 -1
  482. package/models/collection-document.model.d.ts +0 -21
  483. package/models/collection-document.model.js +0 -4
  484. package/models/collection-document.model.js.map +0 -1
  485. package/models/communication-metric.model.d.ts +0 -20
  486. package/models/communication-metric.model.js +0 -4
  487. package/models/communication-metric.model.js.map +0 -1
  488. package/models/counter.model.js +0 -4
  489. package/models/counter.model.js.map +0 -1
  490. package/models/cron-job-history.model.d.ts +0 -15
  491. package/models/cron-job-history.model.js +0 -4
  492. package/models/cron-job-history.model.js.map +0 -1
  493. package/models/cron-job.model.d.ts +0 -14
  494. package/models/cron-job.model.js +0 -4
  495. package/models/cron-job.model.js.map +0 -1
  496. package/models/customer-notification.model.d.ts +0 -26
  497. package/models/customer-notification.model.js +0 -4
  498. package/models/customer-notification.model.js.map +0 -1
  499. package/models/customer-portal-password.model.d.ts +0 -11
  500. package/models/customer-portal-password.model.js +0 -4
  501. package/models/customer-portal-password.model.js.map +0 -1
  502. package/models/dialog.model.d.ts +0 -23
  503. package/models/dialog.model.js +0 -4
  504. package/models/dialog.model.js.map +0 -1
  505. package/models/email-history.model.d.ts +0 -32
  506. package/models/email-history.model.js.map +0 -1
  507. package/models/email-verified.model.js +0 -4
  508. package/models/email-verified.model.js.map +0 -1
  509. package/models/file.model.js +0 -4
  510. package/models/file.model.js.map +0 -1
  511. package/models/flag-update.model.js +0 -4
  512. package/models/flag-update.model.js.map +0 -1
  513. package/models/flag.model.js +0 -4
  514. package/models/flag.model.js.map +0 -1
  515. package/models/log-method-latency.model.d.ts +0 -10
  516. package/models/log-method-latency.model.js +0 -4
  517. package/models/log-method-latency.model.js.map +0 -1
  518. package/models/log-subscription.model.js +0 -4
  519. package/models/log-subscription.model.js.map +0 -1
  520. package/models/log.model.d.ts +0 -17
  521. package/models/log.model.js +0 -4
  522. package/models/log.model.js.map +0 -1
  523. package/models/logged-in-users.model.js +0 -4
  524. package/models/logged-in-users.model.js.map +0 -1
  525. package/models/method-response.model.js +0 -4
  526. package/models/method-response.model.js.map +0 -1
  527. package/models/method.model.d.ts +0 -26
  528. package/models/method.model.js +0 -4
  529. package/models/method.model.js.map +0 -1
  530. package/models/monitor-cpu.model.js +0 -4
  531. package/models/monitor-cpu.model.js.map +0 -1
  532. package/models/monitor-function.model.d.ts +0 -14
  533. package/models/monitor-function.model.js +0 -4
  534. package/models/monitor-function.model.js.map +0 -1
  535. package/models/monitor-memory.model.d.ts +0 -15
  536. package/models/monitor-memory.model.js +0 -4
  537. package/models/monitor-memory.model.js.map +0 -1
  538. package/models/monitor-mongo.model.d.ts +0 -13
  539. package/models/monitor-mongo.model.js +0 -4
  540. package/models/monitor-mongo.model.js.map +0 -1
  541. package/models/notification.model.js +0 -4
  542. package/models/notification.model.js.map +0 -1
  543. package/models/openai-usage-ledger.model.d.ts +0 -15
  544. package/models/openai-usage-ledger.model.js +0 -4
  545. package/models/openai-usage-ledger.model.js.map +0 -1
  546. package/models/pagination.model.d.ts +0 -11
  547. package/models/pagination.model.js +0 -28
  548. package/models/pagination.model.js.map +0 -1
  549. package/models/permission.model.d.ts +0 -12
  550. package/models/permission.model.js +0 -4
  551. package/models/permission.model.js.map +0 -1
  552. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  553. package/models/report-builder-dashboard-builder.model.js +0 -4
  554. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  555. package/models/report-builder-library.model.d.ts +0 -17
  556. package/models/report-builder-library.model.js +0 -4
  557. package/models/report-builder-library.model.js.map +0 -1
  558. package/models/report-builder-report.model.d.ts +0 -121
  559. package/models/report-builder-report.model.js +0 -4
  560. package/models/report-builder-report.model.js.map +0 -1
  561. package/models/report-builder.model.d.ts +0 -61
  562. package/models/report-builder.model.js +0 -4
  563. package/models/report-builder.model.js.map +0 -1
  564. package/models/select-data-label.model.d.ts +0 -9
  565. package/models/select-data-label.model.js +0 -4
  566. package/models/select-data-label.model.js.map +0 -1
  567. package/models/server-message.model.d.ts +0 -32
  568. package/models/server-message.model.js +0 -4
  569. package/models/server-message.model.js.map +0 -1
  570. package/models/slow-query-report.model.d.ts +0 -23
  571. package/models/slow-query-report.model.js +0 -4
  572. package/models/slow-query-report.model.js.map +0 -1
  573. package/models/subscription.model.d.ts +0 -31
  574. package/models/subscription.model.js +0 -4
  575. package/models/subscription.model.js.map +0 -1
  576. package/models/support-ticket.model.d.ts +0 -87
  577. package/models/support-ticket.model.js +0 -4
  578. package/models/support-ticket.model.js.map +0 -1
  579. package/models/user-group.model.d.ts +0 -20
  580. package/models/user-group.model.js +0 -4
  581. package/models/user-group.model.js.map +0 -1
  582. package/models/user-guide.model.js +0 -4
  583. package/models/user-guide.model.js.map +0 -1
  584. package/models/user.model.d.ts +0 -84
  585. package/models/user.model.js +0 -4
  586. package/models/user.model.js.map +0 -1
  587. package/private/images/ResolveIO.png +0 -0
  588. package/public_api.js +0 -118
  589. package/public_api.js.map +0 -1
  590. package/publications/ai-terminal.d.ts +0 -1
  591. package/publications/ai-terminal.js +0 -122
  592. package/publications/ai-terminal.js.map +0 -1
  593. package/publications/app-settings.d.ts +0 -2
  594. package/publications/app-settings.js +0 -28
  595. package/publications/app-settings.js.map +0 -1
  596. package/publications/app-status.d.ts +0 -2
  597. package/publications/app-status.js +0 -16
  598. package/publications/app-status.js.map +0 -1
  599. package/publications/cron-jobs.d.ts +0 -2
  600. package/publications/cron-jobs.js +0 -88
  601. package/publications/cron-jobs.js.map +0 -1
  602. package/publications/customer-notifications.d.ts +0 -2
  603. package/publications/customer-notifications.js +0 -161
  604. package/publications/customer-notifications.js.map +0 -1
  605. package/publications/files.d.ts +0 -2
  606. package/publications/files.js +0 -36
  607. package/publications/files.js.map +0 -1
  608. package/publications/flags-update.d.ts +0 -2
  609. package/publications/flags-update.js +0 -22
  610. package/publications/flags-update.js.map +0 -1
  611. package/publications/flags.d.ts +0 -2
  612. package/publications/flags.js +0 -22
  613. package/publications/flags.js.map +0 -1
  614. package/publications/logs.d.ts +0 -2
  615. package/publications/logs.js +0 -164
  616. package/publications/logs.js.map +0 -1
  617. package/publications/notifications.d.ts +0 -2
  618. package/publications/notifications.js +0 -16
  619. package/publications/notifications.js.map +0 -1
  620. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  621. package/publications/report-builder-dashboard-builders.js +0 -42
  622. package/publications/report-builder-dashboard-builders.js.map +0 -1
  623. package/publications/report-builder-libraries.d.ts +0 -2
  624. package/publications/report-builder-libraries.js +0 -90
  625. package/publications/report-builder-libraries.js.map +0 -1
  626. package/publications/report-builder-reports.d.ts +0 -2
  627. package/publications/report-builder-reports.js +0 -50
  628. package/publications/report-builder-reports.js.map +0 -1
  629. package/publications/super-admin.d.ts +0 -2
  630. package/publications/super-admin.js +0 -16
  631. package/publications/super-admin.js.map +0 -1
  632. package/publications/user-groups.d.ts +0 -1
  633. package/publications/user-groups.js +0 -16
  634. package/publications/user-groups.js.map +0 -1
  635. package/publications/user-guides.d.ts +0 -1
  636. package/publications/user-guides.js +0 -16
  637. package/publications/user-guides.js.map +0 -1
  638. package/resolveio-server-app.d.ts +0 -70
  639. package/resolveio-server-app.js +0 -801
  640. package/resolveio-server-app.js.map +0 -1
  641. package/server-app.d.ts +0 -228
  642. package/server-app.js +0 -3566
  643. package/server-app.js.map +0 -1
  644. package/services/codex-client.d.ts +0 -128
  645. package/services/codex-client.js +0 -1629
  646. package/services/codex-client.js.map +0 -1
  647. package/services/openai-client.d.ts +0 -46
  648. package/services/openai-client.js +0 -318
  649. package/services/openai-client.js.map +0 -1
  650. package/types/error-report.d.ts +0 -25
  651. package/types/error-report.js +0 -4
  652. package/types/error-report.js.map +0 -1
  653. package/types/slow-query-report.d.ts +0 -27
  654. package/types/slow-query-report.js +0 -6
  655. package/types/slow-query-report.js.map +0 -1
  656. package/util/ai-qa-policy.d.ts +0 -124
  657. package/util/ai-qa-policy.js +0 -736
  658. package/util/ai-qa-policy.js.map +0 -1
  659. package/util/ai-runner-artifacts.d.ts +0 -82
  660. package/util/ai-runner-artifacts.js +0 -713
  661. package/util/ai-runner-artifacts.js.map +0 -1
  662. package/util/ai-runner-qa-auth.d.ts +0 -5
  663. package/util/ai-runner-qa-auth.js +0 -822
  664. package/util/ai-runner-qa-auth.js.map +0 -1
  665. package/util/ai-runner-qa-tools.d.ts +0 -25
  666. package/util/ai-runner-qa-tools.js +0 -2910
  667. package/util/ai-runner-qa-tools.js.map +0 -1
  668. package/util/aicoder-runner-v6.d.ts +0 -168
  669. package/util/aicoder-runner-v6.js +0 -347
  670. package/util/aicoder-runner-v6.js.map +0 -1
  671. package/util/common.d.ts +0 -31
  672. package/util/common.js +0 -683
  673. package/util/common.js.map +0 -1
  674. package/util/customer-portal-password.d.ts +0 -13
  675. package/util/customer-portal-password.js +0 -209
  676. package/util/customer-portal-password.js.map +0 -1
  677. package/util/error-reporter.d.ts +0 -52
  678. package/util/error-reporter.js +0 -326
  679. package/util/error-reporter.js.map +0 -1
  680. package/util/error-tracking.d.ts +0 -13
  681. package/util/error-tracking.js +0 -120
  682. package/util/error-tracking.js.map +0 -1
  683. package/util/report-builder-unwinds.d.ts +0 -15
  684. package/util/report-builder-unwinds.js +0 -156
  685. package/util/report-builder-unwinds.js.map +0 -1
  686. package/util/runner-process-janitor.d.ts +0 -27
  687. package/util/runner-process-janitor.js +0 -208
  688. package/util/runner-process-janitor.js.map +0 -1
  689. package/util/schema-report-builder.d.ts +0 -6
  690. package/util/schema-report-builder.js +0 -481
  691. package/util/schema-report-builder.js.map +0 -1
  692. package/util/slow-query-reporter.d.ts +0 -28
  693. package/util/slow-query-reporter.js +0 -226
  694. package/util/slow-query-reporter.js.map +0 -1
  695. package/util/subscription-dependency-context.d.ts +0 -34
  696. package/util/subscription-dependency-context.js +0 -1283
  697. package/util/subscription-dependency-context.js.map +0 -1
  698. package/util/support-runner-v5.d.ts +0 -250
  699. package/util/support-runner-v5.js +0 -634
  700. package/util/support-runner-v5.js.map +0 -1
  701. package/util/tokenizer.d.ts +0 -5
  702. package/util/tokenizer.js +0 -41
  703. package/util/tokenizer.js.map +0 -1
  704. package/workers/codex-runner.worker.d.ts +0 -1
  705. package/workers/codex-runner.worker.js +0 -192
  706. package/workers/codex-runner.worker.js.map +0 -1
  707. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  708. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  709. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  710. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  711. /package/{private → src/private}/email-templates/support-ticket.html +0 -0
@@ -0,0 +1,127 @@
1
+ import { ResolveIOMainServer } from '../src/server-app';
2
+
3
+ function assert(condition: boolean, message: string) {
4
+ if (!condition) {
5
+ throw new Error(message);
6
+ }
7
+ }
8
+
9
+ const ENV_KEYS = [
10
+ 'WORKER_INDEX',
11
+ 'NODE_APP_INSTANCE',
12
+ 'SERVER_MANAGER_WORKER_INDEX',
13
+ 'SERVER_MANAGER_WORKER_INSTANCE',
14
+ 'SERVER_MANAGER_NODE_APP_INSTANCE'
15
+ ];
16
+
17
+ function withEnv(env: Record<string, string | undefined>, test: () => void) {
18
+ const previous: Record<string, string | undefined> = {};
19
+ for (const key of ENV_KEYS) {
20
+ previous[key] = process.env[key];
21
+ delete process.env[key];
22
+ }
23
+
24
+ for (const [key, value] of Object.entries(env)) {
25
+ if (value !== undefined) {
26
+ process.env[key] = value;
27
+ }
28
+ }
29
+
30
+ try {
31
+ test();
32
+ }
33
+ finally {
34
+ for (const key of ENV_KEYS) {
35
+ delete process.env[key];
36
+ if (previous[key] !== undefined) {
37
+ process.env[key] = previous[key];
38
+ }
39
+ }
40
+ }
41
+ }
42
+
43
+ function shouldStartCron(): boolean {
44
+ const server = new ResolveIOMainServer() as any;
45
+ return server.shouldStartCronManagerForWorker();
46
+ }
47
+
48
+ async function testStandaloneNodeReaperAlertsAreThrottled() {
49
+ const server = new ResolveIOMainServer() as any;
50
+ const proc = {
51
+ pid: 12345,
52
+ ppid: 1,
53
+ ageSeconds: 600,
54
+ cpuPct: 99,
55
+ rssKb: 512 * 1024,
56
+ command: 'node',
57
+ args: 'node -e while(true){}'
58
+ };
59
+ const reports: any[] = [];
60
+
61
+ server._standaloneNodeReaperAlertWindowMs = 60 * 60 * 1000;
62
+ server.resolveProcessCwd = () => '/tmp/resolveio-reaper-test';
63
+ server.reportServerError = async (...args: any[]) => {
64
+ reports.push(args);
65
+ };
66
+
67
+ await server.reportStandaloneNodeReaperAction(proc, 'orphan_high_cpu_for_2_scans', 'dry-run');
68
+ await server.reportStandaloneNodeReaperAction(proc, 'orphan_high_cpu_for_2_scans', 'dry-run');
69
+ assert(reports.length === 1, 'Expected duplicate dry-run reaper alert to be throttled');
70
+
71
+ await server.reportStandaloneNodeReaperAction(proc, 'orphan_high_cpu_for_2_scans', 'terminated');
72
+ assert(reports.length === 2, 'Expected different reaper action to report independently');
73
+
74
+ const alertKey = `dry-run|${server.resolveStandaloneNodeProcessSignature(proc)}`;
75
+ server._standaloneNodeReaperAlertTimes.set(alertKey, Date.now() - server._standaloneNodeReaperAlertWindowMs - 1);
76
+ await server.reportStandaloneNodeReaperAction(proc, 'orphan_high_cpu_for_2_scans', 'dry-run');
77
+ assert(reports.length === 3, 'Expected reaper alert to report again after throttle window');
78
+ }
79
+
80
+ async function run() {
81
+ withEnv({ WORKER_INDEX: '0', NODE_APP_INSTANCE: '0' }, () => {
82
+ assert(shouldStartCron() === true, 'Expected default worker 0 to start cron');
83
+ });
84
+
85
+ withEnv({ WORKER_INDEX: '1', NODE_APP_INSTANCE: '0' }, () => {
86
+ assert(shouldStartCron() === false, 'Expected default non-zero worker to skip cron');
87
+ });
88
+
89
+ withEnv({
90
+ WORKER_INDEX: '0',
91
+ NODE_APP_INSTANCE: '0',
92
+ SERVER_MANAGER_WORKER_INDEX: '0',
93
+ SERVER_MANAGER_WORKER_INSTANCE: '1'
94
+ }, () => {
95
+ assert(shouldStartCron() === false, 'Expected publication worker to skip ResolveIO server-manager cron');
96
+ });
97
+
98
+ withEnv({
99
+ WORKER_INDEX: '0',
100
+ NODE_APP_INSTANCE: '1',
101
+ SERVER_MANAGER_WORKER_INDEX: '0',
102
+ SERVER_MANAGER_WORKER_INSTANCE: '1'
103
+ }, () => {
104
+ assert(shouldStartCron() === true, 'Expected ResolveIO server-manager worker to start cron');
105
+ });
106
+
107
+ withEnv({
108
+ WORKER_INDEX: '0',
109
+ NODE_APP_INSTANCE: '0',
110
+ SERVER_MANAGER_WORKER_INDEX: '0',
111
+ SERVER_MANAGER_WORKER_INSTANCE: '0'
112
+ }, () => {
113
+ assert(shouldStartCron() === true, 'Expected explicit default server-manager owner to preserve cron behavior');
114
+ });
115
+
116
+ await testStandaloneNodeReaperAlertsAreThrottled();
117
+ }
118
+
119
+ run()
120
+ .then(() => {
121
+ console.log('server-app-cron-owner.test.ts passed');
122
+ process.exit(0);
123
+ })
124
+ .catch(error => {
125
+ console.error(error);
126
+ process.exit(1);
127
+ });
@@ -0,0 +1,158 @@
1
+ import { ResolveIOMainServer } from '../src/server-app';
2
+
3
+ function assert(condition: boolean, message: string) {
4
+ if (!condition) {
5
+ throw new Error(message);
6
+ }
7
+ }
8
+
9
+ function sleep(ms: number) {
10
+ return new Promise(resolve => setTimeout(resolve, ms));
11
+ }
12
+
13
+ class FakeWebSocket {
14
+ public readyState = 1;
15
+ public closed = false;
16
+ public sent: any[] = [];
17
+ private _handlers = new Map<string, Function>();
18
+
19
+ on(event: string, handler: Function) {
20
+ this._handlers.set(event, handler);
21
+ return this;
22
+ }
23
+
24
+ send(data: any, cb?: (error?: Error) => void) {
25
+ this.sent.push(data);
26
+ if (cb) {
27
+ cb();
28
+ }
29
+ }
30
+
31
+ ping() {
32
+ // noop
33
+ }
34
+
35
+ close() {
36
+ this.closed = true;
37
+ }
38
+
39
+ getHandler(event: string): Function | undefined {
40
+ return this._handlers.get(event);
41
+ }
42
+ }
43
+
44
+ async function testConnectionHandlerDoesNotBlockOnLoggedInUserInsert() {
45
+ const server = new ResolveIOMainServer();
46
+ const serverAny = server as any;
47
+
48
+ let connectionHandler: ((ws: FakeWebSocket, req: any) => Promise<void>) | null = null;
49
+ let createLoggedInUserCalled = false;
50
+
51
+ let resolveCreateLoggedInUser: () => void = null;
52
+ const createLoggedInUserPromise = new Promise<void>(resolve => {
53
+ resolveCreateLoggedInUser = resolve;
54
+ });
55
+
56
+ serverAny._portHTTP = 8080;
57
+ serverAny._clientHeartbeatInitialDelayMs = 1;
58
+ serverAny._methodManager = {
59
+ getEnableDebug: () => false,
60
+ _methods: {}
61
+ };
62
+ serverAny._subscriptionManager = {
63
+ createLoggedInUser: () => {
64
+ createLoggedInUserCalled = true;
65
+ return createLoggedInUserPromise;
66
+ },
67
+ loggedInLatency: () => {},
68
+ unsubscribeAll: async () => {},
69
+ subscribe: async () => {},
70
+ unsubscribe: () => {}
71
+ };
72
+ serverAny._websocketManager = {
73
+ addWebSocket: () => {},
74
+ getWebSocket: () => null,
75
+ send: () => {}
76
+ };
77
+ serverAny._workerDispatcherManager = {
78
+ addWorker: () => {},
79
+ disconnectWorker: () => {},
80
+ sendWorkerPayload: () => {},
81
+ handleWorkerMessage: () => {}
82
+ };
83
+ serverAny._clientRoutes = [];
84
+ serverAny.publicProgram = false;
85
+ serverAny.LOGGER = 'ERROR';
86
+ serverAny.triggerClientHeartbeat = async () => {};
87
+ serverAny.unsubscribeWS = async () => {};
88
+ serverAny._serverHTTP = {
89
+ listen: (_port: number, _host: string, cb: () => void) => cb()
90
+ };
91
+ serverAny._serverWSS = {
92
+ clients: new Set(),
93
+ on: (event: string, handler: any) => {
94
+ if (event === 'connection') {
95
+ connectionHandler = handler;
96
+ }
97
+ }
98
+ };
99
+
100
+ const originalSetInterval = global.setInterval;
101
+ (global as any).setInterval = (() => 0) as any;
102
+
103
+ try {
104
+ serverAny.listen();
105
+
106
+ assert(typeof connectionHandler === 'function', 'Expected WS connection handler registration');
107
+
108
+ const ws = new FakeWebSocket();
109
+ const req = {
110
+ url: '/',
111
+ id_user: 'user-1',
112
+ user: 'Test User',
113
+ user_readonly: false,
114
+ doc_user: {
115
+ roles: {
116
+ groups: [],
117
+ super_admin: true
118
+ }
119
+ },
120
+ socket: {
121
+ remoteAddress: '127.0.0.1'
122
+ },
123
+ headers: {
124
+ origin: 'http://localhost:4200'
125
+ }
126
+ };
127
+
128
+ const connectionResult = await Promise.race([
129
+ connectionHandler(ws, req).then(() => 'resolved'),
130
+ sleep(100).then(() => 'timed_out')
131
+ ]);
132
+
133
+ assert(connectionResult === 'resolved', 'Connection handler blocked on createLoggedInUser');
134
+ await sleep(0);
135
+ assert(createLoggedInUserCalled, 'Expected createLoggedInUser to be called');
136
+ assert(typeof ws.getHandler('message') === 'function', 'Expected message handler registered immediately');
137
+
138
+ const messageHandler = ws.getHandler('message') as (message: any) => Promise<void>;
139
+ await messageHandler('ping');
140
+ assert(ws.sent.includes('pong'), 'Expected ping message to be handled immediately after connection');
141
+
142
+ resolveCreateLoggedInUser();
143
+ }
144
+ finally {
145
+ global.setInterval = originalSetInterval;
146
+ }
147
+ }
148
+
149
+ async function run() {
150
+ await testConnectionHandlerDoesNotBlockOnLoggedInUserInsert();
151
+ console.log('subscription-connect-race tests completed');
152
+ process.exit(0);
153
+ }
154
+
155
+ run().catch(error => {
156
+ console.error(error);
157
+ process.exit(1);
158
+ });
@@ -0,0 +1,324 @@
1
+ import { recordAggregateDependencies, recordDependencyResult, withDependencyTracking } from '../src/util/subscription-dependency-context';
2
+
3
+ function assert(condition: boolean, message: string) {
4
+ if (!condition) {
5
+ throw new Error(message);
6
+ }
7
+ }
8
+
9
+ async function testTracksIdsFromResults() {
10
+ const { snapshot } = await withDependencyTracking(async () => {
11
+ recordDependencyResult('primary', [
12
+ { _id: 'A' },
13
+ { _id: 'B' },
14
+ { _id: { toString: () => 'C' } }
15
+ ]);
16
+ });
17
+
18
+ const primary = snapshot.dependencies.get('primary');
19
+
20
+ assert(primary instanceof Set, 'Expected dependency set for primary collection');
21
+ assert(primary.size === 3, 'Expected three tracked ids for primary collection');
22
+ assert(primary.has('A') && primary.has('B') && primary.has('C'), 'Tracked ids missing expected values');
23
+ }
24
+
25
+ async function testFallsBackToWatchAllWithoutIds() {
26
+ const { snapshot } = await withDependencyTracking(async () => {
27
+ recordDependencyResult('no-ids', [{ foo: 'bar' }]);
28
+ });
29
+
30
+ assert(snapshot.watchAllCollections.has('no-ids'), 'Expected no-ids collection marked as watch-all');
31
+ }
32
+
33
+ async function testCollectsLookupDependencies() {
34
+ const pipeline = [
35
+ {
36
+ $lookup: {
37
+ from: 'secondary',
38
+ localField: 'id_secondary',
39
+ foreignField: '_id',
40
+ as: 'secondaryDocs'
41
+ }
42
+ }
43
+ ];
44
+
45
+ const result = [
46
+ {
47
+ _id: 'P1',
48
+ secondaryDocs: [
49
+ { _id: 'S1' },
50
+ { _id: { toHexString: () => 'S2' } }
51
+ ]
52
+ }
53
+ ];
54
+
55
+ const { snapshot } = await withDependencyTracking(async () => {
56
+ recordAggregateDependencies('primary', pipeline, result);
57
+ });
58
+
59
+ const primary = snapshot.dependencies.get('primary');
60
+ const secondary = snapshot.dependencies.get('secondary');
61
+
62
+ assert(primary?.has('P1'), 'Expected primary dependency to include P1');
63
+ assert(secondary?.has('S1'), 'Expected secondary dependency to include S1');
64
+ assert(secondary?.has('S2'), 'Expected secondary dependency to include S2');
65
+ }
66
+
67
+ async function testLookupFilterStoredWhenNoMatches() {
68
+ const pipeline = [
69
+ {
70
+ $lookup: {
71
+ from: 'secondary',
72
+ localField: 'id_secondary',
73
+ foreignField: 'id_parent',
74
+ as: 'secondaryDocs'
75
+ }
76
+ }
77
+ ];
78
+
79
+ const result = [
80
+ {
81
+ _id: 'P1',
82
+ id_secondary: ['X1', 'X2'],
83
+ secondaryDocs: []
84
+ }
85
+ ];
86
+
87
+ const { snapshot } = await withDependencyTracking(async () => {
88
+ recordAggregateDependencies('primary', pipeline, result);
89
+ });
90
+
91
+ const filters = snapshot.filters.get('secondary');
92
+
93
+ assert(filters && filters.length === 1, 'Expected one filter stored for secondary collection');
94
+ assert(filters[0].id_parent && Array.isArray(filters[0].id_parent.$in), 'Expected filter to use $in on id_parent');
95
+ assert(filters[0].id_parent.$in.includes('X1'), 'Expected filter to include X1');
96
+ assert(filters[0].id_parent.$in.includes('X2'), 'Expected filter to include X2');
97
+ assert(!snapshot.watchAllCollections.has('secondary'), 'Expected secondary collection not marked as watch-all');
98
+ }
99
+
100
+ async function testMatchFilterCapturedForPrimary() {
101
+ const pipeline = [
102
+ {
103
+ $match: {
104
+ status: 'Active',
105
+ id_customer: { $in: ['C1', 'C2'] }
106
+ }
107
+ },
108
+ {
109
+ $lookup: {
110
+ from: 'secondary',
111
+ localField: 'id_secondary',
112
+ foreignField: '_id',
113
+ as: 'secondaryDocs'
114
+ }
115
+ }
116
+ ];
117
+
118
+ const result = [
119
+ {
120
+ _id: 'P1',
121
+ status: 'Active',
122
+ id_customer: 'C1',
123
+ secondaryDocs: []
124
+ }
125
+ ];
126
+
127
+ const { snapshot } = await withDependencyTracking(async () => {
128
+ recordAggregateDependencies('primary', pipeline, result);
129
+ });
130
+
131
+ const filters = snapshot.filters.get('primary');
132
+
133
+ assert(filters && filters.length === 1, 'Expected one filter stored for primary collection');
134
+ const storedFilter = filters[0];
135
+ assert(storedFilter.status === 'Active', 'Expected status to be Active in stored filter');
136
+ assert(storedFilter.id_customer && Array.isArray(storedFilter.id_customer.$in), 'Expected id_customer filter to use $in');
137
+ assert(storedFilter.id_customer.$in.includes('C1'), 'Expected filter to include C1');
138
+ assert(storedFilter.id_customer.$in.includes('C2'), 'Expected filter to include C2');
139
+ }
140
+
141
+ async function testMatchFilterIgnoresLookupAliases() {
142
+ const pipeline = [
143
+ {
144
+ $match: {
145
+ type: 'Truck Treat'
146
+ }
147
+ },
148
+ {
149
+ $lookup: {
150
+ from: 'bols',
151
+ localField: 'id_bol',
152
+ foreignField: '_id',
153
+ as: 'bol'
154
+ }
155
+ },
156
+ {
157
+ $match: {
158
+ 'bol.status': 'Delivered',
159
+ approved: true
160
+ }
161
+ }
162
+ ];
163
+
164
+ const { snapshot } = await withDependencyTracking(async () => {
165
+ recordAggregateDependencies('production-deliveries', pipeline, []);
166
+ });
167
+
168
+ const filters = snapshot.filters.get('production-deliveries');
169
+
170
+ assert(filters && filters.length === 1, 'Expected sanitized filter stored for production-deliveries');
171
+ const storedFilter = filters[0];
172
+
173
+ const serialized = JSON.stringify(storedFilter);
174
+ assert(!serialized.includes('bol.status'), 'Expected lookup alias fields stripped from stored filter');
175
+ assert(serialized.includes('type'), 'Expected base collection field retained');
176
+ assert(serialized.includes('approved'), 'Expected base collection field retained');
177
+ }
178
+
179
+ async function testFindQueryMetadataCaptured() {
180
+ const { snapshot } = await withDependencyTracking(async () => {
181
+ recordDependencyResult('primary', [{ _id: 'P1' }], {
182
+ filter: { status: 'Active' },
183
+ meta: {
184
+ limit: 25,
185
+ skip: 0,
186
+ sort: { createdAt: -1 }
187
+ }
188
+ });
189
+ });
190
+
191
+ const meta = snapshot.queryMetadata.get('primary');
192
+
193
+ assert(meta && meta.length === 1, 'Expected query metadata stored for primary collection');
194
+ assert(meta[0].limit === 25, 'Expected limit metadata to equal 25');
195
+ assert(meta[0].sort && meta[0].sort.createdAt === -1, 'Expected sort metadata captured');
196
+ }
197
+
198
+ async function testAggregateMetadataCaptured() {
199
+ const pipeline = [
200
+ {$match: { status: 'Active' }},
201
+ {$sort: { createdAt: -1 }},
202
+ {$skip: 10},
203
+ {$limit: 5}
204
+ ];
205
+
206
+ const { snapshot } = await withDependencyTracking(async () => {
207
+ recordAggregateDependencies('primary', pipeline, []);
208
+ });
209
+
210
+ const meta = snapshot.queryMetadata.get('primary');
211
+
212
+ assert(meta && meta.length === 1, 'Expected aggregate metadata stored for primary collection');
213
+ assert(meta[0].limit === 5, 'Expected aggregate limit metadata to equal 5');
214
+ assert(meta[0].skip === 10, 'Expected aggregate skip metadata to equal 10');
215
+ assert(meta[0].sort && meta[0].sort.createdAt === -1, 'Expected aggregate sort metadata captured');
216
+ }
217
+
218
+ async function testLookupPipelineFiltersCaptured() {
219
+ const pipeline = [
220
+ {
221
+ $lookup: {
222
+ from: 'orders',
223
+ let: { customerId: '$customer.id' },
224
+ pipeline: [
225
+ {
226
+ $match: {
227
+ $expr: {
228
+ $eq: ['$id_customer', '$$customerId']
229
+ }
230
+ }
231
+ }
232
+ ],
233
+ as: 'orders'
234
+ }
235
+ }
236
+ ];
237
+
238
+ const result = [
239
+ {
240
+ _id: 'cust-1',
241
+ customer: {
242
+ id: 'CUST-A'
243
+ },
244
+ orders: []
245
+ }
246
+ ];
247
+
248
+ const { snapshot } = await withDependencyTracking(async () => {
249
+ recordAggregateDependencies('customers', pipeline, result);
250
+ });
251
+
252
+ const filters = snapshot.filters.get('orders');
253
+
254
+ assert(filters && filters.length === 1, 'Expected one filter stored for orders lookup pipeline');
255
+ assert(filters[0].$expr && filters[0].$expr.$eq, 'Expected pipeline filter to contain $expr equality');
256
+ assert(filters[0].$expr.$eq[1] === 'CUST-A', 'Expected lookup pipeline filter to include substituted customer id');
257
+ assert(!snapshot.watchAllCollections.has('orders'), 'Expected orders collection not marked as watch-all for pipeline lookup');
258
+ }
259
+
260
+ async function testGroupPipelineMarksWatchAll() {
261
+ const pipeline = [
262
+ {$match: {status: 'Active'}},
263
+ {
264
+ $group: {
265
+ _id: '$type',
266
+ count: {$sum: 1}
267
+ }
268
+ }
269
+ ];
270
+
271
+ const { snapshot } = await withDependencyTracking(async () => {
272
+ recordAggregateDependencies('orders', pipeline, [{_id: 'Truck', count: 3}]);
273
+ });
274
+
275
+ assert(snapshot.watchAllCollections.has('orders'), 'Expected grouped aggregate to mark orders as watch-all');
276
+ }
277
+
278
+ async function testLookupPipelineWithoutResolvableFiltersMarksWatchAll() {
279
+ const pipeline = [
280
+ {
281
+ $lookup: {
282
+ from: 'orders',
283
+ pipeline: [
284
+ {$sort: {createdAt: -1}},
285
+ {$limit: 5}
286
+ ],
287
+ as: 'orders'
288
+ }
289
+ },
290
+ {
291
+ $project: {
292
+ orders: 0
293
+ }
294
+ }
295
+ ];
296
+
297
+ const { snapshot } = await withDependencyTracking(async () => {
298
+ recordAggregateDependencies('customers', pipeline, [{_id: 'cust-1'}]);
299
+ });
300
+
301
+ assert(snapshot.watchAllCollections.has('orders'), 'Expected lookup collection orders marked as watch-all when alias results are unavailable');
302
+ }
303
+
304
+ async function run() {
305
+ await testTracksIdsFromResults();
306
+ await testFallsBackToWatchAllWithoutIds();
307
+ await testCollectsLookupDependencies();
308
+ await testLookupFilterStoredWhenNoMatches();
309
+ await testMatchFilterCapturedForPrimary();
310
+ await testMatchFilterIgnoresLookupAliases();
311
+ await testFindQueryMetadataCaptured();
312
+ await testAggregateMetadataCaptured();
313
+ await testLookupPipelineFiltersCaptured();
314
+ await testGroupPipelineMarksWatchAll();
315
+ await testLookupPipelineWithoutResolvableFiltersMarksWatchAll();
316
+
317
+ console.log('subscription dependency tests passed');
318
+ }
319
+
320
+ run().catch(err => {
321
+ console.error('subscription dependency tests failed');
322
+ console.error(err);
323
+ process.exit(1);
324
+ });
@@ -0,0 +1,86 @@
1
+ import { SubscriptionManager } from '../src/managers/subscription.manager';
2
+ import { ActiveSubscriptionModel } from '../src/models/subscription.model';
3
+
4
+ function assert(condition: boolean, message: string) {
5
+ if (!condition) {
6
+ throw new Error(message);
7
+ }
8
+ }
9
+
10
+ function createBaseSubscription(): ActiveSubscriptionModel {
11
+ return {
12
+ publication: 'productionlocationDetailsWithId',
13
+ subscriptionKey: '[]',
14
+ subscriptionData: [],
15
+ collections: ['production-locations'],
16
+ clients: [],
17
+ cacheId: 0,
18
+ running: false,
19
+ runAgain: false,
20
+ collectionDependencies: new Map(),
21
+ collectionFilters: new Map(),
22
+ watchAllCollections: new Set(),
23
+ collectionQueryMeta: new Map()
24
+ };
25
+ }
26
+
27
+ async function testTracksRuntimeDependencies() {
28
+ const manager = new SubscriptionManager() as any;
29
+ const sub = createBaseSubscription();
30
+ manager.ensureDependencyContainers(sub);
31
+
32
+ sub.collectionDependencies.set('truck-treating-deliveries', new Set(['TT1']));
33
+
34
+ assert(
35
+ manager.subscriptionReferencesCollection(sub, 'truck-treating-deliveries'),
36
+ 'Expected dynamic dependency ids to mark collection as tracked'
37
+ );
38
+ }
39
+
40
+ async function testTracksFiltersAndWatchAll() {
41
+ const manager = new SubscriptionManager() as any;
42
+ const sub = createBaseSubscription();
43
+ manager.ensureDependencyContainers(sub);
44
+
45
+ sub.collectionFilters.set('truck-treating-deliveries', [{status: 'Scheduled'}]);
46
+
47
+ assert(
48
+ manager.subscriptionReferencesCollection(sub, 'truck-treating-deliveries'),
49
+ 'Expected dependency filters to mark collection as tracked'
50
+ );
51
+
52
+ sub.collectionFilters.clear();
53
+ sub.watchAllCollections.add('truck-treating-deliveries');
54
+
55
+ assert(
56
+ manager.subscriptionReferencesCollection(sub, 'truck-treating-deliveries'),
57
+ 'Expected watch-all collections to be considered tracked'
58
+ );
59
+ }
60
+
61
+ async function testNonTrackedCollection() {
62
+ const manager = new SubscriptionManager() as any;
63
+ const sub = createBaseSubscription();
64
+ manager.ensureDependencyContainers(sub);
65
+
66
+ assert(
67
+ !manager.subscriptionReferencesCollection(sub, 'truck-treating-deliveries'),
68
+ 'Expected unrelated collections to remain untracked'
69
+ );
70
+ }
71
+
72
+ async function run() {
73
+ await testTracksRuntimeDependencies();
74
+ await testTracksFiltersAndWatchAll();
75
+ await testNonTrackedCollection();
76
+ }
77
+
78
+ run()
79
+ .then(() => {
80
+ console.log('subscription-manager-collection-tracking tests completed');
81
+ process.exit(0);
82
+ })
83
+ .catch(error => {
84
+ console.error(error);
85
+ process.exit(1);
86
+ });