cognitive-core 0.2.0 → 0.2.2
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/.claude/settings.json +111 -2
- package/.sessionlog/settings.json +4 -0
- package/dist/atlas.d.ts +10 -0
- package/dist/atlas.d.ts.map +1 -1
- package/dist/atlas.js +65 -0
- package/dist/atlas.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -1
- package/dist/index.js.map +1 -1
- package/dist/learning/index.d.ts +1 -1
- package/dist/learning/index.d.ts.map +1 -1
- package/dist/learning/index.js.map +1 -1
- package/dist/learning/pipeline.d.ts +4 -31
- package/dist/learning/pipeline.d.ts.map +1 -1
- package/dist/learning/pipeline.js +12 -64
- package/dist/learning/pipeline.js.map +1 -1
- package/dist/learning/unified-pipeline.d.ts +30 -0
- package/dist/learning/unified-pipeline.d.ts.map +1 -1
- package/dist/learning/unified-pipeline.js +207 -0
- package/dist/learning/unified-pipeline.js.map +1 -1
- package/dist/memory/candidate-retrieval.d.ts.map +1 -1
- package/dist/memory/candidate-retrieval.js +3 -1
- package/dist/memory/candidate-retrieval.js.map +1 -1
- package/dist/memory/curated-loader.d.ts +21 -4
- package/dist/memory/curated-loader.d.ts.map +1 -1
- package/dist/memory/curated-loader.js +53 -16
- package/dist/memory/curated-loader.js.map +1 -1
- package/dist/memory/index.d.ts +2 -1
- package/dist/memory/index.d.ts.map +1 -1
- package/dist/memory/index.js +3 -1
- package/dist/memory/index.js.map +1 -1
- package/dist/memory/playbook.d.ts +6 -0
- package/dist/memory/playbook.d.ts.map +1 -1
- package/dist/memory/playbook.js +15 -0
- package/dist/memory/playbook.js.map +1 -1
- package/dist/memory/source-resolver.d.ts +120 -0
- package/dist/memory/source-resolver.d.ts.map +1 -0
- package/dist/memory/source-resolver.js +300 -0
- package/dist/memory/source-resolver.js.map +1 -0
- package/dist/types/config.d.ts +141 -0
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.js +40 -0
- package/dist/types/config.js.map +1 -1
- package/dist/types/index.d.ts +1 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -1
- package/dist/types/index.js.map +1 -1
- package/dist/utils/error-classifier.js +8 -8
- package/dist/utils/error-classifier.js.map +1 -1
- package/dist/workspace/efficacy-toolkit.d.ts +164 -0
- package/dist/workspace/efficacy-toolkit.d.ts.map +1 -0
- package/dist/workspace/efficacy-toolkit.js +281 -0
- package/dist/workspace/efficacy-toolkit.js.map +1 -0
- package/dist/workspace/index.d.ts +2 -1
- package/dist/workspace/index.d.ts.map +1 -1
- package/dist/workspace/index.js +3 -1
- package/dist/workspace/index.js.map +1 -1
- package/dist/workspace/templates/index.d.ts +3 -0
- package/dist/workspace/templates/index.d.ts.map +1 -1
- package/dist/workspace/templates/index.js +6 -0
- package/dist/workspace/templates/index.js.map +1 -1
- package/dist/workspace/templates/playbook-decay-detection.d.ts +46 -0
- package/dist/workspace/templates/playbook-decay-detection.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-decay-detection.js +197 -0
- package/dist/workspace/templates/playbook-decay-detection.js.map +1 -0
- package/dist/workspace/templates/playbook-efficacy-audit.d.ts +46 -0
- package/dist/workspace/templates/playbook-efficacy-audit.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-efficacy-audit.js +160 -0
- package/dist/workspace/templates/playbook-efficacy-audit.js.map +1 -0
- package/dist/workspace/templates/playbook-lifecycle-review.d.ts +51 -0
- package/dist/workspace/templates/playbook-lifecycle-review.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-lifecycle-review.js +187 -0
- package/dist/workspace/templates/playbook-lifecycle-review.js.map +1 -0
- package/dist/workspace/types.d.ts +12 -54
- package/dist/workspace/types.d.ts.map +1 -1
- package/dist/workspace/types.js.map +1 -1
- package/package.json +8 -2
- package/playbooks/compound-engineering/adversarial-review.json +51 -0
- package/playbooks/compound-engineering/agent-native-architecture.json +59 -0
- package/playbooks/compound-engineering/agent-native-review.json +54 -0
- package/playbooks/compound-engineering/api-contract-review.json +52 -0
- package/playbooks/compound-engineering/brainstorm-requirements.json +55 -0
- package/playbooks/compound-engineering/bug-reproduction.json +62 -0
- package/playbooks/compound-engineering/confidence-calibration.json +49 -0
- package/playbooks/compound-engineering/correctness-review.json +49 -0
- package/playbooks/compound-engineering/data-migration-safety.json +59 -0
- package/playbooks/compound-engineering/deployment-verification.json +63 -0
- package/playbooks/compound-engineering/error-recovery-patterns.json +53 -0
- package/playbooks/compound-engineering/implementation-planning.json +64 -0
- package/playbooks/compound-engineering/issue-pattern-analysis.json +53 -0
- package/playbooks/compound-engineering/knowledge-compounding.json +63 -0
- package/playbooks/compound-engineering/learnings-research.json +54 -0
- package/playbooks/compound-engineering/maintainability-review.json +49 -0
- package/playbooks/compound-engineering/performance-review.json +54 -0
- package/playbooks/compound-engineering/plan-adversarial-review.json +56 -0
- package/playbooks/compound-engineering/plan-feasibility-review.json +56 -0
- package/playbooks/compound-engineering/project-standards-review.json +52 -0
- package/playbooks/compound-engineering/reliability-review.json +53 -0
- package/playbooks/compound-engineering/review-orchestration.json +64 -0
- package/playbooks/compound-engineering/security-review.json +54 -0
- package/playbooks/compound-engineering/systematic-execution.json +64 -0
- package/playbooks/compound-engineering/testing-review.json +50 -0
- package/src/atlas.ts +96 -0
- package/src/index.ts +27 -0
- package/src/learning/index.ts +1 -0
- package/src/learning/unified-pipeline.ts +271 -1
- package/src/memory/candidate-retrieval.ts +2 -1
- package/src/memory/curated-loader.ts +69 -16
- package/src/memory/index.ts +16 -0
- package/src/memory/playbook.ts +19 -0
- package/src/memory/source-resolver.ts +422 -0
- package/src/types/config.ts +46 -0
- package/src/types/index.ts +4 -0
- package/src/utils/error-classifier.ts +8 -8
- package/src/workspace/efficacy-toolkit.ts +496 -0
- package/src/workspace/index.ts +29 -0
- package/src/workspace/templates/index.ts +24 -0
- package/src/workspace/templates/playbook-decay-detection.ts +272 -0
- package/src/workspace/templates/playbook-efficacy-audit.ts +246 -0
- package/src/workspace/templates/playbook-lifecycle-review.ts +274 -0
- package/src/workspace/types.ts +22 -78
- package/tests/fixtures/behavioral-trajectories.ts +210 -0
- package/tests/integration/curated-sources-e2e.test.ts +502 -0
- package/tests/integration/pipeline-data-correctness.test.ts +794 -0
- package/tests/learning/meta-learner.test.ts +418 -0
- package/tests/learning/pipeline-memory-updates.test.ts +721 -0
- package/tests/learning/unified-pipeline-efficacy.test.ts +232 -0
- package/tests/memory/candidate-retrieval.test.ts +167 -0
- package/tests/memory/compound-engineering-seed.test.ts +338 -0
- package/tests/memory/curated-loader-extended.test.ts +225 -0
- package/tests/memory/meta.test.ts +399 -0
- package/tests/memory/playbook-quality-validation.test.ts +430 -0
- package/tests/memory/source-resolver.test.ts +700 -0
- package/tests/search/evaluator.test.ts +257 -0
- package/tests/search/verification-runner.test.ts +357 -0
- package/tests/utils/error-classifier.test.ts +149 -0
- package/tests/utils/trajectory-helpers.test.ts +163 -0
- package/tests/workspace/efficacy-toolkit.test.ts +404 -0
- package/tests/workspace/templates/playbook-efficacy.test.ts +377 -0
- package/.claude/settings.local.json +0 -11
- package/dist/learning/llm-extractor.d.ts +0 -88
- package/dist/learning/llm-extractor.d.ts.map +0 -1
- package/dist/learning/llm-extractor.js +0 -372
- package/dist/learning/llm-extractor.js.map +0 -1
- package/dist/learning/loop-coordinator.d.ts +0 -61
- package/dist/learning/loop-coordinator.d.ts.map +0 -1
- package/dist/learning/loop-coordinator.js +0 -96
- package/dist/learning/loop-coordinator.js.map +0 -1
- package/references/agent-workspace/CLAUDE.md +0 -74
- package/references/agent-workspace/README.md +0 -587
- package/references/agent-workspace/media/banner.png +0 -0
- package/references/agent-workspace/package-lock.json +0 -2061
- package/references/agent-workspace/package.json +0 -54
- package/references/agent-workspace/src/handle.ts +0 -122
- package/references/agent-workspace/src/index.ts +0 -32
- package/references/agent-workspace/src/manager.ts +0 -102
- package/references/agent-workspace/src/readers/json.ts +0 -71
- package/references/agent-workspace/src/readers/markdown.ts +0 -37
- package/references/agent-workspace/src/readers/raw.ts +0 -27
- package/references/agent-workspace/src/types.ts +0 -68
- package/references/agent-workspace/src/validation.ts +0 -93
- package/references/agent-workspace/src/writers/json.ts +0 -17
- package/references/agent-workspace/src/writers/markdown.ts +0 -27
- package/references/agent-workspace/src/writers/raw.ts +0 -22
- package/references/agent-workspace/tests/errors.test.ts +0 -652
- package/references/agent-workspace/tests/handle.test.ts +0 -144
- package/references/agent-workspace/tests/manager.test.ts +0 -124
- package/references/agent-workspace/tests/readers.test.ts +0 -205
- package/references/agent-workspace/tests/validation.test.ts +0 -196
- package/references/agent-workspace/tests/writers.test.ts +0 -108
- package/references/agent-workspace/tsconfig.json +0 -20
- package/references/agent-workspace/tsup.config.ts +0 -9
- package/references/minimem/.claude/settings.json +0 -7
- package/references/minimem/.sudocode/issues.jsonl +0 -18
- package/references/minimem/.sudocode/specs.jsonl +0 -1
- package/references/minimem/CLAUDE.md +0 -310
- package/references/minimem/README.md +0 -556
- package/references/minimem/claude-plugin/.claude-plugin/plugin.json +0 -10
- package/references/minimem/claude-plugin/.mcp.json +0 -7
- package/references/minimem/claude-plugin/README.md +0 -158
- package/references/minimem/claude-plugin/commands/recall.md +0 -47
- package/references/minimem/claude-plugin/commands/remember.md +0 -41
- package/references/minimem/claude-plugin/hooks/__tests__/hooks.test.ts +0 -272
- package/references/minimem/claude-plugin/hooks/hooks.json +0 -27
- package/references/minimem/claude-plugin/hooks/session-end.sh +0 -86
- package/references/minimem/claude-plugin/hooks/session-start.sh +0 -85
- package/references/minimem/claude-plugin/skills/memory/SKILL.md +0 -108
- package/references/minimem/package-lock.json +0 -5373
- package/references/minimem/package.json +0 -60
- package/references/minimem/scripts/postbuild.js +0 -35
- package/references/minimem/src/__tests__/edge-cases.test.ts +0 -371
- package/references/minimem/src/__tests__/errors.test.ts +0 -265
- package/references/minimem/src/__tests__/helpers.ts +0 -199
- package/references/minimem/src/__tests__/internal.test.ts +0 -407
- package/references/minimem/src/__tests__/knowledge.test.ts +0 -287
- package/references/minimem/src/__tests__/minimem.integration.test.ts +0 -1127
- package/references/minimem/src/__tests__/session.test.ts +0 -190
- package/references/minimem/src/cli/__tests__/commands.test.ts +0 -759
- package/references/minimem/src/cli/commands/__tests__/conflicts.test.ts +0 -141
- package/references/minimem/src/cli/commands/append.ts +0 -76
- package/references/minimem/src/cli/commands/config.ts +0 -262
- package/references/minimem/src/cli/commands/conflicts.ts +0 -413
- package/references/minimem/src/cli/commands/daemon.ts +0 -169
- package/references/minimem/src/cli/commands/index.ts +0 -12
- package/references/minimem/src/cli/commands/init.ts +0 -88
- package/references/minimem/src/cli/commands/mcp.ts +0 -177
- package/references/minimem/src/cli/commands/push-pull.ts +0 -213
- package/references/minimem/src/cli/commands/search.ts +0 -158
- package/references/minimem/src/cli/commands/status.ts +0 -84
- package/references/minimem/src/cli/commands/sync-init.ts +0 -290
- package/references/minimem/src/cli/commands/sync.ts +0 -70
- package/references/minimem/src/cli/commands/upsert.ts +0 -197
- package/references/minimem/src/cli/config.ts +0 -584
- package/references/minimem/src/cli/index.ts +0 -264
- package/references/minimem/src/cli/shared.ts +0 -161
- package/references/minimem/src/cli/sync/__tests__/central.test.ts +0 -152
- package/references/minimem/src/cli/sync/__tests__/conflicts.test.ts +0 -209
- package/references/minimem/src/cli/sync/__tests__/daemon.test.ts +0 -118
- package/references/minimem/src/cli/sync/__tests__/detection.test.ts +0 -207
- package/references/minimem/src/cli/sync/__tests__/integration.test.ts +0 -476
- package/references/minimem/src/cli/sync/__tests__/registry.test.ts +0 -363
- package/references/minimem/src/cli/sync/__tests__/state.test.ts +0 -255
- package/references/minimem/src/cli/sync/__tests__/validation.test.ts +0 -193
- package/references/minimem/src/cli/sync/__tests__/watcher.test.ts +0 -178
- package/references/minimem/src/cli/sync/central.ts +0 -292
- package/references/minimem/src/cli/sync/conflicts.ts +0 -204
- package/references/minimem/src/cli/sync/daemon.ts +0 -407
- package/references/minimem/src/cli/sync/detection.ts +0 -138
- package/references/minimem/src/cli/sync/index.ts +0 -107
- package/references/minimem/src/cli/sync/operations.ts +0 -373
- package/references/minimem/src/cli/sync/registry.ts +0 -279
- package/references/minimem/src/cli/sync/state.ts +0 -355
- package/references/minimem/src/cli/sync/validation.ts +0 -206
- package/references/minimem/src/cli/sync/watcher.ts +0 -234
- package/references/minimem/src/cli/version.ts +0 -34
- package/references/minimem/src/core/index.ts +0 -9
- package/references/minimem/src/core/indexer.ts +0 -628
- package/references/minimem/src/core/searcher.ts +0 -221
- package/references/minimem/src/db/schema.ts +0 -183
- package/references/minimem/src/db/sqlite-vec.ts +0 -24
- package/references/minimem/src/embeddings/__tests__/embeddings.test.ts +0 -431
- package/references/minimem/src/embeddings/batch-gemini.ts +0 -392
- package/references/minimem/src/embeddings/batch-openai.ts +0 -409
- package/references/minimem/src/embeddings/embeddings.ts +0 -434
- package/references/minimem/src/index.ts +0 -109
- package/references/minimem/src/internal.ts +0 -299
- package/references/minimem/src/minimem.ts +0 -1276
- package/references/minimem/src/search/__tests__/hybrid.test.ts +0 -247
- package/references/minimem/src/search/graph.ts +0 -234
- package/references/minimem/src/search/hybrid.ts +0 -151
- package/references/minimem/src/search/search.ts +0 -256
- package/references/minimem/src/server/__tests__/mcp.test.ts +0 -341
- package/references/minimem/src/server/__tests__/tools.test.ts +0 -364
- package/references/minimem/src/server/mcp.ts +0 -326
- package/references/minimem/src/server/tools.ts +0 -720
- package/references/minimem/src/session.ts +0 -460
- package/references/minimem/tsconfig.json +0 -19
- package/references/minimem/tsup.config.ts +0 -26
- package/references/minimem/vitest.config.ts +0 -24
- package/references/sessionlog/.husky/pre-commit +0 -1
- package/references/sessionlog/.lintstagedrc.json +0 -4
- package/references/sessionlog/.prettierignore +0 -4
- package/references/sessionlog/.prettierrc.json +0 -11
- package/references/sessionlog/LICENSE +0 -21
- package/references/sessionlog/README.md +0 -453
- package/references/sessionlog/eslint.config.js +0 -58
- package/references/sessionlog/package-lock.json +0 -3672
- package/references/sessionlog/package.json +0 -65
- package/references/sessionlog/src/__tests__/agent-hooks.test.ts +0 -570
- package/references/sessionlog/src/__tests__/agent-registry.test.ts +0 -127
- package/references/sessionlog/src/__tests__/claude-code-hooks.test.ts +0 -225
- package/references/sessionlog/src/__tests__/claude-generator.test.ts +0 -46
- package/references/sessionlog/src/__tests__/commit-msg.test.ts +0 -86
- package/references/sessionlog/src/__tests__/cursor-agent.test.ts +0 -224
- package/references/sessionlog/src/__tests__/e2e-live.test.ts +0 -890
- package/references/sessionlog/src/__tests__/event-log.test.ts +0 -183
- package/references/sessionlog/src/__tests__/flush-sentinel.test.ts +0 -105
- package/references/sessionlog/src/__tests__/gemini-agent.test.ts +0 -375
- package/references/sessionlog/src/__tests__/git-hooks.test.ts +0 -78
- package/references/sessionlog/src/__tests__/hook-managers.test.ts +0 -121
- package/references/sessionlog/src/__tests__/lifecycle-tasks.test.ts +0 -759
- package/references/sessionlog/src/__tests__/opencode-agent.test.ts +0 -338
- package/references/sessionlog/src/__tests__/redaction.test.ts +0 -136
- package/references/sessionlog/src/__tests__/session-repo.test.ts +0 -353
- package/references/sessionlog/src/__tests__/session-store.test.ts +0 -166
- package/references/sessionlog/src/__tests__/setup-ccweb.test.ts +0 -466
- package/references/sessionlog/src/__tests__/skill-live.test.ts +0 -461
- package/references/sessionlog/src/__tests__/summarize.test.ts +0 -348
- package/references/sessionlog/src/__tests__/task-plan-e2e.test.ts +0 -610
- package/references/sessionlog/src/__tests__/task-plan-live.test.ts +0 -632
- package/references/sessionlog/src/__tests__/transcript-timestamp.test.ts +0 -121
- package/references/sessionlog/src/__tests__/types.test.ts +0 -166
- package/references/sessionlog/src/__tests__/utils.test.ts +0 -333
- package/references/sessionlog/src/__tests__/validation.test.ts +0 -103
- package/references/sessionlog/src/__tests__/worktree.test.ts +0 -57
- package/references/sessionlog/src/agent/agents/claude-code.ts +0 -1089
- package/references/sessionlog/src/agent/agents/cursor.ts +0 -361
- package/references/sessionlog/src/agent/agents/gemini-cli.ts +0 -632
- package/references/sessionlog/src/agent/agents/opencode.ts +0 -540
- package/references/sessionlog/src/agent/registry.ts +0 -143
- package/references/sessionlog/src/agent/session-types.ts +0 -113
- package/references/sessionlog/src/agent/types.ts +0 -220
- package/references/sessionlog/src/cli.ts +0 -597
- package/references/sessionlog/src/commands/clean.ts +0 -133
- package/references/sessionlog/src/commands/disable.ts +0 -84
- package/references/sessionlog/src/commands/doctor.ts +0 -145
- package/references/sessionlog/src/commands/enable.ts +0 -202
- package/references/sessionlog/src/commands/explain.ts +0 -261
- package/references/sessionlog/src/commands/reset.ts +0 -105
- package/references/sessionlog/src/commands/resume.ts +0 -180
- package/references/sessionlog/src/commands/rewind.ts +0 -195
- package/references/sessionlog/src/commands/setup-ccweb.ts +0 -275
- package/references/sessionlog/src/commands/status.ts +0 -172
- package/references/sessionlog/src/config.ts +0 -165
- package/references/sessionlog/src/events/event-log.ts +0 -126
- package/references/sessionlog/src/git-operations.ts +0 -558
- package/references/sessionlog/src/hooks/git-hooks.ts +0 -165
- package/references/sessionlog/src/hooks/lifecycle.ts +0 -391
- package/references/sessionlog/src/index.ts +0 -650
- package/references/sessionlog/src/security/redaction.ts +0 -283
- package/references/sessionlog/src/session/state-machine.ts +0 -452
- package/references/sessionlog/src/store/checkpoint-store.ts +0 -509
- package/references/sessionlog/src/store/native-store.ts +0 -173
- package/references/sessionlog/src/store/provider-types.ts +0 -99
- package/references/sessionlog/src/store/session-store.ts +0 -266
- package/references/sessionlog/src/strategy/attribution.ts +0 -296
- package/references/sessionlog/src/strategy/common.ts +0 -207
- package/references/sessionlog/src/strategy/content-overlap.ts +0 -228
- package/references/sessionlog/src/strategy/manual-commit.ts +0 -988
- package/references/sessionlog/src/strategy/types.ts +0 -279
- package/references/sessionlog/src/summarize/claude-generator.ts +0 -115
- package/references/sessionlog/src/summarize/summarize.ts +0 -432
- package/references/sessionlog/src/types.ts +0 -508
- package/references/sessionlog/src/utils/chunk-files.ts +0 -49
- package/references/sessionlog/src/utils/commit-message.ts +0 -65
- package/references/sessionlog/src/utils/detect-agent.ts +0 -36
- package/references/sessionlog/src/utils/hook-managers.ts +0 -125
- package/references/sessionlog/src/utils/ide-tags.ts +0 -32
- package/references/sessionlog/src/utils/paths.ts +0 -79
- package/references/sessionlog/src/utils/preview-rewind.ts +0 -80
- package/references/sessionlog/src/utils/rewind-conflict.ts +0 -121
- package/references/sessionlog/src/utils/shadow-branch.ts +0 -109
- package/references/sessionlog/src/utils/string-utils.ts +0 -46
- package/references/sessionlog/src/utils/todo-extract.ts +0 -188
- package/references/sessionlog/src/utils/trailers.ts +0 -187
- package/references/sessionlog/src/utils/transcript-parse.ts +0 -177
- package/references/sessionlog/src/utils/transcript-timestamp.ts +0 -59
- package/references/sessionlog/src/utils/tree-ops.ts +0 -219
- package/references/sessionlog/src/utils/tty.ts +0 -72
- package/references/sessionlog/src/utils/validation.ts +0 -65
- package/references/sessionlog/src/utils/worktree.ts +0 -58
- package/references/sessionlog/src/wire-types.ts +0 -59
- package/references/sessionlog/templates/setup-env.sh +0 -153
- package/references/sessionlog/tsconfig.json +0 -18
- package/references/sessionlog/vitest.config.ts +0 -12
- package/references/skill-tree/.claude/settings.json +0 -6
- package/references/skill-tree/.sudocode/issues.jsonl +0 -19
- package/references/skill-tree/.sudocode/specs.jsonl +0 -3
- package/references/skill-tree/CLAUDE.md +0 -126
- package/references/skill-tree/README.md +0 -372
- package/references/skill-tree/docs/GAPS_v1.md +0 -221
- package/references/skill-tree/docs/INTEGRATION_PLAN.md +0 -467
- package/references/skill-tree/docs/TODOS.md +0 -91
- package/references/skill-tree/docs/anthropic_skill_guide.md +0 -1364
- package/references/skill-tree/docs/design/federated-skill-trees.md +0 -524
- package/references/skill-tree/docs/design/multi-agent-sync.md +0 -759
- package/references/skill-tree/docs/scraper/BRAINSTORM.md +0 -583
- package/references/skill-tree/docs/scraper/POC_PLAN.md +0 -420
- package/references/skill-tree/docs/scraper/README.md +0 -170
- package/references/skill-tree/examples/basic-usage.ts +0 -164
- package/references/skill-tree/package-lock.json +0 -1852
- package/references/skill-tree/package.json +0 -66
- package/references/skill-tree/scraper/README.md +0 -123
- package/references/skill-tree/scraper/docs/DESIGN.md +0 -683
- package/references/skill-tree/scraper/docs/PLAN.md +0 -336
- package/references/skill-tree/scraper/drizzle.config.ts +0 -10
- package/references/skill-tree/scraper/package-lock.json +0 -6329
- package/references/skill-tree/scraper/package.json +0 -68
- package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-description.md +0 -7
- package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-name.md +0 -7
- package/references/skill-tree/scraper/test/fixtures/minimal-skill/SKILL.md +0 -27
- package/references/skill-tree/scraper/test/fixtures/skill-json/SKILL.json +0 -21
- package/references/skill-tree/scraper/test/fixtures/skill-with-meta/SKILL.md +0 -54
- package/references/skill-tree/scraper/test/fixtures/skill-with-meta/_meta.json +0 -24
- package/references/skill-tree/scraper/test/fixtures/valid-skill/SKILL.md +0 -93
- package/references/skill-tree/scraper/test/fixtures/valid-skill/_meta.json +0 -22
- package/references/skill-tree/scraper/tsup.config.ts +0 -14
- package/references/skill-tree/scraper/vitest.config.ts +0 -17
- package/references/skill-tree/scripts/convert-to-vitest.ts +0 -166
- package/references/skill-tree/skills/skill-writer/SKILL.md +0 -339
- package/references/skill-tree/skills/skill-writer/references/examples.md +0 -326
- package/references/skill-tree/skills/skill-writer/references/patterns.md +0 -210
- package/references/skill-tree/skills/skill-writer/references/quality-checklist.md +0 -123
- package/references/skill-tree/test/run-all.ts +0 -106
- package/references/skill-tree/test/utils.ts +0 -128
- package/references/skill-tree/vitest.config.ts +0 -16
|
@@ -1,364 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it, vi } from "vitest";
|
|
2
|
-
|
|
3
|
-
import {
|
|
4
|
-
getToolDefinitions,
|
|
5
|
-
MEMORY_TOOLS,
|
|
6
|
-
MEMORY_SEARCH_TOOL,
|
|
7
|
-
MEMORY_GET_DETAILS_TOOL,
|
|
8
|
-
MemoryToolExecutor,
|
|
9
|
-
type ToolDefinition,
|
|
10
|
-
type MemoryInstance,
|
|
11
|
-
} from "../tools.js";
|
|
12
|
-
import type { Minimem } from "../../minimem.js";
|
|
13
|
-
|
|
14
|
-
describe("Tool definitions", () => {
|
|
15
|
-
it("exports memory_search and memory_get_details tools", () => {
|
|
16
|
-
expect(MEMORY_TOOLS).toHaveLength(5);
|
|
17
|
-
expect(MEMORY_TOOLS.map((t) => t.name)).toEqual([
|
|
18
|
-
"memory_search",
|
|
19
|
-
"memory_get_details",
|
|
20
|
-
"knowledge_search",
|
|
21
|
-
"knowledge_graph",
|
|
22
|
-
"knowledge_path",
|
|
23
|
-
]);
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
it("getToolDefinitions returns all tools", () => {
|
|
27
|
-
const tools = getToolDefinitions();
|
|
28
|
-
expect(tools).toEqual(MEMORY_TOOLS);
|
|
29
|
-
});
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
describe("memory_search tool", () => {
|
|
33
|
-
it("has correct schema", () => {
|
|
34
|
-
expect(MEMORY_SEARCH_TOOL.name).toBe("memory_search");
|
|
35
|
-
expect(MEMORY_SEARCH_TOOL.inputSchema.type).toBe("object");
|
|
36
|
-
expect(MEMORY_SEARCH_TOOL.inputSchema.required).toContain("query");
|
|
37
|
-
expect(MEMORY_SEARCH_TOOL.inputSchema.properties.query.type).toBe("string");
|
|
38
|
-
expect(MEMORY_SEARCH_TOOL.inputSchema.properties.maxResults.type).toBe("number");
|
|
39
|
-
expect(MEMORY_SEARCH_TOOL.inputSchema.properties.minScore.type).toBe("number");
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
it("has detail parameter with compact and full options", () => {
|
|
43
|
-
const detail = MEMORY_SEARCH_TOOL.inputSchema.properties.detail;
|
|
44
|
-
expect(detail.type).toBe("string");
|
|
45
|
-
expect(detail.enum).toEqual(["compact", "full"]);
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
it("has description", () => {
|
|
49
|
-
expect(MEMORY_SEARCH_TOOL.description).toBeTruthy();
|
|
50
|
-
expect(MEMORY_SEARCH_TOOL.description.length).toBeGreaterThan(20);
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
describe("memory_get_details tool", () => {
|
|
55
|
-
it("has correct schema", () => {
|
|
56
|
-
expect(MEMORY_GET_DETAILS_TOOL.name).toBe("memory_get_details");
|
|
57
|
-
expect(MEMORY_GET_DETAILS_TOOL.inputSchema.type).toBe("object");
|
|
58
|
-
expect(MEMORY_GET_DETAILS_TOOL.inputSchema.required).toContain("results");
|
|
59
|
-
expect(MEMORY_GET_DETAILS_TOOL.inputSchema.properties.results.type).toBe("array");
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it("has description mentioning two-step approach", () => {
|
|
63
|
-
expect(MEMORY_GET_DETAILS_TOOL.description).toContain("two-step");
|
|
64
|
-
});
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
describe("Tool schema compatibility", () => {
|
|
68
|
-
const validateToolSchema = (tool: ToolDefinition) => {
|
|
69
|
-
// MCP/OpenAI/Anthropic require type: "object" at top level
|
|
70
|
-
expect(tool.inputSchema.type).toBe("object");
|
|
71
|
-
|
|
72
|
-
// All tools need name and description
|
|
73
|
-
expect(tool.name).toBeTruthy();
|
|
74
|
-
expect(tool.description).toBeTruthy();
|
|
75
|
-
|
|
76
|
-
// Properties should be an object
|
|
77
|
-
expect(typeof tool.inputSchema.properties).toBe("object");
|
|
78
|
-
|
|
79
|
-
// Required should be an array (or undefined)
|
|
80
|
-
if (tool.inputSchema.required !== undefined) {
|
|
81
|
-
expect(Array.isArray(tool.inputSchema.required)).toBe(true);
|
|
82
|
-
}
|
|
83
|
-
};
|
|
84
|
-
|
|
85
|
-
it("all tools have valid schemas", () => {
|
|
86
|
-
for (const tool of MEMORY_TOOLS) {
|
|
87
|
-
validateToolSchema(tool);
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
it("tool names are snake_case", () => {
|
|
92
|
-
for (const tool of MEMORY_TOOLS) {
|
|
93
|
-
expect(tool.name).toMatch(/^[a-z][a-z0-9_]*$/);
|
|
94
|
-
}
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
it("property types are valid JSON Schema types", () => {
|
|
98
|
-
const validTypes = ["string", "number", "boolean", "array", "object", "null"];
|
|
99
|
-
for (const tool of MEMORY_TOOLS) {
|
|
100
|
-
for (const prop of Object.values(tool.inputSchema.properties)) {
|
|
101
|
-
expect(validTypes).toContain(prop.type);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
});
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
describe("memory_search tool schema", () => {
|
|
108
|
-
it("has type parameter for observation filtering", () => {
|
|
109
|
-
const type = MEMORY_SEARCH_TOOL.inputSchema.properties.type;
|
|
110
|
-
expect(type).toBeDefined();
|
|
111
|
-
expect(type.type).toBe("string");
|
|
112
|
-
expect(type.description).toContain("type");
|
|
113
|
-
});
|
|
114
|
-
|
|
115
|
-
it("has directories parameter", () => {
|
|
116
|
-
const dirs = MEMORY_SEARCH_TOOL.inputSchema.properties.directories;
|
|
117
|
-
expect(dirs).toBeDefined();
|
|
118
|
-
expect(dirs.type).toBe("array");
|
|
119
|
-
});
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
// Helper to create mock Minimem for executor tests
|
|
123
|
-
function createMockMinimem(searchResults: Array<{
|
|
124
|
-
path: string;
|
|
125
|
-
startLine: number;
|
|
126
|
-
endLine: number;
|
|
127
|
-
score: number;
|
|
128
|
-
snippet: string;
|
|
129
|
-
}> = []) {
|
|
130
|
-
return {
|
|
131
|
-
search: vi.fn().mockResolvedValue(searchResults),
|
|
132
|
-
readLines: vi.fn().mockImplementation((path: string, opts?: { from?: number; lines?: number }) => {
|
|
133
|
-
// Simulate returning content for known paths
|
|
134
|
-
if (path === "memory/test.md") {
|
|
135
|
-
return Promise.resolve({
|
|
136
|
-
content: "Full content of test.md\nLine 2\nLine 3",
|
|
137
|
-
startLine: opts?.from ?? 1,
|
|
138
|
-
endLine: (opts?.from ?? 1) + (opts?.lines ?? 3) - 1,
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
return Promise.resolve(null);
|
|
142
|
-
}),
|
|
143
|
-
} as unknown as Minimem;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
describe("MemoryToolExecutor", () => {
|
|
147
|
-
describe("memorySearch with type filter", () => {
|
|
148
|
-
it("passes type parameter to search", async () => {
|
|
149
|
-
const mock = createMockMinimem([
|
|
150
|
-
{ path: "memory/test.md", startLine: 1, endLine: 5, score: 0.85, snippet: "Decision about API" },
|
|
151
|
-
]);
|
|
152
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
153
|
-
|
|
154
|
-
await executor.execute("memory_search", {
|
|
155
|
-
query: "API design",
|
|
156
|
-
type: "decision",
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
expect(mock.search).toHaveBeenCalledWith("API design", {
|
|
160
|
-
maxResults: 15,
|
|
161
|
-
minScore: undefined,
|
|
162
|
-
type: "decision",
|
|
163
|
-
});
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
it("does not pass type when not specified", async () => {
|
|
167
|
-
const mock = createMockMinimem([]);
|
|
168
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
169
|
-
|
|
170
|
-
await executor.execute("memory_search", { query: "test" });
|
|
171
|
-
|
|
172
|
-
expect(mock.search).toHaveBeenCalledWith("test", {
|
|
173
|
-
maxResults: 15,
|
|
174
|
-
minScore: undefined,
|
|
175
|
-
type: undefined,
|
|
176
|
-
});
|
|
177
|
-
});
|
|
178
|
-
});
|
|
179
|
-
|
|
180
|
-
describe("memorySearch compact format", () => {
|
|
181
|
-
it("returns compact format by default with preview and hint", async () => {
|
|
182
|
-
const mock = createMockMinimem([
|
|
183
|
-
{ path: "memory/test.md", startLine: 1, endLine: 5, score: 0.9, snippet: "# Architecture Decision\nWe chose TypeScript." },
|
|
184
|
-
]);
|
|
185
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
186
|
-
|
|
187
|
-
const result = await executor.execute("memory_search", { query: "architecture" });
|
|
188
|
-
|
|
189
|
-
const text = result.content[0].text;
|
|
190
|
-
// Compact: uses [0] indexing, percentage without decimal, short preview
|
|
191
|
-
expect(text).toContain("[0]");
|
|
192
|
-
expect(text).toContain("90%");
|
|
193
|
-
expect(text).toContain("memory/test.md:1-5");
|
|
194
|
-
// Should show a heading-based preview
|
|
195
|
-
expect(text).toContain("Architecture Decision");
|
|
196
|
-
// Should include hint
|
|
197
|
-
expect(text).toContain("memory_get_details");
|
|
198
|
-
});
|
|
199
|
-
|
|
200
|
-
it("truncates long previews to ~80 chars with ellipsis", async () => {
|
|
201
|
-
const longSnippet = "A".repeat(120);
|
|
202
|
-
const mock = createMockMinimem([
|
|
203
|
-
{ path: "test.md", startLine: 1, endLine: 1, score: 0.8, snippet: longSnippet },
|
|
204
|
-
]);
|
|
205
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
206
|
-
|
|
207
|
-
const result = await executor.execute("memory_search", { query: "test" });
|
|
208
|
-
|
|
209
|
-
const text = result.content[0].text;
|
|
210
|
-
// Preview should be truncated — the line with the preview should be ~80 chars + prefix
|
|
211
|
-
const previewMatch = text.match(/"([^"]+)"/);
|
|
212
|
-
expect(previewMatch).toBeTruthy();
|
|
213
|
-
expect(previewMatch![1].length).toBeLessThanOrEqual(80);
|
|
214
|
-
expect(previewMatch![1]).toContain("...");
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
it("shows (empty) for empty snippet", async () => {
|
|
218
|
-
const mock = createMockMinimem([
|
|
219
|
-
{ path: "test.md", startLine: 1, endLine: 1, score: 0.5, snippet: "" },
|
|
220
|
-
]);
|
|
221
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
222
|
-
|
|
223
|
-
const result = await executor.execute("memory_search", { query: "test" });
|
|
224
|
-
expect(result.content[0].text).toContain("(empty)");
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
it("returns no results message when empty", async () => {
|
|
228
|
-
const mock = createMockMinimem([]);
|
|
229
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
230
|
-
|
|
231
|
-
const result = await executor.execute("memory_search", { query: "nonexistent" });
|
|
232
|
-
expect(result.content[0].text).toBe("No results found.");
|
|
233
|
-
});
|
|
234
|
-
});
|
|
235
|
-
|
|
236
|
-
describe("memorySearch full format", () => {
|
|
237
|
-
it("returns full snippets when detail=full", async () => {
|
|
238
|
-
const mock = createMockMinimem([
|
|
239
|
-
{ path: "test.md", startLine: 1, endLine: 5, score: 0.85, snippet: "Full detailed content here\nWith multiple lines" },
|
|
240
|
-
]);
|
|
241
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
242
|
-
|
|
243
|
-
const result = await executor.execute("memory_search", { query: "test", detail: "full" });
|
|
244
|
-
|
|
245
|
-
const text = result.content[0].text;
|
|
246
|
-
expect(text).toContain("Full detailed content here");
|
|
247
|
-
expect(text).toContain("With multiple lines");
|
|
248
|
-
// Full mode uses [1] indexing and .1 decimal precision
|
|
249
|
-
expect(text).toContain("[1]");
|
|
250
|
-
expect(text).toContain("85.0%");
|
|
251
|
-
// No hint about memory_get_details
|
|
252
|
-
expect(text).not.toContain("Use memory_get_details");
|
|
253
|
-
});
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
describe("memorySearch multi-directory", () => {
|
|
257
|
-
it("shows directory source when searching multiple dirs", async () => {
|
|
258
|
-
const mock1 = createMockMinimem([
|
|
259
|
-
{ path: "MEMORY.md", startLine: 1, endLine: 3, score: 0.9, snippet: "From project A" },
|
|
260
|
-
]);
|
|
261
|
-
const mock2 = createMockMinimem([
|
|
262
|
-
{ path: "MEMORY.md", startLine: 1, endLine: 3, score: 0.8, snippet: "From project B" },
|
|
263
|
-
]);
|
|
264
|
-
const executor = new MemoryToolExecutor([
|
|
265
|
-
{ minimem: mock1, memoryDir: "/projectA", name: "projectA" },
|
|
266
|
-
{ minimem: mock2, memoryDir: "/projectB", name: "projectB" },
|
|
267
|
-
]);
|
|
268
|
-
|
|
269
|
-
const result = await executor.execute("memory_search", { query: "test", detail: "full" });
|
|
270
|
-
const text = result.content[0].text;
|
|
271
|
-
expect(text).toContain("[projectA]");
|
|
272
|
-
expect(text).toContain("[projectB]");
|
|
273
|
-
expect(text).toContain("Searched 2 directories");
|
|
274
|
-
});
|
|
275
|
-
|
|
276
|
-
it("returns error when directory filter matches nothing", async () => {
|
|
277
|
-
const mock = createMockMinimem([]);
|
|
278
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test", name: "test" });
|
|
279
|
-
|
|
280
|
-
const result = await executor.execute("memory_search", {
|
|
281
|
-
query: "test",
|
|
282
|
-
directories: ["nonexistent"],
|
|
283
|
-
});
|
|
284
|
-
expect(result.isError).toBe(true);
|
|
285
|
-
expect(result.content[0].text).toContain("No matching directories");
|
|
286
|
-
});
|
|
287
|
-
});
|
|
288
|
-
|
|
289
|
-
describe("memoryGetDetails", () => {
|
|
290
|
-
it("returns full text for requested chunks", async () => {
|
|
291
|
-
const mock = createMockMinimem();
|
|
292
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
293
|
-
|
|
294
|
-
const result = await executor.execute("memory_get_details", {
|
|
295
|
-
results: [{ path: "memory/test.md", startLine: 1, endLine: 3 }],
|
|
296
|
-
});
|
|
297
|
-
|
|
298
|
-
expect(mock.readLines).toHaveBeenCalledWith("memory/test.md", { from: 1, lines: 3 });
|
|
299
|
-
const text = result.content[0].text;
|
|
300
|
-
expect(text).toContain("memory/test.md:1-3");
|
|
301
|
-
expect(text).toContain("Full content of test.md");
|
|
302
|
-
});
|
|
303
|
-
|
|
304
|
-
it("returns (not found) for non-existent files", async () => {
|
|
305
|
-
const mock = createMockMinimem();
|
|
306
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
307
|
-
|
|
308
|
-
const result = await executor.execute("memory_get_details", {
|
|
309
|
-
results: [{ path: "memory/nonexistent.md", startLine: 1, endLine: 5 }],
|
|
310
|
-
});
|
|
311
|
-
|
|
312
|
-
const text = result.content[0].text;
|
|
313
|
-
expect(text).toContain("(not found)");
|
|
314
|
-
expect(text).toContain("memory/nonexistent.md:1-5");
|
|
315
|
-
});
|
|
316
|
-
|
|
317
|
-
it("handles multiple results with mixed found/not-found", async () => {
|
|
318
|
-
const mock = createMockMinimem();
|
|
319
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
320
|
-
|
|
321
|
-
const result = await executor.execute("memory_get_details", {
|
|
322
|
-
results: [
|
|
323
|
-
{ path: "memory/test.md", startLine: 1, endLine: 3 },
|
|
324
|
-
{ path: "memory/missing.md", startLine: 1, endLine: 5 },
|
|
325
|
-
],
|
|
326
|
-
});
|
|
327
|
-
|
|
328
|
-
const text = result.content[0].text;
|
|
329
|
-
expect(text).toContain("Full content of test.md");
|
|
330
|
-
expect(text).toContain("(not found)");
|
|
331
|
-
});
|
|
332
|
-
|
|
333
|
-
it("returns error for empty results array", async () => {
|
|
334
|
-
const mock = createMockMinimem();
|
|
335
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
336
|
-
|
|
337
|
-
const result = await executor.execute("memory_get_details", { results: [] });
|
|
338
|
-
expect(result.isError).toBe(true);
|
|
339
|
-
});
|
|
340
|
-
|
|
341
|
-
it("returns error when directory filter matches nothing", async () => {
|
|
342
|
-
const mock = createMockMinimem();
|
|
343
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test", name: "test" });
|
|
344
|
-
|
|
345
|
-
const result = await executor.execute("memory_get_details", {
|
|
346
|
-
results: [{ path: "test.md", startLine: 1, endLine: 1 }],
|
|
347
|
-
directories: ["nonexistent"],
|
|
348
|
-
});
|
|
349
|
-
expect(result.isError).toBe(true);
|
|
350
|
-
expect(result.content[0].text).toContain("No matching directories");
|
|
351
|
-
});
|
|
352
|
-
});
|
|
353
|
-
|
|
354
|
-
describe("unknown tools", () => {
|
|
355
|
-
it("returns error for unknown tool name", async () => {
|
|
356
|
-
const mock = createMockMinimem();
|
|
357
|
-
const executor = new MemoryToolExecutor({ minimem: mock, memoryDir: "/test" });
|
|
358
|
-
|
|
359
|
-
const result = await executor.execute("nonexistent_tool", {});
|
|
360
|
-
expect(result.isError).toBe(true);
|
|
361
|
-
expect(result.content[0].text).toContain("Unknown tool");
|
|
362
|
-
});
|
|
363
|
-
});
|
|
364
|
-
});
|
|
@@ -1,326 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MCP (Model Context Protocol) Server for Minimem
|
|
3
|
-
*
|
|
4
|
-
* Provides memory tools via JSON-RPC 2.0 over stdio.
|
|
5
|
-
* Compatible with Claude Desktop, Cursor, and other MCP clients.
|
|
6
|
-
*
|
|
7
|
-
* Usage:
|
|
8
|
-
* import { Minimem } from "minimem";
|
|
9
|
-
* import { createMcpServer, runMcpServer } from "minimem/mcp";
|
|
10
|
-
*
|
|
11
|
-
* const minimem = await Minimem.create({ ... });
|
|
12
|
-
* const server = createMcpServer(minimem);
|
|
13
|
-
* await runMcpServer(server); // Runs over stdio
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
import * as readline from "node:readline";
|
|
17
|
-
import type { Minimem } from "../minimem.js";
|
|
18
|
-
import {
|
|
19
|
-
MEMORY_TOOLS,
|
|
20
|
-
type ToolDefinition,
|
|
21
|
-
type ToolResult,
|
|
22
|
-
type MemoryInstance,
|
|
23
|
-
MemoryToolExecutor,
|
|
24
|
-
} from "./tools.js";
|
|
25
|
-
|
|
26
|
-
const PROTOCOL_VERSION = "2024-11-05";
|
|
27
|
-
const SERVER_NAME = "minimem";
|
|
28
|
-
const SERVER_VERSION = "0.1.0";
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* JSON-RPC 2.0 request
|
|
32
|
-
*/
|
|
33
|
-
type JsonRpcRequest = {
|
|
34
|
-
jsonrpc: "2.0";
|
|
35
|
-
id: string | number;
|
|
36
|
-
method: string;
|
|
37
|
-
params?: Record<string, unknown>;
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* JSON-RPC 2.0 response
|
|
42
|
-
*/
|
|
43
|
-
type JsonRpcResponse = {
|
|
44
|
-
jsonrpc: "2.0";
|
|
45
|
-
id: string | number | null;
|
|
46
|
-
result?: unknown;
|
|
47
|
-
error?: {
|
|
48
|
-
code: number;
|
|
49
|
-
message: string;
|
|
50
|
-
data?: unknown;
|
|
51
|
-
};
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* JSON-RPC 2.0 notification (no id)
|
|
56
|
-
*/
|
|
57
|
-
type JsonRpcNotification = {
|
|
58
|
-
jsonrpc: "2.0";
|
|
59
|
-
method: string;
|
|
60
|
-
params?: Record<string, unknown>;
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* MCP Server capabilities
|
|
65
|
-
*/
|
|
66
|
-
type ServerCapabilities = {
|
|
67
|
-
tools?: {
|
|
68
|
-
listChanged?: boolean;
|
|
69
|
-
};
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
/**
|
|
73
|
-
* MCP Server info
|
|
74
|
-
*/
|
|
75
|
-
type ServerInfo = {
|
|
76
|
-
name: string;
|
|
77
|
-
version: string;
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* MCP Initialize result
|
|
82
|
-
*/
|
|
83
|
-
type InitializeResult = {
|
|
84
|
-
protocolVersion: string;
|
|
85
|
-
capabilities: ServerCapabilities;
|
|
86
|
-
serverInfo: ServerInfo;
|
|
87
|
-
};
|
|
88
|
-
|
|
89
|
-
/**
|
|
90
|
-
* MCP Tool in list format
|
|
91
|
-
*/
|
|
92
|
-
type McpTool = {
|
|
93
|
-
name: string;
|
|
94
|
-
description: string;
|
|
95
|
-
inputSchema: {
|
|
96
|
-
type: "object";
|
|
97
|
-
properties: Record<string, unknown>;
|
|
98
|
-
required?: string[];
|
|
99
|
-
};
|
|
100
|
-
};
|
|
101
|
-
|
|
102
|
-
/**
|
|
103
|
-
* MCP Server implementation
|
|
104
|
-
*/
|
|
105
|
-
export class McpServer {
|
|
106
|
-
private executor: MemoryToolExecutor;
|
|
107
|
-
private initialized = false;
|
|
108
|
-
|
|
109
|
-
constructor(instances: Minimem | MemoryInstance | MemoryInstance[]) {
|
|
110
|
-
this.executor = new MemoryToolExecutor(instances);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* Handle a JSON-RPC request and return a response
|
|
115
|
-
*/
|
|
116
|
-
async handleRequest(request: JsonRpcRequest): Promise<JsonRpcResponse> {
|
|
117
|
-
try {
|
|
118
|
-
const result = await this.dispatch(request.method, request.params);
|
|
119
|
-
return {
|
|
120
|
-
jsonrpc: "2.0",
|
|
121
|
-
id: request.id,
|
|
122
|
-
result,
|
|
123
|
-
};
|
|
124
|
-
} catch (err) {
|
|
125
|
-
const message = err instanceof Error ? err.message : String(err);
|
|
126
|
-
const code = err instanceof McpError ? err.code : -32603;
|
|
127
|
-
return {
|
|
128
|
-
jsonrpc: "2.0",
|
|
129
|
-
id: request.id,
|
|
130
|
-
error: { code, message },
|
|
131
|
-
};
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
/**
|
|
136
|
-
* Dispatch a method call
|
|
137
|
-
*/
|
|
138
|
-
private async dispatch(
|
|
139
|
-
method: string,
|
|
140
|
-
params?: Record<string, unknown>,
|
|
141
|
-
): Promise<unknown> {
|
|
142
|
-
switch (method) {
|
|
143
|
-
case "initialize":
|
|
144
|
-
return this.initialize(params);
|
|
145
|
-
case "initialized":
|
|
146
|
-
// Notification, no response needed
|
|
147
|
-
return {};
|
|
148
|
-
case "tools/list":
|
|
149
|
-
return this.listTools();
|
|
150
|
-
case "tools/call":
|
|
151
|
-
return this.callTool(params);
|
|
152
|
-
case "ping":
|
|
153
|
-
return {};
|
|
154
|
-
default:
|
|
155
|
-
throw new McpError(-32601, `Method not found: ${method}`);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
/**
|
|
160
|
-
* Handle initialize request
|
|
161
|
-
*/
|
|
162
|
-
private initialize(
|
|
163
|
-
params?: Record<string, unknown>,
|
|
164
|
-
): InitializeResult {
|
|
165
|
-
this.initialized = true;
|
|
166
|
-
return {
|
|
167
|
-
protocolVersion: PROTOCOL_VERSION,
|
|
168
|
-
capabilities: {
|
|
169
|
-
tools: {
|
|
170
|
-
listChanged: false,
|
|
171
|
-
},
|
|
172
|
-
},
|
|
173
|
-
serverInfo: {
|
|
174
|
-
name: SERVER_NAME,
|
|
175
|
-
version: SERVER_VERSION,
|
|
176
|
-
},
|
|
177
|
-
};
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
/**
|
|
181
|
-
* List available tools
|
|
182
|
-
*/
|
|
183
|
-
private listTools(): { tools: McpTool[] } {
|
|
184
|
-
const tools: McpTool[] = MEMORY_TOOLS.map((tool) => ({
|
|
185
|
-
name: tool.name,
|
|
186
|
-
description: tool.description,
|
|
187
|
-
inputSchema: tool.inputSchema,
|
|
188
|
-
}));
|
|
189
|
-
return { tools };
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
/**
|
|
193
|
-
* Call a tool
|
|
194
|
-
*/
|
|
195
|
-
private async callTool(
|
|
196
|
-
params?: Record<string, unknown>,
|
|
197
|
-
): Promise<{ content: Array<{ type: string; text: string }>; isError?: boolean }> {
|
|
198
|
-
if (!params?.name || typeof params.name !== "string") {
|
|
199
|
-
throw new McpError(-32602, "Missing tool name");
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
const toolName = params.name;
|
|
203
|
-
const toolParams = (params.arguments ?? {}) as Record<string, unknown>;
|
|
204
|
-
|
|
205
|
-
const result = await this.executor.execute(toolName, toolParams);
|
|
206
|
-
return result;
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
/**
|
|
211
|
-
* Custom error class for MCP errors
|
|
212
|
-
*/
|
|
213
|
-
class McpError extends Error {
|
|
214
|
-
constructor(
|
|
215
|
-
public code: number,
|
|
216
|
-
message: string,
|
|
217
|
-
) {
|
|
218
|
-
super(message);
|
|
219
|
-
this.name = "McpError";
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
|
|
223
|
-
/**
|
|
224
|
-
* Create an MCP server for the given Minimem instance(s)
|
|
225
|
-
*/
|
|
226
|
-
export function createMcpServer(
|
|
227
|
-
instances: Minimem | MemoryInstance | MemoryInstance[],
|
|
228
|
-
): McpServer {
|
|
229
|
-
return new McpServer(instances);
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
/**
|
|
233
|
-
* Run the MCP server over stdio
|
|
234
|
-
*/
|
|
235
|
-
export async function runMcpServer(server: McpServer): Promise<void> {
|
|
236
|
-
const rl = readline.createInterface({
|
|
237
|
-
input: process.stdin,
|
|
238
|
-
output: process.stdout,
|
|
239
|
-
terminal: false,
|
|
240
|
-
});
|
|
241
|
-
|
|
242
|
-
const send = (message: JsonRpcResponse | JsonRpcNotification) => {
|
|
243
|
-
const json = JSON.stringify(message);
|
|
244
|
-
process.stdout.write(json + "\n");
|
|
245
|
-
};
|
|
246
|
-
|
|
247
|
-
rl.on("line", async (line) => {
|
|
248
|
-
if (!line.trim()) return;
|
|
249
|
-
|
|
250
|
-
try {
|
|
251
|
-
const request = JSON.parse(line) as JsonRpcRequest;
|
|
252
|
-
|
|
253
|
-
if (request.jsonrpc !== "2.0") {
|
|
254
|
-
send({
|
|
255
|
-
jsonrpc: "2.0",
|
|
256
|
-
id: request.id ?? null,
|
|
257
|
-
error: { code: -32600, message: "Invalid JSON-RPC version" },
|
|
258
|
-
});
|
|
259
|
-
return;
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
// Handle notification (no id)
|
|
263
|
-
if (request.id === undefined) {
|
|
264
|
-
await server.handleRequest({ ...request, id: 0 });
|
|
265
|
-
return;
|
|
266
|
-
}
|
|
267
|
-
|
|
268
|
-
const response = await server.handleRequest(request);
|
|
269
|
-
send(response);
|
|
270
|
-
} catch (err) {
|
|
271
|
-
const message = err instanceof Error ? err.message : String(err);
|
|
272
|
-
send({
|
|
273
|
-
jsonrpc: "2.0",
|
|
274
|
-
id: null,
|
|
275
|
-
error: { code: -32700, message: `Parse error: ${message}` },
|
|
276
|
-
});
|
|
277
|
-
}
|
|
278
|
-
});
|
|
279
|
-
|
|
280
|
-
rl.on("close", () => {
|
|
281
|
-
process.exit(0);
|
|
282
|
-
});
|
|
283
|
-
|
|
284
|
-
// Keep the process alive
|
|
285
|
-
await new Promise(() => {});
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
/**
|
|
289
|
-
* MCP server configuration for claude_desktop_config.json
|
|
290
|
-
*
|
|
291
|
-
* Example:
|
|
292
|
-
* {
|
|
293
|
-
* "mcpServers": {
|
|
294
|
-
* "minimem": {
|
|
295
|
-
* "command": "node",
|
|
296
|
-
* "args": ["path/to/your/mcp-server.js"],
|
|
297
|
-
* "env": {
|
|
298
|
-
* "MEMORY_DIR": "/path/to/memory"
|
|
299
|
-
* }
|
|
300
|
-
* }
|
|
301
|
-
* }
|
|
302
|
-
* }
|
|
303
|
-
*/
|
|
304
|
-
export type McpServerConfig = {
|
|
305
|
-
command: string;
|
|
306
|
-
args: string[];
|
|
307
|
-
env?: Record<string, string>;
|
|
308
|
-
};
|
|
309
|
-
|
|
310
|
-
/**
|
|
311
|
-
* Generate MCP server config for Claude Desktop
|
|
312
|
-
*/
|
|
313
|
-
export function generateMcpConfig(opts: {
|
|
314
|
-
serverPath: string;
|
|
315
|
-
memoryDir: string;
|
|
316
|
-
embeddingProvider?: "openai" | "gemini" | "local" | "auto";
|
|
317
|
-
}): McpServerConfig {
|
|
318
|
-
return {
|
|
319
|
-
command: "node",
|
|
320
|
-
args: [opts.serverPath],
|
|
321
|
-
env: {
|
|
322
|
-
MEMORY_DIR: opts.memoryDir,
|
|
323
|
-
...(opts.embeddingProvider ? { EMBEDDING_PROVIDER: opts.embeddingProvider } : {}),
|
|
324
|
-
},
|
|
325
|
-
};
|
|
326
|
-
}
|