@resolveio/server-lib 22.3.219 → 22.3.221

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (745) hide show
  1. package/.nodemon.json +5 -0
  2. package/.vscode/settings.json +21 -0
  3. package/AGENTS.md +195 -0
  4. package/README.md +22 -0
  5. package/build_package.sh +5 -0
  6. package/compileDTS.pl +64 -0
  7. package/docs/ai-assistant-nightly-eval.md +65 -0
  8. package/docs/ai-assistant-preflight-checklist.md +23 -0
  9. package/docs/ai-assistant-report-builder-bridge-playbook.md +115 -0
  10. package/eslint-plugin-custom/index.js +7 -0
  11. package/eslint-plugin-custom/rules/no-filter-zero-index.js +44 -0
  12. package/eslint.config.js +103 -0
  13. package/gulpfile.js +216 -0
  14. package/methodAndPublicationListGenerator.py +375 -0
  15. package/mongodbensurers.js +2 -0
  16. package/mongostop.js +3 -0
  17. package/package.json +1 -1
  18. package/scripts/cleanup-bypassed-callmethod-logs.js +616 -0
  19. package/settings.development.json +25 -0
  20. package/settings.development.redacted.json +25 -0
  21. package/src/.env +12 -0
  22. package/src/ai/assistant-core-heuristics.ts +379 -0
  23. package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +185 -0
  24. package/src/ai/resolveio-platform-intelligence-memory.ts +325 -0
  25. package/{ai/resolveio-platform-intelligence-types.d.ts → src/ai/resolveio-platform-intelligence-types.ts} +20 -15
  26. package/src/ai/resolveio-platform-intelligence.ts +462 -0
  27. package/src/client-server-app.ts +12 -0
  28. package/src/collections/ai-run.collection.ts +117 -0
  29. package/src/collections/ai-terminal-conversation.collection.ts +91 -0
  30. package/src/collections/ai-terminal-issue-report.collection.ts +99 -0
  31. package/src/collections/ai-terminal-message.collection.ts +77 -0
  32. package/src/collections/app-setting.collection.ts +104 -0
  33. package/src/collections/app-status.collection.ts +58 -0
  34. package/src/collections/communication-metric.collection.ts +84 -0
  35. package/src/collections/counter.collection.ts +56 -0
  36. package/src/collections/cron-job-history.collection.ts +94 -0
  37. package/src/collections/cron-job.collection.ts +92 -0
  38. package/src/collections/customer-notification.collection.ts +131 -0
  39. package/src/collections/customer-portal-password.collection.ts +76 -0
  40. package/src/collections/email-history.collection.ts +134 -0
  41. package/src/collections/email-verified.collection.ts +62 -0
  42. package/src/collections/file.collection.ts +74 -0
  43. package/src/collections/flag-update.collection.ts +57 -0
  44. package/src/collections/flag.collection.ts +57 -0
  45. package/src/collections/log-method-latency.collection.ts +77 -0
  46. package/src/collections/log-subscription.collection.ts +80 -0
  47. package/src/collections/log.collection.ts +93 -0
  48. package/src/collections/logged-in-users.collection.ts +67 -0
  49. package/src/collections/monitor-cpu.collection.ts +65 -0
  50. package/src/collections/monitor-function.collection.ts +74 -0
  51. package/src/collections/monitor-memory.collection.ts +77 -0
  52. package/src/collections/monitor-mongo.collection.ts +71 -0
  53. package/src/collections/notification.collection.ts +57 -0
  54. package/src/collections/openai-usage-ledger.collection.ts +131 -0
  55. package/src/collections/report-builder-dashboard-builder.collection.ts +109 -0
  56. package/src/collections/report-builder-library.collection.ts +89 -0
  57. package/src/collections/report-builder-report.collection.ts +184 -0
  58. package/src/collections/user-group.collection.ts +89 -0
  59. package/src/collections/user-guide.collection.ts +57 -0
  60. package/src/collections/user.collection.ts +181 -0
  61. package/src/cron/cron.ts +117 -0
  62. package/src/fixtures/cron-jobs.ts +95 -0
  63. package/src/fixtures/init.ts +35 -0
  64. package/src/http/auth.ts +818 -0
  65. package/src/http/health.ts +7 -0
  66. package/src/http/home.ts +90 -0
  67. package/src/http/slow-query-publication.ts +49 -0
  68. package/src/index.ts +1 -0
  69. package/src/managers/ai-assistant-codex-manager.manager.ts +1131 -0
  70. package/src/managers/ai-run-evidence.manager.ts +264 -0
  71. package/src/managers/communication-metric.manager.ts +82 -0
  72. package/src/managers/cron.manager.ts +333 -0
  73. package/src/managers/customer-notification-content.manager.ts +236 -0
  74. package/src/managers/diagnostic-manager-bootstrap.ts +165 -0
  75. package/src/managers/error-auto-fix.manager.ts +2767 -0
  76. package/src/managers/local-log.manager.ts +113 -0
  77. package/src/managers/method.manager.ts +1857 -0
  78. package/src/managers/mongo.manager.ts +4575 -0
  79. package/src/managers/monitor.manager.ts +507 -0
  80. package/src/managers/openai-usage-ledger.manager.ts +112 -0
  81. package/src/managers/slow-query-verifier.manager.ts +3590 -0
  82. package/src/managers/slow-query.manager.ts +519 -0
  83. package/src/managers/subscription.manager.ts +3128 -0
  84. package/src/managers/websocket.manager.ts +746 -0
  85. package/src/managers/worker-dispatcher.manager.ts +1360 -0
  86. package/src/managers/worker-server.manager.ts +536 -0
  87. package/src/methods/accounts.ts +532 -0
  88. package/src/methods/ai-terminal.ts +29070 -0
  89. package/src/methods/app-settings.ts +114 -0
  90. package/src/methods/aws.ts +649 -0
  91. package/src/methods/collections.ts +641 -0
  92. package/src/methods/counters.ts +69 -0
  93. package/src/methods/cron-jobs.ts +2614 -0
  94. package/src/methods/customer-notifications.ts +458 -0
  95. package/src/methods/diagnostics.ts +616 -0
  96. package/src/methods/flag-updates.ts +7 -0
  97. package/src/methods/flags.ts +7 -0
  98. package/src/methods/logs.ts +657 -0
  99. package/src/methods/mongo-explorer.ts +1880 -0
  100. package/src/methods/monitor.ts +540 -0
  101. package/src/methods/pdf.ts +1236 -0
  102. package/src/methods/publications.ts +129 -0
  103. package/src/methods/report-builder.ts +3300 -0
  104. package/src/methods/support.ts +335 -0
  105. package/src/models/ai-run.model.ts +27 -0
  106. package/src/models/ai-terminal-conversation.model.ts +19 -0
  107. package/src/models/ai-terminal-issue-report.model.ts +21 -0
  108. package/src/models/ai-terminal-message.model.ts +24 -0
  109. package/src/models/app-setting.model.ts +17 -0
  110. package/{models/app-status.model.d.ts → src/models/app-status.model.ts} +3 -2
  111. package/{models/billing-logged-in-users.model.d.ts → src/models/billing-logged-in-users.model.ts} +5 -4
  112. package/src/models/collection-document.model.ts +24 -0
  113. package/src/models/communication-metric.model.ts +23 -0
  114. package/{models/counter.model.d.ts → src/models/counter.model.ts} +4 -3
  115. package/src/models/cron-job-history.model.ts +16 -0
  116. package/src/models/cron-job.model.ts +15 -0
  117. package/src/models/customer-notification.model.ts +28 -0
  118. package/src/models/customer-portal-password.model.ts +12 -0
  119. package/src/models/dialog.model.ts +25 -0
  120. package/{models/email-history.model.js → src/models/email-history.model.ts} +36 -4
  121. package/{models/email-verified.model.d.ts → src/models/email-verified.model.ts} +6 -5
  122. package/{models/file.model.d.ts → src/models/file.model.ts} +8 -7
  123. package/{models/flag-update.model.d.ts → src/models/flag-update.model.ts} +4 -3
  124. package/{models/flag.model.d.ts → src/models/flag.model.ts} +4 -3
  125. package/src/models/log-method-latency.model.ts +11 -0
  126. package/{models/log-subscription.model.d.ts → src/models/log-subscription.model.ts} +11 -9
  127. package/src/models/log.model.ts +19 -0
  128. package/{models/logged-in-users.model.d.ts → src/models/logged-in-users.model.ts} +6 -5
  129. package/{models/method-response.model.d.ts → src/models/method-response.model.ts} +7 -6
  130. package/src/models/method.model.ts +25 -0
  131. package/{models/monitor-cpu.model.d.ts → src/models/monitor-cpu.model.ts} +9 -7
  132. package/src/models/monitor-function.model.ts +16 -0
  133. package/src/models/monitor-memory.model.ts +17 -0
  134. package/src/models/monitor-mongo.model.ts +15 -0
  135. package/{models/notification.model.d.ts → src/models/notification.model.ts} +6 -4
  136. package/src/models/openai-usage-ledger.model.ts +56 -0
  137. package/src/models/pagination.model.ts +35 -0
  138. package/src/models/permission.model.ts +14 -0
  139. package/src/models/report-builder-dashboard-builder.model.ts +29 -0
  140. package/src/models/report-builder-library.model.ts +20 -0
  141. package/src/models/report-builder-report.model.ts +136 -0
  142. package/src/models/report-builder.model.ts +68 -0
  143. package/src/models/select-data-label.model.ts +9 -0
  144. package/src/models/server-message.model.ts +31 -0
  145. package/src/models/slow-query-report.model.ts +23 -0
  146. package/src/models/subscription.model.ts +73 -0
  147. package/src/models/support-ticket.model.ts +104 -0
  148. package/src/models/user-group.model.ts +24 -0
  149. package/{models/user-guide.model.d.ts → src/models/user-guide.model.ts} +5 -4
  150. package/src/models/user.model.ts +96 -0
  151. package/src/private/images/ResolveIO.png +0 -0
  152. package/src/publications/ai-terminal.ts +73 -0
  153. package/src/publications/app-settings.ts +25 -0
  154. package/src/publications/app-status.ts +13 -0
  155. package/src/publications/cron-jobs.ts +40 -0
  156. package/src/publications/customer-notifications.ts +101 -0
  157. package/src/publications/files.ts +33 -0
  158. package/src/publications/flags-update.ts +19 -0
  159. package/src/publications/flags.ts +19 -0
  160. package/src/publications/logs.ts +163 -0
  161. package/src/publications/notifications.ts +13 -0
  162. package/src/publications/report-builder-dashboard-builders.ts +39 -0
  163. package/src/publications/report-builder-libraries.ts +41 -0
  164. package/src/publications/report-builder-reports.ts +47 -0
  165. package/src/publications/super-admin.ts +13 -0
  166. package/src/publications/user-groups.ts +12 -0
  167. package/src/publications/user-guides.ts +12 -0
  168. package/src/resolveio-server-app.ts +617 -0
  169. package/src/server-app.ts +3354 -0
  170. package/src/services/codex-client.ts +1231 -0
  171. package/src/services/openai-client.ts +265 -0
  172. package/src/types/error-report.ts +26 -0
  173. package/src/types/js-tiktoken.d.ts +11 -0
  174. package/src/types/slow-query-report.ts +28 -0
  175. package/src/util/ai-qa-policy.ts +925 -0
  176. package/src/util/ai-run-evidence-adapters.ts +8347 -0
  177. package/src/util/ai-run-evidence-dashboard.ts +323 -0
  178. package/src/util/ai-run-evidence-eval.ts +1057 -0
  179. package/src/util/ai-run-evidence.ts +1430 -0
  180. package/src/util/ai-runner-artifacts.ts +586 -0
  181. package/src/util/ai-runner-manager-autopilot.ts +961 -0
  182. package/src/util/ai-runner-manager-policy.ts +5011 -0
  183. package/src/util/ai-runner-qa-auth.ts +838 -0
  184. package/src/util/ai-runner-qa-tools.ts +3536 -0
  185. package/src/util/aicoder-runner-v6.ts +3121 -0
  186. package/src/util/common.ts +649 -0
  187. package/src/util/customer-portal-password.ts +183 -0
  188. package/src/util/error-reporter.ts +332 -0
  189. package/src/util/error-tracking.ts +79 -0
  190. package/src/util/openai-usage-cost.ts +114 -0
  191. package/src/util/report-builder-unwinds.ts +180 -0
  192. package/src/util/runner-process-janitor.ts +219 -0
  193. package/src/util/schema-report-builder.ts +448 -0
  194. package/src/util/slow-query-reporter.ts +216 -0
  195. package/src/util/subscription-dependency-context.ts +1096 -0
  196. package/src/util/support-runner-v5.ts +10040 -0
  197. package/src/util/tokenizer.ts +38 -0
  198. package/src/workers/codex-runner.worker.ts +142 -0
  199. package/start_server.sh +5 -0
  200. package/tests/ai-assistant-corpus-build.ts +484 -0
  201. package/tests/ai-assistant-corpus-replay-e2e.ts +774 -0
  202. package/tests/ai-assistant-data-parity-e2e.ts +1989 -0
  203. package/tests/ai-assistant-eval-triage.ts +831 -0
  204. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  205. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  206. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  207. package/tests/ai-assistant-routing-eval.test.ts +585 -0
  208. package/tests/ai-assistant-snf-live-eval.ts +975 -0
  209. package/tests/ai-assistant-utils.test.ts +4834 -0
  210. package/tests/ai-manager-autopilot-snapshot.test.ts +193 -0
  211. package/tests/ai-manager-recovery-checkpoint.test.ts +1383 -0
  212. package/tests/ai-run-eval.test.ts +132 -0
  213. package/tests/ai-run-evidence.test.ts +3773 -0
  214. package/tests/ai-runner-contract.test.ts +515 -0
  215. package/tests/aicoder-runner-v6.test.ts +822 -0
  216. package/tests/error-reporter.test.ts +145 -0
  217. package/tests/method-publication-generator.test.ts +46 -0
  218. package/tests/report-builder-linking.test.ts +79 -0
  219. package/tests/resolveio-platform-intelligence.test.ts +352 -0
  220. package/tests/server-app-cron-owner.test.ts +127 -0
  221. package/tests/subscription-connect-race.test.ts +158 -0
  222. package/tests/subscription-dependency-context.test.ts +324 -0
  223. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  224. package/tests/subscription-manager-invalidation.test.ts +86 -0
  225. package/tests/support-runner-v5.test.ts +3201 -0
  226. package/tsconfig.json +34 -0
  227. package/ai/assistant-core-heuristics.d.ts +0 -11
  228. package/ai/assistant-core-heuristics.js +0 -356
  229. package/ai/assistant-core-heuristics.js.map +0 -1
  230. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +0 -3
  231. package/ai/resolveio-platform-intelligence-memory-corpus.js +0 -214
  232. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +0 -1
  233. package/ai/resolveio-platform-intelligence-memory.d.ts +0 -20
  234. package/ai/resolveio-platform-intelligence-memory.js +0 -341
  235. package/ai/resolveio-platform-intelligence-memory.js.map +0 -1
  236. package/ai/resolveio-platform-intelligence-types.js +0 -4
  237. package/ai/resolveio-platform-intelligence-types.js.map +0 -1
  238. package/ai/resolveio-platform-intelligence.d.ts +0 -6
  239. package/ai/resolveio-platform-intelligence.js +0 -463
  240. package/ai/resolveio-platform-intelligence.js.map +0 -1
  241. package/client-server-app.d.ts +0 -1
  242. package/client-server-app.js +0 -68
  243. package/client-server-app.js.map +0 -1
  244. package/collections/ai-run.collection.d.ts +0 -3
  245. package/collections/ai-run.collection.js +0 -170
  246. package/collections/ai-run.collection.js.map +0 -1
  247. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  248. package/collections/ai-terminal-conversation.collection.js +0 -140
  249. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  250. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  251. package/collections/ai-terminal-issue-report.collection.js +0 -148
  252. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  253. package/collections/ai-terminal-message.collection.d.ts +0 -2
  254. package/collections/ai-terminal-message.collection.js +0 -121
  255. package/collections/ai-terminal-message.collection.js.map +0 -1
  256. package/collections/app-setting.collection.d.ts +0 -3
  257. package/collections/app-setting.collection.js +0 -103
  258. package/collections/app-setting.collection.js.map +0 -1
  259. package/collections/app-status.collection.d.ts +0 -3
  260. package/collections/app-status.collection.js +0 -57
  261. package/collections/app-status.collection.js.map +0 -1
  262. package/collections/communication-metric.collection.d.ts +0 -2
  263. package/collections/communication-metric.collection.js +0 -133
  264. package/collections/communication-metric.collection.js.map +0 -1
  265. package/collections/counter.collection.d.ts +0 -3
  266. package/collections/counter.collection.js +0 -56
  267. package/collections/counter.collection.js.map +0 -1
  268. package/collections/cron-job-history.collection.d.ts +0 -3
  269. package/collections/cron-job-history.collection.js +0 -137
  270. package/collections/cron-job-history.collection.js.map +0 -1
  271. package/collections/cron-job.collection.d.ts +0 -3
  272. package/collections/cron-job.collection.js +0 -92
  273. package/collections/cron-job.collection.js.map +0 -1
  274. package/collections/customer-notification.collection.d.ts +0 -3
  275. package/collections/customer-notification.collection.js +0 -130
  276. package/collections/customer-notification.collection.js.map +0 -1
  277. package/collections/customer-portal-password.collection.d.ts +0 -3
  278. package/collections/customer-portal-password.collection.js +0 -75
  279. package/collections/customer-portal-password.collection.js.map +0 -1
  280. package/collections/email-history.collection.d.ts +0 -3
  281. package/collections/email-history.collection.js +0 -134
  282. package/collections/email-history.collection.js.map +0 -1
  283. package/collections/email-verified.collection.d.ts +0 -3
  284. package/collections/email-verified.collection.js +0 -62
  285. package/collections/email-verified.collection.js.map +0 -1
  286. package/collections/file.collection.d.ts +0 -3
  287. package/collections/file.collection.js +0 -74
  288. package/collections/file.collection.js.map +0 -1
  289. package/collections/flag-update.collection.d.ts +0 -3
  290. package/collections/flag-update.collection.js +0 -57
  291. package/collections/flag-update.collection.js.map +0 -1
  292. package/collections/flag.collection.d.ts +0 -3
  293. package/collections/flag.collection.js +0 -57
  294. package/collections/flag.collection.js.map +0 -1
  295. package/collections/log-method-latency.collection.d.ts +0 -3
  296. package/collections/log-method-latency.collection.js +0 -77
  297. package/collections/log-method-latency.collection.js.map +0 -1
  298. package/collections/log-subscription.collection.d.ts +0 -3
  299. package/collections/log-subscription.collection.js +0 -80
  300. package/collections/log-subscription.collection.js.map +0 -1
  301. package/collections/log.collection.d.ts +0 -3
  302. package/collections/log.collection.js +0 -93
  303. package/collections/log.collection.js.map +0 -1
  304. package/collections/logged-in-users.collection.d.ts +0 -3
  305. package/collections/logged-in-users.collection.js +0 -67
  306. package/collections/logged-in-users.collection.js.map +0 -1
  307. package/collections/monitor-cpu.collection.d.ts +0 -3
  308. package/collections/monitor-cpu.collection.js +0 -65
  309. package/collections/monitor-cpu.collection.js.map +0 -1
  310. package/collections/monitor-function.collection.d.ts +0 -3
  311. package/collections/monitor-function.collection.js +0 -74
  312. package/collections/monitor-function.collection.js.map +0 -1
  313. package/collections/monitor-memory.collection.d.ts +0 -3
  314. package/collections/monitor-memory.collection.js +0 -77
  315. package/collections/monitor-memory.collection.js.map +0 -1
  316. package/collections/monitor-mongo.collection.d.ts +0 -3
  317. package/collections/monitor-mongo.collection.js +0 -71
  318. package/collections/monitor-mongo.collection.js.map +0 -1
  319. package/collections/notification.collection.d.ts +0 -3
  320. package/collections/notification.collection.js +0 -57
  321. package/collections/notification.collection.js.map +0 -1
  322. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  323. package/collections/openai-usage-ledger.collection.js +0 -188
  324. package/collections/openai-usage-ledger.collection.js.map +0 -1
  325. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  326. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  327. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  328. package/collections/report-builder-library.collection.d.ts +0 -3
  329. package/collections/report-builder-library.collection.js +0 -87
  330. package/collections/report-builder-library.collection.js.map +0 -1
  331. package/collections/report-builder-report.collection.d.ts +0 -4
  332. package/collections/report-builder-report.collection.js +0 -184
  333. package/collections/report-builder-report.collection.js.map +0 -1
  334. package/collections/user-group.collection.d.ts +0 -4
  335. package/collections/user-group.collection.js +0 -89
  336. package/collections/user-group.collection.js.map +0 -1
  337. package/collections/user-guide.collection.d.ts +0 -3
  338. package/collections/user-guide.collection.js +0 -57
  339. package/collections/user-guide.collection.js.map +0 -1
  340. package/collections/user.collection.d.ts +0 -4
  341. package/collections/user.collection.js +0 -180
  342. package/collections/user.collection.js.map +0 -1
  343. package/cron/cron.d.ts +0 -14
  344. package/cron/cron.js +0 -216
  345. package/cron/cron.js.map +0 -1
  346. package/fixtures/cron-jobs.d.ts +0 -1
  347. package/fixtures/cron-jobs.js +0 -150
  348. package/fixtures/cron-jobs.js.map +0 -1
  349. package/fixtures/init.d.ts +0 -1
  350. package/fixtures/init.js +0 -91
  351. package/fixtures/init.js.map +0 -1
  352. package/http/auth.d.ts +0 -2
  353. package/http/auth.js +0 -951
  354. package/http/auth.js.map +0 -1
  355. package/http/health.d.ts +0 -1
  356. package/http/health.js +0 -11
  357. package/http/health.js.map +0 -1
  358. package/http/home.d.ts +0 -1
  359. package/http/home.js +0 -134
  360. package/http/home.js.map +0 -1
  361. package/http/slow-query-publication.d.ts +0 -2
  362. package/http/slow-query-publication.js +0 -99
  363. package/http/slow-query-publication.js.map +0 -1
  364. package/index.d.ts +0 -1
  365. package/index.js +0 -19
  366. package/index.js.map +0 -1
  367. package/managers/ai-assistant-codex-manager.manager.d.ts +0 -67
  368. package/managers/ai-assistant-codex-manager.manager.js +0 -1113
  369. package/managers/ai-assistant-codex-manager.manager.js.map +0 -1
  370. package/managers/ai-run-evidence.manager.d.ts +0 -36
  371. package/managers/ai-run-evidence.manager.js +0 -377
  372. package/managers/ai-run-evidence.manager.js.map +0 -1
  373. package/managers/communication-metric.manager.d.ts +0 -16
  374. package/managers/communication-metric.manager.js +0 -134
  375. package/managers/communication-metric.manager.js.map +0 -1
  376. package/managers/cron.manager.d.ts +0 -20
  377. package/managers/cron.manager.js +0 -534
  378. package/managers/cron.manager.js.map +0 -1
  379. package/managers/customer-notification-content.manager.d.ts +0 -55
  380. package/managers/customer-notification-content.manager.js +0 -158
  381. package/managers/customer-notification-content.manager.js.map +0 -1
  382. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  383. package/managers/diagnostic-manager-bootstrap.js +0 -260
  384. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  385. package/managers/error-auto-fix.manager.d.ts +0 -149
  386. package/managers/error-auto-fix.manager.js +0 -3064
  387. package/managers/error-auto-fix.manager.js.map +0 -1
  388. package/managers/local-log.manager.d.ts +0 -18
  389. package/managers/local-log.manager.js +0 -88
  390. package/managers/local-log.manager.js.map +0 -1
  391. package/managers/method.manager.d.ts +0 -84
  392. package/managers/method.manager.js +0 -1964
  393. package/managers/method.manager.js.map +0 -1
  394. package/managers/mongo.manager.d.ts +0 -224
  395. package/managers/mongo.manager.js +0 -5000
  396. package/managers/mongo.manager.js.map +0 -1
  397. package/managers/monitor.manager.d.ts +0 -70
  398. package/managers/monitor.manager.js +0 -550
  399. package/managers/monitor.manager.js.map +0 -1
  400. package/managers/openai-usage-ledger.manager.d.ts +0 -30
  401. package/managers/openai-usage-ledger.manager.js +0 -142
  402. package/managers/openai-usage-ledger.manager.js.map +0 -1
  403. package/managers/slow-query-verifier.manager.d.ts +0 -144
  404. package/managers/slow-query-verifier.manager.js +0 -3857
  405. package/managers/slow-query-verifier.manager.js.map +0 -1
  406. package/managers/slow-query.manager.d.ts +0 -28
  407. package/managers/slow-query.manager.js +0 -468
  408. package/managers/slow-query.manager.js.map +0 -1
  409. package/managers/subscription.manager.d.ts +0 -169
  410. package/managers/subscription.manager.js +0 -3434
  411. package/managers/subscription.manager.js.map +0 -1
  412. package/managers/websocket.manager.d.ts +0 -73
  413. package/managers/websocket.manager.js +0 -673
  414. package/managers/websocket.manager.js.map +0 -1
  415. package/managers/worker-dispatcher.manager.d.ts +0 -120
  416. package/managers/worker-dispatcher.manager.js +0 -1266
  417. package/managers/worker-dispatcher.manager.js.map +0 -1
  418. package/managers/worker-server.manager.d.ts +0 -35
  419. package/managers/worker-server.manager.js +0 -582
  420. package/managers/worker-server.manager.js.map +0 -1
  421. package/methods/accounts.d.ts +0 -2
  422. package/methods/accounts.js +0 -624
  423. package/methods/accounts.js.map +0 -1
  424. package/methods/ai-terminal.d.ts +0 -458
  425. package/methods/ai-terminal.js +0 -27991
  426. package/methods/ai-terminal.js.map +0 -1
  427. package/methods/app-settings.d.ts +0 -2
  428. package/methods/app-settings.js +0 -169
  429. package/methods/app-settings.js.map +0 -1
  430. package/methods/aws.d.ts +0 -2
  431. package/methods/aws.js +0 -877
  432. package/methods/aws.js.map +0 -1
  433. package/methods/collections.d.ts +0 -2
  434. package/methods/collections.js +0 -719
  435. package/methods/collections.js.map +0 -1
  436. package/methods/counters.d.ts +0 -2
  437. package/methods/counters.js +0 -113
  438. package/methods/counters.js.map +0 -1
  439. package/methods/cron-jobs.d.ts +0 -2
  440. package/methods/cron-jobs.js +0 -2475
  441. package/methods/cron-jobs.js.map +0 -1
  442. package/methods/customer-notifications.d.ts +0 -2
  443. package/methods/customer-notifications.js +0 -528
  444. package/methods/customer-notifications.js.map +0 -1
  445. package/methods/diagnostics.d.ts +0 -2
  446. package/methods/diagnostics.js +0 -703
  447. package/methods/diagnostics.js.map +0 -1
  448. package/methods/flag-updates.d.ts +0 -2
  449. package/methods/flag-updates.js +0 -8
  450. package/methods/flag-updates.js.map +0 -1
  451. package/methods/flags.d.ts +0 -2
  452. package/methods/flags.js +0 -8
  453. package/methods/flags.js.map +0 -1
  454. package/methods/logs.d.ts +0 -2
  455. package/methods/logs.js +0 -751
  456. package/methods/logs.js.map +0 -1
  457. package/methods/mongo-explorer.d.ts +0 -2
  458. package/methods/mongo-explorer.js +0 -1808
  459. package/methods/mongo-explorer.js.map +0 -1
  460. package/methods/monitor.d.ts +0 -2
  461. package/methods/monitor.js +0 -543
  462. package/methods/monitor.js.map +0 -1
  463. package/methods/pdf.d.ts +0 -2
  464. package/methods/pdf.js +0 -1216
  465. package/methods/pdf.js.map +0 -1
  466. package/methods/publications.d.ts +0 -1
  467. package/methods/publications.js +0 -183
  468. package/methods/publications.js.map +0 -1
  469. package/methods/report-builder.d.ts +0 -2
  470. package/methods/report-builder.js +0 -3094
  471. package/methods/report-builder.js.map +0 -1
  472. package/methods/support.d.ts +0 -2
  473. package/methods/support.js +0 -430
  474. package/methods/support.js.map +0 -1
  475. package/models/ai-run.model.d.ts +0 -19
  476. package/models/ai-run.model.js +0 -4
  477. package/models/ai-run.model.js.map +0 -1
  478. package/models/ai-terminal-conversation.model.d.ts +0 -17
  479. package/models/ai-terminal-conversation.model.js +0 -4
  480. package/models/ai-terminal-conversation.model.js.map +0 -1
  481. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  482. package/models/ai-terminal-issue-report.model.js +0 -4
  483. package/models/ai-terminal-issue-report.model.js.map +0 -1
  484. package/models/ai-terminal-message.model.d.ts +0 -22
  485. package/models/ai-terminal-message.model.js +0 -4
  486. package/models/ai-terminal-message.model.js.map +0 -1
  487. package/models/app-setting.model.d.ts +0 -16
  488. package/models/app-setting.model.js +0 -4
  489. package/models/app-setting.model.js.map +0 -1
  490. package/models/app-status.model.js +0 -4
  491. package/models/app-status.model.js.map +0 -1
  492. package/models/billing-logged-in-users.model.js +0 -4
  493. package/models/billing-logged-in-users.model.js.map +0 -1
  494. package/models/collection-document.model.d.ts +0 -21
  495. package/models/collection-document.model.js +0 -4
  496. package/models/collection-document.model.js.map +0 -1
  497. package/models/communication-metric.model.d.ts +0 -20
  498. package/models/communication-metric.model.js +0 -4
  499. package/models/communication-metric.model.js.map +0 -1
  500. package/models/counter.model.js +0 -4
  501. package/models/counter.model.js.map +0 -1
  502. package/models/cron-job-history.model.d.ts +0 -15
  503. package/models/cron-job-history.model.js +0 -4
  504. package/models/cron-job-history.model.js.map +0 -1
  505. package/models/cron-job.model.d.ts +0 -14
  506. package/models/cron-job.model.js +0 -4
  507. package/models/cron-job.model.js.map +0 -1
  508. package/models/customer-notification.model.d.ts +0 -26
  509. package/models/customer-notification.model.js +0 -4
  510. package/models/customer-notification.model.js.map +0 -1
  511. package/models/customer-portal-password.model.d.ts +0 -11
  512. package/models/customer-portal-password.model.js +0 -4
  513. package/models/customer-portal-password.model.js.map +0 -1
  514. package/models/dialog.model.d.ts +0 -23
  515. package/models/dialog.model.js +0 -4
  516. package/models/dialog.model.js.map +0 -1
  517. package/models/email-history.model.d.ts +0 -32
  518. package/models/email-history.model.js.map +0 -1
  519. package/models/email-verified.model.js +0 -4
  520. package/models/email-verified.model.js.map +0 -1
  521. package/models/file.model.js +0 -4
  522. package/models/file.model.js.map +0 -1
  523. package/models/flag-update.model.js +0 -4
  524. package/models/flag-update.model.js.map +0 -1
  525. package/models/flag.model.js +0 -4
  526. package/models/flag.model.js.map +0 -1
  527. package/models/log-method-latency.model.d.ts +0 -10
  528. package/models/log-method-latency.model.js +0 -4
  529. package/models/log-method-latency.model.js.map +0 -1
  530. package/models/log-subscription.model.js +0 -4
  531. package/models/log-subscription.model.js.map +0 -1
  532. package/models/log.model.d.ts +0 -17
  533. package/models/log.model.js +0 -4
  534. package/models/log.model.js.map +0 -1
  535. package/models/logged-in-users.model.js +0 -4
  536. package/models/logged-in-users.model.js.map +0 -1
  537. package/models/method-response.model.js +0 -4
  538. package/models/method-response.model.js.map +0 -1
  539. package/models/method.model.d.ts +0 -26
  540. package/models/method.model.js +0 -4
  541. package/models/method.model.js.map +0 -1
  542. package/models/monitor-cpu.model.js +0 -4
  543. package/models/monitor-cpu.model.js.map +0 -1
  544. package/models/monitor-function.model.d.ts +0 -14
  545. package/models/monitor-function.model.js +0 -4
  546. package/models/monitor-function.model.js.map +0 -1
  547. package/models/monitor-memory.model.d.ts +0 -15
  548. package/models/monitor-memory.model.js +0 -4
  549. package/models/monitor-memory.model.js.map +0 -1
  550. package/models/monitor-mongo.model.d.ts +0 -13
  551. package/models/monitor-mongo.model.js +0 -4
  552. package/models/monitor-mongo.model.js.map +0 -1
  553. package/models/notification.model.js +0 -4
  554. package/models/notification.model.js.map +0 -1
  555. package/models/openai-usage-ledger.model.d.ts +0 -30
  556. package/models/openai-usage-ledger.model.js +0 -4
  557. package/models/openai-usage-ledger.model.js.map +0 -1
  558. package/models/pagination.model.d.ts +0 -11
  559. package/models/pagination.model.js +0 -28
  560. package/models/pagination.model.js.map +0 -1
  561. package/models/permission.model.d.ts +0 -12
  562. package/models/permission.model.js +0 -4
  563. package/models/permission.model.js.map +0 -1
  564. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  565. package/models/report-builder-dashboard-builder.model.js +0 -4
  566. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  567. package/models/report-builder-library.model.d.ts +0 -17
  568. package/models/report-builder-library.model.js +0 -4
  569. package/models/report-builder-library.model.js.map +0 -1
  570. package/models/report-builder-report.model.d.ts +0 -121
  571. package/models/report-builder-report.model.js +0 -4
  572. package/models/report-builder-report.model.js.map +0 -1
  573. package/models/report-builder.model.d.ts +0 -61
  574. package/models/report-builder.model.js +0 -4
  575. package/models/report-builder.model.js.map +0 -1
  576. package/models/select-data-label.model.d.ts +0 -9
  577. package/models/select-data-label.model.js +0 -4
  578. package/models/select-data-label.model.js.map +0 -1
  579. package/models/server-message.model.d.ts +0 -32
  580. package/models/server-message.model.js +0 -4
  581. package/models/server-message.model.js.map +0 -1
  582. package/models/slow-query-report.model.d.ts +0 -23
  583. package/models/slow-query-report.model.js +0 -4
  584. package/models/slow-query-report.model.js.map +0 -1
  585. package/models/subscription.model.d.ts +0 -31
  586. package/models/subscription.model.js +0 -4
  587. package/models/subscription.model.js.map +0 -1
  588. package/models/support-ticket.model.d.ts +0 -87
  589. package/models/support-ticket.model.js +0 -4
  590. package/models/support-ticket.model.js.map +0 -1
  591. package/models/user-group.model.d.ts +0 -20
  592. package/models/user-group.model.js +0 -4
  593. package/models/user-group.model.js.map +0 -1
  594. package/models/user-guide.model.js +0 -4
  595. package/models/user-guide.model.js.map +0 -1
  596. package/models/user.model.d.ts +0 -84
  597. package/models/user.model.js +0 -4
  598. package/models/user.model.js.map +0 -1
  599. package/private/images/ResolveIO.png +0 -0
  600. package/public_api.js +0 -127
  601. package/public_api.js.map +0 -1
  602. package/publications/ai-terminal.d.ts +0 -1
  603. package/publications/ai-terminal.js +0 -122
  604. package/publications/ai-terminal.js.map +0 -1
  605. package/publications/app-settings.d.ts +0 -2
  606. package/publications/app-settings.js +0 -28
  607. package/publications/app-settings.js.map +0 -1
  608. package/publications/app-status.d.ts +0 -2
  609. package/publications/app-status.js +0 -16
  610. package/publications/app-status.js.map +0 -1
  611. package/publications/cron-jobs.d.ts +0 -2
  612. package/publications/cron-jobs.js +0 -88
  613. package/publications/cron-jobs.js.map +0 -1
  614. package/publications/customer-notifications.d.ts +0 -2
  615. package/publications/customer-notifications.js +0 -161
  616. package/publications/customer-notifications.js.map +0 -1
  617. package/publications/files.d.ts +0 -2
  618. package/publications/files.js +0 -36
  619. package/publications/files.js.map +0 -1
  620. package/publications/flags-update.d.ts +0 -2
  621. package/publications/flags-update.js +0 -22
  622. package/publications/flags-update.js.map +0 -1
  623. package/publications/flags.d.ts +0 -2
  624. package/publications/flags.js +0 -22
  625. package/publications/flags.js.map +0 -1
  626. package/publications/logs.d.ts +0 -2
  627. package/publications/logs.js +0 -164
  628. package/publications/logs.js.map +0 -1
  629. package/publications/notifications.d.ts +0 -2
  630. package/publications/notifications.js +0 -16
  631. package/publications/notifications.js.map +0 -1
  632. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  633. package/publications/report-builder-dashboard-builders.js +0 -42
  634. package/publications/report-builder-dashboard-builders.js.map +0 -1
  635. package/publications/report-builder-libraries.d.ts +0 -2
  636. package/publications/report-builder-libraries.js +0 -90
  637. package/publications/report-builder-libraries.js.map +0 -1
  638. package/publications/report-builder-reports.d.ts +0 -2
  639. package/publications/report-builder-reports.js +0 -50
  640. package/publications/report-builder-reports.js.map +0 -1
  641. package/publications/super-admin.d.ts +0 -2
  642. package/publications/super-admin.js +0 -16
  643. package/publications/super-admin.js.map +0 -1
  644. package/publications/user-groups.d.ts +0 -1
  645. package/publications/user-groups.js +0 -16
  646. package/publications/user-groups.js.map +0 -1
  647. package/publications/user-guides.d.ts +0 -1
  648. package/publications/user-guides.js +0 -16
  649. package/publications/user-guides.js.map +0 -1
  650. package/resolveio-server-app.d.ts +0 -70
  651. package/resolveio-server-app.js +0 -801
  652. package/resolveio-server-app.js.map +0 -1
  653. package/server-app.d.ts +0 -228
  654. package/server-app.js +0 -3566
  655. package/server-app.js.map +0 -1
  656. package/services/codex-client.d.ts +0 -128
  657. package/services/codex-client.js +0 -1629
  658. package/services/codex-client.js.map +0 -1
  659. package/services/openai-client.d.ts +0 -46
  660. package/services/openai-client.js +0 -318
  661. package/services/openai-client.js.map +0 -1
  662. package/types/error-report.d.ts +0 -25
  663. package/types/error-report.js +0 -4
  664. package/types/error-report.js.map +0 -1
  665. package/types/slow-query-report.d.ts +0 -27
  666. package/types/slow-query-report.js +0 -6
  667. package/types/slow-query-report.js.map +0 -1
  668. package/util/ai-qa-policy.d.ts +0 -124
  669. package/util/ai-qa-policy.js +0 -736
  670. package/util/ai-qa-policy.js.map +0 -1
  671. package/util/ai-run-evidence-adapters.d.ts +0 -109
  672. package/util/ai-run-evidence-adapters.js +0 -7234
  673. package/util/ai-run-evidence-adapters.js.map +0 -1
  674. package/util/ai-run-evidence-dashboard.d.ts +0 -88
  675. package/util/ai-run-evidence-dashboard.js +0 -343
  676. package/util/ai-run-evidence-dashboard.js.map +0 -1
  677. package/util/ai-run-evidence-eval.d.ts +0 -86
  678. package/util/ai-run-evidence-eval.js +0 -1018
  679. package/util/ai-run-evidence-eval.js.map +0 -1
  680. package/util/ai-run-evidence.d.ts +0 -244
  681. package/util/ai-run-evidence.js +0 -1096
  682. package/util/ai-run-evidence.js.map +0 -1
  683. package/util/ai-runner-artifacts.d.ts +0 -82
  684. package/util/ai-runner-artifacts.js +0 -713
  685. package/util/ai-runner-artifacts.js.map +0 -1
  686. package/util/ai-runner-manager-autopilot.d.ts +0 -210
  687. package/util/ai-runner-manager-autopilot.js +0 -642
  688. package/util/ai-runner-manager-autopilot.js.map +0 -1
  689. package/util/ai-runner-manager-policy.d.ts +0 -807
  690. package/util/ai-runner-manager-policy.js +0 -3501
  691. package/util/ai-runner-manager-policy.js.map +0 -1
  692. package/util/ai-runner-qa-auth.d.ts +0 -5
  693. package/util/ai-runner-qa-auth.js +0 -839
  694. package/util/ai-runner-qa-auth.js.map +0 -1
  695. package/util/ai-runner-qa-tools.d.ts +0 -26
  696. package/util/ai-runner-qa-tools.js +0 -3520
  697. package/util/ai-runner-qa-tools.js.map +0 -1
  698. package/util/aicoder-runner-v6.d.ts +0 -426
  699. package/util/aicoder-runner-v6.js +0 -2464
  700. package/util/aicoder-runner-v6.js.map +0 -1
  701. package/util/common.d.ts +0 -31
  702. package/util/common.js +0 -683
  703. package/util/common.js.map +0 -1
  704. package/util/customer-portal-password.d.ts +0 -13
  705. package/util/customer-portal-password.js +0 -209
  706. package/util/customer-portal-password.js.map +0 -1
  707. package/util/error-reporter.d.ts +0 -52
  708. package/util/error-reporter.js +0 -326
  709. package/util/error-reporter.js.map +0 -1
  710. package/util/error-tracking.d.ts +0 -13
  711. package/util/error-tracking.js +0 -120
  712. package/util/error-tracking.js.map +0 -1
  713. package/util/openai-usage-cost.d.ts +0 -6
  714. package/util/openai-usage-cost.js +0 -103
  715. package/util/openai-usage-cost.js.map +0 -1
  716. package/util/report-builder-unwinds.d.ts +0 -15
  717. package/util/report-builder-unwinds.js +0 -156
  718. package/util/report-builder-unwinds.js.map +0 -1
  719. package/util/runner-process-janitor.d.ts +0 -27
  720. package/util/runner-process-janitor.js +0 -208
  721. package/util/runner-process-janitor.js.map +0 -1
  722. package/util/schema-report-builder.d.ts +0 -6
  723. package/util/schema-report-builder.js +0 -481
  724. package/util/schema-report-builder.js.map +0 -1
  725. package/util/slow-query-reporter.d.ts +0 -28
  726. package/util/slow-query-reporter.js +0 -226
  727. package/util/slow-query-reporter.js.map +0 -1
  728. package/util/subscription-dependency-context.d.ts +0 -34
  729. package/util/subscription-dependency-context.js +0 -1283
  730. package/util/subscription-dependency-context.js.map +0 -1
  731. package/util/support-runner-v5.d.ts +0 -1426
  732. package/util/support-runner-v5.js +0 -7624
  733. package/util/support-runner-v5.js.map +0 -1
  734. package/util/tokenizer.d.ts +0 -5
  735. package/util/tokenizer.js +0 -41
  736. package/util/tokenizer.js.map +0 -1
  737. package/workers/codex-runner.worker.d.ts +0 -1
  738. package/workers/codex-runner.worker.js +0 -192
  739. package/workers/codex-runner.worker.js.map +0 -1
  740. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  741. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  742. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  743. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  744. /package/{private → src/private}/email-templates/support-ticket.html +0 -0
  745. /package/{public_api.d.ts → src/public_api.ts} +0 -0
