@resolveio/server-lib 22.3.219 → 22.3.221

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (745) hide show
  1. package/.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 +1 -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 +131 -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 +112 -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 +29070 -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 +56 -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/src/publications/ai-terminal.ts +73 -0
  153. package/src/publications/app-settings.ts +25 -0
  154. package/src/publications/app-status.ts +13 -0
  155. package/src/publications/cron-jobs.ts +40 -0
  156. package/src/publications/customer-notifications.ts +101 -0
  157. package/src/publications/files.ts +33 -0
  158. package/src/publications/flags-update.ts +19 -0
  159. package/src/publications/flags.ts +19 -0
  160. package/src/publications/logs.ts +163 -0
  161. package/src/publications/notifications.ts +13 -0
  162. package/src/publications/report-builder-dashboard-builders.ts +39 -0
  163. package/src/publications/report-builder-libraries.ts +41 -0
  164. package/src/publications/report-builder-reports.ts +47 -0
  165. package/src/publications/super-admin.ts +13 -0
  166. package/src/publications/user-groups.ts +12 -0
  167. package/src/publications/user-guides.ts +12 -0
  168. package/src/resolveio-server-app.ts +617 -0
  169. package/src/server-app.ts +3354 -0
  170. package/src/services/codex-client.ts +1231 -0
  171. package/src/services/openai-client.ts +265 -0
  172. package/src/types/error-report.ts +26 -0
  173. package/src/types/js-tiktoken.d.ts +11 -0
  174. package/src/types/slow-query-report.ts +28 -0
  175. package/src/util/ai-qa-policy.ts +925 -0
  176. package/src/util/ai-run-evidence-adapters.ts +8347 -0
  177. package/src/util/ai-run-evidence-dashboard.ts +323 -0
  178. package/src/util/ai-run-evidence-eval.ts +1057 -0
  179. package/src/util/ai-run-evidence.ts +1430 -0
  180. package/src/util/ai-runner-artifacts.ts +586 -0
  181. package/src/util/ai-runner-manager-autopilot.ts +961 -0
  182. package/src/util/ai-runner-manager-policy.ts +5011 -0
  183. package/src/util/ai-runner-qa-auth.ts +838 -0
  184. package/src/util/ai-runner-qa-tools.ts +3536 -0
  185. package/src/util/aicoder-runner-v6.ts +3121 -0
  186. package/src/util/common.ts +649 -0
  187. package/src/util/customer-portal-password.ts +183 -0
  188. package/src/util/error-reporter.ts +332 -0
  189. package/src/util/error-tracking.ts +79 -0
  190. package/src/util/openai-usage-cost.ts +114 -0
  191. package/src/util/report-builder-unwinds.ts +180 -0
  192. package/src/util/runner-process-janitor.ts +219 -0
  193. package/src/util/schema-report-builder.ts +448 -0
  194. package/src/util/slow-query-reporter.ts +216 -0
  195. package/src/util/subscription-dependency-context.ts +1096 -0
  196. package/src/util/support-runner-v5.ts +10040 -0
  197. package/src/util/tokenizer.ts +38 -0
  198. package/src/workers/codex-runner.worker.ts +142 -0
  199. package/start_server.sh +5 -0
  200. package/tests/ai-assistant-corpus-build.ts +484 -0
  201. package/tests/ai-assistant-corpus-replay-e2e.ts +774 -0
  202. package/tests/ai-assistant-data-parity-e2e.ts +1989 -0
  203. package/tests/ai-assistant-eval-triage.ts +831 -0
  204. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  205. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  206. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  207. package/tests/ai-assistant-routing-eval.test.ts +585 -0
  208. package/tests/ai-assistant-snf-live-eval.ts +975 -0
  209. package/tests/ai-assistant-utils.test.ts +4834 -0
  210. package/tests/ai-manager-autopilot-snapshot.test.ts +193 -0
  211. package/tests/ai-manager-recovery-checkpoint.test.ts +1383 -0
  212. package/tests/ai-run-eval.test.ts +132 -0
  213. package/tests/ai-run-evidence.test.ts +3773 -0
  214. package/tests/ai-runner-contract.test.ts +515 -0
  215. package/tests/aicoder-runner-v6.test.ts +822 -0
  216. package/tests/error-reporter.test.ts +145 -0
  217. package/tests/method-publication-generator.test.ts +46 -0
  218. package/tests/report-builder-linking.test.ts +79 -0
  219. package/tests/resolveio-platform-intelligence.test.ts +352 -0
  220. package/tests/server-app-cron-owner.test.ts +127 -0
  221. package/tests/subscription-connect-race.test.ts +158 -0
  222. package/tests/subscription-dependency-context.test.ts +324 -0
  223. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  224. package/tests/subscription-manager-invalidation.test.ts +86 -0
  225. package/tests/support-runner-v5.test.ts +3201 -0
  226. package/tsconfig.json +34 -0
  227. package/ai/assistant-core-heuristics.d.ts +0 -11
  228. package/ai/assistant-core-heuristics.js +0 -356
  229. package/ai/assistant-core-heuristics.js.map +0 -1
  230. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +0 -3
  231. package/ai/resolveio-platform-intelligence-memory-corpus.js +0 -214
  232. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +0 -1
  233. package/ai/resolveio-platform-intelligence-memory.d.ts +0 -20
  234. package/ai/resolveio-platform-intelligence-memory.js +0 -341
  235. package/ai/resolveio-platform-intelligence-memory.js.map +0 -1
  236. package/ai/resolveio-platform-intelligence-types.js +0 -4
  237. package/ai/resolveio-platform-intelligence-types.js.map +0 -1
  238. package/ai/resolveio-platform-intelligence.d.ts +0 -6
  239. package/ai/resolveio-platform-intelligence.js +0 -463
  240. package/ai/resolveio-platform-intelligence.js.map +0 -1
  241. package/client-server-app.d.ts +0 -1
  242. package/client-server-app.js +0 -68
  243. package/client-server-app.js.map +0 -1
  244. package/collections/ai-run.collection.d.ts +0 -3
  245. package/collections/ai-run.collection.js +0 -170
  246. package/collections/ai-run.collection.js.map +0 -1
  247. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  248. package/collections/ai-terminal-conversation.collection.js +0 -140
  249. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  250. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  251. package/collections/ai-terminal-issue-report.collection.js +0 -148
  252. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  253. package/collections/ai-terminal-message.collection.d.ts +0 -2
  254. package/collections/ai-terminal-message.collection.js +0 -121
  255. package/collections/ai-terminal-message.collection.js.map +0 -1
  256. package/collections/app-setting.collection.d.ts +0 -3
  257. package/collections/app-setting.collection.js +0 -103
  258. package/collections/app-setting.collection.js.map +0 -1
  259. package/collections/app-status.collection.d.ts +0 -3
  260. package/collections/app-status.collection.js +0 -57
  261. package/collections/app-status.collection.js.map +0 -1
  262. package/collections/communication-metric.collection.d.ts +0 -2
  263. package/collections/communication-metric.collection.js +0 -133
  264. package/collections/communication-metric.collection.js.map +0 -1
  265. package/collections/counter.collection.d.ts +0 -3
  266. package/collections/counter.collection.js +0 -56
  267. package/collections/counter.collection.js.map +0 -1
  268. package/collections/cron-job-history.collection.d.ts +0 -3
  269. package/collections/cron-job-history.collection.js +0 -137
  270. package/collections/cron-job-history.collection.js.map +0 -1
  271. package/collections/cron-job.collection.d.ts +0 -3
  272. package/collections/cron-job.collection.js +0 -92
  273. package/collections/cron-job.collection.js.map +0 -1
  274. package/collections/customer-notification.collection.d.ts +0 -3
  275. package/collections/customer-notification.collection.js +0 -130
  276. package/collections/customer-notification.collection.js.map +0 -1
  277. package/collections/customer-portal-password.collection.d.ts +0 -3
  278. package/collections/customer-portal-password.collection.js +0 -75
  279. package/collections/customer-portal-password.collection.js.map +0 -1
  280. package/collections/email-history.collection.d.ts +0 -3
  281. package/collections/email-history.collection.js +0 -134
  282. package/collections/email-history.collection.js.map +0 -1
  283. package/collections/email-verified.collection.d.ts +0 -3
  284. package/collections/email-verified.collection.js +0 -62
  285. package/collections/email-verified.collection.js.map +0 -1
  286. package/collections/file.collection.d.ts +0 -3
  287. package/collections/file.collection.js +0 -74
  288. package/collections/file.collection.js.map +0 -1
  289. package/collections/flag-update.collection.d.ts +0 -3
  290. package/collections/flag-update.collection.js +0 -57
  291. package/collections/flag-update.collection.js.map +0 -1
  292. package/collections/flag.collection.d.ts +0 -3
  293. package/collections/flag.collection.js +0 -57
  294. package/collections/flag.collection.js.map +0 -1
  295. package/collections/log-method-latency.collection.d.ts +0 -3
  296. package/collections/log-method-latency.collection.js +0 -77
  297. package/collections/log-method-latency.collection.js.map +0 -1
  298. package/collections/log-subscription.collection.d.ts +0 -3
  299. package/collections/log-subscription.collection.js +0 -80
  300. package/collections/log-subscription.collection.js.map +0 -1
  301. package/collections/log.collection.d.ts +0 -3
  302. package/collections/log.collection.js +0 -93
  303. package/collections/log.collection.js.map +0 -1
  304. package/collections/logged-in-users.collection.d.ts +0 -3
  305. package/collections/logged-in-users.collection.js +0 -67
  306. package/collections/logged-in-users.collection.js.map +0 -1
  307. package/collections/monitor-cpu.collection.d.ts +0 -3
  308. package/collections/monitor-cpu.collection.js +0 -65
  309. package/collections/monitor-cpu.collection.js.map +0 -1
  310. package/collections/monitor-function.collection.d.ts +0 -3
  311. package/collections/monitor-function.collection.js +0 -74
  312. package/collections/monitor-function.collection.js.map +0 -1
  313. package/collections/monitor-memory.collection.d.ts +0 -3
  314. package/collections/monitor-memory.collection.js +0 -77
  315. package/collections/monitor-memory.collection.js.map +0 -1
  316. package/collections/monitor-mongo.collection.d.ts +0 -3
  317. package/collections/monitor-mongo.collection.js +0 -71
  318. package/collections/monitor-mongo.collection.js.map +0 -1
  319. package/collections/notification.collection.d.ts +0 -3
  320. package/collections/notification.collection.js +0 -57
  321. package/collections/notification.collection.js.map +0 -1
  322. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  323. package/collections/openai-usage-ledger.collection.js +0 -188
  324. package/collections/openai-usage-ledger.collection.js.map +0 -1
  325. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  326. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  327. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  328. package/collections/report-builder-library.collection.d.ts +0 -3
  329. package/collections/report-builder-library.collection.js +0 -87
  330. package/collections/report-builder-library.collection.js.map +0 -1
  331. package/collections/report-builder-report.collection.d.ts +0 -4
  332. package/collections/report-builder-report.collection.js +0 -184
  333. package/collections/report-builder-report.collection.js.map +0 -1
  334. package/collections/user-group.collection.d.ts +0 -4
  335. package/collections/user-group.collection.js +0 -89
  336. package/collections/user-group.collection.js.map +0 -1
  337. package/collections/user-guide.collection.d.ts +0 -3
  338. package/collections/user-guide.collection.js +0 -57
  339. package/collections/user-guide.collection.js.map +0 -1
  340. package/collections/user.collection.d.ts +0 -4
  341. package/collections/user.collection.js +0 -180
  342. package/collections/user.collection.js.map +0 -1
  343. package/cron/cron.d.ts +0 -14
  344. package/cron/cron.js +0 -216
  345. package/cron/cron.js.map +0 -1
  346. package/fixtures/cron-jobs.d.ts +0 -1
  347. package/fixtures/cron-jobs.js +0 -150
  348. package/fixtures/cron-jobs.js.map +0 -1
  349. package/fixtures/init.d.ts +0 -1
  350. package/fixtures/init.js +0 -91
  351. package/fixtures/init.js.map +0 -1
  352. package/http/auth.d.ts +0 -2
  353. package/http/auth.js +0 -951
  354. package/http/auth.js.map +0 -1
  355. package/http/health.d.ts +0 -1
  356. package/http/health.js +0 -11
  357. package/http/health.js.map +0 -1
  358. package/http/home.d.ts +0 -1
  359. package/http/home.js +0 -134
  360. package/http/home.js.map +0 -1
  361. package/http/slow-query-publication.d.ts +0 -2
  362. package/http/slow-query-publication.js +0 -99
  363. package/http/slow-query-publication.js.map +0 -1
  364. package/index.d.ts +0 -1
  365. package/index.js +0 -19
  366. package/index.js.map +0 -1
  367. package/managers/ai-assistant-codex-manager.manager.d.ts +0 -67
  368. package/managers/ai-assistant-codex-manager.manager.js +0 -1113
  369. package/managers/ai-assistant-codex-manager.manager.js.map +0 -1
  370. package/managers/ai-run-evidence.manager.d.ts +0 -36
  371. package/managers/ai-run-evidence.manager.js +0 -377
  372. package/managers/ai-run-evidence.manager.js.map +0 -1
  373. package/managers/communication-metric.manager.d.ts +0 -16
  374. package/managers/communication-metric.manager.js +0 -134
  375. package/managers/communication-metric.manager.js.map +0 -1
  376. package/managers/cron.manager.d.ts +0 -20
  377. package/managers/cron.manager.js +0 -534
  378. package/managers/cron.manager.js.map +0 -1
  379. package/managers/customer-notification-content.manager.d.ts +0 -55
  380. package/managers/customer-notification-content.manager.js +0 -158
  381. package/managers/customer-notification-content.manager.js.map +0 -1
  382. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  383. package/managers/diagnostic-manager-bootstrap.js +0 -260
  384. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  385. package/managers/error-auto-fix.manager.d.ts +0 -149
  386. package/managers/error-auto-fix.manager.js +0 -3064
  387. package/managers/error-auto-fix.manager.js.map +0 -1
  388. package/managers/local-log.manager.d.ts +0 -18
  389. package/managers/local-log.manager.js +0 -88
  390. package/managers/local-log.manager.js.map +0 -1
  391. package/managers/method.manager.d.ts +0 -84
  392. package/managers/method.manager.js +0 -1964
  393. package/managers/method.manager.js.map +0 -1
  394. package/managers/mongo.manager.d.ts +0 -224
  395. package/managers/mongo.manager.js +0 -5000
  396. package/managers/mongo.manager.js.map +0 -1
  397. package/managers/monitor.manager.d.ts +0 -70
  398. package/managers/monitor.manager.js +0 -550
  399. package/managers/monitor.manager.js.map +0 -1
  400. package/managers/openai-usage-ledger.manager.d.ts +0 -30
  401. package/managers/openai-usage-ledger.manager.js +0 -142
  402. package/managers/openai-usage-ledger.manager.js.map +0 -1
  403. package/managers/slow-query-verifier.manager.d.ts +0 -144
  404. package/managers/slow-query-verifier.manager.js +0 -3857
  405. package/managers/slow-query-verifier.manager.js.map +0 -1
  406. package/managers/slow-query.manager.d.ts +0 -28
  407. package/managers/slow-query.manager.js +0 -468
  408. package/managers/slow-query.manager.js.map +0 -1
  409. package/managers/subscription.manager.d.ts +0 -169
  410. package/managers/subscription.manager.js +0 -3434
  411. package/managers/subscription.manager.js.map +0 -1
  412. package/managers/websocket.manager.d.ts +0 -73
  413. package/managers/websocket.manager.js +0 -673
  414. package/managers/websocket.manager.js.map +0 -1
  415. package/managers/worker-dispatcher.manager.d.ts +0 -120
  416. package/managers/worker-dispatcher.manager.js +0 -1266
  417. package/managers/worker-dispatcher.manager.js.map +0 -1
  418. package/managers/worker-server.manager.d.ts +0 -35
  419. package/managers/worker-server.manager.js +0 -582
  420. package/managers/worker-server.manager.js.map +0 -1
  421. package/methods/accounts.d.ts +0 -2
  422. package/methods/accounts.js +0 -624
  423. package/methods/accounts.js.map +0 -1
  424. package/methods/ai-terminal.d.ts +0 -458
  425. package/methods/ai-terminal.js +0 -27991
  426. package/methods/ai-terminal.js.map +0 -1
  427. package/methods/app-settings.d.ts +0 -2
  428. package/methods/app-settings.js +0 -169
  429. package/methods/app-settings.js.map +0 -1
  430. package/methods/aws.d.ts +0 -2
  431. package/methods/aws.js +0 -877
  432. package/methods/aws.js.map +0 -1
  433. package/methods/collections.d.ts +0 -2
  434. package/methods/collections.js +0 -719
  435. package/methods/collections.js.map +0 -1
  436. package/methods/counters.d.ts +0 -2
  437. package/methods/counters.js +0 -113
  438. package/methods/counters.js.map +0 -1
  439. package/methods/cron-jobs.d.ts +0 -2
  440. package/methods/cron-jobs.js +0 -2475
  441. package/methods/cron-jobs.js.map +0 -1
  442. package/methods/customer-notifications.d.ts +0 -2
  443. package/methods/customer-notifications.js +0 -528
  444. package/methods/customer-notifications.js.map +0 -1
  445. package/methods/diagnostics.d.ts +0 -2
  446. package/methods/diagnostics.js +0 -703
  447. package/methods/diagnostics.js.map +0 -1
  448. package/methods/flag-updates.d.ts +0 -2
  449. package/methods/flag-updates.js +0 -8
  450. package/methods/flag-updates.js.map +0 -1
  451. package/methods/flags.d.ts +0 -2
  452. package/methods/flags.js +0 -8
  453. package/methods/flags.js.map +0 -1
  454. package/methods/logs.d.ts +0 -2
  455. package/methods/logs.js +0 -751
  456. package/methods/logs.js.map +0 -1
  457. package/methods/mongo-explorer.d.ts +0 -2
  458. package/methods/mongo-explorer.js +0 -1808
  459. package/methods/mongo-explorer.js.map +0 -1
  460. package/methods/monitor.d.ts +0 -2
  461. package/methods/monitor.js +0 -543
  462. package/methods/monitor.js.map +0 -1
  463. package/methods/pdf.d.ts +0 -2
  464. package/methods/pdf.js +0 -1216
  465. package/methods/pdf.js.map +0 -1
  466. package/methods/publications.d.ts +0 -1
  467. package/methods/publications.js +0 -183
  468. package/methods/publications.js.map +0 -1
  469. package/methods/report-builder.d.ts +0 -2
  470. package/methods/report-builder.js +0 -3094
  471. package/methods/report-builder.js.map +0 -1
  472. package/methods/support.d.ts +0 -2
  473. package/methods/support.js +0 -430
  474. package/methods/support.js.map +0 -1
  475. package/models/ai-run.model.d.ts +0 -19
  476. package/models/ai-run.model.js +0 -4
  477. package/models/ai-run.model.js.map +0 -1
  478. package/models/ai-terminal-conversation.model.d.ts +0 -17
  479. package/models/ai-terminal-conversation.model.js +0 -4
  480. package/models/ai-terminal-conversation.model.js.map +0 -1
  481. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  482. package/models/ai-terminal-issue-report.model.js +0 -4
  483. package/models/ai-terminal-issue-report.model.js.map +0 -1
  484. package/models/ai-terminal-message.model.d.ts +0 -22
  485. package/models/ai-terminal-message.model.js +0 -4
  486. package/models/ai-terminal-message.model.js.map +0 -1
  487. package/models/app-setting.model.d.ts +0 -16
  488. package/models/app-setting.model.js +0 -4
  489. package/models/app-setting.model.js.map +0 -1
  490. package/models/app-status.model.js +0 -4
  491. package/models/app-status.model.js.map +0 -1
  492. package/models/billing-logged-in-users.model.js +0 -4
  493. package/models/billing-logged-in-users.model.js.map +0 -1
  494. package/models/collection-document.model.d.ts +0 -21
  495. package/models/collection-document.model.js +0 -4
  496. package/models/collection-document.model.js.map +0 -1
  497. package/models/communication-metric.model.d.ts +0 -20
  498. package/models/communication-metric.model.js +0 -4
  499. package/models/communication-metric.model.js.map +0 -1
  500. package/models/counter.model.js +0 -4
  501. package/models/counter.model.js.map +0 -1
  502. package/models/cron-job-history.model.d.ts +0 -15
  503. package/models/cron-job-history.model.js +0 -4
  504. package/models/cron-job-history.model.js.map +0 -1
  505. package/models/cron-job.model.d.ts +0 -14
  506. package/models/cron-job.model.js +0 -4
  507. package/models/cron-job.model.js.map +0 -1
  508. package/models/customer-notification.model.d.ts +0 -26
  509. package/models/customer-notification.model.js +0 -4
  510. package/models/customer-notification.model.js.map +0 -1
  511. package/models/customer-portal-password.model.d.ts +0 -11
  512. package/models/customer-portal-password.model.js +0 -4
  513. package/models/customer-portal-password.model.js.map +0 -1
  514. package/models/dialog.model.d.ts +0 -23
  515. package/models/dialog.model.js +0 -4
  516. package/models/dialog.model.js.map +0 -1
  517. package/models/email-history.model.d.ts +0 -32
  518. package/models/email-history.model.js.map +0 -1
  519. package/models/email-verified.model.js +0 -4
  520. package/models/email-verified.model.js.map +0 -1
  521. package/models/file.model.js +0 -4
  522. package/models/file.model.js.map +0 -1
  523. package/models/flag-update.model.js +0 -4
  524. package/models/flag-update.model.js.map +0 -1
  525. package/models/flag.model.js +0 -4
  526. package/models/flag.model.js.map +0 -1
  527. package/models/log-method-latency.model.d.ts +0 -10
  528. package/models/log-method-latency.model.js +0 -4
  529. package/models/log-method-latency.model.js.map +0 -1
  530. package/models/log-subscription.model.js +0 -4
  531. package/models/log-subscription.model.js.map +0 -1
  532. package/models/log.model.d.ts +0 -17
  533. package/models/log.model.js +0 -4
  534. package/models/log.model.js.map +0 -1
  535. package/models/logged-in-users.model.js +0 -4
  536. package/models/logged-in-users.model.js.map +0 -1
  537. package/models/method-response.model.js +0 -4
  538. package/models/method-response.model.js.map +0 -1
  539. package/models/method.model.d.ts +0 -26
  540. package/models/method.model.js +0 -4
  541. package/models/method.model.js.map +0 -1
  542. package/models/monitor-cpu.model.js +0 -4
  543. package/models/monitor-cpu.model.js.map +0 -1
  544. package/models/monitor-function.model.d.ts +0 -14
  545. package/models/monitor-function.model.js +0 -4
  546. package/models/monitor-function.model.js.map +0 -1
  547. package/models/monitor-memory.model.d.ts +0 -15
  548. package/models/monitor-memory.model.js +0 -4
  549. package/models/monitor-memory.model.js.map +0 -1
  550. package/models/monitor-mongo.model.d.ts +0 -13
  551. package/models/monitor-mongo.model.js +0 -4
  552. package/models/monitor-mongo.model.js.map +0 -1
  553. package/models/notification.model.js +0 -4
  554. package/models/notification.model.js.map +0 -1
  555. package/models/openai-usage-ledger.model.d.ts +0 -30
  556. package/models/openai-usage-ledger.model.js +0 -4
  557. package/models/openai-usage-ledger.model.js.map +0 -1
  558. package/models/pagination.model.d.ts +0 -11
  559. package/models/pagination.model.js +0 -28
  560. package/models/pagination.model.js.map +0 -1
  561. package/models/permission.model.d.ts +0 -12
  562. package/models/permission.model.js +0 -4
  563. package/models/permission.model.js.map +0 -1
  564. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  565. package/models/report-builder-dashboard-builder.model.js +0 -4
  566. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  567. package/models/report-builder-library.model.d.ts +0 -17
  568. package/models/report-builder-library.model.js +0 -4
  569. package/models/report-builder-library.model.js.map +0 -1
  570. package/models/report-builder-report.model.d.ts +0 -121
  571. package/models/report-builder-report.model.js +0 -4
  572. package/models/report-builder-report.model.js.map +0 -1
  573. package/models/report-builder.model.d.ts +0 -61
  574. package/models/report-builder.model.js +0 -4
  575. package/models/report-builder.model.js.map +0 -1
  576. package/models/select-data-label.model.d.ts +0 -9
  577. package/models/select-data-label.model.js +0 -4
  578. package/models/select-data-label.model.js.map +0 -1
  579. package/models/server-message.model.d.ts +0 -32
  580. package/models/server-message.model.js +0 -4
  581. package/models/server-message.model.js.map +0 -1
  582. package/models/slow-query-report.model.d.ts +0 -23
  583. package/models/slow-query-report.model.js +0 -4
  584. package/models/slow-query-report.model.js.map +0 -1
  585. package/models/subscription.model.d.ts +0 -31
  586. package/models/subscription.model.js +0 -4
  587. package/models/subscription.model.js.map +0 -1
  588. package/models/support-ticket.model.d.ts +0 -87
  589. package/models/support-ticket.model.js +0 -4
  590. package/models/support-ticket.model.js.map +0 -1
  591. package/models/user-group.model.d.ts +0 -20
  592. package/models/user-group.model.js +0 -4
  593. package/models/user-group.model.js.map +0 -1
  594. package/models/user-guide.model.js +0 -4
  595. package/models/user-guide.model.js.map +0 -1
  596. package/models/user.model.d.ts +0 -84
  597. package/models/user.model.js +0 -4
  598. package/models/user.model.js.map +0 -1
  599. package/private/images/ResolveIO.png +0 -0
  600. package/public_api.js +0 -127
  601. package/public_api.js.map +0 -1
  602. package/publications/ai-terminal.d.ts +0 -1
  603. package/publications/ai-terminal.js +0 -122
  604. package/publications/ai-terminal.js.map +0 -1
  605. package/publications/app-settings.d.ts +0 -2
  606. package/publications/app-settings.js +0 -28
  607. package/publications/app-settings.js.map +0 -1
  608. package/publications/app-status.d.ts +0 -2
  609. package/publications/app-status.js +0 -16
  610. package/publications/app-status.js.map +0 -1
  611. package/publications/cron-jobs.d.ts +0 -2
  612. package/publications/cron-jobs.js +0 -88
  613. package/publications/cron-jobs.js.map +0 -1
  614. package/publications/customer-notifications.d.ts +0 -2
  615. package/publications/customer-notifications.js +0 -161
  616. package/publications/customer-notifications.js.map +0 -1
  617. package/publications/files.d.ts +0 -2
  618. package/publications/files.js +0 -36
  619. package/publications/files.js.map +0 -1
  620. package/publications/flags-update.d.ts +0 -2
  621. package/publications/flags-update.js +0 -22
  622. package/publications/flags-update.js.map +0 -1
  623. package/publications/flags.d.ts +0 -2
  624. package/publications/flags.js +0 -22
  625. package/publications/flags.js.map +0 -1
  626. package/publications/logs.d.ts +0 -2
  627. package/publications/logs.js +0 -164
  628. package/publications/logs.js.map +0 -1
  629. package/publications/notifications.d.ts +0 -2
  630. package/publications/notifications.js +0 -16
  631. package/publications/notifications.js.map +0 -1
  632. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  633. package/publications/report-builder-dashboard-builders.js +0 -42
  634. package/publications/report-builder-dashboard-builders.js.map +0 -1
  635. package/publications/report-builder-libraries.d.ts +0 -2
  636. package/publications/report-builder-libraries.js +0 -90
  637. package/publications/report-builder-libraries.js.map +0 -1
  638. package/publications/report-builder-reports.d.ts +0 -2
  639. package/publications/report-builder-reports.js +0 -50
  640. package/publications/report-builder-reports.js.map +0 -1
  641. package/publications/super-admin.d.ts +0 -2
  642. package/publications/super-admin.js +0 -16
  643. package/publications/super-admin.js.map +0 -1
  644. package/publications/user-groups.d.ts +0 -1
  645. package/publications/user-groups.js +0 -16
  646. package/publications/user-groups.js.map +0 -1
  647. package/publications/user-guides.d.ts +0 -1
  648. package/publications/user-guides.js +0 -16
  649. package/publications/user-guides.js.map +0 -1
  650. package/resolveio-server-app.d.ts +0 -70
  651. package/resolveio-server-app.js +0 -801
  652. package/resolveio-server-app.js.map +0 -1
  653. package/server-app.d.ts +0 -228
  654. package/server-app.js +0 -3566
  655. package/server-app.js.map +0 -1
  656. package/services/codex-client.d.ts +0 -128
  657. package/services/codex-client.js +0 -1629
  658. package/services/codex-client.js.map +0 -1
  659. package/services/openai-client.d.ts +0 -46
  660. package/services/openai-client.js +0 -318
  661. package/services/openai-client.js.map +0 -1
  662. package/types/error-report.d.ts +0 -25
  663. package/types/error-report.js +0 -4
  664. package/types/error-report.js.map +0 -1
  665. package/types/slow-query-report.d.ts +0 -27
  666. package/types/slow-query-report.js +0 -6
  667. package/types/slow-query-report.js.map +0 -1
  668. package/util/ai-qa-policy.d.ts +0 -124
  669. package/util/ai-qa-policy.js +0 -736
  670. package/util/ai-qa-policy.js.map +0 -1
  671. package/util/ai-run-evidence-adapters.d.ts +0 -109
  672. package/util/ai-run-evidence-adapters.js +0 -7234
  673. package/util/ai-run-evidence-adapters.js.map +0 -1
  674. package/util/ai-run-evidence-dashboard.d.ts +0 -88
  675. package/util/ai-run-evidence-dashboard.js +0 -343
  676. package/util/ai-run-evidence-dashboard.js.map +0 -1
  677. package/util/ai-run-evidence-eval.d.ts +0 -86
  678. package/util/ai-run-evidence-eval.js +0 -1018
  679. package/util/ai-run-evidence-eval.js.map +0 -1
  680. package/util/ai-run-evidence.d.ts +0 -244
  681. package/util/ai-run-evidence.js +0 -1096
  682. package/util/ai-run-evidence.js.map +0 -1
  683. package/util/ai-runner-artifacts.d.ts +0 -82
  684. package/util/ai-runner-artifacts.js +0 -713
  685. package/util/ai-runner-artifacts.js.map +0 -1
  686. package/util/ai-runner-manager-autopilot.d.ts +0 -210
  687. package/util/ai-runner-manager-autopilot.js +0 -642
  688. package/util/ai-runner-manager-autopilot.js.map +0 -1
  689. package/util/ai-runner-manager-policy.d.ts +0 -807
  690. package/util/ai-runner-manager-policy.js +0 -3501
  691. package/util/ai-runner-manager-policy.js.map +0 -1
  692. package/util/ai-runner-qa-auth.d.ts +0 -5
  693. package/util/ai-runner-qa-auth.js +0 -839
  694. package/util/ai-runner-qa-auth.js.map +0 -1
  695. package/util/ai-runner-qa-tools.d.ts +0 -26
  696. package/util/ai-runner-qa-tools.js +0 -3520
  697. package/util/ai-runner-qa-tools.js.map +0 -1
  698. package/util/aicoder-runner-v6.d.ts +0 -426
  699. package/util/aicoder-runner-v6.js +0 -2464
  700. package/util/aicoder-runner-v6.js.map +0 -1
  701. package/util/common.d.ts +0 -31
  702. package/util/common.js +0 -683
  703. package/util/common.js.map +0 -1
  704. package/util/customer-portal-password.d.ts +0 -13
  705. package/util/customer-portal-password.js +0 -209
  706. package/util/customer-portal-password.js.map +0 -1
  707. package/util/error-reporter.d.ts +0 -52
  708. package/util/error-reporter.js +0 -326
  709. package/util/error-reporter.js.map +0 -1
  710. package/util/error-tracking.d.ts +0 -13
  711. package/util/error-tracking.js +0 -120
  712. package/util/error-tracking.js.map +0 -1
  713. package/util/openai-usage-cost.d.ts +0 -6
  714. package/util/openai-usage-cost.js +0 -103
  715. package/util/openai-usage-cost.js.map +0 -1
  716. package/util/report-builder-unwinds.d.ts +0 -15
  717. package/util/report-builder-unwinds.js +0 -156
  718. package/util/report-builder-unwinds.js.map +0 -1
  719. package/util/runner-process-janitor.d.ts +0 -27
  720. package/util/runner-process-janitor.js +0 -208
  721. package/util/runner-process-janitor.js.map +0 -1
  722. package/util/schema-report-builder.d.ts +0 -6
  723. package/util/schema-report-builder.js +0 -481
  724. package/util/schema-report-builder.js.map +0 -1
  725. package/util/slow-query-reporter.d.ts +0 -28
  726. package/util/slow-query-reporter.js +0 -226
  727. package/util/slow-query-reporter.js.map +0 -1
  728. package/util/subscription-dependency-context.d.ts +0 -34
  729. package/util/subscription-dependency-context.js +0 -1283
  730. package/util/subscription-dependency-context.js.map +0 -1
  731. package/util/support-runner-v5.d.ts +0 -1426
  732. package/util/support-runner-v5.js +0 -7624
  733. package/util/support-runner-v5.js.map +0 -1
  734. package/util/tokenizer.d.ts +0 -5
  735. package/util/tokenizer.js +0 -41
  736. package/util/tokenizer.js.map +0 -1
  737. package/workers/codex-runner.worker.d.ts +0 -1
  738. package/workers/codex-runner.worker.js +0 -192
  739. package/workers/codex-runner.worker.js.map +0 -1
  740. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  741. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  742. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  743. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  744. /package/{private → src/private}/email-templates/support-ticket.html +0 -0
  745. /package/{public_api.d.ts → src/public_api.ts} +0 -0
