@resolveio/server-lib 22.2.33 → 22.2.34

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (649) hide show
  1. package/.github/workflows/ai-assistant-nightly-eval.yml +224 -0
  2. package/.github/workflows/ai-assistant-pr-guardrails.yml +60 -0
  3. package/.nodemon.json +5 -0
  4. package/.vscode/settings.json +21 -0
  5. package/AGENTS.md +179 -0
  6. package/README.md +22 -0
  7. package/build_package.sh +5 -0
  8. package/compileDTS.pl +64 -0
  9. package/docs/ai-assistant-nightly-eval.md +65 -0
  10. package/docs/ai-assistant-preflight-checklist.md +23 -0
  11. package/docs/ai-assistant-report-builder-bridge-playbook.md +115 -0
  12. package/eslint-plugin-custom/index.js +7 -0
  13. package/eslint-plugin-custom/rules/no-filter-zero-index.js +44 -0
  14. package/eslint.config.js +103 -0
  15. package/gulpfile.js +216 -0
  16. package/methodAndPublicationListGenerator.py +319 -0
  17. package/mongodbensurers.js +2 -0
  18. package/mongostop.js +3 -0
  19. package/package.json +1 -1
  20. package/settings.development.json +25 -0
  21. package/settings.development.redacted.json +25 -0
  22. package/src/.env +12 -0
  23. package/src/ai/assistant-core-heuristics.ts +577 -0
  24. package/src/client-server-app.ts +12 -0
  25. package/src/collections/ai-terminal-conversation.collection.ts +91 -0
  26. package/src/collections/ai-terminal-issue-report.collection.ts +99 -0
  27. package/src/collections/ai-terminal-message.collection.ts +77 -0
  28. package/src/collections/app-setting.collection.ts +104 -0
  29. package/src/collections/app-status.collection.ts +58 -0
  30. package/src/collections/communication-metric.collection.ts +84 -0
  31. package/src/collections/counter.collection.ts +56 -0
  32. package/src/collections/cron-job-history.collection.ts +94 -0
  33. package/src/collections/cron-job.collection.ts +92 -0
  34. package/src/collections/customer-notification.collection.ts +131 -0
  35. package/src/collections/customer-portal-password.collection.ts +76 -0
  36. package/src/collections/email-history.collection.ts +121 -0
  37. package/src/collections/email-verified.collection.ts +61 -0
  38. package/src/collections/file.collection.ts +74 -0
  39. package/src/collections/flag-update.collection.ts +57 -0
  40. package/src/collections/flag.collection.ts +57 -0
  41. package/src/collections/log-method-latency.collection.ts +77 -0
  42. package/src/collections/log-subscription.collection.ts +80 -0
  43. package/src/collections/log.collection.ts +93 -0
  44. package/src/collections/logged-in-users.collection.ts +67 -0
  45. package/src/collections/monitor-cpu.collection.ts +65 -0
  46. package/src/collections/monitor-function.collection.ts +74 -0
  47. package/src/collections/monitor-memory.collection.ts +77 -0
  48. package/src/collections/monitor-mongo.collection.ts +71 -0
  49. package/src/collections/notification.collection.ts +57 -0
  50. package/src/collections/openai-usage-ledger.collection.ts +77 -0
  51. package/src/collections/report-builder-dashboard-builder.collection.ts +109 -0
  52. package/src/collections/report-builder-library.collection.ts +89 -0
  53. package/src/collections/report-builder-report.collection.ts +180 -0
  54. package/src/collections/user-group.collection.ts +89 -0
  55. package/src/collections/user-guide.collection.ts +57 -0
  56. package/src/collections/user.collection.ts +181 -0
  57. package/src/cron/cron.ts +117 -0
  58. package/src/fixtures/cron-jobs.ts +95 -0
  59. package/src/fixtures/init.ts +35 -0
  60. package/src/http/auth.ts +764 -0
  61. package/src/http/health.ts +7 -0
  62. package/src/http/home.ts +90 -0
  63. package/src/http/slow-query-publication.ts +49 -0
  64. package/src/index.ts +1 -0
  65. package/src/managers/communication-metric.manager.ts +82 -0
  66. package/src/managers/cron.manager.ts +333 -0
  67. package/src/managers/customer-notification-content.manager.ts +236 -0
  68. package/src/managers/diagnostic-manager-bootstrap.ts +165 -0
  69. package/src/managers/error-auto-fix.manager.ts +2767 -0
  70. package/src/managers/local-log.manager.ts +113 -0
  71. package/src/managers/method.manager.ts +1557 -0
  72. package/src/managers/mongo.manager.ts +4566 -0
  73. package/src/managers/monitor.manager.ts +489 -0
  74. package/src/managers/openai-usage-ledger.manager.ts +116 -0
  75. package/src/managers/slow-query-verifier.manager.ts +3590 -0
  76. package/src/managers/slow-query.manager.ts +519 -0
  77. package/src/managers/subscription.manager.ts +3120 -0
  78. package/src/managers/websocket.manager.ts +746 -0
  79. package/src/managers/worker-dispatcher.manager.ts +1318 -0
  80. package/src/managers/worker-server.manager.ts +468 -0
  81. package/src/methods/accounts.ts +532 -0
  82. package/src/methods/ai-terminal.ts +25505 -0
  83. package/src/methods/app-settings.ts +114 -0
  84. package/src/methods/aws.ts +646 -0
  85. package/src/methods/collections.ts +544 -0
  86. package/src/methods/counters.ts +67 -0
  87. package/src/methods/cron-jobs.ts +2610 -0
  88. package/src/methods/customer-notifications.ts +458 -0
  89. package/src/methods/diagnostics.ts +447 -0
  90. package/src/methods/flag-updates.ts +7 -0
  91. package/src/methods/flags.ts +7 -0
  92. package/src/methods/logs.ts +656 -0
  93. package/src/methods/mongo-explorer.ts +1883 -0
  94. package/src/methods/monitor.ts +540 -0
  95. package/src/methods/pdf.ts +1210 -0
  96. package/src/methods/publications.ts +128 -0
  97. package/src/methods/report-builder.ts +3305 -0
  98. package/src/methods/support.ts +210 -0
  99. package/src/models/ai-terminal-conversation.model.ts +19 -0
  100. package/src/models/ai-terminal-issue-report.model.ts +21 -0
  101. package/src/models/ai-terminal-message.model.ts +24 -0
  102. package/src/models/app-setting.model.ts +17 -0
  103. package/{models/app-status.model.d.ts → src/models/app-status.model.ts} +3 -2
  104. package/{models/billing-logged-in-users.model.d.ts → src/models/billing-logged-in-users.model.ts} +5 -4
  105. package/src/models/collection-document.model.ts +24 -0
  106. package/src/models/communication-metric.model.ts +23 -0
  107. package/{models/counter.model.d.ts → src/models/counter.model.ts} +4 -3
  108. package/src/models/cron-job-history.model.ts +16 -0
  109. package/src/models/cron-job.model.ts +15 -0
  110. package/src/models/customer-notification.model.ts +28 -0
  111. package/src/models/customer-portal-password.model.ts +12 -0
  112. package/src/models/dialog.model.ts +25 -0
  113. package/{models/email-history.model.js → src/models/email-history.model.ts} +34 -4
  114. package/{models/email-verified.model.d.ts → src/models/email-verified.model.ts} +6 -5
  115. package/{models/file.model.d.ts → src/models/file.model.ts} +8 -7
  116. package/{models/flag-update.model.d.ts → src/models/flag-update.model.ts} +4 -3
  117. package/{models/flag.model.d.ts → src/models/flag.model.ts} +4 -3
  118. package/src/models/log-method-latency.model.ts +11 -0
  119. package/{models/log-subscription.model.d.ts → src/models/log-subscription.model.ts} +11 -9
  120. package/src/models/log.model.ts +19 -0
  121. package/{models/logged-in-users.model.d.ts → src/models/logged-in-users.model.ts} +6 -5
  122. package/{models/method-response.model.d.ts → src/models/method-response.model.ts} +7 -6
  123. package/src/models/method.model.ts +23 -0
  124. package/{models/monitor-cpu.model.d.ts → src/models/monitor-cpu.model.ts} +9 -7
  125. package/src/models/monitor-function.model.ts +16 -0
  126. package/src/models/monitor-memory.model.ts +17 -0
  127. package/src/models/monitor-mongo.model.ts +15 -0
  128. package/{models/notification.model.d.ts → src/models/notification.model.ts} +6 -4
  129. package/src/models/openai-usage-ledger.model.ts +16 -0
  130. package/src/models/pagination.model.ts +35 -0
  131. package/src/models/permission.model.ts +14 -0
  132. package/src/models/report-builder-dashboard-builder.model.ts +29 -0
  133. package/src/models/report-builder-library.model.ts +20 -0
  134. package/src/models/report-builder-report.model.ts +135 -0
  135. package/src/models/report-builder.model.ts +68 -0
  136. package/src/models/select-data-label.model.ts +9 -0
  137. package/src/models/server-message.model.ts +31 -0
  138. package/src/models/slow-query-report.model.ts +23 -0
  139. package/src/models/subscription.model.ts +73 -0
  140. package/src/models/support-ticket.model.ts +96 -0
  141. package/src/models/user-group.model.ts +24 -0
  142. package/{models/user-guide.model.d.ts → src/models/user-guide.model.ts} +5 -4
  143. package/src/models/user.model.ts +96 -0
  144. package/src/private/images/ResolveIO.png +0 -0
  145. package/src/publications/ai-terminal.ts +73 -0
  146. package/src/publications/app-settings.ts +25 -0
  147. package/src/publications/app-status.ts +13 -0
  148. package/src/publications/cron-jobs.ts +29 -0
  149. package/src/publications/customer-notifications.ts +101 -0
  150. package/src/publications/files.ts +33 -0
  151. package/src/publications/flags-update.ts +19 -0
  152. package/src/publications/flags.ts +19 -0
  153. package/src/publications/logs.ts +163 -0
  154. package/src/publications/notifications.ts +13 -0
  155. package/src/publications/report-builder-dashboard-builders.ts +39 -0
  156. package/src/publications/report-builder-libraries.ts +41 -0
  157. package/src/publications/report-builder-reports.ts +47 -0
  158. package/src/publications/super-admin.ts +13 -0
  159. package/src/publications/user-groups.ts +12 -0
  160. package/src/publications/user-guides.ts +12 -0
  161. package/src/resolveio-server-app.ts +617 -0
  162. package/src/server-app.ts +2616 -0
  163. package/src/services/codex-client.ts +1117 -0
  164. package/src/services/openai-client.ts +265 -0
  165. package/src/types/error-report.ts +26 -0
  166. package/src/types/js-tiktoken.d.ts +11 -0
  167. package/src/types/slow-query-report.ts +28 -0
  168. package/src/util/common.ts +649 -0
  169. package/src/util/customer-portal-password.ts +183 -0
  170. package/src/util/error-reporter.ts +332 -0
  171. package/src/util/error-tracking.ts +79 -0
  172. package/src/util/report-builder-unwinds.ts +180 -0
  173. package/src/util/schema-report-builder.ts +448 -0
  174. package/src/util/slow-query-reporter.ts +216 -0
  175. package/src/util/subscription-dependency-context.ts +1096 -0
  176. package/src/util/tokenizer.ts +38 -0
  177. package/src/workers/codex-runner.worker.ts +142 -0
  178. package/start_server.sh +5 -0
  179. package/tests/ai-assistant-corpus-build.ts +484 -0
  180. package/tests/ai-assistant-corpus-replay-e2e.ts +773 -0
  181. package/tests/ai-assistant-data-parity-e2e.ts +2018 -0
  182. package/tests/ai-assistant-eval-triage.ts +831 -0
  183. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  184. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  185. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  186. package/tests/ai-assistant-routing-eval.test.ts +560 -0
  187. package/tests/ai-assistant-snf-live-eval.ts +921 -0
  188. package/tests/ai-assistant-utils.test.ts +2165 -0
  189. package/tests/error-reporter.test.ts +145 -0
  190. package/tests/report-builder-linking.test.ts +79 -0
  191. package/tests/subscription-connect-race.test.ts +157 -0
  192. package/tests/subscription-dependency-context.test.ts +324 -0
  193. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  194. package/tests/subscription-manager-invalidation.test.ts +85 -0
  195. package/tsconfig.json +34 -0
  196. package/ai/assistant-core-heuristics.d.ts +0 -11
  197. package/ai/assistant-core-heuristics.js +0 -531
  198. package/ai/assistant-core-heuristics.js.map +0 -1
  199. package/client-server-app.d.ts +0 -1
  200. package/client-server-app.js +0 -68
  201. package/client-server-app.js.map +0 -1
  202. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  203. package/collections/ai-terminal-conversation.collection.js +0 -140
  204. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  205. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  206. package/collections/ai-terminal-issue-report.collection.js +0 -148
  207. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  208. package/collections/ai-terminal-message.collection.d.ts +0 -2
  209. package/collections/ai-terminal-message.collection.js +0 -121
  210. package/collections/ai-terminal-message.collection.js.map +0 -1
  211. package/collections/app-setting.collection.d.ts +0 -3
  212. package/collections/app-setting.collection.js +0 -103
  213. package/collections/app-setting.collection.js.map +0 -1
  214. package/collections/app-status.collection.d.ts +0 -3
  215. package/collections/app-status.collection.js +0 -57
  216. package/collections/app-status.collection.js.map +0 -1
  217. package/collections/communication-metric.collection.d.ts +0 -2
  218. package/collections/communication-metric.collection.js +0 -133
  219. package/collections/communication-metric.collection.js.map +0 -1
  220. package/collections/counter.collection.d.ts +0 -3
  221. package/collections/counter.collection.js +0 -56
  222. package/collections/counter.collection.js.map +0 -1
  223. package/collections/cron-job-history.collection.d.ts +0 -3
  224. package/collections/cron-job-history.collection.js +0 -137
  225. package/collections/cron-job-history.collection.js.map +0 -1
  226. package/collections/cron-job.collection.d.ts +0 -3
  227. package/collections/cron-job.collection.js +0 -92
  228. package/collections/cron-job.collection.js.map +0 -1
  229. package/collections/customer-notification.collection.d.ts +0 -3
  230. package/collections/customer-notification.collection.js +0 -130
  231. package/collections/customer-notification.collection.js.map +0 -1
  232. package/collections/customer-portal-password.collection.d.ts +0 -3
  233. package/collections/customer-portal-password.collection.js +0 -75
  234. package/collections/customer-portal-password.collection.js.map +0 -1
  235. package/collections/email-history.collection.d.ts +0 -3
  236. package/collections/email-history.collection.js +0 -121
  237. package/collections/email-history.collection.js.map +0 -1
  238. package/collections/email-verified.collection.d.ts +0 -3
  239. package/collections/email-verified.collection.js +0 -61
  240. package/collections/email-verified.collection.js.map +0 -1
  241. package/collections/file.collection.d.ts +0 -3
  242. package/collections/file.collection.js +0 -74
  243. package/collections/file.collection.js.map +0 -1
  244. package/collections/flag-update.collection.d.ts +0 -3
  245. package/collections/flag-update.collection.js +0 -57
  246. package/collections/flag-update.collection.js.map +0 -1
  247. package/collections/flag.collection.d.ts +0 -3
  248. package/collections/flag.collection.js +0 -57
  249. package/collections/flag.collection.js.map +0 -1
  250. package/collections/log-method-latency.collection.d.ts +0 -3
  251. package/collections/log-method-latency.collection.js +0 -77
  252. package/collections/log-method-latency.collection.js.map +0 -1
  253. package/collections/log-subscription.collection.d.ts +0 -3
  254. package/collections/log-subscription.collection.js +0 -80
  255. package/collections/log-subscription.collection.js.map +0 -1
  256. package/collections/log.collection.d.ts +0 -3
  257. package/collections/log.collection.js +0 -93
  258. package/collections/log.collection.js.map +0 -1
  259. package/collections/logged-in-users.collection.d.ts +0 -3
  260. package/collections/logged-in-users.collection.js +0 -67
  261. package/collections/logged-in-users.collection.js.map +0 -1
  262. package/collections/monitor-cpu.collection.d.ts +0 -3
  263. package/collections/monitor-cpu.collection.js +0 -65
  264. package/collections/monitor-cpu.collection.js.map +0 -1
  265. package/collections/monitor-function.collection.d.ts +0 -3
  266. package/collections/monitor-function.collection.js +0 -74
  267. package/collections/monitor-function.collection.js.map +0 -1
  268. package/collections/monitor-memory.collection.d.ts +0 -3
  269. package/collections/monitor-memory.collection.js +0 -77
  270. package/collections/monitor-memory.collection.js.map +0 -1
  271. package/collections/monitor-mongo.collection.d.ts +0 -3
  272. package/collections/monitor-mongo.collection.js +0 -71
  273. package/collections/monitor-mongo.collection.js.map +0 -1
  274. package/collections/notification.collection.d.ts +0 -3
  275. package/collections/notification.collection.js +0 -57
  276. package/collections/notification.collection.js.map +0 -1
  277. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  278. package/collections/openai-usage-ledger.collection.js +0 -124
  279. package/collections/openai-usage-ledger.collection.js.map +0 -1
  280. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  281. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  282. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  283. package/collections/report-builder-library.collection.d.ts +0 -3
  284. package/collections/report-builder-library.collection.js +0 -87
  285. package/collections/report-builder-library.collection.js.map +0 -1
  286. package/collections/report-builder-report.collection.d.ts +0 -4
  287. package/collections/report-builder-report.collection.js +0 -180
  288. package/collections/report-builder-report.collection.js.map +0 -1
  289. package/collections/user-group.collection.d.ts +0 -4
  290. package/collections/user-group.collection.js +0 -89
  291. package/collections/user-group.collection.js.map +0 -1
  292. package/collections/user-guide.collection.d.ts +0 -3
  293. package/collections/user-guide.collection.js +0 -57
  294. package/collections/user-guide.collection.js.map +0 -1
  295. package/collections/user.collection.d.ts +0 -4
  296. package/collections/user.collection.js +0 -180
  297. package/collections/user.collection.js.map +0 -1
  298. package/cron/cron.d.ts +0 -14
  299. package/cron/cron.js +0 -216
  300. package/cron/cron.js.map +0 -1
  301. package/fixtures/cron-jobs.d.ts +0 -1
  302. package/fixtures/cron-jobs.js +0 -150
  303. package/fixtures/cron-jobs.js.map +0 -1
  304. package/fixtures/init.d.ts +0 -1
  305. package/fixtures/init.js +0 -91
  306. package/fixtures/init.js.map +0 -1
  307. package/http/auth.d.ts +0 -2
  308. package/http/auth.js +0 -903
  309. package/http/auth.js.map +0 -1
  310. package/http/health.d.ts +0 -1
  311. package/http/health.js +0 -11
  312. package/http/health.js.map +0 -1
  313. package/http/home.d.ts +0 -1
  314. package/http/home.js +0 -134
  315. package/http/home.js.map +0 -1
  316. package/http/slow-query-publication.d.ts +0 -2
  317. package/http/slow-query-publication.js +0 -99
  318. package/http/slow-query-publication.js.map +0 -1
  319. package/index.d.ts +0 -1
  320. package/index.js +0 -19
  321. package/index.js.map +0 -1
  322. package/managers/communication-metric.manager.d.ts +0 -16
  323. package/managers/communication-metric.manager.js +0 -134
  324. package/managers/communication-metric.manager.js.map +0 -1
  325. package/managers/cron.manager.d.ts +0 -20
  326. package/managers/cron.manager.js +0 -534
  327. package/managers/cron.manager.js.map +0 -1
  328. package/managers/customer-notification-content.manager.d.ts +0 -55
  329. package/managers/customer-notification-content.manager.js +0 -158
  330. package/managers/customer-notification-content.manager.js.map +0 -1
  331. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  332. package/managers/diagnostic-manager-bootstrap.js +0 -260
  333. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  334. package/managers/error-auto-fix.manager.d.ts +0 -149
  335. package/managers/error-auto-fix.manager.js +0 -3064
  336. package/managers/error-auto-fix.manager.js.map +0 -1
  337. package/managers/local-log.manager.d.ts +0 -18
  338. package/managers/local-log.manager.js +0 -88
  339. package/managers/local-log.manager.js.map +0 -1
  340. package/managers/method.manager.d.ts +0 -77
  341. package/managers/method.manager.js +0 -1701
  342. package/managers/method.manager.js.map +0 -1
  343. package/managers/mongo.manager.d.ts +0 -222
  344. package/managers/mongo.manager.js +0 -4984
  345. package/managers/mongo.manager.js.map +0 -1
  346. package/managers/monitor.manager.d.ts +0 -69
  347. package/managers/monitor.manager.js +0 -534
  348. package/managers/monitor.manager.js.map +0 -1
  349. package/managers/openai-usage-ledger.manager.d.ts +0 -15
  350. package/managers/openai-usage-ledger.manager.js +0 -144
  351. package/managers/openai-usage-ledger.manager.js.map +0 -1
  352. package/managers/slow-query-verifier.manager.d.ts +0 -144
  353. package/managers/slow-query-verifier.manager.js +0 -3857
  354. package/managers/slow-query-verifier.manager.js.map +0 -1
  355. package/managers/slow-query.manager.d.ts +0 -28
  356. package/managers/slow-query.manager.js +0 -468
  357. package/managers/slow-query.manager.js.map +0 -1
  358. package/managers/subscription.manager.d.ts +0 -169
  359. package/managers/subscription.manager.js +0 -3422
  360. package/managers/subscription.manager.js.map +0 -1
  361. package/managers/websocket.manager.d.ts +0 -73
  362. package/managers/websocket.manager.js +0 -673
  363. package/managers/websocket.manager.js.map +0 -1
  364. package/managers/worker-dispatcher.manager.d.ts +0 -117
  365. package/managers/worker-dispatcher.manager.js +0 -1210
  366. package/managers/worker-dispatcher.manager.js.map +0 -1
  367. package/managers/worker-server.manager.d.ts +0 -16
  368. package/managers/worker-server.manager.js +0 -530
  369. package/managers/worker-server.manager.js.map +0 -1
  370. package/methods/accounts.d.ts +0 -2
  371. package/methods/accounts.js +0 -624
  372. package/methods/accounts.js.map +0 -1
  373. package/methods/ai-terminal.d.ts +0 -304
  374. package/methods/ai-terminal.js +0 -25096
  375. package/methods/ai-terminal.js.map +0 -1
  376. package/methods/app-settings.d.ts +0 -2
  377. package/methods/app-settings.js +0 -169
  378. package/methods/app-settings.js.map +0 -1
  379. package/methods/aws.d.ts +0 -2
  380. package/methods/aws.js +0 -874
  381. package/methods/aws.js.map +0 -1
  382. package/methods/collections.d.ts +0 -2
  383. package/methods/collections.js +0 -626
  384. package/methods/collections.js.map +0 -1
  385. package/methods/counters.d.ts +0 -2
  386. package/methods/counters.js +0 -111
  387. package/methods/counters.js.map +0 -1
  388. package/methods/cron-jobs.d.ts +0 -2
  389. package/methods/cron-jobs.js +0 -2471
  390. package/methods/cron-jobs.js.map +0 -1
  391. package/methods/customer-notifications.d.ts +0 -2
  392. package/methods/customer-notifications.js +0 -528
  393. package/methods/customer-notifications.js.map +0 -1
  394. package/methods/diagnostics.d.ts +0 -2
  395. package/methods/diagnostics.js +0 -514
  396. package/methods/diagnostics.js.map +0 -1
  397. package/methods/flag-updates.d.ts +0 -2
  398. package/methods/flag-updates.js +0 -8
  399. package/methods/flag-updates.js.map +0 -1
  400. package/methods/flags.d.ts +0 -2
  401. package/methods/flags.js +0 -8
  402. package/methods/flags.js.map +0 -1
  403. package/methods/logs.d.ts +0 -2
  404. package/methods/logs.js +0 -750
  405. package/methods/logs.js.map +0 -1
  406. package/methods/mongo-explorer.d.ts +0 -2
  407. package/methods/mongo-explorer.js +0 -1811
  408. package/methods/mongo-explorer.js.map +0 -1
  409. package/methods/monitor.d.ts +0 -2
  410. package/methods/monitor.js +0 -543
  411. package/methods/monitor.js.map +0 -1
  412. package/methods/pdf.d.ts +0 -2
  413. package/methods/pdf.js +0 -1195
  414. package/methods/pdf.js.map +0 -1
  415. package/methods/publications.d.ts +0 -1
  416. package/methods/publications.js +0 -183
  417. package/methods/publications.js.map +0 -1
  418. package/methods/report-builder.d.ts +0 -2
  419. package/methods/report-builder.js +0 -2960
  420. package/methods/report-builder.js.map +0 -1
  421. package/methods/support.d.ts +0 -2
  422. package/methods/support.js +0 -313
  423. package/methods/support.js.map +0 -1
  424. package/models/ai-terminal-conversation.model.d.ts +0 -17
  425. package/models/ai-terminal-conversation.model.js +0 -4
  426. package/models/ai-terminal-conversation.model.js.map +0 -1
  427. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  428. package/models/ai-terminal-issue-report.model.js +0 -4
  429. package/models/ai-terminal-issue-report.model.js.map +0 -1
  430. package/models/ai-terminal-message.model.d.ts +0 -22
  431. package/models/ai-terminal-message.model.js +0 -4
  432. package/models/ai-terminal-message.model.js.map +0 -1
  433. package/models/app-setting.model.d.ts +0 -16
  434. package/models/app-setting.model.js +0 -4
  435. package/models/app-setting.model.js.map +0 -1
  436. package/models/app-status.model.js +0 -4
  437. package/models/app-status.model.js.map +0 -1
  438. package/models/billing-logged-in-users.model.js +0 -4
  439. package/models/billing-logged-in-users.model.js.map +0 -1
  440. package/models/collection-document.model.d.ts +0 -21
  441. package/models/collection-document.model.js +0 -4
  442. package/models/collection-document.model.js.map +0 -1
  443. package/models/communication-metric.model.d.ts +0 -20
  444. package/models/communication-metric.model.js +0 -4
  445. package/models/communication-metric.model.js.map +0 -1
  446. package/models/counter.model.js +0 -4
  447. package/models/counter.model.js.map +0 -1
  448. package/models/cron-job-history.model.d.ts +0 -15
  449. package/models/cron-job-history.model.js +0 -4
  450. package/models/cron-job-history.model.js.map +0 -1
  451. package/models/cron-job.model.d.ts +0 -14
  452. package/models/cron-job.model.js +0 -4
  453. package/models/cron-job.model.js.map +0 -1
  454. package/models/customer-notification.model.d.ts +0 -26
  455. package/models/customer-notification.model.js +0 -4
  456. package/models/customer-notification.model.js.map +0 -1
  457. package/models/customer-portal-password.model.d.ts +0 -11
  458. package/models/customer-portal-password.model.js +0 -4
  459. package/models/customer-portal-password.model.js.map +0 -1
  460. package/models/dialog.model.d.ts +0 -23
  461. package/models/dialog.model.js +0 -4
  462. package/models/dialog.model.js.map +0 -1
  463. package/models/email-history.model.d.ts +0 -30
  464. package/models/email-history.model.js.map +0 -1
  465. package/models/email-verified.model.js +0 -4
  466. package/models/email-verified.model.js.map +0 -1
  467. package/models/file.model.js +0 -4
  468. package/models/file.model.js.map +0 -1
  469. package/models/flag-update.model.js +0 -4
  470. package/models/flag-update.model.js.map +0 -1
  471. package/models/flag.model.js +0 -4
  472. package/models/flag.model.js.map +0 -1
  473. package/models/log-method-latency.model.d.ts +0 -10
  474. package/models/log-method-latency.model.js +0 -4
  475. package/models/log-method-latency.model.js.map +0 -1
  476. package/models/log-subscription.model.js +0 -4
  477. package/models/log-subscription.model.js.map +0 -1
  478. package/models/log.model.d.ts +0 -17
  479. package/models/log.model.js +0 -4
  480. package/models/log.model.js.map +0 -1
  481. package/models/logged-in-users.model.js +0 -4
  482. package/models/logged-in-users.model.js.map +0 -1
  483. package/models/method-response.model.js +0 -4
  484. package/models/method-response.model.js.map +0 -1
  485. package/models/method.model.d.ts +0 -24
  486. package/models/method.model.js +0 -4
  487. package/models/method.model.js.map +0 -1
  488. package/models/monitor-cpu.model.js +0 -4
  489. package/models/monitor-cpu.model.js.map +0 -1
  490. package/models/monitor-function.model.d.ts +0 -14
  491. package/models/monitor-function.model.js +0 -4
  492. package/models/monitor-function.model.js.map +0 -1
  493. package/models/monitor-memory.model.d.ts +0 -15
  494. package/models/monitor-memory.model.js +0 -4
  495. package/models/monitor-memory.model.js.map +0 -1
  496. package/models/monitor-mongo.model.d.ts +0 -13
  497. package/models/monitor-mongo.model.js +0 -4
  498. package/models/monitor-mongo.model.js.map +0 -1
  499. package/models/notification.model.js +0 -4
  500. package/models/notification.model.js.map +0 -1
  501. package/models/openai-usage-ledger.model.d.ts +0 -15
  502. package/models/openai-usage-ledger.model.js +0 -4
  503. package/models/openai-usage-ledger.model.js.map +0 -1
  504. package/models/pagination.model.d.ts +0 -11
  505. package/models/pagination.model.js +0 -28
  506. package/models/pagination.model.js.map +0 -1
  507. package/models/permission.model.d.ts +0 -12
  508. package/models/permission.model.js +0 -4
  509. package/models/permission.model.js.map +0 -1
  510. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  511. package/models/report-builder-dashboard-builder.model.js +0 -4
  512. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  513. package/models/report-builder-library.model.d.ts +0 -17
  514. package/models/report-builder-library.model.js +0 -4
  515. package/models/report-builder-library.model.js.map +0 -1
  516. package/models/report-builder-report.model.d.ts +0 -120
  517. package/models/report-builder-report.model.js +0 -4
  518. package/models/report-builder-report.model.js.map +0 -1
  519. package/models/report-builder.model.d.ts +0 -61
  520. package/models/report-builder.model.js +0 -4
  521. package/models/report-builder.model.js.map +0 -1
  522. package/models/select-data-label.model.d.ts +0 -9
  523. package/models/select-data-label.model.js +0 -4
  524. package/models/select-data-label.model.js.map +0 -1
  525. package/models/server-message.model.d.ts +0 -32
  526. package/models/server-message.model.js +0 -4
  527. package/models/server-message.model.js.map +0 -1
  528. package/models/slow-query-report.model.d.ts +0 -23
  529. package/models/slow-query-report.model.js +0 -4
  530. package/models/slow-query-report.model.js.map +0 -1
  531. package/models/subscription.model.d.ts +0 -31
  532. package/models/subscription.model.js +0 -4
  533. package/models/subscription.model.js.map +0 -1
  534. package/models/support-ticket.model.d.ts +0 -86
  535. package/models/support-ticket.model.js +0 -4
  536. package/models/support-ticket.model.js.map +0 -1
  537. package/models/user-group.model.d.ts +0 -20
  538. package/models/user-group.model.js +0 -4
  539. package/models/user-group.model.js.map +0 -1
  540. package/models/user-guide.model.js +0 -4
  541. package/models/user-guide.model.js.map +0 -1
  542. package/models/user.model.d.ts +0 -84
  543. package/models/user.model.js +0 -4
  544. package/models/user.model.js.map +0 -1
  545. package/private/images/ResolveIO.png +0 -0
  546. package/public_api.js +0 -107
  547. package/public_api.js.map +0 -1
  548. package/publications/ai-terminal.d.ts +0 -1
  549. package/publications/ai-terminal.js +0 -122
  550. package/publications/ai-terminal.js.map +0 -1
  551. package/publications/app-settings.d.ts +0 -2
  552. package/publications/app-settings.js +0 -28
  553. package/publications/app-settings.js.map +0 -1
  554. package/publications/app-status.d.ts +0 -2
  555. package/publications/app-status.js +0 -16
  556. package/publications/app-status.js.map +0 -1
  557. package/publications/cron-jobs.d.ts +0 -2
  558. package/publications/cron-jobs.js +0 -32
  559. package/publications/cron-jobs.js.map +0 -1
  560. package/publications/customer-notifications.d.ts +0 -2
  561. package/publications/customer-notifications.js +0 -161
  562. package/publications/customer-notifications.js.map +0 -1
  563. package/publications/files.d.ts +0 -2
  564. package/publications/files.js +0 -36
  565. package/publications/files.js.map +0 -1
  566. package/publications/flags-update.d.ts +0 -2
  567. package/publications/flags-update.js +0 -22
  568. package/publications/flags-update.js.map +0 -1
  569. package/publications/flags.d.ts +0 -2
  570. package/publications/flags.js +0 -22
  571. package/publications/flags.js.map +0 -1
  572. package/publications/logs.d.ts +0 -2
  573. package/publications/logs.js +0 -164
  574. package/publications/logs.js.map +0 -1
  575. package/publications/notifications.d.ts +0 -2
  576. package/publications/notifications.js +0 -16
  577. package/publications/notifications.js.map +0 -1
  578. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  579. package/publications/report-builder-dashboard-builders.js +0 -42
  580. package/publications/report-builder-dashboard-builders.js.map +0 -1
  581. package/publications/report-builder-libraries.d.ts +0 -2
  582. package/publications/report-builder-libraries.js +0 -90
  583. package/publications/report-builder-libraries.js.map +0 -1
  584. package/publications/report-builder-reports.d.ts +0 -2
  585. package/publications/report-builder-reports.js +0 -50
  586. package/publications/report-builder-reports.js.map +0 -1
  587. package/publications/super-admin.d.ts +0 -2
  588. package/publications/super-admin.js +0 -16
  589. package/publications/super-admin.js.map +0 -1
  590. package/publications/user-groups.d.ts +0 -1
  591. package/publications/user-groups.js +0 -16
  592. package/publications/user-groups.js.map +0 -1
  593. package/publications/user-guides.d.ts +0 -1
  594. package/publications/user-guides.js +0 -16
  595. package/publications/user-guides.js.map +0 -1
  596. package/resolveio-server-app.d.ts +0 -70
  597. package/resolveio-server-app.js +0 -801
  598. package/resolveio-server-app.js.map +0 -1
  599. package/server-app.d.ts +0 -167
  600. package/server-app.js +0 -2784
  601. package/server-app.js.map +0 -1
  602. package/services/codex-client.d.ts +0 -119
  603. package/services/codex-client.js +0 -1470
  604. package/services/codex-client.js.map +0 -1
  605. package/services/openai-client.d.ts +0 -46
  606. package/services/openai-client.js +0 -318
  607. package/services/openai-client.js.map +0 -1
  608. package/types/error-report.d.ts +0 -25
  609. package/types/error-report.js +0 -4
  610. package/types/error-report.js.map +0 -1
  611. package/types/slow-query-report.d.ts +0 -27
  612. package/types/slow-query-report.js +0 -6
  613. package/types/slow-query-report.js.map +0 -1
  614. package/util/common.d.ts +0 -31
  615. package/util/common.js +0 -683
  616. package/util/common.js.map +0 -1
  617. package/util/customer-portal-password.d.ts +0 -13
  618. package/util/customer-portal-password.js +0 -209
  619. package/util/customer-portal-password.js.map +0 -1
  620. package/util/error-reporter.d.ts +0 -52
  621. package/util/error-reporter.js +0 -326
  622. package/util/error-reporter.js.map +0 -1
  623. package/util/error-tracking.d.ts +0 -13
  624. package/util/error-tracking.js +0 -120
  625. package/util/error-tracking.js.map +0 -1
  626. package/util/report-builder-unwinds.d.ts +0 -15
  627. package/util/report-builder-unwinds.js +0 -156
  628. package/util/report-builder-unwinds.js.map +0 -1
  629. package/util/schema-report-builder.d.ts +0 -6
  630. package/util/schema-report-builder.js +0 -481
  631. package/util/schema-report-builder.js.map +0 -1
  632. package/util/slow-query-reporter.d.ts +0 -28
  633. package/util/slow-query-reporter.js +0 -226
  634. package/util/slow-query-reporter.js.map +0 -1
  635. package/util/subscription-dependency-context.d.ts +0 -34
  636. package/util/subscription-dependency-context.js +0 -1283
  637. package/util/subscription-dependency-context.js.map +0 -1
  638. package/util/tokenizer.d.ts +0 -5
  639. package/util/tokenizer.js +0 -41
  640. package/util/tokenizer.js.map +0 -1
  641. package/workers/codex-runner.worker.d.ts +0 -1
  642. package/workers/codex-runner.worker.js +0 -192
  643. package/workers/codex-runner.worker.js.map +0 -1
  644. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  645. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  646. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  647. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  648. /package/{private → src/private}/email-templates/support-ticket.html +0 -0
  649. /package/{public_api.d.ts → src/public_api.ts} +0 -0
