@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,333 @@
|
|
|
1
|
+
import {
|
|
2
|
+
executeAction,
|
|
3
|
+
substituteTemplate
|
|
4
|
+
} from "./chunk-X4VOU6BQ.js";
|
|
5
|
+
|
|
6
|
+
// src/automation/workflow-engine.ts
|
|
7
|
+
import { randomUUID } from "crypto";
|
|
8
|
+
var _definitions = /* @__PURE__ */ new Map();
|
|
9
|
+
var _instances = /* @__PURE__ */ new Map();
|
|
10
|
+
function createWorkflowDefinition(input) {
|
|
11
|
+
const def = {
|
|
12
|
+
id: randomUUID().slice(0, 12),
|
|
13
|
+
...input,
|
|
14
|
+
created_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
15
|
+
};
|
|
16
|
+
def.steps = def.steps.map((s, i) => ({ ...s, index: s.index || i + 1 }));
|
|
17
|
+
_definitions.set(def.id, def);
|
|
18
|
+
return def;
|
|
19
|
+
}
|
|
20
|
+
function getWorkflowDefinition(id) {
|
|
21
|
+
return _definitions.get(id);
|
|
22
|
+
}
|
|
23
|
+
function listWorkflowDefinitions() {
|
|
24
|
+
return [..._definitions.values()];
|
|
25
|
+
}
|
|
26
|
+
function buildTemplateContext(instance) {
|
|
27
|
+
const ctx = { ...instance.context };
|
|
28
|
+
const stepMap = {};
|
|
29
|
+
for (const sr of instance.step_results) {
|
|
30
|
+
stepMap[String(sr.step_index)] = {
|
|
31
|
+
status: sr.status,
|
|
32
|
+
result: sr.result,
|
|
33
|
+
error: sr.error
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
ctx.step = stepMap;
|
|
37
|
+
return ctx;
|
|
38
|
+
}
|
|
39
|
+
function resolveActionParams(action, context) {
|
|
40
|
+
const resolved = {};
|
|
41
|
+
for (const [key, val] of Object.entries(action.params)) {
|
|
42
|
+
resolved[key] = substituteTemplate(val, context);
|
|
43
|
+
}
|
|
44
|
+
return { ...action, params: resolved };
|
|
45
|
+
}
|
|
46
|
+
function startWorkflow(definitionId, context = {}) {
|
|
47
|
+
const def = _definitions.get(definitionId);
|
|
48
|
+
if (!def) throw new Error(`Workflow definition "${definitionId}" not found`);
|
|
49
|
+
const instance = {
|
|
50
|
+
id: randomUUID().slice(0, 12),
|
|
51
|
+
definition_id: definitionId,
|
|
52
|
+
status: "running",
|
|
53
|
+
current_step: 1,
|
|
54
|
+
step_results: [],
|
|
55
|
+
context,
|
|
56
|
+
created_at: (/* @__PURE__ */ new Date()).toISOString(),
|
|
57
|
+
updated_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
58
|
+
};
|
|
59
|
+
_instances.set(instance.id, instance);
|
|
60
|
+
return instance;
|
|
61
|
+
}
|
|
62
|
+
function getWorkflowInstance(id) {
|
|
63
|
+
return _instances.get(id);
|
|
64
|
+
}
|
|
65
|
+
function listWorkflowInstances(status) {
|
|
66
|
+
const all = [..._instances.values()];
|
|
67
|
+
return status ? all.filter((i) => i.status === status) : all;
|
|
68
|
+
}
|
|
69
|
+
async function advanceWorkflow(instanceId) {
|
|
70
|
+
const instance = _instances.get(instanceId);
|
|
71
|
+
if (!instance) throw new Error(`Workflow instance "${instanceId}" not found`);
|
|
72
|
+
if (instance.status !== "running") {
|
|
73
|
+
throw new Error(`Workflow "${instanceId}" is ${instance.status}, cannot advance`);
|
|
74
|
+
}
|
|
75
|
+
const def = _definitions.get(instance.definition_id);
|
|
76
|
+
if (!def) throw new Error(`Workflow definition "${instance.definition_id}" not found`);
|
|
77
|
+
const step = def.steps.find((s) => s.index === instance.current_step);
|
|
78
|
+
if (!step) {
|
|
79
|
+
instance.status = "completed";
|
|
80
|
+
instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
81
|
+
return instance;
|
|
82
|
+
}
|
|
83
|
+
const templateCtx = buildTemplateContext(instance);
|
|
84
|
+
const stepResult = {
|
|
85
|
+
step_index: step.index,
|
|
86
|
+
status: "success",
|
|
87
|
+
started_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
88
|
+
};
|
|
89
|
+
switch (step.type) {
|
|
90
|
+
case "execute_action": {
|
|
91
|
+
const action = step.action ?? buildActionFromConnector(step);
|
|
92
|
+
if (!action) {
|
|
93
|
+
stepResult.status = "failed";
|
|
94
|
+
stepResult.error = "No action defined for execute_action step";
|
|
95
|
+
break;
|
|
96
|
+
}
|
|
97
|
+
const resolvedAction = resolveActionParams(action, templateCtx);
|
|
98
|
+
const result = await executeAction(resolvedAction, templateCtx);
|
|
99
|
+
stepResult.status = result.success ? "success" : "failed";
|
|
100
|
+
stepResult.result = result;
|
|
101
|
+
stepResult.error = result.error;
|
|
102
|
+
if (!result.success) {
|
|
103
|
+
instance.status = "failed";
|
|
104
|
+
}
|
|
105
|
+
break;
|
|
106
|
+
}
|
|
107
|
+
case "wait_for_approval": {
|
|
108
|
+
const { createTask } = await import("./lib/tasks.js");
|
|
109
|
+
const { getCoordinatorName } = await import("./lib/employees.js");
|
|
110
|
+
const message = step.approval_message ? substituteTemplate(step.approval_message, templateCtx) : `Workflow "${def.name}" step ${step.index} ("${step.name}") requires approval.`;
|
|
111
|
+
const task = await createTask({
|
|
112
|
+
title: `[Workflow Approval] ${def.name}: ${step.name}`,
|
|
113
|
+
assignedTo: getCoordinatorName(),
|
|
114
|
+
assignedBy: "workflow-engine",
|
|
115
|
+
projectName: "exe-os",
|
|
116
|
+
priority: "p1",
|
|
117
|
+
context: `${message}
|
|
118
|
+
|
|
119
|
+
**Workflow:** ${def.name} (${instance.id})
|
|
120
|
+
**Step:** ${step.index} \u2014 ${step.name}
|
|
121
|
+
|
|
122
|
+
To approve: call approve_workflow_step with instance_id="${instance.id}"
|
|
123
|
+
To reject: call approve_workflow_step with instance_id="${instance.id}" approved=false`,
|
|
124
|
+
baseDir: process.cwd()
|
|
125
|
+
});
|
|
126
|
+
instance.approval_task_id = task.id;
|
|
127
|
+
instance.status = "waiting_approval";
|
|
128
|
+
stepResult.status = "pending_approval";
|
|
129
|
+
break;
|
|
130
|
+
}
|
|
131
|
+
case "conditional": {
|
|
132
|
+
if (!step.condition) {
|
|
133
|
+
stepResult.status = "failed";
|
|
134
|
+
stepResult.error = "No condition defined for conditional step";
|
|
135
|
+
break;
|
|
136
|
+
}
|
|
137
|
+
const resolvedExpr = substituteTemplate(step.condition.expression, templateCtx);
|
|
138
|
+
const conditionMet = evaluateSimpleExpression(resolvedExpr);
|
|
139
|
+
stepResult.result = { expression: resolvedExpr, met: conditionMet };
|
|
140
|
+
if (conditionMet && step.condition.then_step) {
|
|
141
|
+
instance.current_step = step.condition.then_step;
|
|
142
|
+
stepResult.completed_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
143
|
+
instance.step_results.push(stepResult);
|
|
144
|
+
instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
145
|
+
return instance;
|
|
146
|
+
} else if (!conditionMet && step.condition.else_step) {
|
|
147
|
+
instance.current_step = step.condition.else_step;
|
|
148
|
+
stepResult.completed_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
149
|
+
instance.step_results.push(stepResult);
|
|
150
|
+
instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
151
|
+
return instance;
|
|
152
|
+
}
|
|
153
|
+
break;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
stepResult.completed_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
157
|
+
instance.step_results.push(stepResult);
|
|
158
|
+
if (instance.status === "running") {
|
|
159
|
+
const nextStep = def.steps.find((s) => s.index > step.index);
|
|
160
|
+
if (nextStep) {
|
|
161
|
+
instance.current_step = nextStep.index;
|
|
162
|
+
} else {
|
|
163
|
+
instance.status = "completed";
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
167
|
+
return instance;
|
|
168
|
+
}
|
|
169
|
+
async function runWorkflow(instanceId) {
|
|
170
|
+
let instance = _instances.get(instanceId);
|
|
171
|
+
if (!instance) throw new Error(`Workflow instance "${instanceId}" not found`);
|
|
172
|
+
while (instance.status === "running") {
|
|
173
|
+
instance = await advanceWorkflow(instanceId);
|
|
174
|
+
}
|
|
175
|
+
return instance;
|
|
176
|
+
}
|
|
177
|
+
async function approveWorkflowStep(instanceId, approved = true) {
|
|
178
|
+
const instance = _instances.get(instanceId);
|
|
179
|
+
if (!instance) throw new Error(`Workflow instance "${instanceId}" not found`);
|
|
180
|
+
if (instance.status !== "waiting_approval") {
|
|
181
|
+
throw new Error(`Workflow "${instanceId}" is not waiting for approval (status: ${instance.status})`);
|
|
182
|
+
}
|
|
183
|
+
const pendingResult = instance.step_results.find(
|
|
184
|
+
(sr) => sr.step_index === instance.current_step && sr.status === "pending_approval"
|
|
185
|
+
);
|
|
186
|
+
if (pendingResult) {
|
|
187
|
+
pendingResult.status = approved ? "approved" : "failed";
|
|
188
|
+
pendingResult.completed_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
189
|
+
pendingResult.result = { approved };
|
|
190
|
+
}
|
|
191
|
+
if (!approved) {
|
|
192
|
+
instance.status = "cancelled";
|
|
193
|
+
instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
194
|
+
return instance;
|
|
195
|
+
}
|
|
196
|
+
const def = _definitions.get(instance.definition_id);
|
|
197
|
+
if (!def) throw new Error(`Workflow definition "${instance.definition_id}" not found`);
|
|
198
|
+
const currentStep = def.steps.find((s) => s.index === instance.current_step);
|
|
199
|
+
const nextStep = currentStep ? def.steps.find((s) => s.index > currentStep.index) : void 0;
|
|
200
|
+
if (nextStep) {
|
|
201
|
+
instance.current_step = nextStep.index;
|
|
202
|
+
instance.status = "running";
|
|
203
|
+
} else {
|
|
204
|
+
instance.status = "completed";
|
|
205
|
+
}
|
|
206
|
+
instance.approval_task_id = void 0;
|
|
207
|
+
instance.updated_at = (/* @__PURE__ */ new Date()).toISOString();
|
|
208
|
+
if (instance.status === "running") {
|
|
209
|
+
return runWorkflow(instanceId);
|
|
210
|
+
}
|
|
211
|
+
return instance;
|
|
212
|
+
}
|
|
213
|
+
function buildActionFromConnector(step) {
|
|
214
|
+
if (!step.connector || !step.operation) return null;
|
|
215
|
+
const params = {};
|
|
216
|
+
if (step.payload) {
|
|
217
|
+
for (const [k, v] of Object.entries(step.payload)) {
|
|
218
|
+
params[k] = String(v);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
params._connector = step.connector;
|
|
222
|
+
params._operation = step.operation;
|
|
223
|
+
return {
|
|
224
|
+
type: "mcp_tool",
|
|
225
|
+
params
|
|
226
|
+
};
|
|
227
|
+
}
|
|
228
|
+
function evaluateSimpleExpression(expr) {
|
|
229
|
+
const operators = ["==", "!=", ">=", "<=", ">", "<"];
|
|
230
|
+
for (const op of operators) {
|
|
231
|
+
const idx = expr.indexOf(op);
|
|
232
|
+
if (idx === -1) continue;
|
|
233
|
+
const left = expr.slice(0, idx).trim();
|
|
234
|
+
const right = expr.slice(idx + op.length).trim();
|
|
235
|
+
switch (op) {
|
|
236
|
+
case "==":
|
|
237
|
+
return left === right;
|
|
238
|
+
case "!=":
|
|
239
|
+
return left !== right;
|
|
240
|
+
case ">":
|
|
241
|
+
return Number(left) > Number(right);
|
|
242
|
+
case "<":
|
|
243
|
+
return Number(left) < Number(right);
|
|
244
|
+
case ">=":
|
|
245
|
+
return Number(left) >= Number(right);
|
|
246
|
+
case "<=":
|
|
247
|
+
return Number(left) <= Number(right);
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
return expr.trim() !== "" && expr.trim() !== "false" && expr.trim() !== "0";
|
|
251
|
+
}
|
|
252
|
+
async function persistWorkflows() {
|
|
253
|
+
try {
|
|
254
|
+
const { getClient } = await import("./lib/database.js");
|
|
255
|
+
const client = getClient();
|
|
256
|
+
for (const def of _definitions.values()) {
|
|
257
|
+
await client.execute({
|
|
258
|
+
sql: `INSERT OR REPLACE INTO workflow_definitions (id, name, description, steps, trigger_event, created_at)
|
|
259
|
+
VALUES (?, ?, ?, ?, ?, ?)`,
|
|
260
|
+
args: [def.id, def.name, def.description ?? null, JSON.stringify(def.steps), def.trigger_event ?? null, def.created_at]
|
|
261
|
+
});
|
|
262
|
+
}
|
|
263
|
+
for (const inst of _instances.values()) {
|
|
264
|
+
await client.execute({
|
|
265
|
+
sql: `INSERT OR REPLACE INTO workflow_instances
|
|
266
|
+
(id, definition_id, status, current_step, step_results, context, approval_task_id, created_at, updated_at)
|
|
267
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,
|
|
268
|
+
args: [
|
|
269
|
+
inst.id,
|
|
270
|
+
inst.definition_id,
|
|
271
|
+
inst.status,
|
|
272
|
+
inst.current_step,
|
|
273
|
+
JSON.stringify(inst.step_results),
|
|
274
|
+
JSON.stringify(inst.context),
|
|
275
|
+
inst.approval_task_id ?? null,
|
|
276
|
+
inst.created_at,
|
|
277
|
+
inst.updated_at
|
|
278
|
+
]
|
|
279
|
+
});
|
|
280
|
+
}
|
|
281
|
+
} catch (e) {
|
|
282
|
+
process.stderr.write(`[workflow-engine] persist failed: ${e instanceof Error ? e.message : String(e)}
|
|
283
|
+
`);
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
async function loadWorkflows() {
|
|
287
|
+
try {
|
|
288
|
+
const { getClient } = await import("./lib/database.js");
|
|
289
|
+
const client = getClient();
|
|
290
|
+
const defs = await client.execute("SELECT * FROM workflow_definitions");
|
|
291
|
+
for (const row of defs.rows) {
|
|
292
|
+
const def = {
|
|
293
|
+
id: String(row.id),
|
|
294
|
+
name: String(row.name),
|
|
295
|
+
description: String(row.description),
|
|
296
|
+
steps: JSON.parse(String(row.steps)),
|
|
297
|
+
trigger_event: String(row.trigger_event),
|
|
298
|
+
created_at: String(row.created_at)
|
|
299
|
+
};
|
|
300
|
+
_definitions.set(def.id, def);
|
|
301
|
+
}
|
|
302
|
+
const insts = await client.execute("SELECT * FROM workflow_instances WHERE status NOT IN ('completed', 'cancelled')");
|
|
303
|
+
for (const row of insts.rows) {
|
|
304
|
+
const inst = {
|
|
305
|
+
id: String(row.id),
|
|
306
|
+
definition_id: String(row.definition_id),
|
|
307
|
+
status: String(row.status),
|
|
308
|
+
current_step: Number(row.current_step),
|
|
309
|
+
step_results: JSON.parse(String(row.step_results)),
|
|
310
|
+
context: JSON.parse(String(row.context)),
|
|
311
|
+
approval_task_id: row.approval_task_id ? String(row.approval_task_id) : void 0,
|
|
312
|
+
created_at: String(row.created_at),
|
|
313
|
+
updated_at: String(row.updated_at)
|
|
314
|
+
};
|
|
315
|
+
_instances.set(inst.id, inst);
|
|
316
|
+
}
|
|
317
|
+
} catch {
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
export {
|
|
322
|
+
createWorkflowDefinition,
|
|
323
|
+
getWorkflowDefinition,
|
|
324
|
+
listWorkflowDefinitions,
|
|
325
|
+
startWorkflow,
|
|
326
|
+
getWorkflowInstance,
|
|
327
|
+
listWorkflowInstances,
|
|
328
|
+
advanceWorkflow,
|
|
329
|
+
runWorkflow,
|
|
330
|
+
approveWorkflowStep,
|
|
331
|
+
persistWorkflows,
|
|
332
|
+
loadWorkflows
|
|
333
|
+
};
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getClient
|
|
3
|
+
} from "./chunk-WUKEXVOR.js";
|
|
4
|
+
import "./chunk-2I23RPSI.js";
|
|
5
|
+
import "./chunk-ORDHJRWN.js";
|
|
6
|
+
import "./chunk-5DNJPRDW.js";
|
|
7
|
+
import "./chunk-FXU7JOXK.js";
|
|
8
|
+
import "./chunk-T3B5RK4H.js";
|
|
9
|
+
import "./chunk-LYH5HE24.js";
|
|
10
|
+
import "./chunk-MLKGABMK.js";
|
|
11
|
+
|
|
12
|
+
// src/lib/co-activation.ts
|
|
13
|
+
async function recordCoActivations(entityIds) {
|
|
14
|
+
if (entityIds.length < 2) return;
|
|
15
|
+
const unique = [...new Set(entityIds)].slice(0, 20);
|
|
16
|
+
const client = getClient();
|
|
17
|
+
const pairs = [];
|
|
18
|
+
for (let i = 0; i < unique.length; i++) {
|
|
19
|
+
for (let j = i + 1; j < unique.length; j++) {
|
|
20
|
+
const idI = unique[i];
|
|
21
|
+
const idJ = unique[j];
|
|
22
|
+
const pair = idI < idJ ? [idI, idJ] : [idJ, idI];
|
|
23
|
+
pairs.push(pair);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
for (const [a, b] of pairs) {
|
|
27
|
+
await client.execute({
|
|
28
|
+
sql: `INSERT INTO co_activations (entity_a_id, entity_b_id, count, last_activated_at)
|
|
29
|
+
VALUES (?, ?, 1, datetime('now'))
|
|
30
|
+
ON CONFLICT (entity_a_id, entity_b_id)
|
|
31
|
+
DO UPDATE SET count = count + 1, last_activated_at = datetime('now')`,
|
|
32
|
+
args: [a, b]
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
async function getHotPairs(limit = 20) {
|
|
37
|
+
const client = getClient();
|
|
38
|
+
const result = await client.execute({
|
|
39
|
+
sql: `SELECT entity_a_id, entity_b_id, count, last_activated_at
|
|
40
|
+
FROM co_activations
|
|
41
|
+
ORDER BY count DESC
|
|
42
|
+
LIMIT ?`,
|
|
43
|
+
args: [limit]
|
|
44
|
+
});
|
|
45
|
+
return result.rows.map((r) => ({
|
|
46
|
+
entity_a_id: String(r.entity_a_id),
|
|
47
|
+
entity_b_id: String(r.entity_b_id),
|
|
48
|
+
count: Number(r.count),
|
|
49
|
+
last_activated_at: String(r.last_activated_at)
|
|
50
|
+
}));
|
|
51
|
+
}
|
|
52
|
+
async function getCoActivationNeighbors(entityId, limit = 20) {
|
|
53
|
+
const client = getClient();
|
|
54
|
+
const result = await client.execute({
|
|
55
|
+
sql: `SELECT entity_a_id, entity_b_id, count, last_activated_at
|
|
56
|
+
FROM co_activations
|
|
57
|
+
WHERE entity_a_id = ? OR entity_b_id = ?
|
|
58
|
+
ORDER BY count DESC
|
|
59
|
+
LIMIT ?`,
|
|
60
|
+
args: [entityId, entityId, limit]
|
|
61
|
+
});
|
|
62
|
+
return result.rows.map((r) => ({
|
|
63
|
+
entity_a_id: String(r.entity_a_id),
|
|
64
|
+
entity_b_id: String(r.entity_b_id),
|
|
65
|
+
count: Number(r.count),
|
|
66
|
+
last_activated_at: String(r.last_activated_at)
|
|
67
|
+
}));
|
|
68
|
+
}
|
|
69
|
+
export {
|
|
70
|
+
getCoActivationNeighbors,
|
|
71
|
+
getHotPairs,
|
|
72
|
+
recordCoActivations
|
|
73
|
+
};
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getClient
|
|
3
|
+
} from "./chunk-52UDAVZE.js";
|
|
4
|
+
import "./chunk-2I23RPSI.js";
|
|
5
|
+
import "./chunk-YGWFBN5A.js";
|
|
6
|
+
import "./chunk-5DNJPRDW.js";
|
|
7
|
+
import "./chunk-FXU7JOXK.js";
|
|
8
|
+
import "./chunk-T3B5RK4H.js";
|
|
9
|
+
import "./chunk-LYH5HE24.js";
|
|
10
|
+
import "./chunk-MLKGABMK.js";
|
|
11
|
+
|
|
12
|
+
// src/lib/co-activation.ts
|
|
13
|
+
async function recordCoActivations(entityIds) {
|
|
14
|
+
if (entityIds.length < 2) return;
|
|
15
|
+
const unique = [...new Set(entityIds)].slice(0, 20);
|
|
16
|
+
const client = getClient();
|
|
17
|
+
const pairs = [];
|
|
18
|
+
for (let i = 0; i < unique.length; i++) {
|
|
19
|
+
for (let j = i + 1; j < unique.length; j++) {
|
|
20
|
+
const idI = unique[i];
|
|
21
|
+
const idJ = unique[j];
|
|
22
|
+
const pair = idI < idJ ? [idI, idJ] : [idJ, idI];
|
|
23
|
+
pairs.push(pair);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
for (const [a, b] of pairs) {
|
|
27
|
+
await client.execute({
|
|
28
|
+
sql: `INSERT INTO co_activations (entity_a_id, entity_b_id, count, last_activated_at)
|
|
29
|
+
VALUES (?, ?, 1, datetime('now'))
|
|
30
|
+
ON CONFLICT (entity_a_id, entity_b_id)
|
|
31
|
+
DO UPDATE SET count = count + 1, last_activated_at = datetime('now')`,
|
|
32
|
+
args: [a, b]
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
async function getHotPairs(limit = 20) {
|
|
37
|
+
const client = getClient();
|
|
38
|
+
const result = await client.execute({
|
|
39
|
+
sql: `SELECT entity_a_id, entity_b_id, count, last_activated_at
|
|
40
|
+
FROM co_activations
|
|
41
|
+
ORDER BY count DESC
|
|
42
|
+
LIMIT ?`,
|
|
43
|
+
args: [limit]
|
|
44
|
+
});
|
|
45
|
+
return result.rows.map((r) => ({
|
|
46
|
+
entity_a_id: String(r.entity_a_id),
|
|
47
|
+
entity_b_id: String(r.entity_b_id),
|
|
48
|
+
count: Number(r.count),
|
|
49
|
+
last_activated_at: String(r.last_activated_at)
|
|
50
|
+
}));
|
|
51
|
+
}
|
|
52
|
+
async function getCoActivationNeighbors(entityId, limit = 20) {
|
|
53
|
+
const client = getClient();
|
|
54
|
+
const result = await client.execute({
|
|
55
|
+
sql: `SELECT entity_a_id, entity_b_id, count, last_activated_at
|
|
56
|
+
FROM co_activations
|
|
57
|
+
WHERE entity_a_id = ? OR entity_b_id = ?
|
|
58
|
+
ORDER BY count DESC
|
|
59
|
+
LIMIT ?`,
|
|
60
|
+
args: [entityId, entityId, limit]
|
|
61
|
+
});
|
|
62
|
+
return result.rows.map((r) => ({
|
|
63
|
+
entity_a_id: String(r.entity_a_id),
|
|
64
|
+
entity_b_id: String(r.entity_b_id),
|
|
65
|
+
count: Number(r.count),
|
|
66
|
+
last_activated_at: String(r.last_activated_at)
|
|
67
|
+
}));
|
|
68
|
+
}
|
|
69
|
+
export {
|
|
70
|
+
getCoActivationNeighbors,
|
|
71
|
+
getHotPairs,
|
|
72
|
+
recordCoActivations
|
|
73
|
+
};
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import {
|
|
2
|
+
entityId,
|
|
3
|
+
normalizeEntityName
|
|
4
|
+
} from "./chunk-I7GRBEFS.js";
|
|
5
|
+
import "./chunk-I7AW4237.js";
|
|
6
|
+
import "./chunk-GUMRIUI5.js";
|
|
7
|
+
import {
|
|
8
|
+
getClient
|
|
9
|
+
} from "./chunk-WUKEXVOR.js";
|
|
10
|
+
import "./chunk-2I23RPSI.js";
|
|
11
|
+
import "./chunk-ORDHJRWN.js";
|
|
12
|
+
import "./chunk-5DNJPRDW.js";
|
|
13
|
+
import "./chunk-FXU7JOXK.js";
|
|
14
|
+
import "./chunk-T3B5RK4H.js";
|
|
15
|
+
import "./chunk-LYH5HE24.js";
|
|
16
|
+
import "./chunk-MLKGABMK.js";
|
|
17
|
+
|
|
18
|
+
// src/lib/co-occurrence.ts
|
|
19
|
+
var SPECIFICITY = {
|
|
20
|
+
file: 5,
|
|
21
|
+
function: 4,
|
|
22
|
+
error: 3,
|
|
23
|
+
tool: 2,
|
|
24
|
+
agent: 1,
|
|
25
|
+
project: 0
|
|
26
|
+
};
|
|
27
|
+
function getSpecificity(type) {
|
|
28
|
+
return SPECIFICITY[type] ?? 1;
|
|
29
|
+
}
|
|
30
|
+
function coOccurrenceId(entityId1, entityId2) {
|
|
31
|
+
const sorted = [entityId1, entityId2].sort();
|
|
32
|
+
return `cooccur:${sorted[0]}:${sorted[1]}`;
|
|
33
|
+
}
|
|
34
|
+
async function actualEntityId(name, type, fallbackId) {
|
|
35
|
+
try {
|
|
36
|
+
const result = await getClient().execute({
|
|
37
|
+
sql: "SELECT id FROM entities WHERE LOWER(name) = LOWER(?) AND type = ? LIMIT 1",
|
|
38
|
+
args: [name, type]
|
|
39
|
+
});
|
|
40
|
+
return result.rows[0]?.id ? String(result.rows[0].id) : fallbackId;
|
|
41
|
+
} catch {
|
|
42
|
+
return fallbackId;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
async function createCoOccurrenceEdges(entities, _memoryId) {
|
|
46
|
+
if (entities.length < 2) return 0;
|
|
47
|
+
const client = getClient();
|
|
48
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
49
|
+
const seen = /* @__PURE__ */ new Set();
|
|
50
|
+
const deduped = entities.filter((e) => {
|
|
51
|
+
const key = `${e.type.toLowerCase()}:${normalizeEntityName(e.name)}`;
|
|
52
|
+
if (seen.has(key)) return false;
|
|
53
|
+
seen.add(key);
|
|
54
|
+
return true;
|
|
55
|
+
});
|
|
56
|
+
const sorted = deduped.sort((a, b) => getSpecificity(b.type) - getSpecificity(a.type));
|
|
57
|
+
const MAX_PAIRS = 10;
|
|
58
|
+
const pairs = [];
|
|
59
|
+
for (let i = 0; i < sorted.length && pairs.length < MAX_PAIRS; i++) {
|
|
60
|
+
for (let j = i + 1; j < sorted.length && pairs.length < MAX_PAIRS; j++) {
|
|
61
|
+
pairs.push([sorted[i], sorted[j]]);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
let created = 0;
|
|
65
|
+
for (const [a, b] of pairs) {
|
|
66
|
+
const aName = normalizeEntityName(a.name);
|
|
67
|
+
const bName = normalizeEntityName(b.name);
|
|
68
|
+
const aType = a.type.toLowerCase();
|
|
69
|
+
const bType = b.type.toLowerCase();
|
|
70
|
+
const aId = await actualEntityId(aName, aType, entityId(aName, aType));
|
|
71
|
+
const bId = await actualEntityId(bName, bType, entityId(bName, bType));
|
|
72
|
+
if (aId === bId) continue;
|
|
73
|
+
const relId = coOccurrenceId(aId, bId);
|
|
74
|
+
const sortedIds = [aId, bId].sort();
|
|
75
|
+
const sourceId = sortedIds[0];
|
|
76
|
+
const targetId = sortedIds[1];
|
|
77
|
+
try {
|
|
78
|
+
await client.execute({
|
|
79
|
+
sql: `INSERT INTO relationships (id, source_entity_id, target_entity_id, type, weight, timestamp, properties)
|
|
80
|
+
VALUES (?, ?, ?, 'co_occurs_with', 1.0, ?, '{}')
|
|
81
|
+
ON CONFLICT(source_entity_id, target_entity_id, type) DO UPDATE SET
|
|
82
|
+
weight = MIN(weight + 0.1, 10.0),
|
|
83
|
+
timestamp = ?`,
|
|
84
|
+
args: [relId, sourceId, targetId, now, now]
|
|
85
|
+
});
|
|
86
|
+
created++;
|
|
87
|
+
} catch {
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return created;
|
|
91
|
+
}
|
|
92
|
+
export {
|
|
93
|
+
createCoOccurrenceEdges
|
|
94
|
+
};
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import {
|
|
2
|
+
entityId,
|
|
3
|
+
normalizeEntityName
|
|
4
|
+
} from "./chunk-I7GRBEFS.js";
|
|
5
|
+
import "./chunk-I7AW4237.js";
|
|
6
|
+
import "./chunk-GUMRIUI5.js";
|
|
7
|
+
import {
|
|
8
|
+
getClient
|
|
9
|
+
} from "./chunk-52UDAVZE.js";
|
|
10
|
+
import "./chunk-2I23RPSI.js";
|
|
11
|
+
import "./chunk-YGWFBN5A.js";
|
|
12
|
+
import "./chunk-5DNJPRDW.js";
|
|
13
|
+
import "./chunk-FXU7JOXK.js";
|
|
14
|
+
import "./chunk-T3B5RK4H.js";
|
|
15
|
+
import "./chunk-LYH5HE24.js";
|
|
16
|
+
import "./chunk-MLKGABMK.js";
|
|
17
|
+
|
|
18
|
+
// src/lib/co-occurrence.ts
|
|
19
|
+
var SPECIFICITY = {
|
|
20
|
+
file: 5,
|
|
21
|
+
function: 4,
|
|
22
|
+
error: 3,
|
|
23
|
+
tool: 2,
|
|
24
|
+
agent: 1,
|
|
25
|
+
project: 0
|
|
26
|
+
};
|
|
27
|
+
function getSpecificity(type) {
|
|
28
|
+
return SPECIFICITY[type] ?? 1;
|
|
29
|
+
}
|
|
30
|
+
function coOccurrenceId(entityId1, entityId2) {
|
|
31
|
+
const sorted = [entityId1, entityId2].sort();
|
|
32
|
+
return `cooccur:${sorted[0]}:${sorted[1]}`;
|
|
33
|
+
}
|
|
34
|
+
async function actualEntityId(name, type, fallbackId) {
|
|
35
|
+
try {
|
|
36
|
+
const result = await getClient().execute({
|
|
37
|
+
sql: "SELECT id FROM entities WHERE LOWER(name) = LOWER(?) AND type = ? LIMIT 1",
|
|
38
|
+
args: [name, type]
|
|
39
|
+
});
|
|
40
|
+
return result.rows[0]?.id ? String(result.rows[0].id) : fallbackId;
|
|
41
|
+
} catch {
|
|
42
|
+
return fallbackId;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
async function createCoOccurrenceEdges(entities, _memoryId) {
|
|
46
|
+
if (entities.length < 2) return 0;
|
|
47
|
+
const client = getClient();
|
|
48
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
49
|
+
const seen = /* @__PURE__ */ new Set();
|
|
50
|
+
const deduped = entities.filter((e) => {
|
|
51
|
+
const key = `${e.type.toLowerCase()}:${normalizeEntityName(e.name)}`;
|
|
52
|
+
if (seen.has(key)) return false;
|
|
53
|
+
seen.add(key);
|
|
54
|
+
return true;
|
|
55
|
+
});
|
|
56
|
+
const sorted = deduped.sort((a, b) => getSpecificity(b.type) - getSpecificity(a.type));
|
|
57
|
+
const MAX_PAIRS = 10;
|
|
58
|
+
const pairs = [];
|
|
59
|
+
for (let i = 0; i < sorted.length && pairs.length < MAX_PAIRS; i++) {
|
|
60
|
+
for (let j = i + 1; j < sorted.length && pairs.length < MAX_PAIRS; j++) {
|
|
61
|
+
pairs.push([sorted[i], sorted[j]]);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
let created = 0;
|
|
65
|
+
for (const [a, b] of pairs) {
|
|
66
|
+
const aName = normalizeEntityName(a.name);
|
|
67
|
+
const bName = normalizeEntityName(b.name);
|
|
68
|
+
const aType = a.type.toLowerCase();
|
|
69
|
+
const bType = b.type.toLowerCase();
|
|
70
|
+
const aId = await actualEntityId(aName, aType, entityId(aName, aType));
|
|
71
|
+
const bId = await actualEntityId(bName, bType, entityId(bName, bType));
|
|
72
|
+
if (aId === bId) continue;
|
|
73
|
+
const relId = coOccurrenceId(aId, bId);
|
|
74
|
+
const sortedIds = [aId, bId].sort();
|
|
75
|
+
const sourceId = sortedIds[0];
|
|
76
|
+
const targetId = sortedIds[1];
|
|
77
|
+
try {
|
|
78
|
+
await client.execute({
|
|
79
|
+
sql: `INSERT INTO relationships (id, source_entity_id, target_entity_id, type, weight, timestamp, properties)
|
|
80
|
+
VALUES (?, ?, ?, 'co_occurs_with', 1.0, ?, '{}')
|
|
81
|
+
ON CONFLICT(source_entity_id, target_entity_id, type) DO UPDATE SET
|
|
82
|
+
weight = MIN(weight + 0.1, 10.0),
|
|
83
|
+
timestamp = ?`,
|
|
84
|
+
args: [relId, sourceId, targetId, now, now]
|
|
85
|
+
});
|
|
86
|
+
created++;
|
|
87
|
+
} catch {
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return created;
|
|
91
|
+
}
|
|
92
|
+
export {
|
|
93
|
+
createCoOccurrenceEdges
|
|
94
|
+
};
|