@askexenow/exe-os 0.9.265 → 0.9.267

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 (384) hide show
  1. package/deploy/compose/.env.example +4 -2
  2. package/deploy/compose/docker-compose.yml +6 -4
  3. package/deploy/compose/generate-env.ts +5 -2
  4. package/dist/active-agent-2XJJZFEW.js +25 -0
  5. package/dist/active-agent-JZ4PHIAK.js +26 -0
  6. package/dist/agentic-ontology-J4B525DT.js +25 -0
  7. package/dist/backfill-metadata-TWEC6BJD.js +597 -0
  8. package/dist/backfill-metadata-VGZLCJWZ.js +597 -0
  9. package/dist/backfill-metadata-Y6EABP6Q.js +597 -0
  10. package/dist/behaviors-BPIVFAGY.js +25 -0
  11. package/dist/bin/agentic-ontology-backfill.js +5 -5
  12. package/dist/bin/agentic-reflection-backfill.js +6 -6
  13. package/dist/bin/agentic-semantic-label.js +5 -5
  14. package/dist/bin/backfill-conversations.js +4 -4
  15. package/dist/bin/backfill-responses.js +4 -4
  16. package/dist/bin/backfill-vectors.js +5 -5
  17. package/dist/bin/bulk-sync-postgres.js +6 -6
  18. package/dist/bin/cc-doctor.js +6 -1
  19. package/dist/bin/cleanup-stale-review-tasks.js +9 -9
  20. package/dist/bin/cli.js +15 -15
  21. package/dist/bin/exe-agent-config.js +2 -2
  22. package/dist/bin/exe-agent.js +4 -4
  23. package/dist/bin/exe-assign.js +5 -5
  24. package/dist/bin/exe-boot.js +16 -16
  25. package/dist/bin/exe-call.js +4 -4
  26. package/dist/bin/exe-cloud.js +4 -4
  27. package/dist/bin/exe-dispatch.js +9 -9
  28. package/dist/bin/exe-doctor.js +1 -1
  29. package/dist/bin/exe-export-behaviors.js +7 -7
  30. package/dist/bin/exe-forget.js +6 -6
  31. package/dist/bin/exe-gateway.js +7 -7
  32. package/dist/bin/exe-healthcheck.js +6 -1
  33. package/dist/bin/exe-heartbeat.js +9 -9
  34. package/dist/bin/exe-kill.js +12 -12
  35. package/dist/bin/exe-launch-agent.js +16 -16
  36. package/dist/bin/exe-new-employee.js +6 -6
  37. package/dist/bin/exe-pending-messages.js +10 -10
  38. package/dist/bin/exe-pending-notifications.js +9 -9
  39. package/dist/bin/exe-pending-reviews.js +9 -9
  40. package/dist/bin/exe-rename.js +4 -4
  41. package/dist/bin/exe-review.js +11 -11
  42. package/dist/bin/exe-search.js +5 -5
  43. package/dist/bin/exe-session-cleanup.js +14 -14
  44. package/dist/bin/exe-settings.js +4 -4
  45. package/dist/bin/exe-start-codex.js +11 -11
  46. package/dist/bin/exe-start-opencode.js +8 -8
  47. package/dist/bin/exe-status.js +10 -10
  48. package/dist/bin/exe-team.js +3 -3
  49. package/dist/bin/git-sweep.js +10 -10
  50. package/dist/bin/graph-backfill.js +4 -4
  51. package/dist/bin/graph-export.js +5 -5
  52. package/dist/bin/import-history.js +7 -7
  53. package/dist/bin/install.js +6 -6
  54. package/dist/bin/intercom-check.js +4 -4
  55. package/dist/bin/mcp-sessions.js +2 -2
  56. package/dist/bin/orchestration-metrics.js +4 -4
  57. package/dist/bin/postgres-agentic-reflection-backfill.js +2 -2
  58. package/dist/bin/postgres-agentic-semantic-backfill.js +1 -1
  59. package/dist/bin/scan-tasks.js +9 -9
  60. package/dist/bin/setup.js +1 -1
  61. package/dist/bin/shard-migrate.js +5 -5
  62. package/dist/capacity-monitor-3QORC56J.js +49 -0
  63. package/dist/capacity-monitor-FWRBCZCZ.js +49 -0
  64. package/dist/capacity-monitor-MTYXZ7Q2.js +49 -0
  65. package/dist/catchup-brief-242H63OP.js +151 -0
  66. package/dist/catchup-brief-KNX6L2EN.js +151 -0
  67. package/dist/catchup-brief-T7W2ARRB.js +151 -0
  68. package/dist/catchup-brief-VJDLXJHJ.js +151 -0
  69. package/dist/chunk-2B6FH2QM.js +3951 -0
  70. package/dist/chunk-2FDYA3GS.js +75 -0
  71. package/dist/chunk-2V33IVZF.js +1148 -0
  72. package/dist/chunk-2W5NQOQJ.js +333 -0
  73. package/dist/chunk-32QR5EHE.js +244 -0
  74. package/dist/chunk-3DBROKA6.js +382 -0
  75. package/dist/chunk-3DS2YHAT.js +204 -0
  76. package/dist/chunk-3GP2QTXT.js +128 -0
  77. package/dist/chunk-3O2ZD7YV.js +227 -0
  78. package/dist/chunk-3Q2VWYTA.js +89 -0
  79. package/dist/chunk-43O2PZH7.js +214 -0
  80. package/dist/chunk-4AHL6I7X.js +284 -0
  81. package/dist/chunk-53IGC63J.js +54 -0
  82. package/dist/chunk-5GBPXJIH.js +50 -0
  83. package/dist/chunk-5IXN2532.js +58 -0
  84. package/dist/chunk-5KHVSGHP.js +330 -0
  85. package/dist/chunk-5SH5TR45.js +731 -0
  86. package/dist/chunk-5XGMTWKW.js +128 -0
  87. package/dist/chunk-6AQAILCS.js +13696 -0
  88. package/dist/chunk-6EIBIA3E.js +13696 -0
  89. package/dist/chunk-6KGRRZDA.js +81 -0
  90. package/dist/chunk-72KQJZBH.js +382 -0
  91. package/dist/chunk-7B2AENJ3.js +1345 -0
  92. package/dist/chunk-7GKMYFVR.js +551 -0
  93. package/dist/chunk-7HUGVJHW.js +1021 -0
  94. package/dist/chunk-7HWBGXDV.js +333 -0
  95. package/dist/chunk-7ROGPDW6.js +197 -0
  96. package/dist/chunk-7ZMLNURG.js +513 -0
  97. package/dist/chunk-A3G4UXNA.js +280 -0
  98. package/dist/chunk-A4T6U3XZ.js +371 -0
  99. package/dist/chunk-ADJNRFEK.js +13696 -0
  100. package/dist/chunk-AVJTW67M.js +513 -0
  101. package/dist/chunk-B6RC7DAC.js +1090 -0
  102. package/dist/chunk-BAOJLZVC.js +244 -0
  103. package/dist/chunk-BCUMPA7J.js +159 -0
  104. package/dist/chunk-BH2ST7KK.js +183 -0
  105. package/dist/chunk-C4BIYP5C.js +129 -0
  106. package/dist/chunk-CBUZG6OC.js +89 -0
  107. package/dist/chunk-CGQRWCCP.js +81 -0
  108. package/dist/chunk-CLX4WQHT.js +214 -0
  109. package/dist/chunk-CM32SM3U.js +127 -0
  110. package/dist/chunk-D4CQZL46.js +76 -0
  111. package/dist/chunk-DEBLYXA2.js +56 -0
  112. package/dist/chunk-E45SYT7G.js +617 -0
  113. package/dist/chunk-EDNUE5L3.js +38 -0
  114. package/dist/chunk-EMTXM73F.js +333 -0
  115. package/dist/chunk-ESNHLTLC.js +1073 -0
  116. package/dist/chunk-FICUAZEA.js +128 -0
  117. package/dist/chunk-FP6U5PSY.js +818 -0
  118. package/dist/chunk-G4WZIPDM.js +1921 -0
  119. package/dist/chunk-G55UTKFR.js +89 -0
  120. package/dist/chunk-GIJUXLK5.js +330 -0
  121. package/dist/chunk-GVSSEGIV.js +348 -0
  122. package/dist/chunk-GYOOZ725.js +330 -0
  123. package/dist/chunk-GZ3NZDS5.js +1090 -0
  124. package/dist/chunk-HCULUL4D.js +447 -0
  125. package/dist/chunk-HDRQKH7R.js +1051 -0
  126. package/dist/chunk-HHBN7Y7R.js +197 -0
  127. package/dist/chunk-IP7YSYZB.js +1073 -0
  128. package/dist/chunk-IQBXQ7GF.js +1073 -0
  129. package/dist/chunk-ITF6GEJI.js +2091 -0
  130. package/dist/chunk-IUY6I2CH.js +1148 -0
  131. package/dist/chunk-IXHVSWLM.js +58 -0
  132. package/dist/chunk-IXUGRCIM.js +58 -0
  133. package/dist/chunk-J3ZFONT4.js +1921 -0
  134. package/dist/chunk-JEOFG274.js +394 -0
  135. package/dist/chunk-JH7ISOIJ.js +33 -0
  136. package/dist/chunk-JVRMAVPN.js +731 -0
  137. package/dist/chunk-KBYRYSXT.js +3951 -0
  138. package/dist/chunk-KECNXWD6.js +1051 -0
  139. package/dist/chunk-KI5HUHVX.js +171 -0
  140. package/dist/chunk-KIYCHS35.js +128 -0
  141. package/dist/chunk-KUP3D6G2.js +1345 -0
  142. package/dist/chunk-KXS5HHDH.js +54 -0
  143. package/dist/chunk-LNY2DMEX.js +50 -0
  144. package/dist/chunk-LSI363EB.js +284 -0
  145. package/dist/chunk-LVZW4WQY.js +221 -0
  146. package/dist/chunk-LWOCCDSB.js +240 -0
  147. package/dist/chunk-M4HRKRSE.js +30 -0
  148. package/dist/chunk-MPG5DR3K.js +244 -0
  149. package/dist/chunk-NOG2LVBA.js +159 -0
  150. package/dist/chunk-NP3CYOEY.js +290 -0
  151. package/dist/chunk-OM5524LQ.js +204 -0
  152. package/dist/chunk-ONMXLCZ7.js +495 -0
  153. package/dist/chunk-OVQOKLYA.js +210 -0
  154. package/dist/chunk-OW26ML36.js +1148 -0
  155. package/dist/chunk-OZPTYL2D.js +244 -0
  156. package/dist/chunk-P2DOIWQG.js +260 -0
  157. package/dist/chunk-P2QTTEYP.js +3951 -0
  158. package/dist/chunk-P5IKFL7B.js +85 -0
  159. package/dist/chunk-PD2LUPHD.js +377 -0
  160. package/dist/chunk-PF5EFIAH.js +818 -0
  161. package/dist/chunk-PK3NFO76.js +551 -0
  162. package/dist/chunk-Q4NVLQHH.js +76 -0
  163. package/dist/chunk-QKMFMJTU.js +171 -0
  164. package/dist/chunk-R3ERWIOH.js +197 -0
  165. package/dist/chunk-R3FOMRWJ.js +731 -0
  166. package/dist/chunk-R77M74QM.js +13696 -0
  167. package/dist/chunk-RHZ2CRJU.js +3556 -0
  168. package/dist/chunk-RLR4LVO5.js +1090 -0
  169. package/dist/chunk-RMDDSWFH.js +495 -0
  170. package/dist/chunk-RPLEZ74B.js +95 -0
  171. package/dist/chunk-RXMVPGH2.js +346 -0
  172. package/dist/chunk-S2ARWNS6.js +135 -0
  173. package/dist/chunk-SHPIATX7.js +90 -0
  174. package/dist/chunk-SQUZ3TI2.js +668 -0
  175. package/dist/chunk-SUGBKORD.js +1148 -0
  176. package/dist/chunk-T2XD7XL2.js +346 -0
  177. package/dist/chunk-TAIYLROT.js +127 -0
  178. package/dist/chunk-TCD4XCBS.js +495 -0
  179. package/dist/chunk-TEVTA7JX.js +551 -0
  180. package/dist/chunk-TQVS4W2Y.js +346 -0
  181. package/dist/chunk-TSBMSHMM.js +163 -0
  182. package/dist/chunk-U776PBU6.js +488 -0
  183. package/dist/chunk-UQ27GW5L.js +377 -0
  184. package/dist/chunk-UQMIBSN4.js +159 -0
  185. package/dist/chunk-UTVNIAOF.js +284 -0
  186. package/dist/chunk-VF6VT4MR.js +70 -0
  187. package/dist/chunk-VZXLYUKS.js +171 -0
  188. package/dist/chunk-WHATWGUZ.js +447 -0
  189. package/dist/chunk-WIAHPJDS.js +58 -0
  190. package/dist/chunk-WM5ELLT4.js +54 -0
  191. package/dist/chunk-WUUSPOCC.js +1921 -0
  192. package/dist/chunk-WXHAMPK4.js +81 -0
  193. package/dist/chunk-WYNZ23XH.js +262 -0
  194. package/dist/chunk-WZOQLU2Y.js +127 -0
  195. package/dist/chunk-X24GBZKR.js +157 -0
  196. package/dist/chunk-X5FRF5MG.js +13696 -0
  197. package/dist/chunk-XBPLYFBA.js +204 -0
  198. package/dist/chunk-XDGKFXFW.js +363 -0
  199. package/dist/chunk-XIT6ONPY.js +630 -0
  200. package/dist/chunk-XK66XNN3.js +818 -0
  201. package/dist/chunk-XNRJ5JHU.js +377 -0
  202. package/dist/chunk-XREWTPZM.js +123 -0
  203. package/dist/chunk-XURCA5VD.js +297 -0
  204. package/dist/chunk-Y55VFZJB.js +50 -0
  205. package/dist/chunk-Y5SXCVET.js +214 -0
  206. package/dist/chunk-YIH2YMWP.js +76 -0
  207. package/dist/chunk-YZMCCT73.js +97 -0
  208. package/dist/chunk-Z4476ZEZ.js +513 -0
  209. package/dist/chunk-Z7VAUKRU.js +1345 -0
  210. package/dist/chunk-ZCDGAH7H.js +382 -0
  211. package/dist/chunk-ZTP3VV23.js +447 -0
  212. package/dist/co-activation-JOYR73H2.js +72 -0
  213. package/dist/co-occurrence-G7RRJ3DB.js +74 -0
  214. package/dist/core-memory-6KK55Z65.js +110 -0
  215. package/dist/core-memory-DRYQWHJU.js +110 -0
  216. package/dist/core-memory-QRS6GBXL.js +110 -0
  217. package/dist/crdt-sync-QWK65Z5A.js +33 -0
  218. package/dist/crm-webhook-BNUS3USD.js +10 -0
  219. package/dist/crm-webhook-BSN4TCCY.js +10 -0
  220. package/dist/crm-webhook-ZTIRFVAH.js +10 -0
  221. package/dist/cto-delegation-gate-DNZJGBS7.js +206 -0
  222. package/dist/cto-delegation-gate-IPQBZ3J2.js +206 -0
  223. package/dist/cto-delegation-gate-YI3LK7VY.js +206 -0
  224. package/dist/daemon-orchestration-6TIV6MMN.js +135 -0
  225. package/dist/daemon-orchestration-7LVOHYKA.js +135 -0
  226. package/dist/daemon-orchestration-SDQNWI3K.js +135 -0
  227. package/dist/db-backup-5ENHDNZI.js +33 -0
  228. package/dist/dreaming-5S4SSUIU.js +32 -0
  229. package/dist/dreaming-PGJOCGAM.js +32 -0
  230. package/dist/dreaming-UNHHGOU3.js +32 -0
  231. package/dist/exe-drift-QQJMUQXA.js +68 -0
  232. package/dist/exe-export-BEZZSQB4.js +73 -0
  233. package/dist/exe-export-JJJJDQE3.js +73 -0
  234. package/dist/exe-export-TQGI2VBT.js +73 -0
  235. package/dist/exe-import-2SR2UP3D.js +76 -0
  236. package/dist/exe-import-73Q4VLFK.js +76 -0
  237. package/dist/exe-import-G7VIUGLR.js +76 -0
  238. package/dist/exe-key-6JHEINOM.js +579 -0
  239. package/dist/exe-key-JS7OSDJP.js +579 -0
  240. package/dist/exe-key-RIRPIFK6.js +579 -0
  241. package/dist/exe-snapshot-DSPO4HHJ.js +164 -0
  242. package/dist/exe-snapshot-NDMDQJOH.js +164 -0
  243. package/dist/exe-snapshot-PVCBPMPJ.js +164 -0
  244. package/dist/fast-db-init-22OBOPTN.js +7 -0
  245. package/dist/fast-db-init-M6ZYYGAL.js +7 -0
  246. package/dist/fast-db-init-VLF46DR3.js +7 -0
  247. package/dist/gateway/index.js +8 -8
  248. package/dist/git-staleness-4DGYC3RY.js +110 -0
  249. package/dist/git-task-sweep-CUR7R2ZM.js +40 -0
  250. package/dist/git-task-sweep-VO2DVEXY.js +40 -0
  251. package/dist/git-task-sweep-YG3IVGK3.js +40 -0
  252. package/dist/global-procedures-TYDNKM7V.js +20 -0
  253. package/dist/graph-auto-extract-I6B5HWTP.js +162 -0
  254. package/dist/hooks/bug-report-worker.js +11 -11
  255. package/dist/hooks/codex-stop-task-finalizer.js +11 -11
  256. package/dist/hooks/commit-complete.js +11 -11
  257. package/dist/hooks/error-recall.js +6 -6
  258. package/dist/hooks/exe-heartbeat-hook.js +3 -3
  259. package/dist/hooks/ingest.js +6 -6
  260. package/dist/hooks/instructions-loaded.js +4 -4
  261. package/dist/hooks/manifest.json +19 -19
  262. package/dist/hooks/notification.js +4 -4
  263. package/dist/hooks/post-compact.js +10 -10
  264. package/dist/hooks/post-tool-combined.js +5 -5
  265. package/dist/hooks/pre-compact.js +11 -11
  266. package/dist/hooks/pre-tool-use.js +14 -14
  267. package/dist/hooks/prompt-submit.js +20 -20
  268. package/dist/hooks/session-end.js +15 -15
  269. package/dist/hooks/session-start.js +10 -10
  270. package/dist/hooks/stop.js +14 -14
  271. package/dist/hooks/subagent-stop.js +10 -10
  272. package/dist/hooks/summary-worker.js +14 -14
  273. package/dist/index.js +17 -17
  274. package/dist/installer-4LP73C3M.js +38 -0
  275. package/dist/installer-AUVLNS4D.js +296 -0
  276. package/dist/installer-KCRLQSQH.js +38 -0
  277. package/dist/installer-KGXYUOIV.js +296 -0
  278. package/dist/installer-UI6TNJGO.js +342 -0
  279. package/dist/installer-Z7NPD4PD.js +342 -0
  280. package/dist/lib/cloud-sync.js +4 -4
  281. package/dist/lib/consolidation.js +5 -5
  282. package/dist/lib/database.js +2 -2
  283. package/dist/lib/db-daemon-client.js +6 -0
  284. package/dist/lib/db.js +2 -2
  285. package/dist/lib/employee-templates.js +4 -4
  286. package/dist/lib/employees.js +2 -2
  287. package/dist/lib/exe-daemon.js +41 -40
  288. package/dist/lib/hybrid-search.js +5 -5
  289. package/dist/lib/identity.js +2 -2
  290. package/dist/lib/messaging.js +9 -9
  291. package/dist/lib/reminders.js +3 -3
  292. package/dist/lib/schedules.js +5 -5
  293. package/dist/lib/session-registry.js +4 -4
  294. package/dist/lib/skill-learning.js +4 -4
  295. package/dist/lib/store.js +4 -4
  296. package/dist/lib/task-router.js +3 -3
  297. package/dist/lib/tasks.js +10 -10
  298. package/dist/lib/tmux-routing.js +8 -8
  299. package/dist/lib/token-spend.js +3 -3
  300. package/dist/mcp/register-tools.js +53 -52
  301. package/dist/mcp/server.js +54 -53
  302. package/dist/mcp/tools/complete-reminder.js +4 -4
  303. package/dist/mcp/tools/create-reminder.js +4 -4
  304. package/dist/mcp/tools/create-task.js +12 -12
  305. package/dist/mcp/tools/deactivate-behavior.js +5 -5
  306. package/dist/mcp/tools/list-reminders.js +4 -4
  307. package/dist/mcp/tools/list-tasks.js +12 -12
  308. package/dist/mcp/tools/send-message.js +11 -11
  309. package/dist/mcp/tools/update-task.js +11 -11
  310. package/dist/mcp-http-config-LN5ITKGS.js +27 -0
  311. package/dist/mcp-http-config-V43VHNEH.js +27 -0
  312. package/dist/memory-cards-S36DCEY4.js +174 -0
  313. package/dist/memory-graph-extractor-66YL4V4B.js +17 -0
  314. package/dist/memory-poisoning-defense-MXWE6CTY.js +225 -0
  315. package/dist/memory-reflection-W676LUX5.js +238 -0
  316. package/dist/notifications-NGKMOBKL.js +45 -0
  317. package/dist/notifications-OFLXZTDZ.js +45 -0
  318. package/dist/notifications-XAV4V7T5.js +45 -0
  319. package/dist/orchestration-events-MJLWJ2H2.js +25 -0
  320. package/dist/orchestrator-6MKGTKN7.js +33 -0
  321. package/dist/orchestrator-AIAKV5ST.js +33 -0
  322. package/dist/orchestrator-VK7D6I36.js +33 -0
  323. package/dist/pipeline-router-DXH5QVUH.js +13 -0
  324. package/dist/pipeline-router-EV6C5S33.js +13 -0
  325. package/dist/pipeline-router-G65CQ5EE.js +13 -0
  326. package/dist/plan-limits-TQMLKZBG.js +26 -0
  327. package/dist/project-boot-4XTXHDG4.js +299 -0
  328. package/dist/projection-worker-NAYVNSI4.js +964 -0
  329. package/dist/reranker-KHZI7HQK.js +19 -0
  330. package/dist/reranker-O6QYMIEA.js +19 -0
  331. package/dist/reranker-UPMS3OX7.js +19 -0
  332. package/dist/reranker-ZN73HWSB.js +19 -0
  333. package/dist/review-polling-3UEZSPNT.js +124 -0
  334. package/dist/review-polling-KBDX3ILL.js +124 -0
  335. package/dist/review-polling-ZWOO7QQJ.js +124 -0
  336. package/dist/runtime/index.js +11 -11
  337. package/dist/session-events-2CHOLA6D.js +36 -0
  338. package/dist/session-events-HM22KEHN.js +36 -0
  339. package/dist/session-events-YIUYMJKP.js +36 -0
  340. package/dist/session-kill-telemetry-LUPVYGZX.js +29 -0
  341. package/dist/session-scope-EPZZZHHJ.js +86 -0
  342. package/dist/session-scope-KZ25NMH3.js +86 -0
  343. package/dist/session-scope-ZGE6GHMS.js +86 -0
  344. package/dist/setup-wizard-KNWH54HW.js +12 -0
  345. package/dist/shard-manager-GFKF4AKT.js +30 -0
  346. package/dist/skill-refinement-A5S4KCS4.js +157 -0
  347. package/dist/skill-refinement-C4GNWV4F.js +157 -0
  348. package/dist/skill-refinement-CAUIE4YM.js +157 -0
  349. package/dist/steward-gate-MZ2DV36N.js +13 -0
  350. package/dist/task-enforcement-6OMXG6EA.js +333 -0
  351. package/dist/task-enforcement-D5AP7KJM.js +333 -0
  352. package/dist/task-enforcement-JFSF6QDD.js +333 -0
  353. package/dist/task-scope-4HJSCJ7L.js +35 -0
  354. package/dist/task-scope-7HYE4AS6.js +35 -0
  355. package/dist/task-scope-MP32TKL3.js +35 -0
  356. package/dist/tasks-crud-JJL6MMJF.js +77 -0
  357. package/dist/tasks-crud-KMIPDHBZ.js +77 -0
  358. package/dist/tasks-crud-NOMD6R4W.js +77 -0
  359. package/dist/tasks-notify-5D6LF52K.js +38 -0
  360. package/dist/tasks-notify-J3L2URRG.js +38 -0
  361. package/dist/tasks-notify-JNGGXFUY.js +38 -0
  362. package/dist/tasks-review-N6I5UC7G.js +47 -0
  363. package/dist/tasks-review-USHAMO5N.js +47 -0
  364. package/dist/tasks-review-WO2Y7F6V.js +47 -0
  365. package/dist/telemetry-upload-BV2M2NND.js +739 -0
  366. package/dist/telemetry-upload-O6R7W4CV.js +739 -0
  367. package/dist/telemetry-upload-Y7QPDJW4.js +739 -0
  368. package/dist/token-budget-2LUZOFO7.js +84 -0
  369. package/dist/tool-telemetry-5JT6DPVK.js +17 -0
  370. package/dist/tui/App.js +16 -16
  371. package/dist/tui-data-DMAKZMGD.js +258 -0
  372. package/dist/tui-data-X7NI6ZQ3.js +258 -0
  373. package/dist/tui-data-Z3KQW37O.js +258 -0
  374. package/dist/wiki-acl-QHGGWX63.js +111 -0
  375. package/dist/worker-gate-3AUE4IZX.js +21 -0
  376. package/dist/worker-gate-4XKUOFWO.js +21 -0
  377. package/dist/worker-gate-TPZBOXOA.js +21 -0
  378. package/dist/workflow-engine-F3URLOPA.js +28 -0
  379. package/dist/workflow-engine-OFOL446Z.js +28 -0
  380. package/dist/workflow-engine-VNPPUSNL.js +28 -0
  381. package/dist/worktree-V3NVP7MV.js +26 -0
  382. package/dist/worktree-sweep-2CADL43Y.js +19 -0
  383. package/package.json +1 -1
  384. package/release-notes.json +32 -26
