@resolveio/server-lib 22.2.34 → 22.2.35

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (649) hide show
  1. package/ai/assistant-core-heuristics.d.ts +11 -0
  2. package/ai/assistant-core-heuristics.js +531 -0
  3. package/ai/assistant-core-heuristics.js.map +1 -0
  4. package/client-server-app.d.ts +1 -0
  5. package/client-server-app.js +68 -0
  6. package/client-server-app.js.map +1 -0
  7. package/collections/ai-terminal-conversation.collection.d.ts +2 -0
  8. package/collections/ai-terminal-conversation.collection.js +140 -0
  9. package/collections/ai-terminal-conversation.collection.js.map +1 -0
  10. package/collections/ai-terminal-issue-report.collection.d.ts +2 -0
  11. package/collections/ai-terminal-issue-report.collection.js +148 -0
  12. package/collections/ai-terminal-issue-report.collection.js.map +1 -0
  13. package/collections/ai-terminal-message.collection.d.ts +2 -0
  14. package/collections/ai-terminal-message.collection.js +121 -0
  15. package/collections/ai-terminal-message.collection.js.map +1 -0
  16. package/collections/app-setting.collection.d.ts +3 -0
  17. package/collections/app-setting.collection.js +103 -0
  18. package/collections/app-setting.collection.js.map +1 -0
  19. package/collections/app-status.collection.d.ts +3 -0
  20. package/collections/app-status.collection.js +57 -0
  21. package/collections/app-status.collection.js.map +1 -0
  22. package/collections/communication-metric.collection.d.ts +2 -0
  23. package/collections/communication-metric.collection.js +133 -0
  24. package/collections/communication-metric.collection.js.map +1 -0
  25. package/collections/counter.collection.d.ts +3 -0
  26. package/collections/counter.collection.js +56 -0
  27. package/collections/counter.collection.js.map +1 -0
  28. package/collections/cron-job-history.collection.d.ts +3 -0
  29. package/collections/cron-job-history.collection.js +137 -0
  30. package/collections/cron-job-history.collection.js.map +1 -0
  31. package/collections/cron-job.collection.d.ts +3 -0
  32. package/collections/cron-job.collection.js +92 -0
  33. package/collections/cron-job.collection.js.map +1 -0
  34. package/collections/customer-notification.collection.d.ts +3 -0
  35. package/collections/customer-notification.collection.js +130 -0
  36. package/collections/customer-notification.collection.js.map +1 -0
  37. package/collections/customer-portal-password.collection.d.ts +3 -0
  38. package/collections/customer-portal-password.collection.js +75 -0
  39. package/collections/customer-portal-password.collection.js.map +1 -0
  40. package/collections/email-history.collection.d.ts +3 -0
  41. package/collections/email-history.collection.js +121 -0
  42. package/collections/email-history.collection.js.map +1 -0
  43. package/collections/email-verified.collection.d.ts +3 -0
  44. package/collections/email-verified.collection.js +61 -0
  45. package/collections/email-verified.collection.js.map +1 -0
  46. package/collections/file.collection.d.ts +3 -0
  47. package/collections/file.collection.js +74 -0
  48. package/collections/file.collection.js.map +1 -0
  49. package/collections/flag-update.collection.d.ts +3 -0
  50. package/collections/flag-update.collection.js +57 -0
  51. package/collections/flag-update.collection.js.map +1 -0
  52. package/collections/flag.collection.d.ts +3 -0
  53. package/collections/flag.collection.js +57 -0
  54. package/collections/flag.collection.js.map +1 -0
  55. package/collections/log-method-latency.collection.d.ts +3 -0
  56. package/collections/log-method-latency.collection.js +77 -0
  57. package/collections/log-method-latency.collection.js.map +1 -0
  58. package/collections/log-subscription.collection.d.ts +3 -0
  59. package/collections/log-subscription.collection.js +80 -0
  60. package/collections/log-subscription.collection.js.map +1 -0
  61. package/collections/log.collection.d.ts +3 -0
  62. package/collections/log.collection.js +93 -0
  63. package/collections/log.collection.js.map +1 -0
  64. package/collections/logged-in-users.collection.d.ts +3 -0
  65. package/collections/logged-in-users.collection.js +67 -0
  66. package/collections/logged-in-users.collection.js.map +1 -0
  67. package/collections/monitor-cpu.collection.d.ts +3 -0
  68. package/collections/monitor-cpu.collection.js +65 -0
  69. package/collections/monitor-cpu.collection.js.map +1 -0
  70. package/collections/monitor-function.collection.d.ts +3 -0
  71. package/collections/monitor-function.collection.js +74 -0
  72. package/collections/monitor-function.collection.js.map +1 -0
  73. package/collections/monitor-memory.collection.d.ts +3 -0
  74. package/collections/monitor-memory.collection.js +77 -0
  75. package/collections/monitor-memory.collection.js.map +1 -0
  76. package/collections/monitor-mongo.collection.d.ts +3 -0
  77. package/collections/monitor-mongo.collection.js +71 -0
  78. package/collections/monitor-mongo.collection.js.map +1 -0
  79. package/collections/notification.collection.d.ts +3 -0
  80. package/collections/notification.collection.js +57 -0
  81. package/collections/notification.collection.js.map +1 -0
  82. package/collections/openai-usage-ledger.collection.d.ts +2 -0
  83. package/collections/openai-usage-ledger.collection.js +124 -0
  84. package/collections/openai-usage-ledger.collection.js.map +1 -0
  85. package/collections/report-builder-dashboard-builder.collection.d.ts +3 -0
  86. package/collections/report-builder-dashboard-builder.collection.js +109 -0
  87. package/collections/report-builder-dashboard-builder.collection.js.map +1 -0
  88. package/collections/report-builder-library.collection.d.ts +3 -0
  89. package/collections/report-builder-library.collection.js +87 -0
  90. package/collections/report-builder-library.collection.js.map +1 -0
  91. package/collections/report-builder-report.collection.d.ts +4 -0
  92. package/collections/report-builder-report.collection.js +180 -0
  93. package/collections/report-builder-report.collection.js.map +1 -0
  94. package/collections/user-group.collection.d.ts +4 -0
  95. package/collections/user-group.collection.js +89 -0
  96. package/collections/user-group.collection.js.map +1 -0
  97. package/collections/user-guide.collection.d.ts +3 -0
  98. package/collections/user-guide.collection.js +57 -0
  99. package/collections/user-guide.collection.js.map +1 -0
  100. package/collections/user.collection.d.ts +4 -0
  101. package/collections/user.collection.js +180 -0
  102. package/collections/user.collection.js.map +1 -0
  103. package/cron/cron.d.ts +14 -0
  104. package/cron/cron.js +216 -0
  105. package/cron/cron.js.map +1 -0
  106. package/fixtures/cron-jobs.d.ts +1 -0
  107. package/fixtures/cron-jobs.js +150 -0
  108. package/fixtures/cron-jobs.js.map +1 -0
  109. package/fixtures/init.d.ts +1 -0
  110. package/fixtures/init.js +91 -0
  111. package/fixtures/init.js.map +1 -0
  112. package/http/auth.d.ts +2 -0
  113. package/http/auth.js +903 -0
  114. package/http/auth.js.map +1 -0
  115. package/http/health.d.ts +1 -0
  116. package/http/health.js +11 -0
  117. package/http/health.js.map +1 -0
  118. package/http/home.d.ts +1 -0
  119. package/http/home.js +134 -0
  120. package/http/home.js.map +1 -0
  121. package/http/slow-query-publication.d.ts +2 -0
  122. package/http/slow-query-publication.js +99 -0
  123. package/http/slow-query-publication.js.map +1 -0
  124. package/index.d.ts +1 -0
  125. package/index.js +19 -0
  126. package/index.js.map +1 -0
  127. package/managers/communication-metric.manager.d.ts +16 -0
  128. package/managers/communication-metric.manager.js +134 -0
  129. package/managers/communication-metric.manager.js.map +1 -0
  130. package/managers/cron.manager.d.ts +20 -0
  131. package/managers/cron.manager.js +534 -0
  132. package/managers/cron.manager.js.map +1 -0
  133. package/managers/customer-notification-content.manager.d.ts +55 -0
  134. package/managers/customer-notification-content.manager.js +158 -0
  135. package/managers/customer-notification-content.manager.js.map +1 -0
  136. package/managers/diagnostic-manager-bootstrap.d.ts +9 -0
  137. package/managers/diagnostic-manager-bootstrap.js +260 -0
  138. package/managers/diagnostic-manager-bootstrap.js.map +1 -0
  139. package/managers/error-auto-fix.manager.d.ts +149 -0
  140. package/managers/error-auto-fix.manager.js +3064 -0
  141. package/managers/error-auto-fix.manager.js.map +1 -0
  142. package/managers/local-log.manager.d.ts +18 -0
  143. package/managers/local-log.manager.js +88 -0
  144. package/managers/local-log.manager.js.map +1 -0
  145. package/managers/method.manager.d.ts +77 -0
  146. package/managers/method.manager.js +1701 -0
  147. package/managers/method.manager.js.map +1 -0
  148. package/managers/mongo.manager.d.ts +222 -0
  149. package/managers/mongo.manager.js +4984 -0
  150. package/managers/mongo.manager.js.map +1 -0
  151. package/managers/monitor.manager.d.ts +69 -0
  152. package/managers/monitor.manager.js +534 -0
  153. package/managers/monitor.manager.js.map +1 -0
  154. package/managers/openai-usage-ledger.manager.d.ts +15 -0
  155. package/managers/openai-usage-ledger.manager.js +144 -0
  156. package/managers/openai-usage-ledger.manager.js.map +1 -0
  157. package/managers/slow-query-verifier.manager.d.ts +144 -0
  158. package/managers/slow-query-verifier.manager.js +3857 -0
  159. package/managers/slow-query-verifier.manager.js.map +1 -0
  160. package/managers/slow-query.manager.d.ts +28 -0
  161. package/managers/slow-query.manager.js +468 -0
  162. package/managers/slow-query.manager.js.map +1 -0
  163. package/managers/subscription.manager.d.ts +169 -0
  164. package/managers/subscription.manager.js +3422 -0
  165. package/managers/subscription.manager.js.map +1 -0
  166. package/managers/websocket.manager.d.ts +73 -0
  167. package/managers/websocket.manager.js +673 -0
  168. package/managers/websocket.manager.js.map +1 -0
  169. package/managers/worker-dispatcher.manager.d.ts +117 -0
  170. package/managers/worker-dispatcher.manager.js +1210 -0
  171. package/managers/worker-dispatcher.manager.js.map +1 -0
  172. package/managers/worker-server.manager.d.ts +16 -0
  173. package/managers/worker-server.manager.js +530 -0
  174. package/managers/worker-server.manager.js.map +1 -0
  175. package/methods/accounts.d.ts +2 -0
  176. package/methods/accounts.js +624 -0
  177. package/methods/accounts.js.map +1 -0
  178. package/methods/ai-terminal.d.ts +304 -0
  179. package/methods/ai-terminal.js +25096 -0
  180. package/methods/ai-terminal.js.map +1 -0
  181. package/methods/app-settings.d.ts +2 -0
  182. package/methods/app-settings.js +169 -0
  183. package/methods/app-settings.js.map +1 -0
  184. package/methods/aws.d.ts +2 -0
  185. package/methods/aws.js +874 -0
  186. package/methods/aws.js.map +1 -0
  187. package/methods/collections.d.ts +2 -0
  188. package/methods/collections.js +626 -0
  189. package/methods/collections.js.map +1 -0
  190. package/methods/counters.d.ts +2 -0
  191. package/methods/counters.js +111 -0
  192. package/methods/counters.js.map +1 -0
  193. package/methods/cron-jobs.d.ts +2 -0
  194. package/methods/cron-jobs.js +2471 -0
  195. package/methods/cron-jobs.js.map +1 -0
  196. package/methods/customer-notifications.d.ts +2 -0
  197. package/methods/customer-notifications.js +528 -0
  198. package/methods/customer-notifications.js.map +1 -0
  199. package/methods/diagnostics.d.ts +2 -0
  200. package/methods/diagnostics.js +514 -0
  201. package/methods/diagnostics.js.map +1 -0
  202. package/methods/flag-updates.d.ts +2 -0
  203. package/methods/flag-updates.js +8 -0
  204. package/methods/flag-updates.js.map +1 -0
  205. package/methods/flags.d.ts +2 -0
  206. package/methods/flags.js +8 -0
  207. package/methods/flags.js.map +1 -0
  208. package/methods/logs.d.ts +2 -0
  209. package/methods/logs.js +750 -0
  210. package/methods/logs.js.map +1 -0
  211. package/methods/mongo-explorer.d.ts +2 -0
  212. package/methods/mongo-explorer.js +1811 -0
  213. package/methods/mongo-explorer.js.map +1 -0
  214. package/methods/monitor.d.ts +2 -0
  215. package/methods/monitor.js +543 -0
  216. package/methods/monitor.js.map +1 -0
  217. package/methods/pdf.d.ts +2 -0
  218. package/methods/pdf.js +1195 -0
  219. package/methods/pdf.js.map +1 -0
  220. package/methods/publications.d.ts +1 -0
  221. package/methods/publications.js +183 -0
  222. package/methods/publications.js.map +1 -0
  223. package/methods/report-builder.d.ts +2 -0
  224. package/methods/report-builder.js +3099 -0
  225. package/methods/report-builder.js.map +1 -0
  226. package/methods/support.d.ts +2 -0
  227. package/methods/support.js +313 -0
  228. package/methods/support.js.map +1 -0
  229. package/models/ai-terminal-conversation.model.d.ts +17 -0
  230. package/models/ai-terminal-conversation.model.js +4 -0
  231. package/models/ai-terminal-conversation.model.js.map +1 -0
  232. package/models/ai-terminal-issue-report.model.d.ts +19 -0
  233. package/models/ai-terminal-issue-report.model.js +4 -0
  234. package/models/ai-terminal-issue-report.model.js.map +1 -0
  235. package/models/ai-terminal-message.model.d.ts +22 -0
  236. package/models/ai-terminal-message.model.js +4 -0
  237. package/models/ai-terminal-message.model.js.map +1 -0
  238. package/models/app-setting.model.d.ts +16 -0
  239. package/models/app-setting.model.js +4 -0
  240. package/models/app-setting.model.js.map +1 -0
  241. package/{src/models/app-status.model.ts → models/app-status.model.d.ts} +2 -3
  242. package/models/app-status.model.js +4 -0
  243. package/models/app-status.model.js.map +1 -0
  244. package/{src/models/billing-logged-in-users.model.ts → models/billing-logged-in-users.model.d.ts} +4 -5
  245. package/models/billing-logged-in-users.model.js +4 -0
  246. package/models/billing-logged-in-users.model.js.map +1 -0
  247. package/models/collection-document.model.d.ts +21 -0
  248. package/models/collection-document.model.js +4 -0
  249. package/models/collection-document.model.js.map +1 -0
  250. package/models/communication-metric.model.d.ts +20 -0
  251. package/models/communication-metric.model.js +4 -0
  252. package/models/communication-metric.model.js.map +1 -0
  253. package/{src/models/counter.model.ts → models/counter.model.d.ts} +3 -4
  254. package/models/counter.model.js +4 -0
  255. package/models/counter.model.js.map +1 -0
  256. package/models/cron-job-history.model.d.ts +15 -0
  257. package/models/cron-job-history.model.js +4 -0
  258. package/models/cron-job-history.model.js.map +1 -0
  259. package/models/cron-job.model.d.ts +14 -0
  260. package/models/cron-job.model.js +4 -0
  261. package/models/cron-job.model.js.map +1 -0
  262. package/models/customer-notification.model.d.ts +26 -0
  263. package/models/customer-notification.model.js +4 -0
  264. package/models/customer-notification.model.js.map +1 -0
  265. package/models/customer-portal-password.model.d.ts +11 -0
  266. package/models/customer-portal-password.model.js +4 -0
  267. package/models/customer-portal-password.model.js.map +1 -0
  268. package/models/dialog.model.d.ts +23 -0
  269. package/models/dialog.model.js +4 -0
  270. package/models/dialog.model.js.map +1 -0
  271. package/models/email-history.model.d.ts +30 -0
  272. package/{src/models/email-history.model.ts → models/email-history.model.js} +4 -34
  273. package/models/email-history.model.js.map +1 -0
  274. package/{src/models/email-verified.model.ts → models/email-verified.model.d.ts} +5 -6
  275. package/models/email-verified.model.js +4 -0
  276. package/models/email-verified.model.js.map +1 -0
  277. package/{src/models/file.model.ts → models/file.model.d.ts} +7 -8
  278. package/models/file.model.js +4 -0
  279. package/models/file.model.js.map +1 -0
  280. package/{src/models/flag-update.model.ts → models/flag-update.model.d.ts} +3 -4
  281. package/models/flag-update.model.js +4 -0
  282. package/models/flag-update.model.js.map +1 -0
  283. package/{src/models/flag.model.ts → models/flag.model.d.ts} +3 -4
  284. package/models/flag.model.js +4 -0
  285. package/models/flag.model.js.map +1 -0
  286. package/models/log-method-latency.model.d.ts +10 -0
  287. package/models/log-method-latency.model.js +4 -0
  288. package/models/log-method-latency.model.js.map +1 -0
  289. package/{src/models/log-subscription.model.ts → models/log-subscription.model.d.ts} +9 -11
  290. package/models/log-subscription.model.js +4 -0
  291. package/models/log-subscription.model.js.map +1 -0
  292. package/models/log.model.d.ts +17 -0
  293. package/models/log.model.js +4 -0
  294. package/models/log.model.js.map +1 -0
  295. package/{src/models/logged-in-users.model.ts → models/logged-in-users.model.d.ts} +5 -6
  296. package/models/logged-in-users.model.js +4 -0
  297. package/models/logged-in-users.model.js.map +1 -0
  298. package/{src/models/method-response.model.ts → models/method-response.model.d.ts} +6 -7
  299. package/models/method-response.model.js +4 -0
  300. package/models/method-response.model.js.map +1 -0
  301. package/models/method.model.d.ts +24 -0
  302. package/models/method.model.js +4 -0
  303. package/models/method.model.js.map +1 -0
  304. package/{src/models/monitor-cpu.model.ts → models/monitor-cpu.model.d.ts} +7 -9
  305. package/models/monitor-cpu.model.js +4 -0
  306. package/models/monitor-cpu.model.js.map +1 -0
  307. package/models/monitor-function.model.d.ts +14 -0
  308. package/models/monitor-function.model.js +4 -0
  309. package/models/monitor-function.model.js.map +1 -0
  310. package/models/monitor-memory.model.d.ts +15 -0
  311. package/models/monitor-memory.model.js +4 -0
  312. package/models/monitor-memory.model.js.map +1 -0
  313. package/models/monitor-mongo.model.d.ts +13 -0
  314. package/models/monitor-mongo.model.js +4 -0
  315. package/models/monitor-mongo.model.js.map +1 -0
  316. package/{src/models/notification.model.ts → models/notification.model.d.ts} +4 -6
  317. package/models/notification.model.js +4 -0
  318. package/models/notification.model.js.map +1 -0
  319. package/models/openai-usage-ledger.model.d.ts +15 -0
  320. package/models/openai-usage-ledger.model.js +4 -0
  321. package/models/openai-usage-ledger.model.js.map +1 -0
  322. package/models/pagination.model.d.ts +11 -0
  323. package/models/pagination.model.js +28 -0
  324. package/models/pagination.model.js.map +1 -0
  325. package/models/permission.model.d.ts +12 -0
  326. package/models/permission.model.js +4 -0
  327. package/models/permission.model.js.map +1 -0
  328. package/models/report-builder-dashboard-builder.model.d.ts +25 -0
  329. package/models/report-builder-dashboard-builder.model.js +4 -0
  330. package/models/report-builder-dashboard-builder.model.js.map +1 -0
  331. package/models/report-builder-library.model.d.ts +17 -0
  332. package/models/report-builder-library.model.js +4 -0
  333. package/models/report-builder-library.model.js.map +1 -0
  334. package/models/report-builder-report.model.d.ts +120 -0
  335. package/models/report-builder-report.model.js +4 -0
  336. package/models/report-builder-report.model.js.map +1 -0
  337. package/models/report-builder.model.d.ts +61 -0
  338. package/models/report-builder.model.js +4 -0
  339. package/models/report-builder.model.js.map +1 -0
  340. package/models/select-data-label.model.d.ts +9 -0
  341. package/models/select-data-label.model.js +4 -0
  342. package/models/select-data-label.model.js.map +1 -0
  343. package/models/server-message.model.d.ts +32 -0
  344. package/models/server-message.model.js +4 -0
  345. package/models/server-message.model.js.map +1 -0
  346. package/models/slow-query-report.model.d.ts +23 -0
  347. package/models/slow-query-report.model.js +4 -0
  348. package/models/slow-query-report.model.js.map +1 -0
  349. package/models/subscription.model.d.ts +31 -0
  350. package/models/subscription.model.js +4 -0
  351. package/models/subscription.model.js.map +1 -0
  352. package/models/support-ticket.model.d.ts +86 -0
  353. package/models/support-ticket.model.js +4 -0
  354. package/models/support-ticket.model.js.map +1 -0
  355. package/models/user-group.model.d.ts +20 -0
  356. package/models/user-group.model.js +4 -0
  357. package/models/user-group.model.js.map +1 -0
  358. package/{src/models/user-guide.model.ts → models/user-guide.model.d.ts} +4 -5
  359. package/models/user-guide.model.js +4 -0
  360. package/models/user-guide.model.js.map +1 -0
  361. package/models/user.model.d.ts +84 -0
  362. package/models/user.model.js +4 -0
  363. package/models/user.model.js.map +1 -0
  364. package/package.json +1 -1
  365. package/private/images/ResolveIO.png +0 -0
  366. package/public_api.js +107 -0
  367. package/public_api.js.map +1 -0
  368. package/publications/ai-terminal.d.ts +1 -0
  369. package/publications/ai-terminal.js +122 -0
  370. package/publications/ai-terminal.js.map +1 -0
  371. package/publications/app-settings.d.ts +2 -0
  372. package/publications/app-settings.js +28 -0
  373. package/publications/app-settings.js.map +1 -0
  374. package/publications/app-status.d.ts +2 -0
  375. package/publications/app-status.js +16 -0
  376. package/publications/app-status.js.map +1 -0
  377. package/publications/cron-jobs.d.ts +2 -0
  378. package/publications/cron-jobs.js +32 -0
  379. package/publications/cron-jobs.js.map +1 -0
  380. package/publications/customer-notifications.d.ts +2 -0
  381. package/publications/customer-notifications.js +161 -0
  382. package/publications/customer-notifications.js.map +1 -0
  383. package/publications/files.d.ts +2 -0
  384. package/publications/files.js +36 -0
  385. package/publications/files.js.map +1 -0
  386. package/publications/flags-update.d.ts +2 -0
  387. package/publications/flags-update.js +22 -0
  388. package/publications/flags-update.js.map +1 -0
  389. package/publications/flags.d.ts +2 -0
  390. package/publications/flags.js +22 -0
  391. package/publications/flags.js.map +1 -0
  392. package/publications/logs.d.ts +2 -0
  393. package/publications/logs.js +164 -0
  394. package/publications/logs.js.map +1 -0
  395. package/publications/notifications.d.ts +2 -0
  396. package/publications/notifications.js +16 -0
  397. package/publications/notifications.js.map +1 -0
  398. package/publications/report-builder-dashboard-builders.d.ts +2 -0
  399. package/publications/report-builder-dashboard-builders.js +42 -0
  400. package/publications/report-builder-dashboard-builders.js.map +1 -0
  401. package/publications/report-builder-libraries.d.ts +2 -0
  402. package/publications/report-builder-libraries.js +90 -0
  403. package/publications/report-builder-libraries.js.map +1 -0
  404. package/publications/report-builder-reports.d.ts +2 -0
  405. package/publications/report-builder-reports.js +50 -0
  406. package/publications/report-builder-reports.js.map +1 -0
  407. package/publications/super-admin.d.ts +2 -0
  408. package/publications/super-admin.js +16 -0
  409. package/publications/super-admin.js.map +1 -0
  410. package/publications/user-groups.d.ts +1 -0
  411. package/publications/user-groups.js +16 -0
  412. package/publications/user-groups.js.map +1 -0
  413. package/publications/user-guides.d.ts +1 -0
  414. package/publications/user-guides.js +16 -0
  415. package/publications/user-guides.js.map +1 -0
  416. package/resolveio-server-app.d.ts +70 -0
  417. package/resolveio-server-app.js +801 -0
  418. package/resolveio-server-app.js.map +1 -0
  419. package/server-app.d.ts +167 -0
  420. package/server-app.js +2784 -0
  421. package/server-app.js.map +1 -0
  422. package/services/codex-client.d.ts +119 -0
  423. package/services/codex-client.js +1470 -0
  424. package/services/codex-client.js.map +1 -0
  425. package/services/openai-client.d.ts +46 -0
  426. package/services/openai-client.js +318 -0
  427. package/services/openai-client.js.map +1 -0
  428. package/types/error-report.d.ts +25 -0
  429. package/types/error-report.js +4 -0
  430. package/types/error-report.js.map +1 -0
  431. package/types/slow-query-report.d.ts +27 -0
  432. package/types/slow-query-report.js +6 -0
  433. package/types/slow-query-report.js.map +1 -0
  434. package/util/common.d.ts +31 -0
  435. package/util/common.js +683 -0
  436. package/util/common.js.map +1 -0
  437. package/util/customer-portal-password.d.ts +13 -0
  438. package/util/customer-portal-password.js +209 -0
  439. package/util/customer-portal-password.js.map +1 -0
  440. package/util/error-reporter.d.ts +52 -0
  441. package/util/error-reporter.js +326 -0
  442. package/util/error-reporter.js.map +1 -0
  443. package/util/error-tracking.d.ts +13 -0
  444. package/util/error-tracking.js +120 -0
  445. package/util/error-tracking.js.map +1 -0
  446. package/util/report-builder-unwinds.d.ts +15 -0
  447. package/util/report-builder-unwinds.js +156 -0
  448. package/util/report-builder-unwinds.js.map +1 -0
  449. package/util/schema-report-builder.d.ts +6 -0
  450. package/util/schema-report-builder.js +481 -0
  451. package/util/schema-report-builder.js.map +1 -0
  452. package/util/slow-query-reporter.d.ts +28 -0
  453. package/util/slow-query-reporter.js +226 -0
  454. package/util/slow-query-reporter.js.map +1 -0
  455. package/util/subscription-dependency-context.d.ts +34 -0
  456. package/util/subscription-dependency-context.js +1283 -0
  457. package/util/subscription-dependency-context.js.map +1 -0
  458. package/util/tokenizer.d.ts +5 -0
  459. package/util/tokenizer.js +41 -0
  460. package/util/tokenizer.js.map +1 -0
  461. package/workers/codex-runner.worker.d.ts +1 -0
  462. package/workers/codex-runner.worker.js +192 -0
  463. package/workers/codex-runner.worker.js.map +1 -0
  464. package/.github/workflows/ai-assistant-nightly-eval.yml +0 -224
  465. package/.github/workflows/ai-assistant-pr-guardrails.yml +0 -60
  466. package/.nodemon.json +0 -5
  467. package/.vscode/settings.json +0 -21
  468. package/AGENTS.md +0 -179
  469. package/README.md +0 -22
  470. package/build_package.sh +0 -5
  471. package/compileDTS.pl +0 -64
  472. package/docs/ai-assistant-nightly-eval.md +0 -65
  473. package/docs/ai-assistant-preflight-checklist.md +0 -23
  474. package/docs/ai-assistant-report-builder-bridge-playbook.md +0 -115
  475. package/eslint-plugin-custom/index.js +0 -7
  476. package/eslint-plugin-custom/rules/no-filter-zero-index.js +0 -44
  477. package/eslint.config.js +0 -103
  478. package/gulpfile.js +0 -216
  479. package/methodAndPublicationListGenerator.py +0 -319
  480. package/mongodbensurers.js +0 -2
  481. package/mongostop.js +0 -3
  482. package/settings.development.json +0 -25
  483. package/settings.development.redacted.json +0 -25
  484. package/src/.env +0 -12
  485. package/src/ai/assistant-core-heuristics.ts +0 -577
  486. package/src/client-server-app.ts +0 -12
  487. package/src/collections/ai-terminal-conversation.collection.ts +0 -91
  488. package/src/collections/ai-terminal-issue-report.collection.ts +0 -99
  489. package/src/collections/ai-terminal-message.collection.ts +0 -77
  490. package/src/collections/app-setting.collection.ts +0 -104
  491. package/src/collections/app-status.collection.ts +0 -58
  492. package/src/collections/communication-metric.collection.ts +0 -84
  493. package/src/collections/counter.collection.ts +0 -56
  494. package/src/collections/cron-job-history.collection.ts +0 -94
  495. package/src/collections/cron-job.collection.ts +0 -92
  496. package/src/collections/customer-notification.collection.ts +0 -131
  497. package/src/collections/customer-portal-password.collection.ts +0 -76
  498. package/src/collections/email-history.collection.ts +0 -121
  499. package/src/collections/email-verified.collection.ts +0 -61
  500. package/src/collections/file.collection.ts +0 -74
  501. package/src/collections/flag-update.collection.ts +0 -57
  502. package/src/collections/flag.collection.ts +0 -57
  503. package/src/collections/log-method-latency.collection.ts +0 -77
  504. package/src/collections/log-subscription.collection.ts +0 -80
  505. package/src/collections/log.collection.ts +0 -93
  506. package/src/collections/logged-in-users.collection.ts +0 -67
  507. package/src/collections/monitor-cpu.collection.ts +0 -65
  508. package/src/collections/monitor-function.collection.ts +0 -74
  509. package/src/collections/monitor-memory.collection.ts +0 -77
  510. package/src/collections/monitor-mongo.collection.ts +0 -71
  511. package/src/collections/notification.collection.ts +0 -57
  512. package/src/collections/openai-usage-ledger.collection.ts +0 -77
  513. package/src/collections/report-builder-dashboard-builder.collection.ts +0 -109
  514. package/src/collections/report-builder-library.collection.ts +0 -89
  515. package/src/collections/report-builder-report.collection.ts +0 -180
  516. package/src/collections/user-group.collection.ts +0 -89
  517. package/src/collections/user-guide.collection.ts +0 -57
  518. package/src/collections/user.collection.ts +0 -181
  519. package/src/cron/cron.ts +0 -117
  520. package/src/fixtures/cron-jobs.ts +0 -95
  521. package/src/fixtures/init.ts +0 -35
  522. package/src/http/auth.ts +0 -764
  523. package/src/http/health.ts +0 -7
  524. package/src/http/home.ts +0 -90
  525. package/src/http/slow-query-publication.ts +0 -49
  526. package/src/index.ts +0 -1
  527. package/src/managers/communication-metric.manager.ts +0 -82
  528. package/src/managers/cron.manager.ts +0 -333
  529. package/src/managers/customer-notification-content.manager.ts +0 -236
  530. package/src/managers/diagnostic-manager-bootstrap.ts +0 -165
  531. package/src/managers/error-auto-fix.manager.ts +0 -2767
  532. package/src/managers/local-log.manager.ts +0 -113
  533. package/src/managers/method.manager.ts +0 -1557
  534. package/src/managers/mongo.manager.ts +0 -4566
  535. package/src/managers/monitor.manager.ts +0 -489
  536. package/src/managers/openai-usage-ledger.manager.ts +0 -116
  537. package/src/managers/slow-query-verifier.manager.ts +0 -3590
  538. package/src/managers/slow-query.manager.ts +0 -519
  539. package/src/managers/subscription.manager.ts +0 -3120
  540. package/src/managers/websocket.manager.ts +0 -746
  541. package/src/managers/worker-dispatcher.manager.ts +0 -1318
  542. package/src/managers/worker-server.manager.ts +0 -468
  543. package/src/methods/accounts.ts +0 -532
  544. package/src/methods/ai-terminal.ts +0 -25505
  545. package/src/methods/app-settings.ts +0 -114
  546. package/src/methods/aws.ts +0 -646
  547. package/src/methods/collections.ts +0 -544
  548. package/src/methods/counters.ts +0 -67
  549. package/src/methods/cron-jobs.ts +0 -2610
  550. package/src/methods/customer-notifications.ts +0 -458
  551. package/src/methods/diagnostics.ts +0 -447
  552. package/src/methods/flag-updates.ts +0 -7
  553. package/src/methods/flags.ts +0 -7
  554. package/src/methods/logs.ts +0 -656
  555. package/src/methods/mongo-explorer.ts +0 -1883
  556. package/src/methods/monitor.ts +0 -540
  557. package/src/methods/pdf.ts +0 -1210
  558. package/src/methods/publications.ts +0 -128
  559. package/src/methods/report-builder.ts +0 -3305
  560. package/src/methods/support.ts +0 -210
  561. package/src/models/ai-terminal-conversation.model.ts +0 -19
  562. package/src/models/ai-terminal-issue-report.model.ts +0 -21
  563. package/src/models/ai-terminal-message.model.ts +0 -24
  564. package/src/models/app-setting.model.ts +0 -17
  565. package/src/models/collection-document.model.ts +0 -24
  566. package/src/models/communication-metric.model.ts +0 -23
  567. package/src/models/cron-job-history.model.ts +0 -16
  568. package/src/models/cron-job.model.ts +0 -15
  569. package/src/models/customer-notification.model.ts +0 -28
  570. package/src/models/customer-portal-password.model.ts +0 -12
  571. package/src/models/dialog.model.ts +0 -25
  572. package/src/models/log-method-latency.model.ts +0 -11
  573. package/src/models/log.model.ts +0 -19
  574. package/src/models/method.model.ts +0 -23
  575. package/src/models/monitor-function.model.ts +0 -16
  576. package/src/models/monitor-memory.model.ts +0 -17
  577. package/src/models/monitor-mongo.model.ts +0 -15
  578. package/src/models/openai-usage-ledger.model.ts +0 -16
  579. package/src/models/pagination.model.ts +0 -35
  580. package/src/models/permission.model.ts +0 -14
  581. package/src/models/report-builder-dashboard-builder.model.ts +0 -29
  582. package/src/models/report-builder-library.model.ts +0 -20
  583. package/src/models/report-builder-report.model.ts +0 -135
  584. package/src/models/report-builder.model.ts +0 -68
  585. package/src/models/select-data-label.model.ts +0 -9
  586. package/src/models/server-message.model.ts +0 -31
  587. package/src/models/slow-query-report.model.ts +0 -23
  588. package/src/models/subscription.model.ts +0 -73
  589. package/src/models/support-ticket.model.ts +0 -96
  590. package/src/models/user-group.model.ts +0 -24
  591. package/src/models/user.model.ts +0 -96
  592. package/src/private/images/ResolveIO.png +0 -0
  593. package/src/publications/ai-terminal.ts +0 -73
  594. package/src/publications/app-settings.ts +0 -25
  595. package/src/publications/app-status.ts +0 -13
  596. package/src/publications/cron-jobs.ts +0 -29
  597. package/src/publications/customer-notifications.ts +0 -101
  598. package/src/publications/files.ts +0 -33
  599. package/src/publications/flags-update.ts +0 -19
  600. package/src/publications/flags.ts +0 -19
  601. package/src/publications/logs.ts +0 -163
  602. package/src/publications/notifications.ts +0 -13
  603. package/src/publications/report-builder-dashboard-builders.ts +0 -39
  604. package/src/publications/report-builder-libraries.ts +0 -41
  605. package/src/publications/report-builder-reports.ts +0 -47
  606. package/src/publications/super-admin.ts +0 -13
  607. package/src/publications/user-groups.ts +0 -12
  608. package/src/publications/user-guides.ts +0 -12
  609. package/src/resolveio-server-app.ts +0 -617
  610. package/src/server-app.ts +0 -2616
  611. package/src/services/codex-client.ts +0 -1117
  612. package/src/services/openai-client.ts +0 -265
  613. package/src/types/error-report.ts +0 -26
  614. package/src/types/js-tiktoken.d.ts +0 -11
  615. package/src/types/slow-query-report.ts +0 -28
  616. package/src/util/common.ts +0 -649
  617. package/src/util/customer-portal-password.ts +0 -183
  618. package/src/util/error-reporter.ts +0 -332
  619. package/src/util/error-tracking.ts +0 -79
  620. package/src/util/report-builder-unwinds.ts +0 -180
  621. package/src/util/schema-report-builder.ts +0 -448
  622. package/src/util/slow-query-reporter.ts +0 -216
  623. package/src/util/subscription-dependency-context.ts +0 -1096
  624. package/src/util/tokenizer.ts +0 -38
  625. package/src/workers/codex-runner.worker.ts +0 -142
  626. package/start_server.sh +0 -5
  627. package/tests/ai-assistant-corpus-build.ts +0 -484
  628. package/tests/ai-assistant-corpus-replay-e2e.ts +0 -773
  629. package/tests/ai-assistant-data-parity-e2e.ts +0 -2018
  630. package/tests/ai-assistant-eval-triage.ts +0 -831
  631. package/tests/ai-assistant-openai-e2e.ts +0 -1061
  632. package/tests/ai-assistant-openai-git-e2e.ts +0 -155
  633. package/tests/ai-assistant-preflight-matrix.ts +0 -215
  634. package/tests/ai-assistant-routing-eval.test.ts +0 -560
  635. package/tests/ai-assistant-snf-live-eval.ts +0 -921
  636. package/tests/ai-assistant-utils.test.ts +0 -2165
  637. package/tests/error-reporter.test.ts +0 -145
  638. package/tests/report-builder-linking.test.ts +0 -79
  639. package/tests/subscription-connect-race.test.ts +0 -157
  640. package/tests/subscription-dependency-context.test.ts +0 -324
  641. package/tests/subscription-manager-collection-tracking.test.ts +0 -86
  642. package/tests/subscription-manager-invalidation.test.ts +0 -85
  643. package/tsconfig.json +0 -34
  644. /package/{src/private → private}/email-templates/enrollment.html +0 -0
  645. /package/{src/private → private}/email-templates/forgot-password.html +0 -0
  646. /package/{src/private → private}/email-templates/support-ticket-deleted.html +0 -0
  647. /package/{src/private → private}/email-templates/support-ticket-modified.html +0 -0
  648. /package/{src/private → private}/email-templates/support-ticket.html +0 -0
  649. /package/{src/public_api.ts → public_api.d.ts} +0 -0
