@askexenow/exe-os 0.9.280 → 0.9.281

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 (436) hide show
  1. package/deploy/compose/.env.customer.example +1 -1
  2. package/deploy/compose/.env.default +2 -1
  3. package/deploy/compose/.env.example +1 -1
  4. package/deploy/compose/docker-compose.yml +74 -13
  5. package/deploy/compose/erp-nginx/nginx.conf +52 -0
  6. package/deploy/compose/generate-env.ts +1 -1
  7. package/deploy/compose/init-db.sql +13 -2
  8. package/deploy/stack-manifests/v0.9.json +11 -31
  9. package/dist/active-agent-6ZBHGHXF.js +26 -0
  10. package/dist/active-agent-E23SCYER.js +27 -0
  11. package/dist/active-agent-KMZT44S4.js +26 -0
  12. package/dist/active-agent-LFFTVROM.js +27 -0
  13. package/dist/agentic-ontology-PCZB5HV5.js +25 -0
  14. package/dist/agentic-ontology-PGGJN2ES.js +25 -0
  15. package/dist/assets/tmux.conf +2 -0
  16. package/dist/backfill-metadata-KQ4FEVUR.js +599 -0
  17. package/dist/backfill-metadata-Y3YWCHKJ.js +599 -0
  18. package/dist/behaviors-H4DZECKL.js +39 -0
  19. package/dist/behaviors-WIUTIJF6.js +39 -0
  20. package/dist/bin/agentic-ontology-backfill.js +5 -5
  21. package/dist/bin/agentic-reflection-backfill.js +6 -6
  22. package/dist/bin/agentic-semantic-label.js +5 -5
  23. package/dist/bin/backfill-conversations.js +4 -4
  24. package/dist/bin/backfill-responses.js +4 -4
  25. package/dist/bin/backfill-vectors.js +5 -5
  26. package/dist/bin/bulk-sync-postgres.js +7 -7
  27. package/dist/bin/cc-doctor.js +4 -4
  28. package/dist/bin/cleanup-stale-review-tasks.js +10 -10
  29. package/dist/bin/cli.js +15 -15
  30. package/dist/bin/exe-agent-config.js +2 -2
  31. package/dist/bin/exe-agent.js +4 -4
  32. package/dist/bin/exe-assign.js +5 -5
  33. package/dist/bin/exe-boot.js +17 -17
  34. package/dist/bin/exe-call.js +4 -4
  35. package/dist/bin/exe-cloud.js +5 -5
  36. package/dist/bin/exe-dispatch.js +10 -10
  37. package/dist/bin/exe-doctor.js +1 -1
  38. package/dist/bin/exe-export-behaviors.js +7 -7
  39. package/dist/bin/exe-forget.js +6 -6
  40. package/dist/bin/exe-gateway.js +7 -7
  41. package/dist/bin/exe-healthcheck.js +4 -4
  42. package/dist/bin/exe-heartbeat.js +10 -10
  43. package/dist/bin/exe-kill.js +13 -13
  44. package/dist/bin/exe-launch-agent.js +17 -17
  45. package/dist/bin/exe-new-employee.js +7 -7
  46. package/dist/bin/exe-pending-messages.js +11 -11
  47. package/dist/bin/exe-pending-notifications.js +10 -10
  48. package/dist/bin/exe-pending-reviews.js +10 -10
  49. package/dist/bin/exe-rename.js +4 -4
  50. package/dist/bin/exe-review.js +12 -12
  51. package/dist/bin/exe-search.js +5 -5
  52. package/dist/bin/exe-session-cleanup.js +15 -15
  53. package/dist/bin/exe-settings.js +5 -5
  54. package/dist/bin/exe-start-codex.js +11 -11
  55. package/dist/bin/exe-start-opencode.js +8 -8
  56. package/dist/bin/exe-status.js +11 -11
  57. package/dist/bin/exe-support.js +2 -2
  58. package/dist/bin/exe-team.js +3 -3
  59. package/dist/bin/exe-watchdog.js +17 -2
  60. package/dist/bin/git-sweep.js +11 -11
  61. package/dist/bin/graph-backfill.js +4 -4
  62. package/dist/bin/graph-export.js +5 -5
  63. package/dist/bin/import-history.js +7 -7
  64. package/dist/bin/install.js +8 -7
  65. package/dist/bin/intercom-check.js +4 -4
  66. package/dist/bin/mcp-sessions.js +2 -2
  67. package/dist/bin/orchestration-metrics.js +4 -4
  68. package/dist/bin/postgres-agentic-reflection-backfill.js +2 -2
  69. package/dist/bin/postgres-agentic-semantic-backfill.js +1 -1
  70. package/dist/bin/scan-tasks.js +10 -10
  71. package/dist/bin/setup.js +1 -1
  72. package/dist/bin/shard-migrate.js +4 -4
  73. package/dist/bin/stack-update.js +3 -3
  74. package/dist/bin/vps-health-gate.js +1 -1
  75. package/dist/capability-cards-F22XWGLB.js +88 -0
  76. package/dist/capability-cards-KCKITXXZ.js +88 -0
  77. package/dist/capacity-monitor-CHXGKVEO.js +50 -0
  78. package/dist/capacity-monitor-L3M5KB6T.js +50 -0
  79. package/dist/catchup-brief-BVZANLRZ.js +154 -0
  80. package/dist/catchup-brief-LDUGMC7S.js +154 -0
  81. package/dist/catchup-brief-NZDLL7SA.js +154 -0
  82. package/dist/catchup-brief-OOIXVGBA.js +154 -0
  83. package/dist/catchup-brief-UPXHDYTB.js +154 -0
  84. package/dist/chunk-2BI3FQKL.js +1876 -0
  85. package/dist/chunk-2CJUQGHH.js +362 -0
  86. package/dist/chunk-2EVYBMBJ.js +128 -0
  87. package/dist/chunk-2NQOZOXG.js +2113 -0
  88. package/dist/chunk-2QK5E3LB.js +128 -0
  89. package/dist/chunk-2VTCG4ZU.js +1352 -0
  90. package/dist/chunk-2YGI36DV.js +1119 -0
  91. package/dist/chunk-32BQN2QN.js +185 -0
  92. package/dist/chunk-33JMO4UV.js +157 -0
  93. package/dist/chunk-3DZAYLXY.js +377 -0
  94. package/dist/chunk-3MGBE7GR.js +76 -0
  95. package/dist/chunk-3MTV4FJL.js +271 -0
  96. package/dist/chunk-3NN7VQ27.js +1352 -0
  97. package/dist/chunk-4533HNOG.js +70 -0
  98. package/dist/chunk-456UW3MT.js +731 -0
  99. package/dist/chunk-4AU56XV2.js +58 -0
  100. package/dist/chunk-4MRP6EBR.js +280 -0
  101. package/dist/chunk-4MRWW52U.js +14219 -0
  102. package/dist/chunk-4WWECNAY.js +50 -0
  103. package/dist/chunk-4ZJDDR6L.js +171 -0
  104. package/dist/chunk-522EOPM6.js +382 -0
  105. package/dist/chunk-52UDAVZE.js +3208 -0
  106. package/dist/chunk-5FAMUB4X.js +204 -0
  107. package/dist/chunk-5PGZJQUI.js +58 -0
  108. package/dist/chunk-67TZJXNZ.js +262 -0
  109. package/dist/chunk-6FEZ7GN2.js +123 -0
  110. package/dist/chunk-6MOGND7S.js +14219 -0
  111. package/dist/chunk-6TRSVY7L.js +181 -0
  112. package/dist/chunk-6WCS7ZNK.js +85 -0
  113. package/dist/chunk-6WRYDREW.js +539 -0
  114. package/dist/chunk-72UA2FB3.js +181 -0
  115. package/dist/chunk-77DMFEOL.js +30 -0
  116. package/dist/chunk-7COXVQ5W.js +214 -0
  117. package/dist/chunk-7HLWBYH7.js +60 -0
  118. package/dist/chunk-ALSTZCWT.js +204 -0
  119. package/dist/chunk-ARUTDXZX.js +280 -0
  120. package/dist/chunk-AU47B4QY.js +129 -0
  121. package/dist/chunk-AXOREWVL.js +836 -0
  122. package/dist/chunk-B5MNC54V.js +127 -0
  123. package/dist/chunk-B74VSMKX.js +1350 -0
  124. package/dist/chunk-BHWLH44J.js +362 -0
  125. package/dist/chunk-BUPZ3HD2.js +85 -0
  126. package/dist/chunk-BWVLMA53.js +2113 -0
  127. package/dist/chunk-C5WLBKMJ.js +50 -0
  128. package/dist/chunk-C62T6R2A.js +97 -0
  129. package/dist/chunk-CV5KBAIK.js +33 -0
  130. package/dist/chunk-DAYSDWXA.js +1068 -0
  131. package/dist/chunk-DI4URIUB.js +227 -0
  132. package/dist/chunk-DNTCYFJ6.js +76 -0
  133. package/dist/chunk-DPDRRS7T.js +103 -0
  134. package/dist/chunk-DT3EV6CW.js +103 -0
  135. package/dist/chunk-DX45HDWY.js +1076 -0
  136. package/dist/chunk-E72BD6MG.js +284 -0
  137. package/dist/chunk-EAPUSVKS.js +375 -0
  138. package/dist/chunk-EFUANRRT.js +85 -0
  139. package/dist/chunk-EG2SCT5R.js +1352 -0
  140. package/dist/chunk-EJD2JU77.js +58 -0
  141. package/dist/chunk-EMXYUAVP.js +81 -0
  142. package/dist/chunk-ENM2TAAM.js +14219 -0
  143. package/dist/chunk-EPDRTPVP.js +1876 -0
  144. package/dist/chunk-EW6XDHID.js +221 -0
  145. package/dist/chunk-EYEGSAWZ.js +1094 -0
  146. package/dist/chunk-F6L33PAQ.js +231 -0
  147. package/dist/chunk-FC2SCTVE.js +38 -0
  148. package/dist/chunk-FSRKIZGZ.js +630 -0
  149. package/dist/chunk-FTG7I5CB.js +81 -0
  150. package/dist/chunk-GVFRLWX7.js +30 -0
  151. package/dist/chunk-H3XMZOWW.js +1119 -0
  152. package/dist/chunk-HAKXE6LN.js +123 -0
  153. package/dist/chunk-HLP3ZDTW.js +448 -0
  154. package/dist/chunk-HOYWKQAA.js +510 -0
  155. package/dist/chunk-HWDD64IW.js +712 -0
  156. package/dist/chunk-HWMCULHY.js +127 -0
  157. package/dist/chunk-HZZHRZPK.js +210 -0
  158. package/dist/chunk-ICRWTYNW.js +103 -0
  159. package/dist/chunk-J5MWPC33.js +167 -0
  160. package/dist/chunk-JBXANNNB.js +70 -0
  161. package/dist/chunk-JPBMIYWF.js +1352 -0
  162. package/dist/chunk-JY6EXBFI.js +373 -0
  163. package/dist/chunk-JZLIBXI7.js +14219 -0
  164. package/dist/chunk-JZPTKXJ6.js +668 -0
  165. package/dist/chunk-KEYMA4ZP.js +510 -0
  166. package/dist/chunk-KHGNN6GL.js +2078 -0
  167. package/dist/chunk-KVLB2PD6.js +97 -0
  168. package/dist/chunk-L3YBRBKL.js +1076 -0
  169. package/dist/chunk-L7VZ32NA.js +89 -0
  170. package/dist/chunk-LEHLADW4.js +221 -0
  171. package/dist/chunk-LPD4HILQ.js +262 -0
  172. package/dist/chunk-LSJ3ADDI.js +51 -0
  173. package/dist/chunk-LUMS2MAS.js +58 -0
  174. package/dist/chunk-LV4SEC6C.js +394 -0
  175. package/dist/chunk-LXXBEI4A.js +284 -0
  176. package/dist/chunk-M4NPCAIH.js +456 -0
  177. package/dist/chunk-MFJ62LQ5.js +157 -0
  178. package/dist/chunk-MGEZNKOD.js +836 -0
  179. package/dist/chunk-MJ7X5IBW.js +227 -0
  180. package/dist/chunk-MLGRWCY4.js +54 -0
  181. package/dist/chunk-MQZX57IY.js +348 -0
  182. package/dist/chunk-MY7MFF6J.js +103 -0
  183. package/dist/chunk-MYA2X5OY.js +185 -0
  184. package/dist/chunk-MYEABW5Z.js +630 -0
  185. package/dist/chunk-MZ2TDCAL.js +402 -0
  186. package/dist/chunk-NF3FRB7Z.js +271 -0
  187. package/dist/chunk-NXYIFEPV.js +539 -0
  188. package/dist/chunk-O2GVE5B5.js +58 -0
  189. package/dist/chunk-O5GUCDR2.js +456 -0
  190. package/dist/chunk-OBZNRECA.js +128 -0
  191. package/dist/chunk-OMZ2RLJG.js +214 -0
  192. package/dist/chunk-ORDHJRWN.js +299 -0
  193. package/dist/chunk-OSPIJMCD.js +210 -0
  194. package/dist/chunk-OUGWEH4J.js +240 -0
  195. package/dist/chunk-OV5MJQGC.js +1876 -0
  196. package/dist/chunk-PC635OAG.js +4318 -0
  197. package/dist/chunk-PH46R4J6.js +348 -0
  198. package/dist/chunk-PJP2EP7P.js +394 -0
  199. package/dist/chunk-PODFWH3V.js +333 -0
  200. package/dist/chunk-PPWH3SHR.js +1068 -0
  201. package/dist/chunk-PWPJK7KB.js +4318 -0
  202. package/dist/chunk-PXONZVG4.js +377 -0
  203. package/dist/chunk-QAOGJRZD.js +369 -0
  204. package/dist/chunk-QC3LAEI7.js +197 -0
  205. package/dist/chunk-QDWQDUWI.js +668 -0
  206. package/dist/chunk-QKJFD6BH.js +1350 -0
  207. package/dist/chunk-QNYVJGFM.js +345 -0
  208. package/dist/chunk-QQF3XGQ5.js +14219 -0
  209. package/dist/chunk-QRPFQNI3.js +150 -0
  210. package/dist/chunk-QSSU5XWD.js +731 -0
  211. package/dist/chunk-QXZAGVAV.js +2078 -0
  212. package/dist/chunk-RA54MW64.js +244 -0
  213. package/dist/chunk-RF7PUWXI.js +197 -0
  214. package/dist/chunk-S3INDYSO.js +244 -0
  215. package/dist/chunk-SLQVTHH5.js +369 -0
  216. package/dist/chunk-SY2B74KL.js +345 -0
  217. package/dist/chunk-T6QPXXXW.js +712 -0
  218. package/dist/chunk-TO5M5YCT.js +41 -0
  219. package/dist/chunk-TQ4VXUAF.js +129 -0
  220. package/dist/chunk-UAB7RQC4.js +41 -0
  221. package/dist/chunk-UMEIBDYW.js +97 -0
  222. package/dist/chunk-UXW5TB7Y.js +240 -0
  223. package/dist/chunk-VB2N5WOX.js +150 -0
  224. package/dist/chunk-VLZEMRG3.js +167 -0
  225. package/dist/chunk-VM3V6VK7.js +230 -0
  226. package/dist/chunk-VMCGKBHB.js +1352 -0
  227. package/dist/chunk-VNIYZAR5.js +128 -0
  228. package/dist/chunk-VYV4KOD2.js +85 -0
  229. package/dist/chunk-W4SRJBAT.js +171 -0
  230. package/dist/chunk-W5W3LZ3Q.js +54 -0
  231. package/dist/chunk-WDNZEOM3.js +38 -0
  232. package/dist/chunk-WUKEXVOR.js +3208 -0
  233. package/dist/chunk-X3Z35Q6L.js +373 -0
  234. package/dist/chunk-X4VOU6BQ.js +382 -0
  235. package/dist/chunk-X6EEVSVG.js +290 -0
  236. package/dist/chunk-XFHGWGNB.js +1094 -0
  237. package/dist/chunk-XKOLRWYA.js +33 -0
  238. package/dist/chunk-XMMIL3UD.js +402 -0
  239. package/dist/chunk-XWILC6VA.js +290 -0
  240. package/dist/chunk-Y4OQCX4C.js +97 -0
  241. package/dist/chunk-Y67VYYOA.js +231 -0
  242. package/dist/chunk-YGQCQTQH.js +230 -0
  243. package/dist/chunk-YGWFBN5A.js +299 -0
  244. package/dist/chunk-YMKUXZIG.js +379 -0
  245. package/dist/chunk-YOMLMT7E.js +230 -0
  246. package/dist/chunk-YPESIZOB.js +14219 -0
  247. package/dist/chunk-Z2CGCIU2.js +89 -0
  248. package/dist/chunk-ZLAWNHQR.js +448 -0
  249. package/dist/chunk-ZME5UQSN.js +333 -0
  250. package/dist/co-activation-NUEQYXE5.js +73 -0
  251. package/dist/co-activation-ZG5HLBCZ.js +73 -0
  252. package/dist/co-occurrence-7S5KWQB2.js +94 -0
  253. package/dist/co-occurrence-X5SWDXT2.js +94 -0
  254. package/dist/core-memory-GOPBRGGZ.js +110 -0
  255. package/dist/core-memory-XLCU6L5M.js +110 -0
  256. package/dist/crdt-sync-EPKHPGRZ.js +33 -0
  257. package/dist/crdt-sync-UIQJ5U7T.js +33 -0
  258. package/dist/crm-webhook-MKN23JNU.js +10 -0
  259. package/dist/crm-webhook-SM63BPXO.js +10 -0
  260. package/dist/cto-delegation-gate-PQY5TOVZ.js +279 -0
  261. package/dist/cto-delegation-gate-V5VVUR3G.js +279 -0
  262. package/dist/daemon-orchestration-C7AAS67Q.js +138 -0
  263. package/dist/daemon-orchestration-OBCAJB2H.js +138 -0
  264. package/dist/db-backup-F7VP4QRH.js +33 -0
  265. package/dist/db-backup-KVYC57W7.js +33 -0
  266. package/dist/doc-graph-extractor-H2ETEINP.js +132 -0
  267. package/dist/doc-graph-extractor-PCUZEYCH.js +132 -0
  268. package/dist/dreaming-4OZXSLE3.js +33 -0
  269. package/dist/dreaming-Z2RYEYNT.js +33 -0
  270. package/dist/exe-drift-GEWNIK7A.js +69 -0
  271. package/dist/exe-drift-XCGH7AFO.js +69 -0
  272. package/dist/exe-export-7DKAU5IP.js +75 -0
  273. package/dist/exe-export-BCHH6OE6.js +75 -0
  274. package/dist/exe-import-PDRIZVYF.js +78 -0
  275. package/dist/exe-import-ZCKUDFKL.js +78 -0
  276. package/dist/exe-key-FUWLLI3U.js +580 -0
  277. package/dist/exe-key-RKKNVUMP.js +580 -0
  278. package/dist/exe-snapshot-G4I5FQMK.js +337 -0
  279. package/dist/exe-snapshot-GWU7QTZK.js +337 -0
  280. package/dist/fast-db-init-6QG6YQNT.js +7 -0
  281. package/dist/fast-db-init-X2QDQUA4.js +7 -0
  282. package/dist/founder-context-TOMNUBGJ.js +96 -0
  283. package/dist/founder-context-UU3V6MAS.js +96 -0
  284. package/dist/gateway/index.js +8 -8
  285. package/dist/git-staleness-FEPFMZKF.js +111 -0
  286. package/dist/git-staleness-HYVYLCW3.js +111 -0
  287. package/dist/git-task-sweep-IRV52JIM.js +41 -0
  288. package/dist/git-task-sweep-T6BSM3GS.js +41 -0
  289. package/dist/global-procedures-3AURRMKO.js +21 -0
  290. package/dist/global-procedures-JPCYBZYC.js +21 -0
  291. package/dist/graph-auto-extract-OC3AOSMW.js +182 -0
  292. package/dist/graph-auto-extract-PVDYEJBY.js +182 -0
  293. package/dist/hooks/bug-report-worker.js +12 -12
  294. package/dist/hooks/codex-stop-task-finalizer.js +12 -12
  295. package/dist/hooks/commit-complete.js +12 -12
  296. package/dist/hooks/error-recall.js +6 -6
  297. package/dist/hooks/exe-heartbeat-hook.js +3 -3
  298. package/dist/hooks/ingest.js +6 -6
  299. package/dist/hooks/instructions-loaded.js +4 -4
  300. package/dist/hooks/manifest.json +19 -19
  301. package/dist/hooks/notification.js +4 -4
  302. package/dist/hooks/post-compact.js +11 -11
  303. package/dist/hooks/post-tool-combined.js +5 -5
  304. package/dist/hooks/pre-compact.js +12 -12
  305. package/dist/hooks/pre-tool-use.js +15 -15
  306. package/dist/hooks/prompt-submit.js +22 -22
  307. package/dist/hooks/session-end.js +16 -16
  308. package/dist/hooks/session-start.js +10 -10
  309. package/dist/hooks/stop.js +15 -15
  310. package/dist/hooks/subagent-stop.js +11 -11
  311. package/dist/hooks/summary-worker.js +15 -15
  312. package/dist/index.js +18 -18
  313. package/dist/installer-72XXLBRP.js +39 -0
  314. package/dist/installer-HDXG2BZN.js +343 -0
  315. package/dist/installer-JALMKPCS.js +297 -0
  316. package/dist/installer-Q46SNNLU.js +39 -0
  317. package/dist/installer-W7PIPRCX.js +343 -0
  318. package/dist/installer-Z7WQEOS7.js +297 -0
  319. package/dist/lib/cloud-sync.js +5 -5
  320. package/dist/lib/consolidation.js +5 -5
  321. package/dist/lib/database.js +2 -2
  322. package/dist/lib/db.js +2 -2
  323. package/dist/lib/employee-templates.js +4 -4
  324. package/dist/lib/employees.js +2 -2
  325. package/dist/lib/exe-daemon.js +45 -41
  326. package/dist/lib/hybrid-search.js +5 -5
  327. package/dist/lib/identity.js +2 -2
  328. package/dist/lib/license.js +1 -1
  329. package/dist/lib/messaging.js +10 -10
  330. package/dist/lib/reminders.js +3 -3
  331. package/dist/lib/schedules.js +5 -5
  332. package/dist/lib/session-registry.js +4 -4
  333. package/dist/lib/skill-learning.js +6 -6
  334. package/dist/lib/store.js +4 -4
  335. package/dist/lib/task-router.js +3 -3
  336. package/dist/lib/tasks.js +11 -11
  337. package/dist/lib/tmux-routing.js +9 -9
  338. package/dist/lib/token-spend.js +3 -3
  339. package/dist/license-gate-7JZCHOAG.js +14 -0
  340. package/dist/license-gate-OP4SKL4P.js +14 -0
  341. package/dist/mcp/register-tools.js +58 -58
  342. package/dist/mcp/server.js +59 -59
  343. package/dist/mcp/tools/complete-reminder.js +4 -4
  344. package/dist/mcp/tools/create-reminder.js +4 -4
  345. package/dist/mcp/tools/create-task.js +13 -13
  346. package/dist/mcp/tools/deactivate-behavior.js +7 -7
  347. package/dist/mcp/tools/list-reminders.js +4 -4
  348. package/dist/mcp/tools/list-tasks.js +13 -13
  349. package/dist/mcp/tools/send-message.js +12 -12
  350. package/dist/mcp/tools/update-task.js +12 -12
  351. package/dist/mcp-health-VULNT722.js +17 -0
  352. package/dist/mcp-health-WDOB6XUB.js +19 -0
  353. package/dist/mcp-http-config-2OZ7N74D.js +28 -0
  354. package/dist/mcp-http-config-4VXA5K73.js +28 -0
  355. package/dist/memory-cards-2K6QRZU6.js +179 -0
  356. package/dist/memory-cards-KSJF5OH2.js +179 -0
  357. package/dist/memory-graph-extractor-IJD5HWYT.js +21 -0
  358. package/dist/memory-graph-extractor-O4GAXOK5.js +21 -0
  359. package/dist/memory-poisoning-defense-2JRPWT5V.js +223 -0
  360. package/dist/memory-poisoning-defense-DH4A25NU.js +223 -0
  361. package/dist/memory-reflection-ISY2BBDB.js +243 -0
  362. package/dist/memory-reflection-Z5AQRR6H.js +243 -0
  363. package/dist/notifications-2VSWK2UJ.js +46 -0
  364. package/dist/notifications-4S253VQM.js +46 -0
  365. package/dist/oauth-server-D7D4574D.js +437 -0
  366. package/dist/oauth-server-MACN54SJ.js +437 -0
  367. package/dist/orchestration-events-BGP5RYQI.js +26 -0
  368. package/dist/orchestration-events-MDXUEVRZ.js +26 -0
  369. package/dist/orchestrator-DHK7RSSH.js +34 -0
  370. package/dist/orchestrator-R75WHQVA.js +34 -0
  371. package/dist/pipeline-router-4WUKQQEC.js +14 -0
  372. package/dist/pipeline-router-GWB2XK2Q.js +14 -0
  373. package/dist/plan-limits-NNJRAESF.js +27 -0
  374. package/dist/plan-limits-YTQW4UR4.js +27 -0
  375. package/dist/project-boot-46GZJTEX.js +299 -0
  376. package/dist/project-boot-PPHBBGIF.js +299 -0
  377. package/dist/projection-worker-UPAWXI7P.js +1034 -0
  378. package/dist/projection-worker-ZIKDYBW5.js +1034 -0
  379. package/dist/reranker-5ZBP2RRN.js +19 -0
  380. package/dist/reranker-E2MQIMJL.js +19 -0
  381. package/dist/reranker-GLSDJT3V.js +19 -0
  382. package/dist/reranker-LBBXWNOD.js +19 -0
  383. package/dist/reranker-XZ2EF4OH.js +19 -0
  384. package/dist/retrieval-health-JYRKPSII.js +7 -0
  385. package/dist/retrieval-health-OUV25J6S.js +7 -0
  386. package/dist/retrieval-health-U73JUAZL.js +7 -0
  387. package/dist/retrieval-health-WSZ7TYFF.js +7 -0
  388. package/dist/review-polling-62JV55ZT.js +125 -0
  389. package/dist/review-polling-CJXLWFWK.js +125 -0
  390. package/dist/runtime/index.js +12 -12
  391. package/dist/session-events-2ADD54VI.js +37 -0
  392. package/dist/session-events-QIJVBSKS.js +37 -0
  393. package/dist/session-kill-telemetry-HS6HD2YE.js +30 -0
  394. package/dist/session-kill-telemetry-MRT5FVSM.js +30 -0
  395. package/dist/session-scope-7ICYPC33.js +87 -0
  396. package/dist/session-scope-KMXD6EE6.js +87 -0
  397. package/dist/setup-wizard-B6GIT7YC.js +12 -0
  398. package/dist/setup-wizard-JUIJ4UZO.js +12 -0
  399. package/dist/skill-refinement-HIOX4VMC.js +158 -0
  400. package/dist/skill-refinement-T7JXRYUW.js +158 -0
  401. package/dist/stack-update-5KE6BZKQ.js +74 -0
  402. package/dist/stack-update-OP2RHP7N.js +74 -0
  403. package/dist/stack-update-VGCWDJEE.js +74 -0
  404. package/dist/steward-gate-L22WE3SY.js +14 -0
  405. package/dist/steward-gate-YKD2LUWN.js +14 -0
  406. package/dist/task-enforcement-5AOKXTY4.js +439 -0
  407. package/dist/task-enforcement-VO3YEGIO.js +439 -0
  408. package/dist/task-scope-YV2WPKRD.js +36 -0
  409. package/dist/task-scope-ZSXDZBRE.js +36 -0
  410. package/dist/tasks-crud-C6KADACT.js +78 -0
  411. package/dist/tasks-crud-NV6JEWGL.js +78 -0
  412. package/dist/tasks-notify-E22HSN6O.js +39 -0
  413. package/dist/tasks-notify-RPSEQ4WV.js +39 -0
  414. package/dist/tasks-review-V4ZLXOAZ.js +48 -0
  415. package/dist/tasks-review-ZVRI73JE.js +48 -0
  416. package/dist/telemetry-upload-LXUH7SKI.js +740 -0
  417. package/dist/telemetry-upload-TCDAZTUQ.js +740 -0
  418. package/dist/token-budget-OFBEZJTA.js +85 -0
  419. package/dist/token-budget-WAN57V6S.js +85 -0
  420. package/dist/tool-telemetry-UA3N32PK.js +17 -0
  421. package/dist/tool-telemetry-XXZJ35RR.js +17 -0
  422. package/dist/tui/App.js +17 -17
  423. package/dist/tui-data-46QLCJUE.js +259 -0
  424. package/dist/tui-data-ZDB7BLP2.js +259 -0
  425. package/dist/wiki-acl-HHSIBPF3.js +111 -0
  426. package/dist/wiki-acl-O65GZ2ZF.js +111 -0
  427. package/dist/worker-gate-27I4GAEZ.js +21 -0
  428. package/dist/worker-gate-DXU4HEPY.js +21 -0
  429. package/dist/workflow-engine-63EOEJ5Q.js +28 -0
  430. package/dist/workflow-engine-C6F2RMPN.js +28 -0
  431. package/dist/worktree-SFKKOMFD.js +27 -0
  432. package/dist/worktree-SVCE3S7X.js +27 -0
  433. package/dist/worktree-sweep-S3JHJTVP.js +20 -0
  434. package/dist/worktree-sweep-U3TIQ7WL.js +20 -0
  435. package/package.json +1 -1
  436. package/release-notes.json +88 -26
