@resolveio/server-lib 22.3.42 → 22.3.44

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