@@ -1,145 +0,0 @@
1
- import { ResolveIOServer } from '../src/resolveio-server-app';
2
- import { ErrorReporter } from '../src/util/error-reporter';
3
-
4
- function assert(condition: boolean, message: string) {
5
- if (!condition) {
6
- throw new Error(message);
7
- }
8
- }
9
-
10
- function setServerConfig(overrides: Record<string, any> = {}) {
11
- const serverAny = ResolveIOServer as unknown as Record<string, any>;
12
- serverAny._serverConfig = Object.assign({
13
- CLIENT_NAME: 'TestClient',
14
- ROOT_URL: 'https://test.resolveio.com',
15
- SERVER_URL: 'https://backend.resolveio.com'
16
- }, overrides);
17
- serverAny._client = 'test-client';
18
- }
19
-
20
- function setAutoFixManager(manager: any) {
21
- const serverAny = ResolveIOServer as unknown as Record<string, any>;
22
- serverAny.AutoFixManager = manager;
23
- }
24
-
25
- async function testSuccessfulLocalIngest() {
26
- setServerConfig();
27
- let payloadSnapshot: any = null;
28
- setAutoFixManager({
29
- isReady: () => true,
30
- ingestErrorReport: async (payload: any) => {
31
- payloadSnapshot = payload;
32
- return {status: 'queued'};
33
- }
34
- });
35
-
36
- const result = await ErrorReporter.report({
37
- sourceApp: 'unit-test',
38
- message: 'Invoice close failed',
39
- context: {foo: 'bar'}
40
- });
41
-
42
- assert(result.delivered === true, 'Expected report to be delivered');
43
- assert(result.status === 200, 'Expected local status code');
44
- assert(result.reason === 'queued', 'Expected ingest status to propagate');
45
- assert(payloadSnapshot !== null, 'Expected payload to be ingested');
46
- assert(payloadSnapshot.message === 'Invoice close failed', 'Expected message in payload');
47
- assert(payloadSnapshot.sourceApp === 'unit-test', 'Expected sourceApp in payload');
48
- assert(payloadSnapshot.context.foo === 'bar', 'Expected context payload');
49
- assert(typeof payloadSnapshot.fingerprint === 'string' && payloadSnapshot.fingerprint.length > 0, 'Expected fingerprint');
50
- assert(payloadSnapshot.reportedAt instanceof Date, 'Expected reportedAt to be a Date');
51
- }
52
-
53
- async function testManagerMissing() {
54
- setServerConfig();
55
- setAutoFixManager(null);
56
-
57
- const result = await ErrorReporter.report({
58
- sourceApp: 'unit-test',
59
- message: 'Should fail without manager'
60
- });
61
-
62
- assert(result.delivered === false, 'Expected local manager missing failure');
63
- assert(result.reason === 'local-manager-missing', 'Expected local-manager-missing reason');
64
- }
65
-
66
- async function testManagerNotReady() {
67
- setServerConfig();
68
- setAutoFixManager({
69
- isReady: () => false,
70
- ingestErrorReport: async () => ({status: 'queued'})
71
- });
72
-
73
- const result = await ErrorReporter.report({
74
- sourceApp: 'unit-test',
75
- message: 'Should fail when manager not ready'
76
- });
77
-
78
- assert(result.delivered === false, 'Expected manager not-ready failure');
79
- assert(result.reason === 'local-manager-not-ready', 'Expected local-manager-not-ready reason');
80
- }
81
-
82
- async function testManagerIngestFailure() {
83
- setServerConfig();
84
- setAutoFixManager({
85
- isReady: () => true,
86
- ingestErrorReport: async () => {
87
- throw new Error('ingest boom');
88
- }
89
- });
90
-
91
- const result = await ErrorReporter.report({
92
- sourceApp: 'unit-test',
93
- message: 'Should fail on ingest error'
94
- });
95
-
96
- assert(result.delivered === false, 'Expected local ingest failure');
97
- assert(result.reason === 'local-ingest-failed', 'Expected local-ingest-failed reason');
98
- }
99
-
100
- async function testInvalidDateSerializationDoesNotThrow() {
101
- setServerConfig();
102
- let payloadSnapshot: any = null;
103
- setAutoFixManager({
104
- isReady: () => true,
105
- ingestErrorReport: async (payload: any) => {
106
- payloadSnapshot = payload;
107
- return {status: 'queued'};
108
- }
109
- });
110
-
111
- await ErrorReporter.report({
112
- sourceApp: 'unit-test',
113
- message: 'Invalid date handling',
114
- context: {
115
- badDate: new Date('not-a-date'),
116
- okDate: new Date('2024-01-01T00:00:00.000Z')
117
- },
118
- reportedAt: new Date('not-a-date')
119
- });
120
-
121
- assert(payloadSnapshot !== null, 'Expected payload snapshot for invalid date test');
122
- assert(payloadSnapshot.context.badDate === null, 'Expected invalid date to serialize as null');
123
- assert(payloadSnapshot.context.okDate === '2024-01-01T00:00:00.000Z', 'Expected valid date to serialize normally');
124
- assert(payloadSnapshot.reportedAt instanceof Date, 'Expected fallback reportedAt as Date');
125
- }
126
-
127
- async function run() {
128
- try {
129
- await testSuccessfulLocalIngest();
130
- await testManagerMissing();
131
- await testManagerNotReady();
132
- await testManagerIngestFailure();
133
- await testInvalidDateSerializationDoesNotThrow();
134
- console.log('error reporter tests passed');
135
- }
136
- finally {
137
- setAutoFixManager(null);
138
- }
139
- }
140
-
141
- run().catch(err => {
142
- console.error('error reporter tests failed');
143
- console.error(err);
144
- process.exit(1);
145
- });
@@ -1,79 +0,0 @@
1
- import { applyLinkFieldUnwinds } from '../src/util/report-builder-unwinds';
2
-
3
- function assert(condition: boolean, message: string) {
4
- if (!condition) {
5
- throw new Error(message);
6
- }
7
- }
8
-
9
- function countUnwinds(query: any[], path: string) {
10
- return query.filter(stage => stage?.$unwind?.path === path).length;
11
- }
12
-
13
- function countLookups(query: any[], as: string) {
14
- return query.filter(stage => stage?.$lookup?.as === as).length;
15
- }
16
-
17
- function testAddsMissingUnwindsForLinkedLookupArrayField() {
18
- const query: any[] = [];
19
- const sizes: string[] = [];
20
-
21
- const lookupAsRaw = 'items.$.wo_details.$.Work-order-dynamics (Items -> Wo Details -> Wo) (Lookup)';
22
- const lookupAs = 'items.wo_details.Work-order-dynamics (Items -> Wo Details -> Wo) (Lookup)';
23
-
24
- const fieldFirst = lookupAsRaw + '.$.chemicals.$.id_chemical';
25
- const fieldSecond = 'items.$.id_chemical';
26
-
27
- const selectedFields = [
28
- {
29
- fieldPath: fieldFirst,
30
- lookup_collection: 'work-order-dynamics',
31
- lookup_local_key: 'items.wo_details.id_wo',
32
- lookup_foreign_key: '_id',
33
- lookup_as: lookupAsRaw
34
- },
35
- {
36
- fieldPath: fieldSecond,
37
- lookup_collection: '',
38
- lookup_local_key: '',
39
- lookup_foreign_key: '',
40
- lookup_as: ''
41
- }
42
- ];
43
-
44
- applyLinkFieldUnwinds({
45
- query,
46
- sizes,
47
- fieldsLink: [{field_first: fieldFirst, field_second: fieldSecond, id: 'link_1'}],
48
- selectedFields,
49
- filterArrayFields: [],
50
- groupsRow: []
51
- });
52
-
53
- assert(countLookups(query, lookupAs) === 1, 'Expected lookup stage for linked lookup field');
54
- assert(countUnwinds(query, '$items') === 1, 'Expected unwind for items');
55
- assert(countUnwinds(query, '$items.wo_details') === 1, 'Expected unwind for items.wo_details');
56
- assert(countUnwinds(query, '$' + lookupAs) === 1, 'Expected unwind for lookup results');
57
- assert(countUnwinds(query, '$' + lookupAs + '.chemicals') === 1, 'Expected unwind for lookup chemicals array');
58
-
59
- const originalLength = query.length;
60
-
61
- applyLinkFieldUnwinds({
62
- query,
63
- sizes,
64
- fieldsLink: [{field_first: fieldFirst, field_second: fieldSecond, id: 'link_1'}],
65
- selectedFields,
66
- filterArrayFields: [],
67
- groupsRow: []
68
- });
69
-
70
- assert(query.length === originalLength, 'Expected second call to be idempotent');
71
- }
72
-
73
- function run() {
74
- testAddsMissingUnwindsForLinkedLookupArrayField();
75
- console.log('report builder linking tests passed');
76
- }
77
-
78
- run();
79
-
@@ -1,157 +0,0 @@
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
- assert(createLoggedInUserCalled, 'Expected createLoggedInUser to be called');
135
- assert(typeof ws.getHandler('message') === 'function', 'Expected message handler registered immediately');
136
-
137
- const messageHandler = ws.getHandler('message') as (message: any) => Promise<void>;
138
- await messageHandler('ping');
139
- assert(ws.sent.includes('pong'), 'Expected ping message to be handled immediately after connection');
140
-
141
- resolveCreateLoggedInUser();
142
- }
143
- finally {
144
- global.setInterval = originalSetInterval;
145
- }
146
- }
147
-
148
- async function run() {
149
- await testConnectionHandlerDoesNotBlockOnLoggedInUserInsert();
150
- console.log('subscription-connect-race tests completed');
151
- process.exit(0);
152
- }
153
-
154
- run().catch(error => {
155
- console.error(error);
156
- process.exit(1);
157
- });
@@ -1,324 +0,0 @@
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
- });