@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,121 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trace Module Export
|
|
3
|
+
* Central export for all tracing functionality
|
|
4
|
+
*/
|
|
5
|
+
export { trace, TraceContext, Trace, TraceClass, TraceCritical, } from './debug-trace.js';
|
|
6
|
+
export { wrapCommand, wrapProgram, traceStep, traceQuery, traceAPI, } from './cli-trace-wrapper.js';
|
|
7
|
+
export { createTracedDatabase, wrapDatabase, getQueryStatistics, createTracedTransaction, } from './db-trace-wrapper.js';
|
|
8
|
+
export { TraceLinearAPI, createTracedFetch, wrapGraphQLClient, } from './linear-api-wrapper.js';
|
|
9
|
+
/**
|
|
10
|
+
* Initialize tracing based on environment configuration
|
|
11
|
+
*/
|
|
12
|
+
export function initializeTracing() {
|
|
13
|
+
const config = {
|
|
14
|
+
// Main control
|
|
15
|
+
DEBUG_TRACE: process.env.DEBUG_TRACE === 'true',
|
|
16
|
+
STACKMEMORY_DEBUG: process.env.STACKMEMORY_DEBUG === 'true',
|
|
17
|
+
// Output control
|
|
18
|
+
TRACE_OUTPUT: process.env.TRACE_OUTPUT || 'console', // console|file|both
|
|
19
|
+
TRACE_VERBOSITY: process.env.TRACE_VERBOSITY || 'full', // full|errors|summary
|
|
20
|
+
// Content control
|
|
21
|
+
TRACE_PARAMS: process.env.TRACE_PARAMS !== 'false', // Include parameters
|
|
22
|
+
TRACE_RESULTS: process.env.TRACE_RESULTS !== 'false', // Include results
|
|
23
|
+
TRACE_MASK_SENSITIVE: process.env.TRACE_MASK_SENSITIVE !== 'false', // Mask sensitive data
|
|
24
|
+
// Performance
|
|
25
|
+
TRACE_PERF_THRESHOLD: parseInt(process.env.TRACE_PERF_THRESHOLD || '100'), // ms
|
|
26
|
+
TRACE_MEMORY: process.env.TRACE_MEMORY === 'true', // Track memory usage
|
|
27
|
+
TRACE_MAX_DEPTH: parseInt(process.env.TRACE_MAX_DEPTH || '20'), // Max call depth
|
|
28
|
+
// Database specific
|
|
29
|
+
TRACE_DB: process.env.TRACE_DB === 'true', // Enable database tracing
|
|
30
|
+
TRACE_DB_SLOW: parseInt(process.env.TRACE_DB_SLOW || '100'), // Slow query threshold
|
|
31
|
+
// API specific
|
|
32
|
+
TRACE_API: process.env.TRACE_API === 'true', // Enable API tracing
|
|
33
|
+
TRACE_API_SLOW: parseInt(process.env.TRACE_API_SLOW || '1000'), // Slow API threshold
|
|
34
|
+
};
|
|
35
|
+
// Log configuration if debugging is enabled
|
|
36
|
+
if (config.DEBUG_TRACE || config.STACKMEMORY_DEBUG) {
|
|
37
|
+
console.log('š Trace Configuration:', {
|
|
38
|
+
enabled: true,
|
|
39
|
+
output: config.TRACE_OUTPUT,
|
|
40
|
+
verbosity: config.TRACE_VERBOSITY,
|
|
41
|
+
includeParams: config.TRACE_PARAMS,
|
|
42
|
+
includeResults: config.TRACE_RESULTS,
|
|
43
|
+
maskSensitive: config.TRACE_MASK_SENSITIVE,
|
|
44
|
+
performanceThreshold: config.TRACE_PERF_THRESHOLD,
|
|
45
|
+
captureMemory: config.TRACE_MEMORY,
|
|
46
|
+
maxDepth: config.TRACE_MAX_DEPTH,
|
|
47
|
+
database: {
|
|
48
|
+
enabled: config.TRACE_DB,
|
|
49
|
+
slowThreshold: config.TRACE_DB_SLOW,
|
|
50
|
+
},
|
|
51
|
+
api: {
|
|
52
|
+
enabled: config.TRACE_API,
|
|
53
|
+
slowThreshold: config.TRACE_API_SLOW,
|
|
54
|
+
},
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Helper to enable tracing for a specific scope
|
|
60
|
+
*/
|
|
61
|
+
export function withTracing(fn, options) {
|
|
62
|
+
const originalEnv = process.env.DEBUG_TRACE;
|
|
63
|
+
try {
|
|
64
|
+
// Temporarily enable tracing
|
|
65
|
+
process.env.DEBUG_TRACE = 'true';
|
|
66
|
+
// Apply custom options if provided
|
|
67
|
+
if (options) {
|
|
68
|
+
if (options.output)
|
|
69
|
+
process.env.TRACE_OUTPUT = options.output;
|
|
70
|
+
if (options.verbosity)
|
|
71
|
+
process.env.TRACE_VERBOSITY = options.verbosity;
|
|
72
|
+
if (options.includeParams !== undefined) {
|
|
73
|
+
process.env.TRACE_PARAMS = String(options.includeParams);
|
|
74
|
+
}
|
|
75
|
+
if (options.includeResults !== undefined) {
|
|
76
|
+
process.env.TRACE_RESULTS = String(options.includeResults);
|
|
77
|
+
}
|
|
78
|
+
if (options.performanceThreshold !== undefined) {
|
|
79
|
+
process.env.TRACE_PERF_THRESHOLD = String(options.performanceThreshold);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return fn();
|
|
83
|
+
}
|
|
84
|
+
finally {
|
|
85
|
+
// Restore original environment
|
|
86
|
+
if (originalEnv === undefined) {
|
|
87
|
+
delete process.env.DEBUG_TRACE;
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
process.env.DEBUG_TRACE = originalEnv;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Quick enable/disable functions for debugging
|
|
96
|
+
*/
|
|
97
|
+
export const enableTracing = () => {
|
|
98
|
+
process.env.DEBUG_TRACE = 'true';
|
|
99
|
+
console.log('ā
Tracing enabled');
|
|
100
|
+
};
|
|
101
|
+
export const disableTracing = () => {
|
|
102
|
+
delete process.env.DEBUG_TRACE;
|
|
103
|
+
console.log('ā Tracing disabled');
|
|
104
|
+
};
|
|
105
|
+
export const enableVerboseTracing = () => {
|
|
106
|
+
process.env.DEBUG_TRACE = 'true';
|
|
107
|
+
process.env.TRACE_VERBOSITY = 'full';
|
|
108
|
+
process.env.TRACE_PARAMS = 'true';
|
|
109
|
+
process.env.TRACE_RESULTS = 'true';
|
|
110
|
+
process.env.TRACE_MEMORY = 'true';
|
|
111
|
+
console.log('ā
Verbose tracing enabled');
|
|
112
|
+
};
|
|
113
|
+
export const enableMinimalTracing = () => {
|
|
114
|
+
process.env.DEBUG_TRACE = 'true';
|
|
115
|
+
process.env.TRACE_VERBOSITY = 'summary';
|
|
116
|
+
process.env.TRACE_PARAMS = 'false';
|
|
117
|
+
process.env.TRACE_RESULTS = 'false';
|
|
118
|
+
process.env.TRACE_MEMORY = 'false';
|
|
119
|
+
console.log('ā
Minimal tracing enabled');
|
|
120
|
+
};
|
|
121
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/trace/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Linear API Trace Wrapper
|
|
3
|
+
* Wraps Linear API client with comprehensive tracing for debugging
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Decorator to trace Linear API GraphQL calls
|
|
7
|
+
*/
|
|
8
|
+
export declare function TraceLinearAPI(target: any, propertyKey: string, descriptor: PropertyDescriptor): PropertyDescriptor;
|
|
9
|
+
/**
|
|
10
|
+
* Wrap fetch with tracing for HTTP-level debugging
|
|
11
|
+
*/
|
|
12
|
+
export declare function createTracedFetch(baseFetch?: typeof fetch): typeof fetch;
|
|
13
|
+
/**
|
|
14
|
+
* Create a traced GraphQL client wrapper
|
|
15
|
+
*/
|
|
16
|
+
export declare function wrapGraphQLClient<T>(client: T): T;
|
|
17
|
+
//# sourceMappingURL=linear-api-wrapper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linear-api-wrapper.d.ts","sourceRoot":"","sources":["../../../../src/core/trace/linear-api-wrapper.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAKH;;GAEG;AACH,wBAAgB,cAAc,CAC5B,MAAM,EAAE,GAAG,EACX,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,kBAAkB,sBAuF/B;AAmCD;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,SAAS,eAAQ,GAAG,OAAO,KAAK,CA0EjE;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,GAAG,CAAC,CAgBjD"}
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Linear API Trace Wrapper
|
|
3
|
+
* Wraps Linear API client with comprehensive tracing for debugging
|
|
4
|
+
*/
|
|
5
|
+
import { trace } from './debug-trace.js';
|
|
6
|
+
import { logger } from '../monitoring/logger.js';
|
|
7
|
+
/**
|
|
8
|
+
* Decorator to trace Linear API GraphQL calls
|
|
9
|
+
*/
|
|
10
|
+
export function TraceLinearAPI(target, propertyKey, descriptor) {
|
|
11
|
+
const originalMethod = descriptor.value;
|
|
12
|
+
const isAsync = originalMethod.constructor.name === 'AsyncFunction';
|
|
13
|
+
if (isAsync) {
|
|
14
|
+
descriptor.value = async function (...args) {
|
|
15
|
+
const className = target.constructor.name;
|
|
16
|
+
const methodName = `${className}.${propertyKey}`;
|
|
17
|
+
// Extract meaningful context from arguments
|
|
18
|
+
const context = extractAPIContext(propertyKey, args);
|
|
19
|
+
return trace.traceAsync('api', methodName, context, async () => {
|
|
20
|
+
const startTime = Date.now();
|
|
21
|
+
try {
|
|
22
|
+
// Log API call start
|
|
23
|
+
logger.debug(`Linear API Call: ${methodName}`, context);
|
|
24
|
+
const result = await originalMethod.apply(this, args);
|
|
25
|
+
const duration = Date.now() - startTime;
|
|
26
|
+
// Log successful completion with timing
|
|
27
|
+
logger.info(`Linear API Success: ${methodName}`, {
|
|
28
|
+
duration,
|
|
29
|
+
resultType: Array.isArray(result) ? `array[${result.length}]` : typeof result,
|
|
30
|
+
hasData: result != null,
|
|
31
|
+
});
|
|
32
|
+
// Warn about slow API calls
|
|
33
|
+
if (duration > 1000) {
|
|
34
|
+
logger.warn(`Slow Linear API call: ${methodName} took ${duration}ms`, {
|
|
35
|
+
...context,
|
|
36
|
+
duration,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
return result;
|
|
40
|
+
}
|
|
41
|
+
catch (error) {
|
|
42
|
+
const duration = Date.now() - startTime;
|
|
43
|
+
// Enhanced error logging for API failures
|
|
44
|
+
logger.error(`Linear API Failed: ${methodName}`, error, {
|
|
45
|
+
...context,
|
|
46
|
+
duration,
|
|
47
|
+
errorCode: error.code,
|
|
48
|
+
statusCode: error.statusCode,
|
|
49
|
+
graphQLErrors: error.errors,
|
|
50
|
+
});
|
|
51
|
+
// Add debugging hints based on error type
|
|
52
|
+
if (error.message?.includes('rate limit')) {
|
|
53
|
+
logger.warn('Rate limit hit - consider implementing backoff', {
|
|
54
|
+
method: methodName,
|
|
55
|
+
suggestion: 'Implement exponential backoff or request queuing',
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
else if (error.message?.includes('network')) {
|
|
59
|
+
logger.warn('Network error - check connectivity', {
|
|
60
|
+
method: methodName,
|
|
61
|
+
suggestion: 'Verify API endpoint and network connectivity',
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
else if (error.message?.includes('unauthorized')) {
|
|
65
|
+
logger.warn('Authorization error - check API key', {
|
|
66
|
+
method: methodName,
|
|
67
|
+
suggestion: 'Verify LINEAR_API_KEY is set and valid',
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
throw error;
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
descriptor.value = function (...args) {
|
|
77
|
+
const className = target.constructor.name;
|
|
78
|
+
const methodName = `${className}.${propertyKey}`;
|
|
79
|
+
const context = extractAPIContext(propertyKey, args);
|
|
80
|
+
return trace.traceSync('api', methodName, context, () => {
|
|
81
|
+
return originalMethod.apply(this, args);
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
return descriptor;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Extract meaningful context from API method arguments
|
|
89
|
+
*/
|
|
90
|
+
function extractAPIContext(methodName, args) {
|
|
91
|
+
const context = {};
|
|
92
|
+
// Handle different Linear API methods
|
|
93
|
+
if (methodName === 'createIssue' && args[0]) {
|
|
94
|
+
context.title = args[0].title;
|
|
95
|
+
context.teamId = args[0].teamId;
|
|
96
|
+
context.priority = args[0].priority;
|
|
97
|
+
}
|
|
98
|
+
else if (methodName === 'updateIssue' && args[0]) {
|
|
99
|
+
context.issueId = args[0];
|
|
100
|
+
context.updates = Object.keys(args[1] || {});
|
|
101
|
+
}
|
|
102
|
+
else if (methodName === 'getIssue') {
|
|
103
|
+
context.issueId = args[0];
|
|
104
|
+
}
|
|
105
|
+
else if (methodName === 'getIssues' && args[0]) {
|
|
106
|
+
context.filter = args[0];
|
|
107
|
+
}
|
|
108
|
+
else if (methodName === 'graphql') {
|
|
109
|
+
// For raw GraphQL queries
|
|
110
|
+
const query = args[0];
|
|
111
|
+
if (query) {
|
|
112
|
+
// Extract operation name from query
|
|
113
|
+
const match = query.match(/(?:query|mutation)\s+(\w+)/);
|
|
114
|
+
context.operation = match ? match[1] : 'unknown';
|
|
115
|
+
context.queryLength = query.length;
|
|
116
|
+
context.variables = args[1] ? Object.keys(args[1]) : [];
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return context;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Wrap fetch with tracing for HTTP-level debugging
|
|
123
|
+
*/
|
|
124
|
+
export function createTracedFetch(baseFetch = fetch) {
|
|
125
|
+
return async function tracedFetch(input, init) {
|
|
126
|
+
const url = typeof input === 'string' ? input : input.toString();
|
|
127
|
+
const method = init?.method || 'GET';
|
|
128
|
+
// Mask sensitive headers
|
|
129
|
+
const headers = init?.headers ? { ...init.headers } : {};
|
|
130
|
+
if (headers.Authorization) {
|
|
131
|
+
headers.Authorization = headers.Authorization.substring(0, 20) + '...[MASKED]';
|
|
132
|
+
}
|
|
133
|
+
const context = {
|
|
134
|
+
method,
|
|
135
|
+
url: url.length > 100 ? url.substring(0, 100) + '...' : url,
|
|
136
|
+
headers: Object.keys(headers),
|
|
137
|
+
bodySize: init?.body ? JSON.stringify(init.body).length : 0,
|
|
138
|
+
};
|
|
139
|
+
return trace.api(method, url, context, async () => {
|
|
140
|
+
const startTime = Date.now();
|
|
141
|
+
try {
|
|
142
|
+
const response = await baseFetch(input, init);
|
|
143
|
+
const duration = Date.now() - startTime;
|
|
144
|
+
// Log response details
|
|
145
|
+
logger.debug(`HTTP ${method} ${response.status}`, {
|
|
146
|
+
url: url.substring(0, 100),
|
|
147
|
+
status: response.status,
|
|
148
|
+
duration,
|
|
149
|
+
headers: {
|
|
150
|
+
'content-type': response.headers.get('content-type'),
|
|
151
|
+
'x-ratelimit-remaining': response.headers.get('x-ratelimit-remaining'),
|
|
152
|
+
'x-ratelimit-reset': response.headers.get('x-ratelimit-reset'),
|
|
153
|
+
},
|
|
154
|
+
});
|
|
155
|
+
// Warn about rate limiting
|
|
156
|
+
const remaining = response.headers.get('x-ratelimit-remaining');
|
|
157
|
+
if (remaining && parseInt(remaining) < 10) {
|
|
158
|
+
logger.warn(`Low rate limit remaining: ${remaining}`, {
|
|
159
|
+
url: url.substring(0, 100),
|
|
160
|
+
resetAt: response.headers.get('x-ratelimit-reset'),
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
// Warn about slow responses
|
|
164
|
+
if (duration > 2000) {
|
|
165
|
+
logger.warn(`Slow HTTP response: ${duration}ms`, {
|
|
166
|
+
method,
|
|
167
|
+
url: url.substring(0, 100),
|
|
168
|
+
status: response.status,
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
return response;
|
|
172
|
+
}
|
|
173
|
+
catch (error) {
|
|
174
|
+
const duration = Date.now() - startTime;
|
|
175
|
+
logger.error(`HTTP ${method} failed`, error, {
|
|
176
|
+
url: url.substring(0, 100),
|
|
177
|
+
duration,
|
|
178
|
+
errorType: error.constructor.name,
|
|
179
|
+
errno: error.errno,
|
|
180
|
+
code: error.code,
|
|
181
|
+
});
|
|
182
|
+
throw error;
|
|
183
|
+
}
|
|
184
|
+
});
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Create a traced GraphQL client wrapper
|
|
189
|
+
*/
|
|
190
|
+
export function wrapGraphQLClient(client) {
|
|
191
|
+
const prototype = Object.getPrototypeOf(client);
|
|
192
|
+
const propertyNames = Object.getOwnPropertyNames(prototype);
|
|
193
|
+
for (const propertyName of propertyNames) {
|
|
194
|
+
if (propertyName === 'constructor')
|
|
195
|
+
continue;
|
|
196
|
+
const descriptor = Object.getOwnPropertyDescriptor(prototype, propertyName);
|
|
197
|
+
if (!descriptor || typeof descriptor.value !== 'function')
|
|
198
|
+
continue;
|
|
199
|
+
// Apply tracing to all methods
|
|
200
|
+
TraceLinearAPI(prototype, propertyName, descriptor);
|
|
201
|
+
Object.defineProperty(prototype, propertyName, descriptor);
|
|
202
|
+
}
|
|
203
|
+
return client;
|
|
204
|
+
}
|
|
205
|
+
//# sourceMappingURL=linear-api-wrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linear-api-wrapper.js","sourceRoot":"","sources":["../../../../src/core/trace/linear-api-wrapper.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"performance-test.d.ts","sourceRoot":"","sources":["../../../../src/core/trace/performance-test.ts"],"names":[],"mappings":";AACA;;GAEG"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Performance Test - Find bottlenecks with tracing
|
|
4
|
+
*/
|
|
5
|
+
import { trace } from './index.js';
|
|
6
|
+
import { createTracedDatabase } from './db-trace-wrapper.js';
|
|
7
|
+
import { PebblesTaskStore } from '../../features/tasks/pebbles-task-store.js';
|
|
8
|
+
async function slowDatabaseOperation(db) {
|
|
9
|
+
// Intentionally slow operation
|
|
10
|
+
const stmt = db.prepare(`
|
|
11
|
+
WITH RECURSIVE numbers(n) AS (
|
|
12
|
+
SELECT 1
|
|
13
|
+
UNION ALL
|
|
14
|
+
SELECT n + 1 FROM numbers WHERE n < 1000
|
|
15
|
+
)
|
|
16
|
+
SELECT COUNT(*) as total, SUM(n) as sum FROM numbers
|
|
17
|
+
`);
|
|
18
|
+
return stmt.get();
|
|
19
|
+
}
|
|
20
|
+
async function runPerformanceTest() {
|
|
21
|
+
console.log('š Starting performance test with tracing...\n');
|
|
22
|
+
// Enable verbose tracing
|
|
23
|
+
process.env.DEBUG_TRACE = 'true';
|
|
24
|
+
process.env.TRACE_PERF_THRESHOLD = '50';
|
|
25
|
+
await trace.command('performance-test', {}, async () => {
|
|
26
|
+
// Test 1: Database performance
|
|
27
|
+
await trace.step('Database Performance Test', async () => {
|
|
28
|
+
const db = createTracedDatabase(':memory:', { slowQueryThreshold: 50 });
|
|
29
|
+
// Create a large table
|
|
30
|
+
db.exec(`
|
|
31
|
+
CREATE TABLE test_data (
|
|
32
|
+
id INTEGER PRIMARY KEY,
|
|
33
|
+
value TEXT,
|
|
34
|
+
timestamp INTEGER
|
|
35
|
+
)
|
|
36
|
+
`);
|
|
37
|
+
// Insert many rows (bottleneck!)
|
|
38
|
+
await trace.step('Bulk Insert', async () => {
|
|
39
|
+
const insert = db.prepare('INSERT INTO test_data (value, timestamp) VALUES (?, ?)');
|
|
40
|
+
for (let i = 0; i < 500; i++) {
|
|
41
|
+
insert.run(`value-${i}`, Date.now());
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
// Slow recursive query
|
|
45
|
+
await trace.step('Recursive Query', async () => {
|
|
46
|
+
const result = await slowDatabaseOperation(db);
|
|
47
|
+
console.log('Recursive query result:', result);
|
|
48
|
+
});
|
|
49
|
+
db.close();
|
|
50
|
+
});
|
|
51
|
+
// Test 2: Task Store performance
|
|
52
|
+
await trace.step('Task Store Performance Test', async () => {
|
|
53
|
+
const db = createTracedDatabase(':memory:');
|
|
54
|
+
const taskStore = new PebblesTaskStore('/tmp/stackmemory-perf-test', db);
|
|
55
|
+
// Create many tasks
|
|
56
|
+
await trace.step('Create 100 Tasks', async () => {
|
|
57
|
+
for (let i = 0; i < 100; i++) {
|
|
58
|
+
taskStore.createTask({
|
|
59
|
+
title: `Performance Test Task ${i}`,
|
|
60
|
+
description: `This is a test task with lots of data: ${Array(100).fill('x').join('')}`,
|
|
61
|
+
frameId: 'test-frame',
|
|
62
|
+
priority: 'medium',
|
|
63
|
+
tags: ['perf-test', `batch-${Math.floor(i / 10)}`]
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
// Query tasks with filters
|
|
68
|
+
await trace.step('Query Active Tasks', async () => {
|
|
69
|
+
const tasks = taskStore.getActiveTasks();
|
|
70
|
+
console.log(`Found ${tasks.length} active tasks`);
|
|
71
|
+
});
|
|
72
|
+
// Get metrics (potentially slow aggregation)
|
|
73
|
+
await trace.step('Calculate Metrics', async () => {
|
|
74
|
+
const metrics = taskStore.getMetrics();
|
|
75
|
+
console.log('Metrics:', metrics);
|
|
76
|
+
});
|
|
77
|
+
db.close();
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
// Show execution summary
|
|
81
|
+
const summary = trace.getExecutionSummary();
|
|
82
|
+
console.log(summary);
|
|
83
|
+
// Find the slowest operation
|
|
84
|
+
const traces = trace.exportTraces();
|
|
85
|
+
const slowest = findSlowestOperation(traces);
|
|
86
|
+
if (slowest) {
|
|
87
|
+
console.log('\nš„ BOTTLENECK FOUND!');
|
|
88
|
+
console.log(` Operation: ${slowest.name}`);
|
|
89
|
+
console.log(` Duration: ${slowest.duration}ms`);
|
|
90
|
+
console.log(` Type: ${slowest.type}`);
|
|
91
|
+
console.log(` Trace ID: ${slowest.id}`);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
function findSlowestOperation(traces) {
|
|
95
|
+
let slowest = null;
|
|
96
|
+
let maxDuration = 0;
|
|
97
|
+
function traverse(trace) {
|
|
98
|
+
if (trace.duration && trace.duration > maxDuration) {
|
|
99
|
+
maxDuration = trace.duration;
|
|
100
|
+
slowest = trace;
|
|
101
|
+
}
|
|
102
|
+
if (trace.children) {
|
|
103
|
+
trace.children.forEach(traverse);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
traces.forEach(traverse);
|
|
107
|
+
return slowest;
|
|
108
|
+
}
|
|
109
|
+
// Run the test
|
|
110
|
+
runPerformanceTest().catch(console.error);
|
|
111
|
+
//# sourceMappingURL=performance-test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"performance-test.js","sourceRoot":"","sources":["../../../../src/core/trace/performance-test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trace-demo.d.ts","sourceRoot":"","sources":["../../../../src/core/trace/trace-demo.ts"],"names":[],"mappings":";AACA;;;GAGG;AAqGH,iBAAe,OAAO,kBAqFrB;AAOD,OAAO,EAAE,OAAO,EAAE,CAAC"}
|