@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,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/core/query/query-parser.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Query Parser for StackMemory\n * Handles both natural language and structured queries\n */\n\nimport { QueryTemplates, InlineModifierParser } from './query-templates.js';\n\nexport interface TimeFilter {\n last?: string; // \"1d\", \"3h\", \"1w\", \"2m\"\n since?: Date;\n until?: Date;\n between?: [Date, Date];\n specific?: Date;\n}\n\nexport interface ContentFilter {\n topic?: string[];\n files?: string[];\n errors?: string[];\n tools?: string[];\n keywords?: string[];\n excludeKeywords?: string[];\n}\n\nexport interface FrameFilter {\n type?: FrameType[];\n status?: FrameStatus[];\n score?: {\n min?: number;\n max?: number;\n };\n depth?: {\n min?: number;\n max?: number;\n };\n}\n\nexport interface PeopleFilter {\n owner?: string[];\n contributors?: string[];\n team?: string;\n}\n\nexport interface OutputControl {\n limit?: number;\n sort?: 'time' | 'score' | 'relevance';\n include?: ('digests' | 'events' | 'anchors')[];\n format?: 'full' | 'summary' | 'ids';\n groupBy?: 'frame' | 'time' | 'owner' | 'topic';\n}\n\nexport interface StackMemoryQuery {\n time?: TimeFilter;\n content?: ContentFilter;\n frame?: FrameFilter;\n people?: PeopleFilter;\n output?: OutputControl;\n}\n\nexport interface QueryResponse {\n original: string;\n interpreted: StackMemoryQuery;\n expanded: StackMemoryQuery;\n suggestions?: string[];\n validationErrors?: string[];\n}\n\nexport enum FrameType {\n TASK = 'task',\n DEBUG = 'debug',\n FEATURE = 'feature',\n ARCHITECTURE = 'architecture',\n BUG = 'bug',\n REFACTOR = 'refactor',\n}\n\nexport enum FrameStatus {\n OPEN = 'open',\n CLOSED = 'closed',\n STALLED = 'stalled',\n}\n\nexport class QueryParser {\n private templates = new QueryTemplates();\n private inlineParser = new InlineModifierParser();\n private shortcuts: Map<string, Partial<StackMemoryQuery>> = new Map([\n ['today', { time: { last: '24h' } }],\n [\n 'yesterday',\n { time: { last: '48h', since: new Date(Date.now() - 48 * 3600000) } },\n ],\n ['this week', { time: { last: '7d' } }],\n ['last week', { time: { last: '1w' } }],\n ['this month', { time: { last: '30d' } }],\n ['bugs', { frame: { type: [FrameType.BUG, FrameType.DEBUG] } }],\n ['features', { frame: { type: [FrameType.FEATURE] } }],\n ['architecture', { frame: { type: [FrameType.ARCHITECTURE] } }],\n ['refactoring', { frame: { type: [FrameType.REFACTOR] } }],\n ['critical', { frame: { score: { min: 0.8 } } }],\n ['recent', { time: { last: '4h' } }],\n ['stalled', { frame: { status: [FrameStatus.STALLED] } }],\n ['my work', { people: { owner: ['$current_user'] } }],\n ['team work', { people: { team: '$current_team' } }],\n ]);\n\n /**\n * Parse natural language query into structured format\n */\n parseNaturalLanguage(query: string): StackMemoryQuery {\n // First check for query templates\n const templateResult = this.templates.matchTemplate(query);\n if (templateResult) {\n // Ensure template results have proper defaults\n const structured = templateResult as StackMemoryQuery;\n if (!structured.output) {\n structured.output = {\n limit: 50,\n sort: 'time',\n format: 'summary',\n };\n }\n return this.parseStructured(structured);\n }\n\n // Check for inline modifiers\n const { cleanQuery, modifiers } = this.inlineParser.parse(query);\n\n const result: StackMemoryQuery = {};\n const lowerQuery = cleanQuery.toLowerCase();\n\n // Time-based patterns\n this.parseTimePatterns(lowerQuery, result);\n\n // Topic-based patterns\n this.parseTopicPatterns(lowerQuery, result);\n\n // People-based patterns\n this.parsePeoplePatterns(lowerQuery, result);\n\n // Shortcut expansion\n this.expandShortcuts(lowerQuery, result);\n\n // Merge inline modifiers\n const merged = this.mergeQueries(result, modifiers);\n\n // Default output settings if not specified\n if (!merged.output) {\n merged.output = {\n limit: 50,\n sort: 'time',\n format: 'summary',\n };\n } else {\n // Ensure all output fields have defaults\n if (!merged.output.limit) merged.output.limit = 50;\n if (!merged.output.sort) merged.output.sort = 'time';\n if (!merged.output.format) merged.output.format = 'summary';\n }\n\n return merged;\n }\n\n /**\n * Parse structured query with validation\n */\n parseStructured(query: StackMemoryQuery): StackMemoryQuery {\n // Validate and normalize the query\n if (query.frame?.score) {\n if (query.frame.score.min !== undefined) {\n query.frame.score.min = Math.max(0, Math.min(1, query.frame.score.min));\n }\n if (query.frame.score.max !== undefined) {\n query.frame.score.max = Math.max(0, Math.min(1, query.frame.score.max));\n }\n }\n\n // Apply defaults\n if (!query.output) {\n query.output = {\n limit: 50,\n sort: 'time',\n format: 'full',\n };\n }\n\n return query;\n }\n\n /**\n * Parse hybrid query (natural language with structured modifiers)\n */\n parseHybrid(\n naturalQuery: string,\n modifiers?: Partial<StackMemoryQuery>\n ): StackMemoryQuery {\n const nlQuery = this.parseNaturalLanguage(naturalQuery);\n return this.mergeQueries(nlQuery, modifiers || {});\n }\n\n private parseTimePatterns(query: string, result: StackMemoryQuery): void {\n // \"last day\", \"last week\", \"last month\"\n const lastPattern = /last\\s+(\\d+)?\\s*(day|hour|week|month)s?/i;\n const match = query.match(lastPattern);\n if (match) {\n const quantity = match[1] ? parseInt(match[1]) : 1;\n const unit = match[2].toLowerCase();\n const unitMap: Record<string, string> = {\n hour: 'h',\n day: 'd',\n week: 'w',\n month: 'm',\n };\n result.time = { last: `${quantity}${unitMap[unit]}` };\n }\n\n // \"yesterday\", \"today\", \"this week\"\n for (const [shortcut, value] of this.shortcuts) {\n if (query.includes(shortcut) && value.time) {\n result.time = { ...result.time, ...value.time };\n }\n }\n\n // Date patterns \"December 15\", \"2024-12-20\"\n const datePattern =\n /(\\d{4}-\\d{2}-\\d{2})|((jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\\w*\\s+\\d{1,2})/i;\n const dateMatch = query.match(datePattern);\n if (dateMatch) {\n try {\n const date = new Date(dateMatch[0]);\n if (!isNaN(date.getTime())) {\n result.time = { ...result.time, specific: date };\n }\n } catch {\n // Invalid date, ignore\n }\n }\n }\n\n private parseTopicPatterns(query: string, result: StackMemoryQuery): void {\n // Common topics - match word boundaries for most, but be flexible for compound words\n const topics = [\n 'auth',\n 'authentication',\n 'login',\n 'oauth',\n 'database',\n 'migration',\n 'cache',\n 'api',\n 'bug',\n 'bugs',\n 'error',\n 'fix',\n 'feature',\n 'features',\n 'test',\n 'security',\n 'performance',\n ];\n\n const foundTopics: string[] = [];\n for (const topic of topics) {\n // Always use word boundaries to avoid false positives like \"test\" in \"latest\"\n const regex = new RegExp(`\\\\b${topic}\\\\b`, 'i');\n if (regex.test(query)) {\n // Normalize plurals\n const normalized =\n topic === 'bugs' ? 'bug' : topic === 'features' ? 'feature' : topic;\n if (!foundTopics.includes(normalized)) {\n foundTopics.push(normalized);\n }\n }\n }\n\n if (foundTopics.length > 0) {\n result.content = { ...result.content, topic: foundTopics };\n }\n\n // File patterns\n const filePattern = /(\\w+\\.\\w+)|(\\*\\.\\w+)/g;\n const files = query.match(filePattern);\n if (files) {\n result.content = { ...result.content, files };\n }\n }\n\n private parsePeoplePatterns(query: string, result: StackMemoryQuery): void {\n // \"@alice\", \"@bob\" mentions\n const mentionPattern = /@(\\w+)/g;\n const mentions = [...query.matchAll(mentionPattern)].map((m) => m[1]);\n if (mentions.length > 0) {\n result.people = { owner: mentions };\n }\n\n // \"alice's work\", \"bob's changes\"\n const possessivePattern = /(\\w+)'s\\s+(work|changes|commits|frames)/i;\n const possMatch = query.match(possessivePattern);\n if (possMatch) {\n const person = possMatch[1].toLowerCase();\n if (!result.people) result.people = {};\n result.people = { ...result.people, owner: [person] };\n }\n\n // \"team work\" - use word boundaries to avoid false positives\n if (/\\bteam\\b/.test(query)) {\n if (!result.people) result.people = {};\n result.people = { ...result.people, team: '$current_team' };\n }\n }\n\n private expandShortcuts(query: string, result: StackMemoryQuery): void {\n // Priority shortcuts\n if (query.includes('critical')) {\n result.frame = {\n ...result.frame,\n score: { min: 0.8 },\n };\n } else if (query.includes('high')) {\n result.frame = {\n ...result.frame,\n score: { min: 0.7 },\n };\n }\n\n if (query.includes('low priority')) {\n result.frame = {\n ...result.frame,\n score: { max: 0.3 },\n };\n }\n\n // Status shortcuts\n if (query.includes('open') || query.includes('active')) {\n result.frame = {\n ...result.frame,\n status: [FrameStatus.OPEN],\n };\n }\n\n if (query.includes('closed') || query.includes('done')) {\n result.frame = {\n ...result.frame,\n status: [FrameStatus.CLOSED],\n };\n }\n }\n\n private mergeQueries(\n base: StackMemoryQuery,\n overlay: Partial<StackMemoryQuery>\n ): StackMemoryQuery {\n const merged: StackMemoryQuery = {};\n\n // Only add properties if they have values\n if (base.time || overlay.time) {\n merged.time = { ...base.time, ...overlay.time };\n }\n if (base.content || overlay.content) {\n merged.content = { ...base.content, ...overlay.content };\n }\n if (base.frame || overlay.frame) {\n merged.frame = { ...base.frame, ...overlay.frame };\n }\n if (base.people || overlay.people) {\n merged.people = { ...base.people, ...overlay.people };\n }\n if (base.output || overlay.output) {\n merged.output = { ...base.output, ...overlay.output };\n }\n\n return merged;\n }\n\n /**\n * Expand query with synonyms and related terms\n */\n expandQuery(query: StackMemoryQuery): StackMemoryQuery {\n const synonyms: Record<string, string[]> = {\n auth: ['authentication', 'oauth', 'login', 'session', 'jwt'],\n authentication: ['auth', 'oauth', 'login', 'session', 'jwt'],\n bug: ['error', 'issue', 'problem', 'fix', 'defect'],\n database: ['db', 'sql', 'postgres', 'migration', 'schema'],\n test: ['testing', 'spec', 'unit', 'integration', 'e2e'],\n };\n\n if (query.content?.topic) {\n const expandedTopics = new Set(query.content.topic);\n for (const topic of query.content.topic) {\n const syns = synonyms[topic.toLowerCase()];\n if (syns) {\n syns.forEach((s) => expandedTopics.add(s));\n }\n }\n query.content.topic = Array.from(expandedTopics);\n }\n\n return query;\n }\n\n /**\n * Main parse method that returns a complete QueryResponse\n */\n parse(query: string | StackMemoryQuery): QueryResponse {\n const original = typeof query === 'string' ? query : JSON.stringify(query);\n\n // Parse based on input type (clone to avoid mutation)\n const interpreted =\n typeof query === 'string'\n ? this.parseNaturalLanguage(query)\n : this.parseStructured(JSON.parse(JSON.stringify(query)));\n\n // Validate the query\n const validationErrors = this.validateQuery(interpreted);\n\n // Expand with synonyms\n const expanded = this.expandQuery(JSON.parse(JSON.stringify(interpreted)));\n\n // Generate suggestions\n const suggestions = this.generateSuggestions(interpreted, validationErrors);\n\n return {\n original,\n interpreted,\n expanded,\n suggestions,\n validationErrors:\n validationErrors.length > 0 ? validationErrors : undefined,\n };\n }\n\n /**\n * Validate query for errors and inconsistencies\n */\n private validateQuery(query: StackMemoryQuery): string[] {\n const errors: string[] = [];\n\n // Validate time filters\n if (query.time) {\n if (query.time.since && query.time.until) {\n if (query.time.since > query.time.until) {\n errors.push('Time filter: \"since\" date is after \"until\" date');\n }\n }\n if (query.time.between) {\n if (query.time.between[0] > query.time.between[1]) {\n errors.push('Time filter: Invalid date range in \"between\"');\n }\n }\n }\n\n // Validate score ranges\n if (query.frame?.score) {\n if (\n query.frame.score.min !== undefined &&\n query.frame.score.max !== undefined\n ) {\n if (query.frame.score.min > query.frame.score.max) {\n errors.push(\n 'Frame filter: Minimum score is greater than maximum score'\n );\n }\n }\n }\n\n // Validate depth ranges\n if (query.frame?.depth) {\n if (\n query.frame.depth.min !== undefined &&\n query.frame.depth.max !== undefined\n ) {\n if (query.frame.depth.min > query.frame.depth.max) {\n errors.push(\n 'Frame filter: Minimum depth is greater than maximum depth'\n );\n }\n }\n }\n\n // Validate output limit\n if (query.output?.limit !== undefined) {\n if (query.output.limit < 1 || query.output.limit > 1000) {\n errors.push('Output limit must be between 1 and 1000');\n }\n }\n\n return errors;\n }\n\n /**\n * Generate query suggestions based on the interpreted query\n */\n private generateSuggestions(\n query: StackMemoryQuery,\n errors: string[]\n ): string[] {\n const suggestions: string[] = [];\n\n // If no time filter, suggest adding one\n if (\n !query.time ||\n (!query.time.last &&\n !query.time.since &&\n !query.time.between &&\n !query.time.specific)\n ) {\n suggestions.push('Try adding a time filter like \"last 24h\" or \"today\"');\n }\n\n // If very broad query, suggest refinement\n if (\n !query.content?.topic &&\n !query.frame?.type &&\n !query.people &&\n !query.content?.keywords\n ) {\n suggestions.push(\n 'Consider filtering by topic, frame type, or people to narrow results'\n );\n }\n\n // If searching for bugs/errors without time limit\n if (query.frame?.type?.includes(FrameType.BUG) && !query.time) {\n suggestions.push('Add a time filter to focus on recent bugs');\n }\n\n // If high score threshold without type filter\n if (\n query.frame?.score?.min &&\n query.frame.score.min >= 0.8 &&\n !query.frame?.type\n ) {\n suggestions.push(\n 'Consider adding frame type filter with high score threshold'\n );\n }\n\n // Suggest shortcuts if applicable\n if (query.time?.last === '24h') {\n suggestions.push('You can use \"today\" as a shortcut for last 24 hours');\n }\n\n if (\n query.frame?.type?.includes(FrameType.BUG) &&\n query.frame?.type?.includes(FrameType.DEBUG)\n ) {\n suggestions.push(\n 'You can use \"bugs\" as a shortcut for bug and debug frames'\n );\n }\n\n // If there are errors, suggest corrections\n if (errors.length > 0) {\n suggestions.push(\n 'Please correct the validation errors before running the query'\n );\n }\n\n return suggestions;\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["FrameType", "FrameStatus"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,317 @@
|
|
|
1
|
+
import { FrameType, FrameStatus } from "./query-parser.js";
|
|
2
|
+
class QueryTemplates {
|
|
3
|
+
templates = [
|
|
4
|
+
{
|
|
5
|
+
name: "daily-standup",
|
|
6
|
+
description: "Get work done by a person today for standup",
|
|
7
|
+
pattern: /^standup for @?(\w+)$/i,
|
|
8
|
+
builder: (match) => ({
|
|
9
|
+
time: { last: "24h" },
|
|
10
|
+
people: { owner: [match[1]] },
|
|
11
|
+
output: {
|
|
12
|
+
format: "summary",
|
|
13
|
+
sort: "time",
|
|
14
|
+
groupBy: "frame"
|
|
15
|
+
}
|
|
16
|
+
})
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
name: "error-investigation",
|
|
20
|
+
description: "Investigate errors in a specific component",
|
|
21
|
+
pattern: /^investigate errors? in (.+)$/i,
|
|
22
|
+
builder: (match) => ({
|
|
23
|
+
content: {
|
|
24
|
+
topic: ["error", "bug"],
|
|
25
|
+
keywords: [match[1]]
|
|
26
|
+
},
|
|
27
|
+
frame: {
|
|
28
|
+
type: [FrameType.BUG, FrameType.DEBUG]
|
|
29
|
+
},
|
|
30
|
+
time: { last: "48h" },
|
|
31
|
+
output: {
|
|
32
|
+
format: "full",
|
|
33
|
+
sort: "time",
|
|
34
|
+
include: ["events", "digests"]
|
|
35
|
+
}
|
|
36
|
+
})
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
name: "feature-progress",
|
|
40
|
+
description: "Check progress on a specific feature",
|
|
41
|
+
pattern: /^progress on (.+) feature$/i,
|
|
42
|
+
builder: (match) => ({
|
|
43
|
+
content: {
|
|
44
|
+
topic: ["feature"],
|
|
45
|
+
keywords: [match[1]]
|
|
46
|
+
},
|
|
47
|
+
frame: {
|
|
48
|
+
type: [FrameType.FEATURE],
|
|
49
|
+
status: [FrameStatus.OPEN]
|
|
50
|
+
},
|
|
51
|
+
output: {
|
|
52
|
+
format: "summary",
|
|
53
|
+
sort: "score"
|
|
54
|
+
}
|
|
55
|
+
})
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
name: "code-review",
|
|
59
|
+
description: "Find recent changes for code review",
|
|
60
|
+
pattern: /^code review for (.+)$/i,
|
|
61
|
+
builder: (match) => {
|
|
62
|
+
const target = match[1];
|
|
63
|
+
const isFile = target.includes(".");
|
|
64
|
+
return {
|
|
65
|
+
content: isFile ? { files: [target] } : { topic: [target] },
|
|
66
|
+
time: { last: "24h" },
|
|
67
|
+
output: {
|
|
68
|
+
format: "full",
|
|
69
|
+
include: ["events", "digests"],
|
|
70
|
+
sort: "time"
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
name: "team-retrospective",
|
|
77
|
+
description: "Gather team work for retrospective",
|
|
78
|
+
pattern: /^retrospective for (last|this) (week|sprint|month)$/i,
|
|
79
|
+
builder: (match) => {
|
|
80
|
+
const timeMap = {
|
|
81
|
+
week: "7d",
|
|
82
|
+
sprint: "14d",
|
|
83
|
+
month: "30d"
|
|
84
|
+
};
|
|
85
|
+
return {
|
|
86
|
+
people: { team: "$current_team" },
|
|
87
|
+
time: { last: timeMap[match[2]] || "7d" },
|
|
88
|
+
output: {
|
|
89
|
+
format: "summary",
|
|
90
|
+
groupBy: "owner",
|
|
91
|
+
sort: "score"
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
},
|
|
96
|
+
{
|
|
97
|
+
name: "performance-analysis",
|
|
98
|
+
description: "Analyze performance issues",
|
|
99
|
+
pattern: /^performance (issues?|problems?|analysis) for (.+)$/i,
|
|
100
|
+
builder: (match) => ({
|
|
101
|
+
content: {
|
|
102
|
+
topic: ["performance", "optimization", "slow", "latency"],
|
|
103
|
+
keywords: [match[2]]
|
|
104
|
+
},
|
|
105
|
+
time: { last: "7d" },
|
|
106
|
+
output: {
|
|
107
|
+
format: "full",
|
|
108
|
+
sort: "score"
|
|
109
|
+
}
|
|
110
|
+
})
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
name: "security-audit",
|
|
114
|
+
description: "Security-related frames",
|
|
115
|
+
pattern: /^security audit( for (.+))?$/i,
|
|
116
|
+
builder: (match) => ({
|
|
117
|
+
content: {
|
|
118
|
+
topic: ["security", "vulnerability", "auth", "authorization"],
|
|
119
|
+
keywords: match[2] ? [match[2]] : void 0
|
|
120
|
+
},
|
|
121
|
+
frame: {
|
|
122
|
+
score: { min: 0.7 }
|
|
123
|
+
// High priority for security
|
|
124
|
+
},
|
|
125
|
+
output: {
|
|
126
|
+
format: "full",
|
|
127
|
+
sort: "score"
|
|
128
|
+
}
|
|
129
|
+
})
|
|
130
|
+
},
|
|
131
|
+
{
|
|
132
|
+
name: "deployment-readiness",
|
|
133
|
+
description: "Check deployment readiness",
|
|
134
|
+
pattern: /^deployment readiness( for (.+))?$/i,
|
|
135
|
+
builder: (match) => ({
|
|
136
|
+
content: {
|
|
137
|
+
topic: ["deployment", "release", "production"],
|
|
138
|
+
keywords: match[2] ? [match[2]] : void 0
|
|
139
|
+
},
|
|
140
|
+
frame: {
|
|
141
|
+
status: [FrameStatus.OPEN]
|
|
142
|
+
},
|
|
143
|
+
time: { last: "48h" },
|
|
144
|
+
output: {
|
|
145
|
+
format: "summary",
|
|
146
|
+
sort: "score"
|
|
147
|
+
}
|
|
148
|
+
})
|
|
149
|
+
}
|
|
150
|
+
];
|
|
151
|
+
/**
|
|
152
|
+
* Match query against templates
|
|
153
|
+
*/
|
|
154
|
+
matchTemplate(query) {
|
|
155
|
+
for (const template of this.templates) {
|
|
156
|
+
const match = query.match(template.pattern);
|
|
157
|
+
if (match) {
|
|
158
|
+
return template.builder(match);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
return null;
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* Get all template names and descriptions
|
|
165
|
+
*/
|
|
166
|
+
getTemplateInfo() {
|
|
167
|
+
return this.templates.map((t) => ({
|
|
168
|
+
name: t.name,
|
|
169
|
+
description: t.description
|
|
170
|
+
}));
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Add custom template
|
|
174
|
+
*/
|
|
175
|
+
addTemplate(template) {
|
|
176
|
+
this.templates.push(template);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
class InlineModifierParser {
|
|
180
|
+
modifierPatterns = {
|
|
181
|
+
time: /\+last:(\d+[hdwm])/gi,
|
|
182
|
+
since: /\+since:(\S+)/gi,
|
|
183
|
+
until: /\+until:(\S+)/gi,
|
|
184
|
+
owner: /\+owner:@?(\w+)/gi,
|
|
185
|
+
team: /\+team:(\w+)/gi,
|
|
186
|
+
topic: /\+topic:(\w+)/gi,
|
|
187
|
+
file: /\+file:(\S+)/gi,
|
|
188
|
+
sort: /\+sort:(time|score|relevance)/gi,
|
|
189
|
+
limit: /\+limit:(\d+)/gi,
|
|
190
|
+
format: /\+format:(full|summary|ids)/gi,
|
|
191
|
+
group: /\+group:(frame|time|owner|topic)/gi,
|
|
192
|
+
status: /\+status:(open|closed|stalled)/gi,
|
|
193
|
+
priority: /\+priority:(critical|high|medium|low)/gi
|
|
194
|
+
};
|
|
195
|
+
/**
|
|
196
|
+
* Parse inline modifiers from query
|
|
197
|
+
*/
|
|
198
|
+
parse(query) {
|
|
199
|
+
const modifiers = {};
|
|
200
|
+
let cleanQuery = query;
|
|
201
|
+
const lastMatch = [...query.matchAll(this.modifierPatterns.time)];
|
|
202
|
+
if (lastMatch.length > 0) {
|
|
203
|
+
modifiers.time = { last: lastMatch[0][1] };
|
|
204
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.time, "");
|
|
205
|
+
}
|
|
206
|
+
const sinceMatch = [...query.matchAll(this.modifierPatterns.since)];
|
|
207
|
+
if (sinceMatch.length > 0) {
|
|
208
|
+
const date = new Date(sinceMatch[0][1]);
|
|
209
|
+
if (!isNaN(date.getTime())) {
|
|
210
|
+
modifiers.time = { ...modifiers.time, since: date };
|
|
211
|
+
}
|
|
212
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.since, "");
|
|
213
|
+
}
|
|
214
|
+
const untilMatch = [...query.matchAll(this.modifierPatterns.until)];
|
|
215
|
+
if (untilMatch.length > 0) {
|
|
216
|
+
const date = new Date(untilMatch[0][1]);
|
|
217
|
+
if (!isNaN(date.getTime())) {
|
|
218
|
+
modifiers.time = { ...modifiers.time, until: date };
|
|
219
|
+
}
|
|
220
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.until, "");
|
|
221
|
+
}
|
|
222
|
+
const ownerMatches = [...query.matchAll(this.modifierPatterns.owner)];
|
|
223
|
+
if (ownerMatches.length > 0) {
|
|
224
|
+
modifiers.people = {
|
|
225
|
+
owner: ownerMatches.map((m) => m[1])
|
|
226
|
+
};
|
|
227
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.owner, "");
|
|
228
|
+
}
|
|
229
|
+
const teamMatch = [...query.matchAll(this.modifierPatterns.team)];
|
|
230
|
+
if (teamMatch.length > 0) {
|
|
231
|
+
modifiers.people = {
|
|
232
|
+
...modifiers.people,
|
|
233
|
+
team: teamMatch[0][1]
|
|
234
|
+
};
|
|
235
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.team, "");
|
|
236
|
+
}
|
|
237
|
+
const topicMatches = [...query.matchAll(this.modifierPatterns.topic)];
|
|
238
|
+
if (topicMatches.length > 0) {
|
|
239
|
+
modifiers.content = {
|
|
240
|
+
topic: topicMatches.map((m) => m[1])
|
|
241
|
+
};
|
|
242
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.topic, "");
|
|
243
|
+
}
|
|
244
|
+
const fileMatches = [...query.matchAll(this.modifierPatterns.file)];
|
|
245
|
+
if (fileMatches.length > 0) {
|
|
246
|
+
modifiers.content = {
|
|
247
|
+
...modifiers.content,
|
|
248
|
+
files: fileMatches.map((m) => m[1])
|
|
249
|
+
};
|
|
250
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.file, "");
|
|
251
|
+
}
|
|
252
|
+
const sortMatch = [...query.matchAll(this.modifierPatterns.sort)];
|
|
253
|
+
if (sortMatch.length > 0) {
|
|
254
|
+
modifiers.output = {
|
|
255
|
+
sort: sortMatch[0][1]
|
|
256
|
+
};
|
|
257
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.sort, "");
|
|
258
|
+
}
|
|
259
|
+
const limitMatch = [...query.matchAll(this.modifierPatterns.limit)];
|
|
260
|
+
if (limitMatch.length > 0) {
|
|
261
|
+
modifiers.output = {
|
|
262
|
+
...modifiers.output,
|
|
263
|
+
limit: parseInt(limitMatch[0][1])
|
|
264
|
+
};
|
|
265
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.limit, "");
|
|
266
|
+
}
|
|
267
|
+
const formatMatch = [...query.matchAll(this.modifierPatterns.format)];
|
|
268
|
+
if (formatMatch.length > 0) {
|
|
269
|
+
modifiers.output = {
|
|
270
|
+
...modifiers.output,
|
|
271
|
+
format: formatMatch[0][1]
|
|
272
|
+
};
|
|
273
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.format, "");
|
|
274
|
+
}
|
|
275
|
+
const groupMatch = [...query.matchAll(this.modifierPatterns.group)];
|
|
276
|
+
if (groupMatch.length > 0) {
|
|
277
|
+
modifiers.output = {
|
|
278
|
+
...modifiers.output,
|
|
279
|
+
groupBy: groupMatch[0][1]
|
|
280
|
+
};
|
|
281
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.group, "");
|
|
282
|
+
}
|
|
283
|
+
const statusMatch = [...query.matchAll(this.modifierPatterns.status)];
|
|
284
|
+
if (statusMatch.length > 0) {
|
|
285
|
+
const statusMap = {
|
|
286
|
+
open: FrameStatus.OPEN,
|
|
287
|
+
closed: FrameStatus.CLOSED,
|
|
288
|
+
stalled: FrameStatus.STALLED
|
|
289
|
+
};
|
|
290
|
+
modifiers.frame = {
|
|
291
|
+
status: statusMatch.map((m) => statusMap[m[1]])
|
|
292
|
+
};
|
|
293
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.status, "");
|
|
294
|
+
}
|
|
295
|
+
const priorityMatch = [...query.matchAll(this.modifierPatterns.priority)];
|
|
296
|
+
if (priorityMatch.length > 0) {
|
|
297
|
+
const priorityMap = {
|
|
298
|
+
critical: { min: 0.8 },
|
|
299
|
+
high: { min: 0.7, max: 0.8 },
|
|
300
|
+
medium: { min: 0.4, max: 0.7 },
|
|
301
|
+
low: { max: 0.4 }
|
|
302
|
+
};
|
|
303
|
+
modifiers.frame = {
|
|
304
|
+
...modifiers.frame,
|
|
305
|
+
score: priorityMap[priorityMatch[0][1]]
|
|
306
|
+
};
|
|
307
|
+
cleanQuery = cleanQuery.replace(this.modifierPatterns.priority, "");
|
|
308
|
+
}
|
|
309
|
+
cleanQuery = cleanQuery.replace(/\s+/g, " ").trim();
|
|
310
|
+
return { cleanQuery, modifiers };
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
export {
|
|
314
|
+
InlineModifierParser,
|
|
315
|
+
QueryTemplates
|
|
316
|
+
};
|
|
317
|
+
//# sourceMappingURL=query-templates.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/core/query/query-templates.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Query Templates for StackMemory\n * Provides pre-built query patterns for common use cases\n */\n\nimport { StackMemoryQuery, FrameType, FrameStatus } from './query-parser.js';\n\nexport interface QueryTemplate {\n name: string;\n description: string;\n pattern: RegExp;\n builder: (match: RegExpMatchArray) => Partial<StackMemoryQuery>;\n}\n\nexport class QueryTemplates {\n private templates: QueryTemplate[] = [\n {\n name: 'daily-standup',\n description: 'Get work done by a person today for standup',\n pattern: /^standup for @?(\\w+)$/i,\n builder: (match) => ({\n time: { last: '24h' },\n people: { owner: [match[1]] },\n output: {\n format: 'summary',\n sort: 'time',\n groupBy: 'frame',\n },\n }),\n },\n {\n name: 'error-investigation',\n description: 'Investigate errors in a specific component',\n pattern: /^investigate errors? in (.+)$/i,\n builder: (match) => ({\n content: {\n topic: ['error', 'bug'],\n keywords: [match[1]],\n },\n frame: {\n type: [FrameType.BUG, FrameType.DEBUG],\n },\n time: { last: '48h' },\n output: {\n format: 'full',\n sort: 'time',\n include: ['events', 'digests'],\n },\n }),\n },\n {\n name: 'feature-progress',\n description: 'Check progress on a specific feature',\n pattern: /^progress on (.+) feature$/i,\n builder: (match) => ({\n content: {\n topic: ['feature'],\n keywords: [match[1]],\n },\n frame: {\n type: [FrameType.FEATURE],\n status: [FrameStatus.OPEN],\n },\n output: {\n format: 'summary',\n sort: 'score',\n },\n }),\n },\n {\n name: 'code-review',\n description: 'Find recent changes for code review',\n pattern: /^code review for (.+)$/i,\n builder: (match) => {\n const target = match[1];\n const isFile = target.includes('.');\n return {\n content: isFile ? { files: [target] } : { topic: [target] },\n time: { last: '24h' },\n output: {\n format: 'full',\n include: ['events', 'digests'],\n sort: 'time',\n },\n };\n },\n },\n {\n name: 'team-retrospective',\n description: 'Gather team work for retrospective',\n pattern: /^retrospective for (last|this) (week|sprint|month)$/i,\n builder: (match) => {\n const timeMap: Record<string, string> = {\n week: '7d',\n sprint: '14d',\n month: '30d',\n };\n return {\n people: { team: '$current_team' },\n time: { last: timeMap[match[2]] || '7d' },\n output: {\n format: 'summary',\n groupBy: 'owner',\n sort: 'score',\n },\n };\n },\n },\n {\n name: 'performance-analysis',\n description: 'Analyze performance issues',\n pattern: /^performance (issues?|problems?|analysis) for (.+)$/i,\n builder: (match) => ({\n content: {\n topic: ['performance', 'optimization', 'slow', 'latency'],\n keywords: [match[2]],\n },\n time: { last: '7d' },\n output: {\n format: 'full',\n sort: 'score',\n },\n }),\n },\n {\n name: 'security-audit',\n description: 'Security-related frames',\n pattern: /^security audit( for (.+))?$/i,\n builder: (match) => ({\n content: {\n topic: ['security', 'vulnerability', 'auth', 'authorization'],\n keywords: match[2] ? [match[2]] : undefined,\n },\n frame: {\n score: { min: 0.7 }, // High priority for security\n },\n output: {\n format: 'full',\n sort: 'score',\n },\n }),\n },\n {\n name: 'deployment-readiness',\n description: 'Check deployment readiness',\n pattern: /^deployment readiness( for (.+))?$/i,\n builder: (match) => ({\n content: {\n topic: ['deployment', 'release', 'production'],\n keywords: match[2] ? [match[2]] : undefined,\n },\n frame: {\n status: [FrameStatus.OPEN],\n },\n time: { last: '48h' },\n output: {\n format: 'summary',\n sort: 'score',\n },\n }),\n },\n ];\n\n /**\n * Match query against templates\n */\n matchTemplate(query: string): Partial<StackMemoryQuery> | null {\n for (const template of this.templates) {\n const match = query.match(template.pattern);\n if (match) {\n return template.builder(match);\n }\n }\n return null;\n }\n\n /**\n * Get all template names and descriptions\n */\n getTemplateInfo(): Array<{ name: string; description: string }> {\n return this.templates.map((t) => ({\n name: t.name,\n description: t.description,\n }));\n }\n\n /**\n * Add custom template\n */\n addTemplate(template: QueryTemplate): void {\n this.templates.push(template);\n }\n}\n\n/**\n * Inline modifier parser for queries like:\n * \"auth work +last:3d +owner:alice +sort:score\"\n */\nexport class InlineModifierParser {\n private modifierPatterns = {\n time: /\\+last:(\\d+[hdwm])/gi,\n since: /\\+since:(\\S+)/gi,\n until: /\\+until:(\\S+)/gi,\n owner: /\\+owner:@?(\\w+)/gi,\n team: /\\+team:(\\w+)/gi,\n topic: /\\+topic:(\\w+)/gi,\n file: /\\+file:(\\S+)/gi,\n sort: /\\+sort:(time|score|relevance)/gi,\n limit: /\\+limit:(\\d+)/gi,\n format: /\\+format:(full|summary|ids)/gi,\n group: /\\+group:(frame|time|owner|topic)/gi,\n status: /\\+status:(open|closed|stalled)/gi,\n priority: /\\+priority:(critical|high|medium|low)/gi,\n };\n\n /**\n * Parse inline modifiers from query\n */\n parse(query: string): {\n cleanQuery: string;\n modifiers: Partial<StackMemoryQuery>;\n } {\n const modifiers: Partial<StackMemoryQuery> = {};\n let cleanQuery = query;\n\n // Parse time modifiers\n const lastMatch = [...query.matchAll(this.modifierPatterns.time)];\n if (lastMatch.length > 0) {\n modifiers.time = { last: lastMatch[0][1] };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.time, '');\n }\n\n const sinceMatch = [...query.matchAll(this.modifierPatterns.since)];\n if (sinceMatch.length > 0) {\n const date = new Date(sinceMatch[0][1]);\n if (!isNaN(date.getTime())) {\n modifiers.time = { ...modifiers.time, since: date };\n }\n cleanQuery = cleanQuery.replace(this.modifierPatterns.since, '');\n }\n\n const untilMatch = [...query.matchAll(this.modifierPatterns.until)];\n if (untilMatch.length > 0) {\n const date = new Date(untilMatch[0][1]);\n if (!isNaN(date.getTime())) {\n modifiers.time = { ...modifiers.time, until: date };\n }\n cleanQuery = cleanQuery.replace(this.modifierPatterns.until, '');\n }\n\n // Parse people modifiers\n const ownerMatches = [...query.matchAll(this.modifierPatterns.owner)];\n if (ownerMatches.length > 0) {\n modifiers.people = {\n owner: ownerMatches.map((m) => m[1]),\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.owner, '');\n }\n\n const teamMatch = [...query.matchAll(this.modifierPatterns.team)];\n if (teamMatch.length > 0) {\n modifiers.people = {\n ...modifiers.people,\n team: teamMatch[0][1],\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.team, '');\n }\n\n // Parse content modifiers\n const topicMatches = [...query.matchAll(this.modifierPatterns.topic)];\n if (topicMatches.length > 0) {\n modifiers.content = {\n topic: topicMatches.map((m) => m[1]),\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.topic, '');\n }\n\n const fileMatches = [...query.matchAll(this.modifierPatterns.file)];\n if (fileMatches.length > 0) {\n modifiers.content = {\n ...modifiers.content,\n files: fileMatches.map((m) => m[1]),\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.file, '');\n }\n\n // Parse output modifiers\n const sortMatch = [...query.matchAll(this.modifierPatterns.sort)];\n if (sortMatch.length > 0) {\n modifiers.output = {\n sort: sortMatch[0][1] as 'time' | 'score' | 'relevance',\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.sort, '');\n }\n\n const limitMatch = [...query.matchAll(this.modifierPatterns.limit)];\n if (limitMatch.length > 0) {\n modifiers.output = {\n ...modifiers.output,\n limit: parseInt(limitMatch[0][1]),\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.limit, '');\n }\n\n const formatMatch = [...query.matchAll(this.modifierPatterns.format)];\n if (formatMatch.length > 0) {\n modifiers.output = {\n ...modifiers.output,\n format: formatMatch[0][1] as 'full' | 'summary' | 'ids',\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.format, '');\n }\n\n const groupMatch = [...query.matchAll(this.modifierPatterns.group)];\n if (groupMatch.length > 0) {\n modifiers.output = {\n ...modifiers.output,\n groupBy: groupMatch[0][1] as 'frame' | 'time' | 'owner' | 'topic',\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.group, '');\n }\n\n // Parse frame modifiers\n const statusMatch = [...query.matchAll(this.modifierPatterns.status)];\n if (statusMatch.length > 0) {\n const statusMap: Record<string, FrameStatus> = {\n open: FrameStatus.OPEN,\n closed: FrameStatus.CLOSED,\n stalled: FrameStatus.STALLED,\n };\n modifiers.frame = {\n status: statusMatch.map((m) => statusMap[m[1]]),\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.status, '');\n }\n\n const priorityMatch = [...query.matchAll(this.modifierPatterns.priority)];\n if (priorityMatch.length > 0) {\n const priorityMap: Record<string, { min?: number; max?: number }> = {\n critical: { min: 0.8 },\n high: { min: 0.7, max: 0.8 },\n medium: { min: 0.4, max: 0.7 },\n low: { max: 0.4 },\n };\n modifiers.frame = {\n ...modifiers.frame,\n score: priorityMap[priorityMatch[0][1]],\n };\n cleanQuery = cleanQuery.replace(this.modifierPatterns.priority, '');\n }\n\n // Clean up extra whitespace\n cleanQuery = cleanQuery.replace(/\\s+/g, ' ').trim();\n\n return { cleanQuery, modifiers };\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/core/retrieval/index.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * LLM-Driven Context Retrieval Module\n * Exports all retrieval functionality\n */\n\nexport * from './types.js';\nexport * from './summary-generator.js';\nexport * from './llm-context-retrieval.js';\n"],
|
|
5
|
+
"mappings": "AAKA,cAAc;AACd,cAAc;AACd,cAAc;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|