@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.
- 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 +88 -26
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import {
|
|
2
|
+
updateTask
|
|
3
|
+
} from "./chunk-ZLAWNHQR.js";
|
|
4
|
+
import {
|
|
5
|
+
TASK_ALREADY_CLAIMED_PREFIX
|
|
6
|
+
} from "./chunk-PC635OAG.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-6ZBHGHXF.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,210 @@
|
|
|
1
|
+
import {
|
|
2
|
+
redactSecrets
|
|
3
|
+
} from "./chunk-Y25OJWOQ.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/memory-write-governor.ts
|
|
6
|
+
import { createHash } from "crypto";
|
|
7
|
+
var HIGH_VALUE_SUPERSESSION_TYPES = /* @__PURE__ */ new Set([
|
|
8
|
+
"decision",
|
|
9
|
+
"adr",
|
|
10
|
+
"behavior",
|
|
11
|
+
"procedure"
|
|
12
|
+
]);
|
|
13
|
+
var NOISE_DROP_PATTERNS = [
|
|
14
|
+
/^\s*\[📋\s+\d+\s+reviews?\s+pending\b/im,
|
|
15
|
+
/^\s*<system-reminder>[\s\S]*?<\/system-reminder>\s*$/im,
|
|
16
|
+
/^\s*The UserPromptSubmit hook checks the DB for new tasks/im,
|
|
17
|
+
/^\s*Intercom is a speedup, not delivery/im,
|
|
18
|
+
/^\s*Context bar reads as USAGE not remaining/im,
|
|
19
|
+
// Intercom noise — these repeat on every prompt and cause 18K+ duplicates
|
|
20
|
+
/^\/exe-intercom\b/i,
|
|
21
|
+
/^You have pending notifications\.\s*Run list_tasks/i,
|
|
22
|
+
/^You have open tasks\.\s*Run list_tasks/i,
|
|
23
|
+
/^You have a new P\d+ task/i,
|
|
24
|
+
/^You have more open tasks to dispatch/i,
|
|
25
|
+
/^No new tasks\.\s*(Standing by|Idle|Dashboard)/i
|
|
26
|
+
];
|
|
27
|
+
var SKIP_EMBED_PATTERNS = [
|
|
28
|
+
/tmux capture-pane\b/i,
|
|
29
|
+
/docker ps\b/i,
|
|
30
|
+
/docker images\b/i,
|
|
31
|
+
/git status\b/i,
|
|
32
|
+
/grep .*node_modules/i,
|
|
33
|
+
/npm (install|ci)\b[\s\S]*(added \d+ packages|audited \d+ packages)/i
|
|
34
|
+
];
|
|
35
|
+
function normalizeMemoryText(text) {
|
|
36
|
+
return text.replace(/\r\n/g, "\n").replace(/[ \t]+$/gm, "").replace(/\n{4,}/g, "\n\n\n").trim();
|
|
37
|
+
}
|
|
38
|
+
function classifyMemoryType(input) {
|
|
39
|
+
if (input.memory_type && input.memory_type.trim()) return input.memory_type.trim();
|
|
40
|
+
const tool = input.tool_name.toLowerCase();
|
|
41
|
+
const text = input.raw_text.toLowerCase();
|
|
42
|
+
if (tool.includes("store_decision") || tool.includes("decision")) return "decision";
|
|
43
|
+
if (tool.includes("commit") || text.includes("adr-") || text.includes("architectural decision")) return "adr";
|
|
44
|
+
if (tool.includes("store_behavior") || tool.includes("behavior")) return "behavior";
|
|
45
|
+
if (tool.includes("global_procedure") || text.includes("organization-wide procedures")) return "procedure";
|
|
46
|
+
if (tool.includes("checkpoint") || text.startsWith("context checkpoint")) return "checkpoint";
|
|
47
|
+
if (tool.includes("sessionsummary") || tool.includes("session-summary")) return "summary";
|
|
48
|
+
if (tool.includes("sessionend") || text.startsWith("session ended")) return "summary";
|
|
49
|
+
if (tool.includes("send_whatsapp") || tool.includes("conversation")) return "conversation";
|
|
50
|
+
if (tool === "store_memory" || tool === "manual") return "observation";
|
|
51
|
+
if (tool === "userprompt" || tool === "slashcommand") return "conversation";
|
|
52
|
+
return "raw";
|
|
53
|
+
}
|
|
54
|
+
function shouldDropMemory(text) {
|
|
55
|
+
const normalized = normalizeMemoryText(text);
|
|
56
|
+
if (normalized.length < 10) return { drop: true, reason: "too_short" };
|
|
57
|
+
if (NOISE_DROP_PATTERNS.some((pattern) => pattern.test(normalized))) {
|
|
58
|
+
return { drop: true, reason: "known_boilerplate_noise" };
|
|
59
|
+
}
|
|
60
|
+
return { drop: false };
|
|
61
|
+
}
|
|
62
|
+
function shouldSkipEmbedding(input) {
|
|
63
|
+
const type = classifyMemoryType(input);
|
|
64
|
+
if (HIGH_VALUE_SUPERSESSION_TYPES.has(type)) return false;
|
|
65
|
+
if (type === "raw" && input.raw_text.length > 2e4) return true;
|
|
66
|
+
if (SKIP_EMBED_PATTERNS.some((pattern) => pattern.test(input.raw_text))) return true;
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
function hashMemoryContent(text) {
|
|
70
|
+
return createHash("sha256").update(normalizeMemoryText(text)).digest("hex");
|
|
71
|
+
}
|
|
72
|
+
function scopedDedupArgs(input) {
|
|
73
|
+
return [input.contentHash, input.agentId, input.projectName, input.memoryType];
|
|
74
|
+
}
|
|
75
|
+
function governMemoryRecord(record) {
|
|
76
|
+
const redacted = redactSecrets(record.raw_text);
|
|
77
|
+
const normalized = normalizeMemoryText(redacted.text);
|
|
78
|
+
const memoryType = classifyMemoryType({
|
|
79
|
+
raw_text: normalized,
|
|
80
|
+
agent_id: record.agent_id,
|
|
81
|
+
project_name: record.project_name,
|
|
82
|
+
tool_name: record.tool_name,
|
|
83
|
+
memory_type: record.memory_type
|
|
84
|
+
});
|
|
85
|
+
const drop = shouldDropMemory(normalized);
|
|
86
|
+
const skipEmbedding = shouldSkipEmbedding({
|
|
87
|
+
raw_text: normalized,
|
|
88
|
+
agent_id: record.agent_id,
|
|
89
|
+
project_name: record.project_name,
|
|
90
|
+
tool_name: record.tool_name,
|
|
91
|
+
memory_type: memoryType
|
|
92
|
+
});
|
|
93
|
+
const trajectoryValue = record.trajectory;
|
|
94
|
+
const redactedTrajectory = typeof trajectoryValue === "string" ? redactSecrets(trajectoryValue).text : record.trajectory;
|
|
95
|
+
return {
|
|
96
|
+
record: {
|
|
97
|
+
...record,
|
|
98
|
+
raw_text: normalized,
|
|
99
|
+
memory_type: memoryType,
|
|
100
|
+
vector: skipEmbedding ? null : record.vector,
|
|
101
|
+
keywords: record.keywords ? redactSecrets(record.keywords).text : record.keywords,
|
|
102
|
+
trajectory: redactedTrajectory
|
|
103
|
+
},
|
|
104
|
+
contentHash: hashMemoryContent(normalized),
|
|
105
|
+
shouldDrop: drop.drop,
|
|
106
|
+
dropReason: drop.reason,
|
|
107
|
+
skipEmbedding,
|
|
108
|
+
hygiene: {
|
|
109
|
+
dedup: true,
|
|
110
|
+
supersession: HIGH_VALUE_SUPERSESSION_TYPES.has(memoryType)
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
async function findScopedDuplicate(input) {
|
|
115
|
+
const { getClient } = await import("./lib/database.js");
|
|
116
|
+
const client = getClient();
|
|
117
|
+
const args = scopedDedupArgs(input);
|
|
118
|
+
let sql = `SELECT id FROM memories
|
|
119
|
+
WHERE content_hash = ?
|
|
120
|
+
AND agent_id = ?
|
|
121
|
+
AND project_name = ?
|
|
122
|
+
AND COALESCE(memory_type, 'raw') = ?
|
|
123
|
+
AND COALESCE(status, 'active') != 'deleted'`;
|
|
124
|
+
if (input.excludeId) {
|
|
125
|
+
sql += " AND id != ?";
|
|
126
|
+
args.push(input.excludeId);
|
|
127
|
+
}
|
|
128
|
+
sql += " ORDER BY timestamp DESC LIMIT 1";
|
|
129
|
+
const result = await client.execute({ sql, args });
|
|
130
|
+
return result.rows[0]?.id ? String(result.rows[0].id) : null;
|
|
131
|
+
}
|
|
132
|
+
async function runPostWriteMemoryHygiene(memoryId) {
|
|
133
|
+
try {
|
|
134
|
+
const { getClient } = await import("./lib/database.js");
|
|
135
|
+
const client = getClient();
|
|
136
|
+
const current = await client.execute({
|
|
137
|
+
sql: `SELECT id, agent_id, project_name, memory_type, content_hash, supersedes_id,
|
|
138
|
+
importance, timestamp
|
|
139
|
+
FROM memories
|
|
140
|
+
WHERE id = ?
|
|
141
|
+
LIMIT 1`,
|
|
142
|
+
args: [memoryId]
|
|
143
|
+
});
|
|
144
|
+
const row = current.rows[0];
|
|
145
|
+
if (!row) return;
|
|
146
|
+
const memoryType = String(row.memory_type ?? "raw");
|
|
147
|
+
const contentHash = row.content_hash ? String(row.content_hash) : null;
|
|
148
|
+
const agentId = String(row.agent_id);
|
|
149
|
+
const projectName = String(row.project_name);
|
|
150
|
+
if (contentHash) {
|
|
151
|
+
await client.execute({
|
|
152
|
+
sql: `UPDATE memories
|
|
153
|
+
SET status = 'deleted',
|
|
154
|
+
outcome = COALESCE(outcome, 'superseded')
|
|
155
|
+
WHERE id != ?
|
|
156
|
+
AND content_hash = ?
|
|
157
|
+
AND agent_id = ?
|
|
158
|
+
AND project_name = ?
|
|
159
|
+
AND COALESCE(memory_type, 'raw') = ?
|
|
160
|
+
AND COALESCE(status, 'active') = 'active'`,
|
|
161
|
+
args: [memoryId, contentHash, agentId, projectName, memoryType]
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
const supersedesId = row.supersedes_id ? String(row.supersedes_id) : null;
|
|
165
|
+
if (supersedesId && HIGH_VALUE_SUPERSESSION_TYPES.has(memoryType)) {
|
|
166
|
+
const old = await client.execute({
|
|
167
|
+
sql: `SELECT importance FROM memories WHERE id = ? LIMIT 1`,
|
|
168
|
+
args: [supersedesId]
|
|
169
|
+
});
|
|
170
|
+
const oldImportance = Number(old.rows[0]?.importance ?? 0);
|
|
171
|
+
const newImportance = Number(row.importance ?? 0);
|
|
172
|
+
await client.batch([
|
|
173
|
+
{
|
|
174
|
+
sql: `UPDATE memories
|
|
175
|
+
SET status = 'archived',
|
|
176
|
+
outcome = COALESCE(outcome, 'superseded')
|
|
177
|
+
WHERE id = ?`,
|
|
178
|
+
args: [supersedesId]
|
|
179
|
+
},
|
|
180
|
+
{
|
|
181
|
+
sql: `UPDATE memories
|
|
182
|
+
SET importance = MAX(COALESCE(importance, 5), ?),
|
|
183
|
+
parent_memory_id = COALESCE(parent_memory_id, ?)
|
|
184
|
+
WHERE id = ?`,
|
|
185
|
+
args: [Math.max(oldImportance, newImportance), supersedesId, memoryId]
|
|
186
|
+
}
|
|
187
|
+
], "write");
|
|
188
|
+
}
|
|
189
|
+
} catch (err) {
|
|
190
|
+
process.stderr.write(
|
|
191
|
+
`[memory-governor] post-write hygiene failed for ${memoryId}: ${err instanceof Error ? err.message : String(err)}
|
|
192
|
+
`
|
|
193
|
+
);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
function schedulePostWriteMemoryHygiene(memoryIds) {
|
|
197
|
+
if (process.env.EXE_SKIP_MEMORY_HYGIENE === "1") return;
|
|
198
|
+
if (memoryIds.length === 0) return;
|
|
199
|
+
const run = () => {
|
|
200
|
+
void Promise.all(memoryIds.map((id) => runPostWriteMemoryHygiene(id)));
|
|
201
|
+
};
|
|
202
|
+
if (typeof setImmediate === "function") setImmediate(run);
|
|
203
|
+
else setTimeout(run, 0);
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
export {
|
|
207
|
+
governMemoryRecord,
|
|
208
|
+
findScopedDuplicate,
|
|
209
|
+
schedulePostWriteMemoryHygiene
|
|
210
|
+
};
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
// src/lib/retrieval-health.ts
|
|
2
|
+
async function getRetrievalHealth() {
|
|
3
|
+
let embedDaemon = "unavailable";
|
|
4
|
+
try {
|
|
5
|
+
const { isDaemonAlive } = await import("./mcp-health-WDOB6XUB.js");
|
|
6
|
+
const { alive } = isDaemonAlive();
|
|
7
|
+
if (alive) {
|
|
8
|
+
try {
|
|
9
|
+
const { pingDaemon } = await import("./lib/exe-daemon-client.js");
|
|
10
|
+
const health = await pingDaemon();
|
|
11
|
+
if (health) {
|
|
12
|
+
const embeddingField = health.embedding;
|
|
13
|
+
if (embeddingField === "ok") {
|
|
14
|
+
embedDaemon = "running";
|
|
15
|
+
} else if (embeddingField === "disabled") {
|
|
16
|
+
embedDaemon = "disabled";
|
|
17
|
+
} else {
|
|
18
|
+
embedDaemon = "stopped";
|
|
19
|
+
}
|
|
20
|
+
} else {
|
|
21
|
+
embedDaemon = "stopped";
|
|
22
|
+
}
|
|
23
|
+
} catch {
|
|
24
|
+
embedDaemon = "stopped";
|
|
25
|
+
}
|
|
26
|
+
} else {
|
|
27
|
+
embedDaemon = "unavailable";
|
|
28
|
+
}
|
|
29
|
+
} catch {
|
|
30
|
+
embedDaemon = "unavailable";
|
|
31
|
+
}
|
|
32
|
+
let configuredSearchMode = "hybrid";
|
|
33
|
+
let selfQueryRouterEnabled = true;
|
|
34
|
+
try {
|
|
35
|
+
const { loadConfigSync } = await import("./lib/config.js");
|
|
36
|
+
const cfg = loadConfigSync();
|
|
37
|
+
configuredSearchMode = cfg.searchMode ?? "hybrid";
|
|
38
|
+
selfQueryRouterEnabled = cfg.selfQueryRouter ?? true;
|
|
39
|
+
} catch {
|
|
40
|
+
}
|
|
41
|
+
let actualSearchMode;
|
|
42
|
+
if (configuredSearchMode === "fts") {
|
|
43
|
+
actualSearchMode = "fts+graph";
|
|
44
|
+
} else if (embedDaemon === "running") {
|
|
45
|
+
actualSearchMode = "hybrid (vector+fts+graph)";
|
|
46
|
+
} else {
|
|
47
|
+
actualSearchMode = "fts+graph (degraded from hybrid)";
|
|
48
|
+
}
|
|
49
|
+
let queryRouter;
|
|
50
|
+
if (!selfQueryRouterEnabled) {
|
|
51
|
+
queryRouter = "disabled";
|
|
52
|
+
} else if (embedDaemon === "running" || embedDaemon === "disabled") {
|
|
53
|
+
queryRouter = process.env.ANTHROPIC_API_KEY ? "active" : "fallback";
|
|
54
|
+
} else {
|
|
55
|
+
queryRouter = "fallback";
|
|
56
|
+
}
|
|
57
|
+
let totalMemories = 0;
|
|
58
|
+
let memoriesWithVectors = 0;
|
|
59
|
+
let entities = 0;
|
|
60
|
+
let relationships = 0;
|
|
61
|
+
try {
|
|
62
|
+
const { getClient } = await import("./lib/database.js");
|
|
63
|
+
const client = getClient();
|
|
64
|
+
const [totalRes, vectorRes] = await Promise.all([
|
|
65
|
+
client.execute("SELECT COUNT(*) as cnt FROM memories WHERE status IS NULL OR status != 'deleted'"),
|
|
66
|
+
client.execute("SELECT COUNT(*) as cnt FROM memories WHERE vector IS NOT NULL AND (status IS NULL OR status != 'deleted')")
|
|
67
|
+
]);
|
|
68
|
+
totalMemories = Number(totalRes.rows[0]?.cnt ?? 0);
|
|
69
|
+
memoriesWithVectors = Number(vectorRes.rows[0]?.cnt ?? 0);
|
|
70
|
+
try {
|
|
71
|
+
const { getGraphStats } = await import("./graph-query-XEDHA2PQ.js");
|
|
72
|
+
const stats = await getGraphStats(client);
|
|
73
|
+
entities = stats.entities;
|
|
74
|
+
relationships = stats.relationships;
|
|
75
|
+
} catch {
|
|
76
|
+
}
|
|
77
|
+
} catch {
|
|
78
|
+
}
|
|
79
|
+
const staleCount = totalMemories - memoriesWithVectors;
|
|
80
|
+
const coveragePct = totalMemories > 0 ? Math.round(memoriesWithVectors / totalMemories * 100) : null;
|
|
81
|
+
return {
|
|
82
|
+
embedDaemon,
|
|
83
|
+
searchMode: {
|
|
84
|
+
configured: configuredSearchMode,
|
|
85
|
+
actual: actualSearchMode
|
|
86
|
+
},
|
|
87
|
+
queryRouter,
|
|
88
|
+
vectorBackfill: {
|
|
89
|
+
totalMemories,
|
|
90
|
+
memoriesWithVectors,
|
|
91
|
+
staleCount,
|
|
92
|
+
coveragePct
|
|
93
|
+
},
|
|
94
|
+
graph: {
|
|
95
|
+
entities,
|
|
96
|
+
relationships
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
export {
|
|
102
|
+
getRetrievalHealth
|
|
103
|
+
};
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import {
|
|
2
|
+
EXE_AI_DIR
|
|
3
|
+
} from "./chunk-T3B5RK4H.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/worker-gate.ts
|
|
6
|
+
import { readdirSync, writeFileSync, unlinkSync, mkdirSync, existsSync, readFileSync } from "fs";
|
|
7
|
+
import path from "path";
|
|
8
|
+
import { totalmem, cpus } from "os";
|
|
9
|
+
var WORKER_PID_DIR = path.join(EXE_AI_DIR, "worker-pids");
|
|
10
|
+
function computeMaxWorkers() {
|
|
11
|
+
const totalGB = totalmem() / 1024 ** 3;
|
|
12
|
+
const coreCount = cpus().length;
|
|
13
|
+
const byRam = Math.floor(totalGB / 4);
|
|
14
|
+
const byCpu = Math.floor(coreCount / 2);
|
|
15
|
+
return Math.max(2, Math.min(8, Math.min(byRam, byCpu)));
|
|
16
|
+
}
|
|
17
|
+
var MAX_CONCURRENT_WORKERS = process.env.EXE_MAX_WORKERS ? Math.max(1, parseInt(process.env.EXE_MAX_WORKERS, 10) || 3) : computeMaxWorkers();
|
|
18
|
+
function tryAcquireWorkerSlot() {
|
|
19
|
+
try {
|
|
20
|
+
mkdirSync(WORKER_PID_DIR, { recursive: true });
|
|
21
|
+
const reservationId = `res-${process.pid}-${Date.now()}`;
|
|
22
|
+
const reservationPath = path.join(WORKER_PID_DIR, `${reservationId}.pid`);
|
|
23
|
+
writeFileSync(reservationPath, String(process.pid));
|
|
24
|
+
const files = readdirSync(WORKER_PID_DIR);
|
|
25
|
+
let alive = 0;
|
|
26
|
+
for (const f of files) {
|
|
27
|
+
if (!f.endsWith(".pid")) continue;
|
|
28
|
+
if (f.startsWith("res-")) {
|
|
29
|
+
const resParts = f.replace(".pid", "").split("-");
|
|
30
|
+
const resPid = parseInt(resParts[1] ?? "", 10);
|
|
31
|
+
if (!isNaN(resPid) && resPid > 0) {
|
|
32
|
+
try {
|
|
33
|
+
process.kill(resPid, 0);
|
|
34
|
+
alive++;
|
|
35
|
+
} catch {
|
|
36
|
+
try {
|
|
37
|
+
unlinkSync(path.join(WORKER_PID_DIR, f));
|
|
38
|
+
} catch {
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
} else {
|
|
42
|
+
alive++;
|
|
43
|
+
}
|
|
44
|
+
continue;
|
|
45
|
+
}
|
|
46
|
+
const dashIdx = f.lastIndexOf("-");
|
|
47
|
+
const pid = parseInt(f.slice(dashIdx + 1).replace(".pid", ""), 10);
|
|
48
|
+
if (isNaN(pid)) continue;
|
|
49
|
+
try {
|
|
50
|
+
process.kill(pid, 0);
|
|
51
|
+
alive++;
|
|
52
|
+
} catch {
|
|
53
|
+
try {
|
|
54
|
+
unlinkSync(path.join(WORKER_PID_DIR, f));
|
|
55
|
+
} catch {
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
if (alive >= MAX_CONCURRENT_WORKERS) {
|
|
60
|
+
try {
|
|
61
|
+
unlinkSync(reservationPath);
|
|
62
|
+
} catch {
|
|
63
|
+
}
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
try {
|
|
67
|
+
unlinkSync(reservationPath);
|
|
68
|
+
} catch {
|
|
69
|
+
}
|
|
70
|
+
return true;
|
|
71
|
+
} catch {
|
|
72
|
+
return true;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
function registerWorkerPid(pid) {
|
|
76
|
+
try {
|
|
77
|
+
mkdirSync(WORKER_PID_DIR, { recursive: true });
|
|
78
|
+
writeFileSync(path.join(WORKER_PID_DIR, `worker-${pid}.pid`), String(pid));
|
|
79
|
+
} catch {
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
function cleanupWorkerPid() {
|
|
83
|
+
try {
|
|
84
|
+
unlinkSync(path.join(WORKER_PID_DIR, `worker-${process.pid}.pid`));
|
|
85
|
+
} catch {
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
var BACKFILL_LOCK = path.join(WORKER_PID_DIR, "backfill.lock");
|
|
89
|
+
function tryAcquireBackfillLock() {
|
|
90
|
+
try {
|
|
91
|
+
mkdirSync(WORKER_PID_DIR, { recursive: true });
|
|
92
|
+
if (existsSync(BACKFILL_LOCK)) {
|
|
93
|
+
try {
|
|
94
|
+
const pid = parseInt(
|
|
95
|
+
readFileSync(BACKFILL_LOCK, "utf8").trim(),
|
|
96
|
+
10
|
|
97
|
+
);
|
|
98
|
+
if (!isNaN(pid) && pid > 0) {
|
|
99
|
+
try {
|
|
100
|
+
process.kill(pid, 0);
|
|
101
|
+
return false;
|
|
102
|
+
} catch {
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
} catch {
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
writeFileSync(BACKFILL_LOCK, String(process.pid));
|
|
109
|
+
return true;
|
|
110
|
+
} catch {
|
|
111
|
+
return true;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
function releaseBackfillLock() {
|
|
115
|
+
try {
|
|
116
|
+
unlinkSync(BACKFILL_LOCK);
|
|
117
|
+
} catch {
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
async function getTaskAwareCapacity() {
|
|
121
|
+
const { getClient } = await import("./lib/database.js");
|
|
122
|
+
const { sessionScopeFilter } = await import("./task-scope-YV2WPKRD.js");
|
|
123
|
+
const client = getClient();
|
|
124
|
+
const scope = sessionScopeFilter();
|
|
125
|
+
const result = await client.execute({
|
|
126
|
+
sql: `SELECT assigned_to, COUNT(*) as cnt
|
|
127
|
+
FROM tasks
|
|
128
|
+
WHERE status IN ('open', 'in_progress')${scope.sql}
|
|
129
|
+
GROUP BY assigned_to`,
|
|
130
|
+
args: [...scope.args]
|
|
131
|
+
});
|
|
132
|
+
const busyAgents = [];
|
|
133
|
+
let totalInProgress = 0;
|
|
134
|
+
for (const row of result.rows) {
|
|
135
|
+
const agent = String(row.assigned_to ?? "");
|
|
136
|
+
const count = Number(row.cnt ?? 0);
|
|
137
|
+
if (agent && count > 0) {
|
|
138
|
+
busyAgents.push(agent);
|
|
139
|
+
totalInProgress += count;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
const idleAgents = [];
|
|
143
|
+
try {
|
|
144
|
+
const { listTmuxSessions } = await import("./lib/tmux-status.js");
|
|
145
|
+
const { isExeSession } = await import("./lib/tmux-routing.js");
|
|
146
|
+
const { baseAgentName } = await import("./lib/employees.js");
|
|
147
|
+
const liveSessions = listTmuxSessions().filter((s) => !isExeSession(s) && s.includes("-"));
|
|
148
|
+
const liveAgentNames = new Set(liveSessions.map((s) => baseAgentName(s.split("-")[0] ?? "")));
|
|
149
|
+
for (const name of liveAgentNames) {
|
|
150
|
+
if (name && !busyAgents.includes(name)) {
|
|
151
|
+
idleAgents.push(name);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
} catch {
|
|
155
|
+
}
|
|
156
|
+
return { busyAgents, idleAgents, totalInProgress };
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
export {
|
|
160
|
+
MAX_CONCURRENT_WORKERS,
|
|
161
|
+
tryAcquireWorkerSlot,
|
|
162
|
+
registerWorkerPid,
|
|
163
|
+
cleanupWorkerPid,
|
|
164
|
+
tryAcquireBackfillLock,
|
|
165
|
+
releaseBackfillLock,
|
|
166
|
+
getTaskAwareCapacity
|
|
167
|
+
};
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import {
|
|
2
|
+
loadEmployees
|
|
3
|
+
} from "./chunk-52UDAVZE.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/agent-symlinks.ts
|
|
6
|
+
import os from "os";
|
|
7
|
+
import path from "path";
|
|
8
|
+
import {
|
|
9
|
+
existsSync,
|
|
10
|
+
lstatSync,
|
|
11
|
+
mkdirSync,
|
|
12
|
+
readlinkSync,
|
|
13
|
+
symlinkSync
|
|
14
|
+
} from "fs";
|
|
15
|
+
function claudeAgentsDir(homeDir) {
|
|
16
|
+
return path.join(homeDir, ".claude", "agents");
|
|
17
|
+
}
|
|
18
|
+
function identitySourcePath(homeDir, agentId) {
|
|
19
|
+
return path.join(homeDir, ".exe-os", "identity", `${agentId}.md`);
|
|
20
|
+
}
|
|
21
|
+
function claudeAgentLinkPath(homeDir, agentId) {
|
|
22
|
+
return path.join(claudeAgentsDir(homeDir), `${agentId}.md`);
|
|
23
|
+
}
|
|
24
|
+
function ensureAgentSymlink(agentId, homeDir = os.homedir()) {
|
|
25
|
+
const target = identitySourcePath(homeDir, agentId);
|
|
26
|
+
const link = claudeAgentLinkPath(homeDir, agentId);
|
|
27
|
+
mkdirSync(claudeAgentsDir(homeDir), { recursive: true });
|
|
28
|
+
if (existsSync(link)) {
|
|
29
|
+
let stat;
|
|
30
|
+
try {
|
|
31
|
+
stat = lstatSync(link);
|
|
32
|
+
} catch {
|
|
33
|
+
return { agentId, action: "conflict", target, link, conflict: "stat_failed" };
|
|
34
|
+
}
|
|
35
|
+
if (!stat.isSymbolicLink()) {
|
|
36
|
+
return { agentId, action: "conflict", target, link, conflict: "regular_file" };
|
|
37
|
+
}
|
|
38
|
+
let currentTarget;
|
|
39
|
+
try {
|
|
40
|
+
currentTarget = readlinkSync(link);
|
|
41
|
+
} catch {
|
|
42
|
+
return { agentId, action: "conflict", target, link, conflict: "readlink_failed" };
|
|
43
|
+
}
|
|
44
|
+
if (currentTarget === target) {
|
|
45
|
+
return { agentId, action: "already_correct", target, link };
|
|
46
|
+
}
|
|
47
|
+
return { agentId, action: "conflict", target, link, conflict: `points_to:${currentTarget}` };
|
|
48
|
+
}
|
|
49
|
+
try {
|
|
50
|
+
symlinkSync(target, link);
|
|
51
|
+
} catch (err) {
|
|
52
|
+
return {
|
|
53
|
+
agentId,
|
|
54
|
+
action: "conflict",
|
|
55
|
+
target,
|
|
56
|
+
link,
|
|
57
|
+
conflict: err instanceof Error ? err.message : String(err)
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
return { agentId, action: "created", target, link };
|
|
61
|
+
}
|
|
62
|
+
async function ensureAllAgentSymlinks(homeDir = os.homedir()) {
|
|
63
|
+
const employees = await loadEmployees();
|
|
64
|
+
return employees.map((emp) => ensureAgentSymlink(emp.name, homeDir));
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
export {
|
|
68
|
+
ensureAgentSymlink,
|
|
69
|
+
ensureAllAgentSymlinks
|
|
70
|
+
};
|