@askexenow/exe-os 0.9.272 → 0.9.274

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 (397) hide show
  1. package/dist/backfill-metadata-A3534S32.js +597 -0
  2. package/dist/backfill-metadata-B6F2KJJV.js +597 -0
  3. package/dist/backfill-metadata-BOM2MXLI.js +597 -0
  4. package/dist/backfill-metadata-SJ4YMQFS.js +597 -0
  5. package/dist/backfill-metadata-TAU33HJS.js +597 -0
  6. package/dist/bin/agentic-ontology-backfill.js +1 -1
  7. package/dist/bin/agentic-reflection-backfill.js +1 -1
  8. package/dist/bin/agentic-semantic-label.js +1 -1
  9. package/dist/bin/backfill-conversations.js +1 -1
  10. package/dist/bin/backfill-responses.js +1 -1
  11. package/dist/bin/backfill-vectors.js +2 -2
  12. package/dist/bin/bulk-sync-postgres.js +1 -1
  13. package/dist/bin/cleanup-stale-review-tasks.js +2 -2
  14. package/dist/bin/cli.js +5 -5
  15. package/dist/bin/exe-assign.js +1 -1
  16. package/dist/bin/exe-boot.js +3 -3
  17. package/dist/bin/exe-dispatch.js +2 -2
  18. package/dist/bin/exe-doctor.js +1 -1
  19. package/dist/bin/exe-export-behaviors.js +2 -2
  20. package/dist/bin/exe-forget.js +3 -3
  21. package/dist/bin/exe-gateway.js +5 -5
  22. package/dist/bin/exe-heartbeat.js +2 -2
  23. package/dist/bin/exe-kill.js +3 -3
  24. package/dist/bin/exe-launch-agent.js +3 -3
  25. package/dist/bin/exe-pending-messages.js +3 -3
  26. package/dist/bin/exe-pending-notifications.js +25 -10
  27. package/dist/bin/exe-pending-reviews.js +2 -2
  28. package/dist/bin/exe-review.js +3 -3
  29. package/dist/bin/exe-search.js +2 -2
  30. package/dist/bin/exe-session-cleanup.js +5 -5
  31. package/dist/bin/exe-start-codex.js +1 -1
  32. package/dist/bin/exe-start-opencode.js +1 -1
  33. package/dist/bin/exe-status.js +3 -3
  34. package/dist/bin/exe-team.js +1 -1
  35. package/dist/bin/git-sweep.js +2 -2
  36. package/dist/bin/graph-backfill.js +1 -1
  37. package/dist/bin/graph-export.js +2 -2
  38. package/dist/bin/import-history.js +2 -2
  39. package/dist/bin/intercom-check.js +3 -3
  40. package/dist/bin/mcp-sessions.js +2 -2
  41. package/dist/bin/orchestration-metrics.js +1 -1
  42. package/dist/bin/scan-tasks.js +2 -2
  43. package/dist/bin/shard-migrate.js +1 -1
  44. package/dist/capacity-monitor-2GJOFXGB.js +49 -0
  45. package/dist/capacity-monitor-3Z7W4K25.js +49 -0
  46. package/dist/capacity-monitor-BENS3N7B.js +49 -0
  47. package/dist/capacity-monitor-MQUUEZKB.js +49 -0
  48. package/dist/capacity-monitor-VP4RDLSB.js +49 -0
  49. package/dist/catchup-brief-2Q5GPASS.js +151 -0
  50. package/dist/catchup-brief-B4KGAIPU.js +151 -0
  51. package/dist/catchup-brief-NMOV3SSP.js +151 -0
  52. package/dist/catchup-brief-VMF3ESTZ.js +151 -0
  53. package/dist/catchup-brief-ZL7V3BXC.js +151 -0
  54. package/dist/chunk-2FZLPPOD.js +171 -0
  55. package/dist/chunk-2KWVJV6I.js +171 -0
  56. package/dist/chunk-3A4SOC66.js +551 -0
  57. package/dist/chunk-3FZQAO7A.js +3961 -0
  58. package/dist/chunk-3GSGDPLK.js +171 -0
  59. package/dist/chunk-3IM3JNQV.js +377 -0
  60. package/dist/chunk-3OM3V545.js +448 -0
  61. package/dist/chunk-3T27ZQT6.js +495 -0
  62. package/dist/chunk-3VI3QIHU.js +214 -0
  63. package/dist/chunk-3WG3RRWA.js +1345 -0
  64. package/dist/chunk-42A3JV3A.js +128 -0
  65. package/dist/chunk-44MQXM4F.js +13745 -0
  66. package/dist/chunk-46WLFLGP.js +1073 -0
  67. package/dist/chunk-4JMPQB7K.js +1148 -0
  68. package/dist/chunk-4L25LLQM.js +382 -0
  69. package/dist/chunk-4Q7X3SAM.js +204 -0
  70. package/dist/chunk-4UAUCFHA.js +526 -0
  71. package/dist/chunk-4VRJX2SP.js +495 -0
  72. package/dist/chunk-57RBAR2A.js +214 -0
  73. package/dist/chunk-5JF5OQQU.js +89 -0
  74. package/dist/chunk-5LTY4GLX.js +13745 -0
  75. package/dist/chunk-5M5RYJ22.js +3955 -0
  76. package/dist/chunk-5YO2FER3.js +76 -0
  77. package/dist/chunk-62YI2JOC.js +333 -0
  78. package/dist/chunk-6AGPWYFC.js +447 -0
  79. package/dist/chunk-6CH7TYBG.js +58 -0
  80. package/dist/chunk-6CHHFVRQ.js +284 -0
  81. package/dist/chunk-6D64562N.js +330 -0
  82. package/dist/chunk-6F35WOSR.js +447 -0
  83. package/dist/chunk-6HQ22FC6.js +81 -0
  84. package/dist/chunk-6ZSH2BZR.js +244 -0
  85. package/dist/chunk-74MF4T3T.js +3962 -0
  86. package/dist/chunk-77H7IO3O.js +382 -0
  87. package/dist/chunk-7BUWNG6M.js +159 -0
  88. package/dist/chunk-7CB3G3JP.js +1090 -0
  89. package/dist/chunk-7YEQI2WF.js +13745 -0
  90. package/dist/chunk-AJ63GPM7.js +54 -0
  91. package/dist/chunk-BFJ45HQT.js +244 -0
  92. package/dist/chunk-BMHE3UQU.js +495 -0
  93. package/dist/chunk-BNTUZVPS.js +1921 -0
  94. package/dist/chunk-BSWNP5GP.js +197 -0
  95. package/dist/chunk-C6ODVGTC.js +818 -0
  96. package/dist/chunk-CHBGCQXG.js +333 -0
  97. package/dist/chunk-CHUOANKE.js +346 -0
  98. package/dist/chunk-CSF4RUCN.js +58 -0
  99. package/dist/chunk-CXKHWCNN.js +204 -0
  100. package/dist/chunk-CZR6Z5D7.js +330 -0
  101. package/dist/chunk-D24ANCWY.js +204 -0
  102. package/dist/chunk-DBJCWK6T.js +377 -0
  103. package/dist/chunk-DF4SM6ZX.js +128 -0
  104. package/dist/chunk-DOAC6CLC.js +127 -0
  105. package/dist/chunk-DOGNJ4VR.js +818 -0
  106. package/dist/chunk-DYXJFUCI.js +818 -0
  107. package/dist/chunk-EGR2NYID.js +50 -0
  108. package/dist/chunk-EQ5UBJGX.js +81 -0
  109. package/dist/chunk-EWQLQZNS.js +345 -0
  110. package/dist/chunk-FBRQGHSU.js +377 -0
  111. package/dist/chunk-FC5WORMP.js +81 -0
  112. package/dist/chunk-FS7G6NJD.js +377 -0
  113. package/dist/chunk-FZ42OCSP.js +333 -0
  114. package/dist/chunk-G5HWDSBH.js +50 -0
  115. package/dist/chunk-GCBG5TFS.js +1345 -0
  116. package/dist/chunk-GESN6IDC.js +127 -0
  117. package/dist/chunk-GHD7QG6P.js +58 -0
  118. package/dist/chunk-GJAILPCX.js +171 -0
  119. package/dist/chunk-GKUODJS7.js +214 -0
  120. package/dist/chunk-GLDM2FOM.js +76 -0
  121. package/dist/chunk-GMM2BLFB.js +127 -0
  122. package/dist/chunk-GNM75IOI.js +159 -0
  123. package/dist/chunk-GYIX2HLD.js +81 -0
  124. package/dist/chunk-H4LLEQ3F.js +551 -0
  125. package/dist/chunk-HBVCBBDA.js +127 -0
  126. package/dist/chunk-HBYLXJAW.js +284 -0
  127. package/dist/chunk-HBYRWOH5.js +171 -0
  128. package/dist/chunk-HFINM2JG.js +284 -0
  129. package/dist/chunk-HJGHALOG.js +1345 -0
  130. package/dist/chunk-HRB5CP43.js +13745 -0
  131. package/dist/chunk-IDCLPPIM.js +3959 -0
  132. package/dist/chunk-II5SVNBN.js +551 -0
  133. package/dist/chunk-IIRLKWNZ.js +50 -0
  134. package/dist/chunk-IQXLUTWC.js +50 -0
  135. package/dist/chunk-IWXTFDLS.js +244 -0
  136. package/dist/chunk-J2TGVCPE.js +1090 -0
  137. package/dist/chunk-J4Z5GAJ4.js +551 -0
  138. package/dist/chunk-JJSDZFKM.js +1148 -0
  139. package/dist/chunk-JMN2KOC4.js +128 -0
  140. package/dist/chunk-JQVYPBR2.js +81 -0
  141. package/dist/chunk-KK6ZIA37.js +551 -0
  142. package/dist/chunk-KMU7PFO3.js +1148 -0
  143. package/dist/chunk-L7RDKCIR.js +244 -0
  144. package/dist/chunk-LDDCAATQ.js +1090 -0
  145. package/dist/chunk-LJN2O5IG.js +197 -0
  146. package/dist/chunk-LSIYHKDS.js +54 -0
  147. package/dist/chunk-MREDKOS4.js +731 -0
  148. package/dist/chunk-MSF2Y5MS.js +346 -0
  149. package/dist/chunk-MWUISGAB.js +382 -0
  150. package/dist/chunk-MY647ZHR.js +448 -0
  151. package/dist/chunk-MZ5CEHPQ.js +89 -0
  152. package/dist/chunk-N62LCOUL.js +214 -0
  153. package/dist/chunk-NESTX6DR.js +76 -0
  154. package/dist/chunk-NQZORF6L.js +731 -0
  155. package/dist/chunk-NWEFAFJS.js +197 -0
  156. package/dist/chunk-NYF7GHC5.js +526 -0
  157. package/dist/chunk-NZGGRM4P.js +731 -0
  158. package/dist/chunk-NZM4E6Y3.js +89 -0
  159. package/dist/chunk-O6XF6NUN.js +1090 -0
  160. package/dist/chunk-OF4KG3L7.js +1090 -0
  161. package/dist/chunk-OQZPSWVN.js +526 -0
  162. package/dist/chunk-OR6KJ5HH.js +58 -0
  163. package/dist/chunk-OV6NT6QX.js +128 -0
  164. package/dist/chunk-OZZNVYAK.js +346 -0
  165. package/dist/chunk-PDTR3YUU.js +54 -0
  166. package/dist/chunk-PEGTV6EJ.js +1345 -0
  167. package/dist/chunk-PITVTSQW.js +333 -0
  168. package/dist/chunk-PSUAO4MZ.js +345 -0
  169. package/dist/chunk-PWQIS5E5.js +382 -0
  170. package/dist/chunk-PXXHKWDH.js +818 -0
  171. package/dist/chunk-QNEXJFHM.js +495 -0
  172. package/dist/chunk-QOC46BDY.js +346 -0
  173. package/dist/chunk-QUJMPJF6.js +1148 -0
  174. package/dist/chunk-QZD26GDH.js +1073 -0
  175. package/dist/chunk-RA5JLXBQ.js +89 -0
  176. package/dist/chunk-RFXUXL2D.js +128 -0
  177. package/dist/chunk-RTA6KSSK.js +89 -0
  178. package/dist/chunk-SBX6HSEO.js +159 -0
  179. package/dist/chunk-SEUST6U5.js +284 -0
  180. package/dist/chunk-SGNGDKD6.js +127 -0
  181. package/dist/chunk-SUEQF3ZS.js +214 -0
  182. package/dist/chunk-SWNAM2NW.js +526 -0
  183. package/dist/chunk-TBJP46RP.js +1148 -0
  184. package/dist/chunk-TS7NGPU4.js +1073 -0
  185. package/dist/chunk-TUPDOPMG.js +731 -0
  186. package/dist/chunk-TYKUZVCA.js +1921 -0
  187. package/dist/chunk-TYWQZEEP.js +448 -0
  188. package/dist/chunk-TZMXJVZV.js +345 -0
  189. package/dist/chunk-U2DCN7M6.js +1073 -0
  190. package/dist/chunk-UJZPLZLU.js +197 -0
  191. package/dist/chunk-UKRKOJQZ.js +54 -0
  192. package/dist/chunk-V6YIYBTZ.js +204 -0
  193. package/dist/chunk-VCVGE7HK.js +1921 -0
  194. package/dist/chunk-VEWBH33L.js +1921 -0
  195. package/dist/chunk-VK6YZ6K7.js +1073 -0
  196. package/dist/chunk-VKT4N6WM.js +495 -0
  197. package/dist/chunk-VQD4CTOC.js +50 -0
  198. package/dist/chunk-VQUEP7UA.js +244 -0
  199. package/dist/chunk-VXODHQXB.js +377 -0
  200. package/dist/chunk-VZES6N3E.js +526 -0
  201. package/dist/chunk-W5QNW2XG.js +76 -0
  202. package/dist/chunk-WHK7GXFR.js +13745 -0
  203. package/dist/chunk-WQKYSGIT.js +159 -0
  204. package/dist/chunk-WWPJTPPQ.js +197 -0
  205. package/dist/chunk-WYZSWV6A.js +346 -0
  206. package/dist/chunk-XD6VOXK3.js +159 -0
  207. package/dist/chunk-YEMI5UWM.js +58 -0
  208. package/dist/chunk-YHSATGMH.js +3955 -0
  209. package/dist/chunk-YJBCGD46.js +13745 -0
  210. package/dist/chunk-YLICIT56.js +731 -0
  211. package/dist/chunk-YLOJPYCJ.js +284 -0
  212. package/dist/chunk-YTDY65EM.js +1345 -0
  213. package/dist/chunk-YXVGZDDE.js +333 -0
  214. package/dist/chunk-Z33XSFND.js +76 -0
  215. package/dist/chunk-ZA7N3ZTA.js +1921 -0
  216. package/dist/chunk-ZBCOPT2O.js +54 -0
  217. package/dist/chunk-ZFRG2MNB.js +382 -0
  218. package/dist/chunk-ZPBCPDB3.js +818 -0
  219. package/dist/chunk-ZRRRSVQF.js +204 -0
  220. package/dist/core-memory-554Q3YN5.js +110 -0
  221. package/dist/core-memory-BC4YN5F4.js +110 -0
  222. package/dist/core-memory-GTGDVXLO.js +110 -0
  223. package/dist/core-memory-NID6R3YR.js +110 -0
  224. package/dist/core-memory-XHIC5NAB.js +110 -0
  225. package/dist/crm-webhook-MHZTXU5N.js +10 -0
  226. package/dist/crm-webhook-P6TXQMLI.js +10 -0
  227. package/dist/crm-webhook-TMWJT2Z5.js +10 -0
  228. package/dist/crm-webhook-XISULXI7.js +10 -0
  229. package/dist/crm-webhook-YJ5A7F2E.js +10 -0
  230. package/dist/cto-delegation-gate-4PMJZL2T.js +206 -0
  231. package/dist/cto-delegation-gate-A7YKXTRO.js +206 -0
  232. package/dist/cto-delegation-gate-OREBAHUM.js +206 -0
  233. package/dist/cto-delegation-gate-POHESML5.js +206 -0
  234. package/dist/cto-delegation-gate-XFDEMR3W.js +206 -0
  235. package/dist/daemon-orchestration-HXYPHSYU.js +135 -0
  236. package/dist/daemon-orchestration-I5BE46P3.js +135 -0
  237. package/dist/daemon-orchestration-NKE4FYQS.js +135 -0
  238. package/dist/daemon-orchestration-TFHRZ2RV.js +135 -0
  239. package/dist/daemon-orchestration-YWEXRAZA.js +135 -0
  240. package/dist/dreaming-3F72ROTL.js +32 -0
  241. package/dist/dreaming-DJWC7RVV.js +32 -0
  242. package/dist/dreaming-JD7MNJGS.js +32 -0
  243. package/dist/dreaming-LCKPA3B4.js +32 -0
  244. package/dist/dreaming-SDS5IQYC.js +32 -0
  245. package/dist/exe-export-IZ2OYMT4.js +73 -0
  246. package/dist/exe-export-JNWX6ZCQ.js +73 -0
  247. package/dist/exe-export-OQXCJLWB.js +73 -0
  248. package/dist/exe-export-QUT5WDDK.js +73 -0
  249. package/dist/exe-export-YLVAZQAV.js +73 -0
  250. package/dist/exe-import-AEJYBLA7.js +76 -0
  251. package/dist/exe-import-HWPYARCG.js +76 -0
  252. package/dist/exe-import-JE7YYYBJ.js +76 -0
  253. package/dist/exe-import-K4TWTG24.js +76 -0
  254. package/dist/exe-import-LZKZQ54C.js +76 -0
  255. package/dist/exe-key-6FPQHBW6.js +579 -0
  256. package/dist/exe-key-7XX4OUXD.js +579 -0
  257. package/dist/exe-key-N3XYSEXP.js +579 -0
  258. package/dist/exe-key-Q3ZNYT6L.js +579 -0
  259. package/dist/exe-key-Q47RPB45.js +579 -0
  260. package/dist/exe-snapshot-2USE2HHM.js +164 -0
  261. package/dist/exe-snapshot-HZU66HXX.js +164 -0
  262. package/dist/exe-snapshot-L7OQWZUH.js +164 -0
  263. package/dist/exe-snapshot-NET7N53Z.js +164 -0
  264. package/dist/exe-snapshot-X5N5KIVJ.js +164 -0
  265. package/dist/fast-db-init-C6IPNVPU.js +7 -0
  266. package/dist/fast-db-init-I7CMGBAN.js +7 -0
  267. package/dist/fast-db-init-P6YESOUL.js +7 -0
  268. package/dist/fast-db-init-VDNEFVQF.js +7 -0
  269. package/dist/fast-db-init-Y6C4TM2T.js +7 -0
  270. package/dist/gateway/index.js +6 -6
  271. package/dist/git-task-sweep-C4OV2CEY.js +40 -0
  272. package/dist/git-task-sweep-J66SYJMW.js +40 -0
  273. package/dist/git-task-sweep-JYCD3ZKQ.js +40 -0
  274. package/dist/git-task-sweep-O723DB7F.js +40 -0
  275. package/dist/git-task-sweep-R3CZQT4O.js +40 -0
  276. package/dist/hooks/bug-report-worker.js +4 -4
  277. package/dist/hooks/codex-stop-task-finalizer.js +4 -4
  278. package/dist/hooks/commit-complete.js +4 -4
  279. package/dist/hooks/error-recall.js +2 -2
  280. package/dist/hooks/ingest.js +2 -2
  281. package/dist/hooks/instructions-loaded.js +1 -1
  282. package/dist/hooks/manifest.json +18 -18
  283. package/dist/hooks/notification.js +1 -1
  284. package/dist/hooks/post-compact.js +2 -2
  285. package/dist/hooks/post-tool-combined.js +2 -2
  286. package/dist/hooks/pre-compact.js +3 -3
  287. package/dist/hooks/pre-tool-use.js +6 -6
  288. package/dist/hooks/prompt-submit.js +8 -8
  289. package/dist/hooks/session-end.js +5 -5
  290. package/dist/hooks/session-start.js +5 -5
  291. package/dist/hooks/stop.js +5 -5
  292. package/dist/hooks/subagent-stop.js +2 -2
  293. package/dist/hooks/summary-worker.js +5 -5
  294. package/dist/index.js +9 -9
  295. package/dist/lib/consolidation.js +2 -2
  296. package/dist/lib/exe-daemon.js +18 -17
  297. package/dist/lib/hybrid-search.js +2 -2
  298. package/dist/lib/messaging.js +4 -2
  299. package/dist/lib/schedules.js +2 -2
  300. package/dist/lib/store.js +1 -1
  301. package/dist/lib/tasks.js +3 -3
  302. package/dist/lib/tmux-routing.js +1 -1
  303. package/dist/mcp/register-tools.js +24 -24
  304. package/dist/mcp/server.js +25 -25
  305. package/dist/mcp/tools/create-task.js +4 -4
  306. package/dist/mcp/tools/list-tasks.js +4 -4
  307. package/dist/mcp/tools/send-message.js +3 -3
  308. package/dist/mcp/tools/update-task.js +4 -4
  309. package/dist/notifications-65STXW6N.js +45 -0
  310. package/dist/notifications-C6WBZYSS.js +45 -0
  311. package/dist/notifications-K3JDUPL5.js +45 -0
  312. package/dist/notifications-KQOD66ZK.js +45 -0
  313. package/dist/notifications-PFK5OQEF.js +45 -0
  314. package/dist/orchestrator-3D7QEVGP.js +33 -0
  315. package/dist/orchestrator-CC32RZO5.js +33 -0
  316. package/dist/orchestrator-DDKE4UM3.js +33 -0
  317. package/dist/orchestrator-DWAYSAFR.js +33 -0
  318. package/dist/orchestrator-TL37EAWA.js +33 -0
  319. package/dist/pipeline-router-ADLTS6DZ.js +13 -0
  320. package/dist/pipeline-router-NCOLBCHN.js +13 -0
  321. package/dist/pipeline-router-O6ZLSM6U.js +13 -0
  322. package/dist/pipeline-router-QKLYUYU7.js +13 -0
  323. package/dist/pipeline-router-W2W5XDND.js +13 -0
  324. package/dist/reranker-3GFGGCJF.js +19 -0
  325. package/dist/reranker-3KLYAHO4.js +19 -0
  326. package/dist/reranker-64KDRYPP.js +19 -0
  327. package/dist/reranker-MGY5A7BQ.js +19 -0
  328. package/dist/reranker-ZBX6HSU2.js +19 -0
  329. package/dist/review-polling-3ZZ2T26N.js +124 -0
  330. package/dist/review-polling-62EGCBLH.js +124 -0
  331. package/dist/review-polling-BBQUF54Q.js +124 -0
  332. package/dist/review-polling-RXQZPGRY.js +124 -0
  333. package/dist/review-polling-YBB6DKA5.js +124 -0
  334. package/dist/runtime/index.js +3 -3
  335. package/dist/session-events-EAODNMNR.js +36 -0
  336. package/dist/session-events-MVO6JNUL.js +36 -0
  337. package/dist/session-events-PRVDH3QS.js +36 -0
  338. package/dist/session-events-PU5OQKMB.js +36 -0
  339. package/dist/session-events-UXAPXR2D.js +36 -0
  340. package/dist/session-scope-K4FRGQK4.js +86 -0
  341. package/dist/session-scope-M47JR2SD.js +86 -0
  342. package/dist/session-scope-MRQYSD5S.js +86 -0
  343. package/dist/session-scope-TAH5BUYW.js +86 -0
  344. package/dist/session-scope-UXZ6RUWC.js +86 -0
  345. package/dist/skill-refinement-447DZWNK.js +157 -0
  346. package/dist/skill-refinement-567JSF7L.js +157 -0
  347. package/dist/skill-refinement-6JVQ3TMS.js +157 -0
  348. package/dist/skill-refinement-TCI6A32K.js +157 -0
  349. package/dist/skill-refinement-XNGD3C62.js +157 -0
  350. package/dist/task-enforcement-7QXEVHAS.js +391 -0
  351. package/dist/task-enforcement-AZEO67N6.js +391 -0
  352. package/dist/task-enforcement-EOYP6IO4.js +391 -0
  353. package/dist/task-enforcement-L5XQKFOV.js +391 -0
  354. package/dist/task-enforcement-RJPWWEAE.js +391 -0
  355. package/dist/task-scope-DRQRNWB7.js +35 -0
  356. package/dist/task-scope-GS7TS3UV.js +35 -0
  357. package/dist/task-scope-KQNCP42W.js +35 -0
  358. package/dist/task-scope-OJER4AQ2.js +35 -0
  359. package/dist/task-scope-SM5F6RD3.js +35 -0
  360. package/dist/tasks-crud-6TWWETGB.js +77 -0
  361. package/dist/tasks-crud-DBHYO4MM.js +77 -0
  362. package/dist/tasks-crud-EFYWPPEI.js +77 -0
  363. package/dist/tasks-crud-JIS5B4GZ.js +77 -0
  364. package/dist/tasks-crud-WKJSB5PH.js +77 -0
  365. package/dist/tasks-notify-GEJKT5TO.js +38 -0
  366. package/dist/tasks-notify-OW3JDPLK.js +38 -0
  367. package/dist/tasks-notify-UHE7X6RD.js +38 -0
  368. package/dist/tasks-notify-W5WVP2FG.js +38 -0
  369. package/dist/tasks-notify-YKEOYOKN.js +38 -0
  370. package/dist/tasks-review-2D2X6AHO.js +47 -0
  371. package/dist/tasks-review-DRKN34HO.js +47 -0
  372. package/dist/tasks-review-IQSAXXXE.js +47 -0
  373. package/dist/tasks-review-KWELLLS3.js +47 -0
  374. package/dist/tasks-review-SUJ6AKAS.js +47 -0
  375. package/dist/telemetry-upload-FPQAB6ZU.js +739 -0
  376. package/dist/telemetry-upload-JQYBFEWG.js +739 -0
  377. package/dist/telemetry-upload-MYVBVUGE.js +739 -0
  378. package/dist/telemetry-upload-UPAABLGK.js +739 -0
  379. package/dist/telemetry-upload-UYEHBFGO.js +739 -0
  380. package/dist/tui/App.js +7 -7
  381. package/dist/tui-data-LYUZFNO4.js +258 -0
  382. package/dist/tui-data-NIT4PI5T.js +258 -0
  383. package/dist/tui-data-QM5BOKRF.js +258 -0
  384. package/dist/tui-data-VAE43SM3.js +258 -0
  385. package/dist/tui-data-X7HT3FXF.js +258 -0
  386. package/dist/worker-gate-BZBWTMCY.js +21 -0
  387. package/dist/worker-gate-CHVL6UGT.js +21 -0
  388. package/dist/worker-gate-I6XMCYS4.js +21 -0
  389. package/dist/worker-gate-KQFS4RJE.js +21 -0
  390. package/dist/worker-gate-NRP7CMS7.js +21 -0
  391. package/dist/workflow-engine-AKKOMJJQ.js +28 -0
  392. package/dist/workflow-engine-EHWQO3LX.js +28 -0
  393. package/dist/workflow-engine-EMZ5WMQ5.js +28 -0
  394. package/dist/workflow-engine-I3OUMSF4.js +28 -0
  395. package/dist/workflow-engine-PHTLEAXP.js +28 -0
  396. package/package.json +1 -1
  397. package/release-notes.json +46 -46
