@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,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CLI Command Trace Wrapper
|
|
3
|
+
* Automatically wraps Commander.js commands with comprehensive tracing
|
|
4
|
+
*/
|
|
5
|
+
import { Command } from 'commander';
|
|
6
|
+
export declare function wrapCommand(command: Command): Command;
|
|
7
|
+
/**
|
|
8
|
+
* Wrap the main program with comprehensive tracing
|
|
9
|
+
*/
|
|
10
|
+
export declare function wrapProgram(program: Command): Command;
|
|
11
|
+
/**
|
|
12
|
+
* Helper to wrap async functions with step tracing
|
|
13
|
+
*/
|
|
14
|
+
export declare function traceStep<T>(name: string, fn: () => Promise<T>): Promise<T>;
|
|
15
|
+
/**
|
|
16
|
+
* Helper to wrap database queries
|
|
17
|
+
*/
|
|
18
|
+
export declare function traceQuery<T>(sql: string, params: any, fn: () => T): T;
|
|
19
|
+
/**
|
|
20
|
+
* Helper to wrap API calls
|
|
21
|
+
*/
|
|
22
|
+
export declare function traceAPI<T>(method: string, url: string, body: any, fn: () => Promise<T>): Promise<T>;
|
|
23
|
+
//# sourceMappingURL=cli-trace-wrapper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli-trace-wrapper.d.ts","sourceRoot":"","sources":["../../../../src/core/trace/cli-trace-wrapper.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAoErD;AAgBD;;GAEG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAiDrD;AAED;;GAEG;AACH,wBAAgB,SAAS,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAE3E;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,CAEtE;AAED;;GAEG;AACH,wBAAgB,QAAQ,CAAC,CAAC,EACxB,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,MAAM,EACX,IAAI,EAAE,GAAG,EACT,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACnB,OAAO,CAAC,CAAC,CAAC,CAEZ"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CLI Command Trace Wrapper
|
|
3
|
+
* Automatically wraps Commander.js commands with comprehensive tracing
|
|
4
|
+
*/
|
|
5
|
+
import { trace } from './debug-trace.js';
|
|
6
|
+
import { logger } from '../monitoring/logger.js';
|
|
7
|
+
export function wrapCommand(command) {
|
|
8
|
+
const originalAction = command.action.bind(command);
|
|
9
|
+
command.action(async function (...args) {
|
|
10
|
+
// Extract command path and options
|
|
11
|
+
const commandPath = getCommandPath(command);
|
|
12
|
+
const options = args[args.length - 1];
|
|
13
|
+
const commandArgs = args.slice(0, -1);
|
|
14
|
+
// Build comprehensive context
|
|
15
|
+
const context = {
|
|
16
|
+
command: commandPath,
|
|
17
|
+
args: commandArgs,
|
|
18
|
+
options: typeof options === 'object' ? options : {},
|
|
19
|
+
cwd: process.cwd(),
|
|
20
|
+
env: {
|
|
21
|
+
NODE_ENV: process.env.NODE_ENV,
|
|
22
|
+
DEBUG_TRACE: process.env.DEBUG_TRACE,
|
|
23
|
+
LINEAR_API_KEY: process.env.LINEAR_API_KEY ? '[SET]' : '[NOT SET]',
|
|
24
|
+
},
|
|
25
|
+
timestamp: new Date().toISOString(),
|
|
26
|
+
};
|
|
27
|
+
// Log command start
|
|
28
|
+
logger.info(`CLI Command: ${commandPath}`, context);
|
|
29
|
+
// Wrap the actual action with tracing
|
|
30
|
+
await trace.command(commandPath, context, async () => {
|
|
31
|
+
try {
|
|
32
|
+
// Call the original action with wrapped handler
|
|
33
|
+
const result = await originalAction.apply(null, args);
|
|
34
|
+
// Log successful completion
|
|
35
|
+
logger.info(`CLI Command Completed: ${commandPath}`, {
|
|
36
|
+
duration: trace.exportTraces().find(t => t.name === commandPath)?.duration,
|
|
37
|
+
});
|
|
38
|
+
// Show execution summary if verbose
|
|
39
|
+
if (process.env.DEBUG_TRACE === 'true') {
|
|
40
|
+
console.log(trace.getExecutionSummary());
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
// Enhanced error logging for CLI commands
|
|
45
|
+
logger.error(`CLI Command Failed: ${commandPath}`, error, context);
|
|
46
|
+
// Get the last error trace for debugging
|
|
47
|
+
const lastError = trace.getLastError();
|
|
48
|
+
if (lastError) {
|
|
49
|
+
console.error('\n📍 Error occurred at:');
|
|
50
|
+
console.error(` ${lastError.name}`);
|
|
51
|
+
if (lastError.params) {
|
|
52
|
+
console.error(' With params:', JSON.stringify(lastError.params, null, 2));
|
|
53
|
+
}
|
|
54
|
+
console.error(' Error details:', lastError.error);
|
|
55
|
+
}
|
|
56
|
+
// Re-throw to maintain original error handling
|
|
57
|
+
throw error;
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
// Recursively wrap subcommands
|
|
62
|
+
command.commands.forEach(subcommand => {
|
|
63
|
+
wrapCommand(subcommand);
|
|
64
|
+
});
|
|
65
|
+
return command;
|
|
66
|
+
}
|
|
67
|
+
function getCommandPath(command) {
|
|
68
|
+
const parts = [];
|
|
69
|
+
let current = command;
|
|
70
|
+
while (current) {
|
|
71
|
+
if (current.name()) {
|
|
72
|
+
parts.unshift(current.name());
|
|
73
|
+
}
|
|
74
|
+
current = current.parent;
|
|
75
|
+
}
|
|
76
|
+
return parts.join(' ');
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Wrap the main program with comprehensive tracing
|
|
80
|
+
*/
|
|
81
|
+
export function wrapProgram(program) {
|
|
82
|
+
// Add global error handler with tracing
|
|
83
|
+
program.exitOverride((err) => {
|
|
84
|
+
if (err.code === 'commander.help' || err.code === 'commander.version') {
|
|
85
|
+
// Normal help/version display, not an error
|
|
86
|
+
process.exit(0);
|
|
87
|
+
}
|
|
88
|
+
// Log the error with full context
|
|
89
|
+
logger.error('CLI Error', err, {
|
|
90
|
+
code: err.code,
|
|
91
|
+
exitCode: err.exitCode,
|
|
92
|
+
command: process.argv.slice(2).join(' '),
|
|
93
|
+
});
|
|
94
|
+
// Show trace summary on error
|
|
95
|
+
if (process.env.DEBUG_TRACE === 'true') {
|
|
96
|
+
console.error('\n' + trace.getExecutionSummary());
|
|
97
|
+
}
|
|
98
|
+
process.exit(err.exitCode || 1);
|
|
99
|
+
});
|
|
100
|
+
// Add pre-action hook for setup
|
|
101
|
+
program.hook('preAction', (thisCommand) => {
|
|
102
|
+
// Initialize trace context for this command
|
|
103
|
+
trace.reset();
|
|
104
|
+
// Log command invocation
|
|
105
|
+
const commandPath = getCommandPath(thisCommand);
|
|
106
|
+
logger.debug(`Preparing to execute: ${commandPath}`, {
|
|
107
|
+
args: thisCommand.args,
|
|
108
|
+
opts: thisCommand.opts(),
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
// Add post-action hook for cleanup
|
|
112
|
+
program.hook('postAction', (thisCommand) => {
|
|
113
|
+
// Log completion
|
|
114
|
+
const commandPath = getCommandPath(thisCommand);
|
|
115
|
+
logger.debug(`Completed execution: ${commandPath}`);
|
|
116
|
+
});
|
|
117
|
+
// Wrap all existing commands
|
|
118
|
+
program.commands.forEach(command => {
|
|
119
|
+
wrapCommand(command);
|
|
120
|
+
});
|
|
121
|
+
return program;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Helper to wrap async functions with step tracing
|
|
125
|
+
*/
|
|
126
|
+
export function traceStep(name, fn) {
|
|
127
|
+
return trace.step(name, fn);
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Helper to wrap database queries
|
|
131
|
+
*/
|
|
132
|
+
export function traceQuery(sql, params, fn) {
|
|
133
|
+
return trace.traceSync('query', sql.substring(0, 100), params, fn);
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Helper to wrap API calls
|
|
137
|
+
*/
|
|
138
|
+
export function traceAPI(method, url, body, fn) {
|
|
139
|
+
return trace.api(method, url, body, fn);
|
|
140
|
+
}
|
|
141
|
+
//# sourceMappingURL=cli-trace-wrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli-trace-wrapper.js","sourceRoot":"","sources":["../../../../src/core/trace/cli-trace-wrapper.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Database Operations Trace Wrapper
|
|
3
|
+
* Wraps SQLite operations with comprehensive tracing for debugging
|
|
4
|
+
*/
|
|
5
|
+
import Database from 'better-sqlite3';
|
|
6
|
+
export interface TracedDatabaseOptions extends Database.Options {
|
|
7
|
+
traceEnabled?: boolean;
|
|
8
|
+
slowQueryThreshold?: number;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Create a traced database instance
|
|
12
|
+
*/
|
|
13
|
+
export declare function createTracedDatabase(filename: string, options?: TracedDatabaseOptions): Database.Database;
|
|
14
|
+
/**
|
|
15
|
+
* Wrap an existing database with tracing
|
|
16
|
+
*/
|
|
17
|
+
export declare function wrapDatabase(db: Database.Database, slowQueryThreshold?: number): Database.Database;
|
|
18
|
+
/**
|
|
19
|
+
* Get query statistics from a traced database
|
|
20
|
+
*/
|
|
21
|
+
export declare function getQueryStatistics(db: Database.Database): {
|
|
22
|
+
totalQueries: number;
|
|
23
|
+
slowQueries: number;
|
|
24
|
+
averageDuration: number;
|
|
25
|
+
totalDuration: number;
|
|
26
|
+
queryTypes: Record<string, number>;
|
|
27
|
+
} | null;
|
|
28
|
+
/**
|
|
29
|
+
* Helper to trace a specific query with context
|
|
30
|
+
*/
|
|
31
|
+
export declare function traceQuery<T>(db: Database.Database, queryName: string, query: string, params: any[], fn: () => T): Promise<T>;
|
|
32
|
+
/**
|
|
33
|
+
* Create a traced transaction with automatic rollback on error
|
|
34
|
+
*/
|
|
35
|
+
export declare function createTracedTransaction<T>(db: Database.Database, name: string, fn: (tx: Database.Transaction<(args: any) => T>) => T): T;
|
|
36
|
+
//# sourceMappingURL=db-trace-wrapper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db-trace-wrapper.d.ts","sourceRoot":"","sources":["../../../../src/core/trace/db-trace-wrapper.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AAItC,MAAM,WAAW,qBAAsB,SAAQ,QAAQ,CAAC,OAAO;IAC7D,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAClC,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,qBAAqB,GAC9B,QAAQ,CAAC,QAAQ,CAQnB;AAED;;GAEG;AACH,wBAAgB,YAAY,CAC1B,EAAE,EAAE,QAAQ,CAAC,QAAQ,EACrB,kBAAkB,SAAM,GACvB,QAAQ,CAAC,QAAQ,CAiDnB;AA2JD;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,QAAQ,CAAC,QAAQ,GAAG;IACzD,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,eAAe,EAAE,MAAM,CAAC;IACxB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACpC,GAAG,IAAI,CAUP;AAED;;GAEG;AACH,wBAAsB,UAAU,CAAC,CAAC,EAChC,EAAE,EAAE,QAAQ,CAAC,QAAQ,EACrB,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,GAAG,EAAE,EACb,EAAE,EAAE,MAAM,CAAC,GACV,OAAO,CAAC,CAAC,CAAC,CAwBZ;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,CAAC,EACvC,EAAE,EAAE,QAAQ,CAAC,QAAQ,EACrB,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,CAAC,EAAE,EAAE,QAAQ,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,KAAK,CAAC,GACpD,CAAC,CAwBH"}
|
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Database Operations Trace Wrapper
|
|
3
|
+
* Wraps SQLite operations with comprehensive tracing for debugging
|
|
4
|
+
*/
|
|
5
|
+
import Database from 'better-sqlite3';
|
|
6
|
+
import { trace } from './debug-trace.js';
|
|
7
|
+
import { logger } from '../monitoring/logger.js';
|
|
8
|
+
/**
|
|
9
|
+
* Create a traced database instance
|
|
10
|
+
*/
|
|
11
|
+
export function createTracedDatabase(filename, options) {
|
|
12
|
+
const db = new Database(filename, options);
|
|
13
|
+
if (options?.traceEnabled !== false) {
|
|
14
|
+
return wrapDatabase(db, options?.slowQueryThreshold);
|
|
15
|
+
}
|
|
16
|
+
return db;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Wrap an existing database with tracing
|
|
20
|
+
*/
|
|
21
|
+
export function wrapDatabase(db, slowQueryThreshold = 100) {
|
|
22
|
+
// Wrap prepare method to trace all queries
|
|
23
|
+
const originalPrepare = db.prepare.bind(db);
|
|
24
|
+
db.prepare = function (source) {
|
|
25
|
+
const statement = originalPrepare(source);
|
|
26
|
+
return wrapStatement(statement, source, slowQueryThreshold);
|
|
27
|
+
};
|
|
28
|
+
// Wrap exec for direct SQL execution
|
|
29
|
+
const originalExec = db.exec.bind(db);
|
|
30
|
+
db.exec = function (source) {
|
|
31
|
+
return trace.traceSync('query', `EXEC: ${source.substring(0, 50)}...`, {}, () => {
|
|
32
|
+
const startTime = performance.now();
|
|
33
|
+
const result = originalExec(source);
|
|
34
|
+
const duration = performance.now() - startTime;
|
|
35
|
+
if (duration > slowQueryThreshold) {
|
|
36
|
+
logger.warn(`Slow query detected: ${duration.toFixed(0)}ms`, {
|
|
37
|
+
query: source.substring(0, 200),
|
|
38
|
+
duration,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
return result;
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
// Wrap transaction for transaction tracking
|
|
45
|
+
const originalTransaction = db.transaction.bind(db);
|
|
46
|
+
db.transaction = function (fn) {
|
|
47
|
+
return originalTransaction(function (...args) {
|
|
48
|
+
return trace.traceSync('query', 'TRANSACTION', { args: args.length }, () => {
|
|
49
|
+
return fn.apply(this, args);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
// Add query statistics tracking
|
|
54
|
+
db.__queryStats = {
|
|
55
|
+
totalQueries: 0,
|
|
56
|
+
slowQueries: 0,
|
|
57
|
+
totalDuration: 0,
|
|
58
|
+
queryTypes: {},
|
|
59
|
+
};
|
|
60
|
+
return db;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Wrap a statement with tracing
|
|
64
|
+
*/
|
|
65
|
+
function wrapStatement(statement, source, slowQueryThreshold) {
|
|
66
|
+
const queryType = source.trim().split(/\s+/)[0].toUpperCase();
|
|
67
|
+
const shortQuery = source.substring(0, 100).replace(/\s+/g, ' ');
|
|
68
|
+
// Wrap run method
|
|
69
|
+
const originalRun = statement.run.bind(statement);
|
|
70
|
+
statement.run = function (...params) {
|
|
71
|
+
return trace.traceSync('query', `${queryType}: ${shortQuery}`, params, () => {
|
|
72
|
+
const startTime = performance.now();
|
|
73
|
+
const result = originalRun(...params);
|
|
74
|
+
const duration = performance.now() - startTime;
|
|
75
|
+
// Track statistics
|
|
76
|
+
updateQueryStats(statement, queryType, duration, slowQueryThreshold);
|
|
77
|
+
// Log slow queries
|
|
78
|
+
if (duration > slowQueryThreshold) {
|
|
79
|
+
logger.warn(`Slow ${queryType} query: ${duration.toFixed(0)}ms`, {
|
|
80
|
+
query: shortQuery,
|
|
81
|
+
params,
|
|
82
|
+
duration,
|
|
83
|
+
changes: result.changes,
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
return result;
|
|
87
|
+
});
|
|
88
|
+
};
|
|
89
|
+
// Wrap get method
|
|
90
|
+
const originalGet = statement.get.bind(statement);
|
|
91
|
+
statement.get = function (...params) {
|
|
92
|
+
return trace.traceSync('query', `${queryType} (get): ${shortQuery}`, params, () => {
|
|
93
|
+
const startTime = performance.now();
|
|
94
|
+
const result = originalGet(...params);
|
|
95
|
+
const duration = performance.now() - startTime;
|
|
96
|
+
updateQueryStats(statement, queryType, duration, slowQueryThreshold);
|
|
97
|
+
if (duration > slowQueryThreshold) {
|
|
98
|
+
logger.warn(`Slow ${queryType} query: ${duration.toFixed(0)}ms`, {
|
|
99
|
+
query: shortQuery,
|
|
100
|
+
params,
|
|
101
|
+
duration,
|
|
102
|
+
found: result != null,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
return result;
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
// Wrap all method
|
|
109
|
+
const originalAll = statement.all.bind(statement);
|
|
110
|
+
statement.all = function (...params) {
|
|
111
|
+
return trace.traceSync('query', `${queryType} (all): ${shortQuery}`, params, () => {
|
|
112
|
+
const startTime = performance.now();
|
|
113
|
+
const result = originalAll(...params);
|
|
114
|
+
const duration = performance.now() - startTime;
|
|
115
|
+
updateQueryStats(statement, queryType, duration, slowQueryThreshold);
|
|
116
|
+
if (duration > slowQueryThreshold) {
|
|
117
|
+
logger.warn(`Slow ${queryType} query: ${duration.toFixed(0)}ms`, {
|
|
118
|
+
query: shortQuery,
|
|
119
|
+
params,
|
|
120
|
+
duration,
|
|
121
|
+
rows: result.length,
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
// Warn about potential N+1 queries
|
|
125
|
+
if (result.length > 100 && queryType === 'SELECT') {
|
|
126
|
+
logger.warn(`Large result set: ${result.length} rows`, {
|
|
127
|
+
query: shortQuery,
|
|
128
|
+
suggestion: 'Consider pagination or more specific queries',
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
return result;
|
|
132
|
+
});
|
|
133
|
+
};
|
|
134
|
+
// Wrap iterate method for cursor operations
|
|
135
|
+
const originalIterate = statement.iterate.bind(statement);
|
|
136
|
+
statement.iterate = function (...params) {
|
|
137
|
+
const startTime = performance.now();
|
|
138
|
+
let rowCount = 0;
|
|
139
|
+
const iterator = originalIterate(...params);
|
|
140
|
+
const wrappedIterator = {
|
|
141
|
+
[Symbol.iterator]() {
|
|
142
|
+
return this;
|
|
143
|
+
},
|
|
144
|
+
next() {
|
|
145
|
+
const result = iterator.next();
|
|
146
|
+
if (!result.done) {
|
|
147
|
+
rowCount++;
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
const duration = performance.now() - startTime;
|
|
151
|
+
updateQueryStats(statement, queryType, duration, slowQueryThreshold);
|
|
152
|
+
if (duration > slowQueryThreshold) {
|
|
153
|
+
logger.warn(`Slow ${queryType} iteration: ${duration.toFixed(0)}ms`, {
|
|
154
|
+
query: shortQuery,
|
|
155
|
+
params,
|
|
156
|
+
duration,
|
|
157
|
+
rows: rowCount,
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
return result;
|
|
162
|
+
},
|
|
163
|
+
};
|
|
164
|
+
return wrappedIterator;
|
|
165
|
+
};
|
|
166
|
+
return statement;
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Update query statistics
|
|
170
|
+
*/
|
|
171
|
+
function updateQueryStats(statement, queryType, duration, slowQueryThreshold) {
|
|
172
|
+
const db = statement.database;
|
|
173
|
+
if (db.__queryStats) {
|
|
174
|
+
db.__queryStats.totalQueries++;
|
|
175
|
+
db.__queryStats.totalDuration += duration;
|
|
176
|
+
if (duration > slowQueryThreshold) {
|
|
177
|
+
db.__queryStats.slowQueries++;
|
|
178
|
+
}
|
|
179
|
+
if (!db.__queryStats.queryTypes[queryType]) {
|
|
180
|
+
db.__queryStats.queryTypes[queryType] = 0;
|
|
181
|
+
}
|
|
182
|
+
db.__queryStats.queryTypes[queryType]++;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Get query statistics from a traced database
|
|
187
|
+
*/
|
|
188
|
+
export function getQueryStatistics(db) {
|
|
189
|
+
const stats = db.__queryStats;
|
|
190
|
+
if (!stats)
|
|
191
|
+
return null;
|
|
192
|
+
return {
|
|
193
|
+
...stats,
|
|
194
|
+
averageDuration: stats.totalQueries > 0
|
|
195
|
+
? stats.totalDuration / stats.totalQueries
|
|
196
|
+
: 0,
|
|
197
|
+
};
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Helper to trace a specific query with context
|
|
201
|
+
*/
|
|
202
|
+
export async function traceQuery(db, queryName, query, params, fn) {
|
|
203
|
+
return trace.traceAsync('query', queryName, { query, params }, async () => {
|
|
204
|
+
try {
|
|
205
|
+
const result = fn();
|
|
206
|
+
// Log successful complex queries for debugging
|
|
207
|
+
if (query.includes('JOIN') || query.includes('GROUP BY')) {
|
|
208
|
+
logger.debug(`Complex query executed: ${queryName}`, {
|
|
209
|
+
query: query.substring(0, 200),
|
|
210
|
+
params,
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
return result;
|
|
214
|
+
}
|
|
215
|
+
catch (error) {
|
|
216
|
+
// Enhanced error logging for database errors
|
|
217
|
+
logger.error(`Database query failed: ${queryName}`, error, {
|
|
218
|
+
query,
|
|
219
|
+
params,
|
|
220
|
+
errorCode: error.code,
|
|
221
|
+
});
|
|
222
|
+
throw error;
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* Create a traced transaction with automatic rollback on error
|
|
228
|
+
*/
|
|
229
|
+
export function createTracedTransaction(db, name, fn) {
|
|
230
|
+
return trace.traceSync('query', `TRANSACTION: ${name}`, {}, () => {
|
|
231
|
+
const startTime = performance.now();
|
|
232
|
+
try {
|
|
233
|
+
const tx = db.transaction(fn);
|
|
234
|
+
const result = tx.deferred();
|
|
235
|
+
const duration = performance.now() - startTime;
|
|
236
|
+
logger.info(`Transaction completed: ${name}`, {
|
|
237
|
+
duration,
|
|
238
|
+
success: true,
|
|
239
|
+
});
|
|
240
|
+
return result;
|
|
241
|
+
}
|
|
242
|
+
catch (error) {
|
|
243
|
+
const duration = performance.now() - startTime;
|
|
244
|
+
logger.error(`Transaction failed: ${name}`, error, {
|
|
245
|
+
duration,
|
|
246
|
+
success: false,
|
|
247
|
+
});
|
|
248
|
+
throw error;
|
|
249
|
+
}
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
//# sourceMappingURL=db-trace-wrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db-trace-wrapper.js","sourceRoot":"","sources":["../../../../src/core/trace/db-trace-wrapper.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Debug Trace Module - Comprehensive execution tracing for LLM debugging
|
|
3
|
+
*
|
|
4
|
+
* This module provides detailed execution tracing to help LLMs understand
|
|
5
|
+
* exactly what happened during code execution, making debugging much easier.
|
|
6
|
+
*/
|
|
7
|
+
export interface TraceConfig {
|
|
8
|
+
enabled: boolean;
|
|
9
|
+
verbosity: 'full' | 'errors' | 'summary';
|
|
10
|
+
output: 'console' | 'file' | 'both';
|
|
11
|
+
includeParams: boolean;
|
|
12
|
+
includeResults: boolean;
|
|
13
|
+
maskSensitive: boolean;
|
|
14
|
+
performanceThreshold: number;
|
|
15
|
+
maxDepth: number;
|
|
16
|
+
captureMemory: boolean;
|
|
17
|
+
}
|
|
18
|
+
interface TraceEntry {
|
|
19
|
+
id: string;
|
|
20
|
+
parentId?: string;
|
|
21
|
+
type: 'command' | 'function' | 'step' | 'query' | 'api' | 'error';
|
|
22
|
+
name: string;
|
|
23
|
+
startTime: number;
|
|
24
|
+
endTime?: number;
|
|
25
|
+
duration?: number;
|
|
26
|
+
depth: number;
|
|
27
|
+
params?: any;
|
|
28
|
+
result?: any;
|
|
29
|
+
error?: any;
|
|
30
|
+
memory?: {
|
|
31
|
+
before: NodeJS.MemoryUsage;
|
|
32
|
+
after?: NodeJS.MemoryUsage;
|
|
33
|
+
delta?: {
|
|
34
|
+
rss: number;
|
|
35
|
+
heapUsed: number;
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
metadata?: Record<string, any>;
|
|
39
|
+
children: TraceEntry[];
|
|
40
|
+
}
|
|
41
|
+
export declare class TraceContext {
|
|
42
|
+
private static instance;
|
|
43
|
+
private config;
|
|
44
|
+
private currentTrace;
|
|
45
|
+
private traceStack;
|
|
46
|
+
private allTraces;
|
|
47
|
+
private outputFile?;
|
|
48
|
+
private startTime;
|
|
49
|
+
private sensitivePatterns;
|
|
50
|
+
private constructor();
|
|
51
|
+
static getInstance(): TraceContext;
|
|
52
|
+
private loadConfig;
|
|
53
|
+
private initializeOutputFile;
|
|
54
|
+
private maskSensitiveData;
|
|
55
|
+
private captureMemory;
|
|
56
|
+
private formatDuration;
|
|
57
|
+
private formatMemory;
|
|
58
|
+
private getIndent;
|
|
59
|
+
private formatTraceEntry;
|
|
60
|
+
private outputTrace;
|
|
61
|
+
startTrace(type: TraceEntry['type'], name: string, params?: any, metadata?: Record<string, any>): string;
|
|
62
|
+
endTrace(id: string, result?: any, error?: any): void;
|
|
63
|
+
traceAsync<T>(type: TraceEntry['type'], name: string, params: any, fn: () => Promise<T>): Promise<T>;
|
|
64
|
+
traceSync<T>(type: TraceEntry['type'], name: string, params: any, fn: () => T): T;
|
|
65
|
+
command<T>(name: string, options: any, fn: () => Promise<T>): Promise<T>;
|
|
66
|
+
step<T>(name: string, fn: () => Promise<T>): Promise<T>;
|
|
67
|
+
query<T>(sql: string, params: any, fn: () => Promise<T>): Promise<T>;
|
|
68
|
+
api<T>(method: string, url: string, body: any, fn: () => Promise<T>): Promise<T>;
|
|
69
|
+
getExecutionSummary(): string;
|
|
70
|
+
private countOperations;
|
|
71
|
+
private countErrors;
|
|
72
|
+
private countSlowOperations;
|
|
73
|
+
getLastError(): TraceEntry | null;
|
|
74
|
+
exportTraces(): TraceEntry[];
|
|
75
|
+
reset(): void;
|
|
76
|
+
}
|
|
77
|
+
export declare const trace: TraceContext;
|
|
78
|
+
export declare function Trace(type?: TraceEntry['type']): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => PropertyDescriptor;
|
|
79
|
+
export declare function TraceClass(type?: TraceEntry['type']): <T extends {
|
|
80
|
+
new (...args: any[]): {};
|
|
81
|
+
}>(constructor: T) => T;
|
|
82
|
+
export declare function TraceCritical(target: any, propertyKey: string, descriptor: PropertyDescriptor): PropertyDescriptor;
|
|
83
|
+
export {};
|
|
84
|
+
//# sourceMappingURL=debug-trace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"debug-trace.d.ts","sourceRoot":"","sources":["../../../../src/core/trace/debug-trace.ts"],"names":[],"mappings":"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"}
|