@askexenow/exe-os 0.9.299 → 0.9.301

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 (499) hide show
  1. package/deploy/compose/.env.customer.example +1 -1
  2. package/deploy/compose/.env.example +1 -1
  3. package/deploy/compose/docker-compose.yml +31 -5
  4. package/deploy/compose/erp-nginx/nginx.conf +6 -3
  5. package/deploy/compose/generate-env.ts +1 -1
  6. package/deploy/compose/observability/otel-collector-config.yaml +10 -1
  7. package/deploy/compose/setup.sh +1 -1
  8. package/dist/active-agent-56J56WW5.js +27 -0
  9. package/dist/active-agent-UNJO6AJ2.js +27 -0
  10. package/dist/active-agent-VDWK7TES.js +28 -0
  11. package/dist/active-agent-Y5LSIMVC.js +28 -0
  12. package/dist/agentic-ontology-MZ4WHFDE.js +25 -0
  13. package/dist/agentic-ontology-QEV7GI3T.js +25 -0
  14. package/dist/assets/com.askexe.exed.plist +6 -5
  15. package/dist/backfill-metadata-IHKI5GXV.js +600 -0
  16. package/dist/backfill-metadata-RQZ4BN7G.js +600 -0
  17. package/dist/backfill-metadata-ZU3SZNBD.js +600 -0
  18. package/dist/behaviors-A3L5CWMK.js +46 -0
  19. package/dist/behaviors-G4KWGS24.js +46 -0
  20. package/dist/behaviors-WO67R6C4.js +46 -0
  21. package/dist/bin/agentic-ontology-backfill.js +5 -5
  22. package/dist/bin/agentic-reflection-backfill.js +6 -6
  23. package/dist/bin/agentic-semantic-label.js +5 -5
  24. package/dist/bin/backfill-conversations.js +6 -6
  25. package/dist/bin/backfill-responses.js +6 -6
  26. package/dist/bin/backfill-vectors.js +8 -8
  27. package/dist/bin/bulk-sync-postgres.js +13 -7
  28. package/dist/bin/cc-doctor.js +5 -5
  29. package/dist/bin/cleanup-stale-review-tasks.js +10 -10
  30. package/dist/bin/cli.js +16 -16
  31. package/dist/bin/deferred-daemon-restart.js +1 -1
  32. package/dist/bin/exe-agent-config.js +2 -2
  33. package/dist/bin/exe-agent.js +10 -10
  34. package/dist/bin/exe-assign.js +8 -8
  35. package/dist/bin/exe-boot.js +36 -21
  36. package/dist/bin/exe-call.js +4 -4
  37. package/dist/bin/exe-cloud.js +13 -7
  38. package/dist/bin/exe-dispatch.js +10 -10
  39. package/dist/bin/exe-doctor.js +2 -2
  40. package/dist/bin/exe-export-behaviors.js +7 -7
  41. package/dist/bin/exe-forget.js +6 -6
  42. package/dist/bin/exe-gateway.js +7 -7
  43. package/dist/bin/exe-healthcheck.js +5 -5
  44. package/dist/bin/exe-heartbeat.js +10 -10
  45. package/dist/bin/exe-kill.js +13 -13
  46. package/dist/bin/exe-launch-agent.js +29 -19
  47. package/dist/bin/exe-new-employee.js +6 -6
  48. package/dist/bin/exe-pending-messages.js +11 -11
  49. package/dist/bin/exe-pending-notifications.js +10 -10
  50. package/dist/bin/exe-pending-reviews.js +10 -10
  51. package/dist/bin/exe-rename.js +4 -4
  52. package/dist/bin/exe-review.js +12 -12
  53. package/dist/bin/exe-search.js +5 -5
  54. package/dist/bin/exe-session-cleanup.js +15 -15
  55. package/dist/bin/exe-settings.js +13 -7
  56. package/dist/bin/exe-start-codex.js +11 -11
  57. package/dist/bin/exe-start-opencode.js +8 -8
  58. package/dist/bin/exe-status.js +11 -11
  59. package/dist/bin/exe-team.js +3 -3
  60. package/dist/bin/exe-watchdog.js +3 -3
  61. package/dist/bin/git-sweep.js +11 -11
  62. package/dist/bin/graph-backfill.js +6 -6
  63. package/dist/bin/graph-export.js +5 -5
  64. package/dist/bin/import-history.js +9 -9
  65. package/dist/bin/install-launchd.js +7 -3
  66. package/dist/bin/install.js +19 -15
  67. package/dist/bin/intercom-check.js +4 -4
  68. package/dist/bin/mcp-sessions.js +2 -2
  69. package/dist/bin/orchestration-metrics.js +4 -4
  70. package/dist/bin/postgres-agentic-reflection-backfill.js +2 -2
  71. package/dist/bin/postgres-agentic-semantic-backfill.js +1 -1
  72. package/dist/bin/pre-publish.js +24 -1
  73. package/dist/bin/scan-tasks.js +10 -10
  74. package/dist/bin/setup.js +1 -1
  75. package/dist/bin/shard-migrate.js +4 -4
  76. package/dist/bin/stack-update.js +123 -3
  77. package/dist/bin/vps-health-gate.js +1 -1
  78. package/dist/capability-cards-VTGDTOZ4.js +89 -0
  79. package/dist/capability-cards-XAQSL26B.js +89 -0
  80. package/dist/capacity-monitor-6MQLFFQT.js +51 -0
  81. package/dist/capacity-monitor-BB3LKJLE.js +51 -0
  82. package/dist/capacity-monitor-G2MAJPRP.js +51 -0
  83. package/dist/catchup-brief-BQSL5M5S.js +175 -0
  84. package/dist/catchup-brief-COALBX6L.js +175 -0
  85. package/dist/catchup-brief-VBGEJQRS.js +175 -0
  86. package/dist/cc-binary-detect-B5JDCJ5J.js +19 -0
  87. package/dist/chunk-22LDUTY7.js +14597 -0
  88. package/dist/chunk-24JVDLQJ.js +345 -0
  89. package/dist/chunk-24M4AJPG.js +128 -0
  90. package/dist/chunk-2B7RCTPT.js +85 -0
  91. package/dist/chunk-2QBA6YE6.js +127 -0
  92. package/dist/chunk-2RGDEBZC.js +731 -0
  93. package/dist/chunk-2T3OYZMR.js +1158 -0
  94. package/dist/chunk-32DBQWR5.js +333 -0
  95. package/dist/chunk-3ABY3QDX.js +199 -0
  96. package/dist/chunk-3EOPMTG2.js +128 -0
  97. package/dist/chunk-3G3ECFB5.js +668 -0
  98. package/dist/chunk-3LHOFGHT.js +280 -0
  99. package/dist/chunk-3NS4V4JW.js +382 -0
  100. package/dist/chunk-3NYY2NZ3.js +836 -0
  101. package/dist/chunk-3RA62PNQ.js +58 -0
  102. package/dist/chunk-3ROUD5WA.js +97 -0
  103. package/dist/chunk-3RY2ARDN.js +129 -0
  104. package/dist/chunk-3XRS5AVV.js +567 -0
  105. package/dist/chunk-3Y5IRIRU.js +290 -0
  106. package/dist/chunk-3YK7X5FD.js +1186 -0
  107. package/dist/chunk-3ZWWUKBI.js +210 -0
  108. package/dist/chunk-463G3VAH.js +122 -0
  109. package/dist/chunk-4L6PVYFE.js +54 -0
  110. package/dist/chunk-4LC7BFI2.js +76 -0
  111. package/dist/chunk-4O67LBMK.js +377 -0
  112. package/dist/chunk-4OIU3N6U.js +167 -0
  113. package/dist/chunk-4Z3FWLOE.js +836 -0
  114. package/dist/chunk-5BAU4T5G.js +208 -0
  115. package/dist/chunk-5FP7YHCG.js +1158 -0
  116. package/dist/chunk-5SYYMNPE.js +30 -0
  117. package/dist/chunk-5TO5PH7O.js +304 -0
  118. package/dist/chunk-5U3JZP62.js +1352 -0
  119. package/dist/chunk-5VNFXIGF.js +85 -0
  120. package/dist/chunk-5XD2Y463.js +402 -0
  121. package/dist/chunk-63AENHJC.js +123 -0
  122. package/dist/chunk-673IFJYB.js +731 -0
  123. package/dist/chunk-6UVUJNLY.js +1186 -0
  124. package/dist/chunk-7AWH47AR.js +448 -0
  125. package/dist/chunk-7KPWYWYL.js +290 -0
  126. package/dist/chunk-7P4B6AEP.js +227 -0
  127. package/dist/chunk-7URNGDEY.js +2145 -0
  128. package/dist/chunk-7VHOALNC.js +244 -0
  129. package/dist/chunk-ADZQBZOX.js +122 -0
  130. package/dist/chunk-APSZAEDO.js +1186 -0
  131. package/dist/chunk-ASHF6VO4.js +2265 -0
  132. package/dist/chunk-ASJHCAVL.js +38 -0
  133. package/dist/chunk-BT2LEHIW.js +448 -0
  134. package/dist/chunk-BTS5QUWB.js +50 -0
  135. package/dist/chunk-BWJDJ3BS.js +604 -0
  136. package/dist/chunk-CME46VWP.js +150 -0
  137. package/dist/chunk-D3ICCKXY.js +54 -0
  138. package/dist/chunk-D3IOU3NO.js +377 -0
  139. package/dist/chunk-DFGXRKI2.js +221 -0
  140. package/dist/chunk-DICIFTCS.js +150 -0
  141. package/dist/chunk-DIFI5JDC.js +76 -0
  142. package/dist/chunk-DO65VHQZ.js +128 -0
  143. package/dist/chunk-DPOIJ5SM.js +284 -0
  144. package/dist/chunk-E2OMUBXQ.js +567 -0
  145. package/dist/chunk-ECMXIV6N.js +97 -0
  146. package/dist/chunk-EDMVA3PT.js +727 -0
  147. package/dist/chunk-F5OSXH4A.js +4388 -0
  148. package/dist/chunk-F5OWHPRG.js +236 -0
  149. package/dist/chunk-F7MZA3QP.js +199 -0
  150. package/dist/chunk-FAZNXNA5.js +33 -0
  151. package/dist/chunk-FCHG5RC4.js +197 -0
  152. package/dist/chunk-FFKSPZO2.js +157 -0
  153. package/dist/chunk-FNHYH5U6.js +331 -0
  154. package/dist/chunk-FRNXQSB4.js +134 -0
  155. package/dist/chunk-FTAASABV.js +362 -0
  156. package/dist/chunk-FWPDAQ6Q.js +1350 -0
  157. package/dist/chunk-FZB73QOI.js +210 -0
  158. package/dist/chunk-GBL5QSTM.js +197 -0
  159. package/dist/chunk-GJBR6QLD.js +630 -0
  160. package/dist/chunk-GRSYAHKI.js +535 -0
  161. package/dist/chunk-GRXWINOW.js +244 -0
  162. package/dist/chunk-GUPNVUG5.js +348 -0
  163. package/dist/chunk-GY66UPMX.js +167 -0
  164. package/dist/chunk-HCCG67BY.js +43 -0
  165. package/dist/chunk-HCSZZXZZ.js +197 -0
  166. package/dist/chunk-HNGNZU62.js +240 -0
  167. package/dist/chunk-HP2D5LIE.js +214 -0
  168. package/dist/chunk-HUABQHDC.js +1352 -0
  169. package/dist/chunk-HYKO2LNW.js +157 -0
  170. package/dist/chunk-IFL6DG2K.js +181 -0
  171. package/dist/chunk-IKPQRHVQ.js +304 -0
  172. package/dist/chunk-J5HFRVNW.js +362 -0
  173. package/dist/chunk-J6SD7LT2.js +171 -0
  174. package/dist/chunk-JCWA3X6A.js +402 -0
  175. package/dist/chunk-JHPK33IP.js +2162 -0
  176. package/dist/chunk-JURL2S27.js +128 -0
  177. package/dist/chunk-JWGDH5I2.js +127 -0
  178. package/dist/chunk-KBXQFXYM.js +567 -0
  179. package/dist/chunk-KGY5QIOJ.js +1350 -0
  180. package/dist/chunk-KLES22FB.js +1094 -0
  181. package/dist/chunk-KPUYYOFS.js +122 -0
  182. package/dist/chunk-KY43UELJ.js +331 -0
  183. package/dist/chunk-L32V4O5Z.js +58 -0
  184. package/dist/chunk-LAFARYU5.js +456 -0
  185. package/dist/chunk-LC7ETNTJ.js +1350 -0
  186. package/dist/chunk-LEJ5FKIK.js +55 -0
  187. package/dist/chunk-LNLLCAI4.js +377 -0
  188. package/dist/chunk-LQWZYMNU.js +448 -0
  189. package/dist/chunk-LSDXEHKL.js +381 -0
  190. package/dist/chunk-LY3SOO73.js +76 -0
  191. package/dist/chunk-M6CIHXXB.js +159 -0
  192. package/dist/chunk-MJOQ35DX.js +427 -0
  193. package/dist/chunk-MO5HER5Y.js +345 -0
  194. package/dist/chunk-MS2EOZJQ.js +290 -0
  195. package/dist/chunk-MUIMJGSQ.js +128 -0
  196. package/dist/chunk-MY4TGLT6.js +284 -0
  197. package/dist/chunk-N3ARGCVG.js +345 -0
  198. package/dist/chunk-N4XG2M2U.js +735 -0
  199. package/dist/chunk-N72JNFJ4.js +535 -0
  200. package/dist/chunk-NJMPNYBS.js +427 -0
  201. package/dist/chunk-NM3AUMFE.js +2145 -0
  202. package/dist/chunk-NPPQ3TR4.js +735 -0
  203. package/dist/chunk-NTWF4DAF.js +581 -0
  204. package/dist/chunk-NXL3VKXM.js +331 -0
  205. package/dist/chunk-OJACH2JF.js +128 -0
  206. package/dist/chunk-OMSLHEEF.js +456 -0
  207. package/dist/chunk-OO4IFABD.js +382 -0
  208. package/dist/chunk-OYIP3QVN.js +167 -0
  209. package/dist/chunk-P2IOW54H.js +668 -0
  210. package/dist/chunk-P5KXQ3RN.js +731 -0
  211. package/dist/chunk-P5UXP53T.js +81 -0
  212. package/dist/chunk-PH6VRRFR.js +395 -0
  213. package/dist/chunk-Q3GKOF7Z.js +85 -0
  214. package/dist/chunk-Q65NCNL4.js +1352 -0
  215. package/dist/chunk-QIGS2LRT.js +735 -0
  216. package/dist/chunk-QKBN3CY2.js +381 -0
  217. package/dist/chunk-QNNAVMQH.js +1094 -0
  218. package/dist/chunk-QODDW4YI.js +171 -0
  219. package/dist/chunk-QPAYPTSH.js +2162 -0
  220. package/dist/chunk-QRWDJ5RI.js +381 -0
  221. package/dist/chunk-RBFZCHVB.js +105 -0
  222. package/dist/chunk-RCEULTPF.js +185 -0
  223. package/dist/chunk-RCGHXBCX.js +630 -0
  224. package/dist/chunk-ROSCLRTH.js +204 -0
  225. package/dist/chunk-RYAOSGUW.js +227 -0
  226. package/dist/chunk-S2SPGHPY.js +38 -0
  227. package/dist/chunk-S73ZAJ2S.js +262 -0
  228. package/dist/chunk-SBPEWD7Z.js +171 -0
  229. package/dist/chunk-SDPUWZP5.js +333 -0
  230. package/dist/chunk-SJ4UF7YK.js +1094 -0
  231. package/dist/chunk-SOZ7D77I.js +204 -0
  232. package/dist/chunk-SVLSHDNL.js +54 -0
  233. package/dist/chunk-SVUYBT5N.js +262 -0
  234. package/dist/chunk-T7PTLVJV.js +284 -0
  235. package/dist/chunk-TDX2LK2M.js +240 -0
  236. package/dist/chunk-TGUSLO4B.js +50 -0
  237. package/dist/chunk-TPJH6PE6.js +1158 -0
  238. package/dist/chunk-TVW7EDOJ.js +382 -0
  239. package/dist/chunk-TYRUIE6P.js +58 -0
  240. package/dist/chunk-U5RKGLV6.js +50 -0
  241. package/dist/chunk-UFGTHBHP.js +127 -0
  242. package/dist/chunk-ULCYWCPI.js +1079 -0
  243. package/dist/chunk-UN5EPVBN.js +14597 -0
  244. package/dist/chunk-URLH7ZVR.js +70 -0
  245. package/dist/chunk-USYRTGR7.js +402 -0
  246. package/dist/chunk-V4ABCEHM.js +30 -0
  247. package/dist/chunk-V6LOEOXG.js +3372 -0
  248. package/dist/chunk-VAZOVAW4.js +2162 -0
  249. package/dist/chunk-VEUQVKKT.js +185 -0
  250. package/dist/chunk-VIDDJ5RF.js +214 -0
  251. package/dist/chunk-VKCNXOQ6.js +214 -0
  252. package/dist/chunk-VNB4ROYG.js +348 -0
  253. package/dist/chunk-VWUQFZFB.js +395 -0
  254. package/dist/chunk-W77GRCNA.js +85 -0
  255. package/dist/chunk-WB2B25UM.js +230 -0
  256. package/dist/chunk-WCUZX7F7.js +204 -0
  257. package/dist/chunk-WL5RMOZQ.js +362 -0
  258. package/dist/chunk-WPAXAOHD.js +1079 -0
  259. package/dist/chunk-WVMG4ZRH.js +14597 -0
  260. package/dist/chunk-WYVOTRRZ.js +129 -0
  261. package/dist/chunk-XABJRAUW.js +3346 -0
  262. package/dist/chunk-XQQ7D4I4.js +85 -0
  263. package/dist/chunk-YDFY6YCH.js +280 -0
  264. package/dist/chunk-YGUMRYCN.js +33 -0
  265. package/dist/chunk-YHJPTIPR.js +836 -0
  266. package/dist/chunk-YJSP5PPG.js +128 -0
  267. package/dist/chunk-YLKS7KKC.js +2145 -0
  268. package/dist/chunk-YOMETWOJ.js +4388 -0
  269. package/dist/chunk-YU3KEVCO.js +333 -0
  270. package/dist/chunk-Z4FVFSE3.js +81 -0
  271. package/dist/chunk-Z4TLSNUW.js +244 -0
  272. package/dist/chunk-ZDPU3JTF.js +221 -0
  273. package/dist/chunk-ZDY4LYAJ.js +81 -0
  274. package/dist/chunk-ZG33AACD.js +70 -0
  275. package/dist/chunk-ZKHPZ6KN.js +181 -0
  276. package/dist/chunk-ZO2TM5N5.js +97 -0
  277. package/dist/chunk-ZP6T5K6I.js +535 -0
  278. package/dist/chunk-ZR6ZJT32.js +123 -0
  279. package/dist/chunk-ZSUACDQC.js +4388 -0
  280. package/dist/co-activation-JGF5YIDU.js +74 -0
  281. package/dist/co-activation-XM25BLZM.js +74 -0
  282. package/dist/co-occurrence-CKEMDPWO.js +95 -0
  283. package/dist/co-occurrence-HLLC6GT2.js +95 -0
  284. package/dist/co-occurrence-W2LIAPHI.js +95 -0
  285. package/dist/code-context-index-FCL47WKE.js +30 -0
  286. package/dist/conversation-entity-extractor-WC2RU6RS.js +114 -0
  287. package/dist/core-memory-CRSR2PSL.js +110 -0
  288. package/dist/core-memory-VSKFRMEV.js +110 -0
  289. package/dist/core-memory-ZDA76EU3.js +110 -0
  290. package/dist/crdt-sync-6VH2YDVY.js +33 -0
  291. package/dist/crdt-sync-BJKZB6T6.js +33 -0
  292. package/dist/crm-webhook-E5PAFAUN.js +10 -0
  293. package/dist/crm-webhook-RXFPZJXP.js +10 -0
  294. package/dist/crm-webhook-Z26LEFKG.js +10 -0
  295. package/dist/cto-delegation-gate-45IBLPTK.js +280 -0
  296. package/dist/cto-delegation-gate-EMY6ZZ2F.js +280 -0
  297. package/dist/cto-delegation-gate-SF4EUB2Q.js +280 -0
  298. package/dist/daemon-orchestration-VB3BLYIT.js +143 -0
  299. package/dist/daemon-orchestration-W66UYGUD.js +143 -0
  300. package/dist/daemon-orchestration-Y5Y6YNE3.js +143 -0
  301. package/dist/db-backup-HFJ53IBU.js +43 -0
  302. package/dist/db-backup-NVUTS7L5.js +43 -0
  303. package/dist/doc-graph-extractor-ID45AQ2P.js +133 -0
  304. package/dist/doc-graph-extractor-MLYQYT4B.js +133 -0
  305. package/dist/doc-graph-extractor-SVFSXKL6.js +133 -0
  306. package/dist/dreaming-AZYRAGKA.js +34 -0
  307. package/dist/dreaming-N6B7KBIE.js +34 -0
  308. package/dist/dreaming-WG5CDUHX.js +34 -0
  309. package/dist/entity-boost-XAFCDDB6.js +375 -0
  310. package/dist/exe-drift-3SGA53CL.js +70 -0
  311. package/dist/exe-drift-CPUEAPIU.js +70 -0
  312. package/dist/exe-export-4RTGDV53.js +77 -0
  313. package/dist/exe-export-APUNLKWF.js +77 -0
  314. package/dist/exe-export-NM4SXB3P.js +77 -0
  315. package/dist/exe-import-6GLNCP62.js +80 -0
  316. package/dist/exe-import-AZMIF34Z.js +80 -0
  317. package/dist/exe-import-U4H4ES3Z.js +80 -0
  318. package/dist/exe-key-FIPXUTMF.js +673 -0
  319. package/dist/exe-key-LJV23AJI.js +673 -0
  320. package/dist/exe-key-WTLCMOYJ.js +673 -0
  321. package/dist/exe-snapshot-ILO3WSEC.js +338 -0
  322. package/dist/exe-snapshot-IODRQLBX.js +338 -0
  323. package/dist/exe-snapshot-ZOZBW7V6.js +338 -0
  324. package/dist/fast-db-init-7LYYUCSJ.js +7 -0
  325. package/dist/fast-db-init-ATRZGHOL.js +7 -0
  326. package/dist/fast-db-init-IU7GYFWB.js +7 -0
  327. package/dist/gateway/index.js +11 -11
  328. package/dist/git-staleness-GGCFPHQ5.js +112 -0
  329. package/dist/git-staleness-XNOKI4D3.js +112 -0
  330. package/dist/git-task-sweep-3MO4OVND.js +42 -0
  331. package/dist/git-task-sweep-M3SWXFKJ.js +42 -0
  332. package/dist/git-task-sweep-Y6KNWB67.js +42 -0
  333. package/dist/global-procedures-626WAU3I.js +22 -0
  334. package/dist/global-procedures-EBAPPWGZ.js +22 -0
  335. package/dist/graph-auto-extract-TKHQ4OR3.js +183 -0
  336. package/dist/graph-auto-extract-VGFEWFZX.js +183 -0
  337. package/dist/graph-auto-extract-VJOUQBPK.js +183 -0
  338. package/dist/graph-rag-KECA5TE4.js +35 -0
  339. package/dist/hooks/bug-report-worker.js +12 -12
  340. package/dist/hooks/codex-stop-task-finalizer.js +12 -12
  341. package/dist/hooks/commit-complete.js +12 -12
  342. package/dist/hooks/error-recall.js +6 -6
  343. package/dist/hooks/exe-heartbeat-hook.js +3 -3
  344. package/dist/hooks/ingest-worker.js +3 -3
  345. package/dist/hooks/ingest.js +6 -6
  346. package/dist/hooks/instructions-loaded.js +4 -4
  347. package/dist/hooks/manifest.json +20 -20
  348. package/dist/hooks/notification.js +4 -4
  349. package/dist/hooks/post-compact.js +12 -12
  350. package/dist/hooks/post-tool-combined.js +6 -6
  351. package/dist/hooks/pre-compact.js +16 -16
  352. package/dist/hooks/pre-tool-use.js +15 -15
  353. package/dist/hooks/prompt-submit.js +28 -26
  354. package/dist/hooks/session-end.js +20 -20
  355. package/dist/hooks/session-start.js +12 -12
  356. package/dist/hooks/stop.js +18 -18
  357. package/dist/hooks/subagent-stop.js +11 -11
  358. package/dist/hooks/summary-worker.js +18 -18
  359. package/dist/index.js +20 -20
  360. package/dist/installer-37KFNAWE.js +344 -0
  361. package/dist/installer-3FB5EMPB.js +40 -0
  362. package/dist/installer-BRQ42CPB.js +344 -0
  363. package/dist/installer-F55NR4E2.js +298 -0
  364. package/dist/installer-KOYBUS4J.js +40 -0
  365. package/dist/installer-PXZJG256.js +298 -0
  366. package/dist/lib/cloud-sync.js +13 -7
  367. package/dist/lib/consolidation.js +7 -7
  368. package/dist/lib/database.js +6 -4
  369. package/dist/lib/db-daemon-client.js +11 -202
  370. package/dist/lib/db.js +6 -4
  371. package/dist/lib/embedder.js +3 -3
  372. package/dist/lib/employee-templates.js +4 -4
  373. package/dist/lib/employees.js +2 -2
  374. package/dist/lib/exe-daemon-client.js +2 -2
  375. package/dist/lib/exe-daemon.js +53 -51
  376. package/dist/lib/hybrid-search.js +5 -5
  377. package/dist/lib/identity.js +2 -2
  378. package/dist/lib/messaging.js +10 -10
  379. package/dist/lib/reminders.js +3 -3
  380. package/dist/lib/schedules.js +5 -5
  381. package/dist/lib/session-registry.js +4 -4
  382. package/dist/lib/skill-learning.js +6 -6
  383. package/dist/lib/store.js +4 -4
  384. package/dist/lib/task-router.js +3 -3
  385. package/dist/lib/tasks.js +11 -11
  386. package/dist/lib/tmux-routing.js +9 -9
  387. package/dist/lib/token-spend.js +3 -3
  388. package/dist/mcp/register-tools.js +65 -63
  389. package/dist/mcp/server.js +66 -64
  390. package/dist/mcp/tools/complete-reminder.js +4 -4
  391. package/dist/mcp/tools/create-reminder.js +4 -4
  392. package/dist/mcp/tools/create-task.js +13 -13
  393. package/dist/mcp/tools/deactivate-behavior.js +7 -7
  394. package/dist/mcp/tools/list-reminders.js +4 -4
  395. package/dist/mcp/tools/list-tasks.js +13 -13
  396. package/dist/mcp/tools/send-message.js +12 -12
  397. package/dist/mcp/tools/update-task.js +12 -12
  398. package/dist/mcp-http-config-7KJZI7UD.js +31 -0
  399. package/dist/mcp-http-config-OF3MB7M5.js +31 -0
  400. package/dist/memory-cards-CPIZVXWI.js +180 -0
  401. package/dist/memory-cards-ZIT7ZKL5.js +180 -0
  402. package/dist/memory-graph-extractor-JIYWLBFF.js +22 -0
  403. package/dist/memory-graph-extractor-LY2VORZT.js +22 -0
  404. package/dist/memory-graph-extractor-MDPSLZDM.js +22 -0
  405. package/dist/memory-poisoning-defense-5UZT3WWA.js +224 -0
  406. package/dist/memory-poisoning-defense-SEM25TY5.js +224 -0
  407. package/dist/memory-queue-client-WKWRFERJ.js +16 -0
  408. package/dist/memory-reflection-J2W7CJ7C.js +244 -0
  409. package/dist/memory-reflection-TA2VQYPH.js +244 -0
  410. package/dist/message-queue-client-IFQQ2HI7.js +92 -0
  411. package/dist/notifications-CZBQ3H5T.js +47 -0
  412. package/dist/notifications-EIIL2EQV.js +47 -0
  413. package/dist/notifications-RLMSI4YE.js +47 -0
  414. package/dist/orchestration-events-TGQYA72K.js +27 -0
  415. package/dist/orchestration-events-VUYR6MXE.js +27 -0
  416. package/dist/orchestrator-JQD5G3CW.js +35 -0
  417. package/dist/orchestrator-MAMR4C37.js +35 -0
  418. package/dist/orchestrator-VE5WHEJH.js +35 -0
  419. package/dist/pipeline-router-3Q3YBYSM.js +15 -0
  420. package/dist/pipeline-router-DKXD6DJO.js +15 -0
  421. package/dist/pipeline-router-YNW63BY5.js +15 -0
  422. package/dist/plan-limits-YGXTYCW4.js +28 -0
  423. package/dist/plan-limits-ZM4MNZKY.js +28 -0
  424. package/dist/project-boot-E2TWYTAC.js +299 -0
  425. package/dist/project-boot-TDOZKKDR.js +299 -0
  426. package/dist/projection-worker-TMKUSVGD.js +1084 -0
  427. package/dist/projection-worker-WFPRM4AI.js +1084 -0
  428. package/dist/projection-worker-YKV3PFCV.js +1084 -0
  429. package/dist/prospective-memory-CNJDBNWF.js +232 -0
  430. package/dist/prospective-memory-OAFZUODU.js +232 -0
  431. package/dist/reranker-AFU75HEX.js +19 -0
  432. package/dist/reranker-RYNSJNDF.js +19 -0
  433. package/dist/reranker-YQIRNGDM.js +19 -0
  434. package/dist/retrieval-health-M5BVB7EV.js +12 -0
  435. package/dist/retrieval-health-RSQEIYIB.js +12 -0
  436. package/dist/review-polling-LGX7DUNT.js +126 -0
  437. package/dist/review-polling-MJBCYV4I.js +126 -0
  438. package/dist/review-polling-ZMB3OBPC.js +126 -0
  439. package/dist/runtime/index.js +16 -16
  440. package/dist/services/codex-reviewd/index.js +855 -0
  441. package/dist/session-events-5N47BRFK.js +38 -0
  442. package/dist/session-events-PT6SVS2P.js +38 -0
  443. package/dist/session-events-UTMCKDIN.js +38 -0
  444. package/dist/session-kill-telemetry-FRQA5MVD.js +31 -0
  445. package/dist/session-kill-telemetry-HKL2NQMR.js +31 -0
  446. package/dist/session-scope-2BD6QLNI.js +88 -0
  447. package/dist/session-scope-GQNCM6UQ.js +88 -0
  448. package/dist/session-scope-MMGM232A.js +88 -0
  449. package/dist/setup-wizard-SELXXVLD.js +12 -0
  450. package/dist/setup-wizard-W64I6SHC.js +12 -0
  451. package/dist/setup-wizard-X7YSRDNQ.js +12 -0
  452. package/dist/skill-refinement-CCP4ULZ3.js +159 -0
  453. package/dist/skill-refinement-FXCXTUS2.js +159 -0
  454. package/dist/skill-refinement-WCPDNHZ5.js +159 -0
  455. package/dist/stack-update-5VSGG36W.js +84 -0
  456. package/dist/steward-gate-JDR3SLH3.js +15 -0
  457. package/dist/steward-gate-PIXNK4BK.js +15 -0
  458. package/dist/task-enforcement-LEBWCYZT.js +506 -0
  459. package/dist/task-enforcement-VOSQRAQB.js +506 -0
  460. package/dist/task-enforcement-WCEA4FZI.js +506 -0
  461. package/dist/task-scope-CQZ33PRU.js +37 -0
  462. package/dist/task-scope-JTTEZKDU.js +37 -0
  463. package/dist/task-scope-L5GDL2AV.js +37 -0
  464. package/dist/tasks-crud-DC4GCXQQ.js +79 -0
  465. package/dist/tasks-crud-S36AFYYM.js +79 -0
  466. package/dist/tasks-crud-T32IRPXF.js +79 -0
  467. package/dist/tasks-notify-OBFVHJDP.js +40 -0
  468. package/dist/tasks-notify-OUQWUM6W.js +40 -0
  469. package/dist/tasks-notify-W2W2BJRB.js +40 -0
  470. package/dist/tasks-review-34WV7BX2.js +49 -0
  471. package/dist/tasks-review-N33MTHWJ.js +49 -0
  472. package/dist/tasks-review-OSBG2YN2.js +49 -0
  473. package/dist/telemetry-upload-3CSVO3J7.js +741 -0
  474. package/dist/telemetry-upload-EYHEWTKG.js +741 -0
  475. package/dist/telemetry-upload-XLBW4DRP.js +741 -0
  476. package/dist/token-budget-I6FMMDFX.js +86 -0
  477. package/dist/token-budget-ZG2MQ5GD.js +86 -0
  478. package/dist/tool-capability-index-IWQBQKM7.js +10 -0
  479. package/dist/tool-telemetry-2E3Z7CRV.js +17 -0
  480. package/dist/tool-telemetry-ODL4F2CW.js +17 -0
  481. package/dist/tui/App.js +17 -17
  482. package/dist/tui-data-VWT4Q5UT.js +260 -0
  483. package/dist/tui-data-XFBFBSBE.js +260 -0
  484. package/dist/tui-data-Z5UF7KEI.js +260 -0
  485. package/dist/wiki-acl-EUOPNUIQ.js +111 -0
  486. package/dist/wiki-acl-SZFHCEC4.js +111 -0
  487. package/dist/worker-gate-OOO6BWZ6.js +21 -0
  488. package/dist/worker-gate-OQMKAMP7.js +21 -0
  489. package/dist/worker-gate-ZPP3SZK6.js +21 -0
  490. package/dist/workflow-engine-P7WYJP2B.js +28 -0
  491. package/dist/workflow-engine-QY3IFFR2.js +28 -0
  492. package/dist/workflow-engine-UYNB5RTB.js +28 -0
  493. package/dist/worktree-CNOQZBNT.js +28 -0
  494. package/dist/worktree-H5C4LMQR.js +28 -0
  495. package/dist/worktree-sweep-KFWF3XZD.js +21 -0
  496. package/dist/worktree-sweep-SE7ITXC4.js +21 -0
  497. package/package.json +1 -1
  498. package/release-notes.json +117 -191
  499. package/src/commands/exe.md +18 -1