@@ -0,0 +1,1096 @@
1
+ import { AsyncLocalStorage } from 'async_hooks';
2
+ import { deepCopy } from './common';
3
+
4
+ export interface QueryMeta {
5
+ limit?: number;
6
+ skip?: number;
7
+ sort?: any;
8
+ }
9
+
10
+ export interface DependencyContextSnapshot {
11
+ dependencies: Map<string, Set<string>>;
12
+ filters: Map<string, any[]>;
13
+ watchAllCollections: Set<string>;
14
+ queryMetadata: Map<string, QueryMeta[]>;
15
+ }
16
+
17
+ export interface SerializedDependencySnapshot {
18
+ dependencies: Array<[string, string[]]>;
19
+ filters: Array<[string, any[]]>;
20
+ watchAllCollections: string[];
21
+ queryMetadata: Array<[string, QueryMeta[]]>;
22
+ }
23
+
24
+ export interface PublicationContext {
25
+ publication?: string;
26
+ subscriptionData?: any[];
27
+ userId?: string;
28
+ }
29
+
30
+ interface LookupTarget {
31
+ from: string;
32
+ as: string;
33
+ localField?: string;
34
+ foreignField?: string;
35
+ let?: Record<string, any>;
36
+ pipeline?: any[];
37
+ }
38
+
39
+ interface DependencyContext extends DependencyContextSnapshot, PublicationContext {}
40
+
41
+ const dependencyStorage = new AsyncLocalStorage<DependencyContext>();
42
+
43
+ export async function withDependencyTracking<T>(fn: () => Promise<T>, metadata?: PublicationContext): Promise<{ result: T; snapshot: DependencyContextSnapshot }> {
44
+ const context: DependencyContext = {
45
+ dependencies: new Map(),
46
+ filters: new Map(),
47
+ watchAllCollections: new Set(),
48
+ queryMetadata: new Map()
49
+ };
50
+
51
+ if (metadata?.publication) {
52
+ context.publication = metadata.publication;
53
+ }
54
+
55
+ if (Array.isArray(metadata?.subscriptionData)) {
56
+ context.subscriptionData = metadata.subscriptionData.slice();
57
+ }
58
+
59
+ if (metadata?.userId) {
60
+ context.userId = metadata.userId;
61
+ }
62
+
63
+ let result: T;
64
+
65
+ await dependencyStorage.run(context, async () => {
66
+ result = await fn();
67
+ });
68
+
69
+ return {
70
+ result,
71
+ snapshot: {
72
+ dependencies: cloneDependencyMap(context.dependencies),
73
+ filters: cloneFilterMap(context.filters),
74
+ watchAllCollections: new Set(context.watchAllCollections),
75
+ queryMetadata: cloneQueryMetaMap(context.queryMetadata)
76
+ }
77
+ };
78
+ }
79
+
80
+ export function serializeDependencySnapshot(snapshot: DependencyContextSnapshot): SerializedDependencySnapshot {
81
+ return {
82
+ dependencies: Array.from(snapshot.dependencies.entries()).map(([collection, ids]) => [collection, Array.from(ids)]),
83
+ filters: Array.from(snapshot.filters.entries()).map(([collection, filters]) => [collection, deepCopy(filters)]),
84
+ watchAllCollections: Array.from(snapshot.watchAllCollections),
85
+ queryMetadata: Array.from(snapshot.queryMetadata.entries()).map(([collection, meta]) => [collection, deepCopy(meta)])
86
+ };
87
+ }
88
+
89
+ export function deserializeDependencySnapshot(snapshot: SerializedDependencySnapshot): DependencyContextSnapshot {
90
+ return {
91
+ dependencies: new Map(snapshot.dependencies.map(([collection, ids]) => [collection, new Set(ids)])),
92
+ filters: new Map(snapshot.filters.map(([collection, filters]) => [collection, deepCopy(filters)])),
93
+ watchAllCollections: new Set(snapshot.watchAllCollections),
94
+ queryMetadata: new Map(snapshot.queryMetadata.map(([collection, meta]) => [collection, deepCopy(meta)]))
95
+ };
96
+ }
97
+
98
+ export function getPublicationContext(): PublicationContext {
99
+ const context = dependencyStorage.getStore();
100
+ if (!context) {
101
+ return {};
102
+ }
103
+
104
+ const snapshot: PublicationContext = {};
105
+
106
+ if (context.publication) {
107
+ snapshot.publication = context.publication;
108
+ }
109
+
110
+ if (Array.isArray(context.subscriptionData)) {
111
+ snapshot.subscriptionData = context.subscriptionData.slice();
112
+ }
113
+
114
+ if (context.userId) {
115
+ snapshot.userId = context.userId;
116
+ }
117
+
118
+ return snapshot;
119
+ }
120
+
121
+ export function recordDependencyResult(collection: string, result: unknown, options?: { filter?: any, meta?: QueryMeta }) {
122
+ const context = dependencyStorage.getStore();
123
+
124
+ if (!context) {
125
+ return;
126
+ }
127
+
128
+ if (options?.filter) {
129
+ let filterList = context.filters.get(collection);
130
+
131
+ if (!filterList) {
132
+ filterList = [];
133
+ context.filters.set(collection, filterList);
134
+ }
135
+
136
+ filterList.push(deepCopy(options.filter));
137
+ context.watchAllCollections.delete(collection);
138
+ }
139
+
140
+ if (options?.meta) {
141
+ let metaList = context.queryMetadata.get(collection);
142
+
143
+ if (!metaList) {
144
+ metaList = [];
145
+ context.queryMetadata.set(collection, metaList);
146
+ }
147
+
148
+ metaList.push(deepCopy(options.meta));
149
+ }
150
+
151
+ const ids = new Set<string>();
152
+ collectIdsFromResult(result, ids);
153
+
154
+ if (!ids.size && options?.filter) {
155
+ collectIdsFromFilter(options.filter, ids);
156
+ }
157
+
158
+ if (ids.size) {
159
+ context.watchAllCollections.delete(collection);
160
+ let existing = context.dependencies.get(collection);
161
+
162
+ if (!existing) {
163
+ existing = new Set();
164
+ context.dependencies.set(collection, existing);
165
+ }
166
+
167
+ for (const id of ids) {
168
+ existing.add(id);
169
+ }
170
+ }
171
+ else if (!options?.filter) {
172
+ context.watchAllCollections.add(collection);
173
+ }
174
+ }
175
+
176
+ export function recordAggregateDependencies(collection: string, pipeline: any[], result: unknown) {
177
+ const context = dependencyStorage.getStore();
178
+
179
+ if (!context) {
180
+ return;
181
+ }
182
+
183
+ const lookupTargets = extractLookupTargets(pipeline);
184
+ const lookupAliases = new Set<string>(lookupTargets.map(target => target.as).filter(Boolean));
185
+ const matchFilter = sanitizeMatchFilter(extractMatchFilter(pipeline), lookupAliases);
186
+ const meta = extractAggregateMeta(pipeline);
187
+ recordDependencyResult(collection, result, {
188
+ filter: matchFilter || undefined,
189
+ meta
190
+ });
191
+
192
+ if (!matchFilter) {
193
+ context.watchAllCollections.add(collection);
194
+ }
195
+
196
+ if (shouldWatchAllForAggregatePipeline(pipeline)) {
197
+ context.watchAllCollections.add(collection);
198
+ }
199
+
200
+ if (!lookupTargets.length) {
201
+ return;
202
+ }
203
+
204
+ for (const target of lookupTargets) {
205
+ const nestedValues: unknown[] = [];
206
+ collectLookupValues(result, target.as, nestedValues);
207
+ const rootDocs = Array.isArray(result) ? result : [result];
208
+ const pipelineFilters: any[] = [];
209
+ let pipelineUnresolved = false;
210
+
211
+ for (const rootDoc of rootDocs) {
212
+ const { filters: filtersFromPipeline, unresolved } = buildLookupPipelineFilters(rootDoc, target);
213
+ if (unresolved) {
214
+ pipelineUnresolved = true;
215
+ }
216
+ if (filtersFromPipeline?.length) {
217
+ pipelineFilters.push(...filtersFromPipeline);
218
+ }
219
+ }
220
+
221
+ const filter = buildLookupFilter(result, target.localField, target.foreignField);
222
+
223
+ const uniquePipelineFilters = dedupeFilters(pipelineFilters);
224
+
225
+ if (nestedValues.length) {
226
+ recordDependencyResult(target.from, nestedValues, filter ? { filter } : undefined);
227
+ }
228
+
229
+ if (uniquePipelineFilters.length) {
230
+ const pipelineMeta = extractAggregationMetaFromPipeline(target.pipeline);
231
+ for (const pipelineFilter of uniquePipelineFilters) {
232
+ recordDependencyResult(target.from, [], { filter: pipelineFilter, meta: pipelineMeta });
233
+ }
234
+ continue;
235
+ }
236
+
237
+ if (!nestedValues.length && filter) {
238
+ recordDependencyResult(target.from, [], { filter });
239
+ continue;
240
+ }
241
+
242
+ if (!nestedValues.length) {
243
+ if (pipelineUnresolved) {
244
+ context.watchAllCollections.add(target.from);
245
+ }
246
+ else if (!target.pipeline || !target.pipeline.length) {
247
+ context.watchAllCollections.add(target.from);
248
+ }
249
+ else {
250
+ // Lookup pipeline exists, but we could not derive stable filters/ids.
251
+ context.watchAllCollections.add(target.from);
252
+ }
253
+ }
254
+ }
255
+ }
256
+
257
+ function shouldWatchAllForAggregatePipeline(pipeline: any[]): boolean {
258
+ if (!Array.isArray(pipeline)) {
259
+ return false;
260
+ }
261
+
262
+ return pipeline.some(stage => isCardinalityChangingStage(stage));
263
+ }
264
+
265
+ function isCardinalityChangingStage(stage: any): boolean {
266
+ if (!stage || typeof stage !== 'object') {
267
+ return false;
268
+ }
269
+
270
+ if (stage.$group && typeof stage.$group === 'object') {
271
+ return true;
272
+ }
273
+
274
+ if (stage.$count !== undefined) {
275
+ return true;
276
+ }
277
+
278
+ if (stage.$facet && typeof stage.$facet === 'object') {
279
+ return true;
280
+ }
281
+
282
+ if (stage.$bucket && typeof stage.$bucket === 'object') {
283
+ return true;
284
+ }
285
+
286
+ if (stage.$bucketAuto && typeof stage.$bucketAuto === 'object') {
287
+ return true;
288
+ }
289
+
290
+ if (stage.$sortByCount !== undefined) {
291
+ return true;
292
+ }
293
+
294
+ return false;
295
+ }
296
+
297
+ function extractLookupTargets(pipeline: any[]): LookupTarget[] {
298
+ const lookups: LookupTarget[] = [];
299
+
300
+ if (!Array.isArray(pipeline)) {
301
+ return lookups;
302
+ }
303
+
304
+ for (const stage of pipeline) {
305
+ if (stage && stage.$lookup && typeof stage.$lookup === 'object') {
306
+ const lookup = stage.$lookup;
307
+ if (typeof lookup.from === 'string' && typeof lookup.as === 'string') {
308
+ lookups.push({
309
+ from: lookup.from,
310
+ as: lookup.as,
311
+ localField: typeof lookup.localField === 'string' ? lookup.localField : undefined,
312
+ foreignField: typeof lookup.foreignField === 'string' ? lookup.foreignField : undefined,
313
+ let: lookup.let && typeof lookup.let === 'object' ? lookup.let : undefined,
314
+ pipeline: Array.isArray(lookup.pipeline) ? lookup.pipeline : undefined
315
+ });
316
+ }
317
+ }
318
+ }
319
+
320
+ return lookups;
321
+ }
322
+
323
+ function extractMatchFilter(pipeline: any[]): any {
324
+ if (!Array.isArray(pipeline)) {
325
+ return null;
326
+ }
327
+
328
+ const filters: any[] = [];
329
+
330
+ for (const stage of pipeline) {
331
+ if (stage && stage.$match && typeof stage.$match === 'object') {
332
+ filters.push(deepCopy(stage.$match));
333
+ }
334
+ }
335
+
336
+ if (!filters.length) {
337
+ return null;
338
+ }
339
+
340
+ if (filters.length === 1) {
341
+ return filters[0];
342
+ }
343
+
344
+ return { $and: filters };
345
+ }
346
+
347
+ function sanitizeMatchFilter(filter: any, lookupAliases: Set<string>) {
348
+ if (!filter || !lookupAliases?.size) {
349
+ return filter;
350
+ }
351
+
352
+ return sanitizeFilterNode(filter, lookupAliases);
353
+ }
354
+
355
+ function sanitizeFilterNode(node: any, lookupAliases: Set<string>): any {
356
+ if (!node) {
357
+ return null;
358
+ }
359
+
360
+ if (Array.isArray(node)) {
361
+ const sanitizedArray = node
362
+ .map(entry => sanitizeFilterNode(entry, lookupAliases))
363
+ .filter(isMeaningfulFilterNode);
364
+
365
+ return sanitizedArray.length ? sanitizedArray : null;
366
+ }
367
+
368
+ if (typeof node !== 'object') {
369
+ return node;
370
+ }
371
+
372
+ const result = {};
373
+
374
+ for (const [key, value] of Object.entries(node)) {
375
+ if (key === '$and' || key === '$or' || key === '$nor') {
376
+ if (Array.isArray(value)) {
377
+ const sanitizedChildren = value
378
+ .map(entry => sanitizeFilterNode(entry, lookupAliases))
379
+ .filter(isMeaningfulFilterNode);
380
+
381
+ if (sanitizedChildren.length) {
382
+ result[key] = sanitizedChildren;
383
+ }
384
+ }
385
+
386
+ continue;
387
+ }
388
+
389
+ const rootKey = key.split('.')[0];
390
+
391
+ if (lookupAliases.has(rootKey)) {
392
+ continue;
393
+ }
394
+
395
+ result[key] = value;
396
+ }
397
+
398
+ return Object.keys(result).length ? result : null;
399
+ }
400
+
401
+ function isMeaningfulFilterNode(node: any) {
402
+ if (!node) {
403
+ return false;
404
+ }
405
+
406
+ if (Array.isArray(node)) {
407
+ return node.length > 0;
408
+ }
409
+
410
+ if (typeof node !== 'object') {
411
+ return true;
412
+ }
413
+
414
+ return Object.keys(node).length > 0;
415
+ }
416
+
417
+ function extractAggregateMeta(pipeline: any[]): QueryMeta {
418
+ if (!Array.isArray(pipeline)) {
419
+ return null;
420
+ }
421
+
422
+ let limit = undefined;
423
+ let skip = undefined;
424
+ let sort = null;
425
+
426
+ for (const stage of pipeline) {
427
+ if (stage?.$limit !== undefined && typeof stage.$limit === 'number') {
428
+ limit = stage.$limit;
429
+ }
430
+ else if (stage?.$skip !== undefined && typeof stage.$skip === 'number') {
431
+ skip = stage.$skip;
432
+ }
433
+ else if (stage?.$sort && typeof stage.$sort === 'object') {
434
+ sort = deepCopy(stage.$sort);
435
+ }
436
+ }
437
+
438
+ const meta: QueryMeta = {};
439
+
440
+ if (limit !== undefined) {
441
+ meta.limit = limit;
442
+ }
443
+
444
+ if (skip !== undefined) {
445
+ meta.skip = skip;
446
+ }
447
+
448
+ if (sort) {
449
+ meta.sort = sort;
450
+ }
451
+
452
+ return Object.keys(meta).length ? meta : null;
453
+ }
454
+
455
+ function extractAggregationMetaFromPipeline(pipeline: any[]): QueryMeta {
456
+ if (!Array.isArray(pipeline)) {
457
+ return null;
458
+ }
459
+
460
+ let limit = undefined;
461
+ let skip = undefined;
462
+ let sort = null;
463
+
464
+ for (const stage of pipeline) {
465
+ if (stage?.$limit !== undefined && typeof stage.$limit === 'number') {
466
+ limit = stage.$limit;
467
+ }
468
+ else if (stage?.$skip !== undefined && typeof stage.$skip === 'number') {
469
+ skip = stage.$skip;
470
+ }
471
+ else if (stage?.$sort && typeof stage.$sort === 'object') {
472
+ sort = deepCopy(stage.$sort);
473
+ }
474
+ }
475
+
476
+ const meta: QueryMeta = {};
477
+
478
+ if (limit !== undefined) {
479
+ meta.limit = limit;
480
+ }
481
+
482
+ if (skip !== undefined) {
483
+ meta.skip = skip;
484
+ }
485
+
486
+ if (sort) {
487
+ meta.sort = sort;
488
+ }
489
+
490
+ return Object.keys(meta).length ? meta : null;
491
+ }
492
+
493
+ function collectLookupValues(source: unknown, path: string, output: unknown[]) {
494
+ if (!source) {
495
+ return;
496
+ }
497
+
498
+ if (Array.isArray(source)) {
499
+ for (const item of source) {
500
+ collectLookupValues(item, path, output);
501
+ }
502
+ return;
503
+ }
504
+
505
+ if (typeof source !== 'object') {
506
+ return;
507
+ }
508
+
509
+ const pathSegments = path.split('.');
510
+ collectLookupPathValues(source as Record<string, unknown>, pathSegments, 0, output);
511
+ }
512
+
513
+ function collectLookupPathValues(value: Record<string, unknown>, path: string[], index: number, output: unknown[]) {
514
+ if (!value) {
515
+ return;
516
+ }
517
+
518
+ const current = value[path[index]];
519
+
520
+ if (current === undefined) {
521
+ return;
522
+ }
523
+
524
+ if (index === path.length - 1) {
525
+ output.push(current);
526
+ return;
527
+ }
528
+
529
+ if (Array.isArray(current)) {
530
+ for (const item of current) {
531
+ if (item && typeof item === 'object') {
532
+ collectLookupPathValues(item as Record<string, unknown>, path, index + 1, output);
533
+ }
534
+ }
535
+ }
536
+ else if (current && typeof current === 'object') {
537
+ collectLookupPathValues(current as Record<string, unknown>, path, index + 1, output);
538
+ }
539
+ }
540
+
541
+ function buildLookupFilter(result: unknown, localField?: string, foreignField?: string) {
542
+ if (!localField || !foreignField) {
543
+ return null;
544
+ }
545
+
546
+ const values: any[] = [];
547
+ const segments = localField.split('.');
548
+ collectFieldValues(result, segments, 0, values);
549
+
550
+ const uniqueValues = dedupeFilterValues(values);
551
+
552
+ if (!uniqueValues.length) {
553
+ return null;
554
+ }
555
+
556
+ return {
557
+ [foreignField]: {
558
+ $in: uniqueValues
559
+ }
560
+ };
561
+ }
562
+
563
+ function collectFieldValues(source: unknown, path: string[], index: number, output: any[]) {
564
+ if (!source) {
565
+ return;
566
+ }
567
+
568
+ if (Array.isArray(source)) {
569
+ for (const item of source) {
570
+ collectFieldValues(item, path, index, output);
571
+ }
572
+ return;
573
+ }
574
+
575
+ if (typeof source !== 'object') {
576
+ return;
577
+ }
578
+
579
+ const obj = source as Record<string, unknown>;
580
+ const key = path[index];
581
+ const current = obj[key];
582
+
583
+ if (current === undefined) {
584
+ return;
585
+ }
586
+
587
+ if (index === path.length - 1) {
588
+ appendFilterValue(output, current);
589
+ return;
590
+ }
591
+
592
+ if (Array.isArray(current)) {
593
+ for (const item of current) {
594
+ collectFieldValues(item, path, index + 1, output);
595
+ }
596
+ }
597
+ else {
598
+ collectFieldValues(current, path, index + 1, output);
599
+ }
600
+ }
601
+
602
+ function appendFilterValue(output: any[], value: any) {
603
+ if (value === undefined || value === null) {
604
+ return;
605
+ }
606
+
607
+ if (Array.isArray(value)) {
608
+ for (const item of value) {
609
+ appendFilterValue(output, item);
610
+ }
611
+ return;
612
+ }
613
+
614
+ output.push(value);
615
+ }
616
+
617
+ function dedupeFilterValues(values: any[]): any[] {
618
+ const unique = new Map<string, any>();
619
+
620
+ for (const value of values) {
621
+ const key = serializeFilterValue(value);
622
+ if (!unique.has(key)) {
623
+ unique.set(key, value);
624
+ }
625
+ }
626
+
627
+ return Array.from(unique.values());
628
+ }
629
+
630
+ function serializeFilterValue(value: any): string {
631
+ if (value === null || value === undefined) {
632
+ return 'null';
633
+ }
634
+
635
+ if (typeof value === 'object') {
636
+ if (typeof value.toHexString === 'function') {
637
+ return value.toHexString();
638
+ }
639
+
640
+ if (value instanceof Date) {
641
+ return value.toISOString();
642
+ }
643
+
644
+ if (typeof value.toString === 'function' && value.toString !== Object.prototype.toString) {
645
+ return value.toString();
646
+ }
647
+
648
+ try {
649
+ return JSON.stringify(value);
650
+ }
651
+ catch {
652
+ return '[object]';
653
+ }
654
+ }
655
+
656
+ return String(value);
657
+ }
658
+
659
+ function collectIdsFromResult(source: unknown, ids: Set<string>, visited = new WeakSet<object>()) {
660
+ if (!source) {
661
+ return;
662
+ }
663
+
664
+ if (Array.isArray(source)) {
665
+ for (const item of source) {
666
+ collectIdsFromResult(item, ids, visited);
667
+ }
668
+ return;
669
+ }
670
+
671
+ if (typeof source !== 'object') {
672
+ return;
673
+ }
674
+
675
+ const objectSource = source as Record<string, unknown>;
676
+
677
+ if (visited.has(objectSource)) {
678
+ return;
679
+ }
680
+
681
+ visited.add(objectSource);
682
+
683
+ const normalizedId = normalizeId(objectSource._id);
684
+
685
+ if (normalizedId) {
686
+ ids.add(normalizedId);
687
+ }
688
+
689
+ for (const value of Object.values(objectSource)) {
690
+ if (value && (typeof value === 'object' || Array.isArray(value))) {
691
+ collectIdsFromResult(value, ids, visited);
692
+ }
693
+ }
694
+ }
695
+
696
+ function collectIdsFromFilter(filter: unknown, ids: Set<string>) {
697
+ if (!filter) {
698
+ return;
699
+ }
700
+
701
+ if (Array.isArray(filter)) {
702
+ for (const item of filter) {
703
+ collectIdsFromFilter(item, ids);
704
+ }
705
+ return;
706
+ }
707
+
708
+ if (typeof filter !== 'object') {
709
+ return;
710
+ }
711
+
712
+ const filterObject = filter as Record<string, unknown>;
713
+
714
+ if (filterObject._id !== undefined) {
715
+ collectIdsFromFilterValue(filterObject._id, ids);
716
+ }
717
+
718
+ for (const [key, value] of Object.entries(filterObject)) {
719
+ if (key === '$or' || key === '$and' || key === '$nor') {
720
+ if (Array.isArray(value)) {
721
+ for (const item of value) {
722
+ collectIdsFromFilter(item, ids);
723
+ }
724
+ }
725
+ }
726
+ else if (key !== '_id' && value && typeof value === 'object') {
727
+ collectIdsFromFilter(value, ids);
728
+ }
729
+ }
730
+ }
731
+
732
+ function collectIdsFromFilterValue(value: unknown, ids: Set<string>) {
733
+ if (value === null || value === undefined) {
734
+ return;
735
+ }
736
+
737
+ if (Array.isArray(value)) {
738
+ for (const item of value) {
739
+ collectIdsFromFilterValue(item, ids);
740
+ }
741
+ return;
742
+ }
743
+
744
+ if (typeof value === 'object') {
745
+ for (const [key, inner] of Object.entries(value as Record<string, unknown>)) {
746
+ if (key === '$in' || key === '$nin' || key === '$all') {
747
+ collectIdsFromFilterValue(inner, ids);
748
+ }
749
+ else if (key === '$eq' || key === '$ne') {
750
+ collectIdsFromFilterValue(inner, ids);
751
+ }
752
+ else if (key === '$or' || key === '$and' || key === '$nor') {
753
+ collectIdsFromFilterValue(inner, ids);
754
+ }
755
+ else {
756
+ collectIdsFromFilterValue(inner, ids);
757
+ }
758
+ }
759
+ return;
760
+ }
761
+
762
+ const normalized = normalizeId(value);
763
+
764
+ if (normalized) {
765
+ ids.add(normalized);
766
+ }
767
+ }
768
+
769
+ function normalizeId(value: unknown): string {
770
+ if (value === null || value === undefined) {
771
+ return null;
772
+ }
773
+
774
+ if (typeof value === 'string') {
775
+ const trimmed = value.trim();
776
+ return trimmed.length ? trimmed : null;
777
+ }
778
+
779
+ if (typeof value === 'number' || typeof value === 'bigint') {
780
+ return value.toString();
781
+ }
782
+
783
+ if (typeof value === 'object') {
784
+ const objValue = value as { toHexString?: () => string, toString?: () => string };
785
+
786
+ if (typeof objValue.toHexString === 'function') {
787
+ return objValue.toHexString();
788
+ }
789
+
790
+ if (value instanceof Date) {
791
+ return value.toISOString();
792
+ }
793
+
794
+ if (typeof objValue.toString === 'function') {
795
+ const str = objValue.toString();
796
+ if (str && str !== '[object Object]') {
797
+ return str;
798
+ }
799
+ }
800
+ }
801
+
802
+ return null;
803
+ }
804
+
805
+ function cloneDependencyMap(original: Map<string, Set<string>>): Map<string, Set<string>> {
806
+ const cloned = new Map<string, Set<string>>();
807
+
808
+ for (const [collection, ids] of original.entries()) {
809
+ cloned.set(collection, new Set(ids));
810
+ }
811
+
812
+ return cloned;
813
+ }
814
+
815
+ function cloneFilterMap(original: Map<string, any[]>): Map<string, any[]> {
816
+ const cloned = new Map<string, any[]>();
817
+
818
+ for (const [collection, filters] of original.entries()) {
819
+ cloned.set(collection, filters.map(filter => deepCopy(filter)));
820
+ }
821
+
822
+ return cloned;
823
+ }
824
+
825
+ function cloneQueryMetaMap(original: Map<string, QueryMeta[]>): Map<string, QueryMeta[]> {
826
+ const cloned = new Map<string, QueryMeta[]>();
827
+
828
+ for (const [collection, metaList] of original.entries()) {
829
+ cloned.set(collection, metaList.map(meta => deepCopy(meta)));
830
+ }
831
+
832
+ return cloned;
833
+ }
834
+
835
+
836
+ function buildLookupPipelineFilters(rootDoc: any, target: LookupTarget): { filters: any[], unresolved: boolean } {
837
+ if (!target.pipeline || !target.pipeline.length) {
838
+ return { filters: [], unresolved: false };
839
+ }
840
+
841
+ const matchStages = target.pipeline.map(stage => ({ stage, base: stage.$match })).filter(entry => entry.base);
842
+
843
+ if (!matchStages.length) {
844
+ return buildLookupPipelineFromStack(target.pipeline, [], rootDoc, target.let);
845
+ }
846
+
847
+ const letValuesResult = resolveLetVariables(rootDoc, target.let);
848
+
849
+ if (!letValuesResult.resolved) {
850
+ return { filters: [], unresolved: true };
851
+ }
852
+
853
+ const combinedMatches = [];
854
+
855
+ for (const { base } of matchStages) {
856
+ const substitutionState = { unresolved: false };
857
+ const substituted = substituteLetVariables(base, letValuesResult.values, rootDoc, substitutionState);
858
+
859
+ if (substitutionState.unresolved || containsUnresolvedLetReference(substituted)) {
860
+ return { filters: [], unresolved: true };
861
+ }
862
+
863
+ combinedMatches.push(substituted);
864
+ }
865
+
866
+ if (!combinedMatches.length) {
867
+ return buildLookupPipelineFromStack(target.pipeline, [], rootDoc, target.let);
868
+ }
869
+
870
+ if (combinedMatches.length === 1) {
871
+ return { filters: [combinedMatches[0]], unresolved: false };
872
+ }
873
+
874
+ return { filters: [{ $and: combinedMatches }], unresolved: false };
875
+ }
876
+
877
+ function buildLookupPipelineFromStack(pipeline: any[], initialFilters: any[], rootDoc: any, letMap: Record<string, any>) {
878
+ let currentFilters = initialFilters.slice();
879
+ let unresolved = false;
880
+
881
+ const entries = pipeline.map(stage => stage ? Object.keys(stage)[0] : null);
882
+
883
+ for (let i = 0; i < pipeline.length; i++) {
884
+ const stage = pipeline[i];
885
+ const stageType = entries[i];
886
+
887
+ if (stageType === '$match' && stage.$match) {
888
+ const letValuesResult = resolveLetVariables(rootDoc, letMap);
889
+ if (!letValuesResult.resolved) {
890
+ unresolved = true;
891
+ break;
892
+ }
893
+
894
+ const substitutionState = { unresolved: false };
895
+ const substituted = substituteLetVariables(stage.$match, letValuesResult.values, rootDoc, substitutionState);
896
+
897
+ if (substitutionState.unresolved || containsUnresolvedLetReference(substituted)) {
898
+ unresolved = true;
899
+ break;
900
+ }
901
+
902
+ currentFilters.push(substituted);
903
+ }
904
+ else if (stageType === '$match') {
905
+ unresolved = true;
906
+ break;
907
+ }
908
+ else if (stageType === '$facet') {
909
+ unresolved = true;
910
+ break;
911
+ }
912
+ }
913
+
914
+ if (!currentFilters.length) {
915
+ return { filters: [], unresolved };
916
+ }
917
+
918
+ if (currentFilters.length === 1) {
919
+ return { filters: currentFilters, unresolved };
920
+ }
921
+
922
+ return { filters: [{ $and: currentFilters }], unresolved };
923
+ }
924
+
925
+ function resolveLetVariables(rootDoc: any, letMap: Record<string, any>) {
926
+ if (!letMap || typeof letMap !== 'object') {
927
+ return { resolved: true, values: {} };
928
+ }
929
+
930
+ const values = {};
931
+
932
+ for (const [key, expression] of Object.entries(letMap)) {
933
+ const evaluation = evaluateLetExpression(rootDoc, expression);
934
+
935
+ if (!evaluation.resolved) {
936
+ return { resolved: false, values: null };
937
+ }
938
+
939
+ values[key] = evaluation.value;
940
+ }
941
+
942
+ return { resolved: true, values };
943
+ }
944
+
945
+ function evaluateLetExpression(rootDoc: any, expression: any): { resolved: boolean, value: any } {
946
+ if (typeof expression === 'string') {
947
+ if (expression.startsWith('$$ROOT.')) {
948
+ const path = expression.slice('$$ROOT.'.length);
949
+ return { resolved: true, value: getValueByPath(rootDoc, path) };
950
+ }
951
+ else if (expression === '$$ROOT') {
952
+ return { resolved: true, value: rootDoc };
953
+ }
954
+ else if (expression.startsWith('$$')) {
955
+ return { resolved: false, value: null };
956
+ }
957
+ else if (expression.startsWith('$')) {
958
+ const path = expression.slice(1);
959
+ return { resolved: true, value: getValueByPath(rootDoc, path) };
960
+ }
961
+ else {
962
+ return { resolved: true, value: expression };
963
+ }
964
+ }
965
+ else if (Array.isArray(expression)) {
966
+ return { resolved: false, value: null };
967
+ }
968
+ else if (expression && typeof expression === 'object') {
969
+ return { resolved: false, value: null };
970
+ }
971
+
972
+ return { resolved: true, value: expression };
973
+ }
974
+
975
+ function substituteLetVariables(node: any, letValues: Record<string, any>, rootDoc: any, state: { unresolved: boolean }) {
976
+ if (Array.isArray(node)) {
977
+ return node.map(item => substituteLetVariables(item, letValues, rootDoc, state));
978
+ }
979
+
980
+ if (node && typeof node === 'object') {
981
+ const output = {};
982
+
983
+ for (const [key, value] of Object.entries(node)) {
984
+ output[key] = substituteLetVariables(value, letValues, rootDoc, state);
985
+ }
986
+
987
+ return output;
988
+ }
989
+
990
+ if (typeof node === 'string') {
991
+ if (node.startsWith('$$ROOT.')) {
992
+ const path = node.slice('$$ROOT.'.length);
993
+ return getValueByPath(rootDoc, path);
994
+ }
995
+
996
+ if (node === '$$ROOT') {
997
+ return rootDoc;
998
+ }
999
+
1000
+ if (node.startsWith('$$')) {
1001
+ const varName = node.slice(2);
1002
+
1003
+ if (Object.prototype.hasOwnProperty.call(letValues, varName)) {
1004
+ return letValues[varName];
1005
+ }
1006
+
1007
+ state.unresolved = true;
1008
+ return node;
1009
+ }
1010
+ }
1011
+
1012
+ return node;
1013
+ }
1014
+
1015
+ function containsUnresolvedLetReference(node: any): boolean {
1016
+ if (typeof node === 'string') {
1017
+ return node.includes('$$');
1018
+ }
1019
+
1020
+ if (Array.isArray(node)) {
1021
+ return node.some(item => containsUnresolvedLetReference(item));
1022
+ }
1023
+
1024
+ if (node && typeof node === 'object') {
1025
+ return Object.values(node).some(value => containsUnresolvedLetReference(value));
1026
+ }
1027
+
1028
+ return false;
1029
+ }
1030
+
1031
+ function getValueByPath(source: any, path: string) {
1032
+ if (!source || !path) {
1033
+ return undefined;
1034
+ }
1035
+
1036
+ const segments = path.split('.');
1037
+ let current = source;
1038
+
1039
+ for (const segment of segments) {
1040
+ if (current === null || current === undefined) {
1041
+ return undefined;
1042
+ }
1043
+
1044
+ if (Array.isArray(current)) {
1045
+ const index = parseInt(segment, 10);
1046
+
1047
+ if (isNaN(index) || index < 0 || index >= current.length) {
1048
+ return undefined;
1049
+ }
1050
+
1051
+ current = current[index];
1052
+ }
1053
+ else {
1054
+ current = current[segment];
1055
+ }
1056
+ }
1057
+
1058
+ return current;
1059
+ }
1060
+
1061
+ function canonicalizeFilter(filter: any): string {
1062
+ return JSON.stringify(sortKeys(filter));
1063
+ }
1064
+
1065
+ function sortKeys(value: any): any {
1066
+ if (Array.isArray(value)) {
1067
+ return value.map(item => sortKeys(item));
1068
+ }
1069
+
1070
+ if (value && typeof value === 'object') {
1071
+ const sorted = {};
1072
+ const keys = Object.keys(value).sort();
1073
+
1074
+ for (const key of keys) {
1075
+ sorted[key] = sortKeys(value[key]);
1076
+ }
1077
+
1078
+ return sorted;
1079
+ }
1080
+
1081
+ return value;
1082
+ }
1083
+
1084
+ function dedupeFilters(filters: any[]): any[] {
1085
+ const map = new Map<string, any>();
1086
+
1087
+ for (const filter of filters) {
1088
+ const key = canonicalizeFilter(filter);
1089
+
1090
+ if (!map.has(key)) {
1091
+ map.set(key, filter);
1092
+ }
1093
+ }
1094
+
1095
+ return Array.from(map.values());
1096
+ }