@stackmemoryai/stackmemory 0.5.59 → 0.5.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +105 -1
- package/dist/src/cli/claude-sm.js +130 -50
- package/dist/src/cli/claude-sm.js.map +2 -2
- package/dist/src/cli/index.js +18 -3
- package/dist/src/cli/index.js.map +3 -3
- package/dist/src/core/extensions/custom-tools.js +567 -0
- package/dist/src/core/extensions/custom-tools.js.map +7 -0
- package/dist/src/core/extensions/index.js +55 -0
- package/dist/src/core/extensions/index.js.map +7 -0
- package/dist/src/core/extensions/loader.js +709 -0
- package/dist/src/core/extensions/loader.js.map +7 -0
- package/dist/src/core/extensions/plugin-system.js +506 -0
- package/dist/src/core/extensions/plugin-system.js.map +7 -0
- package/dist/src/core/extensions/provider-adapter.js +617 -0
- package/dist/src/core/extensions/provider-adapter.js.map +7 -0
- package/dist/src/core/extensions/sandbox-runtime.js +664 -0
- package/dist/src/core/extensions/sandbox-runtime.js.map +7 -0
- package/dist/src/core/storage/chromadb-adapter.js +32 -6
- package/dist/src/core/storage/chromadb-adapter.js.map +2 -2
- package/dist/src/skills/repo-ingestion-skill.js +35 -12
- package/dist/src/skills/repo-ingestion-skill.js.map +2 -2
- package/package.json +11 -7
- package/scripts/background-sync-manager.js +145 -83
- package/scripts/claude-sm-autostart.js +17 -12
- package/scripts/gepa/README.md +275 -0
- package/scripts/gepa/config.json +53 -0
- package/scripts/gepa/evals/coding-tasks.jsonl +5 -0
- package/scripts/gepa/evals/fixtures/buggy-loop.js +18 -0
- package/scripts/gepa/evals/fixtures/callback-hell.js +53 -0
- package/scripts/gepa/generations/gen-000/baseline.md +124 -0
- package/scripts/gepa/hooks/auto-optimize.js +494 -0
- package/scripts/gepa/hooks/eval-tracker.js +203 -0
- package/scripts/gepa/hooks/reflect.js +311 -0
- package/scripts/gepa/optimize.js +611 -0
- package/scripts/gepa/state.json +14 -0
- package/scripts/test-pre-publish-quick.sh +1 -1
- package/dist/agents/core/agent-task-manager.js +0 -527
- package/dist/agents/core/agent-task-manager.js.map +0 -7
- package/dist/agents/testing-agent.js +0 -614
- package/dist/agents/testing-agent.js.map +0 -7
- package/dist/agents/verifiers/base-verifier.js +0 -133
- package/dist/agents/verifiers/base-verifier.js.map +0 -7
- package/dist/agents/verifiers/formatter-verifier.js +0 -130
- package/dist/agents/verifiers/formatter-verifier.js.map +0 -7
- package/dist/agents/verifiers/llm-judge.js +0 -252
- package/dist/agents/verifiers/llm-judge.js.map +0 -7
- package/dist/cli/auto-detect.js +0 -321
- package/dist/cli/auto-detect.js.map +0 -7
- package/dist/cli/browser-test.js +0 -33
- package/dist/cli/browser-test.js.map +0 -7
- package/dist/cli/claude-sm-danger.js +0 -21
- package/dist/cli/claude-sm-danger.js.map +0 -7
- package/dist/cli/claude-sm.js +0 -1156
- package/dist/cli/claude-sm.js.map +0 -7
- package/dist/cli/codex-sm-danger.js +0 -21
- package/dist/cli/codex-sm-danger.js.map +0 -7
- package/dist/cli/codex-sm.js +0 -349
- package/dist/cli/codex-sm.js.map +0 -7
- package/dist/cli/commands/api.js +0 -232
- package/dist/cli/commands/api.js.map +0 -7
- package/dist/cli/commands/auto-background.js +0 -180
- package/dist/cli/commands/auto-background.js.map +0 -7
- package/dist/cli/commands/cleanup-processes.js +0 -68
- package/dist/cli/commands/cleanup-processes.js.map +0 -7
- package/dist/cli/commands/clear.js +0 -202
- package/dist/cli/commands/clear.js.map +0 -7
- package/dist/cli/commands/config.js +0 -445
- package/dist/cli/commands/config.js.map +0 -7
- package/dist/cli/commands/context-rehydrate.js +0 -751
- package/dist/cli/commands/context-rehydrate.js.map +0 -7
- package/dist/cli/commands/context.js +0 -343
- package/dist/cli/commands/context.js.map +0 -7
- package/dist/cli/commands/daemon.js +0 -392
- package/dist/cli/commands/daemon.js.map +0 -7
- package/dist/cli/commands/dashboard.js +0 -210
- package/dist/cli/commands/dashboard.js.map +0 -7
- package/dist/cli/commands/db.js +0 -147
- package/dist/cli/commands/db.js.map +0 -7
- package/dist/cli/commands/decision.js +0 -266
- package/dist/cli/commands/decision.js.map +0 -7
- package/dist/cli/commands/discovery.js +0 -279
- package/dist/cli/commands/discovery.js.map +0 -7
- package/dist/cli/commands/handoff.js +0 -624
- package/dist/cli/commands/handoff.js.map +0 -7
- package/dist/cli/commands/hooks.js +0 -298
- package/dist/cli/commands/hooks.js.map +0 -7
- package/dist/cli/commands/linear-unified.js +0 -353
- package/dist/cli/commands/linear-unified.js.map +0 -7
- package/dist/cli/commands/linear.js +0 -529
- package/dist/cli/commands/linear.js.map +0 -7
- package/dist/cli/commands/log.js +0 -169
- package/dist/cli/commands/log.js.map +0 -7
- package/dist/cli/commands/login.js +0 -172
- package/dist/cli/commands/login.js.map +0 -7
- package/dist/cli/commands/migrate.js +0 -240
- package/dist/cli/commands/migrate.js.map +0 -7
- package/dist/cli/commands/model.js +0 -533
- package/dist/cli/commands/model.js.map +0 -7
- package/dist/cli/commands/monitor.js +0 -313
- package/dist/cli/commands/monitor.js.map +0 -7
- package/dist/cli/commands/onboard.js +0 -536
- package/dist/cli/commands/onboard.js.map +0 -7
- package/dist/cli/commands/projects.js +0 -199
- package/dist/cli/commands/projects.js.map +0 -7
- package/dist/cli/commands/quality.js +0 -413
- package/dist/cli/commands/quality.js.map +0 -7
- package/dist/cli/commands/ralph.js +0 -909
- package/dist/cli/commands/ralph.js.map +0 -7
- package/dist/cli/commands/retrieval.js +0 -248
- package/dist/cli/commands/retrieval.js.map +0 -7
- package/dist/cli/commands/search.js +0 -173
- package/dist/cli/commands/search.js.map +0 -7
- package/dist/cli/commands/service.js +0 -749
- package/dist/cli/commands/service.js.map +0 -7
- package/dist/cli/commands/session.js +0 -200
- package/dist/cli/commands/session.js.map +0 -7
- package/dist/cli/commands/settings.js +0 -306
- package/dist/cli/commands/settings.js.map +0 -7
- package/dist/cli/commands/setup.js +0 -701
- package/dist/cli/commands/setup.js.map +0 -7
- package/dist/cli/commands/shell.js +0 -249
- package/dist/cli/commands/shell.js.map +0 -7
- package/dist/cli/commands/signup.js +0 -50
- package/dist/cli/commands/signup.js.map +0 -7
- package/dist/cli/commands/skills.js +0 -470
- package/dist/cli/commands/skills.js.map +0 -7
- package/dist/cli/commands/sms-notify.js +0 -795
- package/dist/cli/commands/sms-notify.js.map +0 -7
- package/dist/cli/commands/storage-tier.js +0 -183
- package/dist/cli/commands/storage-tier.js.map +0 -7
- package/dist/cli/commands/storage.js +0 -360
- package/dist/cli/commands/storage.js.map +0 -7
- package/dist/cli/commands/sweep.js +0 -249
- package/dist/cli/commands/sweep.js.map +0 -7
- package/dist/cli/commands/tasks.js +0 -213
- package/dist/cli/commands/tasks.js.map +0 -7
- package/dist/cli/commands/test.js +0 -286
- package/dist/cli/commands/test.js.map +0 -7
- package/dist/cli/commands/workflow.js +0 -142
- package/dist/cli/commands/workflow.js.map +0 -7
- package/dist/cli/commands/worktree.js +0 -319
- package/dist/cli/commands/worktree.js.map +0 -7
- package/dist/cli/index.js +0 -594
- package/dist/cli/index.js.map +0 -7
- package/dist/cli/opencode-sm.js +0 -448
- package/dist/cli/opencode-sm.js.map +0 -7
- package/dist/cli/utils/viewer.js +0 -96
- package/dist/cli/utils/viewer.js.map +0 -7
- package/dist/core/analytics/team-analytics.js +0 -378
- package/dist/core/analytics/team-analytics.js.map +0 -7
- package/dist/core/config/config-manager.js +0 -398
- package/dist/core/config/config-manager.js.map +0 -7
- package/dist/core/config/feature-flags.js +0 -76
- package/dist/core/config/feature-flags.js.map +0 -7
- package/dist/core/config/storage-config.js +0 -115
- package/dist/core/config/storage-config.js.map +0 -7
- package/dist/core/config/types.js +0 -144
- package/dist/core/config/types.js.map +0 -7
- package/dist/core/context/auto-context.js +0 -80
- package/dist/core/context/auto-context.js.map +0 -7
- package/dist/core/context/dual-stack-manager.js +0 -870
- package/dist/core/context/dual-stack-manager.js.map +0 -7
- package/dist/core/context/enhanced-rehydration.js +0 -994
- package/dist/core/context/enhanced-rehydration.js.map +0 -7
- package/dist/core/context/frame-database.js +0 -479
- package/dist/core/context/frame-database.js.map +0 -7
- package/dist/core/context/frame-digest.js +0 -250
- package/dist/core/context/frame-digest.js.map +0 -7
- package/dist/core/context/frame-handoff-manager.js +0 -778
- package/dist/core/context/frame-handoff-manager.js.map +0 -7
- package/dist/core/context/frame-lifecycle-hooks.js +0 -119
- package/dist/core/context/frame-lifecycle-hooks.js.map +0 -7
- package/dist/core/context/frame-manager.js +0 -1069
- package/dist/core/context/frame-manager.js.map +0 -7
- package/dist/core/context/frame-recovery.js +0 -302
- package/dist/core/context/frame-recovery.js.map +0 -7
- package/dist/core/context/frame-stack.js +0 -314
- package/dist/core/context/frame-stack.js.map +0 -7
- package/dist/core/context/frame-types.js +0 -5
- package/dist/core/context/frame-types.js.map +0 -7
- package/dist/core/context/incremental-gc.js +0 -290
- package/dist/core/context/incremental-gc.js.map +0 -7
- package/dist/core/context/index.js +0 -25
- package/dist/core/context/index.js.map +0 -7
- package/dist/core/context/model-aware-compaction.js +0 -623
- package/dist/core/context/model-aware-compaction.js.map +0 -7
- package/dist/core/context/permission-manager.js +0 -185
- package/dist/core/context/permission-manager.js.map +0 -7
- package/dist/core/context/recursive-context-manager.js +0 -592
- package/dist/core/context/recursive-context-manager.js.map +0 -7
- package/dist/core/context/refactored-frame-manager.js +0 -754
- package/dist/core/context/refactored-frame-manager.js.map +0 -7
- package/dist/core/context/shared-context-layer.js +0 -621
- package/dist/core/context/shared-context-layer.js.map +0 -7
- package/dist/core/context/stack-merge-resolver.js +0 -749
- package/dist/core/context/stack-merge-resolver.js.map +0 -7
- package/dist/core/context/validation.js +0 -130
- package/dist/core/context/validation.js.map +0 -7
- package/dist/core/database/batch-operations.js +0 -384
- package/dist/core/database/batch-operations.js.map +0 -7
- package/dist/core/database/connection-pool.js +0 -330
- package/dist/core/database/connection-pool.js.map +0 -7
- package/dist/core/database/database-adapter.js +0 -60
- package/dist/core/database/database-adapter.js.map +0 -7
- package/dist/core/database/migration-manager.js +0 -614
- package/dist/core/database/migration-manager.js.map +0 -7
- package/dist/core/database/paradedb-adapter.js +0 -990
- package/dist/core/database/paradedb-adapter.js.map +0 -7
- package/dist/core/database/query-cache.js +0 -298
- package/dist/core/database/query-cache.js.map +0 -7
- package/dist/core/database/query-router.js +0 -430
- package/dist/core/database/query-router.js.map +0 -7
- package/dist/core/database/sqlite-adapter.js +0 -738
- package/dist/core/database/sqlite-adapter.js.map +0 -7
- package/dist/core/digest/enhanced-hybrid-digest.js +0 -277
- package/dist/core/digest/enhanced-hybrid-digest.js.map +0 -7
- package/dist/core/digest/frame-digest-integration.js +0 -176
- package/dist/core/digest/frame-digest-integration.js.map +0 -7
- package/dist/core/digest/hybrid-digest-generator.js +0 -553
- package/dist/core/digest/hybrid-digest-generator.js.map +0 -7
- package/dist/core/digest/index.js +0 -9
- package/dist/core/digest/index.js.map +0 -7
- package/dist/core/digest/types.js +0 -25
- package/dist/core/digest/types.js.map +0 -7
- package/dist/core/errors/error-utils.js +0 -208
- package/dist/core/errors/error-utils.js.map +0 -7
- package/dist/core/errors/index.js +0 -521
- package/dist/core/errors/index.js.map +0 -7
- package/dist/core/errors/recovery.js +0 -269
- package/dist/core/errors/recovery.js.map +0 -7
- package/dist/core/execution/parallel-executor.js +0 -258
- package/dist/core/execution/parallel-executor.js.map +0 -7
- package/dist/core/frame/workflow-templates.js +0 -319
- package/dist/core/frame/workflow-templates.js.map +0 -7
- package/dist/core/merge/conflict-detector.js +0 -431
- package/dist/core/merge/conflict-detector.js.map +0 -7
- package/dist/core/merge/index.js +0 -9
- package/dist/core/merge/index.js.map +0 -7
- package/dist/core/merge/resolution-engine.js +0 -558
- package/dist/core/merge/resolution-engine.js.map +0 -7
- package/dist/core/merge/stack-diff.js +0 -532
- package/dist/core/merge/stack-diff.js.map +0 -7
- package/dist/core/merge/unified-merge-resolver.js +0 -303
- package/dist/core/merge/unified-merge-resolver.js.map +0 -7
- package/dist/core/models/fallback-monitor.js +0 -232
- package/dist/core/models/fallback-monitor.js.map +0 -7
- package/dist/core/models/model-router.js +0 -340
- package/dist/core/models/model-router.js.map +0 -7
- package/dist/core/monitoring/error-handler.js +0 -49
- package/dist/core/monitoring/error-handler.js.map +0 -7
- package/dist/core/monitoring/logger.js +0 -202
- package/dist/core/monitoring/logger.js.map +0 -7
- package/dist/core/monitoring/metrics.js +0 -172
- package/dist/core/monitoring/metrics.js.map +0 -7
- package/dist/core/monitoring/progress-tracker.js +0 -189
- package/dist/core/monitoring/progress-tracker.js.map +0 -7
- package/dist/core/monitoring/session-monitor.js +0 -300
- package/dist/core/monitoring/session-monitor.js.map +0 -7
- package/dist/core/performance/context-cache.js +0 -273
- package/dist/core/performance/context-cache.js.map +0 -7
- package/dist/core/performance/index.js +0 -11
- package/dist/core/performance/index.js.map +0 -7
- package/dist/core/performance/lazy-context-loader.js +0 -327
- package/dist/core/performance/lazy-context-loader.js.map +0 -7
- package/dist/core/performance/monitor.js +0 -221
- package/dist/core/performance/monitor.js.map +0 -7
- package/dist/core/performance/optimized-frame-context.js +0 -345
- package/dist/core/performance/optimized-frame-context.js.map +0 -7
- package/dist/core/performance/performance-benchmark.js +0 -277
- package/dist/core/performance/performance-benchmark.js.map +0 -7
- package/dist/core/performance/performance-profiler.js +0 -370
- package/dist/core/performance/performance-profiler.js.map +0 -7
- package/dist/core/performance/streaming-jsonl-parser.js +0 -195
- package/dist/core/performance/streaming-jsonl-parser.js.map +0 -7
- package/dist/core/persistence/postgres-adapter.js +0 -349
- package/dist/core/persistence/postgres-adapter.js.map +0 -7
- package/dist/core/projects/project-isolation.js +0 -201
- package/dist/core/projects/project-isolation.js.map +0 -7
- package/dist/core/projects/project-manager.js +0 -697
- package/dist/core/projects/project-manager.js.map +0 -7
- package/dist/core/query/query-parser.js +0 -370
- package/dist/core/query/query-parser.js.map +0 -7
- package/dist/core/query/query-templates.js +0 -321
- package/dist/core/query/query-templates.js.map +0 -7
- package/dist/core/retrieval/context-retriever.js +0 -479
- package/dist/core/retrieval/context-retriever.js.map +0 -7
- package/dist/core/retrieval/graph-retrieval.js +0 -662
- package/dist/core/retrieval/graph-retrieval.js.map +0 -7
- package/dist/core/retrieval/hierarchical-retrieval.js +0 -656
- package/dist/core/retrieval/hierarchical-retrieval.js.map +0 -7
- package/dist/core/retrieval/index.js +0 -8
- package/dist/core/retrieval/index.js.map +0 -7
- package/dist/core/retrieval/llm-context-retrieval.js +0 -613
- package/dist/core/retrieval/llm-context-retrieval.js.map +0 -7
- package/dist/core/retrieval/llm-provider.js +0 -151
- package/dist/core/retrieval/llm-provider.js.map +0 -7
- package/dist/core/retrieval/retrieval-audit.js +0 -236
- package/dist/core/retrieval/retrieval-audit.js.map +0 -7
- package/dist/core/retrieval/retrieval-benchmarks.js +0 -521
- package/dist/core/retrieval/retrieval-benchmarks.js.map +0 -7
- package/dist/core/retrieval/summary-generator.js +0 -589
- package/dist/core/retrieval/summary-generator.js.map +0 -7
- package/dist/core/retrieval/types.js +0 -21
- package/dist/core/retrieval/types.js.map +0 -7
- package/dist/core/security/index.js +0 -35
- package/dist/core/security/index.js.map +0 -7
- package/dist/core/security/input-sanitizer.js +0 -321
- package/dist/core/security/input-sanitizer.js.map +0 -7
- package/dist/core/session/clear-survival.js +0 -465
- package/dist/core/session/clear-survival.js.map +0 -7
- package/dist/core/session/enhanced-handoff.js +0 -792
- package/dist/core/session/enhanced-handoff.js.map +0 -7
- package/dist/core/session/handoff-generator.js +0 -343
- package/dist/core/session/handoff-generator.js.map +0 -7
- package/dist/core/session/index.js +0 -15
- package/dist/core/session/index.js.map +0 -7
- package/dist/core/session/session-manager.js +0 -347
- package/dist/core/session/session-manager.js.map +0 -7
- package/dist/core/skills/index.js +0 -7
- package/dist/core/skills/index.js.map +0 -7
- package/dist/core/skills/skill-storage.js +0 -764
- package/dist/core/skills/skill-storage.js.map +0 -7
- package/dist/core/skills/types.js +0 -193
- package/dist/core/skills/types.js.map +0 -7
- package/dist/core/storage/chromadb-adapter.js +0 -354
- package/dist/core/storage/chromadb-adapter.js.map +0 -7
- package/dist/core/storage/infinite-storage.js +0 -510
- package/dist/core/storage/infinite-storage.js.map +0 -7
- package/dist/core/storage/railway-optimized-storage.js +0 -591
- package/dist/core/storage/railway-optimized-storage.js.map +0 -7
- package/dist/core/storage/remote-storage.js +0 -489
- package/dist/core/storage/remote-storage.js.map +0 -7
- package/dist/core/storage/two-tier-storage.js +0 -766
- package/dist/core/storage/two-tier-storage.js.map +0 -7
- package/dist/core/trace/cli-trace-wrapper.js +0 -132
- package/dist/core/trace/cli-trace-wrapper.js.map +0 -7
- package/dist/core/trace/db-trace-wrapper.js +0 -247
- package/dist/core/trace/db-trace-wrapper.js.map +0 -7
- package/dist/core/trace/debug-trace.js +0 -417
- package/dist/core/trace/debug-trace.js.map +0 -7
- package/dist/core/trace/index.js +0 -109
- package/dist/core/trace/index.js.map +0 -7
- package/dist/core/trace/linear-api-wrapper.js +0 -178
- package/dist/core/trace/linear-api-wrapper.js.map +0 -7
- package/dist/core/trace/trace-demo.js +0 -154
- package/dist/core/trace/trace-demo.js.map +0 -7
- package/dist/core/trace/trace-detector.demo.js +0 -142
- package/dist/core/trace/trace-detector.demo.js.map +0 -7
- package/dist/core/trace/trace-detector.js +0 -528
- package/dist/core/trace/trace-detector.js.map +0 -7
- package/dist/core/trace/trace-store.js +0 -345
- package/dist/core/trace/trace-store.js.map +0 -7
- package/dist/core/trace/types.js +0 -77
- package/dist/core/trace/types.js.map +0 -7
- package/dist/core/types.js +0 -5
- package/dist/core/types.js.map +0 -7
- package/dist/core/utils/async-mutex.js +0 -114
- package/dist/core/utils/async-mutex.js.map +0 -7
- package/dist/core/utils/compression.js +0 -83
- package/dist/core/utils/compression.js.map +0 -7
- package/dist/core/utils/update-checker.js +0 -218
- package/dist/core/utils/update-checker.js.map +0 -7
- package/dist/core/worktree/worktree-manager.js +0 -465
- package/dist/core/worktree/worktree-manager.js.map +0 -7
- package/dist/daemon/daemon-config.js +0 -149
- package/dist/daemon/daemon-config.js.map +0 -7
- package/dist/daemon/services/context-service.js +0 -122
- package/dist/daemon/services/context-service.js.map +0 -7
- package/dist/daemon/services/linear-service.js +0 -136
- package/dist/daemon/services/linear-service.js.map +0 -7
- package/dist/daemon/session-daemon.js +0 -312
- package/dist/daemon/session-daemon.js.map +0 -7
- package/dist/daemon/unified-daemon.js +0 -276
- package/dist/daemon/unified-daemon.js.map +0 -7
- package/dist/features/analytics/api/analytics-api.js +0 -287
- package/dist/features/analytics/api/analytics-api.js.map +0 -7
- package/dist/features/analytics/core/analytics-service.js +0 -282
- package/dist/features/analytics/core/analytics-service.js.map +0 -7
- package/dist/features/analytics/index.js +0 -18
- package/dist/features/analytics/index.js.map +0 -7
- package/dist/features/analytics/queries/metrics-queries.js +0 -277
- package/dist/features/analytics/queries/metrics-queries.js.map +0 -7
- package/dist/features/analytics/types/metrics.js +0 -5
- package/dist/features/analytics/types/metrics.js.map +0 -7
- package/dist/features/browser/browser-mcp.js +0 -492
- package/dist/features/browser/browser-mcp.js.map +0 -7
- package/dist/features/sweep/index.js +0 -20
- package/dist/features/sweep/index.js.map +0 -7
- package/dist/features/sweep/prediction-client.js +0 -155
- package/dist/features/sweep/prediction-client.js.map +0 -7
- package/dist/features/sweep/prompt-builder.js +0 -85
- package/dist/features/sweep/prompt-builder.js.map +0 -7
- package/dist/features/sweep/pty-wrapper.js +0 -171
- package/dist/features/sweep/pty-wrapper.js.map +0 -7
- package/dist/features/sweep/state-watcher.js +0 -87
- package/dist/features/sweep/state-watcher.js.map +0 -7
- package/dist/features/sweep/status-bar.js +0 -88
- package/dist/features/sweep/status-bar.js.map +0 -7
- package/dist/features/sweep/sweep-server-manager.js +0 -226
- package/dist/features/sweep/sweep-server-manager.js.map +0 -7
- package/dist/features/sweep/tab-interceptor.js +0 -38
- package/dist/features/sweep/tab-interceptor.js.map +0 -7
- package/dist/features/sweep/types.js +0 -18
- package/dist/features/sweep/types.js.map +0 -7
- package/dist/features/tasks/linear-task-manager.js +0 -487
- package/dist/features/tasks/linear-task-manager.js.map +0 -7
- package/dist/features/tasks/task-aware-context.js +0 -410
- package/dist/features/tasks/task-aware-context.js.map +0 -7
- package/dist/features/tui/simple-monitor.js +0 -116
- package/dist/features/tui/simple-monitor.js.map +0 -7
- package/dist/features/tui/swarm-monitor.js +0 -648
- package/dist/features/tui/swarm-monitor.js.map +0 -7
- package/dist/features/web/client/stores/task-store.js +0 -26
- package/dist/features/web/client/stores/task-store.js.map +0 -7
- package/dist/features/web/server/index.js +0 -194
- package/dist/features/web/server/index.js.map +0 -7
- package/dist/hooks/auto-background.js +0 -151
- package/dist/hooks/auto-background.js.map +0 -7
- package/dist/hooks/claude-code-whatsapp-hook.js +0 -197
- package/dist/hooks/claude-code-whatsapp-hook.js.map +0 -7
- package/dist/hooks/config.js +0 -150
- package/dist/hooks/config.js.map +0 -7
- package/dist/hooks/daemon.js +0 -364
- package/dist/hooks/daemon.js.map +0 -7
- package/dist/hooks/events.js +0 -58
- package/dist/hooks/events.js.map +0 -7
- package/dist/hooks/index.js +0 -12
- package/dist/hooks/index.js.map +0 -7
- package/dist/hooks/linear-task-picker.js +0 -186
- package/dist/hooks/linear-task-picker.js.map +0 -7
- package/dist/hooks/schemas.js +0 -197
- package/dist/hooks/schemas.js.map +0 -7
- package/dist/hooks/secure-fs.js +0 -49
- package/dist/hooks/secure-fs.js.map +0 -7
- package/dist/hooks/security-logger.js +0 -155
- package/dist/hooks/security-logger.js.map +0 -7
- package/dist/hooks/session-summary.js +0 -222
- package/dist/hooks/session-summary.js.map +0 -7
- package/dist/hooks/sms-action-runner.js +0 -371
- package/dist/hooks/sms-action-runner.js.map +0 -7
- package/dist/hooks/sms-notify.js +0 -506
- package/dist/hooks/sms-notify.js.map +0 -7
- package/dist/hooks/sms-watcher.js +0 -93
- package/dist/hooks/sms-watcher.js.map +0 -7
- package/dist/hooks/sms-webhook.js +0 -555
- package/dist/hooks/sms-webhook.js.map +0 -7
- package/dist/hooks/whatsapp-commands.js +0 -479
- package/dist/hooks/whatsapp-commands.js.map +0 -7
- package/dist/hooks/whatsapp-scheduler.js +0 -317
- package/dist/hooks/whatsapp-scheduler.js.map +0 -7
- package/dist/hooks/whatsapp-sync.js +0 -409
- package/dist/hooks/whatsapp-sync.js.map +0 -7
- package/dist/index.js +0 -25
- package/dist/index.js.map +0 -7
- package/dist/integrations/anthropic/client.js +0 -263
- package/dist/integrations/anthropic/client.js.map +0 -7
- package/dist/integrations/claude-code/agent-bridge.js +0 -768
- package/dist/integrations/claude-code/agent-bridge.js.map +0 -7
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js +0 -459
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +0 -7
- package/dist/integrations/claude-code/lifecycle-hooks.js +0 -254
- package/dist/integrations/claude-code/lifecycle-hooks.js.map +0 -7
- package/dist/integrations/claude-code/post-task-hooks.js +0 -545
- package/dist/integrations/claude-code/post-task-hooks.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client-stub.js +0 -20
- package/dist/integrations/claude-code/subagent-client-stub.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client.js +0 -511
- package/dist/integrations/claude-code/subagent-client.js.map +0 -7
- package/dist/integrations/claude-code/task-coordinator.js +0 -360
- package/dist/integrations/claude-code/task-coordinator.js.map +0 -7
- package/dist/integrations/linear/auth.js +0 -337
- package/dist/integrations/linear/auth.js.map +0 -7
- package/dist/integrations/linear/auto-sync.js +0 -258
- package/dist/integrations/linear/auto-sync.js.map +0 -7
- package/dist/integrations/linear/client.js +0 -634
- package/dist/integrations/linear/client.js.map +0 -7
- package/dist/integrations/linear/config.js +0 -130
- package/dist/integrations/linear/config.js.map +0 -7
- package/dist/integrations/linear/migration.js +0 -361
- package/dist/integrations/linear/migration.js.map +0 -7
- package/dist/integrations/linear/oauth-server.js +0 -454
- package/dist/integrations/linear/oauth-server.js.map +0 -7
- package/dist/integrations/linear/rest-client.js +0 -213
- package/dist/integrations/linear/rest-client.js.map +0 -7
- package/dist/integrations/linear/sync-manager.js +0 -236
- package/dist/integrations/linear/sync-manager.js.map +0 -7
- package/dist/integrations/linear/sync-service.js +0 -231
- package/dist/integrations/linear/sync-service.js.map +0 -7
- package/dist/integrations/linear/sync.js +0 -782
- package/dist/integrations/linear/sync.js.map +0 -7
- package/dist/integrations/linear/types.js +0 -5
- package/dist/integrations/linear/types.js.map +0 -7
- package/dist/integrations/linear/unified-sync.js +0 -589
- package/dist/integrations/linear/unified-sync.js.map +0 -7
- package/dist/integrations/linear/webhook-handler.js +0 -219
- package/dist/integrations/linear/webhook-handler.js.map +0 -7
- package/dist/integrations/linear/webhook-server.js +0 -218
- package/dist/integrations/linear/webhook-server.js.map +0 -7
- package/dist/integrations/linear/webhook.js +0 -291
- package/dist/integrations/linear/webhook.js.map +0 -7
- package/dist/integrations/mcp/handlers/code-execution-handlers.js +0 -266
- package/dist/integrations/mcp/handlers/code-execution-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/context-handlers.js +0 -257
- package/dist/integrations/mcp/handlers/context-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/discovery-handlers.js +0 -497
- package/dist/integrations/mcp/handlers/discovery-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/index.js +0 -166
- package/dist/integrations/mcp/handlers/index.js.map +0 -7
- package/dist/integrations/mcp/handlers/linear-handlers.js +0 -247
- package/dist/integrations/mcp/handlers/linear-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/skill-handlers.js +0 -529
- package/dist/integrations/mcp/handlers/skill-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/task-handlers.js +0 -239
- package/dist/integrations/mcp/handlers/task-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/trace-handlers.js +0 -308
- package/dist/integrations/mcp/handlers/trace-handlers.js.map +0 -7
- package/dist/integrations/mcp/index.js +0 -23
- package/dist/integrations/mcp/index.js.map +0 -7
- package/dist/integrations/mcp/middleware/tool-scoring.js +0 -356
- package/dist/integrations/mcp/middleware/tool-scoring.js.map +0 -7
- package/dist/integrations/mcp/refactored-server.js +0 -374
- package/dist/integrations/mcp/refactored-server.js.map +0 -7
- package/dist/integrations/mcp/remote-server.js +0 -682
- package/dist/integrations/mcp/remote-server.js.map +0 -7
- package/dist/integrations/mcp/schemas.js +0 -147
- package/dist/integrations/mcp/schemas.js.map +0 -7
- package/dist/integrations/mcp/server.js +0 -1975
- package/dist/integrations/mcp/server.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions-code.js +0 -125
- package/dist/integrations/mcp/tool-definitions-code.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions.js +0 -702
- package/dist/integrations/mcp/tool-definitions.js.map +0 -7
- package/dist/integrations/mcp/trace-test.js +0 -48
- package/dist/integrations/mcp/trace-test.js.map +0 -7
- package/dist/integrations/pg-aiguide/embedding-provider.js +0 -189
- package/dist/integrations/pg-aiguide/embedding-provider.js.map +0 -7
- package/dist/integrations/pg-aiguide/semantic-search.js +0 -187
- package/dist/integrations/pg-aiguide/semantic-search.js.map +0 -7
- package/dist/integrations/pg-aiguide/timescale-analytics.js +0 -224
- package/dist/integrations/pg-aiguide/timescale-analytics.js.map +0 -7
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js +0 -860
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +0 -7
- package/dist/integrations/ralph/context/context-budget-manager.js +0 -301
- package/dist/integrations/ralph/context/context-budget-manager.js.map +0 -7
- package/dist/integrations/ralph/context/stackmemory-context-loader.js +0 -360
- package/dist/integrations/ralph/context/stackmemory-context-loader.js.map +0 -7
- package/dist/integrations/ralph/coordination/enhanced-coordination.js +0 -410
- package/dist/integrations/ralph/coordination/enhanced-coordination.js.map +0 -7
- package/dist/integrations/ralph/index.js +0 -18
- package/dist/integrations/ralph/index.js.map +0 -7
- package/dist/integrations/ralph/learning/pattern-learner.js +0 -401
- package/dist/integrations/ralph/learning/pattern-learner.js.map +0 -7
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js +0 -448
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js +0 -294
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-registry.js +0 -108
- package/dist/integrations/ralph/monitoring/swarm-registry.js.map +0 -7
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js +0 -463
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +0 -7
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js +0 -400
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js.map +0 -7
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js +0 -473
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js.map +0 -7
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js +0 -388
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js.map +0 -7
- package/dist/integrations/ralph/performance/performance-optimizer.js +0 -358
- package/dist/integrations/ralph/performance/performance-optimizer.js.map +0 -7
- package/dist/integrations/ralph/ralph-integration-demo.js +0 -182
- package/dist/integrations/ralph/ralph-integration-demo.js.map +0 -7
- package/dist/integrations/ralph/recovery/crash-recovery.js +0 -462
- package/dist/integrations/ralph/recovery/crash-recovery.js.map +0 -7
- package/dist/integrations/ralph/state/state-reconciler.js +0 -404
- package/dist/integrations/ralph/state/state-reconciler.js.map +0 -7
- package/dist/integrations/ralph/swarm/git-workflow-manager.js +0 -428
- package/dist/integrations/ralph/swarm/git-workflow-manager.js.map +0 -7
- package/dist/integrations/ralph/swarm/swarm-coordinator.js +0 -996
- package/dist/integrations/ralph/swarm/swarm-coordinator.js.map +0 -7
- package/dist/integrations/ralph/types.js +0 -5
- package/dist/integrations/ralph/types.js.map +0 -7
- package/dist/integrations/ralph/visualization/ralph-debugger.js +0 -585
- package/dist/integrations/ralph/visualization/ralph-debugger.js.map +0 -7
- package/dist/mcp/stackmemory-mcp-server.js +0 -554
- package/dist/mcp/stackmemory-mcp-server.js.map +0 -7
- package/dist/middleware/exponential-rate-limiter.js +0 -289
- package/dist/middleware/exponential-rate-limiter.js.map +0 -7
- package/dist/models/user.model.js +0 -358
- package/dist/models/user.model.js.map +0 -7
- package/dist/servers/production/auth-middleware.js +0 -528
- package/dist/servers/production/auth-middleware.js.map +0 -7
- package/dist/servers/railway/config.js +0 -55
- package/dist/servers/railway/config.js.map +0 -7
- package/dist/servers/railway/index-enhanced.js +0 -160
- package/dist/servers/railway/index-enhanced.js.map +0 -7
- package/dist/servers/railway/index.js +0 -1349
- package/dist/servers/railway/index.js.map +0 -7
- package/dist/servers/railway/simple.js +0 -64
- package/dist/servers/railway/simple.js.map +0 -7
- package/dist/servers/railway/storage-test.js +0 -459
- package/dist/servers/railway/storage-test.js.map +0 -7
- package/dist/services/config-service.js +0 -65
- package/dist/services/config-service.js.map +0 -7
- package/dist/services/context-service.js +0 -194
- package/dist/services/context-service.js.map +0 -7
- package/dist/skills/api-discovery.js +0 -354
- package/dist/skills/api-discovery.js.map +0 -7
- package/dist/skills/api-skill.js +0 -475
- package/dist/skills/api-skill.js.map +0 -7
- package/dist/skills/claude-skills.js +0 -1061
- package/dist/skills/claude-skills.js.map +0 -7
- package/dist/skills/dashboard-launcher.js +0 -216
- package/dist/skills/dashboard-launcher.js.map +0 -7
- package/dist/skills/recursive-agent-orchestrator.js +0 -575
- package/dist/skills/recursive-agent-orchestrator.js.map +0 -7
- package/dist/skills/repo-ingestion-skill.js +0 -609
- package/dist/skills/repo-ingestion-skill.js.map +0 -7
- package/dist/skills/security-secrets-scanner.js +0 -284
- package/dist/skills/security-secrets-scanner.js.map +0 -7
- package/dist/skills/unified-rlm-orchestrator.js +0 -404
- package/dist/skills/unified-rlm-orchestrator.js.map +0 -7
- package/dist/types/task.js +0 -5
- package/dist/types/task.js.map +0 -7
- package/dist/utils/env.js +0 -50
- package/dist/utils/env.js.map +0 -7
- package/dist/utils/formatting.js +0 -62
- package/dist/utils/formatting.js.map +0 -7
- package/dist/utils/process-cleanup.js +0 -136
- package/dist/utils/process-cleanup.js.map +0 -7
- package/dist/validation/schemas.js +0 -222
- package/dist/validation/schemas.js.map +0 -7
- /package/dist/{core/merge → src/core/extensions}/types.js +0 -0
- /package/dist/{core/merge → src/core/extensions}/types.js.map +0 -0
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/cli/commands/service.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Service command for StackMemory\n * Manages OS-level service installation for the guardian daemon\n *\n * The guardian service monitors ~/.stackmemory/sessions/ for active sessions\n * and starts context sync when activity is detected.\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { spawn, execSync } from 'child_process';\nimport { existsSync, readFileSync } from 'fs';\nimport { SystemError, ErrorCode } from '../../core/errors/index.js';\n\ninterface ServiceConfig {\n platform: 'darwin' | 'linux' | 'unsupported';\n serviceDir: string;\n serviceName: string;\n serviceFile: string;\n logDir: string;\n}\n\nfunction getServiceConfig(): ServiceConfig {\n const home = process.env.HOME || '';\n const platform = process.platform;\n\n if (platform === 'darwin') {\n return {\n platform: 'darwin',\n serviceDir: path.join(home, 'Library', 'LaunchAgents'),\n serviceName: 'com.stackmemory.guardian',\n serviceFile: path.join(\n home,\n 'Library',\n 'LaunchAgents',\n 'com.stackmemory.guardian.plist'\n ),\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n } else if (platform === 'linux') {\n return {\n platform: 'linux',\n serviceDir: path.join(home, '.config', 'systemd', 'user'),\n serviceName: 'stackmemory-guardian',\n serviceFile: path.join(\n home,\n '.config',\n 'systemd',\n 'user',\n 'stackmemory-guardian.service'\n ),\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n }\n\n return {\n platform: 'unsupported',\n serviceDir: '',\n serviceName: '',\n serviceFile: '',\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n}\n\nfunction _getStackMemoryBinPath(): string {\n const localBin = path.join(process.cwd(), 'dist', 'cli', 'index.js');\n if (existsSync(localBin)) {\n return localBin;\n }\n const globalBin = path.join(\n process.env.HOME || '',\n '.stackmemory',\n 'bin',\n 'stackmemory'\n );\n if (existsSync(globalBin)) {\n return globalBin;\n }\n return 'npx stackmemory';\n}\nvoid _getStackMemoryBinPath;\n\nfunction getNodePath(): string {\n try {\n const nodePath = execSync('which node', { encoding: 'utf-8' }).trim();\n return nodePath;\n } catch {\n return '/usr/local/bin/node';\n }\n}\n\nfunction generateMacOSPlist(config: ServiceConfig): string {\n const home = process.env.HOME || '';\n const nodePath = getNodePath();\n const guardianScript = path.join(home, '.stackmemory', 'guardian.js');\n\n return `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n <key>Label</key>\n <string>${config.serviceName}</string>\n\n <key>ProgramArguments</key>\n <array>\n <string>${nodePath}</string>\n <string>${guardianScript}</string>\n </array>\n\n <key>RunAtLoad</key>\n <true/>\n\n <key>KeepAlive</key>\n <dict>\n <key>SuccessfulExit</key>\n <false/>\n </dict>\n\n <key>WorkingDirectory</key>\n <string>${home}/.stackmemory</string>\n\n <key>StandardOutPath</key>\n <string>${config.logDir}/guardian.log</string>\n\n <key>StandardErrorPath</key>\n <string>${config.logDir}/guardian.error.log</string>\n\n <key>EnvironmentVariables</key>\n <dict>\n <key>HOME</key>\n <string>${home}</string>\n <key>PATH</key>\n <string>/usr/local/bin:/usr/bin:/bin</string>\n </dict>\n\n <key>ThrottleInterval</key>\n <integer>30</integer>\n</dict>\n</plist>`;\n}\n\nfunction generateLinuxSystemdService(config: ServiceConfig): string {\n const home = process.env.HOME || '';\n const nodePath = getNodePath();\n const guardianScript = path.join(home, '.stackmemory', 'guardian.js');\n\n return `[Unit]\nDescription=StackMemory Guardian Service\nDocumentation=https://github.com/stackmemoryai/stackmemory\nAfter=network.target\n\n[Service]\nType=simple\nExecStart=${nodePath} ${guardianScript}\nRestart=on-failure\nRestartSec=30\nWorkingDirectory=${home}/.stackmemory\n\nEnvironment=HOME=${home}\nEnvironment=PATH=/usr/local/bin:/usr/bin:/bin\n\nStandardOutput=append:${config.logDir}/guardian.log\nStandardError=append:${config.logDir}/guardian.error.log\n\n[Install]\nWantedBy=default.target`;\n}\n\nfunction generateGuardianScript(): string {\n return `#!/usr/bin/env node\n/**\n * StackMemory Guardian Service\n * Monitors ~/.stackmemory/sessions/ for active sessions\n * and manages context sync accordingly.\n */\n\nconst fs = require('fs');\nconst path = require('path');\nconst { spawn } = require('child_process');\n\nconst HOME = process.env.HOME || '';\nconst SESSIONS_DIR = path.join(HOME, '.stackmemory', 'sessions');\nconst STATE_FILE = path.join(HOME, '.stackmemory', 'guardian.state');\nconst IDLE_TIMEOUT_MS = 30 * 60 * 1000; // 30 minutes\n\nclass Guardian {\n constructor() {\n this.syncProcess = null;\n this.lastActivityTime = Date.now();\n this.activeSessions = new Set();\n this.checkInterval = null;\n }\n\n log(message, level = 'INFO') {\n const timestamp = new Date().toISOString();\n console.log('[' + timestamp + '] [' + level + '] ' + message);\n }\n\n async getActiveSessions() {\n const sessions = new Set();\n\n try {\n if (!fs.existsSync(SESSIONS_DIR)) {\n return sessions;\n }\n\n const files = fs.readdirSync(SESSIONS_DIR);\n\n for (const file of files) {\n if (!file.endsWith('.json')) continue;\n\n const filePath = path.join(SESSIONS_DIR, file);\n try {\n const content = fs.readFileSync(filePath, 'utf8');\n const session = JSON.parse(content);\n\n // Check if session is active (updated within last 5 minutes)\n const lastUpdate = new Date(session.lastActiveAt || session.startedAt).getTime();\n const fiveMinutesAgo = Date.now() - (5 * 60 * 1000);\n\n if (session.state === 'active' && lastUpdate > fiveMinutesAgo) {\n sessions.add(session.sessionId);\n }\n } catch (err) {\n // Skip invalid session files\n }\n }\n } catch (err) {\n this.log('Error reading sessions: ' + err.message, 'ERROR');\n }\n\n return sessions;\n }\n\n startContextSync() {\n if (this.syncProcess) {\n this.log('Context sync already running');\n return;\n }\n\n this.log('Starting context sync...');\n\n // Find stackmemory binary\n const stackmemoryPaths = [\n path.join(HOME, '.stackmemory', 'bin', 'stackmemory'),\n 'npx'\n ];\n\n let binPath = null;\n for (const p of stackmemoryPaths) {\n if (p === 'npx' || fs.existsSync(p)) {\n binPath = p;\n break;\n }\n }\n\n if (!binPath) {\n this.log('Cannot find stackmemory binary', 'ERROR');\n return;\n }\n\n const args = binPath === 'npx'\n ? ['stackmemory', 'monitor', '--daemon']\n : ['monitor', '--daemon'];\n\n this.syncProcess = spawn(binPath, args, {\n detached: true,\n stdio: ['ignore', 'pipe', 'pipe']\n });\n\n this.syncProcess.stdout.on('data', (data) => {\n this.log('sync: ' + data.toString().trim());\n });\n\n this.syncProcess.stderr.on('data', (data) => {\n this.log('sync error: ' + data.toString().trim(), 'WARN');\n });\n\n this.syncProcess.on('exit', (code) => {\n this.log('Context sync exited with code: ' + code);\n this.syncProcess = null;\n });\n\n this.log('Context sync started');\n }\n\n stopContextSync() {\n if (!this.syncProcess) {\n return;\n }\n\n this.log('Stopping context sync...');\n\n try {\n this.syncProcess.kill('SIGTERM');\n this.syncProcess = null;\n this.log('Context sync stopped');\n } catch (err) {\n this.log('Error stopping sync: ' + err.message, 'ERROR');\n }\n }\n\n saveState() {\n const state = {\n lastCheck: new Date().toISOString(),\n activeSessions: Array.from(this.activeSessions),\n syncRunning: this.syncProcess !== null,\n lastActivity: new Date(this.lastActivityTime).toISOString()\n };\n\n try {\n fs.writeFileSync(STATE_FILE, JSON.stringify(state, null, 2));\n } catch (err) {\n this.log('Error saving state: ' + err.message, 'ERROR');\n }\n }\n\n async check() {\n const currentSessions = await this.getActiveSessions();\n const hadActivity = currentSessions.size > 0;\n\n if (hadActivity) {\n this.lastActivityTime = Date.now();\n }\n\n // Detect session changes\n const newSessions = [...currentSessions].filter(s => !this.activeSessions.has(s));\n const closedSessions = [...this.activeSessions].filter(s => !currentSessions.has(s));\n\n if (newSessions.length > 0) {\n this.log('New sessions detected: ' + newSessions.join(', '));\n if (!this.syncProcess) {\n this.startContextSync();\n }\n }\n\n if (closedSessions.length > 0) {\n this.log('Sessions closed: ' + closedSessions.join(', '));\n }\n\n this.activeSessions = currentSessions;\n\n // Check idle timeout\n const idleTime = Date.now() - this.lastActivityTime;\n if (this.syncProcess && currentSessions.size === 0 && idleTime > IDLE_TIMEOUT_MS) {\n this.log('No activity for 30 minutes, stopping sync');\n this.stopContextSync();\n }\n\n this.saveState();\n }\n\n async start() {\n this.log('StackMemory Guardian starting...');\n this.log('Monitoring: ' + SESSIONS_DIR);\n\n // Ensure directories exist\n const dirs = [\n SESSIONS_DIR,\n path.join(HOME, '.stackmemory', 'logs')\n ];\n\n for (const dir of dirs) {\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n }\n\n // Initial check\n await this.check();\n\n // Start monitoring loop (every 30 seconds)\n this.checkInterval = setInterval(() => this.check(), 30 * 1000);\n\n this.log('Guardian started successfully');\n\n // Handle shutdown signals\n process.on('SIGTERM', () => this.stop());\n process.on('SIGINT', () => this.stop());\n }\n\n stop() {\n this.log('Guardian stopping...');\n\n if (this.checkInterval) {\n clearInterval(this.checkInterval);\n }\n\n this.stopContextSync();\n\n // Clean up state file\n try {\n if (fs.existsSync(STATE_FILE)) {\n fs.unlinkSync(STATE_FILE);\n }\n } catch (err) {\n // Ignore\n }\n\n this.log('Guardian stopped');\n process.exit(0);\n }\n}\n\nconst guardian = new Guardian();\nguardian.start().catch(err => {\n console.error('Guardian failed to start:', err);\n process.exit(1);\n});\n`;\n}\n\nasync function installService(\n config: ServiceConfig,\n spinner: ora.Ora\n): Promise<void> {\n const home = process.env.HOME || '';\n\n // Create directories\n await fs.mkdir(config.serviceDir, { recursive: true });\n await fs.mkdir(config.logDir, { recursive: true });\n\n // Write guardian script\n const guardianPath = path.join(home, '.stackmemory', 'guardian.js');\n await fs.writeFile(guardianPath, generateGuardianScript(), 'utf-8');\n await fs.chmod(guardianPath, 0o755);\n\n if (config.platform === 'darwin') {\n // Write launchd plist\n const plistContent = generateMacOSPlist(config);\n await fs.writeFile(config.serviceFile, plistContent, 'utf-8');\n\n spinner.text = 'Loading service...';\n\n // Load the service\n try {\n execSync(`launchctl load -w \"${config.serviceFile}\"`, { stdio: 'pipe' });\n } catch {\n // Service might already be loaded, try unload first\n try {\n execSync(`launchctl unload \"${config.serviceFile}\"`, { stdio: 'pipe' });\n execSync(`launchctl load -w \"${config.serviceFile}\"`, {\n stdio: 'pipe',\n });\n } catch {\n throw new SystemError(\n 'Failed to load launchd service',\n ErrorCode.SERVICE_UNAVAILABLE,\n { platform: 'darwin', serviceFile: config.serviceFile }\n );\n }\n }\n\n spinner.succeed(chalk.green('Guardian service installed and started'));\n console.log(chalk.gray(`Service file: ${config.serviceFile}`));\n console.log(chalk.gray(`Guardian script: ${guardianPath}`));\n console.log(chalk.gray(`Logs: ${config.logDir}/guardian.log`));\n } else if (config.platform === 'linux') {\n // Write systemd service\n const serviceContent = generateLinuxSystemdService(config);\n await fs.writeFile(config.serviceFile, serviceContent, 'utf-8');\n\n spinner.text = 'Enabling service...';\n\n // Reload systemd and enable service\n try {\n execSync('systemctl --user daemon-reload', { stdio: 'pipe' });\n execSync(`systemctl --user enable ${config.serviceName}`, {\n stdio: 'pipe',\n });\n execSync(`systemctl --user start ${config.serviceName}`, {\n stdio: 'pipe',\n });\n } catch {\n throw new SystemError(\n 'Failed to enable systemd service. Make sure systemd user session is available.',\n ErrorCode.SERVICE_UNAVAILABLE,\n { platform: 'linux', serviceName: config.serviceName }\n );\n }\n\n spinner.succeed(chalk.green('Guardian service installed and started'));\n console.log(chalk.gray(`Service file: ${config.serviceFile}`));\n console.log(chalk.gray(`Guardian script: ${guardianPath}`));\n console.log(chalk.gray(`Logs: ${config.logDir}/guardian.log`));\n }\n}\n\nasync function uninstallService(\n config: ServiceConfig,\n spinner: ora.Ora\n): Promise<void> {\n const home = process.env.HOME || '';\n const guardianPath = path.join(home, '.stackmemory', 'guardian.js');\n\n if (config.platform === 'darwin') {\n spinner.text = 'Unloading service...';\n\n try {\n execSync(`launchctl unload \"${config.serviceFile}\"`, { stdio: 'pipe' });\n } catch {\n // Service might not be loaded\n }\n\n // Remove plist file\n try {\n await fs.unlink(config.serviceFile);\n } catch {\n // File might not exist\n }\n\n // Remove guardian script\n try {\n await fs.unlink(guardianPath);\n } catch {\n // File might not exist\n }\n\n spinner.succeed(chalk.green('Guardian service uninstalled'));\n } else if (config.platform === 'linux') {\n spinner.text = 'Stopping service...';\n\n try {\n execSync(`systemctl --user stop ${config.serviceName}`, {\n stdio: 'pipe',\n });\n execSync(`systemctl --user disable ${config.serviceName}`, {\n stdio: 'pipe',\n });\n } catch {\n // Service might not be running\n }\n\n // Remove service file\n try {\n await fs.unlink(config.serviceFile);\n } catch {\n // File might not exist\n }\n\n // Remove guardian script\n try {\n await fs.unlink(guardianPath);\n } catch {\n // File might not exist\n }\n\n // Reload systemd\n try {\n execSync('systemctl --user daemon-reload', { stdio: 'pipe' });\n } catch {\n // Ignore\n }\n\n spinner.succeed(chalk.green('Guardian service uninstalled'));\n }\n}\n\nasync function showServiceStatus(config: ServiceConfig): Promise<void> {\n const home = process.env.HOME || '';\n const stateFile = path.join(home, '.stackmemory', 'guardian.state');\n\n console.log(chalk.bold('\\nStackMemory Guardian Service Status\\n'));\n\n if (config.platform === 'unsupported') {\n console.log(chalk.red('Platform not supported for service installation'));\n console.log(\n chalk.gray('Supported platforms: macOS (launchd), Linux (systemd)')\n );\n return;\n }\n\n // Check if service file exists\n if (!existsSync(config.serviceFile)) {\n console.log(chalk.yellow('Service not installed'));\n console.log(chalk.gray('Install with: stackmemory service install'));\n return;\n }\n\n let isRunning = false;\n let serviceOutput = '';\n\n if (config.platform === 'darwin') {\n try {\n serviceOutput = execSync(`launchctl list | grep ${config.serviceName}`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n isRunning = serviceOutput.includes(config.serviceName);\n } catch {\n isRunning = false;\n }\n } else if (config.platform === 'linux') {\n try {\n serviceOutput = execSync(\n `systemctl --user is-active ${config.serviceName}`,\n { encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] }\n ).trim();\n isRunning = serviceOutput === 'active';\n } catch {\n isRunning = false;\n }\n }\n\n if (isRunning) {\n console.log(chalk.green('Status: Running'));\n } else {\n console.log(chalk.yellow('Status: Stopped'));\n }\n\n console.log(chalk.gray(`Platform: ${config.platform}`));\n console.log(chalk.gray(`Service: ${config.serviceName}`));\n console.log(chalk.gray(`Config: ${config.serviceFile}`));\n\n // Try to read guardian state\n if (existsSync(stateFile)) {\n try {\n const state = JSON.parse(readFileSync(stateFile, 'utf-8'));\n console.log(chalk.bold('\\nGuardian State:'));\n console.log(` Last check: ${state.lastCheck}`);\n console.log(` Active sessions: ${state.activeSessions?.length || 0}`);\n console.log(` Sync running: ${state.syncRunning ? 'Yes' : 'No'}`);\n console.log(` Last activity: ${state.lastActivity}`);\n } catch {\n // Invalid state file\n }\n }\n}\n\nasync function showServiceLogs(\n config: ServiceConfig,\n lines: number\n): Promise<void> {\n console.log(\n chalk.bold(`\\nStackMemory Guardian Logs (last ${lines} lines)\\n`)\n );\n\n const logFile = path.join(config.logDir, 'guardian.log');\n\n if (!existsSync(logFile)) {\n console.log(chalk.yellow('No logs found'));\n console.log(chalk.gray(`Expected at: ${logFile}`));\n return;\n }\n\n try {\n const content = readFileSync(logFile, 'utf-8');\n const logLines = content.split('\\n').filter(Boolean);\n const lastLines = logLines.slice(-lines);\n\n lastLines.forEach((line) => {\n if (line.includes('[ERROR]')) {\n console.log(chalk.red(line));\n } else if (line.includes('[WARN]')) {\n console.log(chalk.yellow(line));\n } else {\n console.log(chalk.gray(line));\n }\n });\n\n console.log(chalk.gray(`\\nFull log: ${logFile}`));\n } catch (err) {\n console.log(chalk.red(`Failed to read logs: ${(err as Error).message}`));\n }\n}\n\n/**\n * Install service silently (for use by init --daemon)\n * Returns true on success, false on failure\n */\nexport async function installServiceSilent(): Promise<boolean> {\n try {\n const config = getServiceConfig();\n\n if (config.platform === 'unsupported') {\n return false;\n }\n\n const home = process.env.HOME || '';\n\n // Create directories\n await fs.mkdir(config.serviceDir, { recursive: true });\n await fs.mkdir(config.logDir, { recursive: true });\n\n // Write guardian script\n const guardianPath = path.join(home, '.stackmemory', 'guardian.js');\n await fs.writeFile(guardianPath, generateGuardianScript(), 'utf-8');\n await fs.chmod(guardianPath, 0o755);\n\n if (config.platform === 'darwin') {\n const plistContent = generateMacOSPlist(config);\n await fs.writeFile(config.serviceFile, plistContent, 'utf-8');\n\n try {\n execSync(`launchctl load -w \"${config.serviceFile}\"`, {\n stdio: 'pipe',\n });\n } catch {\n try {\n execSync(`launchctl unload \"${config.serviceFile}\"`, {\n stdio: 'pipe',\n });\n execSync(`launchctl load -w \"${config.serviceFile}\"`, {\n stdio: 'pipe',\n });\n } catch {\n return false;\n }\n }\n return true;\n } else if (config.platform === 'linux') {\n const serviceContent = generateLinuxSystemdService(config);\n await fs.writeFile(config.serviceFile, serviceContent, 'utf-8');\n\n try {\n execSync('systemctl --user daemon-reload', { stdio: 'pipe' });\n execSync(`systemctl --user enable ${config.serviceName}`, {\n stdio: 'pipe',\n });\n execSync(`systemctl --user start ${config.serviceName}`, {\n stdio: 'pipe',\n });\n } catch {\n return false;\n }\n return true;\n }\n\n return false;\n } catch {\n return false;\n }\n}\n\nexport function createServiceCommand(): Command {\n const cmd = new Command('service')\n .description('Manage StackMemory guardian OS service (auto-start on login)')\n .addHelpText(\n 'after',\n `\nExamples:\n stackmemory service install Install and start the guardian service\n stackmemory service uninstall Remove the guardian service\n stackmemory service status Show service status\n stackmemory service logs Show recent service logs\n stackmemory service logs -n 50 Show last 50 log lines\n\nThe guardian service:\n - Monitors ~/.stackmemory/sessions/ for active sessions\n - Starts context sync when an active session is detected\n - Stops gracefully after 30 minutes of inactivity\n - Runs automatically on system login (opt-in)\n`\n );\n\n cmd\n .command('install')\n .description('Install the guardian service (starts on login)')\n .action(async () => {\n const spinner = ora('Installing guardian service...').start();\n\n try {\n const config = getServiceConfig();\n\n if (config.platform === 'unsupported') {\n spinner.fail(chalk.red('Platform not supported'));\n console.log(\n chalk.gray('Supported: macOS (launchd), Linux (systemd)')\n );\n process.exit(1);\n }\n\n await installService(config, spinner);\n\n console.log(chalk.bold('\\nGuardian service will:'));\n console.log(' - Start automatically on login');\n console.log(' - Monitor for active StackMemory sessions');\n console.log(' - Manage context sync based on activity');\n console.log(' - Stop gracefully after 30 min idle');\n } catch (err) {\n spinner.fail(\n chalk.red(`Installation failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('uninstall')\n .description('Remove the guardian service')\n .action(async () => {\n const spinner = ora('Uninstalling guardian service...').start();\n\n try {\n const config = getServiceConfig();\n\n if (config.platform === 'unsupported') {\n spinner.fail(chalk.red('Platform not supported'));\n process.exit(1);\n }\n\n await uninstallService(config, spinner);\n } catch (err) {\n spinner.fail(\n chalk.red(`Uninstallation failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('status')\n .description('Show guardian service status')\n .action(async () => {\n try {\n const config = getServiceConfig();\n await showServiceStatus(config);\n } catch (err) {\n console.error(\n chalk.red(`Status check failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('logs')\n .description('Show recent guardian service logs')\n .option('-n, --lines <number>', 'Number of log lines to show', '20')\n .option('-f, --follow', 'Follow log output (tail -f style)')\n .action(async (options) => {\n try {\n const config = getServiceConfig();\n const lines = parseInt(options.lines) || 20;\n\n if (options.follow) {\n // Use tail -f for live following\n const logFile = path.join(config.logDir, 'guardian.log');\n console.log(chalk.bold(`Following ${logFile} (Ctrl+C to stop)\\n`));\n\n const tail = spawn('tail', ['-f', '-n', lines.toString(), logFile], {\n stdio: 'inherit',\n });\n\n process.on('SIGINT', () => {\n tail.kill();\n process.exit(0);\n });\n } else {\n await showServiceLogs(config, lines);\n }\n } catch (err) {\n console.error(\n chalk.red(`Failed to show logs: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n // Default action - show status\n cmd.action(async () => {\n try {\n const config = getServiceConfig();\n await showServiceStatus(config);\n } catch (err) {\n console.error(\n chalk.red(`Status check failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\nexport default createServiceCommand();\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,200 +0,0 @@
|
|
|
1
|
-
import { fileURLToPath as __fileURLToPath } from 'url';
|
|
2
|
-
import { dirname as __pathDirname } from 'path';
|
|
3
|
-
const __filename = __fileURLToPath(import.meta.url);
|
|
4
|
-
const __dirname = __pathDirname(__filename);
|
|
5
|
-
import { Command } from "commander";
|
|
6
|
-
import { sessionManager } from "../../core/session/index.js";
|
|
7
|
-
import { logger } from "../../core/monitoring/logger.js";
|
|
8
|
-
import chalk from "chalk";
|
|
9
|
-
function createSessionCommands() {
|
|
10
|
-
const sessionCommand = new Command("session").description(
|
|
11
|
-
"Manage StackMemory sessions"
|
|
12
|
-
);
|
|
13
|
-
sessionCommand.command("list").description("List all sessions").option("--project", "Show only sessions for current project").option("--active", "Show only active sessions").option("--all", "Show all sessions including closed").action(async (options) => {
|
|
14
|
-
try {
|
|
15
|
-
await sessionManager.initialize();
|
|
16
|
-
const filter = {};
|
|
17
|
-
if (options.project) {
|
|
18
|
-
const projectHash = await getProjectHash();
|
|
19
|
-
filter.projectId = projectHash;
|
|
20
|
-
}
|
|
21
|
-
if (options.active && !options.all) {
|
|
22
|
-
filter.state = "active";
|
|
23
|
-
}
|
|
24
|
-
const sessions = await sessionManager.listSessions(filter);
|
|
25
|
-
if (sessions.length === 0) {
|
|
26
|
-
console.log("No sessions found");
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
console.log(chalk.bold("\n\u{1F4CB} StackMemory Sessions:\n"));
|
|
30
|
-
sessions.forEach((session) => {
|
|
31
|
-
const age = formatAge(Date.now() - session.lastActiveAt);
|
|
32
|
-
const status = session.state === "active" ? chalk.green("\u25CF") : session.state === "suspended" ? chalk.yellow("\u25CF") : chalk.gray("\u25CF");
|
|
33
|
-
console.log(`${status} ${chalk.bold(session.sessionId.slice(0, 8))}`);
|
|
34
|
-
console.log(` Project: ${session.projectId}`);
|
|
35
|
-
if (session.branch) {
|
|
36
|
-
console.log(` Branch: ${session.branch}`);
|
|
37
|
-
}
|
|
38
|
-
console.log(` State: ${session.state}`);
|
|
39
|
-
console.log(` Last active: ${age} ago`);
|
|
40
|
-
console.log("");
|
|
41
|
-
});
|
|
42
|
-
console.log(chalk.gray(`Total: ${sessions.length} session(s)`));
|
|
43
|
-
} catch (error) {
|
|
44
|
-
logger.error("Failed to list sessions", error);
|
|
45
|
-
console.error("\u274C Failed to list sessions:", error.message);
|
|
46
|
-
process.exit(1);
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
sessionCommand.command("current").description("Show current session information").action(async () => {
|
|
50
|
-
try {
|
|
51
|
-
await sessionManager.initialize();
|
|
52
|
-
const session = sessionManager.getCurrentSession();
|
|
53
|
-
if (!session) {
|
|
54
|
-
console.log("No active session");
|
|
55
|
-
return;
|
|
56
|
-
}
|
|
57
|
-
const duration = formatDuration(Date.now() - session.startedAt);
|
|
58
|
-
console.log(chalk.bold("\n\u{1F50D} Current Session:\n"));
|
|
59
|
-
console.log(`Session ID: ${chalk.cyan(session.sessionId)}`);
|
|
60
|
-
console.log(`Run ID: ${session.runId}`);
|
|
61
|
-
console.log(`Project: ${session.projectId}`);
|
|
62
|
-
if (session.branch) {
|
|
63
|
-
console.log(`Branch: ${session.branch}`);
|
|
64
|
-
}
|
|
65
|
-
console.log(`State: ${session.state}`);
|
|
66
|
-
console.log(`Duration: ${duration}`);
|
|
67
|
-
if (session.metadata.user) {
|
|
68
|
-
console.log(`User: ${session.metadata.user}`);
|
|
69
|
-
}
|
|
70
|
-
if (session.metadata.tags && session.metadata.tags.length > 0) {
|
|
71
|
-
console.log(`Tags: ${session.metadata.tags.join(", ")}`);
|
|
72
|
-
}
|
|
73
|
-
} catch (error) {
|
|
74
|
-
logger.error("Failed to show current session", error);
|
|
75
|
-
console.error(
|
|
76
|
-
"\u274C Failed to show current session:",
|
|
77
|
-
error.message
|
|
78
|
-
);
|
|
79
|
-
process.exit(1);
|
|
80
|
-
}
|
|
81
|
-
});
|
|
82
|
-
sessionCommand.command("switch <sessionId>").description("Switch to a different session").action(async (sessionId) => {
|
|
83
|
-
try {
|
|
84
|
-
await sessionManager.initialize();
|
|
85
|
-
const current = sessionManager.getCurrentSession();
|
|
86
|
-
if (current) {
|
|
87
|
-
await sessionManager.suspendSession();
|
|
88
|
-
console.log(`Suspended session: ${current.sessionId.slice(0, 8)}`);
|
|
89
|
-
}
|
|
90
|
-
const session = await sessionManager.resumeSession(sessionId);
|
|
91
|
-
console.log(
|
|
92
|
-
chalk.green(
|
|
93
|
-
`\u2705 Switched to session: ${session.sessionId.slice(0, 8)}`
|
|
94
|
-
)
|
|
95
|
-
);
|
|
96
|
-
console.log(` Project: ${session.projectId}`);
|
|
97
|
-
if (session.branch) {
|
|
98
|
-
console.log(` Branch: ${session.branch}`);
|
|
99
|
-
}
|
|
100
|
-
} catch (error) {
|
|
101
|
-
logger.error("Failed to switch session", error);
|
|
102
|
-
console.error("\u274C Failed to switch session:", error.message);
|
|
103
|
-
process.exit(1);
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
sessionCommand.command("suspend [sessionId]").description("Suspend a session (current if not specified)").action(async (sessionId) => {
|
|
107
|
-
try {
|
|
108
|
-
await sessionManager.initialize();
|
|
109
|
-
await sessionManager.suspendSession(sessionId);
|
|
110
|
-
const id = sessionId || sessionManager.getCurrentSession()?.sessionId;
|
|
111
|
-
console.log(chalk.yellow(`\u23F8\uFE0F Suspended session: ${id?.slice(0, 8)}`));
|
|
112
|
-
} catch (error) {
|
|
113
|
-
logger.error("Failed to suspend session", error);
|
|
114
|
-
console.error(
|
|
115
|
-
"\u274C Failed to suspend session:",
|
|
116
|
-
error.message
|
|
117
|
-
);
|
|
118
|
-
process.exit(1);
|
|
119
|
-
}
|
|
120
|
-
});
|
|
121
|
-
sessionCommand.command("resume <sessionId>").description("Resume a suspended session").action(async (sessionId) => {
|
|
122
|
-
try {
|
|
123
|
-
await sessionManager.initialize();
|
|
124
|
-
const session = await sessionManager.resumeSession(sessionId);
|
|
125
|
-
console.log(
|
|
126
|
-
chalk.green(`\u25B6\uFE0F Resumed session: ${session.sessionId.slice(0, 8)}`)
|
|
127
|
-
);
|
|
128
|
-
console.log(` Project: ${session.projectId}`);
|
|
129
|
-
if (session.branch) {
|
|
130
|
-
console.log(` Branch: ${session.branch}`);
|
|
131
|
-
}
|
|
132
|
-
} catch (error) {
|
|
133
|
-
logger.error("Failed to resume session", error);
|
|
134
|
-
console.error("\u274C Failed to resume session:", error.message);
|
|
135
|
-
process.exit(1);
|
|
136
|
-
}
|
|
137
|
-
});
|
|
138
|
-
sessionCommand.command("merge <sourceId> <targetId>").description("Merge two sessions").action(async (sourceId, targetId) => {
|
|
139
|
-
try {
|
|
140
|
-
await sessionManager.initialize();
|
|
141
|
-
const merged = await sessionManager.mergeSessions(sourceId, targetId);
|
|
142
|
-
console.log(chalk.green(`\u2705 Merged sessions successfully`));
|
|
143
|
-
console.log(` Target: ${merged.sessionId.slice(0, 8)}`);
|
|
144
|
-
console.log(` Source ${sourceId.slice(0, 8)} has been closed`);
|
|
145
|
-
} catch (error) {
|
|
146
|
-
logger.error("Failed to merge sessions", error);
|
|
147
|
-
console.error("\u274C Failed to merge sessions:", error.message);
|
|
148
|
-
process.exit(1);
|
|
149
|
-
}
|
|
150
|
-
});
|
|
151
|
-
sessionCommand.command("cleanup").description("Clean up old closed sessions").option("--days <days>", "Remove sessions older than N days", "30").action(async (options) => {
|
|
152
|
-
try {
|
|
153
|
-
await sessionManager.initialize();
|
|
154
|
-
const days = parseInt(options.days);
|
|
155
|
-
const maxAge = days * 24 * 60 * 60 * 1e3;
|
|
156
|
-
const cleaned = await sessionManager.cleanupStaleSessions(maxAge);
|
|
157
|
-
console.log(chalk.green(`\u2705 Cleaned up ${cleaned} old session(s)`));
|
|
158
|
-
} catch (error) {
|
|
159
|
-
logger.error("Failed to cleanup sessions", error);
|
|
160
|
-
console.error(
|
|
161
|
-
"\u274C Failed to cleanup sessions:",
|
|
162
|
-
error.message
|
|
163
|
-
);
|
|
164
|
-
process.exit(1);
|
|
165
|
-
}
|
|
166
|
-
});
|
|
167
|
-
return sessionCommand;
|
|
168
|
-
}
|
|
169
|
-
async function getProjectHash() {
|
|
170
|
-
const crypto = await import("crypto");
|
|
171
|
-
const cwd = process.cwd();
|
|
172
|
-
const hash = crypto.createHash("sha256");
|
|
173
|
-
hash.update(cwd);
|
|
174
|
-
return hash.digest("hex").substring(0, 12);
|
|
175
|
-
}
|
|
176
|
-
function formatAge(ms) {
|
|
177
|
-
const seconds = Math.floor(ms / 1e3);
|
|
178
|
-
const minutes = Math.floor(seconds / 60);
|
|
179
|
-
const hours = Math.floor(minutes / 60);
|
|
180
|
-
const days = Math.floor(hours / 24);
|
|
181
|
-
if (days > 0) return `${days}d`;
|
|
182
|
-
if (hours > 0) return `${hours}h`;
|
|
183
|
-
if (minutes > 0) return `${minutes}m`;
|
|
184
|
-
return `${seconds}s`;
|
|
185
|
-
}
|
|
186
|
-
function formatDuration(ms) {
|
|
187
|
-
const seconds = Math.floor(ms / 1e3);
|
|
188
|
-
const minutes = Math.floor(seconds / 60);
|
|
189
|
-
const hours = Math.floor(minutes / 60);
|
|
190
|
-
const h = hours;
|
|
191
|
-
const m = minutes % 60;
|
|
192
|
-
const s = seconds % 60;
|
|
193
|
-
if (h > 0) return `${h}h ${m}m ${s}s`;
|
|
194
|
-
if (m > 0) return `${m}m ${s}s`;
|
|
195
|
-
return `${s}s`;
|
|
196
|
-
}
|
|
197
|
-
export {
|
|
198
|
-
createSessionCommands
|
|
199
|
-
};
|
|
200
|
-
//# sourceMappingURL=session.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/cli/commands/session.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Session Management CLI Commands\n * Provides commands for managing StackMemory sessions\n */\n\nimport { Command } from 'commander';\nimport { sessionManager } from '../../core/session/index.js';\nimport { logger } from '../../core/monitoring/logger.js';\nimport chalk from 'chalk';\n\nexport function createSessionCommands(): Command {\n const sessionCommand = new Command('session').description(\n 'Manage StackMemory sessions'\n );\n\n sessionCommand\n .command('list')\n .description('List all sessions')\n .option('--project', 'Show only sessions for current project')\n .option('--active', 'Show only active sessions')\n .option('--all', 'Show all sessions including closed')\n .action(async (options) => {\n try {\n await sessionManager.initialize();\n\n const filter: any = {};\n if (options.project) {\n const projectHash = await getProjectHash();\n filter.projectId = projectHash;\n }\n if (options.active && !options.all) {\n filter.state = 'active';\n }\n\n const sessions = await sessionManager.listSessions(filter);\n\n if (sessions.length === 0) {\n console.log('No sessions found');\n return;\n }\n\n console.log(chalk.bold('\\n\uD83D\uDCCB StackMemory Sessions:\\n'));\n\n sessions.forEach((session) => {\n const age = formatAge(Date.now() - session.lastActiveAt);\n const status =\n session.state === 'active'\n ? chalk.green('\u25CF')\n : session.state === 'suspended'\n ? chalk.yellow('\u25CF')\n : chalk.gray('\u25CF');\n\n console.log(`${status} ${chalk.bold(session.sessionId.slice(0, 8))}`);\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n console.log(` State: ${session.state}`);\n console.log(` Last active: ${age} ago`);\n console.log('');\n });\n\n console.log(chalk.gray(`Total: ${sessions.length} session(s)`));\n } catch (error: unknown) {\n logger.error('Failed to list sessions', error as Error);\n console.error('\u274C Failed to list sessions:', (error as Error).message);\n process.exit(1);\n }\n });\n\n sessionCommand\n .command('current')\n .description('Show current session information')\n .action(async () => {\n try {\n await sessionManager.initialize();\n const session = sessionManager.getCurrentSession();\n\n if (!session) {\n console.log('No active session');\n return;\n }\n\n const duration = formatDuration(Date.now() - session.startedAt);\n\n console.log(chalk.bold('\\n\uD83D\uDD0D Current Session:\\n'));\n console.log(`Session ID: ${chalk.cyan(session.sessionId)}`);\n console.log(`Run ID: ${session.runId}`);\n console.log(`Project: ${session.projectId}`);\n if (session.branch) {\n console.log(`Branch: ${session.branch}`);\n }\n console.log(`State: ${session.state}`);\n console.log(`Duration: ${duration}`);\n\n if (session.metadata.user) {\n console.log(`User: ${session.metadata.user}`);\n }\n if (session.metadata.tags && session.metadata.tags.length > 0) {\n console.log(`Tags: ${session.metadata.tags.join(', ')}`);\n }\n } catch (error: unknown) {\n logger.error('Failed to show current session', error as Error);\n console.error(\n '\u274C Failed to show current session:',\n (error as Error).message\n );\n process.exit(1);\n }\n });\n\n sessionCommand\n .command('switch <sessionId>')\n .description('Switch to a different session')\n .action(async (sessionId) => {\n try {\n await sessionManager.initialize();\n\n // Suspend current session\n const current = sessionManager.getCurrentSession();\n if (current) {\n await sessionManager.suspendSession();\n console.log(`Suspended session: ${current.sessionId.slice(0, 8)}`);\n }\n\n // Resume target session\n const session = await sessionManager.resumeSession(sessionId);\n console.log(\n chalk.green(\n `\u2705 Switched to session: ${session.sessionId.slice(0, 8)}`\n )\n );\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n } catch (error: unknown) {\n logger.error('Failed to switch session', error as Error);\n console.error('\u274C Failed to switch session:', (error as Error).message);\n process.exit(1);\n }\n });\n\n sessionCommand\n .command('suspend [sessionId]')\n .description('Suspend a session (current if not specified)')\n .action(async (sessionId) => {\n try {\n await sessionManager.initialize();\n await sessionManager.suspendSession(sessionId);\n\n const id = sessionId || sessionManager.getCurrentSession()?.sessionId;\n console.log(chalk.yellow(`\u23F8\uFE0F Suspended session: ${id?.slice(0, 8)}`));\n } catch (error: unknown) {\n logger.error('Failed to suspend session', error as Error);\n console.error(\n '\u274C Failed to suspend session:',\n (error as Error).message\n );\n process.exit(1);\n }\n });\n\n sessionCommand\n .command('resume <sessionId>')\n .description('Resume a suspended session')\n .action(async (sessionId) => {\n try {\n await sessionManager.initialize();\n const session = await sessionManager.resumeSession(sessionId);\n\n console.log(\n chalk.green(`\u25B6\uFE0F Resumed session: ${session.sessionId.slice(0, 8)}`)\n );\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n } catch (error: unknown) {\n logger.error('Failed to resume session', error as Error);\n console.error('\u274C Failed to resume session:', (error as Error).message);\n process.exit(1);\n }\n });\n\n sessionCommand\n .command('merge <sourceId> <targetId>')\n .description('Merge two sessions')\n .action(async (sourceId, targetId) => {\n try {\n await sessionManager.initialize();\n const merged = await sessionManager.mergeSessions(sourceId, targetId);\n\n console.log(chalk.green(`\u2705 Merged sessions successfully`));\n console.log(` Target: ${merged.sessionId.slice(0, 8)}`);\n console.log(` Source ${sourceId.slice(0, 8)} has been closed`);\n } catch (error: unknown) {\n logger.error('Failed to merge sessions', error as Error);\n console.error('\u274C Failed to merge sessions:', (error as Error).message);\n process.exit(1);\n }\n });\n\n sessionCommand\n .command('cleanup')\n .description('Clean up old closed sessions')\n .option('--days <days>', 'Remove sessions older than N days', '30')\n .action(async (options) => {\n try {\n await sessionManager.initialize();\n\n const days = parseInt(options.days);\n const maxAge = days * 24 * 60 * 60 * 1000;\n const cleaned = await sessionManager.cleanupStaleSessions(maxAge);\n\n console.log(chalk.green(`\u2705 Cleaned up ${cleaned} old session(s)`));\n } catch (error: unknown) {\n logger.error('Failed to cleanup sessions', error as Error);\n console.error(\n '\u274C Failed to cleanup sessions:',\n (error as Error).message\n );\n process.exit(1);\n }\n });\n\n return sessionCommand;\n}\n\n// Helper functions\nasync function getProjectHash(): Promise<string> {\n const crypto = await import('crypto');\n const cwd = process.cwd();\n const hash = crypto.createHash('sha256');\n hash.update(cwd);\n return hash.digest('hex').substring(0, 12);\n}\n\nfunction formatAge(ms: number): string {\n const seconds = Math.floor(ms / 1000);\n const minutes = Math.floor(seconds / 60);\n const hours = Math.floor(minutes / 60);\n const days = Math.floor(hours / 24);\n\n if (days > 0) return `${days}d`;\n if (hours > 0) return `${hours}h`;\n if (minutes > 0) return `${minutes}m`;\n return `${seconds}s`;\n}\n\nfunction formatDuration(ms: number): string {\n const seconds = Math.floor(ms / 1000);\n const minutes = Math.floor(seconds / 60);\n const hours = Math.floor(minutes / 60);\n\n const h = hours;\n const m = minutes % 60;\n const s = seconds % 60;\n\n if (h > 0) return `${h}h ${m}m ${s}s`;\n if (m > 0) return `${m}m ${s}s`;\n return `${s}s`;\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,306 +0,0 @@
|
|
|
1
|
-
import { fileURLToPath as __fileURLToPath } from 'url';
|
|
2
|
-
import { dirname as __pathDirname } from 'path';
|
|
3
|
-
const __filename = __fileURLToPath(import.meta.url);
|
|
4
|
-
const __dirname = __pathDirname(__filename);
|
|
5
|
-
import { Command } from "commander";
|
|
6
|
-
import chalk from "chalk";
|
|
7
|
-
import inquirer from "inquirer";
|
|
8
|
-
import { existsSync, writeFileSync, mkdirSync, readFileSync } from "fs";
|
|
9
|
-
import { join } from "path";
|
|
10
|
-
import { homedir } from "os";
|
|
11
|
-
import {
|
|
12
|
-
loadSMSConfig,
|
|
13
|
-
saveSMSConfig,
|
|
14
|
-
getMissingConfig
|
|
15
|
-
} from "../../hooks/sms-notify.js";
|
|
16
|
-
function createSettingsCommand() {
|
|
17
|
-
const cmd = new Command("settings").description("View and configure StackMemory settings").addHelpText(
|
|
18
|
-
"after",
|
|
19
|
-
`
|
|
20
|
-
Examples:
|
|
21
|
-
stackmemory settings Show all settings and missing config
|
|
22
|
-
stackmemory settings notifications Configure notifications interactively
|
|
23
|
-
stackmemory settings env Show required environment variables
|
|
24
|
-
`
|
|
25
|
-
);
|
|
26
|
-
cmd.command("show").description("Show current settings and what is missing").action(() => {
|
|
27
|
-
showSettings();
|
|
28
|
-
});
|
|
29
|
-
cmd.command("notifications").alias("notify").description("Configure notifications interactively").action(async () => {
|
|
30
|
-
await configureNotifications();
|
|
31
|
-
});
|
|
32
|
-
cmd.command("env").description("Show required environment variables").action(() => {
|
|
33
|
-
showEnvVars();
|
|
34
|
-
});
|
|
35
|
-
cmd.action(() => {
|
|
36
|
-
showSettings();
|
|
37
|
-
});
|
|
38
|
-
return cmd;
|
|
39
|
-
}
|
|
40
|
-
function showSettings() {
|
|
41
|
-
console.log(chalk.blue.bold("\nStackMemory Settings\n"));
|
|
42
|
-
const config = loadSMSConfig();
|
|
43
|
-
const { missing, configured, ready } = getMissingConfig();
|
|
44
|
-
console.log(chalk.cyan("Notifications:"));
|
|
45
|
-
console.log(
|
|
46
|
-
` ${chalk.gray("Enabled:")} ${config.enabled ? chalk.green("yes") : chalk.yellow("no")}`
|
|
47
|
-
);
|
|
48
|
-
console.log(
|
|
49
|
-
` ${chalk.gray("Channel:")} ${config.channel === "whatsapp" ? chalk.cyan("WhatsApp") : chalk.blue("SMS")}`
|
|
50
|
-
);
|
|
51
|
-
console.log(
|
|
52
|
-
` ${chalk.gray("Ready:")} ${ready ? chalk.green("yes") : chalk.red("no")}`
|
|
53
|
-
);
|
|
54
|
-
if (configured.length > 0) {
|
|
55
|
-
console.log(`
|
|
56
|
-
${chalk.green("Configured:")}`);
|
|
57
|
-
configured.forEach((item) => {
|
|
58
|
-
console.log(` ${chalk.green("\u2713")} ${item}`);
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
if (missing.length > 0) {
|
|
62
|
-
console.log(`
|
|
63
|
-
${chalk.red("Missing:")}`);
|
|
64
|
-
missing.forEach((item) => {
|
|
65
|
-
console.log(` ${chalk.red("\u2717")} ${item}`);
|
|
66
|
-
});
|
|
67
|
-
console.log(
|
|
68
|
-
chalk.yellow('\n Run "stackmemory settings notifications" to configure')
|
|
69
|
-
);
|
|
70
|
-
}
|
|
71
|
-
const ngrokUrlPath = join(homedir(), ".stackmemory", "ngrok-url.txt");
|
|
72
|
-
if (existsSync(ngrokUrlPath)) {
|
|
73
|
-
const ngrokUrl = readFileSync(ngrokUrlPath, "utf8").trim();
|
|
74
|
-
console.log(`
|
|
75
|
-
${chalk.gray("Webhook URL:")} ${ngrokUrl}/sms/incoming`);
|
|
76
|
-
}
|
|
77
|
-
console.log();
|
|
78
|
-
}
|
|
79
|
-
function showEnvVars() {
|
|
80
|
-
console.log(chalk.blue.bold("\nRequired Environment Variables\n"));
|
|
81
|
-
const { missing, configured } = getMissingConfig();
|
|
82
|
-
const config = loadSMSConfig();
|
|
83
|
-
console.log(chalk.cyan("Twilio Credentials (required):"));
|
|
84
|
-
console.log(
|
|
85
|
-
` ${configured.includes("TWILIO_ACCOUNT_SID") ? chalk.green("\u2713") : chalk.red("\u2717")} TWILIO_ACCOUNT_SID`
|
|
86
|
-
);
|
|
87
|
-
console.log(
|
|
88
|
-
` ${configured.includes("TWILIO_AUTH_TOKEN") ? chalk.green("\u2713") : chalk.red("\u2717")} TWILIO_AUTH_TOKEN`
|
|
89
|
-
);
|
|
90
|
-
console.log(
|
|
91
|
-
chalk.cyan(
|
|
92
|
-
`
|
|
93
|
-
${config.channel === "whatsapp" ? "WhatsApp" : "SMS"} Numbers:`
|
|
94
|
-
)
|
|
95
|
-
);
|
|
96
|
-
if (config.channel === "whatsapp") {
|
|
97
|
-
console.log(
|
|
98
|
-
` ${configured.includes("TWILIO_WHATSAPP_FROM") ? chalk.green("\u2713") : chalk.red("\u2717")} TWILIO_WHATSAPP_FROM`
|
|
99
|
-
);
|
|
100
|
-
console.log(
|
|
101
|
-
` ${configured.includes("TWILIO_WHATSAPP_TO") ? chalk.green("\u2713") : chalk.red("\u2717")} TWILIO_WHATSAPP_TO`
|
|
102
|
-
);
|
|
103
|
-
} else {
|
|
104
|
-
console.log(
|
|
105
|
-
` ${configured.includes("TWILIO_SMS_FROM") ? chalk.green("\u2713") : chalk.red("\u2717")} TWILIO_SMS_FROM`
|
|
106
|
-
);
|
|
107
|
-
console.log(
|
|
108
|
-
` ${configured.includes("TWILIO_SMS_TO") ? chalk.green("\u2713") : chalk.red("\u2717")} TWILIO_SMS_TO`
|
|
109
|
-
);
|
|
110
|
-
}
|
|
111
|
-
if (missing.length > 0) {
|
|
112
|
-
console.log(chalk.yellow("\nAdd to your .env file or shell profile:"));
|
|
113
|
-
console.log(chalk.gray("\u2500".repeat(50)));
|
|
114
|
-
if (missing.includes("TWILIO_ACCOUNT_SID")) {
|
|
115
|
-
console.log('export TWILIO_ACCOUNT_SID="your_account_sid"');
|
|
116
|
-
}
|
|
117
|
-
if (missing.includes("TWILIO_AUTH_TOKEN")) {
|
|
118
|
-
console.log('export TWILIO_AUTH_TOKEN="your_auth_token"');
|
|
119
|
-
}
|
|
120
|
-
if (missing.includes("TWILIO_WHATSAPP_FROM")) {
|
|
121
|
-
console.log(
|
|
122
|
-
'export TWILIO_WHATSAPP_FROM="+14155238886" # Twilio sandbox'
|
|
123
|
-
);
|
|
124
|
-
}
|
|
125
|
-
if (missing.includes("TWILIO_WHATSAPP_TO")) {
|
|
126
|
-
console.log('export TWILIO_WHATSAPP_TO="+1234567890" # Your phone');
|
|
127
|
-
}
|
|
128
|
-
if (missing.includes("TWILIO_SMS_FROM")) {
|
|
129
|
-
console.log('export TWILIO_SMS_FROM="+1234567890" # Twilio number');
|
|
130
|
-
}
|
|
131
|
-
if (missing.includes("TWILIO_SMS_TO")) {
|
|
132
|
-
console.log('export TWILIO_SMS_TO="+1234567890" # Your phone');
|
|
133
|
-
}
|
|
134
|
-
console.log(chalk.gray("\u2500".repeat(50)));
|
|
135
|
-
}
|
|
136
|
-
console.log();
|
|
137
|
-
}
|
|
138
|
-
async function configureNotifications() {
|
|
139
|
-
console.log(chalk.blue.bold("\nNotification Setup\n"));
|
|
140
|
-
const config = loadSMSConfig();
|
|
141
|
-
const { missing } = getMissingConfig();
|
|
142
|
-
const { enable } = await inquirer.prompt([
|
|
143
|
-
{
|
|
144
|
-
type: "confirm",
|
|
145
|
-
name: "enable",
|
|
146
|
-
message: "Enable SMS/WhatsApp notifications?",
|
|
147
|
-
default: config.enabled
|
|
148
|
-
}
|
|
149
|
-
]);
|
|
150
|
-
if (!enable) {
|
|
151
|
-
config.enabled = false;
|
|
152
|
-
saveSMSConfig(config);
|
|
153
|
-
console.log(chalk.yellow("Notifications disabled"));
|
|
154
|
-
return;
|
|
155
|
-
}
|
|
156
|
-
const { channel } = await inquirer.prompt([
|
|
157
|
-
{
|
|
158
|
-
type: "list",
|
|
159
|
-
name: "channel",
|
|
160
|
-
message: "Which channel do you want to use?",
|
|
161
|
-
choices: [
|
|
162
|
-
{
|
|
163
|
-
name: "WhatsApp (recommended - cheaper for conversations)",
|
|
164
|
-
value: "whatsapp"
|
|
165
|
-
},
|
|
166
|
-
{ name: "SMS (requires A2P 10DLC registration for US)", value: "sms" }
|
|
167
|
-
],
|
|
168
|
-
default: config.channel
|
|
169
|
-
}
|
|
170
|
-
]);
|
|
171
|
-
config.channel = channel;
|
|
172
|
-
if (missing.includes("TWILIO_ACCOUNT_SID") || missing.includes("TWILIO_AUTH_TOKEN")) {
|
|
173
|
-
console.log(chalk.yellow("\nTwilio credentials not found in environment."));
|
|
174
|
-
const { hasAccount } = await inquirer.prompt([
|
|
175
|
-
{
|
|
176
|
-
type: "confirm",
|
|
177
|
-
name: "hasAccount",
|
|
178
|
-
message: "Do you have a Twilio account?",
|
|
179
|
-
default: true
|
|
180
|
-
}
|
|
181
|
-
]);
|
|
182
|
-
if (!hasAccount) {
|
|
183
|
-
console.log(chalk.cyan("\nCreate a free Twilio account:"));
|
|
184
|
-
console.log(" https://www.twilio.com/try-twilio\n");
|
|
185
|
-
console.log("Then run this command again.");
|
|
186
|
-
return;
|
|
187
|
-
}
|
|
188
|
-
const { saveToEnv } = await inquirer.prompt([
|
|
189
|
-
{
|
|
190
|
-
type: "confirm",
|
|
191
|
-
name: "saveToEnv",
|
|
192
|
-
message: "Would you like to save credentials to ~/.stackmemory/.env?",
|
|
193
|
-
default: true
|
|
194
|
-
}
|
|
195
|
-
]);
|
|
196
|
-
if (saveToEnv) {
|
|
197
|
-
const { accountSid, authToken } = await inquirer.prompt([
|
|
198
|
-
{
|
|
199
|
-
type: "input",
|
|
200
|
-
name: "accountSid",
|
|
201
|
-
message: "Twilio Account SID:",
|
|
202
|
-
validate: (input) => input.startsWith("AC") ? true : "Account SID should start with AC"
|
|
203
|
-
},
|
|
204
|
-
{
|
|
205
|
-
type: "password",
|
|
206
|
-
name: "authToken",
|
|
207
|
-
message: "Twilio Auth Token:",
|
|
208
|
-
mask: "*"
|
|
209
|
-
}
|
|
210
|
-
]);
|
|
211
|
-
saveToEnvFile({
|
|
212
|
-
TWILIO_ACCOUNT_SID: accountSid,
|
|
213
|
-
TWILIO_AUTH_TOKEN: authToken
|
|
214
|
-
});
|
|
215
|
-
console.log(chalk.green("Credentials saved to ~/.stackmemory/.env"));
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
if (channel === "whatsapp") {
|
|
219
|
-
console.log(chalk.cyan("\nWhatsApp Setup:"));
|
|
220
|
-
console.log(
|
|
221
|
-
" 1. Go to: https://console.twilio.com/us1/develop/sms/try-it-out/whatsapp-learn"
|
|
222
|
-
);
|
|
223
|
-
console.log(" 2. Note the sandbox number (e.g., +14155238886)");
|
|
224
|
-
console.log(" 3. Send the join code from your phone\n");
|
|
225
|
-
const { whatsappFrom, whatsappTo } = await inquirer.prompt([
|
|
226
|
-
{
|
|
227
|
-
type: "input",
|
|
228
|
-
name: "whatsappFrom",
|
|
229
|
-
message: "Twilio WhatsApp number (sandbox):",
|
|
230
|
-
default: config.whatsappFromNumber || "+14155238886"
|
|
231
|
-
},
|
|
232
|
-
{
|
|
233
|
-
type: "input",
|
|
234
|
-
name: "whatsappTo",
|
|
235
|
-
message: "Your phone number:",
|
|
236
|
-
default: config.whatsappToNumber,
|
|
237
|
-
validate: (input) => input.startsWith("+") ? true : "Include country code (e.g., +1234567890)"
|
|
238
|
-
}
|
|
239
|
-
]);
|
|
240
|
-
saveToEnvFile({
|
|
241
|
-
TWILIO_WHATSAPP_FROM: whatsappFrom,
|
|
242
|
-
TWILIO_WHATSAPP_TO: whatsappTo,
|
|
243
|
-
TWILIO_CHANNEL: "whatsapp"
|
|
244
|
-
});
|
|
245
|
-
} else {
|
|
246
|
-
console.log(chalk.cyan("\nSMS Setup:"));
|
|
247
|
-
console.log(
|
|
248
|
-
chalk.yellow(" Note: US carriers require A2P 10DLC registration")
|
|
249
|
-
);
|
|
250
|
-
console.log(
|
|
251
|
-
" Register at: https://console.twilio.com/us1/develop/sms/settings/compliance\n"
|
|
252
|
-
);
|
|
253
|
-
const { smsFrom, smsTo } = await inquirer.prompt([
|
|
254
|
-
{
|
|
255
|
-
type: "input",
|
|
256
|
-
name: "smsFrom",
|
|
257
|
-
message: "Twilio SMS number:",
|
|
258
|
-
default: config.smsFromNumber
|
|
259
|
-
},
|
|
260
|
-
{
|
|
261
|
-
type: "input",
|
|
262
|
-
name: "smsTo",
|
|
263
|
-
message: "Your phone number:",
|
|
264
|
-
default: config.smsToNumber,
|
|
265
|
-
validate: (input) => input.startsWith("+") ? true : "Include country code (e.g., +1234567890)"
|
|
266
|
-
}
|
|
267
|
-
]);
|
|
268
|
-
saveToEnvFile({
|
|
269
|
-
TWILIO_SMS_FROM: smsFrom,
|
|
270
|
-
TWILIO_SMS_TO: smsTo,
|
|
271
|
-
TWILIO_CHANNEL: "sms"
|
|
272
|
-
});
|
|
273
|
-
}
|
|
274
|
-
config.enabled = true;
|
|
275
|
-
saveSMSConfig(config);
|
|
276
|
-
console.log(chalk.green("\nNotifications configured!"));
|
|
277
|
-
console.log(chalk.gray("Test with: stackmemory notify test"));
|
|
278
|
-
}
|
|
279
|
-
function saveToEnvFile(vars) {
|
|
280
|
-
const envDir = join(homedir(), ".stackmemory");
|
|
281
|
-
const envPath = join(envDir, ".env");
|
|
282
|
-
if (!existsSync(envDir)) {
|
|
283
|
-
mkdirSync(envDir, { recursive: true });
|
|
284
|
-
}
|
|
285
|
-
let content = "";
|
|
286
|
-
if (existsSync(envPath)) {
|
|
287
|
-
content = readFileSync(envPath, "utf8");
|
|
288
|
-
}
|
|
289
|
-
for (const [key, value] of Object.entries(vars)) {
|
|
290
|
-
const regex = new RegExp(`^${key}=.*$`, "m");
|
|
291
|
-
const line = `${key}="${value}"`;
|
|
292
|
-
if (regex.test(content)) {
|
|
293
|
-
content = content.replace(regex, line);
|
|
294
|
-
} else {
|
|
295
|
-
content += `${content.endsWith("\n") || content === "" ? "" : "\n"}${line}
|
|
296
|
-
`;
|
|
297
|
-
}
|
|
298
|
-
}
|
|
299
|
-
writeFileSync(envPath, content);
|
|
300
|
-
}
|
|
301
|
-
var settings_default = createSettingsCommand;
|
|
302
|
-
export {
|
|
303
|
-
createSettingsCommand,
|
|
304
|
-
settings_default as default
|
|
305
|
-
};
|
|
306
|
-
//# sourceMappingURL=settings.js.map
|