@askexenow/exe-os 0.9.280 → 0.9.282
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.
- package/deploy/compose/.env.customer.example +1 -1
- package/deploy/compose/.env.default +2 -1
- package/deploy/compose/.env.example +1 -1
- package/deploy/compose/docker-compose.yml +74 -13
- package/deploy/compose/erp-nginx/nginx.conf +52 -0
- package/deploy/compose/generate-env.ts +1 -1
- package/deploy/compose/init-db.sql +13 -2
- package/deploy/stack-manifests/v0.9.json +11 -31
- package/dist/active-agent-6ZBHGHXF.js +26 -0
- package/dist/active-agent-E23SCYER.js +27 -0
- package/dist/active-agent-KMZT44S4.js +26 -0
- package/dist/active-agent-LFFTVROM.js +27 -0
- package/dist/agentic-ontology-PCZB5HV5.js +25 -0
- package/dist/agentic-ontology-PGGJN2ES.js +25 -0
- package/dist/assets/tmux.conf +2 -0
- package/dist/backfill-metadata-KQ4FEVUR.js +599 -0
- package/dist/backfill-metadata-Y3YWCHKJ.js +599 -0
- package/dist/behaviors-H4DZECKL.js +39 -0
- package/dist/behaviors-WIUTIJF6.js +39 -0
- package/dist/bin/agentic-ontology-backfill.js +5 -5
- package/dist/bin/agentic-reflection-backfill.js +6 -6
- package/dist/bin/agentic-semantic-label.js +5 -5
- package/dist/bin/backfill-conversations.js +4 -4
- package/dist/bin/backfill-responses.js +4 -4
- package/dist/bin/backfill-vectors.js +5 -5
- package/dist/bin/bulk-sync-postgres.js +7 -7
- package/dist/bin/cc-doctor.js +4 -4
- package/dist/bin/cleanup-stale-review-tasks.js +10 -10
- package/dist/bin/cli.js +15 -15
- package/dist/bin/exe-agent-config.js +2 -2
- package/dist/bin/exe-agent.js +4 -4
- package/dist/bin/exe-assign.js +5 -5
- package/dist/bin/exe-boot.js +17 -17
- package/dist/bin/exe-call.js +4 -4
- package/dist/bin/exe-cloud.js +5 -5
- package/dist/bin/exe-dispatch.js +10 -10
- package/dist/bin/exe-doctor.js +1 -1
- package/dist/bin/exe-export-behaviors.js +7 -7
- package/dist/bin/exe-forget.js +6 -6
- package/dist/bin/exe-gateway.js +7 -7
- package/dist/bin/exe-healthcheck.js +4 -4
- package/dist/bin/exe-heartbeat.js +10 -10
- package/dist/bin/exe-kill.js +13 -13
- package/dist/bin/exe-launch-agent.js +17 -17
- package/dist/bin/exe-new-employee.js +7 -7
- package/dist/bin/exe-pending-messages.js +11 -11
- package/dist/bin/exe-pending-notifications.js +10 -10
- package/dist/bin/exe-pending-reviews.js +10 -10
- package/dist/bin/exe-rename.js +4 -4
- package/dist/bin/exe-review.js +12 -12
- package/dist/bin/exe-search.js +5 -5
- package/dist/bin/exe-session-cleanup.js +15 -15
- package/dist/bin/exe-settings.js +5 -5
- package/dist/bin/exe-start-codex.js +11 -11
- package/dist/bin/exe-start-opencode.js +8 -8
- package/dist/bin/exe-status.js +11 -11
- package/dist/bin/exe-support.js +2 -2
- package/dist/bin/exe-team.js +3 -3
- package/dist/bin/exe-watchdog.js +17 -2
- package/dist/bin/git-sweep.js +11 -11
- package/dist/bin/graph-backfill.js +4 -4
- package/dist/bin/graph-export.js +5 -5
- package/dist/bin/import-history.js +7 -7
- package/dist/bin/install.js +8 -7
- package/dist/bin/intercom-check.js +4 -4
- package/dist/bin/mcp-sessions.js +2 -2
- package/dist/bin/orchestration-metrics.js +4 -4
- package/dist/bin/postgres-agentic-reflection-backfill.js +2 -2
- package/dist/bin/postgres-agentic-semantic-backfill.js +1 -1
- package/dist/bin/scan-tasks.js +10 -10
- package/dist/bin/setup.js +1 -1
- package/dist/bin/shard-migrate.js +4 -4
- package/dist/bin/stack-update.js +3 -3
- package/dist/bin/vps-health-gate.js +1 -1
- package/dist/capability-cards-F22XWGLB.js +88 -0
- package/dist/capability-cards-KCKITXXZ.js +88 -0
- package/dist/capacity-monitor-CHXGKVEO.js +50 -0
- package/dist/capacity-monitor-L3M5KB6T.js +50 -0
- package/dist/catchup-brief-BVZANLRZ.js +154 -0
- package/dist/catchup-brief-LDUGMC7S.js +154 -0
- package/dist/catchup-brief-NZDLL7SA.js +154 -0
- package/dist/catchup-brief-OOIXVGBA.js +154 -0
- package/dist/catchup-brief-UPXHDYTB.js +154 -0
- package/dist/chunk-2BI3FQKL.js +1876 -0
- package/dist/chunk-2CJUQGHH.js +362 -0
- package/dist/chunk-2EVYBMBJ.js +128 -0
- package/dist/chunk-2NQOZOXG.js +2113 -0
- package/dist/chunk-2QK5E3LB.js +128 -0
- package/dist/chunk-2VTCG4ZU.js +1352 -0
- package/dist/chunk-2YGI36DV.js +1119 -0
- package/dist/chunk-32BQN2QN.js +185 -0
- package/dist/chunk-33JMO4UV.js +157 -0
- package/dist/chunk-3DZAYLXY.js +377 -0
- package/dist/chunk-3MGBE7GR.js +76 -0
- package/dist/chunk-3MTV4FJL.js +271 -0
- package/dist/chunk-3NN7VQ27.js +1352 -0
- package/dist/chunk-4533HNOG.js +70 -0
- package/dist/chunk-456UW3MT.js +731 -0
- package/dist/chunk-4AU56XV2.js +58 -0
- package/dist/chunk-4MRP6EBR.js +280 -0
- package/dist/chunk-4MRWW52U.js +14219 -0
- package/dist/chunk-4WWECNAY.js +50 -0
- package/dist/chunk-4ZJDDR6L.js +171 -0
- package/dist/chunk-522EOPM6.js +382 -0
- package/dist/chunk-52UDAVZE.js +3208 -0
- package/dist/chunk-5FAMUB4X.js +204 -0
- package/dist/chunk-5PGZJQUI.js +58 -0
- package/dist/chunk-67TZJXNZ.js +262 -0
- package/dist/chunk-6FEZ7GN2.js +123 -0
- package/dist/chunk-6MOGND7S.js +14219 -0
- package/dist/chunk-6TRSVY7L.js +181 -0
- package/dist/chunk-6WCS7ZNK.js +85 -0
- package/dist/chunk-6WRYDREW.js +539 -0
- package/dist/chunk-72UA2FB3.js +181 -0
- package/dist/chunk-77DMFEOL.js +30 -0
- package/dist/chunk-7COXVQ5W.js +214 -0
- package/dist/chunk-7HLWBYH7.js +60 -0
- package/dist/chunk-ALSTZCWT.js +204 -0
- package/dist/chunk-ARUTDXZX.js +280 -0
- package/dist/chunk-AU47B4QY.js +129 -0
- package/dist/chunk-AXOREWVL.js +836 -0
- package/dist/chunk-B5MNC54V.js +127 -0
- package/dist/chunk-B74VSMKX.js +1350 -0
- package/dist/chunk-BHWLH44J.js +362 -0
- package/dist/chunk-BUPZ3HD2.js +85 -0
- package/dist/chunk-BWVLMA53.js +2113 -0
- package/dist/chunk-C5WLBKMJ.js +50 -0
- package/dist/chunk-C62T6R2A.js +97 -0
- package/dist/chunk-CV5KBAIK.js +33 -0
- package/dist/chunk-DAYSDWXA.js +1068 -0
- package/dist/chunk-DI4URIUB.js +227 -0
- package/dist/chunk-DNTCYFJ6.js +76 -0
- package/dist/chunk-DPDRRS7T.js +103 -0
- package/dist/chunk-DT3EV6CW.js +103 -0
- package/dist/chunk-DX45HDWY.js +1076 -0
- package/dist/chunk-E72BD6MG.js +284 -0
- package/dist/chunk-EAPUSVKS.js +375 -0
- package/dist/chunk-EFUANRRT.js +85 -0
- package/dist/chunk-EG2SCT5R.js +1352 -0
- package/dist/chunk-EJD2JU77.js +58 -0
- package/dist/chunk-EMXYUAVP.js +81 -0
- package/dist/chunk-ENM2TAAM.js +14219 -0
- package/dist/chunk-EPDRTPVP.js +1876 -0
- package/dist/chunk-EW6XDHID.js +221 -0
- package/dist/chunk-EYEGSAWZ.js +1094 -0
- package/dist/chunk-F6L33PAQ.js +231 -0
- package/dist/chunk-FC2SCTVE.js +38 -0
- package/dist/chunk-FSRKIZGZ.js +630 -0
- package/dist/chunk-FTG7I5CB.js +81 -0
- package/dist/chunk-GVFRLWX7.js +30 -0
- package/dist/chunk-H3XMZOWW.js +1119 -0
- package/dist/chunk-HAKXE6LN.js +123 -0
- package/dist/chunk-HLP3ZDTW.js +448 -0
- package/dist/chunk-HOYWKQAA.js +510 -0
- package/dist/chunk-HWDD64IW.js +712 -0
- package/dist/chunk-HWMCULHY.js +127 -0
- package/dist/chunk-HZZHRZPK.js +210 -0
- package/dist/chunk-ICRWTYNW.js +103 -0
- package/dist/chunk-J5MWPC33.js +167 -0
- package/dist/chunk-JBXANNNB.js +70 -0
- package/dist/chunk-JPBMIYWF.js +1352 -0
- package/dist/chunk-JY6EXBFI.js +373 -0
- package/dist/chunk-JZLIBXI7.js +14219 -0
- package/dist/chunk-JZPTKXJ6.js +668 -0
- package/dist/chunk-KEYMA4ZP.js +510 -0
- package/dist/chunk-KHGNN6GL.js +2078 -0
- package/dist/chunk-KVLB2PD6.js +97 -0
- package/dist/chunk-L3YBRBKL.js +1076 -0
- package/dist/chunk-L7VZ32NA.js +89 -0
- package/dist/chunk-LEHLADW4.js +221 -0
- package/dist/chunk-LPD4HILQ.js +262 -0
- package/dist/chunk-LSJ3ADDI.js +51 -0
- package/dist/chunk-LUMS2MAS.js +58 -0
- package/dist/chunk-LV4SEC6C.js +394 -0
- package/dist/chunk-LXXBEI4A.js +284 -0
- package/dist/chunk-M4NPCAIH.js +456 -0
- package/dist/chunk-MFJ62LQ5.js +157 -0
- package/dist/chunk-MGEZNKOD.js +836 -0
- package/dist/chunk-MJ7X5IBW.js +227 -0
- package/dist/chunk-MLGRWCY4.js +54 -0
- package/dist/chunk-MQZX57IY.js +348 -0
- package/dist/chunk-MY7MFF6J.js +103 -0
- package/dist/chunk-MYA2X5OY.js +185 -0
- package/dist/chunk-MYEABW5Z.js +630 -0
- package/dist/chunk-MZ2TDCAL.js +402 -0
- package/dist/chunk-NF3FRB7Z.js +271 -0
- package/dist/chunk-NXYIFEPV.js +539 -0
- package/dist/chunk-O2GVE5B5.js +58 -0
- package/dist/chunk-O5GUCDR2.js +456 -0
- package/dist/chunk-OBZNRECA.js +128 -0
- package/dist/chunk-OMZ2RLJG.js +214 -0
- package/dist/chunk-ORDHJRWN.js +299 -0
- package/dist/chunk-OSPIJMCD.js +210 -0
- package/dist/chunk-OUGWEH4J.js +240 -0
- package/dist/chunk-OV5MJQGC.js +1876 -0
- package/dist/chunk-PC635OAG.js +4318 -0
- package/dist/chunk-PH46R4J6.js +348 -0
- package/dist/chunk-PJP2EP7P.js +394 -0
- package/dist/chunk-PODFWH3V.js +333 -0
- package/dist/chunk-PPWH3SHR.js +1068 -0
- package/dist/chunk-PWPJK7KB.js +4318 -0
- package/dist/chunk-PXONZVG4.js +377 -0
- package/dist/chunk-QAOGJRZD.js +369 -0
- package/dist/chunk-QC3LAEI7.js +197 -0
- package/dist/chunk-QDWQDUWI.js +668 -0
- package/dist/chunk-QKJFD6BH.js +1350 -0
- package/dist/chunk-QNYVJGFM.js +345 -0
- package/dist/chunk-QQF3XGQ5.js +14219 -0
- package/dist/chunk-QRPFQNI3.js +150 -0
- package/dist/chunk-QSSU5XWD.js +731 -0
- package/dist/chunk-QXZAGVAV.js +2078 -0
- package/dist/chunk-RA54MW64.js +244 -0
- package/dist/chunk-RF7PUWXI.js +197 -0
- package/dist/chunk-S3INDYSO.js +244 -0
- package/dist/chunk-SLQVTHH5.js +369 -0
- package/dist/chunk-SY2B74KL.js +345 -0
- package/dist/chunk-T6QPXXXW.js +712 -0
- package/dist/chunk-TO5M5YCT.js +41 -0
- package/dist/chunk-TQ4VXUAF.js +129 -0
- package/dist/chunk-UAB7RQC4.js +41 -0
- package/dist/chunk-UMEIBDYW.js +97 -0
- package/dist/chunk-UXW5TB7Y.js +240 -0
- package/dist/chunk-VB2N5WOX.js +150 -0
- package/dist/chunk-VLZEMRG3.js +167 -0
- package/dist/chunk-VM3V6VK7.js +230 -0
- package/dist/chunk-VMCGKBHB.js +1352 -0
- package/dist/chunk-VNIYZAR5.js +128 -0
- package/dist/chunk-VYV4KOD2.js +85 -0
- package/dist/chunk-W4SRJBAT.js +171 -0
- package/dist/chunk-W5W3LZ3Q.js +54 -0
- package/dist/chunk-WDNZEOM3.js +38 -0
- package/dist/chunk-WUKEXVOR.js +3208 -0
- package/dist/chunk-X3Z35Q6L.js +373 -0
- package/dist/chunk-X4VOU6BQ.js +382 -0
- package/dist/chunk-X6EEVSVG.js +290 -0
- package/dist/chunk-XFHGWGNB.js +1094 -0
- package/dist/chunk-XKOLRWYA.js +33 -0
- package/dist/chunk-XMMIL3UD.js +402 -0
- package/dist/chunk-XWILC6VA.js +290 -0
- package/dist/chunk-Y4OQCX4C.js +97 -0
- package/dist/chunk-Y67VYYOA.js +231 -0
- package/dist/chunk-YGQCQTQH.js +230 -0
- package/dist/chunk-YGWFBN5A.js +299 -0
- package/dist/chunk-YMKUXZIG.js +379 -0
- package/dist/chunk-YOMLMT7E.js +230 -0
- package/dist/chunk-YPESIZOB.js +14219 -0
- package/dist/chunk-Z2CGCIU2.js +89 -0
- package/dist/chunk-ZLAWNHQR.js +448 -0
- package/dist/chunk-ZME5UQSN.js +333 -0
- package/dist/co-activation-NUEQYXE5.js +73 -0
- package/dist/co-activation-ZG5HLBCZ.js +73 -0
- package/dist/co-occurrence-7S5KWQB2.js +94 -0
- package/dist/co-occurrence-X5SWDXT2.js +94 -0
- package/dist/core-memory-GOPBRGGZ.js +110 -0
- package/dist/core-memory-XLCU6L5M.js +110 -0
- package/dist/crdt-sync-EPKHPGRZ.js +33 -0
- package/dist/crdt-sync-UIQJ5U7T.js +33 -0
- package/dist/crm-webhook-MKN23JNU.js +10 -0
- package/dist/crm-webhook-SM63BPXO.js +10 -0
- package/dist/cto-delegation-gate-PQY5TOVZ.js +279 -0
- package/dist/cto-delegation-gate-V5VVUR3G.js +279 -0
- package/dist/daemon-orchestration-C7AAS67Q.js +138 -0
- package/dist/daemon-orchestration-OBCAJB2H.js +138 -0
- package/dist/db-backup-F7VP4QRH.js +33 -0
- package/dist/db-backup-KVYC57W7.js +33 -0
- package/dist/doc-graph-extractor-H2ETEINP.js +132 -0
- package/dist/doc-graph-extractor-PCUZEYCH.js +132 -0
- package/dist/dreaming-4OZXSLE3.js +33 -0
- package/dist/dreaming-Z2RYEYNT.js +33 -0
- package/dist/exe-drift-GEWNIK7A.js +69 -0
- package/dist/exe-drift-XCGH7AFO.js +69 -0
- package/dist/exe-export-7DKAU5IP.js +75 -0
- package/dist/exe-export-BCHH6OE6.js +75 -0
- package/dist/exe-import-PDRIZVYF.js +78 -0
- package/dist/exe-import-ZCKUDFKL.js +78 -0
- package/dist/exe-key-FUWLLI3U.js +580 -0
- package/dist/exe-key-RKKNVUMP.js +580 -0
- package/dist/exe-snapshot-G4I5FQMK.js +337 -0
- package/dist/exe-snapshot-GWU7QTZK.js +337 -0
- package/dist/fast-db-init-6QG6YQNT.js +7 -0
- package/dist/fast-db-init-X2QDQUA4.js +7 -0
- package/dist/founder-context-TOMNUBGJ.js +96 -0
- package/dist/founder-context-UU3V6MAS.js +96 -0
- package/dist/gateway/index.js +8 -8
- package/dist/git-staleness-FEPFMZKF.js +111 -0
- package/dist/git-staleness-HYVYLCW3.js +111 -0
- package/dist/git-task-sweep-IRV52JIM.js +41 -0
- package/dist/git-task-sweep-T6BSM3GS.js +41 -0
- package/dist/global-procedures-3AURRMKO.js +21 -0
- package/dist/global-procedures-JPCYBZYC.js +21 -0
- package/dist/graph-auto-extract-OC3AOSMW.js +182 -0
- package/dist/graph-auto-extract-PVDYEJBY.js +182 -0
- package/dist/hooks/bug-report-worker.js +12 -12
- package/dist/hooks/codex-stop-task-finalizer.js +12 -12
- package/dist/hooks/commit-complete.js +12 -12
- package/dist/hooks/error-recall.js +6 -6
- package/dist/hooks/exe-heartbeat-hook.js +3 -3
- package/dist/hooks/ingest.js +6 -6
- package/dist/hooks/instructions-loaded.js +4 -4
- package/dist/hooks/manifest.json +19 -19
- package/dist/hooks/notification.js +4 -4
- package/dist/hooks/post-compact.js +11 -11
- package/dist/hooks/post-tool-combined.js +5 -5
- package/dist/hooks/pre-compact.js +12 -12
- package/dist/hooks/pre-tool-use.js +15 -15
- package/dist/hooks/prompt-submit.js +22 -22
- package/dist/hooks/session-end.js +16 -16
- package/dist/hooks/session-start.js +10 -10
- package/dist/hooks/stop.js +15 -15
- package/dist/hooks/subagent-stop.js +11 -11
- package/dist/hooks/summary-worker.js +15 -15
- package/dist/index.js +18 -18
- package/dist/installer-72XXLBRP.js +39 -0
- package/dist/installer-HDXG2BZN.js +343 -0
- package/dist/installer-JALMKPCS.js +297 -0
- package/dist/installer-Q46SNNLU.js +39 -0
- package/dist/installer-W7PIPRCX.js +343 -0
- package/dist/installer-Z7WQEOS7.js +297 -0
- package/dist/lib/cloud-sync.js +5 -5
- package/dist/lib/consolidation.js +5 -5
- package/dist/lib/database.js +2 -2
- package/dist/lib/db.js +2 -2
- package/dist/lib/employee-templates.js +4 -4
- package/dist/lib/employees.js +2 -2
- package/dist/lib/exe-daemon.js +45 -41
- package/dist/lib/hybrid-search.js +5 -5
- package/dist/lib/identity.js +2 -2
- package/dist/lib/license.js +1 -1
- package/dist/lib/messaging.js +10 -10
- package/dist/lib/reminders.js +3 -3
- package/dist/lib/schedules.js +5 -5
- package/dist/lib/session-registry.js +4 -4
- package/dist/lib/skill-learning.js +6 -6
- package/dist/lib/store.js +4 -4
- package/dist/lib/task-router.js +3 -3
- package/dist/lib/tasks.js +11 -11
- package/dist/lib/tmux-routing.js +9 -9
- package/dist/lib/token-spend.js +3 -3
- package/dist/license-gate-7JZCHOAG.js +14 -0
- package/dist/license-gate-OP4SKL4P.js +14 -0
- package/dist/mcp/register-tools.js +58 -58
- package/dist/mcp/server.js +59 -59
- package/dist/mcp/tools/complete-reminder.js +4 -4
- package/dist/mcp/tools/create-reminder.js +4 -4
- package/dist/mcp/tools/create-task.js +13 -13
- package/dist/mcp/tools/deactivate-behavior.js +7 -7
- package/dist/mcp/tools/list-reminders.js +4 -4
- package/dist/mcp/tools/list-tasks.js +13 -13
- package/dist/mcp/tools/send-message.js +12 -12
- package/dist/mcp/tools/update-task.js +12 -12
- package/dist/mcp-health-VULNT722.js +17 -0
- package/dist/mcp-health-WDOB6XUB.js +19 -0
- package/dist/mcp-http-config-2OZ7N74D.js +28 -0
- package/dist/mcp-http-config-4VXA5K73.js +28 -0
- package/dist/memory-cards-2K6QRZU6.js +179 -0
- package/dist/memory-cards-KSJF5OH2.js +179 -0
- package/dist/memory-graph-extractor-IJD5HWYT.js +21 -0
- package/dist/memory-graph-extractor-O4GAXOK5.js +21 -0
- package/dist/memory-poisoning-defense-2JRPWT5V.js +223 -0
- package/dist/memory-poisoning-defense-DH4A25NU.js +223 -0
- package/dist/memory-reflection-ISY2BBDB.js +243 -0
- package/dist/memory-reflection-Z5AQRR6H.js +243 -0
- package/dist/notifications-2VSWK2UJ.js +46 -0
- package/dist/notifications-4S253VQM.js +46 -0
- package/dist/oauth-server-D7D4574D.js +437 -0
- package/dist/oauth-server-MACN54SJ.js +437 -0
- package/dist/orchestration-events-BGP5RYQI.js +26 -0
- package/dist/orchestration-events-MDXUEVRZ.js +26 -0
- package/dist/orchestrator-DHK7RSSH.js +34 -0
- package/dist/orchestrator-R75WHQVA.js +34 -0
- package/dist/pipeline-router-4WUKQQEC.js +14 -0
- package/dist/pipeline-router-GWB2XK2Q.js +14 -0
- package/dist/plan-limits-NNJRAESF.js +27 -0
- package/dist/plan-limits-YTQW4UR4.js +27 -0
- package/dist/project-boot-46GZJTEX.js +299 -0
- package/dist/project-boot-PPHBBGIF.js +299 -0
- package/dist/projection-worker-UPAWXI7P.js +1034 -0
- package/dist/projection-worker-ZIKDYBW5.js +1034 -0
- package/dist/reranker-5ZBP2RRN.js +19 -0
- package/dist/reranker-E2MQIMJL.js +19 -0
- package/dist/reranker-GLSDJT3V.js +19 -0
- package/dist/reranker-LBBXWNOD.js +19 -0
- package/dist/reranker-XZ2EF4OH.js +19 -0
- package/dist/retrieval-health-JYRKPSII.js +7 -0
- package/dist/retrieval-health-OUV25J6S.js +7 -0
- package/dist/retrieval-health-U73JUAZL.js +7 -0
- package/dist/retrieval-health-WSZ7TYFF.js +7 -0
- package/dist/review-polling-62JV55ZT.js +125 -0
- package/dist/review-polling-CJXLWFWK.js +125 -0
- package/dist/runtime/index.js +12 -12
- package/dist/session-events-2ADD54VI.js +37 -0
- package/dist/session-events-QIJVBSKS.js +37 -0
- package/dist/session-kill-telemetry-HS6HD2YE.js +30 -0
- package/dist/session-kill-telemetry-MRT5FVSM.js +30 -0
- package/dist/session-scope-7ICYPC33.js +87 -0
- package/dist/session-scope-KMXD6EE6.js +87 -0
- package/dist/setup-wizard-B6GIT7YC.js +12 -0
- package/dist/setup-wizard-JUIJ4UZO.js +12 -0
- package/dist/skill-refinement-HIOX4VMC.js +158 -0
- package/dist/skill-refinement-T7JXRYUW.js +158 -0
- package/dist/stack-update-5KE6BZKQ.js +74 -0
- package/dist/stack-update-OP2RHP7N.js +74 -0
- package/dist/stack-update-VGCWDJEE.js +74 -0
- package/dist/steward-gate-L22WE3SY.js +14 -0
- package/dist/steward-gate-YKD2LUWN.js +14 -0
- package/dist/task-enforcement-5AOKXTY4.js +439 -0
- package/dist/task-enforcement-VO3YEGIO.js +439 -0
- package/dist/task-scope-YV2WPKRD.js +36 -0
- package/dist/task-scope-ZSXDZBRE.js +36 -0
- package/dist/tasks-crud-C6KADACT.js +78 -0
- package/dist/tasks-crud-NV6JEWGL.js +78 -0
- package/dist/tasks-notify-E22HSN6O.js +39 -0
- package/dist/tasks-notify-RPSEQ4WV.js +39 -0
- package/dist/tasks-review-V4ZLXOAZ.js +48 -0
- package/dist/tasks-review-ZVRI73JE.js +48 -0
- package/dist/telemetry-upload-LXUH7SKI.js +740 -0
- package/dist/telemetry-upload-TCDAZTUQ.js +740 -0
- package/dist/token-budget-OFBEZJTA.js +85 -0
- package/dist/token-budget-WAN57V6S.js +85 -0
- package/dist/tool-telemetry-UA3N32PK.js +17 -0
- package/dist/tool-telemetry-XXZJ35RR.js +17 -0
- package/dist/tui/App.js +17 -17
- package/dist/tui-data-46QLCJUE.js +259 -0
- package/dist/tui-data-ZDB7BLP2.js +259 -0
- package/dist/wiki-acl-HHSIBPF3.js +111 -0
- package/dist/wiki-acl-O65GZ2ZF.js +111 -0
- package/dist/worker-gate-27I4GAEZ.js +21 -0
- package/dist/worker-gate-DXU4HEPY.js +21 -0
- package/dist/workflow-engine-63EOEJ5Q.js +28 -0
- package/dist/workflow-engine-C6F2RMPN.js +28 -0
- package/dist/worktree-SFKKOMFD.js +27 -0
- package/dist/worktree-SVCE3S7X.js +27 -0
- package/dist/worktree-sweep-S3JHJTVP.js +20 -0
- package/dist/worktree-sweep-U3TIQ7WL.js +20 -0
- package/package.json +1 -1
- package/release-notes.json +175 -57
|
@@ -0,0 +1,439 @@
|
|
|
1
|
+
import {
|
|
2
|
+
sendIntercom,
|
|
3
|
+
updateTaskStatus
|
|
4
|
+
} from "./chunk-PC635OAG.js";
|
|
5
|
+
import "./chunk-ARUTDXZX.js";
|
|
6
|
+
import "./chunk-4FVVJ7ME.js";
|
|
7
|
+
import "./chunk-4JERP7NT.js";
|
|
8
|
+
import "./chunk-Y67VYYOA.js";
|
|
9
|
+
import "./chunk-MVW62NIZ.js";
|
|
10
|
+
import "./chunk-OYNKIAVW.js";
|
|
11
|
+
import "./chunk-SSTLTIF3.js";
|
|
12
|
+
import {
|
|
13
|
+
recordOrchestrationEventBestEffort
|
|
14
|
+
} from "./chunk-FSRKIZGZ.js";
|
|
15
|
+
import "./chunk-PMVOUPTY.js";
|
|
16
|
+
import "./chunk-NGP6LSV2.js";
|
|
17
|
+
import "./chunk-TQ4VXUAF.js";
|
|
18
|
+
import "./chunk-CVYC6DUW.js";
|
|
19
|
+
import "./chunk-OPU3NYOO.js";
|
|
20
|
+
import "./chunk-GJV3WDWM.js";
|
|
21
|
+
import "./chunk-MP2AFCGL.js";
|
|
22
|
+
import "./chunk-JBXANNNB.js";
|
|
23
|
+
import "./chunk-HYZV25LY.js";
|
|
24
|
+
import {
|
|
25
|
+
isCoordinatorName
|
|
26
|
+
} from "./chunk-52UDAVZE.js";
|
|
27
|
+
import "./chunk-2I23RPSI.js";
|
|
28
|
+
import "./chunk-YGWFBN5A.js";
|
|
29
|
+
import "./chunk-5DNJPRDW.js";
|
|
30
|
+
import "./chunk-FXU7JOXK.js";
|
|
31
|
+
import "./chunk-EAPUSVKS.js";
|
|
32
|
+
import "./chunk-T3B5RK4H.js";
|
|
33
|
+
import "./chunk-LYH5HE24.js";
|
|
34
|
+
import "./chunk-MLKGABMK.js";
|
|
35
|
+
|
|
36
|
+
// src/lib/task-enforcement.ts
|
|
37
|
+
import { appendFile } from "fs/promises";
|
|
38
|
+
import path from "path";
|
|
39
|
+
var TASK_ENFORCEMENT_INTERVAL_MS = 6e4;
|
|
40
|
+
var TASK_ENFORCEMENT_DEBOUNCE_MS = 18e4;
|
|
41
|
+
var MANAGER_GRACE_PERIOD_MS = 6e5;
|
|
42
|
+
var IDLE_PATTERNS = [
|
|
43
|
+
"Standing by",
|
|
44
|
+
"All tasks complete",
|
|
45
|
+
"No tasks found",
|
|
46
|
+
"Anything else?",
|
|
47
|
+
"What do you need?"
|
|
48
|
+
];
|
|
49
|
+
var NUDGE_ECHO_PATTERNS = [
|
|
50
|
+
"You have pending notifications",
|
|
51
|
+
"You have open tasks. Run list_tasks",
|
|
52
|
+
"You have more open tasks to dispatch",
|
|
53
|
+
"Run list_tasks to check for assigned work",
|
|
54
|
+
"Run list_tasks to find them"
|
|
55
|
+
];
|
|
56
|
+
var MCP_ZOMBIE_PATTERNS = [
|
|
57
|
+
"session expired",
|
|
58
|
+
"MCP server disconnected",
|
|
59
|
+
"MCP server is not connected",
|
|
60
|
+
'MCP server "exe-os" is not connected',
|
|
61
|
+
"MCP connection lost",
|
|
62
|
+
"MCP error",
|
|
63
|
+
"MCP_UNHEALTHY"
|
|
64
|
+
];
|
|
65
|
+
var MANAGER_ROLES = ["COO", "CTO"];
|
|
66
|
+
var AUDIT_LOG_PATH = path.join(
|
|
67
|
+
process.env.HOME ?? process.env.USERPROFILE ?? "/tmp",
|
|
68
|
+
".exe-os",
|
|
69
|
+
"enforcement-audit.jsonl"
|
|
70
|
+
);
|
|
71
|
+
function writeAuditEntry(entry) {
|
|
72
|
+
const line = JSON.stringify(entry) + "\n";
|
|
73
|
+
appendFile(AUDIT_LOG_PATH, line).catch(() => {
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
function decideManagerAction(counts, isIdle, withinGracePeriod, nudgeEcho) {
|
|
77
|
+
if (counts.openTasks === 0) return "skip";
|
|
78
|
+
if (withinGracePeriod) return "grace_period";
|
|
79
|
+
if (!isIdle) return "active";
|
|
80
|
+
if (nudgeEcho) return "active";
|
|
81
|
+
if ((counts.inProgressTasks ?? 0) > 0) return "active";
|
|
82
|
+
if (counts.activeSubtasks === 0) return "nudge";
|
|
83
|
+
return "soft_nudge";
|
|
84
|
+
}
|
|
85
|
+
function decideWorkerAction(taskCount, isIdle, nudgeEcho) {
|
|
86
|
+
if (taskCount === 0) return "skip";
|
|
87
|
+
if (nudgeEcho) return "idle";
|
|
88
|
+
return isIdle ? "nudge" : "idle";
|
|
89
|
+
}
|
|
90
|
+
function isIdlePane(paneText) {
|
|
91
|
+
return IDLE_PATTERNS.some((p) => paneText.includes(p));
|
|
92
|
+
}
|
|
93
|
+
function isCurrentlyIdle(paneText) {
|
|
94
|
+
const nonEmptyLines = paneText.split("\n").map((line) => line.trim()).filter(Boolean);
|
|
95
|
+
const lastLine = nonEmptyLines.at(-1) ?? "";
|
|
96
|
+
if (/(?:^|[>❯$#])\s*\/mcp\s*$/.test(lastLine)) return true;
|
|
97
|
+
if (IDLE_PATTERNS.some((p) => lastLine.includes(p))) return true;
|
|
98
|
+
if (lineHasMcpZombiePattern(lastLine)) return true;
|
|
99
|
+
const currentLines = nonEmptyLines.slice(-3);
|
|
100
|
+
return tailHasMcpZombieContext(currentLines) && lineLooksLikeMcpReconnectPrompt(lastLine);
|
|
101
|
+
}
|
|
102
|
+
function isNudgeEcho(paneText) {
|
|
103
|
+
return NUDGE_ECHO_PATTERNS.some((p) => paneText.includes(p));
|
|
104
|
+
}
|
|
105
|
+
function lineHasMcpZombiePattern(line) {
|
|
106
|
+
const lower = line.toLowerCase();
|
|
107
|
+
if (lower.includes("not connected") && !lower.includes("mcp server")) return false;
|
|
108
|
+
return MCP_ZOMBIE_PATTERNS.some((p) => lower.includes(p.toLowerCase()));
|
|
109
|
+
}
|
|
110
|
+
function tailHasMcpZombieContext(lines) {
|
|
111
|
+
return lines.some(lineHasMcpZombiePattern);
|
|
112
|
+
}
|
|
113
|
+
function lineLooksLikeMcpReconnectPrompt(line) {
|
|
114
|
+
const lower = line.toLowerCase();
|
|
115
|
+
return lower.includes("/mcp") && (lower.includes("reconnect") || lower.includes("connect") || lower.includes("run") || lower.includes("try"));
|
|
116
|
+
}
|
|
117
|
+
function isMcpZombiePane(paneText, paneCurrentlyIdle) {
|
|
118
|
+
if (!paneCurrentlyIdle) return false;
|
|
119
|
+
const nonEmptyLines = paneText.split("\n").map((line) => line.trim()).filter(Boolean);
|
|
120
|
+
const lastLine = nonEmptyLines.at(-1) ?? "";
|
|
121
|
+
if (/(?:^|[>❯$#])\s*\/mcp\s*$/.test(lastLine)) return true;
|
|
122
|
+
if (lineHasMcpZombiePattern(lastLine)) return true;
|
|
123
|
+
const currentLines = nonEmptyLines.slice(-3);
|
|
124
|
+
return tailHasMcpZombieContext(currentLines) && lineLooksLikeMcpReconnectPrompt(lastLine);
|
|
125
|
+
}
|
|
126
|
+
function sendNudge(transport, session, runtime, action) {
|
|
127
|
+
const message = action === "nudge" ? "You have open tasks. Run list_tasks to find them." : "You have more open tasks to dispatch. Run list_tasks.";
|
|
128
|
+
if (transport.sendKeysLiteral) {
|
|
129
|
+
transport.sendKeysLiteral(session, message);
|
|
130
|
+
} else {
|
|
131
|
+
transport.sendKeys(session, message);
|
|
132
|
+
}
|
|
133
|
+
process.stderr.write(
|
|
134
|
+
`[enforcement-audit] SENT nudge to ${session} (${runtime}, ${action})
|
|
135
|
+
`
|
|
136
|
+
);
|
|
137
|
+
}
|
|
138
|
+
function _resetNudgeState() {
|
|
139
|
+
}
|
|
140
|
+
function coordinatorScopeFromSession(session) {
|
|
141
|
+
const dashIndex = session.indexOf("-");
|
|
142
|
+
if (dashIndex <= 0) return null;
|
|
143
|
+
const scope = session.slice(dashIndex + 1).trim();
|
|
144
|
+
return scope.length > 0 ? scope : null;
|
|
145
|
+
}
|
|
146
|
+
function strictTaskSessionScope(scope) {
|
|
147
|
+
if (!scope) return { sql: " AND session_scope IS NOT NULL AND 1 = 0", args: [] };
|
|
148
|
+
return { sql: " AND session_scope = ?", args: [scope] };
|
|
149
|
+
}
|
|
150
|
+
async function countOrphanedTasksForAgent(client, agentName, statuses) {
|
|
151
|
+
const result = await client.execute({
|
|
152
|
+
sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_to = ? AND status IN (${statuses}) AND session_scope IS NULL`,
|
|
153
|
+
args: [agentName]
|
|
154
|
+
});
|
|
155
|
+
return Number(result.rows[0]?.cnt ?? 0);
|
|
156
|
+
}
|
|
157
|
+
async function runTaskEnforcementTick(deps) {
|
|
158
|
+
const { transport, employees, client } = deps;
|
|
159
|
+
const now = deps.now ?? Date.now();
|
|
160
|
+
const tickStartedAt = Date.now();
|
|
161
|
+
const sessions = transport.listSessions();
|
|
162
|
+
let processedAnyEmployee = false;
|
|
163
|
+
let processedSessions = 0;
|
|
164
|
+
let nudgesSent = 0;
|
|
165
|
+
const processedScopes = /* @__PURE__ */ new Set();
|
|
166
|
+
recordOrchestrationEventBestEffort({
|
|
167
|
+
eventType: "daemon.tick.started",
|
|
168
|
+
source: "task-enforcement.runTaskEnforcementTick",
|
|
169
|
+
payload: { sessionCount: sessions.length }
|
|
170
|
+
});
|
|
171
|
+
const hasScopeRestriction = deps.scopeFilter.sql.length > 0;
|
|
172
|
+
const allowedScope = hasScopeRestriction && deps.scopeFilter.args.length > 0 ? String(deps.scopeFilter.args[deps.scopeFilter.args.length - 1]) : null;
|
|
173
|
+
for (const session of sessions) {
|
|
174
|
+
if (!session.includes("-")) continue;
|
|
175
|
+
const agentName = session.split("-")[0]?.replace(/\d+$/, "");
|
|
176
|
+
if (!agentName) continue;
|
|
177
|
+
if (allowedScope) {
|
|
178
|
+
const sessionSuffix = session.slice(session.indexOf("-") + 1);
|
|
179
|
+
if (sessionSuffix !== allowedScope) continue;
|
|
180
|
+
}
|
|
181
|
+
if ("isAlive" in transport && typeof transport.isAlive === "function") {
|
|
182
|
+
if (!transport.isAlive(session)) continue;
|
|
183
|
+
}
|
|
184
|
+
const employee = employees.find((e) => e.name === agentName);
|
|
185
|
+
if (!employee) continue;
|
|
186
|
+
processedAnyEmployee = true;
|
|
187
|
+
processedSessions++;
|
|
188
|
+
const coordinatorSession = coordinatorScopeFromSession(session);
|
|
189
|
+
const effectiveScope = strictTaskSessionScope(coordinatorSession);
|
|
190
|
+
if (coordinatorSession) processedScopes.add(coordinatorSession);
|
|
191
|
+
const isManager = MANAGER_ROLES.includes(employee.role);
|
|
192
|
+
try {
|
|
193
|
+
let action = "skip";
|
|
194
|
+
let reason = "";
|
|
195
|
+
let openTasks = 0;
|
|
196
|
+
let activeSubtasks = 0;
|
|
197
|
+
let paneIdle;
|
|
198
|
+
if (isManager) {
|
|
199
|
+
const openResult = await client.execute({
|
|
200
|
+
sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_to = ? AND status = 'open'${effectiveScope.sql}`,
|
|
201
|
+
args: [agentName, ...effectiveScope.args]
|
|
202
|
+
});
|
|
203
|
+
openTasks = Number(openResult.rows[0]?.cnt ?? 0);
|
|
204
|
+
if (openTasks === 0 && coordinatorSession) {
|
|
205
|
+
const orphaned = await countOrphanedTasksForAgent(client, agentName, "'open'");
|
|
206
|
+
if (orphaned > 0) {
|
|
207
|
+
process.stderr.write(
|
|
208
|
+
`[exed] Task enforcement: ${agentName}-${coordinatorSession} has ${orphaned} orphaned open task(s) with NULL session_scope; not nudging until owning scope is repaired.
|
|
209
|
+
`
|
|
210
|
+
);
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
if (openTasks > 0) {
|
|
214
|
+
const subtaskResult = await client.execute({
|
|
215
|
+
sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_by = ? AND status = 'in_progress'${effectiveScope.sql}`,
|
|
216
|
+
args: [agentName, ...effectiveScope.args]
|
|
217
|
+
});
|
|
218
|
+
activeSubtasks = Number(subtaskResult.rows[0]?.cnt ?? 0);
|
|
219
|
+
}
|
|
220
|
+
let withinGracePeriod = false;
|
|
221
|
+
let graceRemaining = 0;
|
|
222
|
+
if (openTasks > 0) {
|
|
223
|
+
const newestResult = await client.execute({
|
|
224
|
+
sql: `SELECT created_at FROM tasks WHERE assigned_to = ? AND status = 'open'${effectiveScope.sql} ORDER BY created_at DESC LIMIT 1`,
|
|
225
|
+
args: [agentName, ...effectiveScope.args]
|
|
226
|
+
});
|
|
227
|
+
const newestCreatedAt = newestResult.rows[0]?.created_at;
|
|
228
|
+
if (newestCreatedAt) {
|
|
229
|
+
const taskAge = now - new Date(newestCreatedAt).getTime();
|
|
230
|
+
if (taskAge < MANAGER_GRACE_PERIOD_MS) {
|
|
231
|
+
withinGracePeriod = true;
|
|
232
|
+
graceRemaining = Math.round((MANAGER_GRACE_PERIOD_MS - taskAge) / 1e3);
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
let inProgressTasks = 0;
|
|
237
|
+
if (openTasks > 0) {
|
|
238
|
+
const ipResult = await client.execute({
|
|
239
|
+
sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_to = ? AND status = 'in_progress'${effectiveScope.sql}`,
|
|
240
|
+
args: [agentName, ...effectiveScope.args]
|
|
241
|
+
});
|
|
242
|
+
inProgressTasks = Number(ipResult.rows[0]?.cnt ?? 0);
|
|
243
|
+
}
|
|
244
|
+
const pane = deps.paneCache?.get(session) ?? (deps.capturePaneAsync ? await deps.capturePaneAsync(session, 20) : transport.capturePane(session, 20));
|
|
245
|
+
paneIdle = isIdlePane(pane);
|
|
246
|
+
const nudgeEcho = isNudgeEcho(pane);
|
|
247
|
+
action = decideManagerAction({ openTasks, activeSubtasks, inProgressTasks }, paneIdle, withinGracePeriod, nudgeEcho);
|
|
248
|
+
if (action === "skip") reason = "no open tasks";
|
|
249
|
+
else if (action === "grace_period") reason = `task assigned <10min ago (${graceRemaining}s remaining)`;
|
|
250
|
+
else if (action === "active") reason = nudgeEcho ? "pane shows previous nudge (anti-loop)" : inProgressTasks > 0 ? `${inProgressTasks} tasks in_progress` : "pane shows active work";
|
|
251
|
+
else if (action === "nudge") reason = `${openTasks} open tasks, 0 delegated, pane idle`;
|
|
252
|
+
else if (action === "soft_nudge") reason = `${openTasks} open tasks, ${activeSubtasks} delegated, pane idle`;
|
|
253
|
+
writeAuditEntry({
|
|
254
|
+
timestamp: new Date(now).toISOString(),
|
|
255
|
+
session,
|
|
256
|
+
agent: agentName,
|
|
257
|
+
role: "manager",
|
|
258
|
+
action,
|
|
259
|
+
reason,
|
|
260
|
+
openTasks,
|
|
261
|
+
activeSubtasks,
|
|
262
|
+
paneIdle,
|
|
263
|
+
graceRemaining: withinGracePeriod ? graceRemaining : void 0
|
|
264
|
+
});
|
|
265
|
+
process.stderr.write(
|
|
266
|
+
`[exed] Task enforcement: ${agentName} (manager) ${openTasks} open, ${activeSubtasks} delegated, pane=${paneIdle ? "idle" : "active"}. Action: ${action} (${reason})
|
|
267
|
+
`
|
|
268
|
+
);
|
|
269
|
+
} else {
|
|
270
|
+
const taskResult = await client.execute({
|
|
271
|
+
sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_to = ? AND status IN ('open', 'in_progress')${effectiveScope.sql}`,
|
|
272
|
+
args: [agentName, ...effectiveScope.args]
|
|
273
|
+
});
|
|
274
|
+
const taskCount = Number(taskResult.rows[0]?.cnt ?? 0);
|
|
275
|
+
openTasks = taskCount;
|
|
276
|
+
if (taskCount === 0 && coordinatorSession) {
|
|
277
|
+
const orphaned = await countOrphanedTasksForAgent(client, agentName, "'open','in_progress'");
|
|
278
|
+
if (orphaned > 0) {
|
|
279
|
+
process.stderr.write(
|
|
280
|
+
`[exed] Task enforcement: ${agentName}-${coordinatorSession} has ${orphaned} orphaned task(s) with NULL session_scope; not nudging until owning scope is repaired.
|
|
281
|
+
`
|
|
282
|
+
);
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
if (taskCount > 0) {
|
|
286
|
+
const pane = deps.paneCache?.get(session) ?? (deps.capturePaneAsync ? await deps.capturePaneAsync(session, 20) : transport.capturePane(session, 20));
|
|
287
|
+
paneIdle = isIdlePane(pane);
|
|
288
|
+
const workerNudgeEcho = isNudgeEcho(pane);
|
|
289
|
+
const paneCurrentlyIdle = isCurrentlyIdle(pane);
|
|
290
|
+
if (isMcpZombiePane(pane, paneCurrentlyIdle) && deps.zombieWorkerRecover) {
|
|
291
|
+
const reason2 = "pane shows dead MCP client";
|
|
292
|
+
await deps.zombieWorkerRecover(session, agentName, coordinatorSession ?? "", reason2);
|
|
293
|
+
writeAuditEntry({
|
|
294
|
+
timestamp: new Date(now).toISOString(),
|
|
295
|
+
session,
|
|
296
|
+
agent: agentName,
|
|
297
|
+
role: "worker",
|
|
298
|
+
action: "active",
|
|
299
|
+
reason: reason2,
|
|
300
|
+
openTasks: taskCount,
|
|
301
|
+
paneIdle
|
|
302
|
+
});
|
|
303
|
+
continue;
|
|
304
|
+
}
|
|
305
|
+
action = decideWorkerAction(taskCount, paneIdle, workerNudgeEcho);
|
|
306
|
+
}
|
|
307
|
+
if (action === "skip") reason = "no tasks";
|
|
308
|
+
else if (action === "idle") reason = `${taskCount} tasks but pane active`;
|
|
309
|
+
else if (action === "nudge") reason = `${taskCount} tasks, pane idle`;
|
|
310
|
+
writeAuditEntry({
|
|
311
|
+
timestamp: new Date(now).toISOString(),
|
|
312
|
+
session,
|
|
313
|
+
agent: agentName,
|
|
314
|
+
role: "worker",
|
|
315
|
+
action,
|
|
316
|
+
reason,
|
|
317
|
+
openTasks: taskCount,
|
|
318
|
+
paneIdle
|
|
319
|
+
});
|
|
320
|
+
process.stderr.write(
|
|
321
|
+
`[exed] Task enforcement: ${agentName} (worker) ${taskCount} tasks, pane=${paneIdle ?? "n/a"}. Action: ${action} (${reason})
|
|
322
|
+
`
|
|
323
|
+
);
|
|
324
|
+
}
|
|
325
|
+
if (action === "skip" || action === "idle" || action === "grace_period" || action === "active") continue;
|
|
326
|
+
nudgesSent++;
|
|
327
|
+
sendIntercom(session, { callerSessionScope: coordinatorSession, reason: "nudge" });
|
|
328
|
+
} catch {
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
if (processedAnyEmployee) {
|
|
332
|
+
try {
|
|
333
|
+
const scopeList = allowedScope ? [...processedScopes].filter((s) => s === allowedScope) : [...processedScopes];
|
|
334
|
+
const staleBlocked = scopeList.length === 0 ? { rows: [] } : await client.execute({
|
|
335
|
+
sql: `SELECT t.id, t.title, b.status as blocker_status
|
|
336
|
+
FROM tasks t
|
|
337
|
+
JOIN tasks b ON t.blocked_by = b.id
|
|
338
|
+
WHERE t.status = 'blocked'
|
|
339
|
+
AND b.status IN ('done', 'cancelled', 'closed')
|
|
340
|
+
AND t.session_scope IN (${scopeList.map(() => "?").join(",")})`,
|
|
341
|
+
args: scopeList
|
|
342
|
+
});
|
|
343
|
+
const nowIso = new Date(now).toISOString();
|
|
344
|
+
for (const row of staleBlocked.rows) {
|
|
345
|
+
try {
|
|
346
|
+
await updateTaskStatus({ taskId: String(row.id), status: "open" });
|
|
347
|
+
} catch {
|
|
348
|
+
await client.execute({
|
|
349
|
+
sql: `UPDATE tasks SET status = 'open', updated_at = ? WHERE id = ?`,
|
|
350
|
+
args: [nowIso, String(row.id)]
|
|
351
|
+
});
|
|
352
|
+
}
|
|
353
|
+
await client.execute({
|
|
354
|
+
sql: `UPDATE tasks SET blocked_by = NULL WHERE id = ?`,
|
|
355
|
+
args: [String(row.id)]
|
|
356
|
+
});
|
|
357
|
+
process.stderr.write(
|
|
358
|
+
`[exed] Auto-unblocked "${String(row.title)}" \u2014 blocker already ${String(row.blocker_status)}
|
|
359
|
+
`
|
|
360
|
+
);
|
|
361
|
+
}
|
|
362
|
+
} catch {
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
if (processedAnyEmployee && deps.reviewerSpawn) {
|
|
366
|
+
try {
|
|
367
|
+
const scopeList = allowedScope ? [...processedScopes].filter((s) => s === allowedScope) : [...processedScopes];
|
|
368
|
+
const reviewerRows = scopeList.length === 0 ? { rows: [] } : await client.execute({
|
|
369
|
+
sql: `SELECT DISTINCT reviewer, session_scope FROM tasks
|
|
370
|
+
WHERE status = 'needs_review'
|
|
371
|
+
AND reviewer IS NOT NULL
|
|
372
|
+
AND reviewer != ''
|
|
373
|
+
AND session_scope IN (${scopeList.map(() => "?").join(",")})`,
|
|
374
|
+
args: scopeList
|
|
375
|
+
});
|
|
376
|
+
const liveSessionSet = new Set(sessions);
|
|
377
|
+
for (const row of reviewerRows.rows) {
|
|
378
|
+
const reviewerName = String(row.reviewer ?? "");
|
|
379
|
+
const sessionScope = row.session_scope ? String(row.session_scope) : null;
|
|
380
|
+
if (!reviewerName || !sessionScope) continue;
|
|
381
|
+
if (isCoordinatorName(reviewerName, employees)) {
|
|
382
|
+
process.stderr.write(
|
|
383
|
+
`[exed] Reviewer auto-spawn: skipping ${reviewerName} (coordinator, not dispatchable)
|
|
384
|
+
`
|
|
385
|
+
);
|
|
386
|
+
continue;
|
|
387
|
+
}
|
|
388
|
+
const reviewerSession = `${reviewerName}-${sessionScope}`;
|
|
389
|
+
if (liveSessionSet.has(reviewerSession)) continue;
|
|
390
|
+
try {
|
|
391
|
+
const result = deps.reviewerSpawn(reviewerName, sessionScope);
|
|
392
|
+
if (!result) continue;
|
|
393
|
+
if (result.status === "spawned") {
|
|
394
|
+
process.stderr.write(
|
|
395
|
+
`[exed] Reviewer auto-spawn: spawned ${reviewerName} in ${sessionScope} (has needs_review tasks)
|
|
396
|
+
`
|
|
397
|
+
);
|
|
398
|
+
} else if (result.status === "failed") {
|
|
399
|
+
process.stderr.write(
|
|
400
|
+
`[exed] Reviewer auto-spawn: failed to spawn ${reviewerName} in ${sessionScope}: ${result.error ?? "unknown"}
|
|
401
|
+
`
|
|
402
|
+
);
|
|
403
|
+
}
|
|
404
|
+
} catch (spawnErr) {
|
|
405
|
+
process.stderr.write(
|
|
406
|
+
`[exed] Reviewer auto-spawn error for ${reviewerName}: ${spawnErr instanceof Error ? spawnErr.message : String(spawnErr)}
|
|
407
|
+
`
|
|
408
|
+
);
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
} catch {
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
recordOrchestrationEventBestEffort({
|
|
415
|
+
eventType: "daemon.tick.completed",
|
|
416
|
+
source: "task-enforcement.runTaskEnforcementTick",
|
|
417
|
+
durationMs: Date.now() - tickStartedAt,
|
|
418
|
+
result: processedAnyEmployee ? "processed" : "no_employee_sessions",
|
|
419
|
+
payload: { sessionCount: sessions.length, processedSessions, nudgesSent }
|
|
420
|
+
});
|
|
421
|
+
}
|
|
422
|
+
export {
|
|
423
|
+
IDLE_PATTERNS,
|
|
424
|
+
MANAGER_GRACE_PERIOD_MS,
|
|
425
|
+
MANAGER_ROLES,
|
|
426
|
+
MCP_ZOMBIE_PATTERNS,
|
|
427
|
+
NUDGE_ECHO_PATTERNS,
|
|
428
|
+
TASK_ENFORCEMENT_DEBOUNCE_MS,
|
|
429
|
+
TASK_ENFORCEMENT_INTERVAL_MS,
|
|
430
|
+
_resetNudgeState,
|
|
431
|
+
decideManagerAction,
|
|
432
|
+
decideWorkerAction,
|
|
433
|
+
isCurrentlyIdle,
|
|
434
|
+
isIdlePane,
|
|
435
|
+
isMcpZombiePane,
|
|
436
|
+
isNudgeEcho,
|
|
437
|
+
runTaskEnforcementTick,
|
|
438
|
+
sendNudge
|
|
439
|
+
};
|