@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,181 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getClient
|
|
3
|
+
} from "./chunk-WUKEXVOR.js";
|
|
4
|
+
import {
|
|
5
|
+
loadConfig
|
|
6
|
+
} from "./chunk-T3B5RK4H.js";
|
|
7
|
+
|
|
8
|
+
// src/lib/reminders.ts
|
|
9
|
+
import crypto from "crypto";
|
|
10
|
+
async function getCloudConfig() {
|
|
11
|
+
try {
|
|
12
|
+
const config = await loadConfig();
|
|
13
|
+
if (config.cloud?.apiKey && config.cloud?.endpoint) {
|
|
14
|
+
return { apiKey: config.cloud.apiKey, endpoint: config.cloud.endpoint };
|
|
15
|
+
}
|
|
16
|
+
} catch {
|
|
17
|
+
}
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
function apiBaseUrl(cloud) {
|
|
21
|
+
try {
|
|
22
|
+
const url = new URL(cloud.endpoint);
|
|
23
|
+
if (url.hostname.startsWith("sync.")) {
|
|
24
|
+
url.hostname = url.hostname.replace(/^sync\./, "api.");
|
|
25
|
+
return url.origin;
|
|
26
|
+
}
|
|
27
|
+
} catch {
|
|
28
|
+
}
|
|
29
|
+
return "https://api.askexe.com";
|
|
30
|
+
}
|
|
31
|
+
async function cloudPushReminder(cloud, text, dueDate) {
|
|
32
|
+
try {
|
|
33
|
+
const base = apiBaseUrl(cloud);
|
|
34
|
+
await fetch(`${base}/v1/reminders`, {
|
|
35
|
+
method: "POST",
|
|
36
|
+
headers: {
|
|
37
|
+
"Authorization": `Bearer ${cloud.apiKey}`,
|
|
38
|
+
"Content-Type": "application/json"
|
|
39
|
+
},
|
|
40
|
+
body: JSON.stringify({ text, due_date: dueDate })
|
|
41
|
+
});
|
|
42
|
+
} catch (err) {
|
|
43
|
+
process.stderr.write(`[reminders] cloud push failed: ${err instanceof Error ? err.message : String(err)}
|
|
44
|
+
`);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
async function cloudFetchReminders(cloud) {
|
|
48
|
+
try {
|
|
49
|
+
const base = apiBaseUrl(cloud);
|
|
50
|
+
const res = await fetch(`${base}/v1/reminders`, {
|
|
51
|
+
method: "GET",
|
|
52
|
+
headers: {
|
|
53
|
+
"Authorization": `Bearer ${cloud.apiKey}`
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
if (!res.ok) return [];
|
|
57
|
+
const data = await res.json();
|
|
58
|
+
if (!Array.isArray(data.items)) return [];
|
|
59
|
+
return data.items.map((r) => ({
|
|
60
|
+
id: r.id,
|
|
61
|
+
text: r.text,
|
|
62
|
+
createdAt: r.created_at,
|
|
63
|
+
dueDate: r.due_date,
|
|
64
|
+
completedAt: r.completed_at,
|
|
65
|
+
source: "cloud"
|
|
66
|
+
}));
|
|
67
|
+
} catch (err) {
|
|
68
|
+
process.stderr.write(`[reminders] cloud fetch failed: ${err instanceof Error ? err.message : String(err)}
|
|
69
|
+
`);
|
|
70
|
+
return [];
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
async function cloudDeleteReminder(cloud, id) {
|
|
74
|
+
try {
|
|
75
|
+
const base = apiBaseUrl(cloud);
|
|
76
|
+
await fetch(`${base}/v1/reminders/${encodeURIComponent(id)}`, {
|
|
77
|
+
method: "DELETE",
|
|
78
|
+
headers: {
|
|
79
|
+
"Authorization": `Bearer ${cloud.apiKey}`
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
} catch (err) {
|
|
83
|
+
process.stderr.write(`[reminders] cloud delete failed: ${err instanceof Error ? err.message : String(err)}
|
|
84
|
+
`);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
function dedup(local, cloud) {
|
|
88
|
+
const localKeys = /* @__PURE__ */ new Set();
|
|
89
|
+
for (const r of local) {
|
|
90
|
+
localKeys.add(`${r.text.trim().toLowerCase()}|${r.dueDate ?? ""}`);
|
|
91
|
+
}
|
|
92
|
+
const merged = local.map((r) => ({ ...r, source: "local" }));
|
|
93
|
+
for (const r of cloud) {
|
|
94
|
+
const key = `${r.text.trim().toLowerCase()}|${r.dueDate ?? ""}`;
|
|
95
|
+
if (localKeys.has(key)) {
|
|
96
|
+
const existing = merged.find(
|
|
97
|
+
(m) => m.text.trim().toLowerCase() === r.text.trim().toLowerCase() && (m.dueDate ?? "") === (r.dueDate ?? "")
|
|
98
|
+
);
|
|
99
|
+
if (existing) existing.source = "both";
|
|
100
|
+
} else {
|
|
101
|
+
merged.push({ ...r, source: "cloud" });
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return merged;
|
|
105
|
+
}
|
|
106
|
+
async function createReminder(text, dueDate) {
|
|
107
|
+
const client = getClient();
|
|
108
|
+
const id = crypto.randomUUID();
|
|
109
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
110
|
+
await client.execute({
|
|
111
|
+
sql: `INSERT INTO reminders (id, text, created_at, due_date) VALUES (?, ?, ?, ?)`,
|
|
112
|
+
args: [id, text, now, dueDate ?? null]
|
|
113
|
+
});
|
|
114
|
+
const cloud = await getCloudConfig();
|
|
115
|
+
if (cloud) {
|
|
116
|
+
cloudPushReminder(cloud, text, dueDate ?? null).catch(() => {
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
return { id, text, createdAt: now, dueDate: dueDate ?? null, completedAt: null };
|
|
120
|
+
}
|
|
121
|
+
async function listReminders(includeCompleted = false) {
|
|
122
|
+
const client = getClient();
|
|
123
|
+
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`;
|
|
124
|
+
const result = await client.execute(sql);
|
|
125
|
+
const local = result.rows.map((row) => ({
|
|
126
|
+
id: String(row.id),
|
|
127
|
+
text: String(row.text),
|
|
128
|
+
createdAt: String(row.created_at),
|
|
129
|
+
dueDate: row.due_date ? String(row.due_date) : null,
|
|
130
|
+
completedAt: row.completed_at ? String(row.completed_at) : null
|
|
131
|
+
}));
|
|
132
|
+
const cloud = await getCloudConfig();
|
|
133
|
+
if (cloud) {
|
|
134
|
+
const cloudReminders = await cloudFetchReminders(cloud);
|
|
135
|
+
return dedup(local, cloudReminders);
|
|
136
|
+
}
|
|
137
|
+
return local;
|
|
138
|
+
}
|
|
139
|
+
async function completeReminder(idOrText) {
|
|
140
|
+
const client = getClient();
|
|
141
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
142
|
+
let result = await client.execute({
|
|
143
|
+
sql: `SELECT id, text FROM reminders WHERE id = ? AND completed_at IS NULL`,
|
|
144
|
+
args: [idOrText]
|
|
145
|
+
});
|
|
146
|
+
if (result.rows.length === 0) {
|
|
147
|
+
result = await client.execute({
|
|
148
|
+
sql: `SELECT id, text FROM reminders WHERE completed_at IS NULL AND text LIKE '%' || ? || '%' LIMIT 1`,
|
|
149
|
+
args: [idOrText]
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
if (result.rows.length === 0) return null;
|
|
153
|
+
const row = result.rows[0];
|
|
154
|
+
const id = String(row.id);
|
|
155
|
+
const text = String(row.text);
|
|
156
|
+
await client.execute({
|
|
157
|
+
sql: `UPDATE reminders SET completed_at = ? WHERE id = ?`,
|
|
158
|
+
args: [now, id]
|
|
159
|
+
});
|
|
160
|
+
const cloud = await getCloudConfig();
|
|
161
|
+
if (cloud) {
|
|
162
|
+
cloudDeleteReminder(cloud, id).catch(() => {
|
|
163
|
+
});
|
|
164
|
+
cloudFetchReminders(cloud).then((cloudReminders) => {
|
|
165
|
+
for (const cr of cloudReminders) {
|
|
166
|
+
if (cr.text.trim().toLowerCase() === text.trim().toLowerCase()) {
|
|
167
|
+
cloudDeleteReminder(cloud, cr.id).catch(() => {
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
}).catch(() => {
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
return { id, text, createdAt: "", dueDate: null, completedAt: now };
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
export {
|
|
178
|
+
createReminder,
|
|
179
|
+
listReminders,
|
|
180
|
+
completeReminder
|
|
181
|
+
};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import {
|
|
2
|
+
createReminder
|
|
3
|
+
} from "./chunk-6TRSVY7L.js";
|
|
4
|
+
|
|
5
|
+
// src/mcp/tools/create-reminder.ts
|
|
6
|
+
import { z } from "zod";
|
|
7
|
+
function registerCreateReminder(server) {
|
|
8
|
+
server.registerTool(
|
|
9
|
+
"create_reminder",
|
|
10
|
+
{
|
|
11
|
+
title: "Create Reminder",
|
|
12
|
+
description: "Set a reminder for the founder. Shown in the boot brief every session.",
|
|
13
|
+
inputSchema: {
|
|
14
|
+
text: z.string().describe("What to remind about"),
|
|
15
|
+
due_date: z.string().optional().describe("Optional due date \u2014 ISO date (2026-04-01) or null for persistent")
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
async ({ text, due_date }) => {
|
|
19
|
+
const reminder = await createReminder(text, due_date);
|
|
20
|
+
const dueStr = reminder.dueDate ? ` (due: ${reminder.dueDate})` : "";
|
|
21
|
+
return {
|
|
22
|
+
content: [{ type: "text", text: `Reminder set: "${reminder.text}"${dueStr}` }]
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export {
|
|
29
|
+
registerCreateReminder
|
|
30
|
+
};
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
import {
|
|
2
|
+
sessionScopeFilter
|
|
3
|
+
} from "./chunk-PWPJK7KB.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-NV6JEWGL.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,60 @@
|
|
|
1
|
+
// src/lib/mcp-health.ts
|
|
2
|
+
import { existsSync, readFileSync } from "fs";
|
|
3
|
+
import path from "path";
|
|
4
|
+
import { homedir } from "os";
|
|
5
|
+
var PID_PATH = path.join(homedir(), ".exe-os", "exed.pid");
|
|
6
|
+
function isDaemonAlive() {
|
|
7
|
+
if (_isDaemonProcess) {
|
|
8
|
+
return { alive: true, pid: process.pid };
|
|
9
|
+
}
|
|
10
|
+
try {
|
|
11
|
+
if (!existsSync(PID_PATH)) {
|
|
12
|
+
const socketPath = process.env.EXE_DAEMON_SOCK ?? path.join(homedir(), ".exe-os", "exed.sock");
|
|
13
|
+
if (existsSync(socketPath)) return { alive: true, pid: null };
|
|
14
|
+
return { alive: false, pid: null };
|
|
15
|
+
}
|
|
16
|
+
const pid = parseInt(readFileSync(PID_PATH, "utf8").trim(), 10);
|
|
17
|
+
if (!Number.isFinite(pid) || pid <= 0) return { alive: false, pid: null };
|
|
18
|
+
process.kill(pid, 0);
|
|
19
|
+
return { alive: true, pid };
|
|
20
|
+
} catch {
|
|
21
|
+
return { alive: false, pid: null };
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
function isMcpHealthy(_timeoutMs = 2e3) {
|
|
25
|
+
if (_isDaemonProcess) return true;
|
|
26
|
+
const { alive } = isDaemonAlive();
|
|
27
|
+
if (!alive) return false;
|
|
28
|
+
const socketPath = process.env.EXE_DAEMON_SOCK ?? process.env.EXE_EMBED_SOCK ?? path.join(homedir(), ".exe-os", "exed.sock");
|
|
29
|
+
return existsSync(socketPath);
|
|
30
|
+
}
|
|
31
|
+
var _isDaemonProcess = false;
|
|
32
|
+
function markAsDaemonProcess() {
|
|
33
|
+
_isDaemonProcess = true;
|
|
34
|
+
}
|
|
35
|
+
var EVENT_LOOP_DEGRADED_THRESHOLD_MS = 5e3;
|
|
36
|
+
var _eventLoopLagMs = 0;
|
|
37
|
+
var _eventLoopLagUpdatedAt = 0;
|
|
38
|
+
function setEventLoopLagMs(lagMs) {
|
|
39
|
+
_eventLoopLagMs = lagMs;
|
|
40
|
+
_eventLoopLagUpdatedAt = Date.now();
|
|
41
|
+
}
|
|
42
|
+
function getEventLoopLagMs() {
|
|
43
|
+
return _eventLoopLagMs;
|
|
44
|
+
}
|
|
45
|
+
function getEventLoopLagUpdatedAt() {
|
|
46
|
+
return _eventLoopLagUpdatedAt;
|
|
47
|
+
}
|
|
48
|
+
function isEventLoopDegraded() {
|
|
49
|
+
return _eventLoopLagMs > EVENT_LOOP_DEGRADED_THRESHOLD_MS;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export {
|
|
53
|
+
isDaemonAlive,
|
|
54
|
+
isMcpHealthy,
|
|
55
|
+
markAsDaemonProcess,
|
|
56
|
+
setEventLoopLagMs,
|
|
57
|
+
getEventLoopLagMs,
|
|
58
|
+
getEventLoopLagUpdatedAt,
|
|
59
|
+
isEventLoopDegraded
|
|
60
|
+
};
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getClient
|
|
3
|
+
} from "./chunk-WUKEXVOR.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/pipeline-router.ts
|
|
6
|
+
import crypto from "crypto";
|
|
7
|
+
async function sinkConversationStore(msg, agentResponse, agentName) {
|
|
8
|
+
try {
|
|
9
|
+
const client = getClient();
|
|
10
|
+
const id = crypto.randomUUID();
|
|
11
|
+
const mediaJson = msg.media ? JSON.stringify(msg.media) : null;
|
|
12
|
+
await client.execute({
|
|
13
|
+
sql: `INSERT INTO conversations
|
|
14
|
+
(id, platform, external_id, sender_id, sender_name, sender_phone, sender_email,
|
|
15
|
+
recipient_id, channel_id, thread_id, reply_to_id,
|
|
16
|
+
content_text, content_media, agent_response, agent_name,
|
|
17
|
+
timestamp, ingested_at)
|
|
18
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,
|
|
19
|
+
args: [
|
|
20
|
+
id,
|
|
21
|
+
msg.platform,
|
|
22
|
+
msg.messageId,
|
|
23
|
+
msg.senderId,
|
|
24
|
+
msg.senderName ?? null,
|
|
25
|
+
msg.senderPhone ?? null,
|
|
26
|
+
msg.senderEmail ?? null,
|
|
27
|
+
msg.accountId ?? null,
|
|
28
|
+
msg.channelId,
|
|
29
|
+
msg.threadId ?? `${msg.platform}:${msg.channelId}`,
|
|
30
|
+
msg.replyTo?.messageId ?? null,
|
|
31
|
+
msg.text ?? null,
|
|
32
|
+
mediaJson,
|
|
33
|
+
agentResponse ?? null,
|
|
34
|
+
agentName ?? null,
|
|
35
|
+
msg.timestamp,
|
|
36
|
+
(/* @__PURE__ */ new Date()).toISOString()
|
|
37
|
+
]
|
|
38
|
+
});
|
|
39
|
+
return true;
|
|
40
|
+
} catch (err) {
|
|
41
|
+
process.stderr.write(
|
|
42
|
+
`[pipeline] conversation-store error: ${err instanceof Error ? err.message : String(err)}
|
|
43
|
+
`
|
|
44
|
+
);
|
|
45
|
+
return false;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
async function sinkMemory(msg, agentResponse, agentName) {
|
|
49
|
+
try {
|
|
50
|
+
const { embed } = await import("./lib/embedder.js");
|
|
51
|
+
const { writeMemory, flushBatch } = await import("./lib/store.js");
|
|
52
|
+
const direction = agentResponse ? "conversation" : "inbound";
|
|
53
|
+
const rawText = [
|
|
54
|
+
`[${msg.platform}] ${direction} from ${msg.senderName ?? msg.senderId}`,
|
|
55
|
+
msg.text ? `Message: ${msg.text}` : null,
|
|
56
|
+
agentResponse ? `Agent (${agentName ?? "unknown"}): ${agentResponse}` : null
|
|
57
|
+
].filter(Boolean).join("\n");
|
|
58
|
+
const vector = await embed(rawText);
|
|
59
|
+
await writeMemory({
|
|
60
|
+
id: crypto.randomUUID(),
|
|
61
|
+
agent_id: agentName ?? "gateway",
|
|
62
|
+
agent_role: "gateway",
|
|
63
|
+
session_id: `gateway-${msg.platform}`,
|
|
64
|
+
timestamp: msg.timestamp,
|
|
65
|
+
tool_name: `gateway-${msg.platform}`,
|
|
66
|
+
project_name: "exe-os",
|
|
67
|
+
has_error: false,
|
|
68
|
+
raw_text: rawText,
|
|
69
|
+
vector,
|
|
70
|
+
importance: 4,
|
|
71
|
+
confidence: 0.8
|
|
72
|
+
});
|
|
73
|
+
await flushBatch();
|
|
74
|
+
return true;
|
|
75
|
+
} catch (err) {
|
|
76
|
+
process.stderr.write(
|
|
77
|
+
`[pipeline] memory-sink error: ${err instanceof Error ? err.message : String(err)}
|
|
78
|
+
`
|
|
79
|
+
);
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
async function sinkCRM(msg, agentResponse, agentName) {
|
|
84
|
+
try {
|
|
85
|
+
const { isCRMBridgeEnabled, pushConversationToCRM, pushInboundMessageToCRM } = await import("./crm-bridge-BVTB6LZK.js");
|
|
86
|
+
if (!isCRMBridgeEnabled()) return false;
|
|
87
|
+
if (agentResponse) {
|
|
88
|
+
await pushConversationToCRM({
|
|
89
|
+
platform: msg.platform,
|
|
90
|
+
senderId: msg.senderId,
|
|
91
|
+
senderName: msg.senderName,
|
|
92
|
+
messageText: msg.text,
|
|
93
|
+
agentResponse,
|
|
94
|
+
agentName: agentName ?? "unknown",
|
|
95
|
+
timestamp: msg.timestamp,
|
|
96
|
+
accountId: msg.accountId
|
|
97
|
+
});
|
|
98
|
+
} else {
|
|
99
|
+
await pushInboundMessageToCRM({
|
|
100
|
+
platform: msg.platform,
|
|
101
|
+
senderId: msg.senderId,
|
|
102
|
+
senderName: msg.senderName,
|
|
103
|
+
messageText: msg.text,
|
|
104
|
+
timestamp: msg.timestamp,
|
|
105
|
+
accountId: msg.accountId
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
return true;
|
|
109
|
+
} catch (err) {
|
|
110
|
+
process.stderr.write(
|
|
111
|
+
`[pipeline] crm-sink error: ${err instanceof Error ? err.message : String(err)}
|
|
112
|
+
`
|
|
113
|
+
);
|
|
114
|
+
return false;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
async function sinkWiki(msg, agentResponse) {
|
|
118
|
+
try {
|
|
119
|
+
const { createWikiClient } = await import("./wiki-client-HETQ6XHM.js");
|
|
120
|
+
const client = await createWikiClient();
|
|
121
|
+
if (!client) return false;
|
|
122
|
+
const content = msg.text ?? "";
|
|
123
|
+
if (content.length < 50) return false;
|
|
124
|
+
const { chatInWorkspace } = await import("./wiki-client-HETQ6XHM.js");
|
|
125
|
+
const ingestText = [
|
|
126
|
+
`[${msg.platform}] Message from ${msg.senderName ?? msg.senderId} (${msg.timestamp}):`,
|
|
127
|
+
content,
|
|
128
|
+
agentResponse ? `
|
|
129
|
+
Agent response: ${agentResponse}` : ""
|
|
130
|
+
].join("\n");
|
|
131
|
+
await chatInWorkspace(client, "conversations", ingestText, "chat");
|
|
132
|
+
return true;
|
|
133
|
+
} catch (err) {
|
|
134
|
+
process.stderr.write(
|
|
135
|
+
`[pipeline] wiki-sink error: ${err instanceof Error ? err.message : String(err)}
|
|
136
|
+
`
|
|
137
|
+
);
|
|
138
|
+
return false;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
async function sinkEntityExtraction(msg, agentResponse, agentName) {
|
|
142
|
+
try {
|
|
143
|
+
const { extractFromConversation } = await import("./conversation-entity-extractor-ZN3J4WGY.js");
|
|
144
|
+
const { storeExtraction } = await import("./graph-rag-HFBYZF3M.js");
|
|
145
|
+
if ((msg.text?.length ?? 0) < 20) return false;
|
|
146
|
+
if (msg.isHistorical) return false;
|
|
147
|
+
const extraction = await extractFromConversation(msg, agentResponse, agentName);
|
|
148
|
+
if (extraction.entities.length === 0) return false;
|
|
149
|
+
const client = getClient();
|
|
150
|
+
const memoryId = `conv:${msg.messageId}`;
|
|
151
|
+
await storeExtraction(client, extraction, memoryId, msg.timestamp);
|
|
152
|
+
import("./conversation-wiki-populator-CIWEI4FV.js").then(
|
|
153
|
+
({ populateWikiFromExtraction }) => populateWikiFromExtraction(extraction, msg, agentResponse, agentName)
|
|
154
|
+
).catch((err) => {
|
|
155
|
+
process.stderr.write(
|
|
156
|
+
`[pipeline] wiki-population error: ${err instanceof Error ? err.message : String(err)}
|
|
157
|
+
`
|
|
158
|
+
);
|
|
159
|
+
});
|
|
160
|
+
return true;
|
|
161
|
+
} catch (err) {
|
|
162
|
+
process.stderr.write(
|
|
163
|
+
`[pipeline] entity-extraction-sink error: ${err instanceof Error ? err.message : String(err)}
|
|
164
|
+
`
|
|
165
|
+
);
|
|
166
|
+
return false;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
async function ingest(msg, agentResponse, agentName) {
|
|
170
|
+
const errors = [];
|
|
171
|
+
const [conversationStored, memorySunk, crmSunk, wikiSunk, entityExtracted] = await Promise.all([
|
|
172
|
+
sinkConversationStore(msg, agentResponse, agentName).catch((e) => {
|
|
173
|
+
errors.push(`conversation: ${e}`);
|
|
174
|
+
return false;
|
|
175
|
+
}),
|
|
176
|
+
sinkMemory(msg, agentResponse, agentName).catch((e) => {
|
|
177
|
+
errors.push(`memory: ${e}`);
|
|
178
|
+
return false;
|
|
179
|
+
}),
|
|
180
|
+
sinkCRM(msg, agentResponse, agentName).catch((e) => {
|
|
181
|
+
errors.push(`crm: ${e}`);
|
|
182
|
+
return false;
|
|
183
|
+
}),
|
|
184
|
+
sinkWiki(msg, agentResponse).catch((e) => {
|
|
185
|
+
errors.push(`wiki: ${e}`);
|
|
186
|
+
return false;
|
|
187
|
+
}),
|
|
188
|
+
sinkEntityExtraction(msg, agentResponse, agentName).catch((e) => {
|
|
189
|
+
errors.push(`entity-extraction: ${e}`);
|
|
190
|
+
return false;
|
|
191
|
+
})
|
|
192
|
+
]);
|
|
193
|
+
if (errors.length > 0) {
|
|
194
|
+
process.stderr.write(
|
|
195
|
+
`[pipeline] ${errors.length} sink error(s): ${errors.join("; ")}
|
|
196
|
+
`
|
|
197
|
+
);
|
|
198
|
+
}
|
|
199
|
+
return { conversationStored, memorySunk, crmSunk, wikiSunk, entityExtracted, errors };
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
export {
|
|
203
|
+
ingest
|
|
204
|
+
};
|