squish-memory 1.1.5 → 1.2.1
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/.env.example +32 -16
- package/CHANGELOG.md +147 -0
- package/README.md +120 -78
- package/{scripts → bin}/dependency-manager.mjs +217 -217
- package/{scripts → bin}/detect-clients.mjs +78 -78
- package/bin/install-interactive.mjs +321 -0
- package/bin/squish-mcp.mjs +44 -0
- package/bin/squish.mjs +33 -0
- package/config/mcp-migration-map.json +1 -6
- package/config/mcp-mode-semantics.json +19 -23
- package/config/mcp-remote-auth.json +3 -26
- package/config/mcp-universal.schema.json +5 -35
- package/config/settings.json +107 -52
- package/config.js +5 -0
- package/config.ts +218 -0
- package/core/adapters/config/claude-code.ts +133 -0
- package/core/adapters/config/cursor.ts +90 -0
- package/core/adapters/config/opencode.ts +89 -0
- package/core/adapters/config/windsurf.ts +90 -0
- package/core/adapters/index.ts +102 -0
- package/core/adapters/timeline.ts +116 -0
- package/core/adapters/types.ts +166 -0
- package/core/agent-preferences.ts +140 -0
- package/core/algorithms/analytics/token-estimator.ts +216 -0
- package/core/algorithms/detection/hash-filters.ts +260 -0
- package/core/algorithms/detection/semantic-ranker.ts +194 -0
- package/core/algorithms/detection/two-stage-detector.ts +421 -0
- package/core/algorithms/handlers/approve-merge.ts +215 -0
- package/core/algorithms/handlers/detect-duplicates.ts +192 -0
- package/core/algorithms/handlers/get-stats.ts +132 -0
- package/core/algorithms/handlers/list-proposals.ts +130 -0
- package/core/algorithms/handlers/preview-merge.ts +139 -0
- package/core/algorithms/handlers/reject-merge.ts +93 -0
- package/core/algorithms/handlers/reverse-merge.ts +155 -0
- package/{dist/core/algorithms/index.js → core/algorithms/index.ts} +39 -26
- package/core/algorithms/operations/cache-maintenance.ts +182 -0
- package/core/algorithms/safety/safety-checks.ts +256 -0
- package/core/algorithms/strategies/merge-strategies.ts +381 -0
- package/core/algorithms/types.ts +140 -0
- package/core/algorithms/utils/response-builder.ts +61 -0
- package/core/associations.ts +363 -0
- package/core/beliefs/decay.ts +289 -0
- package/core/beliefs/extractor.ts +131 -0
- package/core/beliefs/store.ts +557 -0
- package/core/beliefs/types.ts +38 -0
- package/core/commands/mcp-server.ts +5 -0
- package/core/compression.ts +177 -0
- package/core/config.js +2 -0
- package/core/consolidation.ts +330 -0
- package/core/context/agent-context.ts +388 -0
- package/core/context/context-paging.ts +449 -0
- package/core/context/context-window.ts +234 -0
- package/core/context/context.ts +35 -0
- package/core/embeddings/embeddings.ts +616 -0
- package/core/embeddings/google-multimodal.ts +200 -0
- package/{dist/core/local-embeddings.js → core/embeddings/local-embeddings.ts} +12 -11
- package/core/embeddings/qmd-client.ts +495 -0
- package/core/embeddings/transformers-local.ts +261 -0
- package/core/embeddings.js +4 -0
- package/core/error-handling.ts +206 -0
- package/core/external +219 -0
- package/core/graph/entity-deduplicator.ts +232 -0
- package/core/graph/graph-builder.ts +257 -0
- package/core/graph/graph-traversal.ts +490 -0
- package/core/graph/index.ts +24 -0
- package/core/graph/llm-entity-extractor.ts +402 -0
- package/core/graph/multi-hop-retrieval.ts +317 -0
- package/core/graph/relationship-extractor.ts +465 -0
- package/core/hooks/agent-hooks.ts +653 -0
- package/core/hooks/auto-tagger.ts +149 -0
- package/core/hooks/capture-filter.ts +169 -0
- package/core/hot-cache.ts +388 -0
- package/core/index.ts +10 -0
- package/core/ingestion/agent-memory.ts +167 -0
- package/core/ingestion/core-memory.ts +326 -0
- package/core/ingestion/learnings.ts +260 -0
- package/core/ingestion/signal-engine.ts +266 -0
- package/core/integrations/obsidian-vault.ts +197 -0
- package/core/layers/generator.ts +115 -0
- package/{dist/core/lib/db-client.d.ts → core/lib/db-client.ts} +168 -114
- package/core/lib/parse-embedding.ts +59 -0
- package/{dist/core/lib/schemas.js → core/lib/schemas.ts} +102 -87
- package/core/lib/types.ts +49 -0
- package/core/lib/utils.ts +151 -0
- package/core/lib/validation.ts +180 -0
- package/core/lifecycle.ts +353 -0
- package/core/logger.ts +59 -0
- package/core/memory/bridge-discovery.ts +395 -0
- package/core/memory/categorizer.ts +390 -0
- package/core/memory/conflict-detector.ts +62 -0
- package/core/memory/consolidation.ts +372 -0
- package/core/memory/context-collector.ts +75 -0
- package/core/memory/contradiction-resolver.ts +494 -0
- package/core/memory/edit-workflow.ts +174 -0
- package/core/memory/entity-extractor.ts +426 -0
- package/core/memory/entity-resolver.ts +89 -0
- package/core/memory/explain.ts +112 -0
- package/core/memory/fact-deriver.ts +300 -0
- package/core/memory/fact-extractor.ts +120 -0
- package/core/memory/feedback-tracker.ts +200 -0
- package/core/memory/hooks.ts +230 -0
- package/core/memory/hybrid-retrieval.ts +65 -0
- package/core/memory/hybrid-scorer.ts +325 -0
- package/core/memory/hybrid-search.ts +748 -0
- package/core/memory/importance.ts +319 -0
- package/{dist/core/memory/index.js → core/memory/index.ts} +11 -10
- package/core/memory/loader.ts +178 -0
- package/core/memory/markdown/markdown-storage.ts +318 -0
- package/core/memory/memories.ts +565 -0
- package/core/memory/memory-lifecycle.ts +51 -0
- package/core/memory/memory-manager.ts +53 -0
- package/core/memory/migrate.ts +173 -0
- package/core/memory/normalization.ts +30 -0
- package/core/memory/path-strengthener.ts +211 -0
- package/core/memory/progressive-disclosure.ts +392 -0
- package/core/memory/query-processor.ts +130 -0
- package/core/memory/query-rewriter.ts +153 -0
- package/core/memory/response-analyzer.ts +81 -0
- package/core/memory/retrieval-feedback.ts +276 -0
- package/core/memory/serialization.ts +83 -0
- package/core/memory/stale-cleaner.ts +147 -0
- package/core/memory/stats.ts +181 -0
- package/core/memory/telemetry.ts +392 -0
- package/core/memory/temporal-facts.ts +356 -0
- package/core/memory/temporal-parser.ts +477 -0
- package/core/memory/trigger-detector.ts +104 -0
- package/core/memory/write-gate.ts +288 -0
- package/{dist/core/places/index.js → core/places/index.ts} +12 -12
- package/core/places/memory-places.ts +339 -0
- package/core/places/places.ts +406 -0
- package/core/places/rules.ts +308 -0
- package/core/places/walking.ts +192 -0
- package/core/projects +89 -0
- package/core/projects.ts +131 -0
- package/core/redis.ts +82 -0
- package/core/responses.ts +187 -0
- package/core/runtime/trust-report.ts +195 -0
- package/core/runtime/trust-state.ts +360 -0
- package/core/scheduler/cron-scheduler.ts +590 -0
- package/core/scheduler/heartbeat.ts +91 -0
- package/{dist/core/scheduler/index.js → core/scheduler/index.ts} +8 -8
- package/core/scheduler/job-runner.ts +197 -0
- package/core/search/conversations.ts +166 -0
- package/core/search/entities.ts +46 -0
- package/core/search/folder-context.ts +154 -0
- package/core/search/graph-boost.ts +22 -0
- package/{dist/core/search/index.js → core/search/index.ts} +4 -5
- package/core/search/qmd-wrapper.ts +84 -0
- package/core/security/encrypt.ts +51 -0
- package/core/security/governance.ts +102 -0
- package/core/security/privacy.ts +108 -0
- package/core/security/secret-detector.ts +122 -0
- package/core/session/auto-load.ts +160 -0
- package/core/session/entity-tracker.ts +363 -0
- package/{dist/core/session/index.js → core/session/index.ts} +7 -7
- package/core/session/reference-resolver.ts +158 -0
- package/core/session/self-iteration-job.ts +478 -0
- package/core/session/session-hooks.ts +69 -0
- package/core/session/types.ts +36 -0
- package/core/session/working-set.ts +275 -0
- package/{dist/core/snapshots/cleanup.js → core/snapshots/cleanup.ts} +13 -12
- package/core/snapshots/comparison.ts +59 -0
- package/core/snapshots/creation.ts +139 -0
- package/core/snapshots/retrieval.ts +44 -0
- package/core/snapshots/stats.ts +63 -0
- package/core/storage/cache.ts +241 -0
- package/core/storage/database.ts +23 -0
- package/{dist/core/summarization/cleanup.js → core/summarization/cleanup.ts} +13 -12
- package/core/summarization/queries.ts +32 -0
- package/core/summarization/stats.ts +64 -0
- package/core/summarization/strategies.ts +52 -0
- package/core/summarization.ts +248 -0
- package/core/temporal-facts.ts +244 -0
- package/core/tracing/collector.ts +470 -0
- package/core/tracing/visualizer.ts +195 -0
- package/core/utils/cleanup-operations.ts +50 -0
- package/core/utils/content-extraction.ts +95 -0
- package/core/utils/filter-builder.ts +56 -0
- package/core/utils/history-traversal.ts +63 -0
- package/core/utils/memory-operations.ts +56 -0
- package/core/utils/query-operations.ts +83 -0
- package/core/utils/summarization-helpers.ts +45 -0
- package/core/utils/temporal-queries.ts +39 -0
- package/{dist/core/utils/vector-operations.js → core/utils/vector-operations.ts} +135 -129
- package/core/utils/version-management.ts +74 -0
- package/core/worker.ts +333 -0
- package/db/adapter.ts +215 -0
- package/{dist/db/bootstrap.js → db/bootstrap.ts} +388 -418
- package/db/drizzle/migrations/0000_needy_cerebro.sql +402 -0
- package/db/drizzle/migrations/meta/0000_snapshot.json +3451 -0
- package/db/drizzle/migrations/meta/_journal.json +13 -0
- package/db/drizzle/schema-sqlite.ts +1032 -0
- package/db/drizzle/schema.ts +1128 -0
- package/db/drizzle.config.ts +12 -0
- package/db/index.ts +83 -0
- package/db/init.sql +5 -0
- package/db/migrations/associations.ts +35 -0
- package/db/migrations/beliefs.ts +89 -0
- package/db/migrations/core-memory.ts +35 -0
- package/db/migrations/fts.ts +59 -0
- package/db/migrations/index.ts +54 -0
- package/db/migrations/indexes.ts +36 -0
- package/db/migrations/learnings.ts +34 -0
- package/db/migrations/maintenance.ts +68 -0
- package/db/migrations/memories.ts +22 -0
- package/db/migrations/memory-places.ts +35 -0
- package/db/migrations/places.ts +49 -0
- package/db/migrations/projects.ts +21 -0
- package/db/migrations/tier-conversion.ts +24 -0
- package/db/neon.ts +22 -0
- package/db/schema/beliefs.ts +50 -0
- package/db/schema/generator.ts +159 -0
- package/db/schema/index.ts +58 -0
- package/db/schema/learnings.ts +32 -0
- package/db/schema/memories.ts +83 -0
- package/db/schema/projects.ts +33 -0
- package/db/schema.ts +13 -0
- package/db/supabase.ts +27 -0
- package/mcp.json.example +8 -11
- package/package.json +140 -159
- package/packages/cli/package.json +22 -0
- package/packages/cli/src/commands/clean.ts +68 -0
- package/packages/cli/src/commands/context.ts +79 -0
- package/packages/cli/src/commands/doctor.ts +357 -0
- package/packages/cli/src/commands/forget.ts +72 -0
- package/packages/cli/src/commands/health.ts +36 -0
- package/packages/cli/src/commands/inspect.ts +41 -0
- package/packages/cli/src/commands/link.ts +50 -0
- package/packages/cli/src/commands/migrate.ts +93 -0
- package/packages/cli/src/commands/recall.ts +99 -0
- package/packages/cli/src/commands/recent.ts +57 -0
- package/packages/cli/src/commands/remember.ts +139 -0
- package/packages/cli/src/commands/run.ts +58 -0
- package/packages/cli/src/commands/stale.ts +43 -0
- package/packages/cli/src/commands/stats.ts +42 -0
- package/packages/cli/src/index.ts +57 -0
- package/packages/cli/tsconfig.json +24 -0
- package/packages/mcp/package.json +26 -0
- package/packages/mcp/src/index.ts +940 -0
- package/packages/mcp/tsconfig.json +20 -0
- package/skills/squish-memory/SKILL.md +38 -35
- package/skills/squish-memory/{scripts/install.sh → install.sh} +1 -1
- package/skills/squish-memory/references/claude-desktop.json +12 -0
- package/skills/squish-memory/references/openclaw.json +13 -0
- package/skills/squish-memory/references/opencode.json +14 -0
- package/config/hooks/claude-code-hooks.json +0 -39
- package/config/hooks/cursor-hooks.json +0 -30
- package/config/hooks/opencode-hooks.json +0 -30
- package/config/hooks/windsurf-hooks.json +0 -30
- package/config/mcp-cli-fallback-policy.json +0 -22
- package/config/mcp.json +0 -38
- package/config/plugin-manifest.json +0 -101
- package/config/plugin-manifest.schema.json +0 -244
- package/config/plugin.json +0 -32
- package/config/remote-memory-policy.json +0 -32
- package/core/commands/context-paging.md +0 -51
- package/core/commands/context-status.md +0 -22
- package/core/commands/context.md +0 -5
- package/core/commands/core-memory.md +0 -56
- package/core/commands/health.md +0 -5
- package/core/commands/init.md +0 -39
- package/core/commands/merge.md +0 -113
- package/core/commands/recall.md +0 -5
- package/core/commands/remember.md +0 -11
- package/core/commands/search.md +0 -10
- package/dist/config.d.ts +0 -83
- package/dist/config.js +0 -242
- package/dist/core/adapters/config/claude-code.d.ts +0 -45
- package/dist/core/adapters/config/claude-code.js +0 -113
- package/dist/core/adapters/config/cursor.d.ts +0 -26
- package/dist/core/adapters/config/cursor.js +0 -74
- package/dist/core/adapters/config/opencode.d.ts +0 -23
- package/dist/core/adapters/config/opencode.js +0 -73
- package/dist/core/adapters/config/windsurf.d.ts +0 -26
- package/dist/core/adapters/config/windsurf.js +0 -74
- package/dist/core/adapters/index.d.ts +0 -45
- package/dist/core/adapters/index.js +0 -84
- package/dist/core/adapters/scripts/install-adapter.d.ts +0 -19
- package/dist/core/adapters/scripts/install-adapter.js +0 -149
- package/dist/core/adapters/timeline.d.ts +0 -23
- package/dist/core/adapters/timeline.js +0 -88
- package/dist/core/adapters/types.d.ts +0 -157
- package/dist/core/adapters/types.js +0 -50
- package/dist/core/algorithms/analytics/token-estimator.d.ts +0 -50
- package/dist/core/algorithms/analytics/token-estimator.js +0 -154
- package/dist/core/algorithms/detection/hash-filters.d.ts +0 -47
- package/dist/core/algorithms/detection/hash-filters.js +0 -190
- package/dist/core/algorithms/detection/semantic-ranker.d.ts +0 -32
- package/dist/core/algorithms/detection/semantic-ranker.js +0 -118
- package/dist/core/algorithms/detection/two-stage-detector.d.ts +0 -52
- package/dist/core/algorithms/detection/two-stage-detector.js +0 -299
- package/dist/core/algorithms/handlers/approve-merge.d.ts +0 -22
- package/dist/core/algorithms/handlers/approve-merge.js +0 -179
- package/dist/core/algorithms/handlers/detect-duplicates.d.ts +0 -47
- package/dist/core/algorithms/handlers/detect-duplicates.js +0 -145
- package/dist/core/algorithms/handlers/get-stats.d.ts +0 -39
- package/dist/core/algorithms/handlers/get-stats.js +0 -88
- package/dist/core/algorithms/handlers/list-proposals.d.ts +0 -45
- package/dist/core/algorithms/handlers/list-proposals.js +0 -83
- package/dist/core/algorithms/handlers/preview-merge.d.ts +0 -39
- package/dist/core/algorithms/handlers/preview-merge.js +0 -93
- package/dist/core/algorithms/handlers/reject-merge.d.ts +0 -28
- package/dist/core/algorithms/handlers/reject-merge.js +0 -69
- package/dist/core/algorithms/handlers/reverse-merge.d.ts +0 -21
- package/dist/core/algorithms/handlers/reverse-merge.js +0 -121
- package/dist/core/algorithms/index.d.ts +0 -21
- package/dist/core/algorithms/operations/cache-maintenance.d.ts +0 -12
- package/dist/core/algorithms/operations/cache-maintenance.js +0 -157
- package/dist/core/algorithms/safety/safety-checks.d.ts +0 -22
- package/dist/core/algorithms/safety/safety-checks.js +0 -179
- package/dist/core/algorithms/strategies/merge-strategies.d.ts +0 -50
- package/dist/core/algorithms/strategies/merge-strategies.js +0 -288
- package/dist/core/algorithms/types.d.ts +0 -133
- package/dist/core/algorithms/types.js +0 -5
- package/dist/core/algorithms/utils/response-builder.d.ts +0 -28
- package/dist/core/algorithms/utils/response-builder.js +0 -37
- package/dist/core/associations.d.ts +0 -31
- package/dist/core/associations.js +0 -248
- package/dist/core/autosave.d.ts +0 -19
- package/dist/core/autosave.js +0 -16
- package/dist/core/commands/managed-sync.d.ts +0 -10
- package/dist/core/commands/managed-sync.js +0 -64
- package/dist/core/commands/mcp-server.d.ts +0 -3
- package/dist/core/commands/mcp-server.js +0 -739
- package/dist/core/consolidation.d.ts +0 -37
- package/dist/core/consolidation.js +0 -248
- package/dist/core/context/agent-context.d.ts +0 -106
- package/dist/core/context/agent-context.js +0 -274
- package/dist/core/context/context-paging.d.ts +0 -80
- package/dist/core/context/context-paging.js +0 -328
- package/dist/core/context/context-window.d.ts +0 -40
- package/dist/core/context/context-window.js +0 -177
- package/dist/core/context/context.d.ts +0 -7
- package/dist/core/context/context.js +0 -22
- package/dist/core/embeddings/google-multimodal.d.ts +0 -14
- package/dist/core/embeddings/google-multimodal.js +0 -142
- package/dist/core/embeddings/qmd-client.d.ts +0 -136
- package/dist/core/embeddings/qmd-client.js +0 -403
- package/dist/core/embeddings.d.ts +0 -29
- package/dist/core/embeddings.js +0 -454
- package/dist/core/error-handling.d.ts +0 -63
- package/dist/core/error-handling.js +0 -173
- package/dist/core/external-folder/index.d.ts +0 -102
- package/dist/core/external-folder/index.js +0 -294
- package/dist/core/hooks/agent-hooks.d.ts +0 -74
- package/dist/core/hooks/agent-hooks.js +0 -244
- package/dist/core/hooks/auto-tagger.d.ts +0 -19
- package/dist/core/hooks/auto-tagger.js +0 -155
- package/dist/core/hooks/capture-filter.d.ts +0 -41
- package/dist/core/hooks/capture-filter.js +0 -128
- package/dist/core/index.d.ts +0 -10
- package/dist/core/index.js +0 -14
- package/dist/core/ingestion/agent-memory.d.ts +0 -22
- package/dist/core/ingestion/agent-memory.js +0 -109
- package/dist/core/ingestion/core-memory.d.ts +0 -78
- package/dist/core/ingestion/core-memory.js +0 -226
- package/dist/core/ingestion/learnings.d.ts +0 -57
- package/dist/core/ingestion/learnings.js +0 -202
- package/dist/core/layers/generator.d.ts +0 -25
- package/dist/core/layers/generator.js +0 -76
- package/dist/core/lib/db-client.js +0 -130
- package/dist/core/lib/schemas.d.ts +0 -129
- package/dist/core/lib/utils.d.ts +0 -14
- package/dist/core/lib/utils.js +0 -90
- package/dist/core/lib/validation.d.ts +0 -38
- package/dist/core/lib/validation.js +0 -151
- package/dist/core/lifecycle.d.ts +0 -26
- package/dist/core/lifecycle.js +0 -302
- package/dist/core/local-embeddings.d.ts +0 -11
- package/dist/core/logger.d.ts +0 -16
- package/dist/core/logger.js +0 -40
- package/dist/core/mcp/client.d.ts +0 -17
- package/dist/core/mcp/client.js +0 -101
- package/dist/core/mcp/index.d.ts +0 -6
- package/dist/core/mcp/index.js +0 -6
- package/dist/core/mcp/server.d.ts +0 -18
- package/dist/core/mcp/server.js +0 -157
- package/dist/core/mcp/standalone-server.d.ts +0 -13
- package/dist/core/mcp/standalone-server.js +0 -46
- package/dist/core/mcp/tools.d.ts +0 -9
- package/dist/core/mcp/tools.js +0 -365
- package/dist/core/mcp/types.d.ts +0 -315
- package/dist/core/mcp/types.js +0 -48
- package/dist/core/memory/bridge-discovery.d.ts +0 -50
- package/dist/core/memory/bridge-discovery.js +0 -291
- package/dist/core/memory/categorizer.d.ts +0 -27
- package/dist/core/memory/categorizer.js +0 -305
- package/dist/core/memory/conflict-detector.d.ts +0 -7
- package/dist/core/memory/conflict-detector.js +0 -43
- package/dist/core/memory/consolidation.d.ts +0 -42
- package/dist/core/memory/consolidation.js +0 -303
- package/dist/core/memory/context-collector.d.ts +0 -10
- package/dist/core/memory/context-collector.js +0 -56
- package/dist/core/memory/contradiction-resolver.d.ts +0 -40
- package/dist/core/memory/contradiction-resolver.js +0 -368
- package/dist/core/memory/edit-workflow.d.ts +0 -19
- package/dist/core/memory/edit-workflow.js +0 -120
- package/dist/core/memory/entity-extractor.d.ts +0 -33
- package/dist/core/memory/entity-extractor.js +0 -336
- package/dist/core/memory/entity-resolver.d.ts +0 -23
- package/dist/core/memory/entity-resolver.js +0 -64
- package/dist/core/memory/fact-extractor.d.ts +0 -24
- package/dist/core/memory/fact-extractor.js +0 -89
- package/dist/core/memory/feedback-tracker.d.ts +0 -12
- package/dist/core/memory/feedback-tracker.js +0 -155
- package/dist/core/memory/hooks.d.ts +0 -88
- package/dist/core/memory/hooks.js +0 -174
- package/dist/core/memory/hybrid-retrieval.d.ts +0 -29
- package/dist/core/memory/hybrid-retrieval.js +0 -139
- package/dist/core/memory/hybrid-scorer.d.ts +0 -40
- package/dist/core/memory/hybrid-scorer.js +0 -284
- package/dist/core/memory/hybrid-search.d.ts +0 -20
- package/dist/core/memory/hybrid-search.js +0 -359
- package/dist/core/memory/importance.d.ts +0 -63
- package/dist/core/memory/importance.js +0 -298
- package/dist/core/memory/index.d.ts +0 -8
- package/dist/core/memory/loader.d.ts +0 -31
- package/dist/core/memory/loader.js +0 -141
- package/dist/core/memory/markdown/markdown-storage.d.ts +0 -72
- package/dist/core/memory/markdown/markdown-storage.js +0 -243
- package/dist/core/memory/memories.d.ts +0 -47
- package/dist/core/memory/memories.js +0 -449
- package/dist/core/memory/memory-lifecycle.d.ts +0 -8
- package/dist/core/memory/memory-lifecycle.js +0 -55
- package/dist/core/memory/memory-manager.d.ts +0 -15
- package/dist/core/memory/memory-manager.js +0 -46
- package/dist/core/memory/migrate.d.ts +0 -21
- package/dist/core/memory/migrate.js +0 -134
- package/dist/core/memory/normalization.d.ts +0 -22
- package/dist/core/memory/normalization.js +0 -26
- package/dist/core/memory/progressive-disclosure.d.ts +0 -43
- package/dist/core/memory/progressive-disclosure.js +0 -280
- package/dist/core/memory/query-processor.d.ts +0 -21
- package/dist/core/memory/query-processor.js +0 -72
- package/dist/core/memory/query-rewriter.d.ts +0 -13
- package/dist/core/memory/query-rewriter.js +0 -118
- package/dist/core/memory/response-analyzer.d.ts +0 -9
- package/dist/core/memory/response-analyzer.js +0 -61
- package/dist/core/memory/serialization.d.ts +0 -10
- package/dist/core/memory/serialization.js +0 -84
- package/dist/core/memory/stats.d.ts +0 -22
- package/dist/core/memory/stats.js +0 -138
- package/dist/core/memory/telemetry.d.ts +0 -69
- package/dist/core/memory/telemetry.js +0 -313
- package/dist/core/memory/temporal-facts.d.ts +0 -41
- package/dist/core/memory/temporal-facts.js +0 -283
- package/dist/core/memory/temporal-parser.d.ts +0 -32
- package/dist/core/memory/temporal-parser.js +0 -385
- package/dist/core/memory/trigger-detector.d.ts +0 -14
- package/dist/core/memory/trigger-detector.js +0 -42
- package/dist/core/memory/write-gate.d.ts +0 -54
- package/dist/core/memory/write-gate.js +0 -210
- package/dist/core/namespaces/index.d.ts +0 -71
- package/dist/core/namespaces/index.js +0 -305
- package/dist/core/namespaces/uri-parser.d.ts +0 -31
- package/dist/core/namespaces/uri-parser.js +0 -74
- package/dist/core/obsidian-vault.d.ts +0 -30
- package/dist/core/obsidian-vault.js +0 -94
- package/dist/core/places/index.d.ts +0 -14
- package/dist/core/places/memory-places.d.ts +0 -68
- package/dist/core/places/memory-places.js +0 -261
- package/dist/core/places/places.d.ts +0 -88
- package/dist/core/places/places.js +0 -314
- package/dist/core/places/rules.d.ts +0 -74
- package/dist/core/places/rules.js +0 -240
- package/dist/core/places/walking.d.ts +0 -56
- package/dist/core/places/walking.js +0 -121
- package/dist/core/projects.d.ts +0 -17
- package/dist/core/projects.js +0 -108
- package/dist/core/redis.d.ts +0 -11
- package/dist/core/redis.js +0 -69
- package/dist/core/responses.d.ts +0 -96
- package/dist/core/responses.js +0 -122
- package/dist/core/scheduler/cron-scheduler.d.ts +0 -32
- package/dist/core/scheduler/cron-scheduler.js +0 -332
- package/dist/core/scheduler/heartbeat.d.ts +0 -11
- package/dist/core/scheduler/heartbeat.js +0 -73
- package/dist/core/scheduler/index.d.ts +0 -8
- package/dist/core/scheduler/job-runner.d.ts +0 -11
- package/dist/core/scheduler/job-runner.js +0 -164
- package/dist/core/search/conversations.d.ts +0 -25
- package/dist/core/search/conversations.js +0 -110
- package/dist/core/search/entities.d.ts +0 -12
- package/dist/core/search/entities.js +0 -31
- package/dist/core/search/folder-context.d.ts +0 -25
- package/dist/core/search/folder-context.js +0 -119
- package/dist/core/search/graph-boost.d.ts +0 -7
- package/dist/core/search/graph-boost.js +0 -23
- package/dist/core/search/index.d.ts +0 -4
- package/dist/core/search/qmd-search.d.ts +0 -61
- package/dist/core/search/qmd-search.js +0 -178
- package/dist/core/security/encrypt.d.ts +0 -6
- package/dist/core/security/encrypt.js +0 -47
- package/dist/core/security/governance.d.ts +0 -26
- package/dist/core/security/governance.js +0 -79
- package/dist/core/security/privacy.d.ts +0 -23
- package/dist/core/security/privacy.js +0 -82
- package/dist/core/security/secret-detector.d.ts +0 -32
- package/dist/core/security/secret-detector.js +0 -88
- package/dist/core/session/auto-load.d.ts +0 -6
- package/dist/core/session/auto-load.js +0 -119
- package/dist/core/session/index.d.ts +0 -7
- package/dist/core/session/self-iteration-job.d.ts +0 -20
- package/dist/core/session/self-iteration-job.js +0 -282
- package/dist/core/session/session-hooks.d.ts +0 -18
- package/dist/core/session/session-hooks.js +0 -58
- package/dist/core/session/types.d.ts +0 -26
- package/dist/core/session/types.js +0 -10
- package/dist/core/session-hooks/self-iteration-job.d.ts +0 -20
- package/dist/core/session-hooks/self-iteration-job.js +0 -282
- package/dist/core/session-hooks/session-hooks.d.ts +0 -18
- package/dist/core/session-hooks/session-hooks.js +0 -58
- package/dist/core/snapshots/cleanup.d.ts +0 -9
- package/dist/core/snapshots/comparison.d.ts +0 -19
- package/dist/core/snapshots/comparison.js +0 -43
- package/dist/core/snapshots/creation.d.ts +0 -19
- package/dist/core/snapshots/creation.js +0 -126
- package/dist/core/snapshots/retrieval.d.ts +0 -7
- package/dist/core/snapshots/retrieval.js +0 -41
- package/dist/core/snapshots/stats.d.ts +0 -11
- package/dist/core/snapshots/stats.js +0 -52
- package/dist/core/snapshots.d.ts +0 -29
- package/dist/core/snapshots.js +0 -220
- package/dist/core/storage/cache.d.ts +0 -13
- package/dist/core/storage/cache.js +0 -202
- package/dist/core/storage/database.d.ts +0 -12
- package/dist/core/storage/database.js +0 -12
- package/dist/core/summarization/cleanup.d.ts +0 -9
- package/dist/core/summarization/queries.d.ts +0 -9
- package/dist/core/summarization/queries.js +0 -28
- package/dist/core/summarization/stats.d.ts +0 -14
- package/dist/core/summarization/stats.js +0 -52
- package/dist/core/summarization/strategies.d.ts +0 -24
- package/dist/core/summarization/strategies.js +0 -28
- package/dist/core/summarization.d.ts +0 -37
- package/dist/core/summarization.js +0 -188
- package/dist/core/sync/qmd-sync.d.ts +0 -94
- package/dist/core/sync/qmd-sync.js +0 -201
- package/dist/core/temporal-facts.d.ts +0 -54
- package/dist/core/temporal-facts.js +0 -193
- package/dist/core/toon.d.ts +0 -43
- package/dist/core/toon.js +0 -160
- package/dist/core/tracing/collector.d.ts +0 -111
- package/dist/core/tracing/collector.js +0 -350
- package/dist/core/tracing/visualizer.d.ts +0 -32
- package/dist/core/tracing/visualizer.js +0 -165
- package/dist/core/utils/cleanup-operations.d.ts +0 -13
- package/dist/core/utils/cleanup-operations.js +0 -44
- package/dist/core/utils/content-extraction.d.ts +0 -19
- package/dist/core/utils/content-extraction.js +0 -75
- package/dist/core/utils/filter-builder.d.ts +0 -13
- package/dist/core/utils/filter-builder.js +0 -44
- package/dist/core/utils/history-traversal.d.ts +0 -13
- package/dist/core/utils/history-traversal.js +0 -50
- package/dist/core/utils/memory-operations.d.ts +0 -17
- package/dist/core/utils/memory-operations.js +0 -43
- package/dist/core/utils/query-operations.d.ts +0 -18
- package/dist/core/utils/query-operations.js +0 -65
- package/dist/core/utils/summarization-helpers.d.ts +0 -21
- package/dist/core/utils/summarization-helpers.js +0 -38
- package/dist/core/utils/temporal-queries.d.ts +0 -13
- package/dist/core/utils/temporal-queries.js +0 -27
- package/dist/core/utils/vector-operations.d.ts +0 -71
- package/dist/core/utils/version-management.d.ts +0 -9
- package/dist/core/utils/version-management.js +0 -61
- package/dist/core/worker.d.ts +0 -82
- package/dist/core/worker.js +0 -272
- package/dist/db/adapter.d.ts +0 -7
- package/dist/db/adapter.js +0 -175
- package/dist/db/bootstrap.d.ts +0 -9
- package/dist/db/drizzle/schema-sqlite.d.ts +0 -4837
- package/dist/db/drizzle/schema-sqlite.js +0 -684
- package/dist/db/drizzle/schema.d.ts +0 -4082
- package/dist/db/drizzle/schema.js +0 -770
- package/dist/db/drizzle.config.d.ts +0 -3
- package/dist/db/drizzle.config.js +0 -12
- package/dist/db/index.d.ts +0 -7
- package/dist/db/index.js +0 -89
- package/dist/db/neon.d.ts +0 -8
- package/dist/db/neon.js +0 -20
- package/dist/db/schema/index.d.ts +0 -40
- package/dist/db/schema/index.js +0 -105
- package/dist/db/schema/tables/context-sessions.d.ts +0 -9
- package/dist/db/schema/tables/context-sessions.js +0 -37
- package/dist/db/schema/tables/conversations.d.ts +0 -9
- package/dist/db/schema/tables/conversations.js +0 -47
- package/dist/db/schema/tables/core-memory.d.ts +0 -9
- package/dist/db/schema/tables/core-memory.js +0 -41
- package/dist/db/schema/tables/entities.d.ts +0 -9
- package/dist/db/schema/tables/entities.js +0 -39
- package/dist/db/schema/tables/entity-relations.d.ts +0 -9
- package/dist/db/schema/tables/entity-relations.js +0 -31
- package/dist/db/schema/tables/learnings.d.ts +0 -9
- package/dist/db/schema/tables/learnings.js +0 -66
- package/dist/db/schema/tables/memories.d.ts +0 -9
- package/dist/db/schema/tables/memories.js +0 -161
- package/dist/db/schema/tables/memory-associations.d.ts +0 -9
- package/dist/db/schema/tables/memory-associations.js +0 -39
- package/dist/db/schema/tables/memory-hash-cache.d.ts +0 -9
- package/dist/db/schema/tables/memory-hash-cache.js +0 -29
- package/dist/db/schema/tables/memory-merge-history.d.ts +0 -9
- package/dist/db/schema/tables/memory-merge-history.js +0 -33
- package/dist/db/schema/tables/memory-merge-proposals.d.ts +0 -9
- package/dist/db/schema/tables/memory-merge-proposals.js +0 -39
- package/dist/db/schema/tables/messages.d.ts +0 -9
- package/dist/db/schema/tables/messages.js +0 -41
- package/dist/db/schema/tables/namespaces.d.ts +0 -9
- package/dist/db/schema/tables/namespaces.js +0 -37
- package/dist/db/schema/tables/projects.d.ts +0 -9
- package/dist/db/schema/tables/projects.js +0 -31
- package/dist/db/schema/tables/users.d.ts +0 -9
- package/dist/db/schema/tables/users.js +0 -27
- package/dist/db/schema.d.ts +0 -3
- package/dist/db/schema.js +0 -11
- package/dist/db/supabase.d.ts +0 -9
- package/dist/db/supabase.js +0 -24
- package/dist/index.d.ts +0 -7
- package/dist/index.js +0 -1677
- package/dist/vendor/sql.js/sql-wasm.wasm +0 -0
- package/dist/webui/server.d.ts +0 -5
- package/dist/webui/server.js +0 -642
- package/generated/mcp/manifest.json +0 -23
- package/generated/mcp/mcp-servers.json +0 -25
- package/generated/mcp/mcporter.json +0 -34
- package/generated/mcp/openclaw-memory-qmd.json +0 -17
- package/generated/mcp/runtime.json +0 -12
- package/scripts/README.md +0 -60
- package/scripts/build-release.sh +0 -36
- package/scripts/check-secrets.js +0 -132
- package/scripts/copy-runtime-assets.mjs +0 -26
- package/scripts/generate-mcp.mjs +0 -264
- package/scripts/github-release.sh +0 -77
- package/scripts/init-dirs.mjs +0 -13
- package/scripts/install-claude-code.sh +0 -85
- package/scripts/install-cursor.sh +0 -56
- package/scripts/install-hooks.sh +0 -73
- package/scripts/install-interactive.mjs +0 -357
- package/scripts/install-opencode.sh +0 -75
- package/scripts/install-plugin.mjs +0 -415
- package/scripts/install-windsurf.sh +0 -67
- package/scripts/remote-preflight.mjs +0 -62
- package/scripts/squish-fallback.mjs +0 -132
- package/scripts/test-interactive.mjs +0 -131
- package/scripts/verify-mcp.mjs +0 -214
- package/skills/squish-memory/scripts/install.mjs +0 -335
- package/skills/squish-memory/write_skill.js +0 -2
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Reverses/undoes a completed merge and restores original memories.
|
|
3
|
-
*/
|
|
4
|
-
import { getDb } from '../../../db/index.js';
|
|
5
|
-
import { getSchema } from '../../../db/schema.js';
|
|
6
|
-
import { createDatabaseClient } from '../../../core/storage/database.js';
|
|
7
|
-
import { eq } from 'drizzle-orm';
|
|
8
|
-
export async function handleReverseMerge(input) {
|
|
9
|
-
try {
|
|
10
|
-
const { mergeHistoryId, reason } = input;
|
|
11
|
-
if (!mergeHistoryId) {
|
|
12
|
-
return {
|
|
13
|
-
ok: false,
|
|
14
|
-
message: 'mergeHistoryId is required',
|
|
15
|
-
error: 'mergeHistoryId is required',
|
|
16
|
-
};
|
|
17
|
-
}
|
|
18
|
-
const db = createDatabaseClient(await getDb());
|
|
19
|
-
const schema = await getSchema();
|
|
20
|
-
// Step 1: Load merge history record
|
|
21
|
-
const [history] = await db
|
|
22
|
-
.select()
|
|
23
|
-
.from(schema.memoryMergeHistory)
|
|
24
|
-
.where(eq(schema.memoryMergeHistory.id, mergeHistoryId));
|
|
25
|
-
if (!history) {
|
|
26
|
-
return {
|
|
27
|
-
ok: false,
|
|
28
|
-
message: 'Merge history record not found',
|
|
29
|
-
error: `Merge history ${mergeHistoryId} not found`,
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
// Check if already reversed
|
|
33
|
-
if (history.isReversed) {
|
|
34
|
-
return {
|
|
35
|
-
ok: false,
|
|
36
|
-
message: 'Merge already reversed',
|
|
37
|
-
error: 'This merge has already been reversed',
|
|
38
|
-
};
|
|
39
|
-
}
|
|
40
|
-
// Step 2: Load and mark canonical memory as inactive
|
|
41
|
-
const [canonicalMemory] = await db
|
|
42
|
-
.select()
|
|
43
|
-
.from(schema.memories)
|
|
44
|
-
.where(eq(schema.memories.id, history.canonicalMemoryId));
|
|
45
|
-
if (!canonicalMemory) {
|
|
46
|
-
return {
|
|
47
|
-
ok: false,
|
|
48
|
-
message: 'Canonical memory not found',
|
|
49
|
-
error: `Canonical memory ${history.canonicalMemoryId} not found`,
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
const now = new Date();
|
|
53
|
-
// Step 3: Restore source memories from snapshot
|
|
54
|
-
const sourceSnapshot = history.sourceMemoriesSnapshot || [];
|
|
55
|
-
const sourceMemoryIds = history.sourceMemoryIds || [];
|
|
56
|
-
if (sourceSnapshot.length === 0) {
|
|
57
|
-
return {
|
|
58
|
-
ok: false,
|
|
59
|
-
message: 'No snapshot data to restore from',
|
|
60
|
-
error: 'Merge history has no source memories snapshot',
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
// Restore each memory from snapshot
|
|
64
|
-
for (const snapshotData of sourceSnapshot) {
|
|
65
|
-
const memoryId = snapshotData.id;
|
|
66
|
-
// Load current state of the memory (should be marked as merged)
|
|
67
|
-
const [currentMemory] = await db
|
|
68
|
-
.select()
|
|
69
|
-
.from(schema.memories)
|
|
70
|
-
.where(eq(schema.memories.id, memoryId));
|
|
71
|
-
if (currentMemory) {
|
|
72
|
-
// Restore to original state
|
|
73
|
-
await db
|
|
74
|
-
.update(schema.memories)
|
|
75
|
-
.set({
|
|
76
|
-
isMerged: false,
|
|
77
|
-
mergedIntoId: null,
|
|
78
|
-
mergedAt: null,
|
|
79
|
-
isActive: true,
|
|
80
|
-
updatedAt: now,
|
|
81
|
-
})
|
|
82
|
-
.where(eq(schema.memories.id, memoryId));
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
// Step 4: Deactivate canonical memory
|
|
86
|
-
await db
|
|
87
|
-
.update(schema.memories)
|
|
88
|
-
.set({
|
|
89
|
-
isActive: false,
|
|
90
|
-
updatedAt: now,
|
|
91
|
-
})
|
|
92
|
-
.where(eq(schema.memories.id, history.canonicalMemoryId));
|
|
93
|
-
// Step 5: Update merge history record
|
|
94
|
-
await db
|
|
95
|
-
.update(schema.memoryMergeHistory)
|
|
96
|
-
.set({
|
|
97
|
-
isReversed: true,
|
|
98
|
-
reversedAt: now,
|
|
99
|
-
reversedBy: canonicalMemory.userId,
|
|
100
|
-
})
|
|
101
|
-
.where(eq(schema.memoryMergeHistory.id, mergeHistoryId));
|
|
102
|
-
return {
|
|
103
|
-
ok: true,
|
|
104
|
-
message: `Merge reversed successfully. Restored ${sourceMemoryIds.length} memories`,
|
|
105
|
-
data: {
|
|
106
|
-
mergeHistoryId,
|
|
107
|
-
canonicalMemoryId: history.canonicalMemoryId,
|
|
108
|
-
restoredMemoryIds: sourceMemoryIds,
|
|
109
|
-
reversedAt: now.toISOString(),
|
|
110
|
-
},
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
catch (error) {
|
|
114
|
-
return {
|
|
115
|
-
ok: false,
|
|
116
|
-
message: 'Failed to reverse merge',
|
|
117
|
-
error: error instanceof Error ? error.message : 'Unknown error',
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
//# sourceMappingURL=reverse-merge.js.map
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Memory Merging Feature - Barrel Exports
|
|
3
|
-
*
|
|
4
|
-
* Provides a clean public API for memory merging functionality
|
|
5
|
-
*/
|
|
6
|
-
export * from './types.js';
|
|
7
|
-
export { detectDuplicates, analyzeMergePair, getDetectionStats } from './detection/two-stage-detector.js';
|
|
8
|
-
export { SimHashFilter, MinHashFilter, findCandidatePairs } from './detection/hash-filters.js';
|
|
9
|
-
export { rankCandidates, analyzePair } from './detection/semantic-ranker.js';
|
|
10
|
-
export { getMergeStrategy, mergeMemories, MERGE_STRATEGIES } from './strategies/merge-strategies.js';
|
|
11
|
-
export type { MergeStrategy, MergedMemory } from './strategies/merge-strategies.js';
|
|
12
|
-
export { runSafetyChecks, checkBlockers, formatSafetyResults, describeSafetyChecks } from './safety/safety-checks.js';
|
|
13
|
-
export { estimateTokensSaved, calculateProjectTokenSavings, estimateMergeSavingsPreview, getTokenStatistics, formatTokenCount, formatSavingsReport, } from './analytics/token-estimator.js';
|
|
14
|
-
export { handleDetectDuplicates } from './handlers/detect-duplicates.js';
|
|
15
|
-
export { handleListProposals } from './handlers/list-proposals.js';
|
|
16
|
-
export { handlePreviewMerge } from './handlers/preview-merge.js';
|
|
17
|
-
export { handleApproveMerge } from './handlers/approve-merge.js';
|
|
18
|
-
export { handleRejectMerge } from './handlers/reject-merge.js';
|
|
19
|
-
export { handleReverseMerge } from './handlers/reverse-merge.js';
|
|
20
|
-
export { handleGetMergeStats } from './handlers/get-stats.js';
|
|
21
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Hash cache maintenance - SimHash/MinHash signatures for duplicate detection
|
|
3
|
-
*/
|
|
4
|
-
export declare function updateCache(memoryId: string): Promise<boolean>;
|
|
5
|
-
export declare function rebuildCache(projectId: string): Promise<{
|
|
6
|
-
processed: number;
|
|
7
|
-
succeeded: number;
|
|
8
|
-
failed: number;
|
|
9
|
-
}>;
|
|
10
|
-
export declare function isStale(memoryId: string): Promise<boolean>;
|
|
11
|
-
export declare function cleanupOrphaned(projectId: string): Promise<number>;
|
|
12
|
-
//# sourceMappingURL=cache-maintenance.d.ts.map
|
|
@@ -1,157 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Hash cache maintenance - SimHash/MinHash signatures for duplicate detection
|
|
3
|
-
*/
|
|
4
|
-
import { getDb } from '../../../db/index.js';
|
|
5
|
-
import { getSchema } from '../../../db/schema.js';
|
|
6
|
-
import { createDatabaseClient } from '../../../core/storage/database.js';
|
|
7
|
-
import { eq } from 'drizzle-orm';
|
|
8
|
-
import { SimHashFilter, MinHashFilter } from '../detection/hash-filters.js';
|
|
9
|
-
import crypto from 'crypto';
|
|
10
|
-
import { logger } from '../../../core/logger.js';
|
|
11
|
-
function hashContent(content) {
|
|
12
|
-
return crypto.createHash('md5').update(content).digest('hex');
|
|
13
|
-
}
|
|
14
|
-
export async function updateCache(memoryId) {
|
|
15
|
-
try {
|
|
16
|
-
const db = createDatabaseClient(await getDb());
|
|
17
|
-
const schema = await getSchema();
|
|
18
|
-
// Load the memory
|
|
19
|
-
const [memory] = await db
|
|
20
|
-
.select()
|
|
21
|
-
.from(schema.memories)
|
|
22
|
-
.where(eq(schema.memories.id, memoryId));
|
|
23
|
-
if (!memory) {
|
|
24
|
-
return false;
|
|
25
|
-
}
|
|
26
|
-
// Generate hashes
|
|
27
|
-
const simhashFilter = new SimHashFilter();
|
|
28
|
-
const minhashFilter = new MinHashFilter();
|
|
29
|
-
const simhash = simhashFilter.generateHash(memory.content);
|
|
30
|
-
const minhash = minhashFilter.generateSignature(memory.content);
|
|
31
|
-
const contentHash = hashContent(memory.content);
|
|
32
|
-
// Upsert cache entry
|
|
33
|
-
const now = new Date();
|
|
34
|
-
// Check if entry exists
|
|
35
|
-
const [existing] = await db
|
|
36
|
-
.select()
|
|
37
|
-
.from(schema.memoryHashCache)
|
|
38
|
-
.where(eq(schema.memoryHashCache.memoryId, memoryId));
|
|
39
|
-
if (existing) {
|
|
40
|
-
// Update existing
|
|
41
|
-
await db
|
|
42
|
-
.update(schema.memoryHashCache)
|
|
43
|
-
.set({
|
|
44
|
-
simhash,
|
|
45
|
-
minhash: minhash,
|
|
46
|
-
contentHash,
|
|
47
|
-
lastUpdated: now,
|
|
48
|
-
})
|
|
49
|
-
.where(eq(schema.memoryHashCache.memoryId, memoryId));
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
// Create new
|
|
53
|
-
await db.insert(schema.memoryHashCache).values({
|
|
54
|
-
memoryId,
|
|
55
|
-
projectId: memory.projectId,
|
|
56
|
-
simhash,
|
|
57
|
-
minhash: minhash,
|
|
58
|
-
contentHash,
|
|
59
|
-
lastUpdated: now,
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
return true;
|
|
63
|
-
}
|
|
64
|
-
catch (error) {
|
|
65
|
-
logger.error(`Failed to update hash cache for ${memoryId}`, error);
|
|
66
|
-
return false;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
export async function rebuildCache(projectId) {
|
|
70
|
-
try {
|
|
71
|
-
const db = createDatabaseClient(await getDb());
|
|
72
|
-
const schema = await getSchema();
|
|
73
|
-
// Get all memories in project
|
|
74
|
-
const memories = await db
|
|
75
|
-
.select()
|
|
76
|
-
.from(schema.memories)
|
|
77
|
-
.where(eq(schema.memories.projectId, projectId));
|
|
78
|
-
let succeeded = 0;
|
|
79
|
-
let failed = 0;
|
|
80
|
-
for (const memory of memories) {
|
|
81
|
-
const ok = await updateCache(memory.id);
|
|
82
|
-
if (ok) {
|
|
83
|
-
succeeded++;
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
failed++;
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
return {
|
|
90
|
-
processed: memories.length,
|
|
91
|
-
succeeded,
|
|
92
|
-
failed,
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
catch (error) {
|
|
96
|
-
logger.error(`Failed to rebuild hash cache for project ${projectId}`, error);
|
|
97
|
-
return { processed: 0, succeeded: 0, failed: 0 };
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
export async function isStale(memoryId) {
|
|
101
|
-
try {
|
|
102
|
-
const db = createDatabaseClient(await getDb());
|
|
103
|
-
const schema = await getSchema();
|
|
104
|
-
const [memory] = await db
|
|
105
|
-
.select()
|
|
106
|
-
.from(schema.memories)
|
|
107
|
-
.where(eq(schema.memories.id, memoryId));
|
|
108
|
-
if (!memory) {
|
|
109
|
-
return true;
|
|
110
|
-
}
|
|
111
|
-
const [cacheEntry] = await db
|
|
112
|
-
.select()
|
|
113
|
-
.from(schema.memoryHashCache)
|
|
114
|
-
.where(eq(schema.memoryHashCache.memoryId, memoryId));
|
|
115
|
-
if (!cacheEntry) {
|
|
116
|
-
return true; // No cache entry = stale
|
|
117
|
-
}
|
|
118
|
-
const currentContentHash = hashContent(memory.content);
|
|
119
|
-
return currentContentHash !== cacheEntry.contentHash;
|
|
120
|
-
}
|
|
121
|
-
catch (error) {
|
|
122
|
-
logger.error('Failed to check hash cache staleness', error);
|
|
123
|
-
return true; // Assume stale on error
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
export async function cleanupOrphaned(projectId) {
|
|
127
|
-
try {
|
|
128
|
-
const db = createDatabaseClient(await getDb());
|
|
129
|
-
const schema = await getSchema();
|
|
130
|
-
// Get all cache entries for project
|
|
131
|
-
const cacheEntries = await db
|
|
132
|
-
.select()
|
|
133
|
-
.from(schema.memoryHashCache)
|
|
134
|
-
.where(eq(schema.memoryHashCache.projectId, projectId));
|
|
135
|
-
let deleted = 0;
|
|
136
|
-
for (const entry of cacheEntries) {
|
|
137
|
-
// Check if memory exists
|
|
138
|
-
const [memory] = await db
|
|
139
|
-
.select()
|
|
140
|
-
.from(schema.memories)
|
|
141
|
-
.where(eq(schema.memories.id, entry.memoryId));
|
|
142
|
-
if (!memory) {
|
|
143
|
-
// Memory doesn't exist, delete cache entry
|
|
144
|
-
await db
|
|
145
|
-
.delete(schema.memoryHashCache)
|
|
146
|
-
.where(eq(schema.memoryHashCache.memoryId, entry.memoryId));
|
|
147
|
-
deleted++;
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
return deleted;
|
|
151
|
-
}
|
|
152
|
-
catch (error) {
|
|
153
|
-
logger.error('Failed to cleanup orphaned hash cache', error);
|
|
154
|
-
return 0;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
//# sourceMappingURL=cache-maintenance.js.map
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Safety checks to prevent bad merges.
|
|
3
|
-
* Checks run before creating merge proposals and are categorized as BLOCKER or WARNING.
|
|
4
|
-
*/
|
|
5
|
-
import type { Memory } from '../../../db/drizzle/schema.js';
|
|
6
|
-
export interface SafetyCheckResult {
|
|
7
|
-
passed: boolean;
|
|
8
|
-
warnings: string[];
|
|
9
|
-
blockers: string[];
|
|
10
|
-
}
|
|
11
|
-
export interface SafetyCheck {
|
|
12
|
-
name: string;
|
|
13
|
-
description: string;
|
|
14
|
-
type: 'blocker' | 'warning';
|
|
15
|
-
check(memories: Memory[], metadata?: Record<string, unknown>): SafetyCheckResult;
|
|
16
|
-
}
|
|
17
|
-
export declare const SAFETY_CHECKS: SafetyCheck[];
|
|
18
|
-
export declare function runSafetyChecks(memories: Memory[], metadata?: Record<string, unknown>): SafetyCheckResult;
|
|
19
|
-
export declare function checkBlockers(memories: Memory[]): boolean;
|
|
20
|
-
export declare function formatSafetyResults(result: SafetyCheckResult): string;
|
|
21
|
-
export declare function describeSafetyChecks(): string;
|
|
22
|
-
//# sourceMappingURL=safety-checks.d.ts.map
|
|
@@ -1,179 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Safety checks to prevent bad merges.
|
|
3
|
-
* Checks run before creating merge proposals and are categorized as BLOCKER or WARNING.
|
|
4
|
-
*/
|
|
5
|
-
const PASSED_RESULT = { passed: true, warnings: [], blockers: [] };
|
|
6
|
-
function createBlockerCheck(name, description, checkFn) {
|
|
7
|
-
return {
|
|
8
|
-
name,
|
|
9
|
-
description,
|
|
10
|
-
type: 'blocker',
|
|
11
|
-
check: (memories, metadata) => {
|
|
12
|
-
const result = checkFn(memories, metadata);
|
|
13
|
-
return result.passed ? PASSED_RESULT : { passed: false, warnings: [], blockers: result.blockers };
|
|
14
|
-
},
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
function createWarningCheck(name, description, checkFn) {
|
|
18
|
-
return {
|
|
19
|
-
name,
|
|
20
|
-
description,
|
|
21
|
-
type: 'warning',
|
|
22
|
-
check: (memories, metadata) => {
|
|
23
|
-
const result = checkFn(memories, metadata);
|
|
24
|
-
return { passed: true, warnings: result.warnings, blockers: [] };
|
|
25
|
-
},
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
export const SAFETY_CHECKS = [
|
|
29
|
-
createBlockerCheck('immutability', 'Prevent merging immutable memories', (memories) => {
|
|
30
|
-
const immutableMemories = memories.filter((m) => !m.isMergeable);
|
|
31
|
-
if (immutableMemories.length === 0) {
|
|
32
|
-
return { passed: true, blockers: [] };
|
|
33
|
-
}
|
|
34
|
-
return {
|
|
35
|
-
passed: false,
|
|
36
|
-
blockers: [
|
|
37
|
-
`Cannot merge: ${immutableMemories.length} memory(ies) marked as immutable`,
|
|
38
|
-
`IDs: ${immutableMemories.map((m) => m.id).join(', ')}`,
|
|
39
|
-
],
|
|
40
|
-
};
|
|
41
|
-
}),
|
|
42
|
-
createBlockerCheck('type_consistency', 'Ensure all memories are same type', (memories) => {
|
|
43
|
-
const types = new Set(memories.map((m) => m.type));
|
|
44
|
-
if (types.size <= 1) {
|
|
45
|
-
return { passed: true, blockers: [] };
|
|
46
|
-
}
|
|
47
|
-
return {
|
|
48
|
-
passed: false,
|
|
49
|
-
blockers: [
|
|
50
|
-
`Cannot merge different types: ${Array.from(types).join(', ')}`,
|
|
51
|
-
'All memories must be same type (fact, preference, decision, etc.)',
|
|
52
|
-
],
|
|
53
|
-
};
|
|
54
|
-
}),
|
|
55
|
-
createBlockerCheck('already_merged', 'Prevent re-merging of previously merged memories', (memories) => {
|
|
56
|
-
const alreadyMerged = memories.filter((m) => m.isMerged);
|
|
57
|
-
if (alreadyMerged.length === 0) {
|
|
58
|
-
return { passed: true, blockers: [] };
|
|
59
|
-
}
|
|
60
|
-
return {
|
|
61
|
-
passed: false,
|
|
62
|
-
blockers: [
|
|
63
|
-
`Cannot merge: ${alreadyMerged.length} memory(ies) already merged`,
|
|
64
|
-
'Already-merged memories should not be re-merged. Undo previous merge first.',
|
|
65
|
-
],
|
|
66
|
-
};
|
|
67
|
-
}),
|
|
68
|
-
createBlockerCheck('min_similarity', 'Ensure similarity is above minimum threshold', (memories, metadata) => {
|
|
69
|
-
const minThreshold = 0.70;
|
|
70
|
-
if (!metadata || !('similarityScore' in metadata)) {
|
|
71
|
-
return { passed: true, blockers: [] };
|
|
72
|
-
}
|
|
73
|
-
const similarity = metadata.similarityScore;
|
|
74
|
-
if (similarity >= minThreshold) {
|
|
75
|
-
return { passed: true, blockers: [] };
|
|
76
|
-
}
|
|
77
|
-
return {
|
|
78
|
-
passed: false,
|
|
79
|
-
blockers: [
|
|
80
|
-
`Similarity too low: ${(similarity * 100).toFixed(1)}%`,
|
|
81
|
-
`Minimum required: ${(minThreshold * 100).toFixed(0)}%`,
|
|
82
|
-
'Increase similarity threshold or select more similar memories',
|
|
83
|
-
],
|
|
84
|
-
};
|
|
85
|
-
}),
|
|
86
|
-
createWarningCheck('multi_user', 'Warn about merging memories from different users', (memories) => {
|
|
87
|
-
const users = new Set(memories.map((m) => m.userId).filter(Boolean));
|
|
88
|
-
if (users.size <= 1) {
|
|
89
|
-
return { warnings: [] };
|
|
90
|
-
}
|
|
91
|
-
return {
|
|
92
|
-
warnings: [
|
|
93
|
-
`Merging memories from ${users.size} different users`,
|
|
94
|
-
'This is usually not recommended. Ensure you want to consolidate user-specific memories.',
|
|
95
|
-
],
|
|
96
|
-
};
|
|
97
|
-
}),
|
|
98
|
-
createWarningCheck('privacy', 'Warn about mixing private and non-private memories', (memories) => {
|
|
99
|
-
const privacyStates = new Set(memories.map((m) => m.isPrivate));
|
|
100
|
-
if (privacyStates.size <= 1) {
|
|
101
|
-
return { warnings: [] };
|
|
102
|
-
}
|
|
103
|
-
return {
|
|
104
|
-
warnings: [
|
|
105
|
-
'Merging private and non-private memories',
|
|
106
|
-
'The merged result will inherit the privacy setting of the canonical memory',
|
|
107
|
-
],
|
|
108
|
-
};
|
|
109
|
-
}),
|
|
110
|
-
createWarningCheck('secrets', 'Warn about merging memories with detected secrets', (memories) => {
|
|
111
|
-
const withSecrets = memories.filter((m) => m.hasSecrets);
|
|
112
|
-
if (withSecrets.length === 0) {
|
|
113
|
-
return { warnings: [] };
|
|
114
|
-
}
|
|
115
|
-
return {
|
|
116
|
-
warnings: [
|
|
117
|
-
`${withSecrets.length} memory(ies) contain detected secrets`,
|
|
118
|
-
'Ensure merged content does not expose sensitive information',
|
|
119
|
-
'Consider redacting secrets before merging',
|
|
120
|
-
],
|
|
121
|
-
};
|
|
122
|
-
}),
|
|
123
|
-
createBlockerCheck('active_status', 'Ensure all memories are active', (memories) => {
|
|
124
|
-
const inactive = memories.filter((m) => !m.isActive);
|
|
125
|
-
if (inactive.length === 0) {
|
|
126
|
-
return { passed: true, blockers: [] };
|
|
127
|
-
}
|
|
128
|
-
return {
|
|
129
|
-
passed: false,
|
|
130
|
-
blockers: [
|
|
131
|
-
`Cannot merge: ${inactive.length} memory(ies) are inactive (archived/expired)`,
|
|
132
|
-
'Only active memories can be merged',
|
|
133
|
-
],
|
|
134
|
-
};
|
|
135
|
-
}),
|
|
136
|
-
];
|
|
137
|
-
export function runSafetyChecks(memories, metadata) {
|
|
138
|
-
const results = SAFETY_CHECKS.map((check) => check.check(memories, metadata));
|
|
139
|
-
const allBlockers = results.flatMap((r) => r.blockers);
|
|
140
|
-
const allWarnings = results.flatMap((r) => r.warnings);
|
|
141
|
-
return {
|
|
142
|
-
passed: allBlockers.length === 0,
|
|
143
|
-
warnings: allWarnings,
|
|
144
|
-
blockers: allBlockers,
|
|
145
|
-
};
|
|
146
|
-
}
|
|
147
|
-
export function checkBlockers(memories) {
|
|
148
|
-
const blockerChecks = SAFETY_CHECKS.filter((c) => c.type === 'blocker');
|
|
149
|
-
for (const check of blockerChecks) {
|
|
150
|
-
const result = check.check(memories);
|
|
151
|
-
if (!result.passed) {
|
|
152
|
-
return false;
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
return true;
|
|
156
|
-
}
|
|
157
|
-
export function formatSafetyResults(result) {
|
|
158
|
-
if (result.passed && result.warnings.length === 0) {
|
|
159
|
-
return 'All safety checks passed';
|
|
160
|
-
}
|
|
161
|
-
const lines = [];
|
|
162
|
-
if (!result.passed && result.blockers.length > 0) {
|
|
163
|
-
lines.push('BLOCKERS (merge prevented):');
|
|
164
|
-
for (const blocker of result.blockers) {
|
|
165
|
-
lines.push(` ✗ ${blocker}`);
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
if (result.warnings.length > 0) {
|
|
169
|
-
lines.push('WARNINGS (merge allowed with caution):');
|
|
170
|
-
for (const warning of result.warnings) {
|
|
171
|
-
lines.push(` ⚠ ${warning}`);
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
return lines.join('\n');
|
|
175
|
-
}
|
|
176
|
-
export function describeSafetyChecks() {
|
|
177
|
-
return SAFETY_CHECKS.map((check) => `${check.name} [${check.type}]: ${check.description}`).join('\n');
|
|
178
|
-
}
|
|
179
|
-
//# sourceMappingURL=safety-checks.js.map
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Type-specific merge strategies for different memory types.
|
|
3
|
-
* Each type has different merge semantics to preserve meaning and prevent data loss.
|
|
4
|
-
*/
|
|
5
|
-
import type { Memory, MemoryType } from '../../../db/drizzle/schema.js';
|
|
6
|
-
export interface MergeStrategy {
|
|
7
|
-
type: MemoryType;
|
|
8
|
-
/**
|
|
9
|
-
* Merge a set of source memories into a single canonical memory
|
|
10
|
-
*/
|
|
11
|
-
merge(sources: Memory[]): MergedMemory;
|
|
12
|
-
/**
|
|
13
|
-
* Check if memories can be safely merged
|
|
14
|
-
* Returns { ok, reason } where reason explains why merging is not allowed
|
|
15
|
-
*/
|
|
16
|
-
canMerge(sources: Memory[]): {
|
|
17
|
-
ok: boolean;
|
|
18
|
-
reason?: string;
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
export interface MergedMemory {
|
|
22
|
-
content: string;
|
|
23
|
-
summary: string | null;
|
|
24
|
-
tags: string[];
|
|
25
|
-
metadata: Record<string, unknown>;
|
|
26
|
-
mergeReason: string;
|
|
27
|
-
conflictWarnings: string[];
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Base implementation of MergeStrategy with common functionality.
|
|
31
|
-
* Reduces code duplication across specific merge strategies.
|
|
32
|
-
*/
|
|
33
|
-
export declare abstract class BaseMergeStrategy implements MergeStrategy {
|
|
34
|
-
abstract type: MemoryType;
|
|
35
|
-
canMerge(sources: Memory[]): {
|
|
36
|
-
ok: boolean;
|
|
37
|
-
reason?: string;
|
|
38
|
-
};
|
|
39
|
-
protected validateSources(sources: Memory[]): boolean;
|
|
40
|
-
protected handleEmptySources(): MergedMemory;
|
|
41
|
-
protected mergeTags(sources: Memory[]): string[];
|
|
42
|
-
protected buildBaseMetadata(sources: Memory[], extra?: Record<string, unknown>): Record<string, unknown>;
|
|
43
|
-
protected sortByDate(sources: Memory[], order?: 'asc' | 'desc'): Memory[];
|
|
44
|
-
protected sortChronologically(sources: Memory[]): Memory[];
|
|
45
|
-
abstract merge(sources: Memory[]): MergedMemory;
|
|
46
|
-
}
|
|
47
|
-
export declare const MERGE_STRATEGIES: Record<MemoryType, MergeStrategy>;
|
|
48
|
-
export declare function getMergeStrategy(type: MemoryType): MergeStrategy;
|
|
49
|
-
export declare function mergeMemories(sources: Memory[]): MergedMemory;
|
|
50
|
-
//# sourceMappingURL=merge-strategies.d.ts.map
|