@stackmemoryai/stackmemory 0.2.8 → 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/compaction-handler.d.ts.map +1 -1
- package/dist/src/core/context/compaction-handler.js +1 -1
- package/dist/src/core/context/compaction-handler.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 +76 -0
- package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +1 -0
- package/dist/src/core/digest/hybrid-digest-generator.js +629 -0
- package/dist/src/core/digest/hybrid-digest-generator.js.map +1 -0
- package/dist/src/core/digest/index.d.ts +9 -0
- package/dist/src/core/digest/index.d.ts.map +1 -0
- package/dist/src/core/digest/index.js +9 -0
- package/dist/src/core/digest/index.js.map +1 -0
- package/dist/src/core/digest/types.d.ts +154 -0
- package/dist/src/core/digest/types.d.ts.map +1 -0
- package/dist/src/core/digest/types.js +18 -0
- package/dist/src/core/digest/types.js.map +1 -0
- 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/monitoring/logger.d.ts +2 -2
- package/dist/src/core/monitoring/logger.d.ts.map +1 -1
- package/dist/src/core/monitoring/logger.js +10 -5
- package/dist/src/core/monitoring/logger.js.map +1 -1
- package/dist/src/core/monitoring/metrics.d.ts +3 -0
- package/dist/src/core/monitoring/metrics.d.ts.map +1 -1
- package/dist/src/core/monitoring/metrics.js +142 -3
- package/dist/src/core/monitoring/metrics.js.map +1 -1
- 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 +31 -0
- package/dist/src/core/persistence/postgres-adapter.d.ts.map +1 -0
- package/dist/src/core/persistence/postgres-adapter.js +330 -0
- package/dist/src/core/persistence/postgres-adapter.js.map +1 -0
- 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 +6 -6
- 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/core/types.d.ts +35 -0
- package/dist/src/core/types.d.ts.map +1 -0
- package/dist/src/core/types.js +2 -0
- package/dist/src/core/types.js.map +1 -0
- 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/server.js +2 -2
- package/dist/src/integrations/mcp/server.js.map +1 -1
- 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/embedding-provider.d.ts +48 -0
- package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts.map +1 -0
- package/dist/src/integrations/pg-aiguide/embedding-provider.js +190 -0
- package/dist/src/integrations/pg-aiguide/embedding-provider.js.map +1 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts +34 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +1 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.js +176 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.js.map +1 -0
- package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts +44 -0
- package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts.map +1 -0
- package/dist/src/integrations/pg-aiguide/timescale-analytics.js +215 -0
- package/dist/src/integrations/pg-aiguide/timescale-analytics.js.map +1 -0
- 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 +62 -0
- package/dist/src/models/user.model.d.ts.map +1 -0
- package/dist/src/models/user.model.js +311 -0
- package/dist/src/models/user.model.js.map +1 -0
- package/dist/src/servers/production/auth-middleware.d.ts +12 -2
- package/dist/src/servers/production/auth-middleware.d.ts.map +1 -1
- package/dist/src/servers/production/auth-middleware.js +240 -28
- package/dist/src/servers/production/auth-middleware.js.map +1 -1
- package/dist/src/servers/railway/index.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 +12 -3
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/core/projects/project-manager.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Automatic Project Management for StackMemory\n * Auto-detects and organizes projects based on Git origins\n */\n\nimport { execSync } from 'child_process';\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';\nimport { join, basename, dirname } from 'path';\nimport { homedir } from 'os';\nimport Database from 'better-sqlite3';\nimport { logger } from '../monitoring/logger.js';\nimport {\n DatabaseError,\n ProjectError,\n SystemError,\n ErrorCode,\n wrapError,\n createErrorHandler,\n} from '../errors/index.js';\nimport { retry, withTimeout } from '../errors/recovery.js';\n\nexport interface ProjectInfo {\n id: string;\n name: string;\n path: string;\n gitRemote?: string;\n organization?: string;\n accountType: 'personal' | 'work' | 'opensource' | 'client';\n isPrivate: boolean;\n primaryLanguage?: string;\n framework?: string;\n lastAccessed: Date;\n metadata: Record<string, any>;\n}\n\nexport interface OrganizationConfig {\n name: string;\n type: 'company' | 'personal' | 'opensource' | 'client';\n domains: string[];\n githubOrgs: string[];\n gitlabGroups?: string[];\n bitbucketTeams?: string[];\n accountType: 'personal' | 'work' | 'opensource' | 'client';\n autoPatterns?: string[];\n}\n\nexport class ProjectManager {\n private static instance: ProjectManager;\n private db!: Database.Database;\n private configPath: string;\n private organizations: Map<string, OrganizationConfig> = new Map();\n private projectCache: Map<string, ProjectInfo> = new Map();\n private currentProject?: ProjectInfo;\n\n private constructor() {\n this.configPath = join(homedir(), '.stackmemory');\n this.ensureDirectoryStructure();\n this.initializeDatabase();\n this.loadOrganizations();\n this.autoDiscoverOrganizations();\n }\n\n static getInstance(): ProjectManager {\n if (!ProjectManager.instance) {\n ProjectManager.instance = new ProjectManager();\n }\n return ProjectManager.instance;\n }\n\n /**\n * Auto-detect project from current directory\n */\n async detectProject(projectPath?: string): Promise<ProjectInfo> {\n const path = projectPath || process.cwd();\n const errorHandler = createErrorHandler({\n operation: 'detectProject',\n projectPath: path,\n });\n\n try {\n // Check cache first\n const cached = this.projectCache.get(path);\n if (cached && this.isCacheValid(cached)) {\n return cached;\n }\n\n const project = await this.analyzeProject(path);\n\n // Auto-categorize based on git origin\n if (project.gitRemote) {\n project.organization = this.extractOrganization(project.gitRemote);\n project.accountType = this.determineAccountType(\n project.gitRemote,\n project.organization\n );\n project.isPrivate = this.isPrivateRepo(project.gitRemote);\n }\n\n // Detect framework and language\n project.primaryLanguage = this.detectPrimaryLanguage(path);\n project.framework = this.detectFramework(path);\n\n // Store in database with retry logic\n await retry(\n () => Promise.resolve(this.saveProject(project)),\n {\n maxAttempts: 3,\n initialDelay: 100,\n onRetry: (attempt, error) => {\n logger.warn(`Retrying project save (attempt ${attempt})`, {\n projectId: project.id,\n error: error instanceof Error ? error.message : String(error),\n });\n },\n }\n );\n\n this.projectCache.set(path, project);\n this.currentProject = project;\n\n logger.info('Project auto-detected', {\n id: project.id,\n org: project.organization,\n type: project.accountType,\n });\n\n return project;\n } catch (error) {\n const wrappedError = errorHandler(error, {\n projectPath: path,\n operation: 'detectProject',\n });\n \n throw new ProjectError(\n `Failed to detect project at path: ${path}`,\n ErrorCode.PROJECT_INVALID_PATH,\n {\n projectPath: path,\n operation: 'detectProject',\n }\n );\n }\n }\n\n /**\n * Analyze project directory\n */\n private async analyzeProject(projectPath: string): Promise<ProjectInfo> {\n const gitInfo = this.getGitInfo(projectPath);\n const projectName = gitInfo.name || basename(projectPath);\n\n return {\n id: this.generateProjectId(gitInfo.remote || projectPath),\n name: projectName,\n path: projectPath,\n gitRemote: gitInfo.remote,\n organization: undefined,\n accountType: 'personal',\n isPrivate: false,\n lastAccessed: new Date(),\n metadata: {\n branch: gitInfo.branch,\n lastCommit: gitInfo.lastCommit,\n isDirty: gitInfo.isDirty,\n },\n };\n }\n\n /**\n * Extract Git information\n */\n private getGitInfo(projectPath: string): any {\n const info: any = {};\n const errorHandler = createErrorHandler({\n operation: 'getGitInfo',\n projectPath,\n });\n\n try {\n // Get remote origin\n info.remote = execSync('git config --get remote.origin.url', {\n cwd: projectPath,\n encoding: 'utf-8',\n timeout: 5000, // 5 second timeout\n }).trim();\n\n // Get current branch\n info.branch = execSync('git branch --show-current', {\n cwd: projectPath,\n encoding: 'utf-8',\n timeout: 5000,\n }).trim();\n\n // Get last commit\n info.lastCommit = execSync('git log -1 --format=%H', {\n cwd: projectPath,\n encoding: 'utf-8',\n timeout: 5000,\n }).trim();\n\n // Check if working tree is dirty\n const status = execSync('git status --porcelain', {\n cwd: projectPath,\n encoding: 'utf-8',\n timeout: 5000,\n });\n info.isDirty = status.length > 0;\n\n // Extract project name from remote\n const match = info.remote.match(/\\/([^\\/]+?)(\\.git)?$/);\n info.name = match ? match[1] : basename(projectPath);\n } catch (error) {\n // Not a git repository or git not available\n logger.debug('Git info extraction failed, using directory name', {\n projectPath,\n error: error instanceof Error ? error.message : String(error),\n });\n info.name = basename(projectPath);\n }\n\n return info;\n }\n\n /**\n * Extract organization from Git remote\n */\n private extractOrganization(gitRemote: string): string {\n // GitHub: git@github.com:org/repo.git or https://github.com/org/repo\n const githubMatch = gitRemote.match(/github\\.com[:/]([^/]+)\\//);\n if (githubMatch) return githubMatch[1];\n\n // GitLab: git@gitlab.com:org/repo.git\n const gitlabMatch = gitRemote.match(/gitlab\\.com[:/]([^/]+)\\//);\n if (gitlabMatch) return gitlabMatch[1];\n\n // Bitbucket: git@bitbucket.org:org/repo.git\n const bitbucketMatch = gitRemote.match(/bitbucket\\.org[:/]([^/]+)\\//);\n if (bitbucketMatch) return bitbucketMatch[1];\n\n // Custom domain: git@git.company.com:team/repo.git\n const customMatch = gitRemote.match(/@([^:]+)[:/]([^/]+)\\//);\n if (customMatch) return customMatch[2];\n\n return 'unknown';\n }\n\n /**\n * Determine account type based on patterns\n */\n private determineAccountType(\n gitRemote: string,\n organization?: string\n ): 'personal' | 'work' | 'opensource' | 'client' {\n // Check against known organizations\n for (const [, org] of this.organizations) {\n if (org.githubOrgs.includes(organization || '')) {\n return org.accountType;\n }\n\n // Check if remote matches any known domain\n for (const domain of org.domains) {\n if (gitRemote.includes(domain)) {\n return org.accountType;\n }\n }\n }\n\n // Auto-detection heuristics\n if (organization) {\n // Common work patterns\n if (\n organization.includes('corp') ||\n organization.includes('company') ||\n organization.includes('team') ||\n organization.includes('work')\n ) {\n return 'work';\n }\n\n // Common opensource patterns\n if (\n organization.includes('apache') ||\n organization.includes('mozilla') ||\n organization.includes('foundation') ||\n gitRemote.includes('gitlab.freedesktop')\n ) {\n return 'opensource';\n }\n\n // Check if it's the user's own org\n const username = this.getCurrentGitUser();\n if (username && organization.toLowerCase() === username.toLowerCase()) {\n return 'personal';\n }\n }\n\n // Check if it's a private repo (likely work or personal)\n if (this.isPrivateRepo(gitRemote)) {\n // Use additional heuristics\n const currentPath = process.cwd();\n if (\n currentPath.includes('/work/') ||\n currentPath.includes('/Work/') ||\n currentPath.includes('/company/') ||\n currentPath.includes('/job/')\n ) {\n return 'work';\n }\n }\n\n return 'personal';\n }\n\n /**\n * Check if repository is private\n */\n private isPrivateRepo(gitRemote: string): boolean {\n // SSH URLs are typically private\n if (gitRemote.startsWith('git@')) {\n return true;\n }\n\n // HTTPS with credentials\n if (gitRemote.includes('@')) {\n return true;\n }\n\n // Try to check GitHub API (requires authentication for private repos)\n // This is a simplified check\n return false;\n }\n\n /**\n * Detect primary programming language\n */\n private detectPrimaryLanguage(projectPath: string): string | undefined {\n const checks = [\n { file: 'package.json', language: 'JavaScript/TypeScript' },\n { file: 'Cargo.toml', language: 'Rust' },\n { file: 'go.mod', language: 'Go' },\n { file: 'pom.xml', language: 'Java' },\n { file: 'requirements.txt', language: 'Python' },\n { file: 'Gemfile', language: 'Ruby' },\n { file: 'composer.json', language: 'PHP' },\n { file: '*.csproj', language: 'C#' },\n { file: 'Podfile', language: 'Swift/Objective-C' },\n ];\n\n for (const check of checks) {\n if (check.file.includes('*')) {\n // Glob pattern\n try {\n const files = execSync(\n `find ${projectPath} -maxdepth 2 -name \"${check.file}\" 2>/dev/null`,\n {\n encoding: 'utf-8',\n }\n );\n if (files.trim()) return check.language;\n } catch {}\n } else if (existsSync(join(projectPath, check.file))) {\n return check.language;\n }\n }\n\n return undefined;\n }\n\n /**\n * Detect framework\n */\n private detectFramework(projectPath: string): string | undefined {\n const packageJsonPath = join(projectPath, 'package.json');\n if (existsSync(packageJsonPath)) {\n try {\n const pkg = JSON.parse(readFileSync(packageJsonPath, 'utf-8'));\n const deps = { ...pkg.dependencies, ...pkg.devDependencies };\n\n // Check for common frameworks\n if (deps['next']) return 'Next.js';\n if (deps['react']) return 'React';\n if (deps['vue']) return 'Vue';\n if (deps['@angular/core']) return 'Angular';\n if (deps['express']) return 'Express';\n if (deps['fastify']) return 'Fastify';\n if (deps['@nestjs/core']) return 'NestJS';\n } catch {}\n }\n\n // Check for other framework indicators\n if (existsSync(join(projectPath, 'Cargo.toml'))) {\n const cargo = readFileSync(join(projectPath, 'Cargo.toml'), 'utf-8');\n if (cargo.includes('actix-web')) return 'Actix';\n if (cargo.includes('rocket')) return 'Rocket';\n }\n\n return undefined;\n }\n\n /**\n * Get current Git user\n */\n private getCurrentGitUser(): string | undefined {\n try {\n const email = execSync('git config --global user.email', {\n encoding: 'utf-8',\n }).trim();\n\n const username = email.split('@')[0];\n return username;\n } catch {\n return undefined;\n }\n }\n\n /**\n * Generate unique project ID\n */\n private generateProjectId(identifier: string): string {\n // Create a stable ID from the git remote or path\n const cleaned = identifier\n .replace(/\\.git$/, '')\n .replace(/[^a-zA-Z0-9-]/g, '-')\n .toLowerCase();\n\n return cleaned.substring(cleaned.length - 50); // Last 50 chars\n }\n\n /**\n * Initialize database\n */\n private initializeDatabase(): void {\n const dbPath = join(this.configPath, 'projects.db');\n const errorHandler = createErrorHandler({\n operation: 'initializeDatabase',\n dbPath,\n });\n\n try {\n this.db = new Database(dbPath);\n\n this.db.exec(`\n CREATE TABLE IF NOT EXISTS projects (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n path TEXT NOT NULL UNIQUE,\n git_remote TEXT,\n organization TEXT,\n account_type TEXT,\n is_private BOOLEAN,\n primary_language TEXT,\n framework TEXT,\n last_accessed DATETIME,\n metadata JSON,\n created_at DATETIME DEFAULT CURRENT_TIMESTAMP,\n updated_at DATETIME DEFAULT CURRENT_TIMESTAMP\n );\n\n CREATE TABLE IF NOT EXISTS organizations (\n name TEXT PRIMARY KEY,\n type TEXT,\n account_type TEXT,\n config JSON,\n created_at DATETIME DEFAULT CURRENT_TIMESTAMP\n );\n\n CREATE TABLE IF NOT EXISTS project_contexts (\n id INTEGER PRIMARY KEY AUTOINCREMENT,\n project_id TEXT NOT NULL,\n context_type TEXT,\n content TEXT,\n metadata JSON,\n created_at DATETIME DEFAULT CURRENT_TIMESTAMP,\n FOREIGN KEY (project_id) REFERENCES projects(id)\n );\n\n CREATE INDEX IF NOT EXISTS idx_projects_org ON projects(organization);\n CREATE INDEX IF NOT EXISTS idx_projects_type ON projects(account_type);\n CREATE INDEX IF NOT EXISTS idx_contexts_project ON project_contexts(project_id);\n `);\n } catch (error) {\n const dbError = errorHandler(error, {\n dbPath,\n operation: 'initializeDatabase',\n });\n \n throw new DatabaseError(\n 'Failed to initialize projects database',\n ErrorCode.DB_MIGRATION_FAILED,\n {\n dbPath,\n configPath: this.configPath,\n operation: 'initializeDatabase',\n },\n error instanceof Error ? error : undefined\n );\n }\n }\n\n /**\n * Save project to database\n */\n private saveProject(project: ProjectInfo): void {\n try {\n const stmt = this.db.prepare(`\n INSERT OR REPLACE INTO projects \n (id, name, path, git_remote, organization, account_type, is_private, \n primary_language, framework, last_accessed, metadata, updated_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, CURRENT_TIMESTAMP)\n `);\n\n stmt.run(\n project.id,\n project.name,\n project.path,\n project.gitRemote,\n project.organization,\n project.accountType,\n project.isPrivate ? 1 : 0,\n project.primaryLanguage,\n project.framework,\n project.lastAccessed.toISOString(),\n JSON.stringify(project.metadata)\n );\n } catch (error) {\n throw new DatabaseError(\n `Failed to save project: ${project.name}`,\n ErrorCode.DB_QUERY_FAILED,\n {\n projectId: project.id,\n projectName: project.name,\n projectPath: project.path,\n operation: 'saveProject',\n },\n error instanceof Error ? error : undefined\n );\n }\n }\n\n /**\n * Load organizations configuration\n */\n private loadOrganizations(): void {\n const configFile = join(this.configPath, 'organizations.json');\n\n if (existsSync(configFile)) {\n try {\n const config = JSON.parse(readFileSync(configFile, 'utf-8'));\n for (const org of config.organizations || []) {\n this.organizations.set(org.name, org);\n }\n } catch (error) {\n logger.error(\n 'Failed to load organizations config',\n error instanceof Error ? error : undefined\n );\n }\n }\n }\n\n /**\n * Auto-discover organizations from existing projects\n */\n private autoDiscoverOrganizations(): void {\n const errorHandler = createErrorHandler({\n operation: 'autoDiscoverOrganizations',\n });\n\n try {\n const stmt = this.db.prepare(`\n SELECT DISTINCT organization, account_type, COUNT(*) as project_count\n FROM projects\n WHERE organization IS NOT NULL\n GROUP BY organization, account_type\n `);\n\n const orgs = stmt.all() as any[];\n\n for (const org of orgs) {\n if (!this.organizations.has(org.organization)) {\n // Auto-create organization config\n this.organizations.set(org.organization, {\n name: org.organization,\n type: org.account_type === 'work' ? 'company' : 'personal',\n domains: [],\n githubOrgs: [org.organization],\n accountType: org.account_type,\n autoPatterns: [],\n });\n }\n }\n } catch (error) {\n const wrappedError = errorHandler(error, {\n operation: 'autoDiscoverOrganizations',\n });\n \n logger.error(\n 'Failed to auto-discover organizations',\n error instanceof Error ? error : new Error(String(error)),\n {\n operation: 'autoDiscoverOrganizations',\n }\n );\n }\n }\n\n /**\n * Ensure directory structure exists\n */\n private ensureDirectoryStructure(): void {\n const dirs = [\n this.configPath,\n join(this.configPath, 'accounts'),\n join(this.configPath, 'accounts', 'personal'),\n join(this.configPath, 'accounts', 'work'),\n join(this.configPath, 'accounts', 'opensource'),\n join(this.configPath, 'accounts', 'client'),\n join(this.configPath, 'contexts'),\n join(this.configPath, 'patterns'),\n ];\n\n for (const dir of dirs) {\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n }\n }\n\n /**\n * Check if cache is still valid\n */\n private isCacheValid(project: ProjectInfo): boolean {\n const cacheAge = Date.now() - project.lastAccessed.getTime();\n return cacheAge < 5 * 60 * 1000; // 5 minutes\n }\n\n /**\n * Get all projects\n */\n getAllProjects(): ProjectInfo[] {\n try {\n const stmt = this.db.prepare(`\n SELECT * FROM projects\n ORDER BY last_accessed DESC\n `);\n\n const projects = stmt.all() as any[];\n return projects.map((p) => ({\n ...p,\n isPrivate: p.is_private === 1,\n lastAccessed: new Date(p.last_accessed),\n metadata: JSON.parse(p.metadata || '{}'),\n }));\n } catch (error) {\n throw new DatabaseError(\n 'Failed to get all projects',\n ErrorCode.DB_QUERY_FAILED,\n {\n operation: 'getAllProjects',\n },\n error instanceof Error ? error : undefined\n );\n }\n }\n\n /**\n * Get projects by organization\n */\n getProjectsByOrganization(organization: string): ProjectInfo[] {\n try {\n const stmt = this.db.prepare(`\n SELECT * FROM projects\n WHERE organization = ?\n ORDER BY last_accessed DESC\n `);\n\n const projects = stmt.all(organization) as any[];\n return projects.map((p) => ({\n ...p,\n isPrivate: p.is_private === 1,\n lastAccessed: new Date(p.last_accessed),\n metadata: JSON.parse(p.metadata || '{}'),\n }));\n } catch (error) {\n throw new DatabaseError(\n `Failed to get projects by organization: ${organization}`,\n ErrorCode.DB_QUERY_FAILED,\n {\n organization,\n operation: 'getProjectsByOrganization',\n },\n error instanceof Error ? error : undefined\n );\n }\n }\n\n /**\n * Get projects by account type\n */\n getProjectsByAccountType(accountType: string): ProjectInfo[] {\n try {\n const stmt = this.db.prepare(`\n SELECT * FROM projects\n WHERE account_type = ?\n ORDER BY last_accessed DESC\n `);\n\n const projects = stmt.all(accountType) as any[];\n return projects.map((p) => ({\n ...p,\n isPrivate: p.is_private === 1,\n lastAccessed: new Date(p.last_accessed),\n metadata: JSON.parse(p.metadata || '{}'),\n }));\n } catch (error) {\n throw new DatabaseError(\n `Failed to get projects by account type: ${accountType}`,\n ErrorCode.DB_QUERY_FAILED,\n {\n accountType,\n operation: 'getProjectsByAccountType',\n },\n error instanceof Error ? error : undefined\n );\n }\n }\n\n /**\n * Get current project\n */\n getCurrentProject(): ProjectInfo | undefined {\n if (!this.currentProject) {\n this.detectProject();\n }\n return this.currentProject;\n }\n\n /**\n * Save organization config\n */\n saveOrganization(org: OrganizationConfig): void {\n const errorHandler = createErrorHandler({\n operation: 'saveOrganization',\n orgName: org.name,\n });\n\n try {\n this.organizations.set(org.name, org);\n\n // Save to file\n const configFile = join(this.configPath, 'organizations.json');\n const config = {\n organizations: Array.from(this.organizations.values()),\n };\n\n writeFileSync(configFile, JSON.stringify(config, null, 2));\n\n // Save to database\n const stmt = this.db.prepare(`\n INSERT OR REPLACE INTO organizations (name, type, account_type, config)\n VALUES (?, ?, ?, ?)\n `);\n\n stmt.run(org.name, org.type, org.accountType, JSON.stringify(org));\n } catch (error) {\n const wrappedError = errorHandler(error, {\n orgName: org.name,\n operation: 'saveOrganization',\n });\n \n throw new DatabaseError(\n `Failed to save organization: ${org.name}`,\n ErrorCode.DB_QUERY_FAILED,\n {\n orgName: org.name,\n operation: 'saveOrganization',\n },\n error instanceof Error ? error : undefined\n );\n }\n }\n\n /**\n * Auto-categorize all Git repositories in home directory\n */\n async scanAndCategorizeAllProjects(basePaths?: string[]): Promise<void> {\n const paths = basePaths || [\n join(homedir(), 'Dev'),\n join(homedir(), 'dev'),\n join(homedir(), 'Projects'),\n join(homedir(), 'projects'),\n join(homedir(), 'Work'),\n join(homedir(), 'work'),\n join(homedir(), 'Documents/GitHub'),\n join(homedir(), 'code'),\n ];\n\n logger.info('Scanning for Git repositories...');\n\n for (const basePath of paths) {\n if (!existsSync(basePath)) continue;\n\n try {\n // Find all .git directories with timeout\n const gitDirs = execSync(\n `find ${basePath} -type d -name .git -maxdepth 4 2>/dev/null`,\n { encoding: 'utf-8', timeout: 30000 } // 30 second timeout\n )\n .trim()\n .split('\\n')\n .filter(Boolean);\n\n for (const gitDir of gitDirs) {\n const projectPath = dirname(gitDir);\n\n try {\n await this.detectProject(projectPath);\n logger.info(`Discovered project: ${projectPath}`);\n } catch (error) {\n logger.warn(\n `Failed to analyze project: ${projectPath}`,\n {\n projectPath,\n error: error instanceof Error ? error.message : String(error),\n operation: 'scanAndCategorizeAllProjects',\n }\n );\n }\n }\n } catch (error) {\n logger.warn(\n `Failed to scan ${basePath}`,\n error instanceof Error ? { error } : undefined\n );\n }\n }\n\n logger.info(`Scan complete. Found ${this.projectCache.size} projects`);\n }\n\n /**\n * Generate summary report\n */\n generateReport(): string {\n const allProjects = this.getAllProjects();\n\n const report = {\n total: allProjects.length,\n byAccountType: {} as Record<string, number>,\n byOrganization: {} as Record<string, number>,\n byLanguage: {} as Record<string, number>,\n byFramework: {} as Record<string, number>,\n };\n\n for (const project of allProjects) {\n // Count by account type\n report.byAccountType[project.accountType] =\n (report.byAccountType[project.accountType] || 0) + 1;\n\n // Count by organization\n if (project.organization) {\n report.byOrganization[project.organization] =\n (report.byOrganization[project.organization] || 0) + 1;\n }\n\n // Count by language\n if (project.primaryLanguage) {\n report.byLanguage[project.primaryLanguage] =\n (report.byLanguage[project.primaryLanguage] || 0) + 1;\n }\n\n // Count by framework\n if (project.framework) {\n report.byFramework[project.framework] =\n (report.byFramework[project.framework] || 0) + 1;\n }\n }\n\n return JSON.stringify(report, null, 2);\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach } from "vitest";
|
|
2
|
+
import {
|
|
3
|
+
QueryParser,
|
|
4
|
+
FrameType,
|
|
5
|
+
FrameStatus
|
|
6
|
+
} from "../query-parser";
|
|
7
|
+
describe("QueryParser", () => {
|
|
8
|
+
let parser;
|
|
9
|
+
beforeEach(() => {
|
|
10
|
+
parser = new QueryParser();
|
|
11
|
+
});
|
|
12
|
+
describe("parseNaturalLanguage", () => {
|
|
13
|
+
it("should parse time-based queries", () => {
|
|
14
|
+
const query1 = parser.parseNaturalLanguage(
|
|
15
|
+
"provide context from the last day"
|
|
16
|
+
);
|
|
17
|
+
expect(query1.time?.last).toBe("1d");
|
|
18
|
+
const query2 = parser.parseNaturalLanguage(
|
|
19
|
+
"show me what happened yesterday"
|
|
20
|
+
);
|
|
21
|
+
expect(query2.time?.last).toBe("48h");
|
|
22
|
+
const query3 = parser.parseNaturalLanguage(
|
|
23
|
+
"get all work from last 3 weeks"
|
|
24
|
+
);
|
|
25
|
+
expect(query3.time?.last).toBe("3w");
|
|
26
|
+
const query4 = parser.parseNaturalLanguage("what happened today");
|
|
27
|
+
expect(query4.time?.last).toBe("24h");
|
|
28
|
+
});
|
|
29
|
+
it("should parse topic-based queries", () => {
|
|
30
|
+
const query1 = parser.parseNaturalLanguage(
|
|
31
|
+
"find all authentication work"
|
|
32
|
+
);
|
|
33
|
+
expect(query1.content?.topic).toContain("authentication");
|
|
34
|
+
const query2 = parser.parseNaturalLanguage(
|
|
35
|
+
"show database migration frames"
|
|
36
|
+
);
|
|
37
|
+
expect(query2.content?.topic).toContain("database");
|
|
38
|
+
expect(query2.content?.topic).toContain("migration");
|
|
39
|
+
const query3 = parser.parseNaturalLanguage(
|
|
40
|
+
"get frames about the login bug"
|
|
41
|
+
);
|
|
42
|
+
expect(query3.content?.topic).toContain("login");
|
|
43
|
+
expect(query3.content?.topic).toContain("bug");
|
|
44
|
+
});
|
|
45
|
+
it("should parse people-based queries", () => {
|
|
46
|
+
const query1 = parser.parseNaturalLanguage("show @alice's recent work");
|
|
47
|
+
expect(query1.people?.owner).toContain("alice");
|
|
48
|
+
const query2 = parser.parseNaturalLanguage(
|
|
49
|
+
"what did bob's changes include"
|
|
50
|
+
);
|
|
51
|
+
expect(query2.people?.owner).toContain("bob");
|
|
52
|
+
const query3 = parser.parseNaturalLanguage("get team work from today");
|
|
53
|
+
expect(query3.people?.team).toBe("$current_team");
|
|
54
|
+
});
|
|
55
|
+
it("should parse combined queries", () => {
|
|
56
|
+
const query = parser.parseNaturalLanguage(
|
|
57
|
+
"show @alice's auth work from last week"
|
|
58
|
+
);
|
|
59
|
+
expect(query.time?.last).toBe("1w");
|
|
60
|
+
expect(query.people?.owner).toContain("alice");
|
|
61
|
+
expect(query.content?.topic).toContain("auth");
|
|
62
|
+
});
|
|
63
|
+
it("should parse priority shortcuts", () => {
|
|
64
|
+
const query1 = parser.parseNaturalLanguage("get critical bugs");
|
|
65
|
+
expect(query1.frame?.score?.min).toBe(0.8);
|
|
66
|
+
expect(query1.content?.topic).toContain("bug");
|
|
67
|
+
const query2 = parser.parseNaturalLanguage("show high priority features");
|
|
68
|
+
expect(query2.frame?.score?.min).toBe(0.7);
|
|
69
|
+
expect(query2.content?.topic).toContain("feature");
|
|
70
|
+
const query3 = parser.parseNaturalLanguage("find low priority tasks");
|
|
71
|
+
expect(query3.frame?.score?.max).toBe(0.3);
|
|
72
|
+
});
|
|
73
|
+
it("should parse status shortcuts", () => {
|
|
74
|
+
const query1 = parser.parseNaturalLanguage("show open frames");
|
|
75
|
+
expect(query1.frame?.status).toContain(FrameStatus.OPEN);
|
|
76
|
+
const query2 = parser.parseNaturalLanguage("get closed bugs");
|
|
77
|
+
expect(query2.frame?.status).toContain(FrameStatus.CLOSED);
|
|
78
|
+
const query3 = parser.parseNaturalLanguage("find active work");
|
|
79
|
+
expect(query3.frame?.status).toContain(FrameStatus.OPEN);
|
|
80
|
+
});
|
|
81
|
+
it("should set default output settings", () => {
|
|
82
|
+
const query = parser.parseNaturalLanguage("show recent work");
|
|
83
|
+
expect(query.output).toEqual({
|
|
84
|
+
limit: 50,
|
|
85
|
+
sort: "time",
|
|
86
|
+
format: "summary"
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
describe("parseStructured", () => {
|
|
91
|
+
it("should validate score ranges", () => {
|
|
92
|
+
const query = parser.parseStructured({
|
|
93
|
+
frame: {
|
|
94
|
+
score: {
|
|
95
|
+
min: -0.5,
|
|
96
|
+
max: 1.5
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
expect(query.frame?.score?.min).toBe(0);
|
|
101
|
+
expect(query.frame?.score?.max).toBe(1);
|
|
102
|
+
});
|
|
103
|
+
it("should apply default output settings", () => {
|
|
104
|
+
const query = parser.parseStructured({
|
|
105
|
+
time: { last: "1d" }
|
|
106
|
+
});
|
|
107
|
+
expect(query.output).toEqual({
|
|
108
|
+
limit: 50,
|
|
109
|
+
sort: "time",
|
|
110
|
+
format: "full"
|
|
111
|
+
});
|
|
112
|
+
});
|
|
113
|
+
it("should preserve provided settings", () => {
|
|
114
|
+
const input = {
|
|
115
|
+
time: { last: "2h" },
|
|
116
|
+
content: { topic: ["auth"] },
|
|
117
|
+
output: {
|
|
118
|
+
limit: 100,
|
|
119
|
+
sort: "score",
|
|
120
|
+
format: "ids"
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
const query = parser.parseStructured(input);
|
|
124
|
+
expect(query).toEqual(input);
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
describe("parseHybrid", () => {
|
|
128
|
+
it("should merge natural language with structured modifiers", () => {
|
|
129
|
+
const query = parser.parseHybrid("show auth work", {
|
|
130
|
+
time: { last: "3d" },
|
|
131
|
+
output: { limit: 20 }
|
|
132
|
+
});
|
|
133
|
+
expect(query.content?.topic).toContain("auth");
|
|
134
|
+
expect(query.time?.last).toBe("3d");
|
|
135
|
+
expect(query.output?.limit).toBe(20);
|
|
136
|
+
expect(query.output?.format).toBe("summary");
|
|
137
|
+
});
|
|
138
|
+
it("should override natural language with modifiers", () => {
|
|
139
|
+
const query = parser.parseHybrid("show work from last week", {
|
|
140
|
+
time: { last: "1d" }
|
|
141
|
+
});
|
|
142
|
+
expect(query.time?.last).toBe("1d");
|
|
143
|
+
});
|
|
144
|
+
});
|
|
145
|
+
describe("expandQuery", () => {
|
|
146
|
+
it("should expand topics with synonyms", () => {
|
|
147
|
+
const query = parser.expandQuery({
|
|
148
|
+
content: { topic: ["auth"] }
|
|
149
|
+
});
|
|
150
|
+
expect(query.content?.topic).toContain("auth");
|
|
151
|
+
expect(query.content?.topic).toContain("authentication");
|
|
152
|
+
expect(query.content?.topic).toContain("oauth");
|
|
153
|
+
expect(query.content?.topic).toContain("login");
|
|
154
|
+
expect(query.content?.topic).toContain("jwt");
|
|
155
|
+
});
|
|
156
|
+
it("should expand multiple topics", () => {
|
|
157
|
+
const query = parser.expandQuery({
|
|
158
|
+
content: { topic: ["bug", "database"] }
|
|
159
|
+
});
|
|
160
|
+
expect(query.content?.topic).toContain("bug");
|
|
161
|
+
expect(query.content?.topic).toContain("error");
|
|
162
|
+
expect(query.content?.topic).toContain("issue");
|
|
163
|
+
expect(query.content?.topic).toContain("database");
|
|
164
|
+
expect(query.content?.topic).toContain("db");
|
|
165
|
+
expect(query.content?.topic).toContain("sql");
|
|
166
|
+
});
|
|
167
|
+
it("should preserve non-expandable topics", () => {
|
|
168
|
+
const query = parser.expandQuery({
|
|
169
|
+
content: { topic: ["custom-topic"] }
|
|
170
|
+
});
|
|
171
|
+
expect(query.content?.topic).toContain("custom-topic");
|
|
172
|
+
expect(query.content?.topic?.length).toBe(1);
|
|
173
|
+
});
|
|
174
|
+
});
|
|
175
|
+
describe("parse (QueryResponse)", () => {
|
|
176
|
+
it("should return complete QueryResponse for natural language query", () => {
|
|
177
|
+
const response = parser.parse("find authentication bugs from last week");
|
|
178
|
+
expect(response.original).toBe("find authentication bugs from last week");
|
|
179
|
+
expect(response.interpreted).toBeDefined();
|
|
180
|
+
expect(response.interpreted.time?.last).toBe("1w");
|
|
181
|
+
expect(response.interpreted.content?.topic).toContain("authentication");
|
|
182
|
+
expect(response.interpreted.content?.topic).toContain("bug");
|
|
183
|
+
expect(response.expanded).toBeDefined();
|
|
184
|
+
expect(response.expanded.content?.topic).toContain("authentication");
|
|
185
|
+
expect(response.expanded.content?.topic).toContain("auth");
|
|
186
|
+
expect(response.expanded.content?.topic).toContain("oauth");
|
|
187
|
+
expect(response.expanded.content?.topic).toContain("login");
|
|
188
|
+
expect(response.suggestions).toBeDefined();
|
|
189
|
+
expect(response.validationErrors).toBeUndefined();
|
|
190
|
+
});
|
|
191
|
+
it("should return QueryResponse for structured query", () => {
|
|
192
|
+
const structuredQuery = {
|
|
193
|
+
time: { last: "24h" },
|
|
194
|
+
content: { topic: ["database"] },
|
|
195
|
+
output: { limit: 10 }
|
|
196
|
+
};
|
|
197
|
+
const response = parser.parse(structuredQuery);
|
|
198
|
+
expect(response.original).toBe(JSON.stringify(structuredQuery));
|
|
199
|
+
expect(response.interpreted).toMatchObject(structuredQuery);
|
|
200
|
+
expect(response.expanded.content?.topic).toContain("database");
|
|
201
|
+
expect(response.expanded.content?.topic).toContain("db");
|
|
202
|
+
expect(response.expanded.content?.topic).toContain("sql");
|
|
203
|
+
expect(response.suggestions).toBeDefined();
|
|
204
|
+
expect(response.suggestions?.length).toBeGreaterThan(0);
|
|
205
|
+
});
|
|
206
|
+
it("should detect and return validation errors", () => {
|
|
207
|
+
const invalidQuery = {
|
|
208
|
+
time: {
|
|
209
|
+
since: /* @__PURE__ */ new Date("2024-12-25"),
|
|
210
|
+
until: /* @__PURE__ */ new Date("2024-12-20")
|
|
211
|
+
},
|
|
212
|
+
frame: {
|
|
213
|
+
score: { min: 0.9, max: 0.5 }
|
|
214
|
+
},
|
|
215
|
+
output: { limit: 5e3 }
|
|
216
|
+
};
|
|
217
|
+
const response = parser.parse(invalidQuery);
|
|
218
|
+
expect(response.validationErrors).toBeDefined();
|
|
219
|
+
expect(response.validationErrors).toContain(
|
|
220
|
+
'Time filter: "since" date is after "until" date'
|
|
221
|
+
);
|
|
222
|
+
expect(response.validationErrors).toContain(
|
|
223
|
+
"Frame filter: Minimum score is greater than maximum score"
|
|
224
|
+
);
|
|
225
|
+
expect(response.validationErrors).toContain(
|
|
226
|
+
"Output limit must be between 1 and 1000"
|
|
227
|
+
);
|
|
228
|
+
expect(response.suggestions).toContain(
|
|
229
|
+
"Please correct the validation errors before running the query"
|
|
230
|
+
);
|
|
231
|
+
});
|
|
232
|
+
it("should provide helpful suggestions for broad queries", () => {
|
|
233
|
+
const response = parser.parse("show me everything");
|
|
234
|
+
expect(response.suggestions).toBeDefined();
|
|
235
|
+
expect(response.suggestions).toContain(
|
|
236
|
+
'Try adding a time filter like "last 24h" or "today"'
|
|
237
|
+
);
|
|
238
|
+
expect(response.suggestions).toContain(
|
|
239
|
+
"Consider filtering by topic, frame type, or people to narrow results"
|
|
240
|
+
);
|
|
241
|
+
});
|
|
242
|
+
it("should suggest shortcuts when applicable", () => {
|
|
243
|
+
const response1 = parser.parse({ time: { last: "24h" } });
|
|
244
|
+
expect(response1.suggestions).toContain(
|
|
245
|
+
'You can use "today" as a shortcut for last 24 hours'
|
|
246
|
+
);
|
|
247
|
+
const response2 = parser.parse({
|
|
248
|
+
frame: { type: [FrameType.BUG, FrameType.DEBUG] }
|
|
249
|
+
});
|
|
250
|
+
expect(response2.suggestions).toContain(
|
|
251
|
+
'You can use "bugs" as a shortcut for bug and debug frames'
|
|
252
|
+
);
|
|
253
|
+
});
|
|
254
|
+
it("should handle complex natural language queries", () => {
|
|
255
|
+
const response = parser.parse(
|
|
256
|
+
"@alice's critical authentication work from yesterday"
|
|
257
|
+
);
|
|
258
|
+
expect(response.interpreted.people?.owner).toContain("alice");
|
|
259
|
+
expect(response.interpreted.frame?.score?.min).toBe(0.8);
|
|
260
|
+
expect(response.interpreted.content?.topic).toContain("authentication");
|
|
261
|
+
expect(response.interpreted.time?.last).toBe("48h");
|
|
262
|
+
expect(response.expanded.content?.topic).toContain("auth");
|
|
263
|
+
expect(response.expanded.content?.topic).toContain("oauth");
|
|
264
|
+
expect(response.expanded.content?.topic).toContain("login");
|
|
265
|
+
});
|
|
266
|
+
it("should preserve original query in response", () => {
|
|
267
|
+
const nlQuery = "find all bugs today";
|
|
268
|
+
const response1 = parser.parse(nlQuery);
|
|
269
|
+
expect(response1.original).toBe(nlQuery);
|
|
270
|
+
const structQuery = {
|
|
271
|
+
time: { last: "1d" },
|
|
272
|
+
frame: { type: [FrameType.BUG] }
|
|
273
|
+
};
|
|
274
|
+
const response2 = parser.parse(structQuery);
|
|
275
|
+
expect(response2.original).toBe(JSON.stringify(structQuery));
|
|
276
|
+
expect(response2.interpreted.output).toBeDefined();
|
|
277
|
+
expect(response2.interpreted.output?.limit).toBe(50);
|
|
278
|
+
});
|
|
279
|
+
it("should handle queries with file patterns", () => {
|
|
280
|
+
const response = parser.parse(
|
|
281
|
+
"show changes to *.ts and auth.js files today"
|
|
282
|
+
);
|
|
283
|
+
expect(response.interpreted.content?.files).toContain("*.ts");
|
|
284
|
+
expect(response.interpreted.content?.files).toContain("auth.js");
|
|
285
|
+
expect(response.interpreted.time?.last).toBe("24h");
|
|
286
|
+
});
|
|
287
|
+
it("should suggest time filter for bug searches without time limit", () => {
|
|
288
|
+
const response = parser.parse({ frame: { type: [FrameType.BUG] } });
|
|
289
|
+
expect(response.suggestions).toContain(
|
|
290
|
+
"Add a time filter to focus on recent bugs"
|
|
291
|
+
);
|
|
292
|
+
});
|
|
293
|
+
it("should suggest frame type with high score threshold", () => {
|
|
294
|
+
const response = parser.parse({ frame: { score: { min: 0.85 } } });
|
|
295
|
+
expect(response.suggestions).toContain(
|
|
296
|
+
"Consider adding frame type filter with high score threshold"
|
|
297
|
+
);
|
|
298
|
+
});
|
|
299
|
+
});
|
|
300
|
+
});
|
|
301
|
+
//# sourceMappingURL=query-parser.test.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/core/query/__tests__/query-parser.test.ts"],
|
|
4
|
+
"sourcesContent": ["import { describe, it, expect, beforeEach } from 'vitest';\nimport {\n QueryParser,\n FrameType,\n FrameStatus,\n QueryResponse,\n} from '../query-parser';\n\ndescribe('QueryParser', () => {\n let parser: QueryParser;\n\n beforeEach(() => {\n parser = new QueryParser();\n });\n\n describe('parseNaturalLanguage', () => {\n it('should parse time-based queries', () => {\n const query1 = parser.parseNaturalLanguage(\n 'provide context from the last day'\n );\n expect(query1.time?.last).toBe('1d');\n\n const query2 = parser.parseNaturalLanguage(\n 'show me what happened yesterday'\n );\n expect(query2.time?.last).toBe('48h');\n\n const query3 = parser.parseNaturalLanguage(\n 'get all work from last 3 weeks'\n );\n expect(query3.time?.last).toBe('3w');\n\n const query4 = parser.parseNaturalLanguage('what happened today');\n expect(query4.time?.last).toBe('24h');\n });\n\n it('should parse topic-based queries', () => {\n const query1 = parser.parseNaturalLanguage(\n 'find all authentication work'\n );\n expect(query1.content?.topic).toContain('authentication');\n\n const query2 = parser.parseNaturalLanguage(\n 'show database migration frames'\n );\n expect(query2.content?.topic).toContain('database');\n expect(query2.content?.topic).toContain('migration');\n\n const query3 = parser.parseNaturalLanguage(\n 'get frames about the login bug'\n );\n expect(query3.content?.topic).toContain('login');\n expect(query3.content?.topic).toContain('bug');\n });\n\n it('should parse people-based queries', () => {\n const query1 = parser.parseNaturalLanguage(\"show @alice's recent work\");\n expect(query1.people?.owner).toContain('alice');\n\n const query2 = parser.parseNaturalLanguage(\n \"what did bob's changes include\"\n );\n expect(query2.people?.owner).toContain('bob');\n\n const query3 = parser.parseNaturalLanguage('get team work from today');\n expect(query3.people?.team).toBe('$current_team');\n });\n\n it('should parse combined queries', () => {\n const query = parser.parseNaturalLanguage(\n \"show @alice's auth work from last week\"\n );\n expect(query.time?.last).toBe('1w');\n expect(query.people?.owner).toContain('alice');\n expect(query.content?.topic).toContain('auth');\n });\n\n it('should parse priority shortcuts', () => {\n const query1 = parser.parseNaturalLanguage('get critical bugs');\n expect(query1.frame?.score?.min).toBe(0.8);\n expect(query1.content?.topic).toContain('bug');\n\n const query2 = parser.parseNaturalLanguage('show high priority features');\n expect(query2.frame?.score?.min).toBe(0.7);\n expect(query2.content?.topic).toContain('feature');\n\n const query3 = parser.parseNaturalLanguage('find low priority tasks');\n expect(query3.frame?.score?.max).toBe(0.3);\n });\n\n it('should parse status shortcuts', () => {\n const query1 = parser.parseNaturalLanguage('show open frames');\n expect(query1.frame?.status).toContain(FrameStatus.OPEN);\n\n const query2 = parser.parseNaturalLanguage('get closed bugs');\n expect(query2.frame?.status).toContain(FrameStatus.CLOSED);\n\n const query3 = parser.parseNaturalLanguage('find active work');\n expect(query3.frame?.status).toContain(FrameStatus.OPEN);\n });\n\n it('should set default output settings', () => {\n const query = parser.parseNaturalLanguage('show recent work');\n expect(query.output).toEqual({\n limit: 50,\n sort: 'time',\n format: 'summary',\n });\n });\n });\n\n describe('parseStructured', () => {\n it('should validate score ranges', () => {\n const query = parser.parseStructured({\n frame: {\n score: {\n min: -0.5,\n max: 1.5,\n },\n },\n });\n expect(query.frame?.score?.min).toBe(0);\n expect(query.frame?.score?.max).toBe(1);\n });\n\n it('should apply default output settings', () => {\n const query = parser.parseStructured({\n time: { last: '1d' },\n });\n expect(query.output).toEqual({\n limit: 50,\n sort: 'time',\n format: 'full',\n });\n });\n\n it('should preserve provided settings', () => {\n const input = {\n time: { last: '2h' },\n content: { topic: ['auth'] },\n output: {\n limit: 100,\n sort: 'score' as const,\n format: 'ids' as const,\n },\n };\n const query = parser.parseStructured(input);\n expect(query).toEqual(input);\n });\n });\n\n describe('parseHybrid', () => {\n it('should merge natural language with structured modifiers', () => {\n const query = parser.parseHybrid('show auth work', {\n time: { last: '3d' },\n output: { limit: 20 },\n });\n\n expect(query.content?.topic).toContain('auth');\n expect(query.time?.last).toBe('3d');\n expect(query.output?.limit).toBe(20);\n expect(query.output?.format).toBe('summary');\n });\n\n it('should override natural language with modifiers', () => {\n const query = parser.parseHybrid('show work from last week', {\n time: { last: '1d' },\n });\n\n expect(query.time?.last).toBe('1d');\n });\n });\n\n describe('expandQuery', () => {\n it('should expand topics with synonyms', () => {\n const query = parser.expandQuery({\n content: { topic: ['auth'] },\n });\n\n expect(query.content?.topic).toContain('auth');\n expect(query.content?.topic).toContain('authentication');\n expect(query.content?.topic).toContain('oauth');\n expect(query.content?.topic).toContain('login');\n expect(query.content?.topic).toContain('jwt');\n });\n\n it('should expand multiple topics', () => {\n const query = parser.expandQuery({\n content: { topic: ['bug', 'database'] },\n });\n\n expect(query.content?.topic).toContain('bug');\n expect(query.content?.topic).toContain('error');\n expect(query.content?.topic).toContain('issue');\n expect(query.content?.topic).toContain('database');\n expect(query.content?.topic).toContain('db');\n expect(query.content?.topic).toContain('sql');\n });\n\n it('should preserve non-expandable topics', () => {\n const query = parser.expandQuery({\n content: { topic: ['custom-topic'] },\n });\n\n expect(query.content?.topic).toContain('custom-topic');\n expect(query.content?.topic?.length).toBe(1);\n });\n });\n\n describe('parse (QueryResponse)', () => {\n it('should return complete QueryResponse for natural language query', () => {\n const response = parser.parse('find authentication bugs from last week');\n\n expect(response.original).toBe('find authentication bugs from last week');\n expect(response.interpreted).toBeDefined();\n expect(response.interpreted.time?.last).toBe('1w');\n expect(response.interpreted.content?.topic).toContain('authentication');\n expect(response.interpreted.content?.topic).toContain('bug');\n\n expect(response.expanded).toBeDefined();\n expect(response.expanded.content?.topic).toContain('authentication');\n expect(response.expanded.content?.topic).toContain('auth');\n expect(response.expanded.content?.topic).toContain('oauth');\n expect(response.expanded.content?.topic).toContain('login');\n\n expect(response.suggestions).toBeDefined();\n expect(response.validationErrors).toBeUndefined();\n });\n\n it('should return QueryResponse for structured query', () => {\n const structuredQuery = {\n time: { last: '24h' },\n content: { topic: ['database'] },\n output: { limit: 10 },\n };\n\n const response = parser.parse(structuredQuery);\n\n expect(response.original).toBe(JSON.stringify(structuredQuery));\n expect(response.interpreted).toMatchObject(structuredQuery);\n expect(response.expanded.content?.topic).toContain('database');\n expect(response.expanded.content?.topic).toContain('db');\n expect(response.expanded.content?.topic).toContain('sql');\n\n expect(response.suggestions).toBeDefined();\n expect(response.suggestions?.length).toBeGreaterThan(0);\n });\n\n it('should detect and return validation errors', () => {\n const invalidQuery = {\n time: {\n since: new Date('2024-12-25'),\n until: new Date('2024-12-20'),\n },\n frame: {\n score: { min: 0.9, max: 0.5 },\n },\n output: { limit: 5000 },\n };\n\n const response = parser.parse(invalidQuery);\n\n expect(response.validationErrors).toBeDefined();\n expect(response.validationErrors).toContain(\n 'Time filter: \"since\" date is after \"until\" date'\n );\n expect(response.validationErrors).toContain(\n 'Frame filter: Minimum score is greater than maximum score'\n );\n expect(response.validationErrors).toContain(\n 'Output limit must be between 1 and 1000'\n );\n\n expect(response.suggestions).toContain(\n 'Please correct the validation errors before running the query'\n );\n });\n\n it('should provide helpful suggestions for broad queries', () => {\n const response = parser.parse('show me everything');\n\n expect(response.suggestions).toBeDefined();\n expect(response.suggestions).toContain(\n 'Try adding a time filter like \"last 24h\" or \"today\"'\n );\n expect(response.suggestions).toContain(\n 'Consider filtering by topic, frame type, or people to narrow results'\n );\n });\n\n it('should suggest shortcuts when applicable', () => {\n const response1 = parser.parse({ time: { last: '24h' } });\n expect(response1.suggestions).toContain(\n 'You can use \"today\" as a shortcut for last 24 hours'\n );\n\n const response2 = parser.parse({\n frame: { type: [FrameType.BUG, FrameType.DEBUG] },\n });\n expect(response2.suggestions).toContain(\n 'You can use \"bugs\" as a shortcut for bug and debug frames'\n );\n });\n\n it('should handle complex natural language queries', () => {\n const response = parser.parse(\n \"@alice's critical authentication work from yesterday\"\n );\n\n expect(response.interpreted.people?.owner).toContain('alice');\n expect(response.interpreted.frame?.score?.min).toBe(0.8);\n expect(response.interpreted.content?.topic).toContain('authentication');\n expect(response.interpreted.time?.last).toBe('48h');\n\n expect(response.expanded.content?.topic).toContain('auth');\n expect(response.expanded.content?.topic).toContain('oauth');\n expect(response.expanded.content?.topic).toContain('login');\n });\n\n it('should preserve original query in response', () => {\n const nlQuery = 'find all bugs today';\n const response1 = parser.parse(nlQuery);\n expect(response1.original).toBe(nlQuery);\n\n const structQuery = {\n time: { last: '1d' },\n frame: { type: [FrameType.BUG] },\n };\n const response2 = parser.parse(structQuery);\n // Original should be the input as provided, before any processing\n expect(response2.original).toBe(JSON.stringify(structQuery));\n // Interpreted should have defaults added\n expect(response2.interpreted.output).toBeDefined();\n expect(response2.interpreted.output?.limit).toBe(50);\n });\n\n it('should handle queries with file patterns', () => {\n const response = parser.parse(\n 'show changes to *.ts and auth.js files today'\n );\n\n expect(response.interpreted.content?.files).toContain('*.ts');\n expect(response.interpreted.content?.files).toContain('auth.js');\n expect(response.interpreted.time?.last).toBe('24h');\n });\n\n it('should suggest time filter for bug searches without time limit', () => {\n const response = parser.parse({ frame: { type: [FrameType.BUG] } });\n\n expect(response.suggestions).toContain(\n 'Add a time filter to focus on recent bugs'\n );\n });\n\n it('should suggest frame type with high score threshold', () => {\n const response = parser.parse({ frame: { score: { min: 0.85 } } });\n\n expect(response.suggestions).toContain(\n 'Consider adding frame type filter with high score threshold'\n );\n });\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|