@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,313 +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 ora from "ora";
|
|
8
|
-
import { SessionMonitor } from "../../core/monitoring/session-monitor.js";
|
|
9
|
-
import { FrameManager } from "../../core/context/index.js";
|
|
10
|
-
import Database from "better-sqlite3";
|
|
11
|
-
import * as fs from "fs/promises";
|
|
12
|
-
import * as path from "path";
|
|
13
|
-
import { spawn } from "child_process";
|
|
14
|
-
function createMonitorCommand() {
|
|
15
|
-
const cmd = new Command("monitor").description("Run background monitoring for automatic triggers").option("--start", "Start monitoring daemon").option("--stop", "Stop monitoring daemon").option("--status", "Check monitor status").option("--config", "Show monitor configuration").option("--activity", "Update activity timestamp").option("--daemon", "Run as daemon (background process)").option("--foreground", "Run in foreground (for testing)").option("--interval <seconds>", "Check interval in seconds", "30").option("--idle <minutes>", "Idle timeout in minutes", "5").action(async (options) => {
|
|
16
|
-
const spinner = ora();
|
|
17
|
-
try {
|
|
18
|
-
const projectRoot = await getProjectRoot();
|
|
19
|
-
const dbPath = path.join(
|
|
20
|
-
projectRoot,
|
|
21
|
-
".stackmemory",
|
|
22
|
-
"db",
|
|
23
|
-
"stackmemory.db"
|
|
24
|
-
);
|
|
25
|
-
try {
|
|
26
|
-
await fs.access(dbPath);
|
|
27
|
-
} catch {
|
|
28
|
-
console.error(chalk.red("\u2717 StackMemory not initialized"));
|
|
29
|
-
console.log(chalk.yellow("Run: stackmemory init"));
|
|
30
|
-
process.exit(1);
|
|
31
|
-
}
|
|
32
|
-
if (options.start) {
|
|
33
|
-
await startMonitor(projectRoot, options, spinner);
|
|
34
|
-
} else if (options.stop) {
|
|
35
|
-
await stopMonitor(projectRoot, spinner);
|
|
36
|
-
} else if (options.status) {
|
|
37
|
-
await showStatus(projectRoot);
|
|
38
|
-
} else if (options.config) {
|
|
39
|
-
await showConfig(projectRoot);
|
|
40
|
-
} else if (options.activity) {
|
|
41
|
-
await updateActivity(projectRoot);
|
|
42
|
-
} else if (options.daemon) {
|
|
43
|
-
await runDaemon(projectRoot, options);
|
|
44
|
-
} else if (options.foreground) {
|
|
45
|
-
await runForeground(projectRoot, options);
|
|
46
|
-
} else {
|
|
47
|
-
await showStatus(projectRoot);
|
|
48
|
-
}
|
|
49
|
-
} catch (error) {
|
|
50
|
-
spinner.fail(chalk.red(`Error: ${error}`));
|
|
51
|
-
process.exit(1);
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
return cmd;
|
|
55
|
-
}
|
|
56
|
-
async function startMonitor(projectRoot, options, spinner) {
|
|
57
|
-
spinner.start("Starting monitor daemon...");
|
|
58
|
-
const pidFile = path.join(projectRoot, ".stackmemory", "monitor.pid");
|
|
59
|
-
try {
|
|
60
|
-
const pid = await fs.readFile(pidFile, "utf-8");
|
|
61
|
-
try {
|
|
62
|
-
process.kill(parseInt(pid), 0);
|
|
63
|
-
spinner.fail(chalk.yellow("Monitor already running"));
|
|
64
|
-
console.log(chalk.gray(`PID: ${pid}`));
|
|
65
|
-
return;
|
|
66
|
-
} catch {
|
|
67
|
-
await fs.unlink(pidFile).catch(() => {
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
} catch {
|
|
71
|
-
}
|
|
72
|
-
const daemon = spawn(
|
|
73
|
-
process.execPath,
|
|
74
|
-
[
|
|
75
|
-
process.argv[1],
|
|
76
|
-
"monitor",
|
|
77
|
-
"--daemon",
|
|
78
|
-
"--interval",
|
|
79
|
-
options.interval || "30",
|
|
80
|
-
"--idle",
|
|
81
|
-
options.idle || "5"
|
|
82
|
-
],
|
|
83
|
-
{
|
|
84
|
-
cwd: projectRoot,
|
|
85
|
-
detached: true,
|
|
86
|
-
stdio: ["ignore", "ignore", "ignore"]
|
|
87
|
-
}
|
|
88
|
-
);
|
|
89
|
-
await fs.writeFile(pidFile, daemon.pid.toString(), "utf-8");
|
|
90
|
-
daemon.unref();
|
|
91
|
-
spinner.succeed(chalk.green("\u2705 Monitor daemon started"));
|
|
92
|
-
console.log(chalk.gray(`PID: ${daemon.pid}`));
|
|
93
|
-
console.log(chalk.gray(`Check interval: ${options.interval || 30}s`));
|
|
94
|
-
console.log(chalk.gray(`Idle timeout: ${options.idle || 5}min`));
|
|
95
|
-
console.log(chalk.bold("\n\u{1F50D} Monitoring:"));
|
|
96
|
-
console.log(" \u2022 Context usage (warns at 60%, saves at 85%)");
|
|
97
|
-
console.log(" \u2022 Idle detection (handoff after 5min)");
|
|
98
|
-
console.log(" \u2022 Session end (auto-save on exit)");
|
|
99
|
-
console.log(chalk.gray("\nStop with: stackmemory monitor --stop"));
|
|
100
|
-
}
|
|
101
|
-
async function stopMonitor(projectRoot, spinner) {
|
|
102
|
-
spinner.start("Stopping monitor daemon...");
|
|
103
|
-
const pidFile = path.join(projectRoot, ".stackmemory", "monitor.pid");
|
|
104
|
-
try {
|
|
105
|
-
const pid = parseInt(await fs.readFile(pidFile, "utf-8"));
|
|
106
|
-
process.kill(pid, "SIGTERM");
|
|
107
|
-
await fs.unlink(pidFile);
|
|
108
|
-
spinner.succeed(chalk.green("\u2705 Monitor daemon stopped"));
|
|
109
|
-
} catch (error) {
|
|
110
|
-
spinner.fail(chalk.yellow("Monitor not running"));
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
async function showStatus(projectRoot) {
|
|
114
|
-
const pidFile = path.join(projectRoot, ".stackmemory", "monitor.pid");
|
|
115
|
-
const statusFile = path.join(projectRoot, ".stackmemory", "monitor.status");
|
|
116
|
-
console.log(chalk.bold("\n\u{1F4CA} Monitor Status\n"));
|
|
117
|
-
let isRunning = false;
|
|
118
|
-
let pid;
|
|
119
|
-
try {
|
|
120
|
-
pid = parseInt(await fs.readFile(pidFile, "utf-8"));
|
|
121
|
-
process.kill(pid, 0);
|
|
122
|
-
isRunning = true;
|
|
123
|
-
} catch {
|
|
124
|
-
}
|
|
125
|
-
if (isRunning && pid) {
|
|
126
|
-
console.log(chalk.green("\u2705 Monitor is running"));
|
|
127
|
-
console.log(chalk.gray(`PID: ${pid}`));
|
|
128
|
-
try {
|
|
129
|
-
const status = JSON.parse(await fs.readFile(statusFile, "utf-8"));
|
|
130
|
-
console.log(chalk.bold("\nLast Check:"));
|
|
131
|
-
console.log(` Time: ${new Date(status.lastCheck).toLocaleString()}`);
|
|
132
|
-
console.log(` Context: ${Math.round(status.contextPercentage * 100)}%`);
|
|
133
|
-
console.log(
|
|
134
|
-
` Status: ${getStatusEmoji(status.contextStatus)} ${status.contextStatus}`
|
|
135
|
-
);
|
|
136
|
-
if (status.lastActivity) {
|
|
137
|
-
const idleMinutes = Math.round(
|
|
138
|
-
(Date.now() - new Date(status.lastActivity).getTime()) / 6e4
|
|
139
|
-
);
|
|
140
|
-
console.log(` Idle: ${idleMinutes} minutes`);
|
|
141
|
-
}
|
|
142
|
-
if (status.lastLedgerSave) {
|
|
143
|
-
console.log(chalk.bold("\nLast Ledger Save:"));
|
|
144
|
-
console.log(` ${new Date(status.lastLedgerSave).toLocaleString()}`);
|
|
145
|
-
}
|
|
146
|
-
if (status.lastHandoff) {
|
|
147
|
-
console.log(chalk.bold("\nLast Handoff:"));
|
|
148
|
-
console.log(` ${new Date(status.lastHandoff).toLocaleString()}`);
|
|
149
|
-
}
|
|
150
|
-
} catch {
|
|
151
|
-
}
|
|
152
|
-
} else {
|
|
153
|
-
console.log(chalk.yellow("\u26A0\uFE0F Monitor is not running"));
|
|
154
|
-
console.log(chalk.gray("Start with: stackmemory monitor --start"));
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
async function showConfig(projectRoot) {
|
|
158
|
-
const configFile = path.join(projectRoot, ".stackmemory", "config.json");
|
|
159
|
-
console.log(chalk.bold("\n\u2699\uFE0F Monitor Configuration\n"));
|
|
160
|
-
try {
|
|
161
|
-
const config = JSON.parse(await fs.readFile(configFile, "utf-8"));
|
|
162
|
-
const monitorConfig = config.monitor || {};
|
|
163
|
-
console.log("Context Thresholds:");
|
|
164
|
-
console.log(
|
|
165
|
-
` Warning: ${(monitorConfig.contextWarningThreshold || 0.6) * 100}%`
|
|
166
|
-
);
|
|
167
|
-
console.log(
|
|
168
|
-
` Critical: ${(monitorConfig.contextCriticalThreshold || 0.7) * 100}%`
|
|
169
|
-
);
|
|
170
|
-
console.log(
|
|
171
|
-
` Auto-save: ${(monitorConfig.contextAutoSaveThreshold || 0.85) * 100}%`
|
|
172
|
-
);
|
|
173
|
-
console.log("\nTimings:");
|
|
174
|
-
console.log(
|
|
175
|
-
` Check interval: ${monitorConfig.checkIntervalSeconds || 30}s`
|
|
176
|
-
);
|
|
177
|
-
console.log(` Idle timeout: ${monitorConfig.idleTimeoutMinutes || 5}min`);
|
|
178
|
-
console.log("\nAuto Actions:");
|
|
179
|
-
console.log(
|
|
180
|
-
` Auto-save ledger: ${monitorConfig.autoSaveLedger !== false ? "\u2705" : "\u274C"}`
|
|
181
|
-
);
|
|
182
|
-
console.log(
|
|
183
|
-
` Auto-generate handoff: ${monitorConfig.autoGenerateHandoff !== false ? "\u2705" : "\u274C"}`
|
|
184
|
-
);
|
|
185
|
-
console.log(
|
|
186
|
-
` Session-end handoff: ${monitorConfig.sessionEndHandoff !== false ? "\u2705" : "\u274C"}`
|
|
187
|
-
);
|
|
188
|
-
} catch {
|
|
189
|
-
console.log(chalk.gray("Using default configuration"));
|
|
190
|
-
console.log("\nDefaults:");
|
|
191
|
-
console.log(" Warning at 60%, Critical at 70%, Auto-save at 85%");
|
|
192
|
-
console.log(" Check every 30s, Idle timeout 5min");
|
|
193
|
-
console.log(" All auto-actions enabled");
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
async function updateActivity(projectRoot) {
|
|
197
|
-
const activityFile = path.join(
|
|
198
|
-
projectRoot,
|
|
199
|
-
".stackmemory",
|
|
200
|
-
"monitor.activity"
|
|
201
|
-
);
|
|
202
|
-
await fs.mkdir(path.dirname(activityFile), { recursive: true });
|
|
203
|
-
await fs.writeFile(activityFile, (/* @__PURE__ */ new Date()).toISOString(), "utf-8");
|
|
204
|
-
}
|
|
205
|
-
async function runDaemon(projectRoot, options) {
|
|
206
|
-
const dbPath = path.join(projectRoot, ".stackmemory", "db", "stackmemory.db");
|
|
207
|
-
const db = new Database(dbPath);
|
|
208
|
-
const frameManager = new FrameManager(db, "current");
|
|
209
|
-
const monitor = new SessionMonitor(frameManager, db, projectRoot, {
|
|
210
|
-
checkIntervalSeconds: parseInt(options.interval) || 30,
|
|
211
|
-
idleTimeoutMinutes: parseInt(options.idle) || 5,
|
|
212
|
-
autoSaveLedger: true,
|
|
213
|
-
autoGenerateHandoff: true,
|
|
214
|
-
sessionEndHandoff: true
|
|
215
|
-
});
|
|
216
|
-
const statusFile = path.join(projectRoot, ".stackmemory", "monitor.status");
|
|
217
|
-
const activityFile = path.join(
|
|
218
|
-
projectRoot,
|
|
219
|
-
".stackmemory",
|
|
220
|
-
"monitor.activity"
|
|
221
|
-
);
|
|
222
|
-
monitor.on("context:usage", async (data) => {
|
|
223
|
-
try {
|
|
224
|
-
const activityTime = await fs.readFile(activityFile, "utf-8");
|
|
225
|
-
monitor.updateActivity();
|
|
226
|
-
} catch {
|
|
227
|
-
}
|
|
228
|
-
const status = {
|
|
229
|
-
lastCheck: (/* @__PURE__ */ new Date()).toISOString(),
|
|
230
|
-
contextPercentage: data.percentage,
|
|
231
|
-
contextStatus: data.status,
|
|
232
|
-
lastActivity: monitor.getStatus().lastActivity
|
|
233
|
-
};
|
|
234
|
-
await fs.writeFile(statusFile, JSON.stringify(status, null, 2), "utf-8");
|
|
235
|
-
});
|
|
236
|
-
monitor.on("context:ledger_saved", async () => {
|
|
237
|
-
const status = JSON.parse(await fs.readFile(statusFile, "utf-8"));
|
|
238
|
-
status.lastLedgerSave = (/* @__PURE__ */ new Date()).toISOString();
|
|
239
|
-
await fs.writeFile(statusFile, JSON.stringify(status, null, 2), "utf-8");
|
|
240
|
-
});
|
|
241
|
-
monitor.on("handoff:generated", async () => {
|
|
242
|
-
const status = JSON.parse(await fs.readFile(statusFile, "utf-8"));
|
|
243
|
-
status.lastHandoff = (/* @__PURE__ */ new Date()).toISOString();
|
|
244
|
-
await fs.writeFile(statusFile, JSON.stringify(status, null, 2), "utf-8");
|
|
245
|
-
});
|
|
246
|
-
await monitor.start();
|
|
247
|
-
process.on("SIGTERM", async () => {
|
|
248
|
-
await monitor.stop();
|
|
249
|
-
process.exit(0);
|
|
250
|
-
});
|
|
251
|
-
}
|
|
252
|
-
async function runForeground(projectRoot, options) {
|
|
253
|
-
console.log(chalk.bold("\u{1F50D} Running monitor in foreground...\n"));
|
|
254
|
-
const dbPath = path.join(projectRoot, ".stackmemory", "db", "stackmemory.db");
|
|
255
|
-
const db = new Database(dbPath);
|
|
256
|
-
const frameManager = new FrameManager(db, "current");
|
|
257
|
-
const monitor = new SessionMonitor(frameManager, db, projectRoot, {
|
|
258
|
-
checkIntervalSeconds: parseInt(options.interval) || 30,
|
|
259
|
-
idleTimeoutMinutes: parseInt(options.idle) || 5,
|
|
260
|
-
autoSaveLedger: true,
|
|
261
|
-
autoGenerateHandoff: true,
|
|
262
|
-
sessionEndHandoff: true
|
|
263
|
-
});
|
|
264
|
-
monitor.on("context:usage", (data) => {
|
|
265
|
-
console.log(
|
|
266
|
-
`[${(/* @__PURE__ */ new Date()).toLocaleTimeString()}] Context: ${Math.round(data.percentage * 100)}% (${data.status})`
|
|
267
|
-
);
|
|
268
|
-
});
|
|
269
|
-
monitor.on("context:warning", () => {
|
|
270
|
-
console.log(chalk.yellow("\u26A0\uFE0F Context warning threshold reached"));
|
|
271
|
-
});
|
|
272
|
-
monitor.on("context:high", () => {
|
|
273
|
-
console.log(chalk.yellow("\u{1F7E1} Context high - considering auto-save"));
|
|
274
|
-
});
|
|
275
|
-
monitor.on("context:ledger_saved", (data) => {
|
|
276
|
-
console.log(
|
|
277
|
-
chalk.green(`\u2705 Ledger saved (${data.compression}x compression)`)
|
|
278
|
-
);
|
|
279
|
-
});
|
|
280
|
-
monitor.on("handoff:generated", (data) => {
|
|
281
|
-
console.log(chalk.green(`\u{1F4CB} Handoff generated (${data.trigger})`));
|
|
282
|
-
});
|
|
283
|
-
await monitor.start();
|
|
284
|
-
console.log("Press Ctrl+C to stop\n");
|
|
285
|
-
process.on("SIGINT", async () => {
|
|
286
|
-
console.log("\nStopping monitor...");
|
|
287
|
-
await monitor.stop();
|
|
288
|
-
process.exit(0);
|
|
289
|
-
});
|
|
290
|
-
}
|
|
291
|
-
async function getProjectRoot() {
|
|
292
|
-
return process.cwd();
|
|
293
|
-
}
|
|
294
|
-
function getStatusEmoji(status) {
|
|
295
|
-
switch (status) {
|
|
296
|
-
case "ok":
|
|
297
|
-
return "\u{1F7E2}";
|
|
298
|
-
case "warning":
|
|
299
|
-
return "\u{1F7E1}";
|
|
300
|
-
case "high":
|
|
301
|
-
return "\u{1F7E0}";
|
|
302
|
-
case "critical":
|
|
303
|
-
return "\u{1F534}";
|
|
304
|
-
default:
|
|
305
|
-
return "\u26AB";
|
|
306
|
-
}
|
|
307
|
-
}
|
|
308
|
-
var monitor_default = createMonitorCommand();
|
|
309
|
-
export {
|
|
310
|
-
createMonitorCommand,
|
|
311
|
-
monitor_default as default
|
|
312
|
-
};
|
|
313
|
-
//# sourceMappingURL=monitor.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/cli/commands/monitor.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Monitor command for StackMemory\n * Real-time monitoring of context and frame activity\n */\n\n/**\n * Monitor command for StackMemory\n * Runs background monitoring daemon for automatic triggers\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { SessionMonitor } from '../../core/monitoring/session-monitor.js';\nimport { FrameManager } from '../../core/context/index.js';\nimport Database from 'better-sqlite3';\n// getProjectRoot function will be defined below\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { spawn } from 'child_process';\n\nexport function createMonitorCommand(): Command {\n const cmd = new Command('monitor')\n .description('Run background monitoring for automatic triggers')\n .option('--start', 'Start monitoring daemon')\n .option('--stop', 'Stop monitoring daemon')\n .option('--status', 'Check monitor status')\n .option('--config', 'Show monitor configuration')\n .option('--activity', 'Update activity timestamp')\n .option('--daemon', 'Run as daemon (background process)')\n .option('--foreground', 'Run in foreground (for testing)')\n .option('--interval <seconds>', 'Check interval in seconds', '30')\n .option('--idle <minutes>', 'Idle timeout in minutes', '5')\n .action(async (options) => {\n const spinner = ora();\n\n try {\n const projectRoot = await getProjectRoot();\n const dbPath = path.join(\n projectRoot,\n '.stackmemory',\n 'db',\n 'stackmemory.db'\n );\n\n // Check if StackMemory is initialized\n try {\n await fs.access(dbPath);\n } catch {\n console.error(chalk.red('\u2717 StackMemory not initialized'));\n console.log(chalk.yellow('Run: stackmemory init'));\n process.exit(1);\n }\n\n if (options.start) {\n await startMonitor(projectRoot, options, spinner);\n } else if (options.stop) {\n await stopMonitor(projectRoot, spinner);\n } else if (options.status) {\n await showStatus(projectRoot);\n } else if (options.config) {\n await showConfig(projectRoot);\n } else if (options.activity) {\n await updateActivity(projectRoot);\n } else if (options.daemon) {\n await runDaemon(projectRoot, options);\n } else if (options.foreground) {\n await runForeground(projectRoot, options);\n } else {\n // Default: show status\n await showStatus(projectRoot);\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Error: ${error}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\n/**\n * Start monitoring daemon\n */\nasync function startMonitor(projectRoot: string, options: any, spinner: any) {\n spinner.start('Starting monitor daemon...');\n\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n\n // Check if already running\n try {\n const pid = await fs.readFile(pidFile, 'utf-8');\n // Check if process is actually running\n try {\n process.kill(parseInt(pid), 0);\n spinner.fail(chalk.yellow('Monitor already running'));\n console.log(chalk.gray(`PID: ${pid}`));\n return;\n } catch {\n // Process not running, clean up stale PID file\n await fs.unlink(pidFile).catch(() => {});\n }\n } catch {\n // No PID file\n }\n\n // Spawn daemon process\n const daemon = spawn(\n process.execPath,\n [\n process.argv[1],\n 'monitor',\n '--daemon',\n '--interval',\n options.interval || '30',\n '--idle',\n options.idle || '5',\n ],\n {\n cwd: projectRoot,\n detached: true,\n stdio: ['ignore', 'ignore', 'ignore'],\n }\n );\n\n // Store PID\n await fs.writeFile(pidFile, daemon.pid!.toString(), 'utf-8');\n\n daemon.unref();\n\n spinner.succeed(chalk.green('\u2705 Monitor daemon started'));\n console.log(chalk.gray(`PID: ${daemon.pid}`));\n console.log(chalk.gray(`Check interval: ${options.interval || 30}s`));\n console.log(chalk.gray(`Idle timeout: ${options.idle || 5}min`));\n\n console.log(chalk.bold('\\n\uD83D\uDD0D Monitoring:'));\n console.log(' \u2022 Context usage (warns at 60%, saves at 85%)');\n console.log(' \u2022 Idle detection (handoff after 5min)');\n console.log(' \u2022 Session end (auto-save on exit)');\n\n console.log(chalk.gray('\\nStop with: stackmemory monitor --stop'));\n}\n\n/**\n * Stop monitoring daemon\n */\nasync function stopMonitor(projectRoot: string, spinner: ora.Ora) {\n spinner.start('Stopping monitor daemon...');\n\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n\n try {\n const pid = parseInt(await fs.readFile(pidFile, 'utf-8'));\n\n // Send termination signal\n process.kill(pid, 'SIGTERM');\n\n // Clean up PID file\n await fs.unlink(pidFile);\n\n spinner.succeed(chalk.green('\u2705 Monitor daemon stopped'));\n } catch (error: unknown) {\n spinner.fail(chalk.yellow('Monitor not running'));\n }\n}\n\n/**\n * Show monitor status\n */\nasync function showStatus(projectRoot: string) {\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n const statusFile = path.join(projectRoot, '.stackmemory', 'monitor.status');\n\n console.log(chalk.bold('\\n\uD83D\uDCCA Monitor Status\\n'));\n\n // Check if daemon is running\n let isRunning = false;\n let pid: number | undefined;\n\n try {\n pid = parseInt(await fs.readFile(pidFile, 'utf-8'));\n process.kill(pid, 0);\n isRunning = true;\n } catch {\n // Not running\n }\n\n if (isRunning && pid) {\n console.log(chalk.green('\u2705 Monitor is running'));\n console.log(chalk.gray(`PID: ${pid}`));\n\n // Try to read status file\n try {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n\n console.log(chalk.bold('\\nLast Check:'));\n console.log(` Time: ${new Date(status.lastCheck).toLocaleString()}`);\n console.log(` Context: ${Math.round(status.contextPercentage * 100)}%`);\n console.log(\n ` Status: ${getStatusEmoji(status.contextStatus)} ${status.contextStatus}`\n );\n\n if (status.lastActivity) {\n const idleMinutes = Math.round(\n (Date.now() - new Date(status.lastActivity).getTime()) / 60000\n );\n console.log(` Idle: ${idleMinutes} minutes`);\n }\n\n if (status.lastLedgerSave) {\n console.log(chalk.bold('\\nLast Ledger Save:'));\n console.log(` ${new Date(status.lastLedgerSave).toLocaleString()}`);\n }\n\n if (status.lastHandoff) {\n console.log(chalk.bold('\\nLast Handoff:'));\n console.log(` ${new Date(status.lastHandoff).toLocaleString()}`);\n }\n } catch {\n // No status file or invalid\n }\n } else {\n console.log(chalk.yellow('\u26A0\uFE0F Monitor is not running'));\n console.log(chalk.gray('Start with: stackmemory monitor --start'));\n }\n}\n\n/**\n * Show monitor configuration\n */\nasync function showConfig(projectRoot: string) {\n const configFile = path.join(projectRoot, '.stackmemory', 'config.json');\n\n console.log(chalk.bold('\\n\u2699\uFE0F Monitor Configuration\\n'));\n\n try {\n const config = JSON.parse(await fs.readFile(configFile, 'utf-8'));\n const monitorConfig = config.monitor || {};\n\n console.log('Context Thresholds:');\n console.log(\n ` Warning: ${(monitorConfig.contextWarningThreshold || 0.6) * 100}%`\n );\n console.log(\n ` Critical: ${(monitorConfig.contextCriticalThreshold || 0.7) * 100}%`\n );\n console.log(\n ` Auto-save: ${(monitorConfig.contextAutoSaveThreshold || 0.85) * 100}%`\n );\n\n console.log('\\nTimings:');\n console.log(\n ` Check interval: ${monitorConfig.checkIntervalSeconds || 30}s`\n );\n console.log(` Idle timeout: ${monitorConfig.idleTimeoutMinutes || 5}min`);\n\n console.log('\\nAuto Actions:');\n console.log(\n ` Auto-save ledger: ${monitorConfig.autoSaveLedger !== false ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Auto-generate handoff: ${monitorConfig.autoGenerateHandoff !== false ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Session-end handoff: ${monitorConfig.sessionEndHandoff !== false ? '\u2705' : '\u274C'}`\n );\n } catch {\n console.log(chalk.gray('Using default configuration'));\n console.log('\\nDefaults:');\n console.log(' Warning at 60%, Critical at 70%, Auto-save at 85%');\n console.log(' Check every 30s, Idle timeout 5min');\n console.log(' All auto-actions enabled');\n }\n}\n\n/**\n * Update activity timestamp\n */\nasync function updateActivity(projectRoot: string) {\n const activityFile = path.join(\n projectRoot,\n '.stackmemory',\n 'monitor.activity'\n );\n await fs.mkdir(path.dirname(activityFile), { recursive: true });\n await fs.writeFile(activityFile, new Date().toISOString(), 'utf-8');\n // Silent update - no output\n}\n\n/**\n * Run as daemon (background process)\n */\nasync function runDaemon(projectRoot: string, options: any) {\n const dbPath = path.join(projectRoot, '.stackmemory', 'db', 'stackmemory.db');\n const db = new Database(dbPath);\n\n const frameManager = new FrameManager(db, 'current');\n\n const monitor = new SessionMonitor(frameManager, db, projectRoot, {\n checkIntervalSeconds: parseInt(options.interval) || 30,\n idleTimeoutMinutes: parseInt(options.idle) || 5,\n autoSaveLedger: true,\n autoGenerateHandoff: true,\n sessionEndHandoff: true,\n });\n\n // Write status periodically\n const statusFile = path.join(projectRoot, '.stackmemory', 'monitor.status');\n const activityFile = path.join(\n projectRoot,\n '.stackmemory',\n 'monitor.activity'\n );\n\n monitor.on('context:usage', async (data) => {\n // Check for activity file updates\n try {\n const activityTime = await fs.readFile(activityFile, 'utf-8');\n monitor.updateActivity();\n } catch {\n // No activity file\n }\n\n // Write status\n const status = {\n lastCheck: new Date().toISOString(),\n contextPercentage: data.percentage,\n contextStatus: data.status,\n lastActivity: monitor.getStatus().lastActivity,\n };\n\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n monitor.on('context:ledger_saved', async () => {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n status.lastLedgerSave = new Date().toISOString();\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n monitor.on('handoff:generated', async () => {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n status.lastHandoff = new Date().toISOString();\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n // Start monitoring\n await monitor.start();\n\n // Keep process alive\n process.on('SIGTERM', async () => {\n await monitor.stop();\n process.exit(0);\n });\n}\n\n/**\n * Run in foreground (for testing)\n */\nasync function runForeground(projectRoot: string, options: any) {\n console.log(chalk.bold('\uD83D\uDD0D Running monitor in foreground...\\n'));\n\n const dbPath = path.join(projectRoot, '.stackmemory', 'db', 'stackmemory.db');\n const db = new Database(dbPath);\n\n const frameManager = new FrameManager(db, 'current');\n\n const monitor = new SessionMonitor(frameManager, db, projectRoot, {\n checkIntervalSeconds: parseInt(options.interval) || 30,\n idleTimeoutMinutes: parseInt(options.idle) || 5,\n autoSaveLedger: true,\n autoGenerateHandoff: true,\n sessionEndHandoff: true,\n });\n\n // Log all events\n monitor.on('context:usage', (data) => {\n console.log(\n `[${new Date().toLocaleTimeString()}] Context: ${Math.round(data.percentage * 100)}% (${data.status})`\n );\n });\n\n monitor.on('context:warning', () => {\n console.log(chalk.yellow('\u26A0\uFE0F Context warning threshold reached'));\n });\n\n monitor.on('context:high', () => {\n console.log(chalk.yellow('\uD83D\uDFE1 Context high - considering auto-save'));\n });\n\n monitor.on('context:ledger_saved', (data) => {\n console.log(\n chalk.green(`\u2705 Ledger saved (${data.compression}x compression)`)\n );\n });\n\n monitor.on('handoff:generated', (data) => {\n console.log(chalk.green(`\uD83D\uDCCB Handoff generated (${data.trigger})`));\n });\n\n // Start monitoring\n await monitor.start();\n\n console.log('Press Ctrl+C to stop\\n');\n\n // Handle exit\n process.on('SIGINT', async () => {\n console.log('\\nStopping monitor...');\n await monitor.stop();\n process.exit(0);\n });\n}\n\n// Helper functions\n\nasync function getProjectRoot(): Promise<string> {\n return process.cwd();\n}\n\nfunction getStatusEmoji(status: string): string {\n switch (status) {\n case 'ok':\n return '\uD83D\uDFE2';\n case 'warning':\n return '\uD83D\uDFE1';\n case 'high':\n return '\uD83D\uDFE0';\n case 'critical':\n return '\uD83D\uDD34';\n default:\n return '\u26AB';\n }\n}\n\n// Export for use in main CLI\nexport default createMonitorCommand();\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|