@resolveio/server-lib 22.3.3 → 22.3.5

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 (669) hide show
  1. package/.nodemon.json +5 -0
  2. package/.vscode/settings.json +21 -0
  3. package/AGENTS.md +188 -0
  4. package/README.md +22 -0
  5. package/build_package.sh +5 -0
  6. package/compileDTS.pl +64 -0
  7. package/docs/ai-assistant-nightly-eval.md +65 -0
  8. package/docs/ai-assistant-preflight-checklist.md +23 -0
  9. package/docs/ai-assistant-report-builder-bridge-playbook.md +115 -0
  10. package/eslint-plugin-custom/index.js +7 -0
  11. package/eslint-plugin-custom/rules/no-filter-zero-index.js +44 -0
  12. package/eslint.config.js +103 -0
  13. package/gulpfile.js +216 -0
  14. package/methodAndPublicationListGenerator.py +344 -0
  15. package/mongodbensurers.js +2 -0
  16. package/mongostop.js +3 -0
  17. package/package.json +1 -1
  18. package/scripts/cleanup-bypassed-callmethod-logs.js +616 -0
  19. package/settings.development.json +25 -0
  20. package/settings.development.redacted.json +25 -0
  21. package/src/.env +12 -0
  22. package/src/ai/assistant-core-heuristics.ts +379 -0
  23. package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +185 -0
  24. package/src/ai/resolveio-platform-intelligence-memory.ts +325 -0
  25. package/{ai/resolveio-platform-intelligence-types.d.ts → src/ai/resolveio-platform-intelligence-types.ts} +20 -15
  26. package/src/ai/resolveio-platform-intelligence.ts +462 -0
  27. package/src/client-server-app.ts +12 -0
  28. package/src/collections/ai-terminal-conversation.collection.ts +91 -0
  29. package/src/collections/ai-terminal-issue-report.collection.ts +99 -0
  30. package/src/collections/ai-terminal-message.collection.ts +77 -0
  31. package/src/collections/app-setting.collection.ts +104 -0
  32. package/src/collections/app-status.collection.ts +58 -0
  33. package/src/collections/communication-metric.collection.ts +84 -0
  34. package/src/collections/counter.collection.ts +56 -0
  35. package/src/collections/cron-job-history.collection.ts +94 -0
  36. package/src/collections/cron-job.collection.ts +92 -0
  37. package/src/collections/customer-notification.collection.ts +131 -0
  38. package/src/collections/customer-portal-password.collection.ts +76 -0
  39. package/src/collections/email-history.collection.ts +127 -0
  40. package/src/collections/email-verified.collection.ts +62 -0
  41. package/src/collections/file.collection.ts +74 -0
  42. package/src/collections/flag-update.collection.ts +57 -0
  43. package/src/collections/flag.collection.ts +57 -0
  44. package/src/collections/log-method-latency.collection.ts +77 -0
  45. package/src/collections/log-subscription.collection.ts +80 -0
  46. package/src/collections/log.collection.ts +93 -0
  47. package/src/collections/logged-in-users.collection.ts +67 -0
  48. package/src/collections/monitor-cpu.collection.ts +65 -0
  49. package/src/collections/monitor-function.collection.ts +74 -0
  50. package/src/collections/monitor-memory.collection.ts +77 -0
  51. package/src/collections/monitor-mongo.collection.ts +71 -0
  52. package/src/collections/notification.collection.ts +57 -0
  53. package/src/collections/openai-usage-ledger.collection.ts +77 -0
  54. package/src/collections/report-builder-dashboard-builder.collection.ts +109 -0
  55. package/src/collections/report-builder-library.collection.ts +89 -0
  56. package/src/collections/report-builder-report.collection.ts +184 -0
  57. package/src/collections/user-group.collection.ts +89 -0
  58. package/src/collections/user-guide.collection.ts +57 -0
  59. package/src/collections/user.collection.ts +181 -0
  60. package/src/cron/cron.ts +117 -0
  61. package/src/fixtures/cron-jobs.ts +95 -0
  62. package/src/fixtures/init.ts +35 -0
  63. package/src/http/auth.ts +764 -0
  64. package/src/http/health.ts +7 -0
  65. package/src/http/home.ts +90 -0
  66. package/src/http/slow-query-publication.ts +49 -0
  67. package/src/index.ts +1 -0
  68. package/src/managers/ai-assistant-codex-manager.manager.ts +1131 -0
  69. package/src/managers/communication-metric.manager.ts +82 -0
  70. package/src/managers/cron.manager.ts +333 -0
  71. package/src/managers/customer-notification-content.manager.ts +236 -0
  72. package/src/managers/diagnostic-manager-bootstrap.ts +165 -0
  73. package/src/managers/error-auto-fix.manager.ts +2767 -0
  74. package/src/managers/local-log.manager.ts +113 -0
  75. package/src/managers/method.manager.ts +1827 -0
  76. package/src/managers/mongo.manager.ts +4575 -0
  77. package/src/managers/monitor.manager.ts +507 -0
  78. package/src/managers/openai-usage-ledger.manager.ts +116 -0
  79. package/src/managers/slow-query-verifier.manager.ts +3590 -0
  80. package/src/managers/slow-query.manager.ts +519 -0
  81. package/src/managers/subscription.manager.ts +3128 -0
  82. package/src/managers/websocket.manager.ts +746 -0
  83. package/src/managers/worker-dispatcher.manager.ts +1360 -0
  84. package/src/managers/worker-server.manager.ts +536 -0
  85. package/src/methods/accounts.ts +532 -0
  86. package/src/methods/ai-terminal.ts +22943 -0
  87. package/src/methods/app-settings.ts +114 -0
  88. package/src/methods/aws.ts +649 -0
  89. package/src/methods/collections.ts +641 -0
  90. package/src/methods/counters.ts +69 -0
  91. package/src/methods/cron-jobs.ts +2614 -0
  92. package/src/methods/customer-notifications.ts +458 -0
  93. package/src/methods/diagnostics.ts +616 -0
  94. package/src/methods/flag-updates.ts +7 -0
  95. package/src/methods/flags.ts +7 -0
  96. package/src/methods/logs.ts +657 -0
  97. package/src/methods/mongo-explorer.ts +1880 -0
  98. package/src/methods/monitor.ts +540 -0
  99. package/src/methods/pdf.ts +1236 -0
  100. package/src/methods/publications.ts +129 -0
  101. package/src/methods/report-builder.ts +3300 -0
  102. package/src/methods/support.ts +335 -0
  103. package/src/models/ai-terminal-conversation.model.ts +19 -0
  104. package/src/models/ai-terminal-issue-report.model.ts +21 -0
  105. package/src/models/ai-terminal-message.model.ts +24 -0
  106. package/src/models/app-setting.model.ts +17 -0
  107. package/{models/app-status.model.d.ts → src/models/app-status.model.ts} +3 -2
  108. package/{models/billing-logged-in-users.model.d.ts → src/models/billing-logged-in-users.model.ts} +5 -4
  109. package/src/models/collection-document.model.ts +24 -0
  110. package/src/models/communication-metric.model.ts +23 -0
  111. package/{models/counter.model.d.ts → src/models/counter.model.ts} +4 -3
  112. package/src/models/cron-job-history.model.ts +16 -0
  113. package/src/models/cron-job.model.ts +15 -0
  114. package/src/models/customer-notification.model.ts +28 -0
  115. package/src/models/customer-portal-password.model.ts +12 -0
  116. package/src/models/dialog.model.ts +25 -0
  117. package/{models/email-history.model.js → src/models/email-history.model.ts} +35 -4
  118. package/{models/email-verified.model.d.ts → src/models/email-verified.model.ts} +6 -5
  119. package/{models/file.model.d.ts → src/models/file.model.ts} +8 -7
  120. package/{models/flag-update.model.d.ts → src/models/flag-update.model.ts} +4 -3
  121. package/{models/flag.model.d.ts → src/models/flag.model.ts} +4 -3
  122. package/src/models/log-method-latency.model.ts +11 -0
  123. package/{models/log-subscription.model.d.ts → src/models/log-subscription.model.ts} +11 -9
  124. package/src/models/log.model.ts +19 -0
  125. package/{models/logged-in-users.model.d.ts → src/models/logged-in-users.model.ts} +6 -5
  126. package/{models/method-response.model.d.ts → src/models/method-response.model.ts} +7 -6
  127. package/src/models/method.model.ts +25 -0
  128. package/{models/monitor-cpu.model.d.ts → src/models/monitor-cpu.model.ts} +9 -7
  129. package/src/models/monitor-function.model.ts +16 -0
  130. package/src/models/monitor-memory.model.ts +17 -0
  131. package/src/models/monitor-mongo.model.ts +15 -0
  132. package/{models/notification.model.d.ts → src/models/notification.model.ts} +6 -4
  133. package/src/models/openai-usage-ledger.model.ts +16 -0
  134. package/src/models/pagination.model.ts +35 -0
  135. package/src/models/permission.model.ts +14 -0
  136. package/src/models/report-builder-dashboard-builder.model.ts +29 -0
  137. package/src/models/report-builder-library.model.ts +20 -0
  138. package/src/models/report-builder-report.model.ts +136 -0
  139. package/src/models/report-builder.model.ts +68 -0
  140. package/src/models/select-data-label.model.ts +9 -0
  141. package/src/models/server-message.model.ts +31 -0
  142. package/src/models/slow-query-report.model.ts +23 -0
  143. package/src/models/subscription.model.ts +73 -0
  144. package/src/models/support-ticket.model.ts +104 -0
  145. package/src/models/user-group.model.ts +24 -0
  146. package/{models/user-guide.model.d.ts → src/models/user-guide.model.ts} +5 -4
  147. package/src/models/user.model.ts +96 -0
  148. package/src/private/images/ResolveIO.png +0 -0
  149. package/src/publications/ai-terminal.ts +73 -0
  150. package/src/publications/app-settings.ts +25 -0
  151. package/src/publications/app-status.ts +13 -0
  152. package/src/publications/cron-jobs.ts +40 -0
  153. package/src/publications/customer-notifications.ts +101 -0
  154. package/src/publications/files.ts +33 -0
  155. package/src/publications/flags-update.ts +19 -0
  156. package/src/publications/flags.ts +19 -0
  157. package/src/publications/logs.ts +163 -0
  158. package/src/publications/notifications.ts +13 -0
  159. package/src/publications/report-builder-dashboard-builders.ts +39 -0
  160. package/src/publications/report-builder-libraries.ts +41 -0
  161. package/src/publications/report-builder-reports.ts +47 -0
  162. package/src/publications/super-admin.ts +13 -0
  163. package/src/publications/user-groups.ts +12 -0
  164. package/src/publications/user-guides.ts +12 -0
  165. package/src/resolveio-server-app.ts +617 -0
  166. package/src/server-app.ts +3342 -0
  167. package/src/services/codex-client.ts +1124 -0
  168. package/src/services/openai-client.ts +265 -0
  169. package/src/types/error-report.ts +26 -0
  170. package/src/types/js-tiktoken.d.ts +11 -0
  171. package/src/types/slow-query-report.ts +28 -0
  172. package/src/util/common.ts +649 -0
  173. package/src/util/customer-portal-password.ts +183 -0
  174. package/src/util/error-reporter.ts +332 -0
  175. package/src/util/error-tracking.ts +79 -0
  176. package/src/util/report-builder-unwinds.ts +180 -0
  177. package/src/util/schema-report-builder.ts +448 -0
  178. package/src/util/slow-query-reporter.ts +216 -0
  179. package/src/util/subscription-dependency-context.ts +1096 -0
  180. package/src/util/tokenizer.ts +38 -0
  181. package/src/workers/codex-runner.worker.ts +142 -0
  182. package/start_server.sh +5 -0
  183. package/tests/ai-assistant-corpus-build.ts +484 -0
  184. package/tests/ai-assistant-corpus-replay-e2e.ts +774 -0
  185. package/tests/ai-assistant-data-parity-e2e.ts +1989 -0
  186. package/tests/ai-assistant-eval-triage.ts +831 -0
  187. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  188. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  189. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  190. package/tests/ai-assistant-routing-eval.test.ts +560 -0
  191. package/tests/ai-assistant-snf-live-eval.ts +975 -0
  192. package/tests/ai-assistant-utils.test.ts +2860 -0
  193. package/tests/error-reporter.test.ts +145 -0
  194. package/tests/report-builder-linking.test.ts +79 -0
  195. package/tests/resolveio-platform-intelligence.test.ts +352 -0
  196. package/tests/server-app-cron-owner.test.ts +127 -0
  197. package/tests/subscription-connect-race.test.ts +158 -0
  198. package/tests/subscription-dependency-context.test.ts +324 -0
  199. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  200. package/tests/subscription-manager-invalidation.test.ts +86 -0
  201. package/tsconfig.json +34 -0
  202. package/ai/assistant-core-heuristics.d.ts +0 -11
  203. package/ai/assistant-core-heuristics.js +0 -356
  204. package/ai/assistant-core-heuristics.js.map +0 -1
  205. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +0 -3
  206. package/ai/resolveio-platform-intelligence-memory-corpus.js +0 -214
  207. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +0 -1
  208. package/ai/resolveio-platform-intelligence-memory.d.ts +0 -20
  209. package/ai/resolveio-platform-intelligence-memory.js +0 -341
  210. package/ai/resolveio-platform-intelligence-memory.js.map +0 -1
  211. package/ai/resolveio-platform-intelligence-types.js +0 -4
  212. package/ai/resolveio-platform-intelligence-types.js.map +0 -1
  213. package/ai/resolveio-platform-intelligence.d.ts +0 -6
  214. package/ai/resolveio-platform-intelligence.js +0 -463
  215. package/ai/resolveio-platform-intelligence.js.map +0 -1
  216. package/client-server-app.d.ts +0 -1
  217. package/client-server-app.js +0 -68
  218. package/client-server-app.js.map +0 -1
  219. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  220. package/collections/ai-terminal-conversation.collection.js +0 -140
  221. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  222. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  223. package/collections/ai-terminal-issue-report.collection.js +0 -148
  224. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  225. package/collections/ai-terminal-message.collection.d.ts +0 -2
  226. package/collections/ai-terminal-message.collection.js +0 -121
  227. package/collections/ai-terminal-message.collection.js.map +0 -1
  228. package/collections/app-setting.collection.d.ts +0 -3
  229. package/collections/app-setting.collection.js +0 -103
  230. package/collections/app-setting.collection.js.map +0 -1
  231. package/collections/app-status.collection.d.ts +0 -3
  232. package/collections/app-status.collection.js +0 -57
  233. package/collections/app-status.collection.js.map +0 -1
  234. package/collections/communication-metric.collection.d.ts +0 -2
  235. package/collections/communication-metric.collection.js +0 -133
  236. package/collections/communication-metric.collection.js.map +0 -1
  237. package/collections/counter.collection.d.ts +0 -3
  238. package/collections/counter.collection.js +0 -56
  239. package/collections/counter.collection.js.map +0 -1
  240. package/collections/cron-job-history.collection.d.ts +0 -3
  241. package/collections/cron-job-history.collection.js +0 -137
  242. package/collections/cron-job-history.collection.js.map +0 -1
  243. package/collections/cron-job.collection.d.ts +0 -3
  244. package/collections/cron-job.collection.js +0 -92
  245. package/collections/cron-job.collection.js.map +0 -1
  246. package/collections/customer-notification.collection.d.ts +0 -3
  247. package/collections/customer-notification.collection.js +0 -130
  248. package/collections/customer-notification.collection.js.map +0 -1
  249. package/collections/customer-portal-password.collection.d.ts +0 -3
  250. package/collections/customer-portal-password.collection.js +0 -75
  251. package/collections/customer-portal-password.collection.js.map +0 -1
  252. package/collections/email-history.collection.d.ts +0 -3
  253. package/collections/email-history.collection.js +0 -127
  254. package/collections/email-history.collection.js.map +0 -1
  255. package/collections/email-verified.collection.d.ts +0 -3
  256. package/collections/email-verified.collection.js +0 -62
  257. package/collections/email-verified.collection.js.map +0 -1
  258. package/collections/file.collection.d.ts +0 -3
  259. package/collections/file.collection.js +0 -74
  260. package/collections/file.collection.js.map +0 -1
  261. package/collections/flag-update.collection.d.ts +0 -3
  262. package/collections/flag-update.collection.js +0 -57
  263. package/collections/flag-update.collection.js.map +0 -1
  264. package/collections/flag.collection.d.ts +0 -3
  265. package/collections/flag.collection.js +0 -57
  266. package/collections/flag.collection.js.map +0 -1
  267. package/collections/log-method-latency.collection.d.ts +0 -3
  268. package/collections/log-method-latency.collection.js +0 -77
  269. package/collections/log-method-latency.collection.js.map +0 -1
  270. package/collections/log-subscription.collection.d.ts +0 -3
  271. package/collections/log-subscription.collection.js +0 -80
  272. package/collections/log-subscription.collection.js.map +0 -1
  273. package/collections/log.collection.d.ts +0 -3
  274. package/collections/log.collection.js +0 -93
  275. package/collections/log.collection.js.map +0 -1
  276. package/collections/logged-in-users.collection.d.ts +0 -3
  277. package/collections/logged-in-users.collection.js +0 -67
  278. package/collections/logged-in-users.collection.js.map +0 -1
  279. package/collections/monitor-cpu.collection.d.ts +0 -3
  280. package/collections/monitor-cpu.collection.js +0 -65
  281. package/collections/monitor-cpu.collection.js.map +0 -1
  282. package/collections/monitor-function.collection.d.ts +0 -3
  283. package/collections/monitor-function.collection.js +0 -74
  284. package/collections/monitor-function.collection.js.map +0 -1
  285. package/collections/monitor-memory.collection.d.ts +0 -3
  286. package/collections/monitor-memory.collection.js +0 -77
  287. package/collections/monitor-memory.collection.js.map +0 -1
  288. package/collections/monitor-mongo.collection.d.ts +0 -3
  289. package/collections/monitor-mongo.collection.js +0 -71
  290. package/collections/monitor-mongo.collection.js.map +0 -1
  291. package/collections/notification.collection.d.ts +0 -3
  292. package/collections/notification.collection.js +0 -57
  293. package/collections/notification.collection.js.map +0 -1
  294. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  295. package/collections/openai-usage-ledger.collection.js +0 -124
  296. package/collections/openai-usage-ledger.collection.js.map +0 -1
  297. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  298. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  299. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  300. package/collections/report-builder-library.collection.d.ts +0 -3
  301. package/collections/report-builder-library.collection.js +0 -87
  302. package/collections/report-builder-library.collection.js.map +0 -1
  303. package/collections/report-builder-report.collection.d.ts +0 -4
  304. package/collections/report-builder-report.collection.js +0 -184
  305. package/collections/report-builder-report.collection.js.map +0 -1
  306. package/collections/user-group.collection.d.ts +0 -4
  307. package/collections/user-group.collection.js +0 -89
  308. package/collections/user-group.collection.js.map +0 -1
  309. package/collections/user-guide.collection.d.ts +0 -3
  310. package/collections/user-guide.collection.js +0 -57
  311. package/collections/user-guide.collection.js.map +0 -1
  312. package/collections/user.collection.d.ts +0 -4
  313. package/collections/user.collection.js +0 -180
  314. package/collections/user.collection.js.map +0 -1
  315. package/cron/cron.d.ts +0 -14
  316. package/cron/cron.js +0 -216
  317. package/cron/cron.js.map +0 -1
  318. package/fixtures/cron-jobs.d.ts +0 -1
  319. package/fixtures/cron-jobs.js +0 -150
  320. package/fixtures/cron-jobs.js.map +0 -1
  321. package/fixtures/init.d.ts +0 -1
  322. package/fixtures/init.js +0 -91
  323. package/fixtures/init.js.map +0 -1
  324. package/http/auth.d.ts +0 -2
  325. package/http/auth.js +0 -906
  326. package/http/auth.js.map +0 -1
  327. package/http/health.d.ts +0 -1
  328. package/http/health.js +0 -11
  329. package/http/health.js.map +0 -1
  330. package/http/home.d.ts +0 -1
  331. package/http/home.js +0 -134
  332. package/http/home.js.map +0 -1
  333. package/http/slow-query-publication.d.ts +0 -2
  334. package/http/slow-query-publication.js +0 -99
  335. package/http/slow-query-publication.js.map +0 -1
  336. package/index.d.ts +0 -1
  337. package/index.js +0 -19
  338. package/index.js.map +0 -1
  339. package/managers/ai-assistant-codex-manager.manager.d.ts +0 -67
  340. package/managers/ai-assistant-codex-manager.manager.js +0 -1113
  341. package/managers/ai-assistant-codex-manager.manager.js.map +0 -1
  342. package/managers/communication-metric.manager.d.ts +0 -16
  343. package/managers/communication-metric.manager.js +0 -134
  344. package/managers/communication-metric.manager.js.map +0 -1
  345. package/managers/cron.manager.d.ts +0 -20
  346. package/managers/cron.manager.js +0 -534
  347. package/managers/cron.manager.js.map +0 -1
  348. package/managers/customer-notification-content.manager.d.ts +0 -55
  349. package/managers/customer-notification-content.manager.js +0 -158
  350. package/managers/customer-notification-content.manager.js.map +0 -1
  351. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  352. package/managers/diagnostic-manager-bootstrap.js +0 -260
  353. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  354. package/managers/error-auto-fix.manager.d.ts +0 -149
  355. package/managers/error-auto-fix.manager.js +0 -3064
  356. package/managers/error-auto-fix.manager.js.map +0 -1
  357. package/managers/local-log.manager.d.ts +0 -18
  358. package/managers/local-log.manager.js +0 -88
  359. package/managers/local-log.manager.js.map +0 -1
  360. package/managers/method.manager.d.ts +0 -83
  361. package/managers/method.manager.js +0 -1940
  362. package/managers/method.manager.js.map +0 -1
  363. package/managers/mongo.manager.d.ts +0 -224
  364. package/managers/mongo.manager.js +0 -5000
  365. package/managers/mongo.manager.js.map +0 -1
  366. package/managers/monitor.manager.d.ts +0 -70
  367. package/managers/monitor.manager.js +0 -550
  368. package/managers/monitor.manager.js.map +0 -1
  369. package/managers/openai-usage-ledger.manager.d.ts +0 -15
  370. package/managers/openai-usage-ledger.manager.js +0 -144
  371. package/managers/openai-usage-ledger.manager.js.map +0 -1
  372. package/managers/slow-query-verifier.manager.d.ts +0 -144
  373. package/managers/slow-query-verifier.manager.js +0 -3857
  374. package/managers/slow-query-verifier.manager.js.map +0 -1
  375. package/managers/slow-query.manager.d.ts +0 -28
  376. package/managers/slow-query.manager.js +0 -468
  377. package/managers/slow-query.manager.js.map +0 -1
  378. package/managers/subscription.manager.d.ts +0 -169
  379. package/managers/subscription.manager.js +0 -3434
  380. package/managers/subscription.manager.js.map +0 -1
  381. package/managers/websocket.manager.d.ts +0 -73
  382. package/managers/websocket.manager.js +0 -673
  383. package/managers/websocket.manager.js.map +0 -1
  384. package/managers/worker-dispatcher.manager.d.ts +0 -120
  385. package/managers/worker-dispatcher.manager.js +0 -1266
  386. package/managers/worker-dispatcher.manager.js.map +0 -1
  387. package/managers/worker-server.manager.d.ts +0 -35
  388. package/managers/worker-server.manager.js +0 -582
  389. package/managers/worker-server.manager.js.map +0 -1
  390. package/methods/accounts.d.ts +0 -2
  391. package/methods/accounts.js +0 -624
  392. package/methods/accounts.js.map +0 -1
  393. package/methods/ai-terminal.d.ts +0 -322
  394. package/methods/ai-terminal.js +0 -22699
  395. package/methods/ai-terminal.js.map +0 -1
  396. package/methods/app-settings.d.ts +0 -2
  397. package/methods/app-settings.js +0 -169
  398. package/methods/app-settings.js.map +0 -1
  399. package/methods/aws.d.ts +0 -2
  400. package/methods/aws.js +0 -877
  401. package/methods/aws.js.map +0 -1
  402. package/methods/collections.d.ts +0 -2
  403. package/methods/collections.js +0 -719
  404. package/methods/collections.js.map +0 -1
  405. package/methods/counters.d.ts +0 -2
  406. package/methods/counters.js +0 -113
  407. package/methods/counters.js.map +0 -1
  408. package/methods/cron-jobs.d.ts +0 -2
  409. package/methods/cron-jobs.js +0 -2475
  410. package/methods/cron-jobs.js.map +0 -1
  411. package/methods/customer-notifications.d.ts +0 -2
  412. package/methods/customer-notifications.js +0 -528
  413. package/methods/customer-notifications.js.map +0 -1
  414. package/methods/diagnostics.d.ts +0 -2
  415. package/methods/diagnostics.js +0 -703
  416. package/methods/diagnostics.js.map +0 -1
  417. package/methods/flag-updates.d.ts +0 -2
  418. package/methods/flag-updates.js +0 -8
  419. package/methods/flag-updates.js.map +0 -1
  420. package/methods/flags.d.ts +0 -2
  421. package/methods/flags.js +0 -8
  422. package/methods/flags.js.map +0 -1
  423. package/methods/logs.d.ts +0 -2
  424. package/methods/logs.js +0 -751
  425. package/methods/logs.js.map +0 -1
  426. package/methods/mongo-explorer.d.ts +0 -2
  427. package/methods/mongo-explorer.js +0 -1808
  428. package/methods/mongo-explorer.js.map +0 -1
  429. package/methods/monitor.d.ts +0 -2
  430. package/methods/monitor.js +0 -543
  431. package/methods/monitor.js.map +0 -1
  432. package/methods/pdf.d.ts +0 -2
  433. package/methods/pdf.js +0 -1216
  434. package/methods/pdf.js.map +0 -1
  435. package/methods/publications.d.ts +0 -1
  436. package/methods/publications.js +0 -183
  437. package/methods/publications.js.map +0 -1
  438. package/methods/report-builder.d.ts +0 -2
  439. package/methods/report-builder.js +0 -3094
  440. package/methods/report-builder.js.map +0 -1
  441. package/methods/support.d.ts +0 -2
  442. package/methods/support.js +0 -430
  443. package/methods/support.js.map +0 -1
  444. package/models/ai-terminal-conversation.model.d.ts +0 -17
  445. package/models/ai-terminal-conversation.model.js +0 -4
  446. package/models/ai-terminal-conversation.model.js.map +0 -1
  447. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  448. package/models/ai-terminal-issue-report.model.js +0 -4
  449. package/models/ai-terminal-issue-report.model.js.map +0 -1
  450. package/models/ai-terminal-message.model.d.ts +0 -22
  451. package/models/ai-terminal-message.model.js +0 -4
  452. package/models/ai-terminal-message.model.js.map +0 -1
  453. package/models/app-setting.model.d.ts +0 -16
  454. package/models/app-setting.model.js +0 -4
  455. package/models/app-setting.model.js.map +0 -1
  456. package/models/app-status.model.js +0 -4
  457. package/models/app-status.model.js.map +0 -1
  458. package/models/billing-logged-in-users.model.js +0 -4
  459. package/models/billing-logged-in-users.model.js.map +0 -1
  460. package/models/collection-document.model.d.ts +0 -21
  461. package/models/collection-document.model.js +0 -4
  462. package/models/collection-document.model.js.map +0 -1
  463. package/models/communication-metric.model.d.ts +0 -20
  464. package/models/communication-metric.model.js +0 -4
  465. package/models/communication-metric.model.js.map +0 -1
  466. package/models/counter.model.js +0 -4
  467. package/models/counter.model.js.map +0 -1
  468. package/models/cron-job-history.model.d.ts +0 -15
  469. package/models/cron-job-history.model.js +0 -4
  470. package/models/cron-job-history.model.js.map +0 -1
  471. package/models/cron-job.model.d.ts +0 -14
  472. package/models/cron-job.model.js +0 -4
  473. package/models/cron-job.model.js.map +0 -1
  474. package/models/customer-notification.model.d.ts +0 -26
  475. package/models/customer-notification.model.js +0 -4
  476. package/models/customer-notification.model.js.map +0 -1
  477. package/models/customer-portal-password.model.d.ts +0 -11
  478. package/models/customer-portal-password.model.js +0 -4
  479. package/models/customer-portal-password.model.js.map +0 -1
  480. package/models/dialog.model.d.ts +0 -23
  481. package/models/dialog.model.js +0 -4
  482. package/models/dialog.model.js.map +0 -1
  483. package/models/email-history.model.d.ts +0 -31
  484. package/models/email-history.model.js.map +0 -1
  485. package/models/email-verified.model.js +0 -4
  486. package/models/email-verified.model.js.map +0 -1
  487. package/models/file.model.js +0 -4
  488. package/models/file.model.js.map +0 -1
  489. package/models/flag-update.model.js +0 -4
  490. package/models/flag-update.model.js.map +0 -1
  491. package/models/flag.model.js +0 -4
  492. package/models/flag.model.js.map +0 -1
  493. package/models/log-method-latency.model.d.ts +0 -10
  494. package/models/log-method-latency.model.js +0 -4
  495. package/models/log-method-latency.model.js.map +0 -1
  496. package/models/log-subscription.model.js +0 -4
  497. package/models/log-subscription.model.js.map +0 -1
  498. package/models/log.model.d.ts +0 -17
  499. package/models/log.model.js +0 -4
  500. package/models/log.model.js.map +0 -1
  501. package/models/logged-in-users.model.js +0 -4
  502. package/models/logged-in-users.model.js.map +0 -1
  503. package/models/method-response.model.js +0 -4
  504. package/models/method-response.model.js.map +0 -1
  505. package/models/method.model.d.ts +0 -26
  506. package/models/method.model.js +0 -4
  507. package/models/method.model.js.map +0 -1
  508. package/models/monitor-cpu.model.js +0 -4
  509. package/models/monitor-cpu.model.js.map +0 -1
  510. package/models/monitor-function.model.d.ts +0 -14
  511. package/models/monitor-function.model.js +0 -4
  512. package/models/monitor-function.model.js.map +0 -1
  513. package/models/monitor-memory.model.d.ts +0 -15
  514. package/models/monitor-memory.model.js +0 -4
  515. package/models/monitor-memory.model.js.map +0 -1
  516. package/models/monitor-mongo.model.d.ts +0 -13
  517. package/models/monitor-mongo.model.js +0 -4
  518. package/models/monitor-mongo.model.js.map +0 -1
  519. package/models/notification.model.js +0 -4
  520. package/models/notification.model.js.map +0 -1
  521. package/models/openai-usage-ledger.model.d.ts +0 -15
  522. package/models/openai-usage-ledger.model.js +0 -4
  523. package/models/openai-usage-ledger.model.js.map +0 -1
  524. package/models/pagination.model.d.ts +0 -11
  525. package/models/pagination.model.js +0 -28
  526. package/models/pagination.model.js.map +0 -1
  527. package/models/permission.model.d.ts +0 -12
  528. package/models/permission.model.js +0 -4
  529. package/models/permission.model.js.map +0 -1
  530. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  531. package/models/report-builder-dashboard-builder.model.js +0 -4
  532. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  533. package/models/report-builder-library.model.d.ts +0 -17
  534. package/models/report-builder-library.model.js +0 -4
  535. package/models/report-builder-library.model.js.map +0 -1
  536. package/models/report-builder-report.model.d.ts +0 -121
  537. package/models/report-builder-report.model.js +0 -4
  538. package/models/report-builder-report.model.js.map +0 -1
  539. package/models/report-builder.model.d.ts +0 -61
  540. package/models/report-builder.model.js +0 -4
  541. package/models/report-builder.model.js.map +0 -1
  542. package/models/select-data-label.model.d.ts +0 -9
  543. package/models/select-data-label.model.js +0 -4
  544. package/models/select-data-label.model.js.map +0 -1
  545. package/models/server-message.model.d.ts +0 -32
  546. package/models/server-message.model.js +0 -4
  547. package/models/server-message.model.js.map +0 -1
  548. package/models/slow-query-report.model.d.ts +0 -23
  549. package/models/slow-query-report.model.js +0 -4
  550. package/models/slow-query-report.model.js.map +0 -1
  551. package/models/subscription.model.d.ts +0 -31
  552. package/models/subscription.model.js +0 -4
  553. package/models/subscription.model.js.map +0 -1
  554. package/models/support-ticket.model.d.ts +0 -87
  555. package/models/support-ticket.model.js +0 -4
  556. package/models/support-ticket.model.js.map +0 -1
  557. package/models/user-group.model.d.ts +0 -20
  558. package/models/user-group.model.js +0 -4
  559. package/models/user-group.model.js.map +0 -1
  560. package/models/user-guide.model.js +0 -4
  561. package/models/user-guide.model.js.map +0 -1
  562. package/models/user.model.d.ts +0 -84
  563. package/models/user.model.js +0 -4
  564. package/models/user.model.js.map +0 -1
  565. package/private/images/ResolveIO.png +0 -0
  566. package/public_api.js +0 -111
  567. package/public_api.js.map +0 -1
  568. package/publications/ai-terminal.d.ts +0 -1
  569. package/publications/ai-terminal.js +0 -122
  570. package/publications/ai-terminal.js.map +0 -1
  571. package/publications/app-settings.d.ts +0 -2
  572. package/publications/app-settings.js +0 -28
  573. package/publications/app-settings.js.map +0 -1
  574. package/publications/app-status.d.ts +0 -2
  575. package/publications/app-status.js +0 -16
  576. package/publications/app-status.js.map +0 -1
  577. package/publications/cron-jobs.d.ts +0 -2
  578. package/publications/cron-jobs.js +0 -88
  579. package/publications/cron-jobs.js.map +0 -1
  580. package/publications/customer-notifications.d.ts +0 -2
  581. package/publications/customer-notifications.js +0 -161
  582. package/publications/customer-notifications.js.map +0 -1
  583. package/publications/files.d.ts +0 -2
  584. package/publications/files.js +0 -36
  585. package/publications/files.js.map +0 -1
  586. package/publications/flags-update.d.ts +0 -2
  587. package/publications/flags-update.js +0 -22
  588. package/publications/flags-update.js.map +0 -1
  589. package/publications/flags.d.ts +0 -2
  590. package/publications/flags.js +0 -22
  591. package/publications/flags.js.map +0 -1
  592. package/publications/logs.d.ts +0 -2
  593. package/publications/logs.js +0 -164
  594. package/publications/logs.js.map +0 -1
  595. package/publications/notifications.d.ts +0 -2
  596. package/publications/notifications.js +0 -16
  597. package/publications/notifications.js.map +0 -1
  598. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  599. package/publications/report-builder-dashboard-builders.js +0 -42
  600. package/publications/report-builder-dashboard-builders.js.map +0 -1
  601. package/publications/report-builder-libraries.d.ts +0 -2
  602. package/publications/report-builder-libraries.js +0 -90
  603. package/publications/report-builder-libraries.js.map +0 -1
  604. package/publications/report-builder-reports.d.ts +0 -2
  605. package/publications/report-builder-reports.js +0 -50
  606. package/publications/report-builder-reports.js.map +0 -1
  607. package/publications/super-admin.d.ts +0 -2
  608. package/publications/super-admin.js +0 -16
  609. package/publications/super-admin.js.map +0 -1
  610. package/publications/user-groups.d.ts +0 -1
  611. package/publications/user-groups.js +0 -16
  612. package/publications/user-groups.js.map +0 -1
  613. package/publications/user-guides.d.ts +0 -1
  614. package/publications/user-guides.js +0 -16
  615. package/publications/user-guides.js.map +0 -1
  616. package/resolveio-server-app.d.ts +0 -70
  617. package/resolveio-server-app.js +0 -801
  618. package/resolveio-server-app.js.map +0 -1
  619. package/server-app.d.ts +0 -228
  620. package/server-app.js +0 -3549
  621. package/server-app.js.map +0 -1
  622. package/services/codex-client.d.ts +0 -118
  623. package/services/codex-client.js +0 -1475
  624. package/services/codex-client.js.map +0 -1
  625. package/services/openai-client.d.ts +0 -46
  626. package/services/openai-client.js +0 -318
  627. package/services/openai-client.js.map +0 -1
  628. package/types/error-report.d.ts +0 -25
  629. package/types/error-report.js +0 -4
  630. package/types/error-report.js.map +0 -1
  631. package/types/slow-query-report.d.ts +0 -27
  632. package/types/slow-query-report.js +0 -6
  633. package/types/slow-query-report.js.map +0 -1
  634. package/util/common.d.ts +0 -31
  635. package/util/common.js +0 -683
  636. package/util/common.js.map +0 -1
  637. package/util/customer-portal-password.d.ts +0 -13
  638. package/util/customer-portal-password.js +0 -209
  639. package/util/customer-portal-password.js.map +0 -1
  640. package/util/error-reporter.d.ts +0 -52
  641. package/util/error-reporter.js +0 -326
  642. package/util/error-reporter.js.map +0 -1
  643. package/util/error-tracking.d.ts +0 -13
  644. package/util/error-tracking.js +0 -120
  645. package/util/error-tracking.js.map +0 -1
  646. package/util/report-builder-unwinds.d.ts +0 -15
  647. package/util/report-builder-unwinds.js +0 -156
  648. package/util/report-builder-unwinds.js.map +0 -1
  649. package/util/schema-report-builder.d.ts +0 -6
  650. package/util/schema-report-builder.js +0 -481
  651. package/util/schema-report-builder.js.map +0 -1
  652. package/util/slow-query-reporter.d.ts +0 -28
  653. package/util/slow-query-reporter.js +0 -226
  654. package/util/slow-query-reporter.js.map +0 -1
  655. package/util/subscription-dependency-context.d.ts +0 -34
  656. package/util/subscription-dependency-context.js +0 -1283
  657. package/util/subscription-dependency-context.js.map +0 -1
  658. package/util/tokenizer.d.ts +0 -5
  659. package/util/tokenizer.js +0 -41
  660. package/util/tokenizer.js.map +0 -1
  661. package/workers/codex-runner.worker.d.ts +0 -1
  662. package/workers/codex-runner.worker.js +0 -192
  663. package/workers/codex-runner.worker.js.map +0 -1
  664. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  665. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  666. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  667. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  668. /package/{private → src/private}/email-templates/support-ticket.html +0 -0
  669. /package/{public_api.d.ts → src/public_api.ts} +0 -0
