@stackmemoryai/stackmemory 0.2.9 → 0.3.0
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/dist/agents/core/agent-task-manager.js +512 -0
- package/dist/agents/core/agent-task-manager.js.map +7 -0
- package/dist/agents/verifiers/base-verifier.js +129 -0
- package/dist/agents/verifiers/base-verifier.js.map +7 -0
- package/dist/agents/verifiers/formatter-verifier.js +126 -0
- package/dist/agents/verifiers/formatter-verifier.js.map +7 -0
- package/dist/agents/verifiers/llm-judge.js +248 -0
- package/dist/agents/verifiers/llm-judge.js.map +7 -0
- package/dist/cli/__tests__/index.test.js +290 -0
- package/dist/cli/__tests__/index.test.js.map +7 -0
- package/dist/cli/auto-detect.js +317 -0
- package/dist/cli/auto-detect.js.map +7 -0
- package/dist/cli/browser-test.js +29 -0
- package/dist/cli/browser-test.js.map +7 -0
- package/dist/cli/claude-sm.js +369 -0
- package/dist/cli/claude-sm.js.map +7 -0
- package/dist/cli/codex-sm.js +283 -0
- package/dist/cli/codex-sm.js.map +7 -0
- package/dist/cli/commands/agent.js +286 -0
- package/dist/cli/commands/agent.js.map +7 -0
- package/dist/cli/commands/config.js +199 -0
- package/dist/cli/commands/config.js.map +7 -0
- package/dist/cli/commands/context.js +327 -0
- package/dist/cli/commands/context.js.map +7 -0
- package/dist/cli/commands/handoff.js +191 -0
- package/dist/cli/commands/handoff.js.map +7 -0
- package/dist/cli/commands/linear-test.js +115 -0
- package/dist/cli/commands/linear-test.js.map +7 -0
- package/dist/cli/commands/linear.js +378 -0
- package/dist/cli/commands/linear.js.map +7 -0
- package/dist/cli/commands/log.js +165 -0
- package/dist/cli/commands/log.js.map +7 -0
- package/dist/cli/commands/onboard.js +349 -0
- package/dist/cli/commands/onboard.js.map +7 -0
- package/dist/cli/commands/projects.js +195 -0
- package/dist/cli/commands/projects.js.map +7 -0
- package/dist/cli/commands/search.js +152 -0
- package/dist/cli/commands/search.js.map +7 -0
- package/dist/cli/commands/session.js +179 -0
- package/dist/cli/commands/session.js.map +7 -0
- package/dist/cli/commands/tasks.js +205 -0
- package/dist/cli/commands/tasks.js.map +7 -0
- package/dist/cli/commands/webhook.js +131 -0
- package/dist/cli/commands/webhook.js.map +7 -0
- package/dist/cli/commands/worktree.js +276 -0
- package/dist/cli/commands/worktree.js.map +7 -0
- package/dist/cli/index.js +953 -0
- package/dist/cli/index.js.map +7 -0
- package/dist/cli/utils/viewer.js +92 -0
- package/dist/cli/utils/viewer.js.map +7 -0
- package/dist/core/config/__tests__/config-manager.test.js +248 -0
- package/dist/core/config/__tests__/config-manager.test.js.map +7 -0
- package/dist/core/config/config-manager.js +368 -0
- package/dist/core/config/config-manager.js.map +7 -0
- package/dist/core/config/types.js +140 -0
- package/dist/core/config/types.js.map +7 -0
- package/dist/core/context/__tests__/frame-manager.test.js +879 -0
- package/dist/core/context/__tests__/frame-manager.test.js.map +7 -0
- package/dist/core/context/auto-context.js +72 -0
- package/dist/core/context/auto-context.js.map +7 -0
- package/dist/core/context/compaction-handler.js +326 -0
- package/dist/core/context/compaction-handler.js.map +7 -0
- package/dist/core/context/frame-database.js +376 -0
- package/dist/core/context/frame-database.js.map +7 -0
- package/dist/core/context/frame-digest.js +239 -0
- package/dist/core/context/frame-digest.js.map +7 -0
- package/dist/core/context/frame-manager.js +682 -0
- package/dist/core/context/frame-manager.js.map +7 -0
- package/dist/core/context/frame-stack.js +270 -0
- package/dist/core/context/frame-stack.js.map +7 -0
- package/dist/core/context/frame-types.js +1 -0
- package/dist/core/context/frame-types.js.map +7 -0
- package/dist/core/context/index.js +33 -0
- package/dist/core/context/index.js.map +7 -0
- package/dist/core/context/model-aware-compaction.js +619 -0
- package/dist/core/context/model-aware-compaction.js.map +7 -0
- package/dist/core/context/refactored-frame-manager.js +393 -0
- package/dist/core/context/refactored-frame-manager.js.map +7 -0
- package/dist/core/database/batch-operations.js +329 -0
- package/dist/core/database/batch-operations.js.map +7 -0
- package/dist/core/database/connection-pool.js +224 -0
- package/dist/core/database/connection-pool.js.map +7 -0
- package/dist/core/database/query-cache.js +284 -0
- package/dist/core/database/query-cache.js.map +7 -0
- package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js +379 -0
- package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js.map +7 -0
- package/dist/core/digest/__tests__/frame-digest-integration.test.js +230 -0
- package/dist/core/digest/__tests__/frame-digest-integration.test.js.map +7 -0
- package/dist/core/digest/enhanced-hybrid-digest.js +267 -0
- package/dist/core/digest/enhanced-hybrid-digest.js.map +7 -0
- package/dist/core/digest/frame-digest-integration.js +172 -0
- package/dist/core/digest/frame-digest-integration.js.map +7 -0
- package/dist/core/digest/hybrid-digest-generator.js +549 -0
- package/dist/core/digest/hybrid-digest-generator.js.map +7 -0
- package/dist/core/digest/index.js +5 -0
- package/dist/core/digest/index.js.map +7 -0
- package/dist/core/digest/types.js +21 -0
- package/dist/core/digest/types.js.map +7 -0
- package/dist/core/errors/__tests__/error-handling.test.js +270 -0
- package/dist/core/errors/__tests__/error-handling.test.js.map +7 -0
- package/dist/core/errors/index.js +239 -0
- package/dist/core/errors/index.js.map +7 -0
- package/dist/core/errors/recovery.js +258 -0
- package/dist/core/errors/recovery.js.map +7 -0
- package/dist/core/merge/__tests__/conflict-scenarios.test.js +414 -0
- package/dist/core/merge/__tests__/conflict-scenarios.test.js.map +7 -0
- package/dist/core/merge/conflict-detector.js +424 -0
- package/dist/core/merge/conflict-detector.js.map +7 -0
- package/dist/core/merge/index.js +5 -0
- package/dist/core/merge/index.js.map +7 -0
- package/dist/core/merge/resolution-engine.js +565 -0
- package/dist/core/merge/resolution-engine.js.map +7 -0
- package/dist/core/merge/stack-diff.js +528 -0
- package/dist/core/merge/stack-diff.js.map +7 -0
- package/dist/core/merge/types.js +1 -0
- package/dist/core/merge/types.js.map +7 -0
- package/dist/core/monitoring/error-handler.js +278 -0
- package/dist/core/monitoring/error-handler.js.map +7 -0
- package/dist/core/monitoring/logger.js +115 -0
- package/dist/core/monitoring/logger.js.map +7 -0
- package/dist/core/monitoring/metrics.js +157 -0
- package/dist/core/monitoring/metrics.js.map +7 -0
- package/dist/core/monitoring/progress-tracker.js +174 -0
- package/dist/core/monitoring/progress-tracker.js.map +7 -0
- package/dist/core/performance/context-cache.js +269 -0
- package/dist/core/performance/context-cache.js.map +7 -0
- package/dist/core/performance/index.js +7 -0
- package/dist/core/performance/index.js.map +7 -0
- package/dist/core/performance/lazy-context-loader.js +319 -0
- package/dist/core/performance/lazy-context-loader.js.map +7 -0
- package/dist/core/performance/monitor.js +217 -0
- package/dist/core/performance/monitor.js.map +7 -0
- package/dist/core/performance/optimized-frame-context.js +326 -0
- package/dist/core/performance/optimized-frame-context.js.map +7 -0
- package/dist/core/performance/performance-benchmark.js +269 -0
- package/dist/core/performance/performance-benchmark.js.map +7 -0
- package/dist/core/performance/performance-profiler.js +318 -0
- package/dist/core/performance/performance-profiler.js.map +7 -0
- package/dist/core/performance/streaming-jsonl-parser.js +187 -0
- package/dist/core/performance/streaming-jsonl-parser.js.map +7 -0
- package/dist/core/persistence/postgres-adapter.js +345 -0
- package/dist/core/persistence/postgres-adapter.js.map +7 -0
- package/dist/core/projects/project-manager.js +699 -0
- package/dist/core/projects/project-manager.js.map +7 -0
- package/dist/core/query/__tests__/query-parser.test.js +301 -0
- package/dist/core/query/__tests__/query-parser.test.js.map +7 -0
- package/dist/core/query/__tests__/query-templates.test.js +210 -0
- package/dist/core/query/__tests__/query-templates.test.js.map +7 -0
- package/dist/core/query/query-parser.js +366 -0
- package/dist/core/query/query-parser.js.map +7 -0
- package/dist/core/query/query-templates.js +317 -0
- package/dist/core/query/query-templates.js.map +7 -0
- package/dist/core/retrieval/index.js +4 -0
- package/dist/core/retrieval/index.js.map +7 -0
- package/dist/core/retrieval/llm-context-retrieval.js +577 -0
- package/dist/core/retrieval/llm-context-retrieval.js.map +7 -0
- package/dist/core/retrieval/summary-generator.js +585 -0
- package/dist/core/retrieval/summary-generator.js.map +7 -0
- package/dist/core/retrieval/types.js +17 -0
- package/dist/core/retrieval/types.js.map +7 -0
- package/dist/core/session/index.js +11 -0
- package/dist/core/session/index.js.map +7 -0
- package/dist/core/session/session-manager.js +297 -0
- package/dist/core/session/session-manager.js.map +7 -0
- package/dist/core/trace/cli-trace-wrapper.js +110 -0
- package/dist/core/trace/cli-trace-wrapper.js.map +7 -0
- package/dist/core/trace/db-trace-wrapper.js +215 -0
- package/dist/core/trace/db-trace-wrapper.js.map +7 -0
- package/dist/core/trace/debug-trace.js +385 -0
- package/dist/core/trace/debug-trace.js.map +7 -0
- package/dist/core/trace/index.js +158 -0
- package/dist/core/trace/index.js.map +7 -0
- package/dist/core/trace/linear-api-wrapper.js +169 -0
- package/dist/core/trace/linear-api-wrapper.js.map +7 -0
- package/dist/core/trace/trace-demo.js +135 -0
- package/dist/core/trace/trace-demo.js.map +7 -0
- package/dist/core/trace/trace-detector.demo.js +138 -0
- package/dist/core/trace/trace-detector.demo.js.map +7 -0
- package/dist/core/trace/trace-detector.js +386 -0
- package/dist/core/trace/trace-detector.js.map +7 -0
- package/dist/core/trace/trace-detector.test.js +401 -0
- package/dist/core/trace/trace-detector.test.js.map +7 -0
- package/dist/core/trace/trace-store.js +341 -0
- package/dist/core/trace/trace-store.js.map +7 -0
- package/dist/core/trace/types.js +73 -0
- package/dist/core/trace/types.js.map +7 -0
- package/dist/core/types.js +1 -0
- package/dist/core/types.js.map +7 -0
- package/dist/core/utils/update-checker.js +214 -0
- package/dist/core/utils/update-checker.js.map +7 -0
- package/dist/core/worktree/worktree-manager.js +450 -0
- package/dist/core/worktree/worktree-manager.js.map +7 -0
- package/dist/features/analytics/api/analytics-api.js +283 -0
- package/dist/features/analytics/api/analytics-api.js.map +7 -0
- package/dist/features/analytics/core/analytics-service.js +267 -0
- package/dist/features/analytics/core/analytics-service.js.map +7 -0
- package/dist/features/analytics/index.js +14 -0
- package/dist/features/analytics/index.js.map +7 -0
- package/dist/features/analytics/queries/metrics-queries.js +273 -0
- package/dist/features/analytics/queries/metrics-queries.js.map +7 -0
- package/dist/features/analytics/types/metrics.js +1 -0
- package/dist/features/analytics/types/metrics.js.map +7 -0
- package/dist/features/browser/browser-mcp.js +488 -0
- package/dist/features/browser/browser-mcp.js.map +7 -0
- package/dist/features/tasks/__tests__/pebbles-task-store.test.js +747 -0
- package/dist/features/tasks/__tests__/pebbles-task-store.test.js.map +7 -0
- package/dist/features/tasks/pebbles-task-store.js +647 -0
- package/dist/features/tasks/pebbles-task-store.js.map +7 -0
- package/dist/features/tasks/task-aware-context.js +406 -0
- package/dist/features/tasks/task-aware-context.js.map +7 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +7 -0
- package/dist/integrations/linear/__tests__/auth.test.js +558 -0
- package/dist/integrations/linear/__tests__/auth.test.js.map +7 -0
- package/dist/integrations/linear/__tests__/sync-service.test.js +760 -0
- package/dist/integrations/linear/__tests__/sync-service.test.js.map +7 -0
- package/dist/integrations/linear/auth.js +308 -0
- package/dist/integrations/linear/auth.js.map +7 -0
- package/dist/integrations/linear/auto-sync.js +244 -0
- package/dist/integrations/linear/auto-sync.js.map +7 -0
- package/dist/integrations/linear/client.js +448 -0
- package/dist/integrations/linear/client.js.map +7 -0
- package/dist/integrations/linear/config.js +115 -0
- package/dist/integrations/linear/config.js.map +7 -0
- package/dist/integrations/linear/sync-manager.js +233 -0
- package/dist/integrations/linear/sync-manager.js.map +7 -0
- package/dist/integrations/linear/sync-service.js +214 -0
- package/dist/integrations/linear/sync-service.js.map +7 -0
- package/dist/integrations/linear/sync.js +565 -0
- package/dist/integrations/linear/sync.js.map +7 -0
- package/dist/integrations/linear/types.js +1 -0
- package/dist/integrations/linear/types.js.map +7 -0
- package/dist/integrations/linear/webhook-server.js +204 -0
- package/dist/integrations/linear/webhook-server.js.map +7 -0
- package/dist/integrations/linear/webhook.js +269 -0
- package/dist/integrations/linear/webhook.js.map +7 -0
- package/dist/integrations/mcp/__tests__/server.test.js +798 -0
- package/dist/integrations/mcp/__tests__/server.test.js.map +7 -0
- package/dist/integrations/mcp/handlers/context-handlers.js +253 -0
- package/dist/integrations/mcp/handlers/context-handlers.js.map +7 -0
- package/dist/integrations/mcp/handlers/index.js +134 -0
- package/dist/integrations/mcp/handlers/index.js.map +7 -0
- package/dist/integrations/mcp/handlers/linear-handlers.js +243 -0
- package/dist/integrations/mcp/handlers/linear-handlers.js.map +7 -0
- package/dist/integrations/mcp/handlers/task-handlers.js +235 -0
- package/dist/integrations/mcp/handlers/task-handlers.js.map +7 -0
- package/dist/integrations/mcp/handlers/trace-handlers.js +304 -0
- package/dist/integrations/mcp/handlers/trace-handlers.js.map +7 -0
- package/dist/integrations/mcp/index.js +19 -0
- package/dist/integrations/mcp/index.js.map +7 -0
- package/dist/integrations/mcp/refactored-server.js +331 -0
- package/dist/integrations/mcp/refactored-server.js.map +7 -0
- package/dist/integrations/mcp/server.js +1621 -0
- package/dist/integrations/mcp/server.js.map +7 -0
- package/dist/integrations/mcp/tool-definitions.js +562 -0
- package/dist/integrations/mcp/tool-definitions.js.map +7 -0
- package/dist/integrations/mcp/trace-test.js +44 -0
- package/dist/integrations/mcp/trace-test.js.map +7 -0
- package/dist/integrations/pg-aiguide/embedding-provider.js +174 -0
- package/dist/integrations/pg-aiguide/embedding-provider.js.map +7 -0
- package/dist/integrations/pg-aiguide/semantic-search.js +183 -0
- package/dist/integrations/pg-aiguide/semantic-search.js.map +7 -0
- package/dist/integrations/pg-aiguide/timescale-analytics.js +220 -0
- package/dist/integrations/pg-aiguide/timescale-analytics.js.map +7 -0
- package/dist/mcp/stackmemory-mcp-server.js +550 -0
- package/dist/mcp/stackmemory-mcp-server.js.map +7 -0
- package/dist/middleware/exponential-rate-limiter.js +285 -0
- package/dist/middleware/exponential-rate-limiter.js.map +7 -0
- package/dist/models/user.model.js +351 -0
- package/dist/models/user.model.js.map +7 -0
- package/dist/scripts/benchmark-performance.d.ts +7 -0
- package/dist/scripts/benchmark-performance.d.ts.map +1 -0
- package/dist/scripts/benchmark-performance.js +44 -0
- package/dist/scripts/benchmark-performance.js.map +1 -0
- package/dist/scripts/cleanup-duplicate-tasks.d.ts +12 -0
- package/dist/scripts/cleanup-duplicate-tasks.d.ts.map +1 -0
- package/dist/scripts/cleanup-duplicate-tasks.js +215 -0
- package/dist/scripts/cleanup-duplicate-tasks.js.map +1 -0
- package/dist/servers/production/auth-middleware.js +513 -0
- package/dist/servers/production/auth-middleware.js.map +7 -0
- package/dist/servers/railway/index.js +390 -0
- package/dist/servers/railway/index.js.map +7 -0
- package/dist/services/config-service.js +62 -0
- package/dist/services/config-service.js.map +7 -0
- package/dist/services/context-service.js +191 -0
- package/dist/services/context-service.js.map +7 -0
- package/dist/src/agents/core/agent-task-manager.d.ts +154 -0
- package/dist/src/agents/core/agent-task-manager.d.ts.map +1 -0
- package/dist/src/agents/core/agent-task-manager.js +504 -0
- package/dist/src/agents/core/agent-task-manager.js.map +1 -0
- package/dist/src/agents/verifiers/base-verifier.d.ts +112 -0
- package/dist/src/agents/verifiers/base-verifier.d.ts.map +1 -0
- package/dist/src/agents/verifiers/base-verifier.js +130 -0
- package/dist/src/agents/verifiers/base-verifier.js.map +1 -0
- package/dist/src/agents/verifiers/formatter-verifier.d.ts +14 -0
- package/dist/src/agents/verifiers/formatter-verifier.d.ts.map +1 -0
- package/dist/src/agents/verifiers/formatter-verifier.js +107 -0
- package/dist/src/agents/verifiers/formatter-verifier.js.map +1 -0
- package/dist/src/agents/verifiers/llm-judge.d.ts +46 -0
- package/dist/src/agents/verifiers/llm-judge.d.ts.map +1 -0
- package/dist/src/agents/verifiers/llm-judge.js +248 -0
- package/dist/src/agents/verifiers/llm-judge.js.map +1 -0
- package/dist/src/cli/claude-sm.js +55 -0
- package/dist/src/cli/claude-sm.js.map +1 -1
- package/dist/src/cli/commands/agent.d.ts +9 -0
- package/dist/src/cli/commands/agent.d.ts.map +1 -0
- package/dist/src/cli/commands/agent.js +303 -0
- package/dist/src/cli/commands/agent.js.map +1 -0
- package/dist/src/cli/commands/handoff.d.ts +6 -0
- package/dist/src/cli/commands/handoff.d.ts.map +1 -0
- package/dist/src/cli/commands/handoff.js +212 -0
- package/dist/src/cli/commands/handoff.js.map +1 -0
- package/dist/src/cli/index.d.ts.map +1 -1
- package/dist/src/cli/index.js +4 -0
- package/dist/src/cli/index.js.map +1 -1
- package/dist/src/core/context/frame-database.d.ts +59 -0
- package/dist/src/core/context/frame-database.d.ts.map +1 -0
- package/dist/src/core/context/frame-database.js +333 -0
- package/dist/src/core/context/frame-database.js.map +1 -0
- package/dist/src/core/context/frame-digest.d.ts +59 -0
- package/dist/src/core/context/frame-digest.d.ts.map +1 -0
- package/dist/src/core/context/frame-digest.js +264 -0
- package/dist/src/core/context/frame-digest.js.map +1 -0
- package/dist/src/core/context/frame-manager.d.ts +2 -0
- package/dist/src/core/context/frame-manager.d.ts.map +1 -1
- package/dist/src/core/context/frame-manager.js +7 -0
- package/dist/src/core/context/frame-manager.js.map +1 -1
- package/dist/src/core/context/frame-stack.d.ts +85 -0
- package/dist/src/core/context/frame-stack.d.ts.map +1 -0
- package/dist/src/core/context/frame-stack.js +287 -0
- package/dist/src/core/context/frame-stack.js.map +1 -0
- package/dist/src/core/context/frame-types.d.ts +67 -0
- package/dist/src/core/context/frame-types.d.ts.map +1 -0
- package/dist/src/core/context/frame-types.js +6 -0
- package/dist/src/core/context/frame-types.js.map +1 -0
- package/dist/src/core/context/index.d.ts +11 -0
- package/dist/src/core/context/index.d.ts.map +1 -0
- package/dist/src/core/context/index.js +14 -0
- package/dist/src/core/context/index.js.map +1 -0
- package/dist/src/core/context/refactored-frame-manager.d.ts +99 -0
- package/dist/src/core/context/refactored-frame-manager.d.ts.map +1 -0
- package/dist/src/core/context/refactored-frame-manager.js +340 -0
- package/dist/src/core/context/refactored-frame-manager.js.map +1 -0
- package/dist/src/core/database/batch-operations.d.ts +118 -0
- package/dist/src/core/database/batch-operations.d.ts.map +1 -0
- package/dist/src/core/database/batch-operations.js +339 -0
- package/dist/src/core/database/batch-operations.js.map +1 -0
- package/dist/src/core/database/connection-pool.d.ts +79 -0
- package/dist/src/core/database/connection-pool.d.ts.map +1 -0
- package/dist/src/core/database/connection-pool.js +236 -0
- package/dist/src/core/database/connection-pool.js.map +1 -0
- package/dist/src/core/database/query-cache.d.ts +135 -0
- package/dist/src/core/database/query-cache.d.ts.map +1 -0
- package/dist/src/core/database/query-cache.js +294 -0
- package/dist/src/core/database/query-cache.js.map +1 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +125 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +1 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.js +282 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.js.map +1 -0
- package/dist/src/core/digest/frame-digest-integration.d.ts +67 -0
- package/dist/src/core/digest/frame-digest-integration.d.ts.map +1 -0
- package/dist/src/core/digest/frame-digest-integration.js +198 -0
- package/dist/src/core/digest/frame-digest-integration.js.map +1 -0
- package/dist/src/core/digest/hybrid-digest-generator.d.ts +3 -3
- package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +1 -1
- package/dist/src/core/digest/hybrid-digest-generator.js.map +1 -1
- package/dist/src/core/digest/index.d.ts +3 -1
- package/dist/src/core/digest/index.d.ts.map +1 -1
- package/dist/src/core/digest/index.js +3 -1
- package/dist/src/core/digest/index.js.map +1 -1
- package/dist/src/core/errors/index.d.ts +13 -5
- package/dist/src/core/errors/index.d.ts.map +1 -1
- package/dist/src/core/errors/index.js +13 -5
- package/dist/src/core/errors/index.js.map +1 -1
- package/dist/src/core/merge/conflict-detector.d.ts +122 -0
- package/dist/src/core/merge/conflict-detector.d.ts.map +1 -0
- package/dist/src/core/merge/conflict-detector.js +468 -0
- package/dist/src/core/merge/conflict-detector.js.map +1 -0
- package/dist/src/core/merge/index.d.ts +9 -0
- package/dist/src/core/merge/index.d.ts.map +1 -0
- package/dist/src/core/merge/index.js +9 -0
- package/dist/src/core/merge/index.js.map +1 -0
- package/dist/src/core/merge/resolution-engine.d.ts +120 -0
- package/dist/src/core/merge/resolution-engine.d.ts.map +1 -0
- package/dist/src/core/merge/resolution-engine.js +573 -0
- package/dist/src/core/merge/resolution-engine.js.map +1 -0
- package/dist/src/core/merge/stack-diff.d.ts +97 -0
- package/dist/src/core/merge/stack-diff.d.ts.map +1 -0
- package/dist/src/core/merge/stack-diff.js +516 -0
- package/dist/src/core/merge/stack-diff.js.map +1 -0
- package/dist/src/core/merge/types.d.ts +110 -0
- package/dist/src/core/merge/types.d.ts.map +1 -0
- package/dist/src/core/merge/types.js +6 -0
- package/dist/src/core/merge/types.js.map +1 -0
- package/dist/src/core/performance/context-cache.d.ts +109 -0
- package/dist/src/core/performance/context-cache.d.ts.map +1 -0
- package/dist/src/core/performance/context-cache.js +280 -0
- package/dist/src/core/performance/context-cache.js.map +1 -0
- package/dist/src/core/performance/index.d.ts +3 -0
- package/dist/src/core/performance/index.d.ts.map +1 -0
- package/dist/src/core/performance/index.js +3 -0
- package/dist/src/core/performance/index.js.map +1 -0
- package/dist/src/core/performance/lazy-context-loader.d.ts +93 -0
- package/dist/src/core/performance/lazy-context-loader.d.ts.map +1 -0
- package/dist/src/core/performance/lazy-context-loader.js +332 -0
- package/dist/src/core/performance/lazy-context-loader.js.map +1 -0
- package/dist/src/core/performance/monitor.d.ts +48 -0
- package/dist/src/core/performance/monitor.d.ts.map +1 -0
- package/dist/src/core/performance/monitor.js +226 -0
- package/dist/src/core/performance/monitor.js.map +1 -0
- package/dist/src/core/performance/optimized-frame-context.d.ts +74 -0
- package/dist/src/core/performance/optimized-frame-context.d.ts.map +1 -0
- package/dist/src/core/performance/optimized-frame-context.js +330 -0
- package/dist/src/core/performance/optimized-frame-context.js.map +1 -0
- package/dist/src/core/performance/performance-benchmark.d.ts +50 -0
- package/dist/src/core/performance/performance-benchmark.d.ts.map +1 -0
- package/dist/src/core/performance/performance-benchmark.js +290 -0
- package/dist/src/core/performance/performance-benchmark.js.map +1 -0
- package/dist/src/core/performance/performance-profiler.d.ts +151 -0
- package/dist/src/core/performance/performance-profiler.d.ts.map +1 -0
- package/dist/src/core/performance/performance-profiler.js +346 -0
- package/dist/src/core/performance/performance-profiler.js.map +1 -0
- package/dist/src/core/performance/streaming-jsonl-parser.d.ts +41 -0
- package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +1 -0
- package/dist/src/core/performance/streaming-jsonl-parser.js +193 -0
- package/dist/src/core/performance/streaming-jsonl-parser.js.map +1 -0
- package/dist/src/core/persistence/postgres-adapter.d.ts.map +1 -1
- package/dist/src/core/persistence/postgres-adapter.js +18 -4
- package/dist/src/core/persistence/postgres-adapter.js.map +1 -1
- package/dist/src/core/query/query-parser.d.ts +5 -0
- package/dist/src/core/query/query-parser.d.ts.map +1 -1
- package/dist/src/core/query/query-parser.js +86 -18
- package/dist/src/core/query/query-parser.js.map +1 -1
- package/dist/src/core/query/query-templates.d.ts +44 -0
- package/dist/src/core/query/query-templates.d.ts.map +1 -0
- package/dist/src/core/query/query-templates.js +326 -0
- package/dist/src/core/query/query-templates.js.map +1 -0
- package/dist/src/core/retrieval/llm-context-retrieval.d.ts +5 -3
- package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +1 -1
- package/dist/src/core/retrieval/llm-context-retrieval.js +73 -21
- package/dist/src/core/retrieval/llm-context-retrieval.js.map +1 -1
- package/dist/src/core/trace/cli-trace-wrapper.d.ts +23 -0
- package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +1 -0
- package/dist/src/core/trace/cli-trace-wrapper.js +141 -0
- package/dist/src/core/trace/cli-trace-wrapper.js.map +1 -0
- package/dist/src/core/trace/db-trace-wrapper.d.ts +36 -0
- package/dist/src/core/trace/db-trace-wrapper.d.ts.map +1 -0
- package/dist/src/core/trace/db-trace-wrapper.js +252 -0
- package/dist/src/core/trace/db-trace-wrapper.js.map +1 -0
- package/dist/src/core/trace/debug-trace.d.ts +84 -0
- package/dist/src/core/trace/debug-trace.d.ts.map +1 -0
- package/dist/src/core/trace/debug-trace.js +402 -0
- package/dist/src/core/trace/debug-trace.js.map +1 -0
- package/dist/src/core/trace/error-test.d.ts +6 -0
- package/dist/src/core/trace/error-test.d.ts.map +1 -0
- package/dist/src/core/trace/error-test.js +128 -0
- package/dist/src/core/trace/error-test.js.map +1 -0
- package/dist/src/core/trace/index.d.ts +25 -0
- package/dist/src/core/trace/index.d.ts.map +1 -0
- package/dist/src/core/trace/index.js +121 -0
- package/dist/src/core/trace/index.js.map +1 -0
- package/dist/src/core/trace/linear-api-wrapper.d.ts +17 -0
- package/dist/src/core/trace/linear-api-wrapper.d.ts.map +1 -0
- package/dist/src/core/trace/linear-api-wrapper.js +205 -0
- package/dist/src/core/trace/linear-api-wrapper.js.map +1 -0
- package/dist/src/core/trace/performance-test.d.ts +6 -0
- package/dist/src/core/trace/performance-test.d.ts.map +1 -0
- package/dist/src/core/trace/performance-test.js +111 -0
- package/dist/src/core/trace/performance-test.js.map +1 -0
- package/dist/src/core/trace/trace-demo.d.ts +8 -0
- package/dist/src/core/trace/trace-demo.d.ts.map +1 -0
- package/dist/src/core/trace/trace-demo.js +154 -0
- package/dist/src/core/trace/trace-demo.js.map +1 -0
- package/dist/src/core/trace/trace-detector.d.ts +2 -2
- package/dist/src/core/trace/trace-detector.d.ts.map +1 -1
- package/dist/src/core/trace/trace-detector.demo.js +1 -1
- package/dist/src/core/trace/trace-detector.demo.js.map +1 -1
- package/dist/src/core/trace/trace-detector.js +3 -3
- package/dist/src/core/trace/trace-detector.js.map +1 -1
- package/dist/src/features/tasks/pebbles-task-store.d.ts +9 -2
- package/dist/src/features/tasks/pebbles-task-store.d.ts.map +1 -1
- package/dist/src/features/tasks/pebbles-task-store.js +97 -18
- package/dist/src/features/tasks/pebbles-task-store.js.map +1 -1
- package/dist/src/integrations/linear/auth.d.ts.map +1 -1
- package/dist/src/integrations/linear/auth.js.map +1 -1
- package/dist/src/integrations/linear/client.d.ts +15 -1
- package/dist/src/integrations/linear/client.d.ts.map +1 -1
- package/dist/src/integrations/linear/client.js +85 -3
- package/dist/src/integrations/linear/client.js.map +1 -1
- package/dist/src/integrations/linear/sync-manager.d.ts +2 -0
- package/dist/src/integrations/linear/sync-manager.d.ts.map +1 -1
- package/dist/src/integrations/linear/sync-manager.js +16 -4
- package/dist/src/integrations/linear/sync-manager.js.map +1 -1
- package/dist/src/integrations/linear/sync-service.d.ts +23 -2
- package/dist/src/integrations/linear/sync-service.d.ts.map +1 -1
- package/dist/src/integrations/linear/sync-service.js +44 -25
- package/dist/src/integrations/linear/sync-service.js.map +1 -1
- package/dist/src/integrations/linear/sync.d.ts +6 -0
- package/dist/src/integrations/linear/sync.d.ts.map +1 -1
- package/dist/src/integrations/linear/sync.js +27 -2
- package/dist/src/integrations/linear/sync.js.map +1 -1
- package/dist/src/integrations/linear/types.d.ts +16 -1
- package/dist/src/integrations/linear/types.d.ts.map +1 -1
- package/dist/src/integrations/linear/webhook-server.d.ts.map +1 -1
- package/dist/src/integrations/linear/webhook-server.js +10 -8
- package/dist/src/integrations/linear/webhook-server.js.map +1 -1
- package/dist/src/integrations/linear/webhook.d.ts +13 -0
- package/dist/src/integrations/linear/webhook.d.ts.map +1 -1
- package/dist/src/integrations/linear/webhook.js +101 -14
- package/dist/src/integrations/linear/webhook.js.map +1 -1
- package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +39 -0
- package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +1 -0
- package/dist/src/integrations/mcp/handlers/context-handlers.js +266 -0
- package/dist/src/integrations/mcp/handlers/context-handlers.js.map +1 -0
- package/dist/src/integrations/mcp/handlers/index.d.ts +37 -0
- package/dist/src/integrations/mcp/handlers/index.d.ts.map +1 -0
- package/dist/src/integrations/mcp/handlers/index.js +134 -0
- package/dist/src/integrations/mcp/handlers/index.js.map +1 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +33 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +1 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.js +251 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +1 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +42 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +1 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.js +238 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.js.map +1 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +41 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +1 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.js +298 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +1 -0
- package/dist/src/integrations/mcp/index.d.ts +13 -0
- package/dist/src/integrations/mcp/index.d.ts.map +1 -0
- package/dist/src/integrations/mcp/index.js +17 -0
- package/dist/src/integrations/mcp/index.js.map +1 -0
- package/dist/src/integrations/mcp/refactored-server.d.ts +76 -0
- package/dist/src/integrations/mcp/refactored-server.d.ts.map +1 -0
- package/dist/src/integrations/mcp/refactored-server.js +351 -0
- package/dist/src/integrations/mcp/refactored-server.js.map +1 -0
- package/dist/src/integrations/mcp/tool-definitions.d.ts +44 -0
- package/dist/src/integrations/mcp/tool-definitions.d.ts.map +1 -0
- package/dist/src/integrations/mcp/tool-definitions.js +563 -0
- package/dist/src/integrations/mcp/tool-definitions.js.map +1 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +1 -1
- package/dist/src/integrations/pg-aiguide/semantic-search.js +43 -21
- package/dist/src/integrations/pg-aiguide/semantic-search.js.map +1 -1
- package/dist/src/mcp/stackmemory-mcp-server.d.ts +9 -0
- package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +1 -0
- package/dist/src/mcp/stackmemory-mcp-server.js +519 -0
- package/dist/src/mcp/stackmemory-mcp-server.js.map +1 -0
- package/dist/src/middleware/exponential-rate-limiter.d.ts +78 -0
- package/dist/src/middleware/exponential-rate-limiter.d.ts.map +1 -0
- package/dist/src/middleware/exponential-rate-limiter.js +293 -0
- package/dist/src/middleware/exponential-rate-limiter.js.map +1 -0
- package/dist/src/models/user.model.d.ts +8 -1
- package/dist/src/models/user.model.d.ts.map +1 -1
- package/dist/src/models/user.model.js +62 -14
- package/dist/src/models/user.model.js.map +1 -1
- package/dist/src/servers/production/auth-middleware.d.ts +5 -2
- package/dist/src/servers/production/auth-middleware.d.ts.map +1 -1
- package/dist/src/servers/production/auth-middleware.js +71 -34
- package/dist/src/servers/production/auth-middleware.js.map +1 -1
- package/dist/src/services/context-service.d.ts.map +1 -1
- package/dist/src/services/context-service.js +86 -1
- package/dist/src/services/context-service.js.map +1 -1
- package/dist/src/validation/schemas.d.ts +633 -0
- package/dist/src/validation/schemas.d.ts.map +1 -0
- package/dist/src/validation/schemas.js +347 -0
- package/dist/src/validation/schemas.js.map +1 -0
- package/dist/types/task.js +1 -0
- package/dist/types/task.js.map +7 -0
- package/dist/utils/logger.js +52 -0
- package/dist/utils/logger.js.map +7 -0
- package/dist/validation/schemas.js +218 -0
- package/dist/validation/schemas.js.map +7 -0
- package/package.json +7 -3
|
@@ -0,0 +1,346 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Performance Profiler
|
|
3
|
+
* Identifies and optimizes hot paths in StackMemory operations
|
|
4
|
+
*/
|
|
5
|
+
import { logger } from '../monitoring/logger.js';
|
|
6
|
+
import { getQueryStatistics } from '../trace/db-trace-wrapper.js';
|
|
7
|
+
/**
|
|
8
|
+
* Performance profiler with hot path detection
|
|
9
|
+
*/
|
|
10
|
+
export class PerformanceProfiler {
|
|
11
|
+
metrics = new Map();
|
|
12
|
+
hotPaths = new Map();
|
|
13
|
+
samples = new Map();
|
|
14
|
+
isEnabled = true;
|
|
15
|
+
sampleLimit = 1000;
|
|
16
|
+
hotPathThreshold = 5; // Operations taking > 5ms are considered hot
|
|
17
|
+
constructor(options = {}) {
|
|
18
|
+
this.isEnabled = options.enabled ?? true;
|
|
19
|
+
this.sampleLimit = options.sampleLimit ?? 1000;
|
|
20
|
+
this.hotPathThreshold = options.hotPathThreshold ?? 5;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Start timing an operation
|
|
24
|
+
*/
|
|
25
|
+
startTiming(operationName) {
|
|
26
|
+
if (!this.isEnabled) {
|
|
27
|
+
return () => { }; // No-op
|
|
28
|
+
}
|
|
29
|
+
const startTime = performance.now();
|
|
30
|
+
return (metadata) => {
|
|
31
|
+
this.endTiming(operationName, startTime, metadata);
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Time a function execution
|
|
36
|
+
*/
|
|
37
|
+
async timeFunction(operationName, fn, metadata) {
|
|
38
|
+
if (!this.isEnabled) {
|
|
39
|
+
return await fn();
|
|
40
|
+
}
|
|
41
|
+
const endTimer = this.startTiming(operationName);
|
|
42
|
+
try {
|
|
43
|
+
const result = await fn();
|
|
44
|
+
endTimer(metadata);
|
|
45
|
+
return result;
|
|
46
|
+
}
|
|
47
|
+
catch (error) {
|
|
48
|
+
endTimer({ ...metadata, error: true });
|
|
49
|
+
throw error;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Record timing manually
|
|
54
|
+
*/
|
|
55
|
+
recordTiming(operationName, durationMs, metadata) {
|
|
56
|
+
if (!this.isEnabled)
|
|
57
|
+
return;
|
|
58
|
+
this.endTiming(operationName, performance.now() - durationMs, metadata);
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Get performance metrics for an operation
|
|
62
|
+
*/
|
|
63
|
+
getMetrics(operationName) {
|
|
64
|
+
return this.metrics.get(operationName);
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Get all performance metrics
|
|
68
|
+
*/
|
|
69
|
+
getAllMetrics() {
|
|
70
|
+
return new Map(this.metrics);
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Get hot paths sorted by impact
|
|
74
|
+
*/
|
|
75
|
+
getHotPaths(limit = 10) {
|
|
76
|
+
return Array.from(this.hotPaths.values())
|
|
77
|
+
.sort((a, b) => (b.frequency * b.avgDuration) - (a.frequency * a.avgDuration))
|
|
78
|
+
.slice(0, limit);
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Generate comprehensive performance report
|
|
82
|
+
*/
|
|
83
|
+
generateReport(db) {
|
|
84
|
+
const hotPaths = this.getHotPaths(20);
|
|
85
|
+
const recommendations = this.generateRecommendations(hotPaths);
|
|
86
|
+
const report = {
|
|
87
|
+
timestamp: Date.now(),
|
|
88
|
+
hotPaths,
|
|
89
|
+
databaseMetrics: db ? getQueryStatistics(db) : null,
|
|
90
|
+
memoryUsage: process.memoryUsage(),
|
|
91
|
+
cacheMetrics: null, // Will be filled by query cache if available
|
|
92
|
+
recommendations,
|
|
93
|
+
};
|
|
94
|
+
logger.info('Performance report generated', {
|
|
95
|
+
hotPathsCount: hotPaths.length,
|
|
96
|
+
recommendationsCount: recommendations.length,
|
|
97
|
+
topHotPath: hotPaths[0]?.path,
|
|
98
|
+
});
|
|
99
|
+
return report;
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Reset all metrics
|
|
103
|
+
*/
|
|
104
|
+
reset() {
|
|
105
|
+
this.metrics.clear();
|
|
106
|
+
this.hotPaths.clear();
|
|
107
|
+
this.samples.clear();
|
|
108
|
+
logger.info('Performance metrics reset');
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Export metrics to JSON
|
|
112
|
+
*/
|
|
113
|
+
exportMetrics() {
|
|
114
|
+
const data = {
|
|
115
|
+
timestamp: Date.now(),
|
|
116
|
+
metrics: Object.fromEntries(this.metrics),
|
|
117
|
+
hotPaths: Object.fromEntries(this.hotPaths),
|
|
118
|
+
config: {
|
|
119
|
+
sampleLimit: this.sampleLimit,
|
|
120
|
+
hotPathThreshold: this.hotPathThreshold,
|
|
121
|
+
enabled: this.isEnabled,
|
|
122
|
+
},
|
|
123
|
+
};
|
|
124
|
+
return JSON.stringify(data, null, 2);
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Enable/disable profiling
|
|
128
|
+
*/
|
|
129
|
+
setEnabled(enabled) {
|
|
130
|
+
this.isEnabled = enabled;
|
|
131
|
+
logger.info(`Performance profiling ${enabled ? 'enabled' : 'disabled'}`);
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* End timing for an operation
|
|
135
|
+
*/
|
|
136
|
+
endTiming(operationName, startTime, metadata) {
|
|
137
|
+
const duration = performance.now() - startTime;
|
|
138
|
+
const timestamp = Date.now();
|
|
139
|
+
// Update metrics
|
|
140
|
+
this.updateMetrics(operationName, duration, timestamp);
|
|
141
|
+
// Track hot paths
|
|
142
|
+
if (duration > this.hotPathThreshold) {
|
|
143
|
+
this.trackHotPath(operationName, duration, timestamp, metadata);
|
|
144
|
+
}
|
|
145
|
+
// Store sample
|
|
146
|
+
this.storeSample(operationName, duration, timestamp, metadata);
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Update performance metrics for an operation
|
|
150
|
+
*/
|
|
151
|
+
updateMetrics(operationName, duration, timestamp) {
|
|
152
|
+
const existing = this.metrics.get(operationName);
|
|
153
|
+
if (!existing) {
|
|
154
|
+
this.metrics.set(operationName, {
|
|
155
|
+
operationName,
|
|
156
|
+
callCount: 1,
|
|
157
|
+
totalTimeMs: duration,
|
|
158
|
+
avgTimeMs: duration,
|
|
159
|
+
minTimeMs: duration,
|
|
160
|
+
maxTimeMs: duration,
|
|
161
|
+
p95TimeMs: duration,
|
|
162
|
+
lastExecuted: timestamp,
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
existing.callCount++;
|
|
167
|
+
existing.totalTimeMs += duration;
|
|
168
|
+
existing.avgTimeMs = existing.totalTimeMs / existing.callCount;
|
|
169
|
+
existing.minTimeMs = Math.min(existing.minTimeMs, duration);
|
|
170
|
+
existing.maxTimeMs = Math.max(existing.maxTimeMs, duration);
|
|
171
|
+
existing.lastExecuted = timestamp;
|
|
172
|
+
// Update p95 from samples
|
|
173
|
+
existing.p95TimeMs = this.calculateP95(operationName);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Track hot path
|
|
178
|
+
*/
|
|
179
|
+
trackHotPath(operationName, duration, timestamp, metadata) {
|
|
180
|
+
const existing = this.hotPaths.get(operationName);
|
|
181
|
+
if (!existing) {
|
|
182
|
+
this.hotPaths.set(operationName, {
|
|
183
|
+
path: operationName,
|
|
184
|
+
frequency: 1,
|
|
185
|
+
avgDuration: duration,
|
|
186
|
+
totalDuration: duration,
|
|
187
|
+
lastSeen: timestamp,
|
|
188
|
+
samples: [{ timestamp, duration, metadata }],
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
existing.frequency++;
|
|
193
|
+
existing.totalDuration += duration;
|
|
194
|
+
existing.avgDuration = existing.totalDuration / existing.frequency;
|
|
195
|
+
existing.lastSeen = timestamp;
|
|
196
|
+
// Keep limited samples
|
|
197
|
+
existing.samples.push({ timestamp, duration, metadata });
|
|
198
|
+
if (existing.samples.length > 100) {
|
|
199
|
+
existing.samples = existing.samples.slice(-100);
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Store performance sample
|
|
205
|
+
*/
|
|
206
|
+
storeSample(operationName, duration, timestamp, metadata) {
|
|
207
|
+
if (!this.samples.has(operationName)) {
|
|
208
|
+
this.samples.set(operationName, []);
|
|
209
|
+
}
|
|
210
|
+
const samples = this.samples.get(operationName);
|
|
211
|
+
samples.push({ timestamp, duration, metadata });
|
|
212
|
+
// Limit samples to prevent memory growth
|
|
213
|
+
if (samples.length > this.sampleLimit) {
|
|
214
|
+
samples.splice(0, samples.length - this.sampleLimit);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Calculate 95th percentile from samples
|
|
219
|
+
*/
|
|
220
|
+
calculateP95(operationName) {
|
|
221
|
+
const samples = this.samples.get(operationName);
|
|
222
|
+
if (!samples || samples.length === 0)
|
|
223
|
+
return 0;
|
|
224
|
+
const durations = samples.map(s => s.duration).sort((a, b) => a - b);
|
|
225
|
+
const index = Math.floor(durations.length * 0.95);
|
|
226
|
+
return durations[index] || 0;
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* Generate optimization recommendations
|
|
230
|
+
*/
|
|
231
|
+
generateRecommendations(hotPaths) {
|
|
232
|
+
const recommendations = [];
|
|
233
|
+
for (const hotPath of hotPaths.slice(0, 5)) {
|
|
234
|
+
const impact = hotPath.frequency * hotPath.avgDuration;
|
|
235
|
+
if (hotPath.path.includes('getFrameContext') && hotPath.avgDuration > 10) {
|
|
236
|
+
recommendations.push(`Consider caching frame context for ${hotPath.path} (avg: ${hotPath.avgDuration.toFixed(1)}ms)`);
|
|
237
|
+
}
|
|
238
|
+
if (hotPath.path.includes('getFrameEvents') && hotPath.frequency > 100) {
|
|
239
|
+
recommendations.push(`High frequency event queries detected in ${hotPath.path} (${hotPath.frequency} calls). Consider pagination or caching.`);
|
|
240
|
+
}
|
|
241
|
+
if (hotPath.path.includes('bulkInsert') && hotPath.avgDuration > 50) {
|
|
242
|
+
recommendations.push(`Slow bulk insertion in ${hotPath.path}. Consider increasing batch size or using prepared statements.`);
|
|
243
|
+
}
|
|
244
|
+
if (impact > 1000) {
|
|
245
|
+
recommendations.push(`High impact operation: ${hotPath.path} (${impact.toFixed(0)}ms total impact). Consider optimization.`);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
// Memory recommendations
|
|
249
|
+
const memUsage = process.memoryUsage();
|
|
250
|
+
if (memUsage.heapUsed / memUsage.heapTotal > 0.8) {
|
|
251
|
+
recommendations.push('High memory usage detected. Consider implementing cleanup routines or reducing cache sizes.');
|
|
252
|
+
}
|
|
253
|
+
if (recommendations.length === 0) {
|
|
254
|
+
recommendations.push('No significant performance issues detected.');
|
|
255
|
+
}
|
|
256
|
+
return recommendations;
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
// Global profiler instance
|
|
260
|
+
let globalProfiler = null;
|
|
261
|
+
/**
|
|
262
|
+
* Get or create global profiler
|
|
263
|
+
*/
|
|
264
|
+
export function getProfiler() {
|
|
265
|
+
if (!globalProfiler) {
|
|
266
|
+
globalProfiler = new PerformanceProfiler({
|
|
267
|
+
enabled: process.env.NODE_ENV !== 'production' || process.env.STACKMEMORY_PROFILING === 'true',
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
return globalProfiler;
|
|
271
|
+
}
|
|
272
|
+
/**
|
|
273
|
+
* Convenience function to time operations
|
|
274
|
+
*/
|
|
275
|
+
export async function timeOperation(operationName, fn, metadata) {
|
|
276
|
+
return getProfiler().timeFunction(operationName, fn, metadata);
|
|
277
|
+
}
|
|
278
|
+
/**
|
|
279
|
+
* Create a performance monitoring decorator
|
|
280
|
+
*/
|
|
281
|
+
export function performanceMonitor(operationName) {
|
|
282
|
+
return function (target, propertyKey, descriptor) {
|
|
283
|
+
const originalMethod = descriptor.value;
|
|
284
|
+
const finalOperationName = operationName || `${target.constructor.name}.${propertyKey}`;
|
|
285
|
+
descriptor.value = async function (...args) {
|
|
286
|
+
return getProfiler().timeFunction(finalOperationName, () => originalMethod.apply(this, args));
|
|
287
|
+
};
|
|
288
|
+
return descriptor;
|
|
289
|
+
};
|
|
290
|
+
}
|
|
291
|
+
/**
|
|
292
|
+
* Monitor specific StackMemory operations
|
|
293
|
+
*/
|
|
294
|
+
export class StackMemoryPerformanceMonitor {
|
|
295
|
+
profiler = getProfiler();
|
|
296
|
+
/**
|
|
297
|
+
* Monitor frame operations
|
|
298
|
+
*/
|
|
299
|
+
monitorFrameOperations(frameManager) {
|
|
300
|
+
this.wrapMethod(frameManager, 'getFrame', 'FrameManager.getFrame');
|
|
301
|
+
this.wrapMethod(frameManager, 'getFrameEvents', 'FrameManager.getFrameEvents');
|
|
302
|
+
this.wrapMethod(frameManager, 'getFrameAnchors', 'FrameManager.getFrameAnchors');
|
|
303
|
+
this.wrapMethod(frameManager, 'getHotStackContext', 'FrameManager.getHotStackContext');
|
|
304
|
+
}
|
|
305
|
+
/**
|
|
306
|
+
* Monitor database operations
|
|
307
|
+
*/
|
|
308
|
+
monitorDatabaseOperations(db) {
|
|
309
|
+
const originalPrepare = db.prepare;
|
|
310
|
+
db.prepare = function (sql) {
|
|
311
|
+
const stmt = originalPrepare.call(this, sql);
|
|
312
|
+
return wrapStatement(stmt, sql);
|
|
313
|
+
};
|
|
314
|
+
}
|
|
315
|
+
/**
|
|
316
|
+
* Wrap a method with performance monitoring
|
|
317
|
+
*/
|
|
318
|
+
wrapMethod(obj, methodName, operationName) {
|
|
319
|
+
const original = obj[methodName];
|
|
320
|
+
if (typeof original !== 'function')
|
|
321
|
+
return;
|
|
322
|
+
obj[methodName] = async function (...args) {
|
|
323
|
+
return getProfiler().timeFunction(operationName, () => original.apply(this, args));
|
|
324
|
+
};
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
/**
|
|
328
|
+
* Wrap a database statement with performance monitoring
|
|
329
|
+
*/
|
|
330
|
+
function wrapStatement(stmt, sql) {
|
|
331
|
+
const operationName = `SQL.${sql.trim().split(' ')[0].toUpperCase()}`;
|
|
332
|
+
const originalRun = stmt.run;
|
|
333
|
+
const originalGet = stmt.get;
|
|
334
|
+
const originalAll = stmt.all;
|
|
335
|
+
stmt.run = function (...args) {
|
|
336
|
+
return getProfiler().timeFunction(`${operationName}.run`, () => originalRun.apply(this, args));
|
|
337
|
+
};
|
|
338
|
+
stmt.get = function (...args) {
|
|
339
|
+
return getProfiler().timeFunction(`${operationName}.get`, () => originalGet.apply(this, args));
|
|
340
|
+
};
|
|
341
|
+
stmt.all = function (...args) {
|
|
342
|
+
return getProfiler().timeFunction(`${operationName}.all`, () => originalAll.apply(this, args));
|
|
343
|
+
};
|
|
344
|
+
return stmt;
|
|
345
|
+
}
|
|
346
|
+
//# sourceMappingURL=performance-profiler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"performance-profiler.js","sourceRoot":"","sources":["../../../../src/core/performance/performance-profiler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Optimized Streaming JSONL Parser
|
|
3
|
+
* Memory-efficient parsing for large JSONL files with async streaming
|
|
4
|
+
*/
|
|
5
|
+
import { Transform } from 'stream';
|
|
6
|
+
export interface ParseOptions {
|
|
7
|
+
maxLineLength?: number;
|
|
8
|
+
batchSize?: number;
|
|
9
|
+
filter?: (obj: any) => boolean;
|
|
10
|
+
transform?: (obj: any) => any;
|
|
11
|
+
onProgress?: (processed: number, total?: number) => void;
|
|
12
|
+
}
|
|
13
|
+
export declare class StreamingJSONLParser {
|
|
14
|
+
private readonly DEFAULT_BATCH_SIZE;
|
|
15
|
+
private readonly DEFAULT_MAX_LINE_LENGTH;
|
|
16
|
+
/**
|
|
17
|
+
* Stream-parse a JSONL file with batching and backpressure handling
|
|
18
|
+
*/
|
|
19
|
+
parseStream<T = any>(filePath: string, options?: ParseOptions): AsyncGenerator<T[], void, unknown>;
|
|
20
|
+
/**
|
|
21
|
+
* Parse entire file into memory (use for smaller files)
|
|
22
|
+
*/
|
|
23
|
+
parseAll<T = any>(filePath: string, options?: Omit<ParseOptions, 'batchSize'>): Promise<T[]>;
|
|
24
|
+
/**
|
|
25
|
+
* Process JSONL file with a custom processor function
|
|
26
|
+
*/
|
|
27
|
+
process<T = any, R = void>(filePath: string, processor: (items: T[]) => Promise<R>, options?: ParseOptions): Promise<R[]>;
|
|
28
|
+
/**
|
|
29
|
+
* Create a transform stream for JSONL parsing
|
|
30
|
+
*/
|
|
31
|
+
createTransformStream<T = any>(options?: ParseOptions): Transform;
|
|
32
|
+
/**
|
|
33
|
+
* Count lines in JSONL file without parsing
|
|
34
|
+
*/
|
|
35
|
+
countLines(filePath: string): Promise<number>;
|
|
36
|
+
/**
|
|
37
|
+
* Sample random lines from JSONL file
|
|
38
|
+
*/
|
|
39
|
+
sampleLines<T = any>(filePath: string, sampleRate: number, options?: Omit<ParseOptions, 'batchSize'>): AsyncGenerator<T, void, unknown>;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=streaming-jsonl-parser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"streaming-jsonl-parser.d.ts","sourceRoot":"","sources":["../../../../src/core/performance/streaming-jsonl-parser.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,SAAS,EAAY,MAAM,QAAQ,CAAC;AAM7C,MAAM,WAAW,YAAY;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,OAAO,CAAC;IAC/B,SAAS,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,CAAC;IAC9B,UAAU,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;CAC1D;AAED,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAO;IAC1C,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAAe;IAEvD;;OAEG;IACI,WAAW,CAAC,CAAC,GAAG,GAAG,EACxB,QAAQ,EAAE,MAAM,EAChB,OAAO,GAAE,YAAiB,GACzB,cAAc,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC;IAmFrC;;OAEG;IACG,QAAQ,CAAC,CAAC,GAAG,GAAG,EACpB,QAAQ,EAAE,MAAM,EAChB,OAAO,GAAE,IAAI,CAAC,YAAY,EAAE,WAAW,CAAM,GAC5C,OAAO,CAAC,CAAC,EAAE,CAAC;IAaf;;OAEG;IACG,OAAO,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,IAAI,EAC7B,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC,CAAC,EACrC,OAAO,GAAE,YAAiB,GACzB,OAAO,CAAC,CAAC,EAAE,CAAC;IAWf;;OAEG;IACH,qBAAqB,CAAC,CAAC,GAAG,GAAG,EAC3B,OAAO,GAAE,YAAiB,GACzB,SAAS;IAwDZ;;OAEG;IACG,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAYnD;;OAEG;IACI,WAAW,CAAC,CAAC,GAAG,GAAG,EACxB,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,OAAO,GAAE,IAAI,CAAC,YAAY,EAAE,WAAW,CAAM,GAC5C,cAAc,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC;CAapC"}
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Optimized Streaming JSONL Parser
|
|
3
|
+
* Memory-efficient parsing for large JSONL files with async streaming
|
|
4
|
+
*/
|
|
5
|
+
import { createReadStream } from 'fs';
|
|
6
|
+
import { createInterface } from 'readline';
|
|
7
|
+
import { Transform, pipeline } from 'stream';
|
|
8
|
+
import { promisify } from 'util';
|
|
9
|
+
import { logger } from '../monitoring/logger.js';
|
|
10
|
+
const pipelineAsync = promisify(pipeline);
|
|
11
|
+
export class StreamingJSONLParser {
|
|
12
|
+
DEFAULT_BATCH_SIZE = 100;
|
|
13
|
+
DEFAULT_MAX_LINE_LENGTH = 1024 * 1024; // 1MB per line
|
|
14
|
+
/**
|
|
15
|
+
* Stream-parse a JSONL file with batching and backpressure handling
|
|
16
|
+
*/
|
|
17
|
+
async *parseStream(filePath, options = {}) {
|
|
18
|
+
const { batchSize = this.DEFAULT_BATCH_SIZE, maxLineLength = this.DEFAULT_MAX_LINE_LENGTH, filter, transform, onProgress, } = options;
|
|
19
|
+
const stream = createReadStream(filePath, {
|
|
20
|
+
encoding: 'utf8',
|
|
21
|
+
highWaterMark: 64 * 1024, // 64KB chunks
|
|
22
|
+
});
|
|
23
|
+
const rl = createInterface({
|
|
24
|
+
input: stream,
|
|
25
|
+
crlfDelay: Infinity,
|
|
26
|
+
historySize: 0, // Disable history for memory efficiency
|
|
27
|
+
});
|
|
28
|
+
let batch = [];
|
|
29
|
+
let lineCount = 0;
|
|
30
|
+
let processedCount = 0;
|
|
31
|
+
let errorCount = 0;
|
|
32
|
+
try {
|
|
33
|
+
for await (const line of rl) {
|
|
34
|
+
lineCount++;
|
|
35
|
+
if (line.length > maxLineLength) {
|
|
36
|
+
logger.warn('Skipping oversized line', {
|
|
37
|
+
lineNumber: lineCount,
|
|
38
|
+
length: line.length,
|
|
39
|
+
maxLength: maxLineLength,
|
|
40
|
+
});
|
|
41
|
+
errorCount++;
|
|
42
|
+
continue;
|
|
43
|
+
}
|
|
44
|
+
if (!line.trim())
|
|
45
|
+
continue;
|
|
46
|
+
try {
|
|
47
|
+
let obj = JSON.parse(line);
|
|
48
|
+
if (filter && !filter(obj))
|
|
49
|
+
continue;
|
|
50
|
+
if (transform)
|
|
51
|
+
obj = transform(obj);
|
|
52
|
+
batch.push(obj);
|
|
53
|
+
processedCount++;
|
|
54
|
+
if (batch.length >= batchSize) {
|
|
55
|
+
yield batch;
|
|
56
|
+
batch = [];
|
|
57
|
+
onProgress?.(processedCount);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
catch (parseError) {
|
|
61
|
+
errorCount++;
|
|
62
|
+
logger.debug('Failed to parse JSONL line', {
|
|
63
|
+
lineNumber: lineCount,
|
|
64
|
+
error: parseError,
|
|
65
|
+
preview: line.substring(0, 100),
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
// Yield remaining items
|
|
70
|
+
if (batch.length > 0) {
|
|
71
|
+
yield batch;
|
|
72
|
+
onProgress?.(processedCount);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
finally {
|
|
76
|
+
rl.close();
|
|
77
|
+
stream.destroy();
|
|
78
|
+
logger.debug('JSONL parsing complete', {
|
|
79
|
+
filePath,
|
|
80
|
+
totalLines: lineCount,
|
|
81
|
+
processed: processedCount,
|
|
82
|
+
errors: errorCount,
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Parse entire file into memory (use for smaller files)
|
|
88
|
+
*/
|
|
89
|
+
async parseAll(filePath, options = {}) {
|
|
90
|
+
const results = [];
|
|
91
|
+
for await (const batch of this.parseStream(filePath, {
|
|
92
|
+
...options,
|
|
93
|
+
batchSize: Number.MAX_SAFE_INTEGER,
|
|
94
|
+
})) {
|
|
95
|
+
results.push(...batch);
|
|
96
|
+
}
|
|
97
|
+
return results;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Process JSONL file with a custom processor function
|
|
101
|
+
*/
|
|
102
|
+
async process(filePath, processor, options = {}) {
|
|
103
|
+
const results = [];
|
|
104
|
+
for await (const batch of this.parseStream(filePath, options)) {
|
|
105
|
+
const result = await processor(batch);
|
|
106
|
+
results.push(result);
|
|
107
|
+
}
|
|
108
|
+
return results;
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Create a transform stream for JSONL parsing
|
|
112
|
+
*/
|
|
113
|
+
createTransformStream(options = {}) {
|
|
114
|
+
const { filter, transform, maxLineLength = this.DEFAULT_MAX_LINE_LENGTH } = options;
|
|
115
|
+
let buffer = '';
|
|
116
|
+
let lineCount = 0;
|
|
117
|
+
return new Transform({
|
|
118
|
+
objectMode: true,
|
|
119
|
+
transform(chunk, encoding, callback) {
|
|
120
|
+
buffer += chunk.toString();
|
|
121
|
+
const lines = buffer.split('\n');
|
|
122
|
+
// Keep incomplete line in buffer
|
|
123
|
+
buffer = lines.pop() || '';
|
|
124
|
+
for (const line of lines) {
|
|
125
|
+
lineCount++;
|
|
126
|
+
if (!line.trim())
|
|
127
|
+
continue;
|
|
128
|
+
if (line.length > maxLineLength) {
|
|
129
|
+
logger.warn('Skipping oversized line in transform', { lineCount });
|
|
130
|
+
continue;
|
|
131
|
+
}
|
|
132
|
+
try {
|
|
133
|
+
let obj = JSON.parse(line);
|
|
134
|
+
if (filter && !filter(obj))
|
|
135
|
+
continue;
|
|
136
|
+
if (transform)
|
|
137
|
+
obj = transform(obj);
|
|
138
|
+
this.push(obj);
|
|
139
|
+
}
|
|
140
|
+
catch (error) {
|
|
141
|
+
logger.debug('Transform parse error', { lineCount, error });
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
callback();
|
|
145
|
+
},
|
|
146
|
+
flush(callback) {
|
|
147
|
+
// Process any remaining data
|
|
148
|
+
if (buffer.trim()) {
|
|
149
|
+
try {
|
|
150
|
+
let obj = JSON.parse(buffer);
|
|
151
|
+
if (!filter || filter(obj)) {
|
|
152
|
+
if (transform)
|
|
153
|
+
obj = transform(obj);
|
|
154
|
+
this.push(obj);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
catch (error) {
|
|
158
|
+
logger.debug('Flush parse error', { error });
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
callback();
|
|
162
|
+
}
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* Count lines in JSONL file without parsing
|
|
167
|
+
*/
|
|
168
|
+
async countLines(filePath) {
|
|
169
|
+
const stream = createReadStream(filePath, { encoding: 'utf8' });
|
|
170
|
+
const rl = createInterface({ input: stream, historySize: 0 });
|
|
171
|
+
let count = 0;
|
|
172
|
+
for await (const _ of rl) {
|
|
173
|
+
count++;
|
|
174
|
+
}
|
|
175
|
+
return count;
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Sample random lines from JSONL file
|
|
179
|
+
*/
|
|
180
|
+
async *sampleLines(filePath, sampleRate, options = {}) {
|
|
181
|
+
if (sampleRate <= 0 || sampleRate > 1) {
|
|
182
|
+
throw new Error('Sample rate must be between 0 and 1');
|
|
183
|
+
}
|
|
184
|
+
for await (const batch of this.parseStream(filePath, options)) {
|
|
185
|
+
for (const item of batch) {
|
|
186
|
+
if (Math.random() < sampleRate) {
|
|
187
|
+
yield item;
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
//# sourceMappingURL=streaming-jsonl-parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"streaming-jsonl-parser.js","sourceRoot":"","sources":["../../../../src/core/performance/streaming-jsonl-parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgres-adapter.d.ts","sourceRoot":"","sources":["../../../../src/core/persistence/postgres-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,UAAU,EAAgC,MAAM,IAAI,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EACL,kBAAkB,EAClB,WAAW,EACX,SAAS,EACT,WAAW,EACZ,MAAM,aAAa,CAAC;AAGrB,MAAM,WAAW,cAAe,SAAQ,UAAU;IAChD,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,qBAAa,eAAgB,YAAW,kBAAkB;IACxD,OAAO,CAAC,IAAI,CAAO;IACnB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,aAAa,CAAS;gBAElB,MAAM,EAAE,cAAc;IAQ5B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAexB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAM3B,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IAqB5D,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIjC,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAIvB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,WAAW,IAAI,OAAO;YAIR,UAAU;YAaV,gBAAgB;YA+
|
|
1
|
+
{"version":3,"file":"postgres-adapter.d.ts","sourceRoot":"","sources":["../../../../src/core/persistence/postgres-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,UAAU,EAAgC,MAAM,IAAI,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EACL,kBAAkB,EAClB,WAAW,EACX,SAAS,EACT,WAAW,EACZ,MAAM,aAAa,CAAC;AAGrB,MAAM,WAAW,cAAe,SAAQ,UAAU;IAChD,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,qBAAa,eAAgB,YAAW,kBAAkB;IACxD,OAAO,CAAC,IAAI,CAAO;IACnB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,aAAa,CAAS;gBAElB,MAAM,EAAE,cAAc;IAQ5B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAexB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAM3B,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IAqB5D,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIjC,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAIvB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,WAAW,IAAI,OAAO;YAIR,UAAU;YAaV,gBAAgB;YA+EhB,eAAe;YA6Bf,cAAc;IAiCtB,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAe1C,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBhD,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,SAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAmBrE,gBAAgB,CACpB,SAAS,EAAE,MAAM,EACjB,MAAM,CAAC,EAAE,MAAM,EACf,KAAK,SAAK,GACT,OAAO,CAAC,WAAW,EAAE,CAAC;IA0BnB,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;CAuG3D"}
|
|
@@ -95,8 +95,7 @@ export class PostgresAdapter {
|
|
|
95
95
|
timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
96
96
|
type VARCHAR(100) NOT NULL,
|
|
97
97
|
data JSONB NOT NULL,
|
|
98
|
-
metadata JSONB
|
|
99
|
-
INDEX idx_traces_session_timestamp (session_id, timestamp)
|
|
98
|
+
metadata JSONB
|
|
100
99
|
)`,
|
|
101
100
|
// Context frames table
|
|
102
101
|
`CREATE TABLE IF NOT EXISTS context_frames (
|
|
@@ -107,8 +106,7 @@ export class PostgresAdapter {
|
|
|
107
106
|
summary TEXT,
|
|
108
107
|
timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
109
108
|
type VARCHAR(100) NOT NULL,
|
|
110
|
-
metadata JSONB
|
|
111
|
-
INDEX idx_context_project_branch (project_id, branch)
|
|
109
|
+
metadata JSONB
|
|
112
110
|
)`,
|
|
113
111
|
// Decisions table
|
|
114
112
|
`CREATE TABLE IF NOT EXISTS decisions (
|
|
@@ -124,6 +122,22 @@ export class PostgresAdapter {
|
|
|
124
122
|
for (const query of queries) {
|
|
125
123
|
await this.execute(query);
|
|
126
124
|
}
|
|
125
|
+
// Create indexes separately (PostgreSQL doesn't support inline INDEX in CREATE TABLE)
|
|
126
|
+
const indexes = [
|
|
127
|
+
`CREATE INDEX IF NOT EXISTS idx_traces_session_timestamp
|
|
128
|
+
ON traces(session_id, timestamp)`,
|
|
129
|
+
`CREATE INDEX IF NOT EXISTS idx_context_project_branch
|
|
130
|
+
ON context_frames(project_id, branch)`,
|
|
131
|
+
`CREATE INDEX IF NOT EXISTS idx_traces_type
|
|
132
|
+
ON traces(type)`,
|
|
133
|
+
`CREATE INDEX IF NOT EXISTS idx_context_frames_timestamp
|
|
134
|
+
ON context_frames(timestamp)`,
|
|
135
|
+
`CREATE INDEX IF NOT EXISTS idx_decisions_project_session
|
|
136
|
+
ON decisions(project_id, session_id)`,
|
|
137
|
+
];
|
|
138
|
+
for (const index of indexes) {
|
|
139
|
+
await this.execute(index);
|
|
140
|
+
}
|
|
127
141
|
}
|
|
128
142
|
async enableTimescale() {
|
|
129
143
|
try {
|