@resolveio/server-lib 22.3.221 → 22.3.222

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (745) hide show
  1. package/ai/assistant-core-heuristics.d.ts +11 -0
  2. package/ai/assistant-core-heuristics.js +356 -0
  3. package/ai/assistant-core-heuristics.js.map +1 -0
  4. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +3 -0
  5. package/ai/resolveio-platform-intelligence-memory-corpus.js +214 -0
  6. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +1 -0
  7. package/ai/resolveio-platform-intelligence-memory.d.ts +20 -0
  8. package/ai/resolveio-platform-intelligence-memory.js +341 -0
  9. package/ai/resolveio-platform-intelligence-memory.js.map +1 -0
  10. package/{src/ai/resolveio-platform-intelligence-types.ts → ai/resolveio-platform-intelligence-types.d.ts} +15 -20
  11. package/ai/resolveio-platform-intelligence-types.js +4 -0
  12. package/ai/resolveio-platform-intelligence-types.js.map +1 -0
  13. package/ai/resolveio-platform-intelligence.d.ts +6 -0
  14. package/ai/resolveio-platform-intelligence.js +463 -0
  15. package/ai/resolveio-platform-intelligence.js.map +1 -0
  16. package/client-server-app.d.ts +1 -0
  17. package/client-server-app.js +68 -0
  18. package/client-server-app.js.map +1 -0
  19. package/collections/ai-run.collection.d.ts +3 -0
  20. package/collections/ai-run.collection.js +170 -0
  21. package/collections/ai-run.collection.js.map +1 -0
  22. package/collections/ai-terminal-conversation.collection.d.ts +2 -0
  23. package/collections/ai-terminal-conversation.collection.js +140 -0
  24. package/collections/ai-terminal-conversation.collection.js.map +1 -0
  25. package/collections/ai-terminal-issue-report.collection.d.ts +2 -0
  26. package/collections/ai-terminal-issue-report.collection.js +148 -0
  27. package/collections/ai-terminal-issue-report.collection.js.map +1 -0
  28. package/collections/ai-terminal-message.collection.d.ts +2 -0
  29. package/collections/ai-terminal-message.collection.js +121 -0
  30. package/collections/ai-terminal-message.collection.js.map +1 -0
  31. package/collections/app-setting.collection.d.ts +3 -0
  32. package/collections/app-setting.collection.js +103 -0
  33. package/collections/app-setting.collection.js.map +1 -0
  34. package/collections/app-status.collection.d.ts +3 -0
  35. package/collections/app-status.collection.js +57 -0
  36. package/collections/app-status.collection.js.map +1 -0
  37. package/collections/communication-metric.collection.d.ts +2 -0
  38. package/collections/communication-metric.collection.js +133 -0
  39. package/collections/communication-metric.collection.js.map +1 -0
  40. package/collections/counter.collection.d.ts +3 -0
  41. package/collections/counter.collection.js +56 -0
  42. package/collections/counter.collection.js.map +1 -0
  43. package/collections/cron-job-history.collection.d.ts +3 -0
  44. package/collections/cron-job-history.collection.js +137 -0
  45. package/collections/cron-job-history.collection.js.map +1 -0
  46. package/collections/cron-job.collection.d.ts +3 -0
  47. package/collections/cron-job.collection.js +92 -0
  48. package/collections/cron-job.collection.js.map +1 -0
  49. package/collections/customer-notification.collection.d.ts +3 -0
  50. package/collections/customer-notification.collection.js +130 -0
  51. package/collections/customer-notification.collection.js.map +1 -0
  52. package/collections/customer-portal-password.collection.d.ts +3 -0
  53. package/collections/customer-portal-password.collection.js +75 -0
  54. package/collections/customer-portal-password.collection.js.map +1 -0
  55. package/collections/email-history.collection.d.ts +3 -0
  56. package/collections/email-history.collection.js +134 -0
  57. package/collections/email-history.collection.js.map +1 -0
  58. package/collections/email-verified.collection.d.ts +3 -0
  59. package/collections/email-verified.collection.js +62 -0
  60. package/collections/email-verified.collection.js.map +1 -0
  61. package/collections/file.collection.d.ts +3 -0
  62. package/collections/file.collection.js +74 -0
  63. package/collections/file.collection.js.map +1 -0
  64. package/collections/flag-update.collection.d.ts +3 -0
  65. package/collections/flag-update.collection.js +57 -0
  66. package/collections/flag-update.collection.js.map +1 -0
  67. package/collections/flag.collection.d.ts +3 -0
  68. package/collections/flag.collection.js +57 -0
  69. package/collections/flag.collection.js.map +1 -0
  70. package/collections/log-method-latency.collection.d.ts +3 -0
  71. package/collections/log-method-latency.collection.js +77 -0
  72. package/collections/log-method-latency.collection.js.map +1 -0
  73. package/collections/log-subscription.collection.d.ts +3 -0
  74. package/collections/log-subscription.collection.js +80 -0
  75. package/collections/log-subscription.collection.js.map +1 -0
  76. package/collections/log.collection.d.ts +3 -0
  77. package/collections/log.collection.js +93 -0
  78. package/collections/log.collection.js.map +1 -0
  79. package/collections/logged-in-users.collection.d.ts +3 -0
  80. package/collections/logged-in-users.collection.js +67 -0
  81. package/collections/logged-in-users.collection.js.map +1 -0
  82. package/collections/monitor-cpu.collection.d.ts +3 -0
  83. package/collections/monitor-cpu.collection.js +65 -0
  84. package/collections/monitor-cpu.collection.js.map +1 -0
  85. package/collections/monitor-function.collection.d.ts +3 -0
  86. package/collections/monitor-function.collection.js +74 -0
  87. package/collections/monitor-function.collection.js.map +1 -0
  88. package/collections/monitor-memory.collection.d.ts +3 -0
  89. package/collections/monitor-memory.collection.js +77 -0
  90. package/collections/monitor-memory.collection.js.map +1 -0
  91. package/collections/monitor-mongo.collection.d.ts +3 -0
  92. package/collections/monitor-mongo.collection.js +71 -0
  93. package/collections/monitor-mongo.collection.js.map +1 -0
  94. package/collections/notification.collection.d.ts +3 -0
  95. package/collections/notification.collection.js +57 -0
  96. package/collections/notification.collection.js.map +1 -0
  97. package/collections/openai-usage-ledger.collection.d.ts +2 -0
  98. package/collections/openai-usage-ledger.collection.js +188 -0
  99. package/collections/openai-usage-ledger.collection.js.map +1 -0
  100. package/collections/report-builder-dashboard-builder.collection.d.ts +3 -0
  101. package/collections/report-builder-dashboard-builder.collection.js +109 -0
  102. package/collections/report-builder-dashboard-builder.collection.js.map +1 -0
  103. package/collections/report-builder-library.collection.d.ts +3 -0
  104. package/collections/report-builder-library.collection.js +87 -0
  105. package/collections/report-builder-library.collection.js.map +1 -0
  106. package/collections/report-builder-report.collection.d.ts +4 -0
  107. package/collections/report-builder-report.collection.js +184 -0
  108. package/collections/report-builder-report.collection.js.map +1 -0
  109. package/collections/user-group.collection.d.ts +4 -0
  110. package/collections/user-group.collection.js +89 -0
  111. package/collections/user-group.collection.js.map +1 -0
  112. package/collections/user-guide.collection.d.ts +3 -0
  113. package/collections/user-guide.collection.js +57 -0
  114. package/collections/user-guide.collection.js.map +1 -0
  115. package/collections/user.collection.d.ts +4 -0
  116. package/collections/user.collection.js +180 -0
  117. package/collections/user.collection.js.map +1 -0
  118. package/cron/cron.d.ts +14 -0
  119. package/cron/cron.js +216 -0
  120. package/cron/cron.js.map +1 -0
  121. package/fixtures/cron-jobs.d.ts +1 -0
  122. package/fixtures/cron-jobs.js +150 -0
  123. package/fixtures/cron-jobs.js.map +1 -0
  124. package/fixtures/init.d.ts +1 -0
  125. package/fixtures/init.js +91 -0
  126. package/fixtures/init.js.map +1 -0
  127. package/http/auth.d.ts +2 -0
  128. package/http/auth.js +951 -0
  129. package/http/auth.js.map +1 -0
  130. package/http/health.d.ts +1 -0
  131. package/http/health.js +11 -0
  132. package/http/health.js.map +1 -0
  133. package/http/home.d.ts +1 -0
  134. package/http/home.js +134 -0
  135. package/http/home.js.map +1 -0
  136. package/http/slow-query-publication.d.ts +2 -0
  137. package/http/slow-query-publication.js +99 -0
  138. package/http/slow-query-publication.js.map +1 -0
  139. package/index.d.ts +1 -0
  140. package/index.js +19 -0
  141. package/index.js.map +1 -0
  142. package/managers/ai-assistant-codex-manager.manager.d.ts +67 -0
  143. package/managers/ai-assistant-codex-manager.manager.js +1113 -0
  144. package/managers/ai-assistant-codex-manager.manager.js.map +1 -0
  145. package/managers/ai-run-evidence.manager.d.ts +36 -0
  146. package/managers/ai-run-evidence.manager.js +377 -0
  147. package/managers/ai-run-evidence.manager.js.map +1 -0
  148. package/managers/communication-metric.manager.d.ts +16 -0
  149. package/managers/communication-metric.manager.js +134 -0
  150. package/managers/communication-metric.manager.js.map +1 -0
  151. package/managers/cron.manager.d.ts +20 -0
  152. package/managers/cron.manager.js +534 -0
  153. package/managers/cron.manager.js.map +1 -0
  154. package/managers/customer-notification-content.manager.d.ts +55 -0
  155. package/managers/customer-notification-content.manager.js +158 -0
  156. package/managers/customer-notification-content.manager.js.map +1 -0
  157. package/managers/diagnostic-manager-bootstrap.d.ts +9 -0
  158. package/managers/diagnostic-manager-bootstrap.js +260 -0
  159. package/managers/diagnostic-manager-bootstrap.js.map +1 -0
  160. package/managers/error-auto-fix.manager.d.ts +149 -0
  161. package/managers/error-auto-fix.manager.js +3064 -0
  162. package/managers/error-auto-fix.manager.js.map +1 -0
  163. package/managers/local-log.manager.d.ts +18 -0
  164. package/managers/local-log.manager.js +88 -0
  165. package/managers/local-log.manager.js.map +1 -0
  166. package/managers/method.manager.d.ts +84 -0
  167. package/managers/method.manager.js +1964 -0
  168. package/managers/method.manager.js.map +1 -0
  169. package/managers/mongo.manager.d.ts +224 -0
  170. package/managers/mongo.manager.js +5000 -0
  171. package/managers/mongo.manager.js.map +1 -0
  172. package/managers/monitor.manager.d.ts +70 -0
  173. package/managers/monitor.manager.js +550 -0
  174. package/managers/monitor.manager.js.map +1 -0
  175. package/managers/openai-usage-ledger.manager.d.ts +30 -0
  176. package/managers/openai-usage-ledger.manager.js +142 -0
  177. package/managers/openai-usage-ledger.manager.js.map +1 -0
  178. package/managers/slow-query-verifier.manager.d.ts +144 -0
  179. package/managers/slow-query-verifier.manager.js +3857 -0
  180. package/managers/slow-query-verifier.manager.js.map +1 -0
  181. package/managers/slow-query.manager.d.ts +28 -0
  182. package/managers/slow-query.manager.js +468 -0
  183. package/managers/slow-query.manager.js.map +1 -0
  184. package/managers/subscription.manager.d.ts +169 -0
  185. package/managers/subscription.manager.js +3434 -0
  186. package/managers/subscription.manager.js.map +1 -0
  187. package/managers/websocket.manager.d.ts +73 -0
  188. package/managers/websocket.manager.js +673 -0
  189. package/managers/websocket.manager.js.map +1 -0
  190. package/managers/worker-dispatcher.manager.d.ts +120 -0
  191. package/managers/worker-dispatcher.manager.js +1266 -0
  192. package/managers/worker-dispatcher.manager.js.map +1 -0
  193. package/managers/worker-server.manager.d.ts +35 -0
  194. package/managers/worker-server.manager.js +582 -0
  195. package/managers/worker-server.manager.js.map +1 -0
  196. package/methods/accounts.d.ts +2 -0
  197. package/methods/accounts.js +624 -0
  198. package/methods/accounts.js.map +1 -0
  199. package/methods/ai-terminal.d.ts +458 -0
  200. package/methods/ai-terminal.js +27991 -0
  201. package/methods/ai-terminal.js.map +1 -0
  202. package/methods/app-settings.d.ts +2 -0
  203. package/methods/app-settings.js +169 -0
  204. package/methods/app-settings.js.map +1 -0
  205. package/methods/aws.d.ts +2 -0
  206. package/methods/aws.js +877 -0
  207. package/methods/aws.js.map +1 -0
  208. package/methods/collections.d.ts +2 -0
  209. package/methods/collections.js +719 -0
  210. package/methods/collections.js.map +1 -0
  211. package/methods/counters.d.ts +2 -0
  212. package/methods/counters.js +113 -0
  213. package/methods/counters.js.map +1 -0
  214. package/methods/cron-jobs.d.ts +2 -0
  215. package/methods/cron-jobs.js +2475 -0
  216. package/methods/cron-jobs.js.map +1 -0
  217. package/methods/customer-notifications.d.ts +2 -0
  218. package/methods/customer-notifications.js +528 -0
  219. package/methods/customer-notifications.js.map +1 -0
  220. package/methods/diagnostics.d.ts +2 -0
  221. package/methods/diagnostics.js +703 -0
  222. package/methods/diagnostics.js.map +1 -0
  223. package/methods/flag-updates.d.ts +2 -0
  224. package/methods/flag-updates.js +8 -0
  225. package/methods/flag-updates.js.map +1 -0
  226. package/methods/flags.d.ts +2 -0
  227. package/methods/flags.js +8 -0
  228. package/methods/flags.js.map +1 -0
  229. package/methods/logs.d.ts +2 -0
  230. package/methods/logs.js +751 -0
  231. package/methods/logs.js.map +1 -0
  232. package/methods/mongo-explorer.d.ts +2 -0
  233. package/methods/mongo-explorer.js +1808 -0
  234. package/methods/mongo-explorer.js.map +1 -0
  235. package/methods/monitor.d.ts +2 -0
  236. package/methods/monitor.js +543 -0
  237. package/methods/monitor.js.map +1 -0
  238. package/methods/pdf.d.ts +2 -0
  239. package/methods/pdf.js +1216 -0
  240. package/methods/pdf.js.map +1 -0
  241. package/methods/publications.d.ts +1 -0
  242. package/methods/publications.js +183 -0
  243. package/methods/publications.js.map +1 -0
  244. package/methods/report-builder.d.ts +2 -0
  245. package/methods/report-builder.js +3094 -0
  246. package/methods/report-builder.js.map +1 -0
  247. package/methods/support.d.ts +2 -0
  248. package/methods/support.js +430 -0
  249. package/methods/support.js.map +1 -0
  250. package/models/ai-run.model.d.ts +19 -0
  251. package/models/ai-run.model.js +4 -0
  252. package/models/ai-run.model.js.map +1 -0
  253. package/models/ai-terminal-conversation.model.d.ts +17 -0
  254. package/models/ai-terminal-conversation.model.js +4 -0
  255. package/models/ai-terminal-conversation.model.js.map +1 -0
  256. package/models/ai-terminal-issue-report.model.d.ts +19 -0
  257. package/models/ai-terminal-issue-report.model.js +4 -0
  258. package/models/ai-terminal-issue-report.model.js.map +1 -0
  259. package/models/ai-terminal-message.model.d.ts +22 -0
  260. package/models/ai-terminal-message.model.js +4 -0
  261. package/models/ai-terminal-message.model.js.map +1 -0
  262. package/models/app-setting.model.d.ts +16 -0
  263. package/models/app-setting.model.js +4 -0
  264. package/models/app-setting.model.js.map +1 -0
  265. package/{src/models/app-status.model.ts → models/app-status.model.d.ts} +2 -3
  266. package/models/app-status.model.js +4 -0
  267. package/models/app-status.model.js.map +1 -0
  268. package/{src/models/billing-logged-in-users.model.ts → models/billing-logged-in-users.model.d.ts} +4 -5
  269. package/models/billing-logged-in-users.model.js +4 -0
  270. package/models/billing-logged-in-users.model.js.map +1 -0
  271. package/models/collection-document.model.d.ts +21 -0
  272. package/models/collection-document.model.js +4 -0
  273. package/models/collection-document.model.js.map +1 -0
  274. package/models/communication-metric.model.d.ts +20 -0
  275. package/models/communication-metric.model.js +4 -0
  276. package/models/communication-metric.model.js.map +1 -0
  277. package/{src/models/counter.model.ts → models/counter.model.d.ts} +3 -4
  278. package/models/counter.model.js +4 -0
  279. package/models/counter.model.js.map +1 -0
  280. package/models/cron-job-history.model.d.ts +15 -0
  281. package/models/cron-job-history.model.js +4 -0
  282. package/models/cron-job-history.model.js.map +1 -0
  283. package/models/cron-job.model.d.ts +14 -0
  284. package/models/cron-job.model.js +4 -0
  285. package/models/cron-job.model.js.map +1 -0
  286. package/models/customer-notification.model.d.ts +26 -0
  287. package/models/customer-notification.model.js +4 -0
  288. package/models/customer-notification.model.js.map +1 -0
  289. package/models/customer-portal-password.model.d.ts +11 -0
  290. package/models/customer-portal-password.model.js +4 -0
  291. package/models/customer-portal-password.model.js.map +1 -0
  292. package/models/dialog.model.d.ts +23 -0
  293. package/models/dialog.model.js +4 -0
  294. package/models/dialog.model.js.map +1 -0
  295. package/models/email-history.model.d.ts +32 -0
  296. package/{src/models/email-history.model.ts → models/email-history.model.js} +4 -36
  297. package/models/email-history.model.js.map +1 -0
  298. package/{src/models/email-verified.model.ts → models/email-verified.model.d.ts} +5 -6
  299. package/models/email-verified.model.js +4 -0
  300. package/models/email-verified.model.js.map +1 -0
  301. package/{src/models/file.model.ts → models/file.model.d.ts} +7 -8
  302. package/models/file.model.js +4 -0
  303. package/models/file.model.js.map +1 -0
  304. package/{src/models/flag-update.model.ts → models/flag-update.model.d.ts} +3 -4
  305. package/models/flag-update.model.js +4 -0
  306. package/models/flag-update.model.js.map +1 -0
  307. package/{src/models/flag.model.ts → models/flag.model.d.ts} +3 -4
  308. package/models/flag.model.js +4 -0
  309. package/models/flag.model.js.map +1 -0
  310. package/models/log-method-latency.model.d.ts +10 -0
  311. package/models/log-method-latency.model.js +4 -0
  312. package/models/log-method-latency.model.js.map +1 -0
  313. package/{src/models/log-subscription.model.ts → models/log-subscription.model.d.ts} +9 -11
  314. package/models/log-subscription.model.js +4 -0
  315. package/models/log-subscription.model.js.map +1 -0
  316. package/models/log.model.d.ts +17 -0
  317. package/models/log.model.js +4 -0
  318. package/models/log.model.js.map +1 -0
  319. package/{src/models/logged-in-users.model.ts → models/logged-in-users.model.d.ts} +5 -6
  320. package/models/logged-in-users.model.js +4 -0
  321. package/models/logged-in-users.model.js.map +1 -0
  322. package/{src/models/method-response.model.ts → models/method-response.model.d.ts} +6 -7
  323. package/models/method-response.model.js +4 -0
  324. package/models/method-response.model.js.map +1 -0
  325. package/models/method.model.d.ts +26 -0
  326. package/models/method.model.js +4 -0
  327. package/models/method.model.js.map +1 -0
  328. package/{src/models/monitor-cpu.model.ts → models/monitor-cpu.model.d.ts} +7 -9
  329. package/models/monitor-cpu.model.js +4 -0
  330. package/models/monitor-cpu.model.js.map +1 -0
  331. package/models/monitor-function.model.d.ts +14 -0
  332. package/models/monitor-function.model.js +4 -0
  333. package/models/monitor-function.model.js.map +1 -0
  334. package/models/monitor-memory.model.d.ts +15 -0
  335. package/models/monitor-memory.model.js +4 -0
  336. package/models/monitor-memory.model.js.map +1 -0
  337. package/models/monitor-mongo.model.d.ts +13 -0
  338. package/models/monitor-mongo.model.js +4 -0
  339. package/models/monitor-mongo.model.js.map +1 -0
  340. package/{src/models/notification.model.ts → models/notification.model.d.ts} +4 -6
  341. package/models/notification.model.js +4 -0
  342. package/models/notification.model.js.map +1 -0
  343. package/models/openai-usage-ledger.model.d.ts +30 -0
  344. package/models/openai-usage-ledger.model.js +4 -0
  345. package/models/openai-usage-ledger.model.js.map +1 -0
  346. package/models/pagination.model.d.ts +11 -0
  347. package/models/pagination.model.js +28 -0
  348. package/models/pagination.model.js.map +1 -0
  349. package/models/permission.model.d.ts +12 -0
  350. package/models/permission.model.js +4 -0
  351. package/models/permission.model.js.map +1 -0
  352. package/models/report-builder-dashboard-builder.model.d.ts +25 -0
  353. package/models/report-builder-dashboard-builder.model.js +4 -0
  354. package/models/report-builder-dashboard-builder.model.js.map +1 -0
  355. package/models/report-builder-library.model.d.ts +17 -0
  356. package/models/report-builder-library.model.js +4 -0
  357. package/models/report-builder-library.model.js.map +1 -0
  358. package/models/report-builder-report.model.d.ts +121 -0
  359. package/models/report-builder-report.model.js +4 -0
  360. package/models/report-builder-report.model.js.map +1 -0
  361. package/models/report-builder.model.d.ts +61 -0
  362. package/models/report-builder.model.js +4 -0
  363. package/models/report-builder.model.js.map +1 -0
  364. package/models/select-data-label.model.d.ts +9 -0
  365. package/models/select-data-label.model.js +4 -0
  366. package/models/select-data-label.model.js.map +1 -0
  367. package/models/server-message.model.d.ts +32 -0
  368. package/models/server-message.model.js +4 -0
  369. package/models/server-message.model.js.map +1 -0
  370. package/models/slow-query-report.model.d.ts +23 -0
  371. package/models/slow-query-report.model.js +4 -0
  372. package/models/slow-query-report.model.js.map +1 -0
  373. package/models/subscription.model.d.ts +31 -0
  374. package/models/subscription.model.js +4 -0
  375. package/models/subscription.model.js.map +1 -0
  376. package/models/support-ticket.model.d.ts +87 -0
  377. package/models/support-ticket.model.js +4 -0
  378. package/models/support-ticket.model.js.map +1 -0
  379. package/models/user-group.model.d.ts +20 -0
  380. package/models/user-group.model.js +4 -0
  381. package/models/user-group.model.js.map +1 -0
  382. package/{src/models/user-guide.model.ts → models/user-guide.model.d.ts} +4 -5
  383. package/models/user-guide.model.js +4 -0
  384. package/models/user-guide.model.js.map +1 -0
  385. package/models/user.model.d.ts +84 -0
  386. package/models/user.model.js +4 -0
  387. package/models/user.model.js.map +1 -0
  388. package/package.json +1 -1
  389. package/private/images/ResolveIO.png +0 -0
  390. package/public_api.js +127 -0
  391. package/public_api.js.map +1 -0
  392. package/publications/ai-terminal.d.ts +1 -0
  393. package/publications/ai-terminal.js +122 -0
  394. package/publications/ai-terminal.js.map +1 -0
  395. package/publications/app-settings.d.ts +2 -0
  396. package/publications/app-settings.js +28 -0
  397. package/publications/app-settings.js.map +1 -0
  398. package/publications/app-status.d.ts +2 -0
  399. package/publications/app-status.js +16 -0
  400. package/publications/app-status.js.map +1 -0
  401. package/publications/cron-jobs.d.ts +2 -0
  402. package/publications/cron-jobs.js +88 -0
  403. package/publications/cron-jobs.js.map +1 -0
  404. package/publications/customer-notifications.d.ts +2 -0
  405. package/publications/customer-notifications.js +161 -0
  406. package/publications/customer-notifications.js.map +1 -0
  407. package/publications/files.d.ts +2 -0
  408. package/publications/files.js +36 -0
  409. package/publications/files.js.map +1 -0
  410. package/publications/flags-update.d.ts +2 -0
  411. package/publications/flags-update.js +22 -0
  412. package/publications/flags-update.js.map +1 -0
  413. package/publications/flags.d.ts +2 -0
  414. package/publications/flags.js +22 -0
  415. package/publications/flags.js.map +1 -0
  416. package/publications/logs.d.ts +2 -0
  417. package/publications/logs.js +164 -0
  418. package/publications/logs.js.map +1 -0
  419. package/publications/notifications.d.ts +2 -0
  420. package/publications/notifications.js +16 -0
  421. package/publications/notifications.js.map +1 -0
  422. package/publications/report-builder-dashboard-builders.d.ts +2 -0
  423. package/publications/report-builder-dashboard-builders.js +42 -0
  424. package/publications/report-builder-dashboard-builders.js.map +1 -0
  425. package/publications/report-builder-libraries.d.ts +2 -0
  426. package/publications/report-builder-libraries.js +90 -0
  427. package/publications/report-builder-libraries.js.map +1 -0
  428. package/publications/report-builder-reports.d.ts +2 -0
  429. package/publications/report-builder-reports.js +50 -0
  430. package/publications/report-builder-reports.js.map +1 -0
  431. package/publications/super-admin.d.ts +2 -0
  432. package/publications/super-admin.js +16 -0
  433. package/publications/super-admin.js.map +1 -0
  434. package/publications/user-groups.d.ts +1 -0
  435. package/publications/user-groups.js +16 -0
  436. package/publications/user-groups.js.map +1 -0
  437. package/publications/user-guides.d.ts +1 -0
  438. package/publications/user-guides.js +16 -0
  439. package/publications/user-guides.js.map +1 -0
  440. package/resolveio-server-app.d.ts +70 -0
  441. package/resolveio-server-app.js +801 -0
  442. package/resolveio-server-app.js.map +1 -0
  443. package/server-app.d.ts +228 -0
  444. package/server-app.js +3566 -0
  445. package/server-app.js.map +1 -0
  446. package/services/codex-client.d.ts +128 -0
  447. package/services/codex-client.js +1629 -0
  448. package/services/codex-client.js.map +1 -0
  449. package/services/openai-client.d.ts +46 -0
  450. package/services/openai-client.js +318 -0
  451. package/services/openai-client.js.map +1 -0
  452. package/types/error-report.d.ts +25 -0
  453. package/types/error-report.js +4 -0
  454. package/types/error-report.js.map +1 -0
  455. package/types/slow-query-report.d.ts +27 -0
  456. package/types/slow-query-report.js +6 -0
  457. package/types/slow-query-report.js.map +1 -0
  458. package/util/ai-qa-policy.d.ts +124 -0
  459. package/util/ai-qa-policy.js +736 -0
  460. package/util/ai-qa-policy.js.map +1 -0
  461. package/util/ai-run-evidence-adapters.d.ts +109 -0
  462. package/util/ai-run-evidence-adapters.js +7234 -0
  463. package/util/ai-run-evidence-adapters.js.map +1 -0
  464. package/util/ai-run-evidence-dashboard.d.ts +88 -0
  465. package/util/ai-run-evidence-dashboard.js +343 -0
  466. package/util/ai-run-evidence-dashboard.js.map +1 -0
  467. package/util/ai-run-evidence-eval.d.ts +86 -0
  468. package/util/ai-run-evidence-eval.js +1018 -0
  469. package/util/ai-run-evidence-eval.js.map +1 -0
  470. package/util/ai-run-evidence.d.ts +244 -0
  471. package/util/ai-run-evidence.js +1096 -0
  472. package/util/ai-run-evidence.js.map +1 -0
  473. package/util/ai-runner-artifacts.d.ts +82 -0
  474. package/util/ai-runner-artifacts.js +713 -0
  475. package/util/ai-runner-artifacts.js.map +1 -0
  476. package/util/ai-runner-manager-autopilot.d.ts +210 -0
  477. package/util/ai-runner-manager-autopilot.js +642 -0
  478. package/util/ai-runner-manager-autopilot.js.map +1 -0
  479. package/util/ai-runner-manager-policy.d.ts +807 -0
  480. package/util/ai-runner-manager-policy.js +3501 -0
  481. package/util/ai-runner-manager-policy.js.map +1 -0
  482. package/util/ai-runner-qa-auth.d.ts +5 -0
  483. package/util/ai-runner-qa-auth.js +839 -0
  484. package/util/ai-runner-qa-auth.js.map +1 -0
  485. package/util/ai-runner-qa-tools.d.ts +26 -0
  486. package/util/ai-runner-qa-tools.js +3520 -0
  487. package/util/ai-runner-qa-tools.js.map +1 -0
  488. package/util/aicoder-runner-v6.d.ts +426 -0
  489. package/util/aicoder-runner-v6.js +2464 -0
  490. package/util/aicoder-runner-v6.js.map +1 -0
  491. package/util/common.d.ts +31 -0
  492. package/util/common.js +683 -0
  493. package/util/common.js.map +1 -0
  494. package/util/customer-portal-password.d.ts +13 -0
  495. package/util/customer-portal-password.js +209 -0
  496. package/util/customer-portal-password.js.map +1 -0
  497. package/util/error-reporter.d.ts +52 -0
  498. package/util/error-reporter.js +326 -0
  499. package/util/error-reporter.js.map +1 -0
  500. package/util/error-tracking.d.ts +13 -0
  501. package/util/error-tracking.js +120 -0
  502. package/util/error-tracking.js.map +1 -0
  503. package/util/openai-usage-cost.d.ts +6 -0
  504. package/util/openai-usage-cost.js +103 -0
  505. package/util/openai-usage-cost.js.map +1 -0
  506. package/util/report-builder-unwinds.d.ts +15 -0
  507. package/util/report-builder-unwinds.js +156 -0
  508. package/util/report-builder-unwinds.js.map +1 -0
  509. package/util/runner-process-janitor.d.ts +27 -0
  510. package/util/runner-process-janitor.js +208 -0
  511. package/util/runner-process-janitor.js.map +1 -0
  512. package/util/schema-report-builder.d.ts +6 -0
  513. package/util/schema-report-builder.js +481 -0
  514. package/util/schema-report-builder.js.map +1 -0
  515. package/util/slow-query-reporter.d.ts +28 -0
  516. package/util/slow-query-reporter.js +226 -0
  517. package/util/slow-query-reporter.js.map +1 -0
  518. package/util/subscription-dependency-context.d.ts +34 -0
  519. package/util/subscription-dependency-context.js +1283 -0
  520. package/util/subscription-dependency-context.js.map +1 -0
  521. package/util/support-runner-v5.d.ts +1426 -0
  522. package/util/support-runner-v5.js +7643 -0
  523. package/util/support-runner-v5.js.map +1 -0
  524. package/util/tokenizer.d.ts +5 -0
  525. package/util/tokenizer.js +41 -0
  526. package/util/tokenizer.js.map +1 -0
  527. package/workers/codex-runner.worker.d.ts +1 -0
  528. package/workers/codex-runner.worker.js +192 -0
  529. package/workers/codex-runner.worker.js.map +1 -0
  530. package/.nodemon.json +0 -5
  531. package/.vscode/settings.json +0 -21
  532. package/AGENTS.md +0 -195
  533. package/README.md +0 -22
  534. package/build_package.sh +0 -5
  535. package/compileDTS.pl +0 -64
  536. package/docs/ai-assistant-nightly-eval.md +0 -65
  537. package/docs/ai-assistant-preflight-checklist.md +0 -23
  538. package/docs/ai-assistant-report-builder-bridge-playbook.md +0 -115
  539. package/eslint-plugin-custom/index.js +0 -7
  540. package/eslint-plugin-custom/rules/no-filter-zero-index.js +0 -44
  541. package/eslint.config.js +0 -103
  542. package/gulpfile.js +0 -216
  543. package/methodAndPublicationListGenerator.py +0 -375
  544. package/mongodbensurers.js +0 -2
  545. package/mongostop.js +0 -3
  546. package/scripts/cleanup-bypassed-callmethod-logs.js +0 -616
  547. package/settings.development.json +0 -25
  548. package/settings.development.redacted.json +0 -25
  549. package/src/.env +0 -12
  550. package/src/ai/assistant-core-heuristics.ts +0 -379
  551. package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +0 -185
  552. package/src/ai/resolveio-platform-intelligence-memory.ts +0 -325
  553. package/src/ai/resolveio-platform-intelligence.ts +0 -462
  554. package/src/client-server-app.ts +0 -12
  555. package/src/collections/ai-run.collection.ts +0 -117
  556. package/src/collections/ai-terminal-conversation.collection.ts +0 -91
  557. package/src/collections/ai-terminal-issue-report.collection.ts +0 -99
  558. package/src/collections/ai-terminal-message.collection.ts +0 -77
  559. package/src/collections/app-setting.collection.ts +0 -104
  560. package/src/collections/app-status.collection.ts +0 -58
  561. package/src/collections/communication-metric.collection.ts +0 -84
  562. package/src/collections/counter.collection.ts +0 -56
  563. package/src/collections/cron-job-history.collection.ts +0 -94
  564. package/src/collections/cron-job.collection.ts +0 -92
  565. package/src/collections/customer-notification.collection.ts +0 -131
  566. package/src/collections/customer-portal-password.collection.ts +0 -76
  567. package/src/collections/email-history.collection.ts +0 -134
  568. package/src/collections/email-verified.collection.ts +0 -62
  569. package/src/collections/file.collection.ts +0 -74
  570. package/src/collections/flag-update.collection.ts +0 -57
  571. package/src/collections/flag.collection.ts +0 -57
  572. package/src/collections/log-method-latency.collection.ts +0 -77
  573. package/src/collections/log-subscription.collection.ts +0 -80
  574. package/src/collections/log.collection.ts +0 -93
  575. package/src/collections/logged-in-users.collection.ts +0 -67
  576. package/src/collections/monitor-cpu.collection.ts +0 -65
  577. package/src/collections/monitor-function.collection.ts +0 -74
  578. package/src/collections/monitor-memory.collection.ts +0 -77
  579. package/src/collections/monitor-mongo.collection.ts +0 -71
  580. package/src/collections/notification.collection.ts +0 -57
  581. package/src/collections/openai-usage-ledger.collection.ts +0 -131
  582. package/src/collections/report-builder-dashboard-builder.collection.ts +0 -109
  583. package/src/collections/report-builder-library.collection.ts +0 -89
  584. package/src/collections/report-builder-report.collection.ts +0 -184
  585. package/src/collections/user-group.collection.ts +0 -89
  586. package/src/collections/user-guide.collection.ts +0 -57
  587. package/src/collections/user.collection.ts +0 -181
  588. package/src/cron/cron.ts +0 -117
  589. package/src/fixtures/cron-jobs.ts +0 -95
  590. package/src/fixtures/init.ts +0 -35
  591. package/src/http/auth.ts +0 -818
  592. package/src/http/health.ts +0 -7
  593. package/src/http/home.ts +0 -90
  594. package/src/http/slow-query-publication.ts +0 -49
  595. package/src/index.ts +0 -1
  596. package/src/managers/ai-assistant-codex-manager.manager.ts +0 -1131
  597. package/src/managers/ai-run-evidence.manager.ts +0 -264
  598. package/src/managers/communication-metric.manager.ts +0 -82
  599. package/src/managers/cron.manager.ts +0 -333
  600. package/src/managers/customer-notification-content.manager.ts +0 -236
  601. package/src/managers/diagnostic-manager-bootstrap.ts +0 -165
  602. package/src/managers/error-auto-fix.manager.ts +0 -2767
  603. package/src/managers/local-log.manager.ts +0 -113
  604. package/src/managers/method.manager.ts +0 -1857
  605. package/src/managers/mongo.manager.ts +0 -4575
  606. package/src/managers/monitor.manager.ts +0 -507
  607. package/src/managers/openai-usage-ledger.manager.ts +0 -112
  608. package/src/managers/slow-query-verifier.manager.ts +0 -3590
  609. package/src/managers/slow-query.manager.ts +0 -519
  610. package/src/managers/subscription.manager.ts +0 -3128
  611. package/src/managers/websocket.manager.ts +0 -746
  612. package/src/managers/worker-dispatcher.manager.ts +0 -1360
  613. package/src/managers/worker-server.manager.ts +0 -536
  614. package/src/methods/accounts.ts +0 -532
  615. package/src/methods/ai-terminal.ts +0 -29070
  616. package/src/methods/app-settings.ts +0 -114
  617. package/src/methods/aws.ts +0 -649
  618. package/src/methods/collections.ts +0 -641
  619. package/src/methods/counters.ts +0 -69
  620. package/src/methods/cron-jobs.ts +0 -2614
  621. package/src/methods/customer-notifications.ts +0 -458
  622. package/src/methods/diagnostics.ts +0 -616
  623. package/src/methods/flag-updates.ts +0 -7
  624. package/src/methods/flags.ts +0 -7
  625. package/src/methods/logs.ts +0 -657
  626. package/src/methods/mongo-explorer.ts +0 -1880
  627. package/src/methods/monitor.ts +0 -540
  628. package/src/methods/pdf.ts +0 -1236
  629. package/src/methods/publications.ts +0 -129
  630. package/src/methods/report-builder.ts +0 -3300
  631. package/src/methods/support.ts +0 -335
  632. package/src/models/ai-run.model.ts +0 -27
  633. package/src/models/ai-terminal-conversation.model.ts +0 -19
  634. package/src/models/ai-terminal-issue-report.model.ts +0 -21
  635. package/src/models/ai-terminal-message.model.ts +0 -24
  636. package/src/models/app-setting.model.ts +0 -17
  637. package/src/models/collection-document.model.ts +0 -24
  638. package/src/models/communication-metric.model.ts +0 -23
  639. package/src/models/cron-job-history.model.ts +0 -16
  640. package/src/models/cron-job.model.ts +0 -15
  641. package/src/models/customer-notification.model.ts +0 -28
  642. package/src/models/customer-portal-password.model.ts +0 -12
  643. package/src/models/dialog.model.ts +0 -25
  644. package/src/models/log-method-latency.model.ts +0 -11
  645. package/src/models/log.model.ts +0 -19
  646. package/src/models/method.model.ts +0 -25
  647. package/src/models/monitor-function.model.ts +0 -16
  648. package/src/models/monitor-memory.model.ts +0 -17
  649. package/src/models/monitor-mongo.model.ts +0 -15
  650. package/src/models/openai-usage-ledger.model.ts +0 -56
  651. package/src/models/pagination.model.ts +0 -35
  652. package/src/models/permission.model.ts +0 -14
  653. package/src/models/report-builder-dashboard-builder.model.ts +0 -29
  654. package/src/models/report-builder-library.model.ts +0 -20
  655. package/src/models/report-builder-report.model.ts +0 -136
  656. package/src/models/report-builder.model.ts +0 -68
  657. package/src/models/select-data-label.model.ts +0 -9
  658. package/src/models/server-message.model.ts +0 -31
  659. package/src/models/slow-query-report.model.ts +0 -23
  660. package/src/models/subscription.model.ts +0 -73
  661. package/src/models/support-ticket.model.ts +0 -104
  662. package/src/models/user-group.model.ts +0 -24
  663. package/src/models/user.model.ts +0 -96
  664. package/src/private/images/ResolveIO.png +0 -0
  665. package/src/publications/ai-terminal.ts +0 -73
  666. package/src/publications/app-settings.ts +0 -25
  667. package/src/publications/app-status.ts +0 -13
  668. package/src/publications/cron-jobs.ts +0 -40
  669. package/src/publications/customer-notifications.ts +0 -101
  670. package/src/publications/files.ts +0 -33
  671. package/src/publications/flags-update.ts +0 -19
  672. package/src/publications/flags.ts +0 -19
  673. package/src/publications/logs.ts +0 -163
  674. package/src/publications/notifications.ts +0 -13
  675. package/src/publications/report-builder-dashboard-builders.ts +0 -39
  676. package/src/publications/report-builder-libraries.ts +0 -41
  677. package/src/publications/report-builder-reports.ts +0 -47
  678. package/src/publications/super-admin.ts +0 -13
  679. package/src/publications/user-groups.ts +0 -12
  680. package/src/publications/user-guides.ts +0 -12
  681. package/src/resolveio-server-app.ts +0 -617
  682. package/src/server-app.ts +0 -3354
  683. package/src/services/codex-client.ts +0 -1231
  684. package/src/services/openai-client.ts +0 -265
  685. package/src/types/error-report.ts +0 -26
  686. package/src/types/js-tiktoken.d.ts +0 -11
  687. package/src/types/slow-query-report.ts +0 -28
  688. package/src/util/ai-qa-policy.ts +0 -925
  689. package/src/util/ai-run-evidence-adapters.ts +0 -8347
  690. package/src/util/ai-run-evidence-dashboard.ts +0 -323
  691. package/src/util/ai-run-evidence-eval.ts +0 -1057
  692. package/src/util/ai-run-evidence.ts +0 -1430
  693. package/src/util/ai-runner-artifacts.ts +0 -586
  694. package/src/util/ai-runner-manager-autopilot.ts +0 -961
  695. package/src/util/ai-runner-manager-policy.ts +0 -5011
  696. package/src/util/ai-runner-qa-auth.ts +0 -838
  697. package/src/util/ai-runner-qa-tools.ts +0 -3536
  698. package/src/util/aicoder-runner-v6.ts +0 -3121
  699. package/src/util/common.ts +0 -649
  700. package/src/util/customer-portal-password.ts +0 -183
  701. package/src/util/error-reporter.ts +0 -332
  702. package/src/util/error-tracking.ts +0 -79
  703. package/src/util/openai-usage-cost.ts +0 -114
  704. package/src/util/report-builder-unwinds.ts +0 -180
  705. package/src/util/runner-process-janitor.ts +0 -219
  706. package/src/util/schema-report-builder.ts +0 -448
  707. package/src/util/slow-query-reporter.ts +0 -216
  708. package/src/util/subscription-dependency-context.ts +0 -1096
  709. package/src/util/support-runner-v5.ts +0 -10040
  710. package/src/util/tokenizer.ts +0 -38
  711. package/src/workers/codex-runner.worker.ts +0 -142
  712. package/start_server.sh +0 -5
  713. package/tests/ai-assistant-corpus-build.ts +0 -484
  714. package/tests/ai-assistant-corpus-replay-e2e.ts +0 -774
  715. package/tests/ai-assistant-data-parity-e2e.ts +0 -1989
  716. package/tests/ai-assistant-eval-triage.ts +0 -831
  717. package/tests/ai-assistant-openai-e2e.ts +0 -1061
  718. package/tests/ai-assistant-openai-git-e2e.ts +0 -155
  719. package/tests/ai-assistant-preflight-matrix.ts +0 -215
  720. package/tests/ai-assistant-routing-eval.test.ts +0 -585
  721. package/tests/ai-assistant-snf-live-eval.ts +0 -975
  722. package/tests/ai-assistant-utils.test.ts +0 -4834
  723. package/tests/ai-manager-autopilot-snapshot.test.ts +0 -193
  724. package/tests/ai-manager-recovery-checkpoint.test.ts +0 -1383
  725. package/tests/ai-run-eval.test.ts +0 -132
  726. package/tests/ai-run-evidence.test.ts +0 -3773
  727. package/tests/ai-runner-contract.test.ts +0 -515
  728. package/tests/aicoder-runner-v6.test.ts +0 -822
  729. package/tests/error-reporter.test.ts +0 -145
  730. package/tests/method-publication-generator.test.ts +0 -46
  731. package/tests/report-builder-linking.test.ts +0 -79
  732. package/tests/resolveio-platform-intelligence.test.ts +0 -352
  733. package/tests/server-app-cron-owner.test.ts +0 -127
  734. package/tests/subscription-connect-race.test.ts +0 -158
  735. package/tests/subscription-dependency-context.test.ts +0 -324
  736. package/tests/subscription-manager-collection-tracking.test.ts +0 -86
  737. package/tests/subscription-manager-invalidation.test.ts +0 -86
  738. package/tests/support-runner-v5.test.ts +0 -3201
  739. package/tsconfig.json +0 -34
  740. /package/{src/private → private}/email-templates/enrollment.html +0 -0
  741. /package/{src/private → private}/email-templates/forgot-password.html +0 -0
  742. /package/{src/private → private}/email-templates/support-ticket-deleted.html +0 -0
  743. /package/{src/private → private}/email-templates/support-ticket-modified.html +0 -0
  744. /package/{src/private → private}/email-templates/support-ticket.html +0 -0
  745. /package/{src/public_api.ts → public_api.d.ts} +0 -0
