@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,204 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getClient
|
|
3
|
+
} from "./chunk-52UDAVZE.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
|
+
};
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import {
|
|
2
|
+
MODELS_DIR
|
|
3
|
+
} from "./chunk-T3B5RK4H.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/reranker.ts
|
|
6
|
+
import path from "path";
|
|
7
|
+
import { existsSync } from "fs";
|
|
8
|
+
var RERANKER_MODEL_FILE = process.env.EXE_RERANK_MODEL_FILE ?? "exe-reranker-v1-q4_k_m.gguf";
|
|
9
|
+
function isRerankerAvailable() {
|
|
10
|
+
return existsSync(path.join(MODELS_DIR, RERANKER_MODEL_FILE));
|
|
11
|
+
}
|
|
12
|
+
function getRerankerModelPath() {
|
|
13
|
+
return path.join(MODELS_DIR, RERANKER_MODEL_FILE);
|
|
14
|
+
}
|
|
15
|
+
async function disposeReranker() {
|
|
16
|
+
}
|
|
17
|
+
async function rerankWithScores(query, texts, topK) {
|
|
18
|
+
if (texts.length === 0) return [];
|
|
19
|
+
const { rerankViaWorker } = await import("./lib/exe-daemon.js");
|
|
20
|
+
const scored = await rerankViaWorker(query, texts, topK);
|
|
21
|
+
return scored.map((s) => ({
|
|
22
|
+
text: texts[s.index] ?? "",
|
|
23
|
+
score: s.score,
|
|
24
|
+
index: s.index
|
|
25
|
+
}));
|
|
26
|
+
}
|
|
27
|
+
async function rerank(query, candidates, topK = 5) {
|
|
28
|
+
if (candidates.length === 0) return [];
|
|
29
|
+
if (candidates.length <= topK) return candidates;
|
|
30
|
+
const scored = await rerankWithScores(
|
|
31
|
+
query,
|
|
32
|
+
candidates.map((c) => c.raw_text),
|
|
33
|
+
topK
|
|
34
|
+
);
|
|
35
|
+
return scored.map((s) => candidates[s.index]);
|
|
36
|
+
}
|
|
37
|
+
async function rerankWithContext(query, candidates, topK) {
|
|
38
|
+
if (candidates.length === 0) return [];
|
|
39
|
+
const formattedTexts = candidates.map(
|
|
40
|
+
(c) => c.context ? `[${c.context}] ${c.text.slice(0, 460)}` : c.text.slice(0, 512)
|
|
41
|
+
);
|
|
42
|
+
const { rerankViaWorker } = await import("./lib/exe-daemon.js");
|
|
43
|
+
const scored = await rerankViaWorker(query, formattedTexts, topK);
|
|
44
|
+
return scored.map((s) => ({
|
|
45
|
+
text: candidates[s.index]?.text ?? "",
|
|
46
|
+
score: s.score,
|
|
47
|
+
index: s.index
|
|
48
|
+
}));
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export {
|
|
52
|
+
isRerankerAvailable,
|
|
53
|
+
getRerankerModelPath,
|
|
54
|
+
disposeReranker,
|
|
55
|
+
rerankWithScores,
|
|
56
|
+
rerank,
|
|
57
|
+
rerankWithContext
|
|
58
|
+
};
|
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
// src/lib/agentic-ontology.ts
|
|
2
|
+
import { createHash } from "crypto";
|
|
3
|
+
function stableId(...parts) {
|
|
4
|
+
return createHash("sha256").update(parts.map((p) => String(p ?? "")).join("::")).digest("hex").slice(0, 32);
|
|
5
|
+
}
|
|
6
|
+
function clean(text, max = 240) {
|
|
7
|
+
return text.replace(/\u0000/g, "").replace(/```[\s\S]*?```/g, " ").replace(/\s+/g, " ").trim().slice(0, max);
|
|
8
|
+
}
|
|
9
|
+
function inferOntologyEventType(row) {
|
|
10
|
+
const lower = row.raw_text.toLowerCase();
|
|
11
|
+
if (row.has_error) return "error";
|
|
12
|
+
if (/\b(done|complete|completed|fixed|resolved|shipped|deployed|pushed|published)\b/.test(lower)) return "milestone";
|
|
13
|
+
if (/\b(blocked|failed|error|bug|regression|broken)\b/.test(lower)) return "problem";
|
|
14
|
+
if (/\b(decided|decision|adr|we chose|approved|rejected)\b/.test(lower)) return "decision";
|
|
15
|
+
if (/\b(goal|need to|we need|want to|trying to|objective)\b/.test(lower)) return "goal_signal";
|
|
16
|
+
if (["Bash", "Read", "Edit", "Write", "Grep", "Glob"].includes(row.tool_name)) return "tool_action";
|
|
17
|
+
if (row.tool_name.startsWith("memory_card")) return "memory_card";
|
|
18
|
+
return "memory_observation";
|
|
19
|
+
}
|
|
20
|
+
function inferIntention(row) {
|
|
21
|
+
if (row.intent) return clean(row.intent, 220);
|
|
22
|
+
const text = clean(row.raw_text, 1e3);
|
|
23
|
+
const patterns = [
|
|
24
|
+
/(?:we need to|need to|let'?s|i want to|we should|goal is to|objective is to|trying to)\s+([^.!?\n]{8,220})/i,
|
|
25
|
+
/(?:so that|in order to)\s+([^.!?\n]{8,220})/i,
|
|
26
|
+
/(?:task|plan):\s*([^.!?\n]{8,220})/i
|
|
27
|
+
];
|
|
28
|
+
for (const p of patterns) {
|
|
29
|
+
const m = text.match(p);
|
|
30
|
+
if (m?.[1]) return clean(m[1], 220);
|
|
31
|
+
}
|
|
32
|
+
if (["Bash", "Read", "Edit", "Write", "Grep", "Glob"].includes(row.tool_name)) {
|
|
33
|
+
return `${row.tool_name} during ${row.project_name}`;
|
|
34
|
+
}
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
function inferOutcome(row) {
|
|
38
|
+
if (row.outcome) return clean(row.outcome, 220);
|
|
39
|
+
if (row.has_error) return "error";
|
|
40
|
+
const lower = row.raw_text.toLowerCase();
|
|
41
|
+
if (/\b(done|complete|completed|fixed|resolved|shipped|deployed|pushed|published|passed)\b/.test(lower)) return "success_signal";
|
|
42
|
+
if (/\b(blocked|failed|error|regression|broken|not working|could not)\b/.test(lower)) return "failure_signal";
|
|
43
|
+
if (/\b(warning|risk|concern|caveat)\b/.test(lower)) return "risk_signal";
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
function extractGoalCandidates(row) {
|
|
47
|
+
const text = clean(row.raw_text, 1600);
|
|
48
|
+
const patterns = [
|
|
49
|
+
/(?:we need to|need to|i want to|we should|goal is to|objective is to|trying to|let'?s)\s+([^.!?\n]{12,220})/gi,
|
|
50
|
+
/(?:success means|success criteria|so that)\s+([^.!?\n]{12,220})/gi
|
|
51
|
+
];
|
|
52
|
+
const out = [];
|
|
53
|
+
for (const pattern of patterns) {
|
|
54
|
+
for (const m of text.matchAll(pattern)) {
|
|
55
|
+
const candidate = clean(m[1] ?? "", 220);
|
|
56
|
+
if (candidate.length >= 12 && !out.some((x) => x.toLowerCase() === candidate.toLowerCase())) out.push(candidate);
|
|
57
|
+
if (out.length >= 3) return out;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return out;
|
|
61
|
+
}
|
|
62
|
+
function uniq(values, max = 6) {
|
|
63
|
+
const out = [];
|
|
64
|
+
for (const value of values.map((v) => clean(v, 220)).filter(Boolean)) {
|
|
65
|
+
if (!out.some((x) => x.toLowerCase() === value.toLowerCase())) out.push(value);
|
|
66
|
+
if (out.length >= max) break;
|
|
67
|
+
}
|
|
68
|
+
return out;
|
|
69
|
+
}
|
|
70
|
+
function extractMatches(text, patterns, max = 5) {
|
|
71
|
+
const out = [];
|
|
72
|
+
for (const pattern of patterns) {
|
|
73
|
+
for (const match of text.matchAll(pattern)) {
|
|
74
|
+
const value = match[1] ?? match[0];
|
|
75
|
+
if (value) out.push(value);
|
|
76
|
+
if (out.length >= max) return uniq(out, max);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
return uniq(out, max);
|
|
80
|
+
}
|
|
81
|
+
function inferSemanticLabel(row) {
|
|
82
|
+
const text = clean(row.raw_text, 2400);
|
|
83
|
+
const eventType = inferOntologyEventType(row);
|
|
84
|
+
const intention = inferIntention(row);
|
|
85
|
+
const outcome = inferOutcome(row);
|
|
86
|
+
const goals = extractGoalCandidates(row);
|
|
87
|
+
const milestones = extractMatches(text, [
|
|
88
|
+
/\b(?:completed|finished|fixed|resolved|shipped|deployed|published|pushed|passed)\b([^.!?\n]{0,180})/gi,
|
|
89
|
+
/(?:milestone|done):\s*([^.!?\n]{8,220})/gi
|
|
90
|
+
]);
|
|
91
|
+
const problems = extractMatches(text, [
|
|
92
|
+
/\b(?:blocked by|failed because|bug|regression|broken|not working|error)\b([^.!?\n]{0,180})/gi,
|
|
93
|
+
/(?:problem|issue|risk):\s*([^.!?\n]{8,220})/gi
|
|
94
|
+
]);
|
|
95
|
+
const decisions = extractMatches(text, [
|
|
96
|
+
/(?:decided|decision|adr|we chose|approved|rejected)\s+([^.!?\n]{8,220})/gi
|
|
97
|
+
]);
|
|
98
|
+
const temporalAnchors = extractMatches(text, [
|
|
99
|
+
/\b(\d{4}-\d{2}-\d{2}(?:[T ][0-9:.+-Z]+)?)\b/g,
|
|
100
|
+
/\b(today|yesterday|tomorrow|this week|next week|last week|morning|afternoon|tonight)\b/gi
|
|
101
|
+
], 8);
|
|
102
|
+
const nextActions = extractMatches(text, [
|
|
103
|
+
/(?:next|todo|follow[- ]?up|remaining|need to)\s*:?\s*([^.!?\n]{8,220})/gi
|
|
104
|
+
]);
|
|
105
|
+
const actors = uniq([
|
|
106
|
+
row.agent_id,
|
|
107
|
+
...extractMatches(text, [/\b(?:agent|employee|owner|assignee)[:= ]+([a-zA-Z][a-zA-Z0-9_-]{1,40})/gi], 5)
|
|
108
|
+
], 6);
|
|
109
|
+
const successSignals = milestones.length ? milestones : outcome === "success_signal" ? [clean(text, 180)] : [];
|
|
110
|
+
const failureSignals = problems.length ? problems : outcome === "failure_signal" || row.has_error ? [clean(text, 180)] : [];
|
|
111
|
+
const impact = successSignals.length && failureSignals.length ? "mixed" : failureSignals.length ? "negative" : successSignals.length ? "positive" : "neutral";
|
|
112
|
+
const signalCount = goals.length + milestones.length + problems.length + decisions.length + nextActions.length;
|
|
113
|
+
return {
|
|
114
|
+
labeler: "deterministic",
|
|
115
|
+
schemaVersion: 1,
|
|
116
|
+
eventType,
|
|
117
|
+
intention,
|
|
118
|
+
outcome,
|
|
119
|
+
impact,
|
|
120
|
+
confidence: Math.min(0.95, 0.45 + signalCount * 0.08 + (intention ? 0.1 : 0) + (outcome ? 0.1 : 0)),
|
|
121
|
+
goals,
|
|
122
|
+
milestones,
|
|
123
|
+
problems,
|
|
124
|
+
decisions,
|
|
125
|
+
actors,
|
|
126
|
+
temporalAnchors,
|
|
127
|
+
successSignals,
|
|
128
|
+
failureSignals,
|
|
129
|
+
nextActions,
|
|
130
|
+
summary: clean(text, 280)
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
function ontologyPayload(row) {
|
|
134
|
+
const semantic = inferSemanticLabel(row);
|
|
135
|
+
return {
|
|
136
|
+
tool_name: row.tool_name,
|
|
137
|
+
memory_version: row.version ?? null,
|
|
138
|
+
domain: row.domain ?? null,
|
|
139
|
+
trajectory: row.trajectory ? safeJson(row.trajectory) : null,
|
|
140
|
+
semantic
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
function safeJson(value) {
|
|
144
|
+
try {
|
|
145
|
+
return JSON.parse(value);
|
|
146
|
+
} catch {
|
|
147
|
+
return value.slice(0, 1e3);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
async function resolveClient(client) {
|
|
151
|
+
if (client) return client;
|
|
152
|
+
const { getClient } = await import("./lib/database.js");
|
|
153
|
+
return getClient();
|
|
154
|
+
}
|
|
155
|
+
async function insertOntologyForMemory(row, client) {
|
|
156
|
+
const db = await resolveClient(client);
|
|
157
|
+
const occurredAt = row.timestamp;
|
|
158
|
+
const sequence = Number(row.version ?? 0) || Math.floor(new Date(occurredAt).getTime() / 1e3);
|
|
159
|
+
const eventType = inferOntologyEventType(row);
|
|
160
|
+
const intention = inferIntention(row);
|
|
161
|
+
const outcome = inferOutcome(row);
|
|
162
|
+
const eventId = stableId("event", row.id);
|
|
163
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
164
|
+
await db.execute({
|
|
165
|
+
sql: `INSERT INTO agent_sessions (id, agent_id, project_name, started_at, last_event_at, event_count, properties)
|
|
166
|
+
VALUES (?, ?, ?, ?, ?, 1, ?)
|
|
167
|
+
ON CONFLICT(id) DO UPDATE SET last_event_at = MAX(last_event_at, excluded.last_event_at),
|
|
168
|
+
event_count = event_count + 1`,
|
|
169
|
+
args: [row.session_id, row.agent_id, row.project_name, occurredAt, occurredAt, JSON.stringify({ agent_role: row.agent_role })]
|
|
170
|
+
});
|
|
171
|
+
await db.execute({
|
|
172
|
+
sql: `INSERT OR IGNORE INTO agent_events
|
|
173
|
+
(id, event_type, occurred_at, sequence_index, actor_agent_id, agent_role, project_name,
|
|
174
|
+
session_id, task_id, goal_id, parent_event_id, intention, outcome, evidence_memory_id,
|
|
175
|
+
impact, payload, created_at)
|
|
176
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, NULL, NULL, ?, ?, ?, ?, ?, ?)`,
|
|
177
|
+
args: [
|
|
178
|
+
eventId,
|
|
179
|
+
eventType,
|
|
180
|
+
occurredAt,
|
|
181
|
+
sequence,
|
|
182
|
+
row.agent_id,
|
|
183
|
+
row.agent_role,
|
|
184
|
+
row.project_name,
|
|
185
|
+
row.session_id,
|
|
186
|
+
row.task_id ?? null,
|
|
187
|
+
intention,
|
|
188
|
+
outcome,
|
|
189
|
+
row.id,
|
|
190
|
+
row.has_error ? "negative" : outcome === "success_signal" ? "positive" : "neutral",
|
|
191
|
+
JSON.stringify(ontologyPayload(row)),
|
|
192
|
+
now
|
|
193
|
+
]
|
|
194
|
+
});
|
|
195
|
+
const semantic = inferSemanticLabel(row);
|
|
196
|
+
await db.execute({
|
|
197
|
+
sql: `INSERT INTO agent_semantic_labels
|
|
198
|
+
(id, source_memory_id, event_id, labeler, schema_version, confidence, labels, created_at, updated_at)
|
|
199
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
200
|
+
ON CONFLICT(id) DO UPDATE SET confidence = excluded.confidence,
|
|
201
|
+
labels = excluded.labels, updated_at = excluded.updated_at`,
|
|
202
|
+
args: [
|
|
203
|
+
stableId("semantic", row.id, semantic.labeler, semantic.schemaVersion),
|
|
204
|
+
row.id,
|
|
205
|
+
eventId,
|
|
206
|
+
semantic.labeler,
|
|
207
|
+
semantic.schemaVersion,
|
|
208
|
+
semantic.confidence,
|
|
209
|
+
JSON.stringify(semantic),
|
|
210
|
+
now,
|
|
211
|
+
now
|
|
212
|
+
]
|
|
213
|
+
});
|
|
214
|
+
for (const statement of extractGoalCandidates(row)) {
|
|
215
|
+
const goalId = stableId("goal", row.project_name, statement.toLowerCase());
|
|
216
|
+
await db.execute({
|
|
217
|
+
sql: `INSERT INTO agent_goals
|
|
218
|
+
(id, statement, owner_agent_id, project_name, status, priority, success_criteria,
|
|
219
|
+
parent_goal_id, due_at, achieved_at, supersedes_id, created_at, updated_at, source_memory_id)
|
|
220
|
+
VALUES (?, ?, ?, ?, 'open', 5, NULL, NULL, NULL, NULL, NULL, ?, ?, ?)
|
|
221
|
+
ON CONFLICT(id) DO UPDATE SET updated_at = excluded.updated_at`,
|
|
222
|
+
args: [goalId, statement, row.agent_id, row.project_name, now, now, row.id]
|
|
223
|
+
});
|
|
224
|
+
await db.execute({
|
|
225
|
+
sql: `INSERT OR IGNORE INTO agent_goal_links
|
|
226
|
+
(id, goal_id, link_type, target_id, target_type, created_at)
|
|
227
|
+
VALUES (?, ?, 'evidence', ?, 'memory', ?)`,
|
|
228
|
+
args: [stableId("goal_link", goalId, row.id, "memory"), goalId, row.id, now]
|
|
229
|
+
});
|
|
230
|
+
await db.execute({
|
|
231
|
+
sql: `INSERT OR IGNORE INTO agent_goal_links
|
|
232
|
+
(id, goal_id, link_type, target_id, target_type, created_at)
|
|
233
|
+
VALUES (?, ?, 'event', ?, 'event', ?)`,
|
|
234
|
+
args: [stableId("goal_link", goalId, eventId, "event"), goalId, eventId, now]
|
|
235
|
+
});
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
async function insertOntologyForBatch(rows, client) {
|
|
239
|
+
const db = await resolveClient(client);
|
|
240
|
+
let count = 0;
|
|
241
|
+
for (const row of rows) {
|
|
242
|
+
try {
|
|
243
|
+
await insertOntologyForMemory(row, db);
|
|
244
|
+
count++;
|
|
245
|
+
} catch {
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
return count;
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
export {
|
|
252
|
+
stableId,
|
|
253
|
+
clean,
|
|
254
|
+
inferOntologyEventType,
|
|
255
|
+
inferIntention,
|
|
256
|
+
inferOutcome,
|
|
257
|
+
extractGoalCandidates,
|
|
258
|
+
inferSemanticLabel,
|
|
259
|
+
ontologyPayload,
|
|
260
|
+
insertOntologyForMemory,
|
|
261
|
+
insertOntologyForBatch
|
|
262
|
+
};
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getClient
|
|
3
|
+
} from "./chunk-WUKEXVOR.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/session-kill-telemetry.ts
|
|
6
|
+
import crypto from "crypto";
|
|
7
|
+
import { appendFileSync } from "fs";
|
|
8
|
+
import path from "path";
|
|
9
|
+
import os from "os";
|
|
10
|
+
var KILL_FILE_LOG = path.join(os.homedir(), ".exe-os", "logs", "session-kills.jsonl");
|
|
11
|
+
var TOKENS_PER_IDLE_MINUTE = 50;
|
|
12
|
+
async function recordSessionKill(input) {
|
|
13
|
+
const killedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
14
|
+
const id = crypto.randomUUID();
|
|
15
|
+
try {
|
|
16
|
+
const logEntry = JSON.stringify({
|
|
17
|
+
id,
|
|
18
|
+
timestamp: killedAt,
|
|
19
|
+
session: input.sessionName,
|
|
20
|
+
agent: input.agentId,
|
|
21
|
+
reason: input.reason,
|
|
22
|
+
ticksIdle: input.ticksIdle ?? null,
|
|
23
|
+
tokensSaved: input.estimatedTokensSaved ?? null
|
|
24
|
+
});
|
|
25
|
+
appendFileSync(KILL_FILE_LOG, logEntry + "\n");
|
|
26
|
+
} catch {
|
|
27
|
+
process.stderr.write(
|
|
28
|
+
`[session-kill-telemetry] file log write failed for ${input.sessionName}
|
|
29
|
+
`
|
|
30
|
+
);
|
|
31
|
+
}
|
|
32
|
+
try {
|
|
33
|
+
const client = getClient();
|
|
34
|
+
await client.execute({
|
|
35
|
+
sql: `INSERT INTO session_kills
|
|
36
|
+
(id, session_name, agent_id, killed_at, reason,
|
|
37
|
+
ticks_idle, estimated_tokens_saved)
|
|
38
|
+
VALUES (?, ?, ?, ?, ?, ?, ?)`,
|
|
39
|
+
args: [
|
|
40
|
+
id,
|
|
41
|
+
input.sessionName,
|
|
42
|
+
input.agentId,
|
|
43
|
+
killedAt,
|
|
44
|
+
input.reason,
|
|
45
|
+
input.ticksIdle ?? null,
|
|
46
|
+
input.estimatedTokensSaved ?? null
|
|
47
|
+
]
|
|
48
|
+
});
|
|
49
|
+
} catch (err) {
|
|
50
|
+
process.stderr.write(
|
|
51
|
+
`[session-kill-telemetry] DB write failed: ${err instanceof Error ? err.message : String(err)}
|
|
52
|
+
`
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
async function countKillsSince(sinceISO) {
|
|
57
|
+
try {
|
|
58
|
+
const client = getClient();
|
|
59
|
+
const result = await client.execute({
|
|
60
|
+
sql: `SELECT COUNT(*) AS n FROM session_kills WHERE killed_at >= ?`,
|
|
61
|
+
args: [sinceISO]
|
|
62
|
+
});
|
|
63
|
+
const row = result.rows[0];
|
|
64
|
+
return row ? Number(row.n) : 0;
|
|
65
|
+
} catch {
|
|
66
|
+
return 0;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
var IDLE_KILL_STREAK_META_KEY = "idle_kill_suspect_streak";
|
|
70
|
+
var IDLE_KILL_SUSPECT_DAY_THRESHOLD = 3;
|
|
71
|
+
var IDLE_KILL_MIN_LIVE_SESSIONS = 5;
|
|
72
|
+
function parseStreakState(raw) {
|
|
73
|
+
if (!raw) return { lastDate: null, streak: 0 };
|
|
74
|
+
try {
|
|
75
|
+
const parsed = JSON.parse(raw);
|
|
76
|
+
return {
|
|
77
|
+
lastDate: typeof parsed.lastDate === "string" ? parsed.lastDate : null,
|
|
78
|
+
streak: typeof parsed.streak === "number" ? parsed.streak : 0
|
|
79
|
+
};
|
|
80
|
+
} catch {
|
|
81
|
+
return { lastDate: null, streak: 0 };
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
function nextStreakState(prev, qualifiesToday, todayDate) {
|
|
85
|
+
if (!qualifiesToday) return { lastDate: todayDate, streak: 0 };
|
|
86
|
+
if (prev.lastDate === todayDate) return prev;
|
|
87
|
+
return { lastDate: todayDate, streak: prev.streak + 1 };
|
|
88
|
+
}
|
|
89
|
+
function computeIdleKillSuspectStreak(prev, killsToday, liveSessions, todayDate) {
|
|
90
|
+
const qualifies = killsToday === 0 && liveSessions >= IDLE_KILL_MIN_LIVE_SESSIONS;
|
|
91
|
+
const state = nextStreakState(prev, qualifies, todayDate);
|
|
92
|
+
return {
|
|
93
|
+
state,
|
|
94
|
+
suspect: state.streak >= IDLE_KILL_SUSPECT_DAY_THRESHOLD
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
async function sumTokensSavedSince(sinceISO) {
|
|
98
|
+
try {
|
|
99
|
+
const client = getClient();
|
|
100
|
+
const result = await client.execute({
|
|
101
|
+
sql: `SELECT COALESCE(SUM(estimated_tokens_saved), 0) AS total
|
|
102
|
+
FROM session_kills
|
|
103
|
+
WHERE killed_at >= ?`,
|
|
104
|
+
args: [sinceISO]
|
|
105
|
+
});
|
|
106
|
+
const row = result.rows[0];
|
|
107
|
+
return row ? Number(row.total) : 0;
|
|
108
|
+
} catch {
|
|
109
|
+
return 0;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
export {
|
|
114
|
+
TOKENS_PER_IDLE_MINUTE,
|
|
115
|
+
recordSessionKill,
|
|
116
|
+
countKillsSince,
|
|
117
|
+
IDLE_KILL_STREAK_META_KEY,
|
|
118
|
+
IDLE_KILL_SUSPECT_DAY_THRESHOLD,
|
|
119
|
+
IDLE_KILL_MIN_LIVE_SESSIONS,
|
|
120
|
+
parseStreakState,
|
|
121
|
+
computeIdleKillSuspectStreak,
|
|
122
|
+
sumTokensSavedSince
|
|
123
|
+
};
|