@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,459 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import { fileURLToPath as __fileURLToPath } from 'url';
|
|
3
|
-
import { dirname as __pathDirname } from 'path';
|
|
4
|
-
const __filename = __fileURLToPath(import.meta.url);
|
|
5
|
-
const __dirname = __pathDirname(__filename);
|
|
6
|
-
import express from "express";
|
|
7
|
-
import cors from "cors";
|
|
8
|
-
import { createClient } from "redis";
|
|
9
|
-
import pg from "pg";
|
|
10
|
-
import { S3Client, PutObjectCommand, GetObjectCommand, ListObjectsCommand } from "@aws-sdk/client-s3";
|
|
11
|
-
const { Client } = pg;
|
|
12
|
-
async function startServer() {
|
|
13
|
-
const config = {
|
|
14
|
-
port: parseInt(process.env.PORT || "3000"),
|
|
15
|
-
databaseUrl: process.env.DATABASE_URL,
|
|
16
|
-
redisUrl: process.env.REDIS_URL || (process.env.REDISHOST ? `redis://${process.env.REDISHOST}:${process.env.REDISPORT || 6379}` : null),
|
|
17
|
-
corsOrigins: process.env.CORS_ORIGINS?.split(",") || ["*"]
|
|
18
|
-
};
|
|
19
|
-
console.log("\u{1F680} Starting StackMemory Storage Test Server");
|
|
20
|
-
console.log(`\u{1F4CD} Port: ${config.port}`);
|
|
21
|
-
console.log(`\u{1F4BE} PostgreSQL: ${config.databaseUrl ? "configured" : "not configured"}`);
|
|
22
|
-
console.log(`\u{1F534} Redis: ${config.redisUrl ? "configured" : "not configured"}`);
|
|
23
|
-
const app = express();
|
|
24
|
-
app.use(cors({ origin: config.corsOrigins }));
|
|
25
|
-
app.use(express.json());
|
|
26
|
-
app.get("/health", (req, res) => {
|
|
27
|
-
res.json({
|
|
28
|
-
status: "healthy",
|
|
29
|
-
service: "stackmemory-storage-test",
|
|
30
|
-
timestamp: (/* @__PURE__ */ new Date()).toISOString()
|
|
31
|
-
});
|
|
32
|
-
});
|
|
33
|
-
app.get("/api/health", (req, res) => {
|
|
34
|
-
res.json({
|
|
35
|
-
status: "healthy",
|
|
36
|
-
service: "stackmemory-storage-test",
|
|
37
|
-
timestamp: (/* @__PURE__ */ new Date()).toISOString()
|
|
38
|
-
});
|
|
39
|
-
});
|
|
40
|
-
app.get("/", (req, res) => {
|
|
41
|
-
res.json({
|
|
42
|
-
name: "StackMemory Core API",
|
|
43
|
-
version: "0.3.17",
|
|
44
|
-
description: "Core API with Redis, PostgreSQL, and Railway Buckets",
|
|
45
|
-
endpoints: [
|
|
46
|
-
"/health",
|
|
47
|
-
"/api/health",
|
|
48
|
-
"/api/login",
|
|
49
|
-
"/api/status",
|
|
50
|
-
"/test-storage",
|
|
51
|
-
"/create-frame",
|
|
52
|
-
"/list-frames",
|
|
53
|
-
"/api/frames"
|
|
54
|
-
],
|
|
55
|
-
storage_tiers: {
|
|
56
|
-
hot: "Redis (< 24 hours)",
|
|
57
|
-
warm: "Railway Buckets (1-30 days)",
|
|
58
|
-
cold: "PostgreSQL (30+ days)"
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
-
app.post("/api/login", async (req, res) => {
|
|
63
|
-
try {
|
|
64
|
-
const { username, api_key } = req.body;
|
|
65
|
-
const validApiKey = process.env.API_KEY_SECRET || "development-secret";
|
|
66
|
-
if (api_key === validApiKey) {
|
|
67
|
-
const sessionId = `session_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
68
|
-
const sessionData = {
|
|
69
|
-
username: username || "api_user",
|
|
70
|
-
created_at: (/* @__PURE__ */ new Date()).toISOString(),
|
|
71
|
-
api_key_hash: "valid",
|
|
72
|
-
permissions: ["read", "write", "admin"]
|
|
73
|
-
};
|
|
74
|
-
if (config.redisUrl) {
|
|
75
|
-
const redisClient = createClient({ url: config.redisUrl });
|
|
76
|
-
await redisClient.connect();
|
|
77
|
-
await redisClient.setEx(`session:${sessionId}`, 3600, JSON.stringify(sessionData));
|
|
78
|
-
await redisClient.disconnect();
|
|
79
|
-
}
|
|
80
|
-
res.json({
|
|
81
|
-
success: true,
|
|
82
|
-
session_id: sessionId,
|
|
83
|
-
message: "Automatically logged into StackMemory Core API",
|
|
84
|
-
access: {
|
|
85
|
-
redis: config.redisUrl ? "available" : "not_configured",
|
|
86
|
-
postgresql: config.databaseUrl ? "available" : "not_configured",
|
|
87
|
-
buckets: "configurable"
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
} else {
|
|
91
|
-
res.status(401).json({
|
|
92
|
-
success: false,
|
|
93
|
-
message: "Invalid API key"
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
} catch (error) {
|
|
97
|
-
res.status(500).json({
|
|
98
|
-
success: false,
|
|
99
|
-
message: "Login failed",
|
|
100
|
-
error: error.message
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
});
|
|
104
|
-
app.get("/api/status", async (req, res) => {
|
|
105
|
-
const status = {
|
|
106
|
-
service: "stackmemory-core-api",
|
|
107
|
-
version: "0.3.17",
|
|
108
|
-
environment: process.env.NODE_ENV || "production",
|
|
109
|
-
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
110
|
-
storage: {
|
|
111
|
-
tiers: {}
|
|
112
|
-
}
|
|
113
|
-
};
|
|
114
|
-
if (config.redisUrl) {
|
|
115
|
-
try {
|
|
116
|
-
const redisClient = createClient({ url: config.redisUrl });
|
|
117
|
-
await redisClient.connect();
|
|
118
|
-
const info = await redisClient.info("memory");
|
|
119
|
-
const keys = await redisClient.keys("*");
|
|
120
|
-
const usedMemory = info.match(/used_memory_human:(.+)/)?.[1];
|
|
121
|
-
status.storage.tiers.hot_redis = {
|
|
122
|
-
status: "connected",
|
|
123
|
-
memory_used: usedMemory?.trim(),
|
|
124
|
-
keys: keys.length,
|
|
125
|
-
ttl_policy: "auto-expire"
|
|
126
|
-
};
|
|
127
|
-
await redisClient.disconnect();
|
|
128
|
-
} catch (error) {
|
|
129
|
-
status.storage.tiers.hot_redis = { status: "error", message: error.message };
|
|
130
|
-
}
|
|
131
|
-
} else {
|
|
132
|
-
status.storage.tiers.hot_redis = { status: "not_configured" };
|
|
133
|
-
}
|
|
134
|
-
if (config.databaseUrl) {
|
|
135
|
-
try {
|
|
136
|
-
const pgClient = new Client({ connectionString: config.databaseUrl });
|
|
137
|
-
await pgClient.connect();
|
|
138
|
-
const result = await pgClient.query("SELECT COUNT(*) as frames FROM frames WHERE created_at > NOW() - INTERVAL '24 hours'");
|
|
139
|
-
const totalFrames = await pgClient.query("SELECT COUNT(*) as total FROM frames");
|
|
140
|
-
status.storage.tiers.cold_postgresql = {
|
|
141
|
-
status: "connected",
|
|
142
|
-
recent_frames: parseInt(result.rows[0].frames),
|
|
143
|
-
total_frames: parseInt(totalFrames.rows[0].total)
|
|
144
|
-
};
|
|
145
|
-
await pgClient.end();
|
|
146
|
-
} catch (error) {
|
|
147
|
-
status.storage.tiers.cold_postgresql = { status: "error", message: error.message };
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
res.json(status);
|
|
151
|
-
});
|
|
152
|
-
app.get("/test-storage", async (req, res) => {
|
|
153
|
-
const results = {
|
|
154
|
-
postgresql: {},
|
|
155
|
-
redis: {},
|
|
156
|
-
buckets: {},
|
|
157
|
-
summary: {}
|
|
158
|
-
};
|
|
159
|
-
try {
|
|
160
|
-
if (config.databaseUrl) {
|
|
161
|
-
console.log("\u{1F418} Testing PostgreSQL...");
|
|
162
|
-
try {
|
|
163
|
-
const pgClient = new Client({ connectionString: config.databaseUrl });
|
|
164
|
-
await pgClient.connect();
|
|
165
|
-
const timeResult = await pgClient.query("SELECT NOW() as time, version() as version");
|
|
166
|
-
await pgClient.query(`
|
|
167
|
-
CREATE TABLE IF NOT EXISTS frames (
|
|
168
|
-
frame_id TEXT PRIMARY KEY,
|
|
169
|
-
run_id TEXT NOT NULL,
|
|
170
|
-
project_id TEXT NOT NULL,
|
|
171
|
-
type TEXT NOT NULL,
|
|
172
|
-
name TEXT NOT NULL,
|
|
173
|
-
state TEXT DEFAULT 'active',
|
|
174
|
-
inputs JSONB DEFAULT '{}',
|
|
175
|
-
outputs JSONB DEFAULT '{}',
|
|
176
|
-
created_at TIMESTAMP DEFAULT NOW()
|
|
177
|
-
)
|
|
178
|
-
`);
|
|
179
|
-
const testId = `pg-test-${Date.now()}`;
|
|
180
|
-
await pgClient.query(
|
|
181
|
-
"INSERT INTO frames (frame_id, run_id, project_id, type, name) VALUES ($1, $2, $3, $4, $5)",
|
|
182
|
-
[testId, "test-run", "storage-test", "test", "PostgreSQL Test Frame"]
|
|
183
|
-
);
|
|
184
|
-
const frameResult = await pgClient.query("SELECT COUNT(*) as count FROM frames");
|
|
185
|
-
results.postgresql = {
|
|
186
|
-
status: "connected",
|
|
187
|
-
server_time: timeResult.rows[0].time,
|
|
188
|
-
version: timeResult.rows[0].version.split(" ")[0],
|
|
189
|
-
total_frames: parseInt(frameResult.rows[0].count),
|
|
190
|
-
test_frame_id: testId
|
|
191
|
-
};
|
|
192
|
-
await pgClient.end();
|
|
193
|
-
} catch (error) {
|
|
194
|
-
results.postgresql = { status: "error", message: error.message };
|
|
195
|
-
}
|
|
196
|
-
} else {
|
|
197
|
-
results.postgresql = { status: "not_configured" };
|
|
198
|
-
}
|
|
199
|
-
if (config.redisUrl) {
|
|
200
|
-
console.log("\u{1F534} Testing Redis...");
|
|
201
|
-
try {
|
|
202
|
-
const redisClient = createClient({ url: config.redisUrl });
|
|
203
|
-
await redisClient.connect();
|
|
204
|
-
const testKey = `redis-test:${Date.now()}`;
|
|
205
|
-
const testData = {
|
|
206
|
-
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
207
|
-
test: "Redis connectivity test",
|
|
208
|
-
frame_count: 1
|
|
209
|
-
};
|
|
210
|
-
await redisClient.setEx(testKey, 300, JSON.stringify(testData));
|
|
211
|
-
const retrieved = await redisClient.get(testKey);
|
|
212
|
-
const info = await redisClient.info("server");
|
|
213
|
-
const memory = await redisClient.info("memory");
|
|
214
|
-
const version = info.match(/redis_version:(.+)/)?.[1];
|
|
215
|
-
const usedMemory = memory.match(/used_memory_human:(.+)/)?.[1];
|
|
216
|
-
const keys = await redisClient.keys("*");
|
|
217
|
-
results.redis = {
|
|
218
|
-
status: "connected",
|
|
219
|
-
version,
|
|
220
|
-
memory_used: usedMemory?.trim(),
|
|
221
|
-
total_keys: keys.length,
|
|
222
|
-
test_key: testKey,
|
|
223
|
-
test_data_retrieved: retrieved ? JSON.parse(retrieved) : null
|
|
224
|
-
};
|
|
225
|
-
await redisClient.disconnect();
|
|
226
|
-
} catch (error) {
|
|
227
|
-
results.redis = { status: "error", message: error.message };
|
|
228
|
-
}
|
|
229
|
-
} else {
|
|
230
|
-
results.redis = { status: "not_configured" };
|
|
231
|
-
}
|
|
232
|
-
console.log("\u{1FAA3} Testing Railway Buckets...");
|
|
233
|
-
const bucketConfig = {
|
|
234
|
-
endpoint: process.env.RAILWAY_BUCKET_ENDPOINT,
|
|
235
|
-
accessKeyId: process.env.RAILWAY_BUCKET_ACCESS_KEY,
|
|
236
|
-
secretAccessKey: process.env.RAILWAY_BUCKET_SECRET_KEY,
|
|
237
|
-
bucket: process.env.RAILWAY_BUCKET_NAME || "stackmemory-warm"
|
|
238
|
-
};
|
|
239
|
-
if (bucketConfig.endpoint && bucketConfig.accessKeyId && bucketConfig.secretAccessKey) {
|
|
240
|
-
try {
|
|
241
|
-
const s3Client = new S3Client({
|
|
242
|
-
endpoint: bucketConfig.endpoint,
|
|
243
|
-
region: "us-east-1",
|
|
244
|
-
credentials: {
|
|
245
|
-
accessKeyId: bucketConfig.accessKeyId,
|
|
246
|
-
secretAccessKey: bucketConfig.secretAccessKey
|
|
247
|
-
}
|
|
248
|
-
});
|
|
249
|
-
const testKey = `storage-test/frame-${Date.now()}.json`;
|
|
250
|
-
const testFrame = {
|
|
251
|
-
frame_id: `bucket-test-${Date.now()}`,
|
|
252
|
-
type: "test",
|
|
253
|
-
name: "Railway Bucket Test",
|
|
254
|
-
created_at: (/* @__PURE__ */ new Date()).toISOString(),
|
|
255
|
-
data: "This is a test frame stored in Railway Buckets"
|
|
256
|
-
};
|
|
257
|
-
await s3Client.send(new PutObjectCommand({
|
|
258
|
-
Bucket: bucketConfig.bucket,
|
|
259
|
-
Key: testKey,
|
|
260
|
-
Body: JSON.stringify(testFrame),
|
|
261
|
-
ContentType: "application/json"
|
|
262
|
-
}));
|
|
263
|
-
const getResult = await s3Client.send(new GetObjectCommand({
|
|
264
|
-
Bucket: bucketConfig.bucket,
|
|
265
|
-
Key: testKey
|
|
266
|
-
}));
|
|
267
|
-
const listResult = await s3Client.send(new ListObjectsCommand({
|
|
268
|
-
Bucket: bucketConfig.bucket,
|
|
269
|
-
MaxKeys: 10
|
|
270
|
-
}));
|
|
271
|
-
results.buckets = {
|
|
272
|
-
status: "connected",
|
|
273
|
-
endpoint: bucketConfig.endpoint,
|
|
274
|
-
bucket: bucketConfig.bucket,
|
|
275
|
-
test_key: testKey,
|
|
276
|
-
object_count: listResult.Contents?.length || 0,
|
|
277
|
-
test_frame: testFrame
|
|
278
|
-
};
|
|
279
|
-
} catch (error) {
|
|
280
|
-
results.buckets = { status: "error", message: error.message };
|
|
281
|
-
}
|
|
282
|
-
} else {
|
|
283
|
-
results.buckets = {
|
|
284
|
-
status: "not_configured",
|
|
285
|
-
missing: Object.entries(bucketConfig).filter(([key, value]) => !value).map(([key]) => key)
|
|
286
|
-
};
|
|
287
|
-
}
|
|
288
|
-
results.summary = {
|
|
289
|
-
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
290
|
-
tiers: {
|
|
291
|
-
hot: results.redis.status === "connected" ? "available" : "unavailable",
|
|
292
|
-
warm: results.buckets.status === "connected" ? "available" : "unavailable",
|
|
293
|
-
cold: results.postgresql.status === "connected" ? "available" : "unavailable"
|
|
294
|
-
},
|
|
295
|
-
ready_for_production: results.postgresql.status === "connected" && results.redis.status === "connected"
|
|
296
|
-
};
|
|
297
|
-
res.json(results);
|
|
298
|
-
} catch (error) {
|
|
299
|
-
console.error("Storage test error:", error);
|
|
300
|
-
res.status(500).json({
|
|
301
|
-
error: "Storage test failed",
|
|
302
|
-
message: error.message,
|
|
303
|
-
partial_results: results
|
|
304
|
-
});
|
|
305
|
-
}
|
|
306
|
-
});
|
|
307
|
-
app.post("/create-frame", async (req, res) => {
|
|
308
|
-
const frameData = {
|
|
309
|
-
frame_id: `frame-${Date.now()}`,
|
|
310
|
-
run_id: req.body.run_id || "test-run",
|
|
311
|
-
project_id: req.body.project_id || "storage-test",
|
|
312
|
-
type: req.body.type || "test",
|
|
313
|
-
name: req.body.name || "Multi-tier Test Frame",
|
|
314
|
-
inputs: req.body.inputs || {},
|
|
315
|
-
outputs: req.body.outputs || { status: "created" },
|
|
316
|
-
created_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
317
|
-
};
|
|
318
|
-
const results = { frame: frameData, storage: {} };
|
|
319
|
-
try {
|
|
320
|
-
if (config.databaseUrl) {
|
|
321
|
-
const pgClient = new Client({ connectionString: config.databaseUrl });
|
|
322
|
-
await pgClient.connect();
|
|
323
|
-
await pgClient.query(
|
|
324
|
-
"INSERT INTO frames (frame_id, run_id, project_id, type, name, inputs, outputs) VALUES ($1, $2, $3, $4, $5, $6, $7)",
|
|
325
|
-
[frameData.frame_id, frameData.run_id, frameData.project_id, frameData.type, frameData.name, frameData.inputs, frameData.outputs]
|
|
326
|
-
);
|
|
327
|
-
await pgClient.end();
|
|
328
|
-
results.storage.postgresql = "stored";
|
|
329
|
-
}
|
|
330
|
-
if (config.redisUrl) {
|
|
331
|
-
const redisClient = createClient({ url: config.redisUrl });
|
|
332
|
-
await redisClient.connect();
|
|
333
|
-
await redisClient.setEx(`frame:${frameData.frame_id}`, 3600, JSON.stringify(frameData));
|
|
334
|
-
await redisClient.disconnect();
|
|
335
|
-
results.storage.redis = "stored";
|
|
336
|
-
}
|
|
337
|
-
res.json(results);
|
|
338
|
-
} catch (error) {
|
|
339
|
-
res.status(500).json({
|
|
340
|
-
error: "Failed to create frame",
|
|
341
|
-
message: error.message,
|
|
342
|
-
partial_results: results
|
|
343
|
-
});
|
|
344
|
-
}
|
|
345
|
-
});
|
|
346
|
-
app.get("/api/frames", async (req, res) => {
|
|
347
|
-
try {
|
|
348
|
-
const limit = parseInt(req.query.limit) || 10;
|
|
349
|
-
const source = req.query.source || "all";
|
|
350
|
-
const results = {
|
|
351
|
-
frames: [],
|
|
352
|
-
sources_checked: [],
|
|
353
|
-
total_count: 0
|
|
354
|
-
};
|
|
355
|
-
if ((source === "all" || source === "redis") && config.redisUrl) {
|
|
356
|
-
try {
|
|
357
|
-
const redisClient = createClient({ url: config.redisUrl });
|
|
358
|
-
await redisClient.connect();
|
|
359
|
-
const redisKeys = await redisClient.keys("frame:*");
|
|
360
|
-
const redisFrames = [];
|
|
361
|
-
for (const key of redisKeys.slice(0, limit)) {
|
|
362
|
-
const data = await redisClient.get(key);
|
|
363
|
-
if (data) {
|
|
364
|
-
const frame = JSON.parse(data);
|
|
365
|
-
frame.source = "redis";
|
|
366
|
-
frame.tier = "hot";
|
|
367
|
-
redisFrames.push(frame);
|
|
368
|
-
}
|
|
369
|
-
}
|
|
370
|
-
await redisClient.disconnect();
|
|
371
|
-
results.frames.push(...redisFrames);
|
|
372
|
-
results.sources_checked.push("redis");
|
|
373
|
-
} catch (error) {
|
|
374
|
-
results.redis_error = error.message;
|
|
375
|
-
}
|
|
376
|
-
}
|
|
377
|
-
if ((source === "all" || source === "postgresql") && config.databaseUrl) {
|
|
378
|
-
try {
|
|
379
|
-
const pgClient = new Client({ connectionString: config.databaseUrl });
|
|
380
|
-
await pgClient.connect();
|
|
381
|
-
const pgFrames = await pgClient.query(
|
|
382
|
-
"SELECT *, 'postgresql' as source, 'cold' as tier FROM frames ORDER BY created_at DESC LIMIT $1",
|
|
383
|
-
[limit]
|
|
384
|
-
);
|
|
385
|
-
await pgClient.end();
|
|
386
|
-
results.frames.push(...pgFrames.rows);
|
|
387
|
-
results.sources_checked.push("postgresql");
|
|
388
|
-
results.total_count = pgFrames.rowCount;
|
|
389
|
-
} catch (error) {
|
|
390
|
-
results.postgresql_error = error.message;
|
|
391
|
-
}
|
|
392
|
-
}
|
|
393
|
-
if (results.frames.length > 1) {
|
|
394
|
-
results.frames.sort(
|
|
395
|
-
(a, b) => new Date(b.created_at).getTime() - new Date(a.created_at).getTime()
|
|
396
|
-
);
|
|
397
|
-
}
|
|
398
|
-
res.json({
|
|
399
|
-
count: results.frames.length,
|
|
400
|
-
frames: results.frames.slice(0, limit),
|
|
401
|
-
metadata: {
|
|
402
|
-
sources_checked: results.sources_checked,
|
|
403
|
-
total_in_postgresql: results.total_count,
|
|
404
|
-
tier_explanation: {
|
|
405
|
-
hot: "Redis - Recent frames (< 24 hours)",
|
|
406
|
-
cold: "PostgreSQL - All frames (persistent storage)"
|
|
407
|
-
}
|
|
408
|
-
}
|
|
409
|
-
});
|
|
410
|
-
} catch (error) {
|
|
411
|
-
res.status(500).json({
|
|
412
|
-
error: "Failed to fetch frames",
|
|
413
|
-
message: error.message
|
|
414
|
-
});
|
|
415
|
-
}
|
|
416
|
-
});
|
|
417
|
-
app.get("/list-frames", async (req, res) => {
|
|
418
|
-
const results = { sources: {} };
|
|
419
|
-
try {
|
|
420
|
-
if (config.databaseUrl) {
|
|
421
|
-
const pgClient = new Client({ connectionString: config.databaseUrl });
|
|
422
|
-
await pgClient.connect();
|
|
423
|
-
const pgFrames = await pgClient.query("SELECT * FROM frames ORDER BY created_at DESC LIMIT 5");
|
|
424
|
-
await pgClient.end();
|
|
425
|
-
results.sources.postgresql = pgFrames.rows;
|
|
426
|
-
}
|
|
427
|
-
if (config.redisUrl) {
|
|
428
|
-
const redisClient = createClient({ url: config.redisUrl });
|
|
429
|
-
await redisClient.connect();
|
|
430
|
-
const redisKeys = await redisClient.keys("frame:*");
|
|
431
|
-
const redisFrames = [];
|
|
432
|
-
for (const key of redisKeys.slice(0, 5)) {
|
|
433
|
-
const data = await redisClient.get(key);
|
|
434
|
-
if (data) redisFrames.push(JSON.parse(data));
|
|
435
|
-
}
|
|
436
|
-
await redisClient.disconnect();
|
|
437
|
-
results.sources.redis = redisFrames;
|
|
438
|
-
}
|
|
439
|
-
res.json(results);
|
|
440
|
-
} catch (error) {
|
|
441
|
-
res.status(500).json({
|
|
442
|
-
error: "Failed to list frames",
|
|
443
|
-
message: error.message
|
|
444
|
-
});
|
|
445
|
-
}
|
|
446
|
-
});
|
|
447
|
-
app.listen(config.port, "0.0.0.0", () => {
|
|
448
|
-
console.log(`\u2705 Storage Test Server running on port ${config.port}`);
|
|
449
|
-
console.log("\n\u{1F4CA} Available endpoints:");
|
|
450
|
-
console.log(" - GET /test-storage (comprehensive storage test)");
|
|
451
|
-
console.log(" - POST /create-frame (create test frame)");
|
|
452
|
-
console.log(" - GET /list-frames (list recent frames)");
|
|
453
|
-
});
|
|
454
|
-
}
|
|
455
|
-
startServer().catch((error) => {
|
|
456
|
-
console.error("Failed to start storage test server:", error);
|
|
457
|
-
process.exit(1);
|
|
458
|
-
});
|
|
459
|
-
//# sourceMappingURL=storage-test.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/servers/railway/storage-test.ts"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env node\n/**\n * Enhanced Railway Server with Full Storage Testing\n * Tests PostgreSQL, Redis, and Railway Buckets (3-tier system)\n */\n\nimport express from 'express';\nimport cors from 'cors';\nimport { createClient } from 'redis';\nimport pg from 'pg';\nimport { S3Client, PutObjectCommand, GetObjectCommand, ListObjectsCommand } from '@aws-sdk/client-s3';\n\nconst { Client } = pg;\n\ninterface StorageTestResult {\n postgresql: any;\n redis: any;\n buckets: any;\n summary: any;\n}\n\nasync function startServer() {\n const config = {\n port: parseInt(process.env.PORT || '3000'),\n databaseUrl: process.env.DATABASE_URL,\n redisUrl: process.env.REDIS_URL || \n (process.env.REDISHOST ? `redis://${process.env.REDISHOST}:${process.env.REDISPORT || 6379}` : null),\n corsOrigins: process.env.CORS_ORIGINS?.split(',') || ['*']\n };\n \n console.log('\uD83D\uDE80 Starting StackMemory Storage Test Server');\n console.log(`\uD83D\uDCCD Port: ${config.port}`);\n console.log(`\uD83D\uDCBE PostgreSQL: ${config.databaseUrl ? 'configured' : 'not configured'}`);\n console.log(`\uD83D\uDD34 Redis: ${config.redisUrl ? 'configured' : 'not configured'}`);\n \n const app = express();\n \n // Middleware\n app.use(cors({ origin: config.corsOrigins }));\n app.use(express.json());\n \n // Health endpoint\n app.get('/health', (req, res) => {\n res.json({ \n status: 'healthy',\n service: 'stackmemory-storage-test',\n timestamp: new Date().toISOString()\n });\n });\n \n app.get('/api/health', (req, res) => {\n res.json({ \n status: 'healthy',\n service: 'stackmemory-storage-test',\n timestamp: new Date().toISOString()\n });\n });\n \n // Root endpoint\n app.get('/', (req, res) => {\n res.json({\n name: 'StackMemory Core API',\n version: '0.3.17',\n description: 'Core API with Redis, PostgreSQL, and Railway Buckets',\n endpoints: [\n '/health',\n '/api/health',\n '/api/login',\n '/api/status',\n '/test-storage',\n '/create-frame',\n '/list-frames',\n '/api/frames'\n ],\n storage_tiers: {\n hot: 'Redis (< 24 hours)',\n warm: 'Railway Buckets (1-30 days)', \n cold: 'PostgreSQL (30+ days)'\n }\n });\n });\n \n // Auto-login endpoint for seamless API access\n app.post('/api/login', async (req, res) => {\n try {\n const { username, api_key } = req.body;\n \n // Simple API key validation (in production, use proper JWT/OAuth)\n const validApiKey = process.env.API_KEY_SECRET || 'development-secret';\n \n if (api_key === validApiKey) {\n // Store session in Redis if available\n const sessionId = `session_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;\n const sessionData = {\n username: username || 'api_user',\n created_at: new Date().toISOString(),\n api_key_hash: 'valid',\n permissions: ['read', 'write', 'admin']\n };\n \n if (config.redisUrl) {\n const redisClient = createClient({ url: config.redisUrl });\n await redisClient.connect();\n await redisClient.setEx(`session:${sessionId}`, 3600, JSON.stringify(sessionData)); // 1 hour\n await redisClient.disconnect();\n }\n \n res.json({\n success: true,\n session_id: sessionId,\n message: 'Automatically logged into StackMemory Core API',\n access: {\n redis: config.redisUrl ? 'available' : 'not_configured',\n postgresql: config.databaseUrl ? 'available' : 'not_configured',\n buckets: 'configurable'\n }\n });\n } else {\n res.status(401).json({\n success: false,\n message: 'Invalid API key'\n });\n }\n } catch (error: any) {\n res.status(500).json({\n success: false,\n message: 'Login failed',\n error: error.message\n });\n }\n });\n \n // Core API status endpoint\n app.get('/api/status', async (req, res) => {\n const status: any = {\n service: 'stackmemory-core-api',\n version: '0.3.17',\n environment: process.env.NODE_ENV || 'production',\n timestamp: new Date().toISOString(),\n storage: {\n tiers: {}\n }\n };\n \n // Check Redis (Hot Tier)\n if (config.redisUrl) {\n try {\n const redisClient = createClient({ url: config.redisUrl });\n await redisClient.connect();\n \n const info = await redisClient.info('memory');\n const keys = await redisClient.keys('*');\n const usedMemory = info.match(/used_memory_human:(.+)/)?.[1];\n \n status.storage.tiers.hot_redis = {\n status: 'connected',\n memory_used: usedMemory?.trim(),\n keys: keys.length,\n ttl_policy: 'auto-expire'\n };\n \n await redisClient.disconnect();\n } catch (error: any) {\n status.storage.tiers.hot_redis = { status: 'error', message: error.message };\n }\n } else {\n status.storage.tiers.hot_redis = { status: 'not_configured' };\n }\n \n // Check PostgreSQL (Cold Tier)\n if (config.databaseUrl) {\n try {\n const pgClient = new Client({ connectionString: config.databaseUrl });\n await pgClient.connect();\n \n const result = await pgClient.query('SELECT COUNT(*) as frames FROM frames WHERE created_at > NOW() - INTERVAL \\'24 hours\\'');\n const totalFrames = await pgClient.query('SELECT COUNT(*) as total FROM frames');\n \n status.storage.tiers.cold_postgresql = {\n status: 'connected',\n recent_frames: parseInt(result.rows[0].frames),\n total_frames: parseInt(totalFrames.rows[0].total)\n };\n \n await pgClient.end();\n } catch (error: any) {\n status.storage.tiers.cold_postgresql = { status: 'error', message: error.message };\n }\n }\n \n res.json(status);\n });\n \n // Comprehensive storage test endpoint\n app.get('/test-storage', async (req, res) => {\n const results: StorageTestResult = {\n postgresql: {},\n redis: {},\n buckets: {},\n summary: {}\n };\n \n try {\n // Test PostgreSQL\n if (config.databaseUrl) {\n console.log('\uD83D\uDC18 Testing PostgreSQL...');\n try {\n const pgClient = new Client({ connectionString: config.databaseUrl });\n await pgClient.connect();\n \n // Basic connectivity\n const timeResult = await pgClient.query('SELECT NOW() as time, version() as version');\n \n // Create frames table\n await pgClient.query(`\n CREATE TABLE IF NOT EXISTS frames (\n frame_id TEXT PRIMARY KEY,\n run_id TEXT NOT NULL,\n project_id TEXT NOT NULL,\n type TEXT NOT NULL,\n name TEXT NOT NULL,\n state TEXT DEFAULT 'active',\n inputs JSONB DEFAULT '{}',\n outputs JSONB DEFAULT '{}',\n created_at TIMESTAMP DEFAULT NOW()\n )\n `);\n \n // Test insert/select\n const testId = `pg-test-${Date.now()}`;\n await pgClient.query(\n 'INSERT INTO frames (frame_id, run_id, project_id, type, name) VALUES ($1, $2, $3, $4, $5)',\n [testId, 'test-run', 'storage-test', 'test', 'PostgreSQL Test Frame']\n );\n \n const frameResult = await pgClient.query('SELECT COUNT(*) as count FROM frames');\n \n results.postgresql = {\n status: 'connected',\n server_time: timeResult.rows[0].time,\n version: timeResult.rows[0].version.split(' ')[0],\n total_frames: parseInt(frameResult.rows[0].count),\n test_frame_id: testId\n };\n \n await pgClient.end();\n } catch (error: any) {\n results.postgresql = { status: 'error', message: error.message };\n }\n } else {\n results.postgresql = { status: 'not_configured' };\n }\n \n // Test Redis\n if (config.redisUrl) {\n console.log('\uD83D\uDD34 Testing Redis...');\n try {\n const redisClient = createClient({ url: config.redisUrl });\n await redisClient.connect();\n \n // Test basic operations\n const testKey = `redis-test:${Date.now()}`;\n const testData = {\n timestamp: new Date().toISOString(),\n test: 'Redis connectivity test',\n frame_count: 1\n };\n \n await redisClient.setEx(testKey, 300, JSON.stringify(testData)); // 5 min expiry\n const retrieved = await redisClient.get(testKey);\n \n // Get server info\n const info = await redisClient.info('server');\n const memory = await redisClient.info('memory');\n const version = info.match(/redis_version:(.+)/)?.[1];\n const usedMemory = memory.match(/used_memory_human:(.+)/)?.[1];\n \n // Count keys\n const keys = await redisClient.keys('*');\n \n results.redis = {\n status: 'connected',\n version: version,\n memory_used: usedMemory?.trim(),\n total_keys: keys.length,\n test_key: testKey,\n test_data_retrieved: retrieved ? JSON.parse(retrieved) : null\n };\n \n await redisClient.disconnect();\n } catch (error: any) {\n results.redis = { status: 'error', message: error.message };\n }\n } else {\n results.redis = { status: 'not_configured' };\n }\n \n // Test Railway Buckets (S3-compatible)\n console.log('\uD83E\uDEA3 Testing Railway Buckets...');\n const bucketConfig = {\n endpoint: process.env.RAILWAY_BUCKET_ENDPOINT,\n accessKeyId: process.env.RAILWAY_BUCKET_ACCESS_KEY,\n secretAccessKey: process.env.RAILWAY_BUCKET_SECRET_KEY,\n bucket: process.env.RAILWAY_BUCKET_NAME || 'stackmemory-warm'\n };\n \n if (bucketConfig.endpoint && bucketConfig.accessKeyId && bucketConfig.secretAccessKey) {\n try {\n const s3Client = new S3Client({\n endpoint: bucketConfig.endpoint,\n region: 'us-east-1',\n credentials: {\n accessKeyId: bucketConfig.accessKeyId,\n secretAccessKey: bucketConfig.secretAccessKey\n }\n });\n \n // Test write\n const testKey = `storage-test/frame-${Date.now()}.json`;\n const testFrame = {\n frame_id: `bucket-test-${Date.now()}`,\n type: 'test',\n name: 'Railway Bucket Test',\n created_at: new Date().toISOString(),\n data: 'This is a test frame stored in Railway Buckets'\n };\n \n await s3Client.send(new PutObjectCommand({\n Bucket: bucketConfig.bucket,\n Key: testKey,\n Body: JSON.stringify(testFrame),\n ContentType: 'application/json'\n }));\n \n // Test read\n const getResult = await s3Client.send(new GetObjectCommand({\n Bucket: bucketConfig.bucket,\n Key: testKey\n }));\n \n // List objects\n const listResult = await s3Client.send(new ListObjectsCommand({\n Bucket: bucketConfig.bucket,\n MaxKeys: 10\n }));\n \n results.buckets = {\n status: 'connected',\n endpoint: bucketConfig.endpoint,\n bucket: bucketConfig.bucket,\n test_key: testKey,\n object_count: listResult.Contents?.length || 0,\n test_frame: testFrame\n };\n } catch (error: any) {\n results.buckets = { status: 'error', message: error.message };\n }\n } else {\n results.buckets = { \n status: 'not_configured',\n missing: Object.entries(bucketConfig)\n .filter(([key, value]) => !value)\n .map(([key]) => key)\n };\n }\n \n // Summary\n results.summary = {\n timestamp: new Date().toISOString(),\n tiers: {\n hot: results.redis.status === 'connected' ? 'available' : 'unavailable',\n warm: results.buckets.status === 'connected' ? 'available' : 'unavailable',\n cold: results.postgresql.status === 'connected' ? 'available' : 'unavailable'\n },\n ready_for_production: \n results.postgresql.status === 'connected' && \n results.redis.status === 'connected'\n };\n \n res.json(results);\n \n } catch (error: any) {\n console.error('Storage test error:', error);\n res.status(500).json({\n error: 'Storage test failed',\n message: error.message,\n partial_results: results\n });\n }\n });\n \n // Create a test frame across all tiers\n app.post('/create-frame', async (req, res) => {\n const frameData = {\n frame_id: `frame-${Date.now()}`,\n run_id: req.body.run_id || 'test-run',\n project_id: req.body.project_id || 'storage-test',\n type: req.body.type || 'test',\n name: req.body.name || 'Multi-tier Test Frame',\n inputs: req.body.inputs || {},\n outputs: req.body.outputs || { status: 'created' },\n created_at: new Date().toISOString()\n };\n \n const results: any = { frame: frameData, storage: {} };\n \n try {\n // Store in PostgreSQL (cold tier)\n if (config.databaseUrl) {\n const pgClient = new Client({ connectionString: config.databaseUrl });\n await pgClient.connect();\n await pgClient.query(\n 'INSERT INTO frames (frame_id, run_id, project_id, type, name, inputs, outputs) VALUES ($1, $2, $3, $4, $5, $6, $7)',\n [frameData.frame_id, frameData.run_id, frameData.project_id, frameData.type, frameData.name, frameData.inputs, frameData.outputs]\n );\n await pgClient.end();\n results.storage.postgresql = 'stored';\n }\n \n // Store in Redis (hot tier)\n if (config.redisUrl) {\n const redisClient = createClient({ url: config.redisUrl });\n await redisClient.connect();\n await redisClient.setEx(`frame:${frameData.frame_id}`, 3600, JSON.stringify(frameData));\n await redisClient.disconnect();\n results.storage.redis = 'stored';\n }\n \n res.json(results);\n } catch (error: any) {\n res.status(500).json({\n error: 'Failed to create frame',\n message: error.message,\n partial_results: results\n });\n }\n });\n \n // Core API frames endpoint\n app.get('/api/frames', async (req, res) => {\n try {\n const limit = parseInt(req.query.limit as string) || 10;\n const source = req.query.source as string || 'all'; // 'redis', 'postgresql', 'all'\n \n const results: any = { \n frames: [],\n sources_checked: [],\n total_count: 0\n };\n \n // From Redis (hot tier) - most recent\n if ((source === 'all' || source === 'redis') && config.redisUrl) {\n try {\n const redisClient = createClient({ url: config.redisUrl });\n await redisClient.connect();\n const redisKeys = await redisClient.keys('frame:*');\n const redisFrames = [];\n for (const key of redisKeys.slice(0, limit)) {\n const data = await redisClient.get(key);\n if (data) {\n const frame = JSON.parse(data);\n frame.source = 'redis';\n frame.tier = 'hot';\n redisFrames.push(frame);\n }\n }\n await redisClient.disconnect();\n results.frames.push(...redisFrames);\n results.sources_checked.push('redis');\n } catch (error: any) {\n results.redis_error = error.message;\n }\n }\n \n // From PostgreSQL (cold tier) - persistent storage\n if ((source === 'all' || source === 'postgresql') && config.databaseUrl) {\n try {\n const pgClient = new Client({ connectionString: config.databaseUrl });\n await pgClient.connect();\n const pgFrames = await pgClient.query(\n 'SELECT *, \\'postgresql\\' as source, \\'cold\\' as tier FROM frames ORDER BY created_at DESC LIMIT $1',\n [limit]\n );\n await pgClient.end();\n results.frames.push(...pgFrames.rows);\n results.sources_checked.push('postgresql');\n results.total_count = pgFrames.rowCount;\n } catch (error: any) {\n results.postgresql_error = error.message;\n }\n }\n \n // Sort by created_at if multiple sources\n if (results.frames.length > 1) {\n results.frames.sort((a: any, b: any) => \n new Date(b.created_at).getTime() - new Date(a.created_at).getTime()\n );\n }\n \n res.json({\n count: results.frames.length,\n frames: results.frames.slice(0, limit),\n metadata: {\n sources_checked: results.sources_checked,\n total_in_postgresql: results.total_count,\n tier_explanation: {\n hot: 'Redis - Recent frames (< 24 hours)',\n cold: 'PostgreSQL - All frames (persistent storage)'\n }\n }\n });\n } catch (error: any) {\n res.status(500).json({\n error: 'Failed to fetch frames',\n message: error.message\n });\n }\n });\n\n // List recent frames (legacy endpoint)\n app.get('/list-frames', async (req, res) => {\n const results: any = { sources: {} };\n \n try {\n // From PostgreSQL\n if (config.databaseUrl) {\n const pgClient = new Client({ connectionString: config.databaseUrl });\n await pgClient.connect();\n const pgFrames = await pgClient.query('SELECT * FROM frames ORDER BY created_at DESC LIMIT 5');\n await pgClient.end();\n results.sources.postgresql = pgFrames.rows;\n }\n \n // From Redis\n if (config.redisUrl) {\n const redisClient = createClient({ url: config.redisUrl });\n await redisClient.connect();\n const redisKeys = await redisClient.keys('frame:*');\n const redisFrames = [];\n for (const key of redisKeys.slice(0, 5)) {\n const data = await redisClient.get(key);\n if (data) redisFrames.push(JSON.parse(data));\n }\n await redisClient.disconnect();\n results.sources.redis = redisFrames;\n }\n \n res.json(results);\n } catch (error: any) {\n res.status(500).json({\n error: 'Failed to list frames',\n message: error.message\n });\n }\n });\n \n // Start server\n app.listen(config.port, '0.0.0.0', () => {\n console.log(`\u2705 Storage Test Server running on port ${config.port}`);\n console.log('\\n\uD83D\uDCCA Available endpoints:');\n console.log(' - GET /test-storage (comprehensive storage test)');\n console.log(' - POST /create-frame (create test frame)');\n console.log(' - GET /list-frames (list recent frames)');\n });\n}\n\nstartServer().catch(error => {\n console.error('Failed to start storage test server:', error);\n process.exit(1);\n});"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,65 +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 { logger } from "../core/monitoring/logger.js";
|
|
6
|
-
import { readFileSync, writeFileSync, existsSync } from "fs";
|
|
7
|
-
import { join } from "path";
|
|
8
|
-
class ConfigService {
|
|
9
|
-
// Using singleton logger from monitoring
|
|
10
|
-
config = {};
|
|
11
|
-
configPath;
|
|
12
|
-
constructor() {
|
|
13
|
-
this.configPath = join(process.cwd(), ".stackmemory", "config.json");
|
|
14
|
-
this.loadConfig();
|
|
15
|
-
}
|
|
16
|
-
loadConfig() {
|
|
17
|
-
try {
|
|
18
|
-
if (existsSync(this.configPath)) {
|
|
19
|
-
const content = readFileSync(this.configPath, "utf-8");
|
|
20
|
-
this.config = JSON.parse(content);
|
|
21
|
-
logger.debug("Loaded configuration", this.config);
|
|
22
|
-
}
|
|
23
|
-
} catch (error) {
|
|
24
|
-
logger.warn("Failed to load configuration, using defaults", error);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
saveConfig() {
|
|
28
|
-
try {
|
|
29
|
-
writeFileSync(this.configPath, JSON.stringify(this.config, null, 2));
|
|
30
|
-
logger.debug("Saved configuration");
|
|
31
|
-
} catch (error) {
|
|
32
|
-
logger.error("Failed to save configuration", error);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
async getConfig() {
|
|
36
|
-
return this.config;
|
|
37
|
-
}
|
|
38
|
-
async updateConfig(updates) {
|
|
39
|
-
this.config = {
|
|
40
|
-
...this.config,
|
|
41
|
-
...updates
|
|
42
|
-
};
|
|
43
|
-
this.saveConfig();
|
|
44
|
-
}
|
|
45
|
-
async getLinearConfig() {
|
|
46
|
-
return this.config.integrations?.linear || {};
|
|
47
|
-
}
|
|
48
|
-
async updateLinearConfig(updates) {
|
|
49
|
-
if (!this.config.integrations) {
|
|
50
|
-
this.config.integrations = {};
|
|
51
|
-
}
|
|
52
|
-
if (!this.config.integrations.linear) {
|
|
53
|
-
this.config.integrations.linear = {};
|
|
54
|
-
}
|
|
55
|
-
this.config.integrations.linear = {
|
|
56
|
-
...this.config.integrations.linear,
|
|
57
|
-
...updates
|
|
58
|
-
};
|
|
59
|
-
this.saveConfig();
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
export {
|
|
63
|
-
ConfigService
|
|
64
|
-
};
|
|
65
|
-
//# sourceMappingURL=config-service.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/services/config-service.ts"],
|
|
4
|
-
"sourcesContent": ["import { logger } from '../core/monitoring/logger.js';\nimport { readFileSync, writeFileSync, existsSync } from 'fs';\nimport { join } from 'path';\n\nexport interface StackMemoryConfig {\n version?: string;\n projectId?: string;\n integrations?: {\n linear?: {\n enabled?: boolean;\n apiKey?: string;\n teamId?: string;\n projectId?: string;\n syncInterval?: number;\n webhookSecret?: string;\n };\n };\n webhook?: {\n port?: number;\n host?: string;\n ngrokSubdomain?: string;\n };\n features?: {\n autoSync?: boolean;\n realTimeSync?: boolean;\n conflictResolution?: 'manual' | 'auto' | 'prompt';\n };\n}\n\nexport class ConfigService {\n // Using singleton logger from monitoring\n private config: StackMemoryConfig = {};\n private configPath: string;\n\n constructor() {\n // Use singleton logger\n this.configPath = join(process.cwd(), '.stackmemory', 'config.json');\n this.loadConfig();\n }\n\n private loadConfig(): void {\n try {\n if (existsSync(this.configPath)) {\n const content = readFileSync(this.configPath, 'utf-8');\n this.config = JSON.parse(content);\n logger.debug('Loaded configuration', this.config);\n }\n } catch (error: unknown) {\n logger.warn('Failed to load configuration, using defaults', error);\n }\n }\n\n private saveConfig(): void {\n try {\n writeFileSync(this.configPath, JSON.stringify(this.config, null, 2));\n logger.debug('Saved configuration');\n } catch (error: unknown) {\n logger.error('Failed to save configuration', error);\n }\n }\n\n public async getConfig(): Promise<StackMemoryConfig> {\n return this.config;\n }\n\n public async updateConfig(\n updates: Partial<StackMemoryConfig>\n ): Promise<void> {\n this.config = {\n ...this.config,\n ...updates,\n };\n this.saveConfig();\n }\n\n public async getLinearConfig() {\n return this.config.integrations?.linear || {};\n }\n\n public async updateLinearConfig(\n updates: Record<string, unknown>\n ): Promise<void> {\n if (!this.config.integrations) {\n this.config.integrations = {};\n }\n if (!this.config.integrations.linear) {\n this.config.integrations.linear = {};\n }\n\n this.config.integrations.linear = {\n ...this.config.integrations.linear,\n ...updates,\n };\n\n this.saveConfig();\n }\n}\n"],
|
|
5
|
-
"mappings": ";;;;AAAA,SAAS,cAAc;AACvB,SAAS,cAAc,eAAe,kBAAkB;AACxD,SAAS,YAAY;AA2Bd,MAAM,cAAc;AAAA;AAAA,EAEjB,SAA4B,CAAC;AAAA,EAC7B;AAAA,EAER,cAAc;AAEZ,SAAK,aAAa,KAAK,QAAQ,IAAI,GAAG,gBAAgB,aAAa;AACnE,SAAK,WAAW;AAAA,EAClB;AAAA,EAEQ,aAAmB;AACzB,QAAI;AACF,UAAI,WAAW,KAAK,UAAU,GAAG;AAC/B,cAAM,UAAU,aAAa,KAAK,YAAY,OAAO;AACrD,aAAK,SAAS,KAAK,MAAM,OAAO;AAChC,eAAO,MAAM,wBAAwB,KAAK,MAAM;AAAA,MAClD;AAAA,IACF,SAAS,OAAgB;AACvB,aAAO,KAAK,gDAAgD,KAAK;AAAA,IACnE;AAAA,EACF;AAAA,EAEQ,aAAmB;AACzB,QAAI;AACF,oBAAc,KAAK,YAAY,KAAK,UAAU,KAAK,QAAQ,MAAM,CAAC,CAAC;AACnE,aAAO,MAAM,qBAAqB;AAAA,IACpC,SAAS,OAAgB;AACvB,aAAO,MAAM,gCAAgC,KAAK;AAAA,IACpD;AAAA,EACF;AAAA,EAEA,MAAa,YAAwC;AACnD,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAa,aACX,SACe;AACf,SAAK,SAAS;AAAA,MACZ,GAAG,KAAK;AAAA,MACR,GAAG;AAAA,IACL;AACA,SAAK,WAAW;AAAA,EAClB;AAAA,EAEA,MAAa,kBAAkB;AAC7B,WAAO,KAAK,OAAO,cAAc,UAAU,CAAC;AAAA,EAC9C;AAAA,EAEA,MAAa,mBACX,SACe;AACf,QAAI,CAAC,KAAK,OAAO,cAAc;AAC7B,WAAK,OAAO,eAAe,CAAC;AAAA,IAC9B;AACA,QAAI,CAAC,KAAK,OAAO,aAAa,QAAQ;AACpC,WAAK,OAAO,aAAa,SAAS,CAAC;AAAA,IACrC;AAEA,SAAK,OAAO,aAAa,SAAS;AAAA,MAChC,GAAG,KAAK,OAAO,aAAa;AAAA,MAC5B,GAAG;AAAA,IACL;AAEA,SAAK,WAAW;AAAA,EAClB;AACF;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|