@resolveio/server-lib 22.3.221 → 22.3.222

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (745) hide show
  1. package/ai/assistant-core-heuristics.d.ts +11 -0
  2. package/ai/assistant-core-heuristics.js +356 -0
  3. package/ai/assistant-core-heuristics.js.map +1 -0
  4. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +3 -0
  5. package/ai/resolveio-platform-intelligence-memory-corpus.js +214 -0
  6. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +1 -0
  7. package/ai/resolveio-platform-intelligence-memory.d.ts +20 -0
  8. package/ai/resolveio-platform-intelligence-memory.js +341 -0
  9. package/ai/resolveio-platform-intelligence-memory.js.map +1 -0
  10. package/{src/ai/resolveio-platform-intelligence-types.ts → ai/resolveio-platform-intelligence-types.d.ts} +15 -20
  11. package/ai/resolveio-platform-intelligence-types.js +4 -0
  12. package/ai/resolveio-platform-intelligence-types.js.map +1 -0
  13. package/ai/resolveio-platform-intelligence.d.ts +6 -0
  14. package/ai/resolveio-platform-intelligence.js +463 -0
  15. package/ai/resolveio-platform-intelligence.js.map +1 -0
  16. package/client-server-app.d.ts +1 -0
  17. package/client-server-app.js +68 -0
  18. package/client-server-app.js.map +1 -0
  19. package/collections/ai-run.collection.d.ts +3 -0
  20. package/collections/ai-run.collection.js +170 -0
  21. package/collections/ai-run.collection.js.map +1 -0
  22. package/collections/ai-terminal-conversation.collection.d.ts +2 -0
  23. package/collections/ai-terminal-conversation.collection.js +140 -0
  24. package/collections/ai-terminal-conversation.collection.js.map +1 -0
  25. package/collections/ai-terminal-issue-report.collection.d.ts +2 -0
  26. package/collections/ai-terminal-issue-report.collection.js +148 -0
  27. package/collections/ai-terminal-issue-report.collection.js.map +1 -0
  28. package/collections/ai-terminal-message.collection.d.ts +2 -0
  29. package/collections/ai-terminal-message.collection.js +121 -0
  30. package/collections/ai-terminal-message.collection.js.map +1 -0
  31. package/collections/app-setting.collection.d.ts +3 -0
  32. package/collections/app-setting.collection.js +103 -0
  33. package/collections/app-setting.collection.js.map +1 -0
  34. package/collections/app-status.collection.d.ts +3 -0
  35. package/collections/app-status.collection.js +57 -0
  36. package/collections/app-status.collection.js.map +1 -0
  37. package/collections/communication-metric.collection.d.ts +2 -0
  38. package/collections/communication-metric.collection.js +133 -0
  39. package/collections/communication-metric.collection.js.map +1 -0
  40. package/collections/counter.collection.d.ts +3 -0
  41. package/collections/counter.collection.js +56 -0
  42. package/collections/counter.collection.js.map +1 -0
  43. package/collections/cron-job-history.collection.d.ts +3 -0
  44. package/collections/cron-job-history.collection.js +137 -0
  45. package/collections/cron-job-history.collection.js.map +1 -0
  46. package/collections/cron-job.collection.d.ts +3 -0
  47. package/collections/cron-job.collection.js +92 -0
  48. package/collections/cron-job.collection.js.map +1 -0
  49. package/collections/customer-notification.collection.d.ts +3 -0
  50. package/collections/customer-notification.collection.js +130 -0
  51. package/collections/customer-notification.collection.js.map +1 -0
  52. package/collections/customer-portal-password.collection.d.ts +3 -0
  53. package/collections/customer-portal-password.collection.js +75 -0
  54. package/collections/customer-portal-password.collection.js.map +1 -0
  55. package/collections/email-history.collection.d.ts +3 -0
  56. package/collections/email-history.collection.js +134 -0
  57. package/collections/email-history.collection.js.map +1 -0
  58. package/collections/email-verified.collection.d.ts +3 -0
  59. package/collections/email-verified.collection.js +62 -0
  60. package/collections/email-verified.collection.js.map +1 -0
  61. package/collections/file.collection.d.ts +3 -0
  62. package/collections/file.collection.js +74 -0
  63. package/collections/file.collection.js.map +1 -0
  64. package/collections/flag-update.collection.d.ts +3 -0
  65. package/collections/flag-update.collection.js +57 -0
  66. package/collections/flag-update.collection.js.map +1 -0
  67. package/collections/flag.collection.d.ts +3 -0
  68. package/collections/flag.collection.js +57 -0
  69. package/collections/flag.collection.js.map +1 -0
  70. package/collections/log-method-latency.collection.d.ts +3 -0
  71. package/collections/log-method-latency.collection.js +77 -0
  72. package/collections/log-method-latency.collection.js.map +1 -0
  73. package/collections/log-subscription.collection.d.ts +3 -0
  74. package/collections/log-subscription.collection.js +80 -0
  75. package/collections/log-subscription.collection.js.map +1 -0
  76. package/collections/log.collection.d.ts +3 -0
  77. package/collections/log.collection.js +93 -0
  78. package/collections/log.collection.js.map +1 -0
  79. package/collections/logged-in-users.collection.d.ts +3 -0
  80. package/collections/logged-in-users.collection.js +67 -0
  81. package/collections/logged-in-users.collection.js.map +1 -0
  82. package/collections/monitor-cpu.collection.d.ts +3 -0
  83. package/collections/monitor-cpu.collection.js +65 -0
  84. package/collections/monitor-cpu.collection.js.map +1 -0
  85. package/collections/monitor-function.collection.d.ts +3 -0
  86. package/collections/monitor-function.collection.js +74 -0
  87. package/collections/monitor-function.collection.js.map +1 -0
  88. package/collections/monitor-memory.collection.d.ts +3 -0
  89. package/collections/monitor-memory.collection.js +77 -0
  90. package/collections/monitor-memory.collection.js.map +1 -0
  91. package/collections/monitor-mongo.collection.d.ts +3 -0
  92. package/collections/monitor-mongo.collection.js +71 -0
  93. package/collections/monitor-mongo.collection.js.map +1 -0
  94. package/collections/notification.collection.d.ts +3 -0
  95. package/collections/notification.collection.js +57 -0
  96. package/collections/notification.collection.js.map +1 -0
  97. package/collections/openai-usage-ledger.collection.d.ts +2 -0
  98. package/collections/openai-usage-ledger.collection.js +188 -0
  99. package/collections/openai-usage-ledger.collection.js.map +1 -0
  100. package/collections/report-builder-dashboard-builder.collection.d.ts +3 -0
  101. package/collections/report-builder-dashboard-builder.collection.js +109 -0
  102. package/collections/report-builder-dashboard-builder.collection.js.map +1 -0
  103. package/collections/report-builder-library.collection.d.ts +3 -0
  104. package/collections/report-builder-library.collection.js +87 -0
  105. package/collections/report-builder-library.collection.js.map +1 -0
  106. package/collections/report-builder-report.collection.d.ts +4 -0
  107. package/collections/report-builder-report.collection.js +184 -0
  108. package/collections/report-builder-report.collection.js.map +1 -0
  109. package/collections/user-group.collection.d.ts +4 -0
  110. package/collections/user-group.collection.js +89 -0
  111. package/collections/user-group.collection.js.map +1 -0
  112. package/collections/user-guide.collection.d.ts +3 -0
  113. package/collections/user-guide.collection.js +57 -0
  114. package/collections/user-guide.collection.js.map +1 -0
  115. package/collections/user.collection.d.ts +4 -0
  116. package/collections/user.collection.js +180 -0
  117. package/collections/user.collection.js.map +1 -0
  118. package/cron/cron.d.ts +14 -0
  119. package/cron/cron.js +216 -0
  120. package/cron/cron.js.map +1 -0
  121. package/fixtures/cron-jobs.d.ts +1 -0
  122. package/fixtures/cron-jobs.js +150 -0
  123. package/fixtures/cron-jobs.js.map +1 -0
  124. package/fixtures/init.d.ts +1 -0
  125. package/fixtures/init.js +91 -0
  126. package/fixtures/init.js.map +1 -0
  127. package/http/auth.d.ts +2 -0
  128. package/http/auth.js +951 -0
  129. package/http/auth.js.map +1 -0
  130. package/http/health.d.ts +1 -0
  131. package/http/health.js +11 -0
  132. package/http/health.js.map +1 -0
  133. package/http/home.d.ts +1 -0
  134. package/http/home.js +134 -0
  135. package/http/home.js.map +1 -0
  136. package/http/slow-query-publication.d.ts +2 -0
  137. package/http/slow-query-publication.js +99 -0
  138. package/http/slow-query-publication.js.map +1 -0
  139. package/index.d.ts +1 -0
  140. package/index.js +19 -0
  141. package/index.js.map +1 -0
  142. package/managers/ai-assistant-codex-manager.manager.d.ts +67 -0
  143. package/managers/ai-assistant-codex-manager.manager.js +1113 -0
  144. package/managers/ai-assistant-codex-manager.manager.js.map +1 -0
  145. package/managers/ai-run-evidence.manager.d.ts +36 -0
  146. package/managers/ai-run-evidence.manager.js +377 -0
  147. package/managers/ai-run-evidence.manager.js.map +1 -0
  148. package/managers/communication-metric.manager.d.ts +16 -0
  149. package/managers/communication-metric.manager.js +134 -0
  150. package/managers/communication-metric.manager.js.map +1 -0
  151. package/managers/cron.manager.d.ts +20 -0
  152. package/managers/cron.manager.js +534 -0
  153. package/managers/cron.manager.js.map +1 -0
  154. package/managers/customer-notification-content.manager.d.ts +55 -0
  155. package/managers/customer-notification-content.manager.js +158 -0
  156. package/managers/customer-notification-content.manager.js.map +1 -0
  157. package/managers/diagnostic-manager-bootstrap.d.ts +9 -0
  158. package/managers/diagnostic-manager-bootstrap.js +260 -0
  159. package/managers/diagnostic-manager-bootstrap.js.map +1 -0
  160. package/managers/error-auto-fix.manager.d.ts +149 -0
  161. package/managers/error-auto-fix.manager.js +3064 -0
  162. package/managers/error-auto-fix.manager.js.map +1 -0
  163. package/managers/local-log.manager.d.ts +18 -0
  164. package/managers/local-log.manager.js +88 -0
  165. package/managers/local-log.manager.js.map +1 -0
  166. package/managers/method.manager.d.ts +84 -0
  167. package/managers/method.manager.js +1964 -0
  168. package/managers/method.manager.js.map +1 -0
  169. package/managers/mongo.manager.d.ts +224 -0
  170. package/managers/mongo.manager.js +5000 -0
  171. package/managers/mongo.manager.js.map +1 -0
  172. package/managers/monitor.manager.d.ts +70 -0
  173. package/managers/monitor.manager.js +550 -0
  174. package/managers/monitor.manager.js.map +1 -0
  175. package/managers/openai-usage-ledger.manager.d.ts +30 -0
  176. package/managers/openai-usage-ledger.manager.js +142 -0
  177. package/managers/openai-usage-ledger.manager.js.map +1 -0
  178. package/managers/slow-query-verifier.manager.d.ts +144 -0
  179. package/managers/slow-query-verifier.manager.js +3857 -0
  180. package/managers/slow-query-verifier.manager.js.map +1 -0
  181. package/managers/slow-query.manager.d.ts +28 -0
  182. package/managers/slow-query.manager.js +468 -0
  183. package/managers/slow-query.manager.js.map +1 -0
  184. package/managers/subscription.manager.d.ts +169 -0
  185. package/managers/subscription.manager.js +3434 -0
  186. package/managers/subscription.manager.js.map +1 -0
  187. package/managers/websocket.manager.d.ts +73 -0
  188. package/managers/websocket.manager.js +673 -0
  189. package/managers/websocket.manager.js.map +1 -0
  190. package/managers/worker-dispatcher.manager.d.ts +120 -0
  191. package/managers/worker-dispatcher.manager.js +1266 -0
  192. package/managers/worker-dispatcher.manager.js.map +1 -0
  193. package/managers/worker-server.manager.d.ts +35 -0
  194. package/managers/worker-server.manager.js +582 -0
  195. package/managers/worker-server.manager.js.map +1 -0
  196. package/methods/accounts.d.ts +2 -0
  197. package/methods/accounts.js +624 -0
  198. package/methods/accounts.js.map +1 -0
  199. package/methods/ai-terminal.d.ts +458 -0
  200. package/methods/ai-terminal.js +27991 -0
  201. package/methods/ai-terminal.js.map +1 -0
  202. package/methods/app-settings.d.ts +2 -0
  203. package/methods/app-settings.js +169 -0
  204. package/methods/app-settings.js.map +1 -0
  205. package/methods/aws.d.ts +2 -0
  206. package/methods/aws.js +877 -0
  207. package/methods/aws.js.map +1 -0
  208. package/methods/collections.d.ts +2 -0
  209. package/methods/collections.js +719 -0
  210. package/methods/collections.js.map +1 -0
  211. package/methods/counters.d.ts +2 -0
  212. package/methods/counters.js +113 -0
  213. package/methods/counters.js.map +1 -0
  214. package/methods/cron-jobs.d.ts +2 -0
  215. package/methods/cron-jobs.js +2475 -0
  216. package/methods/cron-jobs.js.map +1 -0
  217. package/methods/customer-notifications.d.ts +2 -0
  218. package/methods/customer-notifications.js +528 -0
  219. package/methods/customer-notifications.js.map +1 -0
  220. package/methods/diagnostics.d.ts +2 -0
  221. package/methods/diagnostics.js +703 -0
  222. package/methods/diagnostics.js.map +1 -0
  223. package/methods/flag-updates.d.ts +2 -0
  224. package/methods/flag-updates.js +8 -0
  225. package/methods/flag-updates.js.map +1 -0
  226. package/methods/flags.d.ts +2 -0
  227. package/methods/flags.js +8 -0
  228. package/methods/flags.js.map +1 -0
  229. package/methods/logs.d.ts +2 -0
  230. package/methods/logs.js +751 -0
  231. package/methods/logs.js.map +1 -0
  232. package/methods/mongo-explorer.d.ts +2 -0
  233. package/methods/mongo-explorer.js +1808 -0
  234. package/methods/mongo-explorer.js.map +1 -0
  235. package/methods/monitor.d.ts +2 -0
  236. package/methods/monitor.js +543 -0
  237. package/methods/monitor.js.map +1 -0
  238. package/methods/pdf.d.ts +2 -0
  239. package/methods/pdf.js +1216 -0
  240. package/methods/pdf.js.map +1 -0
  241. package/methods/publications.d.ts +1 -0
  242. package/methods/publications.js +183 -0
  243. package/methods/publications.js.map +1 -0
  244. package/methods/report-builder.d.ts +2 -0
  245. package/methods/report-builder.js +3094 -0
  246. package/methods/report-builder.js.map +1 -0
  247. package/methods/support.d.ts +2 -0
  248. package/methods/support.js +430 -0
  249. package/methods/support.js.map +1 -0
  250. package/models/ai-run.model.d.ts +19 -0
  251. package/models/ai-run.model.js +4 -0
  252. package/models/ai-run.model.js.map +1 -0
  253. package/models/ai-terminal-conversation.model.d.ts +17 -0
  254. package/models/ai-terminal-conversation.model.js +4 -0
  255. package/models/ai-terminal-conversation.model.js.map +1 -0
  256. package/models/ai-terminal-issue-report.model.d.ts +19 -0
  257. package/models/ai-terminal-issue-report.model.js +4 -0
  258. package/models/ai-terminal-issue-report.model.js.map +1 -0
  259. package/models/ai-terminal-message.model.d.ts +22 -0
  260. package/models/ai-terminal-message.model.js +4 -0
  261. package/models/ai-terminal-message.model.js.map +1 -0
  262. package/models/app-setting.model.d.ts +16 -0
  263. package/models/app-setting.model.js +4 -0
  264. package/models/app-setting.model.js.map +1 -0
  265. package/{src/models/app-status.model.ts → models/app-status.model.d.ts} +2 -3
  266. package/models/app-status.model.js +4 -0
  267. package/models/app-status.model.js.map +1 -0
  268. package/{src/models/billing-logged-in-users.model.ts → models/billing-logged-in-users.model.d.ts} +4 -5
  269. package/models/billing-logged-in-users.model.js +4 -0
  270. package/models/billing-logged-in-users.model.js.map +1 -0
  271. package/models/collection-document.model.d.ts +21 -0
  272. package/models/collection-document.model.js +4 -0
  273. package/models/collection-document.model.js.map +1 -0
  274. package/models/communication-metric.model.d.ts +20 -0
  275. package/models/communication-metric.model.js +4 -0
  276. package/models/communication-metric.model.js.map +1 -0
  277. package/{src/models/counter.model.ts → models/counter.model.d.ts} +3 -4
  278. package/models/counter.model.js +4 -0
  279. package/models/counter.model.js.map +1 -0
  280. package/models/cron-job-history.model.d.ts +15 -0
  281. package/models/cron-job-history.model.js +4 -0
  282. package/models/cron-job-history.model.js.map +1 -0
  283. package/models/cron-job.model.d.ts +14 -0
  284. package/models/cron-job.model.js +4 -0
  285. package/models/cron-job.model.js.map +1 -0
  286. package/models/customer-notification.model.d.ts +26 -0
  287. package/models/customer-notification.model.js +4 -0
  288. package/models/customer-notification.model.js.map +1 -0
  289. package/models/customer-portal-password.model.d.ts +11 -0
  290. package/models/customer-portal-password.model.js +4 -0
  291. package/models/customer-portal-password.model.js.map +1 -0
  292. package/models/dialog.model.d.ts +23 -0
  293. package/models/dialog.model.js +4 -0
  294. package/models/dialog.model.js.map +1 -0
  295. package/models/email-history.model.d.ts +32 -0
  296. package/{src/models/email-history.model.ts → models/email-history.model.js} +4 -36
  297. package/models/email-history.model.js.map +1 -0
  298. package/{src/models/email-verified.model.ts → models/email-verified.model.d.ts} +5 -6
  299. package/models/email-verified.model.js +4 -0
  300. package/models/email-verified.model.js.map +1 -0
  301. package/{src/models/file.model.ts → models/file.model.d.ts} +7 -8
  302. package/models/file.model.js +4 -0
  303. package/models/file.model.js.map +1 -0
  304. package/{src/models/flag-update.model.ts → models/flag-update.model.d.ts} +3 -4
  305. package/models/flag-update.model.js +4 -0
  306. package/models/flag-update.model.js.map +1 -0
  307. package/{src/models/flag.model.ts → models/flag.model.d.ts} +3 -4
  308. package/models/flag.model.js +4 -0
  309. package/models/flag.model.js.map +1 -0
  310. package/models/log-method-latency.model.d.ts +10 -0
  311. package/models/log-method-latency.model.js +4 -0
  312. package/models/log-method-latency.model.js.map +1 -0
  313. package/{src/models/log-subscription.model.ts → models/log-subscription.model.d.ts} +9 -11
  314. package/models/log-subscription.model.js +4 -0
  315. package/models/log-subscription.model.js.map +1 -0
  316. package/models/log.model.d.ts +17 -0
  317. package/models/log.model.js +4 -0
  318. package/models/log.model.js.map +1 -0
  319. package/{src/models/logged-in-users.model.ts → models/logged-in-users.model.d.ts} +5 -6
  320. package/models/logged-in-users.model.js +4 -0
  321. package/models/logged-in-users.model.js.map +1 -0
  322. package/{src/models/method-response.model.ts → models/method-response.model.d.ts} +6 -7
  323. package/models/method-response.model.js +4 -0
  324. package/models/method-response.model.js.map +1 -0
  325. package/models/method.model.d.ts +26 -0
  326. package/models/method.model.js +4 -0
  327. package/models/method.model.js.map +1 -0
  328. package/{src/models/monitor-cpu.model.ts → models/monitor-cpu.model.d.ts} +7 -9
  329. package/models/monitor-cpu.model.js +4 -0
  330. package/models/monitor-cpu.model.js.map +1 -0
  331. package/models/monitor-function.model.d.ts +14 -0
  332. package/models/monitor-function.model.js +4 -0
  333. package/models/monitor-function.model.js.map +1 -0
  334. package/models/monitor-memory.model.d.ts +15 -0
  335. package/models/monitor-memory.model.js +4 -0
  336. package/models/monitor-memory.model.js.map +1 -0
  337. package/models/monitor-mongo.model.d.ts +13 -0
  338. package/models/monitor-mongo.model.js +4 -0
  339. package/models/monitor-mongo.model.js.map +1 -0
  340. package/{src/models/notification.model.ts → models/notification.model.d.ts} +4 -6
  341. package/models/notification.model.js +4 -0
  342. package/models/notification.model.js.map +1 -0
  343. package/models/openai-usage-ledger.model.d.ts +30 -0
  344. package/models/openai-usage-ledger.model.js +4 -0
  345. package/models/openai-usage-ledger.model.js.map +1 -0
  346. package/models/pagination.model.d.ts +11 -0
  347. package/models/pagination.model.js +28 -0
  348. package/models/pagination.model.js.map +1 -0
  349. package/models/permission.model.d.ts +12 -0
  350. package/models/permission.model.js +4 -0
  351. package/models/permission.model.js.map +1 -0
  352. package/models/report-builder-dashboard-builder.model.d.ts +25 -0
  353. package/models/report-builder-dashboard-builder.model.js +4 -0
  354. package/models/report-builder-dashboard-builder.model.js.map +1 -0
  355. package/models/report-builder-library.model.d.ts +17 -0
  356. package/models/report-builder-library.model.js +4 -0
  357. package/models/report-builder-library.model.js.map +1 -0
  358. package/models/report-builder-report.model.d.ts +121 -0
  359. package/models/report-builder-report.model.js +4 -0
  360. package/models/report-builder-report.model.js.map +1 -0
  361. package/models/report-builder.model.d.ts +61 -0
  362. package/models/report-builder.model.js +4 -0
  363. package/models/report-builder.model.js.map +1 -0
  364. package/models/select-data-label.model.d.ts +9 -0
  365. package/models/select-data-label.model.js +4 -0
  366. package/models/select-data-label.model.js.map +1 -0
  367. package/models/server-message.model.d.ts +32 -0
  368. package/models/server-message.model.js +4 -0
  369. package/models/server-message.model.js.map +1 -0
  370. package/models/slow-query-report.model.d.ts +23 -0
  371. package/models/slow-query-report.model.js +4 -0
  372. package/models/slow-query-report.model.js.map +1 -0
  373. package/models/subscription.model.d.ts +31 -0
  374. package/models/subscription.model.js +4 -0
  375. package/models/subscription.model.js.map +1 -0
  376. package/models/support-ticket.model.d.ts +87 -0
  377. package/models/support-ticket.model.js +4 -0
  378. package/models/support-ticket.model.js.map +1 -0
  379. package/models/user-group.model.d.ts +20 -0
  380. package/models/user-group.model.js +4 -0
  381. package/models/user-group.model.js.map +1 -0
  382. package/{src/models/user-guide.model.ts → models/user-guide.model.d.ts} +4 -5
  383. package/models/user-guide.model.js +4 -0
  384. package/models/user-guide.model.js.map +1 -0
  385. package/models/user.model.d.ts +84 -0
  386. package/models/user.model.js +4 -0
  387. package/models/user.model.js.map +1 -0
  388. package/package.json +1 -1
  389. package/private/images/ResolveIO.png +0 -0
  390. package/public_api.js +127 -0
  391. package/public_api.js.map +1 -0
  392. package/publications/ai-terminal.d.ts +1 -0
  393. package/publications/ai-terminal.js +122 -0
  394. package/publications/ai-terminal.js.map +1 -0
  395. package/publications/app-settings.d.ts +2 -0
  396. package/publications/app-settings.js +28 -0
  397. package/publications/app-settings.js.map +1 -0
  398. package/publications/app-status.d.ts +2 -0
  399. package/publications/app-status.js +16 -0
  400. package/publications/app-status.js.map +1 -0
  401. package/publications/cron-jobs.d.ts +2 -0
  402. package/publications/cron-jobs.js +88 -0
  403. package/publications/cron-jobs.js.map +1 -0
  404. package/publications/customer-notifications.d.ts +2 -0
  405. package/publications/customer-notifications.js +161 -0
  406. package/publications/customer-notifications.js.map +1 -0
  407. package/publications/files.d.ts +2 -0
  408. package/publications/files.js +36 -0
  409. package/publications/files.js.map +1 -0
  410. package/publications/flags-update.d.ts +2 -0
  411. package/publications/flags-update.js +22 -0
  412. package/publications/flags-update.js.map +1 -0
  413. package/publications/flags.d.ts +2 -0
  414. package/publications/flags.js +22 -0
  415. package/publications/flags.js.map +1 -0
  416. package/publications/logs.d.ts +2 -0
  417. package/publications/logs.js +164 -0
  418. package/publications/logs.js.map +1 -0
  419. package/publications/notifications.d.ts +2 -0
  420. package/publications/notifications.js +16 -0
  421. package/publications/notifications.js.map +1 -0
  422. package/publications/report-builder-dashboard-builders.d.ts +2 -0
  423. package/publications/report-builder-dashboard-builders.js +42 -0
  424. package/publications/report-builder-dashboard-builders.js.map +1 -0
  425. package/publications/report-builder-libraries.d.ts +2 -0
  426. package/publications/report-builder-libraries.js +90 -0
  427. package/publications/report-builder-libraries.js.map +1 -0
  428. package/publications/report-builder-reports.d.ts +2 -0
  429. package/publications/report-builder-reports.js +50 -0
  430. package/publications/report-builder-reports.js.map +1 -0
  431. package/publications/super-admin.d.ts +2 -0
  432. package/publications/super-admin.js +16 -0
  433. package/publications/super-admin.js.map +1 -0
  434. package/publications/user-groups.d.ts +1 -0
  435. package/publications/user-groups.js +16 -0
  436. package/publications/user-groups.js.map +1 -0
  437. package/publications/user-guides.d.ts +1 -0
  438. package/publications/user-guides.js +16 -0
  439. package/publications/user-guides.js.map +1 -0
  440. package/resolveio-server-app.d.ts +70 -0
  441. package/resolveio-server-app.js +801 -0
  442. package/resolveio-server-app.js.map +1 -0
  443. package/server-app.d.ts +228 -0
  444. package/server-app.js +3566 -0
  445. package/server-app.js.map +1 -0
  446. package/services/codex-client.d.ts +128 -0
  447. package/services/codex-client.js +1629 -0
  448. package/services/codex-client.js.map +1 -0
  449. package/services/openai-client.d.ts +46 -0
  450. package/services/openai-client.js +318 -0
  451. package/services/openai-client.js.map +1 -0
  452. package/types/error-report.d.ts +25 -0
  453. package/types/error-report.js +4 -0
  454. package/types/error-report.js.map +1 -0
  455. package/types/slow-query-report.d.ts +27 -0
  456. package/types/slow-query-report.js +6 -0
  457. package/types/slow-query-report.js.map +1 -0
  458. package/util/ai-qa-policy.d.ts +124 -0
  459. package/util/ai-qa-policy.js +736 -0
  460. package/util/ai-qa-policy.js.map +1 -0
  461. package/util/ai-run-evidence-adapters.d.ts +109 -0
  462. package/util/ai-run-evidence-adapters.js +7234 -0
  463. package/util/ai-run-evidence-adapters.js.map +1 -0
  464. package/util/ai-run-evidence-dashboard.d.ts +88 -0
  465. package/util/ai-run-evidence-dashboard.js +343 -0
  466. package/util/ai-run-evidence-dashboard.js.map +1 -0
  467. package/util/ai-run-evidence-eval.d.ts +86 -0
  468. package/util/ai-run-evidence-eval.js +1018 -0
  469. package/util/ai-run-evidence-eval.js.map +1 -0
  470. package/util/ai-run-evidence.d.ts +244 -0
  471. package/util/ai-run-evidence.js +1096 -0
  472. package/util/ai-run-evidence.js.map +1 -0
  473. package/util/ai-runner-artifacts.d.ts +82 -0
  474. package/util/ai-runner-artifacts.js +713 -0
  475. package/util/ai-runner-artifacts.js.map +1 -0
  476. package/util/ai-runner-manager-autopilot.d.ts +210 -0
  477. package/util/ai-runner-manager-autopilot.js +642 -0
  478. package/util/ai-runner-manager-autopilot.js.map +1 -0
  479. package/util/ai-runner-manager-policy.d.ts +807 -0
  480. package/util/ai-runner-manager-policy.js +3501 -0
  481. package/util/ai-runner-manager-policy.js.map +1 -0
  482. package/util/ai-runner-qa-auth.d.ts +5 -0
  483. package/util/ai-runner-qa-auth.js +839 -0
  484. package/util/ai-runner-qa-auth.js.map +1 -0
  485. package/util/ai-runner-qa-tools.d.ts +26 -0
  486. package/util/ai-runner-qa-tools.js +3520 -0
  487. package/util/ai-runner-qa-tools.js.map +1 -0
  488. package/util/aicoder-runner-v6.d.ts +426 -0
  489. package/util/aicoder-runner-v6.js +2464 -0
  490. package/util/aicoder-runner-v6.js.map +1 -0
  491. package/util/common.d.ts +31 -0
  492. package/util/common.js +683 -0
  493. package/util/common.js.map +1 -0
  494. package/util/customer-portal-password.d.ts +13 -0
  495. package/util/customer-portal-password.js +209 -0
  496. package/util/customer-portal-password.js.map +1 -0
  497. package/util/error-reporter.d.ts +52 -0
  498. package/util/error-reporter.js +326 -0
  499. package/util/error-reporter.js.map +1 -0
  500. package/util/error-tracking.d.ts +13 -0
  501. package/util/error-tracking.js +120 -0
  502. package/util/error-tracking.js.map +1 -0
  503. package/util/openai-usage-cost.d.ts +6 -0
  504. package/util/openai-usage-cost.js +103 -0
  505. package/util/openai-usage-cost.js.map +1 -0
  506. package/util/report-builder-unwinds.d.ts +15 -0
  507. package/util/report-builder-unwinds.js +156 -0
  508. package/util/report-builder-unwinds.js.map +1 -0
  509. package/util/runner-process-janitor.d.ts +27 -0
  510. package/util/runner-process-janitor.js +208 -0
  511. package/util/runner-process-janitor.js.map +1 -0
  512. package/util/schema-report-builder.d.ts +6 -0
  513. package/util/schema-report-builder.js +481 -0
  514. package/util/schema-report-builder.js.map +1 -0
  515. package/util/slow-query-reporter.d.ts +28 -0
  516. package/util/slow-query-reporter.js +226 -0
  517. package/util/slow-query-reporter.js.map +1 -0
  518. package/util/subscription-dependency-context.d.ts +34 -0
  519. package/util/subscription-dependency-context.js +1283 -0
  520. package/util/subscription-dependency-context.js.map +1 -0
  521. package/util/support-runner-v5.d.ts +1426 -0
  522. package/util/support-runner-v5.js +7643 -0
  523. package/util/support-runner-v5.js.map +1 -0
  524. package/util/tokenizer.d.ts +5 -0
  525. package/util/tokenizer.js +41 -0
  526. package/util/tokenizer.js.map +1 -0
  527. package/workers/codex-runner.worker.d.ts +1 -0
  528. package/workers/codex-runner.worker.js +192 -0
  529. package/workers/codex-runner.worker.js.map +1 -0
  530. package/.nodemon.json +0 -5
  531. package/.vscode/settings.json +0 -21
  532. package/AGENTS.md +0 -195
  533. package/README.md +0 -22
  534. package/build_package.sh +0 -5
  535. package/compileDTS.pl +0 -64
  536. package/docs/ai-assistant-nightly-eval.md +0 -65
  537. package/docs/ai-assistant-preflight-checklist.md +0 -23
  538. package/docs/ai-assistant-report-builder-bridge-playbook.md +0 -115
  539. package/eslint-plugin-custom/index.js +0 -7
  540. package/eslint-plugin-custom/rules/no-filter-zero-index.js +0 -44
  541. package/eslint.config.js +0 -103
  542. package/gulpfile.js +0 -216
  543. package/methodAndPublicationListGenerator.py +0 -375
  544. package/mongodbensurers.js +0 -2
  545. package/mongostop.js +0 -3
  546. package/scripts/cleanup-bypassed-callmethod-logs.js +0 -616
  547. package/settings.development.json +0 -25
  548. package/settings.development.redacted.json +0 -25
  549. package/src/.env +0 -12
  550. package/src/ai/assistant-core-heuristics.ts +0 -379
  551. package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +0 -185
  552. package/src/ai/resolveio-platform-intelligence-memory.ts +0 -325
  553. package/src/ai/resolveio-platform-intelligence.ts +0 -462
  554. package/src/client-server-app.ts +0 -12
  555. package/src/collections/ai-run.collection.ts +0 -117
  556. package/src/collections/ai-terminal-conversation.collection.ts +0 -91
  557. package/src/collections/ai-terminal-issue-report.collection.ts +0 -99
  558. package/src/collections/ai-terminal-message.collection.ts +0 -77
  559. package/src/collections/app-setting.collection.ts +0 -104
  560. package/src/collections/app-status.collection.ts +0 -58
  561. package/src/collections/communication-metric.collection.ts +0 -84
  562. package/src/collections/counter.collection.ts +0 -56
  563. package/src/collections/cron-job-history.collection.ts +0 -94
  564. package/src/collections/cron-job.collection.ts +0 -92
  565. package/src/collections/customer-notification.collection.ts +0 -131
  566. package/src/collections/customer-portal-password.collection.ts +0 -76
  567. package/src/collections/email-history.collection.ts +0 -134
  568. package/src/collections/email-verified.collection.ts +0 -62
  569. package/src/collections/file.collection.ts +0 -74
  570. package/src/collections/flag-update.collection.ts +0 -57
  571. package/src/collections/flag.collection.ts +0 -57
  572. package/src/collections/log-method-latency.collection.ts +0 -77
  573. package/src/collections/log-subscription.collection.ts +0 -80
  574. package/src/collections/log.collection.ts +0 -93
  575. package/src/collections/logged-in-users.collection.ts +0 -67
  576. package/src/collections/monitor-cpu.collection.ts +0 -65
  577. package/src/collections/monitor-function.collection.ts +0 -74
  578. package/src/collections/monitor-memory.collection.ts +0 -77
  579. package/src/collections/monitor-mongo.collection.ts +0 -71
  580. package/src/collections/notification.collection.ts +0 -57
  581. package/src/collections/openai-usage-ledger.collection.ts +0 -131
  582. package/src/collections/report-builder-dashboard-builder.collection.ts +0 -109
  583. package/src/collections/report-builder-library.collection.ts +0 -89
  584. package/src/collections/report-builder-report.collection.ts +0 -184
  585. package/src/collections/user-group.collection.ts +0 -89
  586. package/src/collections/user-guide.collection.ts +0 -57
  587. package/src/collections/user.collection.ts +0 -181
  588. package/src/cron/cron.ts +0 -117
  589. package/src/fixtures/cron-jobs.ts +0 -95
  590. package/src/fixtures/init.ts +0 -35
  591. package/src/http/auth.ts +0 -818
  592. package/src/http/health.ts +0 -7
  593. package/src/http/home.ts +0 -90
  594. package/src/http/slow-query-publication.ts +0 -49
  595. package/src/index.ts +0 -1
  596. package/src/managers/ai-assistant-codex-manager.manager.ts +0 -1131
  597. package/src/managers/ai-run-evidence.manager.ts +0 -264
  598. package/src/managers/communication-metric.manager.ts +0 -82
  599. package/src/managers/cron.manager.ts +0 -333
  600. package/src/managers/customer-notification-content.manager.ts +0 -236
  601. package/src/managers/diagnostic-manager-bootstrap.ts +0 -165
  602. package/src/managers/error-auto-fix.manager.ts +0 -2767
  603. package/src/managers/local-log.manager.ts +0 -113
  604. package/src/managers/method.manager.ts +0 -1857
  605. package/src/managers/mongo.manager.ts +0 -4575
  606. package/src/managers/monitor.manager.ts +0 -507
  607. package/src/managers/openai-usage-ledger.manager.ts +0 -112
  608. package/src/managers/slow-query-verifier.manager.ts +0 -3590
  609. package/src/managers/slow-query.manager.ts +0 -519
  610. package/src/managers/subscription.manager.ts +0 -3128
  611. package/src/managers/websocket.manager.ts +0 -746
  612. package/src/managers/worker-dispatcher.manager.ts +0 -1360
  613. package/src/managers/worker-server.manager.ts +0 -536
  614. package/src/methods/accounts.ts +0 -532
  615. package/src/methods/ai-terminal.ts +0 -29070
  616. package/src/methods/app-settings.ts +0 -114
  617. package/src/methods/aws.ts +0 -649
  618. package/src/methods/collections.ts +0 -641
  619. package/src/methods/counters.ts +0 -69
  620. package/src/methods/cron-jobs.ts +0 -2614
  621. package/src/methods/customer-notifications.ts +0 -458
  622. package/src/methods/diagnostics.ts +0 -616
  623. package/src/methods/flag-updates.ts +0 -7
  624. package/src/methods/flags.ts +0 -7
  625. package/src/methods/logs.ts +0 -657
  626. package/src/methods/mongo-explorer.ts +0 -1880
  627. package/src/methods/monitor.ts +0 -540
  628. package/src/methods/pdf.ts +0 -1236
  629. package/src/methods/publications.ts +0 -129
  630. package/src/methods/report-builder.ts +0 -3300
  631. package/src/methods/support.ts +0 -335
  632. package/src/models/ai-run.model.ts +0 -27
  633. package/src/models/ai-terminal-conversation.model.ts +0 -19
  634. package/src/models/ai-terminal-issue-report.model.ts +0 -21
  635. package/src/models/ai-terminal-message.model.ts +0 -24
  636. package/src/models/app-setting.model.ts +0 -17
  637. package/src/models/collection-document.model.ts +0 -24
  638. package/src/models/communication-metric.model.ts +0 -23
  639. package/src/models/cron-job-history.model.ts +0 -16
  640. package/src/models/cron-job.model.ts +0 -15
  641. package/src/models/customer-notification.model.ts +0 -28
  642. package/src/models/customer-portal-password.model.ts +0 -12
  643. package/src/models/dialog.model.ts +0 -25
  644. package/src/models/log-method-latency.model.ts +0 -11
  645. package/src/models/log.model.ts +0 -19
  646. package/src/models/method.model.ts +0 -25
  647. package/src/models/monitor-function.model.ts +0 -16
  648. package/src/models/monitor-memory.model.ts +0 -17
  649. package/src/models/monitor-mongo.model.ts +0 -15
  650. package/src/models/openai-usage-ledger.model.ts +0 -56
  651. package/src/models/pagination.model.ts +0 -35
  652. package/src/models/permission.model.ts +0 -14
  653. package/src/models/report-builder-dashboard-builder.model.ts +0 -29
  654. package/src/models/report-builder-library.model.ts +0 -20
  655. package/src/models/report-builder-report.model.ts +0 -136
  656. package/src/models/report-builder.model.ts +0 -68
  657. package/src/models/select-data-label.model.ts +0 -9
  658. package/src/models/server-message.model.ts +0 -31
  659. package/src/models/slow-query-report.model.ts +0 -23
  660. package/src/models/subscription.model.ts +0 -73
  661. package/src/models/support-ticket.model.ts +0 -104
  662. package/src/models/user-group.model.ts +0 -24
  663. package/src/models/user.model.ts +0 -96
  664. package/src/private/images/ResolveIO.png +0 -0
  665. package/src/publications/ai-terminal.ts +0 -73
  666. package/src/publications/app-settings.ts +0 -25
  667. package/src/publications/app-status.ts +0 -13
  668. package/src/publications/cron-jobs.ts +0 -40
  669. package/src/publications/customer-notifications.ts +0 -101
  670. package/src/publications/files.ts +0 -33
  671. package/src/publications/flags-update.ts +0 -19
  672. package/src/publications/flags.ts +0 -19
  673. package/src/publications/logs.ts +0 -163
  674. package/src/publications/notifications.ts +0 -13
  675. package/src/publications/report-builder-dashboard-builders.ts +0 -39
  676. package/src/publications/report-builder-libraries.ts +0 -41
  677. package/src/publications/report-builder-reports.ts +0 -47
  678. package/src/publications/super-admin.ts +0 -13
  679. package/src/publications/user-groups.ts +0 -12
  680. package/src/publications/user-guides.ts +0 -12
  681. package/src/resolveio-server-app.ts +0 -617
  682. package/src/server-app.ts +0 -3354
  683. package/src/services/codex-client.ts +0 -1231
  684. package/src/services/openai-client.ts +0 -265
  685. package/src/types/error-report.ts +0 -26
  686. package/src/types/js-tiktoken.d.ts +0 -11
  687. package/src/types/slow-query-report.ts +0 -28
  688. package/src/util/ai-qa-policy.ts +0 -925
  689. package/src/util/ai-run-evidence-adapters.ts +0 -8347
  690. package/src/util/ai-run-evidence-dashboard.ts +0 -323
  691. package/src/util/ai-run-evidence-eval.ts +0 -1057
  692. package/src/util/ai-run-evidence.ts +0 -1430
  693. package/src/util/ai-runner-artifacts.ts +0 -586
  694. package/src/util/ai-runner-manager-autopilot.ts +0 -961
  695. package/src/util/ai-runner-manager-policy.ts +0 -5011
  696. package/src/util/ai-runner-qa-auth.ts +0 -838
  697. package/src/util/ai-runner-qa-tools.ts +0 -3536
  698. package/src/util/aicoder-runner-v6.ts +0 -3121
  699. package/src/util/common.ts +0 -649
  700. package/src/util/customer-portal-password.ts +0 -183
  701. package/src/util/error-reporter.ts +0 -332
  702. package/src/util/error-tracking.ts +0 -79
  703. package/src/util/openai-usage-cost.ts +0 -114
  704. package/src/util/report-builder-unwinds.ts +0 -180
  705. package/src/util/runner-process-janitor.ts +0 -219
  706. package/src/util/schema-report-builder.ts +0 -448
  707. package/src/util/slow-query-reporter.ts +0 -216
  708. package/src/util/subscription-dependency-context.ts +0 -1096
  709. package/src/util/support-runner-v5.ts +0 -10040
  710. package/src/util/tokenizer.ts +0 -38
  711. package/src/workers/codex-runner.worker.ts +0 -142
  712. package/start_server.sh +0 -5
  713. package/tests/ai-assistant-corpus-build.ts +0 -484
  714. package/tests/ai-assistant-corpus-replay-e2e.ts +0 -774
  715. package/tests/ai-assistant-data-parity-e2e.ts +0 -1989
  716. package/tests/ai-assistant-eval-triage.ts +0 -831
  717. package/tests/ai-assistant-openai-e2e.ts +0 -1061
  718. package/tests/ai-assistant-openai-git-e2e.ts +0 -155
  719. package/tests/ai-assistant-preflight-matrix.ts +0 -215
  720. package/tests/ai-assistant-routing-eval.test.ts +0 -585
  721. package/tests/ai-assistant-snf-live-eval.ts +0 -975
  722. package/tests/ai-assistant-utils.test.ts +0 -4834
  723. package/tests/ai-manager-autopilot-snapshot.test.ts +0 -193
  724. package/tests/ai-manager-recovery-checkpoint.test.ts +0 -1383
  725. package/tests/ai-run-eval.test.ts +0 -132
  726. package/tests/ai-run-evidence.test.ts +0 -3773
  727. package/tests/ai-runner-contract.test.ts +0 -515
  728. package/tests/aicoder-runner-v6.test.ts +0 -822
  729. package/tests/error-reporter.test.ts +0 -145
  730. package/tests/method-publication-generator.test.ts +0 -46
  731. package/tests/report-builder-linking.test.ts +0 -79
  732. package/tests/resolveio-platform-intelligence.test.ts +0 -352
  733. package/tests/server-app-cron-owner.test.ts +0 -127
  734. package/tests/subscription-connect-race.test.ts +0 -158
  735. package/tests/subscription-dependency-context.test.ts +0 -324
  736. package/tests/subscription-manager-collection-tracking.test.ts +0 -86
  737. package/tests/subscription-manager-invalidation.test.ts +0 -86
  738. package/tests/support-runner-v5.test.ts +0 -3201
  739. package/tsconfig.json +0 -34
  740. /package/{src/private → private}/email-templates/enrollment.html +0 -0
  741. /package/{src/private → private}/email-templates/forgot-password.html +0 -0
  742. /package/{src/private → private}/email-templates/support-ticket-deleted.html +0 -0
  743. /package/{src/private → private}/email-templates/support-ticket-modified.html +0 -0
  744. /package/{src/private → private}/email-templates/support-ticket.html +0 -0
  745. /package/{src/public_api.ts → public_api.d.ts} +0 -0
@@ -1,1096 +0,0 @@
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
- }