@@ -1,1231 +0,0 @@
1
- import { promises as fs } from 'fs';
2
- import * as os from 'os';
3
- import * as path from 'path';
4
- import { setTimeout as sleepTimeout } from 'timers/promises';
5
- export interface CodexConfig {
6
- apiKey?: string;
7
- baseUrl?: string;
8
- model?: string;
9
- fallbackModel?: string;
10
- fallbackModels?: string[];
11
- maxRetries?: number;
12
- retryDelayMs?: number;
13
- }
14
-
15
- /* eslint-disable no-unused-vars -- Function type params are required for clarity. */
16
- type StreamEventHandler = (event: any) => void | Promise<void>;
17
- type StreamTextHandler = (delta: string, fullText: string) => void | Promise<void>;
18
- type AgentMessageHandler = (text: string) => void | Promise<void>;
19
- type UsageHandler = (usage: CodexUsageSummary | null) => void | Promise<void>;
20
- type DynamicImport = (specifier: string) => Promise<any>;
21
- /* eslint-enable no-unused-vars */
22
-
23
- type CodexModelFallbackPreference = {
24
- fallbackModel: string;
25
- expiresAt: number;
26
- updatedAt: number;
27
- };
28
-
29
- export interface CodexRunOptions {
30
- timeoutMs?: number;
31
- streamIdleTimeoutMs?: number;
32
- maxRetries?: number;
33
- processWorkingDirectory?: string;
34
- threadOptions?: CodexThreadOptions;
35
- threadKey?: string;
36
- reuseThread?: boolean;
37
- fallbackModels?: string[];
38
- failOnStreamHandlerError?: boolean;
39
- onStreamEvent?: StreamEventHandler;
40
- onStreamText?: StreamTextHandler;
41
- onUsage?: UsageHandler;
42
- }
43
-
44
- export interface CodexUsageSummary {
45
- inputTokens: number;
46
- cachedInputTokens: number;
47
- outputTokens: number;
48
- }
49
-
50
- export type CodexThreadOptions = {
51
- model?: string;
52
- sandboxMode?: 'read-only' | 'workspace-write' | 'danger-full-access';
53
- workingDirectory?: string;
54
- skipGitRepoCheck?: boolean;
55
- modelReasoningEffort?: 'minimal' | 'none' | 'low' | 'medium' | 'high' | 'xhigh';
56
- networkAccessEnabled?: boolean;
57
- webSearchMode?: 'disabled' | 'cached' | 'live';
58
- webSearchEnabled?: boolean;
59
- approvalPolicy?: 'never' | 'on-request' | 'on-failure' | 'untrusted';
60
- additionalDirectories?: string[];
61
- };
62
-
63
- export class CodexClient {
64
- private static readonly PING_PROMPT = "Say 'pong'";
65
- private static readonly MODEL_UNAVAILABLE_FALLBACK_FILE = path.join(os.tmpdir(), 'resolveio-codex-model-fallbacks.json');
66
- private static readonly DEFAULT_MODEL_UNAVAILABLE_TTL_MS = 6 * 60 * 60 * 1000;
67
- private static readonly MIN_MODEL_UNAVAILABLE_TTL_MS = 60 * 1000;
68
- private static readonly modelFallbackPreferences = new Map<string, CodexModelFallbackPreference>();
69
- private static modelFallbackPreferencesLoaded = false;
70
- private static modelFallbackPreferencesLoadPromise: Promise<void> | null = null;
71
- private static cwdFallbackRunning = false;
72
- private codex: any | null = null;
73
- private codexInit: Promise<void> | null = null;
74
- private readonly threadCache = new Map<string, { thread: any; optionsKey: string; modelKey: string }>();
75
- private readonly debugEnabled = (process.env.AI_DASHBOARD_DEBUG || '').trim().toLowerCase() === 'true';
76
- private readonly streamEnabled = this.resolveStreamEnabled();
77
- private readonly cleanZdotdirEnabled = this.resolveCleanZdotdirEnabled();
78
- private zDotDir: string | null = null;
79
- private readonly defaultTimeoutMs = this.resolveDefaultTimeoutMs();
80
- private readonly pingEnabled = this.resolvePingEnabled();
81
- private readonly pingTimeoutMs = this.resolvePingTimeoutMs();
82
- private readonly modelUnavailableTtlMs = this.resolveModelUnavailableTtlMs();
83
- private readonly config: CodexConfig;
84
- private readonly defaultThreadOptions: CodexThreadOptions;
85
-
86
- constructor(config: CodexConfig) {
87
- this.config = config;
88
- if (!this.config.apiKey) {
89
- throw new Error('AI API key is required for AI client');
90
- }
91
- this.defaultThreadOptions = this.resolveDefaultThreadOptions();
92
- }
93
-
94
- async run(prompt: string, options?: CodexRunOptions): Promise<string> {
95
- await this.ensureModelFallbackPreferencesLoaded();
96
- const maxRetries = this.normalizeRetryCount(options?.maxRetries ?? this.config.maxRetries);
97
- const retryDelayMs = this.normalizeRetryDelay(this.config.retryDelayMs);
98
- let lastError: unknown = null;
99
- const modelSequence = this.resolveModelSequence(options);
100
- for (let modelIndex = 0; modelIndex < modelSequence.length; modelIndex += 1) {
101
- const model = modelSequence[modelIndex];
102
- const nextModel = modelSequence[modelIndex + 1];
103
- const modelOptions = this.applyModelOverride(options, model);
104
- let processCwdFallbackApplied = false;
105
- let attempt = 0;
106
- while (attempt <= maxRetries) {
107
- try {
108
- this.log(`run model=${model || this.config.model || 'default'} attempt ${attempt + 1}/${maxRetries + 1}`);
109
- if (this.pingEnabled && !this.isPingPrompt(prompt)) {
110
- await this.runPing(modelOptions?.threadOptions);
111
- }
112
- if (this.streamEnabled && !this.isPingPrompt(prompt)) {
113
- const result = await this.runStreamedOnce(prompt, modelOptions);
114
- await this.clearModelFallbackPreference(model);
115
- return result;
116
- }
117
- const result = await this.runOnce(prompt, modelOptions);
118
- await this.clearModelFallbackPreference(model);
119
- return result;
120
- }
121
- catch (error) {
122
- lastError = error;
123
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
124
- this.log(`run model=${model || this.config.model || 'default'} attempt ${attempt + 1} failed: ${message}`);
125
- if (!processCwdFallbackApplied && this.shouldApplyProcessCwdFallback(error, modelOptions)) {
126
- processCwdFallbackApplied = true;
127
- const workingDirectory = this.resolveProcessWorkingDirectory(modelOptions);
128
- const fallbackOptions = this.applyProcessCwdFallback(modelOptions);
129
- this.log('codex workingDirectory launch failed with os error 2; retrying from process cwd without CLI workingDirectory.');
130
- return await this.withProcessWorkingDirectoryFallback(workingDirectory, async () => {
131
- if (this.streamEnabled && !this.isPingPrompt(prompt)) {
132
- const fallbackResult = await this.runStreamedOnce(prompt, fallbackOptions);
133
- await this.clearModelFallbackPreference(model);
134
- return fallbackResult;
135
- }
136
- const fallbackResult = await this.runOnce(prompt, fallbackOptions);
137
- await this.clearModelFallbackPreference(model);
138
- return fallbackResult;
139
- });
140
- }
141
- if (nextModel && this.isModelAvailabilityError(error)) {
142
- await this.rememberModelFallbackPreference(model, nextModel);
143
- this.log(`model unavailable; retrying with fallback model ${nextModel}`);
144
- break;
145
- }
146
- if (this.isCodexEnvironmentError(error)) {
147
- this.recoverCodexEnvironment(error);
148
- }
149
- if (attempt >= maxRetries || !this.isRetryableError(error)) {
150
- throw lastError;
151
- }
152
- const delay = retryDelayMs * Math.pow(2, attempt);
153
- await this.sleep(delay);
154
- attempt += 1;
155
- }
156
- }
157
- }
158
- throw lastError;
159
- }
160
-
161
- private async runStreamedOnce(prompt: string, options?: CodexRunOptions): Promise<string> {
162
- const startedAt = Date.now();
163
- this.log(`runStreamed start (promptLength=${prompt.length})`);
164
- const thread = await this.startThread(options?.threadOptions, options?.threadKey, options?.reuseThread);
165
- const timeoutMs = options?.timeoutMs ?? this.defaultTimeoutMs;
166
- const streamIdleTimeoutMs = this.normalizeStreamIdleTimeoutMs(options?.streamIdleTimeoutMs);
167
- const controller = typeof AbortController !== 'undefined' ? new AbortController() : null;
168
- const timeoutId = controller
169
- ? setTimeout(() => controller.abort(), timeoutMs)
170
- : null;
171
- let lastStreamActivityAt = Date.now();
172
- const idleTimeoutId = controller && streamIdleTimeoutMs > 0
173
- ? setInterval(() => {
174
- if (Date.now() - lastStreamActivityAt >= streamIdleTimeoutMs) {
175
- controller.abort();
176
- }
177
- }, Math.max(15_000, Math.min(60_000, Math.floor(streamIdleTimeoutMs / 4))))
178
- : null;
179
- let finalResponse = '';
180
- let lastText = '';
181
- let usageSummary: CodexUsageSummary | null = null;
182
- try {
183
- const { events } = await thread.runStreamed(prompt, controller ? { signal: controller.signal } : undefined);
184
- for await (const event of events) {
185
- lastStreamActivityAt = Date.now();
186
- if (event?.type === 'turn.completed') {
187
- usageSummary = this.normalizeUsageSummary(event?.usage);
188
- }
189
- if (options?.onStreamEvent) {
190
- try {
191
- await options.onStreamEvent(event);
192
- }
193
- catch (error) {
194
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
195
- this.log(`onStreamEvent failed: ${message}`);
196
- if (options?.failOnStreamHandlerError) {
197
- throw error;
198
- }
199
- }
200
- }
201
- await this.handleStreamEvent(event, async (text: string) => {
202
- const next = text || '';
203
- if (!next) {
204
- return;
205
- }
206
- const delta = next.startsWith(lastText) ? next.slice(lastText.length) : next;
207
- if (delta) {
208
- this.logStreamText(delta);
209
- if (options?.onStreamText) {
210
- try {
211
- await options.onStreamText(delta, next);
212
- }
213
- catch (error) {
214
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
215
- this.log(`onStreamText failed: ${message}`);
216
- if (options?.failOnStreamHandlerError) {
217
- throw error;
218
- }
219
- }
220
- }
221
- }
222
- lastText = next;
223
- finalResponse = next;
224
- });
225
- if (event?.type === 'turn.failed') {
226
- throw new Error(event.error?.message || 'AI run failed.');
227
- }
228
- if (event?.type === 'error') {
229
- throw new Error(event.message || 'AI stream error.');
230
- }
231
- }
232
- }
233
- catch (error) {
234
- if (controller?.signal?.aborted) {
235
- const idleForMs = Date.now() - lastStreamActivityAt;
236
- if (streamIdleTimeoutMs > 0 && idleForMs >= streamIdleTimeoutMs) {
237
- this.log(`runStreamed idle timed out (durationMs=${Date.now() - startedAt}, idleForMs=${idleForMs})`);
238
- throw new Error(`AI stream stalled with no activity for ${idleForMs}ms.`);
239
- }
240
- this.log(`runStreamed timed out (durationMs=${Date.now() - startedAt})`);
241
- throw new Error('AI request timed out.');
242
- }
243
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
244
- this.log(`runStreamed failed (durationMs=${Date.now() - startedAt}): ${message}`);
245
- throw error;
246
- }
247
- finally {
248
- if (timeoutId) {
249
- clearTimeout(timeoutId);
250
- }
251
- if (idleTimeoutId) {
252
- clearInterval(idleTimeoutId);
253
- }
254
- }
255
- if (!finalResponse) {
256
- throw new Error('AI returned no completion content.');
257
- }
258
- await this.emitUsageSummary(options, usageSummary);
259
- this.log(`runStreamed complete (contentLength=${finalResponse.length}, durationMs=${Date.now() - startedAt})`);
260
- return finalResponse.trim();
261
- }
262
-
263
- private normalizeStreamIdleTimeoutMs(value: any): number {
264
- const parsed = Number(value || 0);
265
- if (!Number.isFinite(parsed) || parsed < 60_000) {
266
- return 0;
267
- }
268
- return Math.floor(parsed);
269
- }
270
-
271
- private async runOnce(prompt: string, options?: CodexRunOptions): Promise<string> {
272
- const startedAt = Date.now();
273
- this.log(`runOnce start (promptLength=${prompt.length})`);
274
- try {
275
- const thread = await this.startThread(options?.threadOptions, options?.threadKey, options?.reuseThread);
276
- const runPromise = thread.run(prompt);
277
- const timeoutMs = options?.timeoutMs ?? this.defaultTimeoutMs;
278
- this.log(`runOnce awaiting result (timeoutMs=${timeoutMs})`);
279
- const result: any = await this.withTimeout(runPromise, timeoutMs);
280
- const content = this.extractContent(result);
281
- if (!content) {
282
- throw new Error('AI returned no completion content.');
283
- }
284
- await this.emitUsageSummary(options, this.normalizeUsageSummary(result?.usage));
285
- this.log(`runOnce complete (contentLength=${content.length}, durationMs=${Date.now() - startedAt})`);
286
- return content;
287
- }
288
- catch (error) {
289
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
290
- this.log(`runOnce failed (durationMs=${Date.now() - startedAt}): ${message}`);
291
- throw error;
292
- }
293
- }
294
-
295
- private async startThread(threadOptions?: CodexThreadOptions, threadKey?: string, reuseThread = true): Promise<any> {
296
- await this.ensureCodex();
297
- const mergedOptions = this.mergeThreadOptions(threadOptions);
298
- const optionsKey = this.buildThreadOptionsKey(mergedOptions);
299
- const effectiveModel = mergedOptions?.model || this.config.model || 'default';
300
- const modelKey = this.normalizeOptionalString(effectiveModel).toLowerCase() || 'default';
301
- const cacheKey = this.buildThreadCacheKey(threadKey, mergedOptions);
302
- const explicitThreadKey = (threadKey || '').trim();
303
- const hasExplicitThreadKey = explicitThreadKey.length > 0;
304
- if (reuseThread && cacheKey) {
305
- const existing = this.threadCache.get(cacheKey);
306
- if (existing) {
307
- const sameOptions = existing.optionsKey === optionsKey;
308
- const sameModel = existing.modelKey === modelKey;
309
- if (sameOptions || (hasExplicitThreadKey && sameModel)) {
310
- if (hasExplicitThreadKey && existing.optionsKey !== optionsKey) {
311
- this.log(`startThread reuse explicit key (${cacheKey}) despite option change`);
312
- }
313
- else {
314
- this.log(`startThread reuse (${cacheKey})`);
315
- }
316
- return existing.thread;
317
- }
318
- if (hasExplicitThreadKey && !sameModel) {
319
- this.log(`startThread explicit key (${cacheKey}) model changed (${existing.modelKey} -> ${modelKey}); creating new thread`);
320
- }
321
- }
322
- }
323
- this.log(`startThread (model=${effectiveModel})`);
324
- if (mergedOptions?.model) {
325
- this.log(`startThread options: ${this.formatThreadOptions(mergedOptions)}`);
326
- const thread = this.codex.startThread(mergedOptions);
327
- this.log('startThread created with model override');
328
- if (cacheKey) {
329
- this.threadCache.set(cacheKey, { thread, optionsKey, modelKey });
330
- }
331
- return thread;
332
- }
333
- if (mergedOptions && Object.keys(mergedOptions).length) {
334
- this.log(`startThread options: ${this.formatThreadOptions(mergedOptions)}`);
335
- }
336
- const thread = this.codex.startThread(mergedOptions);
337
- this.log('startThread created');
338
- if (cacheKey) {
339
- this.threadCache.set(cacheKey, { thread, optionsKey, modelKey });
340
- }
341
- return thread;
342
- }
343
-
344
- private extractContent(result: any): string {
345
- if (!result) {
346
- return '';
347
- }
348
- if (typeof result.finalResponse === 'string') {
349
- return result.finalResponse.trim();
350
- }
351
- if (typeof result === 'string') {
352
- return result.trim();
353
- }
354
- if (Array.isArray(result.items)) {
355
- const lastMessage = [...result.items].reverse().find((item: any) => item?.type === 'agent_message' && typeof item.text === 'string');
356
- if (lastMessage?.text) {
357
- return lastMessage.text.trim();
358
- }
359
- }
360
- if (typeof result.output_text === 'string') {
361
- return result.output_text.trim();
362
- }
363
- if (typeof result.outputText === 'string') {
364
- return result.outputText.trim();
365
- }
366
- if (typeof result.content === 'string') {
367
- return result.content.trim();
368
- }
369
- if (typeof result.text === 'string') {
370
- return result.text.trim();
371
- }
372
- if (Array.isArray(result.content)) {
373
- const text = result.content
374
- .map((part: any) => this.extractPartText(part))
375
- .join('')
376
- .trim();
377
- if (text) {
378
- return text;
379
- }
380
- }
381
- if (Array.isArray(result.output)) {
382
- const text = result.output
383
- .map((item: any) => {
384
- if (!item) {
385
- return '';
386
- }
387
- if (typeof item === 'string') {
388
- return item;
389
- }
390
- if (typeof item.text === 'string') {
391
- return item.text;
392
- }
393
- if (typeof item.content === 'string') {
394
- return item.content;
395
- }
396
- if (Array.isArray(item.content)) {
397
- return item.content.map((part: any) => this.extractPartText(part)).join('');
398
- }
399
- return '';
400
- })
401
- .join('')
402
- .trim();
403
- if (text) {
404
- return text;
405
- }
406
- }
407
- return '';
408
- }
409
-
410
- private async handleStreamEvent(event: any, onAgentMessage: AgentMessageHandler): Promise<void> {
411
- if (!event || !event.type) {
412
- return;
413
- }
414
- switch (event.type) {
415
- case 'thread.started':
416
- this.log(`stream thread.started (id=${event.thread_id || 'unknown'})`);
417
- break;
418
- case 'turn.started':
419
- this.log('stream turn.started');
420
- break;
421
- case 'turn.completed':
422
- this.log('stream turn.completed');
423
- break;
424
- case 'item.started':
425
- case 'item.updated':
426
- case 'item.completed':
427
- await this.handleStreamItem(event.item, onAgentMessage);
428
- break;
429
- default:
430
- break;
431
- }
432
- }
433
-
434
- private normalizeUsageSummary(raw: any): CodexUsageSummary | null {
435
- if (!raw || typeof raw !== 'object') {
436
- return null;
437
- }
438
- const inputTokens = this.normalizeUsageToken(raw.input_tokens ?? raw.inputTokens);
439
- const cachedInputTokens = this.normalizeUsageToken(raw.cached_input_tokens ?? raw.cachedInputTokens);
440
- const outputTokens = this.normalizeUsageToken(raw.output_tokens ?? raw.outputTokens);
441
- if (inputTokens <= 0 && cachedInputTokens <= 0 && outputTokens <= 0) {
442
- return null;
443
- }
444
- return {
445
- inputTokens,
446
- cachedInputTokens,
447
- outputTokens
448
- };
449
- }
450
-
451
- private normalizeUsageToken(value: any): number {
452
- const parsed = Number(value);
453
- if (!Number.isFinite(parsed) || parsed <= 0) {
454
- return 0;
455
- }
456
- return Math.floor(parsed);
457
- }
458
-
459
- private async emitUsageSummary(options: CodexRunOptions | undefined, usage: CodexUsageSummary | null): Promise<void> {
460
- if (!options?.onUsage) {
461
- return;
462
- }
463
- try {
464
- await options.onUsage(usage);
465
- }
466
- catch (error) {
467
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
468
- this.log(`onUsage failed: ${message}`);
469
- }
470
- }
471
-
472
- private async handleStreamItem(item: any, onAgentMessage: AgentMessageHandler): Promise<void> {
473
- if (!item || !item.type) {
474
- return;
475
- }
476
- switch (item.type) {
477
- case 'agent_message':
478
- await onAgentMessage(item.text || '');
479
- break;
480
- case 'command_execution':
481
- if (item.command) {
482
- this.log(`stream command: ${item.command} (${item.status || 'unknown'})`);
483
- }
484
- if (item.aggregated_output) {
485
- const output = item.aggregated_output.length > 800
486
- ? `${item.aggregated_output.slice(0, 800)}...`
487
- : item.aggregated_output;
488
- this.log(`stream command output: ${output}`);
489
- }
490
- break;
491
- case 'file_change':
492
- if (Array.isArray(item.changes) && item.changes.length) {
493
- const summary = item.changes.map((change: any) => `${change.kind}:${change.path}`).join(', ');
494
- this.log(`stream file_change (${item.status || 'unknown'}): ${summary}`);
495
- }
496
- break;
497
- case 'mcp_tool_call':
498
- if (item.tool) {
499
- this.log(`stream tool_call: ${item.tool} (${item.status || 'unknown'})`);
500
- }
501
- if (item.error?.message) {
502
- this.log(`stream tool_call error: ${item.error.message}`);
503
- }
504
- break;
505
- case 'web_search':
506
- if (item.query) {
507
- this.log(`stream web_search: ${item.query}`);
508
- }
509
- break;
510
- case 'todo_list':
511
- if (Array.isArray(item.items)) {
512
- const total = item.items.length;
513
- const done = item.items.filter((entry: any) => entry?.completed).length;
514
- this.log(`stream todo_list: ${done}/${total} completed`);
515
- }
516
- break;
517
- case 'reasoning':
518
- if (item.text) {
519
- const snippet = item.text.length > 200 ? `${item.text.slice(0, 200)}...` : item.text;
520
- this.log(`stream reasoning: ${snippet}`);
521
- }
522
- break;
523
- case 'error':
524
- if (item.message) {
525
- this.log(`stream error: ${item.message}`);
526
- }
527
- break;
528
- default:
529
- break;
530
- }
531
- }
532
-
533
- private logStreamText(text: string): void {
534
- if (!this.debugEnabled) {
535
- return;
536
- }
537
- const lines = text.split(/\r?\n/);
538
- for (const line of lines) {
539
- this.log(`stream: ${line}`);
540
- }
541
- }
542
-
543
- private extractPartText(part: any): string {
544
- if (!part) {
545
- return '';
546
- }
547
- if (typeof part === 'string') {
548
- return part;
549
- }
550
- if (typeof part.text === 'string') {
551
- return part.text;
552
- }
553
- if (typeof part.content === 'string') {
554
- return part.content;
555
- }
556
- return '';
557
- }
558
-
559
- private async withTimeout<T>(promise: Promise<T>, timeoutMs: number): Promise<T> {
560
- let done = false;
561
- const startedAt = Date.now();
562
- const heartbeatMs = Math.max(10000, Math.min(30000, Math.floor(timeoutMs / 4)));
563
- const timeoutPromise = (async (): Promise<T> => {
564
- while (!done) {
565
- const elapsed = Date.now() - startedAt;
566
- if (elapsed >= timeoutMs) {
567
- throw new Error('AI request timed out.');
568
- }
569
- const remaining = timeoutMs - elapsed;
570
- await sleepTimeout(Math.min(heartbeatMs, remaining));
571
- if (done) {
572
- return await promise;
573
- }
574
- const currentElapsed = Date.now() - startedAt;
575
- if (currentElapsed >= timeoutMs) {
576
- throw new Error('AI request timed out.');
577
- }
578
- const currentRemaining = Math.max(0, timeoutMs - currentElapsed);
579
- this.log(`runOnce waiting (elapsedMs=${currentElapsed}, remainingMs=${currentRemaining})`);
580
- }
581
- return await promise;
582
- })();
583
- try {
584
- return await Promise.race([promise, timeoutPromise]);
585
- }
586
- finally {
587
- done = true;
588
- }
589
- }
590
-
591
- private normalizeRetryCount(value?: number): number {
592
- if (typeof value !== 'number' || Number.isNaN(value)) {
593
- return 2;
594
- }
595
- return Math.max(0, Math.floor(value));
596
- }
597
-
598
- private normalizeRetryDelay(value?: number): number {
599
- if (typeof value !== 'number' || Number.isNaN(value)) {
600
- return 500;
601
- }
602
- return Math.max(100, Math.floor(value));
603
- }
604
-
605
- private resolveModelSequence(options?: CodexRunOptions): string[] {
606
- const primary = this.normalizeOptionalString(options?.threadOptions?.model || this.config.model);
607
- const fallbackModels = this.collectFallbackModels(options?.fallbackModels);
608
- const sequence: string[] = [];
609
- const push = (value: any) => {
610
- const normalized = this.normalizeOptionalString(value);
611
- if (!normalized || sequence.includes(normalized)) {
612
- return;
613
- }
614
- sequence.push(normalized);
615
- };
616
- const preferredFallback = this.getModelFallbackPreference(primary);
617
- if (preferredFallback) {
618
- push(preferredFallback);
619
- this.log(`sticky model fallback active: ${primary} -> ${preferredFallback}`);
620
- }
621
- push(primary);
622
- fallbackModels.forEach(push);
623
- if (!sequence.length) {
624
- sequence.push('');
625
- }
626
- return sequence;
627
- }
628
-
629
- private collectFallbackModels(runFallbackModels?: string[]): string[] {
630
- const models: string[] = [];
631
- const push = (value: any) => {
632
- const normalized = this.normalizeOptionalString(value);
633
- if (!normalized || models.includes(normalized)) {
634
- return;
635
- }
636
- models.push(normalized);
637
- };
638
- this.normalizeModelList(runFallbackModels).forEach(push);
639
- this.normalizeModelList(this.config.fallbackModels).forEach(push);
640
- push(this.config.fallbackModel);
641
- this.normalizeModelList(process.env.AI_ASSISTANT_CODEX_FALLBACK_MODELS).forEach(push);
642
- push(process.env.AI_ASSISTANT_CODEX_FALLBACK_MODEL);
643
- this.normalizeModelList(process.env.AI_TERMINAL_CODEX_FALLBACK_MODELS).forEach(push);
644
- push(process.env.AI_TERMINAL_CODEX_FALLBACK_MODEL);
645
- this.normalizeModelList(process.env.AI_DASHBOARD_CODEX_FALLBACK_MODELS).forEach(push);
646
- push(process.env.AI_DASHBOARD_CODEX_FALLBACK_MODEL);
647
- const primaryModel = this.normalizeOptionalString(
648
- this.config.model
649
- || runFallbackModels?.[0]
650
- || ''
651
- );
652
- if (/^gpt-5(?:\.\d+)?-codex$/i.test(primaryModel)) {
653
- push('gpt-5-codex');
654
- }
655
- if (/^gpt-5(?:-codex|\.\d+-codex)$/i.test(primaryModel)) {
656
- push('gpt-5.5');
657
- }
658
- return models;
659
- }
660
-
661
- private normalizeModelList(value: any): string[] {
662
- if (Array.isArray(value)) {
663
- return value
664
- .map(entry => this.normalizeOptionalString(entry))
665
- .filter(Boolean);
666
- }
667
- const raw = this.normalizeOptionalString(value);
668
- if (!raw) {
669
- return [];
670
- }
671
- return raw
672
- .split(',')
673
- .map(entry => this.normalizeOptionalString(entry))
674
- .filter(Boolean);
675
- }
676
-
677
- private applyModelOverride(options: CodexRunOptions | undefined, model: string): CodexRunOptions {
678
- const nextThreadOptions: CodexThreadOptions = {
679
- ...(options?.threadOptions || {})
680
- };
681
- if (model) {
682
- nextThreadOptions.model = model;
683
- }
684
- else {
685
- delete nextThreadOptions.model;
686
- }
687
- return {
688
- ...(options || {}),
689
- threadOptions: nextThreadOptions
690
- };
691
- }
692
-
693
- private isModelAvailabilityError(error: unknown): boolean {
694
- const message = error instanceof Error ? error.message : String(error || '');
695
- const normalized = message.toLowerCase();
696
- if (!normalized.includes('model')) {
697
- return false;
698
- }
699
- if (/does not exist|not found|unknown model|invalid model|unsupported model|model_not_found|no such model/.test(normalized)) {
700
- return true;
701
- }
702
- if (/not available|unavailable|not enabled|not allowed|do not have access|don't have access|insufficient permissions/.test(normalized)) {
703
- return true;
704
- }
705
- return /404/.test(normalized) && /model/.test(normalized);
706
- }
707
-
708
- private isRetryableError(error: unknown): boolean {
709
- const message = error instanceof Error ? error.message : String(error || '');
710
- if (/AI returned no completion content|Codex returned no completion content/i.test(message)) {
711
- return true;
712
- }
713
- if (this.isCodexEnvironmentError(error)) {
714
- return true;
715
- }
716
- const statusMatch = message.match(/\\b(429|5\\d{2})\\b/);
717
- if (statusMatch) {
718
- return true;
719
- }
720
- return /ECONNRESET|ETIMEDOUT|EAI_AGAIN|ENOTFOUND|fetch failed|timed out|timeout/i.test(message);
721
- }
722
-
723
- private isCodexEnvironmentError(error: unknown): boolean {
724
- const message = error instanceof Error ? error.message : String(error || '');
725
- return /error finding codex home|could not update path: no such file or directory/i.test(message);
726
- }
727
-
728
- private recoverCodexEnvironment(error: unknown): void {
729
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
730
- this.log(`recovering codex environment after error: ${message}`);
731
- this.threadCache.clear();
732
- this.codex = null;
733
- this.codexInit = null;
734
- this.zDotDir = null;
735
- }
736
-
737
- private shouldApplyProcessCwdFallback(error: unknown, options?: CodexRunOptions): boolean {
738
- const workingDirectory = this.resolveProcessWorkingDirectory(options);
739
- if (!workingDirectory) {
740
- return false;
741
- }
742
- const message = error instanceof Error ? error.message : String(error || '');
743
- return /no such file or directory \(os error 2\)/i.test(message);
744
- }
745
-
746
- private resolveProcessWorkingDirectory(options?: CodexRunOptions): string {
747
- return this.normalizeOptionalString(options?.processWorkingDirectory || options?.threadOptions?.workingDirectory);
748
- }
749
-
750
- private applyProcessCwdFallback(options?: CodexRunOptions): CodexRunOptions {
751
- const nextThreadOptions: CodexThreadOptions = {
752
- ...(options?.threadOptions || {})
753
- };
754
- delete nextThreadOptions.workingDirectory;
755
- return {
756
- ...(options || {}),
757
- threadOptions: nextThreadOptions
758
- };
759
- }
760
-
761
- private async withProcessWorkingDirectoryFallback<T>(workingDirectory: string, runner: () => Promise<T>): Promise<T> {
762
- const normalizedWorkingDirectory = this.normalizeOptionalString(workingDirectory);
763
- if (!normalizedWorkingDirectory) {
764
- return await runner();
765
- }
766
-
767
- while (CodexClient.cwdFallbackRunning) {
768
- await this.sleep(50);
769
- }
770
- CodexClient.cwdFallbackRunning = true;
771
-
772
- const originalCwd = process.cwd();
773
- try {
774
- process.chdir(normalizedWorkingDirectory);
775
- this.log(`running Codex fallback from process cwd ${normalizedWorkingDirectory}`);
776
- return await runner();
777
- }
778
- finally {
779
- try {
780
- process.chdir(originalCwd);
781
- }
782
- catch (error) {
783
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
784
- this.log(`failed to restore process cwd to ${originalCwd}: ${message}`);
785
- }
786
- CodexClient.cwdFallbackRunning = false;
787
- }
788
- }
789
-
790
- private normalizeOptionalString(value: any): string {
791
- return typeof value === 'string' ? value.trim() : '';
792
- }
793
-
794
- private resolveModelUnavailableTtlMs(): number {
795
- const raw = Number(
796
- process.env.AI_DASHBOARD_CODEX_MODEL_UNAVAILABLE_TTL_MS
797
- || process.env.AI_ASSISTANT_CODEX_MODEL_UNAVAILABLE_TTL_MS
798
- );
799
- if (Number.isFinite(raw) && raw >= CodexClient.MIN_MODEL_UNAVAILABLE_TTL_MS) {
800
- return Math.floor(raw);
801
- }
802
- return CodexClient.DEFAULT_MODEL_UNAVAILABLE_TTL_MS;
803
- }
804
-
805
- private async ensureModelFallbackPreferencesLoaded(): Promise<void> {
806
- if (CodexClient.modelFallbackPreferencesLoaded) {
807
- this.pruneModelFallbackPreferences();
808
- return;
809
- }
810
- if (CodexClient.modelFallbackPreferencesLoadPromise !== null) {
811
- await CodexClient.modelFallbackPreferencesLoadPromise;
812
- this.pruneModelFallbackPreferences();
813
- return;
814
- }
815
- CodexClient.modelFallbackPreferencesLoadPromise = (async () => {
816
- try {
817
- const raw = await fs.readFile(CodexClient.MODEL_UNAVAILABLE_FALLBACK_FILE, 'utf8');
818
- const parsed = JSON.parse(raw);
819
- if (!parsed || typeof parsed !== 'object' || Array.isArray(parsed)) {
820
- return;
821
- }
822
- Object.entries(parsed).forEach(([model, entry]) => {
823
- const key = this.normalizeOptionalString(model);
824
- if (!key) {
825
- return;
826
- }
827
- const fallbackModel = this.normalizeOptionalString((entry as any)?.fallbackModel);
828
- const expiresAt = Number((entry as any)?.expiresAt);
829
- const updatedAt = Number((entry as any)?.updatedAt);
830
- if (!fallbackModel || !Number.isFinite(expiresAt) || expiresAt <= Date.now()) {
831
- return;
832
- }
833
- CodexClient.modelFallbackPreferences.set(key, {
834
- fallbackModel,
835
- expiresAt: Math.floor(expiresAt),
836
- updatedAt: Number.isFinite(updatedAt) ? Math.floor(updatedAt) : Date.now()
837
- });
838
- });
839
- }
840
- catch {
841
- // Ignore cache load errors.
842
- }
843
- finally {
844
- CodexClient.modelFallbackPreferencesLoaded = true;
845
- CodexClient.modelFallbackPreferencesLoadPromise = null;
846
- }
847
- })();
848
- await CodexClient.modelFallbackPreferencesLoadPromise;
849
- this.pruneModelFallbackPreferences();
850
- }
851
-
852
- private pruneModelFallbackPreferences(now = Date.now()): void {
853
- Array.from(CodexClient.modelFallbackPreferences.entries()).forEach(([model, entry]) => {
854
- if (!entry || !Number.isFinite(entry.expiresAt) || entry.expiresAt <= now) {
855
- CodexClient.modelFallbackPreferences.delete(model);
856
- }
857
- });
858
- }
859
-
860
- private getModelFallbackPreference(model: string): string {
861
- const normalizedModel = this.normalizeOptionalString(model);
862
- if (!normalizedModel) {
863
- return '';
864
- }
865
- this.pruneModelFallbackPreferences();
866
- const entry = CodexClient.modelFallbackPreferences.get(normalizedModel);
867
- if (!entry || entry.expiresAt <= Date.now()) {
868
- if (entry) {
869
- CodexClient.modelFallbackPreferences.delete(normalizedModel);
870
- }
871
- return '';
872
- }
873
- return entry.fallbackModel;
874
- }
875
-
876
- private async rememberModelFallbackPreference(model: string, fallbackModel: string): Promise<void> {
877
- const normalizedModel = this.normalizeOptionalString(model);
878
- const normalizedFallback = this.normalizeOptionalString(fallbackModel);
879
- if (!normalizedModel || !normalizedFallback || normalizedModel === normalizedFallback) {
880
- return;
881
- }
882
- const now = Date.now();
883
- CodexClient.modelFallbackPreferences.set(normalizedModel, {
884
- fallbackModel: normalizedFallback,
885
- expiresAt: now + this.modelUnavailableTtlMs,
886
- updatedAt: now
887
- });
888
- this.pruneModelFallbackPreferences(now);
889
- await this.persistModelFallbackPreferences();
890
- }
891
-
892
- private async clearModelFallbackPreference(model: string): Promise<void> {
893
- const normalizedModel = this.normalizeOptionalString(model);
894
- if (!normalizedModel) {
895
- return;
896
- }
897
- if (!CodexClient.modelFallbackPreferences.has(normalizedModel)) {
898
- return;
899
- }
900
- CodexClient.modelFallbackPreferences.delete(normalizedModel);
901
- await this.persistModelFallbackPreferences();
902
- }
903
-
904
- private async persistModelFallbackPreferences(): Promise<void> {
905
- this.pruneModelFallbackPreferences();
906
- if (!CodexClient.modelFallbackPreferences.size) {
907
- try {
908
- await fs.unlink(CodexClient.MODEL_UNAVAILABLE_FALLBACK_FILE);
909
- }
910
- catch {
911
- // Ignore file cleanup errors.
912
- }
913
- return;
914
- }
915
- const serialized: Record<string, CodexModelFallbackPreference> = {};
916
- CodexClient.modelFallbackPreferences.forEach((entry, model) => {
917
- serialized[model] = entry;
918
- });
919
- try {
920
- await fs.writeFile(CodexClient.MODEL_UNAVAILABLE_FALLBACK_FILE, JSON.stringify(serialized), 'utf8');
921
- }
922
- catch {
923
- // Ignore cache persistence errors.
924
- }
925
- }
926
-
927
- private async sleep(ms: number): Promise<void> {
928
- await sleepTimeout(ms);
929
- }
930
-
931
- private async ensureCodex(): Promise<void> {
932
- if (this.codex) {
933
- return;
934
- }
935
- if (this.codexInit !== null) {
936
- await this.codexInit;
937
- return;
938
- }
939
- this.codexInit = (async () => {
940
- this.log('Loading AI SDK module...');
941
- const importer = new Function('specifier', 'return import(specifier)') as DynamicImport;
942
- const mod = await importer('@openai/codex-sdk');
943
- const CodexCtor = mod?.Codex || mod?.default?.Codex || mod?.default || mod;
944
- if (!CodexCtor) {
945
- throw new Error('AI SDK export not found.');
946
- }
947
- this.log('AI SDK module loaded.');
948
- const env = await this.buildCodexEnv();
949
- this.codex = new CodexCtor({
950
- apiKey: this.config.apiKey,
951
- baseUrl: this.config.baseUrl,
952
- model: this.config.model,
953
- env
954
- });
955
- this.log('AI client initialized.');
956
- })();
957
- await this.codexInit;
958
- }
959
-
960
- private log(message: string): void {
961
- if (!this.debugEnabled) {
962
- return;
963
- }
964
- console.log(`[AI-Dashboard][AI] ${message}`);
965
- }
966
-
967
- private resolveDefaultTimeoutMs(): number {
968
- const raw = Number(process.env.AI_DASHBOARD_CODEX_TIMEOUT_MS || process.env.AI_DASHBOARD_AGENT_TIMEOUT_MS);
969
- if (Number.isFinite(raw) && raw > 0) {
970
- return Math.floor(raw);
971
- }
972
- return 600000;
973
- }
974
-
975
- private resolveStreamEnabled(): boolean {
976
- const raw = (process.env.AI_DASHBOARD_CODEX_STREAM || '').trim().toLowerCase();
977
- if (!raw) {
978
- return this.debugEnabled;
979
- }
980
- if (['true', '1', 'yes', 'y', 'on'].includes(raw)) {
981
- return true;
982
- }
983
- if (['false', '0', 'no', 'n', 'off'].includes(raw)) {
984
- return false;
985
- }
986
- return this.debugEnabled;
987
- }
988
-
989
- private resolveCleanZdotdirEnabled(): boolean {
990
- const raw = (process.env.AI_DASHBOARD_CODEX_CLEAN_ZDOTDIR ?? '').trim().toLowerCase();
991
- if (!raw) {
992
- return true;
993
- }
994
- if (['false', '0', 'no', 'n', 'off'].includes(raw)) {
995
- return false;
996
- }
997
- if (['true', '1', 'yes', 'y', 'on'].includes(raw)) {
998
- return true;
999
- }
1000
- return true;
1001
- }
1002
-
1003
- private async buildCodexEnv(): Promise<Record<string, string>> {
1004
- const env: Record<string, string> = {};
1005
- for (const [key, value] of Object.entries(process.env)) {
1006
- if (typeof value === 'string') {
1007
- env[key] = value;
1008
- }
1009
- }
1010
- if (!this.normalizeOptionalString(env.HOME)) {
1011
- const fallbackHome = this.normalizeOptionalString(process.env.HOME || os.homedir());
1012
- if (fallbackHome) {
1013
- env.HOME = fallbackHome;
1014
- }
1015
- }
1016
- await this.ensureCodexHome(env);
1017
- if (this.cleanZdotdirEnabled) {
1018
- env.ZDOTDIR = await this.ensureZdotdir();
1019
- }
1020
- return env;
1021
- }
1022
-
1023
- private async ensureCodexHome(env: Record<string, string>): Promise<void> {
1024
- const current = this.normalizeOptionalString(env.CODEX_HOME || process.env.CODEX_HOME);
1025
- const homeRoot = this.normalizeOptionalString(env.HOME || process.env.HOME || os.homedir());
1026
- const primary = current || (homeRoot ? path.join(homeRoot, '.codex') : path.join(os.tmpdir(), 'resolveio-codex-home'));
1027
- try {
1028
- await fs.mkdir(path.join(primary, 'sessions'), { recursive: true });
1029
- env.CODEX_HOME = primary;
1030
- process.env.CODEX_HOME = primary;
1031
- return;
1032
- }
1033
- catch {
1034
- const fallback = path.join(os.tmpdir(), 'resolveio-codex-home');
1035
- await fs.mkdir(path.join(fallback, 'sessions'), { recursive: true });
1036
- env.CODEX_HOME = fallback;
1037
- process.env.CODEX_HOME = fallback;
1038
- }
1039
- }
1040
-
1041
- private async ensureZdotdir(): Promise<string> {
1042
- if (this.zDotDir) {
1043
- return this.zDotDir;
1044
- }
1045
- const override = (process.env.AI_DASHBOARD_CODEX_ZDOTDIR || '').trim();
1046
- const dir = override || path.join(os.tmpdir(), 'codex-zdotdir');
1047
- await fs.mkdir(dir, { recursive: true });
1048
- await Promise.allSettled([
1049
- fs.writeFile(path.join(dir, '.zshrc'), '', { flag: 'a' }),
1050
- fs.writeFile(path.join(dir, '.zprofile'), '', { flag: 'a' })
1051
- ]);
1052
- this.zDotDir = dir;
1053
- return dir;
1054
- }
1055
-
1056
- private resolvePingEnabled(): boolean {
1057
- return this.normalizeBoolean(process.env.AI_DASHBOARD_CODEX_PING, false);
1058
- }
1059
-
1060
- private resolvePingTimeoutMs(): number {
1061
- const raw = Number(process.env.AI_DASHBOARD_CODEX_PING_TIMEOUT_MS);
1062
- if (Number.isFinite(raw) && raw > 0) {
1063
- return Math.floor(raw);
1064
- }
1065
- return 10000;
1066
- }
1067
-
1068
- private resolveDefaultThreadOptions(): CodexThreadOptions {
1069
- const approvalPolicy = this.normalizeApprovalPolicy(process.env.AI_DASHBOARD_CODEX_APPROVAL_POLICY);
1070
- const sandboxMode = this.normalizeSandboxMode(process.env.AI_DASHBOARD_CODEX_SANDBOX_MODE, 'workspace-write');
1071
- const skipGitRepoCheck = this.normalizeBoolean(process.env.AI_DASHBOARD_CODEX_SKIP_GIT_CHECK, true);
1072
- const webSearchMode = this.normalizeWebSearchMode(process.env.AI_DASHBOARD_CODEX_WEB_SEARCH_MODE);
1073
- const webSearchEnabled = this.normalizeBoolean(process.env.AI_DASHBOARD_CODEX_WEB_SEARCH_ENABLED, false);
1074
- const networkAccessEnabled = this.normalizeBoolean(process.env.AI_DASHBOARD_CODEX_NETWORK_ACCESS_ENABLED, false);
1075
- const modelReasoningEffort = this.normalizeModelReasoningEffort(process.env.AI_DASHBOARD_CODEX_REASONING_EFFORT);
1076
- return {
1077
- model: this.config.model,
1078
- approvalPolicy,
1079
- sandboxMode,
1080
- skipGitRepoCheck,
1081
- webSearchMode,
1082
- webSearchEnabled,
1083
- networkAccessEnabled,
1084
- modelReasoningEffort
1085
- };
1086
- }
1087
-
1088
- private mergeThreadOptions(overrides?: CodexThreadOptions): CodexThreadOptions | undefined {
1089
- const merged: CodexThreadOptions = {
1090
- ...this.defaultThreadOptions,
1091
- ...(overrides || {})
1092
- };
1093
- const effectiveModel = this.normalizeOptionalString(merged.model || this.config.model);
1094
- const normalizedEffort = this.normalizeModelReasoningEffortForModel(effectiveModel, merged.modelReasoningEffort);
1095
- if (normalizedEffort && normalizedEffort !== merged.modelReasoningEffort) {
1096
- this.log(`normalized reasoning effort for model=${effectiveModel || 'default'}: ${merged.modelReasoningEffort} -> ${normalizedEffort}`);
1097
- merged.modelReasoningEffort = normalizedEffort;
1098
- }
1099
- const cleaned = Object.entries(merged).reduce((acc, [key, value]) => {
1100
- if (value === undefined || value === null || value === '') {
1101
- return acc;
1102
- }
1103
- (acc as any)[key] = value;
1104
- return acc;
1105
- }, {} as CodexThreadOptions);
1106
- return Object.keys(cleaned).length ? cleaned : undefined;
1107
- }
1108
-
1109
- private normalizeApprovalPolicy(value?: string): CodexThreadOptions['approvalPolicy'] {
1110
- const normalized = (value || '').trim().toLowerCase();
1111
- if (normalized === 'never' || normalized === 'on-request' || normalized === 'on-failure' || normalized === 'untrusted') {
1112
- return normalized as CodexThreadOptions['approvalPolicy'];
1113
- }
1114
- return 'never';
1115
- }
1116
-
1117
- private normalizeSandboxMode(value?: string, fallback: CodexThreadOptions['sandboxMode'] = 'read-only'): CodexThreadOptions['sandboxMode'] {
1118
- const normalized = (value || '').trim().toLowerCase();
1119
- if (normalized === 'read-only' || normalized === 'workspace-write' || normalized === 'danger-full-access') {
1120
- return normalized as CodexThreadOptions['sandboxMode'];
1121
- }
1122
- return fallback;
1123
- }
1124
-
1125
- private normalizeWebSearchMode(value?: string): CodexThreadOptions['webSearchMode'] | undefined {
1126
- const normalized = (value || '').trim().toLowerCase();
1127
- if (normalized === 'disabled' || normalized === 'cached' || normalized === 'live') {
1128
- return normalized as CodexThreadOptions['webSearchMode'];
1129
- }
1130
- return undefined;
1131
- }
1132
-
1133
- private normalizeModelReasoningEffort(value?: string): CodexThreadOptions['modelReasoningEffort'] | undefined {
1134
- const normalized = (value || '').trim().toLowerCase();
1135
- if (normalized === 'minimal' || normalized === 'none' || normalized === 'low' || normalized === 'medium' || normalized === 'high' || normalized === 'xhigh') {
1136
- return normalized as CodexThreadOptions['modelReasoningEffort'];
1137
- }
1138
- return undefined;
1139
- }
1140
-
1141
- private normalizeModelReasoningEffortForModel(
1142
- model: string,
1143
- effort?: CodexThreadOptions['modelReasoningEffort']
1144
- ): CodexThreadOptions['modelReasoningEffort'] | undefined {
1145
- if (!effort) {
1146
- return effort;
1147
- }
1148
- const normalizedModel = this.normalizeOptionalString(model).toLowerCase();
1149
- if (effort === 'minimal' && (!normalizedModel || normalizedModel.startsWith('gpt-5') || normalizedModel.includes('codex'))) {
1150
- return 'low';
1151
- }
1152
- return effort;
1153
- }
1154
-
1155
- private normalizeBoolean(value: string | undefined, fallback: boolean): boolean {
1156
- if (!value) {
1157
- return fallback;
1158
- }
1159
- const normalized = value.trim().toLowerCase();
1160
- if (['true', '1', 'yes', 'y', 'on'].includes(normalized)) {
1161
- return true;
1162
- }
1163
- if (['false', '0', 'no', 'n', 'off'].includes(normalized)) {
1164
- return false;
1165
- }
1166
- return fallback;
1167
- }
1168
-
1169
- private formatThreadOptions(options: CodexThreadOptions): string {
1170
- const summary: Record<string, string> = {};
1171
- Object.entries(options).forEach(([key, value]) => {
1172
- if (value === undefined || value === null) {
1173
- return;
1174
- }
1175
- summary[key] = String(value);
1176
- });
1177
- return JSON.stringify(summary);
1178
- }
1179
-
1180
- private buildThreadOptionsKey(options?: CodexThreadOptions): string {
1181
- if (!options) {
1182
- return '';
1183
- }
1184
- const ordered: Record<string, string> = {};
1185
- Object.keys(options)
1186
- .sort()
1187
- .forEach((key) => {
1188
- const value = (options as Record<string, unknown>)[key];
1189
- if (value === undefined || value === null) {
1190
- return;
1191
- }
1192
- ordered[key] = Array.isArray(value) ? JSON.stringify(value) : String(value);
1193
- });
1194
- return JSON.stringify(ordered);
1195
- }
1196
-
1197
- private buildThreadCacheKey(threadKey: string | undefined, options?: CodexThreadOptions): string | null {
1198
- if (threadKey) {
1199
- return `thread:${threadKey}`;
1200
- }
1201
- const model = options?.model || this.config.model;
1202
- const workingDirectory = options?.workingDirectory;
1203
- if (!model && !workingDirectory) {
1204
- return null;
1205
- }
1206
- return `thread:auto:${model || 'default'}:${workingDirectory || 'root'}`;
1207
- }
1208
-
1209
- private isPingPrompt(prompt: string): boolean {
1210
- return prompt.trim() === CodexClient.PING_PROMPT;
1211
- }
1212
-
1213
- private async runPing(threadOptions?: CodexThreadOptions): Promise<void> {
1214
- this.log(`runPing start (timeoutMs=${this.pingTimeoutMs})`);
1215
- try {
1216
- const content = await this.runOnce(CodexClient.PING_PROMPT, {
1217
- timeoutMs: this.pingTimeoutMs,
1218
- threadOptions,
1219
- reuseThread: false
1220
- });
1221
- const trimmed = content.trim();
1222
- const preview = trimmed.length > 80 ? `${trimmed.slice(0, 80)}…` : trimmed;
1223
- this.log(`runPing response: ${preview}`);
1224
- }
1225
- catch (error) {
1226
- const message = error instanceof Error ? error.message : String(error || 'Unknown error');
1227
- this.log(`runPing failed: ${message}`);
1228
- throw error;
1229
- }
1230
- }
1231
- }