@@ -0,0 +1,50 @@
1
+ import {
2
+ sendMessage
3
+ } from "./chunk-SY2B74KL.js";
4
+ import {
5
+ getActiveAgent
6
+ } from "./chunk-MYA2X5OY.js";
7
+
8
+ // src/mcp/tools/send-message.ts
9
+ import { z } from "zod";
10
+ function registerSendMessage(server) {
11
+ server.registerTool(
12
+ "send_message",
13
+ {
14
+ title: "Send Message",
15
+ description: "Send a structured message to another agent. Messages are queued and delivered via intercom. NOTE: messages are fire-and-forget \u2014 do NOT use for actionable work dispatch. Use create_task instead to assign work to employees.",
16
+ inputSchema: {
17
+ target_agent: z.string().describe("Recipient agent name"),
18
+ content: z.string().describe("Message content"),
19
+ target_project: z.string().optional().describe("Project context (optional)"),
20
+ priority: z.enum(["normal", "urgent"]).default("normal").describe("Message priority (default: normal)"),
21
+ target_device: z.string().optional().describe("Target device ID for cross-machine delivery (default: local)")
22
+ }
23
+ },
24
+ async ({ target_agent, content, target_project, priority, target_device }) => {
25
+ const { agentId } = getActiveAgent();
26
+ const msg = await sendMessage({
27
+ fromAgent: agentId,
28
+ targetAgent: target_agent,
29
+ targetProject: target_project,
30
+ targetDevice: target_device,
31
+ content,
32
+ priority
33
+ });
34
+ const statusText = msg.status === "delivered" ? "delivered" : msg.status === "failed" ? `failed: ${msg.failureReason}` : "queued (pending delivery)";
35
+ return {
36
+ content: [
37
+ {
38
+ type: "text",
39
+ text: `Message sent to ${target_agent}: ${statusText}
40
+ ID: ${msg.id}`
41
+ }
42
+ ]
43
+ };
44
+ }
45
+ );
46
+ }
47
+
48
+ export {
49
+ registerSendMessage
50
+ };
@@ -0,0 +1,171 @@
1
+ import {
2
+ writeMemoryViaDaemon
3
+ } from "./chunk-U76CXW3D.js";
4
+
5
+ // src/lib/auto-checkpoint.ts
6
+ var FILE_RE = /(?:^|\s)([\w./-]+\.(?:ts|tsx|js|jsx|json|md|yml|yaml|sql|go|py|css|scss|html|sh))(?:\b|$)/g;
7
+ var DECISION_RE = /\b(decision:|decided:|we decided|founder directive|captured in .*architecture|source of truth)\b/i;
8
+ function asString(value, fallback = "") {
9
+ if (value == null) return fallback;
10
+ return String(value);
11
+ }
12
+ function compactLine(text, max = 220) {
13
+ return text.replace(/\s+/g, " ").trim().slice(0, max);
14
+ }
15
+ function topEntries(counts, limit) {
16
+ return [...counts.entries()].sort((a, b) => b[1] - a[1] || a[0].localeCompare(b[0])).slice(0, limit).map(([name, count]) => `${name}(${count})`);
17
+ }
18
+ function buildAutoCheckpoint(input) {
19
+ const maxSamples = input.maxSamples ?? 8;
20
+ const projectCounts = /* @__PURE__ */ new Map();
21
+ const toolCounts = /* @__PURE__ */ new Map();
22
+ const files = /* @__PURE__ */ new Set();
23
+ const errors = [];
24
+ const samples = [];
25
+ const decisionTexts = [];
26
+ for (const row of input.memories) {
27
+ const tool = asString(row.tool_name, "unknown");
28
+ const project = asString(row.project_name, input.projectName || "unknown");
29
+ const raw = asString(row.raw_text);
30
+ const hasError = row.has_error === 1 || row.has_error === true;
31
+ toolCounts.set(tool, (toolCounts.get(tool) ?? 0) + 1);
32
+ projectCounts.set(project, (projectCounts.get(project) ?? 0) + 1);
33
+ if (hasError && errors.length < 5) errors.push(compactLine(raw, 180));
34
+ if (samples.length < maxSamples && raw.length > 30) {
35
+ samples.push(`[${tool}] ${compactLine(raw)}`);
36
+ }
37
+ if (DECISION_RE.test(raw) && decisionTexts.length < 5) {
38
+ decisionTexts.push(`AUTO DECISION CANDIDATE [${input.agentId}]: ${compactLine(raw, 500)}`);
39
+ }
40
+ for (const match of raw.matchAll(FILE_RE)) {
41
+ if (match[1]) files.add(match[1]);
42
+ if (files.size >= 20) break;
43
+ }
44
+ }
45
+ const taskLines = (input.tasks ?? []).slice(0, 10).map((task) => {
46
+ const status = asString(task.status, "unknown");
47
+ const priority = asString(task.priority, "?").toUpperCase();
48
+ const title = asString(task.title, "untitled");
49
+ const taskFile = asString(task.task_file);
50
+ return `- [${status}/${priority}] ${title}${taskFile ? ` (${taskFile})` : ""}`;
51
+ });
52
+ const parts = [
53
+ `CONTEXT CHECKPOINT [auto:${input.reason}]`,
54
+ `Agent: ${input.agentId} (${input.agentRole})`,
55
+ `Session: ${input.sessionId}`,
56
+ `Project: ${input.projectName}`,
57
+ `Time: ${(/* @__PURE__ */ new Date()).toISOString()}`,
58
+ "",
59
+ "## Recent Activity",
60
+ `- Memories scanned: ${input.memories.length}`,
61
+ `- Projects: ${topEntries(projectCounts, 5).join(", ") || input.projectName}`,
62
+ `- Tools: ${topEntries(toolCounts, 8).join(", ") || "none"}`
63
+ ];
64
+ if (taskLines.length > 0) {
65
+ parts.push("", "## Open / Active Tasks", ...taskLines);
66
+ }
67
+ if (files.size > 0) {
68
+ parts.push("", "## Files Mentioned", ...[...files].slice(0, 20).map((f) => `- ${f}`));
69
+ }
70
+ if (samples.length > 0) {
71
+ parts.push("", "## Important Recent Traces", ...samples.map((s) => `- ${s}`));
72
+ }
73
+ if (errors.length > 0) {
74
+ parts.push("", "## Errors / Risks", ...errors.map((e) => `- ${e}`));
75
+ }
76
+ if (decisionTexts.length > 0) {
77
+ parts.push("", "## Decision Candidates", ...decisionTexts.map((d) => `- ${d.replace(/^AUTO DECISION CANDIDATE \\[[^\\]]+\\]: /, "")}`));
78
+ }
79
+ return {
80
+ checkpointText: parts.join("\n"),
81
+ decisionTexts
82
+ };
83
+ }
84
+
85
+ // src/lib/checkpoint-orchestrator.ts
86
+ function toolNameForReason(reason) {
87
+ switch (reason) {
88
+ case "periodic":
89
+ return "auto-summary";
90
+ case "session-end":
91
+ return "SessionEnd";
92
+ case "pre-compact":
93
+ return "pre-compact-hook";
94
+ case "capacity-signal":
95
+ return "auto-checkpoint";
96
+ }
97
+ }
98
+ function importanceForReason(reason, override) {
99
+ if (override !== void 0) return override;
100
+ switch (reason) {
101
+ case "periodic":
102
+ return 7;
103
+ case "session-end":
104
+ case "pre-compact":
105
+ case "capacity-signal":
106
+ return 8;
107
+ }
108
+ }
109
+ function buildContinuityCheckpoint(input) {
110
+ const { checkpointText, decisionTexts } = buildAutoCheckpoint({
111
+ agentId: input.agentId,
112
+ agentRole: input.agentRole,
113
+ sessionId: input.sessionId,
114
+ projectName: input.projectName,
115
+ reason: input.reason,
116
+ memories: input.memories ?? [],
117
+ tasks: input.tasks ?? [],
118
+ maxSamples: input.maxSamples
119
+ });
120
+ const extra = input.extraSections?.filter((section) => section.trim().length > 0) ?? [];
121
+ return {
122
+ checkpointText: extra.length > 0 ? `${checkpointText}
123
+
124
+ ${extra.join("\n\n")}` : checkpointText,
125
+ decisionTexts
126
+ };
127
+ }
128
+ async function writeContinuityCheckpoint(input) {
129
+ const result = buildContinuityCheckpoint(input);
130
+ const now = (/* @__PURE__ */ new Date()).toISOString();
131
+ await writeMemoryViaDaemon({
132
+ raw_text: result.checkpointText,
133
+ agent_id: input.agentId,
134
+ agent_role: input.agentRole,
135
+ session_id: input.sessionId,
136
+ tool_name: toolNameForReason(input.reason),
137
+ project_name: input.projectName,
138
+ timestamp: now,
139
+ importance: importanceForReason(input.reason, input.importance),
140
+ task_id: input.taskId,
141
+ memory_type: "checkpoint"
142
+ });
143
+ const decisionLimit = input.reason === "periodic" ? 3 : 5;
144
+ for (const decisionText of result.decisionTexts.slice(0, decisionLimit)) {
145
+ await writeMemoryViaDaemon({
146
+ raw_text: decisionText,
147
+ agent_id: input.agentId,
148
+ agent_role: input.agentRole,
149
+ session_id: input.sessionId,
150
+ tool_name: "auto-decision",
151
+ project_name: input.projectName,
152
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
153
+ importance: 8,
154
+ memory_type: "decision"
155
+ });
156
+ }
157
+ return result;
158
+ }
159
+ async function checkpointActiveTask(input) {
160
+ const { writeCheckpoint } = await import("./lib/tasks.js");
161
+ await writeCheckpoint({
162
+ taskId: input.taskId,
163
+ step: input.step ?? "pre-compaction-checkpoint",
164
+ contextSummary: `Auto-checkpoint before context compaction. Task: ${input.taskTitle}. Session: ${input.sessionId}. Project: ${input.projectName}.`
165
+ });
166
+ }
167
+
168
+ export {
169
+ writeContinuityCheckpoint,
170
+ checkpointActiveTask
171
+ };
@@ -0,0 +1,382 @@
1
+ // src/automation/trigger-engine.ts
2
+ import { readFileSync, writeFileSync, existsSync, mkdirSync } from "fs";
3
+ import { randomUUID } from "crypto";
4
+ import path from "path";
5
+ import os from "os";
6
+ var TRIGGERS_PATH = path.join(os.homedir(), ".exe-os", "triggers.json");
7
+ var GRAPH_API_VERSION = "v21.0";
8
+ var MAX_PARAM_LENGTH = 2e3;
9
+ var MAX_TRIGGER_DEPTH = 3;
10
+ var _currentTriggerDepth = 0;
11
+ var OUTBOUND_RATE_LIMIT_PER_HOUR = 100;
12
+ var _outboundWindows = /* @__PURE__ */ new Map();
13
+ function checkOutboundRateLimit(channel) {
14
+ const now = Date.now();
15
+ const cutoff = now - 36e5;
16
+ if (!_outboundWindows.has(channel)) _outboundWindows.set(channel, []);
17
+ const window = _outboundWindows.get(channel);
18
+ while (window.length > 0 && window[0] < cutoff) window.shift();
19
+ if (window.length >= OUTBOUND_RATE_LIMIT_PER_HOUR) return false;
20
+ window.push(now);
21
+ return true;
22
+ }
23
+ function sanitizeParam(value, maxLen = MAX_PARAM_LENGTH) {
24
+ const cleaned = value.replace(/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g, "");
25
+ return cleaned.length > maxLen ? cleaned.slice(0, maxLen) : cleaned;
26
+ }
27
+ function sanitizeExternalPayload(text) {
28
+ let sanitized = text;
29
+ sanitized = sanitized.replace(/^(system|SYSTEM|System)\s*:/gm, "[filtered]:");
30
+ sanitized = sanitized.replace(/<\/?system[^>]*>/gi, "[filtered]");
31
+ sanitized = sanitized.replace(/ignore\s+(all\s+)?previous\s+(instructions|prompts|rules)/gi, "[filtered]");
32
+ sanitized = sanitized.replace(/you\s+are\s+now\s+/gi, "[filtered] ");
33
+ return sanitized;
34
+ }
35
+ function substituteTemplate(template, record, sanitizeExternal = false) {
36
+ return template.replace(
37
+ /\{\{(\w+(?:\.\w+)*)\}\}/g,
38
+ (_match, dotPath) => {
39
+ const segments = dotPath.split(".");
40
+ if (segments[0] === "record") segments.shift();
41
+ let current = record;
42
+ for (const seg of segments) {
43
+ if (current == null || typeof current !== "object") return "";
44
+ current = current[seg];
45
+ }
46
+ if (current == null) return "";
47
+ const value = String(current);
48
+ return sanitizeExternal ? sanitizeExternalPayload(value) : value;
49
+ }
50
+ );
51
+ }
52
+ function resolveFieldValue(record, field) {
53
+ let current = record;
54
+ for (const segment of field.split(".")) {
55
+ if (current == null || typeof current !== "object") return void 0;
56
+ current = current[segment];
57
+ }
58
+ return current;
59
+ }
60
+ function evaluateCondition(condition, record) {
61
+ const fieldValue = resolveFieldValue(record, condition.field);
62
+ const target = condition.value;
63
+ switch (condition.op) {
64
+ case "eq":
65
+ return String(fieldValue) === String(target);
66
+ case "neq":
67
+ return String(fieldValue) !== String(target);
68
+ case "gt":
69
+ return Number(fieldValue) > Number(target);
70
+ case "lt":
71
+ return Number(fieldValue) < Number(target);
72
+ case "gte":
73
+ return Number(fieldValue) >= Number(target);
74
+ case "lte":
75
+ return Number(fieldValue) <= Number(target);
76
+ case "contains":
77
+ return String(fieldValue).toLowerCase().includes(String(target).toLowerCase());
78
+ case "not_contains":
79
+ return !String(fieldValue).toLowerCase().includes(String(target).toLowerCase());
80
+ default:
81
+ return false;
82
+ }
83
+ }
84
+ function evaluateConditions(conditions, record) {
85
+ if (conditions.length === 0) return true;
86
+ return conditions.every((c) => evaluateCondition(c, record));
87
+ }
88
+ function loadTriggers(project) {
89
+ if (!existsSync(TRIGGERS_PATH)) return [];
90
+ try {
91
+ const raw = readFileSync(TRIGGERS_PATH, "utf-8");
92
+ const all = JSON.parse(raw);
93
+ if (!Array.isArray(all)) return [];
94
+ if (project) {
95
+ return all.filter((t) => !t.project || t.project === project);
96
+ }
97
+ return all;
98
+ } catch {
99
+ return [];
100
+ }
101
+ }
102
+ function saveTriggers(triggers) {
103
+ const dir = path.dirname(TRIGGERS_PATH);
104
+ if (!existsSync(dir)) mkdirSync(dir, { recursive: true });
105
+ writeFileSync(TRIGGERS_PATH, JSON.stringify(triggers, null, 2), "utf-8");
106
+ }
107
+ function createNewTrigger(input) {
108
+ const triggers = loadTriggers();
109
+ const trigger = {
110
+ id: randomUUID().slice(0, 8),
111
+ ...input
112
+ };
113
+ triggers.push(trigger);
114
+ saveTriggers(triggers);
115
+ return trigger;
116
+ }
117
+ async function executeSendWhatsapp(params) {
118
+ if (!checkOutboundRateLimit("whatsapp")) {
119
+ throw new Error(`Outbound rate limit exceeded for WhatsApp (max ${OUTBOUND_RATE_LIMIT_PER_HOUR}/hour)`);
120
+ }
121
+ const { getAccountByName, getDefaultAccount } = await import("./whatsapp-accounts-BWRZUY23.js");
122
+ const account = params.account ? getAccountByName(params.account) : getDefaultAccount();
123
+ if (!account) {
124
+ throw new Error(
125
+ `No WhatsApp account found${params.account ? ` (${params.account})` : ""}`
126
+ );
127
+ }
128
+ const to = params.to ?? params.recipient;
129
+ const message = params.message ?? params.text;
130
+ if (!to || !message)
131
+ throw new Error("send_whatsapp requires 'to' and 'message' params");
132
+ const url = `https://graph.facebook.com/${GRAPH_API_VERSION}/${account.phoneNumberId}/messages`;
133
+ const res = await fetch(url, {
134
+ method: "POST",
135
+ headers: {
136
+ "Content-Type": "application/json",
137
+ Authorization: `Bearer ${account.accessToken}`
138
+ },
139
+ body: JSON.stringify({
140
+ messaging_product: "whatsapp",
141
+ to,
142
+ type: "text",
143
+ text: { body: message }
144
+ }),
145
+ signal: AbortSignal.timeout(3e4)
146
+ });
147
+ if (!res.ok) {
148
+ const errBody = await res.text();
149
+ throw new Error(`WhatsApp send failed (${res.status}): ${errBody}`);
150
+ }
151
+ }
152
+ async function executeSendMessage(params) {
153
+ const { sendMessage } = await import("./lib/messaging.js");
154
+ const { getCoordinatorName } = await import("./lib/employees.js");
155
+ const rawTo = params.to ?? params.recipient;
156
+ const to = rawTo === "coordinator" ? getCoordinatorName() : rawTo;
157
+ const content = params.message ?? params.content ?? params.text;
158
+ if (!to || !content)
159
+ throw new Error("send_message requires 'to' and 'message' params");
160
+ await sendMessage({
161
+ fromAgent: params.from ?? "trigger-engine",
162
+ targetAgent: to,
163
+ content,
164
+ priority: params.priority ?? "normal"
165
+ });
166
+ }
167
+ async function executeCreateTask(params) {
168
+ const { createTask } = await import("./lib/tasks.js");
169
+ const { getCoordinatorName } = await import("./lib/employees.js");
170
+ const rawAssignedTo = params.assigned_to;
171
+ await createTask({
172
+ title: params.title ?? "Triggered task",
173
+ assignedTo: !rawAssignedTo || rawAssignedTo === "coordinator" ? getCoordinatorName() : rawAssignedTo,
174
+ assignedBy: "trigger-engine",
175
+ projectName: params.project ?? "exe-os",
176
+ priority: params.priority ?? "p1",
177
+ context: params.context ?? params.description ?? "",
178
+ baseDir: process.cwd()
179
+ });
180
+ }
181
+ async function executeUpdateWiki(params) {
182
+ const apiUrl = process.env.EXE_WIKI_API_URL;
183
+ const apiKey = process.env.EXE_WIKI_API_KEY;
184
+ if (!apiUrl || !apiKey) {
185
+ throw new Error("Wiki not configured: EXE_WIKI_API_URL / EXE_WIKI_API_KEY not set");
186
+ }
187
+ const workspace = params.workspace;
188
+ const content = params.content ?? params.text;
189
+ const mode = params.mode ?? "append";
190
+ const section = params.section;
191
+ if (!workspace || !content) {
192
+ throw new Error("update_wiki requires 'workspace' and 'content' params");
193
+ }
194
+ const documentId = params.document_id;
195
+ if (documentId && mode === "append") {
196
+ const readRes = await fetch(`${apiUrl}/v1/document/${documentId}`, {
197
+ headers: { Authorization: `Bearer ${apiKey}` },
198
+ signal: AbortSignal.timeout(15e3)
199
+ });
200
+ if (!readRes.ok) {
201
+ throw new Error(`Wiki read failed (${readRes.status})`);
202
+ }
203
+ const doc = await readRes.json();
204
+ const existingContent = String(doc.content ?? "");
205
+ const title = String(doc.title ?? "Untitled");
206
+ await fetch(`${apiUrl}/v1/document/${documentId}`, {
207
+ method: "DELETE",
208
+ headers: { Authorization: `Bearer ${apiKey}` },
209
+ signal: AbortSignal.timeout(15e3)
210
+ }).catch((err) => {
211
+ process.stderr.write(`[trigger-engine] wiki purge failed: ${err instanceof Error ? err.message : String(err)}
212
+ `);
213
+ });
214
+ const uploadRes = await fetch(`${apiUrl}/v1/document/raw-text`, {
215
+ method: "POST",
216
+ headers: {
217
+ "Content-Type": "application/json",
218
+ Authorization: `Bearer ${apiKey}`
219
+ },
220
+ body: JSON.stringify({
221
+ textContent: section ? existingContent + `
222
+
223
+ ## ${section}
224
+ ${content}` : existingContent + "\n\n" + content,
225
+ metadata: { title },
226
+ workspaceSlugs: [workspace]
227
+ }),
228
+ signal: AbortSignal.timeout(15e3)
229
+ });
230
+ if (!uploadRes.ok) throw new Error(`Wiki upload failed (${uploadRes.status})`);
231
+ } else {
232
+ const title = params.title ?? "Auto-generated";
233
+ const res = await fetch(`${apiUrl}/v1/document/raw-text`, {
234
+ method: "POST",
235
+ headers: {
236
+ "Content-Type": "application/json",
237
+ Authorization: `Bearer ${apiKey}`
238
+ },
239
+ body: JSON.stringify({
240
+ textContent: content,
241
+ metadata: { title },
242
+ workspaceSlugs: [workspace]
243
+ }),
244
+ signal: AbortSignal.timeout(15e3)
245
+ });
246
+ if (!res.ok) throw new Error(`Wiki create failed (${res.status})`);
247
+ }
248
+ }
249
+ async function routeToApproval(action, resolvedParams, triggerName) {
250
+ const { createTask } = await import("./lib/tasks.js");
251
+ const { getCoordinatorName } = await import("./lib/employees.js");
252
+ const actionSummary = action.type === "send_whatsapp" ? `Send WhatsApp to ${resolvedParams.to ?? resolvedParams.recipient ?? "unknown"}: "${(resolvedParams.message ?? resolvedParams.text ?? "").slice(0, 100)}"` : `${action.type}: ${JSON.stringify(resolvedParams).slice(0, 200)}`;
253
+ await createTask({
254
+ title: `[Approval Required] ${triggerName}: ${action.type}`,
255
+ assignedTo: getCoordinatorName(),
256
+ assignedBy: "trigger-engine",
257
+ projectName: resolvedParams.project ?? "exe-os",
258
+ priority: "p1",
259
+ context: `Trigger "${triggerName}" wants to execute this action but requires approval.
260
+
261
+ **Action:** ${action.type}
262
+ **Summary:** ${actionSummary}
263
+ **Full params:** ${JSON.stringify(resolvedParams, null, 2)}
264
+
265
+ To approve, manually run the action via MCP tools.`,
266
+ baseDir: process.cwd()
267
+ });
268
+ }
269
+ async function executeAction(action, record, executor, triggerName) {
270
+ if (executor) {
271
+ return executor(action, record);
272
+ }
273
+ const resolvedParams = {};
274
+ for (const [key, val] of Object.entries(action.params)) {
275
+ resolvedParams[key] = sanitizeParam(substituteTemplate(val, record));
276
+ }
277
+ if (action.requires_approval) {
278
+ try {
279
+ await routeToApproval(action, resolvedParams, triggerName ?? "Unknown trigger");
280
+ return { success: true };
281
+ } catch (err) {
282
+ return {
283
+ success: false,
284
+ error: `Approval routing failed: ${err instanceof Error ? err.message : String(err)}`
285
+ };
286
+ }
287
+ }
288
+ try {
289
+ switch (action.type) {
290
+ case "send_whatsapp":
291
+ await executeSendWhatsapp(resolvedParams);
292
+ break;
293
+ case "send_message":
294
+ await executeSendMessage(resolvedParams);
295
+ break;
296
+ case "create_task":
297
+ await executeCreateTask(resolvedParams);
298
+ break;
299
+ case "update_wiki":
300
+ await executeUpdateWiki(resolvedParams);
301
+ break;
302
+ case "asana": {
303
+ const { loadAsanaConfig, executeAsanaOperation } = await import("./asana-MRQ2OQMJ.js");
304
+ const asanaConfig = loadAsanaConfig();
305
+ if (!asanaConfig) throw new Error("Asana not configured: set ASANA_API_TOKEN env var");
306
+ const operation = resolvedParams.operation ?? resolvedParams._operation;
307
+ if (!operation) throw new Error("asana action requires 'operation' param");
308
+ await executeAsanaOperation(asanaConfig, operation, resolvedParams);
309
+ break;
310
+ }
311
+ case "mcp_tool":
312
+ console.log(
313
+ `[trigger-engine] mcp_tool action: ${JSON.stringify(resolvedParams)}`
314
+ );
315
+ break;
316
+ }
317
+ return { success: true };
318
+ } catch (err) {
319
+ return {
320
+ success: false,
321
+ error: err instanceof Error ? err.message : String(err)
322
+ };
323
+ }
324
+ }
325
+ async function processCRMEvent(event, executor, triggersOverride) {
326
+ if (_currentTriggerDepth >= MAX_TRIGGER_DEPTH) {
327
+ console.error(
328
+ `[trigger-engine] Recursion limit (${MAX_TRIGGER_DEPTH}) reached \u2014 skipping event ${event.objectType}.${event.eventType}`
329
+ );
330
+ return [];
331
+ }
332
+ _currentTriggerDepth++;
333
+ try {
334
+ return await _processCRMEventInner(event, executor, triggersOverride);
335
+ } finally {
336
+ _currentTriggerDepth--;
337
+ }
338
+ }
339
+ async function _processCRMEventInner(event, executor, triggersOverride) {
340
+ const eventString = `${event.objectType}.${event.eventType}`;
341
+ const triggers = triggersOverride ?? loadTriggers();
342
+ const logs = [];
343
+ for (const trigger of triggers) {
344
+ if (!trigger.enabled) continue;
345
+ if (trigger.event !== eventString && trigger.event !== "*") continue;
346
+ if (!evaluateConditions(trigger.conditions, event.record)) continue;
347
+ const actionResults = [];
348
+ for (const action of trigger.actions) {
349
+ const result = await executeAction(action, event.record, executor, trigger.name);
350
+ actionResults.push({
351
+ type: action.type,
352
+ success: result.success,
353
+ error: result.error
354
+ });
355
+ }
356
+ const log = {
357
+ triggerId: trigger.id,
358
+ triggerName: trigger.name,
359
+ event: eventString,
360
+ firedAt: (/* @__PURE__ */ new Date()).toISOString(),
361
+ actionsExecuted: actionResults
362
+ };
363
+ logs.push(log);
364
+ console.log(
365
+ `[trigger-engine] Fired "${trigger.name}" on ${eventString}: ${actionResults.filter((a) => a.success).length}/${actionResults.length} actions succeeded`
366
+ );
367
+ }
368
+ return logs;
369
+ }
370
+ function isScheduledTrigger(trigger) {
371
+ return "schedule" in trigger && "query" in trigger;
372
+ }
373
+
374
+ export {
375
+ sanitizeParam,
376
+ substituteTemplate,
377
+ loadTriggers,
378
+ createNewTrigger,
379
+ executeAction,
380
+ processCRMEvent,
381
+ isScheduledTrigger
382
+ };