@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,167 @@
1
+ import {
2
+ EXE_AI_DIR
3
+ } from "./chunk-R36FAN53.js";
4
+
5
+ // src/lib/worker-gate.ts
6
+ import { readdirSync, writeFileSync, unlinkSync, mkdirSync, existsSync, readFileSync } from "fs";
7
+ import path from "path";
8
+ import { totalmem, cpus } from "os";
9
+ var WORKER_PID_DIR = path.join(EXE_AI_DIR, "worker-pids");
10
+ function computeMaxWorkers() {
11
+ const totalGB = totalmem() / 1024 ** 3;
12
+ const coreCount = cpus().length;
13
+ const byRam = Math.floor(totalGB / 4);
14
+ const byCpu = Math.floor(coreCount / 2);
15
+ return Math.max(2, Math.min(8, Math.min(byRam, byCpu)));
16
+ }
17
+ var MAX_CONCURRENT_WORKERS = process.env.EXE_MAX_WORKERS ? Math.max(1, parseInt(process.env.EXE_MAX_WORKERS, 10) || 3) : computeMaxWorkers();
18
+ function tryAcquireWorkerSlot() {
19
+ try {
20
+ mkdirSync(WORKER_PID_DIR, { recursive: true });
21
+ const reservationId = `res-${process.pid}-${Date.now()}`;
22
+ const reservationPath = path.join(WORKER_PID_DIR, `${reservationId}.pid`);
23
+ writeFileSync(reservationPath, String(process.pid));
24
+ const files = readdirSync(WORKER_PID_DIR);
25
+ let alive = 0;
26
+ for (const f of files) {
27
+ if (!f.endsWith(".pid")) continue;
28
+ if (f.startsWith("res-")) {
29
+ const resParts = f.replace(".pid", "").split("-");
30
+ const resPid = parseInt(resParts[1] ?? "", 10);
31
+ if (!isNaN(resPid) && resPid > 0) {
32
+ try {
33
+ process.kill(resPid, 0);
34
+ alive++;
35
+ } catch {
36
+ try {
37
+ unlinkSync(path.join(WORKER_PID_DIR, f));
38
+ } catch {
39
+ }
40
+ }
41
+ } else {
42
+ alive++;
43
+ }
44
+ continue;
45
+ }
46
+ const dashIdx = f.lastIndexOf("-");
47
+ const pid = parseInt(f.slice(dashIdx + 1).replace(".pid", ""), 10);
48
+ if (isNaN(pid)) continue;
49
+ try {
50
+ process.kill(pid, 0);
51
+ alive++;
52
+ } catch {
53
+ try {
54
+ unlinkSync(path.join(WORKER_PID_DIR, f));
55
+ } catch {
56
+ }
57
+ }
58
+ }
59
+ if (alive >= MAX_CONCURRENT_WORKERS) {
60
+ try {
61
+ unlinkSync(reservationPath);
62
+ } catch {
63
+ }
64
+ return false;
65
+ }
66
+ try {
67
+ unlinkSync(reservationPath);
68
+ } catch {
69
+ }
70
+ return true;
71
+ } catch {
72
+ return true;
73
+ }
74
+ }
75
+ function registerWorkerPid(pid) {
76
+ try {
77
+ mkdirSync(WORKER_PID_DIR, { recursive: true });
78
+ writeFileSync(path.join(WORKER_PID_DIR, `worker-${pid}.pid`), String(pid));
79
+ } catch {
80
+ }
81
+ }
82
+ function cleanupWorkerPid() {
83
+ try {
84
+ unlinkSync(path.join(WORKER_PID_DIR, `worker-${process.pid}.pid`));
85
+ } catch {
86
+ }
87
+ }
88
+ var BACKFILL_LOCK = path.join(WORKER_PID_DIR, "backfill.lock");
89
+ function tryAcquireBackfillLock() {
90
+ try {
91
+ mkdirSync(WORKER_PID_DIR, { recursive: true });
92
+ if (existsSync(BACKFILL_LOCK)) {
93
+ try {
94
+ const pid = parseInt(
95
+ readFileSync(BACKFILL_LOCK, "utf8").trim(),
96
+ 10
97
+ );
98
+ if (!isNaN(pid) && pid > 0) {
99
+ try {
100
+ process.kill(pid, 0);
101
+ return false;
102
+ } catch {
103
+ }
104
+ }
105
+ } catch {
106
+ }
107
+ }
108
+ writeFileSync(BACKFILL_LOCK, String(process.pid));
109
+ return true;
110
+ } catch {
111
+ return true;
112
+ }
113
+ }
114
+ function releaseBackfillLock() {
115
+ try {
116
+ unlinkSync(BACKFILL_LOCK);
117
+ } catch {
118
+ }
119
+ }
120
+ async function getTaskAwareCapacity() {
121
+ const { getClient } = await import("./lib/database.js");
122
+ const { sessionScopeFilter } = await import("./task-scope-CQZ33PRU.js");
123
+ const client = getClient();
124
+ const scope = sessionScopeFilter();
125
+ const result = await client.execute({
126
+ sql: `SELECT assigned_to, COUNT(*) as cnt
127
+ FROM tasks
128
+ WHERE status IN ('open', 'in_progress')${scope.sql}
129
+ GROUP BY assigned_to`,
130
+ args: [...scope.args]
131
+ });
132
+ const busyAgents = [];
133
+ let totalInProgress = 0;
134
+ for (const row of result.rows) {
135
+ const agent = String(row.assigned_to ?? "");
136
+ const count = Number(row.cnt ?? 0);
137
+ if (agent && count > 0) {
138
+ busyAgents.push(agent);
139
+ totalInProgress += count;
140
+ }
141
+ }
142
+ const idleAgents = [];
143
+ try {
144
+ const { listTmuxSessions } = await import("./lib/tmux-status.js");
145
+ const { isExeSession } = await import("./lib/tmux-routing.js");
146
+ const { baseAgentName } = await import("./lib/employees.js");
147
+ const liveSessions = listTmuxSessions().filter((s) => !isExeSession(s) && s.includes("-"));
148
+ const liveAgentNames = new Set(liveSessions.map((s) => baseAgentName(s.split("-")[0] ?? "")));
149
+ for (const name of liveAgentNames) {
150
+ if (name && !busyAgents.includes(name)) {
151
+ idleAgents.push(name);
152
+ }
153
+ }
154
+ } catch {
155
+ }
156
+ return { busyAgents, idleAgents, totalInProgress };
157
+ }
158
+
159
+ export {
160
+ MAX_CONCURRENT_WORKERS,
161
+ tryAcquireWorkerSlot,
162
+ registerWorkerPid,
163
+ cleanupWorkerPid,
164
+ tryAcquireBackfillLock,
165
+ releaseBackfillLock,
166
+ getTaskAwareCapacity
167
+ };
@@ -0,0 +1,43 @@
1
+ // src/lib/daemon-heap.ts
2
+ function computeDaemonHeapCapMb(_totalGb) {
3
+ return 4096;
4
+ }
5
+ var HEAP_FLAG_RE = /^--(max[-_]old[-_]space[-_]size|max[-_]semi[-_]space[-_]size|max[-_]heap[-_]size)(=|$)/i;
6
+ var EMBED_WORKER_DEFAULT_HEAP_MB = 6144;
7
+ var EMBED_WORKER_MIN_HEAP_MB = 3072;
8
+ var EMBED_WORKER_RSS_HEADROOM_MB = 2048;
9
+ var EMBED_WORKER_RSS_KILL_FLOOR_MB = 8192;
10
+ function resolveEmbedWorkerRssKillMb(envValue, heapMb) {
11
+ const heap = Number.isFinite(heapMb) && heapMb > 0 ? heapMb : EMBED_WORKER_DEFAULT_HEAP_MB;
12
+ const safeDefault = Math.max(heap + EMBED_WORKER_RSS_HEADROOM_MB, EMBED_WORKER_RSS_KILL_FLOOR_MB);
13
+ const raw = parseInt(envValue ?? "", 10);
14
+ if (Number.isFinite(raw) && raw > heap + EMBED_WORKER_RSS_HEADROOM_MB) return raw;
15
+ return safeDefault;
16
+ }
17
+ var EMBED_MAX_RESPAWNS = 3;
18
+ var EMBED_BACKOFF_BASE_MS = 1e4;
19
+ var EMBED_BACKOFF_MAX_MS = 6e4;
20
+ function resolveEmbedWorkerHeapMb(envValue) {
21
+ const raw = parseInt(envValue ?? "", 10);
22
+ return Number.isFinite(raw) && raw >= EMBED_WORKER_MIN_HEAP_MB ? raw : EMBED_WORKER_DEFAULT_HEAP_MB;
23
+ }
24
+ function buildEmbedWorkerExecArgv(parentExecArgv, heapMb) {
25
+ return [
26
+ ...parentExecArgv.filter((a) => !HEAP_FLAG_RE.test(a)),
27
+ `--max-old-space-size=${heapMb}`
28
+ ];
29
+ }
30
+ function computeEmbedRespawnDelayMs(respawnCount) {
31
+ if (respawnCount > EMBED_MAX_RESPAWNS) return null;
32
+ return Math.min(EMBED_BACKOFF_BASE_MS * 2 ** (respawnCount - 1), EMBED_BACKOFF_MAX_MS);
33
+ }
34
+
35
+ export {
36
+ computeDaemonHeapCapMb,
37
+ HEAP_FLAG_RE,
38
+ resolveEmbedWorkerRssKillMb,
39
+ EMBED_MAX_RESPAWNS,
40
+ resolveEmbedWorkerHeapMb,
41
+ buildEmbedWorkerExecArgv,
42
+ computeEmbedRespawnDelayMs
43
+ };
@@ -0,0 +1,197 @@
1
+ import {
2
+ initStore
3
+ } from "./chunk-3NYY2NZ3.js";
4
+ import {
5
+ getClient,
6
+ isInitialized
7
+ } from "./chunk-XABJRAUW.js";
8
+
9
+ // src/lib/schedules.ts
10
+ import crypto from "crypto";
11
+ import { execSync } from "child_process";
12
+ var CRON_FIELD = /^[\d*/,\-]+$/;
13
+ function isValidCron(cron) {
14
+ const fields = cron.trim().split(/\s+/);
15
+ if (fields.length !== 5) return false;
16
+ return fields.every((f) => CRON_FIELD.test(f));
17
+ }
18
+ var SAFE_ID = /^[a-zA-Z0-9_\-]+$/;
19
+ function isValidScheduleId(id) {
20
+ return SAFE_ID.test(id) && id.length <= 128;
21
+ }
22
+ async function ensureDb() {
23
+ if (!isInitialized()) {
24
+ await initStore();
25
+ }
26
+ }
27
+ function parseHumanCron(input) {
28
+ const s = input.toLowerCase().trim();
29
+ if (/^[\d*\/,-]+\s+[\d*\/,-]+\s+[\d*\/,-]+\s+[\d*\/,-]+\s+[\d*\/,-]+$/.test(s)) {
30
+ return s;
31
+ }
32
+ const dayMap = {
33
+ sunday: "0",
34
+ sun: "0",
35
+ monday: "1",
36
+ mon: "1",
37
+ tuesday: "2",
38
+ tue: "2",
39
+ wednesday: "3",
40
+ wed: "3",
41
+ thursday: "4",
42
+ thu: "4",
43
+ friday: "5",
44
+ fri: "5",
45
+ saturday: "6",
46
+ sat: "6"
47
+ };
48
+ const everyMatch = s.match(/every\s+(\d+)\s*([mh])/);
49
+ if (everyMatch) {
50
+ const n = everyMatch[1];
51
+ const unit = everyMatch[2];
52
+ if (unit === "m") return `*/${n} * * * *`;
53
+ if (unit === "h") return `0 */${n} * * *`;
54
+ }
55
+ let hour = -1;
56
+ let minute = 0;
57
+ if (/midnight/.test(s)) {
58
+ hour = 0;
59
+ } else if (/noon/.test(s)) {
60
+ hour = 12;
61
+ } else {
62
+ const timeMatch = s.match(/(\d{1,2})(?::(\d{2}))?\s*(am|pm)?/);
63
+ if (timeMatch) {
64
+ hour = parseInt(timeMatch[1], 10);
65
+ minute = timeMatch[2] ? parseInt(timeMatch[2], 10) : 0;
66
+ if (timeMatch[3] === "pm" && hour < 12) hour += 12;
67
+ if (timeMatch[3] === "am" && hour === 12) hour = 0;
68
+ }
69
+ }
70
+ if (hour === -1) hour = 0;
71
+ let dow = "*";
72
+ if (/weekday|weekdays/.test(s)) {
73
+ dow = "1-5";
74
+ } else if (/weekend|weekends/.test(s)) {
75
+ dow = "0,6";
76
+ } else {
77
+ for (const [name, val] of Object.entries(dayMap)) {
78
+ if (s.includes(name)) {
79
+ dow = val;
80
+ break;
81
+ }
82
+ }
83
+ }
84
+ return `${minute} ${hour} * * ${dow}`;
85
+ }
86
+ async function createSchedule(input) {
87
+ if (!isValidCron(input.cron)) {
88
+ throw new Error(`Invalid cron expression: ${input.cron}. Must be 5 fields with only digits, *, /, -, comma.`);
89
+ }
90
+ await ensureDb();
91
+ const client = getClient();
92
+ const id = crypto.randomUUID().slice(0, 8);
93
+ const now = (/* @__PURE__ */ new Date()).toISOString();
94
+ const prompt = input.prompt ?? input.description;
95
+ await client.execute({
96
+ sql: `INSERT INTO schedules (id, cron, description, job_type, prompt, assigned_to, project_name, active, use_crontab, created_at)
97
+ VALUES (?, ?, ?, ?, ?, ?, ?, 1, ?, ?)`,
98
+ args: [
99
+ id,
100
+ input.cron,
101
+ input.description,
102
+ input.jobType ?? "report",
103
+ prompt,
104
+ input.assignedTo ?? null,
105
+ input.projectName ?? null,
106
+ input.useCrontab ? 1 : 0,
107
+ now
108
+ ]
109
+ });
110
+ if (input.useCrontab) {
111
+ addToCrontab(id, input.cron, prompt, input.projectName);
112
+ }
113
+ return {
114
+ id,
115
+ cron: input.cron,
116
+ description: input.description,
117
+ jobType: input.jobType ?? "report",
118
+ prompt,
119
+ assignedTo: input.assignedTo,
120
+ projectName: input.projectName,
121
+ active: true,
122
+ useCrontab: input.useCrontab ?? false,
123
+ createdAt: now
124
+ };
125
+ }
126
+ async function listSchedules(activeOnly = true) {
127
+ await ensureDb();
128
+ const client = getClient();
129
+ const sql = activeOnly ? "SELECT * FROM schedules WHERE active = 1 ORDER BY created_at ASC" : "SELECT * FROM schedules ORDER BY created_at ASC";
130
+ const result = await client.execute({ sql, args: [] });
131
+ return result.rows.map((row) => ({
132
+ id: String(row.id),
133
+ cron: String(row.cron),
134
+ description: String(row.description),
135
+ jobType: String(row.job_type),
136
+ prompt: row.prompt ? String(row.prompt) : void 0,
137
+ assignedTo: row.assigned_to ? String(row.assigned_to) : void 0,
138
+ projectName: row.project_name ? String(row.project_name) : void 0,
139
+ active: Number(row.active) === 1,
140
+ useCrontab: Number(row.use_crontab) === 1,
141
+ createdAt: String(row.created_at)
142
+ }));
143
+ }
144
+ async function deleteSchedule(id) {
145
+ await ensureDb();
146
+ const client = getClient();
147
+ const existing = await client.execute({
148
+ sql: "SELECT use_crontab FROM schedules WHERE id = ?",
149
+ args: [id]
150
+ });
151
+ if (existing.rows.length === 0) return false;
152
+ const usesCrontab = Number(existing.rows[0].use_crontab) === 1;
153
+ await client.execute({
154
+ sql: "DELETE FROM schedules WHERE id = ?",
155
+ args: [id]
156
+ });
157
+ if (usesCrontab) {
158
+ removeFromCrontab(id);
159
+ }
160
+ return true;
161
+ }
162
+ function addToCrontab(id, cron, prompt, projectDir) {
163
+ if (!isValidCron(cron)) {
164
+ throw new Error(`Invalid cron expression: ${cron}`);
165
+ }
166
+ if (!isValidScheduleId(id)) {
167
+ throw new Error(`Invalid schedule ID: ${id}`);
168
+ }
169
+ try {
170
+ const cwd = projectDir ? `cd ${JSON.stringify(projectDir)} && ` : "";
171
+ const escapedPrompt = prompt.replace(/"/g, '\\"');
172
+ const entry = `${cron} ${cwd}claude -p --dangerously-skip-permissions "${escapedPrompt}" # exe-schedule:${id}`;
173
+ execSync(
174
+ `(crontab -l 2>/dev/null; echo ${JSON.stringify(entry)}) | crontab -`,
175
+ { timeout: 5e3, stdio: "ignore" }
176
+ );
177
+ } catch (err) {
178
+ if (err instanceof Error && err.message.startsWith("Invalid")) throw err;
179
+ }
180
+ }
181
+ function removeFromCrontab(id) {
182
+ if (!isValidScheduleId(id)) return;
183
+ try {
184
+ execSync(
185
+ `crontab -l 2>/dev/null | grep -v "exe-schedule:${id}" | crontab -`,
186
+ { timeout: 5e3, stdio: "ignore" }
187
+ );
188
+ } catch {
189
+ }
190
+ }
191
+
192
+ export {
193
+ parseHumanCron,
194
+ createSchedule,
195
+ listSchedules,
196
+ deleteSchedule
197
+ };
@@ -0,0 +1,240 @@
1
+ import {
2
+ getClient,
3
+ isCoordinatorName,
4
+ loadEmployeesSync
5
+ } from "./chunk-XABJRAUW.js";
6
+
7
+ // src/lib/steward-gate.ts
8
+ import crypto from "crypto";
9
+ var ROLE_PERMISSIONS = {
10
+ coordinator: /* @__PURE__ */ new Set([
11
+ "close_task",
12
+ "cancel_task",
13
+ "merge_entities",
14
+ "purge_document",
15
+ "deactivate_behavior",
16
+ "override"
17
+ ]),
18
+ manager: /* @__PURE__ */ new Set([
19
+ "close_task",
20
+ // their team only — enforced contextually
21
+ "deactivate_behavior"
22
+ // their team's behaviors
23
+ ]),
24
+ specialist: /* @__PURE__ */ new Set([
25
+ "deactivate_behavior_own",
26
+ // own behaviors only
27
+ "delete_own_memory"
28
+ ])
29
+ };
30
+ var UNIVERSAL_OPS = /* @__PURE__ */ new Set([
31
+ "update_own_task",
32
+ "store_memory",
33
+ "store_behavior"
34
+ ]);
35
+ var MANAGER_ROLES = /* @__PURE__ */ new Set(["CTO", "CMO"]);
36
+ var StewardGate = class {
37
+ /**
38
+ * Check whether an agent has authority for a destructive operation.
39
+ */
40
+ async checkAuthority(agent, operation, target) {
41
+ const role = await this.resolveRole(agent);
42
+ if (UNIVERSAL_OPS.has(operation)) {
43
+ const decision2 = {
44
+ allowed: true,
45
+ reason: `Operation "${operation}" is universally permitted.`,
46
+ confidence: 1,
47
+ requires_override: false
48
+ };
49
+ await this.logDecision(agent, operation, target, decision2);
50
+ return decision2;
51
+ }
52
+ const permissions = ROLE_PERMISSIONS[role];
53
+ let allowed = permissions.has(operation);
54
+ let reason;
55
+ if (!allowed && role === "specialist" && operation === "deactivate_behavior") {
56
+ const isOwn = await this.isOwnBehavior(agent, target);
57
+ if (isOwn) {
58
+ allowed = true;
59
+ reason = `Specialist "${agent}" can deactivate their own behavior.`;
60
+ } else {
61
+ reason = `Specialist "${agent}" cannot deactivate behaviors belonging to other agents.`;
62
+ }
63
+ } else if (allowed) {
64
+ reason = `Role "${role}" has authority for "${operation}".`;
65
+ } else {
66
+ reason = `Role "${role}" does not have authority for "${operation}". Requires coordinator override.`;
67
+ }
68
+ let requiresOverride = !allowed;
69
+ let confidence = allowed ? 0.95 : 0.9;
70
+ try {
71
+ const dreamingPath = "./dreaming.js";
72
+ const dreaming = await import(
73
+ /* @vite-ignore */
74
+ dreamingPath
75
+ );
76
+ if (typeof dreaming.calculateDrift === "function") {
77
+ const driftScore = await dreaming.calculateDrift(agent);
78
+ if (typeof driftScore === "number" && driftScore > 0.8) {
79
+ requiresOverride = true;
80
+ confidence = Math.max(0.5, confidence - 0.3);
81
+ reason += ` (\u26A0\uFE0F High drift score: ${driftScore.toFixed(2)} \u2014 requires override.)`;
82
+ }
83
+ }
84
+ } catch {
85
+ }
86
+ const decision = {
87
+ allowed: allowed && !requiresOverride,
88
+ reason,
89
+ confidence,
90
+ requires_override: requiresOverride
91
+ };
92
+ await this.logDecision(agent, operation, target, decision);
93
+ return decision;
94
+ }
95
+ /**
96
+ * Record an explicit coordinator override that bypasses the gate.
97
+ */
98
+ async override(agent, operation, target, reason) {
99
+ const role = await this.resolveRole(agent);
100
+ if (role !== "coordinator") {
101
+ const decision2 = {
102
+ allowed: false,
103
+ reason: `Only coordinators can issue overrides. "${agent}" is a ${role}.`,
104
+ confidence: 1,
105
+ requires_override: false
106
+ };
107
+ await this.logDecision(agent, `override:${operation}`, target, decision2);
108
+ return decision2;
109
+ }
110
+ const decision = {
111
+ allowed: true,
112
+ reason: `Coordinator override: ${reason}`,
113
+ confidence: 1,
114
+ requires_override: false
115
+ };
116
+ await this.logDecision(agent, `override:${operation}`, target, decision);
117
+ return decision;
118
+ }
119
+ /**
120
+ * Query the audit trail.
121
+ */
122
+ async getAuditLog(opts) {
123
+ await this.ensureAuditTable();
124
+ const client = getClient();
125
+ const conditions = [];
126
+ const args = [];
127
+ if (opts?.agent) {
128
+ conditions.push("agent = ?");
129
+ args.push(opts.agent);
130
+ }
131
+ if (opts?.operation) {
132
+ conditions.push("operation = ?");
133
+ args.push(opts.operation);
134
+ }
135
+ const where = conditions.length > 0 ? `WHERE ${conditions.join(" AND ")}` : "";
136
+ const limit = opts?.limit ?? 50;
137
+ const result = await client.execute({
138
+ sql: `SELECT * FROM steward_audit ${where} ORDER BY created_at DESC LIMIT ?`,
139
+ args: [...args, limit]
140
+ });
141
+ return result.rows.map((row) => ({
142
+ id: String(row.id),
143
+ agent: String(row.agent),
144
+ operation: String(row.operation),
145
+ target: String(row.target),
146
+ decision: {
147
+ allowed: Number(row.allowed) === 1,
148
+ reason: String(row.reason),
149
+ confidence: Number(row.confidence),
150
+ requires_override: Number(row.requires_override) === 1
151
+ },
152
+ timestamp: String(row.created_at)
153
+ }));
154
+ }
155
+ // -------------------------------------------------------------------------
156
+ // Internal methods
157
+ // -------------------------------------------------------------------------
158
+ /**
159
+ * Resolve an agent name to a role category.
160
+ */
161
+ async resolveRole(agent) {
162
+ if (isCoordinatorName(agent)) return "coordinator";
163
+ try {
164
+ const employees = loadEmployeesSync();
165
+ const employee = employees.find((e) => e.name === agent);
166
+ if (employee && MANAGER_ROLES.has(employee.role)) return "manager";
167
+ } catch {
168
+ }
169
+ return "specialist";
170
+ }
171
+ /**
172
+ * Check if a behavior belongs to the given agent.
173
+ */
174
+ async isOwnBehavior(agent, behaviorId) {
175
+ try {
176
+ const client = getClient();
177
+ const result = await client.execute({
178
+ sql: "SELECT agent_id FROM behaviors WHERE id = ? LIMIT 1",
179
+ args: [behaviorId]
180
+ });
181
+ if (result.rows.length === 0) return false;
182
+ return String(result.rows[0].agent_id) === agent;
183
+ } catch {
184
+ return false;
185
+ }
186
+ }
187
+ /**
188
+ * Ensure the steward_audit table exists.
189
+ */
190
+ async ensureAuditTable() {
191
+ const client = getClient();
192
+ await client.execute({
193
+ sql: `CREATE TABLE IF NOT EXISTS steward_audit (
194
+ id TEXT PRIMARY KEY,
195
+ agent TEXT NOT NULL,
196
+ operation TEXT NOT NULL,
197
+ target TEXT NOT NULL,
198
+ allowed INTEGER NOT NULL,
199
+ reason TEXT NOT NULL,
200
+ confidence REAL NOT NULL,
201
+ requires_override INTEGER NOT NULL DEFAULT 0,
202
+ created_at TEXT NOT NULL
203
+ )`,
204
+ args: []
205
+ });
206
+ }
207
+ /**
208
+ * Log a gate decision to the audit trail.
209
+ */
210
+ async logDecision(agent, operation, target, decision) {
211
+ try {
212
+ await this.ensureAuditTable();
213
+ const client = getClient();
214
+ await client.execute({
215
+ sql: `INSERT INTO steward_audit (id, agent, operation, target, allowed, reason, confidence, requires_override, created_at)
216
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,
217
+ args: [
218
+ crypto.randomUUID(),
219
+ agent,
220
+ operation,
221
+ target,
222
+ decision.allowed ? 1 : 0,
223
+ decision.reason,
224
+ decision.confidence,
225
+ decision.requires_override ? 1 : 0,
226
+ (/* @__PURE__ */ new Date()).toISOString()
227
+ ]
228
+ });
229
+ } catch {
230
+ process.stderr.write(
231
+ `[steward-gate] Audit log write failed for ${agent}:${operation}
232
+ `
233
+ );
234
+ }
235
+ }
236
+ };
237
+
238
+ export {
239
+ StewardGate
240
+ };