@@ -0,0 +1,333 @@
1
+ import {
2
+ executeAction,
3
+ substituteTemplate
4
+ } from "./chunk-ZFRG2MNB.js";
5
+
6
+ // src/automation/workflow-engine.ts
7
+ import { randomUUID } from "crypto";
8
+ var _definitions = /* @__PURE__ */ new Map();
9
+ var _instances = /* @__PURE__ */ new Map();
10
+ function createWorkflowDefinition(input) {
11
+ const def = {
12
+ id: randomUUID().slice(0, 12),
13
+ ...input,
14
+ created_at: (/* @__PURE__ */ new Date()).toISOString()
15
+ };
16
+ def.steps = def.steps.map((s, i) => ({ ...s, index: s.index || i + 1 }));
17
+ _definitions.set(def.id, def);
18
+ return def;
19
+ }
20
+ function getWorkflowDefinition(id) {
21
+ return _definitions.get(id);
22
+ }
23
+ function listWorkflowDefinitions() {
24
+ return [..._definitions.values()];
25
+ }
26
+ function buildTemplateContext(instance) {
27
+ const ctx = { ...instance.context };
28
+ const stepMap = {};
29
+ for (const sr of instance.step_results) {
30
+ stepMap[String(sr.step_index)] = {
31
+ status: sr.status,
32
+ result: sr.result,
33
+ error: sr.error
34
+ };
35
+ }
36
+ ctx.step = stepMap;
37
+ return ctx;
38
+ }
39
+ function resolveActionParams(action, context) {
40
+ const resolved = {};
41
+ for (const [key, val] of Object.entries(action.params)) {
42
+ resolved[key] = substituteTemplate(val, context);
43
+ }
44
+ return { ...action, params: resolved };
45
+ }
46
+ function startWorkflow(definitionId, context = {}) {
47
+ const def = _definitions.get(definitionId);
48
+ if (!def) throw new Error(`Workflow definition "${definitionId}" not found`);
49
+ const instance = {
50
+ id: randomUUID().slice(0, 12),
51
+ definition_id: definitionId,
52
+ status: "running",
53
+ current_step: 1,
54
+ step_results: [],
55
+ context,
56
+ created_at: (/* @__PURE__ */ new Date()).toISOString(),
57
+ updated_at: (/* @__PURE__ */ new Date()).toISOString()
58
+ };
59
+ _instances.set(instance.id, instance);
60
+ return instance;
61
+ }
62
+ function getWorkflowInstance(id) {
63
+ return _instances.get(id);
64
+ }
65
+ function listWorkflowInstances(status) {
66
+ const all = [..._instances.values()];
67
+ return status ? all.filter((i) => i.status === status) : all;
68
+ }
69
+ async function advanceWorkflow(instanceId) {
70
+ const instance = _instances.get(instanceId);
71
+ if (!instance) throw new Error(`Workflow instance "${instanceId}" not found`);
72
+ if (instance.status !== "running") {
73
+ throw new Error(`Workflow "${instanceId}" is ${instance.status}, cannot advance`);
74
+ }
75
+ const def = _definitions.get(instance.definition_id);
76
+ if (!def) throw new Error(`Workflow definition "${instance.definition_id}" not found`);
77
+ const step = def.steps.find((s) => s.index === instance.current_step);
78
+ if (!step) {
79
+ instance.status = "completed";
80
+ instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
81
+ return instance;
82
+ }
83
+ const templateCtx = buildTemplateContext(instance);
84
+ const stepResult = {
85
+ step_index: step.index,
86
+ status: "success",
87
+ started_at: (/* @__PURE__ */ new Date()).toISOString()
88
+ };
89
+ switch (step.type) {
90
+ case "execute_action": {
91
+ const action = step.action ?? buildActionFromConnector(step);
92
+ if (!action) {
93
+ stepResult.status = "failed";
94
+ stepResult.error = "No action defined for execute_action step";
95
+ break;
96
+ }
97
+ const resolvedAction = resolveActionParams(action, templateCtx);
98
+ const result = await executeAction(resolvedAction, templateCtx);
99
+ stepResult.status = result.success ? "success" : "failed";
100
+ stepResult.result = result;
101
+ stepResult.error = result.error;
102
+ if (!result.success) {
103
+ instance.status = "failed";
104
+ }
105
+ break;
106
+ }
107
+ case "wait_for_approval": {
108
+ const { createTask } = await import("./lib/tasks.js");
109
+ const { getCoordinatorName } = await import("./lib/employees.js");
110
+ const message = step.approval_message ? substituteTemplate(step.approval_message, templateCtx) : `Workflow "${def.name}" step ${step.index} ("${step.name}") requires approval.`;
111
+ const task = await createTask({
112
+ title: `[Workflow Approval] ${def.name}: ${step.name}`,
113
+ assignedTo: getCoordinatorName(),
114
+ assignedBy: "workflow-engine",
115
+ projectName: "exe-os",
116
+ priority: "p1",
117
+ context: `${message}
118
+
119
+ **Workflow:** ${def.name} (${instance.id})
120
+ **Step:** ${step.index} \u2014 ${step.name}
121
+
122
+ To approve: call approve_workflow_step with instance_id="${instance.id}"
123
+ To reject: call approve_workflow_step with instance_id="${instance.id}" approved=false`,
124
+ baseDir: process.cwd()
125
+ });
126
+ instance.approval_task_id = task.id;
127
+ instance.status = "waiting_approval";
128
+ stepResult.status = "pending_approval";
129
+ break;
130
+ }
131
+ case "conditional": {
132
+ if (!step.condition) {
133
+ stepResult.status = "failed";
134
+ stepResult.error = "No condition defined for conditional step";
135
+ break;
136
+ }
137
+ const resolvedExpr = substituteTemplate(step.condition.expression, templateCtx);
138
+ const conditionMet = evaluateSimpleExpression(resolvedExpr);
139
+ stepResult.result = { expression: resolvedExpr, met: conditionMet };
140
+ if (conditionMet && step.condition.then_step) {
141
+ instance.current_step = step.condition.then_step;
142
+ stepResult.completed_at = (/* @__PURE__ */ new Date()).toISOString();
143
+ instance.step_results.push(stepResult);
144
+ instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
145
+ return instance;
146
+ } else if (!conditionMet && step.condition.else_step) {
147
+ instance.current_step = step.condition.else_step;
148
+ stepResult.completed_at = (/* @__PURE__ */ new Date()).toISOString();
149
+ instance.step_results.push(stepResult);
150
+ instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
151
+ return instance;
152
+ }
153
+ break;
154
+ }
155
+ }
156
+ stepResult.completed_at = (/* @__PURE__ */ new Date()).toISOString();
157
+ instance.step_results.push(stepResult);
158
+ if (instance.status === "running") {
159
+ const nextStep = def.steps.find((s) => s.index > step.index);
160
+ if (nextStep) {
161
+ instance.current_step = nextStep.index;
162
+ } else {
163
+ instance.status = "completed";
164
+ }
165
+ }
166
+ instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
167
+ return instance;
168
+ }
169
+ async function runWorkflow(instanceId) {
170
+ let instance = _instances.get(instanceId);
171
+ if (!instance) throw new Error(`Workflow instance "${instanceId}" not found`);
172
+ while (instance.status === "running") {
173
+ instance = await advanceWorkflow(instanceId);
174
+ }
175
+ return instance;
176
+ }
177
+ async function approveWorkflowStep(instanceId, approved = true) {
178
+ const instance = _instances.get(instanceId);
179
+ if (!instance) throw new Error(`Workflow instance "${instanceId}" not found`);
180
+ if (instance.status !== "waiting_approval") {
181
+ throw new Error(`Workflow "${instanceId}" is not waiting for approval (status: ${instance.status})`);
182
+ }
183
+ const pendingResult = instance.step_results.find(
184
+ (sr) => sr.step_index === instance.current_step && sr.status === "pending_approval"
185
+ );
186
+ if (pendingResult) {
187
+ pendingResult.status = approved ? "approved" : "failed";
188
+ pendingResult.completed_at = (/* @__PURE__ */ new Date()).toISOString();
189
+ pendingResult.result = { approved };
190
+ }
191
+ if (!approved) {
192
+ instance.status = "cancelled";
193
+ instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
194
+ return instance;
195
+ }
196
+ const def = _definitions.get(instance.definition_id);
197
+ if (!def) throw new Error(`Workflow definition "${instance.definition_id}" not found`);
198
+ const currentStep = def.steps.find((s) => s.index === instance.current_step);
199
+ const nextStep = currentStep ? def.steps.find((s) => s.index > currentStep.index) : void 0;
200
+ if (nextStep) {
201
+ instance.current_step = nextStep.index;
202
+ instance.status = "running";
203
+ } else {
204
+ instance.status = "completed";
205
+ }
206
+ instance.approval_task_id = void 0;
207
+ instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
208
+ if (instance.status === "running") {
209
+ return runWorkflow(instanceId);
210
+ }
211
+ return instance;
212
+ }
213
+ function buildActionFromConnector(step) {
214
+ if (!step.connector || !step.operation) return null;
215
+ const params = {};
216
+ if (step.payload) {
217
+ for (const [k, v] of Object.entries(step.payload)) {
218
+ params[k] = String(v);
219
+ }
220
+ }
221
+ params._connector = step.connector;
222
+ params._operation = step.operation;
223
+ return {
224
+ type: "mcp_tool",
225
+ params
226
+ };
227
+ }
228
+ function evaluateSimpleExpression(expr) {
229
+ const operators = ["==", "!=", ">=", "<=", ">", "<"];
230
+ for (const op of operators) {
231
+ const idx = expr.indexOf(op);
232
+ if (idx === -1) continue;
233
+ const left = expr.slice(0, idx).trim();
234
+ const right = expr.slice(idx + op.length).trim();
235
+ switch (op) {
236
+ case "==":
237
+ return left === right;
238
+ case "!=":
239
+ return left !== right;
240
+ case ">":
241
+ return Number(left) > Number(right);
242
+ case "<":
243
+ return Number(left) < Number(right);
244
+ case ">=":
245
+ return Number(left) >= Number(right);
246
+ case "<=":
247
+ return Number(left) <= Number(right);
248
+ }
249
+ }
250
+ return expr.trim() !== "" && expr.trim() !== "false" && expr.trim() !== "0";
251
+ }
252
+ async function persistWorkflows() {
253
+ try {
254
+ const { getClient } = await import("./lib/database.js");
255
+ const client = getClient();
256
+ for (const def of _definitions.values()) {
257
+ await client.execute({
258
+ sql: `INSERT OR REPLACE INTO workflow_definitions (id, name, description, steps, trigger_event, created_at)
259
+ VALUES (?, ?, ?, ?, ?, ?)`,
260
+ args: [def.id, def.name, def.description ?? null, JSON.stringify(def.steps), def.trigger_event ?? null, def.created_at]
261
+ });
262
+ }
263
+ for (const inst of _instances.values()) {
264
+ await client.execute({
265
+ sql: `INSERT OR REPLACE INTO workflow_instances
266
+ (id, definition_id, status, current_step, step_results, context, approval_task_id, created_at, updated_at)
267
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,
268
+ args: [
269
+ inst.id,
270
+ inst.definition_id,
271
+ inst.status,
272
+ inst.current_step,
273
+ JSON.stringify(inst.step_results),
274
+ JSON.stringify(inst.context),
275
+ inst.approval_task_id ?? null,
276
+ inst.created_at,
277
+ inst.updated_at
278
+ ]
279
+ });
280
+ }
281
+ } catch (e) {
282
+ process.stderr.write(`[workflow-engine] persist failed: ${e instanceof Error ? e.message : String(e)}
283
+ `);
284
+ }
285
+ }
286
+ async function loadWorkflows() {
287
+ try {
288
+ const { getClient } = await import("./lib/database.js");
289
+ const client = getClient();
290
+ const defs = await client.execute("SELECT * FROM workflow_definitions");
291
+ for (const row of defs.rows) {
292
+ const def = {
293
+ id: String(row.id),
294
+ name: String(row.name),
295
+ description: String(row.description),
296
+ steps: JSON.parse(String(row.steps)),
297
+ trigger_event: String(row.trigger_event),
298
+ created_at: String(row.created_at)
299
+ };
300
+ _definitions.set(def.id, def);
301
+ }
302
+ const insts = await client.execute("SELECT * FROM workflow_instances WHERE status NOT IN ('completed', 'cancelled')");
303
+ for (const row of insts.rows) {
304
+ const inst = {
305
+ id: String(row.id),
306
+ definition_id: String(row.definition_id),
307
+ status: String(row.status),
308
+ current_step: Number(row.current_step),
309
+ step_results: JSON.parse(String(row.step_results)),
310
+ context: JSON.parse(String(row.context)),
311
+ approval_task_id: row.approval_task_id ? String(row.approval_task_id) : void 0,
312
+ created_at: String(row.created_at),
313
+ updated_at: String(row.updated_at)
314
+ };
315
+ _instances.set(inst.id, inst);
316
+ }
317
+ } catch {
318
+ }
319
+ }
320
+
321
+ export {
322
+ createWorkflowDefinition,
323
+ getWorkflowDefinition,
324
+ listWorkflowDefinitions,
325
+ startWorkflow,
326
+ getWorkflowInstance,
327
+ listWorkflowInstances,
328
+ advanceWorkflow,
329
+ runWorkflow,
330
+ approveWorkflowStep,
331
+ persistWorkflows,
332
+ loadWorkflows
333
+ };
@@ -0,0 +1,346 @@
1
+ import {
2
+ recordSessionKill
3
+ } from "./chunk-SG2ANG5C.js";
4
+ import {
5
+ sessionScopeFilter,
6
+ verifyPaneAtCapacity,
7
+ writeNotification
8
+ } from "./chunk-5M5RYJ22.js";
9
+ import {
10
+ listSessions
11
+ } from "./chunk-OBUV3W7L.js";
12
+ import {
13
+ getTransport
14
+ } from "./chunk-MVW62NIZ.js";
15
+ import {
16
+ recordOrchestrationEventBestEffort
17
+ } from "./chunk-2NQQP3FF.js";
18
+ import {
19
+ getClient,
20
+ isCoordinatorName
21
+ } from "./chunk-CHBHR5W6.js";
22
+
23
+ // src/lib/capacity-monitor.ts
24
+ var CAPACITY_PATTERNS = [
25
+ /conversation is too long/i,
26
+ /maximum context length/i,
27
+ /context window.*(?:limit|exceed|full)/i,
28
+ /reached.*(?:token|context).*limit/i
29
+ ];
30
+ var CONTENT_LINE_PREFIX = /^[\s>#\-*[]/;
31
+ var CONTENT_LINE_MARKERS = [
32
+ "RESUME:",
33
+ "intercom",
34
+ "capacity-monitor",
35
+ "CAPACITY_PATTERNS",
36
+ "isAtCapacity",
37
+ "CONTENT_LINE_MARKERS",
38
+ "pollCapacityDead",
39
+ "confirmCapacityKill",
40
+ "session_kills",
41
+ "capacity-monitor.test"
42
+ ];
43
+ var SOURCE_CODE_MARKERS = [
44
+ /["'`/].*(?:maximum context length|conversation is too long)/i,
45
+ /(?:maximum context length|conversation is too long).*["'`/]/i
46
+ ];
47
+ var RELAUNCH_COOLDOWN_MS = 5 * 60 * 1e3;
48
+ var _lastRelaunch = /* @__PURE__ */ new Map();
49
+ var RESUME_TITLE_PREFIX = "RESUME:";
50
+ var RESUME_TITLE_LIKE_PATTERN = `${RESUME_TITLE_PREFIX} % hit context capacity%`;
51
+ var RESUME_ACTIVE_STATUSES = ["open", "in_progress"];
52
+ function resumeTaskTitle(agentId) {
53
+ return `${RESUME_TITLE_PREFIX} ${agentId} hit context capacity \u2014 continue open tasks`;
54
+ }
55
+ function buildResumeContext(agentId, openTasks) {
56
+ const taskList = openTasks.map(
57
+ (r, i) => `${i + 1}. [${String(r.priority).toUpperCase()}] ${String(r.title)} (${String(r.task_file)})`
58
+ ).join("\n");
59
+ return [
60
+ "## Context",
61
+ "",
62
+ `${agentId} hit context capacity and was auto-relaunched by the capacity monitor.`,
63
+ "Call recall_my_memory first \u2014 search for 'CONTEXT CHECKPOINT'. Pick up where the previous session stopped.",
64
+ "",
65
+ `You have ${openTasks.length} open task(s). Work through them in priority order:`,
66
+ "",
67
+ taskList,
68
+ "",
69
+ "Read each task file and chain through them. Build and commit after each one."
70
+ ].join("\n");
71
+ }
72
+ var CONFIRMATION_WINDOW_MS = 3 * 60 * 1e3;
73
+ var _pendingCapacityKill = /* @__PURE__ */ new Map();
74
+ function filterPaneContent(paneOutput) {
75
+ return paneOutput.split("\n").filter((line) => {
76
+ if (CONTENT_LINE_PREFIX.test(line)) return false;
77
+ for (const marker of CONTENT_LINE_MARKERS) {
78
+ if (line.includes(marker)) return false;
79
+ }
80
+ for (const re of SOURCE_CODE_MARKERS) {
81
+ if (re.test(line)) return false;
82
+ }
83
+ return true;
84
+ }).join("\n");
85
+ }
86
+ var CC_CONTEXT_BAR_RE = /([\u2588\u2591\u2592\u2593]{10})\s+(\d+)%/;
87
+ var CTX_FLOOR_PERCENT = 50;
88
+ function extractContextPercent(paneOutput) {
89
+ const match = paneOutput.match(CC_CONTEXT_BAR_RE);
90
+ if (!match) return null;
91
+ const parsed = Number.parseInt(match[2], 10);
92
+ return Number.isFinite(parsed) ? parsed : null;
93
+ }
94
+ function isAtCapacity(paneOutput) {
95
+ const filtered = filterPaneContent(paneOutput);
96
+ return CAPACITY_PATTERNS.some((p) => p.test(filtered));
97
+ }
98
+ function confirmCapacityKill(agentId, now = Date.now()) {
99
+ const pendingSince = _pendingCapacityKill.get(agentId);
100
+ if (pendingSince === void 0) {
101
+ _pendingCapacityKill.set(agentId, now);
102
+ return false;
103
+ }
104
+ if (now - pendingSince > CONFIRMATION_WINDOW_MS) {
105
+ _pendingCapacityKill.set(agentId, now);
106
+ return false;
107
+ }
108
+ _pendingCapacityKill.delete(agentId);
109
+ return true;
110
+ }
111
+ function _resetPendingCapacityKills() {
112
+ _pendingCapacityKill.clear();
113
+ }
114
+ function _resetLastRelaunchCache() {
115
+ _lastRelaunch.clear();
116
+ }
117
+ async function lastResumeCreatedAtMs(agentId, sessionScope) {
118
+ const client = getClient();
119
+ const cmScope = sessionScopeFilter(sessionScope ?? null);
120
+ const result = await client.execute({
121
+ sql: `SELECT MAX(created_at) AS last_created_at
122
+ FROM tasks
123
+ WHERE assigned_to = ? AND title LIKE ?${cmScope.sql}`,
124
+ args: [agentId, `${RESUME_TITLE_PREFIX} %`, ...cmScope.args]
125
+ });
126
+ const raw = result.rows[0]?.last_created_at;
127
+ if (raw === null || raw === void 0) return null;
128
+ const parsed = Date.parse(String(raw));
129
+ return Number.isNaN(parsed) ? null : parsed;
130
+ }
131
+ async function isWithinRelaunchCooldown(agentId, now = Date.now(), sessionScope) {
132
+ const cacheKey = sessionScope ? `${agentId}::${sessionScope}` : agentId;
133
+ const cached = _lastRelaunch.get(cacheKey);
134
+ if (cached !== void 0) return now - cached < RELAUNCH_COOLDOWN_MS;
135
+ const persisted = await lastResumeCreatedAtMs(agentId, sessionScope);
136
+ if (persisted === null) return false;
137
+ if (now - persisted >= RELAUNCH_COOLDOWN_MS) return false;
138
+ _lastRelaunch.set(cacheKey, persisted);
139
+ return true;
140
+ }
141
+ async function createOrRefreshResumeTask(agentId, projectDir, openTasks, sessionScope) {
142
+ const client = getClient();
143
+ const now = (/* @__PURE__ */ new Date()).toISOString();
144
+ const context = buildResumeContext(agentId, openTasks);
145
+ const rdScope = sessionScopeFilter(sessionScope ?? null);
146
+ const existing = await client.execute({
147
+ sql: `SELECT id FROM tasks
148
+ WHERE assigned_to = ?
149
+ AND title LIKE ?
150
+ AND status IN (${RESUME_ACTIVE_STATUSES.map(() => "?").join(", ")})${rdScope.sql}
151
+ ORDER BY created_at DESC
152
+ LIMIT 1`,
153
+ args: [agentId, RESUME_TITLE_LIKE_PATTERN, ...RESUME_ACTIVE_STATUSES, ...rdScope.args]
154
+ });
155
+ if (existing.rows.length > 0) {
156
+ const taskId = String(existing.rows[0].id);
157
+ await client.execute({
158
+ sql: `UPDATE tasks SET context = ?, updated_at = ? WHERE id = ?`,
159
+ args: [context, now, taskId]
160
+ });
161
+ recordOrchestrationEventBestEffort({
162
+ eventType: "session.resumed",
163
+ source: "capacity-monitor.createOrRefreshResumeTask",
164
+ agentId,
165
+ taskId,
166
+ payload: { created: false, action: "refreshed" }
167
+ });
168
+ return { created: false, taskId };
169
+ }
170
+ const { createTask } = await import("./lib/tasks.js");
171
+ const task = await createTask({
172
+ title: resumeTaskTitle(agentId),
173
+ assignedTo: agentId,
174
+ assignedBy: "system",
175
+ projectName: projectDir.split("/").pop() ?? "unknown",
176
+ priority: "p0",
177
+ context,
178
+ baseDir: projectDir
179
+ });
180
+ recordOrchestrationEventBestEffort({
181
+ eventType: "session.resumed",
182
+ source: "capacity-monitor.createOrRefreshResumeTask",
183
+ agentId,
184
+ taskId: task.id,
185
+ payload: { created: true, action: "created", openTaskCount: openTasks.length }
186
+ });
187
+ return { created: true, taskId: task.id };
188
+ }
189
+ async function pollCapacityDead() {
190
+ const transport = getTransport();
191
+ const relaunched = [];
192
+ const registered = listSessions();
193
+ if (registered.length === 0) return [];
194
+ let liveSessions;
195
+ try {
196
+ liveSessions = transport.listSessions();
197
+ } catch {
198
+ return [];
199
+ }
200
+ for (const entry of registered) {
201
+ const { windowName, agentId, projectDir } = entry;
202
+ if (!liveSessions.includes(windowName)) continue;
203
+ const cmDashIdx = windowName.indexOf("-");
204
+ const cmDerivedScope = cmDashIdx >= 0 ? windowName.slice(cmDashIdx + 1) : null;
205
+ if (await isWithinRelaunchCooldown(agentId, Date.now(), cmDerivedScope)) continue;
206
+ let pane;
207
+ try {
208
+ pane = transport.capturePane(windowName, 15);
209
+ } catch {
210
+ continue;
211
+ }
212
+ if (!isAtCapacity(pane)) continue;
213
+ const ctxPct = extractContextPercent(pane);
214
+ if (ctxPct !== null && ctxPct < CTX_FLOOR_PERCENT) {
215
+ process.stderr.write(
216
+ `[capacity-monitor] ctx-floor: ${agentId} at ${ctxPct}% in ${windowName} \u2014 below ${CTX_FLOOR_PERCENT}%. Skipping capacity kill (likely self-referential content or false positive).
217
+ `
218
+ );
219
+ continue;
220
+ }
221
+ if (!confirmCapacityKill(agentId)) {
222
+ process.stderr.write(
223
+ `[capacity-monitor] ${agentId} matched capacity pattern once in ${windowName}. Awaiting confirmation on next tick.
224
+ `
225
+ );
226
+ continue;
227
+ }
228
+ const verify = await verifyPaneAtCapacity(windowName);
229
+ if (!verify.atCapacity) {
230
+ process.stderr.write(
231
+ `[capacity-monitor] verifyPaneAtCapacity rejected kill for ${agentId} in ${windowName} (reason: ${verify.reason}). Skipping.
232
+ `
233
+ );
234
+ void recordSessionKill({
235
+ sessionName: windowName,
236
+ agentId,
237
+ reason: "capacity_false_positive_blocked"
238
+ });
239
+ continue;
240
+ }
241
+ process.stderr.write(
242
+ `[capacity-monitor] Detected ${agentId} at capacity in session ${windowName} (confirmed). Auto-relaunching.
243
+ `
244
+ );
245
+ if (isCoordinatorName(agentId)) {
246
+ try {
247
+ const { loadConfigSync } = await import("./lib/config.js");
248
+ const cfg = loadConfigSync();
249
+ if (cfg.sessionLifecycle.autoRelaunchCoordinator !== false) {
250
+ const fs = await import("fs");
251
+ const path = await import("path");
252
+ const os = await import("os");
253
+ const markerDir = path.join(os.homedir(), ".exe-os", "session-cache");
254
+ fs.mkdirSync(markerDir, { recursive: true });
255
+ const markerPath = path.join(markerDir, `relaunch-${windowName}.json`);
256
+ fs.writeFileSync(markerPath, JSON.stringify({
257
+ reason: "context_full",
258
+ agentId,
259
+ projectDir,
260
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
261
+ }));
262
+ process.stderr.write(
263
+ `[capacity-monitor] Coordinator relaunch marker written: ${markerPath}
264
+ `
265
+ );
266
+ }
267
+ transport.kill(windowName);
268
+ void recordSessionKill({ sessionName: windowName, agentId, reason: "capacity" });
269
+ const coordCacheKey = cmDerivedScope ? `${agentId}::${cmDerivedScope}` : agentId;
270
+ _lastRelaunch.set(coordCacheKey, Date.now());
271
+ relaunched.push(agentId);
272
+ } catch (err) {
273
+ process.stderr.write(
274
+ `[capacity-monitor] Coordinator relaunch marker write failed: ${err instanceof Error ? err.message : String(err)}
275
+ `
276
+ );
277
+ }
278
+ continue;
279
+ }
280
+ try {
281
+ transport.kill(windowName);
282
+ void recordSessionKill({
283
+ sessionName: windowName,
284
+ agentId,
285
+ reason: "capacity"
286
+ });
287
+ const client = getClient();
288
+ const dashIdx = windowName.indexOf("-");
289
+ const derivedScope = dashIdx >= 0 ? windowName.slice(dashIdx + 1) : null;
290
+ const rlScope = sessionScopeFilter(derivedScope);
291
+ const openTasks = await client.execute({
292
+ sql: `SELECT id, title, priority, task_file, status
293
+ FROM tasks
294
+ WHERE assigned_to = ? AND status IN ('open', 'in_progress')${rlScope.sql}
295
+ ORDER BY
296
+ CASE priority WHEN 'p0' THEN 0 WHEN 'p1' THEN 1 WHEN 'p2' THEN 2 ELSE 3 END,
297
+ created_at ASC
298
+ LIMIT 10`,
299
+ args: [agentId, ...rlScope.args]
300
+ });
301
+ if (openTasks.rows.length === 0) {
302
+ process.stderr.write(
303
+ `[capacity-monitor] ${agentId} has no open tasks \u2014 skipping relaunch.
304
+ `
305
+ );
306
+ continue;
307
+ }
308
+ const { created } = await createOrRefreshResumeTask(
309
+ agentId,
310
+ projectDir,
311
+ openTasks.rows,
312
+ derivedScope
313
+ );
314
+ if (created) {
315
+ await writeNotification({
316
+ agentId: "system",
317
+ agentRole: "daemon",
318
+ event: "capacity_relaunch",
319
+ project: projectDir.split("/").pop() ?? "unknown",
320
+ summary: `${agentId} hit context capacity. Auto-relaunched with ${openTasks.rows.length} open task(s).`
321
+ });
322
+ }
323
+ const cacheKey = derivedScope ? `${agentId}::${derivedScope}` : agentId;
324
+ _lastRelaunch.set(cacheKey, Date.now());
325
+ if (created) relaunched.push(agentId);
326
+ } catch (err) {
327
+ process.stderr.write(
328
+ `[capacity-monitor] Failed to relaunch ${agentId}: ${err instanceof Error ? err.message : String(err)}
329
+ `
330
+ );
331
+ }
332
+ }
333
+ return relaunched;
334
+ }
335
+
336
+ export {
337
+ CTX_FLOOR_PERCENT,
338
+ extractContextPercent,
339
+ isAtCapacity,
340
+ confirmCapacityKill,
341
+ _resetPendingCapacityKills,
342
+ _resetLastRelaunchCache,
343
+ isWithinRelaunchCooldown,
344
+ createOrRefreshResumeTask,
345
+ pollCapacityDead
346
+ };