@resolveio/server-lib 22.3.48 → 22.3.50

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 (687) hide show
  1. package/.nodemon.json +5 -0
  2. package/.vscode/settings.json +21 -0
  3. package/AGENTS.md +189 -0
  4. package/README.md +22 -0
  5. package/build_package.sh +5 -0
  6. package/compileDTS.pl +64 -0
  7. package/docs/ai-assistant-nightly-eval.md +65 -0
  8. package/docs/ai-assistant-preflight-checklist.md +23 -0
  9. package/docs/ai-assistant-report-builder-bridge-playbook.md +115 -0
  10. package/eslint-plugin-custom/index.js +7 -0
  11. package/eslint-plugin-custom/rules/no-filter-zero-index.js +44 -0
  12. package/eslint.config.js +103 -0
  13. package/gulpfile.js +216 -0
  14. package/methodAndPublicationListGenerator.py +375 -0
  15. package/mongodbensurers.js +2 -0
  16. package/mongostop.js +3 -0
  17. package/package.json +1 -1
  18. package/scripts/cleanup-bypassed-callmethod-logs.js +616 -0
  19. package/settings.development.json +25 -0
  20. package/settings.development.redacted.json +25 -0
  21. package/src/.env +12 -0
  22. package/src/ai/assistant-core-heuristics.ts +379 -0
  23. package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +185 -0
  24. package/src/ai/resolveio-platform-intelligence-memory.ts +325 -0
  25. package/{ai/resolveio-platform-intelligence-types.d.ts → src/ai/resolveio-platform-intelligence-types.ts} +20 -15
  26. package/src/ai/resolveio-platform-intelligence.ts +462 -0
  27. package/src/client-server-app.ts +12 -0
  28. package/src/collections/ai-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 +23043 -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 +3354 -0
  167. package/src/services/codex-client.ts +1223 -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/ai-qa-policy.ts +879 -0
  173. package/src/util/ai-runner-artifacts.ts +430 -0
  174. package/src/util/ai-runner-qa-auth.ts +356 -0
  175. package/src/util/ai-runner-qa-tools.ts +650 -0
  176. package/src/util/common.ts +649 -0
  177. package/src/util/customer-portal-password.ts +183 -0
  178. package/src/util/error-reporter.ts +332 -0
  179. package/src/util/error-tracking.ts +79 -0
  180. package/src/util/report-builder-unwinds.ts +180 -0
  181. package/src/util/schema-report-builder.ts +448 -0
  182. package/src/util/slow-query-reporter.ts +216 -0
  183. package/src/util/subscription-dependency-context.ts +1096 -0
  184. package/src/util/tokenizer.ts +38 -0
  185. package/src/workers/codex-runner.worker.ts +142 -0
  186. package/start_server.sh +5 -0
  187. package/tests/ai-assistant-corpus-build.ts +484 -0
  188. package/tests/ai-assistant-corpus-replay-e2e.ts +774 -0
  189. package/tests/ai-assistant-data-parity-e2e.ts +1989 -0
  190. package/tests/ai-assistant-eval-triage.ts +831 -0
  191. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  192. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  193. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  194. package/tests/ai-assistant-routing-eval.test.ts +560 -0
  195. package/tests/ai-assistant-snf-live-eval.ts +975 -0
  196. package/tests/ai-assistant-utils.test.ts +2860 -0
  197. package/tests/ai-runner-contract.test.ts +263 -0
  198. package/tests/error-reporter.test.ts +145 -0
  199. package/tests/method-publication-generator.test.ts +46 -0
  200. package/tests/report-builder-linking.test.ts +79 -0
  201. package/tests/resolveio-platform-intelligence.test.ts +352 -0
  202. package/tests/server-app-cron-owner.test.ts +127 -0
  203. package/tests/subscription-connect-race.test.ts +158 -0
  204. package/tests/subscription-dependency-context.test.ts +324 -0
  205. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  206. package/tests/subscription-manager-invalidation.test.ts +86 -0
  207. package/tsconfig.json +34 -0
  208. package/ai/assistant-core-heuristics.d.ts +0 -11
  209. package/ai/assistant-core-heuristics.js +0 -356
  210. package/ai/assistant-core-heuristics.js.map +0 -1
  211. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +0 -3
  212. package/ai/resolveio-platform-intelligence-memory-corpus.js +0 -214
  213. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +0 -1
  214. package/ai/resolveio-platform-intelligence-memory.d.ts +0 -20
  215. package/ai/resolveio-platform-intelligence-memory.js +0 -341
  216. package/ai/resolveio-platform-intelligence-memory.js.map +0 -1
  217. package/ai/resolveio-platform-intelligence-types.js +0 -4
  218. package/ai/resolveio-platform-intelligence-types.js.map +0 -1
  219. package/ai/resolveio-platform-intelligence.d.ts +0 -6
  220. package/ai/resolveio-platform-intelligence.js +0 -463
  221. package/ai/resolveio-platform-intelligence.js.map +0 -1
  222. package/client-server-app.d.ts +0 -1
  223. package/client-server-app.js +0 -68
  224. package/client-server-app.js.map +0 -1
  225. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  226. package/collections/ai-terminal-conversation.collection.js +0 -140
  227. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  228. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  229. package/collections/ai-terminal-issue-report.collection.js +0 -148
  230. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  231. package/collections/ai-terminal-message.collection.d.ts +0 -2
  232. package/collections/ai-terminal-message.collection.js +0 -121
  233. package/collections/ai-terminal-message.collection.js.map +0 -1
  234. package/collections/app-setting.collection.d.ts +0 -3
  235. package/collections/app-setting.collection.js +0 -103
  236. package/collections/app-setting.collection.js.map +0 -1
  237. package/collections/app-status.collection.d.ts +0 -3
  238. package/collections/app-status.collection.js +0 -57
  239. package/collections/app-status.collection.js.map +0 -1
  240. package/collections/communication-metric.collection.d.ts +0 -2
  241. package/collections/communication-metric.collection.js +0 -133
  242. package/collections/communication-metric.collection.js.map +0 -1
  243. package/collections/counter.collection.d.ts +0 -3
  244. package/collections/counter.collection.js +0 -56
  245. package/collections/counter.collection.js.map +0 -1
  246. package/collections/cron-job-history.collection.d.ts +0 -3
  247. package/collections/cron-job-history.collection.js +0 -137
  248. package/collections/cron-job-history.collection.js.map +0 -1
  249. package/collections/cron-job.collection.d.ts +0 -3
  250. package/collections/cron-job.collection.js +0 -92
  251. package/collections/cron-job.collection.js.map +0 -1
  252. package/collections/customer-notification.collection.d.ts +0 -3
  253. package/collections/customer-notification.collection.js +0 -130
  254. package/collections/customer-notification.collection.js.map +0 -1
  255. package/collections/customer-portal-password.collection.d.ts +0 -3
  256. package/collections/customer-portal-password.collection.js +0 -75
  257. package/collections/customer-portal-password.collection.js.map +0 -1
  258. package/collections/email-history.collection.d.ts +0 -3
  259. package/collections/email-history.collection.js +0 -127
  260. package/collections/email-history.collection.js.map +0 -1
  261. package/collections/email-verified.collection.d.ts +0 -3
  262. package/collections/email-verified.collection.js +0 -62
  263. package/collections/email-verified.collection.js.map +0 -1
  264. package/collections/file.collection.d.ts +0 -3
  265. package/collections/file.collection.js +0 -74
  266. package/collections/file.collection.js.map +0 -1
  267. package/collections/flag-update.collection.d.ts +0 -3
  268. package/collections/flag-update.collection.js +0 -57
  269. package/collections/flag-update.collection.js.map +0 -1
  270. package/collections/flag.collection.d.ts +0 -3
  271. package/collections/flag.collection.js +0 -57
  272. package/collections/flag.collection.js.map +0 -1
  273. package/collections/log-method-latency.collection.d.ts +0 -3
  274. package/collections/log-method-latency.collection.js +0 -77
  275. package/collections/log-method-latency.collection.js.map +0 -1
  276. package/collections/log-subscription.collection.d.ts +0 -3
  277. package/collections/log-subscription.collection.js +0 -80
  278. package/collections/log-subscription.collection.js.map +0 -1
  279. package/collections/log.collection.d.ts +0 -3
  280. package/collections/log.collection.js +0 -93
  281. package/collections/log.collection.js.map +0 -1
  282. package/collections/logged-in-users.collection.d.ts +0 -3
  283. package/collections/logged-in-users.collection.js +0 -67
  284. package/collections/logged-in-users.collection.js.map +0 -1
  285. package/collections/monitor-cpu.collection.d.ts +0 -3
  286. package/collections/monitor-cpu.collection.js +0 -65
  287. package/collections/monitor-cpu.collection.js.map +0 -1
  288. package/collections/monitor-function.collection.d.ts +0 -3
  289. package/collections/monitor-function.collection.js +0 -74
  290. package/collections/monitor-function.collection.js.map +0 -1
  291. package/collections/monitor-memory.collection.d.ts +0 -3
  292. package/collections/monitor-memory.collection.js +0 -77
  293. package/collections/monitor-memory.collection.js.map +0 -1
  294. package/collections/monitor-mongo.collection.d.ts +0 -3
  295. package/collections/monitor-mongo.collection.js +0 -71
  296. package/collections/monitor-mongo.collection.js.map +0 -1
  297. package/collections/notification.collection.d.ts +0 -3
  298. package/collections/notification.collection.js +0 -57
  299. package/collections/notification.collection.js.map +0 -1
  300. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  301. package/collections/openai-usage-ledger.collection.js +0 -124
  302. package/collections/openai-usage-ledger.collection.js.map +0 -1
  303. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  304. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  305. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  306. package/collections/report-builder-library.collection.d.ts +0 -3
  307. package/collections/report-builder-library.collection.js +0 -87
  308. package/collections/report-builder-library.collection.js.map +0 -1
  309. package/collections/report-builder-report.collection.d.ts +0 -4
  310. package/collections/report-builder-report.collection.js +0 -184
  311. package/collections/report-builder-report.collection.js.map +0 -1
  312. package/collections/user-group.collection.d.ts +0 -4
  313. package/collections/user-group.collection.js +0 -89
  314. package/collections/user-group.collection.js.map +0 -1
  315. package/collections/user-guide.collection.d.ts +0 -3
  316. package/collections/user-guide.collection.js +0 -57
  317. package/collections/user-guide.collection.js.map +0 -1
  318. package/collections/user.collection.d.ts +0 -4
  319. package/collections/user.collection.js +0 -180
  320. package/collections/user.collection.js.map +0 -1
  321. package/cron/cron.d.ts +0 -14
  322. package/cron/cron.js +0 -216
  323. package/cron/cron.js.map +0 -1
  324. package/fixtures/cron-jobs.d.ts +0 -1
  325. package/fixtures/cron-jobs.js +0 -150
  326. package/fixtures/cron-jobs.js.map +0 -1
  327. package/fixtures/init.d.ts +0 -1
  328. package/fixtures/init.js +0 -91
  329. package/fixtures/init.js.map +0 -1
  330. package/http/auth.d.ts +0 -2
  331. package/http/auth.js +0 -906
  332. package/http/auth.js.map +0 -1
  333. package/http/health.d.ts +0 -1
  334. package/http/health.js +0 -11
  335. package/http/health.js.map +0 -1
  336. package/http/home.d.ts +0 -1
  337. package/http/home.js +0 -134
  338. package/http/home.js.map +0 -1
  339. package/http/slow-query-publication.d.ts +0 -2
  340. package/http/slow-query-publication.js +0 -99
  341. package/http/slow-query-publication.js.map +0 -1
  342. package/index.d.ts +0 -1
  343. package/index.js +0 -19
  344. package/index.js.map +0 -1
  345. package/managers/ai-assistant-codex-manager.manager.d.ts +0 -67
  346. package/managers/ai-assistant-codex-manager.manager.js +0 -1113
  347. package/managers/ai-assistant-codex-manager.manager.js.map +0 -1
  348. package/managers/communication-metric.manager.d.ts +0 -16
  349. package/managers/communication-metric.manager.js +0 -134
  350. package/managers/communication-metric.manager.js.map +0 -1
  351. package/managers/cron.manager.d.ts +0 -20
  352. package/managers/cron.manager.js +0 -534
  353. package/managers/cron.manager.js.map +0 -1
  354. package/managers/customer-notification-content.manager.d.ts +0 -55
  355. package/managers/customer-notification-content.manager.js +0 -158
  356. package/managers/customer-notification-content.manager.js.map +0 -1
  357. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  358. package/managers/diagnostic-manager-bootstrap.js +0 -260
  359. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  360. package/managers/error-auto-fix.manager.d.ts +0 -149
  361. package/managers/error-auto-fix.manager.js +0 -3064
  362. package/managers/error-auto-fix.manager.js.map +0 -1
  363. package/managers/local-log.manager.d.ts +0 -18
  364. package/managers/local-log.manager.js +0 -88
  365. package/managers/local-log.manager.js.map +0 -1
  366. package/managers/method.manager.d.ts +0 -83
  367. package/managers/method.manager.js +0 -1941
  368. package/managers/method.manager.js.map +0 -1
  369. package/managers/mongo.manager.d.ts +0 -224
  370. package/managers/mongo.manager.js +0 -5000
  371. package/managers/mongo.manager.js.map +0 -1
  372. package/managers/monitor.manager.d.ts +0 -70
  373. package/managers/monitor.manager.js +0 -550
  374. package/managers/monitor.manager.js.map +0 -1
  375. package/managers/openai-usage-ledger.manager.d.ts +0 -15
  376. package/managers/openai-usage-ledger.manager.js +0 -144
  377. package/managers/openai-usage-ledger.manager.js.map +0 -1
  378. package/managers/slow-query-verifier.manager.d.ts +0 -144
  379. package/managers/slow-query-verifier.manager.js +0 -3857
  380. package/managers/slow-query-verifier.manager.js.map +0 -1
  381. package/managers/slow-query.manager.d.ts +0 -28
  382. package/managers/slow-query.manager.js +0 -468
  383. package/managers/slow-query.manager.js.map +0 -1
  384. package/managers/subscription.manager.d.ts +0 -169
  385. package/managers/subscription.manager.js +0 -3434
  386. package/managers/subscription.manager.js.map +0 -1
  387. package/managers/websocket.manager.d.ts +0 -73
  388. package/managers/websocket.manager.js +0 -673
  389. package/managers/websocket.manager.js.map +0 -1
  390. package/managers/worker-dispatcher.manager.d.ts +0 -120
  391. package/managers/worker-dispatcher.manager.js +0 -1266
  392. package/managers/worker-dispatcher.manager.js.map +0 -1
  393. package/managers/worker-server.manager.d.ts +0 -35
  394. package/managers/worker-server.manager.js +0 -582
  395. package/managers/worker-server.manager.js.map +0 -1
  396. package/methods/accounts.d.ts +0 -2
  397. package/methods/accounts.js +0 -624
  398. package/methods/accounts.js.map +0 -1
  399. package/methods/ai-terminal.d.ts +0 -336
  400. package/methods/ai-terminal.js +0 -22782
  401. package/methods/ai-terminal.js.map +0 -1
  402. package/methods/app-settings.d.ts +0 -2
  403. package/methods/app-settings.js +0 -169
  404. package/methods/app-settings.js.map +0 -1
  405. package/methods/aws.d.ts +0 -2
  406. package/methods/aws.js +0 -877
  407. package/methods/aws.js.map +0 -1
  408. package/methods/collections.d.ts +0 -2
  409. package/methods/collections.js +0 -719
  410. package/methods/collections.js.map +0 -1
  411. package/methods/counters.d.ts +0 -2
  412. package/methods/counters.js +0 -113
  413. package/methods/counters.js.map +0 -1
  414. package/methods/cron-jobs.d.ts +0 -2
  415. package/methods/cron-jobs.js +0 -2475
  416. package/methods/cron-jobs.js.map +0 -1
  417. package/methods/customer-notifications.d.ts +0 -2
  418. package/methods/customer-notifications.js +0 -528
  419. package/methods/customer-notifications.js.map +0 -1
  420. package/methods/diagnostics.d.ts +0 -2
  421. package/methods/diagnostics.js +0 -703
  422. package/methods/diagnostics.js.map +0 -1
  423. package/methods/flag-updates.d.ts +0 -2
  424. package/methods/flag-updates.js +0 -8
  425. package/methods/flag-updates.js.map +0 -1
  426. package/methods/flags.d.ts +0 -2
  427. package/methods/flags.js +0 -8
  428. package/methods/flags.js.map +0 -1
  429. package/methods/logs.d.ts +0 -2
  430. package/methods/logs.js +0 -751
  431. package/methods/logs.js.map +0 -1
  432. package/methods/mongo-explorer.d.ts +0 -2
  433. package/methods/mongo-explorer.js +0 -1808
  434. package/methods/mongo-explorer.js.map +0 -1
  435. package/methods/monitor.d.ts +0 -2
  436. package/methods/monitor.js +0 -543
  437. package/methods/monitor.js.map +0 -1
  438. package/methods/pdf.d.ts +0 -2
  439. package/methods/pdf.js +0 -1216
  440. package/methods/pdf.js.map +0 -1
  441. package/methods/publications.d.ts +0 -1
  442. package/methods/publications.js +0 -183
  443. package/methods/publications.js.map +0 -1
  444. package/methods/report-builder.d.ts +0 -2
  445. package/methods/report-builder.js +0 -3094
  446. package/methods/report-builder.js.map +0 -1
  447. package/methods/support.d.ts +0 -2
  448. package/methods/support.js +0 -430
  449. package/methods/support.js.map +0 -1
  450. package/models/ai-terminal-conversation.model.d.ts +0 -17
  451. package/models/ai-terminal-conversation.model.js +0 -4
  452. package/models/ai-terminal-conversation.model.js.map +0 -1
  453. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  454. package/models/ai-terminal-issue-report.model.js +0 -4
  455. package/models/ai-terminal-issue-report.model.js.map +0 -1
  456. package/models/ai-terminal-message.model.d.ts +0 -22
  457. package/models/ai-terminal-message.model.js +0 -4
  458. package/models/ai-terminal-message.model.js.map +0 -1
  459. package/models/app-setting.model.d.ts +0 -16
  460. package/models/app-setting.model.js +0 -4
  461. package/models/app-setting.model.js.map +0 -1
  462. package/models/app-status.model.js +0 -4
  463. package/models/app-status.model.js.map +0 -1
  464. package/models/billing-logged-in-users.model.js +0 -4
  465. package/models/billing-logged-in-users.model.js.map +0 -1
  466. package/models/collection-document.model.d.ts +0 -21
  467. package/models/collection-document.model.js +0 -4
  468. package/models/collection-document.model.js.map +0 -1
  469. package/models/communication-metric.model.d.ts +0 -20
  470. package/models/communication-metric.model.js +0 -4
  471. package/models/communication-metric.model.js.map +0 -1
  472. package/models/counter.model.js +0 -4
  473. package/models/counter.model.js.map +0 -1
  474. package/models/cron-job-history.model.d.ts +0 -15
  475. package/models/cron-job-history.model.js +0 -4
  476. package/models/cron-job-history.model.js.map +0 -1
  477. package/models/cron-job.model.d.ts +0 -14
  478. package/models/cron-job.model.js +0 -4
  479. package/models/cron-job.model.js.map +0 -1
  480. package/models/customer-notification.model.d.ts +0 -26
  481. package/models/customer-notification.model.js +0 -4
  482. package/models/customer-notification.model.js.map +0 -1
  483. package/models/customer-portal-password.model.d.ts +0 -11
  484. package/models/customer-portal-password.model.js +0 -4
  485. package/models/customer-portal-password.model.js.map +0 -1
  486. package/models/dialog.model.d.ts +0 -23
  487. package/models/dialog.model.js +0 -4
  488. package/models/dialog.model.js.map +0 -1
  489. package/models/email-history.model.d.ts +0 -31
  490. package/models/email-history.model.js.map +0 -1
  491. package/models/email-verified.model.js +0 -4
  492. package/models/email-verified.model.js.map +0 -1
  493. package/models/file.model.js +0 -4
  494. package/models/file.model.js.map +0 -1
  495. package/models/flag-update.model.js +0 -4
  496. package/models/flag-update.model.js.map +0 -1
  497. package/models/flag.model.js +0 -4
  498. package/models/flag.model.js.map +0 -1
  499. package/models/log-method-latency.model.d.ts +0 -10
  500. package/models/log-method-latency.model.js +0 -4
  501. package/models/log-method-latency.model.js.map +0 -1
  502. package/models/log-subscription.model.js +0 -4
  503. package/models/log-subscription.model.js.map +0 -1
  504. package/models/log.model.d.ts +0 -17
  505. package/models/log.model.js +0 -4
  506. package/models/log.model.js.map +0 -1
  507. package/models/logged-in-users.model.js +0 -4
  508. package/models/logged-in-users.model.js.map +0 -1
  509. package/models/method-response.model.js +0 -4
  510. package/models/method-response.model.js.map +0 -1
  511. package/models/method.model.d.ts +0 -26
  512. package/models/method.model.js +0 -4
  513. package/models/method.model.js.map +0 -1
  514. package/models/monitor-cpu.model.js +0 -4
  515. package/models/monitor-cpu.model.js.map +0 -1
  516. package/models/monitor-function.model.d.ts +0 -14
  517. package/models/monitor-function.model.js +0 -4
  518. package/models/monitor-function.model.js.map +0 -1
  519. package/models/monitor-memory.model.d.ts +0 -15
  520. package/models/monitor-memory.model.js +0 -4
  521. package/models/monitor-memory.model.js.map +0 -1
  522. package/models/monitor-mongo.model.d.ts +0 -13
  523. package/models/monitor-mongo.model.js +0 -4
  524. package/models/monitor-mongo.model.js.map +0 -1
  525. package/models/notification.model.js +0 -4
  526. package/models/notification.model.js.map +0 -1
  527. package/models/openai-usage-ledger.model.d.ts +0 -15
  528. package/models/openai-usage-ledger.model.js +0 -4
  529. package/models/openai-usage-ledger.model.js.map +0 -1
  530. package/models/pagination.model.d.ts +0 -11
  531. package/models/pagination.model.js +0 -28
  532. package/models/pagination.model.js.map +0 -1
  533. package/models/permission.model.d.ts +0 -12
  534. package/models/permission.model.js +0 -4
  535. package/models/permission.model.js.map +0 -1
  536. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  537. package/models/report-builder-dashboard-builder.model.js +0 -4
  538. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  539. package/models/report-builder-library.model.d.ts +0 -17
  540. package/models/report-builder-library.model.js +0 -4
  541. package/models/report-builder-library.model.js.map +0 -1
  542. package/models/report-builder-report.model.d.ts +0 -121
  543. package/models/report-builder-report.model.js +0 -4
  544. package/models/report-builder-report.model.js.map +0 -1
  545. package/models/report-builder.model.d.ts +0 -61
  546. package/models/report-builder.model.js +0 -4
  547. package/models/report-builder.model.js.map +0 -1
  548. package/models/select-data-label.model.d.ts +0 -9
  549. package/models/select-data-label.model.js +0 -4
  550. package/models/select-data-label.model.js.map +0 -1
  551. package/models/server-message.model.d.ts +0 -32
  552. package/models/server-message.model.js +0 -4
  553. package/models/server-message.model.js.map +0 -1
  554. package/models/slow-query-report.model.d.ts +0 -23
  555. package/models/slow-query-report.model.js +0 -4
  556. package/models/slow-query-report.model.js.map +0 -1
  557. package/models/subscription.model.d.ts +0 -31
  558. package/models/subscription.model.js +0 -4
  559. package/models/subscription.model.js.map +0 -1
  560. package/models/support-ticket.model.d.ts +0 -87
  561. package/models/support-ticket.model.js +0 -4
  562. package/models/support-ticket.model.js.map +0 -1
  563. package/models/user-group.model.d.ts +0 -20
  564. package/models/user-group.model.js +0 -4
  565. package/models/user-group.model.js.map +0 -1
  566. package/models/user-guide.model.js +0 -4
  567. package/models/user-guide.model.js.map +0 -1
  568. package/models/user.model.d.ts +0 -84
  569. package/models/user.model.js +0 -4
  570. package/models/user.model.js.map +0 -1
  571. package/private/images/ResolveIO.png +0 -0
  572. package/public_api.js +0 -115
  573. package/public_api.js.map +0 -1
  574. package/publications/ai-terminal.d.ts +0 -1
  575. package/publications/ai-terminal.js +0 -122
  576. package/publications/ai-terminal.js.map +0 -1
  577. package/publications/app-settings.d.ts +0 -2
  578. package/publications/app-settings.js +0 -28
  579. package/publications/app-settings.js.map +0 -1
  580. package/publications/app-status.d.ts +0 -2
  581. package/publications/app-status.js +0 -16
  582. package/publications/app-status.js.map +0 -1
  583. package/publications/cron-jobs.d.ts +0 -2
  584. package/publications/cron-jobs.js +0 -88
  585. package/publications/cron-jobs.js.map +0 -1
  586. package/publications/customer-notifications.d.ts +0 -2
  587. package/publications/customer-notifications.js +0 -161
  588. package/publications/customer-notifications.js.map +0 -1
  589. package/publications/files.d.ts +0 -2
  590. package/publications/files.js +0 -36
  591. package/publications/files.js.map +0 -1
  592. package/publications/flags-update.d.ts +0 -2
  593. package/publications/flags-update.js +0 -22
  594. package/publications/flags-update.js.map +0 -1
  595. package/publications/flags.d.ts +0 -2
  596. package/publications/flags.js +0 -22
  597. package/publications/flags.js.map +0 -1
  598. package/publications/logs.d.ts +0 -2
  599. package/publications/logs.js +0 -164
  600. package/publications/logs.js.map +0 -1
  601. package/publications/notifications.d.ts +0 -2
  602. package/publications/notifications.js +0 -16
  603. package/publications/notifications.js.map +0 -1
  604. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  605. package/publications/report-builder-dashboard-builders.js +0 -42
  606. package/publications/report-builder-dashboard-builders.js.map +0 -1
  607. package/publications/report-builder-libraries.d.ts +0 -2
  608. package/publications/report-builder-libraries.js +0 -90
  609. package/publications/report-builder-libraries.js.map +0 -1
  610. package/publications/report-builder-reports.d.ts +0 -2
  611. package/publications/report-builder-reports.js +0 -50
  612. package/publications/report-builder-reports.js.map +0 -1
  613. package/publications/super-admin.d.ts +0 -2
  614. package/publications/super-admin.js +0 -16
  615. package/publications/super-admin.js.map +0 -1
  616. package/publications/user-groups.d.ts +0 -1
  617. package/publications/user-groups.js +0 -16
  618. package/publications/user-groups.js.map +0 -1
  619. package/publications/user-guides.d.ts +0 -1
  620. package/publications/user-guides.js +0 -16
  621. package/publications/user-guides.js.map +0 -1
  622. package/resolveio-server-app.d.ts +0 -70
  623. package/resolveio-server-app.js +0 -801
  624. package/resolveio-server-app.js.map +0 -1
  625. package/server-app.d.ts +0 -228
  626. package/server-app.js +0 -3566
  627. package/server-app.js.map +0 -1
  628. package/services/codex-client.d.ts +0 -126
  629. package/services/codex-client.js +0 -1622
  630. package/services/codex-client.js.map +0 -1
  631. package/services/openai-client.d.ts +0 -46
  632. package/services/openai-client.js +0 -318
  633. package/services/openai-client.js.map +0 -1
  634. package/types/error-report.d.ts +0 -25
  635. package/types/error-report.js +0 -4
  636. package/types/error-report.js.map +0 -1
  637. package/types/slow-query-report.d.ts +0 -27
  638. package/types/slow-query-report.js +0 -6
  639. package/types/slow-query-report.js.map +0 -1
  640. package/util/ai-qa-policy.d.ts +0 -119
  641. package/util/ai-qa-policy.js +0 -650
  642. package/util/ai-qa-policy.js.map +0 -1
  643. package/util/ai-runner-artifacts.d.ts +0 -74
  644. package/util/ai-runner-artifacts.js +0 -531
  645. package/util/ai-runner-artifacts.js.map +0 -1
  646. package/util/ai-runner-qa-auth.d.ts +0 -5
  647. package/util/ai-runner-qa-auth.js +0 -357
  648. package/util/ai-runner-qa-auth.js.map +0 -1
  649. package/util/ai-runner-qa-tools.d.ts +0 -16
  650. package/util/ai-runner-qa-tools.js +0 -635
  651. package/util/ai-runner-qa-tools.js.map +0 -1
  652. package/util/common.d.ts +0 -31
  653. package/util/common.js +0 -683
  654. package/util/common.js.map +0 -1
  655. package/util/customer-portal-password.d.ts +0 -13
  656. package/util/customer-portal-password.js +0 -209
  657. package/util/customer-portal-password.js.map +0 -1
  658. package/util/error-reporter.d.ts +0 -52
  659. package/util/error-reporter.js +0 -326
  660. package/util/error-reporter.js.map +0 -1
  661. package/util/error-tracking.d.ts +0 -13
  662. package/util/error-tracking.js +0 -120
  663. package/util/error-tracking.js.map +0 -1
  664. package/util/report-builder-unwinds.d.ts +0 -15
  665. package/util/report-builder-unwinds.js +0 -156
  666. package/util/report-builder-unwinds.js.map +0 -1
  667. package/util/schema-report-builder.d.ts +0 -6
  668. package/util/schema-report-builder.js +0 -481
  669. package/util/schema-report-builder.js.map +0 -1
  670. package/util/slow-query-reporter.d.ts +0 -28
  671. package/util/slow-query-reporter.js +0 -226
  672. package/util/slow-query-reporter.js.map +0 -1
  673. package/util/subscription-dependency-context.d.ts +0 -34
  674. package/util/subscription-dependency-context.js +0 -1283
  675. package/util/subscription-dependency-context.js.map +0 -1
  676. package/util/tokenizer.d.ts +0 -5
  677. package/util/tokenizer.js +0 -41
  678. package/util/tokenizer.js.map +0 -1
  679. package/workers/codex-runner.worker.d.ts +0 -1
  680. package/workers/codex-runner.worker.js +0 -192
  681. package/workers/codex-runner.worker.js.map +0 -1
  682. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  683. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  684. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  685. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  686. /package/{private → src/private}/email-templates/support-ticket.html +0 -0
  687. /package/{public_api.d.ts → src/public_api.ts} +0 -0
