@stackmemoryai/stackmemory 0.5.59 → 0.5.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +105 -1
- package/dist/src/cli/claude-sm.js +130 -50
- package/dist/src/cli/claude-sm.js.map +2 -2
- package/dist/src/cli/index.js +18 -3
- package/dist/src/cli/index.js.map +3 -3
- package/dist/src/core/extensions/custom-tools.js +567 -0
- package/dist/src/core/extensions/custom-tools.js.map +7 -0
- package/dist/src/core/extensions/index.js +55 -0
- package/dist/src/core/extensions/index.js.map +7 -0
- package/dist/src/core/extensions/loader.js +709 -0
- package/dist/src/core/extensions/loader.js.map +7 -0
- package/dist/src/core/extensions/plugin-system.js +506 -0
- package/dist/src/core/extensions/plugin-system.js.map +7 -0
- package/dist/src/core/extensions/provider-adapter.js +617 -0
- package/dist/src/core/extensions/provider-adapter.js.map +7 -0
- package/dist/src/core/extensions/sandbox-runtime.js +664 -0
- package/dist/src/core/extensions/sandbox-runtime.js.map +7 -0
- package/dist/src/core/storage/chromadb-adapter.js +32 -6
- package/dist/src/core/storage/chromadb-adapter.js.map +2 -2
- package/dist/src/skills/repo-ingestion-skill.js +35 -12
- package/dist/src/skills/repo-ingestion-skill.js.map +2 -2
- package/package.json +11 -7
- package/scripts/background-sync-manager.js +145 -83
- package/scripts/claude-sm-autostart.js +17 -12
- package/scripts/gepa/README.md +275 -0
- package/scripts/gepa/config.json +53 -0
- package/scripts/gepa/evals/coding-tasks.jsonl +5 -0
- package/scripts/gepa/evals/fixtures/buggy-loop.js +18 -0
- package/scripts/gepa/evals/fixtures/callback-hell.js +53 -0
- package/scripts/gepa/generations/gen-000/baseline.md +124 -0
- package/scripts/gepa/hooks/auto-optimize.js +494 -0
- package/scripts/gepa/hooks/eval-tracker.js +203 -0
- package/scripts/gepa/hooks/reflect.js +311 -0
- package/scripts/gepa/optimize.js +611 -0
- package/scripts/gepa/state.json +14 -0
- package/scripts/test-pre-publish-quick.sh +1 -1
- package/dist/agents/core/agent-task-manager.js +0 -527
- package/dist/agents/core/agent-task-manager.js.map +0 -7
- package/dist/agents/testing-agent.js +0 -614
- package/dist/agents/testing-agent.js.map +0 -7
- package/dist/agents/verifiers/base-verifier.js +0 -133
- package/dist/agents/verifiers/base-verifier.js.map +0 -7
- package/dist/agents/verifiers/formatter-verifier.js +0 -130
- package/dist/agents/verifiers/formatter-verifier.js.map +0 -7
- package/dist/agents/verifiers/llm-judge.js +0 -252
- package/dist/agents/verifiers/llm-judge.js.map +0 -7
- package/dist/cli/auto-detect.js +0 -321
- package/dist/cli/auto-detect.js.map +0 -7
- package/dist/cli/browser-test.js +0 -33
- package/dist/cli/browser-test.js.map +0 -7
- package/dist/cli/claude-sm-danger.js +0 -21
- package/dist/cli/claude-sm-danger.js.map +0 -7
- package/dist/cli/claude-sm.js +0 -1156
- package/dist/cli/claude-sm.js.map +0 -7
- package/dist/cli/codex-sm-danger.js +0 -21
- package/dist/cli/codex-sm-danger.js.map +0 -7
- package/dist/cli/codex-sm.js +0 -349
- package/dist/cli/codex-sm.js.map +0 -7
- package/dist/cli/commands/api.js +0 -232
- package/dist/cli/commands/api.js.map +0 -7
- package/dist/cli/commands/auto-background.js +0 -180
- package/dist/cli/commands/auto-background.js.map +0 -7
- package/dist/cli/commands/cleanup-processes.js +0 -68
- package/dist/cli/commands/cleanup-processes.js.map +0 -7
- package/dist/cli/commands/clear.js +0 -202
- package/dist/cli/commands/clear.js.map +0 -7
- package/dist/cli/commands/config.js +0 -445
- package/dist/cli/commands/config.js.map +0 -7
- package/dist/cli/commands/context-rehydrate.js +0 -751
- package/dist/cli/commands/context-rehydrate.js.map +0 -7
- package/dist/cli/commands/context.js +0 -343
- package/dist/cli/commands/context.js.map +0 -7
- package/dist/cli/commands/daemon.js +0 -392
- package/dist/cli/commands/daemon.js.map +0 -7
- package/dist/cli/commands/dashboard.js +0 -210
- package/dist/cli/commands/dashboard.js.map +0 -7
- package/dist/cli/commands/db.js +0 -147
- package/dist/cli/commands/db.js.map +0 -7
- package/dist/cli/commands/decision.js +0 -266
- package/dist/cli/commands/decision.js.map +0 -7
- package/dist/cli/commands/discovery.js +0 -279
- package/dist/cli/commands/discovery.js.map +0 -7
- package/dist/cli/commands/handoff.js +0 -624
- package/dist/cli/commands/handoff.js.map +0 -7
- package/dist/cli/commands/hooks.js +0 -298
- package/dist/cli/commands/hooks.js.map +0 -7
- package/dist/cli/commands/linear-unified.js +0 -353
- package/dist/cli/commands/linear-unified.js.map +0 -7
- package/dist/cli/commands/linear.js +0 -529
- package/dist/cli/commands/linear.js.map +0 -7
- package/dist/cli/commands/log.js +0 -169
- package/dist/cli/commands/log.js.map +0 -7
- package/dist/cli/commands/login.js +0 -172
- package/dist/cli/commands/login.js.map +0 -7
- package/dist/cli/commands/migrate.js +0 -240
- package/dist/cli/commands/migrate.js.map +0 -7
- package/dist/cli/commands/model.js +0 -533
- package/dist/cli/commands/model.js.map +0 -7
- package/dist/cli/commands/monitor.js +0 -313
- package/dist/cli/commands/monitor.js.map +0 -7
- package/dist/cli/commands/onboard.js +0 -536
- package/dist/cli/commands/onboard.js.map +0 -7
- package/dist/cli/commands/projects.js +0 -199
- package/dist/cli/commands/projects.js.map +0 -7
- package/dist/cli/commands/quality.js +0 -413
- package/dist/cli/commands/quality.js.map +0 -7
- package/dist/cli/commands/ralph.js +0 -909
- package/dist/cli/commands/ralph.js.map +0 -7
- package/dist/cli/commands/retrieval.js +0 -248
- package/dist/cli/commands/retrieval.js.map +0 -7
- package/dist/cli/commands/search.js +0 -173
- package/dist/cli/commands/search.js.map +0 -7
- package/dist/cli/commands/service.js +0 -749
- package/dist/cli/commands/service.js.map +0 -7
- package/dist/cli/commands/session.js +0 -200
- package/dist/cli/commands/session.js.map +0 -7
- package/dist/cli/commands/settings.js +0 -306
- package/dist/cli/commands/settings.js.map +0 -7
- package/dist/cli/commands/setup.js +0 -701
- package/dist/cli/commands/setup.js.map +0 -7
- package/dist/cli/commands/shell.js +0 -249
- package/dist/cli/commands/shell.js.map +0 -7
- package/dist/cli/commands/signup.js +0 -50
- package/dist/cli/commands/signup.js.map +0 -7
- package/dist/cli/commands/skills.js +0 -470
- package/dist/cli/commands/skills.js.map +0 -7
- package/dist/cli/commands/sms-notify.js +0 -795
- package/dist/cli/commands/sms-notify.js.map +0 -7
- package/dist/cli/commands/storage-tier.js +0 -183
- package/dist/cli/commands/storage-tier.js.map +0 -7
- package/dist/cli/commands/storage.js +0 -360
- package/dist/cli/commands/storage.js.map +0 -7
- package/dist/cli/commands/sweep.js +0 -249
- package/dist/cli/commands/sweep.js.map +0 -7
- package/dist/cli/commands/tasks.js +0 -213
- package/dist/cli/commands/tasks.js.map +0 -7
- package/dist/cli/commands/test.js +0 -286
- package/dist/cli/commands/test.js.map +0 -7
- package/dist/cli/commands/workflow.js +0 -142
- package/dist/cli/commands/workflow.js.map +0 -7
- package/dist/cli/commands/worktree.js +0 -319
- package/dist/cli/commands/worktree.js.map +0 -7
- package/dist/cli/index.js +0 -594
- package/dist/cli/index.js.map +0 -7
- package/dist/cli/opencode-sm.js +0 -448
- package/dist/cli/opencode-sm.js.map +0 -7
- package/dist/cli/utils/viewer.js +0 -96
- package/dist/cli/utils/viewer.js.map +0 -7
- package/dist/core/analytics/team-analytics.js +0 -378
- package/dist/core/analytics/team-analytics.js.map +0 -7
- package/dist/core/config/config-manager.js +0 -398
- package/dist/core/config/config-manager.js.map +0 -7
- package/dist/core/config/feature-flags.js +0 -76
- package/dist/core/config/feature-flags.js.map +0 -7
- package/dist/core/config/storage-config.js +0 -115
- package/dist/core/config/storage-config.js.map +0 -7
- package/dist/core/config/types.js +0 -144
- package/dist/core/config/types.js.map +0 -7
- package/dist/core/context/auto-context.js +0 -80
- package/dist/core/context/auto-context.js.map +0 -7
- package/dist/core/context/dual-stack-manager.js +0 -870
- package/dist/core/context/dual-stack-manager.js.map +0 -7
- package/dist/core/context/enhanced-rehydration.js +0 -994
- package/dist/core/context/enhanced-rehydration.js.map +0 -7
- package/dist/core/context/frame-database.js +0 -479
- package/dist/core/context/frame-database.js.map +0 -7
- package/dist/core/context/frame-digest.js +0 -250
- package/dist/core/context/frame-digest.js.map +0 -7
- package/dist/core/context/frame-handoff-manager.js +0 -778
- package/dist/core/context/frame-handoff-manager.js.map +0 -7
- package/dist/core/context/frame-lifecycle-hooks.js +0 -119
- package/dist/core/context/frame-lifecycle-hooks.js.map +0 -7
- package/dist/core/context/frame-manager.js +0 -1069
- package/dist/core/context/frame-manager.js.map +0 -7
- package/dist/core/context/frame-recovery.js +0 -302
- package/dist/core/context/frame-recovery.js.map +0 -7
- package/dist/core/context/frame-stack.js +0 -314
- package/dist/core/context/frame-stack.js.map +0 -7
- package/dist/core/context/frame-types.js +0 -5
- package/dist/core/context/frame-types.js.map +0 -7
- package/dist/core/context/incremental-gc.js +0 -290
- package/dist/core/context/incremental-gc.js.map +0 -7
- package/dist/core/context/index.js +0 -25
- package/dist/core/context/index.js.map +0 -7
- package/dist/core/context/model-aware-compaction.js +0 -623
- package/dist/core/context/model-aware-compaction.js.map +0 -7
- package/dist/core/context/permission-manager.js +0 -185
- package/dist/core/context/permission-manager.js.map +0 -7
- package/dist/core/context/recursive-context-manager.js +0 -592
- package/dist/core/context/recursive-context-manager.js.map +0 -7
- package/dist/core/context/refactored-frame-manager.js +0 -754
- package/dist/core/context/refactored-frame-manager.js.map +0 -7
- package/dist/core/context/shared-context-layer.js +0 -621
- package/dist/core/context/shared-context-layer.js.map +0 -7
- package/dist/core/context/stack-merge-resolver.js +0 -749
- package/dist/core/context/stack-merge-resolver.js.map +0 -7
- package/dist/core/context/validation.js +0 -130
- package/dist/core/context/validation.js.map +0 -7
- package/dist/core/database/batch-operations.js +0 -384
- package/dist/core/database/batch-operations.js.map +0 -7
- package/dist/core/database/connection-pool.js +0 -330
- package/dist/core/database/connection-pool.js.map +0 -7
- package/dist/core/database/database-adapter.js +0 -60
- package/dist/core/database/database-adapter.js.map +0 -7
- package/dist/core/database/migration-manager.js +0 -614
- package/dist/core/database/migration-manager.js.map +0 -7
- package/dist/core/database/paradedb-adapter.js +0 -990
- package/dist/core/database/paradedb-adapter.js.map +0 -7
- package/dist/core/database/query-cache.js +0 -298
- package/dist/core/database/query-cache.js.map +0 -7
- package/dist/core/database/query-router.js +0 -430
- package/dist/core/database/query-router.js.map +0 -7
- package/dist/core/database/sqlite-adapter.js +0 -738
- package/dist/core/database/sqlite-adapter.js.map +0 -7
- package/dist/core/digest/enhanced-hybrid-digest.js +0 -277
- package/dist/core/digest/enhanced-hybrid-digest.js.map +0 -7
- package/dist/core/digest/frame-digest-integration.js +0 -176
- package/dist/core/digest/frame-digest-integration.js.map +0 -7
- package/dist/core/digest/hybrid-digest-generator.js +0 -553
- package/dist/core/digest/hybrid-digest-generator.js.map +0 -7
- package/dist/core/digest/index.js +0 -9
- package/dist/core/digest/index.js.map +0 -7
- package/dist/core/digest/types.js +0 -25
- package/dist/core/digest/types.js.map +0 -7
- package/dist/core/errors/error-utils.js +0 -208
- package/dist/core/errors/error-utils.js.map +0 -7
- package/dist/core/errors/index.js +0 -521
- package/dist/core/errors/index.js.map +0 -7
- package/dist/core/errors/recovery.js +0 -269
- package/dist/core/errors/recovery.js.map +0 -7
- package/dist/core/execution/parallel-executor.js +0 -258
- package/dist/core/execution/parallel-executor.js.map +0 -7
- package/dist/core/frame/workflow-templates.js +0 -319
- package/dist/core/frame/workflow-templates.js.map +0 -7
- package/dist/core/merge/conflict-detector.js +0 -431
- package/dist/core/merge/conflict-detector.js.map +0 -7
- package/dist/core/merge/index.js +0 -9
- package/dist/core/merge/index.js.map +0 -7
- package/dist/core/merge/resolution-engine.js +0 -558
- package/dist/core/merge/resolution-engine.js.map +0 -7
- package/dist/core/merge/stack-diff.js +0 -532
- package/dist/core/merge/stack-diff.js.map +0 -7
- package/dist/core/merge/unified-merge-resolver.js +0 -303
- package/dist/core/merge/unified-merge-resolver.js.map +0 -7
- package/dist/core/models/fallback-monitor.js +0 -232
- package/dist/core/models/fallback-monitor.js.map +0 -7
- package/dist/core/models/model-router.js +0 -340
- package/dist/core/models/model-router.js.map +0 -7
- package/dist/core/monitoring/error-handler.js +0 -49
- package/dist/core/monitoring/error-handler.js.map +0 -7
- package/dist/core/monitoring/logger.js +0 -202
- package/dist/core/monitoring/logger.js.map +0 -7
- package/dist/core/monitoring/metrics.js +0 -172
- package/dist/core/monitoring/metrics.js.map +0 -7
- package/dist/core/monitoring/progress-tracker.js +0 -189
- package/dist/core/monitoring/progress-tracker.js.map +0 -7
- package/dist/core/monitoring/session-monitor.js +0 -300
- package/dist/core/monitoring/session-monitor.js.map +0 -7
- package/dist/core/performance/context-cache.js +0 -273
- package/dist/core/performance/context-cache.js.map +0 -7
- package/dist/core/performance/index.js +0 -11
- package/dist/core/performance/index.js.map +0 -7
- package/dist/core/performance/lazy-context-loader.js +0 -327
- package/dist/core/performance/lazy-context-loader.js.map +0 -7
- package/dist/core/performance/monitor.js +0 -221
- package/dist/core/performance/monitor.js.map +0 -7
- package/dist/core/performance/optimized-frame-context.js +0 -345
- package/dist/core/performance/optimized-frame-context.js.map +0 -7
- package/dist/core/performance/performance-benchmark.js +0 -277
- package/dist/core/performance/performance-benchmark.js.map +0 -7
- package/dist/core/performance/performance-profiler.js +0 -370
- package/dist/core/performance/performance-profiler.js.map +0 -7
- package/dist/core/performance/streaming-jsonl-parser.js +0 -195
- package/dist/core/performance/streaming-jsonl-parser.js.map +0 -7
- package/dist/core/persistence/postgres-adapter.js +0 -349
- package/dist/core/persistence/postgres-adapter.js.map +0 -7
- package/dist/core/projects/project-isolation.js +0 -201
- package/dist/core/projects/project-isolation.js.map +0 -7
- package/dist/core/projects/project-manager.js +0 -697
- package/dist/core/projects/project-manager.js.map +0 -7
- package/dist/core/query/query-parser.js +0 -370
- package/dist/core/query/query-parser.js.map +0 -7
- package/dist/core/query/query-templates.js +0 -321
- package/dist/core/query/query-templates.js.map +0 -7
- package/dist/core/retrieval/context-retriever.js +0 -479
- package/dist/core/retrieval/context-retriever.js.map +0 -7
- package/dist/core/retrieval/graph-retrieval.js +0 -662
- package/dist/core/retrieval/graph-retrieval.js.map +0 -7
- package/dist/core/retrieval/hierarchical-retrieval.js +0 -656
- package/dist/core/retrieval/hierarchical-retrieval.js.map +0 -7
- package/dist/core/retrieval/index.js +0 -8
- package/dist/core/retrieval/index.js.map +0 -7
- package/dist/core/retrieval/llm-context-retrieval.js +0 -613
- package/dist/core/retrieval/llm-context-retrieval.js.map +0 -7
- package/dist/core/retrieval/llm-provider.js +0 -151
- package/dist/core/retrieval/llm-provider.js.map +0 -7
- package/dist/core/retrieval/retrieval-audit.js +0 -236
- package/dist/core/retrieval/retrieval-audit.js.map +0 -7
- package/dist/core/retrieval/retrieval-benchmarks.js +0 -521
- package/dist/core/retrieval/retrieval-benchmarks.js.map +0 -7
- package/dist/core/retrieval/summary-generator.js +0 -589
- package/dist/core/retrieval/summary-generator.js.map +0 -7
- package/dist/core/retrieval/types.js +0 -21
- package/dist/core/retrieval/types.js.map +0 -7
- package/dist/core/security/index.js +0 -35
- package/dist/core/security/index.js.map +0 -7
- package/dist/core/security/input-sanitizer.js +0 -321
- package/dist/core/security/input-sanitizer.js.map +0 -7
- package/dist/core/session/clear-survival.js +0 -465
- package/dist/core/session/clear-survival.js.map +0 -7
- package/dist/core/session/enhanced-handoff.js +0 -792
- package/dist/core/session/enhanced-handoff.js.map +0 -7
- package/dist/core/session/handoff-generator.js +0 -343
- package/dist/core/session/handoff-generator.js.map +0 -7
- package/dist/core/session/index.js +0 -15
- package/dist/core/session/index.js.map +0 -7
- package/dist/core/session/session-manager.js +0 -347
- package/dist/core/session/session-manager.js.map +0 -7
- package/dist/core/skills/index.js +0 -7
- package/dist/core/skills/index.js.map +0 -7
- package/dist/core/skills/skill-storage.js +0 -764
- package/dist/core/skills/skill-storage.js.map +0 -7
- package/dist/core/skills/types.js +0 -193
- package/dist/core/skills/types.js.map +0 -7
- package/dist/core/storage/chromadb-adapter.js +0 -354
- package/dist/core/storage/chromadb-adapter.js.map +0 -7
- package/dist/core/storage/infinite-storage.js +0 -510
- package/dist/core/storage/infinite-storage.js.map +0 -7
- package/dist/core/storage/railway-optimized-storage.js +0 -591
- package/dist/core/storage/railway-optimized-storage.js.map +0 -7
- package/dist/core/storage/remote-storage.js +0 -489
- package/dist/core/storage/remote-storage.js.map +0 -7
- package/dist/core/storage/two-tier-storage.js +0 -766
- package/dist/core/storage/two-tier-storage.js.map +0 -7
- package/dist/core/trace/cli-trace-wrapper.js +0 -132
- package/dist/core/trace/cli-trace-wrapper.js.map +0 -7
- package/dist/core/trace/db-trace-wrapper.js +0 -247
- package/dist/core/trace/db-trace-wrapper.js.map +0 -7
- package/dist/core/trace/debug-trace.js +0 -417
- package/dist/core/trace/debug-trace.js.map +0 -7
- package/dist/core/trace/index.js +0 -109
- package/dist/core/trace/index.js.map +0 -7
- package/dist/core/trace/linear-api-wrapper.js +0 -178
- package/dist/core/trace/linear-api-wrapper.js.map +0 -7
- package/dist/core/trace/trace-demo.js +0 -154
- package/dist/core/trace/trace-demo.js.map +0 -7
- package/dist/core/trace/trace-detector.demo.js +0 -142
- package/dist/core/trace/trace-detector.demo.js.map +0 -7
- package/dist/core/trace/trace-detector.js +0 -528
- package/dist/core/trace/trace-detector.js.map +0 -7
- package/dist/core/trace/trace-store.js +0 -345
- package/dist/core/trace/trace-store.js.map +0 -7
- package/dist/core/trace/types.js +0 -77
- package/dist/core/trace/types.js.map +0 -7
- package/dist/core/types.js +0 -5
- package/dist/core/types.js.map +0 -7
- package/dist/core/utils/async-mutex.js +0 -114
- package/dist/core/utils/async-mutex.js.map +0 -7
- package/dist/core/utils/compression.js +0 -83
- package/dist/core/utils/compression.js.map +0 -7
- package/dist/core/utils/update-checker.js +0 -218
- package/dist/core/utils/update-checker.js.map +0 -7
- package/dist/core/worktree/worktree-manager.js +0 -465
- package/dist/core/worktree/worktree-manager.js.map +0 -7
- package/dist/daemon/daemon-config.js +0 -149
- package/dist/daemon/daemon-config.js.map +0 -7
- package/dist/daemon/services/context-service.js +0 -122
- package/dist/daemon/services/context-service.js.map +0 -7
- package/dist/daemon/services/linear-service.js +0 -136
- package/dist/daemon/services/linear-service.js.map +0 -7
- package/dist/daemon/session-daemon.js +0 -312
- package/dist/daemon/session-daemon.js.map +0 -7
- package/dist/daemon/unified-daemon.js +0 -276
- package/dist/daemon/unified-daemon.js.map +0 -7
- package/dist/features/analytics/api/analytics-api.js +0 -287
- package/dist/features/analytics/api/analytics-api.js.map +0 -7
- package/dist/features/analytics/core/analytics-service.js +0 -282
- package/dist/features/analytics/core/analytics-service.js.map +0 -7
- package/dist/features/analytics/index.js +0 -18
- package/dist/features/analytics/index.js.map +0 -7
- package/dist/features/analytics/queries/metrics-queries.js +0 -277
- package/dist/features/analytics/queries/metrics-queries.js.map +0 -7
- package/dist/features/analytics/types/metrics.js +0 -5
- package/dist/features/analytics/types/metrics.js.map +0 -7
- package/dist/features/browser/browser-mcp.js +0 -492
- package/dist/features/browser/browser-mcp.js.map +0 -7
- package/dist/features/sweep/index.js +0 -20
- package/dist/features/sweep/index.js.map +0 -7
- package/dist/features/sweep/prediction-client.js +0 -155
- package/dist/features/sweep/prediction-client.js.map +0 -7
- package/dist/features/sweep/prompt-builder.js +0 -85
- package/dist/features/sweep/prompt-builder.js.map +0 -7
- package/dist/features/sweep/pty-wrapper.js +0 -171
- package/dist/features/sweep/pty-wrapper.js.map +0 -7
- package/dist/features/sweep/state-watcher.js +0 -87
- package/dist/features/sweep/state-watcher.js.map +0 -7
- package/dist/features/sweep/status-bar.js +0 -88
- package/dist/features/sweep/status-bar.js.map +0 -7
- package/dist/features/sweep/sweep-server-manager.js +0 -226
- package/dist/features/sweep/sweep-server-manager.js.map +0 -7
- package/dist/features/sweep/tab-interceptor.js +0 -38
- package/dist/features/sweep/tab-interceptor.js.map +0 -7
- package/dist/features/sweep/types.js +0 -18
- package/dist/features/sweep/types.js.map +0 -7
- package/dist/features/tasks/linear-task-manager.js +0 -487
- package/dist/features/tasks/linear-task-manager.js.map +0 -7
- package/dist/features/tasks/task-aware-context.js +0 -410
- package/dist/features/tasks/task-aware-context.js.map +0 -7
- package/dist/features/tui/simple-monitor.js +0 -116
- package/dist/features/tui/simple-monitor.js.map +0 -7
- package/dist/features/tui/swarm-monitor.js +0 -648
- package/dist/features/tui/swarm-monitor.js.map +0 -7
- package/dist/features/web/client/stores/task-store.js +0 -26
- package/dist/features/web/client/stores/task-store.js.map +0 -7
- package/dist/features/web/server/index.js +0 -194
- package/dist/features/web/server/index.js.map +0 -7
- package/dist/hooks/auto-background.js +0 -151
- package/dist/hooks/auto-background.js.map +0 -7
- package/dist/hooks/claude-code-whatsapp-hook.js +0 -197
- package/dist/hooks/claude-code-whatsapp-hook.js.map +0 -7
- package/dist/hooks/config.js +0 -150
- package/dist/hooks/config.js.map +0 -7
- package/dist/hooks/daemon.js +0 -364
- package/dist/hooks/daemon.js.map +0 -7
- package/dist/hooks/events.js +0 -58
- package/dist/hooks/events.js.map +0 -7
- package/dist/hooks/index.js +0 -12
- package/dist/hooks/index.js.map +0 -7
- package/dist/hooks/linear-task-picker.js +0 -186
- package/dist/hooks/linear-task-picker.js.map +0 -7
- package/dist/hooks/schemas.js +0 -197
- package/dist/hooks/schemas.js.map +0 -7
- package/dist/hooks/secure-fs.js +0 -49
- package/dist/hooks/secure-fs.js.map +0 -7
- package/dist/hooks/security-logger.js +0 -155
- package/dist/hooks/security-logger.js.map +0 -7
- package/dist/hooks/session-summary.js +0 -222
- package/dist/hooks/session-summary.js.map +0 -7
- package/dist/hooks/sms-action-runner.js +0 -371
- package/dist/hooks/sms-action-runner.js.map +0 -7
- package/dist/hooks/sms-notify.js +0 -506
- package/dist/hooks/sms-notify.js.map +0 -7
- package/dist/hooks/sms-watcher.js +0 -93
- package/dist/hooks/sms-watcher.js.map +0 -7
- package/dist/hooks/sms-webhook.js +0 -555
- package/dist/hooks/sms-webhook.js.map +0 -7
- package/dist/hooks/whatsapp-commands.js +0 -479
- package/dist/hooks/whatsapp-commands.js.map +0 -7
- package/dist/hooks/whatsapp-scheduler.js +0 -317
- package/dist/hooks/whatsapp-scheduler.js.map +0 -7
- package/dist/hooks/whatsapp-sync.js +0 -409
- package/dist/hooks/whatsapp-sync.js.map +0 -7
- package/dist/index.js +0 -25
- package/dist/index.js.map +0 -7
- package/dist/integrations/anthropic/client.js +0 -263
- package/dist/integrations/anthropic/client.js.map +0 -7
- package/dist/integrations/claude-code/agent-bridge.js +0 -768
- package/dist/integrations/claude-code/agent-bridge.js.map +0 -7
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js +0 -459
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +0 -7
- package/dist/integrations/claude-code/lifecycle-hooks.js +0 -254
- package/dist/integrations/claude-code/lifecycle-hooks.js.map +0 -7
- package/dist/integrations/claude-code/post-task-hooks.js +0 -545
- package/dist/integrations/claude-code/post-task-hooks.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client-stub.js +0 -20
- package/dist/integrations/claude-code/subagent-client-stub.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client.js +0 -511
- package/dist/integrations/claude-code/subagent-client.js.map +0 -7
- package/dist/integrations/claude-code/task-coordinator.js +0 -360
- package/dist/integrations/claude-code/task-coordinator.js.map +0 -7
- package/dist/integrations/linear/auth.js +0 -337
- package/dist/integrations/linear/auth.js.map +0 -7
- package/dist/integrations/linear/auto-sync.js +0 -258
- package/dist/integrations/linear/auto-sync.js.map +0 -7
- package/dist/integrations/linear/client.js +0 -634
- package/dist/integrations/linear/client.js.map +0 -7
- package/dist/integrations/linear/config.js +0 -130
- package/dist/integrations/linear/config.js.map +0 -7
- package/dist/integrations/linear/migration.js +0 -361
- package/dist/integrations/linear/migration.js.map +0 -7
- package/dist/integrations/linear/oauth-server.js +0 -454
- package/dist/integrations/linear/oauth-server.js.map +0 -7
- package/dist/integrations/linear/rest-client.js +0 -213
- package/dist/integrations/linear/rest-client.js.map +0 -7
- package/dist/integrations/linear/sync-manager.js +0 -236
- package/dist/integrations/linear/sync-manager.js.map +0 -7
- package/dist/integrations/linear/sync-service.js +0 -231
- package/dist/integrations/linear/sync-service.js.map +0 -7
- package/dist/integrations/linear/sync.js +0 -782
- package/dist/integrations/linear/sync.js.map +0 -7
- package/dist/integrations/linear/types.js +0 -5
- package/dist/integrations/linear/types.js.map +0 -7
- package/dist/integrations/linear/unified-sync.js +0 -589
- package/dist/integrations/linear/unified-sync.js.map +0 -7
- package/dist/integrations/linear/webhook-handler.js +0 -219
- package/dist/integrations/linear/webhook-handler.js.map +0 -7
- package/dist/integrations/linear/webhook-server.js +0 -218
- package/dist/integrations/linear/webhook-server.js.map +0 -7
- package/dist/integrations/linear/webhook.js +0 -291
- package/dist/integrations/linear/webhook.js.map +0 -7
- package/dist/integrations/mcp/handlers/code-execution-handlers.js +0 -266
- package/dist/integrations/mcp/handlers/code-execution-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/context-handlers.js +0 -257
- package/dist/integrations/mcp/handlers/context-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/discovery-handlers.js +0 -497
- package/dist/integrations/mcp/handlers/discovery-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/index.js +0 -166
- package/dist/integrations/mcp/handlers/index.js.map +0 -7
- package/dist/integrations/mcp/handlers/linear-handlers.js +0 -247
- package/dist/integrations/mcp/handlers/linear-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/skill-handlers.js +0 -529
- package/dist/integrations/mcp/handlers/skill-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/task-handlers.js +0 -239
- package/dist/integrations/mcp/handlers/task-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/trace-handlers.js +0 -308
- package/dist/integrations/mcp/handlers/trace-handlers.js.map +0 -7
- package/dist/integrations/mcp/index.js +0 -23
- package/dist/integrations/mcp/index.js.map +0 -7
- package/dist/integrations/mcp/middleware/tool-scoring.js +0 -356
- package/dist/integrations/mcp/middleware/tool-scoring.js.map +0 -7
- package/dist/integrations/mcp/refactored-server.js +0 -374
- package/dist/integrations/mcp/refactored-server.js.map +0 -7
- package/dist/integrations/mcp/remote-server.js +0 -682
- package/dist/integrations/mcp/remote-server.js.map +0 -7
- package/dist/integrations/mcp/schemas.js +0 -147
- package/dist/integrations/mcp/schemas.js.map +0 -7
- package/dist/integrations/mcp/server.js +0 -1975
- package/dist/integrations/mcp/server.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions-code.js +0 -125
- package/dist/integrations/mcp/tool-definitions-code.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions.js +0 -702
- package/dist/integrations/mcp/tool-definitions.js.map +0 -7
- package/dist/integrations/mcp/trace-test.js +0 -48
- package/dist/integrations/mcp/trace-test.js.map +0 -7
- package/dist/integrations/pg-aiguide/embedding-provider.js +0 -189
- package/dist/integrations/pg-aiguide/embedding-provider.js.map +0 -7
- package/dist/integrations/pg-aiguide/semantic-search.js +0 -187
- package/dist/integrations/pg-aiguide/semantic-search.js.map +0 -7
- package/dist/integrations/pg-aiguide/timescale-analytics.js +0 -224
- package/dist/integrations/pg-aiguide/timescale-analytics.js.map +0 -7
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js +0 -860
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +0 -7
- package/dist/integrations/ralph/context/context-budget-manager.js +0 -301
- package/dist/integrations/ralph/context/context-budget-manager.js.map +0 -7
- package/dist/integrations/ralph/context/stackmemory-context-loader.js +0 -360
- package/dist/integrations/ralph/context/stackmemory-context-loader.js.map +0 -7
- package/dist/integrations/ralph/coordination/enhanced-coordination.js +0 -410
- package/dist/integrations/ralph/coordination/enhanced-coordination.js.map +0 -7
- package/dist/integrations/ralph/index.js +0 -18
- package/dist/integrations/ralph/index.js.map +0 -7
- package/dist/integrations/ralph/learning/pattern-learner.js +0 -401
- package/dist/integrations/ralph/learning/pattern-learner.js.map +0 -7
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js +0 -448
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js +0 -294
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-registry.js +0 -108
- package/dist/integrations/ralph/monitoring/swarm-registry.js.map +0 -7
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js +0 -463
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +0 -7
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js +0 -400
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js.map +0 -7
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js +0 -473
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js.map +0 -7
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js +0 -388
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js.map +0 -7
- package/dist/integrations/ralph/performance/performance-optimizer.js +0 -358
- package/dist/integrations/ralph/performance/performance-optimizer.js.map +0 -7
- package/dist/integrations/ralph/ralph-integration-demo.js +0 -182
- package/dist/integrations/ralph/ralph-integration-demo.js.map +0 -7
- package/dist/integrations/ralph/recovery/crash-recovery.js +0 -462
- package/dist/integrations/ralph/recovery/crash-recovery.js.map +0 -7
- package/dist/integrations/ralph/state/state-reconciler.js +0 -404
- package/dist/integrations/ralph/state/state-reconciler.js.map +0 -7
- package/dist/integrations/ralph/swarm/git-workflow-manager.js +0 -428
- package/dist/integrations/ralph/swarm/git-workflow-manager.js.map +0 -7
- package/dist/integrations/ralph/swarm/swarm-coordinator.js +0 -996
- package/dist/integrations/ralph/swarm/swarm-coordinator.js.map +0 -7
- package/dist/integrations/ralph/types.js +0 -5
- package/dist/integrations/ralph/types.js.map +0 -7
- package/dist/integrations/ralph/visualization/ralph-debugger.js +0 -585
- package/dist/integrations/ralph/visualization/ralph-debugger.js.map +0 -7
- package/dist/mcp/stackmemory-mcp-server.js +0 -554
- package/dist/mcp/stackmemory-mcp-server.js.map +0 -7
- package/dist/middleware/exponential-rate-limiter.js +0 -289
- package/dist/middleware/exponential-rate-limiter.js.map +0 -7
- package/dist/models/user.model.js +0 -358
- package/dist/models/user.model.js.map +0 -7
- package/dist/servers/production/auth-middleware.js +0 -528
- package/dist/servers/production/auth-middleware.js.map +0 -7
- package/dist/servers/railway/config.js +0 -55
- package/dist/servers/railway/config.js.map +0 -7
- package/dist/servers/railway/index-enhanced.js +0 -160
- package/dist/servers/railway/index-enhanced.js.map +0 -7
- package/dist/servers/railway/index.js +0 -1349
- package/dist/servers/railway/index.js.map +0 -7
- package/dist/servers/railway/simple.js +0 -64
- package/dist/servers/railway/simple.js.map +0 -7
- package/dist/servers/railway/storage-test.js +0 -459
- package/dist/servers/railway/storage-test.js.map +0 -7
- package/dist/services/config-service.js +0 -65
- package/dist/services/config-service.js.map +0 -7
- package/dist/services/context-service.js +0 -194
- package/dist/services/context-service.js.map +0 -7
- package/dist/skills/api-discovery.js +0 -354
- package/dist/skills/api-discovery.js.map +0 -7
- package/dist/skills/api-skill.js +0 -475
- package/dist/skills/api-skill.js.map +0 -7
- package/dist/skills/claude-skills.js +0 -1061
- package/dist/skills/claude-skills.js.map +0 -7
- package/dist/skills/dashboard-launcher.js +0 -216
- package/dist/skills/dashboard-launcher.js.map +0 -7
- package/dist/skills/recursive-agent-orchestrator.js +0 -575
- package/dist/skills/recursive-agent-orchestrator.js.map +0 -7
- package/dist/skills/repo-ingestion-skill.js +0 -609
- package/dist/skills/repo-ingestion-skill.js.map +0 -7
- package/dist/skills/security-secrets-scanner.js +0 -284
- package/dist/skills/security-secrets-scanner.js.map +0 -7
- package/dist/skills/unified-rlm-orchestrator.js +0 -404
- package/dist/skills/unified-rlm-orchestrator.js.map +0 -7
- package/dist/types/task.js +0 -5
- package/dist/types/task.js.map +0 -7
- package/dist/utils/env.js +0 -50
- package/dist/utils/env.js.map +0 -7
- package/dist/utils/formatting.js +0 -62
- package/dist/utils/formatting.js.map +0 -7
- package/dist/utils/process-cleanup.js +0 -136
- package/dist/utils/process-cleanup.js.map +0 -7
- package/dist/validation/schemas.js +0 -222
- package/dist/validation/schemas.js.map +0 -7
- /package/dist/{core/merge → src/core/extensions}/types.js +0 -0
- /package/dist/{core/merge → src/core/extensions}/types.js.map +0 -0
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/core/performance/streaming-jsonl-parser.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Optimized Streaming JSONL Parser\n * Memory-efficient parsing for large JSONL files with async streaming\n */\n\nimport { createReadStream } from 'fs';\nimport { createInterface } from 'readline';\nimport { Transform, pipeline } from 'stream';\nimport { promisify } from 'util';\nimport { logger } from '../monitoring/logger.js';\n\nconst pipelineAsync = promisify(pipeline);\n\nexport interface ParseOptions {\n maxLineLength?: number;\n batchSize?: number;\n filter?: (obj: any) => boolean;\n transform?: (obj: any) => any;\n onProgress?: (processed: number, total?: number) => void;\n}\n\nexport class StreamingJSONLParser {\n private readonly DEFAULT_BATCH_SIZE = 100;\n private readonly DEFAULT_MAX_LINE_LENGTH = 1024 * 1024; // 1MB per line\n\n /**\n * Stream-parse a JSONL file with batching and backpressure handling\n */\n async *parseStream<T = any>(\n filePath: string,\n options: ParseOptions = {}\n ): AsyncGenerator<T[], void, unknown> {\n const {\n batchSize = this.DEFAULT_BATCH_SIZE,\n maxLineLength = this.DEFAULT_MAX_LINE_LENGTH,\n filter,\n transform,\n onProgress,\n } = options;\n\n const stream = createReadStream(filePath, {\n encoding: 'utf8',\n highWaterMark: 64 * 1024, // 64KB chunks\n });\n\n const rl = createInterface({\n input: stream,\n crlfDelay: Infinity,\n historySize: 0, // Disable history for memory efficiency\n });\n\n let batch: T[] = [];\n let lineCount = 0;\n let processedCount = 0;\n let errorCount = 0;\n\n try {\n for await (const line of rl) {\n lineCount++;\n\n if (line.length > maxLineLength) {\n logger.warn('Skipping oversized line', {\n lineNumber: lineCount,\n length: line.length,\n maxLength: maxLineLength,\n });\n errorCount++;\n continue;\n }\n\n if (!line.trim()) continue;\n\n try {\n let obj = JSON.parse(line);\n\n if (filter && !filter(obj)) continue;\n if (transform) obj = transform(obj);\n\n batch.push(obj as T);\n processedCount++;\n\n if (batch.length >= batchSize) {\n yield batch;\n batch = [];\n onProgress?.(processedCount);\n }\n } catch (parseError: unknown) {\n errorCount++;\n logger.debug('Failed to parse JSONL line', {\n lineNumber: lineCount,\n error: parseError,\n preview: line.substring(0, 100),\n });\n }\n }\n\n // Yield remaining items\n if (batch.length > 0) {\n yield batch;\n onProgress?.(processedCount);\n }\n } finally {\n rl.close();\n stream.destroy();\n\n logger.debug('JSONL parsing complete', {\n filePath,\n totalLines: lineCount,\n processed: processedCount,\n errors: errorCount,\n });\n }\n }\n\n /**\n * Parse entire file into memory (use for smaller files)\n */\n async parseAll<T = any>(\n filePath: string,\n options: Omit<ParseOptions, 'batchSize'> = {}\n ): Promise<T[]> {\n const results: T[] = [];\n\n for await (const batch of this.parseStream<T>(filePath, {\n ...options,\n batchSize: Number.MAX_SAFE_INTEGER,\n })) {\n results.push(...batch);\n }\n\n return results;\n }\n\n /**\n * Process JSONL file with a custom processor function\n */\n async process<T = any, R = void>(\n filePath: string,\n processor: (items: T[]) => Promise<R>,\n options: ParseOptions = {}\n ): Promise<R[]> {\n const results: R[] = [];\n\n for await (const batch of this.parseStream<T>(filePath, options)) {\n const result = await processor(batch);\n results.push(result);\n }\n\n return results;\n }\n\n /**\n * Create a transform stream for JSONL parsing\n */\n createTransformStream<T = any>(options: ParseOptions = {}): Transform {\n const {\n filter,\n transform,\n maxLineLength = this.DEFAULT_MAX_LINE_LENGTH,\n } = options;\n let buffer = '';\n let lineCount = 0;\n\n return new Transform({\n objectMode: true,\n transform(chunk: Buffer | string, encoding, callback) {\n buffer += chunk.toString();\n const lines = buffer.split('\\n');\n\n // Keep incomplete line in buffer\n buffer = lines.pop() || '';\n\n for (const line of lines) {\n lineCount++;\n\n if (!line.trim()) continue;\n if (line.length > maxLineLength) {\n logger.warn('Skipping oversized line in transform', { lineCount });\n continue;\n }\n\n try {\n let obj = JSON.parse(line);\n\n if (filter && !filter(obj)) continue;\n if (transform) obj = transform(obj);\n\n this.push(obj);\n } catch (error: unknown) {\n logger.debug('Transform parse error', { lineCount, error });\n }\n }\n\n callback();\n },\n\n flush(callback) {\n // Process any remaining data\n if (buffer.trim()) {\n try {\n let obj = JSON.parse(buffer);\n if (!filter || filter(obj)) {\n if (transform) obj = transform(obj);\n this.push(obj);\n }\n } catch (error: unknown) {\n logger.debug('Flush parse error', { error });\n }\n }\n callback();\n },\n });\n }\n\n /**\n * Count lines in JSONL file without parsing\n */\n async countLines(filePath: string): Promise<number> {\n const stream = createReadStream(filePath, { encoding: 'utf8' });\n const rl = createInterface({ input: stream, historySize: 0 });\n\n let count = 0;\n for await (const _ of rl) {\n count++;\n }\n\n return count;\n }\n\n /**\n * Sample random lines from JSONL file\n */\n async *sampleLines<T = any>(\n filePath: string,\n sampleRate: number,\n options: Omit<ParseOptions, 'batchSize'> = {}\n ): AsyncGenerator<T, void, unknown> {\n if (sampleRate <= 0 || sampleRate > 1) {\n throw new Error('Sample rate must be between 0 and 1');\n }\n\n for await (const batch of this.parseStream<T>(filePath, options)) {\n for (const item of batch) {\n if (Math.random() < sampleRate) {\n yield item;\n }\n }\n }\n }\n}\n"],
|
|
5
|
-
"mappings": ";;;;AAKA,SAAS,wBAAwB;AACjC,SAAS,uBAAuB;AAChC,SAAS,WAAW,gBAAgB;AACpC,SAAS,iBAAiB;AAC1B,SAAS,cAAc;AAEvB,MAAM,gBAAgB,UAAU,QAAQ;AAUjC,MAAM,qBAAqB;AAAA,EACf,qBAAqB;AAAA,EACrB,0BAA0B,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA,EAKlD,OAAO,YACL,UACA,UAAwB,CAAC,GACW;AACpC,UAAM;AAAA,MACJ,YAAY,KAAK;AAAA,MACjB,gBAAgB,KAAK;AAAA,MACrB;AAAA,MACA;AAAA,MACA;AAAA,IACF,IAAI;AAEJ,UAAM,SAAS,iBAAiB,UAAU;AAAA,MACxC,UAAU;AAAA,MACV,eAAe,KAAK;AAAA;AAAA,IACtB,CAAC;AAED,UAAM,KAAK,gBAAgB;AAAA,MACzB,OAAO;AAAA,MACP,WAAW;AAAA,MACX,aAAa;AAAA;AAAA,IACf,CAAC;AAED,QAAI,QAAa,CAAC;AAClB,QAAI,YAAY;AAChB,QAAI,iBAAiB;AACrB,QAAI,aAAa;AAEjB,QAAI;AACF,uBAAiB,QAAQ,IAAI;AAC3B;AAEA,YAAI,KAAK,SAAS,eAAe;AAC/B,iBAAO,KAAK,2BAA2B;AAAA,YACrC,YAAY;AAAA,YACZ,QAAQ,KAAK;AAAA,YACb,WAAW;AAAA,UACb,CAAC;AACD;AACA;AAAA,QACF;AAEA,YAAI,CAAC,KAAK,KAAK,EAAG;AAElB,YAAI;AACF,cAAI,MAAM,KAAK,MAAM,IAAI;AAEzB,cAAI,UAAU,CAAC,OAAO,GAAG,EAAG;AAC5B,cAAI,UAAW,OAAM,UAAU,GAAG;AAElC,gBAAM,KAAK,GAAQ;AACnB;AAEA,cAAI,MAAM,UAAU,WAAW;AAC7B,kBAAM;AACN,oBAAQ,CAAC;AACT,yBAAa,cAAc;AAAA,UAC7B;AAAA,QACF,SAAS,YAAqB;AAC5B;AACA,iBAAO,MAAM,8BAA8B;AAAA,YACzC,YAAY;AAAA,YACZ,OAAO;AAAA,YACP,SAAS,KAAK,UAAU,GAAG,GAAG;AAAA,UAChC,CAAC;AAAA,QACH;AAAA,MACF;AAGA,UAAI,MAAM,SAAS,GAAG;AACpB,cAAM;AACN,qBAAa,cAAc;AAAA,MAC7B;AAAA,IACF,UAAE;AACA,SAAG,MAAM;AACT,aAAO,QAAQ;AAEf,aAAO,MAAM,0BAA0B;AAAA,QACrC;AAAA,QACA,YAAY;AAAA,QACZ,WAAW;AAAA,QACX,QAAQ;AAAA,MACV,CAAC;AAAA,IACH;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,SACJ,UACA,UAA2C,CAAC,GAC9B;AACd,UAAM,UAAe,CAAC;AAEtB,qBAAiB,SAAS,KAAK,YAAe,UAAU;AAAA,MACtD,GAAG;AAAA,MACH,WAAW,OAAO;AAAA,IACpB,CAAC,GAAG;AACF,cAAQ,KAAK,GAAG,KAAK;AAAA,IACvB;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,QACJ,UACA,WACA,UAAwB,CAAC,GACX;AACd,UAAM,UAAe,CAAC;AAEtB,qBAAiB,SAAS,KAAK,YAAe,UAAU,OAAO,GAAG;AAChE,YAAM,SAAS,MAAM,UAAU,KAAK;AACpC,cAAQ,KAAK,MAAM;AAAA,IACrB;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,sBAA+B,UAAwB,CAAC,GAAc;AACpE,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA,gBAAgB,KAAK;AAAA,IACvB,IAAI;AACJ,QAAI,SAAS;AACb,QAAI,YAAY;AAEhB,WAAO,IAAI,UAAU;AAAA,MACnB,YAAY;AAAA,MACZ,UAAU,OAAwB,UAAU,UAAU;AACpD,kBAAU,MAAM,SAAS;AACzB,cAAM,QAAQ,OAAO,MAAM,IAAI;AAG/B,iBAAS,MAAM,IAAI,KAAK;AAExB,mBAAW,QAAQ,OAAO;AACxB;AAEA,cAAI,CAAC,KAAK,KAAK,EAAG;AAClB,cAAI,KAAK,SAAS,eAAe;AAC/B,mBAAO,KAAK,wCAAwC,EAAE,UAAU,CAAC;AACjE;AAAA,UACF;AAEA,cAAI;AACF,gBAAI,MAAM,KAAK,MAAM,IAAI;AAEzB,gBAAI,UAAU,CAAC,OAAO,GAAG,EAAG;AAC5B,gBAAI,UAAW,OAAM,UAAU,GAAG;AAElC,iBAAK,KAAK,GAAG;AAAA,UACf,SAAS,OAAgB;AACvB,mBAAO,MAAM,yBAAyB,EAAE,WAAW,MAAM,CAAC;AAAA,UAC5D;AAAA,QACF;AAEA,iBAAS;AAAA,MACX;AAAA,MAEA,MAAM,UAAU;AAEd,YAAI,OAAO,KAAK,GAAG;AACjB,cAAI;AACF,gBAAI,MAAM,KAAK,MAAM,MAAM;AAC3B,gBAAI,CAAC,UAAU,OAAO,GAAG,GAAG;AAC1B,kBAAI,UAAW,OAAM,UAAU,GAAG;AAClC,mBAAK,KAAK,GAAG;AAAA,YACf;AAAA,UACF,SAAS,OAAgB;AACvB,mBAAO,MAAM,qBAAqB,EAAE,MAAM,CAAC;AAAA,UAC7C;AAAA,QACF;AACA,iBAAS;AAAA,MACX;AAAA,IACF,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,WAAW,UAAmC;AAClD,UAAM,SAAS,iBAAiB,UAAU,EAAE,UAAU,OAAO,CAAC;AAC9D,UAAM,KAAK,gBAAgB,EAAE,OAAO,QAAQ,aAAa,EAAE,CAAC;AAE5D,QAAI,QAAQ;AACZ,qBAAiB,KAAK,IAAI;AACxB;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,OAAO,YACL,UACA,YACA,UAA2C,CAAC,GACV;AAClC,QAAI,cAAc,KAAK,aAAa,GAAG;AACrC,YAAM,IAAI,MAAM,qCAAqC;AAAA,IACvD;AAEA,qBAAiB,SAAS,KAAK,YAAe,UAAU,OAAO,GAAG;AAChE,iBAAW,QAAQ,OAAO;AACxB,YAAI,KAAK,OAAO,IAAI,YAAY;AAC9B,gBAAM;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACF;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,349 +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 { Pool } from "pg";
|
|
6
|
-
import { logger } from "../monitoring/logger.js";
|
|
7
|
-
class PostgresAdapter {
|
|
8
|
-
pool;
|
|
9
|
-
config;
|
|
10
|
-
isInitialized = false;
|
|
11
|
-
constructor(config) {
|
|
12
|
-
this.config = {
|
|
13
|
-
...config,
|
|
14
|
-
vectorDimensions: config.vectorDimensions || 1536
|
|
15
|
-
// OpenAI ada-002 dimensions
|
|
16
|
-
};
|
|
17
|
-
this.pool = new Pool(this.config);
|
|
18
|
-
}
|
|
19
|
-
async connect() {
|
|
20
|
-
try {
|
|
21
|
-
await this.pool.connect();
|
|
22
|
-
await this.initialize();
|
|
23
|
-
this.isInitialized = true;
|
|
24
|
-
logger.info("PostgreSQL connected successfully");
|
|
25
|
-
} catch (error) {
|
|
26
|
-
logger.error(
|
|
27
|
-
"Failed to connect to PostgreSQL",
|
|
28
|
-
error instanceof Error ? error : void 0
|
|
29
|
-
);
|
|
30
|
-
throw error;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
async disconnect() {
|
|
34
|
-
await this.pool.end();
|
|
35
|
-
this.isInitialized = false;
|
|
36
|
-
logger.info("PostgreSQL disconnected");
|
|
37
|
-
}
|
|
38
|
-
async execute(query, params) {
|
|
39
|
-
try {
|
|
40
|
-
const result = await this.pool.query(query, params);
|
|
41
|
-
return {
|
|
42
|
-
rows: result.rows,
|
|
43
|
-
rowCount: result.rowCount || 0,
|
|
44
|
-
fields: result.fields?.map((f) => ({
|
|
45
|
-
name: f.name,
|
|
46
|
-
type: f.dataTypeID.toString()
|
|
47
|
-
}))
|
|
48
|
-
};
|
|
49
|
-
} catch (error) {
|
|
50
|
-
logger.error(
|
|
51
|
-
"Query execution failed",
|
|
52
|
-
error instanceof Error ? error : new Error(String(error)),
|
|
53
|
-
{ query }
|
|
54
|
-
);
|
|
55
|
-
throw error;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
async beginTransaction() {
|
|
59
|
-
await this.execute("BEGIN");
|
|
60
|
-
}
|
|
61
|
-
async commit() {
|
|
62
|
-
await this.execute("COMMIT");
|
|
63
|
-
}
|
|
64
|
-
async rollback() {
|
|
65
|
-
await this.execute("ROLLBACK");
|
|
66
|
-
}
|
|
67
|
-
isConnected() {
|
|
68
|
-
return this.isInitialized;
|
|
69
|
-
}
|
|
70
|
-
async initialize() {
|
|
71
|
-
await this.createBaseSchema();
|
|
72
|
-
if (this.config.enableTimescale) {
|
|
73
|
-
await this.enableTimescale();
|
|
74
|
-
}
|
|
75
|
-
if (this.config.enablePgvector) {
|
|
76
|
-
await this.enablePgvector();
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
async createBaseSchema() {
|
|
80
|
-
const queries = [
|
|
81
|
-
// Projects table
|
|
82
|
-
`CREATE TABLE IF NOT EXISTS projects (
|
|
83
|
-
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
84
|
-
name VARCHAR(255) NOT NULL,
|
|
85
|
-
path TEXT NOT NULL,
|
|
86
|
-
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
87
|
-
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
88
|
-
metadata JSONB
|
|
89
|
-
)`,
|
|
90
|
-
// Sessions table
|
|
91
|
-
`CREATE TABLE IF NOT EXISTS sessions (
|
|
92
|
-
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
93
|
-
project_id UUID REFERENCES projects(id) ON DELETE CASCADE,
|
|
94
|
-
branch VARCHAR(255),
|
|
95
|
-
started_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
96
|
-
ended_at TIMESTAMP,
|
|
97
|
-
metadata JSONB
|
|
98
|
-
)`,
|
|
99
|
-
// Traces table
|
|
100
|
-
`CREATE TABLE IF NOT EXISTS traces (
|
|
101
|
-
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
102
|
-
session_id UUID REFERENCES sessions(id) ON DELETE CASCADE,
|
|
103
|
-
timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
104
|
-
type VARCHAR(100) NOT NULL,
|
|
105
|
-
data JSONB NOT NULL,
|
|
106
|
-
metadata JSONB
|
|
107
|
-
)`,
|
|
108
|
-
// Context frames table
|
|
109
|
-
`CREATE TABLE IF NOT EXISTS context_frames (
|
|
110
|
-
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
111
|
-
project_id UUID REFERENCES projects(id) ON DELETE CASCADE,
|
|
112
|
-
branch VARCHAR(255),
|
|
113
|
-
content TEXT NOT NULL,
|
|
114
|
-
summary TEXT,
|
|
115
|
-
timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
116
|
-
type VARCHAR(100) NOT NULL,
|
|
117
|
-
metadata JSONB
|
|
118
|
-
)`,
|
|
119
|
-
// Decisions table
|
|
120
|
-
`CREATE TABLE IF NOT EXISTS decisions (
|
|
121
|
-
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
122
|
-
project_id UUID REFERENCES projects(id) ON DELETE CASCADE,
|
|
123
|
-
session_id UUID REFERENCES sessions(id) ON DELETE CASCADE,
|
|
124
|
-
decision TEXT NOT NULL,
|
|
125
|
-
rationale TEXT,
|
|
126
|
-
timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
127
|
-
metadata JSONB
|
|
128
|
-
)`
|
|
129
|
-
];
|
|
130
|
-
for (const query of queries) {
|
|
131
|
-
await this.execute(query);
|
|
132
|
-
}
|
|
133
|
-
const indexes = [
|
|
134
|
-
`CREATE INDEX IF NOT EXISTS idx_traces_session_timestamp
|
|
135
|
-
ON traces(session_id, timestamp)`,
|
|
136
|
-
`CREATE INDEX IF NOT EXISTS idx_context_project_branch
|
|
137
|
-
ON context_frames(project_id, branch)`,
|
|
138
|
-
`CREATE INDEX IF NOT EXISTS idx_traces_type
|
|
139
|
-
ON traces(type)`,
|
|
140
|
-
`CREATE INDEX IF NOT EXISTS idx_context_frames_timestamp
|
|
141
|
-
ON context_frames(timestamp)`,
|
|
142
|
-
`CREATE INDEX IF NOT EXISTS idx_decisions_project_session
|
|
143
|
-
ON decisions(project_id, session_id)`
|
|
144
|
-
];
|
|
145
|
-
for (const index of indexes) {
|
|
146
|
-
await this.execute(index);
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
async enableTimescale() {
|
|
150
|
-
try {
|
|
151
|
-
await this.execute("CREATE EXTENSION IF NOT EXISTS timescaledb");
|
|
152
|
-
await this.execute(`
|
|
153
|
-
SELECT create_hypertable('traces', 'timestamp',
|
|
154
|
-
if_not_exists => TRUE,
|
|
155
|
-
chunk_time_interval => INTERVAL '1 day'
|
|
156
|
-
)
|
|
157
|
-
`);
|
|
158
|
-
await this.execute(`
|
|
159
|
-
SELECT create_hypertable('context_frames', 'timestamp',
|
|
160
|
-
if_not_exists => TRUE,
|
|
161
|
-
chunk_time_interval => INTERVAL '7 days'
|
|
162
|
-
)
|
|
163
|
-
`);
|
|
164
|
-
logger.info("TimescaleDB extension enabled");
|
|
165
|
-
} catch (error) {
|
|
166
|
-
logger.warn(
|
|
167
|
-
"Failed to enable TimescaleDB",
|
|
168
|
-
error instanceof Error ? error : void 0
|
|
169
|
-
);
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
async enablePgvector() {
|
|
173
|
-
try {
|
|
174
|
-
await this.execute("CREATE EXTENSION IF NOT EXISTS vector");
|
|
175
|
-
await this.execute(`
|
|
176
|
-
ALTER TABLE context_frames
|
|
177
|
-
ADD COLUMN IF NOT EXISTS embedding vector(${this.config.vectorDimensions})
|
|
178
|
-
`);
|
|
179
|
-
await this.execute(`
|
|
180
|
-
ALTER TABLE traces
|
|
181
|
-
ADD COLUMN IF NOT EXISTS embedding vector(${this.config.vectorDimensions})
|
|
182
|
-
`);
|
|
183
|
-
await this.execute(`
|
|
184
|
-
CREATE INDEX IF NOT EXISTS idx_context_embedding
|
|
185
|
-
ON context_frames
|
|
186
|
-
USING ivfflat (embedding vector_cosine_ops)
|
|
187
|
-
WITH (lists = 100)
|
|
188
|
-
`);
|
|
189
|
-
logger.info("pgvector extension enabled");
|
|
190
|
-
} catch (error) {
|
|
191
|
-
logger.warn(
|
|
192
|
-
"Failed to enable pgvector",
|
|
193
|
-
error instanceof Error ? error : void 0
|
|
194
|
-
);
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
// Data access methods
|
|
198
|
-
async saveTrace(trace) {
|
|
199
|
-
await this.execute(
|
|
200
|
-
`INSERT INTO traces (id, session_id, timestamp, type, data, metadata)
|
|
201
|
-
VALUES ($1, $2, $3, $4, $5, $6)`,
|
|
202
|
-
[
|
|
203
|
-
trace.id,
|
|
204
|
-
trace.sessionId,
|
|
205
|
-
trace.timestamp,
|
|
206
|
-
trace.type,
|
|
207
|
-
JSON.stringify(trace.data),
|
|
208
|
-
trace.metadata ? JSON.stringify(trace.metadata) : null
|
|
209
|
-
]
|
|
210
|
-
);
|
|
211
|
-
}
|
|
212
|
-
async saveContext(context) {
|
|
213
|
-
await this.execute(
|
|
214
|
-
`INSERT INTO context_frames (id, project_id, branch, content, timestamp, type, metadata)
|
|
215
|
-
VALUES ($1, $2, $3, $4, $5, $6, $7)`,
|
|
216
|
-
[
|
|
217
|
-
context.id,
|
|
218
|
-
context.projectId,
|
|
219
|
-
context.branch || null,
|
|
220
|
-
context.content,
|
|
221
|
-
context.timestamp,
|
|
222
|
-
context.type,
|
|
223
|
-
context.metadata ? JSON.stringify(context.metadata) : null
|
|
224
|
-
]
|
|
225
|
-
);
|
|
226
|
-
}
|
|
227
|
-
async getRecentTraces(sessionId, limit = 100) {
|
|
228
|
-
const result = await this.execute(
|
|
229
|
-
`SELECT * FROM traces
|
|
230
|
-
WHERE session_id = $1
|
|
231
|
-
ORDER BY timestamp DESC
|
|
232
|
-
LIMIT $2`,
|
|
233
|
-
[sessionId, limit]
|
|
234
|
-
);
|
|
235
|
-
return result.rows.map((row) => ({
|
|
236
|
-
id: row.id,
|
|
237
|
-
sessionId: row.session_id,
|
|
238
|
-
timestamp: row.timestamp,
|
|
239
|
-
type: row.type,
|
|
240
|
-
data: row.data,
|
|
241
|
-
metadata: row.metadata
|
|
242
|
-
}));
|
|
243
|
-
}
|
|
244
|
-
async getRecentContext(projectId, branch, limit = 50) {
|
|
245
|
-
const query = branch ? `SELECT * FROM context_frames
|
|
246
|
-
WHERE project_id = $1 AND branch = $2
|
|
247
|
-
ORDER BY timestamp DESC
|
|
248
|
-
LIMIT $3` : `SELECT * FROM context_frames
|
|
249
|
-
WHERE project_id = $1
|
|
250
|
-
ORDER BY timestamp DESC
|
|
251
|
-
LIMIT $2`;
|
|
252
|
-
const params = branch ? [projectId, branch, limit] : [projectId, limit];
|
|
253
|
-
const result = await this.execute(query, params);
|
|
254
|
-
return result.rows.map((row) => ({
|
|
255
|
-
id: row.id,
|
|
256
|
-
projectId: row.project_id,
|
|
257
|
-
branch: row.branch,
|
|
258
|
-
content: row.content,
|
|
259
|
-
timestamp: row.timestamp,
|
|
260
|
-
type: row.type,
|
|
261
|
-
metadata: row.metadata
|
|
262
|
-
}));
|
|
263
|
-
}
|
|
264
|
-
// Hybrid SQLite/PostgreSQL migration helper
|
|
265
|
-
async migrateFromSQLite(sqliteDb) {
|
|
266
|
-
logger.info("Starting migration from SQLite to PostgreSQL");
|
|
267
|
-
try {
|
|
268
|
-
await this.beginTransaction();
|
|
269
|
-
const projects = sqliteDb.prepare("SELECT * FROM projects").all();
|
|
270
|
-
for (const project of projects) {
|
|
271
|
-
await this.execute(
|
|
272
|
-
"INSERT INTO projects (id, name, path, created_at, updated_at, metadata) VALUES ($1, $2, $3, $4, $5, $6)",
|
|
273
|
-
[
|
|
274
|
-
project.id,
|
|
275
|
-
project.name,
|
|
276
|
-
project.path,
|
|
277
|
-
project.created_at,
|
|
278
|
-
project.updated_at,
|
|
279
|
-
project.metadata
|
|
280
|
-
]
|
|
281
|
-
);
|
|
282
|
-
}
|
|
283
|
-
const sessions = sqliteDb.prepare("SELECT * FROM sessions").all();
|
|
284
|
-
for (const session of sessions) {
|
|
285
|
-
await this.execute(
|
|
286
|
-
"INSERT INTO sessions (id, project_id, branch, started_at, ended_at, metadata) VALUES ($1, $2, $3, $4, $5, $6)",
|
|
287
|
-
[
|
|
288
|
-
session.id,
|
|
289
|
-
session.project_id,
|
|
290
|
-
session.branch,
|
|
291
|
-
session.started_at,
|
|
292
|
-
session.ended_at,
|
|
293
|
-
session.metadata
|
|
294
|
-
]
|
|
295
|
-
);
|
|
296
|
-
}
|
|
297
|
-
const traceCount = sqliteDb.prepare("SELECT COUNT(*) as count FROM traces").get();
|
|
298
|
-
const batchSize = 1e3;
|
|
299
|
-
for (let offset = 0; offset < traceCount.count; offset += batchSize) {
|
|
300
|
-
const traces = sqliteDb.prepare("SELECT * FROM traces LIMIT ? OFFSET ?").all(batchSize, offset);
|
|
301
|
-
for (const trace of traces) {
|
|
302
|
-
await this.execute(
|
|
303
|
-
"INSERT INTO traces (id, session_id, timestamp, type, data, metadata) VALUES ($1, $2, $3, $4, $5, $6)",
|
|
304
|
-
[
|
|
305
|
-
trace.id,
|
|
306
|
-
trace.session_id,
|
|
307
|
-
trace.timestamp,
|
|
308
|
-
trace.type,
|
|
309
|
-
trace.data,
|
|
310
|
-
trace.metadata
|
|
311
|
-
]
|
|
312
|
-
);
|
|
313
|
-
}
|
|
314
|
-
logger.info(
|
|
315
|
-
`Migrated ${offset + traces.length}/${traceCount.count} traces`
|
|
316
|
-
);
|
|
317
|
-
}
|
|
318
|
-
const contexts = sqliteDb.prepare("SELECT * FROM context_frames").all();
|
|
319
|
-
for (const context of contexts) {
|
|
320
|
-
await this.execute(
|
|
321
|
-
"INSERT INTO context_frames (id, project_id, branch, content, summary, timestamp, type, metadata) VALUES ($1, $2, $3, $4, $5, $6, $7, $8)",
|
|
322
|
-
[
|
|
323
|
-
context.id,
|
|
324
|
-
context.project_id,
|
|
325
|
-
context.branch,
|
|
326
|
-
context.content,
|
|
327
|
-
context.summary,
|
|
328
|
-
context.timestamp,
|
|
329
|
-
context.type,
|
|
330
|
-
context.metadata
|
|
331
|
-
]
|
|
332
|
-
);
|
|
333
|
-
}
|
|
334
|
-
await this.commit();
|
|
335
|
-
logger.info("Migration completed successfully");
|
|
336
|
-
} catch (error) {
|
|
337
|
-
await this.rollback();
|
|
338
|
-
logger.error(
|
|
339
|
-
"Migration failed",
|
|
340
|
-
error instanceof Error ? error : void 0
|
|
341
|
-
);
|
|
342
|
-
throw error;
|
|
343
|
-
}
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
export {
|
|
347
|
-
PostgresAdapter
|
|
348
|
-
};
|
|
349
|
-
//# sourceMappingURL=postgres-adapter.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/core/persistence/postgres-adapter.ts"],
|
|
4
|
-
"sourcesContent": ["import { Pool, PoolConfig, QueryResult as PgQueryResult } from 'pg';\nimport { Database } from 'better-sqlite3';\nimport {\n PersistenceAdapter,\n QueryResult,\n TraceData,\n ContextData,\n} from '../types.js';\nimport { logger } from '../monitoring/logger.js';\n\nexport interface PostgresConfig extends PoolConfig {\n enableTimescale?: boolean;\n enablePgvector?: boolean;\n vectorDimensions?: number;\n}\n\nexport class PostgresAdapter implements PersistenceAdapter {\n private pool: Pool;\n private config: PostgresConfig;\n private isInitialized = false;\n\n constructor(config: PostgresConfig) {\n this.config = {\n ...config,\n vectorDimensions: config.vectorDimensions || 1536, // OpenAI ada-002 dimensions\n };\n this.pool = new Pool(this.config);\n }\n\n async connect(): Promise<void> {\n try {\n await this.pool.connect();\n await this.initialize();\n this.isInitialized = true;\n logger.info('PostgreSQL connected successfully');\n } catch (error: unknown) {\n logger.error(\n 'Failed to connect to PostgreSQL',\n error instanceof Error ? error : undefined\n );\n throw error;\n }\n }\n\n async disconnect(): Promise<void> {\n await this.pool.end();\n this.isInitialized = false;\n logger.info('PostgreSQL disconnected');\n }\n\n async execute(query: string, params?: any[]): Promise<QueryResult> {\n try {\n const result: PgQueryResult = await this.pool.query(query, params);\n return {\n rows: result.rows,\n rowCount: result.rowCount || 0,\n fields: result.fields?.map((f) => ({\n name: f.name,\n type: f.dataTypeID.toString(),\n })),\n };\n } catch (error: unknown) {\n logger.error(\n 'Query execution failed',\n error instanceof Error ? error : new Error(String(error)),\n { query }\n );\n throw error;\n }\n }\n\n async beginTransaction(): Promise<void> {\n await this.execute('BEGIN');\n }\n\n async commit(): Promise<void> {\n await this.execute('COMMIT');\n }\n\n async rollback(): Promise<void> {\n await this.execute('ROLLBACK');\n }\n\n isConnected(): boolean {\n return this.isInitialized;\n }\n\n private async initialize(): Promise<void> {\n // Create base schema\n await this.createBaseSchema();\n\n // Enable extensions if configured\n if (this.config.enableTimescale) {\n await this.enableTimescale();\n }\n if (this.config.enablePgvector) {\n await this.enablePgvector();\n }\n }\n\n private async createBaseSchema(): Promise<void> {\n const queries = [\n // Projects table\n `CREATE TABLE IF NOT EXISTS projects (\n id UUID PRIMARY KEY DEFAULT gen_random_uuid(),\n name VARCHAR(255) NOT NULL,\n path TEXT NOT NULL,\n created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,\n updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,\n metadata JSONB\n )`,\n\n // Sessions table\n `CREATE TABLE IF NOT EXISTS sessions (\n id UUID PRIMARY KEY DEFAULT gen_random_uuid(),\n project_id UUID REFERENCES projects(id) ON DELETE CASCADE,\n branch VARCHAR(255),\n started_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,\n ended_at TIMESTAMP,\n metadata JSONB\n )`,\n\n // Traces table\n `CREATE TABLE IF NOT EXISTS traces (\n id UUID PRIMARY KEY DEFAULT gen_random_uuid(),\n session_id UUID REFERENCES sessions(id) ON DELETE CASCADE,\n timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,\n type VARCHAR(100) NOT NULL,\n data JSONB NOT NULL,\n metadata JSONB\n )`,\n\n // Context frames table\n `CREATE TABLE IF NOT EXISTS context_frames (\n id UUID PRIMARY KEY DEFAULT gen_random_uuid(),\n project_id UUID REFERENCES projects(id) ON DELETE CASCADE,\n branch VARCHAR(255),\n content TEXT NOT NULL,\n summary TEXT,\n timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,\n type VARCHAR(100) NOT NULL,\n metadata JSONB\n )`,\n\n // Decisions table\n `CREATE TABLE IF NOT EXISTS decisions (\n id UUID PRIMARY KEY DEFAULT gen_random_uuid(),\n project_id UUID REFERENCES projects(id) ON DELETE CASCADE,\n session_id UUID REFERENCES sessions(id) ON DELETE CASCADE,\n decision TEXT NOT NULL,\n rationale TEXT,\n timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,\n metadata JSONB\n )`,\n ];\n\n for (const query of queries) {\n await this.execute(query);\n }\n\n // Create indexes separately (PostgreSQL doesn't support inline INDEX in CREATE TABLE)\n const indexes = [\n `CREATE INDEX IF NOT EXISTS idx_traces_session_timestamp \n ON traces(session_id, timestamp)`,\n `CREATE INDEX IF NOT EXISTS idx_context_project_branch \n ON context_frames(project_id, branch)`,\n `CREATE INDEX IF NOT EXISTS idx_traces_type \n ON traces(type)`,\n `CREATE INDEX IF NOT EXISTS idx_context_frames_timestamp \n ON context_frames(timestamp)`,\n `CREATE INDEX IF NOT EXISTS idx_decisions_project_session \n ON decisions(project_id, session_id)`,\n ];\n\n for (const index of indexes) {\n await this.execute(index);\n }\n }\n\n private async enableTimescale(): Promise<void> {\n try {\n await this.execute('CREATE EXTENSION IF NOT EXISTS timescaledb');\n\n // Convert traces to hypertable\n await this.execute(`\n SELECT create_hypertable('traces', 'timestamp',\n if_not_exists => TRUE,\n chunk_time_interval => INTERVAL '1 day'\n )\n `);\n\n // Convert context_frames to hypertable\n await this.execute(`\n SELECT create_hypertable('context_frames', 'timestamp',\n if_not_exists => TRUE,\n chunk_time_interval => INTERVAL '7 days'\n )\n `);\n\n logger.info('TimescaleDB extension enabled');\n } catch (error: unknown) {\n logger.warn(\n 'Failed to enable TimescaleDB',\n error instanceof Error ? error : undefined\n );\n }\n }\n\n private async enablePgvector(): Promise<void> {\n try {\n await this.execute('CREATE EXTENSION IF NOT EXISTS vector');\n\n // Add embedding columns\n await this.execute(`\n ALTER TABLE context_frames \n ADD COLUMN IF NOT EXISTS embedding vector(${this.config.vectorDimensions})\n `);\n\n await this.execute(`\n ALTER TABLE traces \n ADD COLUMN IF NOT EXISTS embedding vector(${this.config.vectorDimensions})\n `);\n\n // Create vector indexes\n await this.execute(`\n CREATE INDEX IF NOT EXISTS idx_context_embedding \n ON context_frames \n USING ivfflat (embedding vector_cosine_ops)\n WITH (lists = 100)\n `);\n\n logger.info('pgvector extension enabled');\n } catch (error: unknown) {\n logger.warn(\n 'Failed to enable pgvector',\n error instanceof Error ? error : undefined\n );\n }\n }\n\n // Data access methods\n async saveTrace(trace: TraceData): Promise<void> {\n await this.execute(\n `INSERT INTO traces (id, session_id, timestamp, type, data, metadata)\n VALUES ($1, $2, $3, $4, $5, $6)`,\n [\n trace.id,\n trace.sessionId,\n trace.timestamp,\n trace.type,\n JSON.stringify(trace.data),\n trace.metadata ? JSON.stringify(trace.metadata) : null,\n ]\n );\n }\n\n async saveContext(context: ContextData): Promise<void> {\n await this.execute(\n `INSERT INTO context_frames (id, project_id, branch, content, timestamp, type, metadata)\n VALUES ($1, $2, $3, $4, $5, $6, $7)`,\n [\n context.id,\n context.projectId,\n context.branch || null,\n context.content,\n context.timestamp,\n context.type,\n context.metadata ? JSON.stringify(context.metadata) : null,\n ]\n );\n }\n\n async getRecentTraces(sessionId: string, limit = 100): Promise<TraceData[]> {\n const result = await this.execute(\n `SELECT * FROM traces \n WHERE session_id = $1 \n ORDER BY timestamp DESC \n LIMIT $2`,\n [sessionId, limit]\n );\n\n return result.rows.map((row: any) => ({\n id: row.id,\n sessionId: row.session_id,\n timestamp: row.timestamp,\n type: row.type,\n data: row.data,\n metadata: row.metadata,\n }));\n }\n\n async getRecentContext(\n projectId: string,\n branch?: string,\n limit = 50\n ): Promise<ContextData[]> {\n const query = branch\n ? `SELECT * FROM context_frames \n WHERE project_id = $1 AND branch = $2 \n ORDER BY timestamp DESC \n LIMIT $3`\n : `SELECT * FROM context_frames \n WHERE project_id = $1 \n ORDER BY timestamp DESC \n LIMIT $2`;\n\n const params = branch ? [projectId, branch, limit] : [projectId, limit];\n const result = await this.execute(query, params);\n\n return result.rows.map((row: any) => ({\n id: row.id,\n projectId: row.project_id,\n branch: row.branch,\n content: row.content,\n timestamp: row.timestamp,\n type: row.type,\n metadata: row.metadata,\n }));\n }\n\n // Hybrid SQLite/PostgreSQL migration helper\n async migrateFromSQLite(sqliteDb: Database): Promise<void> {\n logger.info('Starting migration from SQLite to PostgreSQL');\n\n try {\n await this.beginTransaction();\n\n // Migrate projects\n const projects = sqliteDb\n .prepare('SELECT * FROM projects')\n .all() as any[];\n for (const project of projects) {\n await this.execute(\n 'INSERT INTO projects (id, name, path, created_at, updated_at, metadata) VALUES ($1, $2, $3, $4, $5, $6)',\n [\n project.id,\n project.name,\n project.path,\n project.created_at,\n project.updated_at,\n project.metadata,\n ]\n );\n }\n\n // Migrate sessions\n const sessions = sqliteDb\n .prepare('SELECT * FROM sessions')\n .all() as any[];\n for (const session of sessions) {\n await this.execute(\n 'INSERT INTO sessions (id, project_id, branch, started_at, ended_at, metadata) VALUES ($1, $2, $3, $4, $5, $6)',\n [\n session.id,\n session.project_id,\n session.branch,\n session.started_at,\n session.ended_at,\n session.metadata,\n ]\n );\n }\n\n // Migrate traces in batches\n const traceCount = sqliteDb\n .prepare('SELECT COUNT(*) as count FROM traces')\n .get() as { count: number };\n const batchSize = 1000;\n\n for (let offset = 0; offset < traceCount.count; offset += batchSize) {\n const traces = sqliteDb\n .prepare('SELECT * FROM traces LIMIT ? OFFSET ?')\n .all(batchSize, offset) as any[];\n\n for (const trace of traces) {\n await this.execute(\n 'INSERT INTO traces (id, session_id, timestamp, type, data, metadata) VALUES ($1, $2, $3, $4, $5, $6)',\n [\n trace.id,\n trace.session_id,\n trace.timestamp,\n trace.type,\n trace.data,\n trace.metadata,\n ]\n );\n }\n\n logger.info(\n `Migrated ${offset + traces.length}/${traceCount.count} traces`\n );\n }\n\n // Migrate context frames\n const contexts = sqliteDb\n .prepare('SELECT * FROM context_frames')\n .all() as any[];\n for (const context of contexts) {\n await this.execute(\n 'INSERT INTO context_frames (id, project_id, branch, content, summary, timestamp, type, metadata) VALUES ($1, $2, $3, $4, $5, $6, $7, $8)',\n [\n context.id,\n context.project_id,\n context.branch,\n context.content,\n context.summary,\n context.timestamp,\n context.type,\n context.metadata,\n ]\n );\n }\n\n await this.commit();\n logger.info('Migration completed successfully');\n } catch (error: unknown) {\n await this.rollback();\n logger.error(\n 'Migration failed',\n error instanceof Error ? error : undefined\n );\n throw error;\n }\n }\n}\n"],
|
|
5
|
-
"mappings": ";;;;AAAA,SAAS,YAAsD;AAQ/D,SAAS,cAAc;AAQhB,MAAM,gBAA8C;AAAA,EACjD;AAAA,EACA;AAAA,EACA,gBAAgB;AAAA,EAExB,YAAY,QAAwB;AAClC,SAAK,SAAS;AAAA,MACZ,GAAG;AAAA,MACH,kBAAkB,OAAO,oBAAoB;AAAA;AAAA,IAC/C;AACA,SAAK,OAAO,IAAI,KAAK,KAAK,MAAM;AAAA,EAClC;AAAA,EAEA,MAAM,UAAyB;AAC7B,QAAI;AACF,YAAM,KAAK,KAAK,QAAQ;AACxB,YAAM,KAAK,WAAW;AACtB,WAAK,gBAAgB;AACrB,aAAO,KAAK,mCAAmC;AAAA,IACjD,SAAS,OAAgB;AACvB,aAAO;AAAA,QACL;AAAA,QACA,iBAAiB,QAAQ,QAAQ;AAAA,MACnC;AACA,YAAM;AAAA,IACR;AAAA,EACF;AAAA,EAEA,MAAM,aAA4B;AAChC,UAAM,KAAK,KAAK,IAAI;AACpB,SAAK,gBAAgB;AACrB,WAAO,KAAK,yBAAyB;AAAA,EACvC;AAAA,EAEA,MAAM,QAAQ,OAAe,QAAsC;AACjE,QAAI;AACF,YAAM,SAAwB,MAAM,KAAK,KAAK,MAAM,OAAO,MAAM;AACjE,aAAO;AAAA,QACL,MAAM,OAAO;AAAA,QACb,UAAU,OAAO,YAAY;AAAA,QAC7B,QAAQ,OAAO,QAAQ,IAAI,CAAC,OAAO;AAAA,UACjC,MAAM,EAAE;AAAA,UACR,MAAM,EAAE,WAAW,SAAS;AAAA,QAC9B,EAAE;AAAA,MACJ;AAAA,IACF,SAAS,OAAgB;AACvB,aAAO;AAAA,QACL;AAAA,QACA,iBAAiB,QAAQ,QAAQ,IAAI,MAAM,OAAO,KAAK,CAAC;AAAA,QACxD,EAAE,MAAM;AAAA,MACV;AACA,YAAM;AAAA,IACR;AAAA,EACF;AAAA,EAEA,MAAM,mBAAkC;AACtC,UAAM,KAAK,QAAQ,OAAO;AAAA,EAC5B;AAAA,EAEA,MAAM,SAAwB;AAC5B,UAAM,KAAK,QAAQ,QAAQ;AAAA,EAC7B;AAAA,EAEA,MAAM,WAA0B;AAC9B,UAAM,KAAK,QAAQ,UAAU;AAAA,EAC/B;AAAA,EAEA,cAAuB;AACrB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAc,aAA4B;AAExC,UAAM,KAAK,iBAAiB;AAG5B,QAAI,KAAK,OAAO,iBAAiB;AAC/B,YAAM,KAAK,gBAAgB;AAAA,IAC7B;AACA,QAAI,KAAK,OAAO,gBAAgB;AAC9B,YAAM,KAAK,eAAe;AAAA,IAC5B;AAAA,EACF;AAAA,EAEA,MAAc,mBAAkC;AAC9C,UAAM,UAAU;AAAA;AAAA,MAEd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAUA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAUA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAUA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAYA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASF;AAEA,eAAW,SAAS,SAAS;AAC3B,YAAM,KAAK,QAAQ,KAAK;AAAA,IAC1B;AAGA,UAAM,UAAU;AAAA,MACd;AAAA;AAAA,MAEA;AAAA;AAAA,MAEA;AAAA;AAAA,MAEA;AAAA;AAAA,MAEA;AAAA;AAAA,IAEF;AAEA,eAAW,SAAS,SAAS;AAC3B,YAAM,KAAK,QAAQ,KAAK;AAAA,IAC1B;AAAA,EACF;AAAA,EAEA,MAAc,kBAAiC;AAC7C,QAAI;AACF,YAAM,KAAK,QAAQ,4CAA4C;AAG/D,YAAM,KAAK,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,OAKlB;AAGD,YAAM,KAAK,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,OAKlB;AAED,aAAO,KAAK,+BAA+B;AAAA,IAC7C,SAAS,OAAgB;AACvB,aAAO;AAAA,QACL;AAAA,QACA,iBAAiB,QAAQ,QAAQ;AAAA,MACnC;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAc,iBAAgC;AAC5C,QAAI;AACF,YAAM,KAAK,QAAQ,uCAAuC;AAG1D,YAAM,KAAK,QAAQ;AAAA;AAAA,oDAE2B,KAAK,OAAO,gBAAgB;AAAA,OACzE;AAED,YAAM,KAAK,QAAQ;AAAA;AAAA,oDAE2B,KAAK,OAAO,gBAAgB;AAAA,OACzE;AAGD,YAAM,KAAK,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,OAKlB;AAED,aAAO,KAAK,4BAA4B;AAAA,IAC1C,SAAS,OAAgB;AACvB,aAAO;AAAA,QACL;AAAA,QACA,iBAAiB,QAAQ,QAAQ;AAAA,MACnC;AAAA,IACF;AAAA,EACF;AAAA;AAAA,EAGA,MAAM,UAAU,OAAiC;AAC/C,UAAM,KAAK;AAAA,MACT;AAAA;AAAA,MAEA;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,MAAM;AAAA,QACN,MAAM;AAAA,QACN,KAAK,UAAU,MAAM,IAAI;AAAA,QACzB,MAAM,WAAW,KAAK,UAAU,MAAM,QAAQ,IAAI;AAAA,MACpD;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAM,YAAY,SAAqC;AACrD,UAAM,KAAK;AAAA,MACT;AAAA;AAAA,MAEA;AAAA,QACE,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR,QAAQ,UAAU;AAAA,QAClB,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR,QAAQ,WAAW,KAAK,UAAU,QAAQ,QAAQ,IAAI;AAAA,MACxD;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAM,gBAAgB,WAAmB,QAAQ,KAA2B;AAC1E,UAAM,SAAS,MAAM,KAAK;AAAA,MACxB;AAAA;AAAA;AAAA;AAAA,MAIA,CAAC,WAAW,KAAK;AAAA,IACnB;AAEA,WAAO,OAAO,KAAK,IAAI,CAAC,SAAc;AAAA,MACpC,IAAI,IAAI;AAAA,MACR,WAAW,IAAI;AAAA,MACf,WAAW,IAAI;AAAA,MACf,MAAM,IAAI;AAAA,MACV,MAAM,IAAI;AAAA,MACV,UAAU,IAAI;AAAA,IAChB,EAAE;AAAA,EACJ;AAAA,EAEA,MAAM,iBACJ,WACA,QACA,QAAQ,IACgB;AACxB,UAAM,QAAQ,SACV;AAAA;AAAA;AAAA,qBAIA;AAAA;AAAA;AAAA;AAKJ,UAAM,SAAS,SAAS,CAAC,WAAW,QAAQ,KAAK,IAAI,CAAC,WAAW,KAAK;AACtE,UAAM,SAAS,MAAM,KAAK,QAAQ,OAAO,MAAM;AAE/C,WAAO,OAAO,KAAK,IAAI,CAAC,SAAc;AAAA,MACpC,IAAI,IAAI;AAAA,MACR,WAAW,IAAI;AAAA,MACf,QAAQ,IAAI;AAAA,MACZ,SAAS,IAAI;AAAA,MACb,WAAW,IAAI;AAAA,MACf,MAAM,IAAI;AAAA,MACV,UAAU,IAAI;AAAA,IAChB,EAAE;AAAA,EACJ;AAAA;AAAA,EAGA,MAAM,kBAAkB,UAAmC;AACzD,WAAO,KAAK,8CAA8C;AAE1D,QAAI;AACF,YAAM,KAAK,iBAAiB;AAG5B,YAAM,WAAW,SACd,QAAQ,wBAAwB,EAChC,IAAI;AACP,iBAAW,WAAW,UAAU;AAC9B,cAAM,KAAK;AAAA,UACT;AAAA,UACA;AAAA,YACE,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,UACV;AAAA,QACF;AAAA,MACF;AAGA,YAAM,WAAW,SACd,QAAQ,wBAAwB,EAChC,IAAI;AACP,iBAAW,WAAW,UAAU;AAC9B,cAAM,KAAK;AAAA,UACT;AAAA,UACA;AAAA,YACE,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,UACV;AAAA,QACF;AAAA,MACF;AAGA,YAAM,aAAa,SAChB,QAAQ,sCAAsC,EAC9C,IAAI;AACP,YAAM,YAAY;AAElB,eAAS,SAAS,GAAG,SAAS,WAAW,OAAO,UAAU,WAAW;AACnE,cAAM,SAAS,SACZ,QAAQ,uCAAuC,EAC/C,IAAI,WAAW,MAAM;AAExB,mBAAW,SAAS,QAAQ;AAC1B,gBAAM,KAAK;AAAA,YACT;AAAA,YACA;AAAA,cACE,MAAM;AAAA,cACN,MAAM;AAAA,cACN,MAAM;AAAA,cACN,MAAM;AAAA,cACN,MAAM;AAAA,cACN,MAAM;AAAA,YACR;AAAA,UACF;AAAA,QACF;AAEA,eAAO;AAAA,UACL,YAAY,SAAS,OAAO,MAAM,IAAI,WAAW,KAAK;AAAA,QACxD;AAAA,MACF;AAGA,YAAM,WAAW,SACd,QAAQ,8BAA8B,EACtC,IAAI;AACP,iBAAW,WAAW,UAAU;AAC9B,cAAM,KAAK;AAAA,UACT;AAAA,UACA;AAAA,YACE,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,QAAQ;AAAA,UACV;AAAA,QACF;AAAA,MACF;AAEA,YAAM,KAAK,OAAO;AAClB,aAAO,KAAK,kCAAkC;AAAA,IAChD,SAAS,OAAgB;AACvB,YAAM,KAAK,SAAS;AACpB,aAAO;AAAA,QACL;AAAA,QACA,iBAAiB,QAAQ,QAAQ;AAAA,MACnC;AACA,YAAM;AAAA,IACR;AAAA,EACF;AACF;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,201 +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 { execSync } from "child_process";
|
|
6
|
-
import { createHash } from "crypto";
|
|
7
|
-
import { logger } from "../monitoring/logger.js";
|
|
8
|
-
class ProjectIsolationManager {
|
|
9
|
-
static instance;
|
|
10
|
-
projectCache = /* @__PURE__ */ new Map();
|
|
11
|
-
static getInstance() {
|
|
12
|
-
if (!ProjectIsolationManager.instance) {
|
|
13
|
-
ProjectIsolationManager.instance = new ProjectIsolationManager();
|
|
14
|
-
}
|
|
15
|
-
return ProjectIsolationManager.instance;
|
|
16
|
-
}
|
|
17
|
-
/**
|
|
18
|
-
* Get stable project identification based on git remote URL
|
|
19
|
-
*/
|
|
20
|
-
getProjectIdentification(projectRoot) {
|
|
21
|
-
const cacheKey = projectRoot;
|
|
22
|
-
if (this.projectCache.has(cacheKey)) {
|
|
23
|
-
return this.projectCache.get(cacheKey);
|
|
24
|
-
}
|
|
25
|
-
try {
|
|
26
|
-
const remoteUrl = this.getGitRemoteUrl(projectRoot);
|
|
27
|
-
const gitInfo = this.parseGitRemote(remoteUrl);
|
|
28
|
-
const projectId = this.createStableProjectId(gitInfo.organization, gitInfo.repository);
|
|
29
|
-
const workspaceFilter = this.createWorkspaceFilter(gitInfo.organization, gitInfo.repository, projectRoot);
|
|
30
|
-
const linearConfig = this.getLinearConfiguration(gitInfo.organization, gitInfo.repository, projectRoot);
|
|
31
|
-
const identification = {
|
|
32
|
-
projectId,
|
|
33
|
-
organization: gitInfo.organization,
|
|
34
|
-
repository: gitInfo.repository,
|
|
35
|
-
workspaceFilter,
|
|
36
|
-
linearTeamId: linearConfig.teamId,
|
|
37
|
-
linearOrganization: linearConfig.organization,
|
|
38
|
-
projectPrefix: linearConfig.prefix
|
|
39
|
-
};
|
|
40
|
-
this.projectCache.set(cacheKey, identification);
|
|
41
|
-
logger.info("Project identification created", {
|
|
42
|
-
projectId: identification.projectId,
|
|
43
|
-
workspaceFilter: identification.workspaceFilter,
|
|
44
|
-
linearTeam: identification.linearTeamId
|
|
45
|
-
});
|
|
46
|
-
return identification;
|
|
47
|
-
} catch (error) {
|
|
48
|
-
logger.warn("Could not determine git remote, using fallback identification", { error });
|
|
49
|
-
const fallback = this.createFallbackIdentification(projectRoot);
|
|
50
|
-
this.projectCache.set(cacheKey, fallback);
|
|
51
|
-
return fallback;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
/**
|
|
55
|
-
* Find git repository root and get remote URL
|
|
56
|
-
*/
|
|
57
|
-
getGitRemoteUrl(projectRoot) {
|
|
58
|
-
try {
|
|
59
|
-
const gitRoot = execSync("git rev-parse --show-toplevel", {
|
|
60
|
-
cwd: projectRoot,
|
|
61
|
-
encoding: "utf8",
|
|
62
|
-
timeout: 5e3
|
|
63
|
-
}).trim();
|
|
64
|
-
const result = execSync("git config --get remote.origin.url", {
|
|
65
|
-
cwd: gitRoot,
|
|
66
|
-
encoding: "utf8",
|
|
67
|
-
timeout: 5e3
|
|
68
|
-
});
|
|
69
|
-
return result.trim();
|
|
70
|
-
} catch (error) {
|
|
71
|
-
throw new Error(`Failed to get git remote URL: ${error}`);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
/**
|
|
75
|
-
* Get project name from git repository root directory
|
|
76
|
-
*/
|
|
77
|
-
getProjectNameFromGitRoot(projectRoot) {
|
|
78
|
-
try {
|
|
79
|
-
const gitRoot = execSync("git rev-parse --show-toplevel", {
|
|
80
|
-
cwd: projectRoot,
|
|
81
|
-
encoding: "utf8",
|
|
82
|
-
timeout: 5e3
|
|
83
|
-
}).trim();
|
|
84
|
-
return gitRoot.split("/").pop() || "unknown";
|
|
85
|
-
} catch (error) {
|
|
86
|
-
return projectRoot.split("/").pop() || "unknown";
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
/**
|
|
90
|
-
* Parse git remote URL to extract organization and repository
|
|
91
|
-
*/
|
|
92
|
-
parseGitRemote(remoteUrl) {
|
|
93
|
-
let match = remoteUrl.match(/github\.com[/:]([\w-]+)\/([\w-]+)(?:\.git)?/);
|
|
94
|
-
if (match) {
|
|
95
|
-
return {
|
|
96
|
-
organization: match[1],
|
|
97
|
-
repository: match[2]
|
|
98
|
-
};
|
|
99
|
-
}
|
|
100
|
-
match = remoteUrl.match(/[:/]([\w-]+)\/([\w-]+)(?:\.git)?$/);
|
|
101
|
-
if (match) {
|
|
102
|
-
return {
|
|
103
|
-
organization: match[1],
|
|
104
|
-
repository: match[2]
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
throw new Error(`Could not parse git remote URL: ${remoteUrl}`);
|
|
108
|
-
}
|
|
109
|
-
/**
|
|
110
|
-
* Create stable project ID from organization and repository
|
|
111
|
-
*/
|
|
112
|
-
createStableProjectId(organization, repository) {
|
|
113
|
-
const content = `${organization}/${repository}`;
|
|
114
|
-
const hash = createHash("sha256").update(content).digest("hex");
|
|
115
|
-
return `proj-${hash.substring(0, 12)}`;
|
|
116
|
-
}
|
|
117
|
-
/**
|
|
118
|
-
* Create stable workspace filter using git root folder name
|
|
119
|
-
*/
|
|
120
|
-
createWorkspaceFilter(organization, repository, projectRoot) {
|
|
121
|
-
const projectName = this.getProjectNameFromGitRoot(projectRoot);
|
|
122
|
-
return `${projectName}:${organization}`;
|
|
123
|
-
}
|
|
124
|
-
/**
|
|
125
|
-
* Get Linear configuration based on project
|
|
126
|
-
*/
|
|
127
|
-
getLinearConfiguration(organization, repository, projectRoot) {
|
|
128
|
-
const projectName = projectRoot ? this.getProjectNameFromGitRoot(projectRoot) : repository;
|
|
129
|
-
const projectConfigs = {
|
|
130
|
-
"jonathanpeterwu/stackmemory": {
|
|
131
|
-
teamId: process.env.LINEAR_TEAM_ID || "stackmemory",
|
|
132
|
-
organization: process.env.LINEAR_ORGANIZATION || "stackmemoryai",
|
|
133
|
-
prefix: "SM"
|
|
134
|
-
},
|
|
135
|
-
"Lift-Coefficient/*": {
|
|
136
|
-
teamId: "STA",
|
|
137
|
-
organization: "lift-cl",
|
|
138
|
-
prefix: "STA"
|
|
139
|
-
}
|
|
140
|
-
};
|
|
141
|
-
const exactKey = `${organization}/${repository}`;
|
|
142
|
-
if (projectConfigs[exactKey]) {
|
|
143
|
-
return projectConfigs[exactKey];
|
|
144
|
-
}
|
|
145
|
-
const wildcardKey = `${organization}/*`;
|
|
146
|
-
if (projectConfigs[wildcardKey]) {
|
|
147
|
-
return projectConfigs[wildcardKey];
|
|
148
|
-
}
|
|
149
|
-
const sanitizedProjectName = projectName.replace(/[^a-zA-Z0-9]/g, "");
|
|
150
|
-
return {
|
|
151
|
-
teamId: sanitizedProjectName.toLowerCase(),
|
|
152
|
-
organization: `${organization.toLowerCase()}ai`,
|
|
153
|
-
prefix: sanitizedProjectName.substring(0, 3).toUpperCase()
|
|
154
|
-
};
|
|
155
|
-
}
|
|
156
|
-
/**
|
|
157
|
-
* Create fallback identification for non-git projects
|
|
158
|
-
*/
|
|
159
|
-
createFallbackIdentification(projectRoot) {
|
|
160
|
-
const folderName = projectRoot.split("/").pop() || "unknown";
|
|
161
|
-
const projectId = this.createStableProjectId("local", folderName);
|
|
162
|
-
return {
|
|
163
|
-
projectId,
|
|
164
|
-
organization: "local",
|
|
165
|
-
repository: folderName,
|
|
166
|
-
workspaceFilter: `local:${folderName}`,
|
|
167
|
-
linearTeamId: folderName.toLowerCase().replace(/[^a-z0-9]/g, ""),
|
|
168
|
-
linearOrganization: "local",
|
|
169
|
-
projectPrefix: folderName.substring(0, 3).toUpperCase()
|
|
170
|
-
};
|
|
171
|
-
}
|
|
172
|
-
/**
|
|
173
|
-
* Validate that current project isolation is working
|
|
174
|
-
*/
|
|
175
|
-
validateProjectIsolation(projectRoot) {
|
|
176
|
-
try {
|
|
177
|
-
const identification = this.getProjectIdentification(projectRoot);
|
|
178
|
-
if (!identification.projectId || !identification.workspaceFilter) {
|
|
179
|
-
return false;
|
|
180
|
-
}
|
|
181
|
-
const secondCall = this.getProjectIdentification(projectRoot);
|
|
182
|
-
if (identification.workspaceFilter !== secondCall.workspaceFilter) {
|
|
183
|
-
return false;
|
|
184
|
-
}
|
|
185
|
-
return true;
|
|
186
|
-
} catch (error) {
|
|
187
|
-
logger.error("Project isolation validation failed", { error });
|
|
188
|
-
return false;
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
/**
|
|
192
|
-
* Clear project cache (for testing)
|
|
193
|
-
*/
|
|
194
|
-
clearCache() {
|
|
195
|
-
this.projectCache.clear();
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
export {
|
|
199
|
-
ProjectIsolationManager
|
|
200
|
-
};
|
|
201
|
-
//# sourceMappingURL=project-isolation.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/core/projects/project-isolation.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Project Isolation System\n * Ensures data separation between different projects/organizations\n */\n\nimport { execSync } from 'child_process';\nimport { createHash } from 'crypto';\nimport { logger } from '../monitoring/logger.js';\n\nexport interface ProjectIdentification {\n projectId: string;\n organization: string;\n repository: string;\n workspaceFilter: string;\n linearTeamId?: string;\n linearOrganization?: string;\n projectPrefix: string;\n}\n\nexport class ProjectIsolationManager {\n private static instance: ProjectIsolationManager;\n private projectCache = new Map<string, ProjectIdentification>();\n\n static getInstance(): ProjectIsolationManager {\n if (!ProjectIsolationManager.instance) {\n ProjectIsolationManager.instance = new ProjectIsolationManager();\n }\n return ProjectIsolationManager.instance;\n }\n\n /**\n * Get stable project identification based on git remote URL\n */\n getProjectIdentification(projectRoot: string): ProjectIdentification {\n const cacheKey = projectRoot;\n \n if (this.projectCache.has(cacheKey)) {\n return this.projectCache.get(cacheKey)!;\n }\n\n try {\n // Get git remote URL\n const remoteUrl = this.getGitRemoteUrl(projectRoot);\n const gitInfo = this.parseGitRemote(remoteUrl);\n \n // Create stable project ID from git remote\n const projectId = this.createStableProjectId(gitInfo.organization, gitInfo.repository);\n \n // Create workspace filter (stable across sessions)\n const workspaceFilter = this.createWorkspaceFilter(gitInfo.organization, gitInfo.repository, projectRoot);\n \n // Determine Linear configuration\n const linearConfig = this.getLinearConfiguration(gitInfo.organization, gitInfo.repository, projectRoot);\n \n const identification: ProjectIdentification = {\n projectId,\n organization: gitInfo.organization,\n repository: gitInfo.repository,\n workspaceFilter,\n linearTeamId: linearConfig.teamId,\n linearOrganization: linearConfig.organization,\n projectPrefix: linearConfig.prefix,\n };\n\n this.projectCache.set(cacheKey, identification);\n logger.info('Project identification created', {\n projectId: identification.projectId,\n workspaceFilter: identification.workspaceFilter,\n linearTeam: identification.linearTeamId,\n });\n\n return identification;\n\n } catch (error) {\n // Fallback for non-git projects\n logger.warn('Could not determine git remote, using fallback identification', { error });\n const fallback = this.createFallbackIdentification(projectRoot);\n this.projectCache.set(cacheKey, fallback);\n return fallback;\n }\n }\n\n /**\n * Find git repository root and get remote URL\n */\n private getGitRemoteUrl(projectRoot: string): string {\n try {\n // Find the git root directory (may be parent of current directory)\n const gitRoot = execSync('git rev-parse --show-toplevel', {\n cwd: projectRoot,\n encoding: 'utf8',\n timeout: 5000,\n }).trim();\n\n // Get remote URL from git root\n const result = execSync('git config --get remote.origin.url', {\n cwd: gitRoot,\n encoding: 'utf8',\n timeout: 5000,\n });\n \n return result.trim();\n } catch (error) {\n throw new Error(`Failed to get git remote URL: ${error}`);\n }\n }\n\n /**\n * Get project name from git repository root directory\n */\n private getProjectNameFromGitRoot(projectRoot: string): string {\n try {\n const gitRoot = execSync('git rev-parse --show-toplevel', {\n cwd: projectRoot,\n encoding: 'utf8',\n timeout: 5000,\n }).trim();\n\n // Get the folder name of the git root\n return gitRoot.split('/').pop() || 'unknown';\n } catch (error) {\n // Fallback to current directory name\n return projectRoot.split('/').pop() || 'unknown';\n }\n }\n\n /**\n * Parse git remote URL to extract organization and repository\n */\n private parseGitRemote(remoteUrl: string): { organization: string; repository: string } {\n // Handle GitHub URLs (https and ssh)\n let match = remoteUrl.match(/github\\.com[/:]([\\w-]+)\\/([\\w-]+)(?:\\.git)?/);\n if (match) {\n return {\n organization: match[1],\n repository: match[2],\n };\n }\n\n // Handle other git URLs\n match = remoteUrl.match(/[:/]([\\w-]+)\\/([\\w-]+)(?:\\.git)?$/);\n if (match) {\n return {\n organization: match[1],\n repository: match[2],\n };\n }\n\n throw new Error(`Could not parse git remote URL: ${remoteUrl}`);\n }\n\n /**\n * Create stable project ID from organization and repository\n */\n private createStableProjectId(organization: string, repository: string): string {\n const content = `${organization}/${repository}`;\n const hash = createHash('sha256').update(content).digest('hex');\n return `proj-${hash.substring(0, 12)}`;\n }\n\n /**\n * Create stable workspace filter using git root folder name\n */\n private createWorkspaceFilter(organization: string, repository: string, projectRoot: string): string {\n // Get dynamic project name from git root\n const projectName = this.getProjectNameFromGitRoot(projectRoot);\n \n // Use project name as primary filter, with organization fallback for uniqueness\n return `${projectName}:${organization}`;\n }\n\n /**\n * Get Linear configuration based on project\n */\n private getLinearConfiguration(organization: string, repository: string, projectRoot?: string): {\n teamId?: string;\n organization?: string;\n prefix: string;\n } {\n // Get dynamic project name from git root\n const projectName = projectRoot ? this.getProjectNameFromGitRoot(projectRoot) : repository;\n \n // Project-specific Linear configurations\n const projectConfigs: Record<string, { teamId?: string; organization?: string; prefix: string }> = {\n 'jonathanpeterwu/stackmemory': {\n teamId: process.env.LINEAR_TEAM_ID || 'stackmemory',\n organization: process.env.LINEAR_ORGANIZATION || 'stackmemoryai',\n prefix: 'SM',\n },\n 'Lift-Coefficient/*': {\n teamId: 'STA',\n organization: 'lift-cl',\n prefix: 'STA',\n },\n };\n\n // Check for exact match\n const exactKey = `${organization}/${repository}`;\n if (projectConfigs[exactKey]) {\n return projectConfigs[exactKey];\n }\n\n // Check for organization wildcard match\n const wildcardKey = `${organization}/*`;\n if (projectConfigs[wildcardKey]) {\n return projectConfigs[wildcardKey];\n }\n\n // Default configuration using dynamic project name\n const sanitizedProjectName = projectName.replace(/[^a-zA-Z0-9]/g, '');\n return {\n teamId: sanitizedProjectName.toLowerCase(),\n organization: `${organization.toLowerCase()}ai`,\n prefix: sanitizedProjectName.substring(0, 3).toUpperCase(),\n };\n }\n\n /**\n * Create fallback identification for non-git projects\n */\n private createFallbackIdentification(projectRoot: string): ProjectIdentification {\n const folderName = projectRoot.split('/').pop() || 'unknown';\n const projectId = this.createStableProjectId('local', folderName);\n\n return {\n projectId,\n organization: 'local',\n repository: folderName,\n workspaceFilter: `local:${folderName}`,\n linearTeamId: folderName.toLowerCase().replace(/[^a-z0-9]/g, ''),\n linearOrganization: 'local',\n projectPrefix: folderName.substring(0, 3).toUpperCase(),\n };\n }\n\n /**\n * Validate that current project isolation is working\n */\n validateProjectIsolation(projectRoot: string): boolean {\n try {\n const identification = this.getProjectIdentification(projectRoot);\n \n // Check that we have required fields\n if (!identification.projectId || !identification.workspaceFilter) {\n return false;\n }\n\n // Check that workspace filter is stable\n const secondCall = this.getProjectIdentification(projectRoot);\n if (identification.workspaceFilter !== secondCall.workspaceFilter) {\n return false;\n }\n\n return true;\n } catch (error) {\n logger.error('Project isolation validation failed', { error });\n return false;\n }\n }\n\n /**\n * Clear project cache (for testing)\n */\n clearCache(): void {\n this.projectCache.clear();\n }\n}"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|