@@ -0,0 +1,1057 @@
1
+ import {
2
+ AIRun,
3
+ AIRunOutcomeLabel,
4
+ AIRunSource,
5
+ AIRunTrainingExample,
6
+ buildAIRun,
7
+ buildAIQaRun,
8
+ redactAIRunTrainingExample
9
+ } from './ai-run-evidence';
10
+
11
+ export type AIRunFailureClass =
12
+ | 'none'
13
+ | 'infra'
14
+ | 'compile'
15
+ | 'route'
16
+ | 'journey_contract'
17
+ | 'business'
18
+ | 'release'
19
+ | 'false_pass'
20
+ | 'assistant_missing_evidence'
21
+ | 'assistant_query_error'
22
+ | 'assistant_permission'
23
+ | 'assistant_date_window'
24
+ | 'assistant_query_shape'
25
+ | 'assistant_correctness'
26
+ | 'manual'
27
+ | 'stopped'
28
+ | 'unknown';
29
+
30
+ export type AIRunRetryAction =
31
+ | 'none'
32
+ | 'stop'
33
+ | 'retry_infra_repair'
34
+ | 'retry_build_repair'
35
+ | 'retry_route_repair'
36
+ | 'retry_journey_contract'
37
+ | 'retry_business_repair'
38
+ | 'retry_release_repair'
39
+ | 'retry_assistant_answer_quality'
40
+ | 'retry_assistant_query'
41
+ | 'request_assistant_permission'
42
+ | 'retry_assistant_date_window'
43
+ | 'retry_assistant_query_shape'
44
+ | 'manual_handoff';
45
+
46
+ export interface AIRunEvalExpectedGate {
47
+ key: string;
48
+ status?: string;
49
+ }
50
+
51
+ export interface AIRunEvalExpected {
52
+ outcome: AIRunOutcomeLabel;
53
+ failureClass?: AIRunFailureClass;
54
+ nextActionIncludes?: string;
55
+ gates?: AIRunEvalExpectedGate[];
56
+ }
57
+
58
+ export interface AIRunEvalFixture {
59
+ id: string;
60
+ title: string;
61
+ source: AIRunSource;
62
+ run: AIRun;
63
+ expected: AIRunEvalExpected;
64
+ tags: string[];
65
+ }
66
+
67
+ export interface AIRunEvalResult {
68
+ id: string;
69
+ title: string;
70
+ source: AIRunSource;
71
+ passed: boolean;
72
+ actualOutcome: AIRunOutcomeLabel;
73
+ expectedOutcome: AIRunOutcomeLabel;
74
+ actualFailureClass: AIRunFailureClass;
75
+ expectedFailureClass?: AIRunFailureClass;
76
+ failures: string[];
77
+ tags: string[];
78
+ }
79
+
80
+ export interface AIRunEvalSummary {
81
+ passed: boolean;
82
+ total: number;
83
+ passedCount: number;
84
+ failedCount: number;
85
+ results: AIRunEvalResult[];
86
+ failuresByTag: Record<string, number>;
87
+ outcomes: Record<string, number>;
88
+ }
89
+
90
+ export interface AIRunDatasetExport {
91
+ generatedAt: string;
92
+ totalRuns: number;
93
+ summary: {
94
+ bySource: Record<string, number>;
95
+ byOutcome: Record<string, number>;
96
+ byFailureClass: Record<string, number>;
97
+ estimatedUsd: number;
98
+ totalTokens: number;
99
+ };
100
+ runs: AIRun[];
101
+ trainingExamples: AIRunTrainingExample[];
102
+ }
103
+
104
+ export interface AIRunDatasetExportOptions {
105
+ redact?: boolean;
106
+ includeRuns?: boolean;
107
+ maxEvidenceItems?: number;
108
+ now?: Date | string;
109
+ }
110
+
111
+ export interface AIRunRetryPolicyInput {
112
+ currentRun: AIRun;
113
+ previousRun?: AIRun;
114
+ newEvidenceCount?: number;
115
+ unchangedFailureLimit?: number;
116
+ sameFailureCount?: number;
117
+ historicalAcceptanceRate?: number;
118
+ estimatedNextRetryCostUsd?: number;
119
+ minRetryExpectedValue?: number;
120
+ }
121
+
122
+ export interface AIRunRetryDecision {
123
+ action: AIRunRetryAction;
124
+ failureClass: AIRunFailureClass;
125
+ repeatedFailure: boolean;
126
+ reason: string;
127
+ nextAction: string;
128
+ retryExpectedValue?: number;
129
+ }
130
+
131
+ function cleanText(value: any, max = 1000): string {
132
+ return String(value || '').replace(/\s+/g, ' ').trim().slice(0, max);
133
+ }
134
+
135
+ function countBy<T extends string>(values: T[]): Record<string, number> {
136
+ const result: Record<string, number> = {};
137
+ for (const value of values) {
138
+ result[value] = (result[value] || 0) + 1;
139
+ }
140
+ return result;
141
+ }
142
+
143
+ function isoNow(value?: Date | string): string {
144
+ if (value instanceof Date) {
145
+ return value.toISOString();
146
+ }
147
+ const parsed = value ? new Date(value) : new Date();
148
+ if (Number.isFinite(parsed.getTime())) {
149
+ return parsed.toISOString();
150
+ }
151
+ return new Date().toISOString();
152
+ }
153
+
154
+ function addUnique(values: string[], value: any, max = 1000): void {
155
+ const normalized = cleanText(value, max);
156
+ if (normalized && !values.includes(normalized)) {
157
+ values.push(normalized);
158
+ }
159
+ }
160
+
161
+ function normalizedStatus(value: any): string {
162
+ return cleanText(value, 160).toLowerCase().replace(/[\s-]+/g, '_');
163
+ }
164
+
165
+ function plainObject(value: any): Record<string, any> {
166
+ return value && typeof value === 'object' && !Array.isArray(value) ? value : {};
167
+ }
168
+
169
+ function assistantAnswerQualityMetadata(run: AIRun): Record<string, any> {
170
+ const gate = (run.gates || []).find((entry) => entry.key === 'assistant_answer_quality');
171
+ const gateMetadata = plainObject(gate?.metadata);
172
+ const runMetadata = plainObject(run.metadata);
173
+ const answerQuality = plainObject(runMetadata.answerQuality || runMetadata.answer_quality);
174
+ return {
175
+ ...gateMetadata,
176
+ ...answerQuality
177
+ };
178
+ }
179
+
180
+ function classifyAssistantFailureClass(run: AIRun): AIRunFailureClass {
181
+ const metadata = assistantAnswerQualityMetadata(run);
182
+ const status = normalizedStatus(metadata.status || metadata.answerQualityStatus || metadata.answer_quality_status);
183
+ const queryStatus = normalizedStatus(metadata.queryStatus || metadata.query_status);
184
+ const missingEvidenceStatuses = new Set([
185
+ 'missing_data_source',
186
+ 'missing_query_status',
187
+ 'missing_query_proof',
188
+ 'missing_citations',
189
+ 'missing_citation',
190
+ 'low_confidence',
191
+ 'missing_next_action',
192
+ 'no_data_unverified',
193
+ 'blocked'
194
+ ]);
195
+ if (queryStatus === 'permission_error' || status === 'permission_error') {
196
+ return 'assistant_permission';
197
+ }
198
+ if (queryStatus === 'query_error' || status === 'query_error') {
199
+ return 'assistant_query_error';
200
+ }
201
+ if (status === 'date_incorrect' || status === 'missing_date_window') {
202
+ return 'assistant_date_window';
203
+ }
204
+ if (status === 'illegal_query_shape') {
205
+ return 'assistant_query_shape';
206
+ }
207
+ if (missingEvidenceStatuses.has(status) || !status) {
208
+ return 'assistant_missing_evidence';
209
+ }
210
+ return 'assistant_correctness';
211
+ }
212
+
213
+ export function classifyAIRunFailureClass(run: AIRun): AIRunFailureClass {
214
+ if (run.outcome === 'accepted') {
215
+ return 'none';
216
+ }
217
+ if (run.outcome === 'qa_infra_failed') {
218
+ return 'infra';
219
+ }
220
+ if (run.outcome === 'build_failed') {
221
+ return 'compile';
222
+ }
223
+ if (run.outcome === 'release_blocked') {
224
+ return 'release';
225
+ }
226
+ if (run.source === 'aicoder_app' && (run.gates || []).some((gate) => gate.key === 'aicoder_journey_contract' && (gate.status === 'blocked' || gate.status === 'fail'))) {
227
+ return 'journey_contract';
228
+ }
229
+ if (run.source === 'ai_assistant' && run.outcome === 'false_pass') {
230
+ return classifyAssistantFailureClass(run);
231
+ }
232
+ if (run.outcome === 'false_pass') {
233
+ return 'false_pass';
234
+ }
235
+ if (run.outcome === 'manual_handoff') {
236
+ return 'manual';
237
+ }
238
+ if (run.outcome === 'stopped') {
239
+ return 'stopped';
240
+ }
241
+ if (run.source === 'ai_assistant' && (run.outcome === 'rejected' || run.outcome === 'qa_incomplete')) {
242
+ return classifyAssistantFailureClass(run);
243
+ }
244
+ if (run.qa?.outcome === 'compile_failed') {
245
+ return 'compile';
246
+ }
247
+ if (run.qa?.outcome === 'route_failed') {
248
+ return 'route';
249
+ }
250
+ if (run.qa?.outcome === 'route_only_pass' || run.qa?.outcome === 'incomplete') {
251
+ return 'business';
252
+ }
253
+ if (run.qa?.outcome === 'business_assertion_failed') {
254
+ return 'business';
255
+ }
256
+ if (run.outcome === 'qa_incomplete') {
257
+ return 'business';
258
+ }
259
+ if (run.outcome === 'rejected') {
260
+ return 'business';
261
+ }
262
+ return 'unknown';
263
+ }
264
+
265
+ export function evaluateAIRunFixture(fixture: AIRunEvalFixture): AIRunEvalResult {
266
+ const failures: string[] = [];
267
+ const actualFailureClass = classifyAIRunFailureClass(fixture.run);
268
+ if (fixture.run.outcome !== fixture.expected.outcome) {
269
+ failures.push(`Expected outcome ${fixture.expected.outcome}, got ${fixture.run.outcome}.`);
270
+ }
271
+ if (fixture.expected.failureClass && actualFailureClass !== fixture.expected.failureClass) {
272
+ failures.push(`Expected failure class ${fixture.expected.failureClass}, got ${actualFailureClass}.`);
273
+ }
274
+ if (fixture.expected.nextActionIncludes) {
275
+ const expectedText = fixture.expected.nextActionIncludes.toLowerCase();
276
+ const actualText = cleanText(fixture.run.nextAction, 2000).toLowerCase();
277
+ if (!actualText.includes(expectedText)) {
278
+ failures.push(`Expected next action to include "${fixture.expected.nextActionIncludes}", got "${fixture.run.nextAction || ''}".`);
279
+ }
280
+ }
281
+ const gatesByKey: Record<string, string> = {};
282
+ for (const gate of fixture.run.gates || []) {
283
+ gatesByKey[gate.key] = gate.status;
284
+ }
285
+ for (const expectedGate of fixture.expected.gates || []) {
286
+ if (!gatesByKey[expectedGate.key]) {
287
+ failures.push(`Expected gate ${expectedGate.key} to be present.`);
288
+ }
289
+ else if (expectedGate.status && gatesByKey[expectedGate.key] !== expectedGate.status) {
290
+ failures.push(`Expected gate ${expectedGate.key} status ${expectedGate.status}, got ${gatesByKey[expectedGate.key]}.`);
291
+ }
292
+ }
293
+ return {
294
+ id: fixture.id,
295
+ title: fixture.title,
296
+ source: fixture.source,
297
+ passed: failures.length === 0,
298
+ actualOutcome: fixture.run.outcome,
299
+ expectedOutcome: fixture.expected.outcome,
300
+ actualFailureClass,
301
+ expectedFailureClass: fixture.expected.failureClass,
302
+ failures,
303
+ tags: fixture.tags
304
+ };
305
+ }
306
+
307
+ export function evaluateAIRunFixtures(fixtures: AIRunEvalFixture[] = AI_RUN_SEED_EVAL_FIXTURES): AIRunEvalSummary {
308
+ const results = fixtures.map((fixture) => evaluateAIRunFixture(fixture));
309
+ const failuresByTag: Record<string, number> = {};
310
+ for (const result of results) {
311
+ if (result.passed) {
312
+ continue;
313
+ }
314
+ for (const tag of result.tags) {
315
+ failuresByTag[tag] = (failuresByTag[tag] || 0) + 1;
316
+ }
317
+ }
318
+ const outcomes = countBy(results.map((result) => result.actualOutcome));
319
+ const passedCount = results.filter((result) => result.passed).length;
320
+ return {
321
+ passed: passedCount === results.length,
322
+ total: results.length,
323
+ passedCount,
324
+ failedCount: results.length - passedCount,
325
+ results,
326
+ failuresByTag,
327
+ outcomes
328
+ };
329
+ }
330
+
331
+ export function buildAIRunTrainingExampleFromRun(run: AIRun, maxEvidenceItems = 30): AIRunTrainingExample {
332
+ const evidence: string[] = [];
333
+ for (const gate of run.gates || []) {
334
+ addUnique(evidence, `${gate.key}:${gate.status}: ${gate.reason}`, 1600);
335
+ }
336
+ for (const event of run.events || []) {
337
+ addUnique(evidence, `${event.type}:${event.category || ''}: ${event.message || ''}`, 1400);
338
+ if (evidence.length >= maxEvidenceItems) {
339
+ break;
340
+ }
341
+ }
342
+ if (evidence.length < maxEvidenceItems) {
343
+ for (const assertion of run.qa?.businessAssertions || []) {
344
+ addUnique(evidence, `assertion:${assertion.status}: ${assertion.assertion} observed=${assertion.observed || assertion.dataProof || assertion.message || ''}`, 1600);
345
+ if (evidence.length >= maxEvidenceItems) {
346
+ break;
347
+ }
348
+ }
349
+ }
350
+ return {
351
+ runId: run.id || run.sourceIds.jobId || run.sourceIds.ticketId || run.sourceIds.appId || run.sourceIds.conversationId || `${run.source}:unknown`,
352
+ source: run.source,
353
+ inputSummary: [
354
+ `source=${run.source}`,
355
+ `title=${run.title || ''}`,
356
+ `status=${run.status || ''}`,
357
+ `phase=${run.phase || ''}`,
358
+ `ids=${JSON.stringify(run.sourceIds || {})}`
359
+ ].join(' | '),
360
+ actionSummary: [
361
+ `outcome=${run.outcome}`,
362
+ `failureClass=${classifyAIRunFailureClass(run)}`,
363
+ `nextAction=${run.nextAction || ''}`
364
+ ].join(' | '),
365
+ outcome: run.outcome,
366
+ evidence: evidence.slice(0, maxEvidenceItems),
367
+ cost: run.cost,
368
+ metadata: {
369
+ warnings: run.warnings || [],
370
+ gateCount: (run.gates || []).length,
371
+ eventCount: (run.events || []).length,
372
+ qaOutcome: run.qa?.outcome
373
+ }
374
+ };
375
+ }
376
+
377
+ export function buildAIRunDatasetExport(runs: AIRun[], options: AIRunDatasetExportOptions = {}): AIRunDatasetExport {
378
+ const generatedAt = isoNow(options.now);
379
+ const trainingExamples = runs.map((run) => {
380
+ const example = buildAIRunTrainingExampleFromRun(run, options.maxEvidenceItems || 30);
381
+ return options.redact === false ? example : redactAIRunTrainingExample(example);
382
+ });
383
+ const estimatedUsd = runs.reduce((sum, run) => sum + (Number(run.cost?.estimatedUsd) || 0), 0);
384
+ const totalTokens = runs.reduce((sum, run) => sum + (Number(run.cost?.totalTokens) || 0), 0);
385
+ return {
386
+ generatedAt,
387
+ totalRuns: runs.length,
388
+ summary: {
389
+ bySource: countBy(runs.map((run) => run.source)),
390
+ byOutcome: countBy(runs.map((run) => run.outcome)),
391
+ byFailureClass: countBy(runs.map((run) => classifyAIRunFailureClass(run))),
392
+ estimatedUsd: Number(estimatedUsd.toFixed(6)),
393
+ totalTokens
394
+ },
395
+ runs: options.includeRuns === false ? [] : runs,
396
+ trainingExamples
397
+ };
398
+ }
399
+
400
+ export function decideAIRunRetry(input: AIRunRetryPolicyInput): AIRunRetryDecision {
401
+ const failureClass = classifyAIRunFailureClass(input.currentRun);
402
+ const previousFailureClass = input.previousRun ? classifyAIRunFailureClass(input.previousRun) : undefined;
403
+ const sameFailureCount = Number(input.sameFailureCount || 0);
404
+ const unchangedFailureLimit = Number(input.unchangedFailureLimit || 2);
405
+ const repeatedFailure = previousFailureClass === failureClass && (Number(input.newEvidenceCount || 0) <= 0 || sameFailureCount >= unchangedFailureLimit);
406
+ let retryExpectedValue: number | undefined;
407
+ if (input.historicalAcceptanceRate !== undefined && input.estimatedNextRetryCostUsd !== undefined) {
408
+ retryExpectedValue = Number((Number(input.historicalAcceptanceRate) - Number(input.estimatedNextRetryCostUsd)).toFixed(6));
409
+ }
410
+ if (input.currentRun.outcome === 'accepted') {
411
+ return {
412
+ action: 'none',
413
+ failureClass,
414
+ repeatedFailure: false,
415
+ reason: 'Run is already accepted.',
416
+ nextAction: 'No retry required.',
417
+ retryExpectedValue
418
+ };
419
+ }
420
+ if (failureClass === 'manual') {
421
+ return {
422
+ action: 'manual_handoff',
423
+ failureClass,
424
+ repeatedFailure,
425
+ reason: 'Run is marked for manual handoff.',
426
+ nextAction: input.currentRun.nextAction || 'Ask an operator to resolve the run.',
427
+ retryExpectedValue
428
+ };
429
+ }
430
+ if (failureClass === 'stopped') {
431
+ return {
432
+ action: 'stop',
433
+ failureClass,
434
+ repeatedFailure,
435
+ reason: 'Run was stopped before accepted evidence was recorded.',
436
+ nextAction: input.currentRun.nextAction || 'Do not spend another model cycle unless the request is resumed.',
437
+ retryExpectedValue
438
+ };
439
+ }
440
+ if (repeatedFailure) {
441
+ return {
442
+ action: 'stop',
443
+ failureClass,
444
+ repeatedFailure,
445
+ reason: 'The same failure class repeated with no new evidence. Stop model loops until the evidence changes.',
446
+ nextAction: input.currentRun.nextAction || 'Inspect the failing gate before retrying.',
447
+ retryExpectedValue
448
+ };
449
+ }
450
+ if (retryExpectedValue !== undefined && retryExpectedValue < Number(input.minRetryExpectedValue || 0)) {
451
+ return {
452
+ action: 'stop',
453
+ failureClass,
454
+ repeatedFailure,
455
+ reason: 'Historical retry expected value is below the configured threshold.',
456
+ nextAction: input.currentRun.nextAction || 'Do not retry without new evidence or a cheaper targeted repair.',
457
+ retryExpectedValue
458
+ };
459
+ }
460
+ if (failureClass === 'infra') {
461
+ return {
462
+ action: 'retry_infra_repair',
463
+ failureClass,
464
+ repeatedFailure,
465
+ reason: 'QA infrastructure failed before business validation.',
466
+ nextAction: input.currentRun.nextAction || 'Repair browser, settings, Mongo, ports, or startup before model repair.',
467
+ retryExpectedValue
468
+ };
469
+ }
470
+ if (failureClass === 'compile') {
471
+ return {
472
+ action: 'retry_build_repair',
473
+ failureClass,
474
+ repeatedFailure,
475
+ reason: 'Compile/build evidence failed or was stale.',
476
+ nextAction: input.currentRun.nextAction || 'Repair build before browser QA.',
477
+ retryExpectedValue
478
+ };
479
+ }
480
+ if (failureClass === 'route') {
481
+ return {
482
+ action: 'retry_route_repair',
483
+ failureClass,
484
+ repeatedFailure,
485
+ reason: 'Route probe failed before business proof.',
486
+ nextAction: input.currentRun.nextAction || 'Repair route/auth/startup and rerun the exact probe.',
487
+ retryExpectedValue
488
+ };
489
+ }
490
+ if (failureClass === 'journey_contract') {
491
+ return {
492
+ action: 'retry_journey_contract',
493
+ failureClass,
494
+ repeatedFailure,
495
+ reason: 'AICoder Journey Contract is missing or invalid before workflow build/proof.',
496
+ nextAction: input.currentRun.nextAction || 'Generate or repair docs/APP_JOURNEY_CONTRACT.md, validate the north-star workflow, then regenerate workflow QA rows.',
497
+ retryExpectedValue
498
+ };
499
+ }
500
+ if (failureClass === 'assistant_missing_evidence') {
501
+ return {
502
+ action: 'retry_assistant_answer_quality',
503
+ failureClass,
504
+ repeatedFailure,
505
+ reason: 'Assistant answer is missing structured answerQuality, query proof, citations, confidence, or next-action evidence.',
506
+ nextAction: input.currentRun.nextAction || 'Rebuild the answerQuality record from the exact query/tool evidence before another broad assistant response.',
507
+ retryExpectedValue
508
+ };
509
+ }
510
+ if (failureClass === 'assistant_query_error') {
511
+ return {
512
+ action: 'retry_assistant_query',
513
+ failureClass,
514
+ repeatedFailure,
515
+ reason: 'Assistant data access failed with a query error.',
516
+ nextAction: input.currentRun.nextAction || 'Repair and rerun the failing query/tool call, then answer only from the new query evidence.',
517
+ retryExpectedValue
518
+ };
519
+ }
520
+ if (failureClass === 'assistant_permission') {
521
+ return {
522
+ action: 'request_assistant_permission',
523
+ failureClass,
524
+ repeatedFailure,
525
+ reason: 'Assistant data access was blocked by permission or authorization.',
526
+ nextAction: input.currentRun.nextAction || 'Ask for permission, escalate to an authorized user, or answer with the permission blocker instead of claiming no data.',
527
+ retryExpectedValue
528
+ };
529
+ }
530
+ if (failureClass === 'assistant_date_window') {
531
+ return {
532
+ action: 'retry_assistant_date_window',
533
+ failureClass,
534
+ repeatedFailure,
535
+ reason: 'Assistant date-sensitive answer used the wrong current date or omitted the concrete date window.',
536
+ nextAction: input.currentRun.nextAction || 'Rerun the query using the actual current date and record exact start/end date-window evidence.',
537
+ retryExpectedValue
538
+ };
539
+ }
540
+ if (failureClass === 'assistant_query_shape') {
541
+ return {
542
+ action: 'retry_assistant_query_shape',
543
+ failureClass,
544
+ repeatedFailure,
545
+ reason: 'Assistant query shape is illegal or unsafe for Mongo.',
546
+ nextAction: input.currentRun.nextAction || 'Rewrite the query with a legal projection or aggregation shape before retrying the data answer.',
547
+ retryExpectedValue
548
+ };
549
+ }
550
+ if (failureClass === 'release') {
551
+ return {
552
+ action: 'retry_release_repair',
553
+ failureClass,
554
+ repeatedFailure,
555
+ reason: 'Business proof exists but deploy, publish, or sample-data gates block release.',
556
+ nextAction: input.currentRun.nextAction || 'Repair release gates without another broad model planning loop.',
557
+ retryExpectedValue
558
+ };
559
+ }
560
+ if (failureClass === 'business' || failureClass === 'false_pass' || failureClass === 'assistant_correctness') {
561
+ return {
562
+ action: 'retry_business_repair',
563
+ failureClass,
564
+ repeatedFailure,
565
+ reason: 'Business or assistant correctness proof failed or is missing.',
566
+ nextAction: input.currentRun.nextAction || 'Repair the exact failing workflow/query and rerun the deterministic assertion.',
567
+ retryExpectedValue
568
+ };
569
+ }
570
+ return {
571
+ action: 'manual_handoff',
572
+ failureClass,
573
+ repeatedFailure,
574
+ reason: 'Run lacks enough normalized evidence to choose a safe retry lane.',
575
+ nextAction: input.currentRun.nextAction || 'Ingest more run evidence before retrying.',
576
+ retryExpectedValue
577
+ };
578
+ }
579
+
580
+ const supportAccepted004131 = buildAIRun({
581
+ id: 'support-004131',
582
+ source: 'support_ticket',
583
+ sourceIds: { ticketNumber: '004131', ticketId: 'ticket-004131' },
584
+ title: '004131 accepted support fix',
585
+ status: 'Resolved',
586
+ phase: 'COMPLETE',
587
+ events: [{ type: 'git_commit', message: 'Fix support workflow and verified before/action/after proof.' }],
588
+ qa: buildAIQaRun({
589
+ compile: { status: 'pass', artifactPath: '.build-output/build-server.log' },
590
+ routeProbes: [{ route: '/support/004131', status: 'pass', screenshot: 'qa-artifacts/004131-after.jpg' }],
591
+ businessAssertions: [{
592
+ assertion: 'Before/action/after workflow proves the ticket fix.',
593
+ status: 'pass',
594
+ action: 'Run the ticket workflow against seeded data.',
595
+ expected: 'The corrected state is visible.',
596
+ observed: 'The corrected state is visible after the action.',
597
+ artifactPaths: ['qa-artifacts/004131-proof.json']
598
+ }]
599
+ }),
600
+ explicitAccepted: true,
601
+ terminal: true
602
+ });
603
+
604
+ const supportBuildFailed004333 = buildAIRun({
605
+ id: 'support-004333',
606
+ source: 'support_ticket',
607
+ sourceIds: { ticketNumber: '004333', ticketId: 'ticket-004333' },
608
+ title: '004333 compile failure',
609
+ status: 'Running',
610
+ phase: 'QA',
611
+ events: [{ type: 'log', message: 'Angular build failed before browser QA.' }],
612
+ qa: buildAIQaRun({
613
+ compile: { status: 'fail', artifactPath: '.build-output/build-client.log', message: 'TypeScript compile failed.' }
614
+ })
615
+ });
616
+
617
+ const supportInfraFailed004341 = buildAIRun({
618
+ id: 'support-004341',
619
+ source: 'support_ticket',
620
+ sourceIds: { ticketNumber: '004341', ticketId: 'ticket-004341' },
621
+ title: '004341 missing Puppeteer',
622
+ status: 'Running',
623
+ phase: 'QA',
624
+ events: [{ type: 'qa_infra', message: 'Puppeteer module could not be loaded.' }],
625
+ qa: buildAIQaRun({
626
+ infraChecks: [{ name: 'puppeteer_require', status: 'blocked', message: 'Cannot find module puppeteer.' }]
627
+ })
628
+ });
629
+
630
+ const supportFalsePass004421 = buildAIRun({
631
+ id: 'support-004421',
632
+ source: 'support_ticket',
633
+ sourceIds: { ticketNumber: '004421', ticketId: 'ticket-004421' },
634
+ title: '004421 route-only support QA',
635
+ status: 'Passed',
636
+ phase: 'QA',
637
+ events: [{ type: 'scorecard', message: 'Scorecard passed after route loaded.' }],
638
+ qa: buildAIQaRun({
639
+ infraChecks: [{ name: 'chrome_launch', status: 'pass' }],
640
+ compile: { status: 'pass' },
641
+ routeProbes: [{ route: '/support/004421', status: 'pass', screenshot: 'qa-artifacts/004421-route.jpg' }]
642
+ }),
643
+ scorecardPassed: true
644
+ });
645
+
646
+ const supportBusinessFailed004423 = buildAIRun({
647
+ id: 'support-004423',
648
+ source: 'support_ticket',
649
+ sourceIds: { ticketNumber: '004423', ticketId: 'ticket-004423' },
650
+ title: '004423 business assertion failed',
651
+ status: 'Running',
652
+ phase: 'QA',
653
+ events: [{ type: 'qa_business_assertion', message: 'The expected workflow state did not change.' }],
654
+ qa: buildAIQaRun({
655
+ compile: { status: 'pass' },
656
+ routeProbes: [{ route: '/support/004423', status: 'pass' }],
657
+ businessAssertions: [{
658
+ assertion: 'Ticket workflow changes the requested field.',
659
+ status: 'fail',
660
+ expected: 'Field updates after save.',
661
+ observed: 'Field stayed unchanged.'
662
+ }]
663
+ })
664
+ });
665
+
666
+ const supportStaleBuild004430 = buildAIRun({
667
+ id: 'support-004430',
668
+ source: 'support_ticket',
669
+ sourceIds: { ticketNumber: '004430', ticketId: 'ticket-004430' },
670
+ title: '004430 stale build evidence',
671
+ status: 'Running',
672
+ phase: 'QA',
673
+ events: [{ type: 'qa_compile', message: 'Build log predates the final code diff.' }],
674
+ qa: buildAIQaRun({
675
+ compile: { status: 'stale', staleEvidence: true, artifactPath: '.build-output/build-client.log' }
676
+ })
677
+ });
678
+
679
+ const cryptoPortfolioAccepted = buildAIRun({
680
+ id: 'aicoder-crypto-v6-golden',
681
+ source: 'aicoder_app',
682
+ sourceIds: { appId: 'crypto-v6-golden', jobId: 'crypto-job-golden' },
683
+ title: 'Crypto Portfolio Tracker V6 Golden',
684
+ status: 'Passed',
685
+ phase: 'COMPLETE',
686
+ events: [{ type: 'scorecard', message: 'Quality scorecard passed with workflow proof.' }],
687
+ qa: buildAIQaRun({
688
+ compile: { status: 'pass' },
689
+ routeProbes: [{ route: '/portfolio', status: 'pass', screenshot: 'qa-artifacts/crypto-dashboard.jpg' }],
690
+ businessAssertions: [{
691
+ assertion: 'Portfolio dashboard calculates seeded crypto holdings.',
692
+ status: 'pass',
693
+ dataProof: 'Seeded BTC and ETH holdings render totals, allocation, and change.'
694
+ }]
695
+ }),
696
+ scorecardPassed: true,
697
+ deployStatus: 'pass',
698
+ publishStatus: 'published',
699
+ sampleDataStatus: 'pass',
700
+ terminal: true
701
+ });
702
+
703
+ const layflatReleaseBlocked = buildAIRun({
704
+ id: 'aicoder-layflat-pressure-optimizer',
705
+ source: 'aicoder_app',
706
+ sourceIds: { appId: 'layflat-pressure-optimizer', jobId: 'layflat-job' },
707
+ title: 'Layflat Pressure Optimizer',
708
+ status: 'Passed',
709
+ phase: 'COMPLETE',
710
+ events: [{ type: 'scorecard', message: 'Scorecard passed but sample data/publish gate failed.' }],
711
+ qa: buildAIQaRun({
712
+ compile: { status: 'pass' },
713
+ routeProbes: [{ route: '/optimizer', status: 'pass', screenshot: 'qa-artifacts/layflat-route.jpg' }],
714
+ businessAssertions: [{
715
+ assertion: 'Pressure optimizer computes a layflat hose result.',
716
+ status: 'pass',
717
+ dataProof: 'A seeded hose diameter and flow rate produce PSI loss.'
718
+ }]
719
+ }),
720
+ scorecardPassed: true,
721
+ deployStatus: 'pass',
722
+ publishStatus: 'publish failed',
723
+ sampleDataStatus: 'empty seed collections',
724
+ terminal: true
725
+ });
726
+
727
+ const assistantWrongDateWindow = buildAIRun({
728
+ id: 'assistant-wrong-month-window',
729
+ source: 'ai_assistant',
730
+ sourceIds: { conversationId: 'assistant-date-window' },
731
+ title: 'Assistant wrong month/date-window answer',
732
+ status: 'Closed',
733
+ phase: 'ANSWERED',
734
+ events: [{ type: 'assistant_message', message: 'Answered with the wrong month for today-sensitive invoice data.' }],
735
+ qa: buildAIQaRun({
736
+ businessAssertions: [{
737
+ assertion: 'Assistant date window uses the actual current date.',
738
+ status: 'fail',
739
+ expected: 'Use June 2026 for current-month windows.',
740
+ observed: 'Used a stale month.'
741
+ }]
742
+ }),
743
+ gates: [{
744
+ key: 'assistant_answer_quality',
745
+ label: 'Assistant answer quality',
746
+ status: 'fail',
747
+ reason: 'Assistant answer did not prove it used the actual current date.',
748
+ evidenceRefs: [],
749
+ recordedAt: '2026-06-16T00:00:00.000Z',
750
+ metadata: {
751
+ status: 'date_incorrect',
752
+ queryStatus: 'ok',
753
+ dateBasis: '2026-05-01',
754
+ expectedCurrentDate: '2026-06-16'
755
+ }
756
+ }],
757
+ metadata: {
758
+ answerQuality: {
759
+ status: 'date_incorrect',
760
+ queryStatus: 'ok',
761
+ dateBasis: '2026-05-01',
762
+ expectedCurrentDate: '2026-06-16'
763
+ }
764
+ },
765
+ rejected: true,
766
+ terminal: true
767
+ });
768
+
769
+ const assistantIllegalProjection = buildAIRun({
770
+ id: 'assistant-illegal-mongo-projection',
771
+ source: 'ai_assistant',
772
+ sourceIds: { conversationId: 'assistant-positional-projection' },
773
+ title: 'Assistant illegal Mongo positional projection',
774
+ status: 'Closed',
775
+ phase: 'ANSWERED',
776
+ events: [{ type: 'assistant_message', message: 'Mongo query used an illegal positional projection shape.' }],
777
+ qa: buildAIQaRun({
778
+ businessAssertions: [{
779
+ assertion: 'Assistant avoids illegal Mongo positional projection.',
780
+ status: 'fail',
781
+ expected: 'Use legal aggregation or field projection shape.',
782
+ observed: 'Used invalid positional projection.'
783
+ }]
784
+ }),
785
+ gates: [{
786
+ key: 'assistant_answer_quality',
787
+ label: 'Assistant answer quality',
788
+ status: 'fail',
789
+ reason: 'Assistant must use legal Mongo query/projection shapes before answering.',
790
+ evidenceRefs: [],
791
+ recordedAt: '2026-06-16T00:00:00.000Z',
792
+ metadata: {
793
+ status: 'illegal_query_shape',
794
+ queryStatus: 'ok',
795
+ legalQueryShape: false
796
+ }
797
+ }],
798
+ metadata: {
799
+ answerQuality: {
800
+ status: 'illegal_query_shape',
801
+ queryStatus: 'ok',
802
+ legalQueryShape: false
803
+ }
804
+ },
805
+ rejected: true,
806
+ terminal: true
807
+ });
808
+
809
+ const qaMissingPuppeteer = buildAIRun({
810
+ id: 'qa-missing-puppeteer',
811
+ source: 'qa_runner',
812
+ sourceIds: { jobId: 'qa-missing-puppeteer' },
813
+ title: 'QA runner missing Puppeteer',
814
+ status: 'Running',
815
+ phase: 'PREFLIGHT',
816
+ events: [{ type: 'qa_infra', message: 'Puppeteer failed to require.' }],
817
+ qa: buildAIQaRun({
818
+ infraChecks: [{ name: 'puppeteer_require', status: 'blocked', message: 'Cannot find module puppeteer.' }]
819
+ })
820
+ });
821
+
822
+ const qaBadChromePath = buildAIRun({
823
+ id: 'qa-bad-chrome-path',
824
+ source: 'qa_runner',
825
+ sourceIds: { jobId: 'qa-bad-chrome-path' },
826
+ title: 'QA runner bad Chrome path',
827
+ status: 'Running',
828
+ phase: 'PREFLIGHT',
829
+ events: [{ type: 'qa_infra', message: 'Chrome executable path was missing.' }],
830
+ qa: buildAIQaRun({
831
+ infraChecks: [{ name: 'chrome_executable', status: 'fail', message: 'Chrome executable not found.', path: '/bad/chrome' }]
832
+ })
833
+ });
834
+
835
+ const qaCompileFailure = buildAIRun({
836
+ id: 'qa-compile-failure',
837
+ source: 'qa_runner',
838
+ sourceIds: { jobId: 'qa-compile-failure' },
839
+ title: 'QA runner compile failure',
840
+ status: 'Running',
841
+ phase: 'COMPILE',
842
+ events: [{ type: 'qa_compile', message: 'Compile failed before browser QA.' }],
843
+ qa: buildAIQaRun({
844
+ compile: { status: 'fail', command: 'npm run build', artifactPath: '.build-output/build.log' }
845
+ })
846
+ });
847
+
848
+ const qaRouteOnlyPass = buildAIRun({
849
+ id: 'qa-route-only-pass',
850
+ source: 'qa_runner',
851
+ sourceIds: { jobId: 'qa-route-only-pass' },
852
+ title: 'QA runner route-only pass',
853
+ status: 'Passed',
854
+ phase: 'BROWSER_QA',
855
+ events: [{ type: 'qa_route_probe', message: 'Route loaded but no business proof exists.' }],
856
+ qa: buildAIQaRun({
857
+ compile: { status: 'pass' },
858
+ routeProbes: [{ route: '/dashboard', status: 'pass', screenshot: 'qa-artifacts/dashboard.jpg' }]
859
+ }),
860
+ scorecardPassed: true
861
+ });
862
+
863
+ const qaShellOnlyPage = buildAIRun({
864
+ id: 'qa-shell-only-page',
865
+ source: 'qa_runner',
866
+ sourceIds: { jobId: 'qa-shell-only-page' },
867
+ title: 'QA runner shell-only page',
868
+ status: 'Running',
869
+ phase: 'BROWSER_QA',
870
+ events: [{ type: 'qa_route_probe', message: 'Shell-only route loaded.' }],
871
+ qa: buildAIQaRun({
872
+ compile: { status: 'pass' },
873
+ routeProbes: [{ route: '/dashboard', status: 'pass', shellOnly: true, screenshot: 'qa-artifacts/shell.jpg' }]
874
+ })
875
+ });
876
+
877
+ const qaEmptyData = buildAIRun({
878
+ id: 'qa-empty-data',
879
+ source: 'qa_runner',
880
+ sourceIds: { jobId: 'qa-empty-data' },
881
+ title: 'QA runner empty data',
882
+ status: 'Failed',
883
+ phase: 'BROWSER_QA',
884
+ events: [{ type: 'qa_business_assertion', message: 'Workflow rendered empty data.' }],
885
+ qa: buildAIQaRun({
886
+ compile: { status: 'pass' },
887
+ routeProbes: [{ route: '/invoices', status: 'pass' }],
888
+ businessAssertions: [{
889
+ assertion: 'Invoice dashboard renders non-empty meaningful data.',
890
+ status: 'fail',
891
+ expected: 'At least one meaningful invoice row.',
892
+ observed: 'Empty table.'
893
+ }]
894
+ }),
895
+ terminal: true
896
+ });
897
+
898
+ const qaPublishFailureAfterScorecard = buildAIRun({
899
+ id: 'qa-scorecard-pass-publish-failure',
900
+ source: 'qa_runner',
901
+ sourceIds: { jobId: 'qa-publish-failure' },
902
+ title: 'QA scorecard pass followed by publish failure',
903
+ status: 'Passed',
904
+ phase: 'RELEASE',
905
+ events: [{ type: 'publish', message: 'Scorecard passed but publish failed.' }],
906
+ qa: buildAIQaRun({
907
+ compile: { status: 'pass' },
908
+ routeProbes: [{ route: '/app', status: 'pass' }],
909
+ businessAssertions: [{
910
+ assertion: 'Primary app workflow runs.',
911
+ status: 'pass',
912
+ dataProof: 'Workflow action returned expected state.'
913
+ }]
914
+ }),
915
+ scorecardPassed: true,
916
+ publishStatus: 'publish failed',
917
+ sampleDataStatus: 'pass'
918
+ });
919
+
920
+ export const AI_RUN_SEED_EVAL_FIXTURES: AIRunEvalFixture[] = [
921
+ {
922
+ id: 'support-004131',
923
+ title: 'Support 004131 accepted proof',
924
+ source: 'support_ticket',
925
+ run: supportAccepted004131,
926
+ expected: { outcome: 'accepted', failureClass: 'none', gates: [{ key: 'qa_business_assertion', status: 'pass' }] },
927
+ tags: ['support', 'accepted', 'business_assertion']
928
+ },
929
+ {
930
+ id: 'support-004333',
931
+ title: 'Support 004333 compile failure',
932
+ source: 'support_ticket',
933
+ run: supportBuildFailed004333,
934
+ expected: { outcome: 'build_failed', failureClass: 'compile', nextActionIncludes: 'compile' },
935
+ tags: ['support', 'compile']
936
+ },
937
+ {
938
+ id: 'support-004341',
939
+ title: 'Support 004341 Puppeteer infra failure',
940
+ source: 'support_ticket',
941
+ run: supportInfraFailed004341,
942
+ expected: { outcome: 'qa_infra_failed', failureClass: 'infra', nextActionIncludes: 'browser' },
943
+ tags: ['support', 'infra', 'puppeteer']
944
+ },
945
+ {
946
+ id: 'support-004421',
947
+ title: 'Support 004421 route-only false pass',
948
+ source: 'support_ticket',
949
+ run: supportFalsePass004421,
950
+ expected: { outcome: 'false_pass', failureClass: 'false_pass', gates: [{ key: 'qa_business_assertion', status: 'blocked' }] },
951
+ tags: ['support', 'route_only', 'false_pass']
952
+ },
953
+ {
954
+ id: 'support-004423',
955
+ title: 'Support 004423 business assertion failed',
956
+ source: 'support_ticket',
957
+ run: supportBusinessFailed004423,
958
+ expected: { outcome: 'qa_incomplete', failureClass: 'business', nextActionIncludes: 'assertion' },
959
+ tags: ['support', 'business_assertion']
960
+ },
961
+ {
962
+ id: 'support-004430',
963
+ title: 'Support 004430 stale build evidence',
964
+ source: 'support_ticket',
965
+ run: supportStaleBuild004430,
966
+ expected: { outcome: 'build_failed', failureClass: 'compile', nextActionIncludes: 'build' },
967
+ tags: ['support', 'compile', 'stale_build']
968
+ },
969
+ {
970
+ id: 'aicoder-crypto-v6-golden',
971
+ title: 'AICoder Crypto Portfolio Tracker V6 Golden',
972
+ source: 'aicoder_app',
973
+ run: cryptoPortfolioAccepted,
974
+ expected: { outcome: 'accepted', failureClass: 'none', gates: [{ key: 'qa_business_assertion', status: 'pass' }] },
975
+ tags: ['aicoder', 'crypto', 'accepted']
976
+ },
977
+ {
978
+ id: 'aicoder-layflat-pressure-optimizer',
979
+ title: 'AICoder Layflat Pressure Optimizer release blocked',
980
+ source: 'aicoder_app',
981
+ run: layflatReleaseBlocked,
982
+ expected: { outcome: 'release_blocked', failureClass: 'release', gates: [{ key: 'release', status: 'fail' }] },
983
+ tags: ['aicoder', 'layflat', 'release_blocked', 'sample_data']
984
+ },
985
+ {
986
+ id: 'assistant-wrong-month-window',
987
+ title: 'Assistant wrong month/date-window answer',
988
+ source: 'ai_assistant',
989
+ run: assistantWrongDateWindow,
990
+ expected: { outcome: 'rejected', failureClass: 'assistant_date_window' },
991
+ tags: ['assistant', 'date_window']
992
+ },
993
+ {
994
+ id: 'assistant-illegal-mongo-projection',
995
+ title: 'Assistant illegal Mongo positional projection',
996
+ source: 'ai_assistant',
997
+ run: assistantIllegalProjection,
998
+ expected: { outcome: 'rejected', failureClass: 'assistant_query_shape' },
999
+ tags: ['assistant', 'mongo_query']
1000
+ },
1001
+ {
1002
+ id: 'qa-missing-puppeteer',
1003
+ title: 'QA missing Puppeteer',
1004
+ source: 'qa_runner',
1005
+ run: qaMissingPuppeteer,
1006
+ expected: { outcome: 'qa_infra_failed', failureClass: 'infra' },
1007
+ tags: ['qa_runner', 'infra', 'puppeteer']
1008
+ },
1009
+ {
1010
+ id: 'qa-bad-chrome-path',
1011
+ title: 'QA bad Chrome path',
1012
+ source: 'qa_runner',
1013
+ run: qaBadChromePath,
1014
+ expected: { outcome: 'qa_infra_failed', failureClass: 'infra' },
1015
+ tags: ['qa_runner', 'infra', 'chrome']
1016
+ },
1017
+ {
1018
+ id: 'qa-compile-failure',
1019
+ title: 'QA compile failure',
1020
+ source: 'qa_runner',
1021
+ run: qaCompileFailure,
1022
+ expected: { outcome: 'build_failed', failureClass: 'compile' },
1023
+ tags: ['qa_runner', 'compile']
1024
+ },
1025
+ {
1026
+ id: 'qa-route-only-pass',
1027
+ title: 'QA route-only pass',
1028
+ source: 'qa_runner',
1029
+ run: qaRouteOnlyPass,
1030
+ expected: { outcome: 'false_pass', failureClass: 'false_pass' },
1031
+ tags: ['qa_runner', 'route_only', 'false_pass']
1032
+ },
1033
+ {
1034
+ id: 'qa-shell-only-page',
1035
+ title: 'QA shell-only page',
1036
+ source: 'qa_runner',
1037
+ run: qaShellOnlyPage,
1038
+ expected: { outcome: 'qa_incomplete', failureClass: 'route' },
1039
+ tags: ['qa_runner', 'route', 'shell_only']
1040
+ },
1041
+ {
1042
+ id: 'qa-empty-data',
1043
+ title: 'QA empty data',
1044
+ source: 'qa_runner',
1045
+ run: qaEmptyData,
1046
+ expected: { outcome: 'rejected', failureClass: 'business' },
1047
+ tags: ['qa_runner', 'empty_data', 'business_assertion']
1048
+ },
1049
+ {
1050
+ id: 'qa-scorecard-pass-publish-failure',
1051
+ title: 'QA scorecard pass followed by publish failure',
1052
+ source: 'qa_runner',
1053
+ run: qaPublishFailureAfterScorecard,
1054
+ expected: { outcome: 'release_blocked', failureClass: 'release' },
1055
+ tags: ['qa_runner', 'release_blocked', 'publish']
1056
+ }
1057
+ ];