@resolveio/server-lib 22.3.3 → 22.3.5

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