@@ -0,0 +1,89 @@
1
+ import {
2
+ getActiveAgent
3
+ } from "./chunk-BH2ST7KK.js";
4
+ import {
5
+ listTasks
6
+ } from "./chunk-P2QTTEYP.js";
7
+ import {
8
+ getAgentContext
9
+ } from "./chunk-GJV3WDWM.js";
10
+ import {
11
+ isCoordinatorName
12
+ } from "./chunk-RHZ2CRJU.js";
13
+
14
+ // src/mcp/tools/list-tasks.ts
15
+ import { z } from "zod";
16
+ function registerListTasks(server) {
17
+ server.registerTool(
18
+ "list_tasks",
19
+ {
20
+ title: "List Tasks",
21
+ description: "Query tasks by assignee, status, project, or priority. Defaults to current project. Pass project_name='all' for all projects. When querying your own tasks, project filter is skipped automatically.",
22
+ inputSchema: {
23
+ assigned_to: z.string().optional().describe("Filter by employee name"),
24
+ status: z.enum(["open", "in_progress", "done", "needs_review", "blocked", "cancelled", "closed"]).optional().describe("Filter by status. Default: active tasks only (excludes closed/cancelled)"),
25
+ project_name: z.string().optional().describe("Project name. Defaults to current project. Pass 'all' for all projects."),
26
+ priority: z.enum(["p0", "p1", "p2"]).optional().describe("Filter by priority"),
27
+ cross_session: z.boolean().optional().describe("When true, return tasks from ALL coordinator sessions (read-only). Default: false.")
28
+ }
29
+ },
30
+ async ({ assigned_to, status, project_name, priority, cross_session }) => {
31
+ try {
32
+ const { agentId } = getActiveAgent();
33
+ const isReviewQueue = status === "needs_review";
34
+ const shouldDefaultToOwnQueue = !assigned_to && !isReviewQueue && !isCoordinatorName(agentId);
35
+ const effectiveAssignedTo = assigned_to ?? (shouldDefaultToOwnQueue ? agentId : void 0);
36
+ const effectiveReviewer = !assigned_to && isReviewQueue ? agentId : void 0;
37
+ const isOwnQuery = effectiveAssignedTo === agentId;
38
+ const callerSession = getAgentContext()?.sessionHint || process.env.EXE_SESSION_NAME || process.env.EXE_SESSION || null;
39
+ const resolvedProject = project_name && project_name !== "all" ? project_name : null;
40
+ const effectiveCrossSession = cross_session === true;
41
+ const tasks = await listTasks({
42
+ assignedTo: effectiveAssignedTo,
43
+ reviewer: effectiveReviewer,
44
+ status,
45
+ projectName: resolvedProject,
46
+ priority,
47
+ crossSession: effectiveCrossSession,
48
+ isOwnQuery: !!isOwnQuery,
49
+ callerSession
50
+ });
51
+ if (tasks.length === 0) {
52
+ return {
53
+ content: [{ type: "text", text: "No tasks found." }]
54
+ };
55
+ }
56
+ const lines = tasks.map((t) => {
57
+ const cpIndicator = t.checkpointCount && t.checkpointCount > 0 ? ` [cp:${t.checkpointCount}]` : "";
58
+ let budgetNote = "";
59
+ if (t.budgetTokens !== null) {
60
+ const pct = Math.round(t.tokensUsed / t.budgetTokens * 100);
61
+ budgetNote = ` [${t.tokensUsed}/${t.budgetTokens} tokens, ${pct}%]`;
62
+ }
63
+ const shortId = t.id.slice(0, 8);
64
+ const sessionNote = cross_session && t.sessionScope ? ` [session:${t.sessionScope}]` : "";
65
+ return `- [${t.priority.toUpperCase()}] ${t.title} (${t.projectName}) \u2014 ${t.status}${cpIndicator}${budgetNote}${sessionNote} \u2192 ${t.assignedTo} [id:${shortId}]`;
66
+ });
67
+ return {
68
+ content: [
69
+ {
70
+ type: "text",
71
+ text: `${tasks.length} task(s):
72
+ ${lines.join("\n")}`
73
+ }
74
+ ]
75
+ };
76
+ } catch (err) {
77
+ const msg = err instanceof Error ? err.message : String(err);
78
+ return {
79
+ content: [{ type: "text", text: `Failed to list tasks: ${msg}` }],
80
+ isError: true
81
+ };
82
+ }
83
+ }
84
+ );
85
+ }
86
+
87
+ export {
88
+ registerListTasks
89
+ };
@@ -0,0 +1,81 @@
1
+ // src/bin/fast-db-init.ts
2
+ async function fastDbInit() {
3
+ const { isInitialized, getClient, setExternalClient } = await import("./lib/database.js");
4
+ if (isInitialized()) {
5
+ return getClient();
6
+ }
7
+ const forceDirect = process.env.EXE_DB_DIRECT === "1" || process.env.EXE_DB_READONLY === "1" || process.env.EXE_SKIP_DAEMON === "1";
8
+ if (!forceDirect) {
9
+ try {
10
+ const { connectEmbedDaemon, sendDaemonRequest, isClientConnected, disconnectClient } = await import("./lib/exe-daemon-client.js");
11
+ const { deserializeResultSet } = await import("./daemon-protocol-XW2OLNBS.js");
12
+ await Promise.race([
13
+ connectEmbedDaemon(),
14
+ new Promise((_, reject) => setTimeout(() => reject(new Error("Daemon socket timeout (2s)")), 2e3))
15
+ ]);
16
+ if (isClientConnected()) {
17
+ const daemonClient = {
18
+ async execute(stmt) {
19
+ const sql = typeof stmt === "string" ? stmt : stmt.sql;
20
+ const args = typeof stmt === "string" ? [] : Array.isArray(stmt.args) ? stmt.args : [];
21
+ const resp = await sendDaemonRequest({ type: "db-execute", sql, args });
22
+ if (resp.error) throw new Error(String(resp.error));
23
+ if (resp.db) return deserializeResultSet(resp.db);
24
+ throw new Error("Unexpected daemon response");
25
+ },
26
+ async batch(stmts, mode) {
27
+ const statements = stmts.map((s) => {
28
+ const sql = typeof s === "string" ? s : s.sql;
29
+ const args = typeof s === "string" ? [] : Array.isArray(s.args) ? s.args : [];
30
+ return { sql, args };
31
+ });
32
+ const resp = await sendDaemonRequest({ type: "db-batch", statements, mode: mode ?? "deferred" });
33
+ if (resp.error) throw new Error(String(resp.error));
34
+ const batchResults = resp["db-batch"];
35
+ if (batchResults) return batchResults.map(deserializeResultSet);
36
+ throw new Error("Unexpected daemon batch response");
37
+ },
38
+ async transaction(_mode) {
39
+ throw new Error("Transactions not supported via daemon socket");
40
+ },
41
+ async executeMultiple(_sql) {
42
+ throw new Error("executeMultiple not supported via daemon socket");
43
+ },
44
+ async migrate(_stmts) {
45
+ throw new Error("migrate not supported via daemon socket");
46
+ },
47
+ sync() {
48
+ return Promise.resolve(void 0);
49
+ },
50
+ close() {
51
+ },
52
+ get closed() {
53
+ return false;
54
+ },
55
+ get protocol() {
56
+ return "file";
57
+ }
58
+ };
59
+ try {
60
+ await daemonClient.execute("SELECT 1");
61
+ } catch {
62
+ try {
63
+ disconnectClient();
64
+ } catch {
65
+ }
66
+ throw new Error("Daemon socket validation failed");
67
+ }
68
+ setExternalClient(daemonClient);
69
+ return daemonClient;
70
+ }
71
+ } catch {
72
+ }
73
+ }
74
+ const { initStore } = await import("./lib/store.js");
75
+ await initStore({ lightweight: true });
76
+ return getClient();
77
+ }
78
+
79
+ export {
80
+ fastDbInit
81
+ };
@@ -0,0 +1,214 @@
1
+ import {
2
+ sessionScopeFilter
3
+ } from "./chunk-P2QTTEYP.js";
4
+
5
+ // src/lib/git-task-sweep.ts
6
+ import { execSync } from "child_process";
7
+ var DEFAULT_COMMIT_LIMIT = 50;
8
+ var DEFAULT_STALE_MINUTES = 10;
9
+ var AUTO_ESCALATE_THRESHOLD = 0.6;
10
+ var EXACT_UUID_SCORE = 1;
11
+ var TITLE_KEYWORD_SCORE = 0.5;
12
+ var FILE_PATH_SCORE = 0.3;
13
+ var MIN_KEYWORD_OVERLAP = 3;
14
+ var STOP_WORDS = /* @__PURE__ */ new Set([
15
+ "a",
16
+ "an",
17
+ "the",
18
+ "and",
19
+ "or",
20
+ "but",
21
+ "in",
22
+ "on",
23
+ "at",
24
+ "to",
25
+ "for",
26
+ "of",
27
+ "with",
28
+ "by",
29
+ "from",
30
+ "is",
31
+ "it",
32
+ "as",
33
+ "be",
34
+ "was",
35
+ "are",
36
+ "this",
37
+ "that",
38
+ "not",
39
+ "no",
40
+ "if",
41
+ "so",
42
+ "do",
43
+ "up"
44
+ ]);
45
+ function extractKeywords(text) {
46
+ return text.toLowerCase().replace(/[^a-z0-9\s-]/g, " ").split(/\s+/).filter((w) => w.length >= 3 && !STOP_WORDS.has(w));
47
+ }
48
+ function matchScore(task, commitMessage, changedFiles) {
49
+ if (task.id.length >= 8 && commitMessage.includes(task.id)) {
50
+ return EXACT_UUID_SCORE;
51
+ }
52
+ let score = 0;
53
+ const titleWords = extractKeywords(task.title);
54
+ const commitWords = new Set(extractKeywords(commitMessage));
55
+ const overlap = titleWords.filter((w) => commitWords.has(w));
56
+ if (overlap.length >= MIN_KEYWORD_OVERLAP) {
57
+ score += TITLE_KEYWORD_SCORE;
58
+ }
59
+ if (task.context && changedFiles.length > 0) {
60
+ const contextLower = task.context.toLowerCase();
61
+ const hasFileMatch = changedFiles.some(
62
+ (f) => contextLower.includes(f.toLowerCase())
63
+ );
64
+ if (hasFileMatch) {
65
+ score += FILE_PATH_SCORE;
66
+ }
67
+ }
68
+ return score;
69
+ }
70
+ function getRecentCommits(limit = DEFAULT_COMMIT_LIMIT) {
71
+ try {
72
+ const SEPARATOR = "<<SEP>>";
73
+ const output = execSync(
74
+ `git log --format="%h${SEPARATOR}%s${SEPARATOR}%aI" --name-only -n ${limit} -z`,
75
+ { encoding: "utf8", timeout: 1e4 }
76
+ );
77
+ const entries = output.split("\0").filter(Boolean);
78
+ const commits = [];
79
+ let current = null;
80
+ for (const entry of entries) {
81
+ if (entry.includes(SEPARATOR)) {
82
+ const lines = entry.split("\n");
83
+ const headerLine = lines[0];
84
+ const parts = headerLine.split(SEPARATOR);
85
+ if (parts.length >= 3) {
86
+ if (current) commits.push(current);
87
+ current = {
88
+ hash: parts[0],
89
+ message: parts[1],
90
+ files: lines.slice(1).filter(Boolean),
91
+ date: new Date(parts[2])
92
+ };
93
+ }
94
+ } else if (current) {
95
+ const files = entry.split("\n").filter(Boolean);
96
+ current.files.push(...files);
97
+ }
98
+ }
99
+ if (current) commits.push(current);
100
+ return commits;
101
+ } catch {
102
+ return [];
103
+ }
104
+ }
105
+ function isStale(updatedAt, staleMinutes) {
106
+ const updated = new Date(updatedAt).getTime();
107
+ const threshold = Date.now() - staleMinutes * 6e4;
108
+ return updated < threshold;
109
+ }
110
+ function findBestMatch(task, commits) {
111
+ let best = null;
112
+ for (const commit of commits) {
113
+ const score = matchScore(task, commit.message, commit.files);
114
+ if (score >= AUTO_ESCALATE_THRESHOLD && (!best || score > best.score)) {
115
+ best = { commit, score };
116
+ }
117
+ }
118
+ return best;
119
+ }
120
+ async function sweepTasks(projectName, options = {}) {
121
+ const commitLimit = options.commitLimit ?? DEFAULT_COMMIT_LIMIT;
122
+ const staleMinutes = options.staleMinutes ?? DEFAULT_STALE_MINUTES;
123
+ const dryRun = options.dryRun ?? false;
124
+ const result = { escalated: [], unchanged: 0, errors: [] };
125
+ const commits = getRecentCommits(commitLimit);
126
+ if (commits.length === 0) {
127
+ result.errors.push("No git commits found (not a git repo or empty history)");
128
+ return result;
129
+ }
130
+ let tasks;
131
+ try {
132
+ const { initStore } = await import("./lib/store.js");
133
+ await initStore();
134
+ const { getClient } = await import("./lib/database.js");
135
+ const client = getClient();
136
+ const conditions = ["status = 'in_progress'"];
137
+ const args = [];
138
+ if (projectName) {
139
+ conditions.push("project_name = ?");
140
+ args.push(projectName);
141
+ }
142
+ const swScope = sessionScopeFilter();
143
+ if (swScope.sql) {
144
+ conditions.push("(session_scope IS NULL OR session_scope = ?)");
145
+ args.push(...swScope.args);
146
+ }
147
+ const queryResult = await client.execute({
148
+ sql: `SELECT id, title, assigned_to, project_name, status, updated_at, context
149
+ FROM tasks WHERE ${conditions.join(" AND ")}
150
+ ORDER BY updated_at ASC`,
151
+ args
152
+ });
153
+ tasks = queryResult.rows.map((r) => ({
154
+ id: String(r.id),
155
+ title: String(r.title),
156
+ assignedTo: String(r.assigned_to),
157
+ projectName: String(r.project_name),
158
+ status: String(r.status),
159
+ updatedAt: String(r.updated_at),
160
+ context: r.context ? String(r.context) : void 0
161
+ }));
162
+ } catch (err) {
163
+ result.errors.push(`DB query failed: ${err instanceof Error ? err.message : String(err)}`);
164
+ return result;
165
+ }
166
+ if (tasks.length === 0) {
167
+ return result;
168
+ }
169
+ for (const task of tasks) {
170
+ if (!isStale(task.updatedAt, staleMinutes)) {
171
+ result.unchanged++;
172
+ continue;
173
+ }
174
+ const match = findBestMatch(task, commits);
175
+ if (!match) {
176
+ result.unchanged++;
177
+ continue;
178
+ }
179
+ if (!dryRun) {
180
+ try {
181
+ const { updateTaskStatus } = await import("./tasks-crud-KMIPDHBZ.js");
182
+ await updateTaskStatus({
183
+ taskId: task.id,
184
+ status: "needs_review",
185
+ result: `Auto-escalated by git-sweep: matching commit ${match.commit.hash} found (score: ${match.score.toFixed(2)})`
186
+ });
187
+ } catch (err) {
188
+ result.errors.push(
189
+ `Failed to escalate task ${task.id}: ${err instanceof Error ? err.message : String(err)}`
190
+ );
191
+ continue;
192
+ }
193
+ }
194
+ result.escalated.push({
195
+ taskId: task.id,
196
+ title: task.title,
197
+ matchedCommit: match.commit.hash,
198
+ score: match.score
199
+ });
200
+ process.stderr.write(
201
+ `[git-sweep] ${dryRun ? "WOULD escalate" : "Escalated"} task ${task.id} \u2192 commit ${match.commit.hash} (score: ${match.score.toFixed(2)})
202
+ `
203
+ );
204
+ }
205
+ return result;
206
+ }
207
+
208
+ export {
209
+ extractKeywords,
210
+ matchScore,
211
+ getRecentCommits,
212
+ findBestMatch,
213
+ sweepTasks
214
+ };
@@ -0,0 +1,127 @@
1
+ import {
2
+ updateTask
3
+ } from "./chunk-WHATWGUZ.js";
4
+ import {
5
+ TASK_ALREADY_CLAIMED_PREFIX
6
+ } from "./chunk-2B6FH2QM.js";
7
+
8
+ // src/mcp/tools/update-task.ts
9
+ import { z } from "zod";
10
+ function registerUpdateTask(server) {
11
+ server.registerTool(
12
+ "update_task",
13
+ {
14
+ title: "Update Task",
15
+ description: "Update task status. Employees: use status 'done' with a result summary to complete work \u2014 this triggers needs_review and pings the reviewer automatically. Accepts UUID, slug (filename), or title substring.",
16
+ inputSchema: {
17
+ task_id: z.string().describe("Task identifier \u2014 UUID, slug (e.g. 'fix-auth-bug'), or title substring"),
18
+ status: z.enum(["open", "in_progress", "done", "needs_review", "blocked", "cancelled", "closed"]).describe("New status. 'done' is an alias for 'needs_review' \u2014 both trigger reviewer notification."),
19
+ result: z.string().optional().describe("Result summary (required when completing work)"),
20
+ // Structured result fields (Phase 1: Typed Handoff Objects)
21
+ files_changed: z.array(z.string()).optional().describe("Files created or modified during task execution"),
22
+ decisions: z.array(z.string()).optional().describe("Key decisions made during execution"),
23
+ commits: z.array(z.string()).optional().describe("Commit hashes produced"),
24
+ tests_status: z.enum(["pass", "fail", "skip", "none"]).optional().describe("Test execution status"),
25
+ build_status: z.enum(["pass", "fail", "skip"]).optional().describe("Build status"),
26
+ pr_number: z.number().optional().describe("PR number if created"),
27
+ open_questions: z.array(z.string()).optional().describe("Open questions for reviewer"),
28
+ assertions: z.string().optional().describe(
29
+ 'JSON array of assertions with confidence scores. Use when starting work (in_progress). Format: [{"type":"diagnosis|scope|estimate|approach|build|judgment","claim":"...","confidence":0.8,"basis":"..."}]'
30
+ ),
31
+ assertions_resolved: z.string().optional().describe(
32
+ 'JSON array of resolved assertions. Use when completing work (done/needs_review). Format: [{"claim":"...","outcome":"correct|incorrect|partial","confidence_was":0.8,"actual":"...","why_wrong":"missing_information|wrong_diagnosis|wrong_approach|scope_underestimate|scope_overestimate|external_dependency|changed_requirements","reason":"...","lesson":"..."}]'
33
+ ),
34
+ estimated_minutes: z.number().optional().describe("Time estimate in minutes. Provide when starting work (in_progress). The system auto-computes actual time on completion."),
35
+ estimate_confidence: z.number().min(0).max(1).optional().describe("Confidence in time estimate (0.0-1.0). Provide alongside estimated_minutes.")
36
+ }
37
+ },
38
+ async ({ task_id, status: rawStatus, result, files_changed, decisions, commits, tests_status, build_status, pr_number, open_questions, assertions, assertions_resolved, estimated_minutes, estimate_confidence }) => {
39
+ const status = rawStatus;
40
+ let callerAgentId;
41
+ let callerSession;
42
+ try {
43
+ const { getActiveAgent: getAgent } = await import("./active-agent-2XJJZFEW.js");
44
+ callerAgentId = getAgent().agentId;
45
+ const { getAgentContext } = await import("./agent-context-AZTTMUHP.js");
46
+ callerSession = getAgentContext()?.sessionHint || process.env.EXE_SESSION_NAME || process.env.EXE_SESSION || void 0;
47
+ } catch {
48
+ }
49
+ let task;
50
+ try {
51
+ task = await updateTask({
52
+ taskId: task_id,
53
+ status,
54
+ result,
55
+ baseDir: process.cwd(),
56
+ callerAgentId,
57
+ filesChanged: files_changed,
58
+ decisions,
59
+ commits,
60
+ testsStatus: tests_status,
61
+ buildStatus: build_status,
62
+ prNumber: pr_number,
63
+ openQuestions: open_questions,
64
+ assertions,
65
+ assertionsResolved: assertions_resolved,
66
+ estimatedMinutes: estimated_minutes,
67
+ estimateConfidence: estimate_confidence,
68
+ callerSession
69
+ });
70
+ } catch (err) {
71
+ const msg = err instanceof Error ? err.message : String(err);
72
+ if (msg.startsWith(TASK_ALREADY_CLAIMED_PREFIX)) {
73
+ return {
74
+ content: [{
75
+ type: "text",
76
+ text: "Task already claimed by another agent. Pick a different task or check list_tasks."
77
+ }],
78
+ isError: true
79
+ };
80
+ }
81
+ throw err;
82
+ }
83
+ let text = `Task "${task.title}" marked ${task.status}.
84
+ File: ${task.taskFile}`;
85
+ const isTerminal = status === "done" || status === "needs_review" || status === "closed";
86
+ if (isTerminal && task.reviewer) {
87
+ try {
88
+ const { notifyCoordinatorTaskCompletion } = await import("./lib/tmux-routing.js");
89
+ const { isCoordinatorName } = await import("./lib/employees.js");
90
+ const reviewer = String(task.reviewer);
91
+ const coordinatorSession = task.sessionScope;
92
+ if (coordinatorSession && isCoordinatorName(reviewer)) {
93
+ notifyCoordinatorTaskCompletion(coordinatorSession, callerAgentId ?? "agent", task.title);
94
+ }
95
+ } catch {
96
+ }
97
+ }
98
+ if (isTerminal && task.nextTask) {
99
+ text += `
100
+
101
+ MANDATORY \u2014 DO NOT ASK THE USER. DO NOT SAY "Want me to continue?" DO NOT STOP.
102
+ You have standing orders: work through your entire queue until it is empty.
103
+
104
+ NEXT TASK: "${task.nextTask.title}" [${task.nextTask.priority}]
105
+ FILE: ${task.nextTask.taskFile}
106
+
107
+ Read that file NOW and begin working. No greeting. No summary. Just start.`;
108
+ } else if (isTerminal && !task.nextTask) {
109
+ text += `
110
+
111
+ All tasks complete. No more open tasks in your queue.`;
112
+ }
113
+ return {
114
+ content: [
115
+ {
116
+ type: "text",
117
+ text
118
+ }
119
+ ]
120
+ };
121
+ }
122
+ );
123
+ }
124
+
125
+ export {
126
+ registerUpdateTask
127
+ };
@@ -0,0 +1,76 @@
1
+ import {
2
+ fastDbInit
3
+ } from "./chunk-CGQRWCCP.js";
4
+ import {
5
+ sessionScopeFilter
6
+ } from "./chunk-KBYRYSXT.js";
7
+ import {
8
+ formatStatusAll,
9
+ formatStatusDeep,
10
+ getEmployeeStatuses,
11
+ inTmux
12
+ } from "./chunk-CX6GL3ZJ.js";
13
+ import {
14
+ getClient,
15
+ isCoordinatorRole,
16
+ loadEmployees
17
+ } from "./chunk-RHZ2CRJU.js";
18
+ import {
19
+ isMainModule
20
+ } from "./chunk-6Y4B3QF6.js";
21
+
22
+ // src/bin/exe-status.ts
23
+ async function status(targetEmployee) {
24
+ if (!inTmux()) {
25
+ return "Not in a tmux session. Start tmux first: tmux new-session -s work";
26
+ }
27
+ const employees = await loadEmployees();
28
+ const names = employees.filter((e) => !isCoordinatorRole(e.role)).map((e) => e.name);
29
+ const roles = new Map(employees.map((e) => [e.name, e.role ?? ""]));
30
+ await fastDbInit();
31
+ const client = getClient();
32
+ const taskMap = /* @__PURE__ */ new Map();
33
+ try {
34
+ const esScope = sessionScopeFilter();
35
+ const result = await client.execute({
36
+ sql: `SELECT assigned_to, title, priority FROM tasks
37
+ WHERE status = 'in_progress'${esScope.sql}
38
+ ORDER BY priority ASC, created_at ASC`,
39
+ args: [...esScope.args]
40
+ });
41
+ for (const row of result.rows) {
42
+ const assignee = String(row.assigned_to);
43
+ if (!taskMap.has(assignee)) {
44
+ taskMap.set(assignee, {
45
+ title: String(row.title),
46
+ priority: String(row.priority)
47
+ });
48
+ }
49
+ }
50
+ } catch {
51
+ }
52
+ if (targetEmployee) {
53
+ if (!names.includes(targetEmployee)) {
54
+ return `Employee "${targetEmployee}" not found. Available: ${names.join(", ")}`;
55
+ }
56
+ const statuses2 = getEmployeeStatuses([targetEmployee]);
57
+ const s = statuses2[0];
58
+ return formatStatusDeep(s, taskMap.get(targetEmployee), roles.get(targetEmployee) ?? "");
59
+ }
60
+ const statuses = getEmployeeStatuses(names);
61
+ return formatStatusAll(statuses, taskMap, roles);
62
+ }
63
+ if (isMainModule(import.meta.url)) {
64
+ const target = process.argv[2];
65
+ status(target).then((output) => {
66
+ process.stdout.write(output + "\n");
67
+ }).catch((err) => {
68
+ process.stderr.write(`Error: ${err instanceof Error ? err.message : String(err)}
69
+ `);
70
+ process.exit(1);
71
+ });
72
+ }
73
+
74
+ export {
75
+ status
76
+ };
@@ -0,0 +1,56 @@
1
+ import {
2
+ getClient
3
+ } from "./chunk-RHZ2CRJU.js";
4
+
5
+ // src/lib/reminders.ts
6
+ import crypto from "crypto";
7
+ async function createReminder(text, dueDate) {
8
+ const client = getClient();
9
+ const id = crypto.randomUUID();
10
+ const now = (/* @__PURE__ */ new Date()).toISOString();
11
+ await client.execute({
12
+ sql: `INSERT INTO reminders (id, text, created_at, due_date) VALUES (?, ?, ?, ?)`,
13
+ args: [id, text, now, dueDate ?? null]
14
+ });
15
+ return { id, text, createdAt: now, dueDate: dueDate ?? null, completedAt: null };
16
+ }
17
+ async function listReminders(includeCompleted = false) {
18
+ const client = getClient();
19
+ const sql = includeCompleted ? `SELECT id, text, created_at, due_date, completed_at FROM reminders ORDER BY due_date ASC NULLS LAST LIMIT 500` : `SELECT id, text, created_at, due_date, completed_at FROM reminders WHERE completed_at IS NULL ORDER BY due_date ASC NULLS LAST LIMIT 500`;
20
+ const result = await client.execute(sql);
21
+ return result.rows.map((row) => ({
22
+ id: String(row.id),
23
+ text: String(row.text),
24
+ createdAt: String(row.created_at),
25
+ dueDate: row.due_date ? String(row.due_date) : null,
26
+ completedAt: row.completed_at ? String(row.completed_at) : null
27
+ }));
28
+ }
29
+ async function completeReminder(idOrText) {
30
+ const client = getClient();
31
+ const now = (/* @__PURE__ */ new Date()).toISOString();
32
+ let result = await client.execute({
33
+ sql: `SELECT id, text FROM reminders WHERE id = ? AND completed_at IS NULL`,
34
+ args: [idOrText]
35
+ });
36
+ if (result.rows.length === 0) {
37
+ result = await client.execute({
38
+ sql: `SELECT id, text FROM reminders WHERE completed_at IS NULL AND text LIKE '%' || ? || '%' LIMIT 1`,
39
+ args: [idOrText]
40
+ });
41
+ }
42
+ if (result.rows.length === 0) return null;
43
+ const row = result.rows[0];
44
+ const id = String(row.id);
45
+ await client.execute({
46
+ sql: `UPDATE reminders SET completed_at = ? WHERE id = ?`,
47
+ args: [now, id]
48
+ });
49
+ return { id, text: String(row.text), createdAt: "", dueDate: null, completedAt: now };
50
+ }
51
+
52
+ export {
53
+ createReminder,
54
+ listReminders,
55
+ completeReminder
56
+ };