stellavault 0.2.0 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/packages/core/dist/api/dashboard.d.ts +3 -0
- package/packages/core/{src/api/dashboard.ts → dist/api/dashboard.js} +8 -11
- package/packages/core/dist/api/graph-data.d.ts +11 -0
- package/packages/core/dist/api/graph-data.js +255 -0
- package/packages/core/dist/api/pwa.d.ts +3 -0
- package/packages/core/{src/api/pwa.ts → dist/api/pwa.js} +27 -32
- package/packages/core/dist/api/server.d.ts +16 -0
- package/packages/core/dist/api/server.js +647 -0
- package/packages/core/dist/capture/voice.d.ts +24 -0
- package/packages/core/dist/capture/voice.js +135 -0
- package/packages/core/{src/cloud/index.ts → dist/cloud/index.d.ts} +1 -0
- package/packages/core/dist/cloud/index.js +2 -0
- package/packages/core/dist/cloud/sync.d.ts +29 -0
- package/packages/core/dist/cloud/sync.js +137 -0
- package/packages/core/dist/config.d.ts +27 -0
- package/packages/core/dist/config.js +55 -0
- package/packages/core/dist/federation/credits.d.ts +26 -0
- package/packages/core/dist/federation/credits.js +56 -0
- package/packages/core/dist/federation/identity.d.ts +14 -0
- package/packages/core/dist/federation/identity.js +74 -0
- package/packages/core/{src/federation/index.ts → dist/federation/index.d.ts} +1 -2
- package/packages/core/dist/federation/index.js +5 -0
- package/packages/core/dist/federation/node.d.ts +31 -0
- package/packages/core/dist/federation/node.js +216 -0
- package/packages/core/dist/federation/privacy.d.ts +8 -0
- package/packages/core/dist/federation/privacy.js +40 -0
- package/packages/core/dist/federation/reputation.d.ts +37 -0
- package/packages/core/dist/federation/reputation.js +139 -0
- package/packages/core/dist/federation/search.d.ts +19 -0
- package/packages/core/dist/federation/search.js +101 -0
- package/packages/core/dist/federation/sharing.d.ts +72 -0
- package/packages/core/dist/federation/sharing.js +246 -0
- package/packages/core/dist/federation/trust.d.ts +15 -0
- package/packages/core/dist/federation/trust.js +60 -0
- package/packages/core/dist/federation/types.d.ts +40 -0
- package/packages/core/dist/federation/types.js +3 -0
- package/packages/core/dist/i18n/index.d.ts +6 -0
- package/packages/core/dist/i18n/index.js +81 -0
- package/packages/core/{src/index.ts → dist/index.d.ts} +46 -65
- package/packages/core/dist/index.js +69 -0
- package/packages/core/dist/indexer/chunker.d.ts +14 -0
- package/packages/core/dist/indexer/chunker.js +148 -0
- package/packages/core/dist/indexer/embedder.d.ts +8 -0
- package/packages/core/dist/indexer/embedder.js +3 -0
- package/packages/core/dist/indexer/index.d.ts +28 -0
- package/packages/core/dist/indexer/index.js +74 -0
- package/packages/core/dist/indexer/local-embedder.d.ts +3 -0
- package/packages/core/dist/indexer/local-embedder.js +29 -0
- package/packages/core/dist/indexer/scanner.d.ts +11 -0
- package/packages/core/dist/indexer/scanner.js +137 -0
- package/packages/core/dist/indexer/watcher.d.ts +19 -0
- package/packages/core/dist/indexer/watcher.js +49 -0
- package/packages/core/dist/intelligence/contradiction-detector.d.ts +20 -0
- package/packages/core/dist/intelligence/contradiction-detector.js +115 -0
- package/packages/core/dist/intelligence/decay-engine.d.ts +27 -0
- package/packages/core/dist/intelligence/decay-engine.js +190 -0
- package/packages/core/dist/intelligence/duplicate-detector.d.ts +20 -0
- package/packages/core/dist/intelligence/duplicate-detector.js +55 -0
- package/packages/core/dist/intelligence/fsrs.d.ts +43 -0
- package/packages/core/dist/intelligence/fsrs.js +70 -0
- package/packages/core/dist/intelligence/gap-detector.d.ts +25 -0
- package/packages/core/dist/intelligence/gap-detector.js +78 -0
- package/packages/core/dist/intelligence/learning-path.d.ts +31 -0
- package/packages/core/dist/intelligence/learning-path.js +53 -0
- package/packages/core/dist/intelligence/notifications.d.ts +31 -0
- package/packages/core/dist/intelligence/notifications.js +65 -0
- package/packages/core/dist/intelligence/predictive-gaps.d.ts +14 -0
- package/packages/core/dist/intelligence/predictive-gaps.js +74 -0
- package/packages/core/dist/intelligence/semantic-versioning.d.ts +37 -0
- package/packages/core/dist/intelligence/semantic-versioning.js +68 -0
- package/packages/core/dist/intelligence/types.d.ts +28 -0
- package/packages/core/dist/intelligence/types.js +3 -0
- package/packages/core/dist/mcp/custom-tools.d.ts +29 -0
- package/packages/core/dist/mcp/custom-tools.js +70 -0
- package/packages/core/{src/mcp/index.ts → dist/mcp/index.d.ts} +1 -0
- package/packages/core/dist/mcp/index.js +2 -0
- package/packages/core/dist/mcp/server.d.ts +49 -0
- package/packages/core/dist/mcp/server.js +133 -0
- package/packages/core/dist/mcp/tools/agentic-graph.d.ts +87 -0
- package/packages/core/dist/mcp/tools/agentic-graph.js +88 -0
- package/packages/core/dist/mcp/tools/brief.d.ts +31 -0
- package/packages/core/dist/mcp/tools/brief.js +39 -0
- package/packages/core/dist/mcp/tools/decay.d.ts +33 -0
- package/packages/core/dist/mcp/tools/decay.js +32 -0
- package/packages/core/dist/mcp/tools/decision-journal.d.ts +78 -0
- package/packages/core/dist/mcp/tools/decision-journal.js +79 -0
- package/packages/core/dist/mcp/tools/export.d.ts +29 -0
- package/packages/core/dist/mcp/tools/export.js +60 -0
- package/packages/core/dist/mcp/tools/federated-search.d.ts +29 -0
- package/packages/core/dist/mcp/tools/federated-search.js +36 -0
- package/packages/core/dist/mcp/tools/generate-claude-md.d.ts +35 -0
- package/packages/core/dist/mcp/tools/generate-claude-md.js +107 -0
- package/packages/core/dist/mcp/tools/get-document.d.ts +35 -0
- package/packages/core/dist/mcp/tools/get-document.js +25 -0
- package/packages/core/dist/mcp/tools/get-related.d.ts +32 -0
- package/packages/core/dist/mcp/tools/get-related.js +33 -0
- package/packages/core/dist/mcp/tools/learning-path.d.ts +23 -0
- package/packages/core/dist/mcp/tools/learning-path.js +45 -0
- package/packages/core/dist/mcp/tools/list-topics.d.ts +15 -0
- package/packages/core/dist/mcp/tools/list-topics.js +18 -0
- package/packages/core/dist/mcp/tools/search.d.ts +39 -0
- package/packages/core/dist/mcp/tools/search.js +29 -0
- package/packages/core/dist/mcp/tools/snapshot.d.ts +47 -0
- package/packages/core/dist/mcp/tools/snapshot.js +84 -0
- package/packages/core/dist/multi-vault/index.d.ts +26 -0
- package/packages/core/dist/multi-vault/index.js +80 -0
- package/packages/core/dist/pack/creator.d.ts +21 -0
- package/packages/core/dist/pack/creator.js +105 -0
- package/packages/core/dist/pack/exporter.d.ts +4 -0
- package/packages/core/dist/pack/exporter.js +18 -0
- package/packages/core/dist/pack/importer.d.ts +10 -0
- package/packages/core/dist/pack/importer.js +55 -0
- package/packages/core/{src/pack/index.ts → dist/pack/index.d.ts} +1 -0
- package/packages/core/dist/pack/index.js +5 -0
- package/packages/core/dist/pack/marketplace.d.ts +14 -0
- package/packages/core/dist/pack/marketplace.js +90 -0
- package/packages/core/dist/pack/pii-masker.d.ts +7 -0
- package/packages/core/dist/pack/pii-masker.js +29 -0
- package/packages/core/dist/pack/types.d.ts +36 -0
- package/packages/core/dist/pack/types.js +3 -0
- package/packages/core/dist/plugins/index.d.ts +35 -0
- package/packages/core/dist/plugins/index.js +57 -0
- package/packages/core/dist/plugins/webhooks.d.ts +30 -0
- package/packages/core/dist/plugins/webhooks.js +79 -0
- package/packages/core/dist/search/bm25.d.ts +4 -0
- package/packages/core/dist/search/bm25.js +10 -0
- package/packages/core/dist/search/index.d.ts +13 -0
- package/packages/core/dist/search/index.js +63 -0
- package/packages/core/dist/search/rrf.d.ts +7 -0
- package/packages/core/dist/search/rrf.js +21 -0
- package/packages/core/dist/search/semantic.d.ts +5 -0
- package/packages/core/dist/search/semantic.js +6 -0
- package/packages/core/{src/store/index.ts → dist/store/index.d.ts} +1 -0
- package/packages/core/dist/store/index.js +2 -0
- package/packages/core/dist/store/sqlite-vec.d.ts +6 -0
- package/packages/core/dist/store/sqlite-vec.js +251 -0
- package/packages/core/dist/store/types.d.ts +20 -0
- package/packages/core/dist/store/types.js +3 -0
- package/packages/core/dist/team/index.d.ts +25 -0
- package/packages/core/dist/team/index.js +97 -0
- package/packages/core/dist/types/chunk.d.ts +23 -0
- package/packages/core/dist/types/chunk.js +3 -0
- package/packages/core/dist/types/document.d.ts +23 -0
- package/packages/core/dist/types/document.js +3 -0
- package/packages/core/dist/types/graph.d.ts +39 -0
- package/packages/core/dist/types/graph.js +3 -0
- package/packages/core/dist/types/index.d.ts +5 -0
- package/packages/core/dist/types/index.js +2 -0
- package/packages/core/dist/types/search.d.ts +39 -0
- package/packages/core/dist/types/search.js +3 -0
- package/packages/core/dist/utils/retry.d.ts +25 -0
- package/packages/core/dist/utils/retry.js +59 -0
- package/.github/workflows/pages.yml +0 -37
- package/memory/MEMORY.md +0 -25
- package/packages/cli/dist/commands/brief-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/brief-cmd.js.map +0 -1
- package/packages/cli/dist/commands/capture-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/capture-cmd.js.map +0 -1
- package/packages/cli/dist/commands/card-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/card-cmd.js.map +0 -1
- package/packages/cli/dist/commands/clip-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/clip-cmd.js.map +0 -1
- package/packages/cli/dist/commands/cloud-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/cloud-cmd.js.map +0 -1
- package/packages/cli/dist/commands/contradictions-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/contradictions-cmd.js.map +0 -1
- package/packages/cli/dist/commands/decay-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/decay-cmd.js.map +0 -1
- package/packages/cli/dist/commands/digest-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/digest-cmd.js.map +0 -1
- package/packages/cli/dist/commands/duplicates-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/duplicates-cmd.js.map +0 -1
- package/packages/cli/dist/commands/federate-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/federate-cmd.js.map +0 -1
- package/packages/cli/dist/commands/gaps-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/gaps-cmd.js.map +0 -1
- package/packages/cli/dist/commands/graph-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/graph-cmd.js.map +0 -1
- package/packages/cli/dist/commands/index-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/index-cmd.js.map +0 -1
- package/packages/cli/dist/commands/init-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/init-cmd.js.map +0 -1
- package/packages/cli/dist/commands/learn-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/learn-cmd.js.map +0 -1
- package/packages/cli/dist/commands/pack-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/pack-cmd.js.map +0 -1
- package/packages/cli/dist/commands/review-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/review-cmd.js.map +0 -1
- package/packages/cli/dist/commands/search-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/search-cmd.js.map +0 -1
- package/packages/cli/dist/commands/serve-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/serve-cmd.js.map +0 -1
- package/packages/cli/dist/commands/status-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/status-cmd.js.map +0 -1
- package/packages/cli/dist/commands/sync-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/sync-cmd.js.map +0 -1
- package/packages/cli/dist/commands/vault-cmd.d.ts.map +0 -1
- package/packages/cli/dist/commands/vault-cmd.js.map +0 -1
- package/packages/cli/dist/index.d.ts.map +0 -1
- package/packages/cli/dist/index.js.map +0 -1
- package/packages/cli/src/commands/brief-cmd.ts +0 -87
- package/packages/cli/src/commands/capture-cmd.ts +0 -34
- package/packages/cli/src/commands/card-cmd.ts +0 -29
- package/packages/cli/src/commands/clip-cmd.ts +0 -172
- package/packages/cli/src/commands/cloud-cmd.ts +0 -75
- package/packages/cli/src/commands/contradictions-cmd.ts +0 -41
- package/packages/cli/src/commands/decay-cmd.ts +0 -57
- package/packages/cli/src/commands/digest-cmd.ts +0 -89
- package/packages/cli/src/commands/duplicates-cmd.ts +0 -38
- package/packages/cli/src/commands/federate-cmd.ts +0 -256
- package/packages/cli/src/commands/gaps-cmd.ts +0 -40
- package/packages/cli/src/commands/graph-cmd.ts +0 -88
- package/packages/cli/src/commands/index-cmd.ts +0 -65
- package/packages/cli/src/commands/init-cmd.ts +0 -145
- package/packages/cli/src/commands/learn-cmd.ts +0 -56
- package/packages/cli/src/commands/pack-cmd.ts +0 -121
- package/packages/cli/src/commands/review-cmd.ts +0 -125
- package/packages/cli/src/commands/search-cmd.ts +0 -45
- package/packages/cli/src/commands/serve-cmd.ts +0 -17
- package/packages/cli/src/commands/status-cmd.ts +0 -37
- package/packages/cli/src/commands/sync-cmd.ts +0 -68
- package/packages/cli/src/commands/vault-cmd.ts +0 -64
- package/packages/cli/src/index.ts +0 -187
- package/packages/core/src/api/graph-data.ts +0 -286
- package/packages/core/src/api/server.ts +0 -660
- package/packages/core/src/capture/voice.ts +0 -168
- package/packages/core/src/cloud/sync.ts +0 -167
- package/packages/core/src/config.ts +0 -82
- package/packages/core/src/federation/credits.ts +0 -80
- package/packages/core/src/federation/hyperswarm.d.ts +0 -19
- package/packages/core/src/federation/identity.ts +0 -90
- package/packages/core/src/federation/node.ts +0 -235
- package/packages/core/src/federation/privacy.ts +0 -52
- package/packages/core/src/federation/reputation.ts +0 -202
- package/packages/core/src/federation/search.ts +0 -129
- package/packages/core/src/federation/sharing.ts +0 -315
- package/packages/core/src/federation/trust.ts +0 -76
- package/packages/core/src/federation/types.ts +0 -25
- package/packages/core/src/i18n/index.ts +0 -85
- package/packages/core/src/indexer/chunker.ts +0 -180
- package/packages/core/src/indexer/embedder.ts +0 -9
- package/packages/core/src/indexer/index.ts +0 -113
- package/packages/core/src/indexer/local-embedder.ts +0 -35
- package/packages/core/src/indexer/scanner.ts +0 -142
- package/packages/core/src/indexer/watcher.ts +0 -62
- package/packages/core/src/intelligence/contradiction-detector.ts +0 -134
- package/packages/core/src/intelligence/decay-engine.ts +0 -229
- package/packages/core/src/intelligence/duplicate-detector.ts +0 -71
- package/packages/core/src/intelligence/fsrs.ts +0 -79
- package/packages/core/src/intelligence/gap-detector.ts +0 -109
- package/packages/core/src/intelligence/learning-path.ts +0 -86
- package/packages/core/src/intelligence/notifications.ts +0 -106
- package/packages/core/src/intelligence/predictive-gaps.ts +0 -94
- package/packages/core/src/intelligence/semantic-versioning.ts +0 -97
- package/packages/core/src/intelligence/types.ts +0 -28
- package/packages/core/src/mcp/custom-tools.ts +0 -97
- package/packages/core/src/mcp/server.ts +0 -142
- package/packages/core/src/mcp/tools/agentic-graph.ts +0 -96
- package/packages/core/src/mcp/tools/brief.ts +0 -49
- package/packages/core/src/mcp/tools/decay.ts +0 -40
- package/packages/core/src/mcp/tools/decision-journal.ts +0 -95
- package/packages/core/src/mcp/tools/export.ts +0 -72
- package/packages/core/src/mcp/tools/federated-search.ts +0 -43
- package/packages/core/src/mcp/tools/generate-claude-md.ts +0 -130
- package/packages/core/src/mcp/tools/get-document.ts +0 -26
- package/packages/core/src/mcp/tools/get-related.ts +0 -41
- package/packages/core/src/mcp/tools/learning-path.ts +0 -52
- package/packages/core/src/mcp/tools/list-topics.ts +0 -20
- package/packages/core/src/mcp/tools/search.ts +0 -35
- package/packages/core/src/mcp/tools/snapshot.ts +0 -98
- package/packages/core/src/multi-vault/index.ts +0 -118
- package/packages/core/src/pack/creator.ts +0 -127
- package/packages/core/src/pack/exporter.ts +0 -21
- package/packages/core/src/pack/importer.ts +0 -82
- package/packages/core/src/pack/marketplace.ts +0 -103
- package/packages/core/src/pack/pii-masker.ts +0 -38
- package/packages/core/src/pack/types.ts +0 -39
- package/packages/core/src/plugins/index.ts +0 -100
- package/packages/core/src/plugins/webhooks.ts +0 -110
- package/packages/core/src/search/bm25.ts +0 -16
- package/packages/core/src/search/index.ts +0 -83
- package/packages/core/src/search/rrf.ts +0 -31
- package/packages/core/src/search/semantic.ts +0 -15
- package/packages/core/src/store/sqlite-vec.ts +0 -290
- package/packages/core/src/store/types.ts +0 -22
- package/packages/core/src/team/index.ts +0 -126
- package/packages/core/src/types/chunk.ts +0 -25
- package/packages/core/src/types/document.ts +0 -24
- package/packages/core/src/types/graph.ts +0 -44
- package/packages/core/src/types/index.ts +0 -15
- package/packages/core/src/types/search.ts +0 -38
- package/packages/core/src/utils/retry.ts +0 -85
- package/packages/core/tests/api-card.test.ts +0 -60
- package/packages/core/tests/api-routes.test.ts +0 -98
- package/packages/core/tests/bm25.test.ts +0 -87
- package/packages/core/tests/chunker.test.ts +0 -48
- package/packages/core/tests/cluster.test.ts +0 -75
- package/packages/core/tests/constellation.test.ts +0 -77
- package/packages/core/tests/export-utils.test.ts +0 -97
- package/packages/core/tests/fsrs.test.ts +0 -96
- package/packages/core/tests/gesture-detector.test.ts +0 -45
- package/packages/core/tests/graph-data.test.ts +0 -87
- package/packages/core/tests/layout.test.ts +0 -83
- package/packages/core/tests/mcp.test.ts +0 -148
- package/packages/core/tests/pack.test.ts +0 -127
- package/packages/core/tests/pii-masker.test.ts +0 -42
- package/packages/core/tests/profile-card.test.ts +0 -62
- package/packages/core/tests/rrf.test.ts +0 -29
- package/packages/core/tests/search-integration.test.ts +0 -139
- package/packages/core/tests/store.test.ts +0 -80
- package/packages/graph/click-result.png +0 -0
- package/packages/graph/dist/assets/camera_utils-BMxqtvoZ.js +0 -1
- package/packages/graph/dist/assets/hands-DXA01_mx.js +0 -18
- package/packages/graph/dist/assets/index-DMEe2diW.js +0 -4192
- package/packages/graph/dist/assets/layout.worker-DbKCEFTz.js +0 -1
- package/packages/graph/dist/index.html +0 -17
- package/packages/graph/index.html +0 -17
- package/packages/graph/package.json +0 -32
- package/packages/graph/src/App.tsx +0 -7
- package/packages/graph/src/api/client.ts +0 -39
- package/packages/graph/src/components/ClusterFilter.tsx +0 -73
- package/packages/graph/src/components/ConstellationView.tsx +0 -232
- package/packages/graph/src/components/ExportPanel.tsx +0 -177
- package/packages/graph/src/components/Graph3D.tsx +0 -230
- package/packages/graph/src/components/GraphEdges.tsx +0 -100
- package/packages/graph/src/components/GraphNodes.tsx +0 -386
- package/packages/graph/src/components/HealthDashboard.tsx +0 -173
- package/packages/graph/src/components/Layout.tsx +0 -214
- package/packages/graph/src/components/MotionOverlay.tsx +0 -81
- package/packages/graph/src/components/MotionToggle.tsx +0 -33
- package/packages/graph/src/components/MultiverseView.tsx +0 -286
- package/packages/graph/src/components/NodeDetail.tsx +0 -232
- package/packages/graph/src/components/PulseParticle.tsx +0 -232
- package/packages/graph/src/components/SearchBar.tsx +0 -107
- package/packages/graph/src/components/StarField.tsx +0 -197
- package/packages/graph/src/components/StatusBar.tsx +0 -53
- package/packages/graph/src/components/Timeline.tsx +0 -148
- package/packages/graph/src/components/ToolsPanel.tsx +0 -512
- package/packages/graph/src/components/Tooltip.tsx +0 -100
- package/packages/graph/src/components/TypeFilter.tsx +0 -131
- package/packages/graph/src/embed/EmbedGraph.tsx +0 -144
- package/packages/graph/src/hooks/useConstellationLOD.ts +0 -76
- package/packages/graph/src/hooks/useDecay.ts +0 -37
- package/packages/graph/src/hooks/useExport.ts +0 -165
- package/packages/graph/src/hooks/useGraph.ts +0 -69
- package/packages/graph/src/hooks/useKeyboardNav.ts +0 -122
- package/packages/graph/src/hooks/useLayout.ts +0 -45
- package/packages/graph/src/hooks/useMotion.ts +0 -120
- package/packages/graph/src/hooks/usePulse.ts +0 -58
- package/packages/graph/src/hooks/useSearch.ts +0 -71
- package/packages/graph/src/lib/constellation.ts +0 -107
- package/packages/graph/src/lib/export-utils.ts +0 -48
- package/packages/graph/src/lib/gesture-detector.ts +0 -123
- package/packages/graph/src/lib/layout.worker.ts +0 -153
- package/packages/graph/src/lib/motion-controller.ts +0 -83
- package/packages/graph/src/lib/profile-card.ts +0 -122
- package/packages/graph/src/main.tsx +0 -4
- package/packages/graph/src/stores/graph-store.ts +0 -155
- package/packages/graph/success.png +0 -0
- package/packages/graph/test-click.mjs +0 -49
- package/packages/graph/test-explore.mjs +0 -102
- package/packages/graph/test-final.mjs +0 -61
- package/packages/graph/test-graph.mjs +0 -139
- package/packages/graph/test-hover.mjs +0 -48
- package/packages/graph/test-pulse.mjs +0 -68
- package/packages/graph/test-screenshot.mjs +0 -56
- package/packages/graph/test-v2.mjs +0 -97
- package/packages/graph/tsconfig.tsbuildinfo +0 -1
- package/packages/graph/vite.config.ts +0 -15
- package/packages/sync/.env.example +0 -11
- package/packages/sync/.sync-state.json +0 -317
- package/packages/sync/.upload-state.json +0 -1009
- package/packages/sync/create-stella-network-notion.mjs +0 -151
- package/packages/sync/create-stellavault-project-notion.mjs +0 -322
- package/packages/sync/logs/sync-2026-03-28.log +0 -6
- package/packages/sync/logs/sync-2026-03-29.log +0 -12
- package/packages/sync/logs/sync-2026-03-30.log +0 -6
- package/packages/sync/logs/sync-2026-03-31.log +0 -6
- package/packages/sync/logs/sync-2026-04-01.log +0 -6
- package/packages/sync/logs/sync-2026-04-02.log +0 -6
- package/packages/sync/package-lock.json +0 -373
- package/packages/sync/package.json +0 -16
- package/packages/sync/run-sync.bat +0 -18
- package/packages/sync/run-sync.mjs +0 -46
- package/packages/sync/setup-scheduler.mjs +0 -119
- package/packages/sync/structured-sync.mjs +0 -187
- package/packages/sync/sync-to-obsidian.mjs +0 -264
- package/packages/sync/upload-pdca-to-notion.mjs +0 -495
- package/tsconfig.base.json +0 -18
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
// Design Ref: §12.1 F14 — 결정 저널 (기술 결정 자동 기록)
|
|
2
|
-
|
|
3
|
-
import { writeFileSync, existsSync, mkdirSync, readdirSync, readFileSync } from 'node:fs';
|
|
4
|
-
import { join, resolve } from 'node:path';
|
|
5
|
-
import type { SearchEngine } from '../../search/index.js';
|
|
6
|
-
|
|
7
|
-
export const logDecisionToolDef = {
|
|
8
|
-
name: 'log-decision',
|
|
9
|
-
description: '기술적 결정을 구조화하여 기록합니다. 나중에 "왜 이 선택을 했지?"에 답변할 수 있습니다.',
|
|
10
|
-
inputSchema: {
|
|
11
|
-
type: 'object' as const,
|
|
12
|
-
properties: {
|
|
13
|
-
title: { type: 'string', description: '결정 제목 (예: Zustand 대신 Jotai 선택)' },
|
|
14
|
-
context: { type: 'string', description: '결정 배경/상황' },
|
|
15
|
-
decision: { type: 'string', description: '선택한 내용' },
|
|
16
|
-
alternatives: { type: 'array', items: { type: 'string' }, description: '고려한 대안들' },
|
|
17
|
-
reasoning: { type: 'string', description: '선택 이유' },
|
|
18
|
-
project: { type: 'string', description: '관련 프로젝트명' },
|
|
19
|
-
},
|
|
20
|
-
required: ['title', 'decision', 'reasoning'],
|
|
21
|
-
},
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
export const findDecisionsToolDef = {
|
|
25
|
-
name: 'find-decisions',
|
|
26
|
-
description: '과거 기술 결정을 검색합니다.',
|
|
27
|
-
inputSchema: {
|
|
28
|
-
type: 'object' as const,
|
|
29
|
-
properties: {
|
|
30
|
-
query: { type: 'string', description: '검색 쿼리' },
|
|
31
|
-
},
|
|
32
|
-
required: ['query'],
|
|
33
|
-
},
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
export async function handleLogDecision(
|
|
37
|
-
vaultPath: string,
|
|
38
|
-
args: {
|
|
39
|
-
title: string; context?: string; decision: string;
|
|
40
|
-
alternatives?: string[]; reasoning: string; project?: string;
|
|
41
|
-
},
|
|
42
|
-
) {
|
|
43
|
-
const decisionsDir = join(vaultPath, 'decisions');
|
|
44
|
-
mkdirSync(decisionsDir, { recursive: true });
|
|
45
|
-
|
|
46
|
-
const date = new Date().toISOString().slice(0, 10);
|
|
47
|
-
const slug = args.title.replace(/[^a-zA-Z가-힣0-9\s-]/g, '').replace(/\s+/g, '-').slice(0, 50);
|
|
48
|
-
if (!slug) throw new Error('Invalid decision title');
|
|
49
|
-
const fileName = `${date}-${slug}.md`;
|
|
50
|
-
|
|
51
|
-
const content = [
|
|
52
|
-
'---',
|
|
53
|
-
`title: "${args.title}"`,
|
|
54
|
-
`date: ${date}`,
|
|
55
|
-
`project: "${args.project ?? ''}"`,
|
|
56
|
-
'type: decision',
|
|
57
|
-
'---',
|
|
58
|
-
'',
|
|
59
|
-
`# ${args.title}`,
|
|
60
|
-
'',
|
|
61
|
-
args.context ? `## 배경\n\n${args.context}\n` : '',
|
|
62
|
-
`## 결정\n\n${args.decision}\n`,
|
|
63
|
-
args.alternatives?.length
|
|
64
|
-
? `## 고려한 대안\n\n${args.alternatives.map(a => `- ${a}`).join('\n')}\n`
|
|
65
|
-
: '',
|
|
66
|
-
`## 이유\n\n${args.reasoning}\n`,
|
|
67
|
-
].filter(Boolean).join('\n');
|
|
68
|
-
|
|
69
|
-
const filePath = resolve(decisionsDir, fileName);
|
|
70
|
-
if (!filePath.startsWith(resolve(decisionsDir))) {
|
|
71
|
-
throw new Error('Path traversal detected');
|
|
72
|
-
}
|
|
73
|
-
writeFileSync(filePath, content, 'utf-8');
|
|
74
|
-
|
|
75
|
-
return { saved: filePath, fileName };
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
export async function handleFindDecisions(vaultPath: string, args: { query: string }) {
|
|
79
|
-
const decisionsDir = join(vaultPath, 'decisions');
|
|
80
|
-
if (!existsSync(decisionsDir)) return { decisions: [], message: 'No decisions directory' };
|
|
81
|
-
|
|
82
|
-
const files = readdirSync(decisionsDir).filter(f => f.endsWith('.md'));
|
|
83
|
-
const query = args.query.toLowerCase();
|
|
84
|
-
|
|
85
|
-
const matches = files
|
|
86
|
-
.map(f => {
|
|
87
|
-
const content = readFileSync(join(decisionsDir, f), 'utf-8');
|
|
88
|
-
const score = content.toLowerCase().includes(query) ? 1 : 0;
|
|
89
|
-
return { file: f, content: content.slice(0, 300), score };
|
|
90
|
-
})
|
|
91
|
-
.filter(m => m.score > 0)
|
|
92
|
-
.slice(0, 10);
|
|
93
|
-
|
|
94
|
-
return { decisions: matches, total: files.length };
|
|
95
|
-
}
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
// Design Ref: §12.1 F20 — 지식 내보내기 포맷 (락인 방지)
|
|
2
|
-
|
|
3
|
-
import { writeFileSync, mkdirSync } from 'node:fs';
|
|
4
|
-
import { join, dirname, resolve } from 'node:path';
|
|
5
|
-
import { homedir } from 'node:os';
|
|
6
|
-
import type { VectorStore } from '../../store/types.js';
|
|
7
|
-
|
|
8
|
-
const ALLOWED_EXPORT_DIRS = [
|
|
9
|
-
resolve(homedir(), '.stellavault'),
|
|
10
|
-
resolve('.'),
|
|
11
|
-
];
|
|
12
|
-
|
|
13
|
-
function validateExportPath(outputPath: string): string {
|
|
14
|
-
const resolved = resolve(outputPath);
|
|
15
|
-
const isAllowed = ALLOWED_EXPORT_DIRS.some(dir => resolved.startsWith(resolve(dir)));
|
|
16
|
-
if (!isAllowed) {
|
|
17
|
-
throw new Error(`Export path must be within current directory or ~/.stellavault/. Got: ${resolved}`);
|
|
18
|
-
}
|
|
19
|
-
return resolved;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export const exportToolDef = {
|
|
23
|
-
name: 'export',
|
|
24
|
-
description: '벡터 DB의 문서와 메타데이터를 JSON 파일로 내보냅니다. 다른 도구로 이전 가능.',
|
|
25
|
-
inputSchema: {
|
|
26
|
-
type: 'object' as const,
|
|
27
|
-
properties: {
|
|
28
|
-
outputPath: { type: 'string', description: '출력 파일 경로 (예: ./export.json)' },
|
|
29
|
-
format: { type: 'string', enum: ['json', 'csv'], description: '출력 포맷 (기본: json)' },
|
|
30
|
-
},
|
|
31
|
-
required: ['outputPath'],
|
|
32
|
-
},
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
export async function handleExport(
|
|
36
|
-
store: VectorStore,
|
|
37
|
-
args: { outputPath: string; format?: string },
|
|
38
|
-
) {
|
|
39
|
-
const docs = await store.getAllDocuments();
|
|
40
|
-
const stats = await store.getStats();
|
|
41
|
-
const topics = await store.getTopics();
|
|
42
|
-
|
|
43
|
-
const safePath = validateExportPath(args.outputPath);
|
|
44
|
-
mkdirSync(dirname(safePath), { recursive: true });
|
|
45
|
-
|
|
46
|
-
if (args.format === 'csv') {
|
|
47
|
-
const header = 'id,filePath,title,tags,lastModified,contentHash';
|
|
48
|
-
const rows = docs.map(d =>
|
|
49
|
-
`"${d.id}","${d.filePath}","${d.title.replace(/"/g, '""')}","${d.tags.join(';')}","${d.lastModified}","${d.contentHash}"`
|
|
50
|
-
);
|
|
51
|
-
writeFileSync(safePath, [header, ...rows].join('\n'), 'utf-8');
|
|
52
|
-
} else {
|
|
53
|
-
const exported = {
|
|
54
|
-
exportedAt: new Date().toISOString(),
|
|
55
|
-
version: '1.0',
|
|
56
|
-
stats,
|
|
57
|
-
topics,
|
|
58
|
-
documents: docs.map(d => ({
|
|
59
|
-
id: d.id,
|
|
60
|
-
filePath: d.filePath,
|
|
61
|
-
title: d.title,
|
|
62
|
-
tags: d.tags,
|
|
63
|
-
frontmatter: d.frontmatter,
|
|
64
|
-
lastModified: d.lastModified,
|
|
65
|
-
contentLength: d.content.length,
|
|
66
|
-
})),
|
|
67
|
-
};
|
|
68
|
-
writeFileSync(safePath, JSON.stringify(exported, null, 2), 'utf-8');
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
return { exported: docs.length, path: safePath, format: args.format ?? 'json' };
|
|
72
|
-
}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
// MCP Tool: federated-search (Federation Phase 1b)
|
|
2
|
-
// AI 에이전트가 연합 네트워크를 검색
|
|
3
|
-
|
|
4
|
-
import type { FederatedSearch } from '../../federation/search.js';
|
|
5
|
-
|
|
6
|
-
export function createFederatedSearchTool(federatedSearch: FederatedSearch | null) {
|
|
7
|
-
return {
|
|
8
|
-
name: 'federated-search',
|
|
9
|
-
description: 'Search across all connected Federation peers. Returns results from other Stellavault nodes in the P2P network. Only titles, similarity scores, and 50-char snippets are shared — no raw text leaves any node.',
|
|
10
|
-
inputSchema: {
|
|
11
|
-
type: 'object' as const,
|
|
12
|
-
properties: {
|
|
13
|
-
query: { type: 'string', description: 'Search query' },
|
|
14
|
-
limit: { type: 'number', description: 'Max results per peer (default: 5)' },
|
|
15
|
-
},
|
|
16
|
-
required: ['query'],
|
|
17
|
-
},
|
|
18
|
-
async handler(args: { query: string; limit?: number }) {
|
|
19
|
-
if (!federatedSearch) {
|
|
20
|
-
return { content: [{ type: 'text' as const, text: 'Federation not active. Run `sv federate join` first.' }] };
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const results = await federatedSearch.search(args.query, { limit: args.limit ?? 5 });
|
|
24
|
-
|
|
25
|
-
if (results.length === 0) {
|
|
26
|
-
return { content: [{ type: 'text' as const, text: 'No results from federation peers. Either no peers connected or no matching documents.' }] };
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
const lines = [
|
|
30
|
-
`🌐 Federation Search: "${args.query}" — ${results.length} results from ${new Set(results.map(r => r.peerId)).size} peers`,
|
|
31
|
-
'',
|
|
32
|
-
];
|
|
33
|
-
|
|
34
|
-
for (const r of results) {
|
|
35
|
-
lines.push(`**${r.title}** (${Math.round(r.similarity * 100)}%) [${r.peerName}]`);
|
|
36
|
-
lines.push(` ${r.snippet}...`);
|
|
37
|
-
lines.push('');
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
return { content: [{ type: 'text' as const, text: lines.join('\n') }] };
|
|
41
|
-
},
|
|
42
|
-
};
|
|
43
|
-
}
|
|
@@ -1,130 +0,0 @@
|
|
|
1
|
-
// Design Ref: §12.1 F13 — CLAUDE.md 자동 생성기 (킬러 유스케이스)
|
|
2
|
-
|
|
3
|
-
import type { SearchEngine } from '../../search/index.js';
|
|
4
|
-
import type { VectorStore } from '../../store/types.js';
|
|
5
|
-
|
|
6
|
-
export const generateClaudeMdToolDef = {
|
|
7
|
-
name: 'generate-claude-md',
|
|
8
|
-
description: '프로젝트명을 기반으로 관련 지식(아키텍처, 패턴, 교훈, 결정사항)을 검색하여 CLAUDE.md 초안을 자동 생성합니다.',
|
|
9
|
-
inputSchema: {
|
|
10
|
-
type: 'object' as const,
|
|
11
|
-
properties: {
|
|
12
|
-
projectName: { type: 'string', description: '프로젝트명 또는 주요 키워드' },
|
|
13
|
-
topics: {
|
|
14
|
-
type: 'array',
|
|
15
|
-
items: { type: 'string' },
|
|
16
|
-
description: '추가 검색할 토픽 (예: ["인증", "배포", "성능"])',
|
|
17
|
-
},
|
|
18
|
-
},
|
|
19
|
-
required: ['projectName'],
|
|
20
|
-
},
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
export async function handleGenerateClaudeMd(
|
|
24
|
-
searchEngine: SearchEngine,
|
|
25
|
-
store: VectorStore,
|
|
26
|
-
args: { projectName: string; topics?: string[] },
|
|
27
|
-
) {
|
|
28
|
-
const { projectName, topics = [] } = args;
|
|
29
|
-
|
|
30
|
-
// 프로젝트 관련 지식 검색 (여러 관점)
|
|
31
|
-
const queries = [
|
|
32
|
-
`${projectName} 아키텍처 설계`,
|
|
33
|
-
`${projectName} 패턴 컨벤션`,
|
|
34
|
-
`${projectName} 교훈 실수 주의사항`,
|
|
35
|
-
`${projectName} 기술 스택 의존성`,
|
|
36
|
-
...topics.map(t => `${projectName} ${t}`),
|
|
37
|
-
];
|
|
38
|
-
|
|
39
|
-
const allResults = new Map<string, { title: string; content: string; score: number; category: string }>();
|
|
40
|
-
|
|
41
|
-
for (const query of queries) {
|
|
42
|
-
const results = await searchEngine.search({ query, limit: 3 });
|
|
43
|
-
const category = query.replace(projectName, '').trim();
|
|
44
|
-
for (const r of results) {
|
|
45
|
-
const key = r.chunk.id;
|
|
46
|
-
if (!allResults.has(key) || (allResults.get(key)!.score < r.score)) {
|
|
47
|
-
allResults.set(key, {
|
|
48
|
-
title: `${r.document.title} §${r.chunk.heading}`,
|
|
49
|
-
content: r.chunk.content.slice(0, 500),
|
|
50
|
-
score: r.score,
|
|
51
|
-
category,
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// 카테고리별 분류
|
|
58
|
-
const sorted = [...allResults.values()].sort((a, b) => b.score - a.score);
|
|
59
|
-
|
|
60
|
-
// CLAUDE.md 초안 생성
|
|
61
|
-
const sections: string[] = [];
|
|
62
|
-
sections.push(`# ${projectName} — CLAUDE.md`);
|
|
63
|
-
sections.push('');
|
|
64
|
-
sections.push('> 이 파일은 evan-knowledge-hub MCP에서 자동 생성되었습니다.');
|
|
65
|
-
sections.push(`> 생성일: ${new Date().toISOString().slice(0, 10)}`);
|
|
66
|
-
sections.push(`> 참조 지식: ${sorted.length}건`);
|
|
67
|
-
sections.push('');
|
|
68
|
-
|
|
69
|
-
// 아키텍처 섹션
|
|
70
|
-
const archResults = sorted.filter(r => r.category.includes('아키텍처') || r.category.includes('설계'));
|
|
71
|
-
if (archResults.length > 0) {
|
|
72
|
-
sections.push('## 아키텍처 & 설계');
|
|
73
|
-
sections.push('');
|
|
74
|
-
for (const r of archResults.slice(0, 3)) {
|
|
75
|
-
sections.push(`### ${r.title}`);
|
|
76
|
-
sections.push(r.content.trim());
|
|
77
|
-
sections.push('');
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
// 패턴/컨벤션 섹션
|
|
82
|
-
const patternResults = sorted.filter(r => r.category.includes('패턴') || r.category.includes('컨벤션'));
|
|
83
|
-
if (patternResults.length > 0) {
|
|
84
|
-
sections.push('## 코딩 패턴 & 컨벤션');
|
|
85
|
-
sections.push('');
|
|
86
|
-
for (const r of patternResults.slice(0, 3)) {
|
|
87
|
-
sections.push(`### ${r.title}`);
|
|
88
|
-
sections.push(r.content.trim());
|
|
89
|
-
sections.push('');
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
// 교훈 섹션
|
|
94
|
-
const lessonResults = sorted.filter(r => r.category.includes('교훈') || r.category.includes('실수'));
|
|
95
|
-
if (lessonResults.length > 0) {
|
|
96
|
-
sections.push('## 교훈 & 주의사항');
|
|
97
|
-
sections.push('');
|
|
98
|
-
for (const r of lessonResults.slice(0, 5)) {
|
|
99
|
-
sections.push(`- **${r.title}**: ${r.content.slice(0, 200).replace(/\n/g, ' ').trim()}`);
|
|
100
|
-
}
|
|
101
|
-
sections.push('');
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
// 기타 관련 지식
|
|
105
|
-
const otherResults = sorted.filter(r =>
|
|
106
|
-
!r.category.includes('아키텍처') && !r.category.includes('설계') &&
|
|
107
|
-
!r.category.includes('패턴') && !r.category.includes('교훈') && !r.category.includes('실수')
|
|
108
|
-
);
|
|
109
|
-
if (otherResults.length > 0) {
|
|
110
|
-
sections.push('## 관련 지식');
|
|
111
|
-
sections.push('');
|
|
112
|
-
for (const r of otherResults.slice(0, 5)) {
|
|
113
|
-
sections.push(`- **${r.title}** (score: ${r.score.toFixed(3)})`);
|
|
114
|
-
}
|
|
115
|
-
sections.push('');
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
const claudeMd = sections.join('\n');
|
|
119
|
-
|
|
120
|
-
return {
|
|
121
|
-
content: claudeMd,
|
|
122
|
-
stats: {
|
|
123
|
-
queriesRun: queries.length,
|
|
124
|
-
uniqueResults: sorted.length,
|
|
125
|
-
sections: ['아키텍처', '패턴', '교훈', '관련 지식'].filter((_, i) =>
|
|
126
|
-
[archResults, patternResults, lessonResults, otherResults][i].length > 0
|
|
127
|
-
),
|
|
128
|
-
},
|
|
129
|
-
};
|
|
130
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import type { VectorStore } from '../../store/types.js';
|
|
2
|
-
|
|
3
|
-
export const getDocumentToolDef = {
|
|
4
|
-
name: 'get-document',
|
|
5
|
-
description: '문서 ID 또는 파일 경로로 전체 문서 내용을 가져옵니다.',
|
|
6
|
-
inputSchema: {
|
|
7
|
-
type: 'object' as const,
|
|
8
|
-
properties: {
|
|
9
|
-
id: { type: 'string', description: '문서 ID 또는 파일 경로' },
|
|
10
|
-
},
|
|
11
|
-
required: ['id'],
|
|
12
|
-
},
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
export async function handleGetDocument(store: VectorStore, args: { id: string }) {
|
|
16
|
-
const doc = await store.getDocument(args.id);
|
|
17
|
-
if (!doc) return { error: `Document not found: ${args.id}` };
|
|
18
|
-
return {
|
|
19
|
-
title: doc.title,
|
|
20
|
-
filePath: doc.filePath,
|
|
21
|
-
content: doc.content,
|
|
22
|
-
tags: doc.tags,
|
|
23
|
-
frontmatter: doc.frontmatter,
|
|
24
|
-
lastModified: doc.lastModified,
|
|
25
|
-
};
|
|
26
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import type { SearchEngine } from '../../search/index.js';
|
|
2
|
-
import type { VectorStore } from '../../store/types.js';
|
|
3
|
-
|
|
4
|
-
export const getRelatedToolDef = {
|
|
5
|
-
name: 'get-related',
|
|
6
|
-
description: '특정 문서와 의미적으로 관련된 문서들을 반환합니다.',
|
|
7
|
-
inputSchema: {
|
|
8
|
-
type: 'object' as const,
|
|
9
|
-
properties: {
|
|
10
|
-
id: { type: 'string', description: '기준 문서 ID 또는 파일 경로' },
|
|
11
|
-
limit: { type: 'number', description: '반환할 관련 문서 수 (기본: 5)' },
|
|
12
|
-
},
|
|
13
|
-
required: ['id'],
|
|
14
|
-
},
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
export async function handleGetRelated(
|
|
18
|
-
store: VectorStore,
|
|
19
|
-
searchEngine: SearchEngine,
|
|
20
|
-
args: { id: string; limit?: number },
|
|
21
|
-
) {
|
|
22
|
-
const doc = await store.getDocument(args.id);
|
|
23
|
-
if (!doc) return { error: `Document not found: ${args.id}` };
|
|
24
|
-
|
|
25
|
-
// 문서 제목+내용 일부를 쿼리로 사용하여 관련 문서 검색
|
|
26
|
-
const query = `${doc.title} ${doc.content.slice(0, 200)}`;
|
|
27
|
-
const results = await searchEngine.search({
|
|
28
|
-
query,
|
|
29
|
-
limit: (args.limit ?? 5) + 1, // 자기 자신 제외용 +1
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
return results
|
|
33
|
-
.filter(r => r.document.id !== args.id)
|
|
34
|
-
.slice(0, args.limit ?? 5)
|
|
35
|
-
.map(r => ({
|
|
36
|
-
title: r.document.title,
|
|
37
|
-
filePath: r.document.filePath,
|
|
38
|
-
score: Math.round(r.score * 1000) / 1000,
|
|
39
|
-
tags: r.document.tags,
|
|
40
|
-
}));
|
|
41
|
-
}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
// MCP Tool: get-learning-path (F-A11)
|
|
2
|
-
|
|
3
|
-
import type { VectorStore } from '../../store/types.js';
|
|
4
|
-
import { DecayEngine } from '../../intelligence/decay-engine.js';
|
|
5
|
-
import { detectKnowledgeGaps } from '../../intelligence/gap-detector.js';
|
|
6
|
-
import { generateLearningPath } from '../../intelligence/learning-path.js';
|
|
7
|
-
|
|
8
|
-
export function createLearningPathTool(store: VectorStore) {
|
|
9
|
-
return {
|
|
10
|
-
name: 'get-learning-path',
|
|
11
|
-
description: 'Generate a personalized learning path based on knowledge decay and gaps. Returns prioritized list of what to review, explore, or bridge.',
|
|
12
|
-
inputSchema: {
|
|
13
|
-
type: 'object' as const,
|
|
14
|
-
properties: {
|
|
15
|
-
limit: { type: 'number', description: 'Max items to return (default: 10)' },
|
|
16
|
-
},
|
|
17
|
-
},
|
|
18
|
-
async handler(args: { limit?: number }) {
|
|
19
|
-
const limit = args.limit ?? 10;
|
|
20
|
-
const db = store.getDb() as any;
|
|
21
|
-
if (!db) return { content: [{ type: 'text' as const, text: 'Database not available' }] };
|
|
22
|
-
|
|
23
|
-
const decayEngine = new DecayEngine(db);
|
|
24
|
-
const decayReport = await decayEngine.computeAll();
|
|
25
|
-
|
|
26
|
-
let gaps: any[] = [];
|
|
27
|
-
try {
|
|
28
|
-
const gapReport = await detectKnowledgeGaps(store);
|
|
29
|
-
gaps = gapReport.gaps ?? [];
|
|
30
|
-
} catch { /* ignore */ }
|
|
31
|
-
|
|
32
|
-
const path = generateLearningPath({ decayReport, gaps }, limit);
|
|
33
|
-
|
|
34
|
-
const lines = [
|
|
35
|
-
`🎯 Learning Path (${path.items.length} items, ~${path.summary.estimatedMinutes}min)`,
|
|
36
|
-
'',
|
|
37
|
-
];
|
|
38
|
-
|
|
39
|
-
for (const item of path.items) {
|
|
40
|
-
const icon = item.category === 'review' ? '📖' : item.category === 'bridge' ? '🌉' : '🔭';
|
|
41
|
-
lines.push(`${icon} [${item.priority}] ${item.title} (${item.score}pt)`);
|
|
42
|
-
lines.push(` ${item.reason}`);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
if (path.items.length === 0) {
|
|
46
|
-
lines.push('All clear! Knowledge is in great shape.');
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
return { content: [{ type: 'text' as const, text: lines.join('\n') }] };
|
|
50
|
-
},
|
|
51
|
-
};
|
|
52
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import type { VectorStore } from '../../store/types.js';
|
|
2
|
-
|
|
3
|
-
export const listTopicsToolDef = {
|
|
4
|
-
name: 'list-topics',
|
|
5
|
-
description: '지식 베이스의 전체 토픽/태그 목록과 문서 수를 반환합니다.',
|
|
6
|
-
inputSchema: {
|
|
7
|
-
type: 'object' as const,
|
|
8
|
-
properties: {},
|
|
9
|
-
},
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
export async function handleListTopics(store: VectorStore) {
|
|
13
|
-
const topics = await store.getTopics();
|
|
14
|
-
const stats = await store.getStats();
|
|
15
|
-
return {
|
|
16
|
-
topics,
|
|
17
|
-
totalDocuments: stats.documentCount,
|
|
18
|
-
totalChunks: stats.chunkCount,
|
|
19
|
-
};
|
|
20
|
-
}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import type { SearchEngine } from '../../search/index.js';
|
|
2
|
-
|
|
3
|
-
export const searchToolDef = {
|
|
4
|
-
name: 'search',
|
|
5
|
-
description: '개인 지식 베이스에서 관련 문서/청크를 검색합니다. 자연어 쿼리와 키워드 모두 지원합니다.',
|
|
6
|
-
inputSchema: {
|
|
7
|
-
type: 'object' as const,
|
|
8
|
-
properties: {
|
|
9
|
-
query: { type: 'string', description: '검색 쿼리 (자연어 또는 키워드)' },
|
|
10
|
-
limit: { type: 'number', description: '반환할 결과 수 (기본: 5)' },
|
|
11
|
-
tags: { type: 'array', items: { type: 'string' }, description: '태그 필터' },
|
|
12
|
-
},
|
|
13
|
-
required: ['query'],
|
|
14
|
-
},
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
export async function handleSearch(
|
|
18
|
-
searchEngine: SearchEngine,
|
|
19
|
-
args: { query: string; limit?: number; tags?: string[] },
|
|
20
|
-
) {
|
|
21
|
-
const results = await searchEngine.search({
|
|
22
|
-
query: args.query,
|
|
23
|
-
limit: args.limit ?? 5,
|
|
24
|
-
tags: args.tags,
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
return results.map(r => ({
|
|
28
|
-
title: r.document.title,
|
|
29
|
-
filePath: r.document.filePath,
|
|
30
|
-
heading: r.chunk.heading,
|
|
31
|
-
content: r.chunk.content,
|
|
32
|
-
score: Math.round(r.score * 1000) / 1000,
|
|
33
|
-
tags: r.document.tags,
|
|
34
|
-
}));
|
|
35
|
-
}
|
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
// Design Ref: §12.1 F10 — 컨텍스트 스냅샷 (프로젝트별 지식 묶음)
|
|
2
|
-
|
|
3
|
-
import { readFileSync, writeFileSync, existsSync, mkdirSync } from 'node:fs';
|
|
4
|
-
import { join, resolve, relative } from 'node:path';
|
|
5
|
-
import { homedir } from 'node:os';
|
|
6
|
-
import type { SearchEngine } from '../../search/index.js';
|
|
7
|
-
|
|
8
|
-
const SNAPSHOT_DIR = join(homedir(), '.stellavault', 'snapshots');
|
|
9
|
-
|
|
10
|
-
function sanitizeName(name: string): string {
|
|
11
|
-
const sanitized = name.replace(/[^a-zA-Z0-9가-힣_-]/g, '');
|
|
12
|
-
if (!sanitized) throw new Error('Invalid snapshot name');
|
|
13
|
-
return sanitized;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
function ensureWithinDir(dir: string, filePath: string): string {
|
|
17
|
-
const resolved = resolve(dir, filePath);
|
|
18
|
-
if (!resolved.startsWith(resolve(dir))) {
|
|
19
|
-
throw new Error('Path traversal detected');
|
|
20
|
-
}
|
|
21
|
-
return resolved;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export const createSnapshotToolDef = {
|
|
25
|
-
name: 'create-snapshot',
|
|
26
|
-
description: '현재 프로젝트 관련 지식을 스냅샷으로 저장합니다. 나중에 load-snapshot으로 즉시 컨텍스트 복원.',
|
|
27
|
-
inputSchema: {
|
|
28
|
-
type: 'object' as const,
|
|
29
|
-
properties: {
|
|
30
|
-
name: { type: 'string', description: '스냅샷 이름 (예: my-project-v1)' },
|
|
31
|
-
queries: { type: 'array', items: { type: 'string' }, description: '관련 지식 검색 쿼리들' },
|
|
32
|
-
},
|
|
33
|
-
required: ['name', 'queries'],
|
|
34
|
-
},
|
|
35
|
-
};
|
|
36
|
-
|
|
37
|
-
export const loadSnapshotToolDef = {
|
|
38
|
-
name: 'load-snapshot',
|
|
39
|
-
description: '저장된 스냅샷을 로드하여 프로젝트 컨텍스트를 즉시 복원합니다.',
|
|
40
|
-
inputSchema: {
|
|
41
|
-
type: 'object' as const,
|
|
42
|
-
properties: {
|
|
43
|
-
name: { type: 'string', description: '스냅샷 이름' },
|
|
44
|
-
},
|
|
45
|
-
required: ['name'],
|
|
46
|
-
},
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
export async function handleCreateSnapshot(
|
|
50
|
-
searchEngine: SearchEngine,
|
|
51
|
-
args: { name: string; queries: string[] },
|
|
52
|
-
) {
|
|
53
|
-
mkdirSync(SNAPSHOT_DIR, { recursive: true });
|
|
54
|
-
|
|
55
|
-
const results = [];
|
|
56
|
-
for (const query of args.queries) {
|
|
57
|
-
const hits = await searchEngine.search({ query, limit: 5 });
|
|
58
|
-
results.push(...hits.map(r => ({
|
|
59
|
-
query,
|
|
60
|
-
title: r.document.title,
|
|
61
|
-
filePath: r.document.filePath,
|
|
62
|
-
heading: r.chunk.heading,
|
|
63
|
-
content: r.chunk.content.slice(0, 500),
|
|
64
|
-
score: r.score,
|
|
65
|
-
})));
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
// 중복 제거
|
|
69
|
-
const seen = new Set<string>();
|
|
70
|
-
const unique = results.filter(r => {
|
|
71
|
-
const key = `${r.filePath}:${r.heading}`;
|
|
72
|
-
if (seen.has(key)) return false;
|
|
73
|
-
seen.add(key);
|
|
74
|
-
return true;
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
const snapshot = {
|
|
78
|
-
name: args.name,
|
|
79
|
-
createdAt: new Date().toISOString(),
|
|
80
|
-
queries: args.queries,
|
|
81
|
-
results: unique,
|
|
82
|
-
};
|
|
83
|
-
|
|
84
|
-
const safeName = sanitizeName(args.name);
|
|
85
|
-
const filePath = ensureWithinDir(SNAPSHOT_DIR, `${safeName}.json`);
|
|
86
|
-
writeFileSync(filePath, JSON.stringify(snapshot, null, 2), 'utf-8');
|
|
87
|
-
|
|
88
|
-
return { saved: filePath, resultCount: unique.length };
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
export async function handleLoadSnapshot(args: { name: string }) {
|
|
92
|
-
const safeName = sanitizeName(args.name);
|
|
93
|
-
const filePath = ensureWithinDir(SNAPSHOT_DIR, `${safeName}.json`);
|
|
94
|
-
if (!existsSync(filePath)) {
|
|
95
|
-
return { error: `Snapshot not found: ${args.name}` };
|
|
96
|
-
}
|
|
97
|
-
return JSON.parse(readFileSync(filePath, 'utf-8'));
|
|
98
|
-
}
|