@@ -0,0 +1,656 @@
1
+ import axios from 'axios';
2
+ import { URL } from 'url';
3
+ import { LogMethodLatencies } from '../collections/log-method-latency.collection';
4
+ import { LogSubscriptions } from '../collections/log-subscription.collection';
5
+ import { Logs } from '../collections/log.collection';
6
+ import { MethodManager } from '../managers/method.manager';
7
+ import { ResolveIOServer } from '../resolveio-server-app';
8
+ import { objectIdHexString } from '../util/common';
9
+ import { ErrorReporter } from '../util/error-reporter';
10
+ import { getCorrelationId } from '../util/error-tracking';
11
+
12
+ type LogsSourceMode = 'auto' | 'local' | 'remote' | 'resolveio' | 'aicoder';
13
+
14
+ const DEFAULT_RESOLVEIO_LOGS_ENDPOINT = 'https://backend.resolveio.com/api/logs/query';
15
+ const MAX_LOG_QUERY_LIMIT = 5000;
16
+ const DEFAULT_LOG_QUERY_LIMIT = 250;
17
+ const REMOTE_LOG_QUERY_TIMEOUT_MS = 20000;
18
+
19
+ function normalizeString(value: any): string {
20
+ if (value === undefined || value === null) {
21
+ return '';
22
+ }
23
+ return String(value).trim();
24
+ }
25
+
26
+ function normalizeLogsSourceMode(value: any): LogsSourceMode {
27
+ const mode = normalizeString(value).toLowerCase();
28
+ if (mode === 'local' || mode === 'remote' || mode === 'resolveio' || mode === 'aicoder' || mode === 'auto') {
29
+ return mode;
30
+ }
31
+ return 'auto';
32
+ }
33
+
34
+ function toSafeInteger(value: any, fallback: number): number {
35
+ const parsed = Number(value);
36
+ if (!Number.isFinite(parsed)) {
37
+ return fallback;
38
+ }
39
+ return Math.floor(parsed);
40
+ }
41
+
42
+ function looksLikeResolveIOHost(serverConfig: Record<string, any>): boolean {
43
+ const candidates = [
44
+ serverConfig?.ROOT_URL,
45
+ serverConfig?.SERVER_URL
46
+ ];
47
+ for (const candidate of candidates) {
48
+ const url = normalizeString(candidate);
49
+ if (!url) {
50
+ continue;
51
+ }
52
+ try {
53
+ const parsed = new URL(url.includes('://') ? url : `https://${url}`);
54
+ const host = normalizeString(parsed.hostname).toLowerCase();
55
+ if (host === 'backend.resolveio.com' || host === 'resolveio.com' || host.endsWith('.resolveio.com')) {
56
+ return true;
57
+ }
58
+ }
59
+ catch {
60
+ const host = url.toLowerCase();
61
+ if (host.includes('backend.resolveio.com') || host.includes('resolveio.com')) {
62
+ return true;
63
+ }
64
+ }
65
+ }
66
+ return false;
67
+ }
68
+
69
+ function resolveLogsSourceMode(serverConfig: Record<string, any>, forcedMode?: any): LogsSourceMode {
70
+ const forced = normalizeLogsSourceMode(forcedMode);
71
+ if (forced !== 'auto') {
72
+ return forced;
73
+ }
74
+ const configured = normalizeLogsSourceMode(
75
+ process.env.LOGS_DATA_MODE
76
+ || process.env.RESOLVEIO_LOGS_MODE
77
+ || serverConfig?.LOGS_DATA_MODE
78
+ || serverConfig?.RESOLVEIO_LOGS_MODE
79
+ || serverConfig?.AI_ASSISTANT_MODE
80
+ || process.env.AI_ASSISTANT_MODE
81
+ );
82
+ if (configured !== 'auto') {
83
+ return configured;
84
+ }
85
+ return 'resolveio';
86
+ }
87
+
88
+ function shouldUseRemoteLogsSource(serverConfig: Record<string, any>, forcedMode?: any): boolean {
89
+ const mode = resolveLogsSourceMode(serverConfig, forcedMode);
90
+ if (mode === 'remote') {
91
+ return true;
92
+ }
93
+ if (mode === 'local' || mode === 'aicoder') {
94
+ return false;
95
+ }
96
+ if (mode === 'resolveio') {
97
+ return !looksLikeResolveIOHost(serverConfig);
98
+ }
99
+ return false;
100
+ }
101
+
102
+ function normalizeLogQueryPayload(payload: any): {
103
+ query: Record<string, any>;
104
+ options: Record<string, any>;
105
+ includeCount: boolean;
106
+ sourceMode: LogsSourceMode;
107
+ } {
108
+ const raw = (payload && typeof payload === 'object') ? payload : {};
109
+ const query = (raw.query && typeof raw.query === 'object') ? raw.query : {};
110
+ const optionsRaw = (raw.options && typeof raw.options === 'object') ? raw.options : {};
111
+ const limit = Math.max(1, Math.min(MAX_LOG_QUERY_LIMIT, toSafeInteger(optionsRaw.limit, DEFAULT_LOG_QUERY_LIMIT)));
112
+ const skip = Math.max(0, toSafeInteger(optionsRaw.skip, 0));
113
+ const sort = (optionsRaw.sort && typeof optionsRaw.sort === 'object') ? optionsRaw.sort : { createdAt: -1 };
114
+ const projection = (optionsRaw.projection && typeof optionsRaw.projection === 'object')
115
+ ? optionsRaw.projection
116
+ : ((optionsRaw.fields && typeof optionsRaw.fields === 'object') ? optionsRaw.fields : undefined);
117
+ const includeCount = raw.include_count !== false && raw.includeCount !== false;
118
+ const sourceMode = normalizeLogsSourceMode(raw.force_source || raw.source_mode || raw.mode);
119
+
120
+ return {
121
+ query,
122
+ options: {
123
+ sort,
124
+ limit,
125
+ skip,
126
+ ...(projection ? { projection } : {})
127
+ },
128
+ includeCount,
129
+ sourceMode
130
+ };
131
+ }
132
+
133
+ function resolveRemoteLogsEndpoint(serverConfig: Record<string, any>): string {
134
+ const endpoint = normalizeString(
135
+ process.env.RESOLVEIO_LOGS_ENDPOINT
136
+ || process.env.REMOTE_LOGS_ENDPOINT
137
+ || serverConfig?.RESOLVEIO_LOGS_ENDPOINT
138
+ || serverConfig?.REMOTE_LOGS_ENDPOINT
139
+ );
140
+ return endpoint || DEFAULT_RESOLVEIO_LOGS_ENDPOINT;
141
+ }
142
+
143
+ function resolveRemoteLogsApiKey(serverConfig: Record<string, any>): string {
144
+ return normalizeString(
145
+ process.env.RESOLVEIO_LOGS_API_KEY
146
+ || process.env.REMOTE_LOGS_API_KEY
147
+ || serverConfig?.RESOLVEIO_LOGS_API_KEY
148
+ || serverConfig?.REMOTE_LOGS_API_KEY
149
+ );
150
+ }
151
+
152
+ function reviveIsoDateStrings(value: any): any {
153
+ if (Array.isArray(value)) {
154
+ return value.map((entry) => reviveIsoDateStrings(entry));
155
+ }
156
+ if (!value || typeof value !== 'object') {
157
+ if (typeof value === 'string' && /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:\.\d+)?Z$/.test(value)) {
158
+ const parsed = new Date(value);
159
+ if (!Number.isNaN(parsed.getTime())) {
160
+ return parsed;
161
+ }
162
+ }
163
+ return value;
164
+ }
165
+ const next: Record<string, any> = {};
166
+ Object.keys(value).forEach((key) => {
167
+ next[key] = reviveIsoDateStrings(value[key]);
168
+ });
169
+ return next;
170
+ }
171
+
172
+ async function runLocalLogsQuery(
173
+ query: Record<string, any>,
174
+ options: Record<string, any>,
175
+ includeCount: boolean
176
+ ): Promise<{ source: 'local'; logs: any[]; count: number }> {
177
+ const logs = await Logs.find(query, options);
178
+ const count = includeCount ? await Logs.countDocuments(query) : logs.length;
179
+ return {
180
+ source: 'local',
181
+ logs,
182
+ count
183
+ };
184
+ }
185
+
186
+ async function runRemoteLogsQuery(
187
+ serverConfig: Record<string, any>,
188
+ payload: {
189
+ query: Record<string, any>;
190
+ options: Record<string, any>;
191
+ includeCount: boolean;
192
+ }
193
+ ): Promise<{ source: 'remote'; logs: any[]; count: number; endpoint: string }> {
194
+ const endpoint = resolveRemoteLogsEndpoint(serverConfig);
195
+ const apiKey = resolveRemoteLogsApiKey(serverConfig);
196
+ if (!apiKey) {
197
+ throw new Error('Missing RESOLVEIO_LOGS_API_KEY for remote log query.');
198
+ }
199
+ const response = await axios.post(
200
+ endpoint,
201
+ {
202
+ query: payload.query,
203
+ options: payload.options,
204
+ include_count: payload.includeCount
205
+ },
206
+ {
207
+ headers: {
208
+ 'Content-Type': 'application/json',
209
+ 'x-resolveio-logs-key': apiKey
210
+ },
211
+ timeout: REMOTE_LOG_QUERY_TIMEOUT_MS
212
+ }
213
+ );
214
+ const result = response?.data?.result || {};
215
+ return {
216
+ source: 'remote',
217
+ logs: Array.isArray(result.logs) ? reviveIsoDateStrings(result.logs) : [],
218
+ count: Number.isFinite(Number(result.count)) ? Number(result.count) : 0,
219
+ endpoint
220
+ };
221
+ }
222
+
223
+ export function loadLogMethods(methodManager: MethodManager) {
224
+ methodManager.methods({
225
+ insertErrorLog: {
226
+ function: async function(message, data) {
227
+ const payloadCorrelationId = typeof data === 'object' && data
228
+ ? (typeof data.correlationId === 'string' && data.correlationId)
229
+ || (typeof data.error === 'object' && data.error && typeof data.error.correlationId === 'string' && data.error.correlationId)
230
+ : undefined;
231
+ const correlationId = getCorrelationId() || payloadCorrelationId || objectIdHexString();
232
+ const payload = {
233
+ user: this.user,
234
+ id_user: this.id_user,
235
+ message,
236
+ data,
237
+ correlationId
238
+ };
239
+
240
+ await ErrorReporter.report({
241
+ sourceApp: 'method-logs',
242
+ message: 'Error Detected - ' + ResolveIOServer.getClientName(),
243
+ environment: this.serverConfig?.ROOT_URL || ResolveIOServer.getServerConfig()?.ROOT_URL,
244
+ clientSlug: ResolveIOServer.getClientName(),
245
+ clientName: ResolveIOServer.getServerConfig()?.CLIENT_NAME,
246
+ severity: 'error',
247
+ context: payload,
248
+ metadata: {
249
+ context: 'insertErrorLog',
250
+ message,
251
+ correlationId
252
+ },
253
+ correlationId
254
+ });
255
+
256
+ if (
257
+ ResolveIOServer.shouldWriteLogsOffline()
258
+ ) {
259
+ ResolveIOServer.getLocalLogManager().writeLog({
260
+ type: 'log',
261
+ data: {
262
+ _id: objectIdHexString(),
263
+ createdAt: new Date(),
264
+ type: 'error',
265
+ collection: '',
266
+ id_document: '',
267
+ payload: JSON.stringify([payload], null, 2),
268
+ method: '',
269
+ id_user: this.id_user || '',
270
+ user: this.user || '',
271
+ messageId: 0,
272
+ route: '',
273
+ instance_index: process.env.NODE_APP_INSTANCE || '0',
274
+ correlationId
275
+ }
276
+ });
277
+ }
278
+ else {
279
+ await Logs.insertOne({
280
+ _id: objectIdHexString(),
281
+ type: 'error',
282
+ collection: '',
283
+ id_document: '',
284
+ payload: JSON.stringify([payload], null, 2),
285
+ method: '',
286
+ id_user: this.id_user || '',
287
+ user: this.user || '',
288
+ messageId: 0,
289
+ route: '',
290
+ client: 'ResolveIO',
291
+ instance: ResolveIOServer.getInstanceHost(),
292
+ instance_index: process.env.NODE_APP_INSTANCE || '0',
293
+ correlationId
294
+ });
295
+ }
296
+
297
+ return true;
298
+ },
299
+ skipValidation: true
300
+ },
301
+ insertSubscriptionLog: {
302
+ function: async function(type, subscription, collection_name, subData) {
303
+ if (
304
+ ResolveIOServer.shouldWriteLogsOffline()
305
+ ) {
306
+ ResolveIOServer.getLocalLogManager().writeLog({
307
+ type: 'log-subscription',
308
+ data: {
309
+ _id: objectIdHexString(),
310
+ __v: 0,
311
+ date: new Date(),
312
+ type: type,
313
+ subscription: subscription,
314
+ collection_name: collection_name,
315
+ subData: subData,
316
+ instance_index: process.env.NODE_APP_INSTANCE || '0'
317
+ }
318
+ });
319
+ }
320
+ else {
321
+ await LogSubscriptions.create({
322
+ _id: objectIdHexString(),
323
+ __v: 0,
324
+ date: new Date(),
325
+ type: type,
326
+ subscription: subscription,
327
+ collection_name: collection_name,
328
+ subData: subData,
329
+ client: 'ResolveIO',
330
+ instance: ResolveIOServer.getInstanceHost()
331
+ });
332
+ }
333
+
334
+ return true;
335
+ },
336
+ skipValidation: true
337
+ },
338
+ queryLogsForDashboard: {
339
+ function: async function(payload: any = {}) {
340
+ const normalized = normalizeLogQueryPayload(payload);
341
+ const useRemote = shouldUseRemoteLogsSource(this.serverConfig || {}, normalized.sourceMode);
342
+ if (useRemote) {
343
+ try {
344
+ const remote = await runRemoteLogsQuery(this.serverConfig || {}, normalized);
345
+ return {
346
+ source: remote.source,
347
+ logs: remote.logs,
348
+ count: remote.count,
349
+ endpoint: remote.endpoint
350
+ };
351
+ }
352
+ catch (error) {
353
+ const fallback = await runLocalLogsQuery(normalized.query, normalized.options, normalized.includeCount);
354
+ return {
355
+ source: fallback.source,
356
+ logs: fallback.logs,
357
+ count: fallback.count,
358
+ remote_error: (error as Error)?.message || String(error)
359
+ };
360
+ }
361
+ }
362
+ const local = await runLocalLogsQuery(normalized.query, normalized.options, normalized.includeCount);
363
+ return {
364
+ source: local.source,
365
+ logs: local.logs,
366
+ count: local.count
367
+ };
368
+ },
369
+ skipValidation: true
370
+ },
371
+ queryResolveIOLogsRemote: {
372
+ function: async function(payload: any = {}) {
373
+ const normalized = normalizeLogQueryPayload({
374
+ ...(payload || {}),
375
+ force_source: 'remote'
376
+ });
377
+ const remote = await runRemoteLogsQuery(this.serverConfig || {}, normalized);
378
+ return {
379
+ source: remote.source,
380
+ logs: remote.logs,
381
+ count: remote.count,
382
+ endpoint: remote.endpoint
383
+ };
384
+ },
385
+ skipValidation: true
386
+ },
387
+ superadminAPM: {
388
+ function: async function(date_start: Date, date_end: Date, graphInterval) {
389
+ let latencies = await LogMethodLatencies.aggregate([
390
+ {
391
+ $match: {
392
+ $and: [
393
+ {
394
+ createdAt: {$gte: date_start}
395
+ },
396
+ {
397
+ createdAt: {$lte: date_end}
398
+ }
399
+ ]
400
+ }
401
+ },
402
+ {
403
+ $group: {
404
+ _id: '$method',
405
+ method: {$first: '$method'},
406
+ count: {$sum: 1},
407
+ latency_min: {$min: '$latency_ms'},
408
+ latency_avg: {$avg: '$latency_ms'},
409
+ latency_max: {$max: '$latency_ms'}
410
+ }
411
+ }
412
+ ], {allowDiskUse: true, readPreference: this.serverConfig['ROOT_URL'] !== 'http://localhost:4200' ? 'secondary' : 'primary'}, true);
413
+
414
+ let subscriptions = await LogSubscriptions.aggregate([
415
+ {
416
+ $match: {
417
+ $and: [
418
+ {
419
+ createdAt: {$gte: date_start}
420
+ },
421
+ {
422
+ createdAt: {$lte: date_end}
423
+ }
424
+ ]
425
+ }
426
+ },
427
+ {
428
+ $group: {
429
+ _id: '$subscription',
430
+ subscription: {$first: '$subscription'},
431
+ count: {$sum: 1}
432
+ }
433
+ }
434
+ ], {allowDiskUse: true, readPreference: this.serverConfig['ROOT_URL'] !== 'http://localhost:4200' ? 'secondary' : 'primary'}, true);
435
+
436
+ let groupId = {};
437
+ let groupSort = {};
438
+
439
+ if (graphInterval === 'seconds') {
440
+ groupId = {
441
+ second: {
442
+ $second: {
443
+ date: '$createdAt',
444
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
445
+ }
446
+ },
447
+ minute: {
448
+ $minute: {
449
+ date: '$createdAt',
450
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
451
+ }
452
+ },
453
+ hour: {
454
+ $hour: {
455
+ date: '$createdAt',
456
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
457
+ }
458
+ },
459
+ day: {
460
+ $dayOfMonth: {
461
+ date: '$createdAt',
462
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
463
+ }
464
+ },
465
+ month: {
466
+ $month: {
467
+ date: '$createdAt',
468
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
469
+ }
470
+ },
471
+ year: {
472
+ $year: {
473
+ date: '$createdAt',
474
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
475
+ }
476
+ }
477
+ };
478
+
479
+ groupSort = {
480
+ '_id.year': 1,
481
+ '_id.month': 1,
482
+ '_id.day': 1,
483
+ '_id.hour': 1,
484
+ '_id.minute': 1,
485
+ '_id.second': 1
486
+ };
487
+ }
488
+ else if (graphInterval === 'minutes') {
489
+ groupId = {
490
+ minute: {
491
+ $minute: {
492
+ date: '$createdAt',
493
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
494
+ }
495
+ },
496
+ hour: {
497
+ $hour: {
498
+ date: '$createdAt',
499
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
500
+ }
501
+ },
502
+ day: {
503
+ $dayOfMonth: {
504
+ date: '$createdAt',
505
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
506
+ }
507
+ },
508
+ month: {
509
+ $month: {
510
+ date: '$createdAt',
511
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
512
+ }
513
+ },
514
+ year: {
515
+ $year: {
516
+ date: '$createdAt',
517
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
518
+ }
519
+ }
520
+ };
521
+
522
+ groupSort = {
523
+ '_id.year': 1,
524
+ '_id.month': 1,
525
+ '_id.day': 1,
526
+ '_id.hour': 1,
527
+ '_id.minute': 1
528
+ };
529
+ }
530
+ else if (graphInterval === 'hours') {
531
+ groupId = {
532
+ hour: {
533
+ $hour: {
534
+ date: '$createdAt',
535
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
536
+ }
537
+ },
538
+ day: {
539
+ $dayOfMonth: {
540
+ date: '$createdAt',
541
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
542
+ }
543
+ },
544
+ month: {
545
+ $month: {
546
+ date: '$createdAt',
547
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
548
+ }
549
+ },
550
+ year: {
551
+ $year: {
552
+ date: '$createdAt',
553
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
554
+ }
555
+ }
556
+ };
557
+
558
+ groupSort = {
559
+ '_id.year': 1,
560
+ '_id.month': 1,
561
+ '_id.day': 1,
562
+ '_id.hour': 1
563
+ };
564
+ }
565
+ else {
566
+ groupId = {
567
+ day: {
568
+ $dayOfMonth: {
569
+ date: '$createdAt',
570
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
571
+ }
572
+ },
573
+ month: {
574
+ $month: {
575
+ date: '$createdAt',
576
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
577
+ }
578
+ },
579
+ year: {
580
+ $year: {
581
+ date: '$createdAt',
582
+ timezone: process.env.TZ_CLIENT || 'America/Chicago'
583
+ }
584
+ }
585
+ };
586
+
587
+ groupSort = {
588
+ '_id.year': 1,
589
+ '_id.month': 1,
590
+ '_id.day': 1
591
+ };
592
+ }
593
+
594
+ let methodGraphData = await LogMethodLatencies.aggregate([
595
+ {
596
+ $match: {
597
+ $and: [
598
+ {
599
+ createdAt: {$gte: date_start}
600
+ },
601
+ {
602
+ createdAt: {$lte: date_end}
603
+ }
604
+ ]
605
+ }
606
+ },
607
+ {
608
+ $group: {
609
+ _id: groupId,
610
+ count: {
611
+ $sum: 1
612
+ }
613
+ }
614
+ },
615
+ {
616
+ $sort: groupSort
617
+ }
618
+ ], {allowDiskUse: true, readPreference: this.serverConfig['ROOT_URL'] !== 'http://localhost:4200' ? 'secondary' : 'primary'}, true);
619
+
620
+ let subGraphData = await LogSubscriptions.aggregate([
621
+ {
622
+ $match: {
623
+ $and: [
624
+ {
625
+ createdAt: {$gte: date_start}
626
+ },
627
+ {
628
+ createdAt: {$lte: date_end}
629
+ }
630
+ ]
631
+ }
632
+ },
633
+ {
634
+ $group: {
635
+ _id: groupId,
636
+ count: {
637
+ $sum: 1
638
+ }
639
+ }
640
+ },
641
+ {
642
+ $sort: groupSort
643
+ }
644
+ ], {allowDiskUse: true, readPreference: this.serverConfig['ROOT_URL'] !== 'http://localhost:4200' ? 'secondary' : 'primary'}, true);
645
+
646
+ return {
647
+ methods: latencies,
648
+ subscriptions: subscriptions,
649
+ methodGraphData: methodGraphData,
650
+ subGraphData: subGraphData
651
+ };
652
+ },
653
+ skipValidation: true
654
+ }
655
+ });
656
+ }