@@ -1,1622 +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 __asyncValues = (this && this.__asyncValues) || function (o) {
50
- if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
51
- var m = o[Symbol.asyncIterator], i;
52
- return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
53
- function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
54
- function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
55
- };
56
- var __read = (this && this.__read) || function (o, n) {
57
- var m = typeof Symbol === "function" && o[Symbol.iterator];
58
- if (!m) return o;
59
- var i = m.call(o), r, ar = [], e;
60
- try {
61
- while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
62
- }
63
- catch (error) { e = { error: error }; }
64
- finally {
65
- try {
66
- if (r && !r.done && (m = i["return"])) m.call(i);
67
- }
68
- finally { if (e) throw e.error; }
69
- }
70
- return ar;
71
- };
72
- var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
73
- if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
74
- if (ar || !(i in from)) {
75
- if (!ar) ar = Array.prototype.slice.call(from, 0, i);
76
- ar[i] = from[i];
77
- }
78
- }
79
- return to.concat(ar || Array.prototype.slice.call(from));
80
- };
81
- var __values = (this && this.__values) || function(o) {
82
- var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
83
- if (m) return m.call(o);
84
- if (o && typeof o.length === "number") return {
85
- next: function () {
86
- if (o && i >= o.length) o = void 0;
87
- return { value: o && o[i++], done: !o };
88
- }
89
- };
90
- throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
91
- };
92
- Object.defineProperty(exports, "__esModule", { value: true });
93
- exports.CodexClient = void 0;
94
- var fs_1 = require("fs");
95
- var os = require("os");
96
- var path = require("path");
97
- var promises_1 = require("timers/promises");
98
- var CodexClient = /** @class */ (function () {
99
- function CodexClient(config) {
100
- this.codex = null;
101
- this.codexInit = null;
102
- this.threadCache = new Map();
103
- this.debugEnabled = (process.env.AI_DASHBOARD_DEBUG || '').trim().toLowerCase() === 'true';
104
- this.streamEnabled = this.resolveStreamEnabled();
105
- this.cleanZdotdirEnabled = this.resolveCleanZdotdirEnabled();
106
- this.zDotDir = null;
107
- this.defaultTimeoutMs = this.resolveDefaultTimeoutMs();
108
- this.pingEnabled = this.resolvePingEnabled();
109
- this.pingTimeoutMs = this.resolvePingTimeoutMs();
110
- this.modelUnavailableTtlMs = this.resolveModelUnavailableTtlMs();
111
- this.config = config;
112
- if (!this.config.apiKey) {
113
- throw new Error('AI API key is required for AI client');
114
- }
115
- this.defaultThreadOptions = this.resolveDefaultThreadOptions();
116
- }
117
- CodexClient.prototype.run = function (prompt, options) {
118
- return __awaiter(this, void 0, void 0, function () {
119
- var maxRetries, retryDelayMs, lastError, modelSequence, _loop_1, this_1, modelIndex, state_1;
120
- var _this = this;
121
- return __generator(this, function (_a) {
122
- switch (_a.label) {
123
- case 0: return [4 /*yield*/, this.ensureModelFallbackPreferencesLoaded()];
124
- case 1:
125
- _a.sent();
126
- maxRetries = this.normalizeRetryCount(this.config.maxRetries);
127
- retryDelayMs = this.normalizeRetryDelay(this.config.retryDelayMs);
128
- lastError = null;
129
- modelSequence = this.resolveModelSequence(options);
130
- _loop_1 = function (modelIndex) {
131
- var model, nextModel, modelOptions, processCwdFallbackApplied, attempt, _loop_2, state_2;
132
- return __generator(this, function (_b) {
133
- switch (_b.label) {
134
- case 0:
135
- model = modelSequence[modelIndex];
136
- nextModel = modelSequence[modelIndex + 1];
137
- modelOptions = this_1.applyModelOverride(options, model);
138
- processCwdFallbackApplied = false;
139
- attempt = 0;
140
- _loop_2 = function () {
141
- var result_1, result, error_1, message, workingDirectory, fallbackOptions_1, _c, delay;
142
- return __generator(this, function (_d) {
143
- switch (_d.label) {
144
- case 0:
145
- _d.trys.push([0, 8, , 14]);
146
- this_1.log("run model=".concat(model || this_1.config.model || 'default', " attempt ").concat(attempt + 1, "/").concat(maxRetries + 1));
147
- if (!(this_1.pingEnabled && !this_1.isPingPrompt(prompt))) return [3 /*break*/, 2];
148
- return [4 /*yield*/, this_1.runPing(modelOptions === null || modelOptions === void 0 ? void 0 : modelOptions.threadOptions)];
149
- case 1:
150
- _d.sent();
151
- _d.label = 2;
152
- case 2:
153
- if (!(this_1.streamEnabled && !this_1.isPingPrompt(prompt))) return [3 /*break*/, 5];
154
- return [4 /*yield*/, this_1.runStreamedOnce(prompt, modelOptions)];
155
- case 3:
156
- result_1 = _d.sent();
157
- return [4 /*yield*/, this_1.clearModelFallbackPreference(model)];
158
- case 4:
159
- _d.sent();
160
- return [2 /*return*/, { value: result_1 }];
161
- case 5: return [4 /*yield*/, this_1.runOnce(prompt, modelOptions)];
162
- case 6:
163
- result = _d.sent();
164
- return [4 /*yield*/, this_1.clearModelFallbackPreference(model)];
165
- case 7:
166
- _d.sent();
167
- return [2 /*return*/, { value: result }];
168
- case 8:
169
- error_1 = _d.sent();
170
- lastError = error_1;
171
- message = error_1 instanceof Error ? error_1.message : String(error_1 || 'Unknown error');
172
- this_1.log("run model=".concat(model || this_1.config.model || 'default', " attempt ").concat(attempt + 1, " failed: ").concat(message));
173
- if (!(!processCwdFallbackApplied && this_1.shouldApplyProcessCwdFallback(error_1, modelOptions))) return [3 /*break*/, 10];
174
- processCwdFallbackApplied = true;
175
- workingDirectory = this_1.resolveProcessWorkingDirectory(modelOptions);
176
- fallbackOptions_1 = this_1.applyProcessCwdFallback(modelOptions);
177
- this_1.log('codex workingDirectory launch failed with os error 2; retrying from process cwd without CLI workingDirectory.');
178
- _c = {};
179
- return [4 /*yield*/, this_1.withProcessWorkingDirectoryFallback(workingDirectory, function () { return __awaiter(_this, void 0, void 0, function () {
180
- var fallbackResult_1, fallbackResult;
181
- return __generator(this, function (_a) {
182
- switch (_a.label) {
183
- case 0:
184
- if (!(this.streamEnabled && !this.isPingPrompt(prompt))) return [3 /*break*/, 3];
185
- return [4 /*yield*/, this.runStreamedOnce(prompt, fallbackOptions_1)];
186
- case 1:
187
- fallbackResult_1 = _a.sent();
188
- return [4 /*yield*/, this.clearModelFallbackPreference(model)];
189
- case 2:
190
- _a.sent();
191
- return [2 /*return*/, fallbackResult_1];
192
- case 3: return [4 /*yield*/, this.runOnce(prompt, fallbackOptions_1)];
193
- case 4:
194
- fallbackResult = _a.sent();
195
- return [4 /*yield*/, this.clearModelFallbackPreference(model)];
196
- case 5:
197
- _a.sent();
198
- return [2 /*return*/, fallbackResult];
199
- }
200
- });
201
- }); })];
202
- case 9: return [2 /*return*/, (_c.value = _d.sent(), _c)];
203
- case 10:
204
- if (!(nextModel && this_1.isModelAvailabilityError(error_1))) return [3 /*break*/, 12];
205
- return [4 /*yield*/, this_1.rememberModelFallbackPreference(model, nextModel)];
206
- case 11:
207
- _d.sent();
208
- this_1.log("model unavailable; retrying with fallback model ".concat(nextModel));
209
- return [2 /*return*/, "break"];
210
- case 12:
211
- if (this_1.isCodexEnvironmentError(error_1)) {
212
- this_1.recoverCodexEnvironment(error_1);
213
- }
214
- if (attempt >= maxRetries || !this_1.isRetryableError(error_1)) {
215
- throw lastError;
216
- }
217
- delay = retryDelayMs * Math.pow(2, attempt);
218
- return [4 /*yield*/, this_1.sleep(delay)];
219
- case 13:
220
- _d.sent();
221
- attempt += 1;
222
- return [3 /*break*/, 14];
223
- case 14: return [2 /*return*/];
224
- }
225
- });
226
- };
227
- _b.label = 1;
228
- case 1:
229
- if (!(attempt <= maxRetries)) return [3 /*break*/, 3];
230
- return [5 /*yield**/, _loop_2()];
231
- case 2:
232
- state_2 = _b.sent();
233
- if (typeof state_2 === "object")
234
- return [2 /*return*/, state_2];
235
- if (state_2 === "break")
236
- return [3 /*break*/, 3];
237
- return [3 /*break*/, 1];
238
- case 3: return [2 /*return*/];
239
- }
240
- });
241
- };
242
- this_1 = this;
243
- modelIndex = 0;
244
- _a.label = 2;
245
- case 2:
246
- if (!(modelIndex < modelSequence.length)) return [3 /*break*/, 5];
247
- return [5 /*yield**/, _loop_1(modelIndex)];
248
- case 3:
249
- state_1 = _a.sent();
250
- if (typeof state_1 === "object")
251
- return [2 /*return*/, state_1.value];
252
- _a.label = 4;
253
- case 4:
254
- modelIndex += 1;
255
- return [3 /*break*/, 2];
256
- case 5: throw lastError;
257
- }
258
- });
259
- });
260
- };
261
- CodexClient.prototype.runStreamedOnce = function (prompt, options) {
262
- return __awaiter(this, void 0, void 0, function () {
263
- var startedAt, thread, timeoutMs, streamIdleTimeoutMs, controller, timeoutId, lastStreamActivityAt, idleTimeoutId, finalResponse, lastText, usageSummary, events, _a, events_1, events_1_1, event_1, error_2, message, e_1_1, error_3, idleForMs, message;
264
- var _this = this;
265
- var _b, e_1, _c, _d;
266
- var _e, _f, _g;
267
- return __generator(this, function (_h) {
268
- switch (_h.label) {
269
- case 0:
270
- startedAt = Date.now();
271
- this.log("runStreamed start (promptLength=".concat(prompt.length, ")"));
272
- return [4 /*yield*/, this.startThread(options === null || options === void 0 ? void 0 : options.threadOptions, options === null || options === void 0 ? void 0 : options.threadKey, options === null || options === void 0 ? void 0 : options.reuseThread)];
273
- case 1:
274
- thread = _h.sent();
275
- timeoutMs = (_e = options === null || options === void 0 ? void 0 : options.timeoutMs) !== null && _e !== void 0 ? _e : this.defaultTimeoutMs;
276
- streamIdleTimeoutMs = this.normalizeStreamIdleTimeoutMs(options === null || options === void 0 ? void 0 : options.streamIdleTimeoutMs);
277
- controller = typeof AbortController !== 'undefined' ? new AbortController() : null;
278
- timeoutId = controller
279
- ? setTimeout(function () { return controller.abort(); }, timeoutMs)
280
- : null;
281
- lastStreamActivityAt = Date.now();
282
- idleTimeoutId = controller && streamIdleTimeoutMs > 0
283
- ? setInterval(function () {
284
- if (Date.now() - lastStreamActivityAt >= streamIdleTimeoutMs) {
285
- controller.abort();
286
- }
287
- }, Math.max(15000, Math.min(60000, Math.floor(streamIdleTimeoutMs / 4))))
288
- : null;
289
- finalResponse = '';
290
- lastText = '';
291
- usageSummary = null;
292
- _h.label = 2;
293
- case 2:
294
- _h.trys.push([2, 21, 22, 23]);
295
- return [4 /*yield*/, thread.runStreamed(prompt, controller ? { signal: controller.signal } : undefined)];
296
- case 3:
297
- events = (_h.sent()).events;
298
- _h.label = 4;
299
- case 4:
300
- _h.trys.push([4, 14, 15, 20]);
301
- _a = true, events_1 = __asyncValues(events);
302
- _h.label = 5;
303
- case 5: return [4 /*yield*/, events_1.next()];
304
- case 6:
305
- if (!(events_1_1 = _h.sent(), _b = events_1_1.done, !_b)) return [3 /*break*/, 13];
306
- _d = events_1_1.value;
307
- _a = false;
308
- event_1 = _d;
309
- lastStreamActivityAt = Date.now();
310
- if ((event_1 === null || event_1 === void 0 ? void 0 : event_1.type) === 'turn.completed') {
311
- usageSummary = this.normalizeUsageSummary(event_1 === null || event_1 === void 0 ? void 0 : event_1.usage);
312
- }
313
- if (!(options === null || options === void 0 ? void 0 : options.onStreamEvent)) return [3 /*break*/, 10];
314
- _h.label = 7;
315
- case 7:
316
- _h.trys.push([7, 9, , 10]);
317
- return [4 /*yield*/, options.onStreamEvent(event_1)];
318
- case 8:
319
- _h.sent();
320
- return [3 /*break*/, 10];
321
- case 9:
322
- error_2 = _h.sent();
323
- message = error_2 instanceof Error ? error_2.message : String(error_2 || 'Unknown error');
324
- this.log("onStreamEvent failed: ".concat(message));
325
- return [3 /*break*/, 10];
326
- case 10: return [4 /*yield*/, this.handleStreamEvent(event_1, function (text) { return __awaiter(_this, void 0, void 0, function () {
327
- var next, delta, error_4, message;
328
- return __generator(this, function (_a) {
329
- switch (_a.label) {
330
- case 0:
331
- next = text || '';
332
- if (!next) {
333
- return [2 /*return*/];
334
- }
335
- delta = next.startsWith(lastText) ? next.slice(lastText.length) : next;
336
- if (!delta) return [3 /*break*/, 4];
337
- this.logStreamText(delta);
338
- if (!(options === null || options === void 0 ? void 0 : options.onStreamText)) return [3 /*break*/, 4];
339
- _a.label = 1;
340
- case 1:
341
- _a.trys.push([1, 3, , 4]);
342
- return [4 /*yield*/, options.onStreamText(delta, next)];
343
- case 2:
344
- _a.sent();
345
- return [3 /*break*/, 4];
346
- case 3:
347
- error_4 = _a.sent();
348
- message = error_4 instanceof Error ? error_4.message : String(error_4 || 'Unknown error');
349
- this.log("onStreamText failed: ".concat(message));
350
- return [3 /*break*/, 4];
351
- case 4:
352
- lastText = next;
353
- finalResponse = next;
354
- return [2 /*return*/];
355
- }
356
- });
357
- }); })];
358
- case 11:
359
- _h.sent();
360
- if ((event_1 === null || event_1 === void 0 ? void 0 : event_1.type) === 'turn.failed') {
361
- throw new Error(((_f = event_1.error) === null || _f === void 0 ? void 0 : _f.message) || 'AI run failed.');
362
- }
363
- if ((event_1 === null || event_1 === void 0 ? void 0 : event_1.type) === 'error') {
364
- throw new Error(event_1.message || 'AI stream error.');
365
- }
366
- _h.label = 12;
367
- case 12:
368
- _a = true;
369
- return [3 /*break*/, 5];
370
- case 13: return [3 /*break*/, 20];
371
- case 14:
372
- e_1_1 = _h.sent();
373
- e_1 = { error: e_1_1 };
374
- return [3 /*break*/, 20];
375
- case 15:
376
- _h.trys.push([15, , 18, 19]);
377
- if (!(!_a && !_b && (_c = events_1.return))) return [3 /*break*/, 17];
378
- return [4 /*yield*/, _c.call(events_1)];
379
- case 16:
380
- _h.sent();
381
- _h.label = 17;
382
- case 17: return [3 /*break*/, 19];
383
- case 18:
384
- if (e_1) throw e_1.error;
385
- return [7 /*endfinally*/];
386
- case 19: return [7 /*endfinally*/];
387
- case 20: return [3 /*break*/, 23];
388
- case 21:
389
- error_3 = _h.sent();
390
- if ((_g = controller === null || controller === void 0 ? void 0 : controller.signal) === null || _g === void 0 ? void 0 : _g.aborted) {
391
- idleForMs = Date.now() - lastStreamActivityAt;
392
- if (streamIdleTimeoutMs > 0 && idleForMs >= streamIdleTimeoutMs) {
393
- this.log("runStreamed idle timed out (durationMs=".concat(Date.now() - startedAt, ", idleForMs=").concat(idleForMs, ")"));
394
- throw new Error("AI stream stalled with no activity for ".concat(idleForMs, "ms."));
395
- }
396
- this.log("runStreamed timed out (durationMs=".concat(Date.now() - startedAt, ")"));
397
- throw new Error('AI request timed out.');
398
- }
399
- message = error_3 instanceof Error ? error_3.message : String(error_3 || 'Unknown error');
400
- this.log("runStreamed failed (durationMs=".concat(Date.now() - startedAt, "): ").concat(message));
401
- throw error_3;
402
- case 22:
403
- if (timeoutId) {
404
- clearTimeout(timeoutId);
405
- }
406
- if (idleTimeoutId) {
407
- clearInterval(idleTimeoutId);
408
- }
409
- return [7 /*endfinally*/];
410
- case 23:
411
- if (!finalResponse) {
412
- throw new Error('AI returned no completion content.');
413
- }
414
- return [4 /*yield*/, this.emitUsageSummary(options, usageSummary)];
415
- case 24:
416
- _h.sent();
417
- this.log("runStreamed complete (contentLength=".concat(finalResponse.length, ", durationMs=").concat(Date.now() - startedAt, ")"));
418
- return [2 /*return*/, finalResponse.trim()];
419
- }
420
- });
421
- });
422
- };
423
- CodexClient.prototype.normalizeStreamIdleTimeoutMs = function (value) {
424
- var parsed = Number(value || 0);
425
- if (!Number.isFinite(parsed) || parsed < 60000) {
426
- return 0;
427
- }
428
- return Math.floor(parsed);
429
- };
430
- CodexClient.prototype.runOnce = function (prompt, options) {
431
- return __awaiter(this, void 0, void 0, function () {
432
- var startedAt, thread, runPromise, timeoutMs, result, content, error_5, message;
433
- var _a;
434
- return __generator(this, function (_b) {
435
- switch (_b.label) {
436
- case 0:
437
- startedAt = Date.now();
438
- this.log("runOnce start (promptLength=".concat(prompt.length, ")"));
439
- _b.label = 1;
440
- case 1:
441
- _b.trys.push([1, 5, , 6]);
442
- return [4 /*yield*/, this.startThread(options === null || options === void 0 ? void 0 : options.threadOptions, options === null || options === void 0 ? void 0 : options.threadKey, options === null || options === void 0 ? void 0 : options.reuseThread)];
443
- case 2:
444
- thread = _b.sent();
445
- runPromise = thread.run(prompt);
446
- timeoutMs = (_a = options === null || options === void 0 ? void 0 : options.timeoutMs) !== null && _a !== void 0 ? _a : this.defaultTimeoutMs;
447
- this.log("runOnce awaiting result (timeoutMs=".concat(timeoutMs, ")"));
448
- return [4 /*yield*/, this.withTimeout(runPromise, timeoutMs)];
449
- case 3:
450
- result = _b.sent();
451
- content = this.extractContent(result);
452
- if (!content) {
453
- throw new Error('AI returned no completion content.');
454
- }
455
- return [4 /*yield*/, this.emitUsageSummary(options, this.normalizeUsageSummary(result === null || result === void 0 ? void 0 : result.usage))];
456
- case 4:
457
- _b.sent();
458
- this.log("runOnce complete (contentLength=".concat(content.length, ", durationMs=").concat(Date.now() - startedAt, ")"));
459
- return [2 /*return*/, content];
460
- case 5:
461
- error_5 = _b.sent();
462
- message = error_5 instanceof Error ? error_5.message : String(error_5 || 'Unknown error');
463
- this.log("runOnce failed (durationMs=".concat(Date.now() - startedAt, "): ").concat(message));
464
- throw error_5;
465
- case 6: return [2 /*return*/];
466
- }
467
- });
468
- });
469
- };
470
- CodexClient.prototype.startThread = function (threadOptions_1, threadKey_1) {
471
- return __awaiter(this, arguments, void 0, function (threadOptions, threadKey, reuseThread) {
472
- var mergedOptions, optionsKey, effectiveModel, modelKey, cacheKey, explicitThreadKey, hasExplicitThreadKey, existing, sameOptions, sameModel, thread_1, thread;
473
- if (reuseThread === void 0) { reuseThread = true; }
474
- return __generator(this, function (_a) {
475
- switch (_a.label) {
476
- case 0: return [4 /*yield*/, this.ensureCodex()];
477
- case 1:
478
- _a.sent();
479
- mergedOptions = this.mergeThreadOptions(threadOptions);
480
- optionsKey = this.buildThreadOptionsKey(mergedOptions);
481
- effectiveModel = (mergedOptions === null || mergedOptions === void 0 ? void 0 : mergedOptions.model) || this.config.model || 'default';
482
- modelKey = this.normalizeOptionalString(effectiveModel).toLowerCase() || 'default';
483
- cacheKey = this.buildThreadCacheKey(threadKey, mergedOptions);
484
- explicitThreadKey = (threadKey || '').trim();
485
- hasExplicitThreadKey = explicitThreadKey.length > 0;
486
- if (reuseThread && cacheKey) {
487
- existing = this.threadCache.get(cacheKey);
488
- if (existing) {
489
- sameOptions = existing.optionsKey === optionsKey;
490
- sameModel = existing.modelKey === modelKey;
491
- if (sameOptions || (hasExplicitThreadKey && sameModel)) {
492
- if (hasExplicitThreadKey && existing.optionsKey !== optionsKey) {
493
- this.log("startThread reuse explicit key (".concat(cacheKey, ") despite option change"));
494
- }
495
- else {
496
- this.log("startThread reuse (".concat(cacheKey, ")"));
497
- }
498
- return [2 /*return*/, existing.thread];
499
- }
500
- if (hasExplicitThreadKey && !sameModel) {
501
- this.log("startThread explicit key (".concat(cacheKey, ") model changed (").concat(existing.modelKey, " -> ").concat(modelKey, "); creating new thread"));
502
- }
503
- }
504
- }
505
- this.log("startThread (model=".concat(effectiveModel, ")"));
506
- if (mergedOptions === null || mergedOptions === void 0 ? void 0 : mergedOptions.model) {
507
- this.log("startThread options: ".concat(this.formatThreadOptions(mergedOptions)));
508
- thread_1 = this.codex.startThread(mergedOptions);
509
- this.log('startThread created with model override');
510
- if (cacheKey) {
511
- this.threadCache.set(cacheKey, { thread: thread_1, optionsKey: optionsKey, modelKey: modelKey });
512
- }
513
- return [2 /*return*/, thread_1];
514
- }
515
- if (mergedOptions && Object.keys(mergedOptions).length) {
516
- this.log("startThread options: ".concat(this.formatThreadOptions(mergedOptions)));
517
- }
518
- thread = this.codex.startThread(mergedOptions);
519
- this.log('startThread created');
520
- if (cacheKey) {
521
- this.threadCache.set(cacheKey, { thread: thread, optionsKey: optionsKey, modelKey: modelKey });
522
- }
523
- return [2 /*return*/, thread];
524
- }
525
- });
526
- });
527
- };
528
- CodexClient.prototype.extractContent = function (result) {
529
- var _this = this;
530
- if (!result) {
531
- return '';
532
- }
533
- if (typeof result.finalResponse === 'string') {
534
- return result.finalResponse.trim();
535
- }
536
- if (typeof result === 'string') {
537
- return result.trim();
538
- }
539
- if (Array.isArray(result.items)) {
540
- var lastMessage = __spreadArray([], __read(result.items), false).reverse().find(function (item) { return (item === null || item === void 0 ? void 0 : item.type) === 'agent_message' && typeof item.text === 'string'; });
541
- if (lastMessage === null || lastMessage === void 0 ? void 0 : lastMessage.text) {
542
- return lastMessage.text.trim();
543
- }
544
- }
545
- if (typeof result.output_text === 'string') {
546
- return result.output_text.trim();
547
- }
548
- if (typeof result.outputText === 'string') {
549
- return result.outputText.trim();
550
- }
551
- if (typeof result.content === 'string') {
552
- return result.content.trim();
553
- }
554
- if (typeof result.text === 'string') {
555
- return result.text.trim();
556
- }
557
- if (Array.isArray(result.content)) {
558
- var text = result.content
559
- .map(function (part) { return _this.extractPartText(part); })
560
- .join('')
561
- .trim();
562
- if (text) {
563
- return text;
564
- }
565
- }
566
- if (Array.isArray(result.output)) {
567
- var text = result.output
568
- .map(function (item) {
569
- if (!item) {
570
- return '';
571
- }
572
- if (typeof item === 'string') {
573
- return item;
574
- }
575
- if (typeof item.text === 'string') {
576
- return item.text;
577
- }
578
- if (typeof item.content === 'string') {
579
- return item.content;
580
- }
581
- if (Array.isArray(item.content)) {
582
- return item.content.map(function (part) { return _this.extractPartText(part); }).join('');
583
- }
584
- return '';
585
- })
586
- .join('')
587
- .trim();
588
- if (text) {
589
- return text;
590
- }
591
- }
592
- return '';
593
- };
594
- CodexClient.prototype.handleStreamEvent = function (event, onAgentMessage) {
595
- return __awaiter(this, void 0, void 0, function () {
596
- var _a;
597
- return __generator(this, function (_b) {
598
- switch (_b.label) {
599
- case 0:
600
- if (!event || !event.type) {
601
- return [2 /*return*/];
602
- }
603
- _a = event.type;
604
- switch (_a) {
605
- case 'thread.started': return [3 /*break*/, 1];
606
- case 'turn.started': return [3 /*break*/, 2];
607
- case 'turn.completed': return [3 /*break*/, 3];
608
- case 'item.started': return [3 /*break*/, 4];
609
- case 'item.updated': return [3 /*break*/, 4];
610
- case 'item.completed': return [3 /*break*/, 4];
611
- }
612
- return [3 /*break*/, 6];
613
- case 1:
614
- this.log("stream thread.started (id=".concat(event.thread_id || 'unknown', ")"));
615
- return [3 /*break*/, 7];
616
- case 2:
617
- this.log('stream turn.started');
618
- return [3 /*break*/, 7];
619
- case 3:
620
- this.log('stream turn.completed');
621
- return [3 /*break*/, 7];
622
- case 4: return [4 /*yield*/, this.handleStreamItem(event.item, onAgentMessage)];
623
- case 5:
624
- _b.sent();
625
- return [3 /*break*/, 7];
626
- case 6: return [3 /*break*/, 7];
627
- case 7: return [2 /*return*/];
628
- }
629
- });
630
- });
631
- };
632
- CodexClient.prototype.normalizeUsageSummary = function (raw) {
633
- var _a, _b, _c;
634
- if (!raw || typeof raw !== 'object') {
635
- return null;
636
- }
637
- var inputTokens = this.normalizeUsageToken((_a = raw.input_tokens) !== null && _a !== void 0 ? _a : raw.inputTokens);
638
- var cachedInputTokens = this.normalizeUsageToken((_b = raw.cached_input_tokens) !== null && _b !== void 0 ? _b : raw.cachedInputTokens);
639
- var outputTokens = this.normalizeUsageToken((_c = raw.output_tokens) !== null && _c !== void 0 ? _c : raw.outputTokens);
640
- if (inputTokens <= 0 && cachedInputTokens <= 0 && outputTokens <= 0) {
641
- return null;
642
- }
643
- return {
644
- inputTokens: inputTokens,
645
- cachedInputTokens: cachedInputTokens,
646
- outputTokens: outputTokens
647
- };
648
- };
649
- CodexClient.prototype.normalizeUsageToken = function (value) {
650
- var parsed = Number(value);
651
- if (!Number.isFinite(parsed) || parsed <= 0) {
652
- return 0;
653
- }
654
- return Math.floor(parsed);
655
- };
656
- CodexClient.prototype.emitUsageSummary = function (options, usage) {
657
- return __awaiter(this, void 0, void 0, function () {
658
- var error_6, message;
659
- return __generator(this, function (_a) {
660
- switch (_a.label) {
661
- case 0:
662
- if (!(options === null || options === void 0 ? void 0 : options.onUsage)) {
663
- return [2 /*return*/];
664
- }
665
- _a.label = 1;
666
- case 1:
667
- _a.trys.push([1, 3, , 4]);
668
- return [4 /*yield*/, options.onUsage(usage)];
669
- case 2:
670
- _a.sent();
671
- return [3 /*break*/, 4];
672
- case 3:
673
- error_6 = _a.sent();
674
- message = error_6 instanceof Error ? error_6.message : String(error_6 || 'Unknown error');
675
- this.log("onUsage failed: ".concat(message));
676
- return [3 /*break*/, 4];
677
- case 4: return [2 /*return*/];
678
- }
679
- });
680
- });
681
- };
682
- CodexClient.prototype.handleStreamItem = function (item, onAgentMessage) {
683
- return __awaiter(this, void 0, void 0, function () {
684
- var _a, output, summary, total, done, snippet;
685
- var _b;
686
- return __generator(this, function (_c) {
687
- switch (_c.label) {
688
- case 0:
689
- if (!item || !item.type) {
690
- return [2 /*return*/];
691
- }
692
- _a = item.type;
693
- switch (_a) {
694
- case 'agent_message': return [3 /*break*/, 1];
695
- case 'command_execution': return [3 /*break*/, 3];
696
- case 'file_change': return [3 /*break*/, 4];
697
- case 'mcp_tool_call': return [3 /*break*/, 5];
698
- case 'web_search': return [3 /*break*/, 6];
699
- case 'todo_list': return [3 /*break*/, 7];
700
- case 'reasoning': return [3 /*break*/, 8];
701
- case 'error': return [3 /*break*/, 9];
702
- }
703
- return [3 /*break*/, 10];
704
- case 1: return [4 /*yield*/, onAgentMessage(item.text || '')];
705
- case 2:
706
- _c.sent();
707
- return [3 /*break*/, 11];
708
- case 3:
709
- if (item.command) {
710
- this.log("stream command: ".concat(item.command, " (").concat(item.status || 'unknown', ")"));
711
- }
712
- if (item.aggregated_output) {
713
- output = item.aggregated_output.length > 800
714
- ? "".concat(item.aggregated_output.slice(0, 800), "...")
715
- : item.aggregated_output;
716
- this.log("stream command output: ".concat(output));
717
- }
718
- return [3 /*break*/, 11];
719
- case 4:
720
- if (Array.isArray(item.changes) && item.changes.length) {
721
- summary = item.changes.map(function (change) { return "".concat(change.kind, ":").concat(change.path); }).join(', ');
722
- this.log("stream file_change (".concat(item.status || 'unknown', "): ").concat(summary));
723
- }
724
- return [3 /*break*/, 11];
725
- case 5:
726
- if (item.tool) {
727
- this.log("stream tool_call: ".concat(item.tool, " (").concat(item.status || 'unknown', ")"));
728
- }
729
- if ((_b = item.error) === null || _b === void 0 ? void 0 : _b.message) {
730
- this.log("stream tool_call error: ".concat(item.error.message));
731
- }
732
- return [3 /*break*/, 11];
733
- case 6:
734
- if (item.query) {
735
- this.log("stream web_search: ".concat(item.query));
736
- }
737
- return [3 /*break*/, 11];
738
- case 7:
739
- if (Array.isArray(item.items)) {
740
- total = item.items.length;
741
- done = item.items.filter(function (entry) { return entry === null || entry === void 0 ? void 0 : entry.completed; }).length;
742
- this.log("stream todo_list: ".concat(done, "/").concat(total, " completed"));
743
- }
744
- return [3 /*break*/, 11];
745
- case 8:
746
- if (item.text) {
747
- snippet = item.text.length > 200 ? "".concat(item.text.slice(0, 200), "...") : item.text;
748
- this.log("stream reasoning: ".concat(snippet));
749
- }
750
- return [3 /*break*/, 11];
751
- case 9:
752
- if (item.message) {
753
- this.log("stream error: ".concat(item.message));
754
- }
755
- return [3 /*break*/, 11];
756
- case 10: return [3 /*break*/, 11];
757
- case 11: return [2 /*return*/];
758
- }
759
- });
760
- });
761
- };
762
- CodexClient.prototype.logStreamText = function (text) {
763
- var e_2, _a;
764
- if (!this.debugEnabled) {
765
- return;
766
- }
767
- var lines = text.split(/\r?\n/);
768
- try {
769
- for (var lines_1 = __values(lines), lines_1_1 = lines_1.next(); !lines_1_1.done; lines_1_1 = lines_1.next()) {
770
- var line = lines_1_1.value;
771
- this.log("stream: ".concat(line));
772
- }
773
- }
774
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
775
- finally {
776
- try {
777
- if (lines_1_1 && !lines_1_1.done && (_a = lines_1.return)) _a.call(lines_1);
778
- }
779
- finally { if (e_2) throw e_2.error; }
780
- }
781
- };
782
- CodexClient.prototype.extractPartText = function (part) {
783
- if (!part) {
784
- return '';
785
- }
786
- if (typeof part === 'string') {
787
- return part;
788
- }
789
- if (typeof part.text === 'string') {
790
- return part.text;
791
- }
792
- if (typeof part.content === 'string') {
793
- return part.content;
794
- }
795
- return '';
796
- };
797
- CodexClient.prototype.withTimeout = function (promise, timeoutMs) {
798
- return __awaiter(this, void 0, void 0, function () {
799
- var done, startedAt, heartbeatMs, timeoutPromise;
800
- var _this = this;
801
- return __generator(this, function (_a) {
802
- switch (_a.label) {
803
- case 0:
804
- done = false;
805
- startedAt = Date.now();
806
- heartbeatMs = Math.max(10000, Math.min(30000, Math.floor(timeoutMs / 4)));
807
- timeoutPromise = (function () { return __awaiter(_this, void 0, void 0, function () {
808
- var elapsed, remaining, currentElapsed, currentRemaining;
809
- return __generator(this, function (_a) {
810
- switch (_a.label) {
811
- case 0:
812
- if (!!done) return [3 /*break*/, 4];
813
- elapsed = Date.now() - startedAt;
814
- if (elapsed >= timeoutMs) {
815
- throw new Error('AI request timed out.');
816
- }
817
- remaining = timeoutMs - elapsed;
818
- return [4 /*yield*/, (0, promises_1.setTimeout)(Math.min(heartbeatMs, remaining))];
819
- case 1:
820
- _a.sent();
821
- if (!done) return [3 /*break*/, 3];
822
- return [4 /*yield*/, promise];
823
- case 2: return [2 /*return*/, _a.sent()];
824
- case 3:
825
- currentElapsed = Date.now() - startedAt;
826
- if (currentElapsed >= timeoutMs) {
827
- throw new Error('AI request timed out.');
828
- }
829
- currentRemaining = Math.max(0, timeoutMs - currentElapsed);
830
- this.log("runOnce waiting (elapsedMs=".concat(currentElapsed, ", remainingMs=").concat(currentRemaining, ")"));
831
- return [3 /*break*/, 0];
832
- case 4: return [4 /*yield*/, promise];
833
- case 5: return [2 /*return*/, _a.sent()];
834
- }
835
- });
836
- }); })();
837
- _a.label = 1;
838
- case 1:
839
- _a.trys.push([1, , 3, 4]);
840
- return [4 /*yield*/, Promise.race([promise, timeoutPromise])];
841
- case 2: return [2 /*return*/, _a.sent()];
842
- case 3:
843
- done = true;
844
- return [7 /*endfinally*/];
845
- case 4: return [2 /*return*/];
846
- }
847
- });
848
- });
849
- };
850
- CodexClient.prototype.normalizeRetryCount = function (value) {
851
- if (typeof value !== 'number' || Number.isNaN(value)) {
852
- return 2;
853
- }
854
- return Math.max(0, Math.floor(value));
855
- };
856
- CodexClient.prototype.normalizeRetryDelay = function (value) {
857
- if (typeof value !== 'number' || Number.isNaN(value)) {
858
- return 500;
859
- }
860
- return Math.max(100, Math.floor(value));
861
- };
862
- CodexClient.prototype.resolveModelSequence = function (options) {
863
- var _this = this;
864
- var _a;
865
- var primary = this.normalizeOptionalString(((_a = options === null || options === void 0 ? void 0 : options.threadOptions) === null || _a === void 0 ? void 0 : _a.model) || this.config.model);
866
- var fallbackModels = this.collectFallbackModels(options === null || options === void 0 ? void 0 : options.fallbackModels);
867
- var sequence = [];
868
- var push = function (value) {
869
- var normalized = _this.normalizeOptionalString(value);
870
- if (!normalized || sequence.includes(normalized)) {
871
- return;
872
- }
873
- sequence.push(normalized);
874
- };
875
- var preferredFallback = this.getModelFallbackPreference(primary);
876
- if (preferredFallback) {
877
- push(preferredFallback);
878
- this.log("sticky model fallback active: ".concat(primary, " -> ").concat(preferredFallback));
879
- }
880
- push(primary);
881
- fallbackModels.forEach(push);
882
- if (!sequence.length) {
883
- sequence.push('');
884
- }
885
- return sequence;
886
- };
887
- CodexClient.prototype.collectFallbackModels = function (runFallbackModels) {
888
- var _this = this;
889
- var models = [];
890
- var push = function (value) {
891
- var normalized = _this.normalizeOptionalString(value);
892
- if (!normalized || models.includes(normalized)) {
893
- return;
894
- }
895
- models.push(normalized);
896
- };
897
- this.normalizeModelList(runFallbackModels).forEach(push);
898
- this.normalizeModelList(this.config.fallbackModels).forEach(push);
899
- push(this.config.fallbackModel);
900
- this.normalizeModelList(process.env.AI_ASSISTANT_CODEX_FALLBACK_MODELS).forEach(push);
901
- push(process.env.AI_ASSISTANT_CODEX_FALLBACK_MODEL);
902
- this.normalizeModelList(process.env.AI_TERMINAL_CODEX_FALLBACK_MODELS).forEach(push);
903
- push(process.env.AI_TERMINAL_CODEX_FALLBACK_MODEL);
904
- this.normalizeModelList(process.env.AI_DASHBOARD_CODEX_FALLBACK_MODELS).forEach(push);
905
- push(process.env.AI_DASHBOARD_CODEX_FALLBACK_MODEL);
906
- var primaryModel = this.normalizeOptionalString(this.config.model
907
- || (runFallbackModels === null || runFallbackModels === void 0 ? void 0 : runFallbackModels[0])
908
- || '');
909
- if (/^gpt-5(?:\.\d+)?-codex$/i.test(primaryModel)) {
910
- push('gpt-5-codex');
911
- }
912
- if (/^gpt-5(?:-codex|\.\d+-codex)$/i.test(primaryModel)) {
913
- push('gpt-5.5');
914
- }
915
- return models;
916
- };
917
- CodexClient.prototype.normalizeModelList = function (value) {
918
- var _this = this;
919
- if (Array.isArray(value)) {
920
- return value
921
- .map(function (entry) { return _this.normalizeOptionalString(entry); })
922
- .filter(Boolean);
923
- }
924
- var raw = this.normalizeOptionalString(value);
925
- if (!raw) {
926
- return [];
927
- }
928
- return raw
929
- .split(',')
930
- .map(function (entry) { return _this.normalizeOptionalString(entry); })
931
- .filter(Boolean);
932
- };
933
- CodexClient.prototype.applyModelOverride = function (options, model) {
934
- var nextThreadOptions = __assign({}, ((options === null || options === void 0 ? void 0 : options.threadOptions) || {}));
935
- if (model) {
936
- nextThreadOptions.model = model;
937
- }
938
- else {
939
- delete nextThreadOptions.model;
940
- }
941
- return __assign(__assign({}, (options || {})), { threadOptions: nextThreadOptions });
942
- };
943
- CodexClient.prototype.isModelAvailabilityError = function (error) {
944
- var message = error instanceof Error ? error.message : String(error || '');
945
- var normalized = message.toLowerCase();
946
- if (!normalized.includes('model')) {
947
- return false;
948
- }
949
- if (/does not exist|not found|unknown model|invalid model|unsupported model|model_not_found|no such model/.test(normalized)) {
950
- return true;
951
- }
952
- if (/not available|unavailable|not enabled|not allowed|do not have access|don't have access|insufficient permissions/.test(normalized)) {
953
- return true;
954
- }
955
- return /404/.test(normalized) && /model/.test(normalized);
956
- };
957
- CodexClient.prototype.isRetryableError = function (error) {
958
- var message = error instanceof Error ? error.message : String(error || '');
959
- if (/AI returned no completion content|Codex returned no completion content/i.test(message)) {
960
- return true;
961
- }
962
- if (this.isCodexEnvironmentError(error)) {
963
- return true;
964
- }
965
- var statusMatch = message.match(/\\b(429|5\\d{2})\\b/);
966
- if (statusMatch) {
967
- return true;
968
- }
969
- return /ECONNRESET|ETIMEDOUT|EAI_AGAIN|ENOTFOUND|fetch failed|timed out|timeout/i.test(message);
970
- };
971
- CodexClient.prototype.isCodexEnvironmentError = function (error) {
972
- var message = error instanceof Error ? error.message : String(error || '');
973
- return /error finding codex home|could not update path: no such file or directory/i.test(message);
974
- };
975
- CodexClient.prototype.recoverCodexEnvironment = function (error) {
976
- var message = error instanceof Error ? error.message : String(error || 'Unknown error');
977
- this.log("recovering codex environment after error: ".concat(message));
978
- this.threadCache.clear();
979
- this.codex = null;
980
- this.codexInit = null;
981
- this.zDotDir = null;
982
- };
983
- CodexClient.prototype.shouldApplyProcessCwdFallback = function (error, options) {
984
- var workingDirectory = this.resolveProcessWorkingDirectory(options);
985
- if (!workingDirectory) {
986
- return false;
987
- }
988
- var message = error instanceof Error ? error.message : String(error || '');
989
- return /no such file or directory \(os error 2\)/i.test(message);
990
- };
991
- CodexClient.prototype.resolveProcessWorkingDirectory = function (options) {
992
- var _a;
993
- return this.normalizeOptionalString((options === null || options === void 0 ? void 0 : options.processWorkingDirectory) || ((_a = options === null || options === void 0 ? void 0 : options.threadOptions) === null || _a === void 0 ? void 0 : _a.workingDirectory));
994
- };
995
- CodexClient.prototype.applyProcessCwdFallback = function (options) {
996
- var nextThreadOptions = __assign({}, ((options === null || options === void 0 ? void 0 : options.threadOptions) || {}));
997
- delete nextThreadOptions.workingDirectory;
998
- return __assign(__assign({}, (options || {})), { threadOptions: nextThreadOptions });
999
- };
1000
- CodexClient.prototype.withProcessWorkingDirectoryFallback = function (workingDirectory, runner) {
1001
- return __awaiter(this, void 0, void 0, function () {
1002
- var normalizedWorkingDirectory, originalCwd, message;
1003
- return __generator(this, function (_a) {
1004
- switch (_a.label) {
1005
- case 0:
1006
- normalizedWorkingDirectory = this.normalizeOptionalString(workingDirectory);
1007
- if (!!normalizedWorkingDirectory) return [3 /*break*/, 2];
1008
- return [4 /*yield*/, runner()];
1009
- case 1: return [2 /*return*/, _a.sent()];
1010
- case 2:
1011
- if (!CodexClient.cwdFallbackRunning) return [3 /*break*/, 4];
1012
- return [4 /*yield*/, this.sleep(50)];
1013
- case 3:
1014
- _a.sent();
1015
- return [3 /*break*/, 2];
1016
- case 4:
1017
- CodexClient.cwdFallbackRunning = true;
1018
- originalCwd = process.cwd();
1019
- _a.label = 5;
1020
- case 5:
1021
- _a.trys.push([5, , 7, 8]);
1022
- process.chdir(normalizedWorkingDirectory);
1023
- this.log("running Codex fallback from process cwd ".concat(normalizedWorkingDirectory));
1024
- return [4 /*yield*/, runner()];
1025
- case 6: return [2 /*return*/, _a.sent()];
1026
- case 7:
1027
- try {
1028
- process.chdir(originalCwd);
1029
- }
1030
- catch (error) {
1031
- message = error instanceof Error ? error.message : String(error || 'Unknown error');
1032
- this.log("failed to restore process cwd to ".concat(originalCwd, ": ").concat(message));
1033
- }
1034
- CodexClient.cwdFallbackRunning = false;
1035
- return [7 /*endfinally*/];
1036
- case 8: return [2 /*return*/];
1037
- }
1038
- });
1039
- });
1040
- };
1041
- CodexClient.prototype.normalizeOptionalString = function (value) {
1042
- return typeof value === 'string' ? value.trim() : '';
1043
- };
1044
- CodexClient.prototype.resolveModelUnavailableTtlMs = function () {
1045
- var raw = Number(process.env.AI_DASHBOARD_CODEX_MODEL_UNAVAILABLE_TTL_MS
1046
- || process.env.AI_ASSISTANT_CODEX_MODEL_UNAVAILABLE_TTL_MS);
1047
- if (Number.isFinite(raw) && raw >= CodexClient.MIN_MODEL_UNAVAILABLE_TTL_MS) {
1048
- return Math.floor(raw);
1049
- }
1050
- return CodexClient.DEFAULT_MODEL_UNAVAILABLE_TTL_MS;
1051
- };
1052
- CodexClient.prototype.ensureModelFallbackPreferencesLoaded = function () {
1053
- return __awaiter(this, void 0, void 0, function () {
1054
- var _this = this;
1055
- return __generator(this, function (_a) {
1056
- switch (_a.label) {
1057
- case 0:
1058
- if (CodexClient.modelFallbackPreferencesLoaded) {
1059
- this.pruneModelFallbackPreferences();
1060
- return [2 /*return*/];
1061
- }
1062
- if (!(CodexClient.modelFallbackPreferencesLoadPromise !== null)) return [3 /*break*/, 2];
1063
- return [4 /*yield*/, CodexClient.modelFallbackPreferencesLoadPromise];
1064
- case 1:
1065
- _a.sent();
1066
- this.pruneModelFallbackPreferences();
1067
- return [2 /*return*/];
1068
- case 2:
1069
- CodexClient.modelFallbackPreferencesLoadPromise = (function () { return __awaiter(_this, void 0, void 0, function () {
1070
- var raw, parsed, _a;
1071
- var _this = this;
1072
- return __generator(this, function (_b) {
1073
- switch (_b.label) {
1074
- case 0:
1075
- _b.trys.push([0, 2, 3, 4]);
1076
- return [4 /*yield*/, fs_1.promises.readFile(CodexClient.MODEL_UNAVAILABLE_FALLBACK_FILE, 'utf8')];
1077
- case 1:
1078
- raw = _b.sent();
1079
- parsed = JSON.parse(raw);
1080
- if (!parsed || typeof parsed !== 'object' || Array.isArray(parsed)) {
1081
- return [2 /*return*/];
1082
- }
1083
- Object.entries(parsed).forEach(function (_a) {
1084
- var _b = __read(_a, 2), model = _b[0], entry = _b[1];
1085
- var key = _this.normalizeOptionalString(model);
1086
- if (!key) {
1087
- return;
1088
- }
1089
- var fallbackModel = _this.normalizeOptionalString(entry === null || entry === void 0 ? void 0 : entry.fallbackModel);
1090
- var expiresAt = Number(entry === null || entry === void 0 ? void 0 : entry.expiresAt);
1091
- var updatedAt = Number(entry === null || entry === void 0 ? void 0 : entry.updatedAt);
1092
- if (!fallbackModel || !Number.isFinite(expiresAt) || expiresAt <= Date.now()) {
1093
- return;
1094
- }
1095
- CodexClient.modelFallbackPreferences.set(key, {
1096
- fallbackModel: fallbackModel,
1097
- expiresAt: Math.floor(expiresAt),
1098
- updatedAt: Number.isFinite(updatedAt) ? Math.floor(updatedAt) : Date.now()
1099
- });
1100
- });
1101
- return [3 /*break*/, 4];
1102
- case 2:
1103
- _a = _b.sent();
1104
- return [3 /*break*/, 4];
1105
- case 3:
1106
- CodexClient.modelFallbackPreferencesLoaded = true;
1107
- CodexClient.modelFallbackPreferencesLoadPromise = null;
1108
- return [7 /*endfinally*/];
1109
- case 4: return [2 /*return*/];
1110
- }
1111
- });
1112
- }); })();
1113
- return [4 /*yield*/, CodexClient.modelFallbackPreferencesLoadPromise];
1114
- case 3:
1115
- _a.sent();
1116
- this.pruneModelFallbackPreferences();
1117
- return [2 /*return*/];
1118
- }
1119
- });
1120
- });
1121
- };
1122
- CodexClient.prototype.pruneModelFallbackPreferences = function (now) {
1123
- if (now === void 0) { now = Date.now(); }
1124
- Array.from(CodexClient.modelFallbackPreferences.entries()).forEach(function (_a) {
1125
- var _b = __read(_a, 2), model = _b[0], entry = _b[1];
1126
- if (!entry || !Number.isFinite(entry.expiresAt) || entry.expiresAt <= now) {
1127
- CodexClient.modelFallbackPreferences.delete(model);
1128
- }
1129
- });
1130
- };
1131
- CodexClient.prototype.getModelFallbackPreference = function (model) {
1132
- var normalizedModel = this.normalizeOptionalString(model);
1133
- if (!normalizedModel) {
1134
- return '';
1135
- }
1136
- this.pruneModelFallbackPreferences();
1137
- var entry = CodexClient.modelFallbackPreferences.get(normalizedModel);
1138
- if (!entry || entry.expiresAt <= Date.now()) {
1139
- if (entry) {
1140
- CodexClient.modelFallbackPreferences.delete(normalizedModel);
1141
- }
1142
- return '';
1143
- }
1144
- return entry.fallbackModel;
1145
- };
1146
- CodexClient.prototype.rememberModelFallbackPreference = function (model, fallbackModel) {
1147
- return __awaiter(this, void 0, void 0, function () {
1148
- var normalizedModel, normalizedFallback, now;
1149
- return __generator(this, function (_a) {
1150
- switch (_a.label) {
1151
- case 0:
1152
- normalizedModel = this.normalizeOptionalString(model);
1153
- normalizedFallback = this.normalizeOptionalString(fallbackModel);
1154
- if (!normalizedModel || !normalizedFallback || normalizedModel === normalizedFallback) {
1155
- return [2 /*return*/];
1156
- }
1157
- now = Date.now();
1158
- CodexClient.modelFallbackPreferences.set(normalizedModel, {
1159
- fallbackModel: normalizedFallback,
1160
- expiresAt: now + this.modelUnavailableTtlMs,
1161
- updatedAt: now
1162
- });
1163
- this.pruneModelFallbackPreferences(now);
1164
- return [4 /*yield*/, this.persistModelFallbackPreferences()];
1165
- case 1:
1166
- _a.sent();
1167
- return [2 /*return*/];
1168
- }
1169
- });
1170
- });
1171
- };
1172
- CodexClient.prototype.clearModelFallbackPreference = function (model) {
1173
- return __awaiter(this, void 0, void 0, function () {
1174
- var normalizedModel;
1175
- return __generator(this, function (_a) {
1176
- switch (_a.label) {
1177
- case 0:
1178
- normalizedModel = this.normalizeOptionalString(model);
1179
- if (!normalizedModel) {
1180
- return [2 /*return*/];
1181
- }
1182
- if (!CodexClient.modelFallbackPreferences.has(normalizedModel)) {
1183
- return [2 /*return*/];
1184
- }
1185
- CodexClient.modelFallbackPreferences.delete(normalizedModel);
1186
- return [4 /*yield*/, this.persistModelFallbackPreferences()];
1187
- case 1:
1188
- _a.sent();
1189
- return [2 /*return*/];
1190
- }
1191
- });
1192
- });
1193
- };
1194
- CodexClient.prototype.persistModelFallbackPreferences = function () {
1195
- return __awaiter(this, void 0, void 0, function () {
1196
- var _a, serialized, _b;
1197
- return __generator(this, function (_c) {
1198
- switch (_c.label) {
1199
- case 0:
1200
- this.pruneModelFallbackPreferences();
1201
- if (!!CodexClient.modelFallbackPreferences.size) return [3 /*break*/, 5];
1202
- _c.label = 1;
1203
- case 1:
1204
- _c.trys.push([1, 3, , 4]);
1205
- return [4 /*yield*/, fs_1.promises.unlink(CodexClient.MODEL_UNAVAILABLE_FALLBACK_FILE)];
1206
- case 2:
1207
- _c.sent();
1208
- return [3 /*break*/, 4];
1209
- case 3:
1210
- _a = _c.sent();
1211
- return [3 /*break*/, 4];
1212
- case 4: return [2 /*return*/];
1213
- case 5:
1214
- serialized = {};
1215
- CodexClient.modelFallbackPreferences.forEach(function (entry, model) {
1216
- serialized[model] = entry;
1217
- });
1218
- _c.label = 6;
1219
- case 6:
1220
- _c.trys.push([6, 8, , 9]);
1221
- return [4 /*yield*/, fs_1.promises.writeFile(CodexClient.MODEL_UNAVAILABLE_FALLBACK_FILE, JSON.stringify(serialized), 'utf8')];
1222
- case 7:
1223
- _c.sent();
1224
- return [3 /*break*/, 9];
1225
- case 8:
1226
- _b = _c.sent();
1227
- return [3 /*break*/, 9];
1228
- case 9: return [2 /*return*/];
1229
- }
1230
- });
1231
- });
1232
- };
1233
- CodexClient.prototype.sleep = function (ms) {
1234
- return __awaiter(this, void 0, void 0, function () {
1235
- return __generator(this, function (_a) {
1236
- switch (_a.label) {
1237
- case 0: return [4 /*yield*/, (0, promises_1.setTimeout)(ms)];
1238
- case 1:
1239
- _a.sent();
1240
- return [2 /*return*/];
1241
- }
1242
- });
1243
- });
1244
- };
1245
- CodexClient.prototype.ensureCodex = function () {
1246
- return __awaiter(this, void 0, void 0, function () {
1247
- var _this = this;
1248
- return __generator(this, function (_a) {
1249
- switch (_a.label) {
1250
- case 0:
1251
- if (this.codex) {
1252
- return [2 /*return*/];
1253
- }
1254
- if (!(this.codexInit !== null)) return [3 /*break*/, 2];
1255
- return [4 /*yield*/, this.codexInit];
1256
- case 1:
1257
- _a.sent();
1258
- return [2 /*return*/];
1259
- case 2:
1260
- this.codexInit = (function () { return __awaiter(_this, void 0, void 0, function () {
1261
- var importer, mod, CodexCtor, env;
1262
- var _a;
1263
- return __generator(this, function (_b) {
1264
- switch (_b.label) {
1265
- case 0:
1266
- this.log('Loading AI SDK module...');
1267
- importer = new Function('specifier', 'return import(specifier)');
1268
- return [4 /*yield*/, importer('@openai/codex-sdk')];
1269
- case 1:
1270
- mod = _b.sent();
1271
- CodexCtor = (mod === null || mod === void 0 ? void 0 : mod.Codex) || ((_a = mod === null || mod === void 0 ? void 0 : mod.default) === null || _a === void 0 ? void 0 : _a.Codex) || (mod === null || mod === void 0 ? void 0 : mod.default) || mod;
1272
- if (!CodexCtor) {
1273
- throw new Error('AI SDK export not found.');
1274
- }
1275
- this.log('AI SDK module loaded.');
1276
- return [4 /*yield*/, this.buildCodexEnv()];
1277
- case 2:
1278
- env = _b.sent();
1279
- this.codex = new CodexCtor({
1280
- apiKey: this.config.apiKey,
1281
- baseUrl: this.config.baseUrl,
1282
- model: this.config.model,
1283
- env: env
1284
- });
1285
- this.log('AI client initialized.');
1286
- return [2 /*return*/];
1287
- }
1288
- });
1289
- }); })();
1290
- return [4 /*yield*/, this.codexInit];
1291
- case 3:
1292
- _a.sent();
1293
- return [2 /*return*/];
1294
- }
1295
- });
1296
- });
1297
- };
1298
- CodexClient.prototype.log = function (message) {
1299
- if (!this.debugEnabled) {
1300
- return;
1301
- }
1302
- console.log("[AI-Dashboard][AI] ".concat(message));
1303
- };
1304
- CodexClient.prototype.resolveDefaultTimeoutMs = function () {
1305
- var raw = Number(process.env.AI_DASHBOARD_CODEX_TIMEOUT_MS || process.env.AI_DASHBOARD_AGENT_TIMEOUT_MS);
1306
- if (Number.isFinite(raw) && raw > 0) {
1307
- return Math.floor(raw);
1308
- }
1309
- return 600000;
1310
- };
1311
- CodexClient.prototype.resolveStreamEnabled = function () {
1312
- var raw = (process.env.AI_DASHBOARD_CODEX_STREAM || '').trim().toLowerCase();
1313
- if (!raw) {
1314
- return this.debugEnabled;
1315
- }
1316
- if (['true', '1', 'yes', 'y', 'on'].includes(raw)) {
1317
- return true;
1318
- }
1319
- if (['false', '0', 'no', 'n', 'off'].includes(raw)) {
1320
- return false;
1321
- }
1322
- return this.debugEnabled;
1323
- };
1324
- CodexClient.prototype.resolveCleanZdotdirEnabled = function () {
1325
- var _a;
1326
- var raw = ((_a = process.env.AI_DASHBOARD_CODEX_CLEAN_ZDOTDIR) !== null && _a !== void 0 ? _a : '').trim().toLowerCase();
1327
- if (!raw) {
1328
- return true;
1329
- }
1330
- if (['false', '0', 'no', 'n', 'off'].includes(raw)) {
1331
- return false;
1332
- }
1333
- if (['true', '1', 'yes', 'y', 'on'].includes(raw)) {
1334
- return true;
1335
- }
1336
- return true;
1337
- };
1338
- CodexClient.prototype.buildCodexEnv = function () {
1339
- return __awaiter(this, void 0, void 0, function () {
1340
- var env, _a, _b, _c, key, value, fallbackHome, _d;
1341
- var e_3, _e;
1342
- return __generator(this, function (_f) {
1343
- switch (_f.label) {
1344
- case 0:
1345
- env = {};
1346
- try {
1347
- for (_a = __values(Object.entries(process.env)), _b = _a.next(); !_b.done; _b = _a.next()) {
1348
- _c = __read(_b.value, 2), key = _c[0], value = _c[1];
1349
- if (typeof value === 'string') {
1350
- env[key] = value;
1351
- }
1352
- }
1353
- }
1354
- catch (e_3_1) { e_3 = { error: e_3_1 }; }
1355
- finally {
1356
- try {
1357
- if (_b && !_b.done && (_e = _a.return)) _e.call(_a);
1358
- }
1359
- finally { if (e_3) throw e_3.error; }
1360
- }
1361
- if (!this.normalizeOptionalString(env.HOME)) {
1362
- fallbackHome = this.normalizeOptionalString(process.env.HOME || os.homedir());
1363
- if (fallbackHome) {
1364
- env.HOME = fallbackHome;
1365
- }
1366
- }
1367
- return [4 /*yield*/, this.ensureCodexHome(env)];
1368
- case 1:
1369
- _f.sent();
1370
- if (!this.cleanZdotdirEnabled) return [3 /*break*/, 3];
1371
- _d = env;
1372
- return [4 /*yield*/, this.ensureZdotdir()];
1373
- case 2:
1374
- _d.ZDOTDIR = _f.sent();
1375
- _f.label = 3;
1376
- case 3: return [2 /*return*/, env];
1377
- }
1378
- });
1379
- });
1380
- };
1381
- CodexClient.prototype.ensureCodexHome = function (env) {
1382
- return __awaiter(this, void 0, void 0, function () {
1383
- var current, homeRoot, primary, _a, fallback;
1384
- return __generator(this, function (_b) {
1385
- switch (_b.label) {
1386
- case 0:
1387
- current = this.normalizeOptionalString(env.CODEX_HOME || process.env.CODEX_HOME);
1388
- homeRoot = this.normalizeOptionalString(env.HOME || process.env.HOME || os.homedir());
1389
- primary = current || (homeRoot ? path.join(homeRoot, '.codex') : path.join(os.tmpdir(), 'resolveio-codex-home'));
1390
- _b.label = 1;
1391
- case 1:
1392
- _b.trys.push([1, 3, , 5]);
1393
- return [4 /*yield*/, fs_1.promises.mkdir(path.join(primary, 'sessions'), { recursive: true })];
1394
- case 2:
1395
- _b.sent();
1396
- env.CODEX_HOME = primary;
1397
- process.env.CODEX_HOME = primary;
1398
- return [2 /*return*/];
1399
- case 3:
1400
- _a = _b.sent();
1401
- fallback = path.join(os.tmpdir(), 'resolveio-codex-home');
1402
- return [4 /*yield*/, fs_1.promises.mkdir(path.join(fallback, 'sessions'), { recursive: true })];
1403
- case 4:
1404
- _b.sent();
1405
- env.CODEX_HOME = fallback;
1406
- process.env.CODEX_HOME = fallback;
1407
- return [3 /*break*/, 5];
1408
- case 5: return [2 /*return*/];
1409
- }
1410
- });
1411
- });
1412
- };
1413
- CodexClient.prototype.ensureZdotdir = function () {
1414
- return __awaiter(this, void 0, void 0, function () {
1415
- var override, dir;
1416
- return __generator(this, function (_a) {
1417
- switch (_a.label) {
1418
- case 0:
1419
- if (this.zDotDir) {
1420
- return [2 /*return*/, this.zDotDir];
1421
- }
1422
- override = (process.env.AI_DASHBOARD_CODEX_ZDOTDIR || '').trim();
1423
- dir = override || path.join(os.tmpdir(), 'codex-zdotdir');
1424
- return [4 /*yield*/, fs_1.promises.mkdir(dir, { recursive: true })];
1425
- case 1:
1426
- _a.sent();
1427
- return [4 /*yield*/, Promise.allSettled([
1428
- fs_1.promises.writeFile(path.join(dir, '.zshrc'), '', { flag: 'a' }),
1429
- fs_1.promises.writeFile(path.join(dir, '.zprofile'), '', { flag: 'a' })
1430
- ])];
1431
- case 2:
1432
- _a.sent();
1433
- this.zDotDir = dir;
1434
- return [2 /*return*/, dir];
1435
- }
1436
- });
1437
- });
1438
- };
1439
- CodexClient.prototype.resolvePingEnabled = function () {
1440
- return this.normalizeBoolean(process.env.AI_DASHBOARD_CODEX_PING, false);
1441
- };
1442
- CodexClient.prototype.resolvePingTimeoutMs = function () {
1443
- var raw = Number(process.env.AI_DASHBOARD_CODEX_PING_TIMEOUT_MS);
1444
- if (Number.isFinite(raw) && raw > 0) {
1445
- return Math.floor(raw);
1446
- }
1447
- return 10000;
1448
- };
1449
- CodexClient.prototype.resolveDefaultThreadOptions = function () {
1450
- var approvalPolicy = this.normalizeApprovalPolicy(process.env.AI_DASHBOARD_CODEX_APPROVAL_POLICY);
1451
- var sandboxMode = this.normalizeSandboxMode(process.env.AI_DASHBOARD_CODEX_SANDBOX_MODE, 'workspace-write');
1452
- var skipGitRepoCheck = this.normalizeBoolean(process.env.AI_DASHBOARD_CODEX_SKIP_GIT_CHECK, true);
1453
- var webSearchMode = this.normalizeWebSearchMode(process.env.AI_DASHBOARD_CODEX_WEB_SEARCH_MODE);
1454
- var webSearchEnabled = this.normalizeBoolean(process.env.AI_DASHBOARD_CODEX_WEB_SEARCH_ENABLED, false);
1455
- var networkAccessEnabled = this.normalizeBoolean(process.env.AI_DASHBOARD_CODEX_NETWORK_ACCESS_ENABLED, false);
1456
- var modelReasoningEffort = this.normalizeModelReasoningEffort(process.env.AI_DASHBOARD_CODEX_REASONING_EFFORT);
1457
- return {
1458
- model: this.config.model,
1459
- approvalPolicy: approvalPolicy,
1460
- sandboxMode: sandboxMode,
1461
- skipGitRepoCheck: skipGitRepoCheck,
1462
- webSearchMode: webSearchMode,
1463
- webSearchEnabled: webSearchEnabled,
1464
- networkAccessEnabled: networkAccessEnabled,
1465
- modelReasoningEffort: modelReasoningEffort
1466
- };
1467
- };
1468
- CodexClient.prototype.mergeThreadOptions = function (overrides) {
1469
- var merged = __assign(__assign({}, this.defaultThreadOptions), (overrides || {}));
1470
- var effectiveModel = this.normalizeOptionalString(merged.model || this.config.model);
1471
- var normalizedEffort = this.normalizeModelReasoningEffortForModel(effectiveModel, merged.modelReasoningEffort);
1472
- if (normalizedEffort && normalizedEffort !== merged.modelReasoningEffort) {
1473
- this.log("normalized reasoning effort for model=".concat(effectiveModel || 'default', ": ").concat(merged.modelReasoningEffort, " -> ").concat(normalizedEffort));
1474
- merged.modelReasoningEffort = normalizedEffort;
1475
- }
1476
- var cleaned = Object.entries(merged).reduce(function (acc, _a) {
1477
- var _b = __read(_a, 2), key = _b[0], value = _b[1];
1478
- if (value === undefined || value === null || value === '') {
1479
- return acc;
1480
- }
1481
- acc[key] = value;
1482
- return acc;
1483
- }, {});
1484
- return Object.keys(cleaned).length ? cleaned : undefined;
1485
- };
1486
- CodexClient.prototype.normalizeApprovalPolicy = function (value) {
1487
- var normalized = (value || '').trim().toLowerCase();
1488
- if (normalized === 'never' || normalized === 'on-request' || normalized === 'on-failure' || normalized === 'untrusted') {
1489
- return normalized;
1490
- }
1491
- return 'never';
1492
- };
1493
- CodexClient.prototype.normalizeSandboxMode = function (value, fallback) {
1494
- if (fallback === void 0) { fallback = 'read-only'; }
1495
- var normalized = (value || '').trim().toLowerCase();
1496
- if (normalized === 'read-only' || normalized === 'workspace-write' || normalized === 'danger-full-access') {
1497
- return normalized;
1498
- }
1499
- return fallback;
1500
- };
1501
- CodexClient.prototype.normalizeWebSearchMode = function (value) {
1502
- var normalized = (value || '').trim().toLowerCase();
1503
- if (normalized === 'disabled' || normalized === 'cached' || normalized === 'live') {
1504
- return normalized;
1505
- }
1506
- return undefined;
1507
- };
1508
- CodexClient.prototype.normalizeModelReasoningEffort = function (value) {
1509
- var normalized = (value || '').trim().toLowerCase();
1510
- if (normalized === 'minimal' || normalized === 'none' || normalized === 'low' || normalized === 'medium' || normalized === 'high' || normalized === 'xhigh') {
1511
- return normalized;
1512
- }
1513
- return undefined;
1514
- };
1515
- CodexClient.prototype.normalizeModelReasoningEffortForModel = function (model, effort) {
1516
- if (!effort) {
1517
- return effort;
1518
- }
1519
- var normalizedModel = this.normalizeOptionalString(model).toLowerCase();
1520
- if (effort === 'minimal' && (!normalizedModel || normalizedModel.startsWith('gpt-5') || normalizedModel.includes('codex'))) {
1521
- return 'low';
1522
- }
1523
- return effort;
1524
- };
1525
- CodexClient.prototype.normalizeBoolean = function (value, fallback) {
1526
- if (!value) {
1527
- return fallback;
1528
- }
1529
- var normalized = value.trim().toLowerCase();
1530
- if (['true', '1', 'yes', 'y', 'on'].includes(normalized)) {
1531
- return true;
1532
- }
1533
- if (['false', '0', 'no', 'n', 'off'].includes(normalized)) {
1534
- return false;
1535
- }
1536
- return fallback;
1537
- };
1538
- CodexClient.prototype.formatThreadOptions = function (options) {
1539
- var summary = {};
1540
- Object.entries(options).forEach(function (_a) {
1541
- var _b = __read(_a, 2), key = _b[0], value = _b[1];
1542
- if (value === undefined || value === null) {
1543
- return;
1544
- }
1545
- summary[key] = String(value);
1546
- });
1547
- return JSON.stringify(summary);
1548
- };
1549
- CodexClient.prototype.buildThreadOptionsKey = function (options) {
1550
- if (!options) {
1551
- return '';
1552
- }
1553
- var ordered = {};
1554
- Object.keys(options)
1555
- .sort()
1556
- .forEach(function (key) {
1557
- var value = options[key];
1558
- if (value === undefined || value === null) {
1559
- return;
1560
- }
1561
- ordered[key] = Array.isArray(value) ? JSON.stringify(value) : String(value);
1562
- });
1563
- return JSON.stringify(ordered);
1564
- };
1565
- CodexClient.prototype.buildThreadCacheKey = function (threadKey, options) {
1566
- if (threadKey) {
1567
- return "thread:".concat(threadKey);
1568
- }
1569
- var model = (options === null || options === void 0 ? void 0 : options.model) || this.config.model;
1570
- var workingDirectory = options === null || options === void 0 ? void 0 : options.workingDirectory;
1571
- if (!model && !workingDirectory) {
1572
- return null;
1573
- }
1574
- return "thread:auto:".concat(model || 'default', ":").concat(workingDirectory || 'root');
1575
- };
1576
- CodexClient.prototype.isPingPrompt = function (prompt) {
1577
- return prompt.trim() === CodexClient.PING_PROMPT;
1578
- };
1579
- CodexClient.prototype.runPing = function (threadOptions) {
1580
- return __awaiter(this, void 0, void 0, function () {
1581
- var content, trimmed, preview, error_7, message;
1582
- return __generator(this, function (_a) {
1583
- switch (_a.label) {
1584
- case 0:
1585
- this.log("runPing start (timeoutMs=".concat(this.pingTimeoutMs, ")"));
1586
- _a.label = 1;
1587
- case 1:
1588
- _a.trys.push([1, 3, , 4]);
1589
- return [4 /*yield*/, this.runOnce(CodexClient.PING_PROMPT, {
1590
- timeoutMs: this.pingTimeoutMs,
1591
- threadOptions: threadOptions,
1592
- reuseThread: false
1593
- })];
1594
- case 2:
1595
- content = _a.sent();
1596
- trimmed = content.trim();
1597
- preview = trimmed.length > 80 ? "".concat(trimmed.slice(0, 80), "\u2026") : trimmed;
1598
- this.log("runPing response: ".concat(preview));
1599
- return [3 /*break*/, 4];
1600
- case 3:
1601
- error_7 = _a.sent();
1602
- message = error_7 instanceof Error ? error_7.message : String(error_7 || 'Unknown error');
1603
- this.log("runPing failed: ".concat(message));
1604
- throw error_7;
1605
- case 4: return [2 /*return*/];
1606
- }
1607
- });
1608
- });
1609
- };
1610
- CodexClient.PING_PROMPT = "Say 'pong'";
1611
- CodexClient.MODEL_UNAVAILABLE_FALLBACK_FILE = path.join(os.tmpdir(), 'resolveio-codex-model-fallbacks.json');
1612
- CodexClient.DEFAULT_MODEL_UNAVAILABLE_TTL_MS = 6 * 60 * 60 * 1000;
1613
- CodexClient.MIN_MODEL_UNAVAILABLE_TTL_MS = 60 * 1000;
1614
- CodexClient.modelFallbackPreferences = new Map();
1615
- CodexClient.modelFallbackPreferencesLoaded = false;
1616
- CodexClient.modelFallbackPreferencesLoadPromise = null;
1617
- CodexClient.cwdFallbackRunning = false;
1618
- return CodexClient;
1619
- }());
1620
- exports.CodexClient = CodexClient;
1621
-
1622
- //# sourceMappingURL=codex-client.js.map