@stackmemoryai/stackmemory 0.5.57 → 0.5.59
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/bin/codex-smd +6 -0
- package/dist/cli/codex-sm-danger.js +21 -0
- package/dist/cli/codex-sm-danger.js.map +7 -0
- package/dist/cli/commands/handoff.js +33 -3
- package/dist/cli/commands/handoff.js.map +2 -2
- package/dist/cli/commands/search.js +20 -3
- package/dist/cli/commands/search.js.map +2 -2
- package/dist/core/database/sqlite-adapter.js +13 -3
- package/dist/core/database/sqlite-adapter.js.map +2 -2
- package/dist/core/errors/error-utils.js +208 -0
- package/dist/core/errors/error-utils.js.map +7 -0
- package/dist/core/errors/index.js +13 -4
- package/dist/core/errors/index.js.map +2 -2
- package/dist/core/merge/unified-merge-resolver.js +303 -0
- package/dist/core/merge/unified-merge-resolver.js.map +7 -0
- package/dist/core/monitoring/logger.js +61 -9
- package/dist/core/monitoring/logger.js.map +2 -2
- package/dist/core/security/index.js +35 -0
- package/dist/core/security/index.js.map +7 -0
- package/dist/core/security/input-sanitizer.js +321 -0
- package/dist/core/security/input-sanitizer.js.map +7 -0
- package/dist/core/session/enhanced-handoff.js +136 -2
- package/dist/core/session/enhanced-handoff.js.map +3 -3
- package/dist/integrations/linear/client.js +5 -1
- package/dist/integrations/linear/client.js.map +2 -2
- package/dist/integrations/mcp/remote-server.js +27 -36
- package/dist/integrations/mcp/remote-server.js.map +2 -2
- package/dist/integrations/mcp/server.js +44 -29
- package/dist/integrations/mcp/server.js.map +3 -3
- package/dist/scripts/benchmark-performance.js +48 -0
- package/dist/scripts/benchmark-performance.js.map +7 -0
- package/dist/scripts/check-redis.js +42 -0
- package/dist/scripts/check-redis.js.map +7 -0
- package/dist/scripts/initialize.js +116 -0
- package/dist/scripts/initialize.js.map +7 -0
- package/dist/scripts/list-linear-tasks.js +124 -0
- package/dist/scripts/list-linear-tasks.js.map +7 -0
- package/dist/scripts/measure-handoff-impact.js +340 -0
- package/dist/scripts/measure-handoff-impact.js.map +7 -0
- package/dist/scripts/query-chromadb.js +160 -0
- package/dist/scripts/query-chromadb.js.map +7 -0
- package/dist/scripts/show-linear-summary.js +119 -0
- package/dist/scripts/show-linear-summary.js.map +7 -0
- package/dist/scripts/simple-swarm-demo.js +90 -0
- package/dist/scripts/simple-swarm-demo.js.map +7 -0
- package/dist/scripts/status.js +155 -0
- package/dist/scripts/status.js.map +7 -0
- package/dist/scripts/test-chromadb-sync.js +192 -0
- package/dist/scripts/test-chromadb-sync.js.map +7 -0
- package/dist/scripts/test-ralph-iteration-fix.js +86 -0
- package/dist/scripts/test-ralph-iteration-fix.js.map +7 -0
- package/dist/scripts/test-ralph-iterations.js +121 -0
- package/dist/scripts/test-ralph-iterations.js.map +7 -0
- package/dist/scripts/test-redis-storage.js +389 -0
- package/dist/scripts/test-redis-storage.js.map +7 -0
- package/dist/scripts/test-simple-ralph-state-sync.js +115 -0
- package/dist/scripts/test-simple-ralph-state-sync.js.map +7 -0
- package/dist/scripts/test-swarm-fixes.js +125 -0
- package/dist/scripts/test-swarm-fixes.js.map +7 -0
- package/dist/scripts/test-swarm-tui.js +23 -0
- package/dist/scripts/test-swarm-tui.js.map +7 -0
- package/dist/scripts/test-tui-shortcuts.js +52 -0
- package/dist/scripts/test-tui-shortcuts.js.map +7 -0
- package/dist/scripts/validate-tui-shortcuts.js +60 -0
- package/dist/scripts/validate-tui-shortcuts.js.map +7 -0
- package/dist/src/agents/core/agent-task-manager.js +527 -0
- package/dist/src/agents/core/agent-task-manager.js.map +7 -0
- package/dist/src/agents/verifiers/base-verifier.js +133 -0
- package/dist/src/agents/verifiers/base-verifier.js.map +7 -0
- package/dist/src/agents/verifiers/formatter-verifier.js +130 -0
- package/dist/src/agents/verifiers/formatter-verifier.js.map +7 -0
- package/dist/src/agents/verifiers/llm-judge.js +252 -0
- package/dist/src/agents/verifiers/llm-judge.js.map +7 -0
- package/dist/src/cli/auto-detect.js +321 -0
- package/dist/src/cli/auto-detect.js.map +7 -0
- package/dist/src/cli/claude-sm-danger.js +21 -0
- package/dist/src/cli/claude-sm-danger.js.map +7 -0
- package/dist/src/cli/claude-sm.js +1156 -0
- package/dist/src/cli/claude-sm.js.map +7 -0
- package/dist/src/cli/codex-sm-danger.js +21 -0
- package/dist/src/cli/codex-sm-danger.js.map +7 -0
- package/dist/src/cli/codex-sm.js +349 -0
- package/dist/src/cli/codex-sm.js.map +7 -0
- package/dist/src/cli/commands/api.js +232 -0
- package/dist/src/cli/commands/api.js.map +7 -0
- package/dist/src/cli/commands/auto-background.js +180 -0
- package/dist/src/cli/commands/auto-background.js.map +7 -0
- package/dist/src/cli/commands/cleanup-processes.js +68 -0
- package/dist/src/cli/commands/cleanup-processes.js.map +7 -0
- package/dist/src/cli/commands/clear.js +202 -0
- package/dist/src/cli/commands/clear.js.map +7 -0
- package/dist/src/cli/commands/config.js +445 -0
- package/dist/src/cli/commands/config.js.map +7 -0
- package/dist/src/cli/commands/context-rehydrate.js +751 -0
- package/dist/src/cli/commands/context-rehydrate.js.map +7 -0
- package/dist/src/cli/commands/context.js +343 -0
- package/dist/src/cli/commands/context.js.map +7 -0
- package/dist/src/cli/commands/daemon.js +392 -0
- package/dist/src/cli/commands/daemon.js.map +7 -0
- package/dist/src/cli/commands/dashboard.js +210 -0
- package/dist/src/cli/commands/dashboard.js.map +7 -0
- package/dist/src/cli/commands/db.js +147 -0
- package/dist/src/cli/commands/db.js.map +7 -0
- package/dist/src/cli/commands/decision.js +266 -0
- package/dist/src/cli/commands/decision.js.map +7 -0
- package/dist/src/cli/commands/discovery.js +279 -0
- package/dist/src/cli/commands/discovery.js.map +7 -0
- package/dist/src/cli/commands/handoff.js +624 -0
- package/dist/src/cli/commands/handoff.js.map +7 -0
- package/dist/src/cli/commands/hooks.js +298 -0
- package/dist/src/cli/commands/hooks.js.map +7 -0
- package/dist/src/cli/commands/linear.js +529 -0
- package/dist/src/cli/commands/linear.js.map +7 -0
- package/dist/src/cli/commands/log.js +169 -0
- package/dist/src/cli/commands/log.js.map +7 -0
- package/dist/src/cli/commands/login.js +172 -0
- package/dist/src/cli/commands/login.js.map +7 -0
- package/dist/src/cli/commands/migrate.js +240 -0
- package/dist/src/cli/commands/migrate.js.map +7 -0
- package/dist/src/cli/commands/model.js +533 -0
- package/dist/src/cli/commands/model.js.map +7 -0
- package/dist/src/cli/commands/onboard.js +536 -0
- package/dist/src/cli/commands/onboard.js.map +7 -0
- package/dist/src/cli/commands/projects.js +199 -0
- package/dist/src/cli/commands/projects.js.map +7 -0
- package/dist/src/cli/commands/ralph.js +909 -0
- package/dist/src/cli/commands/ralph.js.map +7 -0
- package/dist/src/cli/commands/retrieval.js +248 -0
- package/dist/src/cli/commands/retrieval.js.map +7 -0
- package/dist/src/cli/commands/search.js +173 -0
- package/dist/src/cli/commands/search.js.map +7 -0
- package/dist/src/cli/commands/service.js +749 -0
- package/dist/src/cli/commands/service.js.map +7 -0
- package/dist/src/cli/commands/session.js +200 -0
- package/dist/src/cli/commands/session.js.map +7 -0
- package/dist/src/cli/commands/settings.js +306 -0
- package/dist/src/cli/commands/settings.js.map +7 -0
- package/dist/src/cli/commands/setup.js +701 -0
- package/dist/src/cli/commands/setup.js.map +7 -0
- package/dist/src/cli/commands/shell.js +249 -0
- package/dist/src/cli/commands/shell.js.map +7 -0
- package/dist/src/cli/commands/signup.js +50 -0
- package/dist/src/cli/commands/signup.js.map +7 -0
- package/dist/src/cli/commands/skills.js +470 -0
- package/dist/src/cli/commands/skills.js.map +7 -0
- package/dist/src/cli/commands/sms-notify.js +795 -0
- package/dist/src/cli/commands/sms-notify.js.map +7 -0
- package/dist/src/cli/commands/storage-tier.js +183 -0
- package/dist/src/cli/commands/storage-tier.js.map +7 -0
- package/dist/src/cli/commands/sweep.js +249 -0
- package/dist/src/cli/commands/sweep.js.map +7 -0
- package/dist/src/cli/commands/tasks.js +213 -0
- package/dist/src/cli/commands/tasks.js.map +7 -0
- package/dist/src/cli/commands/worktree.js +319 -0
- package/dist/src/cli/commands/worktree.js.map +7 -0
- package/dist/src/cli/index.js +594 -0
- package/dist/src/cli/index.js.map +7 -0
- package/dist/src/cli/opencode-sm.js +448 -0
- package/dist/src/cli/opencode-sm.js.map +7 -0
- package/dist/src/cli/utils/viewer.js +96 -0
- package/dist/src/cli/utils/viewer.js.map +7 -0
- package/dist/src/core/config/config-manager.js +398 -0
- package/dist/src/core/config/config-manager.js.map +7 -0
- package/dist/src/core/config/feature-flags.js +76 -0
- package/dist/src/core/config/feature-flags.js.map +7 -0
- package/dist/src/core/config/storage-config.js +115 -0
- package/dist/src/core/config/storage-config.js.map +7 -0
- package/dist/src/core/config/types.js +144 -0
- package/dist/src/core/config/types.js.map +7 -0
- package/dist/src/core/context/auto-context.js +80 -0
- package/dist/src/core/context/auto-context.js.map +7 -0
- package/dist/src/core/context/dual-stack-manager.js +870 -0
- package/dist/src/core/context/dual-stack-manager.js.map +7 -0
- package/dist/src/core/context/enhanced-rehydration.js +994 -0
- package/dist/src/core/context/enhanced-rehydration.js.map +7 -0
- package/dist/src/core/context/frame-database.js +479 -0
- package/dist/src/core/context/frame-database.js.map +7 -0
- package/dist/src/core/context/frame-digest.js +250 -0
- package/dist/src/core/context/frame-digest.js.map +7 -0
- package/dist/src/core/context/frame-handoff-manager.js +778 -0
- package/dist/src/core/context/frame-handoff-manager.js.map +7 -0
- package/dist/src/core/context/frame-lifecycle-hooks.js +119 -0
- package/dist/src/core/context/frame-lifecycle-hooks.js.map +7 -0
- package/dist/src/core/context/frame-recovery.js +302 -0
- package/dist/src/core/context/frame-recovery.js.map +7 -0
- package/dist/src/core/context/frame-stack.js +314 -0
- package/dist/src/core/context/frame-stack.js.map +7 -0
- package/dist/src/core/context/frame-types.js +5 -0
- package/dist/src/core/context/frame-types.js.map +7 -0
- package/dist/src/core/context/index.js +25 -0
- package/dist/src/core/context/index.js.map +7 -0
- package/dist/src/core/context/permission-manager.js +185 -0
- package/dist/src/core/context/permission-manager.js.map +7 -0
- package/dist/src/core/context/recursive-context-manager.js +592 -0
- package/dist/src/core/context/recursive-context-manager.js.map +7 -0
- package/dist/src/core/context/refactored-frame-manager.js +754 -0
- package/dist/src/core/context/refactored-frame-manager.js.map +7 -0
- package/dist/src/core/context/shared-context-layer.js +621 -0
- package/dist/src/core/context/shared-context-layer.js.map +7 -0
- package/dist/src/core/context/stack-merge-resolver.js +749 -0
- package/dist/src/core/context/stack-merge-resolver.js.map +7 -0
- package/dist/src/core/context/validation.js +130 -0
- package/dist/src/core/context/validation.js.map +7 -0
- package/dist/src/core/database/batch-operations.js +384 -0
- package/dist/src/core/database/batch-operations.js.map +7 -0
- package/dist/src/core/database/connection-pool.js +330 -0
- package/dist/src/core/database/connection-pool.js.map +7 -0
- package/dist/src/core/database/database-adapter.js +60 -0
- package/dist/src/core/database/database-adapter.js.map +7 -0
- package/dist/src/core/database/migration-manager.js +614 -0
- package/dist/src/core/database/migration-manager.js.map +7 -0
- package/dist/src/core/database/query-cache.js +298 -0
- package/dist/src/core/database/query-cache.js.map +7 -0
- package/dist/src/core/database/query-router.js +430 -0
- package/dist/src/core/database/query-router.js.map +7 -0
- package/dist/src/core/database/sqlite-adapter.js +738 -0
- package/dist/src/core/database/sqlite-adapter.js.map +7 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.js +277 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.js.map +7 -0
- package/dist/src/core/digest/frame-digest-integration.js +176 -0
- package/dist/src/core/digest/frame-digest-integration.js.map +7 -0
- package/dist/src/core/digest/hybrid-digest-generator.js +553 -0
- package/dist/src/core/digest/hybrid-digest-generator.js.map +7 -0
- package/dist/src/core/digest/index.js +9 -0
- package/dist/src/core/digest/index.js.map +7 -0
- package/dist/src/core/digest/types.js +25 -0
- package/dist/src/core/digest/types.js.map +7 -0
- package/dist/src/core/errors/error-utils.js +208 -0
- package/dist/src/core/errors/error-utils.js.map +7 -0
- package/dist/src/core/errors/index.js +521 -0
- package/dist/src/core/errors/index.js.map +7 -0
- package/dist/src/core/errors/recovery.js +269 -0
- package/dist/src/core/errors/recovery.js.map +7 -0
- package/dist/src/core/execution/parallel-executor.js +258 -0
- package/dist/src/core/execution/parallel-executor.js.map +7 -0
- package/dist/src/core/frame/workflow-templates.js +319 -0
- package/dist/src/core/frame/workflow-templates.js.map +7 -0
- package/dist/src/core/merge/conflict-detector.js +431 -0
- package/dist/src/core/merge/conflict-detector.js.map +7 -0
- package/dist/src/core/merge/index.js +9 -0
- package/dist/src/core/merge/index.js.map +7 -0
- package/dist/src/core/merge/resolution-engine.js +558 -0
- package/dist/src/core/merge/resolution-engine.js.map +7 -0
- package/dist/src/core/merge/stack-diff.js +532 -0
- package/dist/src/core/merge/stack-diff.js.map +7 -0
- package/dist/src/core/merge/types.js +5 -0
- package/dist/src/core/merge/types.js.map +7 -0
- package/dist/src/core/merge/unified-merge-resolver.js +303 -0
- package/dist/src/core/merge/unified-merge-resolver.js.map +7 -0
- package/dist/src/core/models/fallback-monitor.js +232 -0
- package/dist/src/core/models/fallback-monitor.js.map +7 -0
- package/dist/src/core/models/model-router.js +340 -0
- package/dist/src/core/models/model-router.js.map +7 -0
- package/dist/src/core/monitoring/error-handler.js +49 -0
- package/dist/src/core/monitoring/error-handler.js.map +7 -0
- package/dist/src/core/monitoring/logger.js +202 -0
- package/dist/src/core/monitoring/logger.js.map +7 -0
- package/dist/src/core/monitoring/metrics.js +172 -0
- package/dist/src/core/monitoring/metrics.js.map +7 -0
- package/dist/src/core/monitoring/progress-tracker.js +189 -0
- package/dist/src/core/monitoring/progress-tracker.js.map +7 -0
- package/dist/src/core/monitoring/session-monitor.js +300 -0
- package/dist/src/core/monitoring/session-monitor.js.map +7 -0
- package/dist/src/core/performance/context-cache.js +273 -0
- package/dist/src/core/performance/context-cache.js.map +7 -0
- package/dist/src/core/performance/index.js +11 -0
- package/dist/src/core/performance/index.js.map +7 -0
- package/dist/src/core/performance/lazy-context-loader.js +327 -0
- package/dist/src/core/performance/lazy-context-loader.js.map +7 -0
- package/dist/src/core/performance/monitor.js +221 -0
- package/dist/src/core/performance/monitor.js.map +7 -0
- package/dist/src/core/performance/optimized-frame-context.js +345 -0
- package/dist/src/core/performance/optimized-frame-context.js.map +7 -0
- package/dist/src/core/performance/performance-benchmark.js +277 -0
- package/dist/src/core/performance/performance-benchmark.js.map +7 -0
- package/dist/src/core/performance/performance-profiler.js +370 -0
- package/dist/src/core/performance/performance-profiler.js.map +7 -0
- package/dist/src/core/performance/streaming-jsonl-parser.js +195 -0
- package/dist/src/core/performance/streaming-jsonl-parser.js.map +7 -0
- package/dist/src/core/persistence/postgres-adapter.js +349 -0
- package/dist/src/core/persistence/postgres-adapter.js.map +7 -0
- package/dist/src/core/projects/project-isolation.js +201 -0
- package/dist/src/core/projects/project-isolation.js.map +7 -0
- package/dist/src/core/projects/project-manager.js +697 -0
- package/dist/src/core/projects/project-manager.js.map +7 -0
- package/dist/src/core/query/query-parser.js +370 -0
- package/dist/src/core/query/query-parser.js.map +7 -0
- package/dist/src/core/query/query-templates.js +321 -0
- package/dist/src/core/query/query-templates.js.map +7 -0
- package/dist/src/core/retrieval/context-retriever.js +479 -0
- package/dist/src/core/retrieval/context-retriever.js.map +7 -0
- package/dist/src/core/retrieval/index.js +8 -0
- package/dist/src/core/retrieval/index.js.map +7 -0
- package/dist/src/core/retrieval/llm-context-retrieval.js +613 -0
- package/dist/src/core/retrieval/llm-context-retrieval.js.map +7 -0
- package/dist/src/core/retrieval/llm-provider.js +151 -0
- package/dist/src/core/retrieval/llm-provider.js.map +7 -0
- package/dist/src/core/retrieval/retrieval-audit.js +236 -0
- package/dist/src/core/retrieval/retrieval-audit.js.map +7 -0
- package/dist/src/core/retrieval/summary-generator.js +589 -0
- package/dist/src/core/retrieval/summary-generator.js.map +7 -0
- package/dist/src/core/retrieval/types.js +21 -0
- package/dist/src/core/retrieval/types.js.map +7 -0
- package/dist/src/core/security/index.js +35 -0
- package/dist/src/core/security/index.js.map +7 -0
- package/dist/src/core/security/input-sanitizer.js +321 -0
- package/dist/src/core/security/input-sanitizer.js.map +7 -0
- package/dist/src/core/session/clear-survival.js +465 -0
- package/dist/src/core/session/clear-survival.js.map +7 -0
- package/dist/src/core/session/enhanced-handoff.js +792 -0
- package/dist/src/core/session/enhanced-handoff.js.map +7 -0
- package/dist/src/core/session/handoff-generator.js +343 -0
- package/dist/src/core/session/handoff-generator.js.map +7 -0
- package/dist/src/core/session/index.js +15 -0
- package/dist/src/core/session/index.js.map +7 -0
- package/dist/src/core/session/session-manager.js +347 -0
- package/dist/src/core/session/session-manager.js.map +7 -0
- package/dist/src/core/skills/index.js +7 -0
- package/dist/src/core/skills/index.js.map +7 -0
- package/dist/src/core/skills/skill-storage.js +764 -0
- package/dist/src/core/skills/skill-storage.js.map +7 -0
- package/dist/src/core/skills/types.js +193 -0
- package/dist/src/core/skills/types.js.map +7 -0
- package/dist/src/core/storage/chromadb-adapter.js +354 -0
- package/dist/src/core/storage/chromadb-adapter.js.map +7 -0
- package/dist/src/core/storage/infinite-storage.js +510 -0
- package/dist/src/core/storage/infinite-storage.js.map +7 -0
- package/dist/src/core/storage/remote-storage.js +489 -0
- package/dist/src/core/storage/remote-storage.js.map +7 -0
- package/dist/src/core/storage/two-tier-storage.js +766 -0
- package/dist/src/core/storage/two-tier-storage.js.map +7 -0
- package/dist/src/core/trace/cli-trace-wrapper.js +132 -0
- package/dist/src/core/trace/cli-trace-wrapper.js.map +7 -0
- package/dist/src/core/trace/db-trace-wrapper.js +247 -0
- package/dist/src/core/trace/db-trace-wrapper.js.map +7 -0
- package/dist/src/core/trace/debug-trace.js +417 -0
- package/dist/src/core/trace/debug-trace.js.map +7 -0
- package/dist/src/core/trace/index.js +109 -0
- package/dist/src/core/trace/index.js.map +7 -0
- package/dist/src/core/trace/linear-api-wrapper.js +178 -0
- package/dist/src/core/trace/linear-api-wrapper.js.map +7 -0
- package/dist/src/core/trace/trace-detector.js +528 -0
- package/dist/src/core/trace/trace-detector.js.map +7 -0
- package/dist/src/core/trace/trace-store.js +345 -0
- package/dist/src/core/trace/trace-store.js.map +7 -0
- package/dist/src/core/trace/types.js +77 -0
- package/dist/src/core/trace/types.js.map +7 -0
- package/dist/src/core/types.js +5 -0
- package/dist/src/core/types.js.map +7 -0
- package/dist/src/core/utils/async-mutex.js +114 -0
- package/dist/src/core/utils/async-mutex.js.map +7 -0
- package/dist/src/core/utils/compression.js +83 -0
- package/dist/src/core/utils/compression.js.map +7 -0
- package/dist/src/core/utils/update-checker.js +218 -0
- package/dist/src/core/utils/update-checker.js.map +7 -0
- package/dist/src/core/worktree/worktree-manager.js +465 -0
- package/dist/src/core/worktree/worktree-manager.js.map +7 -0
- package/dist/src/daemon/daemon-config.js +149 -0
- package/dist/src/daemon/daemon-config.js.map +7 -0
- package/dist/src/daemon/services/context-service.js +122 -0
- package/dist/src/daemon/services/context-service.js.map +7 -0
- package/dist/src/daemon/services/linear-service.js +136 -0
- package/dist/src/daemon/services/linear-service.js.map +7 -0
- package/dist/src/daemon/session-daemon.js +312 -0
- package/dist/src/daemon/session-daemon.js.map +7 -0
- package/dist/src/daemon/unified-daemon.js +276 -0
- package/dist/src/daemon/unified-daemon.js.map +7 -0
- package/dist/src/features/analytics/api/analytics-api.js +287 -0
- package/dist/src/features/analytics/api/analytics-api.js.map +7 -0
- package/dist/src/features/analytics/core/analytics-service.js +282 -0
- package/dist/src/features/analytics/core/analytics-service.js.map +7 -0
- package/dist/src/features/analytics/index.js +18 -0
- package/dist/src/features/analytics/index.js.map +7 -0
- package/dist/src/features/analytics/queries/metrics-queries.js +277 -0
- package/dist/src/features/analytics/queries/metrics-queries.js.map +7 -0
- package/dist/src/features/analytics/types/metrics.js +5 -0
- package/dist/src/features/analytics/types/metrics.js.map +7 -0
- package/dist/src/features/browser/browser-mcp.js +492 -0
- package/dist/src/features/browser/browser-mcp.js.map +7 -0
- package/dist/src/features/sweep/index.js +20 -0
- package/dist/src/features/sweep/index.js.map +7 -0
- package/dist/src/features/sweep/prediction-client.js +155 -0
- package/dist/src/features/sweep/prediction-client.js.map +7 -0
- package/dist/src/features/sweep/prompt-builder.js +85 -0
- package/dist/src/features/sweep/prompt-builder.js.map +7 -0
- package/dist/src/features/sweep/pty-wrapper.js +171 -0
- package/dist/src/features/sweep/pty-wrapper.js.map +7 -0
- package/dist/src/features/sweep/state-watcher.js +87 -0
- package/dist/src/features/sweep/state-watcher.js.map +7 -0
- package/dist/src/features/sweep/status-bar.js +88 -0
- package/dist/src/features/sweep/status-bar.js.map +7 -0
- package/dist/src/features/sweep/sweep-server-manager.js +226 -0
- package/dist/src/features/sweep/sweep-server-manager.js.map +7 -0
- package/dist/src/features/sweep/tab-interceptor.js +38 -0
- package/dist/src/features/sweep/tab-interceptor.js.map +7 -0
- package/dist/src/features/sweep/types.js +18 -0
- package/dist/src/features/sweep/types.js.map +7 -0
- package/dist/src/features/tasks/linear-task-manager.js +487 -0
- package/dist/src/features/tasks/linear-task-manager.js.map +7 -0
- package/dist/src/features/tasks/task-aware-context.js +410 -0
- package/dist/src/features/tasks/task-aware-context.js.map +7 -0
- package/dist/src/features/tui/simple-monitor.js +116 -0
- package/dist/src/features/tui/simple-monitor.js.map +7 -0
- package/dist/src/features/tui/swarm-monitor.js +648 -0
- package/dist/src/features/tui/swarm-monitor.js.map +7 -0
- package/dist/src/features/web/client/stores/task-store.js +26 -0
- package/dist/src/features/web/client/stores/task-store.js.map +7 -0
- package/dist/src/features/web/server/index.js +194 -0
- package/dist/src/features/web/server/index.js.map +7 -0
- package/dist/src/hooks/auto-background.js +151 -0
- package/dist/src/hooks/auto-background.js.map +7 -0
- package/dist/src/hooks/claude-code-whatsapp-hook.js +197 -0
- package/dist/src/hooks/claude-code-whatsapp-hook.js.map +7 -0
- package/dist/src/hooks/config.js +150 -0
- package/dist/src/hooks/config.js.map +7 -0
- package/dist/src/hooks/daemon.js +364 -0
- package/dist/src/hooks/daemon.js.map +7 -0
- package/dist/src/hooks/events.js +58 -0
- package/dist/src/hooks/events.js.map +7 -0
- package/dist/src/hooks/index.js +12 -0
- package/dist/src/hooks/index.js.map +7 -0
- package/dist/src/hooks/linear-task-picker.js +186 -0
- package/dist/src/hooks/linear-task-picker.js.map +7 -0
- package/dist/src/hooks/schemas.js +197 -0
- package/dist/src/hooks/schemas.js.map +7 -0
- package/dist/src/hooks/secure-fs.js +49 -0
- package/dist/src/hooks/secure-fs.js.map +7 -0
- package/dist/src/hooks/security-logger.js +155 -0
- package/dist/src/hooks/security-logger.js.map +7 -0
- package/dist/src/hooks/session-summary.js +222 -0
- package/dist/src/hooks/session-summary.js.map +7 -0
- package/dist/src/hooks/sms-action-runner.js +371 -0
- package/dist/src/hooks/sms-action-runner.js.map +7 -0
- package/dist/src/hooks/sms-notify.js +506 -0
- package/dist/src/hooks/sms-notify.js.map +7 -0
- package/dist/src/hooks/sms-watcher.js +93 -0
- package/dist/src/hooks/sms-watcher.js.map +7 -0
- package/dist/src/hooks/sms-webhook.js +555 -0
- package/dist/src/hooks/sms-webhook.js.map +7 -0
- package/dist/src/hooks/whatsapp-commands.js +479 -0
- package/dist/src/hooks/whatsapp-commands.js.map +7 -0
- package/dist/src/hooks/whatsapp-scheduler.js +317 -0
- package/dist/src/hooks/whatsapp-scheduler.js.map +7 -0
- package/dist/src/hooks/whatsapp-sync.js +409 -0
- package/dist/src/hooks/whatsapp-sync.js.map +7 -0
- package/dist/src/index.js +25 -0
- package/dist/src/index.js.map +7 -0
- package/dist/src/integrations/anthropic/client.js +263 -0
- package/dist/src/integrations/anthropic/client.js.map +7 -0
- package/dist/src/integrations/claude-code/agent-bridge.js +768 -0
- package/dist/src/integrations/claude-code/agent-bridge.js.map +7 -0
- package/dist/src/integrations/claude-code/enhanced-pre-clear-hooks.js +459 -0
- package/dist/src/integrations/claude-code/enhanced-pre-clear-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/lifecycle-hooks.js +254 -0
- package/dist/src/integrations/claude-code/lifecycle-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/post-task-hooks.js +545 -0
- package/dist/src/integrations/claude-code/post-task-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/subagent-client-stub.js +20 -0
- package/dist/src/integrations/claude-code/subagent-client-stub.js.map +7 -0
- package/dist/src/integrations/claude-code/subagent-client.js +511 -0
- package/dist/src/integrations/claude-code/subagent-client.js.map +7 -0
- package/dist/src/integrations/claude-code/task-coordinator.js +360 -0
- package/dist/src/integrations/claude-code/task-coordinator.js.map +7 -0
- package/dist/src/integrations/linear/auth.js +337 -0
- package/dist/src/integrations/linear/auth.js.map +7 -0
- package/dist/src/integrations/linear/auto-sync.js +258 -0
- package/dist/src/integrations/linear/auto-sync.js.map +7 -0
- package/dist/src/integrations/linear/client.js +634 -0
- package/dist/src/integrations/linear/client.js.map +7 -0
- package/dist/src/integrations/linear/config.js +130 -0
- package/dist/src/integrations/linear/config.js.map +7 -0
- package/dist/src/integrations/linear/migration.js +361 -0
- package/dist/src/integrations/linear/migration.js.map +7 -0
- package/dist/src/integrations/linear/oauth-server.js +454 -0
- package/dist/src/integrations/linear/oauth-server.js.map +7 -0
- package/dist/src/integrations/linear/rest-client.js +213 -0
- package/dist/src/integrations/linear/rest-client.js.map +7 -0
- package/dist/src/integrations/linear/sync-manager.js +236 -0
- package/dist/src/integrations/linear/sync-manager.js.map +7 -0
- package/dist/src/integrations/linear/sync-service.js +231 -0
- package/dist/src/integrations/linear/sync-service.js.map +7 -0
- package/dist/src/integrations/linear/sync.js +782 -0
- package/dist/src/integrations/linear/sync.js.map +7 -0
- package/dist/src/integrations/linear/types.js +5 -0
- package/dist/src/integrations/linear/types.js.map +7 -0
- package/dist/src/integrations/linear/unified-sync.js +589 -0
- package/dist/src/integrations/linear/unified-sync.js.map +7 -0
- package/dist/src/integrations/linear/webhook-handler.js +219 -0
- package/dist/src/integrations/linear/webhook-handler.js.map +7 -0
- package/dist/src/integrations/linear/webhook-server.js +218 -0
- package/dist/src/integrations/linear/webhook-server.js.map +7 -0
- package/dist/src/integrations/linear/webhook.js +291 -0
- package/dist/src/integrations/linear/webhook.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/code-execution-handlers.js +266 -0
- package/dist/src/integrations/mcp/handlers/code-execution-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/context-handlers.js +257 -0
- package/dist/src/integrations/mcp/handlers/context-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/discovery-handlers.js +497 -0
- package/dist/src/integrations/mcp/handlers/discovery-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/index.js +166 -0
- package/dist/src/integrations/mcp/handlers/index.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.js +247 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/skill-handlers.js +529 -0
- package/dist/src/integrations/mcp/handlers/skill-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.js +239 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.js +308 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/index.js +23 -0
- package/dist/src/integrations/mcp/index.js.map +7 -0
- package/dist/src/integrations/mcp/middleware/tool-scoring.js +356 -0
- package/dist/src/integrations/mcp/middleware/tool-scoring.js.map +7 -0
- package/dist/src/integrations/mcp/refactored-server.js +374 -0
- package/dist/src/integrations/mcp/refactored-server.js.map +7 -0
- package/dist/src/integrations/mcp/remote-server.js +682 -0
- package/dist/src/integrations/mcp/remote-server.js.map +7 -0
- package/dist/src/integrations/mcp/schemas.js +147 -0
- package/dist/src/integrations/mcp/schemas.js.map +7 -0
- package/dist/src/integrations/mcp/server.js +1975 -0
- package/dist/src/integrations/mcp/server.js.map +7 -0
- package/dist/src/integrations/mcp/tool-definitions-code.js +125 -0
- package/dist/src/integrations/mcp/tool-definitions-code.js.map +7 -0
- package/dist/src/integrations/mcp/tool-definitions.js +702 -0
- package/dist/src/integrations/mcp/tool-definitions.js.map +7 -0
- package/dist/src/integrations/ralph/bridge/ralph-stackmemory-bridge.js +860 -0
- package/dist/src/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +7 -0
- package/dist/src/integrations/ralph/context/context-budget-manager.js +301 -0
- package/dist/src/integrations/ralph/context/context-budget-manager.js.map +7 -0
- package/dist/src/integrations/ralph/context/stackmemory-context-loader.js +360 -0
- package/dist/src/integrations/ralph/context/stackmemory-context-loader.js.map +7 -0
- package/dist/src/integrations/ralph/coordination/enhanced-coordination.js +410 -0
- package/dist/src/integrations/ralph/coordination/enhanced-coordination.js.map +7 -0
- package/dist/src/integrations/ralph/index.js +18 -0
- package/dist/src/integrations/ralph/index.js.map +7 -0
- package/dist/src/integrations/ralph/learning/pattern-learner.js +401 -0
- package/dist/src/integrations/ralph/learning/pattern-learner.js.map +7 -0
- package/dist/src/integrations/ralph/lifecycle/iteration-lifecycle.js +448 -0
- package/dist/src/integrations/ralph/lifecycle/iteration-lifecycle.js.map +7 -0
- package/dist/src/integrations/ralph/monitoring/swarm-dashboard.js +294 -0
- package/dist/src/integrations/ralph/monitoring/swarm-dashboard.js.map +7 -0
- package/dist/src/integrations/ralph/monitoring/swarm-registry.js +108 -0
- package/dist/src/integrations/ralph/monitoring/swarm-registry.js.map +7 -0
- package/dist/src/integrations/ralph/orchestration/multi-loop-orchestrator.js +463 -0
- package/dist/src/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/compounding-engineering-pattern.js +400 -0
- package/dist/src/integrations/ralph/patterns/compounding-engineering-pattern.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/extended-coherence-sessions.js +473 -0
- package/dist/src/integrations/ralph/patterns/extended-coherence-sessions.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js +388 -0
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js.map +7 -0
- package/dist/src/integrations/ralph/performance/performance-optimizer.js +358 -0
- package/dist/src/integrations/ralph/performance/performance-optimizer.js.map +7 -0
- package/dist/src/integrations/ralph/recovery/crash-recovery.js +462 -0
- package/dist/src/integrations/ralph/recovery/crash-recovery.js.map +7 -0
- package/dist/src/integrations/ralph/state/state-reconciler.js +404 -0
- package/dist/src/integrations/ralph/state/state-reconciler.js.map +7 -0
- package/dist/src/integrations/ralph/swarm/git-workflow-manager.js +428 -0
- package/dist/src/integrations/ralph/swarm/git-workflow-manager.js.map +7 -0
- package/dist/src/integrations/ralph/swarm/swarm-coordinator.js +996 -0
- package/dist/src/integrations/ralph/swarm/swarm-coordinator.js.map +7 -0
- package/dist/src/integrations/ralph/types.js +5 -0
- package/dist/src/integrations/ralph/types.js.map +7 -0
- package/dist/src/integrations/ralph/visualization/ralph-debugger.js +585 -0
- package/dist/src/integrations/ralph/visualization/ralph-debugger.js.map +7 -0
- package/dist/src/mcp/stackmemory-mcp-server.js +554 -0
- package/dist/src/mcp/stackmemory-mcp-server.js.map +7 -0
- package/dist/src/middleware/exponential-rate-limiter.js +289 -0
- package/dist/src/middleware/exponential-rate-limiter.js.map +7 -0
- package/dist/src/models/user.model.js +358 -0
- package/dist/src/models/user.model.js.map +7 -0
- package/dist/src/servers/production/auth-middleware.js +528 -0
- package/dist/src/servers/production/auth-middleware.js.map +7 -0
- package/dist/src/services/config-service.js +65 -0
- package/dist/src/services/config-service.js.map +7 -0
- package/dist/src/services/context-service.js +194 -0
- package/dist/src/services/context-service.js.map +7 -0
- package/dist/src/skills/api-discovery.js +354 -0
- package/dist/src/skills/api-discovery.js.map +7 -0
- package/dist/src/skills/api-skill.js +475 -0
- package/dist/src/skills/api-skill.js.map +7 -0
- package/dist/src/skills/claude-skills.js +1061 -0
- package/dist/src/skills/claude-skills.js.map +7 -0
- package/dist/src/skills/dashboard-launcher.js +216 -0
- package/dist/src/skills/dashboard-launcher.js.map +7 -0
- package/dist/src/skills/recursive-agent-orchestrator.js +575 -0
- package/dist/src/skills/recursive-agent-orchestrator.js.map +7 -0
- package/dist/src/skills/repo-ingestion-skill.js +609 -0
- package/dist/src/skills/repo-ingestion-skill.js.map +7 -0
- package/dist/src/skills/unified-rlm-orchestrator.js +404 -0
- package/dist/src/skills/unified-rlm-orchestrator.js.map +7 -0
- package/dist/src/types/task.js +5 -0
- package/dist/src/types/task.js.map +7 -0
- package/dist/src/utils/env.js +50 -0
- package/dist/src/utils/env.js.map +7 -0
- package/dist/src/utils/formatting.js +62 -0
- package/dist/src/utils/formatting.js.map +7 -0
- package/dist/src/utils/process-cleanup.js +136 -0
- package/dist/src/utils/process-cleanup.js.map +7 -0
- package/package.json +4 -3
- package/scripts/create-cleanup-issues.js +302 -0
- package/scripts/demos/browser-test.ts +39 -0
- package/scripts/demos/ralph-integration-demo.ts +244 -0
- package/scripts/demos/trace-demo.ts +214 -0
- package/scripts/demos/trace-detector.demo.ts +171 -0
- package/scripts/demos/trace-test.ts +67 -0
- package/scripts/initialize.ts +16 -7
- package/scripts/install.sh +14 -62
- package/scripts/status.ts +111 -46
- package/scripts/test-claude-config.sh +123 -0
- package/scripts/validate-claude-config.sh +155 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { fileURLToPath as __fileURLToPath } from 'url';
|
|
3
|
+
import { dirname as __pathDirname } from 'path';
|
|
4
|
+
const __filename = __fileURLToPath(import.meta.url);
|
|
5
|
+
const __dirname = __pathDirname(__filename);
|
|
6
|
+
import chalk from "chalk";
|
|
7
|
+
import { AnalyticsService } from "../../features/analytics/core/analytics-service.js";
|
|
8
|
+
async function displayAnalyticsDashboard(projectPath) {
|
|
9
|
+
const service = new AnalyticsService(projectPath || process.cwd());
|
|
10
|
+
try {
|
|
11
|
+
await service.syncFromTaskStore();
|
|
12
|
+
const state = await service.getDashboardState();
|
|
13
|
+
const { metrics, recentTasks, teamMetrics } = state;
|
|
14
|
+
console.clear();
|
|
15
|
+
console.log(chalk.bold.cyan("\nStackMemory Analytics Dashboard\n"));
|
|
16
|
+
console.log(chalk.gray("\u2500".repeat(50)));
|
|
17
|
+
console.log(chalk.bold.white("\nKey Metrics\n"));
|
|
18
|
+
const metricsDisplay = [
|
|
19
|
+
["Total Tasks", metrics.totalTasks],
|
|
20
|
+
["Completed", chalk.green(metrics.completedTasks)],
|
|
21
|
+
["In Progress", chalk.yellow(metrics.inProgressTasks)],
|
|
22
|
+
["Blocked", chalk.red(metrics.blockedTasks)],
|
|
23
|
+
["Completion Rate", `${metrics.completionRate.toFixed(1)}%`],
|
|
24
|
+
["Avg Time to Complete", formatDuration(metrics.averageTimeToComplete)],
|
|
25
|
+
["Effort Accuracy", `${metrics.effortAccuracy.toFixed(0)}%`],
|
|
26
|
+
["Blocking Issues", metrics.blockingIssuesCount]
|
|
27
|
+
];
|
|
28
|
+
metricsDisplay.forEach(([label, value]) => {
|
|
29
|
+
console.log(` ${chalk.gray(String(label).padEnd(20))} ${value}`);
|
|
30
|
+
});
|
|
31
|
+
if (metrics.velocityTrend.length > 0) {
|
|
32
|
+
console.log(chalk.bold.white("\n\u{1F4C9} Velocity Trend (last 7 days)\n"));
|
|
33
|
+
const maxVelocity = Math.max(...metrics.velocityTrend);
|
|
34
|
+
const scale = maxVelocity > 0 ? 10 / maxVelocity : 1;
|
|
35
|
+
metrics.velocityTrend.slice(-7).forEach((velocity, i) => {
|
|
36
|
+
const bar = "\u2588".repeat(Math.round(velocity * scale));
|
|
37
|
+
const day = /* @__PURE__ */ new Date();
|
|
38
|
+
day.setDate(day.getDate() - (6 - i));
|
|
39
|
+
console.log(
|
|
40
|
+
` ${day.toLocaleDateString("en", { weekday: "short" }).padEnd(4)} ${bar} ${velocity}`
|
|
41
|
+
);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
if (recentTasks.length > 0) {
|
|
45
|
+
console.log(chalk.bold.white("\nRecent Tasks\n"));
|
|
46
|
+
recentTasks.slice(0, 5).forEach((task) => {
|
|
47
|
+
const statePrefix = {
|
|
48
|
+
completed: "[DONE]",
|
|
49
|
+
in_progress: "[PROG]",
|
|
50
|
+
blocked: "[BLCK]",
|
|
51
|
+
todo: "[TODO]"
|
|
52
|
+
}[task.state];
|
|
53
|
+
const priorityColor = {
|
|
54
|
+
urgent: chalk.red,
|
|
55
|
+
high: chalk.yellow,
|
|
56
|
+
medium: chalk.blue,
|
|
57
|
+
low: chalk.gray
|
|
58
|
+
}[task.priority];
|
|
59
|
+
console.log(
|
|
60
|
+
` ${statePrefix} ${priorityColor(`[${task.priority.toUpperCase()}]`)} ${task.title.slice(0, 50)}`
|
|
61
|
+
);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
if (teamMetrics.length > 0) {
|
|
65
|
+
console.log(chalk.bold.white("\n\u{1F465} Team Performance\n"));
|
|
66
|
+
teamMetrics.slice(0, 3).forEach((member) => {
|
|
67
|
+
const bar = "\u2593".repeat(Math.round(member.contributionPercentage / 10));
|
|
68
|
+
console.log(
|
|
69
|
+
` ${member.userName.padEnd(15)} ${bar} ${member.contributionPercentage.toFixed(0)}% (${member.individualMetrics.completedTasks} tasks)`
|
|
70
|
+
);
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
console.log(chalk.gray("\n" + "\u2500".repeat(50)));
|
|
74
|
+
console.log(
|
|
75
|
+
chalk.gray(`Last updated: ${state.lastUpdated.toLocaleString()}`)
|
|
76
|
+
);
|
|
77
|
+
console.log();
|
|
78
|
+
} finally {
|
|
79
|
+
service.close();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
function formatDuration(ms) {
|
|
83
|
+
if (ms === 0) return "N/A";
|
|
84
|
+
const hours = Math.floor(ms / 36e5);
|
|
85
|
+
const days = Math.floor(hours / 24);
|
|
86
|
+
if (days > 0) return `${days}d ${hours % 24}h`;
|
|
87
|
+
if (hours > 0) return `${hours}h`;
|
|
88
|
+
return "<1h";
|
|
89
|
+
}
|
|
90
|
+
if (import.meta.url === `file://${process.argv[1]}`) {
|
|
91
|
+
displayAnalyticsDashboard().catch(console.error);
|
|
92
|
+
}
|
|
93
|
+
export {
|
|
94
|
+
displayAnalyticsDashboard
|
|
95
|
+
};
|
|
96
|
+
//# sourceMappingURL=viewer.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/cli/utils/viewer.ts"],
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\nimport chalk from 'chalk';\nimport { AnalyticsService } from '../../features/analytics/core/analytics-service.js';\n\nexport async function displayAnalyticsDashboard(\n projectPath?: string\n): Promise<void> {\n const service = new AnalyticsService(projectPath || process.cwd());\n\n try {\n // Sync from task store before displaying\n await service.syncFromTaskStore();\n const state = await service.getDashboardState();\n const { metrics, recentTasks, teamMetrics } = state;\n\n console.clear();\n console.log(chalk.bold.cyan('\\nStackMemory Analytics Dashboard\\n'));\n console.log(chalk.gray('\u2500'.repeat(50)));\n\n // Key Metrics\n console.log(chalk.bold.white('\\nKey Metrics\\n'));\n\n const metricsDisplay = [\n ['Total Tasks', metrics.totalTasks],\n ['Completed', chalk.green(metrics.completedTasks)],\n ['In Progress', chalk.yellow(metrics.inProgressTasks)],\n ['Blocked', chalk.red(metrics.blockedTasks)],\n ['Completion Rate', `${metrics.completionRate.toFixed(1)}%`],\n ['Avg Time to Complete', formatDuration(metrics.averageTimeToComplete)],\n ['Effort Accuracy', `${metrics.effortAccuracy.toFixed(0)}%`],\n ['Blocking Issues', metrics.blockingIssuesCount],\n ];\n\n metricsDisplay.forEach(([label, value]) => {\n console.log(` ${chalk.gray(String(label).padEnd(20))} ${value}`);\n });\n\n // Velocity Trend (mini chart)\n if (metrics.velocityTrend.length > 0) {\n console.log(chalk.bold.white('\\n\uD83D\uDCC9 Velocity Trend (last 7 days)\\n'));\n const maxVelocity = Math.max(...metrics.velocityTrend);\n const scale = maxVelocity > 0 ? 10 / maxVelocity : 1;\n\n metrics.velocityTrend.slice(-7).forEach((velocity, i) => {\n const bar = '\u2588'.repeat(Math.round(velocity * scale));\n const day = new Date();\n day.setDate(day.getDate() - (6 - i));\n console.log(\n ` ${day.toLocaleDateString('en', { weekday: 'short' }).padEnd(4)} ${bar} ${velocity}`\n );\n });\n }\n\n // Recent Tasks\n if (recentTasks.length > 0) {\n console.log(chalk.bold.white('\\nRecent Tasks\\n'));\n recentTasks.slice(0, 5).forEach((task) => {\n const statePrefix = {\n completed: '[DONE]',\n in_progress: '[PROG]',\n blocked: '[BLCK]',\n todo: '[TODO]',\n }[task.state];\n\n const priorityColor = {\n urgent: chalk.red,\n high: chalk.yellow,\n medium: chalk.blue,\n low: chalk.gray,\n }[task.priority];\n\n console.log(\n ` ${statePrefix} ${priorityColor(`[${task.priority.toUpperCase()}]`)} ${task.title.slice(0, 50)}`\n );\n });\n }\n\n // Team Performance\n if (teamMetrics.length > 0) {\n console.log(chalk.bold.white('\\n\uD83D\uDC65 Team Performance\\n'));\n teamMetrics.slice(0, 3).forEach((member) => {\n const bar = '\u2593'.repeat(Math.round(member.contributionPercentage / 10));\n console.log(\n ` ${member.userName.padEnd(15)} ${bar} ${member.contributionPercentage.toFixed(0)}% (${member.individualMetrics.completedTasks} tasks)`\n );\n });\n }\n\n console.log(chalk.gray('\\n' + '\u2500'.repeat(50)));\n console.log(\n chalk.gray(`Last updated: ${state.lastUpdated.toLocaleString()}`)\n );\n console.log();\n } finally {\n service.close();\n }\n}\n\nfunction formatDuration(ms: number): string {\n if (ms === 0) return 'N/A';\n const hours = Math.floor(ms / 3600000);\n const days = Math.floor(hours / 24);\n if (days > 0) return `${days}d ${hours % 24}h`;\n if (hours > 0) return `${hours}h`;\n return '<1h';\n}\n\n// Allow direct execution\nif (import.meta.url === `file://${process.argv[1]}`) {\n displayAnalyticsDashboard().catch(console.error);\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,398 @@
|
|
|
1
|
+
import { fileURLToPath as __fileURLToPath } from 'url';
|
|
2
|
+
import { dirname as __pathDirname } from 'path';
|
|
3
|
+
const __filename = __fileURLToPath(import.meta.url);
|
|
4
|
+
const __dirname = __pathDirname(__filename);
|
|
5
|
+
import * as fs from "fs";
|
|
6
|
+
import * as path from "path";
|
|
7
|
+
import * as yaml from "js-yaml";
|
|
8
|
+
import {
|
|
9
|
+
DEFAULT_CONFIG,
|
|
10
|
+
PRESET_PROFILES
|
|
11
|
+
} from "./types.js";
|
|
12
|
+
class ConfigManager {
|
|
13
|
+
static instance = null;
|
|
14
|
+
config;
|
|
15
|
+
configPath;
|
|
16
|
+
fileWatcher;
|
|
17
|
+
onChangeCallbacks = [];
|
|
18
|
+
constructor(configPath) {
|
|
19
|
+
this.configPath = configPath || path.join(process.cwd(), ".stackmemory", "config.yaml");
|
|
20
|
+
this.config = this.loadConfig();
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Get singleton instance of ConfigManager
|
|
24
|
+
*/
|
|
25
|
+
static getInstance(configPath) {
|
|
26
|
+
if (!ConfigManager.instance) {
|
|
27
|
+
ConfigManager.instance = new ConfigManager(configPath);
|
|
28
|
+
}
|
|
29
|
+
return ConfigManager.instance;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Load configuration from file or use defaults
|
|
33
|
+
*/
|
|
34
|
+
loadConfig() {
|
|
35
|
+
try {
|
|
36
|
+
if (fs.existsSync(this.configPath)) {
|
|
37
|
+
const content = fs.readFileSync(this.configPath, "utf-8");
|
|
38
|
+
const loaded = yaml.load(content);
|
|
39
|
+
return this.mergeWithDefaults(loaded);
|
|
40
|
+
}
|
|
41
|
+
} catch (error) {
|
|
42
|
+
console.warn(`Failed to load config from ${this.configPath}:`, error);
|
|
43
|
+
}
|
|
44
|
+
return this.mergeWithDefaults({});
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Merge loaded config with defaults
|
|
48
|
+
*/
|
|
49
|
+
mergeWithDefaults(loaded) {
|
|
50
|
+
const config = {
|
|
51
|
+
version: loaded.version || DEFAULT_CONFIG.version,
|
|
52
|
+
profile: loaded.profile,
|
|
53
|
+
scoring: {
|
|
54
|
+
weights: {
|
|
55
|
+
...DEFAULT_CONFIG.scoring.weights,
|
|
56
|
+
...loaded.scoring?.weights
|
|
57
|
+
},
|
|
58
|
+
tool_scores: {
|
|
59
|
+
...DEFAULT_CONFIG.scoring.tool_scores,
|
|
60
|
+
...loaded.scoring?.tool_scores
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
retention: {
|
|
64
|
+
local: {
|
|
65
|
+
...DEFAULT_CONFIG.retention.local,
|
|
66
|
+
...loaded.retention?.local
|
|
67
|
+
},
|
|
68
|
+
remote: {
|
|
69
|
+
...DEFAULT_CONFIG.retention.remote,
|
|
70
|
+
...loaded.retention?.remote
|
|
71
|
+
},
|
|
72
|
+
generational_gc: {
|
|
73
|
+
...DEFAULT_CONFIG.retention.generational_gc,
|
|
74
|
+
...loaded.retention?.generational_gc
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
performance: { ...DEFAULT_CONFIG.performance, ...loaded.performance },
|
|
78
|
+
profiles: { ...PRESET_PROFILES, ...loaded.profiles }
|
|
79
|
+
};
|
|
80
|
+
if (config.profile && config.profiles?.[config.profile]) {
|
|
81
|
+
this.applyProfile(config, config.profiles[config.profile]);
|
|
82
|
+
}
|
|
83
|
+
return config;
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Apply a profile to the configuration
|
|
87
|
+
*/
|
|
88
|
+
applyProfile(config, profile) {
|
|
89
|
+
if (profile.scoring) {
|
|
90
|
+
if (profile.scoring.weights) {
|
|
91
|
+
config.scoring.weights = {
|
|
92
|
+
...config.scoring.weights,
|
|
93
|
+
...profile.scoring.weights
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
if (profile.scoring.tool_scores) {
|
|
97
|
+
config.scoring.tool_scores = {
|
|
98
|
+
...config.scoring.tool_scores,
|
|
99
|
+
...profile.scoring.tool_scores
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
if (profile.retention) {
|
|
104
|
+
if (profile.retention.local) {
|
|
105
|
+
config.retention.local = {
|
|
106
|
+
...config.retention.local,
|
|
107
|
+
...profile.retention.local
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
if (profile.retention.remote) {
|
|
111
|
+
config.retention.remote = {
|
|
112
|
+
...config.retention.remote,
|
|
113
|
+
...profile.retention.remote
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
if (profile.retention.generational_gc) {
|
|
117
|
+
config.retention.generational_gc = {
|
|
118
|
+
...config.retention.generational_gc,
|
|
119
|
+
...profile.retention.generational_gc
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (profile.performance) {
|
|
124
|
+
config.performance = { ...config.performance, ...profile.performance };
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Validate configuration
|
|
129
|
+
*/
|
|
130
|
+
validate() {
|
|
131
|
+
const result = {
|
|
132
|
+
valid: true,
|
|
133
|
+
errors: [],
|
|
134
|
+
warnings: [],
|
|
135
|
+
suggestions: []
|
|
136
|
+
};
|
|
137
|
+
const weights = this.config.scoring.weights;
|
|
138
|
+
const weightSum = weights.base + weights.impact + weights.persistence + weights.reference;
|
|
139
|
+
if (Math.abs(weightSum - 1) > 1e-3) {
|
|
140
|
+
result.errors.push(
|
|
141
|
+
`Weights must sum to 1.0 (current: ${weightSum.toFixed(3)})`
|
|
142
|
+
);
|
|
143
|
+
result.valid = false;
|
|
144
|
+
}
|
|
145
|
+
Object.entries(weights).forEach(([key, value]) => {
|
|
146
|
+
if (value < 0 || value > 1) {
|
|
147
|
+
result.errors.push(
|
|
148
|
+
`Weight ${key} must be between 0 and 1 (current: ${value})`
|
|
149
|
+
);
|
|
150
|
+
result.valid = false;
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
Object.entries(this.config.scoring.tool_scores).forEach(([tool, score]) => {
|
|
154
|
+
if (score !== void 0 && (score < 0 || score > 1)) {
|
|
155
|
+
result.errors.push(
|
|
156
|
+
`Tool score for ${tool} must be between 0 and 1 (current: ${score})`
|
|
157
|
+
);
|
|
158
|
+
result.valid = false;
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
const youngMs = this.parseDuration(this.config.retention.local.young);
|
|
162
|
+
const matureMs = this.parseDuration(this.config.retention.local.mature);
|
|
163
|
+
const oldMs = this.parseDuration(this.config.retention.local.old);
|
|
164
|
+
if (youngMs >= matureMs) {
|
|
165
|
+
result.errors.push(
|
|
166
|
+
"Young retention period must be less than mature period"
|
|
167
|
+
);
|
|
168
|
+
result.valid = false;
|
|
169
|
+
}
|
|
170
|
+
if (matureMs >= oldMs) {
|
|
171
|
+
result.errors.push(
|
|
172
|
+
"Mature retention period must be less than old period"
|
|
173
|
+
);
|
|
174
|
+
result.valid = false;
|
|
175
|
+
}
|
|
176
|
+
const maxSize = this.parseSize(this.config.retention.local.max_size);
|
|
177
|
+
const availableSpace = this.getAvailableDiskSpace();
|
|
178
|
+
if (availableSpace > 0 && maxSize > availableSpace) {
|
|
179
|
+
result.warnings.push(
|
|
180
|
+
`max_size (${this.config.retention.local.max_size}) exceeds available disk space`
|
|
181
|
+
);
|
|
182
|
+
}
|
|
183
|
+
if (this.config.performance.retrieval_timeout_ms < 100) {
|
|
184
|
+
result.warnings.push(
|
|
185
|
+
"retrieval_timeout_ms < 100ms may be too aggressive"
|
|
186
|
+
);
|
|
187
|
+
}
|
|
188
|
+
if (this.config.performance.max_stack_depth > 1e4) {
|
|
189
|
+
result.warnings.push("max_stack_depth > 10000 may impact performance");
|
|
190
|
+
}
|
|
191
|
+
if (!this.config.profile) {
|
|
192
|
+
result.suggestions.push("Consider using a profile for your use case");
|
|
193
|
+
}
|
|
194
|
+
if (this.config?.scoring?.tool_scores?.search && this.config.scoring.tool_scores.search < 0.5) {
|
|
195
|
+
result.suggestions.push(
|
|
196
|
+
"Search tool score seems low - consider increasing for better discovery"
|
|
197
|
+
);
|
|
198
|
+
}
|
|
199
|
+
return result;
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Parse duration string to milliseconds
|
|
203
|
+
*/
|
|
204
|
+
parseDuration(duration) {
|
|
205
|
+
const match = duration.match(/^(\d+)([hdwm])$/);
|
|
206
|
+
if (!match) return 0;
|
|
207
|
+
const value = parseInt(match[1]);
|
|
208
|
+
const unit = match[2];
|
|
209
|
+
const multipliers = {
|
|
210
|
+
h: 36e5,
|
|
211
|
+
// hours
|
|
212
|
+
d: 864e5,
|
|
213
|
+
// days
|
|
214
|
+
w: 6048e5,
|
|
215
|
+
// weeks
|
|
216
|
+
m: 2592e6
|
|
217
|
+
// months (30 days)
|
|
218
|
+
};
|
|
219
|
+
return value * (multipliers[unit] || 0);
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Parse size string to bytes
|
|
223
|
+
*/
|
|
224
|
+
parseSize(size) {
|
|
225
|
+
const match = size.match(/^(\d+(?:\.\d+)?)([KMGT]B)?$/i);
|
|
226
|
+
if (!match) return 0;
|
|
227
|
+
const value = parseFloat(match[1]);
|
|
228
|
+
const unit = match[2]?.toUpperCase() || "B";
|
|
229
|
+
const multipliers = {
|
|
230
|
+
B: 1,
|
|
231
|
+
KB: 1024,
|
|
232
|
+
MB: 1024 * 1024,
|
|
233
|
+
GB: 1024 * 1024 * 1024,
|
|
234
|
+
TB: 1024 * 1024 * 1024 * 1024
|
|
235
|
+
};
|
|
236
|
+
return value * (multipliers[unit] || 1);
|
|
237
|
+
}
|
|
238
|
+
/**
|
|
239
|
+
* Get available disk space (simplified)
|
|
240
|
+
*/
|
|
241
|
+
getAvailableDiskSpace() {
|
|
242
|
+
return 0;
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* Save configuration to file
|
|
246
|
+
*/
|
|
247
|
+
save() {
|
|
248
|
+
const dir = path.dirname(this.configPath);
|
|
249
|
+
if (!fs.existsSync(dir)) {
|
|
250
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
251
|
+
}
|
|
252
|
+
const content = yaml.dump(this.config, {
|
|
253
|
+
indent: 2,
|
|
254
|
+
lineWidth: 120,
|
|
255
|
+
noRefs: true
|
|
256
|
+
});
|
|
257
|
+
fs.writeFileSync(this.configPath, content, "utf-8");
|
|
258
|
+
}
|
|
259
|
+
/**
|
|
260
|
+
* Get current configuration
|
|
261
|
+
*/
|
|
262
|
+
getConfig() {
|
|
263
|
+
return { ...this.config };
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Get a specific configuration value by path
|
|
267
|
+
* Example: config.get('project.id') returns config.project.id
|
|
268
|
+
*/
|
|
269
|
+
get(path2) {
|
|
270
|
+
const keys = path2.split(".");
|
|
271
|
+
let value = this.config;
|
|
272
|
+
for (const key of keys) {
|
|
273
|
+
if (value && typeof value === "object" && key in value) {
|
|
274
|
+
value = value[key];
|
|
275
|
+
} else {
|
|
276
|
+
return void 0;
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
return value;
|
|
280
|
+
}
|
|
281
|
+
/**
|
|
282
|
+
* Set active profile
|
|
283
|
+
*/
|
|
284
|
+
setProfile(profileName) {
|
|
285
|
+
const allProfiles = { ...PRESET_PROFILES, ...this.config.profiles };
|
|
286
|
+
if (!allProfiles[profileName]) {
|
|
287
|
+
return false;
|
|
288
|
+
}
|
|
289
|
+
this.config.profile = profileName;
|
|
290
|
+
this.applyProfile(this.config, allProfiles[profileName]);
|
|
291
|
+
this.notifyChange();
|
|
292
|
+
return true;
|
|
293
|
+
}
|
|
294
|
+
/**
|
|
295
|
+
* Update weights
|
|
296
|
+
*/
|
|
297
|
+
updateWeights(weights) {
|
|
298
|
+
this.config.scoring.weights = {
|
|
299
|
+
...this.config.scoring.weights,
|
|
300
|
+
...weights
|
|
301
|
+
};
|
|
302
|
+
this.notifyChange();
|
|
303
|
+
}
|
|
304
|
+
/**
|
|
305
|
+
* Update tool scores
|
|
306
|
+
*/
|
|
307
|
+
updateToolScores(scores) {
|
|
308
|
+
this.config.scoring.tool_scores = {
|
|
309
|
+
...this.config.scoring.tool_scores,
|
|
310
|
+
...scores
|
|
311
|
+
};
|
|
312
|
+
this.notifyChange();
|
|
313
|
+
}
|
|
314
|
+
/**
|
|
315
|
+
* Enable hot reload
|
|
316
|
+
*/
|
|
317
|
+
enableHotReload() {
|
|
318
|
+
if (this.fileWatcher) return;
|
|
319
|
+
if (fs.existsSync(this.configPath)) {
|
|
320
|
+
this.fileWatcher = fs.watch(this.configPath, (eventType) => {
|
|
321
|
+
if (eventType === "change") {
|
|
322
|
+
const newConfig = this.loadConfig();
|
|
323
|
+
const validation = this.validate();
|
|
324
|
+
if (validation.valid) {
|
|
325
|
+
this.config = newConfig;
|
|
326
|
+
this.notifyChange();
|
|
327
|
+
console.log("Configuration reloaded");
|
|
328
|
+
} else {
|
|
329
|
+
console.error(
|
|
330
|
+
"Invalid configuration, keeping previous:",
|
|
331
|
+
validation.errors
|
|
332
|
+
);
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
});
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
/**
|
|
339
|
+
* Disable hot reload
|
|
340
|
+
*/
|
|
341
|
+
disableHotReload() {
|
|
342
|
+
if (this.fileWatcher) {
|
|
343
|
+
this.fileWatcher.close();
|
|
344
|
+
this.fileWatcher = void 0;
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
/**
|
|
348
|
+
* Register change callback
|
|
349
|
+
*/
|
|
350
|
+
onChange(callback) {
|
|
351
|
+
this.onChangeCallbacks.push(callback);
|
|
352
|
+
}
|
|
353
|
+
/**
|
|
354
|
+
* Notify all change callbacks
|
|
355
|
+
*/
|
|
356
|
+
notifyChange() {
|
|
357
|
+
const config = this.getConfig();
|
|
358
|
+
this.onChangeCallbacks.forEach((cb) => cb(config));
|
|
359
|
+
}
|
|
360
|
+
/**
|
|
361
|
+
* Calculate importance score for a tool
|
|
362
|
+
*/
|
|
363
|
+
calculateScore(tool, additionalFactors) {
|
|
364
|
+
const baseScore = this.config.scoring.tool_scores[tool] || 0.5;
|
|
365
|
+
const weights = this.config.scoring.weights;
|
|
366
|
+
let score = baseScore * weights.base;
|
|
367
|
+
if (additionalFactors) {
|
|
368
|
+
if (additionalFactors.filesAffected !== void 0) {
|
|
369
|
+
const impactMultiplier = Math.min(
|
|
370
|
+
additionalFactors.filesAffected / 10,
|
|
371
|
+
1
|
|
372
|
+
);
|
|
373
|
+
score += impactMultiplier * weights.impact;
|
|
374
|
+
}
|
|
375
|
+
if (additionalFactors.isPermanent) {
|
|
376
|
+
score += 0.2 * weights.persistence;
|
|
377
|
+
}
|
|
378
|
+
if (additionalFactors.referenceCount !== void 0) {
|
|
379
|
+
const refMultiplier = Math.min(
|
|
380
|
+
additionalFactors.referenceCount / 100,
|
|
381
|
+
1
|
|
382
|
+
);
|
|
383
|
+
score += refMultiplier * weights.reference;
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
return Math.min(Math.max(score, 0), 1);
|
|
387
|
+
}
|
|
388
|
+
/**
|
|
389
|
+
* Get available profiles
|
|
390
|
+
*/
|
|
391
|
+
getProfiles() {
|
|
392
|
+
return { ...PRESET_PROFILES, ...this.config.profiles };
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
export {
|
|
396
|
+
ConfigManager
|
|
397
|
+
};
|
|
398
|
+
//# sourceMappingURL=config-manager.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/core/config/config-manager.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Configuration Manager for StackMemory\n * Handles loading, validation, and management of configuration\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as yaml from 'js-yaml';\nimport {\n StackMemoryConfig,\n ProfileConfig,\n DEFAULT_CONFIG,\n PRESET_PROFILES,\n ScoringWeights,\n} from './types.js';\n\nexport interface ValidationResult {\n valid: boolean;\n errors: string[];\n warnings: string[];\n suggestions: string[];\n}\n\nexport class ConfigManager {\n private static instance: ConfigManager | null = null;\n private config: StackMemoryConfig;\n private configPath: string;\n private fileWatcher?: fs.FSWatcher;\n private onChangeCallbacks: Array<(config: StackMemoryConfig) => void> = [];\n\n constructor(configPath?: string) {\n this.configPath =\n configPath || path.join(process.cwd(), '.stackmemory', 'config.yaml');\n this.config = this.loadConfig();\n }\n\n /**\n * Get singleton instance of ConfigManager\n */\n public static getInstance(configPath?: string): ConfigManager {\n if (!ConfigManager.instance) {\n ConfigManager.instance = new ConfigManager(configPath);\n }\n return ConfigManager.instance;\n }\n\n /**\n * Load configuration from file or use defaults\n */\n private loadConfig(): StackMemoryConfig {\n try {\n if (fs.existsSync(this.configPath)) {\n const content = fs.readFileSync(this.configPath, 'utf-8');\n const loaded = yaml.load(content) as Partial<StackMemoryConfig>;\n return this.mergeWithDefaults(loaded);\n }\n } catch (error: unknown) {\n console.warn(`Failed to load config from ${this.configPath}:`, error);\n }\n // Deep clone to prevent mutation of DEFAULT_CONFIG\n return this.mergeWithDefaults({});\n }\n\n /**\n * Merge loaded config with defaults\n */\n private mergeWithDefaults(\n loaded: Partial<StackMemoryConfig>\n ): StackMemoryConfig {\n const config: StackMemoryConfig = {\n version: loaded.version || DEFAULT_CONFIG.version,\n profile: loaded.profile,\n scoring: {\n weights: {\n ...DEFAULT_CONFIG.scoring.weights,\n ...loaded.scoring?.weights,\n },\n tool_scores: {\n ...DEFAULT_CONFIG.scoring.tool_scores,\n ...loaded.scoring?.tool_scores,\n },\n },\n retention: {\n local: {\n ...DEFAULT_CONFIG.retention.local,\n ...loaded.retention?.local,\n },\n remote: {\n ...DEFAULT_CONFIG.retention.remote,\n ...loaded.retention?.remote,\n },\n generational_gc: {\n ...DEFAULT_CONFIG.retention.generational_gc,\n ...loaded.retention?.generational_gc,\n },\n },\n performance: { ...DEFAULT_CONFIG.performance, ...loaded.performance },\n profiles: { ...PRESET_PROFILES, ...loaded.profiles },\n };\n\n // Apply active profile if specified\n if (config.profile && config.profiles?.[config.profile]) {\n this.applyProfile(config, config.profiles[config.profile]);\n }\n\n return config;\n }\n\n /**\n * Apply a profile to the configuration\n */\n private applyProfile(\n config: StackMemoryConfig,\n profile: ProfileConfig\n ): void {\n if (profile.scoring) {\n if (profile.scoring.weights) {\n config.scoring.weights = {\n ...config.scoring.weights,\n ...profile.scoring.weights,\n };\n }\n if (profile.scoring.tool_scores) {\n config.scoring.tool_scores = {\n ...config.scoring.tool_scores,\n ...profile.scoring.tool_scores,\n };\n }\n }\n\n if (profile.retention) {\n if (profile.retention.local) {\n config.retention.local = {\n ...config.retention.local,\n ...profile.retention.local,\n };\n }\n if (profile.retention.remote) {\n config.retention.remote = {\n ...config.retention.remote,\n ...profile.retention.remote,\n };\n }\n if (profile.retention.generational_gc) {\n config.retention.generational_gc = {\n ...config.retention.generational_gc,\n ...profile.retention.generational_gc,\n };\n }\n }\n\n if (profile.performance) {\n config.performance = { ...config.performance, ...profile.performance };\n }\n }\n\n /**\n * Validate configuration\n */\n validate(): ValidationResult {\n const result: ValidationResult = {\n valid: true,\n errors: [],\n warnings: [],\n suggestions: [],\n };\n\n // Validate weights sum to 1.0\n const weights = this.config.scoring.weights;\n const weightSum =\n weights.base + weights.impact + weights.persistence + weights.reference;\n if (Math.abs(weightSum - 1.0) > 0.001) {\n result.errors.push(\n `Weights must sum to 1.0 (current: ${weightSum.toFixed(3)})`\n );\n result.valid = false;\n }\n\n // Validate weight ranges\n Object.entries(weights).forEach(([key, value]) => {\n if (value < 0 || value > 1) {\n result.errors.push(\n `Weight ${key} must be between 0 and 1 (current: ${value})`\n );\n result.valid = false;\n }\n });\n\n // Validate tool scores\n Object.entries(this.config.scoring.tool_scores).forEach(([tool, score]) => {\n if (score !== undefined && (score < 0 || score > 1)) {\n result.errors.push(\n `Tool score for ${tool} must be between 0 and 1 (current: ${score})`\n );\n result.valid = false;\n }\n });\n\n // Validate retention periods are ordered\n const youngMs = this.parseDuration(this.config.retention.local.young);\n const matureMs = this.parseDuration(this.config.retention.local.mature);\n const oldMs = this.parseDuration(this.config.retention.local.old);\n\n if (youngMs >= matureMs) {\n result.errors.push(\n 'Young retention period must be less than mature period'\n );\n result.valid = false;\n }\n if (matureMs >= oldMs) {\n result.errors.push(\n 'Mature retention period must be less than old period'\n );\n result.valid = false;\n }\n\n // Validate max size\n const maxSize = this.parseSize(this.config.retention.local.max_size);\n const availableSpace = this.getAvailableDiskSpace();\n if (availableSpace > 0 && maxSize > availableSpace) {\n result.warnings.push(\n `max_size (${this.config.retention.local.max_size}) exceeds available disk space`\n );\n }\n\n // Performance warnings\n if (this.config.performance.retrieval_timeout_ms < 100) {\n result.warnings.push(\n 'retrieval_timeout_ms < 100ms may be too aggressive'\n );\n }\n\n if (this.config.performance.max_stack_depth > 10000) {\n result.warnings.push('max_stack_depth > 10000 may impact performance');\n }\n\n // Suggestions\n if (!this.config.profile) {\n result.suggestions.push('Consider using a profile for your use case');\n }\n\n if (\n this.config?.scoring?.tool_scores?.search &&\n this.config.scoring.tool_scores.search < 0.5\n ) {\n result.suggestions.push(\n 'Search tool score seems low - consider increasing for better discovery'\n );\n }\n\n return result;\n }\n\n /**\n * Parse duration string to milliseconds\n */\n private parseDuration(duration: string): number {\n const match = duration.match(/^(\\d+)([hdwm])$/);\n if (!match) return 0;\n\n const value = parseInt(match[1]);\n const unit = match[2];\n\n const multipliers: Record<string, number> = {\n h: 3600000, // hours\n d: 86400000, // days\n w: 604800000, // weeks\n m: 2592000000, // months (30 days)\n };\n\n return value * (multipliers[unit] || 0);\n }\n\n /**\n * Parse size string to bytes\n */\n private parseSize(size: string): number {\n const match = size.match(/^(\\d+(?:\\.\\d+)?)([KMGT]B)?$/i);\n if (!match) return 0;\n\n const value = parseFloat(match[1]);\n const unit = match[2]?.toUpperCase() || 'B';\n\n const multipliers: Record<string, number> = {\n B: 1,\n KB: 1024,\n MB: 1024 * 1024,\n GB: 1024 * 1024 * 1024,\n TB: 1024 * 1024 * 1024 * 1024,\n };\n\n return value * (multipliers[unit] || 1);\n }\n\n /**\n * Get available disk space (simplified)\n */\n private getAvailableDiskSpace(): number {\n // This would need platform-specific implementation\n // For now, return 0 to skip validation\n return 0;\n }\n\n /**\n * Save configuration to file\n */\n save(): void {\n const dir = path.dirname(this.configPath);\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n\n const content = yaml.dump(this.config, {\n indent: 2,\n lineWidth: 120,\n noRefs: true,\n });\n\n fs.writeFileSync(this.configPath, content, 'utf-8');\n }\n\n /**\n * Get current configuration\n */\n getConfig(): StackMemoryConfig {\n return { ...this.config };\n }\n\n /**\n * Get a specific configuration value by path\n * Example: config.get('project.id') returns config.project.id\n */\n get(path: string): any {\n const keys = path.split('.');\n let value: any = this.config;\n \n for (const key of keys) {\n if (value && typeof value === 'object' && key in value) {\n value = value[key];\n } else {\n return undefined;\n }\n }\n \n return value;\n }\n\n /**\n * Set active profile\n */\n setProfile(profileName: string): boolean {\n const allProfiles = { ...PRESET_PROFILES, ...this.config.profiles };\n if (!allProfiles[profileName]) {\n return false;\n }\n\n // Apply the profile to current config\n this.config.profile = profileName;\n this.applyProfile(this.config, allProfiles[profileName]);\n this.notifyChange();\n return true;\n }\n\n /**\n * Update weights\n */\n updateWeights(weights: Partial<ScoringWeights>): void {\n this.config.scoring.weights = {\n ...this.config.scoring.weights,\n ...weights,\n };\n this.notifyChange();\n }\n\n /**\n * Update tool scores\n */\n updateToolScores(scores: Record<string, number>): void {\n this.config.scoring.tool_scores = {\n ...this.config.scoring.tool_scores,\n ...scores,\n };\n this.notifyChange();\n }\n\n /**\n * Enable hot reload\n */\n enableHotReload(): void {\n if (this.fileWatcher) return;\n\n if (fs.existsSync(this.configPath)) {\n this.fileWatcher = fs.watch(this.configPath, (eventType) => {\n if (eventType === 'change') {\n const newConfig = this.loadConfig();\n const validation = this.validate();\n\n if (validation.valid) {\n this.config = newConfig;\n this.notifyChange();\n console.log('Configuration reloaded');\n } else {\n console.error(\n 'Invalid configuration, keeping previous:',\n validation.errors\n );\n }\n }\n });\n }\n }\n\n /**\n * Disable hot reload\n */\n disableHotReload(): void {\n if (this.fileWatcher) {\n this.fileWatcher.close();\n this.fileWatcher = undefined;\n }\n }\n\n /**\n * Register change callback\n */\n onChange(callback: (config: StackMemoryConfig) => void): void {\n this.onChangeCallbacks.push(callback);\n }\n\n /**\n * Notify all change callbacks\n */\n private notifyChange(): void {\n const config = this.getConfig();\n this.onChangeCallbacks.forEach((cb) => cb(config));\n }\n\n /**\n * Calculate importance score for a tool\n */\n calculateScore(\n tool: string,\n additionalFactors?: {\n filesAffected?: number;\n isPermanent?: boolean;\n referenceCount?: number;\n }\n ): number {\n const baseScore = this.config.scoring.tool_scores[tool] || 0.5;\n const weights = this.config.scoring.weights;\n\n let score = baseScore * weights.base;\n\n if (additionalFactors) {\n // Impact multiplier (files affected)\n if (additionalFactors.filesAffected !== undefined) {\n const impactMultiplier = Math.min(\n additionalFactors.filesAffected / 10,\n 1\n );\n score += impactMultiplier * weights.impact;\n }\n\n // Persistence bonus\n if (additionalFactors.isPermanent) {\n score += 0.2 * weights.persistence;\n }\n\n // Reference count\n if (additionalFactors.referenceCount !== undefined) {\n const refMultiplier = Math.min(\n additionalFactors.referenceCount / 100,\n 1\n );\n score += refMultiplier * weights.reference;\n }\n }\n\n return Math.min(Math.max(score, 0), 1); // Clamp to [0, 1]\n }\n\n /**\n * Get available profiles\n */\n getProfiles(): Record<string, ProfileConfig> {\n return { ...PRESET_PROFILES, ...this.config.profiles };\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["path"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { fileURLToPath as __fileURLToPath } from 'url';
|
|
2
|
+
import { dirname as __pathDirname } from 'path';
|
|
3
|
+
const __filename = __fileURLToPath(import.meta.url);
|
|
4
|
+
const __dirname = __pathDirname(__filename);
|
|
5
|
+
function isLocalOnly() {
|
|
6
|
+
return process.env["STACKMEMORY_LOCAL"] === "true" || process.env["STACKMEMORY_LOCAL"] === "1" || process.env["LOCAL_ONLY"] === "true";
|
|
7
|
+
}
|
|
8
|
+
function isFeatureEnabled(feature) {
|
|
9
|
+
if (feature === "core") return true;
|
|
10
|
+
if (isLocalOnly()) return false;
|
|
11
|
+
switch (feature) {
|
|
12
|
+
case "linear":
|
|
13
|
+
return process.env["STACKMEMORY_LINEAR"] !== "false" && (!!process.env["LINEAR_API_KEY"] || !!process.env["LINEAR_OAUTH_TOKEN"]);
|
|
14
|
+
case "whatsapp":
|
|
15
|
+
return process.env["STACKMEMORY_WHATSAPP"] !== "false" && !!process.env["TWILIO_ACCOUNT_SID"];
|
|
16
|
+
case "chromadb":
|
|
17
|
+
return process.env["STACKMEMORY_CHROMADB"] === "true";
|
|
18
|
+
case "aiSummaries":
|
|
19
|
+
return process.env["STACKMEMORY_AI"] !== "false" && (!!process.env["ANTHROPIC_API_KEY"] || !!process.env["OPENAI_API_KEY"]);
|
|
20
|
+
case "skills":
|
|
21
|
+
return process.env["STACKMEMORY_SKILLS"] === "true" || process.env["STACKMEMORY_SKILLS"] === "1";
|
|
22
|
+
case "ralph":
|
|
23
|
+
return process.env["STACKMEMORY_RALPH"] !== "false";
|
|
24
|
+
case "greptile":
|
|
25
|
+
return process.env["STACKMEMORY_GREPTILE"] !== "false" && !!process.env["GREPTILE_API_KEY"];
|
|
26
|
+
default:
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
function getFeatureFlags() {
|
|
31
|
+
return {
|
|
32
|
+
core: true,
|
|
33
|
+
linear: isFeatureEnabled("linear"),
|
|
34
|
+
whatsapp: isFeatureEnabled("whatsapp"),
|
|
35
|
+
chromadb: isFeatureEnabled("chromadb"),
|
|
36
|
+
aiSummaries: isFeatureEnabled("aiSummaries"),
|
|
37
|
+
skills: isFeatureEnabled("skills"),
|
|
38
|
+
ralph: isFeatureEnabled("ralph"),
|
|
39
|
+
greptile: isFeatureEnabled("greptile")
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
function logFeatureStatus() {
|
|
43
|
+
const flags = getFeatureFlags();
|
|
44
|
+
const local = isLocalOnly();
|
|
45
|
+
console.log(
|
|
46
|
+
`StackMemory Mode: ${local ? "LOCAL (no external services)" : "FULL"}`
|
|
47
|
+
);
|
|
48
|
+
if (!local) {
|
|
49
|
+
console.log(
|
|
50
|
+
` Linear: ${flags.linear ? "enabled" : "disabled (no API key)"}`
|
|
51
|
+
);
|
|
52
|
+
console.log(
|
|
53
|
+
` WhatsApp: ${flags.whatsapp ? "enabled" : "disabled (no Twilio)"}`
|
|
54
|
+
);
|
|
55
|
+
console.log(` ChromaDB: ${flags.chromadb ? "enabled" : "disabled"}`);
|
|
56
|
+
console.log(
|
|
57
|
+
` AI Summaries: ${flags.aiSummaries ? "enabled" : "disabled (no API key)"}`
|
|
58
|
+
);
|
|
59
|
+
console.log(
|
|
60
|
+
` Skills: ${flags.skills ? "enabled" : "disabled (set STACKMEMORY_SKILLS=true)"}`
|
|
61
|
+
);
|
|
62
|
+
console.log(
|
|
63
|
+
` Ralph: ${flags.ralph ? "enabled" : "disabled (set STACKMEMORY_RALPH=true)"}`
|
|
64
|
+
);
|
|
65
|
+
console.log(
|
|
66
|
+
` Greptile: ${flags.greptile ? "enabled" : "disabled (no GREPTILE_API_KEY)"}`
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
export {
|
|
71
|
+
getFeatureFlags,
|
|
72
|
+
isFeatureEnabled,
|
|
73
|
+
isLocalOnly,
|
|
74
|
+
logFeatureStatus
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=feature-flags.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/core/config/feature-flags.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Feature Flags Configuration\n * Controls which external integrations are enabled\n *\n * Set STACKMEMORY_LOCAL=true to run without any external services\n */\n\nexport interface FeatureFlags {\n // Core features (always available)\n core: true;\n\n // External integrations (can be disabled)\n linear: boolean;\n whatsapp: boolean;\n chromadb: boolean;\n aiSummaries: boolean;\n skills: boolean;\n ralph: boolean;\n greptile: boolean;\n}\n\n/**\n * Check if running in local-only mode\n * When true, all external service integrations are disabled\n */\nexport function isLocalOnly(): boolean {\n return (\n process.env['STACKMEMORY_LOCAL'] === 'true' ||\n process.env['STACKMEMORY_LOCAL'] === '1' ||\n process.env['LOCAL_ONLY'] === 'true'\n );\n}\n\n/**\n * Check if a specific feature is enabled\n */\nexport function isFeatureEnabled(feature: keyof FeatureFlags): boolean {\n if (feature === 'core') return true;\n\n // In local-only mode, external integrations are disabled\n if (isLocalOnly()) return false;\n\n // Check feature-specific env vars\n switch (feature) {\n case 'linear':\n return (\n process.env['STACKMEMORY_LINEAR'] !== 'false' &&\n (!!process.env['LINEAR_API_KEY'] || !!process.env['LINEAR_OAUTH_TOKEN'])\n );\n case 'whatsapp':\n return (\n process.env['STACKMEMORY_WHATSAPP'] !== 'false' &&\n !!process.env['TWILIO_ACCOUNT_SID']\n );\n case 'chromadb':\n return process.env['STACKMEMORY_CHROMADB'] === 'true';\n case 'aiSummaries':\n return (\n process.env['STACKMEMORY_AI'] !== 'false' &&\n (!!process.env['ANTHROPIC_API_KEY'] || !!process.env['OPENAI_API_KEY'])\n );\n case 'skills':\n // Skills enabled explicitly or when AI summaries available\n return (\n process.env['STACKMEMORY_SKILLS'] === 'true' ||\n process.env['STACKMEMORY_SKILLS'] === '1'\n );\n case 'ralph':\n // Ralph enabled by default in development (unless explicitly disabled)\n // For npm package users, must be explicitly enabled\n return process.env['STACKMEMORY_RALPH'] !== 'false';\n case 'greptile':\n // Greptile enabled when API key is available\n return (\n process.env['STACKMEMORY_GREPTILE'] !== 'false' &&\n !!process.env['GREPTILE_API_KEY']\n );\n default:\n return false;\n }\n}\n\n/**\n * Get all feature flags\n */\nexport function getFeatureFlags(): FeatureFlags {\n return {\n core: true,\n linear: isFeatureEnabled('linear'),\n whatsapp: isFeatureEnabled('whatsapp'),\n chromadb: isFeatureEnabled('chromadb'),\n aiSummaries: isFeatureEnabled('aiSummaries'),\n skills: isFeatureEnabled('skills'),\n ralph: isFeatureEnabled('ralph'),\n greptile: isFeatureEnabled('greptile'),\n };\n}\n\n/**\n * Log feature flags status (for debugging)\n */\nexport function logFeatureStatus(): void {\n const flags = getFeatureFlags();\n const local = isLocalOnly();\n\n console.log(\n `StackMemory Mode: ${local ? 'LOCAL (no external services)' : 'FULL'}`\n );\n if (!local) {\n console.log(\n ` Linear: ${flags.linear ? 'enabled' : 'disabled (no API key)'}`\n );\n console.log(\n ` WhatsApp: ${flags.whatsapp ? 'enabled' : 'disabled (no Twilio)'}`\n );\n console.log(` ChromaDB: ${flags.chromadb ? 'enabled' : 'disabled'}`);\n console.log(\n ` AI Summaries: ${flags.aiSummaries ? 'enabled' : 'disabled (no API key)'}`\n );\n console.log(\n ` Skills: ${flags.skills ? 'enabled' : 'disabled (set STACKMEMORY_SKILLS=true)'}`\n );\n console.log(\n ` Ralph: ${flags.ralph ? 'enabled' : 'disabled (set STACKMEMORY_RALPH=true)'}`\n );\n console.log(\n ` Greptile: ${flags.greptile ? 'enabled' : 'disabled (no GREPTILE_API_KEY)'}`\n );\n }\n}\n"],
|
|
5
|
+
"mappings": ";;;;AAyBO,SAAS,cAAuB;AACrC,SACE,QAAQ,IAAI,mBAAmB,MAAM,UACrC,QAAQ,IAAI,mBAAmB,MAAM,OACrC,QAAQ,IAAI,YAAY,MAAM;AAElC;AAKO,SAAS,iBAAiB,SAAsC;AACrE,MAAI,YAAY,OAAQ,QAAO;AAG/B,MAAI,YAAY,EAAG,QAAO;AAG1B,UAAQ,SAAS;AAAA,IACf,KAAK;AACH,aACE,QAAQ,IAAI,oBAAoB,MAAM,YACrC,CAAC,CAAC,QAAQ,IAAI,gBAAgB,KAAK,CAAC,CAAC,QAAQ,IAAI,oBAAoB;AAAA,IAE1E,KAAK;AACH,aACE,QAAQ,IAAI,sBAAsB,MAAM,WACxC,CAAC,CAAC,QAAQ,IAAI,oBAAoB;AAAA,IAEtC,KAAK;AACH,aAAO,QAAQ,IAAI,sBAAsB,MAAM;AAAA,IACjD,KAAK;AACH,aACE,QAAQ,IAAI,gBAAgB,MAAM,YACjC,CAAC,CAAC,QAAQ,IAAI,mBAAmB,KAAK,CAAC,CAAC,QAAQ,IAAI,gBAAgB;AAAA,IAEzE,KAAK;AAEH,aACE,QAAQ,IAAI,oBAAoB,MAAM,UACtC,QAAQ,IAAI,oBAAoB,MAAM;AAAA,IAE1C,KAAK;AAGH,aAAO,QAAQ,IAAI,mBAAmB,MAAM;AAAA,IAC9C,KAAK;AAEH,aACE,QAAQ,IAAI,sBAAsB,MAAM,WACxC,CAAC,CAAC,QAAQ,IAAI,kBAAkB;AAAA,IAEpC;AACE,aAAO;AAAA,EACX;AACF;AAKO,SAAS,kBAAgC;AAC9C,SAAO;AAAA,IACL,MAAM;AAAA,IACN,QAAQ,iBAAiB,QAAQ;AAAA,IACjC,UAAU,iBAAiB,UAAU;AAAA,IACrC,UAAU,iBAAiB,UAAU;AAAA,IACrC,aAAa,iBAAiB,aAAa;AAAA,IAC3C,QAAQ,iBAAiB,QAAQ;AAAA,IACjC,OAAO,iBAAiB,OAAO;AAAA,IAC/B,UAAU,iBAAiB,UAAU;AAAA,EACvC;AACF;AAKO,SAAS,mBAAyB;AACvC,QAAM,QAAQ,gBAAgB;AAC9B,QAAM,QAAQ,YAAY;AAE1B,UAAQ;AAAA,IACN,qBAAqB,QAAQ,iCAAiC,MAAM;AAAA,EACtE;AACA,MAAI,CAAC,OAAO;AACV,YAAQ;AAAA,MACN,aAAa,MAAM,SAAS,YAAY,uBAAuB;AAAA,IACjE;AACA,YAAQ;AAAA,MACN,eAAe,MAAM,WAAW,YAAY,sBAAsB;AAAA,IACpE;AACA,YAAQ,IAAI,eAAe,MAAM,WAAW,YAAY,UAAU,EAAE;AACpE,YAAQ;AAAA,MACN,mBAAmB,MAAM,cAAc,YAAY,uBAAuB;AAAA,IAC5E;AACA,YAAQ;AAAA,MACN,aAAa,MAAM,SAAS,YAAY,wCAAwC;AAAA,IAClF;AACA,YAAQ;AAAA,MACN,YAAY,MAAM,QAAQ,YAAY,uCAAuC;AAAA,IAC/E;AACA,YAAQ;AAAA,MACN,eAAe,MAAM,WAAW,YAAY,gCAAgC;AAAA,IAC9E;AAAA,EACF;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|