@@ -0,0 +1,731 @@
1
+ import {
2
+ MultiAgentOrchestrator
3
+ } from "./chunk-T7PTLVJV.js";
4
+ import {
5
+ createQuietRenderer,
6
+ createTerminalRenderer,
7
+ renderAgentEvents
8
+ } from "./chunk-YZFZDJWZ.js";
9
+ import {
10
+ checkDangerousPatterns,
11
+ hasCriticalPattern
12
+ } from "./chunk-CMCYL2JC.js";
13
+ import {
14
+ checkPathSafety,
15
+ checkReadPathSafety,
16
+ containsPathTraversal
17
+ } from "./chunk-NGVOA6ZQ.js";
18
+ import {
19
+ ContextManager,
20
+ agentLoop,
21
+ compactMessages,
22
+ createContextManager,
23
+ createDenialTrackingState,
24
+ estimateTokens,
25
+ getContextLimit,
26
+ needsCompaction,
27
+ recordDenial,
28
+ recordSuccess,
29
+ shouldFallbackToAsk
30
+ } from "./chunk-UAMWGUBX.js";
31
+ import {
32
+ ToolRegistry,
33
+ partitionTools,
34
+ zodToJsonSchema
35
+ } from "./chunk-JRLNE3T2.js";
36
+ import {
37
+ EMPLOYEE_PERMISSIONS,
38
+ checkPermission,
39
+ createPermissionsFromPreset,
40
+ createRestrictedPermissions
41
+ } from "./chunk-2O2UKMUE.js";
42
+ import {
43
+ PERMISSION_PRESETS,
44
+ evaluatePermission,
45
+ getPresetByRole,
46
+ matchInputPattern,
47
+ matchToolPattern
48
+ } from "./chunk-HF25XPZE.js";
49
+ import {
50
+ composeHooks,
51
+ createDefaultHooks
52
+ } from "./chunk-O377P7GM.js";
53
+ import {
54
+ StateBus,
55
+ orgBus
56
+ } from "./chunk-MP2AFCGL.js";
57
+ import {
58
+ __export
59
+ } from "./chunk-MLKGABMK.js";
60
+
61
+ // src/runtime/index.ts
62
+ var runtime_exports = {};
63
+ __export(runtime_exports, {
64
+ ContextManager: () => ContextManager,
65
+ EMPLOYEE_PERMISSIONS: () => EMPLOYEE_PERMISSIONS,
66
+ IPCServer: () => IPCServer,
67
+ MultiAgentOrchestrator: () => MultiAgentOrchestrator,
68
+ PERMISSION_PRESETS: () => PERMISSION_PRESETS,
69
+ SessionManager: () => SessionManager,
70
+ StateBus: () => StateBus,
71
+ ToolRegistry: () => ToolRegistry,
72
+ agentLoop: () => agentLoop,
73
+ checkDangerousPatterns: () => checkDangerousPatterns,
74
+ checkGitSafety: () => checkGitSafety,
75
+ checkPathSafety: () => checkPathSafety,
76
+ checkPermission: () => checkPermission,
77
+ checkReadPathSafety: () => checkReadPathSafety,
78
+ compactMessages: () => compactMessages,
79
+ composeHooks: () => composeHooks,
80
+ containsPathTraversal: () => containsPathTraversal,
81
+ createContextManager: () => createContextManager,
82
+ createDefaultHooks: () => createDefaultHooks,
83
+ createDenialTrackingState: () => createDenialTrackingState,
84
+ createPermissionsFromPreset: () => createPermissionsFromPreset,
85
+ createQuietRenderer: () => createQuietRenderer,
86
+ createRestrictedPermissions: () => createRestrictedPermissions,
87
+ createTerminalRenderer: () => createTerminalRenderer,
88
+ estimateTokens: () => estimateTokens,
89
+ evaluatePermission: () => evaluatePermission,
90
+ getContextLimit: () => getContextLimit,
91
+ getPresetByRole: () => getPresetByRole,
92
+ hasCriticalPattern: () => hasCriticalPattern,
93
+ matchInputPattern: () => matchInputPattern,
94
+ matchToolPattern: () => matchToolPattern,
95
+ needsCompaction: () => needsCompaction,
96
+ orgBus: () => orgBus,
97
+ partitionTools: () => partitionTools,
98
+ recordDenial: () => recordDenial,
99
+ recordSuccess: () => recordSuccess,
100
+ renderAgentEvents: () => renderAgentEvents,
101
+ shouldFallbackToAsk: () => shouldFallbackToAsk,
102
+ targetsMainBranch: () => targetsMainBranch,
103
+ zodToJsonSchema: () => zodToJsonSchema
104
+ });
105
+
106
+ // src/runtime/git-safety.ts
107
+ var GIT_DANGEROUS_PATTERNS = [
108
+ // Force push to main/master — critical (must be before general force push)
109
+ {
110
+ regex: /\bgit\s+push\s+.*(?:--force(?:-with-lease)?|-f)\b.*\b(main|master)\b/,
111
+ severity: "critical",
112
+ reason: "Force push to main/master \u2014 this can destroy shared history"
113
+ },
114
+ // Force push (any branch)
115
+ {
116
+ regex: /\bgit\s+push\s+.*--force(?:-with-lease)?\b/,
117
+ severity: "warning",
118
+ reason: "Force push can overwrite remote history"
119
+ },
120
+ {
121
+ regex: /\bgit\s+push\s+-f\b/,
122
+ severity: "warning",
123
+ reason: "Force push (-f) can overwrite remote history"
124
+ },
125
+ // Hard reset
126
+ {
127
+ regex: /\bgit\s+reset\s+--hard\b/,
128
+ severity: "warning",
129
+ reason: "Hard reset discards all uncommitted changes permanently"
130
+ },
131
+ // Clean with force
132
+ {
133
+ regex: /\bgit\s+clean\s+(?:-[a-zA-Z]*f|.*--force\b)/,
134
+ severity: "warning",
135
+ reason: "Git clean -f permanently removes untracked files"
136
+ },
137
+ // Delete branch with force
138
+ {
139
+ regex: /\bgit\s+branch\s+-D\b/,
140
+ severity: "warning",
141
+ reason: "Force delete branch (uppercase -D) skips merge check"
142
+ },
143
+ // Checkout . (discard all changes)
144
+ {
145
+ regex: /\bgit\s+checkout\s+\.\s*$/,
146
+ severity: "warning",
147
+ reason: "Discards all uncommitted changes in working directory"
148
+ },
149
+ // Restore . (discard all changes)
150
+ {
151
+ regex: /\bgit\s+restore\s+\.\s*$/,
152
+ severity: "warning",
153
+ reason: "Restores all files, discarding uncommitted changes"
154
+ },
155
+ // No-verify (skip hooks)
156
+ {
157
+ regex: /\bgit\s+(commit|push)\s+.*--no-verify\b/,
158
+ severity: "warning",
159
+ reason: "Skipping git hooks (--no-verify) bypasses safety checks"
160
+ },
161
+ // Rebase with drop
162
+ {
163
+ regex: /\bgit\s+rebase\s+-i\b/,
164
+ severity: "warning",
165
+ reason: "Interactive rebase can rewrite commit history"
166
+ },
167
+ // Amend published commits
168
+ {
169
+ regex: /\bgit\s+commit\s+.*--amend\b/,
170
+ severity: "warning",
171
+ reason: "Amending commits rewrites history \u2014 dangerous if already pushed"
172
+ }
173
+ ];
174
+ function checkGitSafety(command) {
175
+ for (const pattern of GIT_DANGEROUS_PATTERNS) {
176
+ if (pattern.regex.test(command)) {
177
+ return {
178
+ safe: false,
179
+ severity: pattern.severity,
180
+ reason: pattern.reason
181
+ };
182
+ }
183
+ }
184
+ return { safe: true, severity: "info" };
185
+ }
186
+ function targetsMainBranch(command) {
187
+ return /\b(main|master)\b/.test(command) && /\bgit\s+(push|rebase|reset)\b/.test(command);
188
+ }
189
+
190
+ // src/runtime/session-manager.ts
191
+ import { randomUUID as randomUUID2 } from "crypto";
192
+
193
+ // src/runtime/exe-hooks.ts
194
+ import { randomUUID } from "crypto";
195
+ function createExeOSHooks(config) {
196
+ let sessionRegistered = false;
197
+ return {
198
+ async onSessionStart(context) {
199
+ try {
200
+ const { initStore } = await import("./lib/store.js");
201
+ await initStore();
202
+ } catch (err) {
203
+ process.stderr.write(
204
+ `[exe-hooks] store init failed: ${err instanceof Error ? err.message : String(err)}
205
+ `
206
+ );
207
+ }
208
+ try {
209
+ const { listBehaviors } = await import("./behaviors-WO67R6C4.js");
210
+ const behaviors = await listBehaviors(config.agentId, config.projectName, 12);
211
+ if (behaviors.length > 0) {
212
+ process.stderr.write(
213
+ `[exe-hooks] Loaded ${behaviors.length} behaviors for ${config.agentId}
214
+ `
215
+ );
216
+ }
217
+ } catch (err) {
218
+ process.stderr.write(
219
+ `[exe-hooks] behavior load failed: ${err instanceof Error ? err.message : String(err)}
220
+ `
221
+ );
222
+ }
223
+ try {
224
+ const { registerSession } = await import("./lib/session-registry.js");
225
+ registerSession({
226
+ windowName: `api-${config.agentId}-${Date.now()}`,
227
+ agentId: config.agentId,
228
+ projectDir: context.cwd,
229
+ parentExe: null,
230
+ pid: process.pid,
231
+ registeredAt: context.startedAt
232
+ });
233
+ sessionRegistered = true;
234
+ } catch (err) {
235
+ process.stderr.write(
236
+ `[exe-hooks] session register failed: ${err instanceof Error ? err.message : String(err)}
237
+ `
238
+ );
239
+ }
240
+ },
241
+ async afterToolUse(block, result, _context) {
242
+ if (block.type !== "tool_use") return;
243
+ const toolName = block.name ?? "unknown";
244
+ const ALLOWED_RE = /^(Bash|Edit|Write|Read|Glob|Grep|Agent|mcp__.*)$/;
245
+ if (!ALLOWED_RE.test(toolName)) return;
246
+ try {
247
+ const { extractSemanticText } = await import("./content-extractor-EYRVGD6O.js");
248
+ const { writeMemory } = await import("./lib/store.js");
249
+ const toolInput = block.input ?? {};
250
+ const toolResponse = result.isError ? { error: result.content } : { output: result.content };
251
+ const rawText = extractSemanticText(toolName, toolInput, toolResponse);
252
+ await writeMemory({
253
+ id: randomUUID(),
254
+ agent_id: config.agentId,
255
+ agent_role: "employee",
256
+ session_id: `api-${config.agentId}`,
257
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
258
+ tool_name: toolName,
259
+ project_name: config.projectName,
260
+ has_error: result.isError ?? false,
261
+ raw_text: rawText,
262
+ vector: null
263
+ });
264
+ } catch (err) {
265
+ process.stderr.write(
266
+ `[exe-hooks] memory ingest failed for ${toolName}: ${err instanceof Error ? err.message : String(err)}
267
+ `
268
+ );
269
+ }
270
+ },
271
+ async onSessionEnd(_context, summary) {
272
+ try {
273
+ const { writeMemory } = await import("./lib/store.js");
274
+ await writeMemory({
275
+ id: randomUUID(),
276
+ agent_id: config.agentId,
277
+ agent_role: "employee",
278
+ session_id: `api-${config.agentId}`,
279
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
280
+ tool_name: "SessionEnd",
281
+ project_name: config.projectName,
282
+ has_error: false,
283
+ raw_text: [
284
+ "CONTEXT CHECKPOINT [auto:session-end]",
285
+ `Agent: ${config.agentId}`,
286
+ `Project: ${config.projectName}`,
287
+ `Time: ${(/* @__PURE__ */ new Date()).toISOString()}`,
288
+ "",
289
+ "## Runtime Summary",
290
+ summary || "Session ended. No runtime summary was provided."
291
+ ].join("\n"),
292
+ vector: null,
293
+ importance: 8,
294
+ memory_type: "checkpoint"
295
+ });
296
+ } catch (err) {
297
+ process.stderr.write(
298
+ `[exe-hooks] session summary store failed: ${err instanceof Error ? err.message : String(err)}
299
+ `
300
+ );
301
+ }
302
+ if (sessionRegistered) {
303
+ try {
304
+ const { pruneStaleSessions } = await import("./lib/session-registry.js");
305
+ pruneStaleSessions();
306
+ } catch {
307
+ }
308
+ }
309
+ },
310
+ async onError(error, _context) {
311
+ try {
312
+ const { classifyError } = await import("./lib/error-detector.js");
313
+ const classification = classifyError(error.message);
314
+ process.stderr.write(
315
+ `[exe-hooks] Error (${classification}): ${error.message.slice(0, 100)}
316
+ `
317
+ );
318
+ } catch {
319
+ }
320
+ },
321
+ async onPostCompact(removedMessages, _injectedSummary) {
322
+ process.stderr.write(
323
+ `[exe-hooks] Post-compact: ${removedMessages} messages removed for ${config.agentId}
324
+ `
325
+ );
326
+ },
327
+ async onSubagentStop(_reason) {
328
+ try {
329
+ const { getClient } = await import("./lib/database.js");
330
+ const { sessionScopeFilter } = await import("./task-scope-CQZ33PRU.js");
331
+ const client = getClient();
332
+ const ehScope = sessionScopeFilter();
333
+ const tasks = await client.execute({
334
+ sql: `SELECT title, status FROM tasks
335
+ WHERE assigned_to = ? AND status IN ('open', 'in_progress')${ehScope.sql}
336
+ LIMIT 5`,
337
+ args: [config.agentId, ...ehScope.args]
338
+ });
339
+ if (tasks.rows.length > 0) {
340
+ const titles = tasks.rows.map((r) => `"${String(r.title)}" (${String(r.status)})`).join(", ");
341
+ return {
342
+ block: true,
343
+ message: `Cannot stop: ${tasks.rows.length} uncompleted task(s): ${titles}. Complete or mark blocked first.`
344
+ };
345
+ }
346
+ } catch {
347
+ }
348
+ return { block: false };
349
+ },
350
+ async onNotification(message) {
351
+ try {
352
+ const { getClient } = await import("./lib/database.js");
353
+ const client = getClient();
354
+ await client.execute({
355
+ sql: `INSERT OR IGNORE INTO notifications (id, type, source_agent, message, task_file, created_at, read)
356
+ VALUES (?, 'system', ?, ?, NULL, ?, 0)`,
357
+ args: [randomUUID(), config.agentId, message.slice(0, 500), (/* @__PURE__ */ new Date()).toISOString()]
358
+ });
359
+ } catch {
360
+ }
361
+ },
362
+ async onPermissionRequest(toolName) {
363
+ const readOnlyTools = /^(Read|Glob|Grep)$/;
364
+ if (readOnlyTools.test(toolName)) {
365
+ return { autoApprove: true };
366
+ }
367
+ return { autoApprove: false };
368
+ },
369
+ async onTaskAssigned(event) {
370
+ try {
371
+ const { writeMemory } = await import("./lib/store.js");
372
+ await writeMemory({
373
+ id: randomUUID(),
374
+ agent_id: config.agentId,
375
+ agent_role: "employee",
376
+ session_id: `api-${config.agentId}`,
377
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
378
+ tool_name: "TaskAssigned",
379
+ project_name: event.projectName,
380
+ has_error: false,
381
+ raw_text: `Task assigned: "${event.title}" [${event.priority}] by ${event.assignedBy}`,
382
+ vector: null
383
+ });
384
+ } catch (err) {
385
+ process.stderr.write(
386
+ `[exe-hooks] task-assigned memory failed: ${err instanceof Error ? err.message : String(err)}
387
+ `
388
+ );
389
+ }
390
+ },
391
+ async onReviewReceived(event) {
392
+ try {
393
+ const { writeMemory } = await import("./lib/store.js");
394
+ await writeMemory({
395
+ id: randomUUID(),
396
+ agent_id: config.agentId,
397
+ agent_role: "employee",
398
+ session_id: `api-${config.agentId}`,
399
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
400
+ tool_name: "ReviewReceived",
401
+ project_name: config.projectName,
402
+ has_error: false,
403
+ raw_text: `Review received for "${event.taskTitle}" from ${event.reviewer}: ${event.result}`,
404
+ vector: null
405
+ });
406
+ } catch (err) {
407
+ process.stderr.write(
408
+ `[exe-hooks] review-received memory failed: ${err instanceof Error ? err.message : String(err)}
409
+ `
410
+ );
411
+ }
412
+ },
413
+ async onContextPressure(event) {
414
+ process.stderr.write(
415
+ `[exe-hooks] Context pressure: ${event.percentUsed}% (${event.threshold}% threshold) for ${config.agentId}
416
+ `
417
+ );
418
+ if (event.threshold >= 90) {
419
+ try {
420
+ const { writeMemory, flushBatch } = await import("./lib/store.js");
421
+ const { getClient } = await import("./lib/database.js");
422
+ const { sessionScopeFilter: cpScopeFilter } = await import("./task-scope-CQZ33PRU.js");
423
+ const client = getClient();
424
+ const cpScope = cpScopeFilter();
425
+ const tasks = await client.execute({
426
+ sql: `SELECT title, status, task_file FROM tasks
427
+ WHERE assigned_to = ? AND status IN ('open', 'in_progress')${cpScope.sql}
428
+ ORDER BY priority ASC LIMIT 10`,
429
+ args: [config.agentId, ...cpScope.args]
430
+ });
431
+ if (tasks.rows.length > 0) {
432
+ const taskList = tasks.rows.map((r) => `- [${String(r.status)}] ${String(r.title)} (${String(r.task_file)})`).join("\n");
433
+ await writeMemory({
434
+ id: randomUUID(),
435
+ agent_id: config.agentId,
436
+ agent_role: "employee",
437
+ session_id: `api-${config.agentId}`,
438
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
439
+ tool_name: "auto-checkpoint",
440
+ project_name: config.projectName,
441
+ has_error: false,
442
+ raw_text: `CONTEXT CHECKPOINT [${event.percentUsed}% pressure]: Open tasks:
443
+ ${taskList}`,
444
+ vector: null
445
+ });
446
+ await flushBatch();
447
+ }
448
+ } catch {
449
+ }
450
+ }
451
+ },
452
+ async onCrossAgentMessage(event) {
453
+ process.stderr.write(
454
+ `[exe-hooks] Message from ${event.fromAgent}: ${event.message.slice(0, 100)}
455
+ `
456
+ );
457
+ try {
458
+ const { writeMemory } = await import("./lib/store.js");
459
+ await writeMemory({
460
+ id: randomUUID(),
461
+ agent_id: config.agentId,
462
+ agent_role: "employee",
463
+ session_id: `api-${config.agentId}`,
464
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
465
+ tool_name: "CrossAgentMessage",
466
+ project_name: config.projectName,
467
+ has_error: false,
468
+ raw_text: `Message from ${event.fromAgent}: ${event.message}`,
469
+ vector: null
470
+ });
471
+ } catch (err) {
472
+ process.stderr.write(
473
+ `[exe-hooks] cross-agent memory failed: ${err instanceof Error ? err.message : String(err)}
474
+ `
475
+ );
476
+ }
477
+ }
478
+ };
479
+ }
480
+
481
+ // src/runtime/session-manager.ts
482
+ var SessionManager = class {
483
+ sessions = /* @__PURE__ */ new Map();
484
+ eventHandlers = /* @__PURE__ */ new Set();
485
+ /** Start a new agent session for an employee */
486
+ startSession(employeeId, config) {
487
+ const sessionId = randomUUID2();
488
+ const abortController = new AbortController();
489
+ const session = {
490
+ info: {
491
+ sessionId,
492
+ employeeId,
493
+ model: config.model,
494
+ provider: config.provider.name,
495
+ startedAt: (/* @__PURE__ */ new Date()).toISOString(),
496
+ status: "active",
497
+ messageCount: 0
498
+ },
499
+ config: { ...config, abortController },
500
+ history: [],
501
+ abortController,
502
+ processing: false
503
+ };
504
+ this.sessions.set(sessionId, session);
505
+ orgBus.emit({
506
+ type: "session_started",
507
+ sessionId,
508
+ employee: employeeId,
509
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
510
+ });
511
+ return sessionId;
512
+ }
513
+ /** Stop a session */
514
+ stopSession(sessionId) {
515
+ const session = this.sessions.get(sessionId);
516
+ if (!session) return;
517
+ session.abortController.abort();
518
+ session.info.status = "stopped";
519
+ orgBus.emit({
520
+ type: "session_ended",
521
+ sessionId,
522
+ employee: session.info.employeeId,
523
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
524
+ });
525
+ }
526
+ /** Send a message to an active session */
527
+ async sendMessage(sessionId, text) {
528
+ const session = this.sessions.get(sessionId);
529
+ if (!session || session.info.status !== "active") return;
530
+ if (session.processing) return;
531
+ session.processing = true;
532
+ session.info.messageCount++;
533
+ orgBus.emit({
534
+ type: "employee_status",
535
+ employee: session.info.employeeId,
536
+ status: "working",
537
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
538
+ });
539
+ try {
540
+ const events = agentLoop(text, session.history, session.config);
541
+ for await (const event of events) {
542
+ for (const handler of this.eventHandlers) {
543
+ try {
544
+ handler(sessionId, event);
545
+ } catch {
546
+ }
547
+ }
548
+ if (event.type === "text") {
549
+ }
550
+ }
551
+ } catch (err) {
552
+ for (const handler of this.eventHandlers) {
553
+ try {
554
+ handler(sessionId, {
555
+ type: "error",
556
+ error: err instanceof Error ? err : new Error(String(err))
557
+ });
558
+ } catch {
559
+ }
560
+ }
561
+ } finally {
562
+ session.processing = false;
563
+ orgBus.emit({
564
+ type: "employee_status",
565
+ employee: session.info.employeeId,
566
+ status: "idle",
567
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
568
+ });
569
+ }
570
+ session.history.push({ role: "user", content: text });
571
+ }
572
+ /** Get all active sessions */
573
+ getActiveSessions() {
574
+ return [...this.sessions.values()].filter((s) => s.info.status === "active").map((s) => ({ ...s.info }));
575
+ }
576
+ /** Get all sessions (including stopped) */
577
+ getAllSessions() {
578
+ return [...this.sessions.values()].map((s) => ({ ...s.info }));
579
+ }
580
+ /** Get a specific session */
581
+ getSession(sessionId) {
582
+ return this.sessions.get(sessionId)?.info;
583
+ }
584
+ /** Subscribe to events from all sessions */
585
+ onEvent(handler) {
586
+ this.eventHandlers.add(handler);
587
+ }
588
+ /** Unsubscribe */
589
+ offEvent(handler) {
590
+ this.eventHandlers.delete(handler);
591
+ }
592
+ /** Start a session with ExeOS hooks wired in */
593
+ startExeOSSession(employeeId, config, hookConfig) {
594
+ const exeHooks = createExeOSHooks(hookConfig);
595
+ const composedConfig = {
596
+ ...config,
597
+ hooks: composeHooks(exeHooks, config.hooks)
598
+ };
599
+ return this.startSession(employeeId, composedConfig);
600
+ }
601
+ /** Stop all sessions */
602
+ stopAll() {
603
+ for (const sessionId of this.sessions.keys()) {
604
+ this.stopSession(sessionId);
605
+ }
606
+ }
607
+ };
608
+
609
+ // src/runtime/ipc.ts
610
+ import { createServer } from "http";
611
+ import { WebSocketServer, WebSocket } from "ws";
612
+ var PERMISSION_TIMEOUT_MS = 6e4;
613
+ var IPCServer = class {
614
+ httpServer = null;
615
+ wss = null;
616
+ clients = /* @__PURE__ */ new Set();
617
+ commandHandler = null;
618
+ pendingPermissions = /* @__PURE__ */ new Map();
619
+ /** Start the WebSocket server */
620
+ async start(port) {
621
+ return new Promise((resolve, reject) => {
622
+ this.httpServer = createServer();
623
+ this.wss = new WebSocketServer({ server: this.httpServer });
624
+ this.wss.on("connection", (ws) => {
625
+ this.clients.add(ws);
626
+ ws.on("close", () => this.clients.delete(ws));
627
+ ws.on("message", (data) => {
628
+ try {
629
+ const cmd = JSON.parse(data.toString());
630
+ if (cmd.type === "permission_response") {
631
+ this.resolvePermission(cmd.toolCallId, cmd.decision);
632
+ return;
633
+ }
634
+ if (this.commandHandler) {
635
+ this.commandHandler(cmd, (resp) => {
636
+ if (ws.readyState === WebSocket.OPEN) {
637
+ ws.send(JSON.stringify(resp));
638
+ }
639
+ });
640
+ }
641
+ } catch {
642
+ if (ws.readyState === WebSocket.OPEN) {
643
+ ws.send(JSON.stringify({ type: "error", message: "Invalid command" }));
644
+ }
645
+ }
646
+ });
647
+ });
648
+ this.httpServer.listen(port, () => {
649
+ resolve();
650
+ });
651
+ this.httpServer.on("error", reject);
652
+ });
653
+ }
654
+ /** Stop the server */
655
+ async stop() {
656
+ for (const [, pending] of this.pendingPermissions) {
657
+ clearTimeout(pending.timer);
658
+ pending.resolve("deny");
659
+ }
660
+ this.pendingPermissions.clear();
661
+ for (const client of this.clients) {
662
+ client.close();
663
+ }
664
+ this.clients.clear();
665
+ if (this.wss) {
666
+ this.wss.close();
667
+ this.wss = null;
668
+ }
669
+ if (this.httpServer) {
670
+ await new Promise((resolve) => {
671
+ this.httpServer.close(() => resolve());
672
+ });
673
+ this.httpServer = null;
674
+ }
675
+ }
676
+ /** Broadcast an agent event to all connected clients */
677
+ broadcastEvent(sessionId, event) {
678
+ const message = JSON.stringify({ type: "event", sessionId, event });
679
+ for (const client of this.clients) {
680
+ if (client.readyState === WebSocket.OPEN) {
681
+ client.send(message);
682
+ }
683
+ }
684
+ }
685
+ /** Register a command handler */
686
+ onCommand(handler) {
687
+ this.commandHandler = handler;
688
+ }
689
+ /**
690
+ * Request permission from a connected client.
691
+ * Broadcasts a permission_request event and waits for a permission_response command.
692
+ * Auto-denies after 60s timeout if no response is received.
693
+ */
694
+ requestPermission(sessionId, req) {
695
+ return new Promise((resolve) => {
696
+ const timer = setTimeout(() => {
697
+ this.pendingPermissions.delete(req.id);
698
+ resolve("deny");
699
+ }, PERMISSION_TIMEOUT_MS);
700
+ this.pendingPermissions.set(req.id, { resolve, timer });
701
+ this.broadcastEvent(sessionId, {
702
+ type: "permission_request",
703
+ name: req.name,
704
+ id: req.id,
705
+ description: req.description,
706
+ filePath: req.filePath
707
+ });
708
+ });
709
+ }
710
+ /** Resolve a pending permission request with the user's decision */
711
+ resolvePermission(toolCallId, decision) {
712
+ const pending = this.pendingPermissions.get(toolCallId);
713
+ if (pending) {
714
+ clearTimeout(pending.timer);
715
+ this.pendingPermissions.delete(toolCallId);
716
+ pending.resolve(decision);
717
+ }
718
+ }
719
+ /** Get connected client count */
720
+ get clientCount() {
721
+ return this.clients.size;
722
+ }
723
+ };
724
+
725
+ export {
726
+ checkGitSafety,
727
+ targetsMainBranch,
728
+ SessionManager,
729
+ IPCServer,
730
+ runtime_exports
731
+ };