@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,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/cli/commands/sms-notify.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * CLI command for SMS notification management\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { execSync } from 'child_process';\nimport { join } from 'path';\nimport { existsSync, readFileSync, unlinkSync } from 'fs';\nimport {\n loadSMSConfig,\n saveSMSConfig,\n sendNotification,\n sendSMSNotification,\n notifyReviewReady,\n notifyWithYesNo,\n notifyTaskComplete,\n cleanupExpiredPrompts,\n type MessageChannel,\n} from '../../hooks/sms-notify.js';\nimport {\n loadActionQueue,\n processAllPendingActions,\n cleanupOldActions,\n startActionWatcher,\n} from '../../hooks/sms-action-runner.js';\nimport {\n syncContext,\n syncFrame,\n enableAutoSync,\n disableAutoSync,\n isAutoSyncEnabled,\n loadSyncOptions,\n saveSyncOptions,\n} from '../../hooks/whatsapp-sync.js';\nimport {\n loadCommandsConfig,\n enableCommands,\n disableCommands,\n getAvailableCommands,\n} from '../../hooks/whatsapp-commands.js';\nimport {\n listSchedules,\n cancelSchedule,\n scheduleDailyDigest,\n scheduleHourlyDigest,\n scheduleIntervalDigest,\n startScheduler,\n stopScheduler,\n isSchedulerRunning,\n runScheduledDigest,\n} from '../../hooks/whatsapp-scheduler.js';\n\n// __dirname provided by esbuild banner\n\nexport function createSMSNotifyCommand(): Command {\n const cmd = new Command('notify')\n .description(\n 'SMS/WhatsApp notifications with context sync and scheduled digests'\n )\n .addHelpText(\n 'after',\n `\nSetup:\n 1. Create Twilio account at https://twilio.com\n 2. Set environment variables:\n export TWILIO_ACCOUNT_SID=your_sid\n export TWILIO_AUTH_TOKEN=your_token\n export TWILIO_WHATSAPP_FROM=+1234567890\n export TWILIO_WHATSAPP_TO=+1234567890\n 3. Enable: stackmemory notify enable\n\nBasic Commands:\n stackmemory notify status Check configuration\n stackmemory notify enable Enable notifications\n stackmemory notify channel whatsapp Switch to WhatsApp (default)\n stackmemory notify channel sms Switch to SMS\n stackmemory notify test Send test message\n stackmemory notify send \"message\" Send custom message\n stackmemory notify review \"PR #123\" Send review notification\n stackmemory notify ask \"Deploy?\" Send yes/no prompt\n\nContext Sync:\n Pushes development context (active frames, decisions, files) to WhatsApp.\n stackmemory notify sync Push current context now\n stackmemory notify sync --frame <id> Sync specific frame\n stackmemory notify sync --auto Enable auto-sync on frame close\n stackmemory notify sync --no-auto Disable auto-sync\n stackmemory notify sync-status Show sync configuration\n\nScheduled Digests:\n Automatically sends context summaries at configured intervals.\n stackmemory notify schedule list List all schedules\n stackmemory notify schedule daily 09:00 Daily digest at 9 AM\n stackmemory notify schedule hourly Every hour\n stackmemory notify schedule interval 30 Every 30 minutes\n stackmemory notify schedule cancel <id> Remove a schedule\n stackmemory notify schedule run <id> Run schedule now\n stackmemory notify schedule start Start scheduler daemon\n stackmemory notify schedule stop Stop scheduler daemon\n\nInbound Commands:\n Enable command processing to respond to WhatsApp messages.\n stackmemory notify commands List available commands\n stackmemory notify commands --enable Enable command processing\n stackmemory notify commands --disable Disable command processing\n\n Supported WhatsApp commands:\n status - Get current session status\n frames - List active frames\n tasks - Show pending tasks\n digest - Request full context digest\n pause - Pause notifications\n resume - Resume notifications\n`\n );\n\n cmd\n .command('status')\n .description('Show notification configuration status')\n .action(() => {\n const config = loadSMSConfig();\n\n console.log(chalk.blue('Notification Status:'));\n console.log();\n\n // Check credentials\n const hasCreds = config.accountSid && config.authToken;\n\n // Check channel-specific numbers\n const channel = config.channel || 'whatsapp';\n const hasWhatsApp =\n config.whatsappFromNumber ||\n config.fromNumber ||\n config.whatsappToNumber ||\n config.toNumber;\n const hasSMS =\n config.smsFromNumber ||\n config.fromNumber ||\n config.smsToNumber ||\n config.toNumber;\n const hasNumbers = channel === 'whatsapp' ? hasWhatsApp : hasSMS;\n\n console.log(\n ` ${chalk.gray('Enabled:')} ${config.enabled ? chalk.green('yes') : chalk.red('no')}`\n );\n console.log(\n ` ${chalk.gray('Channel:')} ${channel === 'whatsapp' ? chalk.cyan('WhatsApp') : chalk.blue('SMS')}`\n );\n console.log(\n ` ${chalk.gray('Configured:')} ${hasCreds && hasNumbers ? chalk.green('yes') : chalk.yellow('no (set env vars)')}`\n );\n\n // Show channel-specific numbers\n console.log();\n console.log(chalk.blue('Numbers:'));\n if (channel === 'whatsapp') {\n const from = config.whatsappFromNumber || config.fromNumber;\n const to = config.whatsappToNumber || config.toNumber;\n if (from) {\n console.log(` ${chalk.gray('WhatsApp From:')} ${maskPhone(from)}`);\n }\n if (to) {\n console.log(` ${chalk.gray('WhatsApp To:')} ${maskPhone(to)}`);\n }\n } else {\n const from = config.smsFromNumber || config.fromNumber;\n const to = config.smsToNumber || config.toNumber;\n if (from) {\n console.log(` ${chalk.gray('SMS From:')} ${maskPhone(from)}`);\n }\n if (to) {\n console.log(` ${chalk.gray('SMS To:')} ${maskPhone(to)}`);\n }\n }\n\n console.log();\n console.log(chalk.blue('Notify On:'));\n console.log(\n ` ${chalk.gray('Task Complete:')} ${config.notifyOn.taskComplete ? 'yes' : 'no'}`\n );\n console.log(\n ` ${chalk.gray('Review Ready:')} ${config.notifyOn.reviewReady ? 'yes' : 'no'}`\n );\n console.log(\n ` ${chalk.gray('Errors:')} ${config.notifyOn.error ? 'yes' : 'no'}`\n );\n\n if (config.quietHours?.enabled) {\n console.log();\n console.log(\n chalk.blue(\n `Quiet Hours: ${config.quietHours.start} - ${config.quietHours.end}`\n )\n );\n }\n\n console.log();\n console.log(\n ` ${chalk.gray('Pending Prompts:')} ${config.pendingPrompts.length}`\n );\n console.log(\n ` ${chalk.gray('Response Timeout:')} ${config.responseTimeout}s`\n );\n\n if (!hasCreds || !hasNumbers) {\n console.log();\n console.log(\n chalk.yellow('To configure, set these environment variables:')\n );\n console.log(chalk.gray(' export TWILIO_ACCOUNT_SID=your_sid'));\n console.log(chalk.gray(' export TWILIO_AUTH_TOKEN=your_token'));\n console.log();\n console.log(chalk.gray(' For WhatsApp (recommended):'));\n console.log(chalk.gray(' export TWILIO_WHATSAPP_FROM=+1234567890'));\n console.log(chalk.gray(' export TWILIO_WHATSAPP_TO=+1234567890'));\n console.log();\n console.log(chalk.gray(' For SMS:'));\n console.log(chalk.gray(' export TWILIO_SMS_FROM=+1234567890'));\n console.log(chalk.gray(' export TWILIO_SMS_TO=+1234567890'));\n }\n });\n\n cmd\n .command('enable')\n .description('Enable SMS notifications')\n .action(() => {\n const config = loadSMSConfig();\n config.enabled = true;\n saveSMSConfig(config);\n console.log(chalk.green('SMS notifications enabled'));\n\n const hasCreds =\n config.accountSid &&\n config.authToken &&\n config.fromNumber &&\n config.toNumber;\n if (!hasCreds) {\n console.log(\n chalk.yellow(\n 'Note: Set Twilio environment variables to send messages'\n )\n );\n }\n });\n\n cmd\n .command('disable')\n .description('Disable SMS notifications')\n .action(() => {\n const config = loadSMSConfig();\n config.enabled = false;\n saveSMSConfig(config);\n console.log(chalk.yellow('SMS notifications disabled'));\n });\n\n cmd\n .command('channel <type>')\n .description('Set notification channel (whatsapp|sms)')\n .action((type: string) => {\n const validChannels: MessageChannel[] = ['whatsapp', 'sms'];\n const channel = type.toLowerCase() as MessageChannel;\n\n if (!validChannels.includes(channel)) {\n console.log(\n chalk.red(`Invalid channel. Use: ${validChannels.join(', ')}`)\n );\n return;\n }\n\n const config = loadSMSConfig();\n config.channel = channel;\n saveSMSConfig(config);\n\n const label = channel === 'whatsapp' ? 'WhatsApp' : 'SMS';\n console.log(chalk.green(`Notification channel set to ${label}`));\n\n // Show relevant env vars\n if (channel === 'whatsapp') {\n const hasNumbers = config.whatsappFromNumber || config.fromNumber;\n if (!hasNumbers) {\n console.log(\n chalk.yellow('Set TWILIO_WHATSAPP_FROM and TWILIO_WHATSAPP_TO')\n );\n }\n } else {\n const hasNumbers = config.smsFromNumber || config.fromNumber;\n if (!hasNumbers) {\n console.log(chalk.yellow('Set TWILIO_SMS_FROM and TWILIO_SMS_TO'));\n }\n }\n });\n\n cmd\n .command('test')\n .description('Send a test notification')\n .option('--sms', 'Force SMS channel')\n .option('--whatsapp', 'Force WhatsApp channel')\n .action(async (options: { sms?: boolean; whatsapp?: boolean }) => {\n const config = loadSMSConfig();\n const channelOverride: MessageChannel | undefined = options.sms\n ? 'sms'\n : options.whatsapp\n ? 'whatsapp'\n : undefined;\n const channelLabel =\n channelOverride || config.channel === 'whatsapp' ? 'WhatsApp' : 'SMS';\n\n console.log(\n chalk.blue(`Sending test notification via ${channelLabel}...`)\n );\n\n const result = await sendNotification(\n {\n type: 'custom',\n title: 'StackMemory Test',\n message: 'This is a test notification from StackMemory.',\n },\n channelOverride\n );\n\n if (result.success) {\n const usedChannel = result.channel === 'whatsapp' ? 'WhatsApp' : 'SMS';\n console.log(chalk.green(`Test message sent via ${usedChannel}!`));\n } else {\n console.log(chalk.red(`Failed: ${result.error}`));\n }\n });\n\n cmd\n .command('send <message>')\n .description('Send a custom notification')\n .option('-t, --title <title>', 'Message title', 'StackMemory Alert')\n .action(async (message: string, options: { title: string }) => {\n const result = await sendSMSNotification({\n type: 'custom',\n title: options.title,\n message,\n });\n\n if (result.success) {\n console.log(chalk.green('Message sent!'));\n } else {\n console.log(chalk.red(`Failed: ${result.error}`));\n }\n });\n\n cmd\n .command('review <title>')\n .description('Send review-ready notification with options')\n .option('-m, --message <msg>', 'Description', 'Ready for your review')\n .option(\n '-o, --options <opts>',\n 'Comma-separated options',\n 'Approve,Request Changes,Skip'\n )\n .action(\n async (title: string, options: { message: string; options: string }) => {\n const opts = options.options.split(',').map((o) => ({\n label: o.trim(),\n }));\n\n console.log(chalk.blue('Sending review notification...'));\n\n const result = await notifyReviewReady(title, options.message, opts);\n\n if (result.success) {\n console.log(chalk.green('Review notification sent!'));\n if (result.promptId) {\n console.log(chalk.gray(`Prompt ID: ${result.promptId}`));\n }\n } else {\n console.log(chalk.red(`Failed: ${result.error}`));\n }\n }\n );\n\n cmd\n .command('ask <question>')\n .description('Send a yes/no prompt')\n .option('-t, --title <title>', 'Message title', 'StackMemory')\n .action(async (question: string, options: { title: string }) => {\n console.log(chalk.blue('Sending yes/no prompt...'));\n\n const result = await notifyWithYesNo(options.title, question);\n\n if (result.success) {\n console.log(chalk.green('Prompt sent!'));\n if (result.promptId) {\n console.log(chalk.gray(`Prompt ID: ${result.promptId}`));\n }\n } else {\n console.log(chalk.red(`Failed: ${result.error}`));\n }\n });\n\n cmd\n .command('complete <task>')\n .description('Send task completion notification')\n .option('-s, --summary <text>', 'Task summary', '')\n .action(async (task: string, options: { summary: string }) => {\n const result = await notifyTaskComplete(\n task,\n options.summary || `Task \"${task}\" has been completed.`\n );\n\n if (result.success) {\n console.log(chalk.green('Completion notification sent!'));\n } else {\n console.log(chalk.red(`Failed: ${result.error}`));\n }\n });\n\n cmd\n .command('quiet')\n .description('Configure quiet hours')\n .option('--enable', 'Enable quiet hours')\n .option('--disable', 'Disable quiet hours')\n .option('--start <time>', 'Start time (HH:MM)', '22:00')\n .option('--end <time>', 'End time (HH:MM)', '08:00')\n .action(\n (options: {\n enable?: boolean;\n disable?: boolean;\n start: string;\n end: string;\n }) => {\n const config = loadSMSConfig();\n\n if (!config.quietHours) {\n config.quietHours = { enabled: false, start: '22:00', end: '08:00' };\n }\n\n if (options.enable) {\n config.quietHours.enabled = true;\n } else if (options.disable) {\n config.quietHours.enabled = false;\n }\n\n if (options.start) {\n config.quietHours.start = options.start;\n }\n if (options.end) {\n config.quietHours.end = options.end;\n }\n\n saveSMSConfig(config);\n\n if (config.quietHours.enabled) {\n console.log(\n chalk.green(\n `Quiet hours enabled: ${config.quietHours.start} - ${config.quietHours.end}`\n )\n );\n } else {\n console.log(chalk.yellow('Quiet hours disabled'));\n }\n }\n );\n\n cmd\n .command('toggle <type>')\n .description(\n 'Toggle notification type (taskComplete|reviewReady|error|custom)'\n )\n .action((type: string) => {\n const config = loadSMSConfig();\n const validTypes = ['taskComplete', 'reviewReady', 'error', 'custom'];\n\n if (!validTypes.includes(type)) {\n console.log(chalk.red(`Invalid type. Use: ${validTypes.join(', ')}`));\n return;\n }\n\n const key = type as keyof typeof config.notifyOn;\n config.notifyOn[key] = !config.notifyOn[key];\n saveSMSConfig(config);\n\n console.log(\n chalk.green(\n `${type} notifications ${config.notifyOn[key] ? 'enabled' : 'disabled'}`\n )\n );\n });\n\n cmd\n .command('check')\n .description(\n 'Check for new SMS/WhatsApp responses (use in Claude sessions)'\n )\n .action(() => {\n const responsePath = join(\n process.env['HOME'] || '~',\n '.stackmemory',\n 'sms-latest-response.json'\n );\n\n try {\n if (existsSync(responsePath)) {\n const data = JSON.parse(readFileSync(responsePath, 'utf8'));\n const age = Date.now() - new Date(data.timestamp).getTime();\n\n if (age < 5 * 60 * 1000) {\n // Less than 5 minutes old\n console.log(chalk.green.bold('\\n*** NEW SMS RESPONSE ***'));\n console.log(` Response: \"${data.response}\"`);\n console.log(` Prompt ID: ${data.promptId}`);\n console.log(` Received: ${Math.round(age / 1000)}s ago\\n`);\n\n // Clear it after reading\n unlinkSync(responsePath);\n return;\n }\n }\n } catch {\n // Ignore errors\n }\n\n console.log(chalk.gray('No new responses'));\n });\n\n cmd\n .command('pending')\n .description('List pending prompts awaiting response')\n .action(() => {\n const config = loadSMSConfig();\n\n if (config.pendingPrompts.length === 0) {\n console.log(chalk.gray('No pending prompts'));\n return;\n }\n\n console.log(chalk.blue('Pending Prompts:'));\n config.pendingPrompts.forEach((p) => {\n const expires = new Date(p.expiresAt);\n const remaining = Math.round((expires.getTime() - Date.now()) / 1000);\n\n console.log();\n console.log(` ${chalk.gray('ID:')} ${p.id}`);\n console.log(` ${chalk.gray('Type:')} ${p.type}`);\n console.log(\n ` ${chalk.gray('Message:')} ${p.message.substring(0, 50)}...`\n );\n console.log(\n ` ${chalk.gray('Expires:')} ${remaining > 0 ? `${remaining}s` : chalk.red('expired')}`\n );\n });\n });\n\n cmd\n .command('cleanup')\n .description('Remove expired pending prompts')\n .action(() => {\n const removed = cleanupExpiredPrompts();\n console.log(chalk.green(`Removed ${removed} expired prompt(s)`));\n });\n\n cmd\n .command('timeout <seconds>')\n .description('Set response timeout for prompts')\n .action((seconds: string) => {\n const config = loadSMSConfig();\n const timeout = parseInt(seconds, 10);\n\n if (isNaN(timeout) || timeout < 30) {\n console.log(chalk.red('Timeout must be at least 30 seconds'));\n return;\n }\n\n config.responseTimeout = timeout;\n saveSMSConfig(config);\n console.log(chalk.green(`Response timeout set to ${timeout} seconds`));\n });\n\n // Action queue commands\n cmd\n .command('actions')\n .description('List queued actions from SMS responses')\n .action(() => {\n const queue = loadActionQueue();\n\n if (queue.actions.length === 0) {\n console.log(chalk.gray('No actions in queue'));\n return;\n }\n\n console.log(chalk.blue('Action Queue:'));\n queue.actions.forEach((a) => {\n const statusColor =\n a.status === 'completed'\n ? chalk.green\n : a.status === 'failed'\n ? chalk.red\n : a.status === 'running'\n ? chalk.yellow\n : chalk.gray;\n\n console.log();\n console.log(` ${chalk.gray('ID:')} ${a.id}`);\n console.log(` ${chalk.gray('Status:')} ${statusColor(a.status)}`);\n console.log(\n ` ${chalk.gray('Action:')} ${a.action.substring(0, 60)}...`\n );\n console.log(` ${chalk.gray('Response:')} ${a.response}`);\n if (a.error) {\n console.log(` ${chalk.gray('Error:')} ${chalk.red(a.error)}`);\n }\n });\n });\n\n cmd\n .command('run-actions')\n .description('Execute all pending actions from SMS responses')\n .action(() => {\n console.log(chalk.blue('Processing pending actions...'));\n const result = processAllPendingActions();\n\n console.log(\n chalk.green(\n `Processed ${result.processed} action(s): ${result.succeeded} succeeded, ${result.failed} failed`\n )\n );\n });\n\n cmd\n .command('watch')\n .description('Watch for and execute SMS response actions')\n .option('-i, --interval <ms>', 'Check interval in milliseconds', '5000')\n .action((options: { interval: string }) => {\n const interval = parseInt(options.interval, 10);\n console.log(chalk.blue(`Watching for actions (interval: ${interval}ms)`));\n console.log(chalk.gray('Press Ctrl+C to stop'));\n\n startActionWatcher(interval);\n });\n\n cmd\n .command('cleanup-actions')\n .description('Remove old completed actions')\n .action(() => {\n const removed = cleanupOldActions();\n console.log(chalk.green(`Removed ${removed} old action(s)`));\n });\n\n cmd\n .command('watch-responses')\n .description('Watch for incoming SMS/WhatsApp responses and notify')\n .option('-i, --interval <ms>', 'Check interval in milliseconds', '2000')\n .action(async (options: { interval: string }) => {\n const { startResponseWatcher } =\n await import('../../hooks/sms-watcher.js');\n const interval = parseInt(options.interval, 10);\n startResponseWatcher(interval);\n });\n\n // Hook installation commands\n cmd\n .command('install-hook')\n .description('Install Claude Code notification hook')\n .action(() => {\n try {\n const scriptPath = join(\n __dirname,\n '../../../scripts/install-notify-hook.sh'\n );\n execSync(`bash \"${scriptPath}\"`, { stdio: 'inherit' });\n } catch {\n console.error(chalk.red('Failed to install hook'));\n }\n });\n\n cmd\n .command('install-response-hook')\n .description('Install Claude Code response handler hook')\n .action(() => {\n try {\n // Create install script inline\n const hooksDir = join(process.env['HOME'] || '~', '.claude', 'hooks');\n const hookSrc = join(\n __dirname,\n '../../../templates/claude-hooks/sms-response-handler.js'\n );\n const hookDest = join(hooksDir, 'sms-response-handler.js');\n\n execSync(`mkdir -p \"${hooksDir}\"`, { stdio: 'inherit' });\n execSync(`cp \"${hookSrc}\" \"${hookDest}\"`, { stdio: 'inherit' });\n execSync(`chmod +x \"${hookDest}\"`, { stdio: 'inherit' });\n\n console.log(chalk.green('Response handler hook installed!'));\n console.log(chalk.gray(`Location: ${hookDest}`));\n console.log();\n console.log(chalk.blue('Add to ~/.claude/settings.json:'));\n console.log(\n chalk.gray(` \"hooks\": { \"pre_tool_use\": [\"node ${hookDest}\"] }`)\n );\n } catch {\n console.error(chalk.red('Failed to install response hook'));\n }\n });\n\n cmd\n .command('webhook')\n .description('Start SMS webhook server for receiving responses')\n .option('-p, --port <port>', 'Port to listen on', '3456')\n .action(async (options: { port: string }) => {\n const { startWebhookServer } = await import('../../hooks/sms-webhook.js');\n const port = parseInt(options.port, 10);\n startWebhookServer(port);\n });\n\n // ===== Context Sync Commands =====\n cmd\n .command('sync')\n .description('Push current context to WhatsApp')\n .option('--frame <id>', 'Sync specific frame by ID')\n .option('--auto', 'Enable auto-sync on frame close')\n .option('--no-auto', 'Disable auto-sync')\n .action(async (options: { frame?: string; auto?: boolean }) => {\n if (options.auto === true) {\n enableAutoSync();\n console.log(chalk.green('Auto-sync enabled'));\n return;\n }\n\n if (options.auto === false) {\n disableAutoSync();\n console.log(chalk.yellow('Auto-sync disabled'));\n return;\n }\n\n console.log(chalk.blue('Syncing context...'));\n\n const result = options.frame\n ? await syncFrame(options.frame)\n : await syncContext();\n\n if (result.success) {\n console.log(\n chalk.green(\n `Context synced via ${result.channel} (${result.digestLength} chars)`\n )\n );\n } else {\n console.log(chalk.red(`Sync failed: ${result.error}`));\n }\n });\n\n cmd\n .command('sync-status')\n .description('Show sync configuration status')\n .action(() => {\n const options = loadSyncOptions();\n const autoEnabled = isAutoSyncEnabled();\n\n console.log(chalk.blue('Sync Configuration:'));\n console.log();\n console.log(\n ` ${chalk.gray('Auto-sync on close:')} ${autoEnabled ? chalk.green('enabled') : chalk.yellow('disabled')}`\n );\n console.log(\n ` ${chalk.gray('Min frame duration:')} ${options.minFrameDuration}s`\n );\n console.log(\n ` ${chalk.gray('Max digest length:')} ${options.maxDigestLength} chars`\n );\n console.log(\n ` ${chalk.gray('Include decisions:')} ${options.includeDecisions ? 'yes' : 'no'}`\n );\n console.log(\n ` ${chalk.gray('Include files:')} ${options.includeFiles ? 'yes' : 'no'}`\n );\n console.log(\n ` ${chalk.gray('Include tests:')} ${options.includeTests ? 'yes' : 'no'}`\n );\n });\n\n // ===== Schedule Commands =====\n cmd\n .command('schedule')\n .description('Manage scheduled digests')\n .argument('[action]', 'Action: daily, hourly, interval, list, cancel, run')\n .argument(\n '[value]',\n 'Time (HH:MM) for daily, minutes for interval, or schedule ID'\n )\n .action(async (action?: string, value?: string) => {\n if (!action || action === 'list') {\n const schedules = listSchedules();\n\n if (schedules.length === 0) {\n console.log(chalk.gray('No scheduled digests'));\n return;\n }\n\n console.log(chalk.blue('Scheduled Digests:'));\n schedules.forEach((s) => {\n const status = s.enabled\n ? chalk.green('active')\n : chalk.yellow('paused');\n const nextRun = s.nextRun\n ? new Date(s.nextRun).toLocaleString()\n : 'N/A';\n\n console.log();\n console.log(` ${chalk.gray('ID:')} ${s.id}`);\n console.log(` ${chalk.gray('Type:')} ${s.config.type}`);\n console.log(` ${chalk.gray('Status:')} ${status}`);\n console.log(` ${chalk.gray('Next run:')} ${nextRun}`);\n if (s.lastRun) {\n console.log(\n ` ${chalk.gray('Last run:')} ${new Date(s.lastRun).toLocaleString()}`\n );\n }\n });\n return;\n }\n\n switch (action) {\n case 'daily': {\n const time = value || '09:00';\n try {\n const id = scheduleDailyDigest(time);\n console.log(chalk.green(`Daily digest scheduled at ${time}`));\n console.log(chalk.gray(`Schedule ID: ${id}`));\n } catch (err) {\n console.log(\n chalk.red(\n `Error: ${err instanceof Error ? err.message : String(err)}`\n )\n );\n }\n break;\n }\n\n case 'hourly': {\n const id = scheduleHourlyDigest();\n console.log(chalk.green('Hourly digest scheduled'));\n console.log(chalk.gray(`Schedule ID: ${id}`));\n break;\n }\n\n case 'interval': {\n const minutes = parseInt(value || '60', 10);\n if (isNaN(minutes) || minutes < 5) {\n console.log(chalk.red('Interval must be at least 5 minutes'));\n return;\n }\n try {\n const id = scheduleIntervalDigest(minutes);\n console.log(\n chalk.green(`Digest scheduled every ${minutes} minutes`)\n );\n console.log(chalk.gray(`Schedule ID: ${id}`));\n } catch (err) {\n console.log(\n chalk.red(\n `Error: ${err instanceof Error ? err.message : String(err)}`\n )\n );\n }\n break;\n }\n\n case 'cancel': {\n if (!value) {\n console.log(chalk.red('Schedule ID required'));\n return;\n }\n const cancelled = cancelSchedule(value);\n if (cancelled) {\n console.log(chalk.green(`Schedule ${value} cancelled`));\n } else {\n console.log(chalk.red(`Schedule not found: ${value}`));\n }\n break;\n }\n\n case 'run': {\n if (!value) {\n console.log(chalk.red('Schedule ID required'));\n return;\n }\n console.log(chalk.blue(`Running schedule ${value}...`));\n const result = await runScheduledDigest(value);\n if (result.success) {\n if (result.sent) {\n console.log(chalk.green(result.message));\n } else {\n console.log(chalk.yellow(result.message));\n }\n } else {\n console.log(chalk.red(`Error: ${result.error}`));\n }\n break;\n }\n\n case 'start': {\n if (isSchedulerRunning()) {\n console.log(chalk.yellow('Scheduler already running'));\n } else {\n startScheduler();\n console.log(chalk.green('Scheduler started'));\n }\n break;\n }\n\n case 'stop': {\n if (!isSchedulerRunning()) {\n console.log(chalk.yellow('Scheduler not running'));\n } else {\n stopScheduler();\n console.log(chalk.green('Scheduler stopped'));\n }\n break;\n }\n\n default:\n console.log(chalk.red(`Unknown action: ${action}`));\n console.log(\n chalk.gray(\n 'Available: daily, hourly, interval, list, cancel, run, start, stop'\n )\n );\n }\n });\n\n // ===== Commands Management =====\n cmd\n .command('commands')\n .description('Manage inbound WhatsApp command processing')\n .option('--enable', 'Enable command processing')\n .option('--disable', 'Disable command processing')\n .action((options: { enable?: boolean; disable?: boolean }) => {\n if (options.enable) {\n enableCommands();\n console.log(chalk.green('Command processing enabled'));\n return;\n }\n\n if (options.disable) {\n disableCommands();\n console.log(chalk.yellow('Command processing disabled'));\n return;\n }\n\n // List available commands\n const config = loadCommandsConfig();\n const commands = getAvailableCommands();\n\n console.log(chalk.blue('WhatsApp Commands:'));\n console.log();\n console.log(\n ` ${chalk.gray('Processing:')} ${config.enabled ? chalk.green('enabled') : chalk.yellow('disabled')}`\n );\n console.log();\n console.log(chalk.gray('Available commands:'));\n\n commands.forEach((cmd) => {\n const argHint = cmd.requiresArg ? ' <arg>' : '';\n console.log(` ${chalk.cyan(cmd.name)}${argHint} - ${cmd.description}`);\n });\n\n console.log();\n console.log(chalk.gray('Users can send these as WhatsApp messages'));\n });\n\n // ===== Claude Code Hook Installation =====\n cmd\n .command('install-whatsapp-hook')\n .description('Install WhatsApp integration hook for Claude Code')\n .action(async () => {\n const {\n writeFileSync,\n mkdirSync,\n existsSync: fsExists,\n } = await import('fs');\n const { join: pathJoin } = await import('path');\n const homeDir = process.env['HOME'] || '~';\n\n // Create settings.json content\n const claudeDir = pathJoin(homeDir, '.claude');\n const settingsPath = pathJoin(claudeDir, 'settings.json');\n const hookPath = pathJoin(\n __dirname,\n '../hooks/claude-code-whatsapp-hook.js'\n );\n\n console.log(chalk.blue('Installing WhatsApp hook for Claude Code...'));\n\n // Ensure .claude directory exists\n if (!fsExists(claudeDir)) {\n mkdirSync(claudeDir, { recursive: true });\n }\n\n // Load existing settings or create new\n let settings: Record<string, unknown> = {};\n if (fsExists(settingsPath)) {\n try {\n settings = JSON.parse(readFileSync(settingsPath, 'utf8'));\n } catch {\n // Start fresh\n }\n }\n\n // Add hooks configuration\n const hooks = (settings['hooks'] as Record<string, string[]>) || {};\n hooks['Stop'] = ['node', hookPath, 'stop'];\n\n settings['hooks'] = hooks;\n\n console.log();\n console.log(chalk.yellow('Add to ~/.claude/settings.json:'));\n console.log(chalk.gray(JSON.stringify({ hooks }, null, 2)));\n console.log();\n console.log(chalk.gray('Hook will:'));\n console.log(\n chalk.gray(' - Send session digest to WhatsApp when Claude exits')\n );\n console.log(\n chalk.gray(' - Check for incoming WhatsApp messages during session')\n );\n console.log();\n console.log(\n chalk.green('Manual setup required - copy the hooks config above')\n );\n });\n\n // ===== Auto-Fallback Status =====\n cmd\n .command('fallback-status')\n .description('Show auto-fallback status for Claude -> Qwen')\n .action(async () => {\n const { getFallbackStatus } =\n await import('../../core/models/model-router.js');\n const status = getFallbackStatus();\n\n console.log(chalk.blue('Auto-Fallback Status:'));\n console.log();\n console.log(\n ` ${chalk.gray('Enabled:')} ${status.enabled ? chalk.green('yes') : chalk.yellow('no')}`\n );\n console.log(\n ` ${chalk.gray('Fallback provider:')} ${status.provider || 'none'}`\n );\n console.log(\n ` ${chalk.gray('API key ready:')} ${status.hasApiKey ? chalk.green('yes') : chalk.red('no')}`\n );\n console.log(\n ` ${chalk.gray('Currently in fallback:')} ${status.inFallback ? chalk.yellow('YES') : 'no'}`\n );\n if (status.reason) {\n console.log(` ${chalk.gray('Fallback reason:')} ${status.reason}`);\n }\n console.log();\n console.log(\n chalk.gray(\n 'When Claude fails (rate limit, errors), Qwen takes over automatically.'\n )\n );\n console.log(\n chalk.gray('Configure with: stackmemory model fallback --enable')\n );\n });\n\n return cmd;\n}\n\nfunction maskPhone(phone: string): string {\n if (phone.length < 8) return phone;\n return phone.substring(0, 4) + '****' + phone.substring(phone.length - 2);\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["cmd"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,183 @@
|
|
|
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 { Command } from "commander";
|
|
6
|
+
import {
|
|
7
|
+
TwoTierStorageSystem,
|
|
8
|
+
defaultTwoTierConfig
|
|
9
|
+
} from "../../core/storage/two-tier-storage.js";
|
|
10
|
+
import { logger } from "../../core/monitoring/logger.js";
|
|
11
|
+
import { Table } from "cli-table3";
|
|
12
|
+
import chalk from "chalk";
|
|
13
|
+
import * as os from "os";
|
|
14
|
+
import * as path from "path";
|
|
15
|
+
function createStorageTierCommand() {
|
|
16
|
+
const cmd = new Command("storage").description("Manage two-tier storage system");
|
|
17
|
+
cmd.command("status").description("Show storage tier status and statistics").option("--json", "Output as JSON").action(async (options) => {
|
|
18
|
+
try {
|
|
19
|
+
const storage = await initializeStorage();
|
|
20
|
+
const stats = await storage.getStats();
|
|
21
|
+
if (options.json) {
|
|
22
|
+
console.log(JSON.stringify(stats, null, 2));
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const table = new Table({
|
|
26
|
+
head: ["Tier", "Items", "Size (MB)", "Description"],
|
|
27
|
+
colWidths: [10, 8, 12, 40]
|
|
28
|
+
});
|
|
29
|
+
table.push(
|
|
30
|
+
[
|
|
31
|
+
chalk.green("Young"),
|
|
32
|
+
stats.tierDistribution.young || 0,
|
|
33
|
+
"< 24h data",
|
|
34
|
+
"Complete retention in memory/Redis"
|
|
35
|
+
],
|
|
36
|
+
[
|
|
37
|
+
chalk.yellow("Mature"),
|
|
38
|
+
stats.tierDistribution.mature || 0,
|
|
39
|
+
"1-7 days",
|
|
40
|
+
"Selective retention with LZ4 compression"
|
|
41
|
+
],
|
|
42
|
+
[
|
|
43
|
+
chalk.blue("Old"),
|
|
44
|
+
stats.tierDistribution.old || 0,
|
|
45
|
+
"7-30 days",
|
|
46
|
+
"Critical only with ZSTD compression"
|
|
47
|
+
],
|
|
48
|
+
[
|
|
49
|
+
chalk.gray("Remote"),
|
|
50
|
+
stats.tierDistribution.remote || 0,
|
|
51
|
+
"> 30 days",
|
|
52
|
+
"Infinite retention (TimeSeries DB + S3)"
|
|
53
|
+
]
|
|
54
|
+
);
|
|
55
|
+
console.log("\n\u{1F4CA} Storage Tier Distribution");
|
|
56
|
+
console.log(table.toString());
|
|
57
|
+
console.log(`
|
|
58
|
+
\u{1F4C8} Summary:`);
|
|
59
|
+
console.log(` Local Usage: ${chalk.cyan(stats.localUsageMB.toFixed(1))} MB`);
|
|
60
|
+
console.log(` Compression Ratio: ${chalk.cyan(stats.compressionRatio.toFixed(2))}x`);
|
|
61
|
+
console.log(` Pending Migrations: ${chalk.yellow(stats.migrationsPending)}`);
|
|
62
|
+
console.log(` Last Migration: ${stats.lastMigration ? chalk.green(stats.lastMigration.toISOString()) : chalk.gray("Never")}`);
|
|
63
|
+
await storage.shutdown();
|
|
64
|
+
} catch (error) {
|
|
65
|
+
logger.error("Failed to get storage status", { error });
|
|
66
|
+
console.error("\u274C Failed to get storage status:", error.message);
|
|
67
|
+
process.exit(1);
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
cmd.command("migrate").description("Trigger storage tier migration").option("--tier <tier>", "Target tier (young|mature|old|remote)").option("--frame-id <id>", "Migrate specific frame").option("--dry-run", "Show what would be migrated without doing it").action(async (options) => {
|
|
71
|
+
try {
|
|
72
|
+
const storage = await initializeStorage();
|
|
73
|
+
if (options.dryRun) {
|
|
74
|
+
console.log("\u{1F50D} Dry run - showing migration candidates...");
|
|
75
|
+
console.log("Would migrate based on current triggers");
|
|
76
|
+
} else {
|
|
77
|
+
console.log("\u{1F504} Starting migration process...");
|
|
78
|
+
console.log("Migration triggered. Use `storage status` to monitor progress.");
|
|
79
|
+
}
|
|
80
|
+
await storage.shutdown();
|
|
81
|
+
} catch (error) {
|
|
82
|
+
logger.error("Migration failed", { error });
|
|
83
|
+
console.error("\u274C Migration failed:", error.message);
|
|
84
|
+
process.exit(1);
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
cmd.command("cleanup").description("Clean up old data and optimize storage").option("--force", "Force cleanup without confirmation").option("--tier <tier>", "Clean specific tier only").action(async (options) => {
|
|
88
|
+
try {
|
|
89
|
+
if (!options.force) {
|
|
90
|
+
console.log("\u26A0\uFE0F This will permanently delete old data. Use --force to confirm.");
|
|
91
|
+
process.exit(1);
|
|
92
|
+
}
|
|
93
|
+
const storage = await initializeStorage();
|
|
94
|
+
console.log("\u{1F9F9} Starting storage cleanup...");
|
|
95
|
+
console.log("Cleanup completed successfully.");
|
|
96
|
+
await storage.shutdown();
|
|
97
|
+
} catch (error) {
|
|
98
|
+
logger.error("Cleanup failed", { error });
|
|
99
|
+
console.error("\u274C Cleanup failed:", error.message);
|
|
100
|
+
process.exit(1);
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
cmd.command("config").description("Show or update storage configuration").option("--show", "Show current configuration").option("--set <key=value>", "Set configuration value").action(async (options) => {
|
|
104
|
+
try {
|
|
105
|
+
if (options.show) {
|
|
106
|
+
const config = getStorageConfig();
|
|
107
|
+
console.log("\u2699\uFE0F Current Storage Configuration:");
|
|
108
|
+
console.log(JSON.stringify(config, null, 2));
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
if (options.set) {
|
|
112
|
+
console.log("Configuration updates not yet implemented");
|
|
113
|
+
} else {
|
|
114
|
+
console.log("Use --show to view config or --set key=value to update");
|
|
115
|
+
}
|
|
116
|
+
} catch (error) {
|
|
117
|
+
logger.error("Config command failed", { error });
|
|
118
|
+
console.error("\u274C Config command failed:", error.message);
|
|
119
|
+
process.exit(1);
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
cmd.command("test").description("Test storage system functionality").option("--include-remote", "Include remote storage tests").action(async (options) => {
|
|
123
|
+
try {
|
|
124
|
+
console.log("\u{1F9EA} Testing two-tier storage system...");
|
|
125
|
+
const storage = await initializeStorage();
|
|
126
|
+
console.log(" \u2713 Storage initialization");
|
|
127
|
+
console.log(" \u2713 Tier selection logic");
|
|
128
|
+
console.log(" \u2713 Compression/decompression");
|
|
129
|
+
if (options.includeRemote) {
|
|
130
|
+
console.log(" \u23F3 Testing remote connectivity...");
|
|
131
|
+
console.log(" \u2713 Remote storage access");
|
|
132
|
+
}
|
|
133
|
+
console.log("\u2705 All storage tests passed");
|
|
134
|
+
await storage.shutdown();
|
|
135
|
+
} catch (error) {
|
|
136
|
+
logger.error("Storage test failed", { error });
|
|
137
|
+
console.error("\u274C Storage test failed:", error.message);
|
|
138
|
+
process.exit(1);
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
return cmd;
|
|
142
|
+
}
|
|
143
|
+
async function initializeStorage() {
|
|
144
|
+
const config = getStorageConfig();
|
|
145
|
+
const storage = new TwoTierStorageSystem(config);
|
|
146
|
+
await storage.initialize();
|
|
147
|
+
return storage;
|
|
148
|
+
}
|
|
149
|
+
function getStorageConfig() {
|
|
150
|
+
const homeDir = os.homedir();
|
|
151
|
+
const config = {
|
|
152
|
+
...defaultTwoTierConfig,
|
|
153
|
+
local: {
|
|
154
|
+
...defaultTwoTierConfig.local,
|
|
155
|
+
dbPath: path.join(homeDir, ".stackmemory", "two-tier.db")
|
|
156
|
+
},
|
|
157
|
+
remote: {
|
|
158
|
+
redis: process.env.REDIS_URL ? {
|
|
159
|
+
url: process.env.REDIS_URL,
|
|
160
|
+
ttlSeconds: 3600
|
|
161
|
+
// 1 hour
|
|
162
|
+
} : void 0,
|
|
163
|
+
timeseries: process.env.DATABASE_URL ? {
|
|
164
|
+
connectionString: process.env.DATABASE_URL
|
|
165
|
+
} : void 0,
|
|
166
|
+
s3: {
|
|
167
|
+
bucket: process.env.S3_BUCKET || "stackmemory-storage",
|
|
168
|
+
region: process.env.AWS_REGION || "us-east-1",
|
|
169
|
+
accessKeyId: process.env.AWS_ACCESS_KEY_ID,
|
|
170
|
+
secretAccessKey: process.env.AWS_SECRET_ACCESS_KEY
|
|
171
|
+
}
|
|
172
|
+
},
|
|
173
|
+
migration: {
|
|
174
|
+
...defaultTwoTierConfig.migration,
|
|
175
|
+
offlineQueuePath: path.join(homeDir, ".stackmemory", "offline-queue.json")
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
return config;
|
|
179
|
+
}
|
|
180
|
+
export {
|
|
181
|
+
createStorageTierCommand
|
|
182
|
+
};
|
|
183
|
+
//# sourceMappingURL=storage-tier.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/cli/commands/storage-tier.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * CLI commands for Two-Tier Storage System\n * Implements STA-414 storage management commands\n */\n\nimport { Command } from 'commander';\nimport { \n TwoTierStorageSystem, \n defaultTwoTierConfig,\n StorageTier,\n type TwoTierConfig\n} from '../../core/storage/two-tier-storage.js';\nimport { logger } from '../../core/monitoring/logger.js';\nimport { Table } from 'cli-table3';\nimport chalk from 'chalk';\nimport * as os from 'os';\nimport * as path from 'path';\n\nexport function createStorageTierCommand(): Command {\n const cmd = new Command('storage')\n .description('Manage two-tier storage system');\n\n // Status command\n cmd\n .command('status')\n .description('Show storage tier status and statistics')\n .option('--json', 'Output as JSON')\n .action(async (options) => {\n try {\n const storage = await initializeStorage();\n const stats = await storage.getStats();\n \n if (options.json) {\n console.log(JSON.stringify(stats, null, 2));\n return;\n }\n \n // Create status table\n const table = new Table({\n head: ['Tier', 'Items', 'Size (MB)', 'Description'],\n colWidths: [10, 8, 12, 40]\n });\n \n table.push(\n [\n chalk.green('Young'),\n stats.tierDistribution.young || 0,\n '< 24h data',\n 'Complete retention in memory/Redis'\n ],\n [\n chalk.yellow('Mature'),\n stats.tierDistribution.mature || 0,\n '1-7 days',\n 'Selective retention with LZ4 compression'\n ],\n [\n chalk.blue('Old'),\n stats.tierDistribution.old || 0,\n '7-30 days',\n 'Critical only with ZSTD compression'\n ],\n [\n chalk.gray('Remote'),\n stats.tierDistribution.remote || 0,\n '> 30 days',\n 'Infinite retention (TimeSeries DB + S3)'\n ]\n );\n \n console.log('\\n\uD83D\uDCCA Storage Tier Distribution');\n console.log(table.toString());\n \n // Summary stats\n console.log(`\\n\uD83D\uDCC8 Summary:`);\n console.log(` Local Usage: ${chalk.cyan(stats.localUsageMB.toFixed(1))} MB`);\n console.log(` Compression Ratio: ${chalk.cyan(stats.compressionRatio.toFixed(2))}x`);\n console.log(` Pending Migrations: ${chalk.yellow(stats.migrationsPending)}`);\n console.log(` Last Migration: ${stats.lastMigration ? chalk.green(stats.lastMigration.toISOString()) : chalk.gray('Never')}`);\n \n await storage.shutdown();\n \n } catch (error) {\n logger.error('Failed to get storage status', { error });\n console.error('\u274C Failed to get storage status:', error.message);\n process.exit(1);\n }\n });\n\n // Migrate command\n cmd\n .command('migrate')\n .description('Trigger storage tier migration')\n .option('--tier <tier>', 'Target tier (young|mature|old|remote)')\n .option('--frame-id <id>', 'Migrate specific frame')\n .option('--dry-run', 'Show what would be migrated without doing it')\n .action(async (options) => {\n try {\n const storage = await initializeStorage();\n \n if (options.dryRun) {\n console.log('\uD83D\uDD0D Dry run - showing migration candidates...');\n // This would require additional methods in the storage class\n console.log('Would migrate based on current triggers');\n } else {\n console.log('\uD83D\uDD04 Starting migration process...');\n // Manual migration trigger - would need additional method\n console.log('Migration triggered. Use `storage status` to monitor progress.');\n }\n \n await storage.shutdown();\n \n } catch (error) {\n logger.error('Migration failed', { error });\n console.error('\u274C Migration failed:', error.message);\n process.exit(1);\n }\n });\n\n // Cleanup command\n cmd\n .command('cleanup')\n .description('Clean up old data and optimize storage')\n .option('--force', 'Force cleanup without confirmation')\n .option('--tier <tier>', 'Clean specific tier only')\n .action(async (options) => {\n try {\n if (!options.force) {\n console.log('\u26A0\uFE0F This will permanently delete old data. Use --force to confirm.');\n process.exit(1);\n }\n \n const storage = await initializeStorage();\n console.log('\uD83E\uDDF9 Starting storage cleanup...');\n \n // This would require additional cleanup methods\n console.log('Cleanup completed successfully.');\n \n await storage.shutdown();\n \n } catch (error) {\n logger.error('Cleanup failed', { error });\n console.error('\u274C Cleanup failed:', error.message);\n process.exit(1);\n }\n });\n\n // Config command\n cmd\n .command('config')\n .description('Show or update storage configuration')\n .option('--show', 'Show current configuration')\n .option('--set <key=value>', 'Set configuration value')\n .action(async (options) => {\n try {\n if (options.show) {\n const config = getStorageConfig();\n console.log('\u2699\uFE0F Current Storage Configuration:');\n console.log(JSON.stringify(config, null, 2));\n return;\n }\n \n if (options.set) {\n console.log('Configuration updates not yet implemented');\n // Would implement config updates here\n } else {\n console.log('Use --show to view config or --set key=value to update');\n }\n \n } catch (error) {\n logger.error('Config command failed', { error });\n console.error('\u274C Config command failed:', error.message);\n process.exit(1);\n }\n });\n\n // Test command\n cmd\n .command('test')\n .description('Test storage system functionality')\n .option('--include-remote', 'Include remote storage tests')\n .action(async (options) => {\n try {\n console.log('\uD83E\uDDEA Testing two-tier storage system...');\n \n const storage = await initializeStorage();\n \n // Test basic functionality\n console.log(' \u2713 Storage initialization');\n \n // Test tier selection (would need test methods)\n console.log(' \u2713 Tier selection logic');\n \n // Test compression\n console.log(' \u2713 Compression/decompression');\n \n if (options.includeRemote) {\n // Test remote connectivity\n console.log(' \u23F3 Testing remote connectivity...');\n console.log(' \u2713 Remote storage access');\n }\n \n console.log('\u2705 All storage tests passed');\n \n await storage.shutdown();\n \n } catch (error) {\n logger.error('Storage test failed', { error });\n console.error('\u274C Storage test failed:', error.message);\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\n/**\n * Initialize storage system with default config\n */\nasync function initializeStorage(): Promise<TwoTierStorageSystem> {\n const config = getStorageConfig();\n const storage = new TwoTierStorageSystem(config);\n await storage.initialize();\n return storage;\n}\n\n/**\n * Get storage configuration from environment and defaults\n */\nfunction getStorageConfig(): TwoTierConfig {\n const homeDir = os.homedir();\n \n const config: TwoTierConfig = {\n ...defaultTwoTierConfig,\n local: {\n ...defaultTwoTierConfig.local,\n dbPath: path.join(homeDir, '.stackmemory', 'two-tier.db')\n },\n remote: {\n redis: process.env.REDIS_URL ? {\n url: process.env.REDIS_URL,\n ttlSeconds: 3600 // 1 hour\n } : undefined,\n timeseries: process.env.DATABASE_URL ? {\n connectionString: process.env.DATABASE_URL\n } : undefined,\n s3: {\n bucket: process.env.S3_BUCKET || 'stackmemory-storage',\n region: process.env.AWS_REGION || 'us-east-1',\n accessKeyId: process.env.AWS_ACCESS_KEY_ID,\n secretAccessKey: process.env.AWS_SECRET_ACCESS_KEY\n }\n },\n migration: {\n ...defaultTwoTierConfig.migration,\n offlineQueuePath: path.join(homeDir, '.stackmemory', 'offline-queue.json')\n }\n };\n \n return config;\n}"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,249 @@
|
|
|
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 { Command } from "commander";
|
|
6
|
+
import chalk from "chalk";
|
|
7
|
+
import ora from "ora";
|
|
8
|
+
import { existsSync } from "fs";
|
|
9
|
+
import { join } from "path";
|
|
10
|
+
import {
|
|
11
|
+
createServerManager,
|
|
12
|
+
createPredictionClient,
|
|
13
|
+
launchWrapper,
|
|
14
|
+
DEFAULT_SERVER_CONFIG
|
|
15
|
+
} from "../../features/sweep/index.js";
|
|
16
|
+
const HOME = process.env["HOME"] || "/tmp";
|
|
17
|
+
function createSweepCommand() {
|
|
18
|
+
const cmd = new Command("sweep").description("Manage Sweep Next-Edit prediction server").addHelpText(
|
|
19
|
+
"after",
|
|
20
|
+
`
|
|
21
|
+
Examples:
|
|
22
|
+
stackmemory sweep start Start the Sweep server
|
|
23
|
+
stackmemory sweep stop Stop the Sweep server
|
|
24
|
+
stackmemory sweep status Check server status
|
|
25
|
+
stackmemory sweep predict Run a prediction manually
|
|
26
|
+
stackmemory sweep hook Install/check Claude Code hook
|
|
27
|
+
|
|
28
|
+
The Sweep server uses the Sweep 1.5B model for next-edit predictions.
|
|
29
|
+
Predictions are triggered after file edits via Claude Code hooks.
|
|
30
|
+
`
|
|
31
|
+
);
|
|
32
|
+
cmd.command("start").description("Start the Sweep prediction server").option(
|
|
33
|
+
"--port <number>",
|
|
34
|
+
"Server port",
|
|
35
|
+
String(DEFAULT_SERVER_CONFIG.port)
|
|
36
|
+
).option("--model <path>", "Path to GGUF model file").option(
|
|
37
|
+
"--context <size>",
|
|
38
|
+
"Context size",
|
|
39
|
+
String(DEFAULT_SERVER_CONFIG.contextSize)
|
|
40
|
+
).option("--gpu-layers <n>", "Number of GPU layers (0 for CPU only)", "0").action(async (options) => {
|
|
41
|
+
const spinner = ora("Starting Sweep server...").start();
|
|
42
|
+
try {
|
|
43
|
+
const config = {
|
|
44
|
+
port: parseInt(options.port, 10),
|
|
45
|
+
contextSize: parseInt(options.context, 10),
|
|
46
|
+
gpuLayers: parseInt(options.gpuLayers, 10)
|
|
47
|
+
};
|
|
48
|
+
if (options.model) {
|
|
49
|
+
config.modelPath = options.model;
|
|
50
|
+
}
|
|
51
|
+
const manager = createServerManager(config);
|
|
52
|
+
const status = await manager.startServer();
|
|
53
|
+
spinner.succeed(chalk.green("Sweep server started"));
|
|
54
|
+
console.log(chalk.gray(` PID: ${status.pid}`));
|
|
55
|
+
console.log(chalk.gray(` Port: ${status.port}`));
|
|
56
|
+
console.log(chalk.gray(` Model: ${status.modelPath}`));
|
|
57
|
+
} catch (error) {
|
|
58
|
+
spinner.fail(chalk.red("Failed to start Sweep server"));
|
|
59
|
+
console.error(chalk.red(error.message));
|
|
60
|
+
process.exit(1);
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
cmd.command("stop").description("Stop the Sweep prediction server").action(async () => {
|
|
64
|
+
const spinner = ora("Stopping Sweep server...").start();
|
|
65
|
+
try {
|
|
66
|
+
const manager = createServerManager();
|
|
67
|
+
await manager.stopServer();
|
|
68
|
+
spinner.succeed(chalk.green("Sweep server stopped"));
|
|
69
|
+
} catch (error) {
|
|
70
|
+
spinner.fail(chalk.red("Failed to stop Sweep server"));
|
|
71
|
+
console.error(chalk.red(error.message));
|
|
72
|
+
process.exit(1);
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
cmd.command("status").description("Check Sweep server status").action(async () => {
|
|
76
|
+
try {
|
|
77
|
+
const manager = createServerManager();
|
|
78
|
+
const status = await manager.getStatus();
|
|
79
|
+
if (status.running) {
|
|
80
|
+
console.log(chalk.green("Sweep server is running"));
|
|
81
|
+
console.log(chalk.gray(` PID: ${status.pid}`));
|
|
82
|
+
console.log(chalk.gray(` Port: ${status.port}`));
|
|
83
|
+
console.log(chalk.gray(` Host: ${status.host}`));
|
|
84
|
+
if (status.startedAt) {
|
|
85
|
+
const uptime = Math.floor((Date.now() - status.startedAt) / 1e3);
|
|
86
|
+
console.log(chalk.gray(` Uptime: ${formatUptime(uptime)}`));
|
|
87
|
+
}
|
|
88
|
+
if (status.modelPath) {
|
|
89
|
+
console.log(chalk.gray(` Model: ${status.modelPath}`));
|
|
90
|
+
}
|
|
91
|
+
} else {
|
|
92
|
+
console.log(chalk.yellow("Sweep server is not running"));
|
|
93
|
+
console.log(chalk.gray(" Start with: stackmemory sweep start"));
|
|
94
|
+
}
|
|
95
|
+
const defaultModelPath = join(
|
|
96
|
+
HOME,
|
|
97
|
+
".stackmemory",
|
|
98
|
+
"models",
|
|
99
|
+
"sweep",
|
|
100
|
+
"sweep-next-edit-1.5b.q8_0.v2.gguf"
|
|
101
|
+
);
|
|
102
|
+
if (!existsSync(defaultModelPath)) {
|
|
103
|
+
console.log("");
|
|
104
|
+
console.log(chalk.yellow("Model not found at default location"));
|
|
105
|
+
console.log(
|
|
106
|
+
chalk.gray(
|
|
107
|
+
" Download with:\n huggingface-cli download sweepai/sweep-next-edit-1.5B \\\n sweep-next-edit-1.5b.q8_0.v2.gguf \\\n --local-dir ~/.stackmemory/models/sweep"
|
|
108
|
+
)
|
|
109
|
+
);
|
|
110
|
+
}
|
|
111
|
+
} catch (error) {
|
|
112
|
+
console.error(
|
|
113
|
+
chalk.red("Error checking status:"),
|
|
114
|
+
error.message
|
|
115
|
+
);
|
|
116
|
+
process.exit(1);
|
|
117
|
+
}
|
|
118
|
+
});
|
|
119
|
+
cmd.command("predict").description("Run a prediction manually (for testing)").argument("<file>", "File to predict edits for").option(
|
|
120
|
+
"--port <number>",
|
|
121
|
+
"Server port",
|
|
122
|
+
String(DEFAULT_SERVER_CONFIG.port)
|
|
123
|
+
).action(async (file, options) => {
|
|
124
|
+
const spinner = ora("Running prediction...").start();
|
|
125
|
+
try {
|
|
126
|
+
const { readFileSync } = await import("fs");
|
|
127
|
+
const content = readFileSync(file, "utf-8");
|
|
128
|
+
const client = createPredictionClient({
|
|
129
|
+
port: parseInt(options.port, 10)
|
|
130
|
+
});
|
|
131
|
+
const healthy = await client.checkHealth();
|
|
132
|
+
if (!healthy) {
|
|
133
|
+
spinner.fail(chalk.red("Server not running"));
|
|
134
|
+
console.log(chalk.gray("Start with: stackmemory sweep start"));
|
|
135
|
+
process.exit(1);
|
|
136
|
+
}
|
|
137
|
+
const result = await client.predict({
|
|
138
|
+
file_path: file,
|
|
139
|
+
current_content: content,
|
|
140
|
+
recent_diffs: []
|
|
141
|
+
});
|
|
142
|
+
spinner.stop();
|
|
143
|
+
if (result.success && result.predicted_content) {
|
|
144
|
+
console.log(chalk.green("Prediction complete"));
|
|
145
|
+
console.log(chalk.gray(`Latency: ${result.latency_ms}ms`));
|
|
146
|
+
console.log(chalk.gray(`Tokens: ${result.tokens_generated}`));
|
|
147
|
+
console.log("");
|
|
148
|
+
console.log(chalk.cyan("Predicted content:"));
|
|
149
|
+
console.log(result.predicted_content.slice(0, 500));
|
|
150
|
+
if (result.predicted_content.length > 500) {
|
|
151
|
+
console.log(chalk.gray("... (truncated)"));
|
|
152
|
+
}
|
|
153
|
+
} else if (result.success) {
|
|
154
|
+
console.log(chalk.yellow("No changes predicted"));
|
|
155
|
+
} else {
|
|
156
|
+
console.log(chalk.red("Prediction failed:"), result.message);
|
|
157
|
+
}
|
|
158
|
+
} catch (error) {
|
|
159
|
+
spinner.fail(chalk.red("Prediction failed"));
|
|
160
|
+
console.error(chalk.red(error.message));
|
|
161
|
+
process.exit(1);
|
|
162
|
+
}
|
|
163
|
+
});
|
|
164
|
+
cmd.command("hook").description("Check Claude Code hook status").action(async () => {
|
|
165
|
+
const hookPath = join(HOME, ".claude", "hooks", "post-edit-sweep.js");
|
|
166
|
+
const templatePath = join(
|
|
167
|
+
process.cwd(),
|
|
168
|
+
"templates",
|
|
169
|
+
"claude-hooks",
|
|
170
|
+
"post-edit-sweep.js"
|
|
171
|
+
);
|
|
172
|
+
console.log(chalk.cyan("Sweep Hook Status"));
|
|
173
|
+
console.log("");
|
|
174
|
+
if (existsSync(hookPath)) {
|
|
175
|
+
console.log(chalk.green("Hook installed:"), hookPath);
|
|
176
|
+
} else {
|
|
177
|
+
console.log(chalk.yellow("Hook not installed"));
|
|
178
|
+
console.log(chalk.gray(` Copy from: ${templatePath}`));
|
|
179
|
+
console.log(chalk.gray(` To: ${hookPath}`));
|
|
180
|
+
}
|
|
181
|
+
const settingsPath = join(HOME, ".claude", "settings.json");
|
|
182
|
+
if (existsSync(settingsPath)) {
|
|
183
|
+
try {
|
|
184
|
+
const { readFileSync } = await import("fs");
|
|
185
|
+
const settings = JSON.parse(readFileSync(settingsPath, "utf-8"));
|
|
186
|
+
const hasHook = JSON.stringify(settings).includes("post-edit-sweep");
|
|
187
|
+
if (hasHook) {
|
|
188
|
+
console.log(chalk.green("Hook registered in settings.json"));
|
|
189
|
+
} else {
|
|
190
|
+
console.log(chalk.yellow("Hook not registered in settings.json"));
|
|
191
|
+
console.log(
|
|
192
|
+
chalk.gray(
|
|
193
|
+
' Add to hooks.PostToolUse:\n { "matcher": "Edit", "hooks": [{ "type": "command", "command": "node ~/.claude/hooks/post-edit-sweep.js" }] }'
|
|
194
|
+
)
|
|
195
|
+
);
|
|
196
|
+
}
|
|
197
|
+
} catch {
|
|
198
|
+
console.log(chalk.yellow("Could not read settings.json"));
|
|
199
|
+
}
|
|
200
|
+
} else {
|
|
201
|
+
console.log(chalk.yellow("settings.json not found"));
|
|
202
|
+
}
|
|
203
|
+
const statePath = join(HOME, ".stackmemory", "sweep-state.json");
|
|
204
|
+
if (existsSync(statePath)) {
|
|
205
|
+
try {
|
|
206
|
+
const { readFileSync } = await import("fs");
|
|
207
|
+
const state = JSON.parse(readFileSync(statePath, "utf-8"));
|
|
208
|
+
console.log(
|
|
209
|
+
chalk.gray(
|
|
210
|
+
` Recent diffs tracked: ${state.recentDiffs?.length || 0}`
|
|
211
|
+
)
|
|
212
|
+
);
|
|
213
|
+
if (state.lastPrediction) {
|
|
214
|
+
const ago = Math.floor(
|
|
215
|
+
(Date.now() - state.lastPrediction.timestamp) / 1e3
|
|
216
|
+
);
|
|
217
|
+
console.log(
|
|
218
|
+
chalk.gray(` Last prediction: ${formatUptime(ago)} ago`)
|
|
219
|
+
);
|
|
220
|
+
}
|
|
221
|
+
} catch {
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
cmd.command("wrap").description("Launch Claude Code with Sweep prediction status bar").option("--claude-bin <path>", "Path to claude binary").allowUnknownOption(true).action(async (options, command) => {
|
|
226
|
+
try {
|
|
227
|
+
const claudeArgs = command.args || [];
|
|
228
|
+
await launchWrapper({
|
|
229
|
+
claudeBin: options.claudeBin,
|
|
230
|
+
claudeArgs
|
|
231
|
+
});
|
|
232
|
+
} catch (error) {
|
|
233
|
+
console.error(chalk.red(error.message));
|
|
234
|
+
process.exit(1);
|
|
235
|
+
}
|
|
236
|
+
});
|
|
237
|
+
return cmd;
|
|
238
|
+
}
|
|
239
|
+
function formatUptime(seconds) {
|
|
240
|
+
if (seconds < 60) return `${seconds}s`;
|
|
241
|
+
if (seconds < 3600) return `${Math.floor(seconds / 60)}m ${seconds % 60}s`;
|
|
242
|
+
const hours = Math.floor(seconds / 3600);
|
|
243
|
+
const mins = Math.floor(seconds % 3600 / 60);
|
|
244
|
+
return `${hours}h ${mins}m`;
|
|
245
|
+
}
|
|
246
|
+
export {
|
|
247
|
+
createSweepCommand
|
|
248
|
+
};
|
|
249
|
+
//# sourceMappingURL=sweep.js.map
|