memento-mcp-server 0.1.0
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/.cursor/rules/cache-management.mdc +171 -0
- package/.cursor/rules/database-schema.mdc +344 -0
- package/.cursor/rules/deployment.mdc +596 -0
- package/.cursor/rules/error-logging.mdc +298 -0
- package/.cursor/rules/forgetting-algorithms.mdc +426 -0
- package/.cursor/rules/http-server.mdc +432 -0
- package/.cursor/rules/hybrid-search.mdc +424 -0
- package/.cursor/rules/implementation.mdc +369 -0
- package/.cursor/rules/lightweight-embedding.mdc +178 -0
- package/.cursor/rules/mcp-client-development.mdc +0 -0
- package/.cursor/rules/mcp-server-development.mdc +0 -0
- package/.cursor/rules/mcp-tools-architecture.mdc +205 -0
- package/.cursor/rules/memento-memory-rule.mdc +8 -0
- package/.cursor/rules/memento-project-overview.mdc +0 -0
- package/.cursor/rules/memory-algorithms.mdc +502 -0
- package/.cursor/rules/monitoring.mdc +622 -0
- package/.cursor/rules/performance-alerts.mdc +537 -0
- package/.cursor/rules/performance-monitoring.mdc +345 -0
- package/.cursor/rules/performance-optimization.mdc +563 -0
- package/.cursor/rules/project-structure.mdc +310 -0
- package/.cursor/rules/testing.mdc +473 -0
- package/.dockerignore +15 -0
- package/.eslintrc.json +34 -0
- package/.github/ISSUE_TEMPLATE/bug_report.md +51 -0
- package/.github/ISSUE_TEMPLATE/feature_request.md +45 -0
- package/.github/ISSUE_TEMPLATE/question.md +31 -0
- package/.github/PULL_REQUEST_TEMPLATE.md +97 -0
- package/AGENTS.md +28 -0
- package/CHANGELOG.md +416 -0
- package/CODE_OF_CONDUCT.md +62 -0
- package/CONTRIBUTING.md +165 -0
- package/DOCKER_SETUP_GUIDE.md +84 -0
- package/Dockerfile +90 -0
- package/INSTALL.en.md +303 -0
- package/INSTALL.md +303 -0
- package/README.en.md +330 -0
- package/README.md +427 -0
- package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +1068 -0
- package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +46 -0
- package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +48 -0
- package/dist/algorithms/forgetting-algorithm.d.ts +90 -0
- package/dist/algorithms/forgetting-algorithm.d.ts.map +1 -0
- package/dist/algorithms/forgetting-algorithm.js +160 -0
- package/dist/algorithms/forgetting-algorithm.js.map +1 -0
- package/dist/algorithms/hybrid-search-engine.d.ts +108 -0
- package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -0
- package/dist/algorithms/hybrid-search-engine.js +384 -0
- package/dist/algorithms/hybrid-search-engine.js.map +1 -0
- package/dist/algorithms/search-engine.d.ts +64 -0
- package/dist/algorithms/search-engine.d.ts.map +1 -0
- package/dist/algorithms/search-engine.js +304 -0
- package/dist/algorithms/search-engine.js.map +1 -0
- package/dist/algorithms/search-ranking.d.ts +145 -0
- package/dist/algorithms/search-ranking.d.ts.map +1 -0
- package/dist/algorithms/search-ranking.js +311 -0
- package/dist/algorithms/search-ranking.js.map +1 -0
- package/dist/algorithms/spaced-repetition.d.ts +83 -0
- package/dist/algorithms/spaced-repetition.d.ts.map +1 -0
- package/dist/algorithms/spaced-repetition.js +153 -0
- package/dist/algorithms/spaced-repetition.js.map +1 -0
- package/dist/algorithms/vector-search-engine.d.ts +96 -0
- package/dist/algorithms/vector-search-engine.d.ts.map +1 -0
- package/dist/algorithms/vector-search-engine.js +410 -0
- package/dist/algorithms/vector-search-engine.js.map +1 -0
- package/dist/client/index.d.ts +55 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +179 -0
- package/dist/client/index.js.map +1 -0
- package/dist/config/index.d.ts +20 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +87 -0
- package/dist/config/index.js.map +1 -0
- package/dist/database/init.d.ts +7 -0
- package/dist/database/init.d.ts.map +1 -0
- package/dist/database/init.js +117 -0
- package/dist/database/init.js.map +1 -0
- package/dist/database/migrate.d.ts +6 -0
- package/dist/database/migrate.d.ts.map +1 -0
- package/dist/database/migrate.js +84 -0
- package/dist/database/migrate.js.map +1 -0
- package/dist/database/schema.sql +159 -0
- package/dist/npm-client/context-injector.d.ts +106 -0
- package/dist/npm-client/context-injector.d.ts.map +1 -0
- package/dist/npm-client/context-injector.js +296 -0
- package/dist/npm-client/context-injector.js.map +1 -0
- package/dist/npm-client/index.d.ts +42 -0
- package/dist/npm-client/index.d.ts.map +1 -0
- package/dist/npm-client/index.js +43 -0
- package/dist/npm-client/index.js.map +1 -0
- package/dist/npm-client/memento-client.d.ts +114 -0
- package/dist/npm-client/memento-client.d.ts.map +1 -0
- package/dist/npm-client/memento-client.js +391 -0
- package/dist/npm-client/memento-client.js.map +1 -0
- package/dist/npm-client/memory-manager.d.ts +137 -0
- package/dist/npm-client/memory-manager.d.ts.map +1 -0
- package/dist/npm-client/memory-manager.js +341 -0
- package/dist/npm-client/memory-manager.js.map +1 -0
- package/dist/npm-client/types.d.ts +216 -0
- package/dist/npm-client/types.d.ts.map +1 -0
- package/dist/npm-client/types.js +44 -0
- package/dist/npm-client/types.js.map +1 -0
- package/dist/npm-client/utils.d.ts +91 -0
- package/dist/npm-client/utils.d.ts.map +1 -0
- package/dist/npm-client/utils.js +351 -0
- package/dist/npm-client/utils.js.map +1 -0
- package/dist/scripts/copy-assets.d.ts +3 -0
- package/dist/scripts/copy-assets.d.ts.map +1 -0
- package/dist/scripts/copy-assets.js +31 -0
- package/dist/scripts/copy-assets.js.map +1 -0
- package/dist/server/http-server.d.ts +28 -0
- package/dist/server/http-server.d.ts.map +1 -0
- package/dist/server/http-server.js +930 -0
- package/dist/server/http-server.js.map +1 -0
- package/dist/server/index-backup.d.ts +5 -0
- package/dist/server/index-backup.d.ts.map +1 -0
- package/dist/server/index-backup.js +793 -0
- package/dist/server/index-backup.js.map +1 -0
- package/dist/server/index-refactored.d.ts +6 -0
- package/dist/server/index-refactored.d.ts.map +1 -0
- package/dist/server/index-refactored.js +206 -0
- package/dist/server/index-refactored.js.map +1 -0
- package/dist/server/index.d.ts +12 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +301 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/simple-mcp-server.d.ts +8 -0
- package/dist/server/simple-mcp-server.d.ts.map +1 -0
- package/dist/server/simple-mcp-server.js +152 -0
- package/dist/server/simple-mcp-server.js.map +1 -0
- package/dist/services/async-optimizer.d.ts +136 -0
- package/dist/services/async-optimizer.d.ts.map +1 -0
- package/dist/services/async-optimizer.js +406 -0
- package/dist/services/async-optimizer.js.map +1 -0
- package/dist/services/batch-scheduler.d.ts +156 -0
- package/dist/services/batch-scheduler.d.ts.map +1 -0
- package/dist/services/batch-scheduler.js +612 -0
- package/dist/services/batch-scheduler.js.map +1 -0
- package/dist/services/cache-service.d.ts +168 -0
- package/dist/services/cache-service.d.ts.map +1 -0
- package/dist/services/cache-service.js +360 -0
- package/dist/services/cache-service.js.map +1 -0
- package/dist/services/database-optimizer.d.ts +110 -0
- package/dist/services/database-optimizer.d.ts.map +1 -0
- package/dist/services/database-optimizer.js +369 -0
- package/dist/services/database-optimizer.js.map +1 -0
- package/dist/services/embedding-provider-factory.d.ts +62 -0
- package/dist/services/embedding-provider-factory.d.ts.map +1 -0
- package/dist/services/embedding-provider-factory.js +152 -0
- package/dist/services/embedding-provider-factory.js.map +1 -0
- package/dist/services/embedding-service.d.ts +95 -0
- package/dist/services/embedding-service.d.ts.map +1 -0
- package/dist/services/embedding-service.js +276 -0
- package/dist/services/embedding-service.js.map +1 -0
- package/dist/services/error-logging-service.d.ts +134 -0
- package/dist/services/error-logging-service.d.ts.map +1 -0
- package/dist/services/error-logging-service.js +271 -0
- package/dist/services/error-logging-service.js.map +1 -0
- package/dist/services/forgetting-policy-service.d.ts +94 -0
- package/dist/services/forgetting-policy-service.d.ts.map +1 -0
- package/dist/services/forgetting-policy-service.js +233 -0
- package/dist/services/forgetting-policy-service.js.map +1 -0
- package/dist/services/gemini-embedding-service.d.ts +82 -0
- package/dist/services/gemini-embedding-service.d.ts.map +1 -0
- package/dist/services/gemini-embedding-service.js +232 -0
- package/dist/services/gemini-embedding-service.js.map +1 -0
- package/dist/services/lightweight-embedding-service.d.ts +95 -0
- package/dist/services/lightweight-embedding-service.d.ts.map +1 -0
- package/dist/services/lightweight-embedding-service.js +263 -0
- package/dist/services/lightweight-embedding-service.js.map +1 -0
- package/dist/services/memory-embedding-service.d.ts +69 -0
- package/dist/services/memory-embedding-service.d.ts.map +1 -0
- package/dist/services/memory-embedding-service.js +223 -0
- package/dist/services/memory-embedding-service.js.map +1 -0
- package/dist/services/minilm-embedding-service.d.ts +92 -0
- package/dist/services/minilm-embedding-service.d.ts.map +1 -0
- package/dist/services/minilm-embedding-service.js +216 -0
- package/dist/services/minilm-embedding-service.js.map +1 -0
- package/dist/services/performance-alert-service.d.ts +142 -0
- package/dist/services/performance-alert-service.d.ts.map +1 -0
- package/dist/services/performance-alert-service.js +366 -0
- package/dist/services/performance-alert-service.js.map +1 -0
- package/dist/services/performance-monitor.d.ts +144 -0
- package/dist/services/performance-monitor.d.ts.map +1 -0
- package/dist/services/performance-monitor.js +416 -0
- package/dist/services/performance-monitor.js.map +1 -0
- package/dist/services/performance-monitoring-integration.d.ts +77 -0
- package/dist/services/performance-monitoring-integration.d.ts.map +1 -0
- package/dist/services/performance-monitoring-integration.js +177 -0
- package/dist/services/performance-monitoring-integration.js.map +1 -0
- package/dist/services/unified-embedding-service.d.ts +75 -0
- package/dist/services/unified-embedding-service.d.ts.map +1 -0
- package/dist/services/unified-embedding-service.js +211 -0
- package/dist/services/unified-embedding-service.js.map +1 -0
- package/dist/test/debug-http-v2.d.ts +5 -0
- package/dist/test/debug-http-v2.d.ts.map +1 -0
- package/dist/test/debug-http-v2.js +28 -0
- package/dist/test/debug-http-v2.js.map +1 -0
- package/dist/test/performance-benchmark.d.ts +57 -0
- package/dist/test/performance-benchmark.d.ts.map +1 -0
- package/dist/test/performance-benchmark.js +427 -0
- package/dist/test/performance-benchmark.js.map +1 -0
- package/dist/test/test-alerts-direct.d.ts +7 -0
- package/dist/test/test-alerts-direct.d.ts.map +1 -0
- package/dist/test/test-alerts-direct.js +101 -0
- package/dist/test/test-alerts-direct.js.map +1 -0
- package/dist/test/test-batch-scheduler.d.ts +2 -0
- package/dist/test/test-batch-scheduler.d.ts.map +1 -0
- package/dist/test/test-batch-scheduler.js +156 -0
- package/dist/test/test-batch-scheduler.js.map +1 -0
- package/dist/test/test-client.d.ts +5 -0
- package/dist/test/test-client.d.ts.map +1 -0
- package/dist/test/test-client.js +86 -0
- package/dist/test/test-client.js.map +1 -0
- package/dist/test/test-embedding.d.ts +6 -0
- package/dist/test/test-embedding.d.ts.map +1 -0
- package/dist/test/test-embedding.js +142 -0
- package/dist/test/test-embedding.js.map +1 -0
- package/dist/test/test-error-logging.d.ts +7 -0
- package/dist/test/test-error-logging.d.ts.map +1 -0
- package/dist/test/test-error-logging.js +105 -0
- package/dist/test/test-error-logging.js.map +1 -0
- package/dist/test/test-forgetting.d.ts +6 -0
- package/dist/test/test-forgetting.d.ts.map +1 -0
- package/dist/test/test-forgetting.js +154 -0
- package/dist/test/test-forgetting.js.map +1 -0
- package/dist/test/test-gemini-embedding.d.ts +7 -0
- package/dist/test/test-gemini-embedding.d.ts.map +1 -0
- package/dist/test/test-gemini-embedding.js +134 -0
- package/dist/test/test-gemini-embedding.js.map +1 -0
- package/dist/test/test-http-server-v2-simple.d.ts +6 -0
- package/dist/test/test-http-server-v2-simple.d.ts.map +1 -0
- package/dist/test/test-http-server-v2-simple.js +131 -0
- package/dist/test/test-http-server-v2-simple.js.map +1 -0
- package/dist/test/test-http-server-v2.d.ts +7 -0
- package/dist/test/test-http-server-v2.d.ts.map +1 -0
- package/dist/test/test-http-server-v2.js +529 -0
- package/dist/test/test-http-server-v2.js.map +1 -0
- package/dist/test/test-lightweight-embedding.d.ts +6 -0
- package/dist/test/test-lightweight-embedding.d.ts.map +1 -0
- package/dist/test/test-lightweight-embedding.js +189 -0
- package/dist/test/test-lightweight-embedding.js.map +1 -0
- package/dist/test/test-m1-completion.d.ts +7 -0
- package/dist/test/test-m1-completion.d.ts.map +1 -0
- package/dist/test/test-m1-completion.js +124 -0
- package/dist/test/test-m1-completion.js.map +1 -0
- package/dist/test/test-memory-injection-prompt.d.ts +2 -0
- package/dist/test/test-memory-injection-prompt.d.ts.map +1 -0
- package/dist/test/test-memory-injection-prompt.js +299 -0
- package/dist/test/test-memory-injection-prompt.js.map +1 -0
- package/dist/test/test-performance-alerts.d.ts +7 -0
- package/dist/test/test-performance-alerts.d.ts.map +1 -0
- package/dist/test/test-performance-alerts.js +109 -0
- package/dist/test/test-performance-alerts.js.map +1 -0
- package/dist/test/test-performance-monitor.d.ts +2 -0
- package/dist/test/test-performance-monitor.d.ts.map +1 -0
- package/dist/test/test-performance-monitor.js +182 -0
- package/dist/test/test-performance-monitor.js.map +1 -0
- package/dist/test/test-performance-monitoring.d.ts +6 -0
- package/dist/test/test-performance-monitoring.d.ts.map +1 -0
- package/dist/test/test-performance-monitoring.js +156 -0
- package/dist/test/test-performance-monitoring.js.map +1 -0
- package/dist/test/test-search.d.ts +5 -0
- package/dist/test/test-search.d.ts.map +1 -0
- package/dist/test/test-search.js +141 -0
- package/dist/test/test-search.js.map +1 -0
- package/dist/test/test-simple-alerts.d.ts +6 -0
- package/dist/test/test-simple-alerts.d.ts.map +1 -0
- package/dist/test/test-simple-alerts.js +106 -0
- package/dist/test/test-simple-alerts.js.map +1 -0
- package/dist/test/test-vector-search-engine.d.ts +2 -0
- package/dist/test/test-vector-search-engine.d.ts.map +1 -0
- package/dist/test/test-vector-search-engine.js +225 -0
- package/dist/test/test-vector-search-engine.js.map +1 -0
- package/dist/tools/base-tool.d.ts +64 -0
- package/dist/tools/base-tool.d.ts.map +1 -0
- package/dist/tools/base-tool.js +158 -0
- package/dist/tools/base-tool.js.map +1 -0
- package/dist/tools/cleanup-memory-tool.d.ts +10 -0
- package/dist/tools/cleanup-memory-tool.d.ts.map +1 -0
- package/dist/tools/cleanup-memory-tool.js +66 -0
- package/dist/tools/cleanup-memory-tool.js.map +1 -0
- package/dist/tools/database-optimize-tool.d.ts +10 -0
- package/dist/tools/database-optimize-tool.d.ts.map +1 -0
- package/dist/tools/database-optimize-tool.js +64 -0
- package/dist/tools/database-optimize-tool.js.map +1 -0
- package/dist/tools/error-stats.d.ts +93 -0
- package/dist/tools/error-stats.d.ts.map +1 -0
- package/dist/tools/error-stats.js +115 -0
- package/dist/tools/error-stats.js.map +1 -0
- package/dist/tools/forget-tool.d.ts +63 -0
- package/dist/tools/forget-tool.d.ts.map +1 -0
- package/dist/tools/forget-tool.js +340 -0
- package/dist/tools/forget-tool.js.map +1 -0
- package/dist/tools/forgetting-stats-tool.d.ts +10 -0
- package/dist/tools/forgetting-stats-tool.d.ts.map +1 -0
- package/dist/tools/forgetting-stats-tool.js +37 -0
- package/dist/tools/forgetting-stats-tool.js.map +1 -0
- package/dist/tools/index.d.ts +33 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +55 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/memory-injection-prompt.d.ts +31 -0
- package/dist/tools/memory-injection-prompt.d.ts.map +1 -0
- package/dist/tools/memory-injection-prompt.js +203 -0
- package/dist/tools/memory-injection-prompt.js.map +1 -0
- package/dist/tools/performance-alerts.d.ts +127 -0
- package/dist/tools/performance-alerts.d.ts.map +1 -0
- package/dist/tools/performance-alerts.js +208 -0
- package/dist/tools/performance-alerts.js.map +1 -0
- package/dist/tools/performance-stats-tool.d.ts +10 -0
- package/dist/tools/performance-stats-tool.d.ts.map +1 -0
- package/dist/tools/performance-stats-tool.js +38 -0
- package/dist/tools/performance-stats-tool.js.map +1 -0
- package/dist/tools/pin-tool.d.ts +39 -0
- package/dist/tools/pin-tool.d.ts.map +1 -0
- package/dist/tools/pin-tool.js +211 -0
- package/dist/tools/pin-tool.js.map +1 -0
- package/dist/tools/recall-tool.d.ts +27 -0
- package/dist/tools/recall-tool.d.ts.map +1 -0
- package/dist/tools/recall-tool.js +335 -0
- package/dist/tools/recall-tool.js.map +1 -0
- package/dist/tools/remember-tool.d.ts +10 -0
- package/dist/tools/remember-tool.d.ts.map +1 -0
- package/dist/tools/remember-tool.js +101 -0
- package/dist/tools/remember-tool.js.map +1 -0
- package/dist/tools/resolve-error.d.ts +54 -0
- package/dist/tools/resolve-error.d.ts.map +1 -0
- package/dist/tools/resolve-error.js +63 -0
- package/dist/tools/resolve-error.js.map +1 -0
- package/dist/tools/tool-registry.d.ts +134 -0
- package/dist/tools/tool-registry.d.ts.map +1 -0
- package/dist/tools/tool-registry.js +337 -0
- package/dist/tools/tool-registry.js.map +1 -0
- package/dist/tools/types.d.ts +56 -0
- package/dist/tools/types.d.ts.map +1 -0
- package/dist/tools/types.js +23 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/tools/unpin-tool.d.ts +43 -0
- package/dist/tools/unpin-tool.d.ts.map +1 -0
- package/dist/tools/unpin-tool.js +233 -0
- package/dist/tools/unpin-tool.js.map +1 -0
- package/dist/types/embedding.types.d.ts +65 -0
- package/dist/types/embedding.types.d.ts.map +1 -0
- package/dist/types/embedding.types.js +6 -0
- package/dist/types/embedding.types.js.map +1 -0
- package/dist/types/index.d.ts +103 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +5 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/database.d.ts +62 -0
- package/dist/utils/database.d.ts.map +1 -0
- package/dist/utils/database.js +399 -0
- package/dist/utils/database.js.map +1 -0
- package/dist/utils/stopwords.d.ts +18 -0
- package/dist/utils/stopwords.d.ts.map +1 -0
- package/dist/utils/stopwords.js +117 -0
- package/dist/utils/stopwords.js.map +1 -0
- package/docker-compose.dev.yml +50 -0
- package/docker-compose.prod.yml +77 -0
- package/docker-compose.yml +43 -0
- package/docs/en/Memento-Goals.md +217 -0
- package/docs/en/Memento-M1-DetailSpecs.md +130 -0
- package/docs/en/Memento-Milestones.md +135 -0
- package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +177 -0
- package/docs/en/api-reference.md +658 -0
- package/docs/en/architecture.md +1302 -0
- package/docs/en/developer-guide.md +1005 -0
- package/docs/en/user-manual.md +595 -0
- package/docs/ko/Memento-Goals.md +217 -0
- package/docs/ko/Memento-M1-DetailSpecs.md +130 -0
- package/docs/ko/Memento-Milestones.md +134 -0
- package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +177 -0
- package/docs/ko/api-reference.md +658 -0
- package/docs/ko/architecture.md +1302 -0
- package/docs/ko/developer-guide.md +1006 -0
- package/docs/ko/embedding-api-reference.md +122 -0
- package/docs/ko/embedding-configuration.md +62 -0
- package/docs/ko/embedding-performance-benchmark.md +62 -0
- package/docs/ko/embedding-service-guide.md +314 -0
- package/docs/ko/user-manual.md +595 -0
- package/env.example +49 -0
- package/install.sh +191 -0
- package/mcp-http-client.js +218 -0
- package/mcp.json +0 -0
- package/package.json +125 -0
- package/packages/mcp-client/docs/API-REFERENCE.md +560 -0
- package/packages/mcp-client/docs/BEST-PRACTICES.md +564 -0
- package/packages/mcp-client/docs/MIGRATION-GUIDE.md +344 -0
- package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +476 -0
- package/packages/mcp-client/docs/TROUBLESHOOTING.md +564 -0
- package/packages/mcp-client/package-lock.json +907 -0
- package/packages/mcp-client/package.json +58 -0
- package/packages/mcp-client/performance-optimizer.js +428 -0
- package/packages/mcp-client/test-basic.js +65 -0
- package/packages/mcp-client/test-integration.js +366 -0
- package/scripts/auto-setup.js +234 -0
- package/scripts/backup-daily.bat +28 -0
- package/scripts/backup-embeddings.js +108 -0
- package/scripts/check-db-integrity.js +93 -0
- package/scripts/debug-embeddings.js +184 -0
- package/scripts/direct-sql-migration.sql +36 -0
- package/scripts/docker-migration.sh +105 -0
- package/scripts/fix-migration.js +93 -0
- package/scripts/fix-vector-dimensions.js +206 -0
- package/scripts/migrate-embedding-data.js +307 -0
- package/scripts/regenerate-embeddings.js +144 -0
- package/scripts/restore-legacy.ps1 +60 -0
- package/scripts/restore-legacy.sh +62 -0
- package/scripts/run-migration.js +122 -0
- package/scripts/safe-migration.js +150 -0
- package/scripts/simple-migrate.js +41 -0
- package/scripts/simple-update.js +123 -0
- package/scripts/start-container.sh +10 -0
- package/src/algorithms/forgetting-algorithm.spec.ts +538 -0
- package/src/algorithms/forgetting-algorithm.ts +243 -0
- package/src/algorithms/hybrid-search-engine.spec.ts +484 -0
- package/src/algorithms/hybrid-search-engine.ts +489 -0
- package/src/algorithms/search-engine.spec.ts +429 -0
- package/src/algorithms/search-engine.ts +392 -0
- package/src/algorithms/search-ranking.spec.ts +293 -0
- package/src/algorithms/search-ranking.ts +407 -0
- package/src/algorithms/spaced-repetition.spec.ts +510 -0
- package/src/algorithms/spaced-repetition.ts +238 -0
- package/src/algorithms/vector-search-engine.ts +505 -0
- package/src/client/index.spec.ts +427 -0
- package/src/client/index.ts +222 -0
- package/src/config/index.spec.ts +339 -0
- package/src/config/index.ts +106 -0
- package/src/database/init.spec.ts +239 -0
- package/src/database/init.ts +130 -0
- package/src/database/migrate.spec.ts +293 -0
- package/src/database/migrate.ts +94 -0
- package/src/database/migrations/001_add_embedding_metadata.sql +29 -0
- package/src/database/schema.sql +159 -0
- package/src/npm-client/context-injector.spec.ts +335 -0
- package/src/npm-client/context-injector.ts +412 -0
- package/src/npm-client/index.spec.ts +108 -0
- package/src/npm-client/index.ts +96 -0
- package/src/npm-client/memento-client.spec.ts +549 -0
- package/src/npm-client/memento-client.ts +501 -0
- package/src/npm-client/memory-manager.spec.ts +374 -0
- package/src/npm-client/memory-manager.ts +414 -0
- package/src/npm-client/types.spec.ts +427 -0
- package/src/npm-client/types.ts +296 -0
- package/src/npm-client/utils.spec.ts +355 -0
- package/src/npm-client/utils.ts +423 -0
- package/src/scripts/copy-assets.js +37 -0
- package/src/server/http-server.spec.ts +648 -0
- package/src/server/http-server.ts +1030 -0
- package/src/server/index-backup.ts +875 -0
- package/src/server/index-refactored.ts +237 -0
- package/src/server/index.spec.ts +281 -0
- package/src/server/index.ts +347 -0
- package/src/server/simple-mcp-server.spec.ts +207 -0
- package/src/server/simple-mcp-server.ts +173 -0
- package/src/services/async-optimizer.spec.ts +569 -0
- package/src/services/async-optimizer.ts +484 -0
- package/src/services/batch-scheduler.ts +759 -0
- package/src/services/cache-service.spec.ts +372 -0
- package/src/services/cache-service.ts +434 -0
- package/src/services/database-optimizer.spec.ts +344 -0
- package/src/services/database-optimizer.ts +450 -0
- package/src/services/embedding-provider-factory.ts +173 -0
- package/src/services/embedding-service.spec.ts +342 -0
- package/src/services/embedding-service.ts +333 -0
- package/src/services/error-logging-service.spec.ts +416 -0
- package/src/services/error-logging-service.ts +383 -0
- package/src/services/forgetting-policy-service.spec.ts +140 -0
- package/src/services/forgetting-policy-service.ts +334 -0
- package/src/services/gemini-embedding-service.spec.ts +463 -0
- package/src/services/gemini-embedding-service.ts +283 -0
- package/src/services/lightweight-embedding-service.spec.ts +458 -0
- package/src/services/lightweight-embedding-service.ts +324 -0
- package/src/services/memory-embedding-service.spec.ts +417 -0
- package/src/services/memory-embedding-service.ts +289 -0
- package/src/services/minilm-embedding-service.spec.ts +104 -0
- package/src/services/minilm-embedding-service.ts +262 -0
- package/src/services/performance-alert-service.spec.ts +517 -0
- package/src/services/performance-alert-service.ts +477 -0
- package/src/services/performance-monitor.spec.ts +401 -0
- package/src/services/performance-monitor.ts +532 -0
- package/src/services/performance-monitoring-integration.spec.ts +478 -0
- package/src/services/performance-monitoring-integration.ts.bak +276 -0
- package/src/services/unified-embedding-service.spec.ts +224 -0
- package/src/services/unified-embedding-service.ts +255 -0
- package/src/test/debug-http-v2.ts +30 -0
- package/src/test/embedding-integration-test.spec.ts +295 -0
- package/src/test/embedding-integration-test.ts +295 -0
- package/src/test/embedding-performance-benchmark.spec.ts +354 -0
- package/src/test/embedding-performance-benchmark.ts +312 -0
- package/src/test/performance-benchmark.ts +565 -0
- package/src/test/test-alerts-direct.ts +136 -0
- package/src/test/test-batch-scheduler-simple.spec.ts +122 -0
- package/src/test/test-batch-scheduler.spec.ts +453 -0
- package/src/test/test-batch-scheduler.ts +182 -0
- package/src/test/test-client.ts +97 -0
- package/src/test/test-embedding.ts +153 -0
- package/src/test/test-error-handling.spec.ts +575 -0
- package/src/test/test-error-logging.ts +117 -0
- package/src/test/test-forgetting.ts +162 -0
- package/src/test/test-gemini-embedding.ts +159 -0
- package/src/test/test-http-server-v2-simple.ts +147 -0
- package/src/test/test-http-server-v2.ts +586 -0
- package/src/test/test-hybrid-search-engine.spec.ts +521 -0
- package/src/test/test-integration-fixed.spec.ts +612 -0
- package/src/test/test-integration.spec.ts +463 -0
- package/src/test/test-lightweight-embedding.ts +208 -0
- package/src/test/test-m1-completion.spec.ts +614 -0
- package/src/test/test-m1-completion.ts +141 -0
- package/src/test/test-m1-integration.spec.ts +514 -0
- package/src/test/test-memory-injection-prompt.spec.ts +650 -0
- package/src/test/test-memory-injection-prompt.ts +391 -0
- package/src/test/test-performance-alerts.ts +125 -0
- package/src/test/test-performance-monitor-updates.spec.ts +490 -0
- package/src/test/test-performance-monitor.spec.ts +284 -0
- package/src/test/test-performance-monitor.ts +228 -0
- package/src/test/test-performance-monitoring.ts +171 -0
- package/src/test/test-search.ts +151 -0
- package/src/test/test-simple-alerts.ts +136 -0
- package/src/test/test-vector-search-engine.spec.ts +408 -0
- package/src/test/test-vector-search-engine.ts +303 -0
- package/src/tools/base-tool.ts +189 -0
- package/src/tools/cleanup-memory-tool.ts +77 -0
- package/src/tools/database-optimize-tool.ts +79 -0
- package/src/tools/error-stats.ts +119 -0
- package/src/tools/forget-tool.spec.ts +613 -0
- package/src/tools/forget-tool.ts +454 -0
- package/src/tools/forgetting-stats-tool.ts +47 -0
- package/src/tools/index.ts +71 -0
- package/src/tools/memory-injection-prompt.ts +257 -0
- package/src/tools/performance-alerts.ts +226 -0
- package/src/tools/performance-stats-tool.ts +48 -0
- package/src/tools/pin-tool.spec.ts +497 -0
- package/src/tools/pin-tool.ts +277 -0
- package/src/tools/recall-tool.spec.ts +475 -0
- package/src/tools/recall-tool.ts +389 -0
- package/src/tools/remember-tool.spec.ts +469 -0
- package/src/tools/remember-tool.ts +112 -0
- package/src/tools/resolve-error.ts +69 -0
- package/src/tools/tool-registry.ts +417 -0
- package/src/tools/types.ts +63 -0
- package/src/tools/unpin-tool.spec.ts +549 -0
- package/src/tools/unpin-tool.ts +306 -0
- package/src/types/embedding.types.ts +78 -0
- package/src/types/index.spec.ts +420 -0
- package/src/types/index.ts +117 -0
- package/src/utils/database.spec.ts +77 -0
- package/src/utils/database.ts +458 -0
- package/src/utils/stopwords.ts +128 -0
- package/start-docker-setup.bat +38 -0
- package/static/logo.png +0 -0
- package/static/memento_logo.svg +2 -0
- package/test-docker.js +103 -0
- package/tsconfig.json +46 -0
- package/vitest.config.ts +23 -0
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SQLite 데이터베이스 초기화 스크립트
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import Database from 'better-sqlite3';
|
|
6
|
+
import { readFileSync } from 'fs';
|
|
7
|
+
import { join, dirname } from 'path';
|
|
8
|
+
import { fileURLToPath } from 'url';
|
|
9
|
+
import { mementoConfig } from '../config/index.js';
|
|
10
|
+
|
|
11
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
12
|
+
const __dirname = dirname(__filename);
|
|
13
|
+
|
|
14
|
+
// MCP 서버에서는 모든 로그 출력을 완전히 차단
|
|
15
|
+
const log = (...args: any[]) => {};
|
|
16
|
+
|
|
17
|
+
export async function initializeDatabase(): Promise<Database.Database> {
|
|
18
|
+
log('🗄️ SQLite 데이터베이스 초기화 중...');
|
|
19
|
+
|
|
20
|
+
// 데이터 디렉토리 생성
|
|
21
|
+
const dbDir = dirname(mementoConfig.dbPath);
|
|
22
|
+
try {
|
|
23
|
+
const fs = require('fs');
|
|
24
|
+
if (!fs.existsSync(dbDir)) {
|
|
25
|
+
fs.mkdirSync(dbDir, { recursive: true });
|
|
26
|
+
}
|
|
27
|
+
} catch (error) {
|
|
28
|
+
// 디렉토리가 이미 존재하는 경우 무시
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
try {
|
|
32
|
+
// SQLite 데이터베이스 연결
|
|
33
|
+
const db = new Database(mementoConfig.dbPath);
|
|
34
|
+
|
|
35
|
+
// WAL 모드 사용 (동시 읽기 성능 향상)
|
|
36
|
+
db.pragma('journal_mode = WAL');
|
|
37
|
+
|
|
38
|
+
// 외래키 제약 조건 활성화
|
|
39
|
+
db.pragma('foreign_keys = ON');
|
|
40
|
+
|
|
41
|
+
// FTS5 확장 로드 시도 (Docker 환경에서는 더 안정적)
|
|
42
|
+
try {
|
|
43
|
+
// Docker 환경에서는 FTS5가 기본적으로 포함되어 있음
|
|
44
|
+
if (process.env.NODE_ENV === 'production' || process.env.DOCKER === 'true') {
|
|
45
|
+
// Docker 환경에서는 FTS5가 기본 포함되어 있으므로 로드 시도하지 않음
|
|
46
|
+
log('🐳 Docker 환경에서 FTS5 사용 가능');
|
|
47
|
+
} else {
|
|
48
|
+
// 로컬 환경에서만 확장 로드 시도
|
|
49
|
+
db.loadExtension('fts5');
|
|
50
|
+
log('✅ FTS5 확장 로드 완료');
|
|
51
|
+
}
|
|
52
|
+
} catch (error) {
|
|
53
|
+
log('⚠️ FTS5 확장 로드 실패, 기본 검색으로 전환:', error);
|
|
54
|
+
// FTS5가 없어도 기본 기능은 동작하도록 계속 진행
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
// 잠금 타임아웃 설정 (60초로 증가)
|
|
58
|
+
db.pragma('busy_timeout = 60000');
|
|
59
|
+
|
|
60
|
+
// 동시성 설정 최적화
|
|
61
|
+
db.pragma('synchronous = NORMAL');
|
|
62
|
+
db.pragma('cache_size = 20000'); // 캐시 크기 증가
|
|
63
|
+
db.pragma('temp_store = MEMORY');
|
|
64
|
+
db.pragma('mmap_size = 268435456'); // 256MB 메모리 맵핑
|
|
65
|
+
|
|
66
|
+
// WAL 설정 최적화 (락 문제 해결)
|
|
67
|
+
db.pragma('wal_autocheckpoint = 100'); // 더 자주 체크포인트 (100페이지마다)
|
|
68
|
+
db.pragma('journal_size_limit = 33554432'); // 32MB WAL 크기 제한 (더 작게)
|
|
69
|
+
db.pragma('wal_checkpoint(TRUNCATE)'); // WAL 파일 정리
|
|
70
|
+
|
|
71
|
+
// 추가 안정성 설정
|
|
72
|
+
db.pragma('locking_mode = NORMAL'); // 정상 잠금 모드
|
|
73
|
+
db.pragma('read_uncommitted = 0'); // 커밋된 읽기만 허용
|
|
74
|
+
|
|
75
|
+
// sqlite-vec 확장 로드
|
|
76
|
+
try {
|
|
77
|
+
const { getLoadablePath } = await import('sqlite-vec');
|
|
78
|
+
const extensionPath = getLoadablePath();
|
|
79
|
+
db.loadExtension(extensionPath);
|
|
80
|
+
console.log('✅ sqlite-vec 확장 로드 성공');
|
|
81
|
+
} catch (error) {
|
|
82
|
+
console.warn('⚠️ sqlite-vec 확장 로드 실패 (벡터 검색 기능 비활성화):', error);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// 스키마 파일 읽기 및 실행
|
|
86
|
+
const schemaPath = join(__dirname, 'schema.sql');
|
|
87
|
+
const schema = readFileSync(schemaPath, 'utf-8');
|
|
88
|
+
|
|
89
|
+
// 스키마 실행
|
|
90
|
+
db.exec(schema);
|
|
91
|
+
|
|
92
|
+
log('✅ 데이터베이스 초기화 완료');
|
|
93
|
+
log(`📁 데이터베이스 경로: ${mementoConfig.dbPath}`);
|
|
94
|
+
|
|
95
|
+
return db;
|
|
96
|
+
} catch (error) {
|
|
97
|
+
log('❌ 데이터베이스 초기화 실패:', error);
|
|
98
|
+
throw error;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
export function closeDatabase(db: Database.Database): void {
|
|
103
|
+
if (!db) {
|
|
104
|
+
log('🔒 데이터베이스가 이미 닫혔습니다');
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
try {
|
|
109
|
+
db.close();
|
|
110
|
+
log('🔒 데이터베이스 연결 종료');
|
|
111
|
+
} catch (error) {
|
|
112
|
+
log('❌ 데이터베이스 종료 실패:', error);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// CLI에서 직접 실행할 때
|
|
117
|
+
if (process.argv[1] && process.argv[1].endsWith('init.ts')) {
|
|
118
|
+
console.log('🚀 데이터베이스 초기화 스크립트 시작');
|
|
119
|
+
(async () => {
|
|
120
|
+
try {
|
|
121
|
+
const db = await initializeDatabase();
|
|
122
|
+
console.log('🎉 데이터베이스 초기화 성공!');
|
|
123
|
+
closeDatabase(db);
|
|
124
|
+
process.exit(0);
|
|
125
|
+
} catch (error) {
|
|
126
|
+
console.error('❌ 데이터베이스 초기화 실패:', error);
|
|
127
|
+
process.exit(1);
|
|
128
|
+
}
|
|
129
|
+
})();
|
|
130
|
+
}
|
|
@@ -0,0 +1,293 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, vi, afterEach } from 'vitest';
|
|
2
|
+
import { migrateDatabase } from './migrate.js';
|
|
3
|
+
import Database from 'better-sqlite3';
|
|
4
|
+
import { mementoConfig } from '../config/index.js';
|
|
5
|
+
|
|
6
|
+
// Mock dependencies
|
|
7
|
+
vi.mock('better-sqlite3');
|
|
8
|
+
vi.mock('../config/index.js', () => ({
|
|
9
|
+
mementoConfig: {
|
|
10
|
+
dbPath: './test-data/test.db'
|
|
11
|
+
}
|
|
12
|
+
}));
|
|
13
|
+
|
|
14
|
+
describe('Database Migration', () => {
|
|
15
|
+
let mockDb: any;
|
|
16
|
+
let consoleSpy: any;
|
|
17
|
+
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
vi.clearAllMocks();
|
|
20
|
+
|
|
21
|
+
// Mock database instance
|
|
22
|
+
mockDb = {
|
|
23
|
+
exec: vi.fn(),
|
|
24
|
+
close: vi.fn(),
|
|
25
|
+
prepare: vi.fn().mockReturnValue({
|
|
26
|
+
run: vi.fn(),
|
|
27
|
+
all: vi.fn(),
|
|
28
|
+
get: vi.fn()
|
|
29
|
+
})
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
vi.mocked(Database).mockImplementation(() => mockDb);
|
|
33
|
+
|
|
34
|
+
// Mock console methods
|
|
35
|
+
consoleSpy = {
|
|
36
|
+
log: vi.spyOn(console, 'log').mockImplementation(() => {}),
|
|
37
|
+
error: vi.spyOn(console, 'error').mockImplementation(() => {})
|
|
38
|
+
};
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
afterEach(() => {
|
|
42
|
+
vi.restoreAllMocks();
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
describe('migrateDatabase', () => {
|
|
46
|
+
it('마이그레이션을 성공적으로 실행해야 함', () => {
|
|
47
|
+
mockDb.exec.mockImplementation(() => {});
|
|
48
|
+
|
|
49
|
+
migrateDatabase();
|
|
50
|
+
|
|
51
|
+
expect(Database).toHaveBeenCalledWith('./test-data/test.db');
|
|
52
|
+
expect(mockDb.close).toHaveBeenCalled();
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
it('사용성 통계 컬럼을 추가해야 함', () => {
|
|
56
|
+
mockDb.exec.mockImplementation(() => {});
|
|
57
|
+
|
|
58
|
+
migrateDatabase();
|
|
59
|
+
|
|
60
|
+
expect(mockDb.exec).toHaveBeenCalledWith('ALTER TABLE memory_item ADD COLUMN view_count INTEGER DEFAULT 0');
|
|
61
|
+
expect(mockDb.exec).toHaveBeenCalledWith('ALTER TABLE memory_item ADD COLUMN cite_count INTEGER DEFAULT 0');
|
|
62
|
+
expect(mockDb.exec).toHaveBeenCalledWith('ALTER TABLE memory_item ADD COLUMN edit_count INTEGER DEFAULT 0');
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
it('중복 컬럼 에러를 무시해야 함', () => {
|
|
66
|
+
mockDb.exec.mockImplementation((sql: string) => {
|
|
67
|
+
if (sql.includes('view_count')) {
|
|
68
|
+
throw new Error('duplicate column name: view_count');
|
|
69
|
+
}
|
|
70
|
+
if (sql.includes('cite_count')) {
|
|
71
|
+
throw new Error('duplicate column name: cite_count');
|
|
72
|
+
}
|
|
73
|
+
if (sql.includes('edit_count')) {
|
|
74
|
+
throw new Error('duplicate column name: edit_count');
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
expect(() => migrateDatabase()).not.toThrow();
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
it('중복 컬럼이 아닌 다른 에러는 던져야 함', () => {
|
|
82
|
+
mockDb.exec.mockImplementation((sql: string) => {
|
|
83
|
+
if (sql.includes('view_count')) {
|
|
84
|
+
throw new Error('table not found');
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
expect(() => migrateDatabase()).toThrow('table not found');
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
it('임베딩 테이블을 생성해야 함', () => {
|
|
92
|
+
mockDb.exec.mockImplementation(() => {});
|
|
93
|
+
|
|
94
|
+
migrateDatabase();
|
|
95
|
+
|
|
96
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE TABLE IF NOT EXISTS memory_embedding'));
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
it('임베딩 인덱스를 생성해야 함', () => {
|
|
100
|
+
mockDb.exec.mockImplementation(() => {});
|
|
101
|
+
|
|
102
|
+
migrateDatabase();
|
|
103
|
+
|
|
104
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE INDEX IF NOT EXISTS idx_memory_embedding_memory_id'));
|
|
105
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE INDEX IF NOT EXISTS idx_memory_embedding_model'));
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
it('링크 테이블을 생성해야 함', () => {
|
|
109
|
+
mockDb.exec.mockImplementation(() => {});
|
|
110
|
+
|
|
111
|
+
migrateDatabase();
|
|
112
|
+
|
|
113
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE TABLE IF NOT EXISTS memory_link'));
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
it('링크 인덱스를 생성해야 함', () => {
|
|
117
|
+
mockDb.exec.mockImplementation(() => {});
|
|
118
|
+
|
|
119
|
+
migrateDatabase();
|
|
120
|
+
|
|
121
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE INDEX IF NOT EXISTS idx_memory_link_source'));
|
|
122
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE INDEX IF NOT EXISTS idx_memory_link_target'));
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
it('피드백 테이블을 생성해야 함', () => {
|
|
126
|
+
mockDb.exec.mockImplementation(() => {});
|
|
127
|
+
|
|
128
|
+
migrateDatabase();
|
|
129
|
+
|
|
130
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE TABLE IF NOT EXISTS memory_feedback'));
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
it('피드백 인덱스를 생성해야 함', () => {
|
|
134
|
+
mockDb.exec.mockImplementation(() => {});
|
|
135
|
+
|
|
136
|
+
migrateDatabase();
|
|
137
|
+
|
|
138
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE INDEX IF NOT EXISTS idx_memory_feedback_memory_id'));
|
|
139
|
+
expect(mockDb.exec).toHaveBeenCalledWith(expect.stringContaining('CREATE INDEX IF NOT EXISTS idx_memory_feedback_event_type'));
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
it('성공 메시지를 출력해야 함', () => {
|
|
143
|
+
mockDb.exec.mockImplementation(() => {});
|
|
144
|
+
|
|
145
|
+
migrateDatabase();
|
|
146
|
+
|
|
147
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('🔄 데이터베이스 마이그레이션 시작');
|
|
148
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('📊 사용성 통계 컬럼 추가 중...');
|
|
149
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('✅ 사용성 통계 컬럼 추가 완료');
|
|
150
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('🧠 임베딩 테이블 생성 중...');
|
|
151
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('✅ 임베딩 테이블 생성 완료');
|
|
152
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('🔗 링크 테이블 생성 중...');
|
|
153
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('✅ 링크 테이블 생성 완료');
|
|
154
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('💬 피드백 테이블 생성 중...');
|
|
155
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('✅ 피드백 테이블 생성 완료');
|
|
156
|
+
expect(consoleSpy.log).toHaveBeenCalledWith('🎉 데이터베이스 마이그레이션 완료');
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
it('에러 발생 시 에러 메시지를 출력하고 에러를 던져야 함', () => {
|
|
160
|
+
const error = new Error('Migration failed');
|
|
161
|
+
mockDb.exec.mockImplementation(() => {
|
|
162
|
+
throw error;
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
expect(() => migrateDatabase()).toThrow('Migration failed');
|
|
166
|
+
expect(consoleSpy.error).toHaveBeenCalledWith('❌ 데이터베이스 마이그레이션 실패:', error);
|
|
167
|
+
});
|
|
168
|
+
|
|
169
|
+
it('데이터베이스 연결 실패 시 에러를 던져야 함', () => {
|
|
170
|
+
vi.mocked(Database).mockImplementation(() => {
|
|
171
|
+
throw new Error('Connection failed');
|
|
172
|
+
});
|
|
173
|
+
|
|
174
|
+
expect(() => migrateDatabase()).toThrow('Connection failed');
|
|
175
|
+
});
|
|
176
|
+
|
|
177
|
+
it('마이그레이션 완료 후 데이터베이스를 닫아야 함', () => {
|
|
178
|
+
mockDb.exec.mockImplementation(() => {});
|
|
179
|
+
|
|
180
|
+
migrateDatabase();
|
|
181
|
+
|
|
182
|
+
expect(mockDb.close).toHaveBeenCalled();
|
|
183
|
+
});
|
|
184
|
+
|
|
185
|
+
it('에러 발생 시에도 데이터베이스를 닫아야 함', () => {
|
|
186
|
+
mockDb.exec.mockImplementation(() => {
|
|
187
|
+
throw new Error('Migration failed');
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
try {
|
|
191
|
+
migrateDatabase();
|
|
192
|
+
} catch (error) {
|
|
193
|
+
// Expected error
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
expect(mockDb.close).toHaveBeenCalled();
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
describe('테이블 생성', () => {
|
|
201
|
+
it('임베딩 테이블에 올바른 컬럼을 포함해야 함', () => {
|
|
202
|
+
mockDb.exec.mockImplementation(() => {});
|
|
203
|
+
|
|
204
|
+
migrateDatabase();
|
|
205
|
+
|
|
206
|
+
const embeddingTableCall = mockDb.exec.mock.calls.find(call =>
|
|
207
|
+
call[0].includes('CREATE TABLE IF NOT EXISTS memory_embedding')
|
|
208
|
+
);
|
|
209
|
+
|
|
210
|
+
expect(embeddingTableCall).toBeDefined();
|
|
211
|
+
expect(embeddingTableCall[0]).toContain('memory_id TEXT NOT NULL');
|
|
212
|
+
expect(embeddingTableCall[0]).toContain('embedding BLOB NOT NULL');
|
|
213
|
+
expect(embeddingTableCall[0]).toContain('model TEXT NOT NULL');
|
|
214
|
+
expect(embeddingTableCall[0]).toContain('created_at DATETIME DEFAULT CURRENT_TIMESTAMP');
|
|
215
|
+
});
|
|
216
|
+
|
|
217
|
+
it('링크 테이블에 올바른 컬럼을 포함해야 함', () => {
|
|
218
|
+
mockDb.exec.mockImplementation(() => {});
|
|
219
|
+
|
|
220
|
+
migrateDatabase();
|
|
221
|
+
|
|
222
|
+
const linkTableCall = mockDb.exec.mock.calls.find(call =>
|
|
223
|
+
call[0].includes('CREATE TABLE IF NOT EXISTS memory_link')
|
|
224
|
+
);
|
|
225
|
+
|
|
226
|
+
expect(linkTableCall).toBeDefined();
|
|
227
|
+
expect(linkTableCall[0]).toContain('source_id TEXT NOT NULL');
|
|
228
|
+
expect(linkTableCall[0]).toContain('target_id TEXT NOT NULL');
|
|
229
|
+
expect(linkTableCall[0]).toContain('relation_type TEXT NOT NULL');
|
|
230
|
+
expect(linkTableCall[0]).toContain('created_at DATETIME DEFAULT CURRENT_TIMESTAMP');
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
it('피드백 테이블에 올바른 컬럼을 포함해야 함', () => {
|
|
234
|
+
mockDb.exec.mockImplementation(() => {});
|
|
235
|
+
|
|
236
|
+
migrateDatabase();
|
|
237
|
+
|
|
238
|
+
const feedbackTableCall = mockDb.exec.mock.calls.find(call =>
|
|
239
|
+
call[0].includes('CREATE TABLE IF NOT EXISTS memory_feedback')
|
|
240
|
+
);
|
|
241
|
+
|
|
242
|
+
expect(feedbackTableCall).toBeDefined();
|
|
243
|
+
expect(feedbackTableCall[0]).toContain('memory_id TEXT NOT NULL');
|
|
244
|
+
expect(feedbackTableCall[0]).toContain('event_type TEXT NOT NULL');
|
|
245
|
+
expect(feedbackTableCall[0]).toContain('score REAL');
|
|
246
|
+
expect(feedbackTableCall[0]).toContain('created_at DATETIME DEFAULT CURRENT_TIMESTAMP');
|
|
247
|
+
});
|
|
248
|
+
});
|
|
249
|
+
|
|
250
|
+
describe('인덱스 생성', () => {
|
|
251
|
+
it('임베딩 테이블에 필요한 인덱스를 생성해야 함', () => {
|
|
252
|
+
mockDb.exec.mockImplementation(() => {});
|
|
253
|
+
|
|
254
|
+
migrateDatabase();
|
|
255
|
+
|
|
256
|
+
const indexCalls = mockDb.exec.mock.calls.filter(call =>
|
|
257
|
+
call[0].includes('CREATE INDEX IF NOT EXISTS idx_memory_embedding')
|
|
258
|
+
);
|
|
259
|
+
|
|
260
|
+
expect(indexCalls).toHaveLength(2);
|
|
261
|
+
expect(indexCalls.some(call => call[0].includes('memory_id'))).toBe(true);
|
|
262
|
+
expect(indexCalls.some(call => call[0].includes('model'))).toBe(true);
|
|
263
|
+
});
|
|
264
|
+
|
|
265
|
+
it('링크 테이블에 필요한 인덱스를 생성해야 함', () => {
|
|
266
|
+
mockDb.exec.mockImplementation(() => {});
|
|
267
|
+
|
|
268
|
+
migrateDatabase();
|
|
269
|
+
|
|
270
|
+
const indexCalls = mockDb.exec.mock.calls.filter(call =>
|
|
271
|
+
call[0].includes('CREATE INDEX IF NOT EXISTS idx_memory_link')
|
|
272
|
+
);
|
|
273
|
+
|
|
274
|
+
expect(indexCalls).toHaveLength(2);
|
|
275
|
+
expect(indexCalls.some(call => call[0].includes('source_id'))).toBe(true);
|
|
276
|
+
expect(indexCalls.some(call => call[0].includes('target_id'))).toBe(true);
|
|
277
|
+
});
|
|
278
|
+
|
|
279
|
+
it('피드백 테이블에 필요한 인덱스를 생성해야 함', () => {
|
|
280
|
+
mockDb.exec.mockImplementation(() => {});
|
|
281
|
+
|
|
282
|
+
migrateDatabase();
|
|
283
|
+
|
|
284
|
+
const indexCalls = mockDb.exec.mock.calls.filter(call =>
|
|
285
|
+
call[0].includes('CREATE INDEX IF NOT EXISTS idx_memory_feedback')
|
|
286
|
+
);
|
|
287
|
+
|
|
288
|
+
expect(indexCalls).toHaveLength(2);
|
|
289
|
+
expect(indexCalls.some(call => call[0].includes('memory_id'))).toBe(true);
|
|
290
|
+
expect(indexCalls.some(call => call[0].includes('event_type'))).toBe(true);
|
|
291
|
+
});
|
|
292
|
+
});
|
|
293
|
+
});
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 데이터베이스 마이그레이션 스크립트
|
|
3
|
+
* 기존 데이터베이스에 새 컬럼 추가
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import Database from 'better-sqlite3';
|
|
7
|
+
import { mementoConfig } from '../config/index.js';
|
|
8
|
+
|
|
9
|
+
function migrateDatabase() {
|
|
10
|
+
console.log('🔄 데이터베이스 마이그레이션 시작');
|
|
11
|
+
|
|
12
|
+
const db = new Database(mementoConfig.dbPath);
|
|
13
|
+
|
|
14
|
+
try {
|
|
15
|
+
// 사용성 통계 컬럼 추가
|
|
16
|
+
console.log('📊 사용성 통계 컬럼 추가 중...');
|
|
17
|
+
|
|
18
|
+
try {
|
|
19
|
+
db.exec('ALTER TABLE memory_item ADD COLUMN view_count INTEGER DEFAULT 0');
|
|
20
|
+
} catch (err: any) {
|
|
21
|
+
if (!err.message.includes('duplicate column name')) {
|
|
22
|
+
throw err;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
try {
|
|
27
|
+
db.exec('ALTER TABLE memory_item ADD COLUMN cite_count INTEGER DEFAULT 0');
|
|
28
|
+
} catch (err: any) {
|
|
29
|
+
if (!err.message.includes('duplicate column name')) {
|
|
30
|
+
throw err;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
try {
|
|
35
|
+
db.exec('ALTER TABLE memory_item ADD COLUMN edit_count INTEGER DEFAULT 0');
|
|
36
|
+
} catch (err: any) {
|
|
37
|
+
if (!err.message.includes('duplicate column name')) {
|
|
38
|
+
throw err;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
console.log('✅ 사용성 통계 컬럼 추가 완료');
|
|
43
|
+
|
|
44
|
+
// 임베딩 테이블 생성 (기존에 없다면)
|
|
45
|
+
console.log('🧠 임베딩 테이블 생성 중...');
|
|
46
|
+
|
|
47
|
+
db.exec(`
|
|
48
|
+
CREATE TABLE IF NOT EXISTS memory_embedding (
|
|
49
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
50
|
+
memory_id TEXT NOT NULL,
|
|
51
|
+
embedding TEXT NOT NULL,
|
|
52
|
+
dim INTEGER NOT NULL,
|
|
53
|
+
model TEXT,
|
|
54
|
+
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
55
|
+
FOREIGN KEY (memory_id) REFERENCES memory_item(id) ON DELETE CASCADE,
|
|
56
|
+
UNIQUE(memory_id)
|
|
57
|
+
)
|
|
58
|
+
`);
|
|
59
|
+
|
|
60
|
+
console.log('✅ 임베딩 테이블 생성 완료');
|
|
61
|
+
|
|
62
|
+
// 기존 데이터에 기본값 설정
|
|
63
|
+
console.log('🔧 기존 데이터 업데이트 중...');
|
|
64
|
+
|
|
65
|
+
db.exec(`
|
|
66
|
+
UPDATE memory_item
|
|
67
|
+
SET view_count = 0, cite_count = 0, edit_count = 0
|
|
68
|
+
WHERE view_count IS NULL OR cite_count IS NULL OR edit_count IS NULL
|
|
69
|
+
`);
|
|
70
|
+
|
|
71
|
+
console.log('✅ 기존 데이터 업데이트 완료');
|
|
72
|
+
|
|
73
|
+
// 마이그레이션 완료
|
|
74
|
+
console.log('🎉 데이터베이스 마이그레이션 완료!');
|
|
75
|
+
|
|
76
|
+
} catch (error) {
|
|
77
|
+
console.error('❌ 마이그레이션 실패:', error);
|
|
78
|
+
throw error;
|
|
79
|
+
} finally {
|
|
80
|
+
db.close();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
// 마이그레이션 실행
|
|
85
|
+
if (process.argv[1] && process.argv[1].endsWith('migrate.ts')) {
|
|
86
|
+
try {
|
|
87
|
+
migrateDatabase();
|
|
88
|
+
console.log('✅ 마이그레이션 완료');
|
|
89
|
+
process.exit(0);
|
|
90
|
+
} catch (error) {
|
|
91
|
+
console.error('❌ 마이그레이션 실패:', error);
|
|
92
|
+
process.exit(1);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
-- 임베딩 메타데이터 추가 마이그레이션
|
|
2
|
+
-- 기존 memory_embedding 테이블에 제공자 정보 추가
|
|
3
|
+
|
|
4
|
+
-- 1. 새로운 컬럼 추가
|
|
5
|
+
ALTER TABLE memory_embedding ADD COLUMN embedding_provider TEXT;
|
|
6
|
+
ALTER TABLE memory_embedding ADD COLUMN dimensions INTEGER;
|
|
7
|
+
ALTER TABLE memory_embedding ADD COLUMN created_by TEXT DEFAULT 'migration';
|
|
8
|
+
|
|
9
|
+
-- 2. 기존 데이터 업데이트
|
|
10
|
+
-- 512차원 데이터는 TF-IDF로 추정 (기본값)
|
|
11
|
+
UPDATE memory_embedding
|
|
12
|
+
SET
|
|
13
|
+
embedding_provider = CASE
|
|
14
|
+
WHEN model = 'lightweight-hybrid' THEN 'tfidf'
|
|
15
|
+
WHEN model IS NULL OR model = '' THEN 'tfidf'
|
|
16
|
+
ELSE 'unknown'
|
|
17
|
+
END,
|
|
18
|
+
dimensions = dim,
|
|
19
|
+
created_by = 'legacy'
|
|
20
|
+
WHERE embedding_provider IS NULL;
|
|
21
|
+
|
|
22
|
+
-- 3. 인덱스 추가
|
|
23
|
+
CREATE INDEX IF NOT EXISTS idx_memory_embedding_provider ON memory_embedding(embedding_provider);
|
|
24
|
+
CREATE INDEX IF NOT EXISTS idx_memory_embedding_dimensions ON memory_embedding(dimensions);
|
|
25
|
+
CREATE INDEX IF NOT EXISTS idx_memory_embedding_created_by ON memory_embedding(created_by);
|
|
26
|
+
|
|
27
|
+
-- 4. 제약 조건 추가
|
|
28
|
+
-- embedding_provider는 유효한 값만 허용
|
|
29
|
+
-- 이 부분은 SQLite에서 CHECK 제약조건이 제한적이므로 애플리케이션 레벨에서 검증
|