@stackmemoryai/stackmemory 0.5.59 → 0.5.61
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/README.md +105 -1
- package/dist/src/cli/claude-sm.js +130 -50
- package/dist/src/cli/claude-sm.js.map +2 -2
- package/dist/src/cli/index.js +18 -3
- package/dist/src/cli/index.js.map +3 -3
- package/dist/src/core/extensions/custom-tools.js +567 -0
- package/dist/src/core/extensions/custom-tools.js.map +7 -0
- package/dist/src/core/extensions/index.js +55 -0
- package/dist/src/core/extensions/index.js.map +7 -0
- package/dist/src/core/extensions/loader.js +709 -0
- package/dist/src/core/extensions/loader.js.map +7 -0
- package/dist/src/core/extensions/plugin-system.js +506 -0
- package/dist/src/core/extensions/plugin-system.js.map +7 -0
- package/dist/src/core/extensions/provider-adapter.js +617 -0
- package/dist/src/core/extensions/provider-adapter.js.map +7 -0
- package/dist/src/core/extensions/sandbox-runtime.js +664 -0
- package/dist/src/core/extensions/sandbox-runtime.js.map +7 -0
- package/dist/src/core/storage/chromadb-adapter.js +32 -6
- package/dist/src/core/storage/chromadb-adapter.js.map +2 -2
- package/dist/src/skills/repo-ingestion-skill.js +35 -12
- package/dist/src/skills/repo-ingestion-skill.js.map +2 -2
- package/package.json +11 -7
- package/scripts/background-sync-manager.js +145 -83
- package/scripts/claude-sm-autostart.js +17 -12
- package/scripts/gepa/README.md +275 -0
- package/scripts/gepa/config.json +53 -0
- package/scripts/gepa/evals/coding-tasks.jsonl +5 -0
- package/scripts/gepa/evals/fixtures/buggy-loop.js +18 -0
- package/scripts/gepa/evals/fixtures/callback-hell.js +53 -0
- package/scripts/gepa/generations/gen-000/baseline.md +124 -0
- package/scripts/gepa/hooks/auto-optimize.js +494 -0
- package/scripts/gepa/hooks/eval-tracker.js +203 -0
- package/scripts/gepa/hooks/reflect.js +311 -0
- package/scripts/gepa/optimize.js +611 -0
- package/scripts/gepa/state.json +14 -0
- package/scripts/test-pre-publish-quick.sh +1 -1
- package/dist/agents/core/agent-task-manager.js +0 -527
- package/dist/agents/core/agent-task-manager.js.map +0 -7
- package/dist/agents/testing-agent.js +0 -614
- package/dist/agents/testing-agent.js.map +0 -7
- package/dist/agents/verifiers/base-verifier.js +0 -133
- package/dist/agents/verifiers/base-verifier.js.map +0 -7
- package/dist/agents/verifiers/formatter-verifier.js +0 -130
- package/dist/agents/verifiers/formatter-verifier.js.map +0 -7
- package/dist/agents/verifiers/llm-judge.js +0 -252
- package/dist/agents/verifiers/llm-judge.js.map +0 -7
- package/dist/cli/auto-detect.js +0 -321
- package/dist/cli/auto-detect.js.map +0 -7
- package/dist/cli/browser-test.js +0 -33
- package/dist/cli/browser-test.js.map +0 -7
- package/dist/cli/claude-sm-danger.js +0 -21
- package/dist/cli/claude-sm-danger.js.map +0 -7
- package/dist/cli/claude-sm.js +0 -1156
- package/dist/cli/claude-sm.js.map +0 -7
- package/dist/cli/codex-sm-danger.js +0 -21
- package/dist/cli/codex-sm-danger.js.map +0 -7
- package/dist/cli/codex-sm.js +0 -349
- package/dist/cli/codex-sm.js.map +0 -7
- package/dist/cli/commands/api.js +0 -232
- package/dist/cli/commands/api.js.map +0 -7
- package/dist/cli/commands/auto-background.js +0 -180
- package/dist/cli/commands/auto-background.js.map +0 -7
- package/dist/cli/commands/cleanup-processes.js +0 -68
- package/dist/cli/commands/cleanup-processes.js.map +0 -7
- package/dist/cli/commands/clear.js +0 -202
- package/dist/cli/commands/clear.js.map +0 -7
- package/dist/cli/commands/config.js +0 -445
- package/dist/cli/commands/config.js.map +0 -7
- package/dist/cli/commands/context-rehydrate.js +0 -751
- package/dist/cli/commands/context-rehydrate.js.map +0 -7
- package/dist/cli/commands/context.js +0 -343
- package/dist/cli/commands/context.js.map +0 -7
- package/dist/cli/commands/daemon.js +0 -392
- package/dist/cli/commands/daemon.js.map +0 -7
- package/dist/cli/commands/dashboard.js +0 -210
- package/dist/cli/commands/dashboard.js.map +0 -7
- package/dist/cli/commands/db.js +0 -147
- package/dist/cli/commands/db.js.map +0 -7
- package/dist/cli/commands/decision.js +0 -266
- package/dist/cli/commands/decision.js.map +0 -7
- package/dist/cli/commands/discovery.js +0 -279
- package/dist/cli/commands/discovery.js.map +0 -7
- package/dist/cli/commands/handoff.js +0 -624
- package/dist/cli/commands/handoff.js.map +0 -7
- package/dist/cli/commands/hooks.js +0 -298
- package/dist/cli/commands/hooks.js.map +0 -7
- package/dist/cli/commands/linear-unified.js +0 -353
- package/dist/cli/commands/linear-unified.js.map +0 -7
- package/dist/cli/commands/linear.js +0 -529
- package/dist/cli/commands/linear.js.map +0 -7
- package/dist/cli/commands/log.js +0 -169
- package/dist/cli/commands/log.js.map +0 -7
- package/dist/cli/commands/login.js +0 -172
- package/dist/cli/commands/login.js.map +0 -7
- package/dist/cli/commands/migrate.js +0 -240
- package/dist/cli/commands/migrate.js.map +0 -7
- package/dist/cli/commands/model.js +0 -533
- package/dist/cli/commands/model.js.map +0 -7
- package/dist/cli/commands/monitor.js +0 -313
- package/dist/cli/commands/monitor.js.map +0 -7
- package/dist/cli/commands/onboard.js +0 -536
- package/dist/cli/commands/onboard.js.map +0 -7
- package/dist/cli/commands/projects.js +0 -199
- package/dist/cli/commands/projects.js.map +0 -7
- package/dist/cli/commands/quality.js +0 -413
- package/dist/cli/commands/quality.js.map +0 -7
- package/dist/cli/commands/ralph.js +0 -909
- package/dist/cli/commands/ralph.js.map +0 -7
- package/dist/cli/commands/retrieval.js +0 -248
- package/dist/cli/commands/retrieval.js.map +0 -7
- package/dist/cli/commands/search.js +0 -173
- package/dist/cli/commands/search.js.map +0 -7
- package/dist/cli/commands/service.js +0 -749
- package/dist/cli/commands/service.js.map +0 -7
- package/dist/cli/commands/session.js +0 -200
- package/dist/cli/commands/session.js.map +0 -7
- package/dist/cli/commands/settings.js +0 -306
- package/dist/cli/commands/settings.js.map +0 -7
- package/dist/cli/commands/setup.js +0 -701
- package/dist/cli/commands/setup.js.map +0 -7
- package/dist/cli/commands/shell.js +0 -249
- package/dist/cli/commands/shell.js.map +0 -7
- package/dist/cli/commands/signup.js +0 -50
- package/dist/cli/commands/signup.js.map +0 -7
- package/dist/cli/commands/skills.js +0 -470
- package/dist/cli/commands/skills.js.map +0 -7
- package/dist/cli/commands/sms-notify.js +0 -795
- package/dist/cli/commands/sms-notify.js.map +0 -7
- package/dist/cli/commands/storage-tier.js +0 -183
- package/dist/cli/commands/storage-tier.js.map +0 -7
- package/dist/cli/commands/storage.js +0 -360
- package/dist/cli/commands/storage.js.map +0 -7
- package/dist/cli/commands/sweep.js +0 -249
- package/dist/cli/commands/sweep.js.map +0 -7
- package/dist/cli/commands/tasks.js +0 -213
- package/dist/cli/commands/tasks.js.map +0 -7
- package/dist/cli/commands/test.js +0 -286
- package/dist/cli/commands/test.js.map +0 -7
- package/dist/cli/commands/workflow.js +0 -142
- package/dist/cli/commands/workflow.js.map +0 -7
- package/dist/cli/commands/worktree.js +0 -319
- package/dist/cli/commands/worktree.js.map +0 -7
- package/dist/cli/index.js +0 -594
- package/dist/cli/index.js.map +0 -7
- package/dist/cli/opencode-sm.js +0 -448
- package/dist/cli/opencode-sm.js.map +0 -7
- package/dist/cli/utils/viewer.js +0 -96
- package/dist/cli/utils/viewer.js.map +0 -7
- package/dist/core/analytics/team-analytics.js +0 -378
- package/dist/core/analytics/team-analytics.js.map +0 -7
- package/dist/core/config/config-manager.js +0 -398
- package/dist/core/config/config-manager.js.map +0 -7
- package/dist/core/config/feature-flags.js +0 -76
- package/dist/core/config/feature-flags.js.map +0 -7
- package/dist/core/config/storage-config.js +0 -115
- package/dist/core/config/storage-config.js.map +0 -7
- package/dist/core/config/types.js +0 -144
- package/dist/core/config/types.js.map +0 -7
- package/dist/core/context/auto-context.js +0 -80
- package/dist/core/context/auto-context.js.map +0 -7
- package/dist/core/context/dual-stack-manager.js +0 -870
- package/dist/core/context/dual-stack-manager.js.map +0 -7
- package/dist/core/context/enhanced-rehydration.js +0 -994
- package/dist/core/context/enhanced-rehydration.js.map +0 -7
- package/dist/core/context/frame-database.js +0 -479
- package/dist/core/context/frame-database.js.map +0 -7
- package/dist/core/context/frame-digest.js +0 -250
- package/dist/core/context/frame-digest.js.map +0 -7
- package/dist/core/context/frame-handoff-manager.js +0 -778
- package/dist/core/context/frame-handoff-manager.js.map +0 -7
- package/dist/core/context/frame-lifecycle-hooks.js +0 -119
- package/dist/core/context/frame-lifecycle-hooks.js.map +0 -7
- package/dist/core/context/frame-manager.js +0 -1069
- package/dist/core/context/frame-manager.js.map +0 -7
- package/dist/core/context/frame-recovery.js +0 -302
- package/dist/core/context/frame-recovery.js.map +0 -7
- package/dist/core/context/frame-stack.js +0 -314
- package/dist/core/context/frame-stack.js.map +0 -7
- package/dist/core/context/frame-types.js +0 -5
- package/dist/core/context/frame-types.js.map +0 -7
- package/dist/core/context/incremental-gc.js +0 -290
- package/dist/core/context/incremental-gc.js.map +0 -7
- package/dist/core/context/index.js +0 -25
- package/dist/core/context/index.js.map +0 -7
- package/dist/core/context/model-aware-compaction.js +0 -623
- package/dist/core/context/model-aware-compaction.js.map +0 -7
- package/dist/core/context/permission-manager.js +0 -185
- package/dist/core/context/permission-manager.js.map +0 -7
- package/dist/core/context/recursive-context-manager.js +0 -592
- package/dist/core/context/recursive-context-manager.js.map +0 -7
- package/dist/core/context/refactored-frame-manager.js +0 -754
- package/dist/core/context/refactored-frame-manager.js.map +0 -7
- package/dist/core/context/shared-context-layer.js +0 -621
- package/dist/core/context/shared-context-layer.js.map +0 -7
- package/dist/core/context/stack-merge-resolver.js +0 -749
- package/dist/core/context/stack-merge-resolver.js.map +0 -7
- package/dist/core/context/validation.js +0 -130
- package/dist/core/context/validation.js.map +0 -7
- package/dist/core/database/batch-operations.js +0 -384
- package/dist/core/database/batch-operations.js.map +0 -7
- package/dist/core/database/connection-pool.js +0 -330
- package/dist/core/database/connection-pool.js.map +0 -7
- package/dist/core/database/database-adapter.js +0 -60
- package/dist/core/database/database-adapter.js.map +0 -7
- package/dist/core/database/migration-manager.js +0 -614
- package/dist/core/database/migration-manager.js.map +0 -7
- package/dist/core/database/paradedb-adapter.js +0 -990
- package/dist/core/database/paradedb-adapter.js.map +0 -7
- package/dist/core/database/query-cache.js +0 -298
- package/dist/core/database/query-cache.js.map +0 -7
- package/dist/core/database/query-router.js +0 -430
- package/dist/core/database/query-router.js.map +0 -7
- package/dist/core/database/sqlite-adapter.js +0 -738
- package/dist/core/database/sqlite-adapter.js.map +0 -7
- package/dist/core/digest/enhanced-hybrid-digest.js +0 -277
- package/dist/core/digest/enhanced-hybrid-digest.js.map +0 -7
- package/dist/core/digest/frame-digest-integration.js +0 -176
- package/dist/core/digest/frame-digest-integration.js.map +0 -7
- package/dist/core/digest/hybrid-digest-generator.js +0 -553
- package/dist/core/digest/hybrid-digest-generator.js.map +0 -7
- package/dist/core/digest/index.js +0 -9
- package/dist/core/digest/index.js.map +0 -7
- package/dist/core/digest/types.js +0 -25
- package/dist/core/digest/types.js.map +0 -7
- package/dist/core/errors/error-utils.js +0 -208
- package/dist/core/errors/error-utils.js.map +0 -7
- package/dist/core/errors/index.js +0 -521
- package/dist/core/errors/index.js.map +0 -7
- package/dist/core/errors/recovery.js +0 -269
- package/dist/core/errors/recovery.js.map +0 -7
- package/dist/core/execution/parallel-executor.js +0 -258
- package/dist/core/execution/parallel-executor.js.map +0 -7
- package/dist/core/frame/workflow-templates.js +0 -319
- package/dist/core/frame/workflow-templates.js.map +0 -7
- package/dist/core/merge/conflict-detector.js +0 -431
- package/dist/core/merge/conflict-detector.js.map +0 -7
- package/dist/core/merge/index.js +0 -9
- package/dist/core/merge/index.js.map +0 -7
- package/dist/core/merge/resolution-engine.js +0 -558
- package/dist/core/merge/resolution-engine.js.map +0 -7
- package/dist/core/merge/stack-diff.js +0 -532
- package/dist/core/merge/stack-diff.js.map +0 -7
- package/dist/core/merge/unified-merge-resolver.js +0 -303
- package/dist/core/merge/unified-merge-resolver.js.map +0 -7
- package/dist/core/models/fallback-monitor.js +0 -232
- package/dist/core/models/fallback-monitor.js.map +0 -7
- package/dist/core/models/model-router.js +0 -340
- package/dist/core/models/model-router.js.map +0 -7
- package/dist/core/monitoring/error-handler.js +0 -49
- package/dist/core/monitoring/error-handler.js.map +0 -7
- package/dist/core/monitoring/logger.js +0 -202
- package/dist/core/monitoring/logger.js.map +0 -7
- package/dist/core/monitoring/metrics.js +0 -172
- package/dist/core/monitoring/metrics.js.map +0 -7
- package/dist/core/monitoring/progress-tracker.js +0 -189
- package/dist/core/monitoring/progress-tracker.js.map +0 -7
- package/dist/core/monitoring/session-monitor.js +0 -300
- package/dist/core/monitoring/session-monitor.js.map +0 -7
- package/dist/core/performance/context-cache.js +0 -273
- package/dist/core/performance/context-cache.js.map +0 -7
- package/dist/core/performance/index.js +0 -11
- package/dist/core/performance/index.js.map +0 -7
- package/dist/core/performance/lazy-context-loader.js +0 -327
- package/dist/core/performance/lazy-context-loader.js.map +0 -7
- package/dist/core/performance/monitor.js +0 -221
- package/dist/core/performance/monitor.js.map +0 -7
- package/dist/core/performance/optimized-frame-context.js +0 -345
- package/dist/core/performance/optimized-frame-context.js.map +0 -7
- package/dist/core/performance/performance-benchmark.js +0 -277
- package/dist/core/performance/performance-benchmark.js.map +0 -7
- package/dist/core/performance/performance-profiler.js +0 -370
- package/dist/core/performance/performance-profiler.js.map +0 -7
- package/dist/core/performance/streaming-jsonl-parser.js +0 -195
- package/dist/core/performance/streaming-jsonl-parser.js.map +0 -7
- package/dist/core/persistence/postgres-adapter.js +0 -349
- package/dist/core/persistence/postgres-adapter.js.map +0 -7
- package/dist/core/projects/project-isolation.js +0 -201
- package/dist/core/projects/project-isolation.js.map +0 -7
- package/dist/core/projects/project-manager.js +0 -697
- package/dist/core/projects/project-manager.js.map +0 -7
- package/dist/core/query/query-parser.js +0 -370
- package/dist/core/query/query-parser.js.map +0 -7
- package/dist/core/query/query-templates.js +0 -321
- package/dist/core/query/query-templates.js.map +0 -7
- package/dist/core/retrieval/context-retriever.js +0 -479
- package/dist/core/retrieval/context-retriever.js.map +0 -7
- package/dist/core/retrieval/graph-retrieval.js +0 -662
- package/dist/core/retrieval/graph-retrieval.js.map +0 -7
- package/dist/core/retrieval/hierarchical-retrieval.js +0 -656
- package/dist/core/retrieval/hierarchical-retrieval.js.map +0 -7
- package/dist/core/retrieval/index.js +0 -8
- package/dist/core/retrieval/index.js.map +0 -7
- package/dist/core/retrieval/llm-context-retrieval.js +0 -613
- package/dist/core/retrieval/llm-context-retrieval.js.map +0 -7
- package/dist/core/retrieval/llm-provider.js +0 -151
- package/dist/core/retrieval/llm-provider.js.map +0 -7
- package/dist/core/retrieval/retrieval-audit.js +0 -236
- package/dist/core/retrieval/retrieval-audit.js.map +0 -7
- package/dist/core/retrieval/retrieval-benchmarks.js +0 -521
- package/dist/core/retrieval/retrieval-benchmarks.js.map +0 -7
- package/dist/core/retrieval/summary-generator.js +0 -589
- package/dist/core/retrieval/summary-generator.js.map +0 -7
- package/dist/core/retrieval/types.js +0 -21
- package/dist/core/retrieval/types.js.map +0 -7
- package/dist/core/security/index.js +0 -35
- package/dist/core/security/index.js.map +0 -7
- package/dist/core/security/input-sanitizer.js +0 -321
- package/dist/core/security/input-sanitizer.js.map +0 -7
- package/dist/core/session/clear-survival.js +0 -465
- package/dist/core/session/clear-survival.js.map +0 -7
- package/dist/core/session/enhanced-handoff.js +0 -792
- package/dist/core/session/enhanced-handoff.js.map +0 -7
- package/dist/core/session/handoff-generator.js +0 -343
- package/dist/core/session/handoff-generator.js.map +0 -7
- package/dist/core/session/index.js +0 -15
- package/dist/core/session/index.js.map +0 -7
- package/dist/core/session/session-manager.js +0 -347
- package/dist/core/session/session-manager.js.map +0 -7
- package/dist/core/skills/index.js +0 -7
- package/dist/core/skills/index.js.map +0 -7
- package/dist/core/skills/skill-storage.js +0 -764
- package/dist/core/skills/skill-storage.js.map +0 -7
- package/dist/core/skills/types.js +0 -193
- package/dist/core/skills/types.js.map +0 -7
- package/dist/core/storage/chromadb-adapter.js +0 -354
- package/dist/core/storage/chromadb-adapter.js.map +0 -7
- package/dist/core/storage/infinite-storage.js +0 -510
- package/dist/core/storage/infinite-storage.js.map +0 -7
- package/dist/core/storage/railway-optimized-storage.js +0 -591
- package/dist/core/storage/railway-optimized-storage.js.map +0 -7
- package/dist/core/storage/remote-storage.js +0 -489
- package/dist/core/storage/remote-storage.js.map +0 -7
- package/dist/core/storage/two-tier-storage.js +0 -766
- package/dist/core/storage/two-tier-storage.js.map +0 -7
- package/dist/core/trace/cli-trace-wrapper.js +0 -132
- package/dist/core/trace/cli-trace-wrapper.js.map +0 -7
- package/dist/core/trace/db-trace-wrapper.js +0 -247
- package/dist/core/trace/db-trace-wrapper.js.map +0 -7
- package/dist/core/trace/debug-trace.js +0 -417
- package/dist/core/trace/debug-trace.js.map +0 -7
- package/dist/core/trace/index.js +0 -109
- package/dist/core/trace/index.js.map +0 -7
- package/dist/core/trace/linear-api-wrapper.js +0 -178
- package/dist/core/trace/linear-api-wrapper.js.map +0 -7
- package/dist/core/trace/trace-demo.js +0 -154
- package/dist/core/trace/trace-demo.js.map +0 -7
- package/dist/core/trace/trace-detector.demo.js +0 -142
- package/dist/core/trace/trace-detector.demo.js.map +0 -7
- package/dist/core/trace/trace-detector.js +0 -528
- package/dist/core/trace/trace-detector.js.map +0 -7
- package/dist/core/trace/trace-store.js +0 -345
- package/dist/core/trace/trace-store.js.map +0 -7
- package/dist/core/trace/types.js +0 -77
- package/dist/core/trace/types.js.map +0 -7
- package/dist/core/types.js +0 -5
- package/dist/core/types.js.map +0 -7
- package/dist/core/utils/async-mutex.js +0 -114
- package/dist/core/utils/async-mutex.js.map +0 -7
- package/dist/core/utils/compression.js +0 -83
- package/dist/core/utils/compression.js.map +0 -7
- package/dist/core/utils/update-checker.js +0 -218
- package/dist/core/utils/update-checker.js.map +0 -7
- package/dist/core/worktree/worktree-manager.js +0 -465
- package/dist/core/worktree/worktree-manager.js.map +0 -7
- package/dist/daemon/daemon-config.js +0 -149
- package/dist/daemon/daemon-config.js.map +0 -7
- package/dist/daemon/services/context-service.js +0 -122
- package/dist/daemon/services/context-service.js.map +0 -7
- package/dist/daemon/services/linear-service.js +0 -136
- package/dist/daemon/services/linear-service.js.map +0 -7
- package/dist/daemon/session-daemon.js +0 -312
- package/dist/daemon/session-daemon.js.map +0 -7
- package/dist/daemon/unified-daemon.js +0 -276
- package/dist/daemon/unified-daemon.js.map +0 -7
- package/dist/features/analytics/api/analytics-api.js +0 -287
- package/dist/features/analytics/api/analytics-api.js.map +0 -7
- package/dist/features/analytics/core/analytics-service.js +0 -282
- package/dist/features/analytics/core/analytics-service.js.map +0 -7
- package/dist/features/analytics/index.js +0 -18
- package/dist/features/analytics/index.js.map +0 -7
- package/dist/features/analytics/queries/metrics-queries.js +0 -277
- package/dist/features/analytics/queries/metrics-queries.js.map +0 -7
- package/dist/features/analytics/types/metrics.js +0 -5
- package/dist/features/analytics/types/metrics.js.map +0 -7
- package/dist/features/browser/browser-mcp.js +0 -492
- package/dist/features/browser/browser-mcp.js.map +0 -7
- package/dist/features/sweep/index.js +0 -20
- package/dist/features/sweep/index.js.map +0 -7
- package/dist/features/sweep/prediction-client.js +0 -155
- package/dist/features/sweep/prediction-client.js.map +0 -7
- package/dist/features/sweep/prompt-builder.js +0 -85
- package/dist/features/sweep/prompt-builder.js.map +0 -7
- package/dist/features/sweep/pty-wrapper.js +0 -171
- package/dist/features/sweep/pty-wrapper.js.map +0 -7
- package/dist/features/sweep/state-watcher.js +0 -87
- package/dist/features/sweep/state-watcher.js.map +0 -7
- package/dist/features/sweep/status-bar.js +0 -88
- package/dist/features/sweep/status-bar.js.map +0 -7
- package/dist/features/sweep/sweep-server-manager.js +0 -226
- package/dist/features/sweep/sweep-server-manager.js.map +0 -7
- package/dist/features/sweep/tab-interceptor.js +0 -38
- package/dist/features/sweep/tab-interceptor.js.map +0 -7
- package/dist/features/sweep/types.js +0 -18
- package/dist/features/sweep/types.js.map +0 -7
- package/dist/features/tasks/linear-task-manager.js +0 -487
- package/dist/features/tasks/linear-task-manager.js.map +0 -7
- package/dist/features/tasks/task-aware-context.js +0 -410
- package/dist/features/tasks/task-aware-context.js.map +0 -7
- package/dist/features/tui/simple-monitor.js +0 -116
- package/dist/features/tui/simple-monitor.js.map +0 -7
- package/dist/features/tui/swarm-monitor.js +0 -648
- package/dist/features/tui/swarm-monitor.js.map +0 -7
- package/dist/features/web/client/stores/task-store.js +0 -26
- package/dist/features/web/client/stores/task-store.js.map +0 -7
- package/dist/features/web/server/index.js +0 -194
- package/dist/features/web/server/index.js.map +0 -7
- package/dist/hooks/auto-background.js +0 -151
- package/dist/hooks/auto-background.js.map +0 -7
- package/dist/hooks/claude-code-whatsapp-hook.js +0 -197
- package/dist/hooks/claude-code-whatsapp-hook.js.map +0 -7
- package/dist/hooks/config.js +0 -150
- package/dist/hooks/config.js.map +0 -7
- package/dist/hooks/daemon.js +0 -364
- package/dist/hooks/daemon.js.map +0 -7
- package/dist/hooks/events.js +0 -58
- package/dist/hooks/events.js.map +0 -7
- package/dist/hooks/index.js +0 -12
- package/dist/hooks/index.js.map +0 -7
- package/dist/hooks/linear-task-picker.js +0 -186
- package/dist/hooks/linear-task-picker.js.map +0 -7
- package/dist/hooks/schemas.js +0 -197
- package/dist/hooks/schemas.js.map +0 -7
- package/dist/hooks/secure-fs.js +0 -49
- package/dist/hooks/secure-fs.js.map +0 -7
- package/dist/hooks/security-logger.js +0 -155
- package/dist/hooks/security-logger.js.map +0 -7
- package/dist/hooks/session-summary.js +0 -222
- package/dist/hooks/session-summary.js.map +0 -7
- package/dist/hooks/sms-action-runner.js +0 -371
- package/dist/hooks/sms-action-runner.js.map +0 -7
- package/dist/hooks/sms-notify.js +0 -506
- package/dist/hooks/sms-notify.js.map +0 -7
- package/dist/hooks/sms-watcher.js +0 -93
- package/dist/hooks/sms-watcher.js.map +0 -7
- package/dist/hooks/sms-webhook.js +0 -555
- package/dist/hooks/sms-webhook.js.map +0 -7
- package/dist/hooks/whatsapp-commands.js +0 -479
- package/dist/hooks/whatsapp-commands.js.map +0 -7
- package/dist/hooks/whatsapp-scheduler.js +0 -317
- package/dist/hooks/whatsapp-scheduler.js.map +0 -7
- package/dist/hooks/whatsapp-sync.js +0 -409
- package/dist/hooks/whatsapp-sync.js.map +0 -7
- package/dist/index.js +0 -25
- package/dist/index.js.map +0 -7
- package/dist/integrations/anthropic/client.js +0 -263
- package/dist/integrations/anthropic/client.js.map +0 -7
- package/dist/integrations/claude-code/agent-bridge.js +0 -768
- package/dist/integrations/claude-code/agent-bridge.js.map +0 -7
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js +0 -459
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +0 -7
- package/dist/integrations/claude-code/lifecycle-hooks.js +0 -254
- package/dist/integrations/claude-code/lifecycle-hooks.js.map +0 -7
- package/dist/integrations/claude-code/post-task-hooks.js +0 -545
- package/dist/integrations/claude-code/post-task-hooks.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client-stub.js +0 -20
- package/dist/integrations/claude-code/subagent-client-stub.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client.js +0 -511
- package/dist/integrations/claude-code/subagent-client.js.map +0 -7
- package/dist/integrations/claude-code/task-coordinator.js +0 -360
- package/dist/integrations/claude-code/task-coordinator.js.map +0 -7
- package/dist/integrations/linear/auth.js +0 -337
- package/dist/integrations/linear/auth.js.map +0 -7
- package/dist/integrations/linear/auto-sync.js +0 -258
- package/dist/integrations/linear/auto-sync.js.map +0 -7
- package/dist/integrations/linear/client.js +0 -634
- package/dist/integrations/linear/client.js.map +0 -7
- package/dist/integrations/linear/config.js +0 -130
- package/dist/integrations/linear/config.js.map +0 -7
- package/dist/integrations/linear/migration.js +0 -361
- package/dist/integrations/linear/migration.js.map +0 -7
- package/dist/integrations/linear/oauth-server.js +0 -454
- package/dist/integrations/linear/oauth-server.js.map +0 -7
- package/dist/integrations/linear/rest-client.js +0 -213
- package/dist/integrations/linear/rest-client.js.map +0 -7
- package/dist/integrations/linear/sync-manager.js +0 -236
- package/dist/integrations/linear/sync-manager.js.map +0 -7
- package/dist/integrations/linear/sync-service.js +0 -231
- package/dist/integrations/linear/sync-service.js.map +0 -7
- package/dist/integrations/linear/sync.js +0 -782
- package/dist/integrations/linear/sync.js.map +0 -7
- package/dist/integrations/linear/types.js +0 -5
- package/dist/integrations/linear/types.js.map +0 -7
- package/dist/integrations/linear/unified-sync.js +0 -589
- package/dist/integrations/linear/unified-sync.js.map +0 -7
- package/dist/integrations/linear/webhook-handler.js +0 -219
- package/dist/integrations/linear/webhook-handler.js.map +0 -7
- package/dist/integrations/linear/webhook-server.js +0 -218
- package/dist/integrations/linear/webhook-server.js.map +0 -7
- package/dist/integrations/linear/webhook.js +0 -291
- package/dist/integrations/linear/webhook.js.map +0 -7
- package/dist/integrations/mcp/handlers/code-execution-handlers.js +0 -266
- package/dist/integrations/mcp/handlers/code-execution-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/context-handlers.js +0 -257
- package/dist/integrations/mcp/handlers/context-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/discovery-handlers.js +0 -497
- package/dist/integrations/mcp/handlers/discovery-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/index.js +0 -166
- package/dist/integrations/mcp/handlers/index.js.map +0 -7
- package/dist/integrations/mcp/handlers/linear-handlers.js +0 -247
- package/dist/integrations/mcp/handlers/linear-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/skill-handlers.js +0 -529
- package/dist/integrations/mcp/handlers/skill-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/task-handlers.js +0 -239
- package/dist/integrations/mcp/handlers/task-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/trace-handlers.js +0 -308
- package/dist/integrations/mcp/handlers/trace-handlers.js.map +0 -7
- package/dist/integrations/mcp/index.js +0 -23
- package/dist/integrations/mcp/index.js.map +0 -7
- package/dist/integrations/mcp/middleware/tool-scoring.js +0 -356
- package/dist/integrations/mcp/middleware/tool-scoring.js.map +0 -7
- package/dist/integrations/mcp/refactored-server.js +0 -374
- package/dist/integrations/mcp/refactored-server.js.map +0 -7
- package/dist/integrations/mcp/remote-server.js +0 -682
- package/dist/integrations/mcp/remote-server.js.map +0 -7
- package/dist/integrations/mcp/schemas.js +0 -147
- package/dist/integrations/mcp/schemas.js.map +0 -7
- package/dist/integrations/mcp/server.js +0 -1975
- package/dist/integrations/mcp/server.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions-code.js +0 -125
- package/dist/integrations/mcp/tool-definitions-code.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions.js +0 -702
- package/dist/integrations/mcp/tool-definitions.js.map +0 -7
- package/dist/integrations/mcp/trace-test.js +0 -48
- package/dist/integrations/mcp/trace-test.js.map +0 -7
- package/dist/integrations/pg-aiguide/embedding-provider.js +0 -189
- package/dist/integrations/pg-aiguide/embedding-provider.js.map +0 -7
- package/dist/integrations/pg-aiguide/semantic-search.js +0 -187
- package/dist/integrations/pg-aiguide/semantic-search.js.map +0 -7
- package/dist/integrations/pg-aiguide/timescale-analytics.js +0 -224
- package/dist/integrations/pg-aiguide/timescale-analytics.js.map +0 -7
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js +0 -860
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +0 -7
- package/dist/integrations/ralph/context/context-budget-manager.js +0 -301
- package/dist/integrations/ralph/context/context-budget-manager.js.map +0 -7
- package/dist/integrations/ralph/context/stackmemory-context-loader.js +0 -360
- package/dist/integrations/ralph/context/stackmemory-context-loader.js.map +0 -7
- package/dist/integrations/ralph/coordination/enhanced-coordination.js +0 -410
- package/dist/integrations/ralph/coordination/enhanced-coordination.js.map +0 -7
- package/dist/integrations/ralph/index.js +0 -18
- package/dist/integrations/ralph/index.js.map +0 -7
- package/dist/integrations/ralph/learning/pattern-learner.js +0 -401
- package/dist/integrations/ralph/learning/pattern-learner.js.map +0 -7
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js +0 -448
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js +0 -294
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-registry.js +0 -108
- package/dist/integrations/ralph/monitoring/swarm-registry.js.map +0 -7
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js +0 -463
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +0 -7
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js +0 -400
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js.map +0 -7
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js +0 -473
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js.map +0 -7
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js +0 -388
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js.map +0 -7
- package/dist/integrations/ralph/performance/performance-optimizer.js +0 -358
- package/dist/integrations/ralph/performance/performance-optimizer.js.map +0 -7
- package/dist/integrations/ralph/ralph-integration-demo.js +0 -182
- package/dist/integrations/ralph/ralph-integration-demo.js.map +0 -7
- package/dist/integrations/ralph/recovery/crash-recovery.js +0 -462
- package/dist/integrations/ralph/recovery/crash-recovery.js.map +0 -7
- package/dist/integrations/ralph/state/state-reconciler.js +0 -404
- package/dist/integrations/ralph/state/state-reconciler.js.map +0 -7
- package/dist/integrations/ralph/swarm/git-workflow-manager.js +0 -428
- package/dist/integrations/ralph/swarm/git-workflow-manager.js.map +0 -7
- package/dist/integrations/ralph/swarm/swarm-coordinator.js +0 -996
- package/dist/integrations/ralph/swarm/swarm-coordinator.js.map +0 -7
- package/dist/integrations/ralph/types.js +0 -5
- package/dist/integrations/ralph/types.js.map +0 -7
- package/dist/integrations/ralph/visualization/ralph-debugger.js +0 -585
- package/dist/integrations/ralph/visualization/ralph-debugger.js.map +0 -7
- package/dist/mcp/stackmemory-mcp-server.js +0 -554
- package/dist/mcp/stackmemory-mcp-server.js.map +0 -7
- package/dist/middleware/exponential-rate-limiter.js +0 -289
- package/dist/middleware/exponential-rate-limiter.js.map +0 -7
- package/dist/models/user.model.js +0 -358
- package/dist/models/user.model.js.map +0 -7
- package/dist/servers/production/auth-middleware.js +0 -528
- package/dist/servers/production/auth-middleware.js.map +0 -7
- package/dist/servers/railway/config.js +0 -55
- package/dist/servers/railway/config.js.map +0 -7
- package/dist/servers/railway/index-enhanced.js +0 -160
- package/dist/servers/railway/index-enhanced.js.map +0 -7
- package/dist/servers/railway/index.js +0 -1349
- package/dist/servers/railway/index.js.map +0 -7
- package/dist/servers/railway/simple.js +0 -64
- package/dist/servers/railway/simple.js.map +0 -7
- package/dist/servers/railway/storage-test.js +0 -459
- package/dist/servers/railway/storage-test.js.map +0 -7
- package/dist/services/config-service.js +0 -65
- package/dist/services/config-service.js.map +0 -7
- package/dist/services/context-service.js +0 -194
- package/dist/services/context-service.js.map +0 -7
- package/dist/skills/api-discovery.js +0 -354
- package/dist/skills/api-discovery.js.map +0 -7
- package/dist/skills/api-skill.js +0 -475
- package/dist/skills/api-skill.js.map +0 -7
- package/dist/skills/claude-skills.js +0 -1061
- package/dist/skills/claude-skills.js.map +0 -7
- package/dist/skills/dashboard-launcher.js +0 -216
- package/dist/skills/dashboard-launcher.js.map +0 -7
- package/dist/skills/recursive-agent-orchestrator.js +0 -575
- package/dist/skills/recursive-agent-orchestrator.js.map +0 -7
- package/dist/skills/repo-ingestion-skill.js +0 -609
- package/dist/skills/repo-ingestion-skill.js.map +0 -7
- package/dist/skills/security-secrets-scanner.js +0 -284
- package/dist/skills/security-secrets-scanner.js.map +0 -7
- package/dist/skills/unified-rlm-orchestrator.js +0 -404
- package/dist/skills/unified-rlm-orchestrator.js.map +0 -7
- package/dist/types/task.js +0 -5
- package/dist/types/task.js.map +0 -7
- package/dist/utils/env.js +0 -50
- package/dist/utils/env.js.map +0 -7
- package/dist/utils/formatting.js +0 -62
- package/dist/utils/formatting.js.map +0 -7
- package/dist/utils/process-cleanup.js +0 -136
- package/dist/utils/process-cleanup.js.map +0 -7
- package/dist/validation/schemas.js +0 -222
- package/dist/validation/schemas.js.map +0 -7
- /package/dist/{core/merge → src/core/extensions}/types.js +0 -0
- /package/dist/{core/merge → src/core/extensions}/types.js.map +0 -0
|
@@ -1,398 +0,0 @@
|
|
|
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
|
|
@@ -1,7 +0,0 @@
|
|
|
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": ";;;;AAKA,YAAY,QAAQ;AACpB,YAAY,UAAU;AACtB,YAAY,UAAU;AACtB;AAAA,EAGE;AAAA,EACA;AAAA,OAEK;AASA,MAAM,cAAc;AAAA,EACzB,OAAe,WAAiC;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AAAA,EACA,oBAAgE,CAAC;AAAA,EAEzE,YAAY,YAAqB;AAC/B,SAAK,aACH,cAAc,KAAK,KAAK,QAAQ,IAAI,GAAG,gBAAgB,aAAa;AACtE,SAAK,SAAS,KAAK,WAAW;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA,EAKA,OAAc,YAAY,YAAoC;AAC5D,QAAI,CAAC,cAAc,UAAU;AAC3B,oBAAc,WAAW,IAAI,cAAc,UAAU;AAAA,IACvD;AACA,WAAO,cAAc;AAAA,EACvB;AAAA;AAAA;AAAA;AAAA,EAKQ,aAAgC;AACtC,QAAI;AACF,UAAI,GAAG,WAAW,KAAK,UAAU,GAAG;AAClC,cAAM,UAAU,GAAG,aAAa,KAAK,YAAY,OAAO;AACxD,cAAM,SAAS,KAAK,KAAK,OAAO;AAChC,eAAO,KAAK,kBAAkB,MAAM;AAAA,MACtC;AAAA,IACF,SAAS,OAAgB;AACvB,cAAQ,KAAK,8BAA8B,KAAK,UAAU,KAAK,KAAK;AAAA,IACtE;AAEA,WAAO,KAAK,kBAAkB,CAAC,CAAC;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA,EAKQ,kBACN,QACmB;AACnB,UAAM,SAA4B;AAAA,MAChC,SAAS,OAAO,WAAW,eAAe;AAAA,MAC1C,SAAS,OAAO;AAAA,MAChB,SAAS;AAAA,QACP,SAAS;AAAA,UACP,GAAG,eAAe,QAAQ;AAAA,UAC1B,GAAG,OAAO,SAAS;AAAA,QACrB;AAAA,QACA,aAAa;AAAA,UACX,GAAG,eAAe,QAAQ;AAAA,UAC1B,GAAG,OAAO,SAAS;AAAA,QACrB;AAAA,MACF;AAAA,MACA,WAAW;AAAA,QACT,OAAO;AAAA,UACL,GAAG,eAAe,UAAU;AAAA,UAC5B,GAAG,OAAO,WAAW;AAAA,QACvB;AAAA,QACA,QAAQ;AAAA,UACN,GAAG,eAAe,UAAU;AAAA,UAC5B,GAAG,OAAO,WAAW;AAAA,QACvB;AAAA,QACA,iBAAiB;AAAA,UACf,GAAG,eAAe,UAAU;AAAA,UAC5B,GAAG,OAAO,WAAW;AAAA,QACvB;AAAA,MACF;AAAA,MACA,aAAa,EAAE,GAAG,eAAe,aAAa,GAAG,OAAO,YAAY;AAAA,MACpE,UAAU,EAAE,GAAG,iBAAiB,GAAG,OAAO,SAAS;AAAA,IACrD;AAGA,QAAI,OAAO,WAAW,OAAO,WAAW,OAAO,OAAO,GAAG;AACvD,WAAK,aAAa,QAAQ,OAAO,SAAS,OAAO,OAAO,CAAC;AAAA,IAC3D;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,aACN,QACA,SACM;AACN,QAAI,QAAQ,SAAS;AACnB,UAAI,QAAQ,QAAQ,SAAS;AAC3B,eAAO,QAAQ,UAAU;AAAA,UACvB,GAAG,OAAO,QAAQ;AAAA,UAClB,GAAG,QAAQ,QAAQ;AAAA,QACrB;AAAA,MACF;AACA,UAAI,QAAQ,QAAQ,aAAa;AAC/B,eAAO,QAAQ,cAAc;AAAA,UAC3B,GAAG,OAAO,QAAQ;AAAA,UAClB,GAAG,QAAQ,QAAQ;AAAA,QACrB;AAAA,MACF;AAAA,IACF;AAEA,QAAI,QAAQ,WAAW;AACrB,UAAI,QAAQ,UAAU,OAAO;AAC3B,eAAO,UAAU,QAAQ;AAAA,UACvB,GAAG,OAAO,UAAU;AAAA,UACpB,GAAG,QAAQ,UAAU;AAAA,QACvB;AAAA,MACF;AACA,UAAI,QAAQ,UAAU,QAAQ;AAC5B,eAAO,UAAU,SAAS;AAAA,UACxB,GAAG,OAAO,UAAU;AAAA,UACpB,GAAG,QAAQ,UAAU;AAAA,QACvB;AAAA,MACF;AACA,UAAI,QAAQ,UAAU,iBAAiB;AACrC,eAAO,UAAU,kBAAkB;AAAA,UACjC,GAAG,OAAO,UAAU;AAAA,UACpB,GAAG,QAAQ,UAAU;AAAA,QACvB;AAAA,MACF;AAAA,IACF;AAEA,QAAI,QAAQ,aAAa;AACvB,aAAO,cAAc,EAAE,GAAG,OAAO,aAAa,GAAG,QAAQ,YAAY;AAAA,IACvE;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,WAA6B;AAC3B,UAAM,SAA2B;AAAA,MAC/B,OAAO;AAAA,MACP,QAAQ,CAAC;AAAA,MACT,UAAU,CAAC;AAAA,MACX,aAAa,CAAC;AAAA,IAChB;AAGA,UAAM,UAAU,KAAK,OAAO,QAAQ;AACpC,UAAM,YACJ,QAAQ,OAAO,QAAQ,SAAS,QAAQ,cAAc,QAAQ;AAChE,QAAI,KAAK,IAAI,YAAY,CAAG,IAAI,MAAO;AACrC,aAAO,OAAO;AAAA,QACZ,qCAAqC,UAAU,QAAQ,CAAC,CAAC;AAAA,MAC3D;AACA,aAAO,QAAQ;AAAA,IACjB;AAGA,WAAO,QAAQ,OAAO,EAAE,QAAQ,CAAC,CAAC,KAAK,KAAK,MAAM;AAChD,UAAI,QAAQ,KAAK,QAAQ,GAAG;AAC1B,eAAO,OAAO;AAAA,UACZ,UAAU,GAAG,sCAAsC,KAAK;AAAA,QAC1D;AACA,eAAO,QAAQ;AAAA,MACjB;AAAA,IACF,CAAC;AAGD,WAAO,QAAQ,KAAK,OAAO,QAAQ,WAAW,EAAE,QAAQ,CAAC,CAAC,MAAM,KAAK,MAAM;AACzE,UAAI,UAAU,WAAc,QAAQ,KAAK,QAAQ,IAAI;AACnD,eAAO,OAAO;AAAA,UACZ,kBAAkB,IAAI,sCAAsC,KAAK;AAAA,QACnE;AACA,eAAO,QAAQ;AAAA,MACjB;AAAA,IACF,CAAC;AAGD,UAAM,UAAU,KAAK,cAAc,KAAK,OAAO,UAAU,MAAM,KAAK;AACpE,UAAM,WAAW,KAAK,cAAc,KAAK,OAAO,UAAU,MAAM,MAAM;AACtE,UAAM,QAAQ,KAAK,cAAc,KAAK,OAAO,UAAU,MAAM,GAAG;AAEhE,QAAI,WAAW,UAAU;AACvB,aAAO,OAAO;AAAA,QACZ;AAAA,MACF;AACA,aAAO,QAAQ;AAAA,IACjB;AACA,QAAI,YAAY,OAAO;AACrB,aAAO,OAAO;AAAA,QACZ;AAAA,MACF;AACA,aAAO,QAAQ;AAAA,IACjB;AAGA,UAAM,UAAU,KAAK,UAAU,KAAK,OAAO,UAAU,MAAM,QAAQ;AACnE,UAAM,iBAAiB,KAAK,sBAAsB;AAClD,QAAI,iBAAiB,KAAK,UAAU,gBAAgB;AAClD,aAAO,SAAS;AAAA,QACd,aAAa,KAAK,OAAO,UAAU,MAAM,QAAQ;AAAA,MACnD;AAAA,IACF;AAGA,QAAI,KAAK,OAAO,YAAY,uBAAuB,KAAK;AACtD,aAAO,SAAS;AAAA,QACd;AAAA,MACF;AAAA,IACF;AAEA,QAAI,KAAK,OAAO,YAAY,kBAAkB,KAAO;AACnD,aAAO,SAAS,KAAK,gDAAgD;AAAA,IACvE;AAGA,QAAI,CAAC,KAAK,OAAO,SAAS;AACxB,aAAO,YAAY,KAAK,4CAA4C;AAAA,IACtE;AAEA,QACE,KAAK,QAAQ,SAAS,aAAa,UACnC,KAAK,OAAO,QAAQ,YAAY,SAAS,KACzC;AACA,aAAO,YAAY;AAAA,QACjB;AAAA,MACF;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,cAAc,UAA0B;AAC9C,UAAM,QAAQ,SAAS,MAAM,iBAAiB;AAC9C,QAAI,CAAC,MAAO,QAAO;AAEnB,UAAM,QAAQ,SAAS,MAAM,CAAC,CAAC;AAC/B,UAAM,OAAO,MAAM,CAAC;AAEpB,UAAM,cAAsC;AAAA,MAC1C,GAAG;AAAA;AAAA,MACH,GAAG;AAAA;AAAA,MACH,GAAG;AAAA;AAAA,MACH,GAAG;AAAA;AAAA,IACL;AAEA,WAAO,SAAS,YAAY,IAAI,KAAK;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA,EAKQ,UAAU,MAAsB;AACtC,UAAM,QAAQ,KAAK,MAAM,8BAA8B;AACvD,QAAI,CAAC,MAAO,QAAO;AAEnB,UAAM,QAAQ,WAAW,MAAM,CAAC,CAAC;AACjC,UAAM,OAAO,MAAM,CAAC,GAAG,YAAY,KAAK;AAExC,UAAM,cAAsC;AAAA,MAC1C,GAAG;AAAA,MACH,IAAI;AAAA,MACJ,IAAI,OAAO;AAAA,MACX,IAAI,OAAO,OAAO;AAAA,MAClB,IAAI,OAAO,OAAO,OAAO;AAAA,IAC3B;AAEA,WAAO,SAAS,YAAY,IAAI,KAAK;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA,EAKQ,wBAAgC;AAGtC,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,OAAa;AACX,UAAM,MAAM,KAAK,QAAQ,KAAK,UAAU;AACxC,QAAI,CAAC,GAAG,WAAW,GAAG,GAAG;AACvB,SAAG,UAAU,KAAK,EAAE,WAAW,KAAK,CAAC;AAAA,IACvC;AAEA,UAAM,UAAU,KAAK,KAAK,KAAK,QAAQ;AAAA,MACrC,QAAQ;AAAA,MACR,WAAW;AAAA,MACX,QAAQ;AAAA,IACV,CAAC;AAED,OAAG,cAAc,KAAK,YAAY,SAAS,OAAO;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA,EAKA,YAA+B;AAC7B,WAAO,EAAE,GAAG,KAAK,OAAO;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,IAAIA,OAAmB;AACrB,UAAM,OAAOA,MAAK,MAAM,GAAG;AAC3B,QAAI,QAAa,KAAK;AAEtB,eAAW,OAAO,MAAM;AACtB,UAAI,SAAS,OAAO,UAAU,YAAY,OAAO,OAAO;AACtD,gBAAQ,MAAM,GAAG;AAAA,MACnB,OAAO;AACL,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,WAAW,aAA8B;AACvC,UAAM,cAAc,EAAE,GAAG,iBAAiB,GAAG,KAAK,OAAO,SAAS;AAClE,QAAI,CAAC,YAAY,WAAW,GAAG;AAC7B,aAAO;AAAA,IACT;AAGA,SAAK,OAAO,UAAU;AACtB,SAAK,aAAa,KAAK,QAAQ,YAAY,WAAW,CAAC;AACvD,SAAK,aAAa;AAClB,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,cAAc,SAAwC;AACpD,SAAK,OAAO,QAAQ,UAAU;AAAA,MAC5B,GAAG,KAAK,OAAO,QAAQ;AAAA,MACvB,GAAG;AAAA,IACL;AACA,SAAK,aAAa;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAiB,QAAsC;AACrD,SAAK,OAAO,QAAQ,cAAc;AAAA,MAChC,GAAG,KAAK,OAAO,QAAQ;AAAA,MACvB,GAAG;AAAA,IACL;AACA,SAAK,aAAa;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA,EAKA,kBAAwB;AACtB,QAAI,KAAK,YAAa;AAEtB,QAAI,GAAG,WAAW,KAAK,UAAU,GAAG;AAClC,WAAK,cAAc,GAAG,MAAM,KAAK,YAAY,CAAC,cAAc;AAC1D,YAAI,cAAc,UAAU;AAC1B,gBAAM,YAAY,KAAK,WAAW;AAClC,gBAAM,aAAa,KAAK,SAAS;AAEjC,cAAI,WAAW,OAAO;AACpB,iBAAK,SAAS;AACd,iBAAK,aAAa;AAClB,oBAAQ,IAAI,wBAAwB;AAAA,UACtC,OAAO;AACL,oBAAQ;AAAA,cACN;AAAA,cACA,WAAW;AAAA,YACb;AAAA,UACF;AAAA,QACF;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,mBAAyB;AACvB,QAAI,KAAK,aAAa;AACpB,WAAK,YAAY,MAAM;AACvB,WAAK,cAAc;AAAA,IACrB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,SAAS,UAAqD;AAC5D,SAAK,kBAAkB,KAAK,QAAQ;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA,EAKQ,eAAqB;AAC3B,UAAM,SAAS,KAAK,UAAU;AAC9B,SAAK,kBAAkB,QAAQ,CAAC,OAAO,GAAG,MAAM,CAAC;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA,EAKA,eACE,MACA,mBAKQ;AACR,UAAM,YAAY,KAAK,OAAO,QAAQ,YAAY,IAAI,KAAK;AAC3D,UAAM,UAAU,KAAK,OAAO,QAAQ;AAEpC,QAAI,QAAQ,YAAY,QAAQ;AAEhC,QAAI,mBAAmB;AAErB,UAAI,kBAAkB,kBAAkB,QAAW;AACjD,cAAM,mBAAmB,KAAK;AAAA,UAC5B,kBAAkB,gBAAgB;AAAA,UAClC;AAAA,QACF;AACA,iBAAS,mBAAmB,QAAQ;AAAA,MACtC;AAGA,UAAI,kBAAkB,aAAa;AACjC,iBAAS,MAAM,QAAQ;AAAA,MACzB;AAGA,UAAI,kBAAkB,mBAAmB,QAAW;AAClD,cAAM,gBAAgB,KAAK;AAAA,UACzB,kBAAkB,iBAAiB;AAAA,UACnC;AAAA,QACF;AACA,iBAAS,gBAAgB,QAAQ;AAAA,MACnC;AAAA,IACF;AAEA,WAAO,KAAK,IAAI,KAAK,IAAI,OAAO,CAAC,GAAG,CAAC;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA,EAKA,cAA6C;AAC3C,WAAO,EAAE,GAAG,iBAAiB,GAAG,KAAK,OAAO,SAAS;AAAA,EACvD;AACF;",
|
|
6
|
-
"names": ["path"]
|
|
7
|
-
}
|
|
@@ -1,76 +0,0 @@
|
|
|
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
|
|
@@ -1,7 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,115 +0,0 @@
|
|
|
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 { existsSync, readFileSync, writeFileSync, mkdirSync } from "fs";
|
|
6
|
-
import { join } from "path";
|
|
7
|
-
import { homedir } from "os";
|
|
8
|
-
const DEFAULT_STORAGE_CONFIG = {
|
|
9
|
-
mode: "sqlite",
|
|
10
|
-
chromadb: {
|
|
11
|
-
enabled: false
|
|
12
|
-
}
|
|
13
|
-
};
|
|
14
|
-
const STACKMEMORY_DIR = join(homedir(), ".stackmemory");
|
|
15
|
-
const CONFIG_FILE = join(STACKMEMORY_DIR, "storage-config.json");
|
|
16
|
-
function loadStorageConfig() {
|
|
17
|
-
try {
|
|
18
|
-
if (existsSync(CONFIG_FILE)) {
|
|
19
|
-
const content = readFileSync(CONFIG_FILE, "utf-8");
|
|
20
|
-
const config = JSON.parse(content);
|
|
21
|
-
return {
|
|
22
|
-
mode: config.mode || DEFAULT_STORAGE_CONFIG.mode,
|
|
23
|
-
chromadb: {
|
|
24
|
-
...DEFAULT_STORAGE_CONFIG.chromadb,
|
|
25
|
-
...config.chromadb
|
|
26
|
-
}
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
} catch (error) {
|
|
30
|
-
console.warn("Failed to load storage config, using defaults:", error);
|
|
31
|
-
}
|
|
32
|
-
return DEFAULT_STORAGE_CONFIG;
|
|
33
|
-
}
|
|
34
|
-
function saveStorageConfig(config) {
|
|
35
|
-
try {
|
|
36
|
-
if (!existsSync(STACKMEMORY_DIR)) {
|
|
37
|
-
mkdirSync(STACKMEMORY_DIR, { recursive: true });
|
|
38
|
-
}
|
|
39
|
-
writeFileSync(CONFIG_FILE, JSON.stringify(config, null, 2), "utf-8");
|
|
40
|
-
} catch (error) {
|
|
41
|
-
console.error("Failed to save storage config:", error);
|
|
42
|
-
throw error;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
function isChromaDBEnabled() {
|
|
46
|
-
const config = loadStorageConfig();
|
|
47
|
-
if (!config.chromadb.enabled) {
|
|
48
|
-
return false;
|
|
49
|
-
}
|
|
50
|
-
const apiKey = config.chromadb.apiKey || process.env["CHROMADB_API_KEY"];
|
|
51
|
-
if (!apiKey) {
|
|
52
|
-
return false;
|
|
53
|
-
}
|
|
54
|
-
return true;
|
|
55
|
-
}
|
|
56
|
-
function getStorageMode() {
|
|
57
|
-
const config = loadStorageConfig();
|
|
58
|
-
if (config.mode === "hybrid" && !isChromaDBEnabled()) {
|
|
59
|
-
return "sqlite";
|
|
60
|
-
}
|
|
61
|
-
return config.mode;
|
|
62
|
-
}
|
|
63
|
-
function getChromaDBConfig() {
|
|
64
|
-
if (!isChromaDBEnabled()) {
|
|
65
|
-
return null;
|
|
66
|
-
}
|
|
67
|
-
const config = loadStorageConfig();
|
|
68
|
-
const apiKey = config.chromadb.apiKey || process.env["CHROMADB_API_KEY"];
|
|
69
|
-
const apiUrl = config.chromadb.apiUrl || process.env["CHROMADB_API_URL"] || "https://api.trychroma.com";
|
|
70
|
-
return {
|
|
71
|
-
enabled: true,
|
|
72
|
-
apiKey,
|
|
73
|
-
apiUrl,
|
|
74
|
-
tenant: config.chromadb.tenant || process.env["CHROMADB_TENANT"] || "default_tenant",
|
|
75
|
-
database: config.chromadb.database || process.env["CHROMADB_DATABASE"] || "default_database"
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
function enableChromaDB(chromaConfig) {
|
|
79
|
-
const config = loadStorageConfig();
|
|
80
|
-
config.mode = "hybrid";
|
|
81
|
-
config.chromadb = {
|
|
82
|
-
enabled: true,
|
|
83
|
-
apiKey: chromaConfig.apiKey,
|
|
84
|
-
apiUrl: chromaConfig.apiUrl || "https://api.trychroma.com",
|
|
85
|
-
tenant: chromaConfig.tenant || "default_tenant",
|
|
86
|
-
database: chromaConfig.database || "default_database"
|
|
87
|
-
};
|
|
88
|
-
saveStorageConfig(config);
|
|
89
|
-
}
|
|
90
|
-
function disableChromaDB() {
|
|
91
|
-
const config = loadStorageConfig();
|
|
92
|
-
config.mode = "sqlite";
|
|
93
|
-
config.chromadb = {
|
|
94
|
-
enabled: false
|
|
95
|
-
};
|
|
96
|
-
saveStorageConfig(config);
|
|
97
|
-
}
|
|
98
|
-
function getStorageModeDescription() {
|
|
99
|
-
const mode = getStorageMode();
|
|
100
|
-
if (mode === "hybrid") {
|
|
101
|
-
return "Hybrid (SQLite + ChromaDB for semantic search and cloud backup)";
|
|
102
|
-
}
|
|
103
|
-
return "SQLite (local storage only, fast, no external dependencies)";
|
|
104
|
-
}
|
|
105
|
-
export {
|
|
106
|
-
disableChromaDB,
|
|
107
|
-
enableChromaDB,
|
|
108
|
-
getChromaDBConfig,
|
|
109
|
-
getStorageMode,
|
|
110
|
-
getStorageModeDescription,
|
|
111
|
-
isChromaDBEnabled,
|
|
112
|
-
loadStorageConfig,
|
|
113
|
-
saveStorageConfig
|
|
114
|
-
};
|
|
115
|
-
//# sourceMappingURL=storage-config.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/core/config/storage-config.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Storage Configuration for StackMemory\n * Handles storage mode detection and ChromaDB configuration\n */\n\nimport { existsSync, readFileSync, writeFileSync, mkdirSync } from 'fs';\nimport { join } from 'path';\nimport { homedir } from 'os';\n\nexport type StorageMode = 'sqlite' | 'hybrid';\n\nexport interface ChromaDBConfig {\n enabled: boolean;\n apiKey?: string;\n apiUrl?: string;\n tenant?: string;\n database?: string;\n}\n\nexport interface StorageConfig {\n mode: StorageMode;\n chromadb: ChromaDBConfig;\n}\n\nconst DEFAULT_STORAGE_CONFIG: StorageConfig = {\n mode: 'sqlite',\n chromadb: {\n enabled: false,\n },\n};\n\nconst STACKMEMORY_DIR = join(homedir(), '.stackmemory');\nconst CONFIG_FILE = join(STACKMEMORY_DIR, 'storage-config.json');\n\n/**\n * Load storage configuration from disk\n */\nexport function loadStorageConfig(): StorageConfig {\n try {\n if (existsSync(CONFIG_FILE)) {\n const content = readFileSync(CONFIG_FILE, 'utf-8');\n const config = JSON.parse(content) as Partial<StorageConfig>;\n return {\n mode: config.mode || DEFAULT_STORAGE_CONFIG.mode,\n chromadb: {\n ...DEFAULT_STORAGE_CONFIG.chromadb,\n ...config.chromadb,\n },\n };\n }\n } catch (error) {\n console.warn('Failed to load storage config, using defaults:', error);\n }\n return DEFAULT_STORAGE_CONFIG;\n}\n\n/**\n * Save storage configuration to disk\n */\nexport function saveStorageConfig(config: StorageConfig): void {\n try {\n if (!existsSync(STACKMEMORY_DIR)) {\n mkdirSync(STACKMEMORY_DIR, { recursive: true });\n }\n writeFileSync(CONFIG_FILE, JSON.stringify(config, null, 2), 'utf-8');\n } catch (error) {\n console.error('Failed to save storage config:', error);\n throw error;\n }\n}\n\n/**\n * Check if ChromaDB is enabled and properly configured\n */\nexport function isChromaDBEnabled(): boolean {\n const config = loadStorageConfig();\n\n if (!config.chromadb.enabled) {\n return false;\n }\n\n // ChromaDB requires an API key to be configured\n const apiKey = config.chromadb.apiKey || process.env['CHROMADB_API_KEY'];\n if (!apiKey) {\n return false;\n }\n\n return true;\n}\n\n/**\n * Get the current storage mode\n * Returns 'sqlite' for local-only storage\n * Returns 'hybrid' when ChromaDB is enabled (SQLite + ChromaDB)\n */\nexport function getStorageMode(): StorageMode {\n const config = loadStorageConfig();\n\n // Verify ChromaDB is actually usable before returning hybrid\n if (config.mode === 'hybrid' && !isChromaDBEnabled()) {\n return 'sqlite';\n }\n\n return config.mode;\n}\n\n/**\n * Get ChromaDB configuration (for use when initializing ChromaDB adapter)\n */\nexport function getChromaDBConfig(): ChromaDBConfig | null {\n if (!isChromaDBEnabled()) {\n return null;\n }\n\n const config = loadStorageConfig();\n const apiKey = config.chromadb.apiKey || process.env['CHROMADB_API_KEY'];\n const apiUrl =\n config.chromadb.apiUrl ||\n process.env['CHROMADB_API_URL'] ||\n 'https://api.trychroma.com';\n\n return {\n enabled: true,\n apiKey,\n apiUrl,\n tenant:\n config.chromadb.tenant ||\n process.env['CHROMADB_TENANT'] ||\n 'default_tenant',\n database:\n config.chromadb.database ||\n process.env['CHROMADB_DATABASE'] ||\n 'default_database',\n };\n}\n\n/**\n * Enable ChromaDB with the given configuration\n */\nexport function enableChromaDB(chromaConfig: {\n apiKey: string;\n apiUrl?: string;\n tenant?: string;\n database?: string;\n}): void {\n const config = loadStorageConfig();\n config.mode = 'hybrid';\n config.chromadb = {\n enabled: true,\n apiKey: chromaConfig.apiKey,\n apiUrl: chromaConfig.apiUrl || 'https://api.trychroma.com',\n tenant: chromaConfig.tenant || 'default_tenant',\n database: chromaConfig.database || 'default_database',\n };\n saveStorageConfig(config);\n}\n\n/**\n * Disable ChromaDB and use SQLite-only mode\n */\nexport function disableChromaDB(): void {\n const config = loadStorageConfig();\n config.mode = 'sqlite';\n config.chromadb = {\n enabled: false,\n };\n saveStorageConfig(config);\n}\n\n/**\n * Get a human-readable description of the current storage mode\n */\nexport function getStorageModeDescription(): string {\n const mode = getStorageMode();\n if (mode === 'hybrid') {\n return 'Hybrid (SQLite + ChromaDB for semantic search and cloud backup)';\n }\n return 'SQLite (local storage only, fast, no external dependencies)';\n}\n"],
|
|
5
|
-
"mappings": ";;;;AAKA,SAAS,YAAY,cAAc,eAAe,iBAAiB;AACnE,SAAS,YAAY;AACrB,SAAS,eAAe;AAiBxB,MAAM,yBAAwC;AAAA,EAC5C,MAAM;AAAA,EACN,UAAU;AAAA,IACR,SAAS;AAAA,EACX;AACF;AAEA,MAAM,kBAAkB,KAAK,QAAQ,GAAG,cAAc;AACtD,MAAM,cAAc,KAAK,iBAAiB,qBAAqB;AAKxD,SAAS,oBAAmC;AACjD,MAAI;AACF,QAAI,WAAW,WAAW,GAAG;AAC3B,YAAM,UAAU,aAAa,aAAa,OAAO;AACjD,YAAM,SAAS,KAAK,MAAM,OAAO;AACjC,aAAO;AAAA,QACL,MAAM,OAAO,QAAQ,uBAAuB;AAAA,QAC5C,UAAU;AAAA,UACR,GAAG,uBAAuB;AAAA,UAC1B,GAAG,OAAO;AAAA,QACZ;AAAA,MACF;AAAA,IACF;AAAA,EACF,SAAS,OAAO;AACd,YAAQ,KAAK,kDAAkD,KAAK;AAAA,EACtE;AACA,SAAO;AACT;AAKO,SAAS,kBAAkB,QAA6B;AAC7D,MAAI;AACF,QAAI,CAAC,WAAW,eAAe,GAAG;AAChC,gBAAU,iBAAiB,EAAE,WAAW,KAAK,CAAC;AAAA,IAChD;AACA,kBAAc,aAAa,KAAK,UAAU,QAAQ,MAAM,CAAC,GAAG,OAAO;AAAA,EACrE,SAAS,OAAO;AACd,YAAQ,MAAM,kCAAkC,KAAK;AACrD,UAAM;AAAA,EACR;AACF;AAKO,SAAS,oBAA6B;AAC3C,QAAM,SAAS,kBAAkB;AAEjC,MAAI,CAAC,OAAO,SAAS,SAAS;AAC5B,WAAO;AAAA,EACT;AAGA,QAAM,SAAS,OAAO,SAAS,UAAU,QAAQ,IAAI,kBAAkB;AACvE,MAAI,CAAC,QAAQ;AACX,WAAO;AAAA,EACT;AAEA,SAAO;AACT;AAOO,SAAS,iBAA8B;AAC5C,QAAM,SAAS,kBAAkB;AAGjC,MAAI,OAAO,SAAS,YAAY,CAAC,kBAAkB,GAAG;AACpD,WAAO;AAAA,EACT;AAEA,SAAO,OAAO;AAChB;AAKO,SAAS,oBAA2C;AACzD,MAAI,CAAC,kBAAkB,GAAG;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,SAAS,kBAAkB;AACjC,QAAM,SAAS,OAAO,SAAS,UAAU,QAAQ,IAAI,kBAAkB;AACvE,QAAM,SACJ,OAAO,SAAS,UAChB,QAAQ,IAAI,kBAAkB,KAC9B;AAEF,SAAO;AAAA,IACL,SAAS;AAAA,IACT;AAAA,IACA;AAAA,IACA,QACE,OAAO,SAAS,UAChB,QAAQ,IAAI,iBAAiB,KAC7B;AAAA,IACF,UACE,OAAO,SAAS,YAChB,QAAQ,IAAI,mBAAmB,KAC/B;AAAA,EACJ;AACF;AAKO,SAAS,eAAe,cAKtB;AACP,QAAM,SAAS,kBAAkB;AACjC,SAAO,OAAO;AACd,SAAO,WAAW;AAAA,IAChB,SAAS;AAAA,IACT,QAAQ,aAAa;AAAA,IACrB,QAAQ,aAAa,UAAU;AAAA,IAC/B,QAAQ,aAAa,UAAU;AAAA,IAC/B,UAAU,aAAa,YAAY;AAAA,EACrC;AACA,oBAAkB,MAAM;AAC1B;AAKO,SAAS,kBAAwB;AACtC,QAAM,SAAS,kBAAkB;AACjC,SAAO,OAAO;AACd,SAAO,WAAW;AAAA,IAChB,SAAS;AAAA,EACX;AACA,oBAAkB,MAAM;AAC1B;AAKO,SAAS,4BAAoC;AAClD,QAAM,OAAO,eAAe;AAC5B,MAAI,SAAS,UAAU;AACrB,WAAO;AAAA,EACT;AACA,SAAO;AACT;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|