package/server-app.js DELETED
@@ -1,3549 +0,0 @@
1
- "use strict";
2
- var __assign = (this && this.__assign) || function () {
3
- __assign = Object.assign || function(t) {
4
- for (var s, i = 1, n = arguments.length; i < n; i++) {
5
- s = arguments[i];
6
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
- t[p] = s[p];
8
- }
9
- return t;
10
- };
11
- return __assign.apply(this, arguments);
12
- };
13
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
- return new (P || (P = Promise))(function (resolve, reject) {
16
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
- step((generator = generator.apply(thisArg, _arguments || [])).next());
20
- });
21
- };
22
- var __generator = (this && this.__generator) || function (thisArg, body) {
23
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
24
- return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
- function verb(n) { return function (v) { return step([n, v]); }; }
26
- function step(op) {
27
- if (f) throw new TypeError("Generator is already executing.");
28
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
30
- if (y = 0, t) op = [op[0] & 2, t.value];
31
- switch (op[0]) {
32
- case 0: case 1: t = op; break;
33
- case 4: _.label++; return { value: op[1], done: false };
34
- case 5: _.label++; y = op[1]; op = [0]; continue;
35
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
- default:
37
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
- if (t[2]) _.ops.pop();
42
- _.trys.pop(); continue;
43
- }
44
- op = body.call(thisArg, _);
45
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
- }
48
- };
49
- var __values = (this && this.__values) || function(o) {
50
- var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
51
- if (m) return m.call(o);
52
- if (o && typeof o.length === "number") return {
53
- next: function () {
54
- if (o && i >= o.length) o = void 0;
55
- return { value: o && o[i++], done: !o };
56
- }
57
- };
58
- throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
59
- };
60
- var __read = (this && this.__read) || function (o, n) {
61
- var m = typeof Symbol === "function" && o[Symbol.iterator];
62
- if (!m) return o;
63
- var i = m.call(o), r, ar = [], e;
64
- try {
65
- while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
66
- }
67
- catch (error) { e = { error: error }; }
68
- finally {
69
- try {
70
- if (r && !r.done && (m = i["return"])) m.call(i);
71
- }
72
- finally { if (e) throw e.error; }
73
- }
74
- return ar;
75
- };
76
- var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
77
- if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
78
- if (ar || !(i in from)) {
79
- if (!ar) ar = Array.prototype.slice.call(from, 0, i);
80
- ar[i] = from[i];
81
- }
82
- }
83
- return to.concat(ar || Array.prototype.slice.call(from));
84
- };
85
- Object.defineProperty(exports, "__esModule", { value: true });
86
- exports.ResolveIOMainServer = void 0;
87
- var express = require("express");
88
- var xmlParser = require("express-xml-bodyparser");
89
- var http_1 = require("http");
90
- var crypto = require("crypto");
91
- var fs = require("fs");
92
- var jwt = require("jsonwebtoken");
93
- var moment = require("moment-timezone");
94
- var msgpackr_1 = require("msgpackr");
95
- var os = require("os");
96
- var path = require("path");
97
- var perf_hooks_1 = require("perf_hooks");
98
- var inspector = require("inspector");
99
- var child_process_1 = require("child_process");
100
- var url_1 = require("url");
101
- var WebSocket = require("ws");
102
- var log_collection_1 = require("./collections/log.collection");
103
- var user_collection_1 = require("./collections/user.collection");
104
- var cron_manager_1 = require("./managers/cron.manager");
105
- var method_manager_1 = require("./managers/method.manager");
106
- var monitor_manager_1 = require("./managers/monitor.manager");
107
- var subscription_manager_1 = require("./managers/subscription.manager");
108
- var common_1 = require("./util/common");
109
- var error_reporter_1 = require("./util/error-reporter");
110
- var error_tracking_1 = require("./util/error-tracking");
111
- var mongodb_1 = require("mongodb");
112
- var auth_1 = require("./http/auth");
113
- var health_1 = require("./http/health");
114
- var home_1 = require("./http/home");
115
- var slow_query_publication_1 = require("./http/slow-query-publication");
116
- var websocket_manager_1 = require("./managers/websocket.manager");
117
- var worker_dispatcher_manager_1 = require("./managers/worker-dispatcher.manager");
118
- var worker_server_manager_1 = require("./managers/worker-server.manager");
119
- var ai_assistant_codex_manager_manager_1 = require("./managers/ai-assistant-codex-manager.manager");
120
- var resolveio_server_app_1 = require("./resolveio-server-app");
121
- var CLIENT_REQUEST_LOG_SKIP_LIST = new Set([
122
- 'reportBuilderGetResults',
123
- 'reportBuilderGetDistinctValue',
124
- 'reportBuilderBuildTree',
125
- 'generatePDF',
126
- 'getWOOfflineData',
127
- 'countQuery',
128
- 'countWithQuery',
129
- 'countCollectionWithQuery',
130
- 'find',
131
- 'findOne',
132
- 'findWithOptions',
133
- 'getDrivers',
134
- 'processAirdropDistribution',
135
- 'qbHandleResponse',
136
- 'getSignedUrls',
137
- 'getSignedUrl',
138
- 'getSignedUrlWithId',
139
- 'getSignedUrlsAndFilesWithId',
140
- 'updateDocumentProps',
141
- 'insertDocument',
142
- 'updateDocument',
143
- 'uploadFileAndSave'
144
- ]);
145
- function shouldWriteClientRequestLog(methodName) {
146
- return !CLIENT_REQUEST_LOG_SKIP_LIST.has(methodName);
147
- }
148
- var ResolveIOMainServer = /** @class */ (function () {
149
- function ResolveIOMainServer() {
150
- this._offlineUpdates = [];
151
- this.sesMail = false;
152
- this.publicProgram = false;
153
- this._rebootFlag = false;
154
- this.LOGGER = 'ERROR'; //ERROR / DEBUG
155
- this._clientRoutes = [];
156
- this._aiAssistantCodexManager = null;
157
- this._httpServerClosePromise = null;
158
- this._websocketServerClosePromise = null;
159
- this._wsConnectDebug = false;
160
- this._perfDebug = false;
161
- this._perfDebugIntervalMs = 2000;
162
- this._perfDebugTimer = null;
163
- this._perfDebugLastCpu = null;
164
- this._perfDebugLastTs = 0;
165
- this._eventLoopHistogram = null;
166
- this._cpuProfileOnStart = false;
167
- this._cpuProfileAuto = false;
168
- this._cpuProfileDurationMs = 15000;
169
- this._cpuProfileThresholdPct = 90;
170
- this._cpuProfileTriggerCount = 3;
171
- this._cpuProfileHighCount = 0;
172
- this._cpuProfileDir = null;
173
- this._cpuProfileSession = null;
174
- this._timerDebug = false;
175
- this._timerDebugThresholdMs = 50;
176
- this._timerDebugMinDelayMs = 5;
177
- this._timerDebugSampleRate = 1;
178
- this._timerDebugLogLimit = 100;
179
- this._timerDebugLogCount = 0;
180
- this._aiWorkerDebug = false;
181
- this._standaloneNodeReaperEnabled = false;
182
- this._standaloneNodeReaperIntervalMs = 60000;
183
- this._standaloneNodeReaperMinAgeSeconds = 300;
184
- this._standaloneNodeReaperMaxKillsPerSignature = 1;
185
- this._standaloneNodeReaperKillWindowMs = 60 * 60 * 1000;
186
- this._standaloneNodeReaperIncludeSystemdServices = false;
187
- this._standaloneNodeReaperHighCpuPct = 85;
188
- this._standaloneNodeReaperHighRssMb = 4096;
189
- this._standaloneNodeReaperHighMinAgeSeconds = 60;
190
- this._standaloneNodeReaperHighConsecutiveScans = 2;
191
- this._standaloneNodeReaperDryRun = false;
192
- this._standaloneNodeReaperAlertWindowMs = 60 * 60 * 1000;
193
- this._standaloneNodeReaperTimer = null;
194
- this._standaloneNodeReaperRunning = false;
195
- this._standaloneNodeReaperKillCounts = new Map();
196
- this._standaloneNodeReaperSuppressedSignatures = new Set();
197
- this._standaloneNodeReaperResourceHits = new Map();
198
- this._standaloneNodeReaperAlertTimes = new Map();
199
- this._lastErrorMsg = null;
200
- this._debugMsgRecv = 0;
201
- this._debugMsgQueue = 0;
202
- this._isWorkersEnabled = false;
203
- this._isWorkerInstance = false;
204
- this._safeShutdown = false;
205
- this._dynamicAppGatewayEnabled = false;
206
- this._dynamicAppGatewayCache = new Map();
207
- this._socketTier = '';
208
- this._maxClientSockets = 0;
209
- this._singleIpPerUser = false;
210
- this._socketPolicyUpgradeUrl = '';
211
- this._clientHeartbeatIntervalMs = 20000;
212
- this._clientHeartbeatInitialDelayMs = 5000;
213
- this._clientHeartbeatBackpressureBytes = 5 * 1024 * 1024;
214
- this._dynamicAppGatewayCacheMs = 30 * 1000;
215
- }
216
- ResolveIOMainServer.create = function () {
217
- return __awaiter(this, void 0, void 0, function () {
218
- var resolveioMainServer;
219
- return __generator(this, function (_a) {
220
- switch (_a.label) {
221
- case 0:
222
- resolveioMainServer = new ResolveIOMainServer();
223
- return [4 /*yield*/, resolveioMainServer.initialize()];
224
- case 1:
225
- _a.sent();
226
- return [2 /*return*/, resolveioMainServer];
227
- }
228
- });
229
- });
230
- };
231
- ResolveIOMainServer.prototype.initialize = function () {
232
- return __awaiter(this, void 0, void 0, function () {
233
- var _a, workerRole, workerIndex, workerInstance, skipWorkerServerConnection, skipCronForProcessOnly;
234
- var _this = this;
235
- return __generator(this, function (_b) {
236
- switch (_b.label) {
237
- case 0:
238
- this._serverStartTime = new Date();
239
- this._lastErrorMsg = null;
240
- this._wsConnectDebug = this.resolveConnectDebug();
241
- this._perfDebug = this.resolvePerfDebug();
242
- this._cpuProfileOnStart = this.resolveCpuProfileOnStart();
243
- this._cpuProfileAuto = this.resolveCpuProfileAuto();
244
- this._cpuProfileDurationMs = this.resolveCpuProfileDurationMs();
245
- this._cpuProfileThresholdPct = this.resolveCpuProfileThresholdPct();
246
- this._cpuProfileTriggerCount = this.resolveCpuProfileTriggerCount();
247
- this._cpuProfileDir = this.resolveCpuProfileDir();
248
- this._timerDebug = this.resolveTimerDebug();
249
- this._timerDebugThresholdMs = this.resolveTimerDebugThresholdMs();
250
- this._timerDebugMinDelayMs = this.resolveTimerDebugMinDelayMs();
251
- this._timerDebugSampleRate = this.resolveTimerDebugSampleRate();
252
- this._timerDebugLogLimit = this.resolveTimerDebugLogLimit();
253
- this._aiWorkerDebug = this.parseDebugFlag(process.env.AI_ASSISTANT_WORKER_DEBUG);
254
- this._standaloneNodeReaperEnabled = this.resolveStandaloneNodeReaperEnabled();
255
- this._standaloneNodeReaperIntervalMs = this.resolveStandaloneNodeReaperIntervalMs();
256
- this._standaloneNodeReaperMinAgeSeconds = this.resolveStandaloneNodeReaperMinAgeSeconds();
257
- this._standaloneNodeReaperMaxKillsPerSignature = this.resolveStandaloneNodeReaperMaxKillsPerSignature();
258
- this._standaloneNodeReaperKillWindowMs = this.resolveStandaloneNodeReaperKillWindowMs();
259
- this._standaloneNodeReaperIncludeSystemdServices = this.resolveStandaloneNodeReaperIncludeSystemdServices();
260
- this._standaloneNodeReaperHighCpuPct = this.resolveStandaloneNodeReaperHighCpuPct();
261
- this._standaloneNodeReaperHighRssMb = this.resolveStandaloneNodeReaperHighRssMb();
262
- this._standaloneNodeReaperHighMinAgeSeconds = this.resolveStandaloneNodeReaperHighMinAgeSeconds();
263
- this._standaloneNodeReaperHighConsecutiveScans = this.resolveStandaloneNodeReaperHighConsecutiveScans();
264
- this._standaloneNodeReaperDryRun = this.resolveStandaloneNodeReaperDryRun();
265
- this._standaloneNodeReaperAlertWindowMs = this.resolveStandaloneNodeReaperAlertWindowMs();
266
- this._dynamicAppGatewayEnabled = this.resolveDynamicAppGatewayEnabled();
267
- this._socketTier = this.resolveSocketTier();
268
- this._maxClientSockets = this.resolveMaxClientSockets(this._socketTier);
269
- this._singleIpPerUser = this.resolveSingleIpPerUserPolicy(this._socketTier);
270
- this._socketPolicyUpgradeUrl = this.resolveSocketPolicyUpgradeUrl();
271
- if (this._maxClientSockets > 0 || this._singleIpPerUser) {
272
- console.info(new Date(), '[Socket Policy] configured', {
273
- tier: this._socketTier || 'none',
274
- maxClientSockets: this._maxClientSockets,
275
- singleIpPerUser: this._singleIpPerUser
276
- });
277
- }
278
- _a = this;
279
- return [4 /*yield*/, monitor_manager_1.MonitorManager.create()];
280
- case 1:
281
- _a._monitorManager = _b.sent();
282
- this._monitorManagerFunction = new monitor_manager_1.MonitorManagerFunction();
283
- this.installTimerDebug();
284
- this.startPerfDebug();
285
- if (this._cpuProfileOnStart) {
286
- this.startCpuProfile('on-start');
287
- }
288
- // Check for workers and decide what to start
289
- this._isWorkersEnabled = process.env.IS_WORKERS_ENABLED === 'true';
290
- this._isWorkerInstance = process.env.IS_WORKER_INSTANCE === 'true';
291
- this.startStandaloneNodeReaper();
292
- setInterval(function () {
293
- if (_this._methodManager && _this._methodManager.getEnableDebug()) {
294
- console.log(new Date(), 'Server App', 'Msg Recv Hits', _this._debugMsgRecv);
295
- console.log(new Date(), 'Server App', 'Msg Queue Hits', _this._debugMsgQueue);
296
- }
297
- _this._debugMsgQueue = 0;
298
- _this._debugMsgRecv = 0;
299
- }, 60000);
300
- process.removeAllListeners('unhandledRejection');
301
- process.on('unhandledRejection', function (error, rej) { return __awaiter(_this, void 0, void 0, function () {
302
- var _a, normalizedError, correlationId, errorDetails, diffTimeSec;
303
- var _this = this;
304
- return __generator(this, function (_b) {
305
- switch (_b.label) {
306
- case 0:
307
- _a = (0, error_tracking_1.ensureErrorWithCorrelation)(error), normalizedError = _a.error, correlationId = _a.correlationId;
308
- if (this._methodManager.getEnableDebug()) {
309
- console.error(new Date(), 'ERROR DETECTED w/ Debug Flag Active: unhandledRejection', [normalizedError, rej, { correlationId: correlationId }]);
310
- }
311
- // Condition to filter out the MongoError with specific codes
312
- if (normalizedError && normalizedError['name'] === 'MongoError' && (normalizedError['code'] === 48 || normalizedError['code'] === 26 || normalizedError['code'] === 11000 || normalizedError['code'] === 251)) {
313
- return [2 /*return*/]; // Simply return without doing anything further
314
- }
315
- // if (normalizedError && normalizedError['name'] === 'MongoServerError' && (!initServerFlag || normalizedError['code'] === 26 || normalizedError['code'] === 11000 || normalizedError['code'] === 86 || normalizedError['code'] === 251)) {
316
- // return; // Simply return without doing anything further
317
- // }
318
- if (normalizedError && normalizedError['name'] === 'MongoServerError') {
319
- return [2 /*return*/]; // Simply return without doing anything further
320
- }
321
- errorDetails = {
322
- id: correlationId,
323
- name: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.name,
324
- message: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.message,
325
- stack: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.stack,
326
- code: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.code,
327
- codeName: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.codeName
328
- };
329
- console.error(new Date(), 'Unhandled Rejection at Promise', [errorDetails]);
330
- diffTimeSec = moment().diff(this._serverStartTime, 'seconds');
331
- if (!(normalizedError && (normalizedError['name'] === 'MongoNetworkTimeoutError' || normalizedError instanceof mongodb_1.MongoNetworkTimeoutError))) return [3 /*break*/, 1];
332
- if (diffTimeSec > 60 && !this._lastErrorMsg) {
333
- this._lastErrorMsg = new Date();
334
- setTimeout(function () {
335
- _this._lastErrorMsg = null;
336
- }, 60000);
337
- // Exiting the process
338
- process.exit(1);
339
- }
340
- return [3 /*break*/, 5];
341
- case 1:
342
- if (!(normalizedError && normalizedError['name'] === 'MongoError' && normalizedError['message'] === 'not master')) return [3 /*break*/, 2];
343
- if (diffTimeSec > 60 && !this._lastErrorMsg) {
344
- this._lastErrorMsg = new Date();
345
- setTimeout(function () {
346
- _this._lastErrorMsg = null;
347
- }, 60000);
348
- }
349
- process.exit(1);
350
- return [3 /*break*/, 5];
351
- case 2:
352
- if (!(normalizedError && normalizedError['name'] === 'MongoError' && normalizedError['message'] === 'not master and slaveOk=false')) return [3 /*break*/, 3];
353
- if (diffTimeSec > 60 && !this._lastErrorMsg) {
354
- this._lastErrorMsg = new Date();
355
- setTimeout(function () {
356
- _this._lastErrorMsg = null;
357
- }, 60000);
358
- }
359
- process.exit(1);
360
- return [3 /*break*/, 5];
361
- case 3:
362
- if (!(normalizedError && normalizedError['name'] !== 'StatusError' && normalizedError['message'] !== '')) return [3 /*break*/, 5];
363
- if (!(diffTimeSec > 60 && !this._lastErrorMsg)) return [3 /*break*/, 5];
364
- this._lastErrorMsg = new Date();
365
- setTimeout(function () {
366
- _this._lastErrorMsg = null;
367
- }, 60000);
368
- return [4 /*yield*/, this.reportServerError('SERVER - Unhandled Rejection - ' + resolveio_server_app_1.ResolveIOServer.getServerConfig()['CLIENT_NAME'], correlationId, errorDetails, {
369
- context: 'unhandledRejection',
370
- scenario: 'General'
371
- })];
372
- case 4:
373
- _b.sent();
374
- _b.label = 5;
375
- case 5: return [2 /*return*/];
376
- }
377
- });
378
- }); });
379
- process.on('uncaughtException', function (error) { return __awaiter(_this, void 0, void 0, function () {
380
- var _a, normalizedError, correlationId, diffTimeSec, errorDetails;
381
- var _this = this;
382
- return __generator(this, function (_b) {
383
- switch (_b.label) {
384
- case 0:
385
- _a = (0, error_tracking_1.ensureErrorWithCorrelation)(error), normalizedError = _a.error, correlationId = _a.correlationId;
386
- console.error(normalizedError, 'Uncaught Exception thrown', { correlationId: correlationId });
387
- diffTimeSec = moment().diff(this._serverStartTime, 'seconds');
388
- if (!(diffTimeSec > 60 && !this._lastErrorMsg)) return [3 /*break*/, 2];
389
- this._lastErrorMsg = new Date();
390
- setTimeout(function () {
391
- _this._lastErrorMsg = null;
392
- }, 60000);
393
- errorDetails = {
394
- id: correlationId,
395
- name: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.name,
396
- message: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.message,
397
- stack: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.stack,
398
- code: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.code,
399
- codeName: normalizedError === null || normalizedError === void 0 ? void 0 : normalizedError.codeName
400
- };
401
- return [4 /*yield*/, this.reportServerError('SERVER - Unhandled Exception - ' + resolveio_server_app_1.ResolveIOServer.getServerConfig()['CLIENT_NAME'], correlationId, errorDetails, {
402
- context: 'uncaughtException'
403
- })];
404
- case 1:
405
- _b.sent();
406
- _b.label = 2;
407
- case 2: return [2 /*return*/];
408
- }
409
- });
410
- }); });
411
- //PM2 wants to reboot/restart
412
- process.on('SIGINT', function () { return __awaiter(_this, void 0, void 0, function () {
413
- var error_1;
414
- return __generator(this, function (_a) {
415
- switch (_a.label) {
416
- case 0:
417
- this._rebootFlag = true;
418
- _a.label = 1;
419
- case 1:
420
- _a.trys.push([1, 3, , 4]);
421
- return [4 /*yield*/, this.shutdownNetworkServers()];
422
- case 2:
423
- _a.sent();
424
- return [3 /*break*/, 4];
425
- case 3:
426
- error_1 = _a.sent();
427
- console.error(new Date(), 'Error closing network servers (SIGINT)', error_1);
428
- return [3 /*break*/, 4];
429
- case 4: return [4 /*yield*/, this.safeShutdown()];
430
- case 5:
431
- _a.sent();
432
- return [2 /*return*/];
433
- }
434
- });
435
- }); });
436
- process.on('SIGTERM', function () { return __awaiter(_this, void 0, void 0, function () {
437
- var error_2;
438
- return __generator(this, function (_a) {
439
- switch (_a.label) {
440
- case 0:
441
- this._rebootFlag = true;
442
- _a.label = 1;
443
- case 1:
444
- _a.trys.push([1, 3, , 4]);
445
- return [4 /*yield*/, this.shutdownNetworkServers()];
446
- case 2:
447
- _a.sent();
448
- return [3 /*break*/, 4];
449
- case 3:
450
- error_2 = _a.sent();
451
- console.error(new Date(), 'Error closing network servers (SIGTERM)', error_2);
452
- return [3 /*break*/, 4];
453
- case 4: return [4 /*yield*/, this.safeShutdown()];
454
- case 5:
455
- _a.sent();
456
- return [2 /*return*/];
457
- }
458
- });
459
- }); });
460
- process.on('SIGQUIT', function () { return __awaiter(_this, void 0, void 0, function () {
461
- var error_3;
462
- return __generator(this, function (_a) {
463
- switch (_a.label) {
464
- case 0:
465
- this._rebootFlag = true;
466
- _a.label = 1;
467
- case 1:
468
- _a.trys.push([1, 3, , 4]);
469
- return [4 /*yield*/, this.shutdownNetworkServers()];
470
- case 2:
471
- _a.sent();
472
- return [3 /*break*/, 4];
473
- case 3:
474
- error_3 = _a.sent();
475
- console.error(new Date(), 'Error closing network servers (SIGQUIT)', error_3);
476
- return [3 /*break*/, 4];
477
- case 4: return [4 /*yield*/, this.safeShutdown()];
478
- case 5:
479
- _a.sent();
480
- return [2 /*return*/];
481
- }
482
- });
483
- }); });
484
- if (this.LOGGER === 'DEBUG') {
485
- console.log('Starting ResolveIO Server');
486
- }
487
- if (this._isWorkersEnabled) {
488
- if (this._isWorkerInstance) {
489
- workerRole = this.resolveWorkerRole();
490
- workerIndex = this.normalizeWorkerSelectorValue(process.env.WORKER_INDEX) || 'UNKNOWN';
491
- workerInstance = this.normalizeWorkerSelectorValue(process.env.NODE_APP_INSTANCE) || 'UNKNOWN';
492
- console.log("Running as Worker: ".concat(workerRole), workerIndex, workerInstance);
493
- this._methodManager = method_manager_1.MethodManager.create(null, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);
494
- this._subscriptionManager = subscription_manager_1.SubscriptionManager.createPublicationRegistry(resolveio_server_app_1.ResolveIOServer.getServerConfig());
495
- skipWorkerServerConnection = this.parseDebugFlag(process.env.DISABLE_WORKER_SERVER_CONNECTION)
496
- || this.parseDebugFlag(process.env.SUPPORT_CODEX_MANAGER_PROCESS_ONLY)
497
- || this.parseDebugFlag(process.env.SUPPORT_AUTO_MANAGER_PROCESS_ONLY)
498
- || this.parseDebugFlag(process.env.AI_ASSISTANT_CODEX_MANAGER_PROCESS_ONLY);
499
- if (skipWorkerServerConnection) {
500
- console.log(new Date(), 'Worker server connection disabled for process-only runtime', {
501
- workerIndex: process.env.WORKER_INDEX || null,
502
- workerInstance: process.env.NODE_APP_INSTANCE || null
503
- });
504
- this._workerServerManager = null;
505
- }
506
- else {
507
- this._workerServerManager = worker_server_manager_1.WorkerServerManager.create(this._methodManager, this.getServerConfig());
508
- }
509
- skipCronForProcessOnly = this.parseDebugFlag(process.env.SUPPORT_CODEX_MANAGER_PROCESS_ONLY)
510
- || this.parseDebugFlag(process.env.SUPPORT_AUTO_MANAGER_PROCESS_ONLY)
511
- || this.parseDebugFlag(process.env.AI_ASSISTANT_CODEX_MANAGER_PROCESS_ONLY);
512
- if (this.shouldStartCronManagerForWorker() && !skipCronForProcessOnly) {
513
- this._cronManager = cron_manager_1.CronManager.create();
514
- }
515
- }
516
- else {
517
- console.log('Running as a Server instance', process.env.NODE_APP_INSTANCE);
518
- this._websocketManager = websocket_manager_1.WebSocketManager.create(this);
519
- this._methodManager = method_manager_1.MethodManager.create(this._websocketManager, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);
520
- this._workerDispatcherManager = worker_dispatcher_manager_1.WorkerDispatcherManager.create(this._websocketManager, this._methodManager);
521
- this._subscriptionManager = subscription_manager_1.SubscriptionManager.create(this._serverWSS, resolveio_server_app_1.ResolveIOServer.getServerConfig(), this._monitorManagerFunction);
522
- this.startServerInstance();
523
- this.listen();
524
- }
525
- }
526
- else {
527
- console.log('Running with Workers Disabled', process.env.NODE_APP_INSTANCE);
528
- this._websocketManager = websocket_manager_1.WebSocketManager.create(this);
529
- this._methodManager = method_manager_1.MethodManager.create(this._websocketManager, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);
530
- this._subscriptionManager = subscription_manager_1.SubscriptionManager.create(this._serverWSS, resolveio_server_app_1.ResolveIOServer.getServerConfig(), this._monitorManagerFunction);
531
- this._cronManager = cron_manager_1.CronManager.create();
532
- this.startServerInstance();
533
- this.listen();
534
- }
535
- this.startAiAssistantCodexManagerIfEnabled();
536
- return [2 /*return*/];
537
- }
538
- });
539
- });
540
- };
541
- ResolveIOMainServer.prototype.startAiAssistantCodexManagerIfEnabled = function () {
542
- try {
543
- this._aiAssistantCodexManager = ai_assistant_codex_manager_manager_1.AiAssistantCodexManager.createIfEnabled({
544
- isWorkersEnabled: this._isWorkersEnabled,
545
- isWorkerInstance: this._isWorkerInstance,
546
- workerIndex: process.env.WORKER_INDEX || null,
547
- workerInstance: process.env.NODE_APP_INSTANCE || null
548
- });
549
- resolveio_server_app_1.ResolveIOServer['AiAssistantCodexManager'] = this._aiAssistantCodexManager;
550
- }
551
- catch (error) {
552
- console.error(new Date(), 'Failed to start AI Assistant Codex Manager', error);
553
- resolveio_server_app_1.ResolveIOServer['AiAssistantCodexManager'] = null;
554
- }
555
- };
556
- ResolveIOMainServer.prototype.startStandaloneNodeReaper = function () {
557
- var _this = this;
558
- var _a, _b, _c;
559
- if (!this._standaloneNodeReaperEnabled || this._standaloneNodeReaperTimer) {
560
- return;
561
- }
562
- if (process.platform !== 'linux' || !this.isPm2ManagedRuntime() || !this.isPrimaryPm2Instance()) {
563
- return;
564
- }
565
- var initialDelayMs = Math.min(30000, this._standaloneNodeReaperIntervalMs);
566
- var firstRunTimer = setTimeout(function () { return __awaiter(_this, void 0, void 0, function () {
567
- var error_4;
568
- return __generator(this, function (_a) {
569
- switch (_a.label) {
570
- case 0:
571
- _a.trys.push([0, 2, , 3]);
572
- return [4 /*yield*/, this.reapStandaloneNodeProcesses()];
573
- case 1:
574
- _a.sent();
575
- return [3 /*break*/, 3];
576
- case 2:
577
- error_4 = _a.sent();
578
- console.error(new Date(), '[Standalone Node Reaper] failed', error_4);
579
- return [3 /*break*/, 3];
580
- case 3: return [2 /*return*/];
581
- }
582
- });
583
- }); }, initialDelayMs);
584
- (_a = firstRunTimer.unref) === null || _a === void 0 ? void 0 : _a.call(firstRunTimer);
585
- this._standaloneNodeReaperTimer = setInterval(function () { return __awaiter(_this, void 0, void 0, function () {
586
- var error_5;
587
- return __generator(this, function (_a) {
588
- switch (_a.label) {
589
- case 0:
590
- _a.trys.push([0, 2, , 3]);
591
- return [4 /*yield*/, this.reapStandaloneNodeProcesses()];
592
- case 1:
593
- _a.sent();
594
- return [3 /*break*/, 3];
595
- case 2:
596
- error_5 = _a.sent();
597
- console.error(new Date(), '[Standalone Node Reaper] failed', error_5);
598
- return [3 /*break*/, 3];
599
- case 3: return [2 /*return*/];
600
- }
601
- });
602
- }); }, this._standaloneNodeReaperIntervalMs);
603
- (_c = (_b = this._standaloneNodeReaperTimer).unref) === null || _c === void 0 ? void 0 : _c.call(_b);
604
- console.log(new Date(), '[Standalone Node Reaper] enabled', {
605
- intervalMs: this._standaloneNodeReaperIntervalMs,
606
- minAgeSeconds: this._standaloneNodeReaperMinAgeSeconds,
607
- maxKillsPerSignature: this._standaloneNodeReaperMaxKillsPerSignature,
608
- killWindowMs: this._standaloneNodeReaperKillWindowMs,
609
- highCpuPct: this._standaloneNodeReaperHighCpuPct,
610
- highRssMb: this._standaloneNodeReaperHighRssMb,
611
- highMinAgeSeconds: this._standaloneNodeReaperHighMinAgeSeconds,
612
- highConsecutiveScans: this._standaloneNodeReaperHighConsecutiveScans,
613
- alertWindowMs: this._standaloneNodeReaperAlertWindowMs,
614
- dryRun: this._standaloneNodeReaperDryRun
615
- });
616
- };
617
- ResolveIOMainServer.prototype.reapStandaloneNodeProcesses = function () {
618
- return __awaiter(this, void 0, void 0, function () {
619
- var processes, protectedPids, _loop_1, this_1, processes_1, processes_1_1, proc, e_1_1;
620
- var e_1, _a;
621
- var _this = this;
622
- var _b;
623
- return __generator(this, function (_c) {
624
- switch (_c.label) {
625
- case 0:
626
- if (this._standaloneNodeReaperRunning) {
627
- return [2 /*return*/];
628
- }
629
- this._standaloneNodeReaperRunning = true;
630
- _c.label = 1;
631
- case 1:
632
- _c.trys.push([1, , 11, 12]);
633
- return [4 /*yield*/, this.listSystemProcesses()];
634
- case 2:
635
- processes = _c.sent();
636
- protectedPids = this.resolvePm2ProtectedPids(processes);
637
- _loop_1 = function (proc) {
638
- var signature, reason, details, details, killTimer, error_6;
639
- return __generator(this, function (_d) {
640
- switch (_d.label) {
641
- case 0:
642
- if (!this_1.shouldReapStandaloneNodeProcess(proc, protectedPids)) {
643
- return [2 /*return*/, "continue"];
644
- }
645
- signature = this_1.resolveStandaloneNodeProcessSignature(proc);
646
- if (!this_1.canReapStandaloneNodeSignature(signature)) {
647
- this_1.logStandaloneNodeReaperSuppressed(proc, signature);
648
- return [2 /*return*/, "continue"];
649
- }
650
- reason = this_1.resolveStandaloneNodeReaperReason(proc);
651
- if (!this_1._standaloneNodeReaperDryRun) return [3 /*break*/, 2];
652
- this_1.recordStandaloneNodeReaperKill(signature);
653
- details = this_1.createStandaloneNodeReaperDetails(proc, reason, 'dry-run');
654
- console.warn(new Date(), '[Standalone Node Reaper] dry-run would terminate stale node process', details);
655
- return [4 /*yield*/, this_1.reportStandaloneNodeReaperAction(proc, reason, 'dry-run')];
656
- case 1:
657
- _d.sent();
658
- return [2 /*return*/, "continue"];
659
- case 2:
660
- _d.trys.push([2, 4, , 5]);
661
- process.kill(proc.pid, 'SIGTERM');
662
- this_1.recordStandaloneNodeReaperKill(signature);
663
- details = this_1.createStandaloneNodeReaperDetails(proc, reason, 'terminated');
664
- console.warn(new Date(), '[Standalone Node Reaper] terminated stale node process', details);
665
- return [4 /*yield*/, this_1.reportStandaloneNodeReaperAction(proc, reason, 'terminated')];
666
- case 3:
667
- _d.sent();
668
- killTimer = setTimeout(function () { return __awaiter(_this, void 0, void 0, function () {
669
- var _a;
670
- return __generator(this, function (_b) {
671
- switch (_b.label) {
672
- case 0:
673
- _b.trys.push([0, 2, , 3]);
674
- process.kill(proc.pid, 0);
675
- process.kill(proc.pid, 'SIGKILL');
676
- console.warn(new Date(), '[Standalone Node Reaper] force killed stale node process', {
677
- pid: proc.pid,
678
- reason: reason,
679
- command: proc.args
680
- });
681
- return [4 /*yield*/, this.reportStandaloneNodeReaperAction(proc, reason, 'force-killed')];
682
- case 1:
683
- _b.sent();
684
- return [3 /*break*/, 3];
685
- case 2:
686
- _a = _b.sent();
687
- return [3 /*break*/, 3];
688
- case 3: return [2 /*return*/];
689
- }
690
- });
691
- }); }, 10000);
692
- (_b = killTimer.unref) === null || _b === void 0 ? void 0 : _b.call(killTimer);
693
- return [3 /*break*/, 5];
694
- case 4:
695
- error_6 = _d.sent();
696
- if ((error_6 === null || error_6 === void 0 ? void 0 : error_6['code']) !== 'ESRCH') {
697
- console.error(new Date(), '[Standalone Node Reaper] kill failed', {
698
- pid: proc.pid,
699
- command: proc.args,
700
- error: (error_6 === null || error_6 === void 0 ? void 0 : error_6['message']) || error_6
701
- });
702
- }
703
- return [3 /*break*/, 5];
704
- case 5: return [2 /*return*/];
705
- }
706
- });
707
- };
708
- this_1 = this;
709
- _c.label = 3;
710
- case 3:
711
- _c.trys.push([3, 8, 9, 10]);
712
- processes_1 = __values(processes), processes_1_1 = processes_1.next();
713
- _c.label = 4;
714
- case 4:
715
- if (!!processes_1_1.done) return [3 /*break*/, 7];
716
- proc = processes_1_1.value;
717
- return [5 /*yield**/, _loop_1(proc)];
718
- case 5:
719
- _c.sent();
720
- _c.label = 6;
721
- case 6:
722
- processes_1_1 = processes_1.next();
723
- return [3 /*break*/, 4];
724
- case 7: return [3 /*break*/, 10];
725
- case 8:
726
- e_1_1 = _c.sent();
727
- e_1 = { error: e_1_1 };
728
- return [3 /*break*/, 10];
729
- case 9:
730
- try {
731
- if (processes_1_1 && !processes_1_1.done && (_a = processes_1.return)) _a.call(processes_1);
732
- }
733
- finally { if (e_1) throw e_1.error; }
734
- return [7 /*endfinally*/];
735
- case 10: return [3 /*break*/, 12];
736
- case 11:
737
- this._standaloneNodeReaperRunning = false;
738
- return [7 /*endfinally*/];
739
- case 12: return [2 /*return*/];
740
- }
741
- });
742
- });
743
- };
744
- ResolveIOMainServer.prototype.createStandaloneNodeReaperDetails = function (proc, reason, action) {
745
- return {
746
- action: action,
747
- pid: proc.pid,
748
- ppid: proc.ppid,
749
- ageSeconds: proc.ageSeconds,
750
- cpuPct: proc.cpuPct,
751
- rssMb: (0, common_1.round)(proc.rssKb / 1024),
752
- reason: reason,
753
- command: proc.args
754
- };
755
- };
756
- ResolveIOMainServer.prototype.reportStandaloneNodeReaperAction = function (proc, reason, action) {
757
- return __awaiter(this, void 0, void 0, function () {
758
- var signature, alertKey, now, lastReportedAt, error_7;
759
- var _a;
760
- return __generator(this, function (_b) {
761
- switch (_b.label) {
762
- case 0:
763
- signature = this.resolveStandaloneNodeProcessSignature(proc);
764
- alertKey = "".concat(action, "|").concat(signature);
765
- now = Date.now();
766
- lastReportedAt = this._standaloneNodeReaperAlertTimes.get(alertKey);
767
- if (lastReportedAt && (now - lastReportedAt) < this._standaloneNodeReaperAlertWindowMs) {
768
- return [2 /*return*/];
769
- }
770
- _b.label = 1;
771
- case 1:
772
- _b.trys.push([1, 3, , 4]);
773
- return [4 /*yield*/, this.reportServerError("SERVER - Standalone Node Reaper ".concat(action, " process - ").concat(((_a = resolveio_server_app_1.ResolveIOServer.getServerConfig()) === null || _a === void 0 ? void 0 : _a['CLIENT_NAME']) || resolveio_server_app_1.ResolveIOServer.getClientName()), crypto.randomUUID(), __assign(__assign({}, this.createStandaloneNodeReaperDetails(proc, reason, action)), { host: os.hostname(), workerIndex: process.env.WORKER_INDEX || null, workerInstance: process.env.NODE_APP_INSTANCE || null, dryRun: this._standaloneNodeReaperDryRun, alertWindowMs: this._standaloneNodeReaperAlertWindowMs }), {
774
- context: 'standaloneNodeReaper',
775
- action: action,
776
- reason: reason,
777
- signature: signature
778
- }, 'warning')];
779
- case 2:
780
- _b.sent();
781
- this._standaloneNodeReaperAlertTimes.set(alertKey, now);
782
- return [3 /*break*/, 4];
783
- case 3:
784
- error_7 = _b.sent();
785
- console.error(new Date(), '[Standalone Node Reaper] alert failed', {
786
- action: action,
787
- pid: proc.pid,
788
- error: (error_7 === null || error_7 === void 0 ? void 0 : error_7['message']) || error_7
789
- });
790
- return [3 /*break*/, 4];
791
- case 4: return [2 /*return*/];
792
- }
793
- });
794
- });
795
- };
796
- ResolveIOMainServer.prototype.listSystemProcesses = function () {
797
- return __awaiter(this, void 0, void 0, function () {
798
- var output;
799
- var _this = this;
800
- return __generator(this, function (_a) {
801
- switch (_a.label) {
802
- case 0: return [4 /*yield*/, this.execFileText('ps', ['-eo', 'pid=,ppid=,etimes=,pcpu=,rss=,comm=,args='], 5000)];
803
- case 1:
804
- output = _a.sent();
805
- return [2 /*return*/, output
806
- .split('\n')
807
- .map(function (line) { return line.trim(); })
808
- .filter(Boolean)
809
- .map(function (line) { return _this.parseProcessSnapshot(line); })
810
- .filter(function (proc) { return proc !== null; })];
811
- }
812
- });
813
- });
814
- };
815
- ResolveIOMainServer.prototype.parseProcessSnapshot = function (line) {
816
- var match = line.match(/^(\d+)\s+(\d+)\s+(\d+)\s+([\d.]+)\s+(\d+)\s+(\S+)\s+(.*)$/);
817
- if (!match) {
818
- return null;
819
- }
820
- return {
821
- pid: parseInt(match[1], 10),
822
- ppid: parseInt(match[2], 10),
823
- ageSeconds: parseInt(match[3], 10),
824
- cpuPct: parseFloat(match[4]),
825
- rssKb: parseInt(match[5], 10),
826
- command: match[6],
827
- args: match[7] || ''
828
- };
829
- };
830
- ResolveIOMainServer.prototype.execFileText = function (command, args, timeoutMs) {
831
- // eslint-disable-next-line no-restricted-syntax
832
- return new Promise(function (resolve, reject) {
833
- (0, child_process_1.execFile)(command, args, { timeout: timeoutMs, maxBuffer: 1024 * 1024 }, function (error, stdout) {
834
- if (error) {
835
- reject(error);
836
- return;
837
- }
838
- resolve(stdout || '');
839
- });
840
- });
841
- };
842
- ResolveIOMainServer.prototype.resolvePm2ProtectedPids = function (processes) {
843
- var e_2, _a, e_3, _b;
844
- var byPid = new Map();
845
- var children = new Map();
846
- try {
847
- for (var processes_2 = __values(processes), processes_2_1 = processes_2.next(); !processes_2_1.done; processes_2_1 = processes_2.next()) {
848
- var proc = processes_2_1.value;
849
- byPid.set(proc.pid, proc);
850
- if (!children.has(proc.ppid)) {
851
- children.set(proc.ppid, []);
852
- }
853
- children.get(proc.ppid).push(proc.pid);
854
- }
855
- }
856
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
857
- finally {
858
- try {
859
- if (processes_2_1 && !processes_2_1.done && (_a = processes_2.return)) _a.call(processes_2);
860
- }
861
- finally { if (e_2) throw e_2.error; }
862
- }
863
- var protectedPids = new Set();
864
- var addWithDescendants = function (pid) {
865
- var e_4, _a;
866
- if (protectedPids.has(pid)) {
867
- return;
868
- }
869
- protectedPids.add(pid);
870
- try {
871
- for (var _b = __values(children.get(pid) || []), _c = _b.next(); !_c.done; _c = _b.next()) {
872
- var childPid = _c.value;
873
- addWithDescendants(childPid);
874
- }
875
- }
876
- catch (e_4_1) { e_4 = { error: e_4_1 }; }
877
- finally {
878
- try {
879
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
880
- }
881
- finally { if (e_4) throw e_4.error; }
882
- }
883
- };
884
- try {
885
- for (var processes_3 = __values(processes), processes_3_1 = processes_3.next(); !processes_3_1.done; processes_3_1 = processes_3.next()) {
886
- var proc = processes_3_1.value;
887
- if (proc.args.includes('pm2-runtime') || proc.args.includes('/pm2/')) {
888
- addWithDescendants(proc.pid);
889
- }
890
- }
891
- }
892
- catch (e_3_1) { e_3 = { error: e_3_1 }; }
893
- finally {
894
- try {
895
- if (processes_3_1 && !processes_3_1.done && (_b = processes_3.return)) _b.call(processes_3);
896
- }
897
- finally { if (e_3) throw e_3.error; }
898
- }
899
- var currentPid = process.pid;
900
- while (currentPid && byPid.has(currentPid)) {
901
- protectedPids.add(currentPid);
902
- currentPid = byPid.get(currentPid).ppid;
903
- }
904
- return protectedPids;
905
- };
906
- ResolveIOMainServer.prototype.shouldReapStandaloneNodeProcess = function (proc, protectedPids) {
907
- if (proc.pid === process.pid || proc.ppid !== 1 || protectedPids.has(proc.pid)) {
908
- return false;
909
- }
910
- if (!this.isNodeProcess(proc) || !this.isSameUidProcess(proc.pid)) {
911
- return false;
912
- }
913
- if (!this._standaloneNodeReaperIncludeSystemdServices && this.isProtectedSystemdServiceProcess(proc)) {
914
- return false;
915
- }
916
- if (!this.isResolveIOAppProcess(proc)) {
917
- return false;
918
- }
919
- if (proc.ageSeconds >= this._standaloneNodeReaperMinAgeSeconds) {
920
- return true;
921
- }
922
- if (proc.ageSeconds < this._standaloneNodeReaperHighMinAgeSeconds || !this.hasHighStandaloneNodeResourceUsage(proc)) {
923
- this.clearStandaloneNodeResourceHit(proc);
924
- return false;
925
- }
926
- return this.recordStandaloneNodeResourceHit(proc) >= this._standaloneNodeReaperHighConsecutiveScans;
927
- };
928
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperReason = function (proc) {
929
- if (proc.ageSeconds >= this._standaloneNodeReaperMinAgeSeconds) {
930
- return "orphan_age_seconds_gte_".concat(this._standaloneNodeReaperMinAgeSeconds);
931
- }
932
- var rssMb = proc.rssKb / 1024;
933
- if (proc.cpuPct >= this._standaloneNodeReaperHighCpuPct && rssMb >= this._standaloneNodeReaperHighRssMb) {
934
- return "orphan_high_cpu_and_rss_for_".concat(this._standaloneNodeReaperHighConsecutiveScans, "_scans");
935
- }
936
- if (proc.cpuPct >= this._standaloneNodeReaperHighCpuPct) {
937
- return "orphan_high_cpu_for_".concat(this._standaloneNodeReaperHighConsecutiveScans, "_scans");
938
- }
939
- if (rssMb >= this._standaloneNodeReaperHighRssMb) {
940
- return "orphan_high_rss_for_".concat(this._standaloneNodeReaperHighConsecutiveScans, "_scans");
941
- }
942
- return 'orphan_stale_node_process';
943
- };
944
- ResolveIOMainServer.prototype.isNodeProcess = function (proc) {
945
- return proc.command === 'node' || proc.command.startsWith('node ') || proc.args === 'node' || proc.args.startsWith('node ');
946
- };
947
- ResolveIOMainServer.prototype.isResolveIOAppProcess = function (proc) {
948
- var e_5, _a;
949
- var normalizedArgs = proc.args || '';
950
- var appDirs = this.resolveCurrentAppDirs();
951
- try {
952
- for (var appDirs_1 = __values(appDirs), appDirs_1_1 = appDirs_1.next(); !appDirs_1_1.done; appDirs_1_1 = appDirs_1.next()) {
953
- var appDir = appDirs_1_1.value;
954
- if (normalizedArgs.includes(appDir)) {
955
- return true;
956
- }
957
- }
958
- }
959
- catch (e_5_1) { e_5 = { error: e_5_1 }; }
960
- finally {
961
- try {
962
- if (appDirs_1_1 && !appDirs_1_1.done && (_a = appDirs_1.return)) _a.call(appDirs_1);
963
- }
964
- finally { if (e_5) throw e_5.error; }
965
- }
966
- if (normalizedArgs.includes('server-app.js') && normalizedArgs.includes('require(')) {
967
- return true;
968
- }
969
- var cwd = this.resolveProcessCwd(proc.pid);
970
- return cwd !== null && appDirs.has(cwd) && /\b(index|server-app)\.js\b/.test(normalizedArgs);
971
- };
972
- ResolveIOMainServer.prototype.hasHighStandaloneNodeResourceUsage = function (proc) {
973
- var rssMb = proc.rssKb / 1024;
974
- return proc.cpuPct >= this._standaloneNodeReaperHighCpuPct || rssMb >= this._standaloneNodeReaperHighRssMb;
975
- };
976
- ResolveIOMainServer.prototype.recordStandaloneNodeResourceHit = function (proc) {
977
- var signature = this.resolveStandaloneNodeProcessSignature(proc);
978
- var now = Date.now();
979
- var current = this._standaloneNodeReaperResourceHits.get(signature);
980
- if (!current || (now - current.lastSeenMs) > (this._standaloneNodeReaperIntervalMs * 3)) {
981
- this._standaloneNodeReaperResourceHits.set(signature, { count: 1, lastSeenMs: now });
982
- return 1;
983
- }
984
- current.count += 1;
985
- current.lastSeenMs = now;
986
- return current.count;
987
- };
988
- ResolveIOMainServer.prototype.clearStandaloneNodeResourceHit = function (proc) {
989
- this._standaloneNodeReaperResourceHits.delete(this.resolveStandaloneNodeProcessSignature(proc));
990
- };
991
- ResolveIOMainServer.prototype.resolveStandaloneNodeProcessSignature = function (proc) {
992
- var cwd = this.resolveProcessCwd(proc.pid) || '';
993
- return "".concat(cwd, "|").concat(proc.args);
994
- };
995
- ResolveIOMainServer.prototype.canReapStandaloneNodeSignature = function (signature) {
996
- var now = Date.now();
997
- var current = this._standaloneNodeReaperKillCounts.get(signature);
998
- if (!current || (now - current.windowStartMs) > this._standaloneNodeReaperKillWindowMs) {
999
- this._standaloneNodeReaperKillCounts.set(signature, { count: 0, windowStartMs: now });
1000
- this._standaloneNodeReaperSuppressedSignatures.delete(signature);
1001
- return true;
1002
- }
1003
- return current.count < this._standaloneNodeReaperMaxKillsPerSignature;
1004
- };
1005
- ResolveIOMainServer.prototype.recordStandaloneNodeReaperKill = function (signature) {
1006
- var now = Date.now();
1007
- var current = this._standaloneNodeReaperKillCounts.get(signature);
1008
- if (!current || (now - current.windowStartMs) > this._standaloneNodeReaperKillWindowMs) {
1009
- this._standaloneNodeReaperKillCounts.set(signature, { count: 1, windowStartMs: now });
1010
- this._standaloneNodeReaperSuppressedSignatures.delete(signature);
1011
- return;
1012
- }
1013
- current.count += 1;
1014
- };
1015
- ResolveIOMainServer.prototype.logStandaloneNodeReaperSuppressed = function (proc, signature) {
1016
- if (this._standaloneNodeReaperSuppressedSignatures.has(signature)) {
1017
- return;
1018
- }
1019
- this._standaloneNodeReaperSuppressedSignatures.add(signature);
1020
- console.warn(new Date(), '[Standalone Node Reaper] suppressing recurring stale node process', {
1021
- pid: proc.pid,
1022
- ppid: proc.ppid,
1023
- ageSeconds: proc.ageSeconds,
1024
- cpuPct: proc.cpuPct,
1025
- rssMb: (0, common_1.round)(proc.rssKb / 1024),
1026
- maxKillsPerSignature: this._standaloneNodeReaperMaxKillsPerSignature,
1027
- killWindowMs: this._standaloneNodeReaperKillWindowMs,
1028
- command: proc.args
1029
- });
1030
- };
1031
- ResolveIOMainServer.prototype.resolveCurrentAppDirs = function () {
1032
- var e_6, _a;
1033
- var _b;
1034
- var dirs = new Set();
1035
- try {
1036
- for (var _c = __values([process.cwd(), (_b = resolveio_server_app_1.ResolveIOServer.getClientDir) === null || _b === void 0 ? void 0 : _b.call(resolveio_server_app_1.ResolveIOServer)]), _d = _c.next(); !_d.done; _d = _c.next()) {
1037
- var value = _d.value;
1038
- if (!value) {
1039
- continue;
1040
- }
1041
- var resolved = this.safeRealpath(value);
1042
- if (resolved) {
1043
- dirs.add(resolved);
1044
- }
1045
- }
1046
- }
1047
- catch (e_6_1) { e_6 = { error: e_6_1 }; }
1048
- finally {
1049
- try {
1050
- if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
1051
- }
1052
- finally { if (e_6) throw e_6.error; }
1053
- }
1054
- return dirs;
1055
- };
1056
- ResolveIOMainServer.prototype.resolveProcessCwd = function (pid) {
1057
- return this.safeRealpath("/proc/".concat(pid, "/cwd"));
1058
- };
1059
- ResolveIOMainServer.prototype.safeRealpath = function (value) {
1060
- try {
1061
- return fs.realpathSync(value);
1062
- }
1063
- catch (_a) {
1064
- return null;
1065
- }
1066
- };
1067
- ResolveIOMainServer.prototype.isSameUidProcess = function (pid) {
1068
- if (typeof process.getuid !== 'function') {
1069
- return true;
1070
- }
1071
- try {
1072
- var status_1 = fs.readFileSync("/proc/".concat(pid, "/status"), 'utf8');
1073
- var uidLine = status_1.split('\n').find(function (line) { return line.startsWith('Uid:'); });
1074
- if (!uidLine) {
1075
- return false;
1076
- }
1077
- var uid = parseInt(uidLine.split(/\s+/)[1], 10);
1078
- return uid === process.getuid();
1079
- }
1080
- catch (_a) {
1081
- return false;
1082
- }
1083
- };
1084
- ResolveIOMainServer.prototype.isProtectedSystemdServiceProcess = function (proc) {
1085
- var serviceName = this.resolveSystemdServiceName(proc.pid);
1086
- if (!serviceName) {
1087
- return false;
1088
- }
1089
- return /\bindex\.js\b/.test(proc.args);
1090
- };
1091
- ResolveIOMainServer.prototype.resolveSystemdServiceName = function (pid) {
1092
- try {
1093
- var cgroup = fs.readFileSync("/proc/".concat(pid, "/cgroup"), 'utf8');
1094
- var serviceLine = cgroup.split('\n').find(function (line) { return line.includes('/system.slice/') && line.includes('.service'); });
1095
- if (!serviceLine) {
1096
- return null;
1097
- }
1098
- var match = serviceLine.match(/\/system\.slice\/([^/]+\.service)/);
1099
- return match ? match[1] : null;
1100
- }
1101
- catch (_a) {
1102
- return null;
1103
- }
1104
- };
1105
- ResolveIOMainServer.prototype.shutdownNetworkServers = function () {
1106
- return __awaiter(this, void 0, void 0, function () {
1107
- return __generator(this, function (_a) {
1108
- switch (_a.label) {
1109
- case 0: return [4 /*yield*/, this.closeWebSocketServerGracefully()];
1110
- case 1:
1111
- _a.sent();
1112
- return [4 /*yield*/, this.closeHttpServerGracefully()];
1113
- case 2:
1114
- _a.sent();
1115
- return [2 /*return*/];
1116
- }
1117
- });
1118
- });
1119
- };
1120
- ResolveIOMainServer.prototype.closeHttpServerGracefully = function () {
1121
- return __awaiter(this, void 0, void 0, function () {
1122
- var _this = this;
1123
- return __generator(this, function (_a) {
1124
- switch (_a.label) {
1125
- case 0:
1126
- if (!this._serverHTTP) {
1127
- return [2 /*return*/];
1128
- }
1129
- if (!(this._httpServerClosePromise !== null)) return [3 /*break*/, 2];
1130
- return [4 /*yield*/, this._httpServerClosePromise];
1131
- case 1:
1132
- _a.sent();
1133
- return [2 /*return*/];
1134
- case 2:
1135
- // eslint-disable-next-line no-restricted-syntax
1136
- this._httpServerClosePromise = new Promise(function (resolve) {
1137
- try {
1138
- _this._serverHTTP.close(function (error) {
1139
- if (error && error['code'] !== 'ERR_SERVER_NOT_RUNNING') {
1140
- console.error(new Date(), 'Error closing HTTP server before shutdown', error);
1141
- }
1142
- resolve();
1143
- });
1144
- }
1145
- catch (error) {
1146
- if (error && error['code'] !== 'ERR_SERVER_NOT_RUNNING') {
1147
- console.error(new Date(), 'Error closing HTTP server before shutdown', error);
1148
- }
1149
- resolve();
1150
- }
1151
- });
1152
- return [4 /*yield*/, this._httpServerClosePromise];
1153
- case 3:
1154
- _a.sent();
1155
- return [2 /*return*/];
1156
- }
1157
- });
1158
- });
1159
- };
1160
- ResolveIOMainServer.prototype.closeWebSocketServerGracefully = function () {
1161
- return __awaiter(this, void 0, void 0, function () {
1162
- var _this = this;
1163
- return __generator(this, function (_a) {
1164
- switch (_a.label) {
1165
- case 0:
1166
- if (!this._serverWSS) {
1167
- return [2 /*return*/];
1168
- }
1169
- if (!(this._websocketServerClosePromise !== null)) return [3 /*break*/, 2];
1170
- return [4 /*yield*/, this._websocketServerClosePromise];
1171
- case 1:
1172
- _a.sent();
1173
- return [2 /*return*/];
1174
- case 2:
1175
- this._serverWSS.clients.forEach(function (ws) {
1176
- try {
1177
- ws.close(1001, 'Server restarting');
1178
- }
1179
- catch (error) {
1180
- console.error(new Date(), 'Error closing WebSocket client before shutdown', error);
1181
- }
1182
- });
1183
- // eslint-disable-next-line no-restricted-syntax
1184
- this._websocketServerClosePromise = new Promise(function (resolve) {
1185
- try {
1186
- _this._serverWSS.close(function (error) {
1187
- if (error) {
1188
- console.error(new Date(), 'Error closing WebSocket server before shutdown', error);
1189
- }
1190
- resolve();
1191
- });
1192
- }
1193
- catch (error) {
1194
- console.error(new Date(), 'Error closing WebSocket server before shutdown', error);
1195
- resolve();
1196
- }
1197
- });
1198
- return [4 /*yield*/, this._websocketServerClosePromise];
1199
- case 3:
1200
- _a.sent();
1201
- return [2 /*return*/];
1202
- }
1203
- });
1204
- });
1205
- };
1206
- ResolveIOMainServer.prototype.startServerInstance = function () {
1207
- // Start express app
1208
- this._app = express();
1209
- // Use built-in express JSON parser
1210
- this._app.use(express.json({
1211
- limit: '50mb',
1212
- reviver: common_1.dateReviver // Note: 'reviver' is an option for JSON.parse, which can be passed here
1213
- }));
1214
- // Use built-in express URL-encoded parser
1215
- this._app.use(express.urlencoded({
1216
- limit: '50mb',
1217
- extended: true, // `extended` must be explicitly true or false
1218
- parameterLimit: 1000000
1219
- }));
1220
- this._app.use(xmlParser());
1221
- // Set port
1222
- this._portHTTP = process.env.NODE_APP_INSTANCE ? parseInt('808' + process.env.NODE_APP_INSTANCE) : 8080;
1223
- if (this.LOGGER === 'DEBUG') {
1224
- console.log('Setup ports');
1225
- }
1226
- // Create http server and websock server
1227
- this.createServer();
1228
- if (this.LOGGER === 'DEBUG') {
1229
- console.log('Create server');
1230
- }
1231
- // Set CORS
1232
- this._app.use(function (req, res, next) {
1233
- res.setHeader('Access-Control-Allow-Origin', '*');
1234
- res.setHeader('Access-Control-Allow-Methods', 'GET, POST');
1235
- res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');
1236
- res.setHeader('Access-Control-Allow-Credentials', 'false');
1237
- next();
1238
- });
1239
- if (this.LOGGER === 'DEBUG') {
1240
- console.log('Setup cors');
1241
- }
1242
- this.installDynamicAppGatewayMiddleware();
1243
- // Set up http login route
1244
- (0, auth_1.setupAuthRoutes)(this, this._app, resolveio_server_app_1.ResolveIOServer.getServerConfig());
1245
- (0, health_1.setupHealthRoutes)(this._app);
1246
- (0, slow_query_publication_1.setupSlowQueryPublicationRoutes)(this._app);
1247
- if (resolveio_server_app_1.ResolveIOServer.getServerConfig()['CLIENT_NAME'] === 'ResolveIO' || this.publicProgram) {
1248
- (0, home_1.setupHomeRoutes)(this, this._app, resolveio_server_app_1.ResolveIOServer.getServerConfig());
1249
- }
1250
- if (this.LOGGER === 'DEBUG') {
1251
- console.log('Setup express routes');
1252
- }
1253
- };
1254
- ResolveIOMainServer.prototype.installDynamicAppGatewayMiddleware = function () {
1255
- var _this = this;
1256
- if (!this._dynamicAppGatewayEnabled) {
1257
- return;
1258
- }
1259
- this._app.use(function (req, res, next) { return __awaiter(_this, void 0, void 0, function () {
1260
- var appId, appDoc, allowedHosts, controlHosts, requestHost, originHeader, originHost, expectedToken, providedToken, error_8;
1261
- var _a, _b, _c;
1262
- return __generator(this, function (_d) {
1263
- switch (_d.label) {
1264
- case 0:
1265
- appId = this.extractDynamicAppGatewayId(req);
1266
- if (!appId) {
1267
- next();
1268
- return [2 /*return*/];
1269
- }
1270
- _d.label = 1;
1271
- case 1:
1272
- _d.trys.push([1, 3, , 4]);
1273
- return [4 /*yield*/, this.resolveCachedDynamicAppGatewayApp(appId)];
1274
- case 2:
1275
- appDoc = _d.sent();
1276
- if (!appDoc) {
1277
- res.status(404).send(JSON.stringify({
1278
- error: true,
1279
- result: 'App not found.'
1280
- }));
1281
- return [2 /*return*/];
1282
- }
1283
- allowedHosts = this.resolveDynamicAppAllowedHosts(appDoc);
1284
- controlHosts = this.resolveDynamicAppControlHosts();
1285
- requestHost = this.normalizeHostname(this.normalizeHeaderValue((_a = req.headers) === null || _a === void 0 ? void 0 : _a['x-forwarded-host'])
1286
- || this.normalizeHeaderValue((_b = req.headers) === null || _b === void 0 ? void 0 : _b.host));
1287
- originHeader = this.normalizeHeaderValue((_c = req.headers) === null || _c === void 0 ? void 0 : _c.origin);
1288
- originHost = this.resolveOriginHostname(originHeader);
1289
- if (requestHost && controlHosts.has(requestHost) && !this.isLocalHostname(requestHost)) {
1290
- res.status(403).send(JSON.stringify({
1291
- error: true,
1292
- result: 'App API must be requested from an app domain.'
1293
- }));
1294
- return [2 /*return*/];
1295
- }
1296
- if (requestHost && !allowedHosts.has(requestHost) && !this.isLocalHostname(requestHost)) {
1297
- res.status(403).send(JSON.stringify({
1298
- error: true,
1299
- result: 'Host not allowed for app API.'
1300
- }));
1301
- return [2 /*return*/];
1302
- }
1303
- if (originHost && controlHosts.has(originHost) && !this.isLocalHostname(originHost)) {
1304
- res.status(403).send(JSON.stringify({
1305
- error: true,
1306
- result: 'App API origin must be an app domain.'
1307
- }));
1308
- return [2 /*return*/];
1309
- }
1310
- if (originHost && !allowedHosts.has(originHost)) {
1311
- res.status(403).send(JSON.stringify({
1312
- error: true,
1313
- result: 'Origin not allowed for app API.'
1314
- }));
1315
- return [2 /*return*/];
1316
- }
1317
- if (originHeader) {
1318
- this.applyDynamicAppGatewayCorsHeaders(res, originHeader);
1319
- }
1320
- if (req.method === 'OPTIONS') {
1321
- res.status(204).end();
1322
- return [2 /*return*/];
1323
- }
1324
- expectedToken = this.normalizeHeaderValue(appDoc === null || appDoc === void 0 ? void 0 : appDoc.rio_token);
1325
- if (!expectedToken) {
1326
- res.status(500).send(JSON.stringify({
1327
- error: true,
1328
- result: 'App token is not configured.'
1329
- }));
1330
- return [2 /*return*/];
1331
- }
1332
- providedToken = this.resolveDynamicAppGatewayToken(req);
1333
- if (!providedToken || providedToken !== expectedToken) {
1334
- res.status(401).send(JSON.stringify({
1335
- error: true,
1336
- result: 'Invalid or missing RIO token.'
1337
- }));
1338
- return [2 /*return*/];
1339
- }
1340
- next();
1341
- return [3 /*break*/, 4];
1342
- case 3:
1343
- error_8 = _d.sent();
1344
- console.error(new Date(), '[DynamicAppGateway] middleware failure', error_8);
1345
- res.status(500).send(JSON.stringify({
1346
- error: true,
1347
- result: (error_8 === null || error_8 === void 0 ? void 0 : error_8.message) || 'Dynamic app gateway error.'
1348
- }));
1349
- return [3 /*break*/, 4];
1350
- case 4: return [2 /*return*/];
1351
- }
1352
- });
1353
- }); });
1354
- };
1355
- ResolveIOMainServer.prototype.resolveDynamicAppGatewayEnabled = function () {
1356
- var _a;
1357
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig() || {};
1358
- var raw = (_a = config['AI_CODER_DYNAMIC_APP_GATEWAY']) !== null && _a !== void 0 ? _a : process.env.AI_CODER_DYNAMIC_APP_GATEWAY;
1359
- if (raw !== undefined && raw !== null && "".concat(raw).trim() !== '') {
1360
- return this.parseDebugFlag(raw);
1361
- }
1362
- var urls = [
1363
- config['ROOT_URL'],
1364
- config['SEC_ROOT_URL'],
1365
- config['SERVER_URL'],
1366
- process.env.ROOT_URL,
1367
- process.env.SEC_ROOT_URL,
1368
- process.env.SERVER_URL
1369
- ]
1370
- .map(function (value) { return "".concat(value || '').trim().toLowerCase(); })
1371
- .filter(Boolean);
1372
- return urls.some(function (value) { return value.includes('aicoder'); });
1373
- };
1374
- ResolveIOMainServer.prototype.extractDynamicAppGatewayId = function (req) {
1375
- var rawPath = "".concat(req.originalUrl || req.url || req.path || '');
1376
- var normalizedPath = rawPath.split('?')[0];
1377
- if (!normalizedPath.startsWith('/api/apps/')) {
1378
- return '';
1379
- }
1380
- var parts = normalizedPath.split('/').filter(Boolean);
1381
- if (parts.length < 3) {
1382
- return '';
1383
- }
1384
- return "".concat(parts[2] || '').trim();
1385
- };
1386
- ResolveIOMainServer.prototype.resolveDynamicAppGatewayToken = function (req) {
1387
- var e_7, _a, e_8, _b, e_9, _c;
1388
- var _d, _e, _f, _g, _h;
1389
- var authHeader = this.normalizeHeaderValue(((_d = req.headers) === null || _d === void 0 ? void 0 : _d.authorization) || ((_e = req.headers) === null || _e === void 0 ? void 0 : _e.Authorization));
1390
- if (authHeader) {
1391
- var bearerMatch = authHeader.match(/^bearer\s+(.+)$/i);
1392
- if (bearerMatch && bearerMatch[1]) {
1393
- return bearerMatch[1].trim();
1394
- }
1395
- }
1396
- var headerCandidates = [
1397
- (_f = req.headers) === null || _f === void 0 ? void 0 : _f['x-rio-token'],
1398
- (_g = req.headers) === null || _g === void 0 ? void 0 : _g['x-app-token'],
1399
- (_h = req.headers) === null || _h === void 0 ? void 0 : _h['x-api-key']
1400
- ];
1401
- try {
1402
- for (var headerCandidates_1 = __values(headerCandidates), headerCandidates_1_1 = headerCandidates_1.next(); !headerCandidates_1_1.done; headerCandidates_1_1 = headerCandidates_1.next()) {
1403
- var candidate = headerCandidates_1_1.value;
1404
- var value = this.normalizeHeaderValue(candidate);
1405
- if (value) {
1406
- return value;
1407
- }
1408
- }
1409
- }
1410
- catch (e_7_1) { e_7 = { error: e_7_1 }; }
1411
- finally {
1412
- try {
1413
- if (headerCandidates_1_1 && !headerCandidates_1_1.done && (_a = headerCandidates_1.return)) _a.call(headerCandidates_1);
1414
- }
1415
- finally { if (e_7) throw e_7.error; }
1416
- }
1417
- var body = req.body || {};
1418
- var query = req.query || {};
1419
- var bodyCandidates = [body.rioToken, body.rio_token, body.apiKey, body.token];
1420
- try {
1421
- for (var bodyCandidates_1 = __values(bodyCandidates), bodyCandidates_1_1 = bodyCandidates_1.next(); !bodyCandidates_1_1.done; bodyCandidates_1_1 = bodyCandidates_1.next()) {
1422
- var candidate = bodyCandidates_1_1.value;
1423
- var value = this.normalizeHeaderValue(candidate);
1424
- if (value) {
1425
- return value;
1426
- }
1427
- }
1428
- }
1429
- catch (e_8_1) { e_8 = { error: e_8_1 }; }
1430
- finally {
1431
- try {
1432
- if (bodyCandidates_1_1 && !bodyCandidates_1_1.done && (_b = bodyCandidates_1.return)) _b.call(bodyCandidates_1);
1433
- }
1434
- finally { if (e_8) throw e_8.error; }
1435
- }
1436
- var queryCandidates = [query.rioToken, query.rio_token, query.apiKey, query.token];
1437
- try {
1438
- for (var queryCandidates_1 = __values(queryCandidates), queryCandidates_1_1 = queryCandidates_1.next(); !queryCandidates_1_1.done; queryCandidates_1_1 = queryCandidates_1.next()) {
1439
- var candidate = queryCandidates_1_1.value;
1440
- var value = this.normalizeHeaderValue(candidate);
1441
- if (value) {
1442
- return value;
1443
- }
1444
- }
1445
- }
1446
- catch (e_9_1) { e_9 = { error: e_9_1 }; }
1447
- finally {
1448
- try {
1449
- if (queryCandidates_1_1 && !queryCandidates_1_1.done && (_c = queryCandidates_1.return)) _c.call(queryCandidates_1);
1450
- }
1451
- finally { if (e_9) throw e_9.error; }
1452
- }
1453
- return '';
1454
- };
1455
- ResolveIOMainServer.prototype.normalizeHeaderValue = function (value) {
1456
- if (Array.isArray(value)) {
1457
- return value.map(function (entry) { return "".concat(entry || '').trim(); }).filter(Boolean).join(',');
1458
- }
1459
- return "".concat(value || '').trim();
1460
- };
1461
- ResolveIOMainServer.prototype.normalizeHostname = function (value) {
1462
- var raw = "".concat(value || '').trim();
1463
- if (!raw) {
1464
- return '';
1465
- }
1466
- var candidate = raw.split(',')[0].trim();
1467
- if (!candidate) {
1468
- return '';
1469
- }
1470
- try {
1471
- if (candidate.startsWith('http://') || candidate.startsWith('https://')) {
1472
- return new url_1.URL(candidate).hostname.toLowerCase();
1473
- }
1474
- if (candidate.includes('/')) {
1475
- return new url_1.URL("http://".concat(candidate)).hostname.toLowerCase();
1476
- }
1477
- }
1478
- catch (_a) { }
1479
- candidate = candidate.replace(/^\[/, '').replace(/\]$/, '');
1480
- var lastColon = candidate.lastIndexOf(':');
1481
- if (lastColon > -1 && candidate.indexOf(':') === lastColon) {
1482
- candidate = candidate.slice(0, lastColon);
1483
- }
1484
- return candidate.toLowerCase();
1485
- };
1486
- ResolveIOMainServer.prototype.resolveOriginHostname = function (origin) {
1487
- var raw = "".concat(origin || '').trim();
1488
- if (!raw) {
1489
- return '';
1490
- }
1491
- try {
1492
- return new url_1.URL(raw).hostname.toLowerCase();
1493
- }
1494
- catch (_a) {
1495
- return this.normalizeHostname(raw);
1496
- }
1497
- };
1498
- ResolveIOMainServer.prototype.isLocalHostname = function (hostname) {
1499
- var normalized = this.normalizeHostname(hostname);
1500
- return normalized === 'localhost' || normalized === '127.0.0.1' || normalized === '::1';
1501
- };
1502
- ResolveIOMainServer.prototype.resolveDynamicAppControlHosts = function () {
1503
- var e_10, _a;
1504
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig() || {};
1505
- var hosts = new Set();
1506
- var candidates = [
1507
- config['ROOT_URL'],
1508
- config['SEC_ROOT_URL'],
1509
- config['SERVER_URL'],
1510
- process.env.ROOT_URL,
1511
- process.env.SEC_ROOT_URL,
1512
- process.env.SERVER_URL,
1513
- process.env.AI_CODER_ROOT_URL,
1514
- process.env.AI_CODER_SEC_ROOT_URL,
1515
- process.env.AI_CODER_SERVER_URL
1516
- ];
1517
- try {
1518
- for (var candidates_1 = __values(candidates), candidates_1_1 = candidates_1.next(); !candidates_1_1.done; candidates_1_1 = candidates_1.next()) {
1519
- var candidate = candidates_1_1.value;
1520
- var normalized = this.normalizeHostname("".concat(candidate || ''));
1521
- if (normalized) {
1522
- hosts.add(normalized);
1523
- }
1524
- }
1525
- }
1526
- catch (e_10_1) { e_10 = { error: e_10_1 }; }
1527
- finally {
1528
- try {
1529
- if (candidates_1_1 && !candidates_1_1.done && (_a = candidates_1.return)) _a.call(candidates_1);
1530
- }
1531
- finally { if (e_10) throw e_10.error; }
1532
- }
1533
- return hosts;
1534
- };
1535
- ResolveIOMainServer.prototype.resolveDynamicAppAllowedHosts = function (appDoc) {
1536
- var e_11, _a;
1537
- var hosts = new Set();
1538
- var candidates = [
1539
- appDoc === null || appDoc === void 0 ? void 0 : appDoc.domain,
1540
- appDoc === null || appDoc === void 0 ? void 0 : appDoc.backend_domain
1541
- ];
1542
- if ((appDoc === null || appDoc === void 0 ? void 0 : appDoc.subdomain) && (appDoc === null || appDoc === void 0 ? void 0 : appDoc.domain_base)) {
1543
- candidates.push("".concat(appDoc.subdomain, ".").concat(appDoc.domain_base));
1544
- }
1545
- try {
1546
- for (var candidates_2 = __values(candidates), candidates_2_1 = candidates_2.next(); !candidates_2_1.done; candidates_2_1 = candidates_2.next()) {
1547
- var candidate = candidates_2_1.value;
1548
- var normalized = this.normalizeHostname("".concat(candidate || ''));
1549
- if (normalized) {
1550
- hosts.add(normalized);
1551
- }
1552
- }
1553
- }
1554
- catch (e_11_1) { e_11 = { error: e_11_1 }; }
1555
- finally {
1556
- try {
1557
- if (candidates_2_1 && !candidates_2_1.done && (_a = candidates_2.return)) _a.call(candidates_2);
1558
- }
1559
- finally { if (e_11) throw e_11.error; }
1560
- }
1561
- return hosts;
1562
- };
1563
- ResolveIOMainServer.prototype.applyDynamicAppGatewayCorsHeaders = function (res, origin) {
1564
- res.setHeader('Access-Control-Allow-Origin', origin);
1565
- res.setHeader('Vary', 'Origin');
1566
- res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, PATCH, DELETE, OPTIONS');
1567
- res.setHeader('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept, Authorization, X-Rio-Token, X-API-Key');
1568
- res.setHeader('Access-Control-Allow-Credentials', 'true');
1569
- res.setHeader('Access-Control-Max-Age', '600');
1570
- };
1571
- ResolveIOMainServer.prototype.resolveCachedDynamicAppGatewayApp = function (appId) {
1572
- return __awaiter(this, void 0, void 0, function () {
1573
- var now, cached, db, appCollection, appDoc, generated;
1574
- return __generator(this, function (_a) {
1575
- switch (_a.label) {
1576
- case 0:
1577
- now = Date.now();
1578
- cached = this._dynamicAppGatewayCache.get(appId);
1579
- if (cached && cached.expiresAt > now) {
1580
- return [2 /*return*/, cached.app];
1581
- }
1582
- db = resolveio_server_app_1.ResolveIOServer.getMainDB();
1583
- if (!db) {
1584
- return [2 /*return*/, null];
1585
- }
1586
- appCollection = db.collection('ai-coder-apps');
1587
- return [4 /*yield*/, appCollection.findOne({ _id: appId }, {
1588
- projection: {
1589
- _id: 1,
1590
- domain: 1,
1591
- backend_domain: 1,
1592
- subdomain: 1,
1593
- domain_base: 1,
1594
- rio_token: 1
1595
- }
1596
- })];
1597
- case 1:
1598
- appDoc = _a.sent();
1599
- if (!appDoc) {
1600
- this._dynamicAppGatewayCache.delete(appId);
1601
- return [2 /*return*/, null];
1602
- }
1603
- if (!!this.normalizeHeaderValue(appDoc.rio_token)) return [3 /*break*/, 3];
1604
- generated = crypto.randomBytes(32).toString('hex');
1605
- return [4 /*yield*/, appCollection.updateOne({ _id: appId }, {
1606
- $set: {
1607
- rio_token: generated,
1608
- updatedAt: new Date()
1609
- }
1610
- })];
1611
- case 2:
1612
- _a.sent();
1613
- appDoc.rio_token = generated;
1614
- _a.label = 3;
1615
- case 3:
1616
- this._dynamicAppGatewayCache.set(appId, {
1617
- expiresAt: now + this._dynamicAppGatewayCacheMs,
1618
- app: appDoc
1619
- });
1620
- return [2 /*return*/, appDoc];
1621
- }
1622
- });
1623
- });
1624
- };
1625
- ResolveIOMainServer.prototype.safeShutdown = function () {
1626
- return __awaiter(this, void 0, void 0, function () {
1627
- var _a;
1628
- var _this = this;
1629
- return __generator(this, function (_b) {
1630
- switch (_b.label) {
1631
- case 0:
1632
- if (!this._safeShutdown) {
1633
- console.log(new Date(), 'Safe Shutdown Command Received');
1634
- }
1635
- if (!(!this._monitorManagerFunction.getActiveMonitorFunctions().length
1636
- && !this._offlineUpdates.length && (!this._workerDispatcherManager || this._workerDispatcherManager.isSafeShutdown()))) return [3 /*break*/, 7];
1637
- if (!resolveio_server_app_1.ResolveIOServer.getMongoConnection()) return [3 /*break*/, 5];
1638
- _b.label = 1;
1639
- case 1:
1640
- _b.trys.push([1, 3, , 4]);
1641
- return [4 /*yield*/, resolveio_server_app_1.ResolveIOServer.getMongoConnection().close(false)];
1642
- case 2:
1643
- _b.sent();
1644
- console.log(new Date(), 'Safe Exit Complete, Process Exit');
1645
- process.exit(0);
1646
- return [3 /*break*/, 4];
1647
- case 3:
1648
- _a = _b.sent();
1649
- process.exit(1);
1650
- return [3 /*break*/, 4];
1651
- case 4:
1652
- ;
1653
- return [3 /*break*/, 6];
1654
- case 5:
1655
- process.exit(0);
1656
- _b.label = 6;
1657
- case 6: return [3 /*break*/, 8];
1658
- case 7:
1659
- if (!this._safeShutdown) {
1660
- this._safeShutdown = true;
1661
- setTimeout(function () {
1662
- _this._safeShutdown = false;
1663
- }, 1000);
1664
- console.log(new Date(), 'Safe Exit In Progress', this._monitorManagerFunction.getActiveMonitorFunctions().length, this._offlineUpdates.length);
1665
- }
1666
- setImmediate(function () { return __awaiter(_this, void 0, void 0, function () {
1667
- return __generator(this, function (_a) {
1668
- switch (_a.label) {
1669
- case 0: return [4 /*yield*/, this.safeShutdown()];
1670
- case 1:
1671
- _a.sent();
1672
- return [2 /*return*/];
1673
- }
1674
- });
1675
- }); });
1676
- _b.label = 8;
1677
- case 8: return [2 /*return*/];
1678
- }
1679
- });
1680
- });
1681
- };
1682
- ResolveIOMainServer.prototype.getIsWorkersEnabled = function () {
1683
- return this._isWorkersEnabled;
1684
- };
1685
- ResolveIOMainServer.prototype.getIsWorkerInstance = function () {
1686
- return this._isWorkerInstance;
1687
- };
1688
- ResolveIOMainServer.prototype.getWSList = function () {
1689
- var res = [];
1690
- this._serverWSS.clients.forEach(function (ws) {
1691
- res.push(ws['id_socket']);
1692
- });
1693
- return res;
1694
- };
1695
- ResolveIOMainServer.prototype.getWSUserList = function () {
1696
- var res = [];
1697
- this._serverWSS.clients.forEach(function (ws) {
1698
- res.push(ws['id_user']);
1699
- });
1700
- return res;
1701
- };
1702
- ResolveIOMainServer.prototype.getHTTPServer = function () {
1703
- return this._serverHTTP;
1704
- };
1705
- ResolveIOMainServer.prototype.getCronManager = function () {
1706
- return this._cronManager;
1707
- };
1708
- ResolveIOMainServer.prototype.reportServerError = function (subject_1, correlationId_1, context_1, meta_1) {
1709
- return __awaiter(this, arguments, void 0, function (subject, correlationId, context, meta, severity, stackOverride) {
1710
- var config, metadata;
1711
- if (severity === void 0) { severity = 'error'; }
1712
- return __generator(this, function (_a) {
1713
- switch (_a.label) {
1714
- case 0:
1715
- config = resolveio_server_app_1.ResolveIOServer.getServerConfig();
1716
- metadata = Object.assign({}, meta || {});
1717
- if (correlationId && !metadata.correlationId) {
1718
- metadata.correlationId = correlationId;
1719
- }
1720
- return [4 /*yield*/, error_reporter_1.ErrorReporter.report({
1721
- sourceApp: 'server-app',
1722
- message: subject,
1723
- environment: (config === null || config === void 0 ? void 0 : config.ROOT_URL) || process.env.NODE_ENV || 'unknown',
1724
- clientSlug: resolveio_server_app_1.ResolveIOServer.getClientName(),
1725
- clientName: config === null || config === void 0 ? void 0 : config.CLIENT_NAME,
1726
- severity: severity,
1727
- stack: stackOverride || (typeof (context === null || context === void 0 ? void 0 : context.stack) === 'string' ? context.stack : undefined),
1728
- context: context,
1729
- metadata: metadata,
1730
- correlationId: correlationId
1731
- })];
1732
- case 1:
1733
- _a.sent();
1734
- return [2 /*return*/];
1735
- }
1736
- });
1737
- });
1738
- };
1739
- ResolveIOMainServer.prototype.getMethodManager = function () {
1740
- return this._methodManager;
1741
- };
1742
- ResolveIOMainServer.prototype.getSubscriptionManager = function () {
1743
- return this._subscriptionManager;
1744
- };
1745
- ResolveIOMainServer.prototype.getMonitorManager = function () {
1746
- return this._monitorManager;
1747
- };
1748
- ResolveIOMainServer.prototype.getRebootFlag = function () {
1749
- return this._rebootFlag;
1750
- };
1751
- ResolveIOMainServer.prototype.getWebSocketManager = function () {
1752
- return this._websocketManager;
1753
- };
1754
- ResolveIOMainServer.prototype.createServer = function () {
1755
- var _this = this;
1756
- this._serverHTTP = (0, http_1.createServer)(this._app);
1757
- this._serverHTTP.keepAliveTimeout = 65000;
1758
- this._serverHTTP.headersTimeout = 66000;
1759
- this._serverWSS = new WebSocket.Server({
1760
- server: this._serverHTTP,
1761
- verifyClient: this.publicProgram ? null : function (info, cb) {
1762
- if (_this._rebootFlag) {
1763
- cb(false, 409, 'Unable To Process');
1764
- }
1765
- else {
1766
- if (_this.LOGGER === 'DEBUG') {
1767
- console.log('Verify Client', info, cb);
1768
- }
1769
- // If it's a worker, we might skip token checks or do a simple check:
1770
- if (info.req.url && info.req.url.includes('workerToken=')) {
1771
- var requestUrl = void 0;
1772
- var rootUrl = resolveio_server_app_1.ResolveIOServer.getServerConfig()['ROOT_URL'] || 'http://localhost';
1773
- try {
1774
- requestUrl = new url_1.URL(info.req.url, rootUrl);
1775
- }
1776
- catch (_a) {
1777
- cb(false, 400, 'Bad Request');
1778
- return;
1779
- }
1780
- var workerToken = requestUrl.searchParams.get('workerToken') || '';
1781
- var workerIndex = _this.normalizeWorkerSelectorValue(requestUrl.searchParams.get('workerIndex'));
1782
- var workerInstance = _this.normalizeWorkerSelectorValue(requestUrl.searchParams.get('workerInstance'));
1783
- var expectedWorkerToken = String(resolveio_server_app_1.ResolveIOServer.getServerConfig()['WORKER_TOKEN'] || '');
1784
- if (!workerIndex || !workerInstance) {
1785
- cb(false, 400, 'Missing worker identity');
1786
- return;
1787
- }
1788
- if (workerToken === expectedWorkerToken) {
1789
- info.req['workerIndex'] = workerIndex;
1790
- info.req['workerInstance'] = workerInstance;
1791
- cb(true);
1792
- }
1793
- else {
1794
- cb(false, 401, 'Unauthorized');
1795
- }
1796
- return;
1797
- }
1798
- var protocolsHeader = info.req.headers['sec-websocket-protocol'];
1799
- if (!protocolsHeader || typeof protocolsHeader !== 'string') {
1800
- cb(false, 401, 'Unauthorized');
1801
- return;
1802
- }
1803
- var infoData = protocolsHeader.split(/,/);
1804
- if (!(0, common_1.isAllowedOrigin)(info.origin, resolveio_server_app_1.ResolveIOServer.getServerConfig())) {
1805
- cb(false, 401, 'Unauthorized');
1806
- }
1807
- else {
1808
- var token = infoData[0];
1809
- if (!token) {
1810
- cb(false, 401, 'Unauthorized');
1811
- }
1812
- else {
1813
- jwt.verify(token, resolveio_server_app_1.ResolveIOServer.getServerConfig()['JWT_SECRET'], function (err, decoded) { return __awaiter(_this, void 0, void 0, function () {
1814
- var user, socketAdmission, _a;
1815
- return __generator(this, function (_b) {
1816
- switch (_b.label) {
1817
- case 0:
1818
- if (!err) return [3 /*break*/, 1];
1819
- cb(false, 401, 'Unauthorized');
1820
- return [3 /*break*/, 8];
1821
- case 1:
1822
- info.req['id_user'] = decoded['id_user'];
1823
- _b.label = 2;
1824
- case 2:
1825
- _b.trys.push([2, 7, , 8]);
1826
- return [4 /*yield*/, user_collection_1.Users.findById(decoded['id_user'])];
1827
- case 3:
1828
- user = _b.sent();
1829
- if (!user) return [3 /*break*/, 5];
1830
- return [4 /*yield*/, this.evaluateClientSocketAdmission(decoded['id_user'], info.req)];
1831
- case 4:
1832
- socketAdmission = _b.sent();
1833
- if (!socketAdmission.allowed) {
1834
- cb(false, socketAdmission.statusCode, socketAdmission.message || 'Socket connection rejected.');
1835
- return [2 /*return*/];
1836
- }
1837
- info.req['user'] = user.fullname;
1838
- info.req['user_readonly'] = user.readonly || false;
1839
- info.req['doc_user'] = user;
1840
- info.req['client_ip'] = socketAdmission.clientIp;
1841
- cb(true);
1842
- return [3 /*break*/, 6];
1843
- case 5:
1844
- cb(false);
1845
- _b.label = 6;
1846
- case 6: return [3 /*break*/, 8];
1847
- case 7:
1848
- _a = _b.sent();
1849
- cb(false);
1850
- return [3 /*break*/, 8];
1851
- case 8: return [2 /*return*/];
1852
- }
1853
- });
1854
- }); });
1855
- }
1856
- }
1857
- }
1858
- }
1859
- });
1860
- };
1861
- /**
1862
- * Listen for connections from clients or workers.
1863
- */
1864
- ResolveIOMainServer.prototype.listen = function () {
1865
- var _this = this;
1866
- var host = process.env.RESOLVEIO_BIND_HOST || '127.0.0.1';
1867
- this._serverHTTP.listen(this._portHTTP, host, function () {
1868
- console.log('Running HTTP/WS server on port %s', _this._portHTTP);
1869
- });
1870
- this._serverWSS.on('connection', function (ws, req) { return __awaiter(_this, void 0, void 0, function () {
1871
- var workerId_1, workerIndex, workerInstance, rootUrl, requestUrl, workerIndexForLog, workerInstanceForLog, interval_1, lastComm_1, missedPongs_1, heartbeatIntervalMs, maxMissedPongs_1, maxSilenceMs_1, socketAdmission, socketPolicyError_1;
1872
- var _this = this;
1873
- var _a;
1874
- return __generator(this, function (_b) {
1875
- switch (_b.label) {
1876
- case 0:
1877
- if (!(req.url && req.url.includes('workerToken='))) return [3 /*break*/, 1];
1878
- workerId_1 = (0, common_1.objectIdHexString)();
1879
- ws['id_worker'] = workerId_1;
1880
- workerIndex = null;
1881
- workerInstance = null;
1882
- ws['supportsBinary'] = true;
1883
- if (req.url) {
1884
- rootUrl = resolveio_server_app_1.ResolveIOServer.getServerConfig()['ROOT_URL'] || 'http://localhost';
1885
- try {
1886
- requestUrl = new url_1.URL(req.url, rootUrl);
1887
- workerIndex = requestUrl.searchParams.get('workerIndex');
1888
- workerInstance = requestUrl.searchParams.get('workerInstance');
1889
- }
1890
- catch (_c) {
1891
- workerIndex = null;
1892
- workerInstance = null;
1893
- }
1894
- }
1895
- if (!workerIndex && req['workerIndex']) {
1896
- workerIndex = req['workerIndex'];
1897
- }
1898
- if (!workerInstance && req['workerInstance']) {
1899
- workerInstance = req['workerInstance'];
1900
- }
1901
- workerIndex = this.normalizeWorkerSelectorValue(workerIndex);
1902
- workerInstance = this.normalizeWorkerSelectorValue(workerInstance);
1903
- if (!workerIndex || !workerInstance) {
1904
- console.warn(new Date(), 'Rejected worker connection with missing identity', {
1905
- workerId: workerId_1,
1906
- workerIndex: workerIndex || null,
1907
- workerInstance: workerInstance || null
1908
- });
1909
- ws.close(1008, 'Missing worker identity');
1910
- return [2 /*return*/];
1911
- }
1912
- ws['workerIndex'] = workerIndex;
1913
- ws['workerInstance'] = workerInstance;
1914
- workerIndexForLog = ws['workerIndex'] || 'UNKNOWN';
1915
- workerInstanceForLog = ws['workerInstance'] || 'UNKNOWN';
1916
- console.log(new Date(), 'Worker Connected', workerIndexForLog, workerInstanceForLog);
1917
- this._workerDispatcherManager.addWorker(ws);
1918
- interval_1 = null;
1919
- lastComm_1 = new Date();
1920
- missedPongs_1 = 0;
1921
- heartbeatIntervalMs = 30000;
1922
- maxMissedPongs_1 = 2;
1923
- maxSilenceMs_1 = heartbeatIntervalMs * (maxMissedPongs_1 + 1);
1924
- this._workerDispatcherManager.sendWorkerPayload(ws, 'ping');
1925
- interval_1 = setInterval(function () {
1926
- var now = Date.now();
1927
- var last = lastComm_1 ? lastComm_1.getTime() : 0;
1928
- var silenceMs = last ? now - last : maxSilenceMs_1 + 1;
1929
- if (silenceMs > maxSilenceMs_1 || missedPongs_1 > maxMissedPongs_1) {
1930
- _this._workerDispatcherManager.disconnectWorker(ws['id_worker']);
1931
- ws.close();
1932
- return;
1933
- }
1934
- missedPongs_1 += 1;
1935
- _this._workerDispatcherManager.sendWorkerPayload(ws, 'ping');
1936
- }, heartbeatIntervalMs);
1937
- ws.on('message', function (message) {
1938
- lastComm_1 = new Date();
1939
- if (typeof message === 'string') {
1940
- if (message === 'ping') {
1941
- _this._workerDispatcherManager.sendWorkerPayload(ws, 'pong');
1942
- }
1943
- else if (message === 'pong') {
1944
- missedPongs_1 = 0;
1945
- }
1946
- else {
1947
- _this._workerDispatcherManager.handleWorkerMessage(ws['id_worker'], message);
1948
- }
1949
- return;
1950
- }
1951
- var buffer;
1952
- if (Buffer.isBuffer(message)) {
1953
- buffer = message;
1954
- }
1955
- else if (Array.isArray(message)) {
1956
- var chunks = message;
1957
- buffer = Buffer.concat(chunks);
1958
- }
1959
- else if (message instanceof ArrayBuffer) {
1960
- buffer = Buffer.from(message);
1961
- }
1962
- else if (ArrayBuffer.isView(message)) {
1963
- var view = message;
1964
- buffer = Buffer.from(view.buffer, view.byteOffset, view.byteLength);
1965
- }
1966
- else {
1967
- buffer = Buffer.from(message);
1968
- }
1969
- if (buffer.length === 4) {
1970
- var heartbeat = buffer.toString('utf8');
1971
- if (heartbeat === 'ping') {
1972
- _this._workerDispatcherManager.sendWorkerPayload(ws, 'pong');
1973
- return;
1974
- }
1975
- else if (heartbeat === 'pong') {
1976
- missedPongs_1 = 0;
1977
- return;
1978
- }
1979
- }
1980
- _this._workerDispatcherManager.handleWorkerMessage(ws['id_worker'], buffer);
1981
- });
1982
- ws.on('close', function () {
1983
- _this._workerDispatcherManager.disconnectWorker(ws['id_worker']);
1984
- console.log(new Date(), 'Worker disconnected:', workerId_1);
1985
- if (interval_1) {
1986
- clearInterval(interval_1);
1987
- }
1988
- });
1989
- ws.on('error', function (error) {
1990
- _this._workerDispatcherManager.disconnectWorker(ws['id_worker']);
1991
- console.error('Error on WS Worker', error);
1992
- ws.close();
1993
- });
1994
- return [3 /*break*/, 6];
1995
- case 1:
1996
- // Normal client
1997
- ws['id_socket'] = (0, common_1.objectIdHexString)();
1998
- ws['supportsBinary'] = true;
1999
- ws['id_user'] = req['id_user'];
2000
- ws['user'] = req['user'];
2001
- ws['user_readonly'] = req['user_readonly'];
2002
- ws['doc_user'] = req['doc_user'];
2003
- ws['client_ip'] = this.resolveClientIp(req);
2004
- socketAdmission = void 0;
2005
- _b.label = 2;
2006
- case 2:
2007
- _b.trys.push([2, 4, , 5]);
2008
- return [4 /*yield*/, this.evaluateClientSocketAdmission(ws['id_user'], req)];
2009
- case 3:
2010
- socketAdmission = _b.sent();
2011
- return [3 /*break*/, 5];
2012
- case 4:
2013
- socketPolicyError_1 = _b.sent();
2014
- this.logConnectDebug('WS socket policy evaluation failed', {
2015
- id_socket: ws['id_socket'],
2016
- id_user: ws['id_user'],
2017
- user: ws['user'],
2018
- ip: ws['client_ip'],
2019
- error: (socketPolicyError_1 === null || socketPolicyError_1 === void 0 ? void 0 : socketPolicyError_1.message) || socketPolicyError_1
2020
- });
2021
- try {
2022
- ws.close(1011, 'Socket policy error');
2023
- }
2024
- catch (_d) { }
2025
- return [2 /*return*/];
2026
- case 5:
2027
- if (!socketAdmission.allowed) {
2028
- this.logConnectDebug('WS client rejected', {
2029
- id_socket: ws['id_socket'],
2030
- id_user: ws['id_user'],
2031
- user: ws['user'],
2032
- ip: ws['client_ip'],
2033
- reason: socketAdmission.message
2034
- });
2035
- try {
2036
- ws.close(1008, this.buildSocketLimitCloseReason());
2037
- }
2038
- catch (_e) { }
2039
- return [2 /*return*/];
2040
- }
2041
- ws['client_ip'] = socketAdmission.clientIp || ws['client_ip'];
2042
- this._websocketManager.addWebSocket(ws);
2043
- this.logConnectDebug('WS client connected', {
2044
- id_socket: ws['id_socket'],
2045
- id_user: ws['id_user'],
2046
- user: ws['user'],
2047
- url: req === null || req === void 0 ? void 0 : req.url,
2048
- ip: ws['client_ip'],
2049
- origin: (_a = req === null || req === void 0 ? void 0 : req.headers) === null || _a === void 0 ? void 0 : _a.origin
2050
- });
2051
- setTimeout(function () { return __awaiter(_this, void 0, void 0, function () {
2052
- return __generator(this, function (_a) {
2053
- switch (_a.label) {
2054
- case 0: return [4 /*yield*/, this.triggerClientHeartbeat(ws)];
2055
- case 1:
2056
- _a.sent();
2057
- return [2 /*return*/];
2058
- }
2059
- });
2060
- }); }, this._clientHeartbeatInitialDelayMs);
2061
- if (this.LOGGER === 'DEBUG') {
2062
- console.log('Connection from user: ' + req['user']);
2063
- }
2064
- ws['isAlive'] = true;
2065
- ws['retryCnt'] = 0;
2066
- ws.on('pong', function () {
2067
- ws['isAlive'] = true;
2068
- ws['pongTime'] = new Date();
2069
- if (ws['pingTime']) {
2070
- ws['latency'] = moment.duration(moment(ws['pongTime']).diff(ws['pingTime'])).asMilliseconds();
2071
- _this._subscriptionManager.loggedInLatency(ws);
2072
- }
2073
- });
2074
- ws.on('message', function (message) { return __awaiter(_this, void 0, void 0, function () {
2075
- var socketData, usedBinary, bufferPayload, decodeResult, decodeResult, decodeResult, view, decodeResult, e_12, correlationId, context;
2076
- return __generator(this, function (_a) {
2077
- switch (_a.label) {
2078
- case 0:
2079
- this._debugMsgRecv += 1;
2080
- socketData = [];
2081
- usedBinary = false;
2082
- _a.label = 1;
2083
- case 1:
2084
- _a.trys.push([1, 2, , 4]);
2085
- if (typeof message === 'string') {
2086
- if (message === 'ping' || message === 'pong') {
2087
- socketData = message;
2088
- }
2089
- else {
2090
- socketData = JSON.parse(message, common_1.dateReviver);
2091
- }
2092
- }
2093
- else if (Buffer.isBuffer(message)) {
2094
- bufferPayload = message;
2095
- decodeResult = this.decodeBufferPayload(bufferPayload);
2096
- socketData = decodeResult.data;
2097
- usedBinary = decodeResult.usedBinary;
2098
- }
2099
- else if (Array.isArray(message)) {
2100
- bufferPayload = Buffer.concat(message);
2101
- decodeResult = this.decodeBufferPayload(bufferPayload);
2102
- socketData = decodeResult.data;
2103
- usedBinary = decodeResult.usedBinary;
2104
- }
2105
- else if (message instanceof ArrayBuffer) {
2106
- bufferPayload = Buffer.from(message);
2107
- decodeResult = this.decodeBufferPayload(bufferPayload);
2108
- socketData = decodeResult.data;
2109
- usedBinary = decodeResult.usedBinary;
2110
- }
2111
- else if (ArrayBuffer.isView(message)) {
2112
- view = message;
2113
- bufferPayload = Buffer.from(view.buffer, view.byteOffset, view.byteLength);
2114
- decodeResult = this.decodeBufferPayload(bufferPayload);
2115
- socketData = decodeResult.data;
2116
- usedBinary = decodeResult.usedBinary;
2117
- }
2118
- else {
2119
- throw new Error('Unsupported WebSocket message type: ' + typeof message);
2120
- }
2121
- return [3 /*break*/, 4];
2122
- case 2:
2123
- e_12 = _a.sent();
2124
- console.log('Error - WS message parse', e_12);
2125
- correlationId = (0, common_1.objectIdHexString)();
2126
- context = {
2127
- rawBinary: bufferPayload ? bufferPayload.toString('base64') : undefined,
2128
- rawMessage: typeof message === 'string' ? message : undefined,
2129
- error: e_12 instanceof Error ? { name: e_12.name, message: e_12.message, stack: e_12.stack } : e_12
2130
- };
2131
- return [4 /*yield*/, this.reportServerError('SERVER - JSON Parse Error - ' + resolveio_server_app_1.ResolveIOServer.getServerConfig()['CLIENT_NAME'], correlationId, context, { context: 'websocket-message-parse' }, 'error', e_12 instanceof Error ? e_12.stack : undefined)];
2132
- case 3:
2133
- _a.sent();
2134
- return [2 /*return*/];
2135
- case 4:
2136
- if (usedBinary) {
2137
- ws['supportsBinary'] = true;
2138
- }
2139
- // call our existing processSocketMessage
2140
- return [4 /*yield*/, this.processSocketMessage(ws, socketData)];
2141
- case 5:
2142
- // call our existing processSocketMessage
2143
- _a.sent();
2144
- return [2 /*return*/];
2145
- }
2146
- });
2147
- }); })
2148
- .on('end', function () {
2149
- ws.close();
2150
- })
2151
- .on('error', function () {
2152
- ws.close();
2153
- })
2154
- .on('close', function () { return __awaiter(_this, void 0, void 0, function () {
2155
- return __generator(this, function (_a) {
2156
- switch (_a.label) {
2157
- case 0:
2158
- this.logConnectDebug('WS client closed', {
2159
- id_socket: ws['id_socket'],
2160
- id_user: ws['id_user'],
2161
- user: ws['user']
2162
- });
2163
- return [4 /*yield*/, this.unsubscribeWS(ws)];
2164
- case 1:
2165
- _a.sent();
2166
- return [2 /*return*/];
2167
- }
2168
- });
2169
- }); });
2170
- // Do not block message handler registration on DB write; this avoids losing
2171
- // very-early subscription messages sent immediately after websocket open.
2172
- setTimeout(function () { return __awaiter(_this, void 0, void 0, function () {
2173
- var error_9;
2174
- return __generator(this, function (_a) {
2175
- switch (_a.label) {
2176
- case 0:
2177
- _a.trys.push([0, 2, , 3]);
2178
- return [4 /*yield*/, this._subscriptionManager.createLoggedInUser(ws['id_socket'])];
2179
- case 1:
2180
- _a.sent();
2181
- return [3 /*break*/, 3];
2182
- case 2:
2183
- error_9 = _a.sent();
2184
- console.error(new Date(), 'Error creating logged-in user', ws['id_socket'], error_9);
2185
- this.logConnectDebug('Create logged-in user failed', {
2186
- id_socket: ws['id_socket'],
2187
- id_user: ws['id_user'],
2188
- user: ws['user'],
2189
- error: (error_9 === null || error_9 === void 0 ? void 0 : error_9.message) || error_9
2190
- });
2191
- return [3 /*break*/, 3];
2192
- case 3: return [2 /*return*/];
2193
- }
2194
- });
2195
- }); }, 0);
2196
- _b.label = 6;
2197
- case 6: return [2 /*return*/];
2198
- }
2199
- });
2200
- }); });
2201
- // Keep alive timer
2202
- setInterval(function () { return __awaiter(_this, void 0, void 0, function () {
2203
- var _a, _b, ws, e_13_1;
2204
- var e_13, _c;
2205
- return __generator(this, function (_d) {
2206
- switch (_d.label) {
2207
- case 0:
2208
- _d.trys.push([0, 10, 11, 12]);
2209
- _a = __values(this._serverWSS.clients), _b = _a.next();
2210
- _d.label = 1;
2211
- case 1:
2212
- if (!!_b.done) return [3 /*break*/, 9];
2213
- ws = _b.value;
2214
- if (!(ws['pingTime'] && Date.now() - ws['pingTime'].getTime() >= this._clientHeartbeatIntervalMs)) return [3 /*break*/, 8];
2215
- if (this.shouldDeferHeartbeat(ws)) {
2216
- ws['isAlive'] = true;
2217
- ws['retryCnt'] = 0;
2218
- ws['pingTime'] = new Date();
2219
- return [3 /*break*/, 8];
2220
- }
2221
- if (!(ws['isAlive'] === false)) return [3 /*break*/, 6];
2222
- ws['retryCnt']++;
2223
- if (!(ws['retryCnt'] >= 3)) return [3 /*break*/, 3];
2224
- return [4 /*yield*/, this.unsubscribeWS(ws)];
2225
- case 2:
2226
- _d.sent();
2227
- return [3 /*break*/, 5];
2228
- case 3: return [4 /*yield*/, this.triggerClientHeartbeat(ws)];
2229
- case 4:
2230
- _d.sent();
2231
- _d.label = 5;
2232
- case 5: return [3 /*break*/, 8];
2233
- case 6:
2234
- ws['retryCnt'] = 0;
2235
- ws['isAlive'] = false;
2236
- return [4 /*yield*/, this.triggerClientHeartbeat(ws)];
2237
- case 7:
2238
- _d.sent();
2239
- _d.label = 8;
2240
- case 8:
2241
- _b = _a.next();
2242
- return [3 /*break*/, 1];
2243
- case 9: return [3 /*break*/, 12];
2244
- case 10:
2245
- e_13_1 = _d.sent();
2246
- e_13 = { error: e_13_1 };
2247
- return [3 /*break*/, 12];
2248
- case 11:
2249
- try {
2250
- if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
2251
- }
2252
- finally { if (e_13) throw e_13.error; }
2253
- return [7 /*endfinally*/];
2254
- case 12: return [2 /*return*/];
2255
- }
2256
- });
2257
- }); }, this._clientHeartbeatIntervalMs);
2258
- };
2259
- ResolveIOMainServer.prototype.processSocketMessage = function (ws, socketData) {
2260
- return __awaiter(this, void 0, void 0, function () {
2261
- var socketData_1, socketData_1_1, message, e_14_1;
2262
- var e_14, _a;
2263
- return __generator(this, function (_b) {
2264
- switch (_b.label) {
2265
- case 0:
2266
- if (typeof socketData === 'string' && socketData === 'ping') {
2267
- if (ws && ws.readyState === WebSocket.OPEN) {
2268
- ws.send('pong');
2269
- }
2270
- return [2 /*return*/];
2271
- }
2272
- else if (typeof socketData === 'string' && socketData === 'pong') {
2273
- ws['isAlive'] = true;
2274
- ws['pongTime'] = new Date();
2275
- ws['latency'] = moment.duration(moment(ws['pongTime']).diff(ws['pingTime'])).asMilliseconds();
2276
- this._subscriptionManager.loggedInLatency(ws);
2277
- return [2 /*return*/];
2278
- }
2279
- // If the top level is not an array, let's skip
2280
- if (!Array.isArray(socketData[0])) {
2281
- console.log('Invalid message format (expected array of arrays)', socketData);
2282
- this.logConnectDebug('Invalid message format', {
2283
- id_socket: ws ? ws['id_socket'] : null,
2284
- user: ws ? ws['user'] : null,
2285
- preview: Array.isArray(socketData) ? socketData.slice(0, 3) : socketData
2286
- });
2287
- return [2 /*return*/];
2288
- }
2289
- _b.label = 1;
2290
- case 1:
2291
- _b.trys.push([1, 6, 7, 8]);
2292
- socketData_1 = __values(socketData), socketData_1_1 = socketData_1.next();
2293
- _b.label = 2;
2294
- case 2:
2295
- if (!!socketData_1_1.done) return [3 /*break*/, 5];
2296
- message = socketData_1_1.value;
2297
- return [4 /*yield*/, this.handleClientMessage(ws, message)];
2298
- case 3:
2299
- _b.sent();
2300
- _b.label = 4;
2301
- case 4:
2302
- socketData_1_1 = socketData_1.next();
2303
- return [3 /*break*/, 2];
2304
- case 5: return [3 /*break*/, 8];
2305
- case 6:
2306
- e_14_1 = _b.sent();
2307
- e_14 = { error: e_14_1 };
2308
- return [3 /*break*/, 8];
2309
- case 7:
2310
- try {
2311
- if (socketData_1_1 && !socketData_1_1.done && (_a = socketData_1.return)) _a.call(socketData_1);
2312
- }
2313
- finally { if (e_14) throw e_14.error; }
2314
- return [7 /*endfinally*/];
2315
- case 8: return [2 /*return*/];
2316
- }
2317
- });
2318
- });
2319
- };
2320
- ResolveIOMainServer.prototype.decodeBufferPayload = function (buffer) {
2321
- var textPayload = buffer.toString('utf8');
2322
- if (this.looksLikeTextPayload(textPayload)) {
2323
- try {
2324
- return { data: this.parseTextFallback(textPayload), usedBinary: false };
2325
- }
2326
- catch (_a) {
2327
- // fall through to attempt MessagePack decode
2328
- }
2329
- }
2330
- try {
2331
- return { data: (0, msgpackr_1.unpack)(buffer), usedBinary: true };
2332
- }
2333
- catch (binaryErr) {
2334
- try {
2335
- return { data: this.parseTextFallback(textPayload), usedBinary: false };
2336
- }
2337
- catch (_b) {
2338
- throw binaryErr;
2339
- }
2340
- }
2341
- };
2342
- ResolveIOMainServer.prototype.parseTextFallback = function (rawMessage) {
2343
- if (rawMessage === 'ping' || rawMessage === 'pong') {
2344
- return rawMessage;
2345
- }
2346
- try {
2347
- return JSON.parse(rawMessage, common_1.dateReviver);
2348
- }
2349
- catch (err) {
2350
- throw err;
2351
- }
2352
- };
2353
- ResolveIOMainServer.prototype.looksLikeTextPayload = function (text) {
2354
- if (!text) {
2355
- return false;
2356
- }
2357
- var trimmed = text.trim();
2358
- if (!trimmed) {
2359
- return false;
2360
- }
2361
- var first = trimmed[0];
2362
- return first === '[' || first === '{' || first === '"' || first === 'p' || first === 'P';
2363
- };
2364
- ResolveIOMainServer.prototype.resolveConnectDebug = function () {
2365
- var _a, _b, _c;
2366
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2367
- var raw = (_c = (_b = (_a = process.env.WS_CONNECT_DEBUG) !== null && _a !== void 0 ? _a : process.env.CONNECT_DEBUG) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['WS_CONNECT_DEBUG']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['CONNECT_DEBUG'];
2368
- return this.parseDebugFlag(raw);
2369
- };
2370
- ResolveIOMainServer.prototype.resolvePerfDebug = function () {
2371
- var _a, _b, _c;
2372
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2373
- var raw = (_c = (_b = (_a = process.env.PERF_DEBUG) !== null && _a !== void 0 ? _a : process.env.CPU_DEBUG) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['PERF_DEBUG']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['CPU_DEBUG'];
2374
- return this.parseDebugFlag(raw);
2375
- };
2376
- ResolveIOMainServer.prototype.resolveCpuProfileOnStart = function () {
2377
- var _a, _b, _c;
2378
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2379
- var raw = (_c = (_b = (_a = process.env.CPU_PROFILE_ON_START) !== null && _a !== void 0 ? _a : process.env.CPU_PROFILE_START) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['CPU_PROFILE_ON_START']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['CPU_PROFILE_START'];
2380
- return this.parseDebugFlag(raw);
2381
- };
2382
- ResolveIOMainServer.prototype.resolveCpuProfileAuto = function () {
2383
- var _a;
2384
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2385
- var raw = (_a = process.env.CPU_PROFILE_AUTO) !== null && _a !== void 0 ? _a : config === null || config === void 0 ? void 0 : config['CPU_PROFILE_AUTO'];
2386
- return this.parseDebugFlag(raw);
2387
- };
2388
- ResolveIOMainServer.prototype.resolveCpuProfileDurationMs = function () {
2389
- var _a, _b, _c;
2390
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2391
- var raw = (_c = (_b = (_a = process.env.CPU_PROFILE_DURATION_MS) !== null && _a !== void 0 ? _a : process.env.PERF_PROFILE_DURATION_MS) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['CPU_PROFILE_DURATION_MS']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['PERF_PROFILE_DURATION_MS'];
2392
- return this.parsePositiveInt(raw, this._cpuProfileDurationMs);
2393
- };
2394
- ResolveIOMainServer.prototype.resolveCpuProfileThresholdPct = function () {
2395
- var _a, _b, _c;
2396
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2397
- var raw = (_c = (_b = (_a = process.env.CPU_PROFILE_THRESHOLD_PCT) !== null && _a !== void 0 ? _a : process.env.PERF_PROFILE_THRESHOLD_PCT) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['CPU_PROFILE_THRESHOLD_PCT']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['PERF_PROFILE_THRESHOLD_PCT'];
2398
- return this.parsePositiveFloat(raw, this._cpuProfileThresholdPct);
2399
- };
2400
- ResolveIOMainServer.prototype.resolveCpuProfileTriggerCount = function () {
2401
- var _a;
2402
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2403
- var raw = (_a = process.env.CPU_PROFILE_TRIGGER_COUNT) !== null && _a !== void 0 ? _a : config === null || config === void 0 ? void 0 : config['CPU_PROFILE_TRIGGER_COUNT'];
2404
- return this.parsePositiveInt(raw, this._cpuProfileTriggerCount);
2405
- };
2406
- ResolveIOMainServer.prototype.resolveCpuProfileDir = function () {
2407
- var _a;
2408
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2409
- var raw = (_a = process.env.CPU_PROFILE_DIR) !== null && _a !== void 0 ? _a : config === null || config === void 0 ? void 0 : config['CPU_PROFILE_DIR'];
2410
- return typeof raw === 'string' && raw.trim() ? raw.trim() : null;
2411
- };
2412
- ResolveIOMainServer.prototype.resolveTimerDebug = function () {
2413
- var _a;
2414
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2415
- var raw = (_a = process.env.TIMER_DEBUG) !== null && _a !== void 0 ? _a : config === null || config === void 0 ? void 0 : config['TIMER_DEBUG'];
2416
- return this.parseDebugFlag(raw);
2417
- };
2418
- ResolveIOMainServer.prototype.resolveTimerDebugThresholdMs = function () {
2419
- var _a;
2420
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2421
- var raw = (_a = process.env.TIMER_DEBUG_THRESHOLD_MS) !== null && _a !== void 0 ? _a : config === null || config === void 0 ? void 0 : config['TIMER_DEBUG_THRESHOLD_MS'];
2422
- return this.parsePositiveFloat(raw, this._timerDebugThresholdMs);
2423
- };
2424
- ResolveIOMainServer.prototype.resolveTimerDebugMinDelayMs = function () {
2425
- var _a;
2426
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2427
- var raw = (_a = process.env.TIMER_DEBUG_MIN_DELAY_MS) !== null && _a !== void 0 ? _a : config === null || config === void 0 ? void 0 : config['TIMER_DEBUG_MIN_DELAY_MS'];
2428
- return this.parsePositiveFloat(raw, this._timerDebugMinDelayMs);
2429
- };
2430
- ResolveIOMainServer.prototype.resolveTimerDebugSampleRate = function () {
2431
- var _a;
2432
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2433
- var raw = (_a = process.env.TIMER_DEBUG_SAMPLE_RATE) !== null && _a !== void 0 ? _a : config === null || config === void 0 ? void 0 : config['TIMER_DEBUG_SAMPLE_RATE'];
2434
- var parsed = parseFloat(raw !== null && raw !== void 0 ? raw : '');
2435
- if (Number.isFinite(parsed) && parsed > 0 && parsed <= 1) {
2436
- return parsed;
2437
- }
2438
- return this._timerDebugSampleRate;
2439
- };
2440
- ResolveIOMainServer.prototype.resolveTimerDebugLogLimit = function () {
2441
- var _a;
2442
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2443
- var raw = (_a = process.env.TIMER_DEBUG_LOG_LIMIT) !== null && _a !== void 0 ? _a : config === null || config === void 0 ? void 0 : config['TIMER_DEBUG_LOG_LIMIT'];
2444
- return this.parsePositiveInt(raw, this._timerDebugLogLimit);
2445
- };
2446
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperEnabled = function () {
2447
- var _a, _b, _c;
2448
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2449
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_ENABLED) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_ENABLED) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_ENABLED']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_ENABLED'];
2450
- var configured = this.parseOptionalBoolean(raw);
2451
- if (configured !== null) {
2452
- return configured;
2453
- }
2454
- return this.isPm2ManagedRuntime() && !this.isLocalRuntime();
2455
- };
2456
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperIntervalMs = function () {
2457
- var _a, _b, _c;
2458
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2459
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_INTERVAL_MS) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_INTERVAL_MS) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_INTERVAL_MS']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_INTERVAL_MS'];
2460
- return this.parsePositiveInt(raw, this._standaloneNodeReaperIntervalMs);
2461
- };
2462
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperMinAgeSeconds = function () {
2463
- var _a, _b, _c;
2464
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2465
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_MIN_AGE_SECONDS) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_MIN_AGE_SECONDS) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_MIN_AGE_SECONDS']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_MIN_AGE_SECONDS'];
2466
- return this.parsePositiveInt(raw, this._standaloneNodeReaperMinAgeSeconds);
2467
- };
2468
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperMaxKillsPerSignature = function () {
2469
- var _a, _b, _c;
2470
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2471
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_MAX_KILLS_PER_SIGNATURE) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_MAX_KILLS_PER_SIGNATURE) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_MAX_KILLS_PER_SIGNATURE']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_MAX_KILLS_PER_SIGNATURE'];
2472
- return this.parsePositiveInt(raw, this._standaloneNodeReaperMaxKillsPerSignature);
2473
- };
2474
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperKillWindowMs = function () {
2475
- var _a, _b, _c;
2476
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2477
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_KILL_WINDOW_MS) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_KILL_WINDOW_MS) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_KILL_WINDOW_MS']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_KILL_WINDOW_MS'];
2478
- return this.parsePositiveInt(raw, this._standaloneNodeReaperKillWindowMs);
2479
- };
2480
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperIncludeSystemdServices = function () {
2481
- var _a, _b, _c;
2482
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2483
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_INCLUDE_SYSTEMD_SERVICES) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_INCLUDE_SYSTEMD_SERVICES) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_INCLUDE_SYSTEMD_SERVICES']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_INCLUDE_SYSTEMD_SERVICES'];
2484
- return this.parseDebugFlag(raw);
2485
- };
2486
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperHighCpuPct = function () {
2487
- var _a, _b, _c;
2488
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2489
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_HIGH_CPU_PCT) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_HIGH_CPU_PCT) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_HIGH_CPU_PCT']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_HIGH_CPU_PCT'];
2490
- return this.parsePositiveFloat(raw, this._standaloneNodeReaperHighCpuPct);
2491
- };
2492
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperHighRssMb = function () {
2493
- var _a, _b, _c;
2494
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2495
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_HIGH_RSS_MB) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_HIGH_RSS_MB) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_HIGH_RSS_MB']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_HIGH_RSS_MB'];
2496
- return this.parsePositiveFloat(raw, this._standaloneNodeReaperHighRssMb);
2497
- };
2498
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperHighMinAgeSeconds = function () {
2499
- var _a, _b, _c;
2500
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2501
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_HIGH_MIN_AGE_SECONDS) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_HIGH_MIN_AGE_SECONDS) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_HIGH_MIN_AGE_SECONDS']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_HIGH_MIN_AGE_SECONDS'];
2502
- return this.parsePositiveInt(raw, this._standaloneNodeReaperHighMinAgeSeconds);
2503
- };
2504
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperHighConsecutiveScans = function () {
2505
- var _a, _b, _c;
2506
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2507
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_HIGH_CONSECUTIVE_SCANS) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_HIGH_CONSECUTIVE_SCANS) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_HIGH_CONSECUTIVE_SCANS']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_HIGH_CONSECUTIVE_SCANS'];
2508
- return this.parsePositiveInt(raw, this._standaloneNodeReaperHighConsecutiveScans);
2509
- };
2510
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperDryRun = function () {
2511
- var _a, _b, _c;
2512
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2513
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_DRY_RUN) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_DRY_RUN) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_DRY_RUN']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_DRY_RUN'];
2514
- return this.parseDebugFlag(raw);
2515
- };
2516
- ResolveIOMainServer.prototype.resolveStandaloneNodeReaperAlertWindowMs = function () {
2517
- var _a, _b, _c;
2518
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2519
- var raw = (_c = (_b = (_a = process.env.RESOLVEIO_STANDALONE_NODE_REAPER_ALERT_WINDOW_MS) !== null && _a !== void 0 ? _a : process.env.STANDALONE_NODE_REAPER_ALERT_WINDOW_MS) !== null && _b !== void 0 ? _b : config === null || config === void 0 ? void 0 : config['RESOLVEIO_STANDALONE_NODE_REAPER_ALERT_WINDOW_MS']) !== null && _c !== void 0 ? _c : config === null || config === void 0 ? void 0 : config['STANDALONE_NODE_REAPER_ALERT_WINDOW_MS'];
2520
- return this.parsePositiveInt(raw, this._standaloneNodeReaperAlertWindowMs);
2521
- };
2522
- ResolveIOMainServer.prototype.isPm2ManagedRuntime = function () {
2523
- return Boolean(process.env.pm_id
2524
- || process.env.PM2_HOME
2525
- || process.env.NODE_APP_INSTANCE
2526
- || "".concat(process.env._ || '').includes('pm2'));
2527
- };
2528
- ResolveIOMainServer.prototype.isPrimaryPm2Instance = function () {
2529
- var appInstance = this.normalizeWorkerSelectorValue(process.env.NODE_APP_INSTANCE);
2530
- return !appInstance || appInstance === '0';
2531
- };
2532
- ResolveIOMainServer.prototype.isLocalRuntime = function () {
2533
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig ? resolveio_server_app_1.ResolveIOServer.getServerConfig() : null;
2534
- var rootUrl = "".concat(process.env.ROOT_URL || (config === null || config === void 0 ? void 0 : config['ROOT_URL']) || '').trim().toLowerCase();
2535
- var serverUrl = "".concat(process.env.SERVER_URL || (config === null || config === void 0 ? void 0 : config['SERVER_URL']) || '').trim().toLowerCase();
2536
- return rootUrl.includes('localhost') || rootUrl.includes('127.0.0.1') || serverUrl.includes('localhost') || serverUrl.includes('127.0.0.1');
2537
- };
2538
- ResolveIOMainServer.prototype.normalizeWorkerSelectorValue = function (value) {
2539
- if (value === null || value === undefined) {
2540
- return null;
2541
- }
2542
- var normalized = String(value).trim();
2543
- return normalized.length ? normalized : null;
2544
- };
2545
- ResolveIOMainServer.prototype.shouldStartCronManagerForWorker = function () {
2546
- var workerIndex = this.normalizeWorkerSelectorValue(process.env.WORKER_INDEX);
2547
- var workerInstance = this.normalizeWorkerSelectorValue(process.env.NODE_APP_INSTANCE) || '0';
2548
- var hasExplicitServerManagerOwner = process.env.SERVER_MANAGER_WORKER_INDEX !== undefined
2549
- || process.env.SERVER_MANAGER_WORKER_INSTANCE !== undefined
2550
- || process.env.SERVER_MANAGER_NODE_APP_INSTANCE !== undefined;
2551
- if (!hasExplicitServerManagerOwner) {
2552
- return workerIndex === '0';
2553
- }
2554
- var serverManagerWorkerIndex = this.normalizeWorkerSelectorValue(process.env.SERVER_MANAGER_WORKER_INDEX) || '0';
2555
- var serverManagerWorkerInstance = this.normalizeWorkerSelectorValue(process.env.SERVER_MANAGER_WORKER_INSTANCE || process.env.SERVER_MANAGER_NODE_APP_INSTANCE) || '0';
2556
- return workerIndex === serverManagerWorkerIndex && workerInstance === serverManagerWorkerInstance;
2557
- };
2558
- ResolveIOMainServer.prototype.parseWorkerSelector = function (value) {
2559
- if (value === null || value === undefined) {
2560
- return null;
2561
- }
2562
- var raw = Array.isArray(value) ? value.join(',') : String(value);
2563
- var parts = raw.split(',').map(function (part) { return part.trim(); }).filter(Boolean);
2564
- if (!parts.length) {
2565
- return null;
2566
- }
2567
- return new Set(parts);
2568
- };
2569
- ResolveIOMainServer.prototype.workerMatchesSelector = function (workerIndex, workerInstance, indexes, instances) {
2570
- if (!indexes && !instances) {
2571
- return false;
2572
- }
2573
- var indexMatch = indexes ? (workerIndex ? indexes.has(workerIndex) : false) : true;
2574
- var instanceMatch = instances ? (workerInstance ? instances.has(workerInstance) : false) : true;
2575
- return indexMatch && instanceMatch;
2576
- };
2577
- ResolveIOMainServer.prototype.resolveWorkerRole = function () {
2578
- var workerIndex = this.normalizeWorkerSelectorValue(process.env.WORKER_INDEX);
2579
- var workerInstance = this.normalizeWorkerSelectorValue(process.env.NODE_APP_INSTANCE);
2580
- var publicationIndexes = this.parseWorkerSelector(process.env.PUBLICATION_WORKER_INDEX
2581
- || process.env.SUBSCRIPTION_WORKER_INDEX
2582
- || process.env.WORKER_PUBLICATION_INDEX);
2583
- var publicationInstances = this.parseWorkerSelector(process.env.PUBLICATION_WORKER_INSTANCE
2584
- || process.env.SUBSCRIPTION_WORKER_INSTANCE
2585
- || process.env.WORKER_PUBLICATION_INSTANCE);
2586
- var codexIndexes = this.parseWorkerSelector(process.env.AI_ASSISTANT_CODEX_WORKER_INDEX
2587
- || process.env.CODEX_WORKER_INDEX
2588
- || process.env.WORKER_CODEX_INDEX);
2589
- var codexInstances = this.parseWorkerSelector(process.env.AI_ASSISTANT_CODEX_WORKER_INSTANCE
2590
- || process.env.CODEX_WORKER_INSTANCE
2591
- || process.env.WORKER_CODEX_INSTANCE);
2592
- if (this.workerMatchesSelector(workerIndex, workerInstance, publicationIndexes, publicationInstances)) {
2593
- return 'Subscription';
2594
- }
2595
- if (this.workerMatchesSelector(workerIndex, workerInstance, codexIndexes, codexInstances)) {
2596
- return 'Codex';
2597
- }
2598
- return 'Other';
2599
- };
2600
- ResolveIOMainServer.prototype.parsePositiveInt = function (value, fallback) {
2601
- var parsed = parseInt(value !== null && value !== void 0 ? value : '', 10);
2602
- if (Number.isNaN(parsed) || parsed <= 0) {
2603
- return fallback;
2604
- }
2605
- return parsed;
2606
- };
2607
- ResolveIOMainServer.prototype.parsePositiveFloat = function (value, fallback) {
2608
- var parsed = parseFloat(value !== null && value !== void 0 ? value : '');
2609
- if (Number.isNaN(parsed) || parsed <= 0) {
2610
- return fallback;
2611
- }
2612
- return parsed;
2613
- };
2614
- ResolveIOMainServer.prototype.startPerfDebug = function () {
2615
- var _this = this;
2616
- var _a;
2617
- if (!this._perfDebug || this._perfDebugTimer) {
2618
- return;
2619
- }
2620
- this._perfDebugIntervalMs = this.parsePositiveInt((_a = process.env.PERF_DEBUG_INTERVAL_MS) !== null && _a !== void 0 ? _a : process.env.CPU_DEBUG_INTERVAL_MS, this._perfDebugIntervalMs);
2621
- this._perfDebugLastCpu = process.cpuUsage();
2622
- this._perfDebugLastTs = Date.now();
2623
- this._eventLoopHistogram = (0, perf_hooks_1.monitorEventLoopDelay)({ resolution: 20 });
2624
- this._eventLoopHistogram.enable();
2625
- this._perfDebugTimer = setInterval(function () {
2626
- var now = Date.now();
2627
- var elapsedMs = now - _this._perfDebugLastTs;
2628
- var cpuDiff = _this._perfDebugLastCpu ? process.cpuUsage(_this._perfDebugLastCpu) : process.cpuUsage();
2629
- var cpuMs = (cpuDiff.user + cpuDiff.system) / 1000;
2630
- var cpuPct = elapsedMs > 0 ? (cpuMs / elapsedMs) * 100 : 0;
2631
- var mem = process.memoryUsage();
2632
- var heapUsedMb = (0, common_1.round)((mem.heapUsed / 1024 / 1024) * 10) / 10;
2633
- var rssMb = (0, common_1.round)((mem.rss / 1024 / 1024) * 10) / 10;
2634
- var handles = typeof process._getActiveHandles === 'function'
2635
- ? process._getActiveHandles().length
2636
- : null;
2637
- var requests = typeof process._getActiveRequests === 'function'
2638
- ? process._getActiveRequests().length
2639
- : null;
2640
- var histogram = _this._eventLoopHistogram;
2641
- var eventLoop = histogram ? {
2642
- meanMs: (0, common_1.round)((histogram.mean / 1e6) * 100) / 100,
2643
- p50Ms: (0, common_1.round)((histogram.percentile(50) / 1e6) * 100) / 100,
2644
- p95Ms: (0, common_1.round)((histogram.percentile(95) / 1e6) * 100) / 100,
2645
- p99Ms: (0, common_1.round)((histogram.percentile(99) / 1e6) * 100) / 100,
2646
- maxMs: (0, common_1.round)((histogram.max / 1e6) * 100) / 100
2647
- } : null;
2648
- histogram === null || histogram === void 0 ? void 0 : histogram.reset();
2649
- console.log(new Date(), '[Perf Debug]', JSON.stringify({
2650
- cpuPct: (0, common_1.round)(cpuPct * 10) / 10,
2651
- cpuMs: (0, common_1.round)(cpuMs),
2652
- elapsedMs: elapsedMs,
2653
- eventLoop: eventLoop,
2654
- heapUsedMb: heapUsedMb,
2655
- rssMb: rssMb,
2656
- activeHandles: handles,
2657
- activeRequests: requests,
2658
- msgRecv: _this._debugMsgRecv,
2659
- msgQueue: _this._debugMsgQueue
2660
- }));
2661
- if (_this._cpuProfileAuto) {
2662
- if (cpuPct >= _this._cpuProfileThresholdPct) {
2663
- _this._cpuProfileHighCount += 1;
2664
- }
2665
- else {
2666
- _this._cpuProfileHighCount = 0;
2667
- }
2668
- if (_this._cpuProfileHighCount >= _this._cpuProfileTriggerCount) {
2669
- _this._cpuProfileHighCount = 0;
2670
- _this.startCpuProfile('auto-high-cpu');
2671
- }
2672
- }
2673
- _this._perfDebugLastCpu = process.cpuUsage();
2674
- _this._perfDebugLastTs = now;
2675
- }, this._perfDebugIntervalMs);
2676
- };
2677
- ResolveIOMainServer.prototype.installTimerDebug = function () {
2678
- var _this = this;
2679
- if (!this._timerDebug) {
2680
- return;
2681
- }
2682
- var g = global;
2683
- if (g.__resolveioTimerDebugInstalled) {
2684
- return;
2685
- }
2686
- g.__resolveioTimerDebugInstalled = true;
2687
- var originalSetTimeout = global.setTimeout;
2688
- var originalSetInterval = global.setInterval;
2689
- var thresholdMs = this._timerDebugThresholdMs;
2690
- var minDelayMs = this._timerDebugMinDelayMs;
2691
- var sampleRate = this._timerDebugSampleRate;
2692
- var shouldSample = function () { return sampleRate >= 1 || Math.random() <= sampleRate; };
2693
- var logTimer = function (type, durationMs, delayMs, createdStack) {
2694
- if (_this._timerDebugLogLimit > 0 && _this._timerDebugLogCount >= _this._timerDebugLogLimit) {
2695
- return;
2696
- }
2697
- _this._timerDebugLogCount += 1;
2698
- var stackLines = createdStack
2699
- ? createdStack.split('\n').slice(1, 6).map(function (line) { return line.trim(); }).join(' | ')
2700
- : undefined;
2701
- console.log(new Date(), '[Timer Debug]', JSON.stringify({
2702
- type: type,
2703
- durationMs: (0, common_1.round)(durationMs * 10) / 10,
2704
- delayMs: delayMs !== null && delayMs !== void 0 ? delayMs : null,
2705
- createdAt: stackLines
2706
- }));
2707
- };
2708
- var wrapTimer = function (handler, type, delayMs) {
2709
- if (typeof handler !== 'function') {
2710
- return handler;
2711
- }
2712
- var createdStack = new Error().stack;
2713
- var shouldFlagShortDelay = typeof delayMs === 'number' && delayMs <= minDelayMs;
2714
- return function wrappedTimer() {
2715
- var args = [];
2716
- for (var _i = 0; _i < arguments.length; _i++) {
2717
- args[_i] = arguments[_i];
2718
- }
2719
- var start = process.hrtime.bigint();
2720
- try {
2721
- return handler.apply(this, args);
2722
- }
2723
- finally {
2724
- var elapsedMs = Number(process.hrtime.bigint() - start) / 1e6;
2725
- if (shouldSample() && (elapsedMs >= thresholdMs || shouldFlagShortDelay)) {
2726
- logTimer(type, elapsedMs, delayMs, createdStack);
2727
- }
2728
- }
2729
- };
2730
- };
2731
- global.setTimeout = (function (handler, timeout) {
2732
- var args = [];
2733
- for (var _i = 2; _i < arguments.length; _i++) {
2734
- args[_i - 2] = arguments[_i];
2735
- }
2736
- return originalSetTimeout.apply(void 0, __spreadArray([wrapTimer(handler, 'setTimeout', timeout), timeout], __read(args), false));
2737
- });
2738
- global.setInterval = (function (handler, timeout) {
2739
- var args = [];
2740
- for (var _i = 2; _i < arguments.length; _i++) {
2741
- args[_i - 2] = arguments[_i];
2742
- }
2743
- return originalSetInterval.apply(void 0, __spreadArray([wrapTimer(handler, 'setInterval', timeout), timeout], __read(args), false));
2744
- });
2745
- };
2746
- ResolveIOMainServer.prototype.startCpuProfile = function (trigger) {
2747
- var _this = this;
2748
- if (this._cpuProfileSession) {
2749
- return;
2750
- }
2751
- try {
2752
- var session_1 = new inspector.Session();
2753
- session_1.connect();
2754
- session_1.post('Profiler.enable', function () {
2755
- session_1.post('Profiler.start', function () {
2756
- _this._cpuProfileSession = session_1;
2757
- console.log(new Date(), '[Perf Debug]', 'CPU profile started', trigger);
2758
- setTimeout(function () {
2759
- _this.stopCpuProfile(trigger);
2760
- }, _this._cpuProfileDurationMs);
2761
- });
2762
- });
2763
- }
2764
- catch (error) {
2765
- console.error(new Date(), '[Perf Debug]', 'CPU profile start failed', error);
2766
- }
2767
- };
2768
- ResolveIOMainServer.prototype.stopCpuProfile = function (trigger) {
2769
- var _this = this;
2770
- var session = this._cpuProfileSession;
2771
- if (!session) {
2772
- return;
2773
- }
2774
- session.post('Profiler.stop', function (err, res) {
2775
- var _a;
2776
- if (err) {
2777
- console.error(new Date(), '[Perf Debug]', 'CPU profile stop failed', err);
2778
- }
2779
- else {
2780
- try {
2781
- var dir = _this.resolveWritableProfileDir();
2782
- var filename = "resolveio-cpuprofile-".concat(process.pid, "-").concat(Date.now(), ".cpuprofile");
2783
- var filePath = path.join(dir, filename);
2784
- fs.writeFileSync(filePath, JSON.stringify((_a = res === null || res === void 0 ? void 0 : res.profile) !== null && _a !== void 0 ? _a : {}));
2785
- console.log(new Date(), '[Perf Debug]', 'CPU profile saved', filePath, trigger);
2786
- }
2787
- catch (writeErr) {
2788
- console.error(new Date(), '[Perf Debug]', 'CPU profile write failed', writeErr);
2789
- }
2790
- }
2791
- try {
2792
- session.disconnect();
2793
- }
2794
- catch (_b) { }
2795
- _this._cpuProfileSession = null;
2796
- });
2797
- };
2798
- ResolveIOMainServer.prototype.resolveWritableProfileDir = function () {
2799
- var preferred = this._cpuProfileDir;
2800
- if (preferred) {
2801
- try {
2802
- fs.mkdirSync(preferred, { recursive: true });
2803
- return preferred;
2804
- }
2805
- catch (_a) { }
2806
- }
2807
- return os.tmpdir();
2808
- };
2809
- ResolveIOMainServer.prototype.parseDebugFlag = function (value) {
2810
- if (value === true) {
2811
- return true;
2812
- }
2813
- if (value === false || value === null || value === undefined) {
2814
- return false;
2815
- }
2816
- if (typeof value === 'number') {
2817
- return value === 1;
2818
- }
2819
- if (typeof value === 'string') {
2820
- var normalized = value.trim().toLowerCase();
2821
- return ['1', 'true', 'yes', 'y', 'on'].includes(normalized);
2822
- }
2823
- return false;
2824
- };
2825
- ResolveIOMainServer.prototype.parseOptionalBoolean = function (value) {
2826
- if (value === null || value === undefined) {
2827
- return null;
2828
- }
2829
- var normalized = "".concat(value).trim();
2830
- if (!normalized) {
2831
- return null;
2832
- }
2833
- return this.parseDebugFlag(normalized);
2834
- };
2835
- ResolveIOMainServer.prototype.parseNonNegativeInt = function (value, fallback) {
2836
- var parsed = parseInt("".concat(value !== null && value !== void 0 ? value : ''), 10);
2837
- if (Number.isNaN(parsed) || parsed < 0) {
2838
- return fallback;
2839
- }
2840
- return parsed;
2841
- };
2842
- ResolveIOMainServer.prototype.resolveSocketTier = function () {
2843
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig() || {};
2844
- return "".concat(process.env.AI_CODER_PLAN_TIER || config['AI_CODER_PLAN_TIER'] || '').trim().toLowerCase();
2845
- };
2846
- ResolveIOMainServer.prototype.resolveSocketTierKeySuffix = function (planTier) {
2847
- return "".concat(planTier || '')
2848
- .trim()
2849
- .toUpperCase()
2850
- .replace(/[^A-Z0-9]+/g, '_');
2851
- };
2852
- ResolveIOMainServer.prototype.resolveMaxClientSockets = function (planTier) {
2853
- var _a, _b, _c;
2854
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig() || {};
2855
- var explicitLimit = this.parseNonNegativeInt((_a = config['AI_CODER_MAX_SOCKETS']) !== null && _a !== void 0 ? _a : process.env.AI_CODER_MAX_SOCKETS, -1);
2856
- if (explicitLimit >= 0) {
2857
- return explicitLimit;
2858
- }
2859
- var normalizedTier = "".concat(planTier || '').trim().toLowerCase();
2860
- var tierKeySuffix = this.resolveSocketTierKeySuffix(normalizedTier);
2861
- if (tierKeySuffix) {
2862
- var tierLimitKey = "AI_CODER_MAX_SOCKETS_".concat(tierKeySuffix);
2863
- var tierLimit = this.parseNonNegativeInt((_b = config[tierLimitKey]) !== null && _b !== void 0 ? _b : process.env[tierLimitKey], -1);
2864
- if (tierLimit >= 0) {
2865
- return tierLimit;
2866
- }
2867
- }
2868
- var maxUsers = this.parseNonNegativeInt((_c = config['AI_CODER_MAX_USERS']) !== null && _c !== void 0 ? _c : process.env.AI_CODER_MAX_USERS, -1);
2869
- if (maxUsers > 0) {
2870
- return maxUsers === 1 ? 1 : maxUsers * 2;
2871
- }
2872
- if (normalizedTier === 'tool') {
2873
- return 1;
2874
- }
2875
- if (normalizedTier === 'small') {
2876
- return 10;
2877
- }
2878
- if (normalizedTier === 'medium') {
2879
- return 50;
2880
- }
2881
- if (normalizedTier === 'large') {
2882
- return 200;
2883
- }
2884
- if (normalizedTier === 'enterprise') {
2885
- return 0;
2886
- }
2887
- return 0;
2888
- };
2889
- ResolveIOMainServer.prototype.resolveSingleIpPerUserPolicy = function (planTier) {
2890
- var _a, _b;
2891
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig() || {};
2892
- var normalizedTier = "".concat(planTier || '').trim().toLowerCase();
2893
- var tierKeySuffix = this.resolveSocketTierKeySuffix(normalizedTier);
2894
- if (tierKeySuffix) {
2895
- var tierPolicyKey = "AI_CODER_SINGLE_IP_PER_USER_".concat(tierKeySuffix);
2896
- var tierPolicy = this.parseOptionalBoolean((_a = config[tierPolicyKey]) !== null && _a !== void 0 ? _a : process.env[tierPolicyKey]);
2897
- if (tierPolicy !== null) {
2898
- return tierPolicy;
2899
- }
2900
- }
2901
- var policy = this.parseOptionalBoolean((_b = config['AI_CODER_SINGLE_IP_PER_USER']) !== null && _b !== void 0 ? _b : process.env.AI_CODER_SINGLE_IP_PER_USER);
2902
- if (policy !== null) {
2903
- return policy;
2904
- }
2905
- return !!normalizedTier;
2906
- };
2907
- ResolveIOMainServer.prototype.resolveSocketPolicyUpgradeUrl = function () {
2908
- var config = resolveio_server_app_1.ResolveIOServer.getServerConfig() || {};
2909
- var direct = "".concat(config['AI_CODER_SOCKET_UPGRADE_URL'] || process.env.AI_CODER_SOCKET_UPGRADE_URL || '').trim();
2910
- if (direct) {
2911
- return direct.replace(/\/$/, '');
2912
- }
2913
- var dashboard = "".concat(config['AI_CODER_CLIENT_DASHBOARD_URL'] || process.env.AI_CODER_CLIENT_DASHBOARD_URL || '').trim();
2914
- if (dashboard) {
2915
- return dashboard.replace(/\/$/, '');
2916
- }
2917
- var root = "".concat(config['AI_CODER_ROOT_URL'] || process.env.AI_CODER_ROOT_URL || config['ROOT_URL'] || process.env.ROOT_URL || '').trim();
2918
- if (!root) {
2919
- return '';
2920
- }
2921
- return "".concat(root.replace(/\/$/, ''), "/dashboard/client");
2922
- };
2923
- ResolveIOMainServer.prototype.resolveSocketUpgradeUrlWithAppId = function () {
2924
- var base = "".concat(this._socketPolicyUpgradeUrl || '').trim();
2925
- if (!base) {
2926
- return '';
2927
- }
2928
- var appId = "".concat(process.env.AI_CODER_APP_ID || '').trim();
2929
- if (!appId) {
2930
- return base;
2931
- }
2932
- var separator = base.includes('?') ? '&' : '?';
2933
- return "".concat(base).concat(separator, "appId=").concat(encodeURIComponent(appId));
2934
- };
2935
- ResolveIOMainServer.prototype.normalizeIpAddress = function (value) {
2936
- var ip = "".concat(value || '').trim();
2937
- if (!ip) {
2938
- return '';
2939
- }
2940
- if (ip.includes(',')) {
2941
- ip = ip.split(',')[0].trim();
2942
- }
2943
- if (ip.startsWith('::ffff:')) {
2944
- ip = ip.slice(7);
2945
- }
2946
- if (/^\d+\.\d+\.\d+\.\d+:\d+$/.test(ip)) {
2947
- ip = ip.split(':')[0].trim();
2948
- }
2949
- if (ip === '::1') {
2950
- return '127.0.0.1';
2951
- }
2952
- return ip.toLowerCase();
2953
- };
2954
- ResolveIOMainServer.prototype.resolveClientIp = function (req) {
2955
- var _a, _b, _c, _d;
2956
- var forwardedFor = this.normalizeHeaderValue((_a = req === null || req === void 0 ? void 0 : req.headers) === null || _a === void 0 ? void 0 : _a['x-forwarded-for']);
2957
- if (forwardedFor) {
2958
- return this.normalizeIpAddress(forwardedFor);
2959
- }
2960
- var realIp = this.normalizeHeaderValue((_b = req === null || req === void 0 ? void 0 : req.headers) === null || _b === void 0 ? void 0 : _b['x-real-ip']);
2961
- if (realIp) {
2962
- return this.normalizeIpAddress(realIp);
2963
- }
2964
- var socketIp = ((_c = req === null || req === void 0 ? void 0 : req.socket) === null || _c === void 0 ? void 0 : _c.remoteAddress) || ((_d = req === null || req === void 0 ? void 0 : req.connection) === null || _d === void 0 ? void 0 : _d.remoteAddress) || (req === null || req === void 0 ? void 0 : req.ip) || '';
2965
- return this.normalizeIpAddress(socketIp);
2966
- };
2967
- ResolveIOMainServer.prototype.buildSocketLimitMessage = function (activeSockets) {
2968
- var tierLabel = this._socketTier ? this._socketTier[0].toUpperCase() + this._socketTier.slice(1) : 'Current';
2969
- var upgradeUrl = this.resolveSocketUpgradeUrlWithAppId();
2970
- var base = "Socket connection limit reached (".concat(activeSockets, "/").concat(this._maxClientSockets, ") for the ").concat(tierLabel, " tier.");
2971
- if (!upgradeUrl) {
2972
- return "".concat(base, " Upgrade to increase capacity.");
2973
- }
2974
- return "".concat(base, " Upgrade at ").concat(upgradeUrl, ".");
2975
- };
2976
- ResolveIOMainServer.prototype.buildSocketLimitCloseReason = function () {
2977
- return "Socket limit reached (".concat(this._maxClientSockets, ")");
2978
- };
2979
- ResolveIOMainServer.prototype.disconnectUserSocketsFromDifferentIps = function (idUser, incomingIp) {
2980
- return __awaiter(this, void 0, void 0, function () {
2981
- var normalizedUser, normalizedIncomingIp, userSockets, disconnected, userSockets_1, userSockets_1_1, existingSocket, existingIp, e_15_1;
2982
- var e_15, _a;
2983
- return __generator(this, function (_b) {
2984
- switch (_b.label) {
2985
- case 0:
2986
- if (!this._websocketManager) {
2987
- return [2 /*return*/, 0];
2988
- }
2989
- normalizedUser = "".concat(idUser || '').trim();
2990
- normalizedIncomingIp = this.normalizeIpAddress(incomingIp);
2991
- if (!normalizedUser || !normalizedIncomingIp) {
2992
- return [2 /*return*/, 0];
2993
- }
2994
- userSockets = this._websocketManager.getUserWebSockets(normalizedUser);
2995
- disconnected = 0;
2996
- _b.label = 1;
2997
- case 1:
2998
- _b.trys.push([1, 6, 7, 8]);
2999
- userSockets_1 = __values(userSockets), userSockets_1_1 = userSockets_1.next();
3000
- _b.label = 2;
3001
- case 2:
3002
- if (!!userSockets_1_1.done) return [3 /*break*/, 5];
3003
- existingSocket = userSockets_1_1.value;
3004
- existingIp = this.normalizeIpAddress(existingSocket === null || existingSocket === void 0 ? void 0 : existingSocket['client_ip']);
3005
- if (!existingIp || existingIp === normalizedIncomingIp) {
3006
- return [3 /*break*/, 4];
3007
- }
3008
- this.logConnectDebug('WS single-ip enforcement disconnect', {
3009
- id_socket: existingSocket === null || existingSocket === void 0 ? void 0 : existingSocket['id_socket'],
3010
- id_user: normalizedUser,
3011
- existingIp: existingIp,
3012
- incomingIp: normalizedIncomingIp
3013
- });
3014
- return [4 /*yield*/, this.unsubscribeWS(existingSocket)];
3015
- case 3:
3016
- _b.sent();
3017
- if (existingSocket.readyState === WebSocket.OPEN || existingSocket.readyState === WebSocket.CONNECTING) {
3018
- try {
3019
- existingSocket.close(1008, 'Signed in from another IP');
3020
- }
3021
- catch (_c) { }
3022
- }
3023
- disconnected += 1;
3024
- _b.label = 4;
3025
- case 4:
3026
- userSockets_1_1 = userSockets_1.next();
3027
- return [3 /*break*/, 2];
3028
- case 5: return [3 /*break*/, 8];
3029
- case 6:
3030
- e_15_1 = _b.sent();
3031
- e_15 = { error: e_15_1 };
3032
- return [3 /*break*/, 8];
3033
- case 7:
3034
- try {
3035
- if (userSockets_1_1 && !userSockets_1_1.done && (_a = userSockets_1.return)) _a.call(userSockets_1);
3036
- }
3037
- finally { if (e_15) throw e_15.error; }
3038
- return [7 /*endfinally*/];
3039
- case 8: return [2 /*return*/, disconnected];
3040
- }
3041
- });
3042
- });
3043
- };
3044
- ResolveIOMainServer.prototype.evaluateClientSocketAdmission = function (idUser, req) {
3045
- return __awaiter(this, void 0, void 0, function () {
3046
- var normalizedUser, clientIp, activeSockets, message;
3047
- return __generator(this, function (_a) {
3048
- switch (_a.label) {
3049
- case 0:
3050
- normalizedUser = "".concat(idUser || '').trim();
3051
- clientIp = this.resolveClientIp(req);
3052
- if (!this._singleIpPerUser) return [3 /*break*/, 2];
3053
- return [4 /*yield*/, this.disconnectUserSocketsFromDifferentIps(normalizedUser, clientIp)];
3054
- case 1:
3055
- _a.sent();
3056
- _a.label = 2;
3057
- case 2:
3058
- if (this._maxClientSockets > 0 && this._websocketManager) {
3059
- activeSockets = this._websocketManager.getActiveWebSocketCount();
3060
- if (activeSockets >= this._maxClientSockets) {
3061
- message = this.buildSocketLimitMessage(activeSockets);
3062
- this.logConnectDebug('WS socket limit blocked', {
3063
- id_user: normalizedUser,
3064
- clientIp: clientIp,
3065
- activeSockets: activeSockets,
3066
- maxClientSockets: this._maxClientSockets
3067
- });
3068
- return [2 /*return*/, {
3069
- allowed: false,
3070
- statusCode: 429,
3071
- message: message,
3072
- clientIp: clientIp
3073
- }];
3074
- }
3075
- }
3076
- return [2 /*return*/, {
3077
- allowed: true,
3078
- statusCode: 200,
3079
- message: '',
3080
- clientIp: clientIp
3081
- }];
3082
- }
3083
- });
3084
- });
3085
- };
3086
- ResolveIOMainServer.prototype.logConnectDebug = function (message, details) {
3087
- if (!this._wsConnectDebug) {
3088
- return;
3089
- }
3090
- if (details) {
3091
- console.log(new Date(), '[Connect Debug]', message, JSON.stringify(details));
3092
- }
3093
- else {
3094
- console.log(new Date(), '[Connect Debug]', message);
3095
- }
3096
- };
3097
- ResolveIOMainServer.prototype.triggerClientHeartbeat = function (ws) {
3098
- return __awaiter(this, void 0, void 0, function () {
3099
- var err_1;
3100
- var _this = this;
3101
- var _a;
3102
- return __generator(this, function (_b) {
3103
- switch (_b.label) {
3104
- case 0:
3105
- if (!ws || ws.readyState !== WebSocket.OPEN) {
3106
- return [2 /*return*/];
3107
- }
3108
- ws['pingTime'] = new Date();
3109
- _b.label = 1;
3110
- case 1:
3111
- _b.trys.push([1, 2, , 4]);
3112
- if (typeof ws.ping === 'function') {
3113
- ws.ping();
3114
- }
3115
- return [3 /*break*/, 4];
3116
- case 2:
3117
- err_1 = _b.sent();
3118
- if ((_a = this._methodManager) === null || _a === void 0 ? void 0 : _a.getEnableDebug()) {
3119
- console.log(new Date(), 'Server App', 'Error WS Ping Frame', err_1);
3120
- }
3121
- return [4 /*yield*/, this.unsubscribeWS(ws)];
3122
- case 3:
3123
- _b.sent();
3124
- return [2 /*return*/];
3125
- case 4:
3126
- ws.send('ping', function (error) { return __awaiter(_this, void 0, void 0, function () {
3127
- var _a;
3128
- return __generator(this, function (_b) {
3129
- switch (_b.label) {
3130
- case 0:
3131
- if (!error) return [3 /*break*/, 2];
3132
- if ((_a = this._methodManager) === null || _a === void 0 ? void 0 : _a.getEnableDebug()) {
3133
- console.log(new Date(), 'Server App', 'Error WS Ping');
3134
- }
3135
- return [4 /*yield*/, this.unsubscribeWS(ws)];
3136
- case 1:
3137
- _b.sent();
3138
- _b.label = 2;
3139
- case 2: return [2 /*return*/];
3140
- }
3141
- });
3142
- }); });
3143
- return [2 /*return*/];
3144
- }
3145
- });
3146
- });
3147
- };
3148
- ResolveIOMainServer.prototype.shouldDeferHeartbeat = function (ws) {
3149
- if (!ws || ws.readyState !== WebSocket.OPEN) {
3150
- return false;
3151
- }
3152
- var bufferedAmount = typeof ws.bufferedAmount === 'number' ? ws.bufferedAmount : 0;
3153
- return bufferedAmount >= this._clientHeartbeatBackpressureBytes;
3154
- };
3155
- ResolveIOMainServer.prototype.handleClientMessage = function (ws, msg) {
3156
- return __awaiter(this, void 0, void 0, function () {
3157
- var messageRoute_1, messageDate, messageId, type, subType, pub, serverRes, offlineUpdates, i, update, data, updateRoute, updateDate, updateMessageId, updateType, method, serverResMethod, err_2, dataCopy_1, date, msgId_1, msgType, methodName_1, ack, method, forceWorker, targetWorkerIndex, targetWorkerInstance, hasWorkerForMethod, isAiCodex, isExcludedFromWorker, shouldDispatchToWorker, queueSnapshot, err_3;
3158
- var _a;
3159
- var _this = this;
3160
- return __generator(this, function (_b) {
3161
- switch (_b.label) {
3162
- case 0:
3163
- _b.trys.push([0, 24, , 25]);
3164
- messageRoute_1 = msg[0];
3165
- messageDate = msg[1];
3166
- messageId = msg[2];
3167
- type = msg[3];
3168
- if (!this.publicProgram && this._clientRoutes.some(function (a) { return messageRoute_1.includes(a); }) && !ws['doc_user'].roles.groups.some(function (a) { return a.views.some(function (b) { return messageRoute_1.includes(b) || b.includes(messageRoute_1); }); }) && !ws['doc_user'].roles.super_admin) {
3169
- return [2 /*return*/];
3170
- }
3171
- if (!(type === 'subscription')) return [3 /*break*/, 4];
3172
- subType = msg[4];
3173
- pub = msg[5];
3174
- this.logConnectDebug('Subscription message', {
3175
- subType: subType,
3176
- publication: pub,
3177
- messageId: messageId,
3178
- messageRoute: messageRoute_1,
3179
- args: Math.max(0, msg.length - 6),
3180
- id_socket: ws ? ws['id_socket'] : null,
3181
- user: ws ? ws['user'] : null
3182
- });
3183
- if (!(subType === 'sub')) return [3 /*break*/, 2];
3184
- return [4 /*yield*/, this._subscriptionManager.subscribe(messageRoute_1, messageDate, ws, messageId, pub, msg.slice(6))];
3185
- case 1:
3186
- _b.sent();
3187
- return [3 /*break*/, 3];
3188
- case 2:
3189
- this._subscriptionManager.unsubscribe(messageRoute_1, messageDate, ws, messageId, pub, msg.slice(6));
3190
- _b.label = 3;
3191
- case 3: return [3 /*break*/, 23];
3192
- case 4:
3193
- if (!(!this.publicProgram && type === 'offline')) return [3 /*break*/, 16];
3194
- serverRes = {
3195
- messageId: messageId,
3196
- hasError: false,
3197
- data: 'ACK'
3198
- };
3199
- if (ws && ws.readyState === WebSocket.OPEN) {
3200
- this._websocketManager.send(ws, serverRes);
3201
- }
3202
- this._offlineUpdates.push(ws);
3203
- offlineUpdates = msg[4];
3204
- i = 0;
3205
- _b.label = 5;
3206
- case 5:
3207
- if (!(i < offlineUpdates.length)) return [3 /*break*/, 15];
3208
- update = offlineUpdates[i];
3209
- data = update.data;
3210
- updateRoute = data.shift();
3211
- updateDate = data.shift();
3212
- updateMessageId = data.shift();
3213
- updateType = data.shift();
3214
- method = data.shift();
3215
- serverResMethod = {
3216
- messageId: updateMessageId,
3217
- hasError: false,
3218
- data: 'ACK'
3219
- };
3220
- if (ws && ws.readyState === WebSocket.OPEN) {
3221
- this._websocketManager.send(ws, serverResMethod);
3222
- }
3223
- if (method === 'insertDocument' && data[0] === 'driver-gps') {
3224
- return [3 /*break*/, 14];
3225
- }
3226
- if (!shouldWriteClientRequestLog(method)) return [3 /*break*/, 8];
3227
- if (!resolveio_server_app_1.ResolveIOServer.shouldWriteLogsOffline()) return [3 /*break*/, 6];
3228
- resolveio_server_app_1.ResolveIOServer.getLocalLogManager().writeLog({
3229
- type: 'log',
3230
- data: {
3231
- _id: (0, common_1.objectIdHexString)(),
3232
- createdAt: new Date(),
3233
- type: 'client-request',
3234
- collection: '',
3235
- id_document: '',
3236
- payload: (0, common_1.getBinarySize)(JSON.stringify([data])) < 1000000 ? JSON.stringify([data], null, 2) : 'Too Big',
3237
- method: method,
3238
- id_user: ws['id_user'] || '',
3239
- user: ws['user'] || '',
3240
- messageId: messageId,
3241
- route: messageRoute_1,
3242
- instance_index: process.env.NODE_APP_INSTANCE || '0'
3243
- }
3244
- });
3245
- return [3 /*break*/, 8];
3246
- case 6: return [4 /*yield*/, log_collection_1.Logs.insertOne({
3247
- _id: (0, common_1.objectIdHexString)(),
3248
- type: 'client-request',
3249
- collection: '',
3250
- id_document: '',
3251
- payload: (0, common_1.getBinarySize)(JSON.stringify([data])) < 1000000 ? JSON.stringify([data], null, 2) : 'Too Big',
3252
- method: method,
3253
- id_user: ws['id_user'] || '',
3254
- user: ws['user'] || '',
3255
- messageId: messageId,
3256
- route: messageRoute_1,
3257
- client: 'ResolveIO',
3258
- instance: resolveio_server_app_1.ResolveIOServer.getInstanceHost(),
3259
- instance_index: process.env.NODE_APP_INSTANCE || '0'
3260
- })];
3261
- case 7:
3262
- _b.sent();
3263
- _b.label = 8;
3264
- case 8:
3265
- if (!this._methodManager._methods[method]) return [3 /*break*/, 13];
3266
- _b.label = 9;
3267
- case 9:
3268
- _b.trys.push([9, 11, , 12]);
3269
- return [4 /*yield*/, (_a = this._methodManager.callMethod).call.apply(_a, __spreadArray([Object.assign({}, this._methodManager, method_manager_1.MethodManager.prototype, { id_user: ws['id_user'], user: ws['user'], id_ws: ws['id_socket'] }), method], __read(data), false))];
3270
- case 10:
3271
- _b.sent();
3272
- return [3 /*break*/, 12];
3273
- case 11:
3274
- err_2 = _b.sent();
3275
- console.log(new Date(), 'Offline Error', JSON.stringify(err_2, null, 2));
3276
- return [3 /*break*/, 12];
3277
- case 12:
3278
- if (method === 'updateDocumentOffline' || method === 'updateDocumentPropsOffline') {
3279
- resolveio_server_app_1.ResolveIOServer.getMongoManager().invalidateQueryCache(data[0]);
3280
- }
3281
- return [3 /*break*/, 14];
3282
- case 13:
3283
- console.log('Offline - Could not find method: ' + method);
3284
- _b.label = 14;
3285
- case 14:
3286
- i++;
3287
- return [3 /*break*/, 5];
3288
- case 15:
3289
- this._offlineUpdates.splice(this._offlineUpdates.map(function (a) { return a['id_socket']; }).indexOf(ws['id_socket']), 1);
3290
- return [3 /*break*/, 23];
3291
- case 16:
3292
- dataCopy_1 = __spreadArray([], __read(msg), false);
3293
- dataCopy_1.shift();
3294
- date = dataCopy_1.shift();
3295
- msgId_1 = dataCopy_1.shift();
3296
- msgType = dataCopy_1.shift();
3297
- if (!(msgType === 'method')) return [3 /*break*/, 23];
3298
- methodName_1 = dataCopy_1.shift();
3299
- if (ws['user_readonly']) {
3300
- return [2 /*return*/];
3301
- }
3302
- if (!shouldWriteClientRequestLog(methodName_1)) return [3 /*break*/, 19];
3303
- if (!resolveio_server_app_1.ResolveIOServer.shouldWriteLogsOffline()) return [3 /*break*/, 17];
3304
- resolveio_server_app_1.ResolveIOServer.getLocalLogManager().writeLog({
3305
- type: 'log',
3306
- data: {
3307
- _id: (0, common_1.objectIdHexString)(),
3308
- createdAt: new Date(),
3309
- type: 'client-request',
3310
- collection: '',
3311
- id_document: '',
3312
- payload: (0, common_1.getBinarySize)(JSON.stringify([dataCopy_1])) < 1000000 ? JSON.stringify([dataCopy_1], null, 2) : 'Too Big',
3313
- method: methodName_1,
3314
- id_user: ws['id_user'] || '',
3315
- user: ws['user'] || '',
3316
- messageId: messageId,
3317
- route: messageRoute_1,
3318
- instance_index: process.env.NODE_APP_INSTANCE || '0'
3319
- }
3320
- });
3321
- return [3 /*break*/, 19];
3322
- case 17: return [4 /*yield*/, log_collection_1.Logs.insertOne({
3323
- _id: (0, common_1.objectIdHexString)(),
3324
- type: 'client-request',
3325
- collection: '',
3326
- id_document: '',
3327
- payload: (0, common_1.getBinarySize)(JSON.stringify([dataCopy_1])) < 1000000 ? JSON.stringify([dataCopy_1], null, 2) : 'Too Big',
3328
- method: methodName_1,
3329
- id_user: ws['id_user'] || '',
3330
- user: ws['user'] || '',
3331
- messageId: messageId,
3332
- route: messageRoute_1,
3333
- client: 'ResolveIO',
3334
- instance: resolveio_server_app_1.ResolveIOServer.getInstanceHost(),
3335
- instance_index: process.env.NODE_APP_INSTANCE || '0'
3336
- })];
3337
- case 18:
3338
- _b.sent();
3339
- _b.label = 19;
3340
- case 19:
3341
- ack = {
3342
- messageId: msgId_1,
3343
- hasError: false,
3344
- data: 'ACK'
3345
- };
3346
- if (ws && ws.readyState === WebSocket.OPEN) {
3347
- this._websocketManager.send(ws, ack);
3348
- }
3349
- method = this._methodManager.getMethod(methodName_1);
3350
- forceWorker = this._isWorkersEnabled && !!(method === null || method === void 0 ? void 0 : method.forceWorker);
3351
- targetWorkerIndex = this._isWorkersEnabled && method ? method.targetWorkerIndex : null;
3352
- targetWorkerInstance = this._isWorkersEnabled && method ? method.targetWorkerInstance : null;
3353
- hasWorkerForMethod = this._workerDispatcherManager ? this._workerDispatcherManager.hasWorkersForMethod(methodName_1) : false;
3354
- isAiCodex = methodName_1 === 'aiCoderTerminalRunCodex' || methodName_1 === 'aiCoderAppRunCodex';
3355
- isExcludedFromWorker = (methodName_1 === 'find' ||
3356
- methodName_1 === 'insertDocument' ||
3357
- methodName_1 === 'countWithQuery' ||
3358
- methodName_1 === 'findOne' ||
3359
- methodName_1 === 'updateDocumentProps' ||
3360
- methodName_1 === 'findWithOptions' ||
3361
- methodName_1 === 'updateDocument' ||
3362
- methodName_1 === 'insertErrorLog' ||
3363
- methodName_1 === 'removeDocument' ||
3364
- methodName_1 === 'supportCreateBillingUser' ||
3365
- methodName_1 === 'getSignedUrl' ||
3366
- methodName_1 === 'getSignedUrls' ||
3367
- methodName_1 === 'getSignedUrlWithId' ||
3368
- methodName_1 === 'incorrectUser' ||
3369
- methodName_1 === 'reloadWS' ||
3370
- methodName_1 === 'reconnectWS' ||
3371
- methodName_1 === 'disconnectWS');
3372
- if ((targetWorkerIndex || targetWorkerInstance || forceWorker) && this._isWorkersEnabled && !hasWorkerForMethod && this._methodManager.getEnableDebug()) {
3373
- console.warn(new Date(), '[WorkerDispatcher] Worker unavailable, running method locally', {
3374
- method: methodName_1,
3375
- targetWorkerIndex: targetWorkerIndex || null,
3376
- targetWorkerInstance: targetWorkerInstance || null,
3377
- forceWorker: forceWorker
3378
- });
3379
- }
3380
- shouldDispatchToWorker = (method &&
3381
- !method.skipWorker &&
3382
- this._isWorkersEnabled &&
3383
- this._workerDispatcherManager &&
3384
- hasWorkerForMethod &&
3385
- (forceWorker || !isExcludedFromWorker));
3386
- if (isAiCodex && this._aiWorkerDebug) {
3387
- queueSnapshot = this._workerDispatcherManager ? this._workerDispatcherManager.getQueueSnapshot() : null;
3388
- console.log(new Date(), '[AI Worker Debug] dispatch check', {
3389
- isWorkersEnabled: this._isWorkersEnabled,
3390
- isWorkerInstance: this._isWorkerInstance,
3391
- forceWorker: forceWorker,
3392
- hasWorkerForMethod: hasWorkerForMethod,
3393
- targetWorkerIndex: targetWorkerIndex || null,
3394
- targetWorkerInstance: targetWorkerInstance || null,
3395
- shouldDispatchToWorker: shouldDispatchToWorker,
3396
- queueSnapshot: queueSnapshot
3397
- });
3398
- }
3399
- if (!shouldDispatchToWorker) return [3 /*break*/, 20];
3400
- this._workerDispatcherManager.sendClientTask(msgId_1, methodName_1, dataCopy_1, {
3401
- id_user: ws['id_user'],
3402
- user: ws['user'],
3403
- id_ws: ws['id_socket']
3404
- });
3405
- return [3 /*break*/, 23];
3406
- case 20:
3407
- if (!(methodName_1 === 'aiCoderTerminalRunCodex' || methodName_1 === 'aiCoderAppRunCodex')) return [3 /*break*/, 21];
3408
- if (this._aiWorkerDebug) {
3409
- console.warn(new Date(), '[AI Worker Debug] AI execution running locally', {
3410
- isWorkersEnabled: this._isWorkersEnabled,
3411
- isWorkerInstance: this._isWorkerInstance,
3412
- targetWorkerIndex: targetWorkerIndex || null,
3413
- targetWorkerInstance: targetWorkerInstance || null,
3414
- hasWorkerForMethod: hasWorkerForMethod
3415
- });
3416
- }
3417
- setTimeout(function () { return __awaiter(_this, void 0, void 0, function () {
3418
- var error_10;
3419
- return __generator(this, function (_a) {
3420
- switch (_a.label) {
3421
- case 0:
3422
- _a.trys.push([0, 2, , 3]);
3423
- return [4 /*yield*/, this.callMethodLocally(ws, msgId_1, methodName_1, dataCopy_1)];
3424
- case 1:
3425
- _a.sent();
3426
- return [3 /*break*/, 3];
3427
- case 2:
3428
- error_10 = _a.sent();
3429
- console.error(new Date(), 'AI execution run failed:', error_10);
3430
- return [3 /*break*/, 3];
3431
- case 3: return [2 /*return*/];
3432
- }
3433
- });
3434
- }); }, 0);
3435
- return [3 /*break*/, 23];
3436
- case 21: return [4 /*yield*/, this.callMethodLocally(ws, msgId_1, methodName_1, dataCopy_1)];
3437
- case 22:
3438
- _b.sent();
3439
- _b.label = 23;
3440
- case 23: return [3 /*break*/, 25];
3441
- case 24:
3442
- err_3 = _b.sent();
3443
- throw err_3;
3444
- case 25: return [2 /*return*/];
3445
- }
3446
- });
3447
- });
3448
- };
3449
- /**
3450
- * callMethodLocally is your old approach for invoking the method in-process.
3451
- */
3452
- ResolveIOMainServer.prototype.callMethodLocally = function (ws, messageId, method, params) {
3453
- return __awaiter(this, void 0, void 0, function () {
3454
- var serverRes, result, resultBytes, err_4;
3455
- var _a;
3456
- return __generator(this, function (_b) {
3457
- switch (_b.label) {
3458
- case 0:
3459
- serverRes = {
3460
- messageId: messageId,
3461
- hasError: false,
3462
- data: null
3463
- };
3464
- _b.label = 1;
3465
- case 1:
3466
- _b.trys.push([1, 3, , 4]);
3467
- return [4 /*yield*/, (_a = this._methodManager.callMethod).call.apply(_a, __spreadArray([Object.assign({}, this._methodManager, method_manager_1.MethodManager.prototype, {
3468
- id_user: ws['id_user'],
3469
- user: ws['user'],
3470
- id_ws: ws['id_socket']
3471
- }),
3472
- method], __read(params), false))];
3473
- case 2:
3474
- result = _b.sent();
3475
- serverRes.data = result;
3476
- if (this._aiWorkerDebug && typeof method === 'string' && method.startsWith('ai')) {
3477
- resultBytes = null;
3478
- try {
3479
- resultBytes = Buffer.byteLength(JSON.stringify(result));
3480
- }
3481
- catch (_c) {
3482
- resultBytes = null;
3483
- }
3484
- console.log(new Date(), '[AI Worker Debug] local method result', {
3485
- method: method,
3486
- messageId: messageId,
3487
- id_socket: ws ? ws['id_socket'] : null,
3488
- id_user: ws ? ws['id_user'] : null,
3489
- resultBytes: resultBytes
3490
- });
3491
- }
3492
- return [3 /*break*/, 4];
3493
- case 3:
3494
- err_4 = _b.sent();
3495
- serverRes.hasError = true;
3496
- serverRes.data = err_4 || 'Unknown error';
3497
- return [3 /*break*/, 4];
3498
- case 4:
3499
- if (ws && ws.readyState === WebSocket.OPEN) {
3500
- this._websocketManager.send(ws, serverRes);
3501
- }
3502
- return [2 /*return*/];
3503
- }
3504
- });
3505
- });
3506
- };
3507
- /**
3508
- * Cleanly remove a client from the subscription manager, etc.
3509
- */
3510
- ResolveIOMainServer.prototype.unsubscribeWS = function (ws) {
3511
- return __awaiter(this, void 0, void 0, function () {
3512
- return __generator(this, function (_a) {
3513
- switch (_a.label) {
3514
- case 0:
3515
- if (this._subscriptionManager && this._methodManager.getEnableDebug()) {
3516
- console.log(new Date(), 'Server App', 'Unsub WS', ws['user'], ws['id_socket']);
3517
- }
3518
- this.logConnectDebug('WS unsubscribe', {
3519
- id_socket: ws ? ws['id_socket'] : null,
3520
- id_user: ws ? ws['id_user'] : null,
3521
- user: ws ? ws['user'] : null
3522
- });
3523
- return [4 /*yield*/, this._subscriptionManager.unsubscribeAll(ws)];
3524
- case 1:
3525
- _a.sent();
3526
- ws.removeAllListeners();
3527
- ws = null;
3528
- return [2 /*return*/];
3529
- }
3530
- });
3531
- });
3532
- };
3533
- ResolveIOMainServer.prototype.getApp = function () {
3534
- return this._app;
3535
- };
3536
- ResolveIOMainServer.prototype.getServerConfig = function () {
3537
- return resolveio_server_app_1.ResolveIOServer.getServerConfig();
3538
- };
3539
- ResolveIOMainServer.prototype.getWorkerDispatcherManager = function () {
3540
- return this._workerDispatcherManager;
3541
- };
3542
- ResolveIOMainServer.prototype.getWorkerServerManager = function () {
3543
- return this._workerServerManager;
3544
- };
3545
- return ResolveIOMainServer;
3546
- }());
3547
- exports.ResolveIOMainServer = ResolveIOMainServer;
3548
-
3549
- //# sourceMappingURL=server-app.js.map