@stackmemoryai/stackmemory 0.5.58 → 0.5.61
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/README.md +105 -1
- package/dist/scripts/benchmark-performance.js +48 -0
- package/dist/scripts/benchmark-performance.js.map +7 -0
- package/dist/scripts/check-redis.js +42 -0
- package/dist/scripts/check-redis.js.map +7 -0
- package/dist/scripts/initialize.js +116 -0
- package/dist/scripts/initialize.js.map +7 -0
- package/dist/scripts/list-linear-tasks.js +124 -0
- package/dist/scripts/list-linear-tasks.js.map +7 -0
- package/dist/scripts/measure-handoff-impact.js +340 -0
- package/dist/scripts/measure-handoff-impact.js.map +7 -0
- package/dist/scripts/query-chromadb.js +160 -0
- package/dist/scripts/query-chromadb.js.map +7 -0
- package/dist/scripts/show-linear-summary.js +119 -0
- package/dist/scripts/show-linear-summary.js.map +7 -0
- package/dist/scripts/simple-swarm-demo.js +90 -0
- package/dist/scripts/simple-swarm-demo.js.map +7 -0
- package/dist/scripts/status.js +155 -0
- package/dist/scripts/status.js.map +7 -0
- package/dist/scripts/test-chromadb-sync.js +192 -0
- package/dist/scripts/test-chromadb-sync.js.map +7 -0
- package/dist/scripts/test-ralph-iteration-fix.js +86 -0
- package/dist/scripts/test-ralph-iteration-fix.js.map +7 -0
- package/dist/scripts/test-ralph-iterations.js +121 -0
- package/dist/scripts/test-ralph-iterations.js.map +7 -0
- package/dist/scripts/test-redis-storage.js +389 -0
- package/dist/scripts/test-redis-storage.js.map +7 -0
- package/dist/scripts/test-simple-ralph-state-sync.js +115 -0
- package/dist/scripts/test-simple-ralph-state-sync.js.map +7 -0
- package/dist/scripts/test-swarm-fixes.js +125 -0
- package/dist/scripts/test-swarm-fixes.js.map +7 -0
- package/dist/scripts/test-swarm-tui.js +23 -0
- package/dist/scripts/test-swarm-tui.js.map +7 -0
- package/dist/scripts/test-tui-shortcuts.js +52 -0
- package/dist/scripts/test-tui-shortcuts.js.map +7 -0
- package/dist/scripts/validate-tui-shortcuts.js +60 -0
- package/dist/scripts/validate-tui-shortcuts.js.map +7 -0
- package/dist/src/agents/core/agent-task-manager.js.map +7 -0
- package/dist/src/agents/verifiers/base-verifier.js.map +7 -0
- package/dist/src/agents/verifiers/formatter-verifier.js.map +7 -0
- package/dist/src/agents/verifiers/llm-judge.js.map +7 -0
- package/dist/src/cli/auto-detect.js.map +7 -0
- package/dist/src/cli/claude-sm-danger.js.map +7 -0
- package/dist/src/cli/claude-sm.js +1236 -0
- package/dist/src/cli/claude-sm.js.map +7 -0
- package/dist/src/cli/codex-sm-danger.js.map +7 -0
- package/dist/src/cli/codex-sm.js.map +7 -0
- package/dist/src/cli/commands/api.js.map +7 -0
- package/dist/src/cli/commands/auto-background.js.map +7 -0
- package/dist/src/cli/commands/cleanup-processes.js.map +7 -0
- package/dist/src/cli/commands/clear.js.map +7 -0
- package/dist/src/cli/commands/config.js.map +7 -0
- package/dist/src/cli/commands/context-rehydrate.js.map +7 -0
- package/dist/src/cli/commands/context.js.map +7 -0
- package/dist/src/cli/commands/daemon.js.map +7 -0
- package/dist/src/cli/commands/dashboard.js.map +7 -0
- package/dist/src/cli/commands/db.js.map +7 -0
- package/dist/src/cli/commands/decision.js.map +7 -0
- package/dist/src/cli/commands/discovery.js.map +7 -0
- package/dist/src/cli/commands/handoff.js.map +7 -0
- package/dist/src/cli/commands/hooks.js.map +7 -0
- package/dist/src/cli/commands/linear.js.map +7 -0
- package/dist/src/cli/commands/log.js.map +7 -0
- package/dist/src/cli/commands/login.js.map +7 -0
- package/dist/src/cli/commands/migrate.js.map +7 -0
- package/dist/src/cli/commands/model.js.map +7 -0
- package/dist/src/cli/commands/onboard.js.map +7 -0
- package/dist/src/cli/commands/projects.js.map +7 -0
- package/dist/src/cli/commands/ralph.js.map +7 -0
- package/dist/src/cli/commands/retrieval.js.map +7 -0
- package/dist/src/cli/commands/search.js +173 -0
- package/dist/src/cli/commands/search.js.map +7 -0
- package/dist/src/cli/commands/service.js.map +7 -0
- package/dist/src/cli/commands/session.js.map +7 -0
- package/dist/src/cli/commands/settings.js.map +7 -0
- package/dist/src/cli/commands/setup.js.map +7 -0
- package/dist/src/cli/commands/shell.js.map +7 -0
- package/dist/src/cli/commands/signup.js.map +7 -0
- package/dist/src/cli/commands/skills.js.map +7 -0
- package/dist/src/cli/commands/sms-notify.js.map +7 -0
- package/dist/src/cli/commands/storage-tier.js.map +7 -0
- package/dist/src/cli/commands/sweep.js.map +7 -0
- package/dist/src/cli/commands/tasks.js.map +7 -0
- package/dist/src/cli/commands/worktree.js.map +7 -0
- package/dist/src/cli/index.js +609 -0
- package/dist/src/cli/index.js.map +7 -0
- package/dist/src/cli/opencode-sm.js.map +7 -0
- package/dist/src/cli/utils/viewer.js.map +7 -0
- package/dist/src/core/config/config-manager.js.map +7 -0
- package/dist/src/core/config/feature-flags.js.map +7 -0
- package/dist/src/core/config/storage-config.js.map +7 -0
- package/dist/src/core/config/types.js.map +7 -0
- package/dist/src/core/context/auto-context.js.map +7 -0
- package/dist/src/core/context/dual-stack-manager.js.map +7 -0
- package/dist/src/core/context/enhanced-rehydration.js.map +7 -0
- package/dist/src/core/context/frame-database.js.map +7 -0
- package/dist/src/core/context/frame-digest.js.map +7 -0
- package/dist/src/core/context/frame-handoff-manager.js.map +7 -0
- package/dist/src/core/context/frame-lifecycle-hooks.js.map +7 -0
- package/dist/src/core/context/frame-recovery.js.map +7 -0
- package/dist/src/core/context/frame-stack.js.map +7 -0
- package/dist/src/core/context/index.js.map +7 -0
- package/dist/src/core/context/permission-manager.js.map +7 -0
- package/dist/src/core/context/recursive-context-manager.js.map +7 -0
- package/dist/src/core/context/refactored-frame-manager.js.map +7 -0
- package/dist/src/core/context/shared-context-layer.js.map +7 -0
- package/dist/src/core/context/stack-merge-resolver.js.map +7 -0
- package/dist/src/core/context/validation.js.map +7 -0
- package/dist/src/core/database/batch-operations.js.map +7 -0
- package/dist/src/core/database/connection-pool.js.map +7 -0
- package/dist/src/core/database/database-adapter.js.map +7 -0
- package/dist/src/core/database/migration-manager.js.map +7 -0
- package/dist/src/core/database/query-cache.js.map +7 -0
- package/dist/src/core/database/query-router.js.map +7 -0
- package/dist/src/core/database/sqlite-adapter.js +738 -0
- package/dist/src/core/database/sqlite-adapter.js.map +7 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.js.map +7 -0
- package/dist/src/core/digest/frame-digest-integration.js.map +7 -0
- package/dist/src/core/digest/hybrid-digest-generator.js.map +7 -0
- package/dist/src/core/digest/index.js.map +7 -0
- package/dist/src/core/digest/types.js.map +7 -0
- package/dist/src/core/errors/error-utils.js +208 -0
- package/dist/src/core/errors/error-utils.js.map +7 -0
- package/dist/src/core/errors/index.js +521 -0
- package/dist/src/core/errors/index.js.map +7 -0
- package/dist/src/core/errors/recovery.js.map +7 -0
- package/dist/src/core/execution/parallel-executor.js.map +7 -0
- package/dist/src/core/extensions/custom-tools.js +567 -0
- package/dist/src/core/extensions/custom-tools.js.map +7 -0
- package/dist/src/core/extensions/index.js +55 -0
- package/dist/src/core/extensions/index.js.map +7 -0
- package/dist/src/core/extensions/loader.js +709 -0
- package/dist/src/core/extensions/loader.js.map +7 -0
- package/dist/src/core/extensions/plugin-system.js +506 -0
- package/dist/src/core/extensions/plugin-system.js.map +7 -0
- package/dist/src/core/extensions/provider-adapter.js +617 -0
- package/dist/src/core/extensions/provider-adapter.js.map +7 -0
- package/dist/src/core/extensions/sandbox-runtime.js +664 -0
- package/dist/src/core/extensions/sandbox-runtime.js.map +7 -0
- package/dist/src/core/frame/workflow-templates.js.map +7 -0
- package/dist/src/core/merge/conflict-detector.js.map +7 -0
- package/dist/src/core/merge/index.js.map +7 -0
- package/dist/src/core/merge/resolution-engine.js.map +7 -0
- package/dist/src/core/merge/stack-diff.js.map +7 -0
- package/dist/src/core/merge/unified-merge-resolver.js +303 -0
- package/dist/src/core/merge/unified-merge-resolver.js.map +7 -0
- package/dist/src/core/models/fallback-monitor.js.map +7 -0
- package/dist/src/core/models/model-router.js.map +7 -0
- package/dist/src/core/monitoring/error-handler.js.map +7 -0
- package/dist/src/core/monitoring/logger.js +202 -0
- package/dist/src/core/monitoring/logger.js.map +7 -0
- package/dist/src/core/monitoring/metrics.js.map +7 -0
- package/dist/src/core/monitoring/progress-tracker.js.map +7 -0
- package/dist/src/core/monitoring/session-monitor.js.map +7 -0
- package/dist/src/core/performance/context-cache.js.map +7 -0
- package/dist/src/core/performance/index.js.map +7 -0
- package/dist/src/core/performance/lazy-context-loader.js.map +7 -0
- package/dist/src/core/performance/monitor.js.map +7 -0
- package/dist/src/core/performance/optimized-frame-context.js.map +7 -0
- package/dist/src/core/performance/performance-benchmark.js.map +7 -0
- package/dist/src/core/performance/performance-profiler.js.map +7 -0
- package/dist/src/core/performance/streaming-jsonl-parser.js.map +7 -0
- package/dist/src/core/persistence/postgres-adapter.js.map +7 -0
- package/dist/src/core/projects/project-isolation.js.map +7 -0
- package/dist/src/core/projects/project-manager.js.map +7 -0
- package/dist/src/core/query/query-parser.js.map +7 -0
- package/dist/src/core/query/query-templates.js.map +7 -0
- package/dist/src/core/retrieval/context-retriever.js.map +7 -0
- package/dist/src/core/retrieval/index.js.map +7 -0
- package/dist/src/core/retrieval/llm-context-retrieval.js.map +7 -0
- package/dist/src/core/retrieval/llm-provider.js.map +7 -0
- package/dist/src/core/retrieval/retrieval-audit.js.map +7 -0
- package/dist/src/core/retrieval/summary-generator.js.map +7 -0
- package/dist/src/core/retrieval/types.js.map +7 -0
- package/dist/src/core/security/index.js +35 -0
- package/dist/src/core/security/index.js.map +7 -0
- package/dist/src/core/security/input-sanitizer.js +321 -0
- package/dist/src/core/security/input-sanitizer.js.map +7 -0
- package/dist/src/core/session/clear-survival.js.map +7 -0
- package/dist/src/core/session/enhanced-handoff.js.map +7 -0
- package/dist/src/core/session/handoff-generator.js.map +7 -0
- package/dist/src/core/session/index.js.map +7 -0
- package/dist/src/core/session/session-manager.js.map +7 -0
- package/dist/src/core/skills/index.js.map +7 -0
- package/dist/src/core/skills/skill-storage.js.map +7 -0
- package/dist/src/core/skills/types.js.map +7 -0
- package/dist/src/core/storage/chromadb-adapter.js +380 -0
- package/dist/src/core/storage/chromadb-adapter.js.map +7 -0
- package/dist/src/core/storage/infinite-storage.js.map +7 -0
- package/dist/src/core/storage/remote-storage.js.map +7 -0
- package/dist/src/core/storage/two-tier-storage.js.map +7 -0
- package/dist/src/core/trace/cli-trace-wrapper.js.map +7 -0
- package/dist/src/core/trace/db-trace-wrapper.js.map +7 -0
- package/dist/src/core/trace/debug-trace.js.map +7 -0
- package/dist/src/core/trace/index.js.map +7 -0
- package/dist/src/core/trace/linear-api-wrapper.js.map +7 -0
- package/dist/src/core/trace/trace-detector.js.map +7 -0
- package/dist/src/core/trace/trace-store.js.map +7 -0
- package/dist/src/core/trace/types.js.map +7 -0
- package/dist/src/core/utils/async-mutex.js.map +7 -0
- package/dist/src/core/utils/compression.js.map +7 -0
- package/dist/src/core/utils/update-checker.js.map +7 -0
- package/dist/src/core/worktree/worktree-manager.js.map +7 -0
- package/dist/src/daemon/daemon-config.js.map +7 -0
- package/dist/src/daemon/services/context-service.js.map +7 -0
- package/dist/src/daemon/services/linear-service.js.map +7 -0
- package/dist/src/daemon/session-daemon.js.map +7 -0
- package/dist/src/daemon/unified-daemon.js.map +7 -0
- package/dist/src/features/analytics/api/analytics-api.js.map +7 -0
- package/dist/src/features/analytics/core/analytics-service.js.map +7 -0
- package/dist/src/features/analytics/index.js.map +7 -0
- package/dist/src/features/analytics/queries/metrics-queries.js.map +7 -0
- package/dist/src/features/browser/browser-mcp.js.map +7 -0
- package/dist/src/features/sweep/index.js.map +7 -0
- package/dist/src/features/sweep/prediction-client.js.map +7 -0
- package/dist/src/features/sweep/prompt-builder.js.map +7 -0
- package/dist/src/features/sweep/pty-wrapper.js.map +7 -0
- package/dist/src/features/sweep/state-watcher.js.map +7 -0
- package/dist/src/features/sweep/status-bar.js.map +7 -0
- package/dist/src/features/sweep/sweep-server-manager.js.map +7 -0
- package/dist/src/features/sweep/tab-interceptor.js.map +7 -0
- package/dist/src/features/sweep/types.js.map +7 -0
- package/dist/src/features/tasks/linear-task-manager.js.map +7 -0
- package/dist/src/features/tasks/task-aware-context.js.map +7 -0
- package/dist/src/features/tui/simple-monitor.js.map +7 -0
- package/dist/src/features/tui/swarm-monitor.js.map +7 -0
- package/dist/src/features/web/client/stores/task-store.js.map +7 -0
- package/dist/src/features/web/server/index.js.map +7 -0
- package/dist/src/hooks/auto-background.js.map +7 -0
- package/dist/src/hooks/claude-code-whatsapp-hook.js.map +7 -0
- package/dist/src/hooks/config.js.map +7 -0
- package/dist/src/hooks/daemon.js.map +7 -0
- package/dist/src/hooks/events.js.map +7 -0
- package/dist/src/hooks/index.js.map +7 -0
- package/dist/src/hooks/linear-task-picker.js.map +7 -0
- package/dist/src/hooks/schemas.js.map +7 -0
- package/dist/src/hooks/secure-fs.js.map +7 -0
- package/dist/src/hooks/security-logger.js.map +7 -0
- package/dist/src/hooks/session-summary.js.map +7 -0
- package/dist/src/hooks/sms-action-runner.js.map +7 -0
- package/dist/src/hooks/sms-notify.js.map +7 -0
- package/dist/src/hooks/sms-watcher.js.map +7 -0
- package/dist/src/hooks/sms-webhook.js.map +7 -0
- package/dist/src/hooks/whatsapp-commands.js.map +7 -0
- package/dist/src/hooks/whatsapp-scheduler.js.map +7 -0
- package/dist/src/hooks/whatsapp-sync.js.map +7 -0
- package/dist/src/index.js.map +7 -0
- package/dist/src/integrations/anthropic/client.js.map +7 -0
- package/dist/src/integrations/claude-code/agent-bridge.js.map +7 -0
- package/dist/src/integrations/claude-code/enhanced-pre-clear-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/lifecycle-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/post-task-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/subagent-client-stub.js.map +7 -0
- package/dist/src/integrations/claude-code/subagent-client.js.map +7 -0
- package/dist/src/integrations/claude-code/task-coordinator.js.map +7 -0
- package/dist/src/integrations/linear/auth.js.map +7 -0
- package/dist/src/integrations/linear/auto-sync.js.map +7 -0
- package/dist/src/integrations/linear/client.js +634 -0
- package/dist/src/integrations/linear/client.js.map +7 -0
- package/dist/src/integrations/linear/config.js.map +7 -0
- package/dist/src/integrations/linear/migration.js.map +7 -0
- package/dist/src/integrations/linear/oauth-server.js.map +7 -0
- package/dist/src/integrations/linear/rest-client.js.map +7 -0
- package/dist/src/integrations/linear/sync-manager.js.map +7 -0
- package/dist/src/integrations/linear/sync-service.js.map +7 -0
- package/dist/src/integrations/linear/sync.js.map +7 -0
- package/dist/src/integrations/linear/unified-sync.js.map +7 -0
- package/dist/src/integrations/linear/webhook-handler.js.map +7 -0
- package/dist/src/integrations/linear/webhook-server.js.map +7 -0
- package/dist/src/integrations/linear/webhook.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/code-execution-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/context-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/discovery-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/index.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/skill-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/index.js.map +7 -0
- package/dist/src/integrations/mcp/middleware/tool-scoring.js.map +7 -0
- package/dist/src/integrations/mcp/refactored-server.js.map +7 -0
- package/dist/src/integrations/mcp/remote-server.js +682 -0
- package/dist/src/integrations/mcp/remote-server.js.map +7 -0
- package/dist/src/integrations/mcp/schemas.js.map +7 -0
- package/dist/src/integrations/mcp/server.js +1975 -0
- package/dist/src/integrations/mcp/server.js.map +7 -0
- package/dist/src/integrations/mcp/tool-definitions-code.js.map +7 -0
- package/dist/src/integrations/mcp/tool-definitions.js.map +7 -0
- package/dist/src/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +7 -0
- package/dist/src/integrations/ralph/context/context-budget-manager.js.map +7 -0
- package/dist/src/integrations/ralph/context/stackmemory-context-loader.js.map +7 -0
- package/dist/src/integrations/ralph/coordination/enhanced-coordination.js.map +7 -0
- package/dist/src/integrations/ralph/index.js.map +7 -0
- package/dist/src/integrations/ralph/learning/pattern-learner.js.map +7 -0
- package/dist/src/integrations/ralph/lifecycle/iteration-lifecycle.js.map +7 -0
- package/dist/src/integrations/ralph/monitoring/swarm-dashboard.js.map +7 -0
- package/dist/src/integrations/ralph/monitoring/swarm-registry.js.map +7 -0
- package/dist/src/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/compounding-engineering-pattern.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/extended-coherence-sessions.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js.map +7 -0
- package/dist/src/integrations/ralph/performance/performance-optimizer.js.map +7 -0
- package/dist/src/integrations/ralph/recovery/crash-recovery.js.map +7 -0
- package/dist/src/integrations/ralph/state/state-reconciler.js.map +7 -0
- package/dist/src/integrations/ralph/swarm/git-workflow-manager.js.map +7 -0
- package/dist/src/integrations/ralph/swarm/swarm-coordinator.js.map +7 -0
- package/dist/src/integrations/ralph/types.js +5 -0
- package/dist/src/integrations/ralph/visualization/ralph-debugger.js.map +7 -0
- package/dist/src/mcp/stackmemory-mcp-server.js.map +7 -0
- package/dist/src/middleware/exponential-rate-limiter.js.map +7 -0
- package/dist/src/models/user.model.js.map +7 -0
- package/dist/src/servers/production/auth-middleware.js.map +7 -0
- package/dist/src/services/config-service.js.map +7 -0
- package/dist/src/services/context-service.js.map +7 -0
- package/dist/src/skills/api-discovery.js.map +7 -0
- package/dist/src/skills/api-skill.js.map +7 -0
- package/dist/src/skills/claude-skills.js.map +7 -0
- package/dist/src/skills/dashboard-launcher.js.map +7 -0
- package/dist/src/skills/recursive-agent-orchestrator.js.map +7 -0
- package/dist/src/skills/repo-ingestion-skill.js +632 -0
- package/dist/src/skills/repo-ingestion-skill.js.map +7 -0
- package/dist/src/skills/unified-rlm-orchestrator.js.map +7 -0
- package/dist/src/types/task.js.map +7 -0
- package/dist/src/utils/env.js.map +7 -0
- package/dist/src/utils/formatting.js.map +7 -0
- package/dist/src/utils/process-cleanup.js.map +7 -0
- package/package.json +13 -9
- package/scripts/background-sync-manager.js +145 -83
- package/scripts/claude-sm-autostart.js +17 -12
- package/scripts/gepa/README.md +275 -0
- package/scripts/gepa/config.json +53 -0
- package/scripts/gepa/evals/coding-tasks.jsonl +5 -0
- package/scripts/gepa/evals/fixtures/buggy-loop.js +18 -0
- package/scripts/gepa/evals/fixtures/callback-hell.js +53 -0
- package/scripts/gepa/generations/gen-000/baseline.md +124 -0
- package/scripts/gepa/hooks/auto-optimize.js +494 -0
- package/scripts/gepa/hooks/eval-tracker.js +203 -0
- package/scripts/gepa/hooks/reflect.js +311 -0
- package/scripts/gepa/optimize.js +611 -0
- package/scripts/gepa/state.json +14 -0
- package/scripts/initialize.ts +16 -7
- package/scripts/install.sh +14 -62
- package/scripts/status.ts +111 -46
- package/scripts/test-pre-publish-quick.sh +1 -1
- package/dist/agents/core/agent-task-manager.js.map +0 -7
- package/dist/agents/testing-agent.js +0 -614
- package/dist/agents/testing-agent.js.map +0 -7
- package/dist/agents/verifiers/base-verifier.js.map +0 -7
- package/dist/agents/verifiers/formatter-verifier.js.map +0 -7
- package/dist/agents/verifiers/llm-judge.js.map +0 -7
- package/dist/cli/auto-detect.js.map +0 -7
- package/dist/cli/browser-test.js +0 -33
- package/dist/cli/browser-test.js.map +0 -7
- package/dist/cli/claude-sm-danger.js.map +0 -7
- package/dist/cli/claude-sm.js +0 -1156
- package/dist/cli/claude-sm.js.map +0 -7
- package/dist/cli/codex-sm-danger.js.map +0 -7
- package/dist/cli/codex-sm.js.map +0 -7
- package/dist/cli/commands/api.js.map +0 -7
- package/dist/cli/commands/auto-background.js.map +0 -7
- package/dist/cli/commands/cleanup-processes.js.map +0 -7
- package/dist/cli/commands/clear.js.map +0 -7
- package/dist/cli/commands/config.js.map +0 -7
- package/dist/cli/commands/context-rehydrate.js.map +0 -7
- package/dist/cli/commands/context.js.map +0 -7
- package/dist/cli/commands/daemon.js.map +0 -7
- package/dist/cli/commands/dashboard.js.map +0 -7
- package/dist/cli/commands/db.js.map +0 -7
- package/dist/cli/commands/decision.js.map +0 -7
- package/dist/cli/commands/discovery.js.map +0 -7
- package/dist/cli/commands/handoff.js.map +0 -7
- package/dist/cli/commands/hooks.js.map +0 -7
- package/dist/cli/commands/linear-unified.js +0 -353
- package/dist/cli/commands/linear-unified.js.map +0 -7
- package/dist/cli/commands/linear.js.map +0 -7
- package/dist/cli/commands/log.js.map +0 -7
- package/dist/cli/commands/login.js.map +0 -7
- package/dist/cli/commands/migrate.js.map +0 -7
- package/dist/cli/commands/model.js.map +0 -7
- package/dist/cli/commands/monitor.js +0 -313
- package/dist/cli/commands/monitor.js.map +0 -7
- package/dist/cli/commands/onboard.js.map +0 -7
- package/dist/cli/commands/projects.js.map +0 -7
- package/dist/cli/commands/quality.js +0 -413
- package/dist/cli/commands/quality.js.map +0 -7
- package/dist/cli/commands/ralph.js.map +0 -7
- package/dist/cli/commands/retrieval.js.map +0 -7
- package/dist/cli/commands/search.js +0 -156
- package/dist/cli/commands/search.js.map +0 -7
- package/dist/cli/commands/service.js.map +0 -7
- package/dist/cli/commands/session.js.map +0 -7
- package/dist/cli/commands/settings.js.map +0 -7
- package/dist/cli/commands/setup.js.map +0 -7
- package/dist/cli/commands/shell.js.map +0 -7
- package/dist/cli/commands/signup.js.map +0 -7
- package/dist/cli/commands/skills.js.map +0 -7
- package/dist/cli/commands/sms-notify.js.map +0 -7
- package/dist/cli/commands/storage-tier.js.map +0 -7
- package/dist/cli/commands/storage.js +0 -360
- package/dist/cli/commands/storage.js.map +0 -7
- package/dist/cli/commands/sweep.js.map +0 -7
- package/dist/cli/commands/tasks.js.map +0 -7
- package/dist/cli/commands/test.js +0 -286
- package/dist/cli/commands/test.js.map +0 -7
- package/dist/cli/commands/workflow.js +0 -142
- package/dist/cli/commands/workflow.js.map +0 -7
- package/dist/cli/commands/worktree.js.map +0 -7
- package/dist/cli/index.js +0 -594
- package/dist/cli/index.js.map +0 -7
- package/dist/cli/opencode-sm.js.map +0 -7
- package/dist/cli/utils/viewer.js.map +0 -7
- package/dist/core/analytics/team-analytics.js +0 -378
- package/dist/core/analytics/team-analytics.js.map +0 -7
- package/dist/core/config/config-manager.js.map +0 -7
- package/dist/core/config/feature-flags.js.map +0 -7
- package/dist/core/config/storage-config.js.map +0 -7
- package/dist/core/config/types.js.map +0 -7
- package/dist/core/context/auto-context.js.map +0 -7
- package/dist/core/context/dual-stack-manager.js.map +0 -7
- package/dist/core/context/enhanced-rehydration.js.map +0 -7
- package/dist/core/context/frame-database.js.map +0 -7
- package/dist/core/context/frame-digest.js.map +0 -7
- package/dist/core/context/frame-handoff-manager.js.map +0 -7
- package/dist/core/context/frame-lifecycle-hooks.js.map +0 -7
- package/dist/core/context/frame-manager.js +0 -1069
- package/dist/core/context/frame-manager.js.map +0 -7
- package/dist/core/context/frame-recovery.js.map +0 -7
- package/dist/core/context/frame-stack.js.map +0 -7
- package/dist/core/context/incremental-gc.js +0 -290
- package/dist/core/context/incremental-gc.js.map +0 -7
- package/dist/core/context/index.js.map +0 -7
- package/dist/core/context/model-aware-compaction.js +0 -623
- package/dist/core/context/model-aware-compaction.js.map +0 -7
- package/dist/core/context/permission-manager.js.map +0 -7
- package/dist/core/context/recursive-context-manager.js.map +0 -7
- package/dist/core/context/refactored-frame-manager.js.map +0 -7
- package/dist/core/context/shared-context-layer.js.map +0 -7
- package/dist/core/context/stack-merge-resolver.js.map +0 -7
- package/dist/core/context/validation.js.map +0 -7
- package/dist/core/database/batch-operations.js.map +0 -7
- package/dist/core/database/connection-pool.js.map +0 -7
- package/dist/core/database/database-adapter.js.map +0 -7
- package/dist/core/database/migration-manager.js.map +0 -7
- package/dist/core/database/paradedb-adapter.js +0 -990
- package/dist/core/database/paradedb-adapter.js.map +0 -7
- package/dist/core/database/query-cache.js.map +0 -7
- package/dist/core/database/query-router.js.map +0 -7
- package/dist/core/database/sqlite-adapter.js +0 -728
- package/dist/core/database/sqlite-adapter.js.map +0 -7
- package/dist/core/digest/enhanced-hybrid-digest.js.map +0 -7
- package/dist/core/digest/frame-digest-integration.js.map +0 -7
- package/dist/core/digest/hybrid-digest-generator.js.map +0 -7
- package/dist/core/digest/index.js.map +0 -7
- package/dist/core/digest/types.js.map +0 -7
- package/dist/core/errors/index.js +0 -512
- package/dist/core/errors/index.js.map +0 -7
- package/dist/core/errors/recovery.js.map +0 -7
- package/dist/core/execution/parallel-executor.js.map +0 -7
- package/dist/core/frame/workflow-templates.js.map +0 -7
- package/dist/core/merge/conflict-detector.js.map +0 -7
- package/dist/core/merge/index.js.map +0 -7
- package/dist/core/merge/resolution-engine.js.map +0 -7
- package/dist/core/merge/stack-diff.js.map +0 -7
- package/dist/core/models/fallback-monitor.js.map +0 -7
- package/dist/core/models/model-router.js.map +0 -7
- package/dist/core/monitoring/error-handler.js.map +0 -7
- package/dist/core/monitoring/logger.js +0 -150
- package/dist/core/monitoring/logger.js.map +0 -7
- package/dist/core/monitoring/metrics.js.map +0 -7
- package/dist/core/monitoring/progress-tracker.js.map +0 -7
- package/dist/core/monitoring/session-monitor.js.map +0 -7
- package/dist/core/performance/context-cache.js.map +0 -7
- package/dist/core/performance/index.js.map +0 -7
- package/dist/core/performance/lazy-context-loader.js.map +0 -7
- package/dist/core/performance/monitor.js.map +0 -7
- package/dist/core/performance/optimized-frame-context.js.map +0 -7
- package/dist/core/performance/performance-benchmark.js.map +0 -7
- package/dist/core/performance/performance-profiler.js.map +0 -7
- package/dist/core/performance/streaming-jsonl-parser.js.map +0 -7
- package/dist/core/persistence/postgres-adapter.js.map +0 -7
- package/dist/core/projects/project-isolation.js.map +0 -7
- package/dist/core/projects/project-manager.js.map +0 -7
- package/dist/core/query/query-parser.js.map +0 -7
- package/dist/core/query/query-templates.js.map +0 -7
- package/dist/core/retrieval/context-retriever.js.map +0 -7
- package/dist/core/retrieval/graph-retrieval.js +0 -662
- package/dist/core/retrieval/graph-retrieval.js.map +0 -7
- package/dist/core/retrieval/hierarchical-retrieval.js +0 -656
- package/dist/core/retrieval/hierarchical-retrieval.js.map +0 -7
- package/dist/core/retrieval/index.js.map +0 -7
- package/dist/core/retrieval/llm-context-retrieval.js.map +0 -7
- package/dist/core/retrieval/llm-provider.js.map +0 -7
- package/dist/core/retrieval/retrieval-audit.js.map +0 -7
- package/dist/core/retrieval/retrieval-benchmarks.js +0 -521
- package/dist/core/retrieval/retrieval-benchmarks.js.map +0 -7
- package/dist/core/retrieval/summary-generator.js.map +0 -7
- package/dist/core/retrieval/types.js.map +0 -7
- package/dist/core/session/clear-survival.js.map +0 -7
- package/dist/core/session/enhanced-handoff.js.map +0 -7
- package/dist/core/session/handoff-generator.js.map +0 -7
- package/dist/core/session/index.js.map +0 -7
- package/dist/core/session/session-manager.js.map +0 -7
- package/dist/core/skills/index.js.map +0 -7
- package/dist/core/skills/skill-storage.js.map +0 -7
- package/dist/core/skills/types.js.map +0 -7
- package/dist/core/storage/chromadb-adapter.js +0 -354
- package/dist/core/storage/chromadb-adapter.js.map +0 -7
- package/dist/core/storage/infinite-storage.js.map +0 -7
- package/dist/core/storage/railway-optimized-storage.js +0 -591
- package/dist/core/storage/railway-optimized-storage.js.map +0 -7
- package/dist/core/storage/remote-storage.js.map +0 -7
- package/dist/core/storage/two-tier-storage.js.map +0 -7
- package/dist/core/trace/cli-trace-wrapper.js.map +0 -7
- package/dist/core/trace/db-trace-wrapper.js.map +0 -7
- package/dist/core/trace/debug-trace.js.map +0 -7
- package/dist/core/trace/index.js.map +0 -7
- package/dist/core/trace/linear-api-wrapper.js.map +0 -7
- package/dist/core/trace/trace-demo.js +0 -154
- package/dist/core/trace/trace-demo.js.map +0 -7
- package/dist/core/trace/trace-detector.demo.js +0 -142
- package/dist/core/trace/trace-detector.demo.js.map +0 -7
- package/dist/core/trace/trace-detector.js.map +0 -7
- package/dist/core/trace/trace-store.js.map +0 -7
- package/dist/core/trace/types.js.map +0 -7
- package/dist/core/utils/async-mutex.js.map +0 -7
- package/dist/core/utils/compression.js.map +0 -7
- package/dist/core/utils/update-checker.js.map +0 -7
- package/dist/core/worktree/worktree-manager.js.map +0 -7
- package/dist/daemon/daemon-config.js.map +0 -7
- package/dist/daemon/services/context-service.js.map +0 -7
- package/dist/daemon/services/linear-service.js.map +0 -7
- package/dist/daemon/session-daemon.js.map +0 -7
- package/dist/daemon/unified-daemon.js.map +0 -7
- package/dist/features/analytics/api/analytics-api.js.map +0 -7
- package/dist/features/analytics/core/analytics-service.js.map +0 -7
- package/dist/features/analytics/index.js.map +0 -7
- package/dist/features/analytics/queries/metrics-queries.js.map +0 -7
- package/dist/features/browser/browser-mcp.js.map +0 -7
- package/dist/features/sweep/index.js.map +0 -7
- package/dist/features/sweep/prediction-client.js.map +0 -7
- package/dist/features/sweep/prompt-builder.js.map +0 -7
- package/dist/features/sweep/pty-wrapper.js.map +0 -7
- package/dist/features/sweep/state-watcher.js.map +0 -7
- package/dist/features/sweep/status-bar.js.map +0 -7
- package/dist/features/sweep/sweep-server-manager.js.map +0 -7
- package/dist/features/sweep/tab-interceptor.js.map +0 -7
- package/dist/features/sweep/types.js.map +0 -7
- package/dist/features/tasks/linear-task-manager.js.map +0 -7
- package/dist/features/tasks/task-aware-context.js.map +0 -7
- package/dist/features/tui/simple-monitor.js.map +0 -7
- package/dist/features/tui/swarm-monitor.js.map +0 -7
- package/dist/features/web/client/stores/task-store.js.map +0 -7
- package/dist/features/web/server/index.js.map +0 -7
- package/dist/hooks/auto-background.js.map +0 -7
- package/dist/hooks/claude-code-whatsapp-hook.js.map +0 -7
- package/dist/hooks/config.js.map +0 -7
- package/dist/hooks/daemon.js.map +0 -7
- package/dist/hooks/events.js.map +0 -7
- package/dist/hooks/index.js.map +0 -7
- package/dist/hooks/linear-task-picker.js.map +0 -7
- package/dist/hooks/schemas.js.map +0 -7
- package/dist/hooks/secure-fs.js.map +0 -7
- package/dist/hooks/security-logger.js.map +0 -7
- package/dist/hooks/session-summary.js.map +0 -7
- package/dist/hooks/sms-action-runner.js.map +0 -7
- package/dist/hooks/sms-notify.js.map +0 -7
- package/dist/hooks/sms-watcher.js.map +0 -7
- package/dist/hooks/sms-webhook.js.map +0 -7
- package/dist/hooks/whatsapp-commands.js.map +0 -7
- package/dist/hooks/whatsapp-scheduler.js.map +0 -7
- package/dist/hooks/whatsapp-sync.js.map +0 -7
- package/dist/index.js.map +0 -7
- package/dist/integrations/anthropic/client.js.map +0 -7
- package/dist/integrations/claude-code/agent-bridge.js.map +0 -7
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +0 -7
- package/dist/integrations/claude-code/lifecycle-hooks.js.map +0 -7
- package/dist/integrations/claude-code/post-task-hooks.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client-stub.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client.js.map +0 -7
- package/dist/integrations/claude-code/task-coordinator.js.map +0 -7
- package/dist/integrations/linear/auth.js.map +0 -7
- package/dist/integrations/linear/auto-sync.js.map +0 -7
- package/dist/integrations/linear/client.js +0 -630
- package/dist/integrations/linear/client.js.map +0 -7
- package/dist/integrations/linear/config.js.map +0 -7
- package/dist/integrations/linear/migration.js.map +0 -7
- package/dist/integrations/linear/oauth-server.js.map +0 -7
- package/dist/integrations/linear/rest-client.js.map +0 -7
- package/dist/integrations/linear/sync-manager.js.map +0 -7
- package/dist/integrations/linear/sync-service.js.map +0 -7
- package/dist/integrations/linear/sync.js.map +0 -7
- package/dist/integrations/linear/unified-sync.js.map +0 -7
- package/dist/integrations/linear/webhook-handler.js.map +0 -7
- package/dist/integrations/linear/webhook-server.js.map +0 -7
- package/dist/integrations/linear/webhook.js.map +0 -7
- package/dist/integrations/mcp/handlers/code-execution-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/context-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/discovery-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/index.js.map +0 -7
- package/dist/integrations/mcp/handlers/linear-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/skill-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/task-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/trace-handlers.js.map +0 -7
- package/dist/integrations/mcp/index.js.map +0 -7
- package/dist/integrations/mcp/middleware/tool-scoring.js.map +0 -7
- package/dist/integrations/mcp/refactored-server.js.map +0 -7
- package/dist/integrations/mcp/remote-server.js +0 -691
- package/dist/integrations/mcp/remote-server.js.map +0 -7
- package/dist/integrations/mcp/schemas.js.map +0 -7
- package/dist/integrations/mcp/server.js +0 -1960
- package/dist/integrations/mcp/server.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions-code.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions.js.map +0 -7
- package/dist/integrations/mcp/trace-test.js +0 -48
- package/dist/integrations/mcp/trace-test.js.map +0 -7
- package/dist/integrations/pg-aiguide/embedding-provider.js +0 -189
- package/dist/integrations/pg-aiguide/embedding-provider.js.map +0 -7
- package/dist/integrations/pg-aiguide/semantic-search.js +0 -187
- package/dist/integrations/pg-aiguide/semantic-search.js.map +0 -7
- package/dist/integrations/pg-aiguide/timescale-analytics.js +0 -224
- package/dist/integrations/pg-aiguide/timescale-analytics.js.map +0 -7
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +0 -7
- package/dist/integrations/ralph/context/context-budget-manager.js.map +0 -7
- package/dist/integrations/ralph/context/stackmemory-context-loader.js.map +0 -7
- package/dist/integrations/ralph/coordination/enhanced-coordination.js.map +0 -7
- package/dist/integrations/ralph/index.js.map +0 -7
- package/dist/integrations/ralph/learning/pattern-learner.js.map +0 -7
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-registry.js.map +0 -7
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +0 -7
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js.map +0 -7
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js.map +0 -7
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js.map +0 -7
- package/dist/integrations/ralph/performance/performance-optimizer.js.map +0 -7
- package/dist/integrations/ralph/ralph-integration-demo.js +0 -182
- package/dist/integrations/ralph/ralph-integration-demo.js.map +0 -7
- package/dist/integrations/ralph/recovery/crash-recovery.js.map +0 -7
- package/dist/integrations/ralph/state/state-reconciler.js.map +0 -7
- package/dist/integrations/ralph/swarm/git-workflow-manager.js.map +0 -7
- package/dist/integrations/ralph/swarm/swarm-coordinator.js.map +0 -7
- package/dist/integrations/ralph/visualization/ralph-debugger.js.map +0 -7
- package/dist/mcp/stackmemory-mcp-server.js.map +0 -7
- package/dist/middleware/exponential-rate-limiter.js.map +0 -7
- package/dist/models/user.model.js.map +0 -7
- package/dist/servers/production/auth-middleware.js.map +0 -7
- package/dist/servers/railway/config.js +0 -55
- package/dist/servers/railway/config.js.map +0 -7
- package/dist/servers/railway/index-enhanced.js +0 -160
- package/dist/servers/railway/index-enhanced.js.map +0 -7
- package/dist/servers/railway/index.js +0 -1349
- package/dist/servers/railway/index.js.map +0 -7
- package/dist/servers/railway/simple.js +0 -64
- package/dist/servers/railway/simple.js.map +0 -7
- package/dist/servers/railway/storage-test.js +0 -459
- package/dist/servers/railway/storage-test.js.map +0 -7
- package/dist/services/config-service.js.map +0 -7
- package/dist/services/context-service.js.map +0 -7
- package/dist/skills/api-discovery.js.map +0 -7
- package/dist/skills/api-skill.js.map +0 -7
- package/dist/skills/claude-skills.js.map +0 -7
- package/dist/skills/dashboard-launcher.js.map +0 -7
- package/dist/skills/recursive-agent-orchestrator.js.map +0 -7
- package/dist/skills/repo-ingestion-skill.js +0 -609
- package/dist/skills/repo-ingestion-skill.js.map +0 -7
- package/dist/skills/security-secrets-scanner.js +0 -284
- package/dist/skills/security-secrets-scanner.js.map +0 -7
- package/dist/skills/unified-rlm-orchestrator.js.map +0 -7
- package/dist/utils/env.js.map +0 -7
- package/dist/utils/formatting.js.map +0 -7
- package/dist/utils/process-cleanup.js.map +0 -7
- package/dist/validation/schemas.js +0 -222
- package/dist/validation/schemas.js.map +0 -7
- /package/dist/{agents → src/agents}/core/agent-task-manager.js +0 -0
- /package/dist/{agents → src/agents}/verifiers/base-verifier.js +0 -0
- /package/dist/{agents → src/agents}/verifiers/formatter-verifier.js +0 -0
- /package/dist/{agents → src/agents}/verifiers/llm-judge.js +0 -0
- /package/dist/{cli → src/cli}/auto-detect.js +0 -0
- /package/dist/{cli → src/cli}/claude-sm-danger.js +0 -0
- /package/dist/{cli → src/cli}/codex-sm-danger.js +0 -0
- /package/dist/{cli → src/cli}/codex-sm.js +0 -0
- /package/dist/{cli → src/cli}/commands/api.js +0 -0
- /package/dist/{cli → src/cli}/commands/auto-background.js +0 -0
- /package/dist/{cli → src/cli}/commands/cleanup-processes.js +0 -0
- /package/dist/{cli → src/cli}/commands/clear.js +0 -0
- /package/dist/{cli → src/cli}/commands/config.js +0 -0
- /package/dist/{cli → src/cli}/commands/context-rehydrate.js +0 -0
- /package/dist/{cli → src/cli}/commands/context.js +0 -0
- /package/dist/{cli → src/cli}/commands/daemon.js +0 -0
- /package/dist/{cli → src/cli}/commands/dashboard.js +0 -0
- /package/dist/{cli → src/cli}/commands/db.js +0 -0
- /package/dist/{cli → src/cli}/commands/decision.js +0 -0
- /package/dist/{cli → src/cli}/commands/discovery.js +0 -0
- /package/dist/{cli → src/cli}/commands/handoff.js +0 -0
- /package/dist/{cli → src/cli}/commands/hooks.js +0 -0
- /package/dist/{cli → src/cli}/commands/linear.js +0 -0
- /package/dist/{cli → src/cli}/commands/log.js +0 -0
- /package/dist/{cli → src/cli}/commands/login.js +0 -0
- /package/dist/{cli → src/cli}/commands/migrate.js +0 -0
- /package/dist/{cli → src/cli}/commands/model.js +0 -0
- /package/dist/{cli → src/cli}/commands/onboard.js +0 -0
- /package/dist/{cli → src/cli}/commands/projects.js +0 -0
- /package/dist/{cli → src/cli}/commands/ralph.js +0 -0
- /package/dist/{cli → src/cli}/commands/retrieval.js +0 -0
- /package/dist/{cli → src/cli}/commands/service.js +0 -0
- /package/dist/{cli → src/cli}/commands/session.js +0 -0
- /package/dist/{cli → src/cli}/commands/settings.js +0 -0
- /package/dist/{cli → src/cli}/commands/setup.js +0 -0
- /package/dist/{cli → src/cli}/commands/shell.js +0 -0
- /package/dist/{cli → src/cli}/commands/signup.js +0 -0
- /package/dist/{cli → src/cli}/commands/skills.js +0 -0
- /package/dist/{cli → src/cli}/commands/sms-notify.js +0 -0
- /package/dist/{cli → src/cli}/commands/storage-tier.js +0 -0
- /package/dist/{cli → src/cli}/commands/sweep.js +0 -0
- /package/dist/{cli → src/cli}/commands/tasks.js +0 -0
- /package/dist/{cli → src/cli}/commands/worktree.js +0 -0
- /package/dist/{cli → src/cli}/opencode-sm.js +0 -0
- /package/dist/{cli → src/cli}/utils/viewer.js +0 -0
- /package/dist/{core → src/core}/config/config-manager.js +0 -0
- /package/dist/{core → src/core}/config/feature-flags.js +0 -0
- /package/dist/{core → src/core}/config/storage-config.js +0 -0
- /package/dist/{core → src/core}/config/types.js +0 -0
- /package/dist/{core → src/core}/context/auto-context.js +0 -0
- /package/dist/{core → src/core}/context/dual-stack-manager.js +0 -0
- /package/dist/{core → src/core}/context/enhanced-rehydration.js +0 -0
- /package/dist/{core → src/core}/context/frame-database.js +0 -0
- /package/dist/{core → src/core}/context/frame-digest.js +0 -0
- /package/dist/{core → src/core}/context/frame-handoff-manager.js +0 -0
- /package/dist/{core → src/core}/context/frame-lifecycle-hooks.js +0 -0
- /package/dist/{core → src/core}/context/frame-recovery.js +0 -0
- /package/dist/{core → src/core}/context/frame-stack.js +0 -0
- /package/dist/{core → src/core}/context/frame-types.js +0 -0
- /package/dist/{core → src/core}/context/frame-types.js.map +0 -0
- /package/dist/{core → src/core}/context/index.js +0 -0
- /package/dist/{core → src/core}/context/permission-manager.js +0 -0
- /package/dist/{core → src/core}/context/recursive-context-manager.js +0 -0
- /package/dist/{core → src/core}/context/refactored-frame-manager.js +0 -0
- /package/dist/{core → src/core}/context/shared-context-layer.js +0 -0
- /package/dist/{core → src/core}/context/stack-merge-resolver.js +0 -0
- /package/dist/{core → src/core}/context/validation.js +0 -0
- /package/dist/{core → src/core}/database/batch-operations.js +0 -0
- /package/dist/{core → src/core}/database/connection-pool.js +0 -0
- /package/dist/{core → src/core}/database/database-adapter.js +0 -0
- /package/dist/{core → src/core}/database/migration-manager.js +0 -0
- /package/dist/{core → src/core}/database/query-cache.js +0 -0
- /package/dist/{core → src/core}/database/query-router.js +0 -0
- /package/dist/{core → src/core}/digest/enhanced-hybrid-digest.js +0 -0
- /package/dist/{core → src/core}/digest/frame-digest-integration.js +0 -0
- /package/dist/{core → src/core}/digest/hybrid-digest-generator.js +0 -0
- /package/dist/{core → src/core}/digest/index.js +0 -0
- /package/dist/{core → src/core}/digest/types.js +0 -0
- /package/dist/{core → src/core}/errors/recovery.js +0 -0
- /package/dist/{core → src/core}/execution/parallel-executor.js +0 -0
- /package/dist/{core/merge → src/core/extensions}/types.js +0 -0
- /package/dist/{core/merge → src/core/extensions}/types.js.map +0 -0
- /package/dist/{core → src/core}/frame/workflow-templates.js +0 -0
- /package/dist/{core → src/core}/merge/conflict-detector.js +0 -0
- /package/dist/{core → src/core}/merge/index.js +0 -0
- /package/dist/{core → src/core}/merge/resolution-engine.js +0 -0
- /package/dist/{core → src/core}/merge/stack-diff.js +0 -0
- /package/dist/{core → src/core/merge}/types.js +0 -0
- /package/dist/{core → src/core/merge}/types.js.map +0 -0
- /package/dist/{core → src/core}/models/fallback-monitor.js +0 -0
- /package/dist/{core → src/core}/models/model-router.js +0 -0
- /package/dist/{core → src/core}/monitoring/error-handler.js +0 -0
- /package/dist/{core → src/core}/monitoring/metrics.js +0 -0
- /package/dist/{core → src/core}/monitoring/progress-tracker.js +0 -0
- /package/dist/{core → src/core}/monitoring/session-monitor.js +0 -0
- /package/dist/{core → src/core}/performance/context-cache.js +0 -0
- /package/dist/{core → src/core}/performance/index.js +0 -0
- /package/dist/{core → src/core}/performance/lazy-context-loader.js +0 -0
- /package/dist/{core → src/core}/performance/monitor.js +0 -0
- /package/dist/{core → src/core}/performance/optimized-frame-context.js +0 -0
- /package/dist/{core → src/core}/performance/performance-benchmark.js +0 -0
- /package/dist/{core → src/core}/performance/performance-profiler.js +0 -0
- /package/dist/{core → src/core}/performance/streaming-jsonl-parser.js +0 -0
- /package/dist/{core → src/core}/persistence/postgres-adapter.js +0 -0
- /package/dist/{core → src/core}/projects/project-isolation.js +0 -0
- /package/dist/{core → src/core}/projects/project-manager.js +0 -0
- /package/dist/{core → src/core}/query/query-parser.js +0 -0
- /package/dist/{core → src/core}/query/query-templates.js +0 -0
- /package/dist/{core → src/core}/retrieval/context-retriever.js +0 -0
- /package/dist/{core → src/core}/retrieval/index.js +0 -0
- /package/dist/{core → src/core}/retrieval/llm-context-retrieval.js +0 -0
- /package/dist/{core → src/core}/retrieval/llm-provider.js +0 -0
- /package/dist/{core → src/core}/retrieval/retrieval-audit.js +0 -0
- /package/dist/{core → src/core}/retrieval/summary-generator.js +0 -0
- /package/dist/{core → src/core}/retrieval/types.js +0 -0
- /package/dist/{core → src/core}/session/clear-survival.js +0 -0
- /package/dist/{core → src/core}/session/enhanced-handoff.js +0 -0
- /package/dist/{core → src/core}/session/handoff-generator.js +0 -0
- /package/dist/{core → src/core}/session/index.js +0 -0
- /package/dist/{core → src/core}/session/session-manager.js +0 -0
- /package/dist/{core → src/core}/skills/index.js +0 -0
- /package/dist/{core → src/core}/skills/skill-storage.js +0 -0
- /package/dist/{core → src/core}/skills/types.js +0 -0
- /package/dist/{core → src/core}/storage/infinite-storage.js +0 -0
- /package/dist/{core → src/core}/storage/remote-storage.js +0 -0
- /package/dist/{core → src/core}/storage/two-tier-storage.js +0 -0
- /package/dist/{core → src/core}/trace/cli-trace-wrapper.js +0 -0
- /package/dist/{core → src/core}/trace/db-trace-wrapper.js +0 -0
- /package/dist/{core → src/core}/trace/debug-trace.js +0 -0
- /package/dist/{core → src/core}/trace/index.js +0 -0
- /package/dist/{core → src/core}/trace/linear-api-wrapper.js +0 -0
- /package/dist/{core → src/core}/trace/trace-detector.js +0 -0
- /package/dist/{core → src/core}/trace/trace-store.js +0 -0
- /package/dist/{core → src/core}/trace/types.js +0 -0
- /package/dist/{integrations/linear → src/core}/types.js +0 -0
- /package/dist/{integrations/linear → src/core}/types.js.map +0 -0
- /package/dist/{core → src/core}/utils/async-mutex.js +0 -0
- /package/dist/{core → src/core}/utils/compression.js +0 -0
- /package/dist/{core → src/core}/utils/update-checker.js +0 -0
- /package/dist/{core → src/core}/worktree/worktree-manager.js +0 -0
- /package/dist/{daemon → src/daemon}/daemon-config.js +0 -0
- /package/dist/{daemon → src/daemon}/services/context-service.js +0 -0
- /package/dist/{daemon → src/daemon}/services/linear-service.js +0 -0
- /package/dist/{daemon → src/daemon}/session-daemon.js +0 -0
- /package/dist/{daemon → src/daemon}/unified-daemon.js +0 -0
- /package/dist/{features → src/features}/analytics/api/analytics-api.js +0 -0
- /package/dist/{features → src/features}/analytics/core/analytics-service.js +0 -0
- /package/dist/{features → src/features}/analytics/index.js +0 -0
- /package/dist/{features → src/features}/analytics/queries/metrics-queries.js +0 -0
- /package/dist/{features → src/features}/analytics/types/metrics.js +0 -0
- /package/dist/{features → src/features}/analytics/types/metrics.js.map +0 -0
- /package/dist/{features → src/features}/browser/browser-mcp.js +0 -0
- /package/dist/{features → src/features}/sweep/index.js +0 -0
- /package/dist/{features → src/features}/sweep/prediction-client.js +0 -0
- /package/dist/{features → src/features}/sweep/prompt-builder.js +0 -0
- /package/dist/{features → src/features}/sweep/pty-wrapper.js +0 -0
- /package/dist/{features → src/features}/sweep/state-watcher.js +0 -0
- /package/dist/{features → src/features}/sweep/status-bar.js +0 -0
- /package/dist/{features → src/features}/sweep/sweep-server-manager.js +0 -0
- /package/dist/{features → src/features}/sweep/tab-interceptor.js +0 -0
- /package/dist/{features → src/features}/sweep/types.js +0 -0
- /package/dist/{features → src/features}/tasks/linear-task-manager.js +0 -0
- /package/dist/{features → src/features}/tasks/task-aware-context.js +0 -0
- /package/dist/{features → src/features}/tui/simple-monitor.js +0 -0
- /package/dist/{features → src/features}/tui/swarm-monitor.js +0 -0
- /package/dist/{features → src/features}/web/client/stores/task-store.js +0 -0
- /package/dist/{features → src/features}/web/server/index.js +0 -0
- /package/dist/{hooks → src/hooks}/auto-background.js +0 -0
- /package/dist/{hooks → src/hooks}/claude-code-whatsapp-hook.js +0 -0
- /package/dist/{hooks → src/hooks}/config.js +0 -0
- /package/dist/{hooks → src/hooks}/daemon.js +0 -0
- /package/dist/{hooks → src/hooks}/events.js +0 -0
- /package/dist/{hooks → src/hooks}/index.js +0 -0
- /package/dist/{hooks → src/hooks}/linear-task-picker.js +0 -0
- /package/dist/{hooks → src/hooks}/schemas.js +0 -0
- /package/dist/{hooks → src/hooks}/secure-fs.js +0 -0
- /package/dist/{hooks → src/hooks}/security-logger.js +0 -0
- /package/dist/{hooks → src/hooks}/session-summary.js +0 -0
- /package/dist/{hooks → src/hooks}/sms-action-runner.js +0 -0
- /package/dist/{hooks → src/hooks}/sms-notify.js +0 -0
- /package/dist/{hooks → src/hooks}/sms-watcher.js +0 -0
- /package/dist/{hooks → src/hooks}/sms-webhook.js +0 -0
- /package/dist/{hooks → src/hooks}/whatsapp-commands.js +0 -0
- /package/dist/{hooks → src/hooks}/whatsapp-scheduler.js +0 -0
- /package/dist/{hooks → src/hooks}/whatsapp-sync.js +0 -0
- /package/dist/{index.js → src/index.js} +0 -0
- /package/dist/{integrations → src/integrations}/anthropic/client.js +0 -0
- /package/dist/{integrations → src/integrations}/claude-code/agent-bridge.js +0 -0
- /package/dist/{integrations → src/integrations}/claude-code/enhanced-pre-clear-hooks.js +0 -0
- /package/dist/{integrations → src/integrations}/claude-code/lifecycle-hooks.js +0 -0
- /package/dist/{integrations → src/integrations}/claude-code/post-task-hooks.js +0 -0
- /package/dist/{integrations → src/integrations}/claude-code/subagent-client-stub.js +0 -0
- /package/dist/{integrations → src/integrations}/claude-code/subagent-client.js +0 -0
- /package/dist/{integrations → src/integrations}/claude-code/task-coordinator.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/auth.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/auto-sync.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/config.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/migration.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/oauth-server.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/rest-client.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/sync-manager.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/sync-service.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/sync.js +0 -0
- /package/dist/{integrations/ralph → src/integrations/linear}/types.js +0 -0
- /package/dist/{integrations/ralph → src/integrations/linear}/types.js.map +0 -0
- /package/dist/{integrations → src/integrations}/linear/unified-sync.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/webhook-handler.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/webhook-server.js +0 -0
- /package/dist/{integrations → src/integrations}/linear/webhook.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/handlers/code-execution-handlers.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/handlers/context-handlers.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/handlers/discovery-handlers.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/handlers/index.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/handlers/linear-handlers.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/handlers/skill-handlers.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/handlers/task-handlers.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/handlers/trace-handlers.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/index.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/middleware/tool-scoring.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/refactored-server.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/schemas.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/tool-definitions-code.js +0 -0
- /package/dist/{integrations → src/integrations}/mcp/tool-definitions.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/bridge/ralph-stackmemory-bridge.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/context/context-budget-manager.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/context/stackmemory-context-loader.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/coordination/enhanced-coordination.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/index.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/learning/pattern-learner.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/lifecycle/iteration-lifecycle.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/monitoring/swarm-dashboard.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/monitoring/swarm-registry.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/orchestration/multi-loop-orchestrator.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/patterns/compounding-engineering-pattern.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/patterns/extended-coherence-sessions.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/patterns/oracle-worker-pattern.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/performance/performance-optimizer.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/recovery/crash-recovery.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/state/state-reconciler.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/swarm/git-workflow-manager.js +0 -0
- /package/dist/{integrations → src/integrations}/ralph/swarm/swarm-coordinator.js +0 -0
- /package/dist/{types/task.js.map → src/integrations/ralph/types.js.map} +0 -0
- /package/dist/{integrations → src/integrations}/ralph/visualization/ralph-debugger.js +0 -0
- /package/dist/{mcp → src/mcp}/stackmemory-mcp-server.js +0 -0
- /package/dist/{middleware → src/middleware}/exponential-rate-limiter.js +0 -0
- /package/dist/{models → src/models}/user.model.js +0 -0
- /package/dist/{servers → src/servers}/production/auth-middleware.js +0 -0
- /package/dist/{services → src/services}/config-service.js +0 -0
- /package/dist/{services → src/services}/context-service.js +0 -0
- /package/dist/{skills → src/skills}/api-discovery.js +0 -0
- /package/dist/{skills → src/skills}/api-skill.js +0 -0
- /package/dist/{skills → src/skills}/claude-skills.js +0 -0
- /package/dist/{skills → src/skills}/dashboard-launcher.js +0 -0
- /package/dist/{skills → src/skills}/recursive-agent-orchestrator.js +0 -0
- /package/dist/{skills → src/skills}/unified-rlm-orchestrator.js +0 -0
- /package/dist/{types → src/types}/task.js +0 -0
- /package/dist/{utils → src/utils}/env.js +0 -0
- /package/dist/{utils → src/utils}/formatting.js +0 -0
- /package/dist/{utils → src/utils}/process-cleanup.js +0 -0
|
@@ -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(() => Promise.resolve(this.saveProject(project)), {\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 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: unknown) {\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: unknown) {\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: unknown) {\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: unknown) {\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: unknown) {\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: unknown) {\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: unknown) {\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: unknown) {\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: unknown) {\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: unknown) {\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: unknown) {\n logger.warn(`Failed to analyze project: ${projectPath}`, {\n projectPath,\n error: error instanceof Error ? error.message : String(error),\n operation: 'scanAndCategorizeAllProjects',\n });\n }\n }\n } catch (error: unknown) {\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,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,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": ";;;;AAKA,SAA2B,WAAW,mBAAmB;AASlD,MAAM,eAAe;AAAA,EAClB,YAA6B;AAAA,IACnC;AAAA,MACE,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,MACT,SAAS,CAAC,WAAW;AAAA,QACnB,MAAM,EAAE,MAAM,MAAM;AAAA,QACpB,QAAQ,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,EAAE;AAAA,QAC5B,QAAQ;AAAA,UACN,QAAQ;AAAA,UACR,MAAM;AAAA,UACN,SAAS;AAAA,QACX;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,MACT,SAAS,CAAC,WAAW;AAAA,QACnB,SAAS;AAAA,UACP,OAAO,CAAC,SAAS,KAAK;AAAA,UACtB,UAAU,CAAC,MAAM,CAAC,CAAC;AAAA,QACrB;AAAA,QACA,OAAO;AAAA,UACL,MAAM,CAAC,UAAU,KAAK,UAAU,KAAK;AAAA,QACvC;AAAA,QACA,MAAM,EAAE,MAAM,MAAM;AAAA,QACpB,QAAQ;AAAA,UACN,QAAQ;AAAA,UACR,MAAM;AAAA,UACN,SAAS,CAAC,UAAU,SAAS;AAAA,QAC/B;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,MACT,SAAS,CAAC,WAAW;AAAA,QACnB,SAAS;AAAA,UACP,OAAO,CAAC,SAAS;AAAA,UACjB,UAAU,CAAC,MAAM,CAAC,CAAC;AAAA,QACrB;AAAA,QACA,OAAO;AAAA,UACL,MAAM,CAAC,UAAU,OAAO;AAAA,UACxB,QAAQ,CAAC,YAAY,IAAI;AAAA,QAC3B;AAAA,QACA,QAAQ;AAAA,UACN,QAAQ;AAAA,UACR,MAAM;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,MACT,SAAS,CAAC,UAAU;AAClB,cAAM,SAAS,MAAM,CAAC;AACtB,cAAM,SAAS,OAAO,SAAS,GAAG;AAClC,eAAO;AAAA,UACL,SAAS,SAAS,EAAE,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,MAAM,EAAE;AAAA,UAC1D,MAAM,EAAE,MAAM,MAAM;AAAA,UACpB,QAAQ;AAAA,YACN,QAAQ;AAAA,YACR,SAAS,CAAC,UAAU,SAAS;AAAA,YAC7B,MAAM;AAAA,UACR;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,MACT,SAAS,CAAC,UAAU;AAClB,cAAM,UAAkC;AAAA,UACtC,MAAM;AAAA,UACN,QAAQ;AAAA,UACR,OAAO;AAAA,QACT;AACA,eAAO;AAAA,UACL,QAAQ,EAAE,MAAM,gBAAgB;AAAA,UAChC,MAAM,EAAE,MAAM,QAAQ,MAAM,CAAC,CAAC,KAAK,KAAK;AAAA,UACxC,QAAQ;AAAA,YACN,QAAQ;AAAA,YACR,SAAS;AAAA,YACT,MAAM;AAAA,UACR;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,MACT,SAAS,CAAC,WAAW;AAAA,QACnB,SAAS;AAAA,UACP,OAAO,CAAC,eAAe,gBAAgB,QAAQ,SAAS;AAAA,UACxD,UAAU,CAAC,MAAM,CAAC,CAAC;AAAA,QACrB;AAAA,QACA,MAAM,EAAE,MAAM,KAAK;AAAA,QACnB,QAAQ;AAAA,UACN,QAAQ;AAAA,UACR,MAAM;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,MACT,SAAS,CAAC,WAAW;AAAA,QACnB,SAAS;AAAA,UACP,OAAO,CAAC,YAAY,iBAAiB,QAAQ,eAAe;AAAA,UAC5D,UAAU,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI;AAAA,QACpC;AAAA,QACA,OAAO;AAAA,UACL,OAAO,EAAE,KAAK,IAAI;AAAA;AAAA,QACpB;AAAA,QACA,QAAQ;AAAA,UACN,QAAQ;AAAA,UACR,MAAM;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,MACT,SAAS,CAAC,WAAW;AAAA,QACnB,SAAS;AAAA,UACP,OAAO,CAAC,cAAc,WAAW,YAAY;AAAA,UAC7C,UAAU,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI;AAAA,QACpC;AAAA,QACA,OAAO;AAAA,UACL,QAAQ,CAAC,YAAY,IAAI;AAAA,QAC3B;AAAA,QACA,MAAM,EAAE,MAAM,MAAM;AAAA,QACpB,QAAQ;AAAA,UACN,QAAQ;AAAA,UACR,MAAM;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,cAAc,OAAiD;AAC7D,eAAW,YAAY,KAAK,WAAW;AACrC,YAAM,QAAQ,MAAM,MAAM,SAAS,OAAO;AAC1C,UAAI,OAAO;AACT,eAAO,SAAS,QAAQ,KAAK;AAAA,MAC/B;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,kBAAgE;AAC9D,WAAO,KAAK,UAAU,IAAI,CAAC,OAAO;AAAA,MAChC,MAAM,EAAE;AAAA,MACR,aAAa,EAAE;AAAA,IACjB,EAAE;AAAA,EACJ;AAAA;AAAA;AAAA;AAAA,EAKA,YAAY,UAA+B;AACzC,SAAK,UAAU,KAAK,QAAQ;AAAA,EAC9B;AACF;AAMO,MAAM,qBAAqB;AAAA,EACxB,mBAAmB;AAAA,IACzB,MAAM;AAAA,IACN,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM;AAAA,IACN,OAAO;AAAA,IACP,MAAM;AAAA,IACN,MAAM;AAAA,IACN,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,UAAU;AAAA,EACZ;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,OAGJ;AACA,UAAM,YAAuC,CAAC;AAC9C,QAAI,aAAa;AAGjB,UAAM,YAAY,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,IAAI,CAAC;AAChE,QAAI,UAAU,SAAS,GAAG;AACxB,gBAAU,OAAO,EAAE,MAAM,UAAU,CAAC,EAAE,CAAC,EAAE;AACzC,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,MAAM,EAAE;AAAA,IAChE;AAEA,UAAM,aAAa,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,CAAC;AAClE,QAAI,WAAW,SAAS,GAAG;AACzB,YAAM,OAAO,IAAI,KAAK,WAAW,CAAC,EAAE,CAAC,CAAC;AACtC,UAAI,CAAC,MAAM,KAAK,QAAQ,CAAC,GAAG;AAC1B,kBAAU,OAAO,EAAE,GAAG,UAAU,MAAM,OAAO,KAAK;AAAA,MACpD;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,OAAO,EAAE;AAAA,IACjE;AAEA,UAAM,aAAa,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,CAAC;AAClE,QAAI,WAAW,SAAS,GAAG;AACzB,YAAM,OAAO,IAAI,KAAK,WAAW,CAAC,EAAE,CAAC,CAAC;AACtC,UAAI,CAAC,MAAM,KAAK,QAAQ,CAAC,GAAG;AAC1B,kBAAU,OAAO,EAAE,GAAG,UAAU,MAAM,OAAO,KAAK;AAAA,MACpD;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,OAAO,EAAE;AAAA,IACjE;AAGA,UAAM,eAAe,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,CAAC;AACpE,QAAI,aAAa,SAAS,GAAG;AAC3B,gBAAU,SAAS;AAAA,QACjB,OAAO,aAAa,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;AAAA,MACrC;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,OAAO,EAAE;AAAA,IACjE;AAEA,UAAM,YAAY,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,IAAI,CAAC;AAChE,QAAI,UAAU,SAAS,GAAG;AACxB,gBAAU,SAAS;AAAA,QACjB,GAAG,UAAU;AAAA,QACb,MAAM,UAAU,CAAC,EAAE,CAAC;AAAA,MACtB;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,MAAM,EAAE;AAAA,IAChE;AAGA,UAAM,eAAe,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,CAAC;AACpE,QAAI,aAAa,SAAS,GAAG;AAC3B,gBAAU,UAAU;AAAA,QAClB,OAAO,aAAa,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;AAAA,MACrC;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,OAAO,EAAE;AAAA,IACjE;AAEA,UAAM,cAAc,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,IAAI,CAAC;AAClE,QAAI,YAAY,SAAS,GAAG;AAC1B,gBAAU,UAAU;AAAA,QAClB,GAAG,UAAU;AAAA,QACb,OAAO,YAAY,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;AAAA,MACpC;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,MAAM,EAAE;AAAA,IAChE;AAGA,UAAM,YAAY,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,IAAI,CAAC;AAChE,QAAI,UAAU,SAAS,GAAG;AACxB,gBAAU,SAAS;AAAA,QACjB,MAAM,UAAU,CAAC,EAAE,CAAC;AAAA,MACtB;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,MAAM,EAAE;AAAA,IAChE;AAEA,UAAM,aAAa,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,CAAC;AAClE,QAAI,WAAW,SAAS,GAAG;AACzB,gBAAU,SAAS;AAAA,QACjB,GAAG,UAAU;AAAA,QACb,OAAO,SAAS,WAAW,CAAC,EAAE,CAAC,CAAC;AAAA,MAClC;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,OAAO,EAAE;AAAA,IACjE;AAEA,UAAM,cAAc,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,MAAM,CAAC;AACpE,QAAI,YAAY,SAAS,GAAG;AAC1B,gBAAU,SAAS;AAAA,QACjB,GAAG,UAAU;AAAA,QACb,QAAQ,YAAY,CAAC,EAAE,CAAC;AAAA,MAC1B;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,QAAQ,EAAE;AAAA,IAClE;AAEA,UAAM,aAAa,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,CAAC;AAClE,QAAI,WAAW,SAAS,GAAG;AACzB,gBAAU,SAAS;AAAA,QACjB,GAAG,UAAU;AAAA,QACb,SAAS,WAAW,CAAC,EAAE,CAAC;AAAA,MAC1B;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,OAAO,EAAE;AAAA,IACjE;AAGA,UAAM,cAAc,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,MAAM,CAAC;AACpE,QAAI,YAAY,SAAS,GAAG;AAC1B,YAAM,YAAyC;AAAA,QAC7C,MAAM,YAAY;AAAA,QAClB,QAAQ,YAAY;AAAA,QACpB,SAAS,YAAY;AAAA,MACvB;AACA,gBAAU,QAAQ;AAAA,QAChB,QAAQ,YAAY,IAAI,CAAC,MAAM,UAAU,EAAE,CAAC,CAAC,CAAC;AAAA,MAChD;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,QAAQ,EAAE;AAAA,IAClE;AAEA,UAAM,gBAAgB,CAAC,GAAG,MAAM,SAAS,KAAK,iBAAiB,QAAQ,CAAC;AACxE,QAAI,cAAc,SAAS,GAAG;AAC5B,YAAM,cAA8D;AAAA,QAClE,UAAU,EAAE,KAAK,IAAI;AAAA,QACrB,MAAM,EAAE,KAAK,KAAK,KAAK,IAAI;AAAA,QAC3B,QAAQ,EAAE,KAAK,KAAK,KAAK,IAAI;AAAA,QAC7B,KAAK,EAAE,KAAK,IAAI;AAAA,MAClB;AACA,gBAAU,QAAQ;AAAA,QAChB,GAAG,UAAU;AAAA,QACb,OAAO,YAAY,cAAc,CAAC,EAAE,CAAC,CAAC;AAAA,MACxC;AACA,mBAAa,WAAW,QAAQ,KAAK,iBAAiB,UAAU,EAAE;AAAA,IACpE;AAGA,iBAAa,WAAW,QAAQ,QAAQ,GAAG,EAAE,KAAK;AAElD,WAAO,EAAE,YAAY,UAAU;AAAA,EACjC;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/core/retrieval/context-retriever.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * LLM-driven Context Retrieval System\n * Intelligently retrieves relevant context using ParadeDB search capabilities\n */\n\nimport {\n DatabaseAdapter,\n SearchOptions,\n} from '../database/database-adapter.js';\nimport { Frame } from '../context/index.js';\nimport { logger } from '../monitoring/logger.js';\n\nexport interface ContextQuery {\n text: string;\n type?: 'semantic' | 'keyword' | 'hybrid';\n maxResults?: number;\n timeRange?: {\n start?: Date;\n end?: Date;\n };\n frameTypes?: string[];\n scoreThreshold?: number;\n includeDigests?: boolean;\n}\n\nexport interface RetrievedContext {\n frame: Frame;\n score: number;\n relevanceReason: string;\n retrievalMethod: 'bm25' | 'vector' | 'hybrid';\n matchedFields: string[];\n}\n\nexport interface ContextRetrievalResult {\n contexts: RetrievedContext[];\n totalMatches: number;\n retrievalTimeMs: number;\n strategy: string;\n queryAnalysis: {\n intent: string;\n concepts: string[];\n complexity: 'simple' | 'moderate' | 'complex';\n };\n}\n\nexport interface RetrievalStrategy {\n name: string;\n searchType: 'text' | 'vector' | 'hybrid';\n weights?: { text: number; vector: number };\n boost?: Record<string, number>;\n fallbackStrategy?: string;\n}\n\nexport class ContextRetriever {\n private readonly adapter: DatabaseAdapter;\n private readonly strategies: Map<string, RetrievalStrategy> = new Map();\n private queryCache = new Map<string, ContextRetrievalResult>();\n private cacheMaxSize = 100;\n private cacheExpiryMs = 300000; // 5 minutes\n\n constructor(adapter: DatabaseAdapter) {\n this.adapter = adapter;\n this.initializeStrategies();\n }\n\n private initializeStrategies(): void {\n // Keyword-based search for specific terms\n this.strategies.set('keyword', {\n name: 'Keyword Search',\n searchType: 'text',\n boost: {\n name: 2.0,\n digest_text: 1.5,\n inputs: 1.2,\n outputs: 1.2,\n },\n fallbackStrategy: 'semantic',\n });\n\n // Semantic search using vector embeddings\n this.strategies.set('semantic', {\n name: 'Semantic Search',\n searchType: 'vector',\n fallbackStrategy: 'hybrid',\n });\n\n // Hybrid approach combining text and vector search\n this.strategies.set('hybrid', {\n name: 'Hybrid Search',\n searchType: 'hybrid',\n weights: { text: 0.6, vector: 0.4 },\n boost: {\n name: 2.0,\n digest_text: 1.5,\n },\n fallbackStrategy: 'keyword',\n });\n\n // Recent activity search\n this.strategies.set('recent', {\n name: 'Recent Activity',\n searchType: 'text',\n boost: {\n created_at: 3.0,\n closed_at: 2.0,\n },\n fallbackStrategy: 'hybrid',\n });\n\n // Error and debugging context\n this.strategies.set('debug', {\n name: 'Debug Context',\n searchType: 'hybrid',\n weights: { text: 0.8, vector: 0.2 },\n boost: {\n type: 2.5, // Boost error frames\n digest_text: 2.0,\n outputs: 1.8,\n },\n fallbackStrategy: 'keyword',\n });\n }\n\n async retrieveContext(query: ContextQuery): Promise<ContextRetrievalResult> {\n const startTime = Date.now();\n\n // Handle empty query gracefully\n if (!query.text || query.text.trim().length === 0) {\n logger.debug('Empty query provided, returning empty result');\n return {\n contexts: [],\n totalMatches: 0,\n retrievalTimeMs: Date.now() - startTime,\n strategy: 'empty_query',\n queryAnalysis: {\n intent: 'general',\n concepts: [],\n complexity: 'simple',\n },\n };\n }\n\n const cacheKey = this.generateCacheKey(query);\n\n // Check cache first\n const cached = this.getCachedResult(cacheKey);\n if (cached) {\n logger.debug('Context retrieval cache hit');\n return cached;\n }\n\n try {\n logger.info('Starting LLM-driven context retrieval', {\n query: query.text,\n });\n\n // Analyze query to determine best strategy\n const queryAnalysis = await this.analyzeQuery(query);\n const strategy = this.selectStrategy(queryAnalysis, query);\n\n logger.debug('Selected retrieval strategy', {\n strategy: strategy.name,\n analysis: queryAnalysis,\n });\n\n // Execute retrieval with selected strategy\n const contexts = await this.executeRetrieval(\n query,\n strategy,\n queryAnalysis\n );\n\n // Post-process and rank results\n const rankedContexts = await this.rankAndFilter(\n contexts,\n query,\n queryAnalysis\n );\n\n const result: ContextRetrievalResult = {\n contexts: rankedContexts,\n totalMatches: contexts.length,\n retrievalTimeMs: Date.now() - startTime,\n strategy: strategy.name,\n queryAnalysis,\n };\n\n // Cache result\n this.cacheResult(cacheKey, result);\n\n logger.info('Context retrieval completed', {\n resultsCount: rankedContexts.length,\n timeMs: result.retrievalTimeMs,\n strategy: strategy.name,\n });\n\n return result;\n } catch (error: unknown) {\n logger.error('Context retrieval failed:', error);\n\n // Return fallback empty result\n return {\n contexts: [],\n totalMatches: 0,\n retrievalTimeMs: Date.now() - startTime,\n strategy: 'fallback',\n queryAnalysis: {\n intent: 'unknown',\n concepts: [],\n complexity: 'simple',\n },\n };\n }\n }\n\n private async analyzeQuery(query: ContextQuery): Promise<{\n intent: string;\n concepts: string[];\n complexity: 'simple' | 'moderate' | 'complex';\n }> {\n const text = query.text.toLowerCase().trim();\n const words = text.split(/\\s+/);\n\n // Determine intent based on keywords\n let intent = 'general';\n if (\n this.containsKeywords(text, [\n 'error',\n 'exception',\n 'fail',\n 'bug',\n 'issue',\n 'problem',\n 'debug',\n ])\n ) {\n intent = 'debug';\n } else if (\n this.containsKeywords(text, ['how', 'what', 'why', 'when', 'where'])\n ) {\n intent = 'explanation';\n } else if (\n this.containsKeywords(text, [\n 'implement',\n 'create',\n 'build',\n 'add',\n 'develop',\n ])\n ) {\n intent = 'implementation';\n } else if (\n this.containsKeywords(text, [\n 'recent',\n 'latest',\n 'last',\n 'current',\n 'happened',\n ])\n ) {\n intent = 'recent_activity';\n }\n\n // Extract concepts (simplified - in production would use NLP)\n const concepts = this.extractConcepts(text);\n\n // Determine complexity\n let complexity: 'simple' | 'moderate' | 'complex' = 'simple';\n if (words.length > 10 || concepts.length > 5) {\n complexity = 'complex';\n } else if (words.length > 5 || concepts.length > 2) {\n complexity = 'moderate';\n }\n\n return { intent, concepts, complexity };\n }\n\n private containsKeywords(text: string, keywords: string[]): boolean {\n return keywords.some((keyword) =>\n text.toLowerCase().includes(keyword.toLowerCase())\n );\n }\n\n private extractConcepts(text: string): string[] {\n // Simplified concept extraction - in production would use NLP/embeddings\n const technicalTerms = [\n 'database',\n 'sql',\n 'query',\n 'index',\n 'migration',\n 'adapter',\n 'frame',\n 'event',\n 'anchor',\n 'digest',\n 'context',\n 'search',\n 'vector',\n 'embedding',\n 'similarity',\n 'score',\n 'rank',\n 'performance',\n 'optimization',\n 'cache',\n 'pool',\n 'connection',\n 'error',\n 'exception',\n 'debug',\n 'trace',\n 'log',\n 'monitor',\n ];\n\n const concepts: string[] = [];\n const words = text.split(/\\W+/).map((w) => w.toLowerCase());\n\n for (const term of technicalTerms) {\n if (words.includes(term)) {\n concepts.push(term);\n }\n }\n\n // Add bigrams for common technical phrases\n const bigrams = this.extractBigrams(words);\n const technicalBigrams = [\n 'database adapter',\n 'query router',\n 'connection pool',\n 'vector search',\n ];\n\n for (const bigram of bigrams) {\n if (technicalBigrams.includes(bigram)) {\n concepts.push(bigram);\n }\n }\n\n return [...new Set(concepts)]; // Remove duplicates\n }\n\n private extractBigrams(words: string[]): string[] {\n const bigrams: string[] = [];\n for (let i = 0; i < words.length - 1; i++) {\n bigrams.push(`${words[i]} ${words[i + 1]}`);\n }\n return bigrams;\n }\n\n private selectStrategy(\n analysis: { intent: string; complexity: string },\n query: ContextQuery\n ): RetrievalStrategy {\n // Override with explicit query type\n if (query.type) {\n return (\n this.strategies.get(\n query.type === 'keyword'\n ? 'keyword'\n : query.type === 'semantic'\n ? 'semantic'\n : 'hybrid'\n ) || this.strategies.get('hybrid')!\n );\n }\n\n // Select based on intent and complexity\n switch (analysis.intent) {\n case 'debug':\n return this.strategies.get('debug')!;\n case 'recent_activity':\n return this.strategies.get('recent')!;\n case 'explanation':\n return analysis.complexity === 'simple'\n ? this.strategies.get('keyword')!\n : this.strategies.get('semantic')!;\n case 'implementation':\n return this.strategies.get('hybrid')!;\n default:\n return analysis.complexity === 'complex'\n ? this.strategies.get('semantic')!\n : this.strategies.get('keyword')!;\n }\n }\n\n private async executeRetrieval(\n query: ContextQuery,\n strategy: RetrievalStrategy,\n analysis: { intent: string; concepts: string[] }\n ): Promise<RetrievedContext[]> {\n const searchOptions: SearchOptions = {\n query: query.text,\n searchType: strategy.searchType,\n limit: query.maxResults || 20,\n scoreThreshold: query.scoreThreshold || 0.1,\n boost: strategy.boost,\n };\n\n // Add field filtering based on query type\n if (query.frameTypes) {\n searchOptions.fields = ['type', 'name', 'digest_text'];\n }\n\n let rawResults: Array<Frame & { score: number }> = [];\n\n try {\n if (strategy.searchType === 'hybrid' && strategy.weights) {\n // Use hybrid search with embeddings (placeholder - would need actual embeddings)\n const embedding = await this.generateEmbedding(query.text);\n rawResults = await this.adapter.searchHybrid(\n query.text,\n embedding,\n strategy.weights\n );\n } else {\n // Use text or vector search\n rawResults = await this.adapter.search(searchOptions);\n }\n } catch (error: unknown) {\n logger.warn(`Strategy ${strategy.name} failed, trying fallback:`, error);\n\n if (strategy.fallbackStrategy) {\n const fallbackStrategy = this.strategies.get(strategy.fallbackStrategy);\n if (fallbackStrategy) {\n return this.executeRetrieval(query, fallbackStrategy, analysis);\n }\n }\n\n // Return empty results instead of throwing to prevent cascading failures\n return [];\n }\n\n // Convert to RetrievedContext objects\n return rawResults.map((result) => ({\n frame: result,\n score: result.score,\n relevanceReason: this.generateRelevanceReason(result, query, analysis),\n retrievalMethod: strategy.searchType as 'bm25' | 'vector' | 'hybrid',\n matchedFields: this.identifyMatchedFields(result, query),\n }));\n }\n\n private async generateEmbedding(text: string): Promise<number[]> {\n // Placeholder - in production would use actual embedding service\n // For now, return a mock embedding\n const hash = this.simpleHash(text);\n return Array.from(\n { length: 384 },\n (_, i) => ((hash + i) % 100) / 100 - 0.5\n );\n }\n\n private simpleHash(str: string): number {\n let hash = 0;\n for (let i = 0; i < str.length; i++) {\n const char = str.charCodeAt(i);\n hash = (hash << 5) - hash + char;\n hash = hash & hash; // Convert to 32-bit integer\n }\n return Math.abs(hash);\n }\n\n private generateRelevanceReason(\n frame: Frame,\n query: ContextQuery,\n analysis: { intent: string; concepts: string[] }\n ): string {\n const reasons: string[] = [];\n\n // Check for direct matches\n if (frame.name.toLowerCase().includes(query.text.toLowerCase())) {\n reasons.push('Frame name matches query');\n }\n\n if (frame.digest_text?.toLowerCase().includes(query.text.toLowerCase())) {\n reasons.push('Content contains query terms');\n }\n\n // Check for concept matches\n for (const concept of analysis.concepts) {\n if (\n frame.digest_text?.toLowerCase().includes(concept.toLowerCase()) ||\n frame.name.toLowerCase().includes(concept.toLowerCase())\n ) {\n reasons.push(`Related to ${concept}`);\n }\n }\n\n // Frame type relevance\n if (analysis.intent === 'debug' && frame.type.includes('error')) {\n reasons.push('Error context for debugging');\n }\n\n return reasons.length > 0\n ? reasons.join('; ')\n : 'General semantic similarity';\n }\n\n private identifyMatchedFields(frame: Frame, query: ContextQuery): string[] {\n const matched: string[] = [];\n const queryLower = query.text.toLowerCase();\n\n if (frame.name.toLowerCase().includes(queryLower)) {\n matched.push('name');\n }\n\n if (frame.digest_text?.toLowerCase().includes(queryLower)) {\n matched.push('digest_text');\n }\n\n if (frame.type.toLowerCase().includes(queryLower)) {\n matched.push('type');\n }\n\n return matched;\n }\n\n private async rankAndFilter(\n contexts: RetrievedContext[],\n query: ContextQuery,\n analysis: { intent: string; complexity: string }\n ): Promise<RetrievedContext[]> {\n // Apply additional filtering\n let filtered = contexts;\n\n // Filter by time range\n if (query.timeRange) {\n filtered = filtered.filter((ctx) => {\n const frameTime = new Date(ctx.frame.created_at);\n const start = query.timeRange?.start;\n const end = query.timeRange?.end;\n\n return (!start || frameTime >= start) && (!end || frameTime <= end);\n });\n }\n\n // Filter by frame types\n if (query.frameTypes) {\n filtered = filtered.filter((ctx) =>\n query.frameTypes!.includes(ctx.frame.type)\n );\n }\n\n // Apply score threshold\n if (query.scoreThreshold) {\n filtered = filtered.filter((ctx) => ctx.score >= query.scoreThreshold!);\n }\n\n // Enhanced ranking based on multiple factors\n const ranked = filtered.map((ctx) => ({\n ...ctx,\n score: this.calculateEnhancedScore(ctx, query, analysis),\n }));\n\n // Sort by enhanced score\n ranked.sort((a, b) => b.score - a.score);\n\n // Limit results\n const maxResults = query.maxResults || 20;\n return ranked.slice(0, maxResults);\n }\n\n private calculateEnhancedScore(\n context: RetrievedContext,\n query: ContextQuery,\n analysis: { intent: string; concepts: string[] }\n ): number {\n let score = context.score;\n\n // Boost recent frames\n const ageHours = (Date.now() - context.frame.created_at) / (1000 * 60 * 60);\n if (ageHours < 24) {\n score *= 1.2; // 20% boost for frames from last 24 hours\n } else if (ageHours < 168) {\n // 1 week\n score *= 1.1; // 10% boost for frames from last week\n }\n\n // Boost based on frame completeness\n if (context.frame.closed_at) {\n score *= 1.1; // Completed frames are more valuable\n }\n\n // Boost based on intent matching\n if (analysis.intent === 'debug' && context.frame.type.includes('error')) {\n score *= 1.5;\n }\n\n // Boost based on matched fields\n if (context.matchedFields.includes('name')) {\n score *= 1.3; // Name matches are highly relevant\n }\n\n if (context.matchedFields.length > 1) {\n score *= 1.1; // Multiple field matches\n }\n\n // Penalize very old frames for recent queries\n if (analysis.intent === 'recent_activity' && ageHours > 168) {\n score *= 0.5;\n }\n\n return score;\n }\n\n private generateCacheKey(query: ContextQuery): string {\n return JSON.stringify({\n text: query.text,\n type: query.type,\n maxResults: query.maxResults,\n frameTypes: query.frameTypes,\n scoreThreshold: query.scoreThreshold,\n });\n }\n\n private getCachedResult(cacheKey: string): ContextRetrievalResult | null {\n const entry = this.queryCache.get(cacheKey);\n if (!entry) return null;\n\n // Check expiry (simplified - would include timestamp in real implementation)\n return entry;\n }\n\n private cacheResult(cacheKey: string, result: ContextRetrievalResult): void {\n // Implement LRU eviction if cache is full\n if (this.queryCache.size >= this.cacheMaxSize) {\n const firstKey = this.queryCache.keys().next().value;\n this.queryCache.delete(firstKey);\n }\n\n this.queryCache.set(cacheKey, result);\n }\n\n // Utility methods for integration\n async findSimilarFrames(\n frameId: string,\n limit = 10\n ): Promise<RetrievedContext[]> {\n const frame = await this.adapter.getFrame(frameId);\n if (!frame) {\n throw new Error(`Frame not found: ${frameId}`);\n }\n\n const query: ContextQuery = {\n text: frame.digest_text || frame.name,\n type: 'semantic',\n maxResults: limit,\n scoreThreshold: 0.3,\n };\n\n const result = await this.retrieveContext(query);\n\n // Filter out the original frame\n return result.contexts.filter((ctx) => ctx.frame.frame_id !== frameId);\n }\n\n async findContextForError(\n errorMessage: string,\n stackTrace?: string\n ): Promise<RetrievedContext[]> {\n const query: ContextQuery = {\n text: `${errorMessage} ${stackTrace || ''}`.trim(),\n type: 'hybrid',\n maxResults: 15,\n frameTypes: ['error', 'debug', 'function'],\n scoreThreshold: 0.2,\n };\n\n const result = await this.retrieveContext(query);\n return result.contexts;\n }\n\n async getRecentContext(\n hours = 24,\n frameTypes?: string[]\n ): Promise<RetrievedContext[]> {\n const query: ContextQuery = {\n text: 'recent activity context',\n type: 'keyword',\n maxResults: 50,\n timeRange: {\n start: new Date(Date.now() - hours * 60 * 60 * 1000),\n },\n frameTypes,\n scoreThreshold: 0.1,\n };\n\n const result = await this.retrieveContext(query);\n return result.contexts;\n }\n\n // Analytics and insights\n getRetrievalStats() {\n return {\n cacheSize: this.queryCache.size,\n strategiesCount: this.strategies.size,\n availableStrategies: Array.from(this.strategies.keys()),\n };\n }\n\n clearCache(): void {\n this.queryCache.clear();\n logger.info('Context retrieval cache cleared');\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
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/core/retrieval/llm-context-retrieval.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * LLM-Driven Context Retrieval System\n * Uses LLM analysis to intelligently select relevant context\n */\n\nimport Database from 'better-sqlite3';\nimport {\n FrameManager,\n Frame,\n Anchor,\n Event,\n} from '../context/index.js';\nimport { QueryParser, StackMemoryQuery } from '../query/query-parser.js';\nimport { CompressedSummaryGenerator } from './summary-generator.js';\nimport {\n CompressedSummary,\n LLMAnalysisRequest,\n LLMAnalysisResponse,\n RetrievedContext,\n FrameRetrievalPlan,\n ContextRecommendation,\n RetrievalConfig,\n DEFAULT_RETRIEVAL_CONFIG,\n RetrievalHints,\n RetrievalMetadata,\n} from './types.js';\nimport { logger } from '../monitoring/logger.js';\nimport { LazyContextLoader } from '../performance/lazy-context-loader.js';\nimport { ContextCache } from '../performance/context-cache.js';\nimport { LLMProvider, createLLMProvider } from './llm-provider.js';\nimport { RetrievalAuditStore } from './retrieval-audit.js';\n\n// Re-export LLMProvider type for external use\nexport type { LLMProvider } from './llm-provider.js';\n\n/**\n * LLM provider interface for context analysis\n * @deprecated Use import from './llm-provider.js' instead\n */\nexport interface LLMProviderInterface {\n analyze(prompt: string, maxTokens: number): Promise<string>;\n}\n\n/**\n * Simple heuristic-based fallback when LLM is unavailable\n */\nclass HeuristicAnalyzer {\n analyze(\n query: string,\n summary: CompressedSummary,\n parsedQuery?: StackMemoryQuery\n ): LLMAnalysisResponse {\n const framesToRetrieve: FrameRetrievalPlan[] = [];\n const recommendations: ContextRecommendation[] = [];\n const matchedPatterns: string[] = [];\n\n // Score frames based on query relevance\n const queryLower = query.toLowerCase();\n const queryWords = queryLower.split(/\\W+/).filter((w) => w.length > 2);\n\n for (const frame of summary.recentSession.frames) {\n let priority = 5; // Base priority\n const reasons: string[] = [];\n\n // Recency boost\n const ageHours = (Date.now() - frame.createdAt) / (1000 * 60 * 60);\n if (ageHours < 1) {\n priority += 3;\n reasons.push('very recent');\n } else if (ageHours < 6) {\n priority += 2;\n reasons.push('recent');\n }\n\n // Score boost\n priority += Math.floor(frame.score * 3);\n\n // Name matching\n const nameLower = frame.name.toLowerCase();\n const nameMatches = queryWords.filter((w) => nameLower.includes(w));\n if (nameMatches.length > 0) {\n priority += nameMatches.length * 2;\n reasons.push(`matches: ${nameMatches.join(', ')}`);\n matchedPatterns.push(`name_match:${nameMatches.join(',')}`);\n }\n\n // Type matching from parsed query\n if (parsedQuery?.frame?.type) {\n const frameType = frame.type.toLowerCase();\n if (parsedQuery.frame.type.some((t) => t.toLowerCase() === frameType)) {\n priority += 2;\n reasons.push('type match');\n }\n }\n\n // Topic matching\n if (parsedQuery?.content?.topic) {\n const topics = parsedQuery.content.topic;\n const topicMatches = topics.filter(\n (t) =>\n nameLower.includes(t.toLowerCase()) ||\n (frame.digestPreview &&\n frame.digestPreview.toLowerCase().includes(t.toLowerCase()))\n );\n if (topicMatches.length > 0) {\n priority += topicMatches.length;\n reasons.push(`topic: ${topicMatches.join(', ')}`);\n }\n }\n\n // Cap priority at 10\n priority = Math.min(priority, 10);\n\n if (priority >= 5) {\n framesToRetrieve.push({\n frameId: frame.frameId,\n priority,\n reason: reasons.length > 0 ? reasons.join('; ') : 'relevant context',\n includeEvents: priority >= 7,\n includeAnchors: true,\n includeDigest: true,\n estimatedTokens: this.estimateFrameTokens(frame),\n });\n }\n }\n\n // Sort by priority\n framesToRetrieve.sort((a, b) => b.priority - a.priority);\n\n // Generate recommendations based on errors\n if (summary.recentSession.errorsEncountered.length > 0) {\n recommendations.push({\n type: 'include',\n target: 'error_context',\n reason: `${summary.recentSession.errorsEncountered.length} errors encountered recently`,\n impact: 'medium',\n });\n }\n\n // Recommend including decisions if query seems decision-related\n if (\n queryLower.includes('decision') ||\n queryLower.includes('why') ||\n queryLower.includes('chose')\n ) {\n recommendations.push({\n type: 'include',\n target: 'decisions',\n reason: 'Query appears to be about past decisions',\n impact: 'high',\n });\n }\n\n // Calculate confidence based on match quality\n const avgPriority =\n framesToRetrieve.length > 0\n ? framesToRetrieve.reduce((sum, f) => sum + f.priority, 0) /\n framesToRetrieve.length\n : 0;\n const confidenceScore = Math.min(avgPriority / 10, 0.95);\n\n // Generate reasoning\n const reasoning = this.generateReasoning(\n query,\n framesToRetrieve,\n summary,\n matchedPatterns\n );\n\n return {\n reasoning,\n framesToRetrieve: framesToRetrieve.slice(0, 10), // Limit to top 10\n confidenceScore,\n recommendations,\n metadata: {\n analysisTimeMs: 0, // Will be set by caller\n summaryTokens: this.estimateSummaryTokens(summary),\n queryComplexity: this.assessQueryComplexity(query, parsedQuery),\n matchedPatterns,\n fallbackUsed: true,\n },\n };\n }\n\n private estimateFrameTokens(frame: {\n eventCount: number;\n anchorCount: number;\n digestPreview?: string;\n }): number {\n let tokens = 50; // Base frame header\n tokens += frame.eventCount * 30; // Estimate per event\n tokens += frame.anchorCount * 40; // Estimate per anchor\n if (frame.digestPreview) tokens += frame.digestPreview.length / 4;\n return Math.floor(tokens);\n }\n\n private estimateSummaryTokens(summary: CompressedSummary): number {\n return Math.floor(JSON.stringify(summary).length / 4);\n }\n\n private assessQueryComplexity(\n query: string,\n parsedQuery?: StackMemoryQuery\n ): 'simple' | 'moderate' | 'complex' {\n const wordCount = query.split(/\\s+/).length;\n const hasTimeFilter = !!parsedQuery?.time;\n const hasContentFilter = !!parsedQuery?.content;\n const hasPeopleFilter = !!parsedQuery?.people;\n const hasFrameFilter = !!parsedQuery?.frame;\n\n const filterCount = [\n hasTimeFilter,\n hasContentFilter,\n hasPeopleFilter,\n hasFrameFilter,\n ].filter(Boolean).length;\n\n if (wordCount <= 5 && filterCount <= 1) return 'simple';\n if (wordCount <= 15 && filterCount <= 2) return 'moderate';\n return 'complex';\n }\n\n private generateReasoning(\n query: string,\n frames: FrameRetrievalPlan[],\n summary: CompressedSummary,\n matchedPatterns: string[]\n ): string {\n const parts: string[] = [];\n\n parts.push(`Query: \"${query}\"`);\n parts.push(\n `Analyzed ${summary.recentSession.frames.length} recent frames.`\n );\n\n if (matchedPatterns.length > 0) {\n parts.push(`Matched patterns: ${matchedPatterns.join(', ')}`);\n }\n\n if (frames.length > 0) {\n parts.push(`Selected ${frames.length} frames for retrieval.`);\n const topFrames = frames.slice(0, 3);\n parts.push(\n `Top frames: ${topFrames.map((f) => `${f.frameId} (priority: ${f.priority})`).join(', ')}`\n );\n } else {\n parts.push('No highly relevant frames found. Using general context.');\n }\n\n return parts.join(' ');\n }\n}\n\n/**\n * Main LLM Context Retrieval class\n */\nexport class LLMContextRetrieval {\n private db: Database.Database;\n private frameManager: FrameManager;\n private summaryGenerator: CompressedSummaryGenerator;\n private queryParser: QueryParser;\n private heuristicAnalyzer: HeuristicAnalyzer;\n private llmProvider?: LLMProvider;\n private config: RetrievalConfig;\n private projectId: string;\n private lazyLoader: LazyContextLoader;\n private contextCache: ContextCache<RetrievedContext>;\n private auditStore: RetrievalAuditStore;\n private enableAudit: boolean;\n\n constructor(\n db: Database.Database,\n frameManager: FrameManager,\n projectId: string,\n config: Partial<RetrievalConfig> = {},\n llmProvider?: LLMProvider\n ) {\n this.db = db;\n this.frameManager = frameManager;\n this.projectId = projectId;\n this.config = { ...DEFAULT_RETRIEVAL_CONFIG, ...config };\n\n // Auto-create LLM provider if not provided and API key is available\n this.llmProvider = llmProvider ?? createLLMProvider();\n if (this.llmProvider) {\n logger.info('LLM provider configured for context retrieval', {\n projectId,\n provider: this.config.llmConfig.provider,\n });\n }\n\n this.summaryGenerator = new CompressedSummaryGenerator(\n db,\n frameManager,\n projectId,\n config\n );\n this.queryParser = new QueryParser();\n this.heuristicAnalyzer = new HeuristicAnalyzer();\n\n // Initialize audit store\n this.auditStore = new RetrievalAuditStore(db, projectId);\n this.enableAudit = true; // Can be made configurable\n\n // Initialize performance optimizations\n this.lazyLoader = new LazyContextLoader(db, projectId);\n this.contextCache = new ContextCache<RetrievedContext>({\n maxSize: 50 * 1024 * 1024, // 50MB for context cache\n maxItems: 100,\n defaultTTL: 600000, // 10 minutes\n });\n\n // Start cache cleanup\n this.contextCache.startCleanup(60000);\n }\n\n /**\n * Get the audit store for external access\n */\n getAuditStore(): RetrievalAuditStore {\n return this.auditStore;\n }\n\n /**\n * Check if LLM provider is available\n */\n hasLLMProvider(): boolean {\n return !!this.llmProvider;\n }\n\n /**\n * Retrieve context based on query using LLM analysis (with caching)\n */\n public async retrieveContext(\n query: string,\n options: {\n tokenBudget?: number;\n hints?: RetrievalHints;\n forceRefresh?: boolean;\n } = {}\n ): Promise<RetrievedContext> {\n const startTime = Date.now();\n const tokenBudget = options.tokenBudget || this.config.defaultTokenBudget;\n\n // Check cache first unless force refresh\n if (!options.forceRefresh) {\n const cacheKey = `${query}:${tokenBudget}:${JSON.stringify(options.hints || {})}`;\n const cached = this.contextCache.get(cacheKey);\n if (cached) {\n logger.debug('Context cache hit', {\n query: query.substring(0, 50),\n cacheStats: this.contextCache.getStats(),\n });\n return cached;\n }\n }\n\n logger.info('Starting context retrieval', {\n projectId: this.projectId,\n query: query.substring(0, 100),\n tokenBudget,\n });\n\n // 1. Parse the query\n const parsedQuery = this.queryParser.parseNaturalLanguage(query);\n\n // 2. Generate compressed summary\n const summary = this.summaryGenerator.generateSummary({\n forceRefresh: options.forceRefresh,\n });\n\n // 3. Perform LLM analysis\n const analysis = await this.analyzeWithLLM({\n currentQuery: query,\n parsedQuery,\n compressedSummary: summary,\n tokenBudget,\n hints: options.hints,\n });\n\n // 4. Retrieve frames based on analysis\n const { frames, anchors, events, tokensUsed } = await this.retrieveFrames(\n analysis,\n tokenBudget\n );\n\n // 5. Assemble context string\n const context = this.assembleContext(frames, anchors, events, analysis);\n\n const metadata: RetrievalMetadata = {\n retrievalTimeMs: Date.now() - startTime,\n cacheHit: false, // Would need cache tracking\n framesScanned: summary.recentSession.frames.length,\n framesIncluded: frames.length,\n compressionRatio: tokensUsed > 0 ? tokenBudget / tokensUsed : 1,\n };\n\n logger.info('Context retrieval complete', {\n projectId: this.projectId,\n framesIncluded: frames.length,\n tokensUsed,\n retrievalTimeMs: metadata.retrievalTimeMs,\n confidence: analysis.confidenceScore,\n });\n\n const result: RetrievedContext = {\n context,\n frames,\n anchors,\n events,\n analysis,\n tokenUsage: {\n budget: tokenBudget,\n used: tokensUsed,\n remaining: tokenBudget - tokensUsed,\n },\n metadata,\n };\n\n // Record audit entry\n if (this.enableAudit) {\n const provider = analysis.metadata.fallbackUsed\n ? 'heuristic'\n : this.llmProvider\n ? 'anthropic'\n : 'heuristic';\n this.auditStore.record(query, analysis, {\n tokensUsed,\n tokenBudget,\n provider,\n });\n }\n\n // Cache the result\n if (!options.forceRefresh) {\n const cacheKey = `${query}:${tokenBudget}:${JSON.stringify(options.hints || {})}`;\n this.contextCache.set(cacheKey, result, {\n ttl: 600000, // 10 minutes\n });\n }\n\n return result;\n }\n\n /**\n * Perform LLM analysis or fall back to heuristics\n */\n private async analyzeWithLLM(\n request: LLMAnalysisRequest\n ): Promise<LLMAnalysisResponse> {\n const startTime = Date.now();\n\n // Try LLM analysis if provider is available\n if (this.llmProvider) {\n try {\n const prompt = this.buildAnalysisPrompt(request);\n const response = await this.llmProvider.analyze(\n prompt,\n this.config.llmConfig.maxTokens\n );\n const analysis = this.parseAnalysisResponse(response, request);\n analysis.metadata.analysisTimeMs = Date.now() - startTime;\n analysis.metadata.fallbackUsed = false;\n\n // Validate confidence threshold\n if (analysis.confidenceScore >= this.config.minConfidenceThreshold) {\n return analysis;\n }\n\n logger.warn('LLM confidence below threshold, using fallback', {\n confidence: analysis.confidenceScore,\n threshold: this.config.minConfidenceThreshold,\n });\n } catch (error: any) {\n logger.error(\n 'LLM analysis failed, using fallback',\n error instanceof Error ? error : new Error(String(error))\n );\n }\n }\n\n // Fall back to heuristic analysis\n if (this.config.enableFallback) {\n const analysis = this.heuristicAnalyzer.analyze(\n request.currentQuery,\n request.compressedSummary,\n request.parsedQuery\n );\n analysis.metadata.analysisTimeMs = Date.now() - startTime;\n return analysis;\n }\n\n // Return empty analysis if no fallback\n return {\n reasoning:\n 'Unable to perform analysis - LLM unavailable and fallback disabled',\n framesToRetrieve: [],\n confidenceScore: 0,\n recommendations: [],\n metadata: {\n analysisTimeMs: Date.now() - startTime,\n summaryTokens: 0,\n queryComplexity: 'simple',\n matchedPatterns: [],\n fallbackUsed: false,\n },\n };\n }\n\n /**\n * Build the prompt for LLM analysis\n */\n private buildAnalysisPrompt(request: LLMAnalysisRequest): string {\n const summary = request.compressedSummary;\n\n return `You are analyzing a code project's memory to retrieve relevant context.\n\n## Current Query\n\"${request.currentQuery}\"\n\n## Token Budget\n${request.tokenBudget} tokens available\n\n## Recent Session Summary\n- Frames: ${summary.recentSession.frames.length}\n- Time range: ${new Date(summary.recentSession.timeRange.start).toISOString()} to ${new Date(summary.recentSession.timeRange.end).toISOString()}\n- Dominant operations: ${summary.recentSession.dominantOperations.map((o) => `${o.operation}(${o.count})`).join(', ')}\n- Files touched: ${summary.recentSession.filesTouched\n .slice(0, 5)\n .map((f) => f.path)\n .join(', ')}\n- Errors: ${summary.recentSession.errorsEncountered.length}\n\n## Available Frames\n${summary.recentSession.frames\n .slice(0, 15)\n .map(\n (f) =>\n `- ${f.frameId}: \"${f.name}\" (${f.type}, score: ${f.score.toFixed(2)}, events: ${f.eventCount})`\n )\n .join('\\n')}\n\n## Key Decisions\n${summary.historicalPatterns.keyDecisions\n .slice(0, 5)\n .map((d) => `- ${d.text.substring(0, 80)}...`)\n .join('\\n')}\n\n## Task\nAnalyze the query and select the most relevant frames to retrieve.\nReturn a JSON object with:\n{\n \"reasoning\": \"Your analysis of why these frames are relevant\",\n \"framesToRetrieve\": [\n {\"frameId\": \"...\", \"priority\": 1-10, \"reason\": \"...\", \"includeEvents\": true/false, \"includeAnchors\": true/false}\n ],\n \"confidenceScore\": 0.0-1.0,\n \"recommendations\": [{\"type\": \"include/exclude/summarize\", \"target\": \"...\", \"reason\": \"...\", \"impact\": \"low/medium/high\"}]\n}\n\n${request.hints ? `\\n## Hints\\n${JSON.stringify(request.hints)}` : ''}\n\nRespond with only the JSON object, no other text.`;\n }\n\n /**\n * Parse LLM response into structured analysis\n */\n private parseAnalysisResponse(\n response: string,\n request: LLMAnalysisRequest\n ): LLMAnalysisResponse {\n try {\n // Extract JSON from response (handle markdown code blocks)\n let jsonStr = response;\n const jsonMatch = response.match(/```(?:json)?\\s*([\\s\\S]*?)```/);\n if (jsonMatch) {\n jsonStr = jsonMatch[1];\n }\n\n const parsed = JSON.parse(jsonStr.trim());\n\n // Validate and normalize the response\n return {\n reasoning: parsed.reasoning || 'No reasoning provided',\n framesToRetrieve: (parsed.framesToRetrieve || []).map((f: any) => ({\n frameId: f.frameId,\n priority: Math.min(10, Math.max(1, f.priority || 5)),\n reason: f.reason || 'Selected by LLM',\n includeEvents: f.includeEvents ?? true,\n includeAnchors: f.includeAnchors ?? true,\n includeDigest: f.includeDigest ?? true,\n estimatedTokens: f.estimatedTokens || 100,\n })),\n confidenceScore: Math.min(\n 1,\n Math.max(0, parsed.confidenceScore || 0.5)\n ),\n recommendations: (parsed.recommendations || []).map((r: any) => ({\n type: r.type || 'include',\n target: r.target || '',\n reason: r.reason || '',\n impact: r.impact || 'medium',\n })),\n metadata: {\n analysisTimeMs: 0,\n summaryTokens: Math.floor(\n JSON.stringify(request.compressedSummary).length / 4\n ),\n queryComplexity: this.assessQueryComplexity(request.currentQuery),\n matchedPatterns: [],\n fallbackUsed: false,\n },\n };\n } catch (error: unknown) {\n logger.warn('Failed to parse LLM response, using fallback', {\n error,\n response,\n });\n return this.heuristicAnalyzer.analyze(\n request.currentQuery,\n request.compressedSummary,\n request.parsedQuery\n );\n }\n }\n\n private assessQueryComplexity(\n query: string\n ): 'simple' | 'moderate' | 'complex' {\n const wordCount = query.split(/\\s+/).length;\n if (wordCount <= 5) return 'simple';\n if (wordCount <= 15) return 'moderate';\n return 'complex';\n }\n\n /**\n * Retrieve frames based on analysis (with lazy loading)\n */\n private async retrieveFrames(\n analysis: LLMAnalysisResponse,\n tokenBudget: number\n ): Promise<{\n frames: Frame[];\n anchors: Anchor[];\n events: Event[];\n tokensUsed: number;\n }> {\n const frames: Frame[] = [];\n const anchors: Anchor[] = [];\n const events: Event[] = [];\n let tokensUsed = 0;\n\n // Preload frames for better performance\n const frameIds = analysis.framesToRetrieve.map((p: any) => p.frameId);\n await this.lazyLoader.preloadContext(frameIds, {\n parallel: true,\n depth: 2, // Load frames, anchors, and events\n });\n\n // Retrieve frames in priority order within budget\n for (const plan of analysis.framesToRetrieve) {\n if (tokensUsed + plan.estimatedTokens > tokenBudget) {\n logger.debug('Token budget exceeded, stopping retrieval', {\n tokensUsed,\n budget: tokenBudget,\n });\n break;\n }\n\n // Use lazy loader for efficient retrieval\n try {\n const frame = await this.lazyLoader.lazyFrame(plan.frameId).get();\n frames.push(frame);\n tokensUsed += 50; // Base frame tokens\n\n // Include anchors if requested\n if (plan.includeAnchors) {\n const frameAnchors = await this.lazyLoader\n .lazyAnchors(plan.frameId)\n .get();\n anchors.push(...frameAnchors);\n tokensUsed += frameAnchors.length * 40;\n }\n\n // Include events if requested\n if (plan.includeEvents) {\n const frameEvents = await this.lazyLoader\n .lazyEvents(plan.frameId, 10)\n .get();\n events.push(...frameEvents);\n tokensUsed += frameEvents.length * 30;\n }\n } catch (error: unknown) {\n logger.warn('Failed to retrieve frame', {\n frameId: plan.frameId,\n error,\n });\n }\n }\n\n return { frames, anchors, events, tokensUsed };\n }\n\n private getFrameAnchors(frameId: string): Anchor[] {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT * FROM anchors WHERE frame_id = ?\n ORDER BY priority DESC, created_at DESC\n `\n )\n .all(frameId) as any[];\n\n return rows.map((row) => ({\n ...row,\n metadata: JSON.parse(row.metadata || '{}'),\n }));\n } catch {\n return [];\n }\n }\n\n /**\n * Assemble final context string\n */\n private assembleContext(\n frames: Frame[],\n anchors: Anchor[],\n events: Event[],\n analysis: LLMAnalysisResponse\n ): string {\n const sections: string[] = [];\n\n // Add retrieval reasoning (auditable)\n sections.push('## Context Retrieval Analysis');\n sections.push(\n `*Confidence: ${(analysis.confidenceScore * 100).toFixed(0)}%*`\n );\n sections.push(analysis.reasoning);\n sections.push('');\n\n // Add frames\n if (frames.length > 0) {\n sections.push('## Relevant Frames');\n for (const frame of frames) {\n sections.push(`### ${frame.name} (${frame.type})`);\n if (frame.digest_text) {\n sections.push(frame.digest_text);\n }\n sections.push('');\n }\n }\n\n // Add key anchors\n const decisions = anchors.filter((a) => a.type === 'DECISION');\n const constraints = anchors.filter((a) => a.type === 'CONSTRAINT');\n const facts = anchors.filter((a) => a.type === 'FACT');\n\n if (decisions.length > 0) {\n sections.push('## Key Decisions');\n for (const d of decisions.slice(0, 5)) {\n sections.push(`- ${d.text}`);\n }\n sections.push('');\n }\n\n if (constraints.length > 0) {\n sections.push('## Active Constraints');\n for (const c of constraints.slice(0, 5)) {\n sections.push(`- ${c.text}`);\n }\n sections.push('');\n }\n\n if (facts.length > 0) {\n sections.push('## Important Facts');\n for (const f of facts.slice(0, 5)) {\n sections.push(`- ${f.text}`);\n }\n sections.push('');\n }\n\n // Add recent events summary\n if (events.length > 0) {\n sections.push('## Recent Activity');\n const eventSummary = this.summarizeEvents(events);\n sections.push(eventSummary);\n sections.push('');\n }\n\n // Add recommendations\n if (analysis.recommendations.length > 0) {\n sections.push('## Recommendations');\n for (const rec of analysis.recommendations) {\n const icon =\n rec.type === 'include' ? '+' : rec.type === 'exclude' ? '-' : '~';\n sections.push(`${icon} [${rec.impact.toUpperCase()}] ${rec.reason}`);\n }\n }\n\n return sections.join('\\n');\n }\n\n private summarizeEvents(events: Event[]): string {\n const byType: Record<string, number> = {};\n for (const event of events) {\n byType[event.event_type] = (byType[event.event_type] || 0) + 1;\n }\n\n return Object.entries(byType)\n .map(([type, count]) => `- ${type}: ${count} occurrences`)\n .join('\\n');\n }\n\n /**\n * Get just the compressed summary (useful for external analysis)\n */\n public getSummary(forceRefresh = false): CompressedSummary {\n return this.summaryGenerator.generateSummary({ forceRefresh });\n }\n\n /**\n * Set LLM provider\n */\n public setLLMProvider(provider: LLMProvider): void {\n this.llmProvider = provider;\n }\n\n /**\n * Clear all caches\n */\n public clearCache(): void {\n this.summaryGenerator.clearCache();\n this.lazyLoader.clearCache();\n this.contextCache.clear();\n logger.info('Cleared all caches', {\n projectId: this.projectId,\n cacheStats: this.contextCache.getStats(),\n });\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/llm-provider.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * LLM Provider Implementation for Context Retrieval\n * Provides real Anthropic API integration for intelligent context analysis\n */\n\nimport Anthropic from '@anthropic-ai/sdk';\nimport { logger } from '../monitoring/logger.js';\n\n/**\n * LLM provider interface for context analysis\n */\nexport interface LLMProvider {\n analyze(prompt: string, maxTokens: number): Promise<string>;\n}\n\n/**\n * Configuration for Anthropic LLM provider\n */\nexport interface AnthropicProviderConfig {\n apiKey: string;\n model?: string;\n temperature?: number;\n maxRetries?: number;\n timeout?: number;\n}\n\n/**\n * Real Anthropic LLM provider using the official SDK\n */\nexport class AnthropicLLMProvider implements LLMProvider {\n private client: Anthropic;\n private model: string;\n private temperature: number;\n private maxRetries: number;\n private timeout: number;\n\n constructor(config: AnthropicProviderConfig) {\n this.client = new Anthropic({\n apiKey: config.apiKey,\n });\n this.model = config.model || 'claude-3-haiku-20240307';\n this.temperature = config.temperature ?? 0.3;\n this.maxRetries = config.maxRetries ?? 2;\n this.timeout = config.timeout ?? 30000;\n\n logger.info('AnthropicLLMProvider initialized', {\n model: this.model,\n temperature: this.temperature,\n });\n }\n\n /**\n * Analyze a prompt using the Anthropic API\n */\n async analyze(prompt: string, maxTokens: number): Promise<string> {\n const startTime = Date.now();\n let lastError: Error | null = null;\n\n for (let attempt = 0; attempt <= this.maxRetries; attempt++) {\n try {\n const response = await this.makeRequest(prompt, maxTokens);\n\n logger.debug('LLM analysis completed', {\n model: this.model,\n promptLength: prompt.length,\n responseLength: response.length,\n durationMs: Date.now() - startTime,\n attempt,\n });\n\n return response;\n } catch (error) {\n lastError = error instanceof Error ? error : new Error(String(error));\n\n // Check if retryable\n if (this.isRetryableError(error) && attempt < this.maxRetries) {\n const backoffMs = Math.pow(2, attempt) * 1000;\n logger.warn('LLM request failed, retrying', {\n attempt,\n backoffMs,\n error: lastError.message,\n });\n await this.sleep(backoffMs);\n continue;\n }\n\n break;\n }\n }\n\n logger.error('LLM analysis failed after retries', lastError!);\n throw lastError;\n }\n\n /**\n * Make the actual API request\n */\n private async makeRequest(\n prompt: string,\n maxTokens: number\n ): Promise<string> {\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), this.timeout);\n\n try {\n const response = await this.client.messages.create({\n model: this.model,\n max_tokens: maxTokens,\n temperature: this.temperature,\n messages: [\n {\n role: 'user',\n content: prompt,\n },\n ],\n });\n\n // Extract text from response\n const textContent = response.content.find((c) => c.type === 'text');\n if (!textContent || textContent.type !== 'text') {\n throw new Error('No text content in response');\n }\n\n return textContent.text;\n } finally {\n clearTimeout(timeoutId);\n }\n }\n\n /**\n * Check if an error is retryable\n */\n private isRetryableError(error: unknown): boolean {\n if (error instanceof Anthropic.RateLimitError) {\n return true;\n }\n if (error instanceof Anthropic.APIConnectionError) {\n return true;\n }\n if (error instanceof Anthropic.InternalServerError) {\n return true;\n }\n // Timeout errors are retryable\n if (error instanceof Error && error.name === 'AbortError') {\n return true;\n }\n return false;\n }\n\n private sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n}\n\n/**\n * Local fallback LLM provider - uses heuristic summarization without external APIs\n * This ensures StackMemory works in LOCAL_ONLY mode\n */\nexport class LocalFallbackProvider implements LLMProvider {\n async analyze(prompt: string, maxTokens: number): Promise<string> {\n // Extract content from prompt and create a heuristic summary\n const lines = prompt.split('\\n').filter((l) => l.trim());\n const contentStart = lines.findIndex((l) => l.includes('Content:'));\n\n if (contentStart === -1 || lines.length < 3) {\n return 'Context summary not available (local mode)';\n }\n\n // Extract key information heuristically\n const content = lines.slice(contentStart + 1).join('\\n');\n const sentences = content\n .split(/[.!?]+/)\n .filter((s) => s.trim().length > 10);\n\n // Take first few sentences up to maxTokens (rough approximation: 4 chars = 1 token)\n const maxChars = maxTokens * 4;\n let summary = '';\n for (const sentence of sentences.slice(0, 5)) {\n if (summary.length + sentence.length > maxChars) break;\n summary += sentence.trim() + '. ';\n }\n\n return (\n summary.trim() || 'Context available (use LLM API for detailed analysis)'\n );\n }\n}\n\n/**\n * Factory function to create an LLM provider based on environment\n */\nexport function createLLMProvider(): LLMProvider | undefined {\n // Check for local-only mode\n if (\n process.env['STACKMEMORY_LOCAL'] === 'true' ||\n process.env['LOCAL_ONLY'] === 'true'\n ) {\n logger.info('LOCAL mode - using heuristic summarization');\n return new LocalFallbackProvider();\n }\n\n const apiKey = process.env['ANTHROPIC_API_KEY'];\n\n if (!apiKey) {\n logger.info(\n 'No ANTHROPIC_API_KEY found, LLM retrieval will use heuristics'\n );\n return new LocalFallbackProvider();\n }\n\n return new AnthropicLLMProvider({\n apiKey,\n model: process.env['ANTHROPIC_MODEL'] || 'claude-3-haiku-20240307',\n temperature: parseFloat(process.env['ANTHROPIC_TEMPERATURE'] || '0.3'),\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/retrieval-audit.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Retrieval Audit Store\n * Records retrieval decisions for auditing and debugging\n */\n\nimport Database from 'better-sqlite3';\nimport { v4 as uuidv4 } from 'uuid';\nimport { logger } from '../monitoring/logger.js';\nimport { LLMAnalysisResponse } from './types.js';\n\n/**\n * A single retrieval audit entry\n */\nexport interface RetrievalAuditEntry {\n id: string;\n timestamp: number;\n projectId: string;\n query: string;\n reasoning: string;\n framesRetrieved: string[];\n confidenceScore: number;\n provider: 'anthropic' | 'heuristic' | 'cached';\n tokensUsed: number;\n tokenBudget: number;\n analysisTimeMs: number;\n queryComplexity: 'simple' | 'moderate' | 'complex';\n}\n\n/**\n * Stores retrieval audit entries for later inspection\n */\nexport class RetrievalAuditStore {\n private db: Database.Database;\n private projectId: string;\n private initialized = false;\n\n constructor(db: Database.Database, projectId: string) {\n this.db = db;\n this.projectId = projectId;\n this.initSchema();\n }\n\n /**\n * Initialize the audit table schema\n */\n private initSchema(): void {\n if (this.initialized) return;\n\n try {\n this.db.exec(`\n CREATE TABLE IF NOT EXISTS retrieval_audit (\n id TEXT PRIMARY KEY,\n timestamp INTEGER NOT NULL,\n project_id TEXT NOT NULL,\n query TEXT NOT NULL,\n reasoning TEXT NOT NULL,\n frames_retrieved TEXT NOT NULL,\n confidence_score REAL NOT NULL,\n provider TEXT NOT NULL,\n tokens_used INTEGER NOT NULL,\n token_budget INTEGER NOT NULL,\n analysis_time_ms INTEGER NOT NULL,\n query_complexity TEXT NOT NULL\n );\n\n CREATE INDEX IF NOT EXISTS idx_retrieval_audit_project_time\n ON retrieval_audit(project_id, timestamp DESC);\n\n CREATE INDEX IF NOT EXISTS idx_retrieval_audit_query\n ON retrieval_audit(project_id, query);\n `);\n\n this.initialized = true;\n logger.debug('Retrieval audit schema initialized');\n } catch (error) {\n logger.warn('Failed to initialize retrieval audit schema', {\n error: error instanceof Error ? error.message : String(error),\n });\n }\n }\n\n /**\n * Record a retrieval decision\n */\n record(\n query: string,\n analysis: LLMAnalysisResponse,\n options: {\n tokensUsed: number;\n tokenBudget: number;\n provider: 'anthropic' | 'heuristic' | 'cached';\n }\n ): string {\n const id = uuidv4();\n const timestamp = Date.now();\n\n try {\n const stmt = this.db.prepare(`\n INSERT INTO retrieval_audit (\n id, timestamp, project_id, query, reasoning, frames_retrieved,\n confidence_score, provider, tokens_used, token_budget,\n analysis_time_ms, query_complexity\n ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n `);\n\n stmt.run(\n id,\n timestamp,\n this.projectId,\n query,\n analysis.reasoning,\n JSON.stringify(analysis.framesToRetrieve.map((f) => f.frameId)),\n analysis.confidenceScore,\n options.provider,\n options.tokensUsed,\n options.tokenBudget,\n analysis.metadata.analysisTimeMs,\n analysis.metadata.queryComplexity\n );\n\n logger.debug('Recorded retrieval audit entry', {\n id,\n query: query.slice(0, 50),\n });\n return id;\n } catch (error) {\n logger.warn('Failed to record retrieval audit', {\n error: error instanceof Error ? error.message : String(error),\n });\n return id; // Return ID even on failure\n }\n }\n\n /**\n * Get recent retrieval audit entries\n */\n getRecent(limit = 10): RetrievalAuditEntry[] {\n try {\n const stmt = this.db.prepare(`\n SELECT * FROM retrieval_audit\n WHERE project_id = ?\n ORDER BY timestamp DESC\n LIMIT ?\n `);\n\n const rows = stmt.all(this.projectId, limit) as any[];\n return rows.map(this.rowToEntry);\n } catch (error) {\n logger.warn('Failed to get recent audit entries', {\n error: error instanceof Error ? error.message : String(error),\n });\n return [];\n }\n }\n\n /**\n * Get audit entry by ID\n */\n getById(id: string): RetrievalAuditEntry | null {\n try {\n const stmt = this.db.prepare(`\n SELECT * FROM retrieval_audit WHERE id = ?\n `);\n\n const row = stmt.get(id) as any;\n return row ? this.rowToEntry(row) : null;\n } catch (error) {\n logger.warn('Failed to get audit entry', {\n error: error instanceof Error ? error.message : String(error),\n id,\n });\n return null;\n }\n }\n\n /**\n * Search audit entries by query text\n */\n searchByQuery(searchTerm: string, limit = 10): RetrievalAuditEntry[] {\n try {\n const stmt = this.db.prepare(`\n SELECT * FROM retrieval_audit\n WHERE project_id = ? AND query LIKE ?\n ORDER BY timestamp DESC\n LIMIT ?\n `);\n\n const rows = stmt.all(this.projectId, `%${searchTerm}%`, limit) as any[];\n return rows.map(this.rowToEntry);\n } catch (error) {\n logger.warn('Failed to search audit entries', {\n error: error instanceof Error ? error.message : String(error),\n });\n return [];\n }\n }\n\n /**\n * Get statistics about retrieval patterns\n */\n getStats(): {\n totalRetrievals: number;\n avgConfidence: number;\n providerBreakdown: Record<string, number>;\n avgTokensUsed: number;\n avgAnalysisTime: number;\n } {\n try {\n const statsStmt = this.db.prepare(`\n SELECT\n COUNT(*) as total,\n AVG(confidence_score) as avg_confidence,\n AVG(tokens_used) as avg_tokens,\n AVG(analysis_time_ms) as avg_time\n FROM retrieval_audit\n WHERE project_id = ?\n `);\n\n const providerStmt = this.db.prepare(`\n SELECT provider, COUNT(*) as count\n FROM retrieval_audit\n WHERE project_id = ?\n GROUP BY provider\n `);\n\n const stats = statsStmt.get(this.projectId) as any;\n const providers = providerStmt.all(this.projectId) as any[];\n\n const providerBreakdown: Record<string, number> = {};\n for (const p of providers) {\n providerBreakdown[p.provider] = p.count;\n }\n\n return {\n totalRetrievals: stats?.total || 0,\n avgConfidence: stats?.avg_confidence || 0,\n providerBreakdown,\n avgTokensUsed: stats?.avg_tokens || 0,\n avgAnalysisTime: stats?.avg_time || 0,\n };\n } catch (error) {\n logger.warn('Failed to get audit stats', {\n error: error instanceof Error ? error.message : String(error),\n });\n return {\n totalRetrievals: 0,\n avgConfidence: 0,\n providerBreakdown: {},\n avgTokensUsed: 0,\n avgAnalysisTime: 0,\n };\n }\n }\n\n /**\n * Clean up old audit entries\n */\n cleanup(maxAgeMs = 7 * 24 * 60 * 60 * 1000): number {\n try {\n const cutoff = Date.now() - maxAgeMs;\n const stmt = this.db.prepare(`\n DELETE FROM retrieval_audit\n WHERE project_id = ? AND timestamp < ?\n `);\n\n const result = stmt.run(this.projectId, cutoff);\n logger.info('Cleaned up old audit entries', { deleted: result.changes });\n return result.changes;\n } catch (error) {\n logger.warn('Failed to cleanup audit entries', {\n error: error instanceof Error ? error.message : String(error),\n });\n return 0;\n }\n }\n\n private rowToEntry(row: any): RetrievalAuditEntry {\n return {\n id: row.id,\n timestamp: row.timestamp,\n projectId: row.project_id,\n query: row.query,\n reasoning: row.reasoning,\n framesRetrieved: JSON.parse(row.frames_retrieved),\n confidenceScore: row.confidence_score,\n provider: row.provider as 'anthropic' | 'heuristic' | 'cached',\n tokensUsed: row.tokens_used,\n tokenBudget: row.token_budget,\n analysisTimeMs: row.analysis_time_ms,\n queryComplexity: row.query_complexity as\n | 'simple'\n | 'moderate'\n | 'complex',\n };\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/summary-generator.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Compressed Summary Generator\n * Creates compact summaries of project memory for LLM analysis\n */\n\nimport Database from 'better-sqlite3';\nimport {\n FrameManager,\n Frame,\n Anchor,\n Event,\n} from '../context/index.js';\nimport { TraceDetector } from '../trace/trace-detector.js';\nimport {\n CompressedSummary,\n RecentSessionSummary,\n HistoricalPatterns,\n QueryableIndices,\n SummaryStats,\n FrameSummary,\n OperationSummary,\n FileSummary,\n ErrorSummary,\n DecisionSummary,\n IssueSummary,\n ToolSequence,\n ActivityPattern,\n RetrievalConfig,\n DEFAULT_RETRIEVAL_CONFIG,\n} from './types.js';\nimport { logger } from '../monitoring/logger.js';\n\nexport class CompressedSummaryGenerator {\n private db: Database.Database;\n private frameManager: FrameManager;\n private traceDetector?: TraceDetector;\n private projectId: string;\n private config: RetrievalConfig;\n private cache: Map<\n string,\n { summary: CompressedSummary; expiresAt: number }\n > = new Map();\n\n constructor(\n db: Database.Database,\n frameManager: FrameManager,\n projectId: string,\n config: Partial<RetrievalConfig> = {},\n traceDetector?: TraceDetector\n ) {\n this.db = db;\n this.frameManager = frameManager;\n this.projectId = projectId;\n this.config = { ...DEFAULT_RETRIEVAL_CONFIG, ...config };\n this.traceDetector = traceDetector;\n }\n\n /**\n * Generate a compressed summary for LLM analysis\n */\n public generateSummary(\n options: {\n maxFrames?: number;\n timeRangeHours?: number;\n forceRefresh?: boolean;\n } = {}\n ): CompressedSummary {\n const cacheKey = `summary_${this.projectId}_${options.maxFrames || this.config.maxSummaryFrames}`;\n\n // Check cache\n if (!options.forceRefresh) {\n const cached = this.cache.get(cacheKey);\n if (cached && cached.expiresAt > Date.now()) {\n logger.debug('Using cached summary', { projectId: this.projectId });\n return cached.summary;\n }\n }\n\n const startTime = Date.now();\n const maxFrames = options.maxFrames || this.config.maxSummaryFrames;\n const timeRangeHours = options.timeRangeHours || 24;\n\n // Generate all components\n const recentSession = this.generateRecentSessionSummary(\n maxFrames,\n timeRangeHours\n );\n const historicalPatterns = this.generateHistoricalPatterns();\n const queryableIndices = this.generateQueryableIndices();\n const stats = this.generateStats();\n\n const summary: CompressedSummary = {\n projectId: this.projectId,\n generatedAt: Date.now(),\n recentSession,\n historicalPatterns,\n queryableIndices,\n stats,\n };\n\n // Cache the result\n this.cache.set(cacheKey, {\n summary,\n expiresAt: Date.now() + this.config.cacheTtlSeconds * 1000,\n });\n\n logger.info('Generated compressed summary', {\n projectId: this.projectId,\n frames: recentSession.frames.length,\n generationTimeMs: Date.now() - startTime,\n });\n\n return summary;\n }\n\n /**\n * Generate recent session summary\n */\n private generateRecentSessionSummary(\n maxFrames: number,\n timeRangeHours: number\n ): RecentSessionSummary {\n const cutoffTime = Math.floor(Date.now() / 1000) - timeRangeHours * 3600;\n\n // Get recent frames\n const frames = this.getRecentFrames(maxFrames, cutoffTime);\n const frameSummaries = frames.map((f) => this.summarizeFrame(f));\n\n // Get dominant operations\n const dominantOperations = this.getDominantOperations(cutoffTime);\n\n // Get files touched\n const filesTouched = this.getFilesTouched(cutoffTime);\n\n // Get errors encountered\n const errorsEncountered = this.getErrorsEncountered(cutoffTime);\n\n // Calculate time range\n const timestamps = frames.map((f) => f.created_at).filter((t) => t);\n const start = timestamps.length > 0 ? Math.min(...timestamps) : cutoffTime;\n const end =\n timestamps.length > 0\n ? Math.max(...timestamps)\n : Math.floor(Date.now() / 1000);\n\n return {\n frames: frameSummaries,\n dominantOperations,\n filesTouched,\n errorsEncountered,\n timeRange: {\n start: start * 1000,\n end: end * 1000,\n durationMs: (end - start) * 1000,\n },\n };\n }\n\n /**\n * Generate historical patterns\n */\n private generateHistoricalPatterns(): HistoricalPatterns {\n return {\n topicFrameCounts: this.getTopicFrameCounts(),\n keyDecisions: this.getKeyDecisions(),\n recurringIssues: this.getRecurringIssues(),\n commonToolSequences: this.getCommonToolSequences(),\n activityPatterns: this.getActivityPatterns(),\n };\n }\n\n /**\n * Generate queryable indices\n */\n private generateQueryableIndices(): QueryableIndices {\n return {\n byErrorType: this.indexByErrorType(),\n byTimeframe: this.indexByTimeframe(),\n byContributor: this.indexByContributor(),\n byTopic: this.indexByTopic(),\n byFile: this.indexByFile(),\n };\n }\n\n /**\n * Generate summary statistics\n */\n private generateStats(): SummaryStats {\n try {\n const frameStats =\n (this.db\n .prepare(\n `\n SELECT \n COUNT(*) as totalFrames,\n MIN(created_at) as oldestFrame,\n MAX(created_at) as newestFrame,\n AVG(depth) as avgDepth\n FROM frames\n WHERE project_id = ?\n `\n )\n .get(this.projectId) as any) || {};\n\n const eventCount = (this.db\n .prepare(\n `\n SELECT COUNT(*) as count FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ?\n `\n )\n .get(this.projectId) as any) || { count: 0 };\n\n const anchorCount = (this.db\n .prepare(\n `\n SELECT COUNT(*) as count FROM anchors a\n JOIN frames f ON a.frame_id = f.frame_id\n WHERE f.project_id = ?\n `\n )\n .get(this.projectId) as any) || { count: 0 };\n\n const decisionCount = (this.db\n .prepare(\n `\n SELECT COUNT(*) as count FROM anchors a\n JOIN frames f ON a.frame_id = f.frame_id\n WHERE f.project_id = ? AND a.type = 'DECISION'\n `\n )\n .get(this.projectId) as any) || { count: 0 };\n\n const totalFrames = frameStats.totalFrames || 0;\n\n return {\n totalFrames,\n totalEvents: eventCount.count || 0,\n totalAnchors: anchorCount.count || 0,\n totalDecisions: decisionCount.count || 0,\n oldestFrame: (frameStats.oldestFrame || 0) * 1000,\n newestFrame: (frameStats.newestFrame || 0) * 1000,\n avgFrameDepth: frameStats.avgDepth || 0,\n avgEventsPerFrame:\n totalFrames > 0 ? (eventCount.count || 0) / totalFrames : 0,\n };\n } catch (error: unknown) {\n logger.warn('Error generating stats, using defaults', { error });\n return {\n totalFrames: 0,\n totalEvents: 0,\n totalAnchors: 0,\n totalDecisions: 0,\n oldestFrame: 0,\n newestFrame: 0,\n avgFrameDepth: 0,\n avgEventsPerFrame: 0,\n };\n }\n }\n\n // Helper methods for recent session\n\n private getRecentFrames(limit: number, cutoffTime: number): Frame[] {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT * FROM frames\n WHERE project_id = ? AND created_at >= ?\n ORDER BY created_at DESC\n LIMIT ?\n `\n )\n .all(this.projectId, cutoffTime, limit) as any[];\n\n return rows.map((row) => ({\n ...row,\n inputs: JSON.parse(row.inputs || '{}'),\n outputs: JSON.parse(row.outputs || '{}'),\n digest_json: JSON.parse(row.digest_json || '{}'),\n }));\n } catch {\n return [];\n }\n }\n\n private summarizeFrame(frame: Frame): FrameSummary {\n // Get event count\n const eventCount = (this.db\n .prepare(\n `\n SELECT COUNT(*) as count FROM events WHERE frame_id = ?\n `\n )\n .get(frame.frame_id) as any) || { count: 0 };\n\n // Get anchor count\n const anchorCount = (this.db\n .prepare(\n `\n SELECT COUNT(*) as count FROM anchors WHERE frame_id = ?\n `\n )\n .get(frame.frame_id) as any) || { count: 0 };\n\n // Calculate score based on activity\n const score = this.calculateFrameScore(\n frame,\n eventCount.count,\n anchorCount.count\n );\n\n return {\n frameId: frame.frame_id,\n name: frame.name,\n type: frame.type,\n depth: frame.depth,\n eventCount: eventCount.count,\n anchorCount: anchorCount.count,\n score,\n createdAt: frame.created_at * 1000,\n closedAt: frame.closed_at ? frame.closed_at * 1000 : undefined,\n digestPreview: frame.digest_text?.substring(0, 100),\n };\n }\n\n private calculateFrameScore(\n frame: Frame,\n eventCount: number,\n anchorCount: number\n ): number {\n let score = 0.3; // Base score\n\n // Activity bonus\n score += Math.min(eventCount / 50, 0.3);\n score += Math.min(anchorCount / 10, 0.2);\n\n // Recency bonus\n const ageHours = (Date.now() / 1000 - frame.created_at) / 3600;\n if (ageHours < 1) score += 0.2;\n else if (ageHours < 6) score += 0.1;\n\n // Open frame bonus\n if (frame.state === 'active') score += 0.1;\n\n return Math.min(score, 1.0);\n }\n\n private getDominantOperations(cutoffTime: number): OperationSummary[] {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT \n e.event_type as operation,\n COUNT(*) as count,\n MAX(e.ts) as lastOccurrence,\n SUM(CASE WHEN json_extract(e.payload, '$.success') = 1 THEN 1 ELSE 0 END) as successCount\n FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ? AND e.ts >= ?\n GROUP BY e.event_type\n ORDER BY count DESC\n LIMIT 10\n `\n )\n .all(this.projectId, cutoffTime) as any[];\n\n return rows.map((row) => ({\n operation: row.operation,\n count: row.count,\n lastOccurrence: row.lastOccurrence * 1000,\n successRate: row.count > 0 ? row.successCount / row.count : 0,\n }));\n } catch {\n return [];\n }\n }\n\n private getFilesTouched(cutoffTime: number): FileSummary[] {\n try {\n // Extract file paths from event payloads\n const rows = this.db\n .prepare(\n `\n SELECT \n json_extract(e.payload, '$.file_path') as path,\n e.event_type as operation,\n MAX(e.ts) as lastModified\n FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ? \n AND e.ts >= ?\n AND json_extract(e.payload, '$.file_path') IS NOT NULL\n GROUP BY json_extract(e.payload, '$.file_path'), e.event_type\n `\n )\n .all(this.projectId, cutoffTime) as any[];\n\n // Aggregate by file\n const fileMap = new Map<string, FileSummary>();\n for (const row of rows) {\n if (!row.path) continue;\n\n const existing = fileMap.get(row.path);\n if (existing) {\n existing.operationCount++;\n existing.operations.push(row.operation);\n existing.lastModified = Math.max(\n existing.lastModified,\n row.lastModified * 1000\n );\n } else {\n fileMap.set(row.path, {\n path: row.path,\n operationCount: 1,\n lastModified: row.lastModified * 1000,\n operations: [row.operation],\n });\n }\n }\n\n return Array.from(fileMap.values())\n .sort((a, b) => b.operationCount - a.operationCount)\n .slice(0, 20);\n } catch {\n return [];\n }\n }\n\n private getErrorsEncountered(cutoffTime: number): ErrorSummary[] {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT \n json_extract(e.payload, '$.error_type') as errorType,\n json_extract(e.payload, '$.error') as message,\n COUNT(*) as count,\n MAX(e.ts) as lastOccurrence\n FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ? \n AND e.ts >= ?\n AND (json_extract(e.payload, '$.error') IS NOT NULL \n OR json_extract(e.payload, '$.error_type') IS NOT NULL)\n GROUP BY json_extract(e.payload, '$.error_type'), json_extract(e.payload, '$.error')\n ORDER BY count DESC\n LIMIT 15\n `\n )\n .all(this.projectId, cutoffTime) as any[];\n\n return rows.map((row) => ({\n errorType: row.errorType || 'unknown',\n message: row.message || '',\n count: row.count,\n lastOccurrence: row.lastOccurrence * 1000,\n resolved: false, // Would need more context to determine\n }));\n } catch {\n return [];\n }\n }\n\n // Helper methods for historical patterns\n\n private getTopicFrameCounts(): Record<string, number> {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT type, COUNT(*) as count\n FROM frames\n WHERE project_id = ?\n GROUP BY type\n `\n )\n .all(this.projectId) as any[];\n\n const counts: Record<string, number> = {};\n for (const row of rows) {\n counts[row.type] = row.count;\n }\n return counts;\n } catch {\n return {};\n }\n }\n\n private getKeyDecisions(): DecisionSummary[] {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT \n a.anchor_id as id,\n a.text,\n a.frame_id as frameId,\n a.created_at as timestamp,\n a.priority\n FROM anchors a\n JOIN frames f ON a.frame_id = f.frame_id\n WHERE f.project_id = ? AND a.type = 'DECISION'\n ORDER BY a.priority DESC, a.created_at DESC\n LIMIT 20\n `\n )\n .all(this.projectId) as any[];\n\n return rows.map((row) => ({\n id: row.id,\n text: row.text,\n frameId: row.frameId,\n timestamp: row.timestamp * 1000,\n impact:\n row.priority >= 7 ? 'high' : row.priority >= 4 ? 'medium' : 'low',\n }));\n } catch {\n return [];\n }\n }\n\n private getRecurringIssues(): IssueSummary[] {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT \n json_extract(e.payload, '$.error_type') as issueType,\n COUNT(*) as occurrenceCount,\n MAX(e.ts) as lastSeen\n FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ? \n AND json_extract(e.payload, '$.error_type') IS NOT NULL\n GROUP BY json_extract(e.payload, '$.error_type')\n HAVING COUNT(*) > 1\n ORDER BY occurrenceCount DESC\n LIMIT 10\n `\n )\n .all(this.projectId) as any[];\n\n return rows.map((row) => ({\n issueType: row.issueType,\n occurrenceCount: row.occurrenceCount,\n lastSeen: row.lastSeen * 1000,\n resolutionRate: 0.5, // Would need resolution tracking\n }));\n } catch {\n return [];\n }\n }\n\n private getCommonToolSequences(): ToolSequence[] {\n // Use trace detector if available\n if (this.traceDetector) {\n const stats = this.traceDetector.getStatistics();\n const sequences: ToolSequence[] = [];\n\n for (const [type, count] of Object.entries(stats.tracesByType)) {\n sequences.push({\n pattern: type,\n frequency: count,\n avgDuration: 0, // Would need more data\n successRate: 0.8, // Estimate\n });\n }\n\n return sequences;\n }\n\n return [];\n }\n\n private getActivityPatterns(): ActivityPattern[] {\n try {\n // Get hourly distribution\n const hourlyRows = this.db\n .prepare(\n `\n SELECT \n strftime('%H', datetime(e.ts, 'unixepoch')) as hour,\n COUNT(*) as count\n FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ?\n GROUP BY hour\n ORDER BY count DESC\n `\n )\n .all(this.projectId) as any[];\n\n const peakHours = hourlyRows.slice(0, 3).map((r) => `${r.hour}:00`);\n const totalEvents = hourlyRows.reduce((sum, r) => sum + r.count, 0);\n\n return [\n {\n periodType: 'hourly',\n peakPeriods: peakHours,\n avgEventsPerPeriod: totalEvents / 24,\n },\n ];\n } catch {\n return [];\n }\n }\n\n // Helper methods for queryable indices\n\n private indexByErrorType(): Record<string, string[]> {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT DISTINCT\n json_extract(e.payload, '$.error_type') as errorType,\n f.frame_id\n FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ? \n AND json_extract(e.payload, '$.error_type') IS NOT NULL\n `\n )\n .all(this.projectId) as any[];\n\n const index: Record<string, string[]> = {};\n for (const row of rows) {\n if (!row.errorType) continue;\n if (!index[row.errorType]) index[row.errorType] = [];\n if (!index[row.errorType].includes(row.frame_id)) {\n index[row.errorType].push(row.frame_id);\n }\n }\n return index;\n } catch {\n return {};\n }\n }\n\n private indexByTimeframe(): Record<string, string[]> {\n try {\n const now = Math.floor(Date.now() / 1000);\n const timeframes = {\n last_hour: now - 3600,\n last_day: now - 86400,\n last_week: now - 604800,\n last_month: now - 2592000,\n };\n\n const index: Record<string, string[]> = {};\n\n for (const [label, cutoff] of Object.entries(timeframes)) {\n const rows = this.db\n .prepare(\n `\n SELECT frame_id FROM frames\n WHERE project_id = ? AND created_at >= ?\n `\n )\n .all(this.projectId, cutoff) as any[];\n\n index[label] = rows.map((r) => r.frame_id);\n }\n\n return index;\n } catch {\n return {};\n }\n }\n\n private indexByContributor(): Record<string, string[]> {\n // Would need user tracking - return empty for now\n return {};\n }\n\n private indexByTopic(): Record<string, string[]> {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT frame_id, type, name FROM frames\n WHERE project_id = ?\n `\n )\n .all(this.projectId) as any[];\n\n const index: Record<string, string[]> = {};\n\n for (const row of rows) {\n // Index by frame type\n if (!index[row.type]) index[row.type] = [];\n index[row.type].push(row.frame_id);\n\n // Index by keywords in name\n const keywords = this.extractKeywords(row.name);\n for (const keyword of keywords) {\n if (!index[keyword]) index[keyword] = [];\n if (!index[keyword].includes(row.frame_id)) {\n index[keyword].push(row.frame_id);\n }\n }\n }\n\n return index;\n } catch {\n return {};\n }\n }\n\n private indexByFile(): Record<string, string[]> {\n try {\n const rows = this.db\n .prepare(\n `\n SELECT DISTINCT\n json_extract(e.payload, '$.file_path') as filePath,\n f.frame_id\n FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ? \n AND json_extract(e.payload, '$.file_path') IS NOT NULL\n `\n )\n .all(this.projectId) as any[];\n\n const index: Record<string, string[]> = {};\n for (const row of rows) {\n if (!row.filePath) continue;\n if (!index[row.filePath]) index[row.filePath] = [];\n if (!index[row.filePath].includes(row.frame_id)) {\n index[row.filePath].push(row.frame_id);\n }\n }\n return index;\n } catch {\n return {};\n }\n }\n\n private extractKeywords(text: string): string[] {\n const stopWords = new Set([\n 'the',\n 'a',\n 'an',\n 'and',\n 'or',\n 'but',\n 'in',\n 'on',\n 'at',\n 'to',\n 'for',\n ]);\n return text\n .toLowerCase()\n .split(/\\W+/)\n .filter((word) => word.length > 2 && !stopWords.has(word));\n }\n\n /**\n * Clear the cache\n */\n public clearCache(): void {\n this.cache.clear();\n logger.debug('Summary cache cleared', { projectId: this.projectId });\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/types.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Types for LLM-Driven Context Retrieval System\n * Implements intelligent context selection based on compressed summaries\n */\n\nimport { Frame, Anchor, Event } from '../context/index.js';\nimport { StackMemoryQuery } from '../query/query-parser.js';\n\n/**\n * Compressed summary of recent session activity\n */\nexport interface RecentSessionSummary {\n /** Recent frames with their key attributes */\n frames: FrameSummary[];\n /** Dominant operations performed */\n dominantOperations: OperationSummary[];\n /** Files that were touched */\n filesTouched: FileSummary[];\n /** Errors encountered */\n errorsEncountered: ErrorSummary[];\n /** Time range covered */\n timeRange: {\n start: number;\n end: number;\n durationMs: number;\n };\n}\n\nexport interface FrameSummary {\n frameId: string;\n name: string;\n type: string;\n depth: number;\n eventCount: number;\n anchorCount: number;\n score: number;\n createdAt: number;\n closedAt?: number;\n digestPreview?: string;\n}\n\nexport interface OperationSummary {\n operation: string;\n count: number;\n lastOccurrence: number;\n successRate: number;\n}\n\nexport interface FileSummary {\n path: string;\n operationCount: number;\n lastModified: number;\n operations: string[];\n}\n\nexport interface ErrorSummary {\n errorType: string;\n message: string;\n count: number;\n lastOccurrence: number;\n resolved: boolean;\n}\n\n/**\n * Historical patterns extracted from memory\n */\nexport interface HistoricalPatterns {\n /** Frame counts by topic */\n topicFrameCounts: Record<string, number>;\n /** Key decisions made */\n keyDecisions: DecisionSummary[];\n /** Recurring issues */\n recurringIssues: IssueSummary[];\n /** Common tool sequences */\n commonToolSequences: ToolSequence[];\n /** Time-based activity patterns */\n activityPatterns: ActivityPattern[];\n}\n\nexport interface DecisionSummary {\n id: string;\n text: string;\n frameId: string;\n timestamp: number;\n impact: 'low' | 'medium' | 'high';\n relatedFiles?: string[];\n}\n\nexport interface IssueSummary {\n issueType: string;\n occurrenceCount: number;\n lastSeen: number;\n resolutionRate: number;\n commonFixes?: string[];\n}\n\nexport interface ToolSequence {\n pattern: string;\n frequency: number;\n avgDuration: number;\n successRate: number;\n}\n\nexport interface ActivityPattern {\n periodType: 'hourly' | 'daily' | 'weekly';\n peakPeriods: string[];\n avgEventsPerPeriod: number;\n}\n\n/**\n * Queryable indices for fast retrieval\n */\nexport interface QueryableIndices {\n /** Index by error type */\n byErrorType: Record<string, string[]>; // errorType -> frameIds\n /** Index by timeframe */\n byTimeframe: Record<string, string[]>; // timeKey -> frameIds\n /** Index by contributor */\n byContributor: Record<string, string[]>; // userId -> frameIds\n /** Index by topic */\n byTopic: Record<string, string[]>; // topic -> frameIds\n /** Index by file */\n byFile: Record<string, string[]>; // filePath -> frameIds\n}\n\n/**\n * Complete compressed summary for LLM analysis\n */\nexport interface CompressedSummary {\n /** Project identifier */\n projectId: string;\n /** Generation timestamp */\n generatedAt: number;\n /** Recent session summary */\n recentSession: RecentSessionSummary;\n /** Historical patterns */\n historicalPatterns: HistoricalPatterns;\n /** Queryable indices */\n queryableIndices: QueryableIndices;\n /** Summary statistics */\n stats: SummaryStats;\n}\n\nexport interface SummaryStats {\n totalFrames: number;\n totalEvents: number;\n totalAnchors: number;\n totalDecisions: number;\n oldestFrame: number;\n newestFrame: number;\n avgFrameDepth: number;\n avgEventsPerFrame: number;\n}\n\n/**\n * LLM analysis request\n */\nexport interface LLMAnalysisRequest {\n /** Current user query */\n currentQuery: string;\n /** Parsed structured query */\n parsedQuery?: StackMemoryQuery;\n /** Compressed summary */\n compressedSummary: CompressedSummary;\n /** Token budget for context */\n tokenBudget: number;\n /** Optional hints for retrieval */\n hints?: RetrievalHints;\n}\n\nexport interface RetrievalHints {\n /** Prefer recent frames */\n preferRecent?: boolean;\n /** Focus on specific topics */\n focusTopics?: string[];\n /** Include error context */\n includeErrors?: boolean;\n /** Include decision history */\n includeDecisions?: boolean;\n /** Minimum relevance score */\n minRelevance?: number;\n}\n\n/**\n * LLM analysis response\n */\nexport interface LLMAnalysisResponse {\n /** Reasoning for the retrieval decision (auditable) */\n reasoning: string;\n /** Frames to retrieve with priority order */\n framesToRetrieve: FrameRetrievalPlan[];\n /** Confidence score (0.0 - 1.0) */\n confidenceScore: number;\n /** Additional context recommendations */\n recommendations: ContextRecommendation[];\n /** Analysis metadata */\n metadata: AnalysisMetadata;\n}\n\nexport interface FrameRetrievalPlan {\n frameId: string;\n priority: number; // 1-10, higher = more important\n reason: string;\n includeEvents: boolean;\n includeAnchors: boolean;\n includeDigest: boolean;\n estimatedTokens: number;\n}\n\nexport interface ContextRecommendation {\n type: 'include' | 'exclude' | 'summarize';\n target: string; // frameId, anchorId, or description\n reason: string;\n impact: 'low' | 'medium' | 'high';\n}\n\nexport interface AnalysisMetadata {\n analysisTimeMs: number;\n summaryTokens: number;\n queryComplexity: 'simple' | 'moderate' | 'complex';\n matchedPatterns: string[];\n fallbackUsed: boolean;\n}\n\n/**\n * Retrieved context result\n */\nexport interface RetrievedContext {\n /** Assembled context string */\n context: string;\n /** Frames included */\n frames: Frame[];\n /** Anchors included */\n anchors: Anchor[];\n /** Events included */\n events: Event[];\n /** LLM analysis that drove retrieval */\n analysis: LLMAnalysisResponse;\n /** Token usage */\n tokenUsage: {\n budget: number;\n used: number;\n remaining: number;\n };\n /** Retrieval metadata */\n metadata: RetrievalMetadata;\n}\n\nexport interface RetrievalMetadata {\n retrievalTimeMs: number;\n cacheHit: boolean;\n framesScanned: number;\n framesIncluded: number;\n compressionRatio: number;\n}\n\n/**\n * Configuration for the retrieval system\n */\nexport interface RetrievalConfig {\n /** Maximum frames to include in summary */\n maxSummaryFrames: number;\n /** Default token budget */\n defaultTokenBudget: number;\n /** Cache TTL in seconds */\n cacheTtlSeconds: number;\n /** Minimum confidence to use LLM suggestions */\n minConfidenceThreshold: number;\n /** Enable fallback to heuristic retrieval */\n enableFallback: boolean;\n /** LLM provider configuration */\n llmConfig: {\n provider: 'anthropic' | 'openai' | 'local';\n model: string;\n maxTokens: number;\n temperature: number;\n };\n}\n\nexport const DEFAULT_RETRIEVAL_CONFIG: RetrievalConfig = {\n maxSummaryFrames: 15,\n defaultTokenBudget: 8000,\n cacheTtlSeconds: 300,\n minConfidenceThreshold: 0.6,\n enableFallback: true,\n llmConfig: {\n provider: 'anthropic',\n model: 'claude-3-haiku-20240307',\n maxTokens: 1024,\n temperature: 0.3,\n },\n};\n"],
|
|
5
|
+
"mappings": ";;;;AAuRO,MAAM,2BAA4C;AAAA,EACvD,kBAAkB;AAAA,EAClB,oBAAoB;AAAA,EACpB,iBAAiB;AAAA,EACjB,wBAAwB;AAAA,EACxB,gBAAgB;AAAA,EAChB,WAAW;AAAA,IACT,UAAU;AAAA,IACV,OAAO;AAAA,IACP,WAAW;AAAA,IACX,aAAa;AAAA,EACf;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|