@askexenow/exe-os 0.9.292 → 0.9.293
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/generate-env.ts +27 -1
- package/dist/active-agent-OEJKODGY.js +27 -0
- package/dist/active-agent-PFZAEMJA.js +28 -0
- package/dist/active-agent-USK4RVP5.js +28 -0
- package/dist/active-agent-XEZTZEV7.js +27 -0
- package/dist/agentic-ontology-46PBPTLE.js +25 -0
- package/dist/agentic-ontology-WTXI6RLB.js +25 -0
- package/dist/assets/com.askexe.exed.plist +70 -0
- package/dist/backfill-metadata-IYP2QGGD.js +600 -0
- package/dist/backfill-metadata-S523IKKJ.js +600 -0
- package/dist/behaviors-GPCWN3RL.js +46 -0
- package/dist/behaviors-UYEYYVIH.js +46 -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 +6 -6
- package/dist/bin/backfill-responses.js +6 -6
- package/dist/bin/backfill-vectors.js +8 -8
- package/dist/bin/bulk-sync-postgres.js +7 -6
- package/dist/bin/cc-doctor.js +4 -4
- package/dist/bin/cleanup-stale-review-tasks.js +11 -11
- package/dist/bin/cli.js +16 -16
- package/dist/bin/deferred-daemon-restart.js +1 -1
- package/dist/bin/exe-agent-config.js +2 -2
- package/dist/bin/exe-agent.js +4 -4
- package/dist/bin/exe-assign.js +8 -8
- package/dist/bin/exe-boot.js +38 -18
- package/dist/bin/exe-call.js +4 -4
- package/dist/bin/exe-cloud.js +11 -4
- package/dist/bin/exe-dispatch.js +11 -11
- package/dist/bin/exe-doctor.js +2 -2
- 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 +11 -11
- package/dist/bin/exe-kill.js +14 -14
- package/dist/bin/exe-launch-agent.js +36 -18
- package/dist/bin/exe-new-employee.js +6 -6
- package/dist/bin/exe-pending-messages.js +12 -12
- package/dist/bin/exe-pending-notifications.js +11 -11
- package/dist/bin/exe-pending-reviews.js +11 -11
- package/dist/bin/exe-rename.js +4 -4
- package/dist/bin/exe-review.js +13 -13
- package/dist/bin/exe-search.js +5 -5
- package/dist/bin/exe-session-cleanup.js +16 -16
- package/dist/bin/exe-settings.js +12 -4
- package/dist/bin/exe-start-codex.js +11 -11
- package/dist/bin/exe-start-opencode.js +8 -8
- package/dist/bin/exe-status.js +12 -12
- package/dist/bin/exe-team.js +3 -3
- package/dist/bin/git-sweep.js +12 -12
- 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-launchd.js +46 -10
- package/dist/bin/install.js +8 -8
- 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 +11 -11
- package/dist/bin/setup.js +1 -1
- package/dist/bin/shard-migrate.js +4 -4
- package/dist/capability-cards-7XF2UW3Z.js +89 -0
- package/dist/capability-cards-DME6OMOK.js +89 -0
- package/dist/capacity-monitor-7SKMXRIK.js +51 -0
- package/dist/capacity-monitor-MNEA6FMY.js +51 -0
- package/dist/catchup-brief-46O3RLWO.js +175 -0
- package/dist/catchup-brief-EPEKZKRA.js +175 -0
- package/dist/chunk-2EMOVUJR.js +128 -0
- package/dist/chunk-2JE7LJCZ.js +240 -0
- package/dist/chunk-2LHQ5MGP.js +377 -0
- package/dist/chunk-2ZXMXFGH.js +4380 -0
- package/dist/chunk-3KIMGEFL.js +54 -0
- package/dist/chunk-3PY5PK75.js +14533 -0
- package/dist/chunk-3SDAK22H.js +538 -0
- package/dist/chunk-4CEGPB6F.js +240 -0
- package/dist/chunk-4HDMB2M5.js +574 -0
- package/dist/chunk-4KCLWBF6.js +197 -0
- package/dist/chunk-4WZ55DSC.js +381 -0
- package/dist/chunk-5QX4LHOF.js +668 -0
- package/dist/chunk-5RSGWGYP.js +1119 -0
- package/dist/chunk-5SWY4J5G.js +284 -0
- package/dist/chunk-5ZHIAIDE.js +424 -0
- package/dist/chunk-5ZKD5ZVT.js +33 -0
- package/dist/chunk-67X246EI.js +424 -0
- package/dist/chunk-6A56VNVX.js +448 -0
- package/dist/chunk-6EEBG6WU.js +345 -0
- package/dist/chunk-6EI5U2KJ.js +171 -0
- package/dist/chunk-6G4JWZPF.js +128 -0
- package/dist/chunk-6GTLJHAG.js +150 -0
- package/dist/chunk-6LDZPC2H.js +1079 -0
- package/dist/chunk-6PNCZTKV.js +1119 -0
- package/dist/chunk-6QPDD4BI.js +123 -0
- package/dist/chunk-6ZMLJ6ZQ.js +2129 -0
- package/dist/chunk-72O5EJ52.js +204 -0
- package/dist/chunk-737NSJT4.js +553 -0
- package/dist/chunk-7P5TUGTL.js +456 -0
- package/dist/chunk-7XDF7BZQ.js +192 -0
- package/dist/chunk-ALYNEMIH.js +150 -0
- package/dist/chunk-B4PYJHIV.js +402 -0
- package/dist/chunk-B5ZCGIYB.js +630 -0
- package/dist/chunk-BE3T47CS.js +97 -0
- package/dist/chunk-BNJ3YCPD.js +192 -0
- package/dist/chunk-BUBYDG7Q.js +1079 -0
- package/dist/chunk-CSCRGRZT.js +345 -0
- package/dist/chunk-CY4S3HMG.js +30 -0
- package/dist/chunk-D2WYUJHM.js +50 -0
- package/dist/chunk-D3X64YSB.js +377 -0
- package/dist/chunk-D6TPR4BN.js +204 -0
- package/dist/chunk-DDI57ILJ.js +38 -0
- package/dist/chunk-DQBHY3Q4.js +210 -0
- package/dist/chunk-DVFHAY2J.js +630 -0
- package/dist/chunk-DWCR5GGG.js +128 -0
- package/dist/chunk-DZJPVLVR.js +2078 -0
- package/dist/chunk-E45SQG7C.js +280 -0
- package/dist/chunk-EJ7CWALW.js +244 -0
- package/dist/chunk-EM5WXY6H.js +836 -0
- package/dist/chunk-EOVVOUXC.js +381 -0
- package/dist/chunk-EVV55PHP.js +331 -0
- package/dist/chunk-F4FMIWEL.js +214 -0
- package/dist/chunk-F5GLICUP.js +85 -0
- package/dist/chunk-F5WN7EQ2.js +333 -0
- package/dist/chunk-FVXYTNSI.js +123 -0
- package/dist/chunk-FXD5LXRD.js +8 -0
- package/dist/chunk-G53LIPLG.js +76 -0
- package/dist/chunk-GEJAUWIZ.js +1350 -0
- package/dist/chunk-GJDYAXUL.js +227 -0
- package/dist/chunk-GJS7CJRC.js +129 -0
- package/dist/chunk-GTVP4QTZ.js +362 -0
- package/dist/chunk-HG7Z7JHX.js +85 -0
- package/dist/chunk-HH3MBGMJ.js +70 -0
- package/dist/chunk-HJBKBEC4.js +58 -0
- package/dist/chunk-HKSTWZ22.js +456 -0
- package/dist/chunk-HMP5VT6A.js +118 -0
- package/dist/chunk-HN2PWLQI.js +167 -0
- package/dist/chunk-HN3HGFBL.js +20 -0
- package/dist/chunk-HREBA7BJ.js +290 -0
- package/dist/chunk-HV7F5CXJ.js +553 -0
- package/dist/chunk-HWXIMSB7.js +30 -0
- package/dist/chunk-HWY5ROLO.js +129 -0
- package/dist/chunk-IDJCLLJF.js +3298 -0
- package/dist/chunk-IPMGAQGC.js +290 -0
- package/dist/chunk-IRT55NLF.js +382 -0
- package/dist/chunk-IXZ7OTB3.js +159 -0
- package/dist/chunk-J7JVMFKR.js +262 -0
- package/dist/chunk-JABYHL7R.js +171 -0
- package/dist/chunk-JE2ICRS5.js +197 -0
- package/dist/chunk-JLH273CW.js +70 -0
- package/dist/chunk-JPTT22PI.js +54 -0
- package/dist/chunk-JVT6ONVZ.js +731 -0
- package/dist/chunk-KJEG2OQN.js +1350 -0
- package/dist/chunk-LSASGUNP.js +85 -0
- package/dist/chunk-LSTM35QE.js +1186 -0
- package/dist/chunk-LZEWGBU2.js +97 -0
- package/dist/chunk-M2IOPGVR.js +731 -0
- package/dist/chunk-MBININJN.js +2078 -0
- package/dist/chunk-MJ2MCLZH.js +402 -0
- package/dist/chunk-MX63V4YD.js +38 -0
- package/dist/chunk-N7TWCWY5.js +128 -0
- package/dist/chunk-NAKIQODV.js +331 -0
- package/dist/chunk-NMJSZ5FC.js +185 -0
- package/dist/chunk-NXCJWGAF.js +836 -0
- package/dist/chunk-OLJTE7LW.js +157 -0
- package/dist/chunk-OPDX7KTW.js +167 -0
- package/dist/chunk-OXM62MI7.js +221 -0
- package/dist/chunk-PC53GP5N.js +55 -0
- package/dist/chunk-PMMQFOER.js +81 -0
- package/dist/chunk-PVVG22J4.js +735 -0
- package/dist/chunk-Q326CKO3.js +377 -0
- package/dist/chunk-QAK47LG3.js +81 -0
- package/dist/chunk-QAWSQ5LG.js +157 -0
- package/dist/chunk-QLPHEY7D.js +668 -0
- package/dist/chunk-QV4CHWME.js +97 -0
- package/dist/chunk-QY46R3SB.js +348 -0
- package/dist/chunk-RAERYWCL.js +299 -0
- package/dist/chunk-RT5NXMH2.js +284 -0
- package/dist/chunk-RUUIZJSU.js +127 -0
- package/dist/chunk-S3PNZLTN.js +50 -0
- package/dist/chunk-S6WSWJBL.js +362 -0
- package/dist/chunk-STOZKLK6.js +1352 -0
- package/dist/chunk-SZCJI4TR.js +735 -0
- package/dist/chunk-T3FMPQOR.js +85 -0
- package/dist/chunk-T6EKR34W.js +58 -0
- package/dist/chunk-TKIOFYNW.js +1186 -0
- package/dist/chunk-TM2GZWIT.js +3313 -0
- package/dist/chunk-TWFTSIAI.js +4380 -0
- package/dist/chunk-U7BFATN7.js +538 -0
- package/dist/chunk-UAQZT24C.js +181 -0
- package/dist/chunk-UFHBNXGV.js +333 -0
- package/dist/chunk-UVN3LWCL.js +214 -0
- package/dist/chunk-UVRS32RJ.js +97 -0
- package/dist/chunk-V6R43RSE.js +227 -0
- package/dist/chunk-VHMVQUCR.js +448 -0
- package/dist/chunk-VK7NRMIW.js +2133 -0
- package/dist/chunk-VRFO3H3R.js +76 -0
- package/dist/chunk-VRZS4KWF.js +122 -0
- package/dist/chunk-WOXY76VV.js +33 -0
- package/dist/chunk-X6VOKECC.js +348 -0
- package/dist/chunk-XADXYWPE.js +280 -0
- package/dist/chunk-XCP56OMR.js +1352 -0
- package/dist/chunk-XDH5XB72.js +262 -0
- package/dist/chunk-XFPSFPVD.js +1094 -0
- package/dist/chunk-XOT6CVJA.js +244 -0
- package/dist/chunk-XWRIBBYP.js +210 -0
- package/dist/chunk-XWVCURC2.js +181 -0
- package/dist/chunk-YA6SJFNN.js +221 -0
- package/dist/chunk-YDMUHYCP.js +127 -0
- package/dist/chunk-YKQQ4UTG.js +382 -0
- package/dist/chunk-YNORJIBH.js +208 -0
- package/dist/chunk-YQ2R4BLZ.js +14533 -0
- package/dist/chunk-YUIT7Z7I.js +299 -0
- package/dist/chunk-ZD6EJ7LY.js +604 -0
- package/dist/chunk-ZHHBVPOX.js +1094 -0
- package/dist/chunk-ZNY54QWW.js +377 -0
- package/dist/chunk-ZVABYVSP.js +122 -0
- package/dist/chunk-ZVDYPSJH.js +94 -0
- package/dist/chunk-ZXNQ7GRU.js +185 -0
- package/dist/co-activation-ACVH2TL4.js +74 -0
- package/dist/co-activation-EJ63SDWZ.js +74 -0
- package/dist/co-occurrence-VKJWYROE.js +95 -0
- package/dist/co-occurrence-X2M3ASN4.js +95 -0
- package/dist/code-context-index-5EFZGRML.js +30 -0
- package/dist/core-memory-G3AEM4FY.js +110 -0
- package/dist/core-memory-GOI4WKP5.js +110 -0
- package/dist/crdt-sync-QXBHJ5GL.js +33 -0
- package/dist/crdt-sync-WX6YMYZS.js +33 -0
- package/dist/crm-webhook-EEL2F5TM.js +10 -0
- package/dist/crm-webhook-OYNQH4RZ.js +10 -0
- package/dist/cto-delegation-gate-RP4XBAZZ.js +280 -0
- package/dist/cto-delegation-gate-XOD3NAJS.js +280 -0
- package/dist/daemon-orchestration-33R5DNF2.js +139 -0
- package/dist/daemon-orchestration-EEPWOFMX.js +139 -0
- package/dist/db-backup-T4OALIZH.js +41 -0
- package/dist/db-backup-U5TNET7Z.js +41 -0
- package/dist/dispatch-ack-4S44HBWB.js +15 -0
- package/dist/doc-graph-extractor-O5EADZ3H.js +133 -0
- package/dist/doc-graph-extractor-SFMDR2SB.js +133 -0
- package/dist/dreaming-IXYC3FUN.js +34 -0
- package/dist/dreaming-ODYGZEIV.js +34 -0
- package/dist/entity-boost-XBGZKDJZ.js +375 -0
- package/dist/exe-drift-BKAGZUO2.js +70 -0
- package/dist/exe-drift-N7QYRQX7.js +70 -0
- package/dist/exe-export-AQZ3ZPSJ.js +77 -0
- package/dist/exe-export-QQGWWVZC.js +77 -0
- package/dist/exe-import-EVEGB2O4.js +80 -0
- package/dist/exe-import-RPL3RSZ2.js +80 -0
- package/dist/exe-key-5FYKRZOH.js +673 -0
- package/dist/exe-key-Y256JM3G.js +673 -0
- package/dist/exe-snapshot-AUJQ53Z7.js +338 -0
- package/dist/exe-snapshot-CSJDVWXM.js +338 -0
- package/dist/fast-db-init-57YCVJQP.js +7 -0
- package/dist/fast-db-init-VU4FDPGX.js +7 -0
- package/dist/gateway/index.js +8 -8
- package/dist/git-staleness-CR46BFAY.js +112 -0
- package/dist/git-staleness-H4NWNDJ5.js +112 -0
- package/dist/git-task-sweep-F7ASO7CZ.js +42 -0
- package/dist/git-task-sweep-XSPCOBUY.js +42 -0
- package/dist/global-procedures-7FDCJNWI.js +22 -0
- package/dist/global-procedures-GX7V5L76.js +22 -0
- package/dist/graph-auto-extract-JI3VW5KY.js +183 -0
- package/dist/graph-auto-extract-KFNHAHBK.js +183 -0
- package/dist/hooks/bug-report-worker.js +13 -13
- package/dist/hooks/codex-stop-task-finalizer.js +13 -13
- package/dist/hooks/commit-complete.js +13 -13
- package/dist/hooks/error-recall.js +6 -6
- package/dist/hooks/exe-heartbeat-hook.js +3 -3
- package/dist/hooks/ingest-worker.js +3 -3
- package/dist/hooks/ingest.js +6 -6
- package/dist/hooks/instructions-loaded.js +4 -4
- package/dist/hooks/manifest.json +20 -20
- package/dist/hooks/notification.js +4 -4
- package/dist/hooks/post-compact.js +12 -12
- package/dist/hooks/post-tool-combined.js +6 -6
- package/dist/hooks/pre-compact.js +16 -16
- package/dist/hooks/pre-tool-use.js +17 -17
- package/dist/hooks/prompt-submit.js +25 -25
- package/dist/hooks/session-end.js +23 -21
- package/dist/hooks/session-start.js +12 -12
- package/dist/hooks/stop.js +19 -19
- package/dist/hooks/subagent-stop.js +43 -13
- package/dist/hooks/summary-worker.js +19 -19
- package/dist/index.js +19 -19
- package/dist/installer-6PMCIZQZ.js +298 -0
- package/dist/installer-7ET5M2DD.js +344 -0
- package/dist/installer-K7BYY3XC.js +344 -0
- package/dist/installer-U6W7TQZU.js +40 -0
- package/dist/installer-UL4HFVPT.js +298 -0
- package/dist/installer-XMQRESAT.js +40 -0
- package/dist/lib/cloud-sync.js +12 -4
- package/dist/lib/consolidation.js +5 -5
- package/dist/lib/database.js +2 -2
- package/dist/lib/db-daemon-client.js +2 -2
- package/dist/lib/db.js +2 -2
- package/dist/lib/embedder.js +3 -3
- package/dist/lib/employee-templates.js +4 -4
- package/dist/lib/employees.js +2 -2
- package/dist/lib/exe-daemon-client.js +2 -2
- package/dist/lib/exe-daemon.js +50 -39
- package/dist/lib/hybrid-search.js +5 -5
- package/dist/lib/identity.js +2 -2
- package/dist/lib/messaging.js +11 -11
- 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 +12 -12
- package/dist/lib/tmux-routing.js +10 -10
- package/dist/lib/tmux-transport.js +2 -1
- package/dist/lib/token-spend.js +3 -3
- package/dist/lib/transport.js +3 -2
- package/dist/mcp/register-tools.js +62 -62
- package/dist/mcp/server.js +63 -63
- 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 +15 -15
- 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 +14 -14
- package/dist/mcp/tools/send-message.js +13 -13
- package/dist/mcp/tools/update-task.js +13 -13
- package/dist/mcp-http-config-JZPO4B6K.js +29 -0
- package/dist/mcp-http-config-L6TEBZOW.js +29 -0
- package/dist/memory-cards-EIA3YLFA.js +180 -0
- package/dist/memory-cards-MDZGVJWJ.js +180 -0
- package/dist/memory-graph-extractor-BMZBK2LX.js +22 -0
- package/dist/memory-graph-extractor-U2Q7MTBZ.js +22 -0
- package/dist/memory-poisoning-defense-ORWGA4KK.js +224 -0
- package/dist/memory-poisoning-defense-ZY5P2OOG.js +224 -0
- package/dist/memory-queue-client-A2PMQVEU.js +16 -0
- package/dist/memory-reflection-35NUYL3Z.js +244 -0
- package/dist/memory-reflection-NHOC2FGF.js +244 -0
- package/dist/message-queue-client-L5VZ44IN.js +92 -0
- package/dist/notifications-7GGXNR42.js +47 -0
- package/dist/notifications-B2YCZD3T.js +47 -0
- package/dist/orchestration-events-7EQJF377.js +27 -0
- package/dist/orchestration-events-VJTAOA2R.js +27 -0
- package/dist/orchestrator-IAU2Y3K3.js +35 -0
- package/dist/orchestrator-YOM5D5EJ.js +35 -0
- package/dist/pipeline-router-ITQDOV2B.js +15 -0
- package/dist/pipeline-router-VYFAS3ZX.js +15 -0
- package/dist/plan-limits-OJQINDD3.js +28 -0
- package/dist/plan-limits-UWVCNA67.js +28 -0
- package/dist/project-boot-GSLIQJVS.js +299 -0
- package/dist/project-boot-NRU7RRED.js +299 -0
- package/dist/projection-worker-SKLKJJFA.js +1084 -0
- package/dist/projection-worker-XVOLBYQC.js +1084 -0
- package/dist/prospective-memory-JOKZL7QJ.js +232 -0
- package/dist/prospective-memory-WQSB2IPD.js +232 -0
- package/dist/reranker-5HJXM4K5.js +19 -0
- package/dist/reranker-Q7KD2VDL.js +19 -0
- package/dist/retrieval-health-BAKZOWX7.js +11 -0
- package/dist/retrieval-health-LXDMWIAZ.js +11 -0
- package/dist/review-polling-GBRSJ7X5.js +126 -0
- package/dist/review-polling-YDS35QTO.js +126 -0
- package/dist/runtime/index.js +13 -13
- package/dist/session-events-EJID2CZE.js +38 -0
- package/dist/session-events-UPXPYEA3.js +38 -0
- package/dist/session-kill-telemetry-7FP74BIM.js +31 -0
- package/dist/session-kill-telemetry-XLMNOBBQ.js +31 -0
- package/dist/session-scope-QCN23H6B.js +88 -0
- package/dist/session-scope-ZR2W2EDF.js +88 -0
- package/dist/setup-wizard-7H4CE5UL.js +12 -0
- package/dist/setup-wizard-MR3XA4BC.js +12 -0
- package/dist/skill-refinement-6UK4P4UQ.js +159 -0
- package/dist/skill-refinement-RYBLDKDP.js +159 -0
- package/dist/steward-gate-PSF4JQUC.js +15 -0
- package/dist/steward-gate-U2HQZ4LX.js +15 -0
- package/dist/task-enforcement-NL6WPS3T.js +506 -0
- package/dist/task-enforcement-RYWTWHQJ.js +506 -0
- package/dist/task-scope-43TBGXSP.js +37 -0
- package/dist/task-scope-BR4ZJLQT.js +37 -0
- package/dist/tasks-crud-AQLUDVES.js +79 -0
- package/dist/tasks-crud-LWTHIDHF.js +79 -0
- package/dist/tasks-notify-PZQMVQHI.js +40 -0
- package/dist/tasks-notify-U4QZ2FGV.js +40 -0
- package/dist/tasks-review-E3LQRBNB.js +49 -0
- package/dist/tasks-review-NIGU6K3L.js +49 -0
- package/dist/telemetry-upload-PQLC5A4D.js +741 -0
- package/dist/telemetry-upload-QOYSUDDH.js +741 -0
- package/dist/token-budget-OJGWYISJ.js +86 -0
- package/dist/token-budget-VMQLMHSU.js +86 -0
- package/dist/tool-capability-index-4M3BFQTU.js +10 -0
- package/dist/tool-telemetry-4YD2E6UU.js +17 -0
- package/dist/tool-telemetry-662N3S5Q.js +17 -0
- package/dist/tui/App.js +18 -18
- package/dist/tui-data-IIGF5XRY.js +260 -0
- package/dist/tui-data-W4INCXEA.js +260 -0
- package/dist/wiki-acl-KXXMRMIM.js +111 -0
- package/dist/wiki-acl-XSRBJSBD.js +111 -0
- package/dist/worker-gate-7GMM23JY.js +21 -0
- package/dist/worker-gate-F6LY67TM.js +21 -0
- package/dist/workflow-engine-G4JTWI5N.js +28 -0
- package/dist/workflow-engine-UHOVTA5Q.js +28 -0
- package/dist/worktree-OJMZ4RG4.js +28 -0
- package/dist/worktree-ZLF4MX6T.js +28 -0
- package/dist/worktree-sweep-5Z6V7MNJ.js +21 -0
- package/dist/worktree-sweep-M64OW2MU.js +21 -0
- package/package.json +2 -2
- package/release-notes.json +14 -14
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
import {
|
|
2
|
+
blobToVector
|
|
3
|
+
} from "./chunk-OTVEIJUQ.js";
|
|
4
|
+
import {
|
|
5
|
+
getClient
|
|
6
|
+
} from "./chunk-IDJCLLJF.js";
|
|
7
|
+
import "./chunk-2I23RPSI.js";
|
|
8
|
+
import "./chunk-Q326CKO3.js";
|
|
9
|
+
import "./chunk-PNQDP3OA.js";
|
|
10
|
+
import "./chunk-7HLWBYH7.js";
|
|
11
|
+
import "./chunk-FXU7JOXK.js";
|
|
12
|
+
import {
|
|
13
|
+
loadConfig
|
|
14
|
+
} from "./chunk-R36FAN53.js";
|
|
15
|
+
import "./chunk-LYH5HE24.js";
|
|
16
|
+
import "./chunk-MLKGABMK.js";
|
|
17
|
+
|
|
18
|
+
// src/lib/memory-poisoning-defense.ts
|
|
19
|
+
var SYSTEM_TOOLS = /* @__PURE__ */ new Set([
|
|
20
|
+
"session-start",
|
|
21
|
+
"ingest",
|
|
22
|
+
"ingest-worker",
|
|
23
|
+
"consolidation",
|
|
24
|
+
"skill-learning",
|
|
25
|
+
"summary-worker",
|
|
26
|
+
"bug-report-worker",
|
|
27
|
+
"reflection",
|
|
28
|
+
"dreaming-engine",
|
|
29
|
+
"daemon"
|
|
30
|
+
]);
|
|
31
|
+
function computeTrustLevel(toolName, agentId) {
|
|
32
|
+
if (SYSTEM_TOOLS.has(toolName)) return "system";
|
|
33
|
+
if (agentId && (toolName.startsWith("mcp__exe") || toolName === "manual" || toolName === "store_memory")) {
|
|
34
|
+
return "agent";
|
|
35
|
+
}
|
|
36
|
+
if (toolName.includes("webhook") || toolName.includes("pipeline") || toolName.includes("ingest_raw")) {
|
|
37
|
+
return "external";
|
|
38
|
+
}
|
|
39
|
+
return "unknown";
|
|
40
|
+
}
|
|
41
|
+
function cosineDistance(a, b) {
|
|
42
|
+
if (a.length !== b.length || a.length === 0) return 1;
|
|
43
|
+
let dotProduct = 0;
|
|
44
|
+
let normA = 0;
|
|
45
|
+
let normB = 0;
|
|
46
|
+
for (let i = 0; i < a.length; i++) {
|
|
47
|
+
dotProduct += a[i] * b[i];
|
|
48
|
+
normA += a[i] * a[i];
|
|
49
|
+
normB += b[i] * b[i];
|
|
50
|
+
}
|
|
51
|
+
const denom = Math.sqrt(normA) * Math.sqrt(normB);
|
|
52
|
+
if (denom === 0) return 1;
|
|
53
|
+
const similarity = dotProduct / denom;
|
|
54
|
+
return 1 - similarity;
|
|
55
|
+
}
|
|
56
|
+
async function getAgentCentroid(agentId, projectName) {
|
|
57
|
+
const client = getClient();
|
|
58
|
+
try {
|
|
59
|
+
const result = await client.execute({
|
|
60
|
+
sql: `SELECT centroid_vector FROM agent_centroids WHERE agent_id = ? AND project_name = ?`,
|
|
61
|
+
args: [agentId, projectName]
|
|
62
|
+
});
|
|
63
|
+
if (result.rows.length === 0 || !result.rows[0].centroid_vector) return null;
|
|
64
|
+
const vector = blobToVector(result.rows[0].centroid_vector);
|
|
65
|
+
return vector.length > 0 ? vector : null;
|
|
66
|
+
} catch {
|
|
67
|
+
return null;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
async function checkAnomaly(vector, agentId, projectName, threshold) {
|
|
71
|
+
const centroid = await getAgentCentroid(agentId, projectName);
|
|
72
|
+
if (!centroid) return { anomalous: false, distance: 0 };
|
|
73
|
+
const distance = cosineDistance(vector, centroid);
|
|
74
|
+
const effectiveThreshold = threshold ?? 0.85;
|
|
75
|
+
return { anomalous: distance > effectiveThreshold, distance };
|
|
76
|
+
}
|
|
77
|
+
async function refreshAgentCentroid(agentId, projectName, sampleSize = 100) {
|
|
78
|
+
const client = getClient();
|
|
79
|
+
const result = await client.execute({
|
|
80
|
+
sql: `SELECT vector FROM memories
|
|
81
|
+
WHERE agent_id = ? AND project_name = ? AND vector IS NOT NULL
|
|
82
|
+
AND status = 'active' AND quarantined = 0
|
|
83
|
+
ORDER BY timestamp DESC LIMIT ?`,
|
|
84
|
+
args: [agentId, projectName, sampleSize]
|
|
85
|
+
});
|
|
86
|
+
if (result.rows.length < 5) return;
|
|
87
|
+
let dim = 0;
|
|
88
|
+
const vectors = [];
|
|
89
|
+
for (const row of result.rows) {
|
|
90
|
+
const arr = blobToVector(row.vector);
|
|
91
|
+
if (arr.length > 0 && (dim === 0 || arr.length === dim)) {
|
|
92
|
+
dim = arr.length;
|
|
93
|
+
vectors.push(arr);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
if (vectors.length < 5 || dim === 0) return;
|
|
97
|
+
const centroid = new Float32Array(dim);
|
|
98
|
+
for (const v of vectors) {
|
|
99
|
+
for (let i = 0; i < dim; i++) {
|
|
100
|
+
centroid[i] += v[i] / vectors.length;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
const centroidBlob = Buffer.from(centroid.buffer);
|
|
104
|
+
await client.execute({
|
|
105
|
+
sql: `INSERT OR REPLACE INTO agent_centroids (agent_id, project_name, centroid_vector, sample_count, updated_at)
|
|
106
|
+
VALUES (?, ?, ?, ?, ?)`,
|
|
107
|
+
args: [agentId, projectName, centroidBlob, vectors.length, (/* @__PURE__ */ new Date()).toISOString()]
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
async function quarantineMemory(memoryId, reason) {
|
|
111
|
+
const client = getClient();
|
|
112
|
+
await client.execute({
|
|
113
|
+
sql: `UPDATE memories SET quarantined = 1, quarantine_reason = ? WHERE id = ?`,
|
|
114
|
+
args: [reason, memoryId]
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
async function approveQuarantined(memoryId) {
|
|
118
|
+
const client = getClient();
|
|
119
|
+
await client.execute({
|
|
120
|
+
sql: `UPDATE memories SET quarantined = 0, quarantine_reason = NULL WHERE id = ?`,
|
|
121
|
+
args: [memoryId]
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
async function rejectQuarantined(memoryId) {
|
|
125
|
+
const client = getClient();
|
|
126
|
+
await client.execute({
|
|
127
|
+
sql: `UPDATE memories SET status = 'archived', quarantine_reason = COALESCE(quarantine_reason, '') || ' [REJECTED]' WHERE id = ?`,
|
|
128
|
+
args: [memoryId]
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
async function listQuarantined(limit = 20) {
|
|
132
|
+
const client = getClient();
|
|
133
|
+
const result = await client.execute({
|
|
134
|
+
sql: `SELECT id, agent_id, raw_text, quarantine_reason, timestamp
|
|
135
|
+
FROM memories
|
|
136
|
+
WHERE quarantined = 1 AND status = 'active'
|
|
137
|
+
ORDER BY timestamp DESC LIMIT ?`,
|
|
138
|
+
args: [limit]
|
|
139
|
+
});
|
|
140
|
+
return result.rows.map((r) => ({
|
|
141
|
+
id: String(r.id),
|
|
142
|
+
agentId: String(r.agent_id),
|
|
143
|
+
rawText: String(r.raw_text).slice(0, 200),
|
|
144
|
+
reason: String(r.quarantine_reason ?? "unknown"),
|
|
145
|
+
createdAt: String(r.timestamp)
|
|
146
|
+
}));
|
|
147
|
+
}
|
|
148
|
+
var _writeCounters = /* @__PURE__ */ new Map();
|
|
149
|
+
var _sessionCounters = /* @__PURE__ */ new Map();
|
|
150
|
+
function checkRateLimit(agentId, sessionId, limits) {
|
|
151
|
+
const perMinute = limits?.perMinute ?? 50;
|
|
152
|
+
const perSession = limits?.perSession ?? 5e3;
|
|
153
|
+
const now = Date.now();
|
|
154
|
+
const minuteKey = `${agentId}:minute`;
|
|
155
|
+
const minuteCounter = _writeCounters.get(minuteKey);
|
|
156
|
+
if (minuteCounter && now - minuteCounter.windowStart < 6e4) {
|
|
157
|
+
if (minuteCounter.count >= perMinute) {
|
|
158
|
+
return { allowed: false, reason: `Rate limit: ${perMinute}/minute exceeded for ${agentId}` };
|
|
159
|
+
}
|
|
160
|
+
minuteCounter.count++;
|
|
161
|
+
} else {
|
|
162
|
+
_writeCounters.set(minuteKey, { count: 1, windowStart: now });
|
|
163
|
+
}
|
|
164
|
+
const sessionCount = (_sessionCounters.get(sessionId) ?? 0) + 1;
|
|
165
|
+
_sessionCounters.set(sessionId, sessionCount);
|
|
166
|
+
if (sessionCount > perSession) {
|
|
167
|
+
return { allowed: false, reason: `Session limit: ${perSession} memories exceeded for session ${sessionId}` };
|
|
168
|
+
}
|
|
169
|
+
return { allowed: true };
|
|
170
|
+
}
|
|
171
|
+
function resetRateLimits() {
|
|
172
|
+
_writeCounters.clear();
|
|
173
|
+
_sessionCounters.clear();
|
|
174
|
+
}
|
|
175
|
+
async function checkMemoryPoisoning(opts) {
|
|
176
|
+
const config = await loadConfig();
|
|
177
|
+
const defenseConfig = config.poisoningDefense;
|
|
178
|
+
if (!defenseConfig?.enabled) {
|
|
179
|
+
return { passed: true, trustLevel: computeTrustLevel(opts.toolName, opts.agentId), quarantined: false };
|
|
180
|
+
}
|
|
181
|
+
const trustLevel = computeTrustLevel(opts.toolName, opts.agentId);
|
|
182
|
+
const rateCheck = checkRateLimit(opts.agentId, opts.sessionId, defenseConfig.rateLimits);
|
|
183
|
+
if (!rateCheck.allowed) {
|
|
184
|
+
await quarantineMemory(opts.memoryId, rateCheck.reason);
|
|
185
|
+
return { passed: false, trustLevel, quarantined: true, reason: rateCheck.reason };
|
|
186
|
+
}
|
|
187
|
+
if (opts.importance >= 8 && trustLevel !== "system") {
|
|
188
|
+
const highImpLimit = defenseConfig.rateLimits?.highImportance ?? 20;
|
|
189
|
+
const sessionHighImp = (_sessionCounters.get(`${opts.sessionId}:highimp`) ?? 0) + 1;
|
|
190
|
+
_sessionCounters.set(`${opts.sessionId}:highimp`, sessionHighImp);
|
|
191
|
+
if (sessionHighImp > highImpLimit) {
|
|
192
|
+
await quarantineMemory(opts.memoryId, `High-importance inflation: ${sessionHighImp} importance>=8 memories in session`);
|
|
193
|
+
return { passed: false, trustLevel, quarantined: true, reason: "importance inflation" };
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
if (opts.vector && opts.vector.length > 0) {
|
|
197
|
+
const threshold = defenseConfig.anomalyThreshold ?? 0.85;
|
|
198
|
+
const anomaly = await checkAnomaly(opts.vector, opts.agentId, opts.projectName, threshold);
|
|
199
|
+
if (anomaly.anomalous) {
|
|
200
|
+
await quarantineMemory(opts.memoryId, `Anomalous vector: distance ${anomaly.distance.toFixed(3)} > threshold ${threshold}`);
|
|
201
|
+
return {
|
|
202
|
+
passed: false,
|
|
203
|
+
trustLevel,
|
|
204
|
+
anomalyDistance: anomaly.distance,
|
|
205
|
+
quarantined: true,
|
|
206
|
+
reason: `anomaly distance ${anomaly.distance.toFixed(3)}`
|
|
207
|
+
};
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
return { passed: true, trustLevel, quarantined: false };
|
|
211
|
+
}
|
|
212
|
+
export {
|
|
213
|
+
approveQuarantined,
|
|
214
|
+
checkAnomaly,
|
|
215
|
+
checkMemoryPoisoning,
|
|
216
|
+
checkRateLimit,
|
|
217
|
+
computeTrustLevel,
|
|
218
|
+
getAgentCentroid,
|
|
219
|
+
listQuarantined,
|
|
220
|
+
quarantineMemory,
|
|
221
|
+
refreshAgentCentroid,
|
|
222
|
+
rejectQuarantined,
|
|
223
|
+
resetRateLimits
|
|
224
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import {
|
|
2
|
+
batchWriteMemoryViaDaemon,
|
|
3
|
+
writeMemoryViaDaemon
|
|
4
|
+
} from "./chunk-PC53GP5N.js";
|
|
5
|
+
import "./chunk-MEWGYH6Z.js";
|
|
6
|
+
import "./chunk-4HDMB2M5.js";
|
|
7
|
+
import "./chunk-QOZQ2MYZ.js";
|
|
8
|
+
import "./chunk-FXD5LXRD.js";
|
|
9
|
+
import "./chunk-7L2EV3XX.js";
|
|
10
|
+
import "./chunk-R36FAN53.js";
|
|
11
|
+
import "./chunk-LYH5HE24.js";
|
|
12
|
+
import "./chunk-MLKGABMK.js";
|
|
13
|
+
export {
|
|
14
|
+
batchWriteMemoryViaDaemon,
|
|
15
|
+
writeMemoryViaDaemon
|
|
16
|
+
};
|
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
import {
|
|
2
|
+
buildFtsMatch,
|
|
3
|
+
tokenizeForFts
|
|
4
|
+
} from "./chunk-AB4PAQYK.js";
|
|
5
|
+
import {
|
|
6
|
+
getClient
|
|
7
|
+
} from "./chunk-TM2GZWIT.js";
|
|
8
|
+
import "./chunk-2I23RPSI.js";
|
|
9
|
+
import "./chunk-D3X64YSB.js";
|
|
10
|
+
import "./chunk-PNQDP3OA.js";
|
|
11
|
+
import "./chunk-7HLWBYH7.js";
|
|
12
|
+
import "./chunk-FXU7JOXK.js";
|
|
13
|
+
import "./chunk-R36FAN53.js";
|
|
14
|
+
import "./chunk-LYH5HE24.js";
|
|
15
|
+
import "./chunk-MLKGABMK.js";
|
|
16
|
+
|
|
17
|
+
// src/lib/memory-reflection.ts
|
|
18
|
+
var REFLECTION_SCHEMA = `
|
|
19
|
+
CREATE TABLE IF NOT EXISTS memory_reflections (
|
|
20
|
+
id TEXT PRIMARY KEY,
|
|
21
|
+
agent_id TEXT NOT NULL,
|
|
22
|
+
project_name TEXT,
|
|
23
|
+
insight_type TEXT NOT NULL CHECK (insight_type IN ('pattern', 'contradiction', 'evolution', 'summary')),
|
|
24
|
+
subject TEXT NOT NULL,
|
|
25
|
+
content TEXT NOT NULL,
|
|
26
|
+
source_card_ids TEXT NOT NULL DEFAULT '[]',
|
|
27
|
+
confidence REAL NOT NULL DEFAULT 0.7,
|
|
28
|
+
active INTEGER NOT NULL DEFAULT 1,
|
|
29
|
+
created_at TEXT NOT NULL,
|
|
30
|
+
expires_at TEXT
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
CREATE INDEX IF NOT EXISTS idx_memory_reflections_agent
|
|
34
|
+
ON memory_reflections(agent_id, insight_type, created_at DESC);
|
|
35
|
+
|
|
36
|
+
CREATE VIRTUAL TABLE IF NOT EXISTS memory_reflections_fts USING fts5(
|
|
37
|
+
content, subject,
|
|
38
|
+
content=memory_reflections, content_rowid=rowid
|
|
39
|
+
);
|
|
40
|
+
|
|
41
|
+
CREATE TRIGGER IF NOT EXISTS memory_reflections_ai AFTER INSERT ON memory_reflections BEGIN
|
|
42
|
+
INSERT INTO memory_reflections_fts(rowid, content, subject)
|
|
43
|
+
VALUES (new.rowid, new.content, new.subject);
|
|
44
|
+
END;
|
|
45
|
+
|
|
46
|
+
CREATE TRIGGER IF NOT EXISTS memory_reflections_ad AFTER DELETE ON memory_reflections BEGIN
|
|
47
|
+
INSERT INTO memory_reflections_fts(memory_reflections_fts, rowid, content, subject)
|
|
48
|
+
VALUES ('delete', old.rowid, old.content, old.subject);
|
|
49
|
+
END;
|
|
50
|
+
`;
|
|
51
|
+
async function detectContradictions(agentId, projectName) {
|
|
52
|
+
const client = getClient();
|
|
53
|
+
const insights = [];
|
|
54
|
+
let sql = `SELECT subject, GROUP_CONCAT(id) as card_ids,
|
|
55
|
+
GROUP_CONCAT(content, '|||') as contents,
|
|
56
|
+
GROUP_CONCAT(timestamp) as timestamps,
|
|
57
|
+
COUNT(*) as cnt
|
|
58
|
+
FROM memory_cards
|
|
59
|
+
WHERE agent_id = ? AND active = 1 AND subject IS NOT NULL`;
|
|
60
|
+
const args = [agentId];
|
|
61
|
+
if (projectName) {
|
|
62
|
+
sql += " AND project_name = ?";
|
|
63
|
+
args.push(projectName);
|
|
64
|
+
}
|
|
65
|
+
sql += " GROUP BY subject HAVING cnt >= 2 ORDER BY cnt DESC LIMIT 100";
|
|
66
|
+
const result = await client.execute({ sql, args });
|
|
67
|
+
for (const row of result.rows) {
|
|
68
|
+
const subject = row.subject;
|
|
69
|
+
const cardIds = row.card_ids.split(",");
|
|
70
|
+
const contents = row.contents.split("|||");
|
|
71
|
+
const timestamps = row.timestamps.split(",");
|
|
72
|
+
if (contents.length < 2) continue;
|
|
73
|
+
const unique = new Set(contents.map((c) => c.toLowerCase().trim()));
|
|
74
|
+
if (unique.size < 2) continue;
|
|
75
|
+
const pairs = contents.map((c, i) => ({ content: c, ts: timestamps[i], id: cardIds[i] }));
|
|
76
|
+
pairs.sort((a, b) => (a.ts ?? "").localeCompare(b.ts ?? ""));
|
|
77
|
+
const earliest = pairs[0];
|
|
78
|
+
const latest = pairs[pairs.length - 1];
|
|
79
|
+
if (earliest.content.toLowerCase().trim() === latest.content.toLowerCase().trim()) continue;
|
|
80
|
+
const insightContent = `${subject}: changed from "${earliest.content.slice(0, 100)}" to "${latest.content.slice(0, 100)}"`;
|
|
81
|
+
const id = `reflect-evol-${subject.slice(0, 20)}-${Date.now()}`.replace(/[^a-zA-Z0-9-]/g, "_");
|
|
82
|
+
insights.push({
|
|
83
|
+
id,
|
|
84
|
+
agent_id: agentId,
|
|
85
|
+
project_name: projectName ?? null,
|
|
86
|
+
insight_type: "evolution",
|
|
87
|
+
subject,
|
|
88
|
+
content: insightContent,
|
|
89
|
+
source_card_ids: cardIds.slice(0, 10),
|
|
90
|
+
confidence: 0.7,
|
|
91
|
+
created_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
return insights;
|
|
95
|
+
}
|
|
96
|
+
async function detectPatterns(agentId, projectName) {
|
|
97
|
+
const client = getClient();
|
|
98
|
+
const insights = [];
|
|
99
|
+
let sql = `SELECT subject, card_type, COUNT(DISTINCT session_id) as sessions,
|
|
100
|
+
COUNT(*) as total, GROUP_CONCAT(id) as card_ids,
|
|
101
|
+
GROUP_CONCAT(content, '|||') as sample_contents
|
|
102
|
+
FROM memory_cards
|
|
103
|
+
WHERE agent_id = ? AND active = 1 AND subject IS NOT NULL`;
|
|
104
|
+
const args = [agentId];
|
|
105
|
+
if (projectName) {
|
|
106
|
+
sql += " AND project_name = ?";
|
|
107
|
+
args.push(projectName);
|
|
108
|
+
}
|
|
109
|
+
sql += " GROUP BY subject, card_type HAVING sessions >= 3 ORDER BY sessions DESC LIMIT 50";
|
|
110
|
+
const result = await client.execute({ sql, args });
|
|
111
|
+
for (const row of result.rows) {
|
|
112
|
+
const subject = row.subject;
|
|
113
|
+
const cardType = row.card_type;
|
|
114
|
+
const sessions = Number(row.sessions);
|
|
115
|
+
const total = Number(row.total);
|
|
116
|
+
const cardIds = row.card_ids.split(",");
|
|
117
|
+
const samples = row.sample_contents.split("|||").slice(0, 3);
|
|
118
|
+
const insightContent = `${subject} appears in ${sessions} sessions (${total} mentions) as ${cardType}. Examples: ${samples.map((s) => `"${s.slice(0, 80)}"`).join("; ")}`;
|
|
119
|
+
const id = `reflect-pattern-${subject.slice(0, 20)}-${Date.now()}`.replace(/[^a-zA-Z0-9-]/g, "_");
|
|
120
|
+
insights.push({
|
|
121
|
+
id,
|
|
122
|
+
agent_id: agentId,
|
|
123
|
+
project_name: projectName ?? null,
|
|
124
|
+
insight_type: "pattern",
|
|
125
|
+
subject,
|
|
126
|
+
content: insightContent,
|
|
127
|
+
source_card_ids: cardIds.slice(0, 10),
|
|
128
|
+
confidence: Math.min(0.5 + sessions * 0.1, 0.95),
|
|
129
|
+
created_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
return insights;
|
|
133
|
+
}
|
|
134
|
+
async function generateSummaries(agentId, projectName) {
|
|
135
|
+
const client = getClient();
|
|
136
|
+
const insights = [];
|
|
137
|
+
let sql = `SELECT subject, COUNT(*) as cnt, GROUP_CONCAT(id) as card_ids,
|
|
138
|
+
GROUP_CONCAT(content, '|||') as all_contents,
|
|
139
|
+
MIN(timestamp) as first_seen, MAX(timestamp) as last_seen
|
|
140
|
+
FROM memory_cards
|
|
141
|
+
WHERE agent_id = ? AND active = 1 AND subject IS NOT NULL`;
|
|
142
|
+
const args = [agentId];
|
|
143
|
+
if (projectName) {
|
|
144
|
+
sql += " AND project_name = ?";
|
|
145
|
+
args.push(projectName);
|
|
146
|
+
}
|
|
147
|
+
sql += " GROUP BY subject HAVING cnt >= 5 ORDER BY cnt DESC LIMIT 30";
|
|
148
|
+
const result = await client.execute({ sql, args });
|
|
149
|
+
for (const row of result.rows) {
|
|
150
|
+
const subject = row.subject;
|
|
151
|
+
const cnt = Number(row.cnt);
|
|
152
|
+
const cardIds = row.card_ids.split(",");
|
|
153
|
+
const allContents = (row.sample_contents ?? row.all_contents ?? "").split("|||");
|
|
154
|
+
const firstSeen = row.first_seen;
|
|
155
|
+
const lastSeen = row.last_seen;
|
|
156
|
+
const unique = [...new Set(allContents.map((c) => c.trim()))].filter((c) => c.length > 10).slice(0, 5);
|
|
157
|
+
if (unique.length < 2) continue;
|
|
158
|
+
const insightContent = `${subject} (${cnt} facts, ${firstSeen?.slice(0, 10)} to ${lastSeen?.slice(0, 10)}): ${unique.map((u) => u.slice(0, 80)).join(". ")}`;
|
|
159
|
+
const id = `reflect-summary-${subject.slice(0, 20)}-${Date.now()}`.replace(/[^a-zA-Z0-9-]/g, "_");
|
|
160
|
+
insights.push({
|
|
161
|
+
id,
|
|
162
|
+
agent_id: agentId,
|
|
163
|
+
project_name: projectName ?? null,
|
|
164
|
+
insight_type: "summary",
|
|
165
|
+
subject,
|
|
166
|
+
content: insightContent,
|
|
167
|
+
source_card_ids: cardIds.slice(0, 10),
|
|
168
|
+
confidence: 0.6,
|
|
169
|
+
created_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
return insights;
|
|
173
|
+
}
|
|
174
|
+
async function runReflection(agentId, projectName) {
|
|
175
|
+
const [contradictions, patterns, summaries] = await Promise.all([
|
|
176
|
+
detectContradictions(agentId, projectName),
|
|
177
|
+
detectPatterns(agentId, projectName),
|
|
178
|
+
generateSummaries(agentId, projectName)
|
|
179
|
+
]);
|
|
180
|
+
const all = [...contradictions, ...patterns, ...summaries];
|
|
181
|
+
if (all.length === 0) return { contradictions: 0, patterns: 0, summaries: 0 };
|
|
182
|
+
const client = getClient();
|
|
183
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
184
|
+
const stmts = all.map((insight) => ({
|
|
185
|
+
sql: `INSERT OR IGNORE INTO memory_reflections
|
|
186
|
+
(id, agent_id, project_name, insight_type, subject, content,
|
|
187
|
+
source_card_ids, confidence, active, created_at)
|
|
188
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, 1, ?)`,
|
|
189
|
+
args: [
|
|
190
|
+
insight.id,
|
|
191
|
+
insight.agent_id,
|
|
192
|
+
insight.project_name,
|
|
193
|
+
insight.insight_type,
|
|
194
|
+
insight.subject,
|
|
195
|
+
insight.content,
|
|
196
|
+
JSON.stringify(insight.source_card_ids),
|
|
197
|
+
insight.confidence,
|
|
198
|
+
now
|
|
199
|
+
]
|
|
200
|
+
}));
|
|
201
|
+
await client.batch(stmts, "write");
|
|
202
|
+
return {
|
|
203
|
+
contradictions: contradictions.length,
|
|
204
|
+
patterns: patterns.length,
|
|
205
|
+
summaries: summaries.length
|
|
206
|
+
};
|
|
207
|
+
}
|
|
208
|
+
async function searchReflections(queryText, agentId, limit = 5) {
|
|
209
|
+
const terms = tokenizeForFts(queryText, { maxTerms: 8 });
|
|
210
|
+
if (terms.length === 0) return [];
|
|
211
|
+
const matchExpr = buildFtsMatch(terms, { prefix: true, join: terms.length >= 3 ? "AND" : "OR" });
|
|
212
|
+
const client = getClient();
|
|
213
|
+
const result = await client.execute({
|
|
214
|
+
sql: `SELECT r.id, r.agent_id, r.project_name, r.insight_type, r.subject,
|
|
215
|
+
r.content, r.source_card_ids, r.confidence, r.created_at
|
|
216
|
+
FROM memory_reflections r
|
|
217
|
+
JOIN memory_reflections_fts fts ON r.rowid = fts.rowid
|
|
218
|
+
WHERE memory_reflections_fts MATCH ?
|
|
219
|
+
AND r.agent_id = ?
|
|
220
|
+
AND r.active = 1
|
|
221
|
+
ORDER BY rank
|
|
222
|
+
LIMIT ?`,
|
|
223
|
+
args: [matchExpr, agentId, limit]
|
|
224
|
+
});
|
|
225
|
+
return result.rows.map((row) => ({
|
|
226
|
+
id: row.id,
|
|
227
|
+
agent_id: row.agent_id,
|
|
228
|
+
project_name: row.project_name,
|
|
229
|
+
insight_type: row.insight_type,
|
|
230
|
+
subject: row.subject,
|
|
231
|
+
content: row.content,
|
|
232
|
+
source_card_ids: JSON.parse(row.source_card_ids ?? "[]"),
|
|
233
|
+
confidence: Number(row.confidence),
|
|
234
|
+
created_at: row.created_at
|
|
235
|
+
}));
|
|
236
|
+
}
|
|
237
|
+
export {
|
|
238
|
+
REFLECTION_SCHEMA,
|
|
239
|
+
detectContradictions,
|
|
240
|
+
detectPatterns,
|
|
241
|
+
generateSummaries,
|
|
242
|
+
runReflection,
|
|
243
|
+
searchReflections
|
|
244
|
+
};
|