@stackmemoryai/stackmemory 0.5.21 → 0.5.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli/claude-sm.js +94 -18
- package/dist/cli/claude-sm.js.map +2 -2
- package/dist/cli/commands/retrieval.js +248 -0
- package/dist/cli/commands/retrieval.js.map +7 -0
- package/dist/cli/index.js +2 -0
- package/dist/cli/index.js.map +2 -2
- package/dist/core/retrieval/llm-context-retrieval.js +36 -2
- package/dist/core/retrieval/llm-context-retrieval.js.map +3 -3
- package/dist/core/retrieval/llm-provider.js +128 -0
- package/dist/core/retrieval/llm-provider.js.map +7 -0
- package/dist/core/retrieval/retrieval-audit.js +236 -0
- package/dist/core/retrieval/retrieval-audit.js.map +7 -0
- package/dist/hooks/linear-task-picker.js +180 -0
- package/dist/hooks/linear-task-picker.js.map +7 -0
- package/dist/hooks/session-summary.js +197 -0
- package/dist/hooks/session-summary.js.map +7 -0
- package/dist/hooks/sms-action-runner.js +87 -20
- package/dist/hooks/sms-action-runner.js.map +2 -2
- package/dist/hooks/sms-webhook.js +6 -6
- package/dist/hooks/sms-webhook.js.map +2 -2
- package/dist/integrations/linear/client.js +125 -0
- package/dist/integrations/linear/client.js.map +2 -2
- package/package.json +1 -1
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/cli/commands/retrieval.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Retrieval CLI Commands\n * View and manage LLM-driven context retrieval settings and audit logs\n */\n\nimport { Command } from 'commander';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync } from 'fs';\nimport chalk from 'chalk';\nimport { RetrievalAuditStore } from '../../core/retrieval/retrieval-audit.js';\n\nexport function createRetrievalCommands(): Command {\n const retrieval = new Command('retrieval')\n .alias('ret')\n .description('Manage LLM-driven context retrieval');\n\n // Audit subcommand\n retrieval\n .command('audit')\n .description('View retrieval audit log')\n .option('-l, --limit <n>', 'Number of entries to show', '10')\n .option('-q, --query <text>', 'Filter by query text')\n .option('-v, --verbose', 'Show full details')\n .action(async (options) => {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n chalk.red('StackMemory not initialized in this directory.')\n );\n console.log(chalk.gray('Run \"stackmemory init\" first.'));\n return;\n }\n\n const db = new Database(dbPath);\n\n try {\n // Get project ID\n let projectId = 'default';\n try {\n const row = db\n .prepare(`SELECT value FROM metadata WHERE key = 'project_id'`)\n .get() as any;\n if (row?.value) projectId = row.value;\n } catch {\n // Use default\n }\n\n const auditStore = new RetrievalAuditStore(db, projectId);\n\n let entries;\n if (options.query) {\n entries = auditStore.searchByQuery(\n options.query,\n parseInt(options.limit)\n );\n console.log(\n chalk.blue(\n `\\nRetrieval audit entries matching \"${options.query}\":\\n`\n )\n );\n } else {\n entries = auditStore.getRecent(parseInt(options.limit));\n console.log(chalk.blue('\\nRecent retrieval audit entries:\\n'));\n }\n\n if (entries.length === 0) {\n console.log(chalk.gray('No audit entries found.'));\n console.log(\n chalk.gray(\n '\\nRetrieval audit records decisions made by the LLM-driven'\n )\n );\n console.log(\n chalk.gray(\n 'context retrieval system. Run some queries to generate entries.'\n )\n );\n return;\n }\n\n for (const entry of entries) {\n const date = new Date(entry.timestamp).toLocaleString();\n const providerIcon =\n entry.provider === 'anthropic'\n ? chalk.green('LLM')\n : entry.provider === 'cached'\n ? chalk.yellow('CACHE')\n : chalk.gray('HEUR');\n\n console.log(\n `${chalk.cyan(entry.id.slice(0, 8))} ${chalk.gray(date)} [${providerIcon}]`\n );\n console.log(\n ` Query: ${chalk.white(entry.query.slice(0, 60))}${entry.query.length > 60 ? '...' : ''}`\n );\n console.log(\n ` Confidence: ${formatConfidence(entry.confidenceScore)} | ` +\n `Tokens: ${entry.tokensUsed}/${entry.tokenBudget} | ` +\n `Time: ${entry.analysisTimeMs}ms | ` +\n `Complexity: ${entry.queryComplexity}`\n );\n\n if (options.verbose) {\n console.log(\n ` Frames: ${entry.framesRetrieved.join(', ') || 'none'}`\n );\n console.log(\n ` Reasoning: ${chalk.gray(entry.reasoning.slice(0, 200))}${entry.reasoning.length > 200 ? '...' : ''}`\n );\n }\n\n console.log('');\n }\n } finally {\n db.close();\n }\n });\n\n // Stats subcommand\n retrieval\n .command('stats')\n .description('Show retrieval statistics')\n .action(async () => {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n chalk.red('StackMemory not initialized in this directory.')\n );\n return;\n }\n\n const db = new Database(dbPath);\n\n try {\n let projectId = 'default';\n try {\n const row = db\n .prepare(`SELECT value FROM metadata WHERE key = 'project_id'`)\n .get() as any;\n if (row?.value) projectId = row.value;\n } catch {\n // Use default\n }\n\n const auditStore = new RetrievalAuditStore(db, projectId);\n const stats = auditStore.getStats();\n\n console.log(chalk.blue('\\nRetrieval Statistics\\n'));\n\n console.log(`Total retrievals: ${chalk.white(stats.totalRetrievals)}`);\n console.log(\n `Average confidence: ${formatConfidence(stats.avgConfidence)}`\n );\n console.log(\n `Average tokens used: ${chalk.white(Math.round(stats.avgTokensUsed))}`\n );\n console.log(\n `Average analysis time: ${chalk.white(Math.round(stats.avgAnalysisTime))}ms`\n );\n\n console.log('\\nProvider breakdown:');\n for (const [provider, count] of Object.entries(\n stats.providerBreakdown\n )) {\n const pct =\n stats.totalRetrievals > 0\n ? ((count / stats.totalRetrievals) * 100).toFixed(1)\n : '0';\n const icon =\n provider === 'anthropic'\n ? chalk.green('LLM')\n : provider === 'cached'\n ? chalk.yellow('CACHE')\n : chalk.gray('HEUR');\n console.log(` ${icon}: ${count} (${pct}%)`);\n }\n\n console.log('');\n } finally {\n db.close();\n }\n });\n\n // Reasoning subcommand - show detailed reasoning for a specific entry\n retrieval\n .command('reasoning <id>')\n .description('Show detailed reasoning for a retrieval decision')\n .action(async (id) => {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n chalk.red('StackMemory not initialized in this directory.')\n );\n return;\n }\n\n const db = new Database(dbPath);\n\n try {\n let projectId = 'default';\n try {\n const row = db\n .prepare(`SELECT value FROM metadata WHERE key = 'project_id'`)\n .get() as any;\n if (row?.value) projectId = row.value;\n } catch {\n // Use default\n }\n\n const auditStore = new RetrievalAuditStore(db, projectId);\n\n // Try to find entry by partial ID\n const entries = auditStore.getRecent(100);\n const entry = entries.find((e) => e.id.startsWith(id));\n\n if (!entry) {\n console.log(\n chalk.red(`No audit entry found with ID starting with \"${id}\"`)\n );\n return;\n }\n\n console.log(chalk.blue('\\nRetrieval Decision Details\\n'));\n\n console.log(`ID: ${chalk.white(entry.id)}`);\n console.log(\n `Time: ${chalk.white(new Date(entry.timestamp).toLocaleString())}`\n );\n console.log(`Provider: ${chalk.white(entry.provider)}`);\n console.log(`Query: ${chalk.white(entry.query)}`);\n console.log(`Complexity: ${chalk.white(entry.queryComplexity)}`);\n console.log(`Confidence: ${formatConfidence(entry.confidenceScore)}`);\n console.log(\n `Tokens: ${chalk.white(`${entry.tokensUsed}/${entry.tokenBudget}`)}`\n );\n console.log(\n `Analysis Time: ${chalk.white(`${entry.analysisTimeMs}ms`)}`\n );\n\n console.log(chalk.blue('\\nReasoning:'));\n console.log(entry.reasoning);\n\n console.log(chalk.blue('\\nFrames Retrieved:'));\n if (entry.framesRetrieved.length === 0) {\n console.log(chalk.gray(' (none)'));\n } else {\n for (const frameId of entry.framesRetrieved) {\n console.log(` - ${frameId}`);\n }\n }\n\n console.log('');\n } finally {\n db.close();\n }\n });\n\n // Cleanup subcommand\n retrieval\n .command('cleanup')\n .description('Remove old audit entries')\n .option('-d, --days <n>', 'Keep entries from last N days', '7')\n .action(async (options) => {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n chalk.red('StackMemory not initialized in this directory.')\n );\n return;\n }\n\n const db = new Database(dbPath);\n\n try {\n let projectId = 'default';\n try {\n const row = db\n .prepare(`SELECT value FROM metadata WHERE key = 'project_id'`)\n .get() as any;\n if (row?.value) projectId = row.value;\n } catch {\n // Use default\n }\n\n const auditStore = new RetrievalAuditStore(db, projectId);\n const days = parseInt(options.days);\n const maxAgeMs = days * 24 * 60 * 60 * 1000;\n const deleted = auditStore.cleanup(maxAgeMs);\n\n console.log(\n chalk.green(\n `Cleaned up ${deleted} old audit entries (older than ${days} days)`\n )\n );\n } finally {\n db.close();\n }\n });\n\n // Status subcommand - show current retrieval configuration\n retrieval\n .command('status')\n .description('Show current retrieval system status')\n .action(async () => {\n const hasApiKey = !!process.env['ANTHROPIC_API_KEY'];\n const model = process.env['ANTHROPIC_MODEL'] || 'claude-3-haiku-20240307';\n\n console.log(chalk.blue('\\nRetrieval System Status\\n'));\n\n if (hasApiKey) {\n console.log(`LLM Provider: ${chalk.green('Anthropic (active)')}`);\n console.log(`Model: ${chalk.white(model)}`);\n } else {\n console.log(\n `LLM Provider: ${chalk.yellow('Heuristic fallback (no API key)')}`\n );\n console.log(\n chalk.gray('Set ANTHROPIC_API_KEY to enable LLM-driven retrieval')\n );\n }\n\n console.log(`Default Token Budget: ${chalk.white('8000')}`);\n console.log(`Confidence Threshold: ${chalk.white('0.6')}`);\n console.log(`Cache TTL: ${chalk.white('5 minutes')}`);\n\n console.log('');\n });\n\n return retrieval;\n}\n\nfunction formatConfidence(score: number): string {\n if (score >= 0.8) return chalk.green(`${(score * 100).toFixed(0)}%`);\n if (score >= 0.6) return chalk.yellow(`${(score * 100).toFixed(0)}%`);\n return chalk.red(`${(score * 100).toFixed(0)}%`);\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
package/dist/cli/index.js
CHANGED
|
@@ -49,6 +49,7 @@ import { createCleanupProcessesCommand } from "./commands/cleanup-processes.js";
|
|
|
49
49
|
import { createAutoBackgroundCommand } from "./commands/auto-background.js";
|
|
50
50
|
import { createSMSNotifyCommand } from "./commands/sms-notify.js";
|
|
51
51
|
import { createSettingsCommand } from "./commands/settings.js";
|
|
52
|
+
import { createRetrievalCommands } from "./commands/retrieval.js";
|
|
52
53
|
import { ProjectManager } from "../core/projects/project-manager.js";
|
|
53
54
|
import Database from "better-sqlite3";
|
|
54
55
|
import { join } from "path";
|
|
@@ -505,6 +506,7 @@ program.addCommand(createCleanupProcessesCommand());
|
|
|
505
506
|
program.addCommand(createAutoBackgroundCommand());
|
|
506
507
|
program.addCommand(createSMSNotifyCommand());
|
|
507
508
|
program.addCommand(createSettingsCommand());
|
|
509
|
+
program.addCommand(createRetrievalCommands());
|
|
508
510
|
program.command("dashboard").description("Display monitoring dashboard in terminal").option("-w, --watch", "Auto-refresh dashboard").option("-i, --interval <seconds>", "Refresh interval in seconds", "5").action(async (options) => {
|
|
509
511
|
const { dashboardCommand } = await import("./commands/dashboard.js");
|
|
510
512
|
await dashboardCommand.handler(options);
|
package/dist/cli/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/cli/index.ts"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory CLI\n * Command-line interface for StackMemory operations\n */\n\n// Set environment flag for CLI usage to skip async context bridge\nprocess.env['STACKMEMORY_CLI'] = 'true';\n\n// Load environment variables\nimport 'dotenv/config';\n\n// Initialize tracing system early\nimport { initializeTracing, trace } from '../core/trace/index.js';\ninitializeTracing();\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/frame-manager.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { registerLinearCommands } from './commands/linear.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { createTaskCommands } from './commands/tasks.js';\nimport { createSearchCommand } from './commands/search.js';\nimport { createLogCommand } from './commands/log.js';\nimport { createContextCommands } from './commands/context.js';\nimport { createConfigCommand } from './commands/config.js';\nimport { createHandoffCommand } from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport { createStorageCommand } from './commands/storage.js';\nimport { createSkillsCommand } from './commands/skills.js';\nimport { createTestCommand } from './commands/test.js';\nimport clearCommand from './commands/clear.js';\nimport createWorkflowCommand from './commands/workflow.js';\nimport monitorCommand from './commands/monitor.js';\nimport qualityCommand from './commands/quality.js';\nimport createRalphCommand from './commands/ralph.js';\nimport serviceCommand from './commands/service.js';\nimport { registerLoginCommand } from './commands/login.js';\nimport { registerSignupCommand } from './commands/signup.js';\nimport { registerLogoutCommand, registerDbCommands } from './commands/db.js';\nimport { createSweepCommand } from './commands/sweep.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createShellCommand } from './commands/shell.js';\nimport { createAPICommand } from './commands/api.js';\nimport { createCleanupProcessesCommand } from './commands/cleanup-processes.js';\nimport { createAutoBackgroundCommand } from './commands/auto-background.js';\nimport { createSMSNotifyCommand } from './commands/sms-notify.js';\nimport { createSettingsCommand } from './commands/settings.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport {\n loadStorageConfig,\n enableChromaDB,\n getStorageModeDescription,\n} from '../core/config/storage-config.js';\nimport { loadSMSConfig } from '../hooks/sms-notify.js';\nimport { spawn } from 'child_process';\nimport { homedir } from 'os';\n\n// Read version from package.json\nimport { createRequire } from 'module';\nconst require = createRequire(import.meta.url);\nconst pkg = require('../../package.json');\nconst VERSION = pkg.version;\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\n// Auto-start webhook and ngrok if notifications are enabled\nasync function startNotificationServices(): Promise<void> {\n try {\n const config = loadSMSConfig();\n if (!config.enabled) return;\n\n const WEBHOOK_PORT = 3456;\n let webhookStarted = false;\n let ngrokStarted = false;\n\n // Check if webhook is already running\n const webhookRunning = await fetch(\n `http://localhost:${WEBHOOK_PORT}/health`\n )\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!webhookRunning) {\n // Start webhook in background using the dist path\n const webhookPath = join(__dirname, '../hooks/sms-webhook.js');\n const webhookProcess = spawn('node', [webhookPath], {\n detached: true,\n stdio: 'ignore',\n env: { ...process.env, SMS_WEBHOOK_PORT: String(WEBHOOK_PORT) },\n });\n webhookProcess.unref();\n webhookStarted = true;\n }\n\n // Check if ngrok is running\n const ngrokRunning = await fetch('http://localhost:4040/api/tunnels')\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!ngrokRunning) {\n // Start ngrok in background\n const ngrokProcess = spawn('ngrok', ['http', String(WEBHOOK_PORT)], {\n detached: true,\n stdio: 'ignore',\n });\n ngrokProcess.unref();\n ngrokStarted = true;\n }\n\n // Save ngrok URL after startup\n if (webhookStarted || ngrokStarted) {\n setTimeout(async () => {\n try {\n const tunnels = await fetch('http://localhost:4040/api/tunnels').then(\n (r) =>\n r.json() as Promise<{ tunnels: Array<{ public_url: string }> }>\n );\n const publicUrl = tunnels?.tunnels?.[0]?.public_url;\n if (publicUrl) {\n const configDir = join(homedir(), '.stackmemory');\n const configPath = join(configDir, 'ngrok-url.txt');\n const { writeFileSync, mkdirSync, existsSync } = await import('fs');\n if (!existsSync(configDir)) {\n mkdirSync(configDir, { recursive: true });\n }\n writeFileSync(configPath, publicUrl);\n console.log(\n chalk.gray(`[notify] Webhook: ${publicUrl}/sms/incoming`)\n );\n }\n } catch {\n // Ignore errors\n }\n }, 4000);\n }\n } catch {\n // Silently ignore - notifications are optional\n }\n}\n\nstartNotificationServices();\n\nprogram\n .name('stackmemory')\n .description(\n 'Lossless memory runtime for AI coding tools - organizes context as a call stack instead of linear chat logs, with team collaboration and infinite retention'\n )\n .version(VERSION);\n\nprogram\n .command('init')\n .description(\n `Initialize StackMemory in current project\n\nStorage Modes:\n SQLite (default): Local only, fast, no setup required\n ChromaDB (hybrid): Adds semantic search and cloud backup, requires API key`\n )\n .option('--sqlite', 'Use SQLite-only storage (default, skip prompts)')\n .option(\n '--chromadb',\n 'Enable ChromaDB for semantic search (prompts for API key)'\n )\n .option('--skip-storage-prompt', 'Skip storage configuration prompt')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n // Handle storage configuration\n let storageConfig = loadStorageConfig();\n const isFirstTimeSetup =\n !storageConfig.chromadb.enabled && storageConfig.mode === 'sqlite';\n\n // Skip prompts if --sqlite flag or --skip-storage-prompt\n if (options.sqlite || options.skipStoragePrompt) {\n // Use SQLite-only (default)\n console.log(chalk.gray('Using SQLite-only storage mode.'));\n } else if (options.chromadb) {\n // User explicitly requested ChromaDB, prompt for API key\n await promptAndEnableChromaDB();\n } else if (isFirstTimeSetup && process.stdin.isTTY) {\n // Interactive mode - ask user about ChromaDB\n console.log(chalk.cyan('\\nStorage Configuration'));\n console.log(chalk.gray('StackMemory supports two storage modes:\\n'));\n console.log(chalk.white(' SQLite (default):'));\n console.log(chalk.gray(' - Local storage only'));\n console.log(chalk.gray(' - Fast and simple'));\n console.log(chalk.gray(' - No external dependencies\\n'));\n console.log(chalk.white(' ChromaDB (hybrid):'));\n console.log(chalk.gray(' - Semantic search across your context'));\n console.log(chalk.gray(' - Cloud backup capability'));\n console.log(chalk.gray(' - Requires ChromaDB API key\\n'));\n\n const { enableChroma } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableChroma',\n message: 'Enable ChromaDB for semantic search? (requires API key)',\n default: false,\n },\n ]);\n\n if (enableChroma) {\n await promptAndEnableChromaDB();\n } else {\n console.log(chalk.gray('Using SQLite-only storage mode.'));\n }\n }\n\n // Initialize SQLite database\n const dbPath = join(dbDir, 'context.db');\n const db = new Database(dbPath);\n new FrameManager(db, 'cli-project');\n\n logger.info('StackMemory initialized successfully', { projectRoot });\n console.log(\n chalk.green('\\n[OK] StackMemory initialized in'),\n projectRoot\n );\n\n // Show current storage mode\n storageConfig = loadStorageConfig();\n console.log(chalk.gray(`Storage mode: ${getStorageModeDescription()}`));\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error(\n chalk.red('[ERROR] Initialization failed:'),\n (error as Error).message\n );\n process.exit(1);\n }\n });\n\n/**\n * Prompt user for ChromaDB configuration and enable it\n */\nasync function promptAndEnableChromaDB(): Promise<void> {\n const answers = await inquirer.prompt([\n {\n type: 'password',\n name: 'apiKey',\n message: 'Enter your ChromaDB API key:',\n validate: (input: string) => {\n if (!input || input.trim().length === 0) {\n return 'API key is required for ChromaDB';\n }\n return true;\n },\n },\n {\n type: 'input',\n name: 'apiUrl',\n message: 'ChromaDB API URL (press Enter for default):',\n default: 'https://api.trychroma.com',\n },\n ]);\n\n enableChromaDB({\n apiKey: answers.apiKey,\n apiUrl: answers.apiUrl,\n });\n\n console.log(chalk.green('[OK] ChromaDB enabled for semantic search.'));\n console.log(\n chalk.gray('API key saved to ~/.stackmemory/storage-config.json')\n );\n}\n\nprogram\n .command('status')\n .description('Show current StackMemory status')\n .option('--all', 'Show all active frames across sessions')\n .option('--project', 'Show all active frames in current project')\n .option('--session <id>', 'Show frames for specific session')\n .action(async (options) => {\n return trace.command('stackmemory-status', options, async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n // Check for updates and display if available\n await UpdateChecker.checkForUpdates(VERSION);\n\n // Initialize session manager and shared context\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n const session = await sessionManager.getOrCreateSession({\n projectPath: projectRoot,\n sessionId: options.session,\n });\n\n // Auto-discover shared context on startup\n const contextDiscovery = await sharedContextLayer.autoDiscoverContext();\n\n // Show context hints if available\n if (\n contextDiscovery.hasSharedContext &&\n contextDiscovery.sessionCount > 1\n ) {\n console.log(`\\n\uD83D\uDCA1 Shared Context Available:`);\n console.log(\n ` ${contextDiscovery.sessionCount} sessions with shared context`\n );\n\n if (contextDiscovery.recentPatterns.length > 0) {\n console.log(` Recent patterns:`);\n contextDiscovery.recentPatterns.slice(0, 3).forEach((p) => {\n console.log(\n ` \u2022 ${p.type}: ${p.pattern.slice(0, 50)} (${p.frequency}x)`\n );\n });\n }\n\n if (contextDiscovery.lastDecisions.length > 0) {\n console.log(\n ` Last decision: ${contextDiscovery.lastDecisions[0].decision.slice(0, 60)}`\n );\n }\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db, session.projectId);\n\n // Set query mode based on options\n if (options.all) {\n frameManager.setQueryMode(FrameQueryMode.ALL_ACTIVE);\n } else if (options.project) {\n frameManager.setQueryMode(FrameQueryMode.PROJECT_ACTIVE);\n }\n\n const activeFrames = frameManager.getActiveFramePath();\n const stackDepth = frameManager.getStackDepth();\n\n // Always get total counts across all sessions\n const totalStats = db\n .prepare(\n `\n SELECT \n COUNT(*) as total_frames,\n SUM(CASE WHEN state = 'active' THEN 1 ELSE 0 END) as active_frames,\n SUM(CASE WHEN state = 'closed' THEN 1 ELSE 0 END) as closed_frames,\n COUNT(DISTINCT run_id) as total_sessions\n FROM frames\n WHERE project_id = ?\n `\n )\n .get(session.projectId) as {\n total_frames: number;\n active_frames: number;\n closed_frames: number;\n total_sessions: number;\n };\n\n const contextCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM contexts\n `\n )\n .get() as { count: number };\n\n const eventCount = 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(session.projectId) as { count: number };\n\n console.log('\uD83D\uDCCA StackMemory Status:');\n console.log(\n ` Session: ${session.sessionId.slice(0, 8)} (${session.state}, ${Math.round((Date.now() - session.startedAt) / 1000 / 60)}min old)`\n );\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n\n // Show total database statistics\n console.log(`\\n Database Statistics (this project):`);\n console.log(\n ` Frames: ${totalStats.total_frames || 0} (${totalStats.active_frames || 0} active, ${totalStats.closed_frames || 0} closed)`\n );\n console.log(` Events: ${eventCount.count || 0}`);\n console.log(` Sessions: ${totalStats.total_sessions || 0}`);\n console.log(\n ` Cached contexts: ${contextCount.count || 0} (global)`\n );\n\n // Show recent activity\n const recentFrames = db\n .prepare(\n `\n SELECT name, type, state, datetime(created_at, 'unixepoch') as created\n FROM frames\n WHERE project_id = ?\n ORDER BY created_at DESC\n LIMIT 3\n `\n )\n .all(session.projectId) as Array<{\n name: string;\n type: string;\n state: string;\n created: string;\n }>;\n\n if (recentFrames.length > 0) {\n console.log(`\\n Recent Activity:`);\n recentFrames.forEach((f) => {\n const stateIcon = f.state === 'active' ? '\uD83D\uDFE2' : '\u26AB';\n console.log(\n ` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`\n );\n });\n }\n\n console.log(`\\n Current Session:`);\n console.log(` Stack depth: ${stackDepth}`);\n console.log(` Active frames: ${activeFrames.length}`);\n\n if (activeFrames.length > 0) {\n activeFrames.forEach((frame, i) => {\n const indent = ' ' + ' '.repeat(frame.depth || i);\n const prefix = i === 0 ? '\u2514\u2500' : ' \u2514\u2500';\n console.log(`${indent}${prefix} ${frame.name} [${frame.type}]`);\n });\n }\n\n // Show other sessions if in default mode\n if (!options.all && !options.project) {\n const otherSessions = await sessionManager.listSessions({\n projectId: session.projectId,\n state: 'active',\n });\n\n const otherActive = otherSessions.filter(\n (s) => s.sessionId !== session.sessionId\n );\n if (otherActive.length > 0) {\n console.log(`\\n Other Active Sessions (same project):`);\n otherActive.forEach((s) => {\n const age = Math.round(\n (Date.now() - s.lastActiveAt) / 1000 / 60 / 60\n );\n console.log(\n ` - ${s.sessionId.slice(0, 8)}: ${s.branch || 'main'}, ${age}h old`\n );\n });\n console.log(`\\n Tip: Use --all to see frames across sessions`);\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to get status', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n });\n\nprogram\n .command('update-check')\n .description('Check for StackMemory updates')\n .action(async () => {\n try {\n console.log('\uD83D\uDD0D Checking for updates...');\n await UpdateChecker.forceCheck(VERSION);\n } catch (error: unknown) {\n logger.error('Update check failed', error as Error);\n console.error('\u274C Update check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('progress')\n .description('Show current progress and recent changes')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const progress = new ProgressTracker(projectRoot);\n console.log(progress.getSummary());\n } catch (error: unknown) {\n logger.error('Failed to show progress', error as Error);\n console.error('\u274C Failed to show progress:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-server')\n .description('Start StackMemory MCP server for Claude Desktop')\n .option('-p, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runMCPServer } = await import('../integrations/mcp/server.js');\n\n // Set project root\n process.env['PROJECT_ROOT'] = options.project;\n\n console.log('\uD83D\uDE80 Starting StackMemory MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n\n // Check for updates silently\n UpdateChecker.checkForUpdates(VERSION, true).catch(() => {});\n\n // Start the MCP server\n await runMCPServer();\n } catch (error: unknown) {\n logger.error('Failed to start MCP server', error as Error);\n console.error('\u274C MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Add test context command\nprogram\n .command('context:test')\n .description('Test context persistence by creating sample frames')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db, 'cli-project');\n\n // Create test frames\n console.log('\uD83D\uDCDD Creating test context frames...');\n\n const rootFrame = frameManager.createFrame({\n type: 'task',\n name: 'Test Session',\n inputs: { test: true, timestamp: new Date().toISOString() },\n });\n\n const taskFrame = frameManager.createFrame({\n type: 'subtask',\n name: 'Sample Task',\n inputs: { description: 'Testing context persistence' },\n parentFrameId: rootFrame,\n });\n\n const commandFrame = frameManager.createFrame({\n type: 'tool_scope',\n name: 'test-command',\n inputs: { args: ['--test'] },\n parentFrameId: taskFrame,\n });\n\n // Add some events\n frameManager.addEvent(\n 'observation',\n {\n message: 'Test event recorded',\n },\n commandFrame\n );\n\n console.log('\u2705 Test frames created!');\n console.log(`\uD83D\uDCCA Stack depth: ${frameManager.getStackDepth()}`);\n console.log(\n `\uD83D\uDD04 Active frames: ${frameManager.getActiveFramePath().length}`\n );\n\n // Close one frame to test state changes\n frameManager.closeFrame(commandFrame);\n console.log(\n `\uD83D\uDCCA After closing command frame: depth = ${frameManager.getStackDepth()}`\n );\n\n db.close();\n } catch (error: unknown) {\n logger.error('Test context failed', error as Error);\n console.error('\u274C Test failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register project management commands\n// Register command modules\nregisterOnboardingCommand(program);\nregisterSignupCommand(program);\nregisterLoginCommand(program);\nregisterLogoutCommand(program);\nregisterDbCommands(program);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands\nregisterLinearCommands(program);\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createHandoffCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(createStorageCommand());\nprogram.addCommand(createSkillsCommand());\nprogram.addCommand(createTestCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(createWorkflowCommand());\nprogram.addCommand(monitorCommand);\nprogram.addCommand(qualityCommand);\nprogram.addCommand(createRalphCommand());\nprogram.addCommand(serviceCommand);\nprogram.addCommand(createSweepCommand());\nprogram.addCommand(createHooksCommand());\nprogram.addCommand(createShellCommand());\nprogram.addCommand(createAPICommand());\nprogram.addCommand(createCleanupProcessesCommand());\nprogram.addCommand(createAutoBackgroundCommand());\nprogram.addCommand(createSMSNotifyCommand());\nprogram.addCommand(createSettingsCommand());\n\n// Register dashboard command\nprogram\n .command('dashboard')\n .description('Display monitoring dashboard in terminal')\n .option('-w, --watch', 'Auto-refresh dashboard')\n .option('-i, --interval <seconds>', 'Refresh interval in seconds', '5')\n .action(async (options) => {\n const { dashboardCommand } = await import('./commands/dashboard.js');\n await dashboardCommand.handler(options);\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n}\n\n// Only parse when running as main module (not when imported for testing)\nconst isMainModule =\n import.meta.url === `file://${process.argv[1]}` ||\n process.argv[1]?.endsWith('/stackmemory') ||\n process.argv[1]?.endsWith('index.ts') ||\n process.argv[1]?.includes('tsx');\n\nif (isMainModule) {\n program.parse();\n}\n\nexport { program };\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory CLI\n * Command-line interface for StackMemory operations\n */\n\n// Set environment flag for CLI usage to skip async context bridge\nprocess.env['STACKMEMORY_CLI'] = 'true';\n\n// Load environment variables\nimport 'dotenv/config';\n\n// Initialize tracing system early\nimport { initializeTracing, trace } from '../core/trace/index.js';\ninitializeTracing();\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/frame-manager.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { registerLinearCommands } from './commands/linear.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { createTaskCommands } from './commands/tasks.js';\nimport { createSearchCommand } from './commands/search.js';\nimport { createLogCommand } from './commands/log.js';\nimport { createContextCommands } from './commands/context.js';\nimport { createConfigCommand } from './commands/config.js';\nimport { createHandoffCommand } from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport { createStorageCommand } from './commands/storage.js';\nimport { createSkillsCommand } from './commands/skills.js';\nimport { createTestCommand } from './commands/test.js';\nimport clearCommand from './commands/clear.js';\nimport createWorkflowCommand from './commands/workflow.js';\nimport monitorCommand from './commands/monitor.js';\nimport qualityCommand from './commands/quality.js';\nimport createRalphCommand from './commands/ralph.js';\nimport serviceCommand from './commands/service.js';\nimport { registerLoginCommand } from './commands/login.js';\nimport { registerSignupCommand } from './commands/signup.js';\nimport { registerLogoutCommand, registerDbCommands } from './commands/db.js';\nimport { createSweepCommand } from './commands/sweep.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createShellCommand } from './commands/shell.js';\nimport { createAPICommand } from './commands/api.js';\nimport { createCleanupProcessesCommand } from './commands/cleanup-processes.js';\nimport { createAutoBackgroundCommand } from './commands/auto-background.js';\nimport { createSMSNotifyCommand } from './commands/sms-notify.js';\nimport { createSettingsCommand } from './commands/settings.js';\nimport { createRetrievalCommands } from './commands/retrieval.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport {\n loadStorageConfig,\n enableChromaDB,\n getStorageModeDescription,\n} from '../core/config/storage-config.js';\nimport { loadSMSConfig } from '../hooks/sms-notify.js';\nimport { spawn } from 'child_process';\nimport { homedir } from 'os';\n\n// Read version from package.json\nimport { createRequire } from 'module';\nconst require = createRequire(import.meta.url);\nconst pkg = require('../../package.json');\nconst VERSION = pkg.version;\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\n// Auto-start webhook and ngrok if notifications are enabled\nasync function startNotificationServices(): Promise<void> {\n try {\n const config = loadSMSConfig();\n if (!config.enabled) return;\n\n const WEBHOOK_PORT = 3456;\n let webhookStarted = false;\n let ngrokStarted = false;\n\n // Check if webhook is already running\n const webhookRunning = await fetch(\n `http://localhost:${WEBHOOK_PORT}/health`\n )\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!webhookRunning) {\n // Start webhook in background using the dist path\n const webhookPath = join(__dirname, '../hooks/sms-webhook.js');\n const webhookProcess = spawn('node', [webhookPath], {\n detached: true,\n stdio: 'ignore',\n env: { ...process.env, SMS_WEBHOOK_PORT: String(WEBHOOK_PORT) },\n });\n webhookProcess.unref();\n webhookStarted = true;\n }\n\n // Check if ngrok is running\n const ngrokRunning = await fetch('http://localhost:4040/api/tunnels')\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!ngrokRunning) {\n // Start ngrok in background\n const ngrokProcess = spawn('ngrok', ['http', String(WEBHOOK_PORT)], {\n detached: true,\n stdio: 'ignore',\n });\n ngrokProcess.unref();\n ngrokStarted = true;\n }\n\n // Save ngrok URL after startup\n if (webhookStarted || ngrokStarted) {\n setTimeout(async () => {\n try {\n const tunnels = await fetch('http://localhost:4040/api/tunnels').then(\n (r) =>\n r.json() as Promise<{ tunnels: Array<{ public_url: string }> }>\n );\n const publicUrl = tunnels?.tunnels?.[0]?.public_url;\n if (publicUrl) {\n const configDir = join(homedir(), '.stackmemory');\n const configPath = join(configDir, 'ngrok-url.txt');\n const { writeFileSync, mkdirSync, existsSync } = await import('fs');\n if (!existsSync(configDir)) {\n mkdirSync(configDir, { recursive: true });\n }\n writeFileSync(configPath, publicUrl);\n console.log(\n chalk.gray(`[notify] Webhook: ${publicUrl}/sms/incoming`)\n );\n }\n } catch {\n // Ignore errors\n }\n }, 4000);\n }\n } catch {\n // Silently ignore - notifications are optional\n }\n}\n\nstartNotificationServices();\n\nprogram\n .name('stackmemory')\n .description(\n 'Lossless memory runtime for AI coding tools - organizes context as a call stack instead of linear chat logs, with team collaboration and infinite retention'\n )\n .version(VERSION);\n\nprogram\n .command('init')\n .description(\n `Initialize StackMemory in current project\n\nStorage Modes:\n SQLite (default): Local only, fast, no setup required\n ChromaDB (hybrid): Adds semantic search and cloud backup, requires API key`\n )\n .option('--sqlite', 'Use SQLite-only storage (default, skip prompts)')\n .option(\n '--chromadb',\n 'Enable ChromaDB for semantic search (prompts for API key)'\n )\n .option('--skip-storage-prompt', 'Skip storage configuration prompt')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n // Handle storage configuration\n let storageConfig = loadStorageConfig();\n const isFirstTimeSetup =\n !storageConfig.chromadb.enabled && storageConfig.mode === 'sqlite';\n\n // Skip prompts if --sqlite flag or --skip-storage-prompt\n if (options.sqlite || options.skipStoragePrompt) {\n // Use SQLite-only (default)\n console.log(chalk.gray('Using SQLite-only storage mode.'));\n } else if (options.chromadb) {\n // User explicitly requested ChromaDB, prompt for API key\n await promptAndEnableChromaDB();\n } else if (isFirstTimeSetup && process.stdin.isTTY) {\n // Interactive mode - ask user about ChromaDB\n console.log(chalk.cyan('\\nStorage Configuration'));\n console.log(chalk.gray('StackMemory supports two storage modes:\\n'));\n console.log(chalk.white(' SQLite (default):'));\n console.log(chalk.gray(' - Local storage only'));\n console.log(chalk.gray(' - Fast and simple'));\n console.log(chalk.gray(' - No external dependencies\\n'));\n console.log(chalk.white(' ChromaDB (hybrid):'));\n console.log(chalk.gray(' - Semantic search across your context'));\n console.log(chalk.gray(' - Cloud backup capability'));\n console.log(chalk.gray(' - Requires ChromaDB API key\\n'));\n\n const { enableChroma } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableChroma',\n message: 'Enable ChromaDB for semantic search? (requires API key)',\n default: false,\n },\n ]);\n\n if (enableChroma) {\n await promptAndEnableChromaDB();\n } else {\n console.log(chalk.gray('Using SQLite-only storage mode.'));\n }\n }\n\n // Initialize SQLite database\n const dbPath = join(dbDir, 'context.db');\n const db = new Database(dbPath);\n new FrameManager(db, 'cli-project');\n\n logger.info('StackMemory initialized successfully', { projectRoot });\n console.log(\n chalk.green('\\n[OK] StackMemory initialized in'),\n projectRoot\n );\n\n // Show current storage mode\n storageConfig = loadStorageConfig();\n console.log(chalk.gray(`Storage mode: ${getStorageModeDescription()}`));\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error(\n chalk.red('[ERROR] Initialization failed:'),\n (error as Error).message\n );\n process.exit(1);\n }\n });\n\n/**\n * Prompt user for ChromaDB configuration and enable it\n */\nasync function promptAndEnableChromaDB(): Promise<void> {\n const answers = await inquirer.prompt([\n {\n type: 'password',\n name: 'apiKey',\n message: 'Enter your ChromaDB API key:',\n validate: (input: string) => {\n if (!input || input.trim().length === 0) {\n return 'API key is required for ChromaDB';\n }\n return true;\n },\n },\n {\n type: 'input',\n name: 'apiUrl',\n message: 'ChromaDB API URL (press Enter for default):',\n default: 'https://api.trychroma.com',\n },\n ]);\n\n enableChromaDB({\n apiKey: answers.apiKey,\n apiUrl: answers.apiUrl,\n });\n\n console.log(chalk.green('[OK] ChromaDB enabled for semantic search.'));\n console.log(\n chalk.gray('API key saved to ~/.stackmemory/storage-config.json')\n );\n}\n\nprogram\n .command('status')\n .description('Show current StackMemory status')\n .option('--all', 'Show all active frames across sessions')\n .option('--project', 'Show all active frames in current project')\n .option('--session <id>', 'Show frames for specific session')\n .action(async (options) => {\n return trace.command('stackmemory-status', options, async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n // Check for updates and display if available\n await UpdateChecker.checkForUpdates(VERSION);\n\n // Initialize session manager and shared context\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n const session = await sessionManager.getOrCreateSession({\n projectPath: projectRoot,\n sessionId: options.session,\n });\n\n // Auto-discover shared context on startup\n const contextDiscovery = await sharedContextLayer.autoDiscoverContext();\n\n // Show context hints if available\n if (\n contextDiscovery.hasSharedContext &&\n contextDiscovery.sessionCount > 1\n ) {\n console.log(`\\n\uD83D\uDCA1 Shared Context Available:`);\n console.log(\n ` ${contextDiscovery.sessionCount} sessions with shared context`\n );\n\n if (contextDiscovery.recentPatterns.length > 0) {\n console.log(` Recent patterns:`);\n contextDiscovery.recentPatterns.slice(0, 3).forEach((p) => {\n console.log(\n ` \u2022 ${p.type}: ${p.pattern.slice(0, 50)} (${p.frequency}x)`\n );\n });\n }\n\n if (contextDiscovery.lastDecisions.length > 0) {\n console.log(\n ` Last decision: ${contextDiscovery.lastDecisions[0].decision.slice(0, 60)}`\n );\n }\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db, session.projectId);\n\n // Set query mode based on options\n if (options.all) {\n frameManager.setQueryMode(FrameQueryMode.ALL_ACTIVE);\n } else if (options.project) {\n frameManager.setQueryMode(FrameQueryMode.PROJECT_ACTIVE);\n }\n\n const activeFrames = frameManager.getActiveFramePath();\n const stackDepth = frameManager.getStackDepth();\n\n // Always get total counts across all sessions\n const totalStats = db\n .prepare(\n `\n SELECT \n COUNT(*) as total_frames,\n SUM(CASE WHEN state = 'active' THEN 1 ELSE 0 END) as active_frames,\n SUM(CASE WHEN state = 'closed' THEN 1 ELSE 0 END) as closed_frames,\n COUNT(DISTINCT run_id) as total_sessions\n FROM frames\n WHERE project_id = ?\n `\n )\n .get(session.projectId) as {\n total_frames: number;\n active_frames: number;\n closed_frames: number;\n total_sessions: number;\n };\n\n const contextCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM contexts\n `\n )\n .get() as { count: number };\n\n const eventCount = 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(session.projectId) as { count: number };\n\n console.log('\uD83D\uDCCA StackMemory Status:');\n console.log(\n ` Session: ${session.sessionId.slice(0, 8)} (${session.state}, ${Math.round((Date.now() - session.startedAt) / 1000 / 60)}min old)`\n );\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n\n // Show total database statistics\n console.log(`\\n Database Statistics (this project):`);\n console.log(\n ` Frames: ${totalStats.total_frames || 0} (${totalStats.active_frames || 0} active, ${totalStats.closed_frames || 0} closed)`\n );\n console.log(` Events: ${eventCount.count || 0}`);\n console.log(` Sessions: ${totalStats.total_sessions || 0}`);\n console.log(\n ` Cached contexts: ${contextCount.count || 0} (global)`\n );\n\n // Show recent activity\n const recentFrames = db\n .prepare(\n `\n SELECT name, type, state, datetime(created_at, 'unixepoch') as created\n FROM frames\n WHERE project_id = ?\n ORDER BY created_at DESC\n LIMIT 3\n `\n )\n .all(session.projectId) as Array<{\n name: string;\n type: string;\n state: string;\n created: string;\n }>;\n\n if (recentFrames.length > 0) {\n console.log(`\\n Recent Activity:`);\n recentFrames.forEach((f) => {\n const stateIcon = f.state === 'active' ? '\uD83D\uDFE2' : '\u26AB';\n console.log(\n ` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`\n );\n });\n }\n\n console.log(`\\n Current Session:`);\n console.log(` Stack depth: ${stackDepth}`);\n console.log(` Active frames: ${activeFrames.length}`);\n\n if (activeFrames.length > 0) {\n activeFrames.forEach((frame, i) => {\n const indent = ' ' + ' '.repeat(frame.depth || i);\n const prefix = i === 0 ? '\u2514\u2500' : ' \u2514\u2500';\n console.log(`${indent}${prefix} ${frame.name} [${frame.type}]`);\n });\n }\n\n // Show other sessions if in default mode\n if (!options.all && !options.project) {\n const otherSessions = await sessionManager.listSessions({\n projectId: session.projectId,\n state: 'active',\n });\n\n const otherActive = otherSessions.filter(\n (s) => s.sessionId !== session.sessionId\n );\n if (otherActive.length > 0) {\n console.log(`\\n Other Active Sessions (same project):`);\n otherActive.forEach((s) => {\n const age = Math.round(\n (Date.now() - s.lastActiveAt) / 1000 / 60 / 60\n );\n console.log(\n ` - ${s.sessionId.slice(0, 8)}: ${s.branch || 'main'}, ${age}h old`\n );\n });\n console.log(`\\n Tip: Use --all to see frames across sessions`);\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to get status', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n });\n\nprogram\n .command('update-check')\n .description('Check for StackMemory updates')\n .action(async () => {\n try {\n console.log('\uD83D\uDD0D Checking for updates...');\n await UpdateChecker.forceCheck(VERSION);\n } catch (error: unknown) {\n logger.error('Update check failed', error as Error);\n console.error('\u274C Update check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('progress')\n .description('Show current progress and recent changes')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const progress = new ProgressTracker(projectRoot);\n console.log(progress.getSummary());\n } catch (error: unknown) {\n logger.error('Failed to show progress', error as Error);\n console.error('\u274C Failed to show progress:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-server')\n .description('Start StackMemory MCP server for Claude Desktop')\n .option('-p, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runMCPServer } = await import('../integrations/mcp/server.js');\n\n // Set project root\n process.env['PROJECT_ROOT'] = options.project;\n\n console.log('\uD83D\uDE80 Starting StackMemory MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n\n // Check for updates silently\n UpdateChecker.checkForUpdates(VERSION, true).catch(() => {});\n\n // Start the MCP server\n await runMCPServer();\n } catch (error: unknown) {\n logger.error('Failed to start MCP server', error as Error);\n console.error('\u274C MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Add test context command\nprogram\n .command('context:test')\n .description('Test context persistence by creating sample frames')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db, 'cli-project');\n\n // Create test frames\n console.log('\uD83D\uDCDD Creating test context frames...');\n\n const rootFrame = frameManager.createFrame({\n type: 'task',\n name: 'Test Session',\n inputs: { test: true, timestamp: new Date().toISOString() },\n });\n\n const taskFrame = frameManager.createFrame({\n type: 'subtask',\n name: 'Sample Task',\n inputs: { description: 'Testing context persistence' },\n parentFrameId: rootFrame,\n });\n\n const commandFrame = frameManager.createFrame({\n type: 'tool_scope',\n name: 'test-command',\n inputs: { args: ['--test'] },\n parentFrameId: taskFrame,\n });\n\n // Add some events\n frameManager.addEvent(\n 'observation',\n {\n message: 'Test event recorded',\n },\n commandFrame\n );\n\n console.log('\u2705 Test frames created!');\n console.log(`\uD83D\uDCCA Stack depth: ${frameManager.getStackDepth()}`);\n console.log(\n `\uD83D\uDD04 Active frames: ${frameManager.getActiveFramePath().length}`\n );\n\n // Close one frame to test state changes\n frameManager.closeFrame(commandFrame);\n console.log(\n `\uD83D\uDCCA After closing command frame: depth = ${frameManager.getStackDepth()}`\n );\n\n db.close();\n } catch (error: unknown) {\n logger.error('Test context failed', error as Error);\n console.error('\u274C Test failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register project management commands\n// Register command modules\nregisterOnboardingCommand(program);\nregisterSignupCommand(program);\nregisterLoginCommand(program);\nregisterLogoutCommand(program);\nregisterDbCommands(program);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands\nregisterLinearCommands(program);\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createHandoffCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(createStorageCommand());\nprogram.addCommand(createSkillsCommand());\nprogram.addCommand(createTestCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(createWorkflowCommand());\nprogram.addCommand(monitorCommand);\nprogram.addCommand(qualityCommand);\nprogram.addCommand(createRalphCommand());\nprogram.addCommand(serviceCommand);\nprogram.addCommand(createSweepCommand());\nprogram.addCommand(createHooksCommand());\nprogram.addCommand(createShellCommand());\nprogram.addCommand(createAPICommand());\nprogram.addCommand(createCleanupProcessesCommand());\nprogram.addCommand(createAutoBackgroundCommand());\nprogram.addCommand(createSMSNotifyCommand());\nprogram.addCommand(createSettingsCommand());\nprogram.addCommand(createRetrievalCommands());\n\n// Register dashboard command\nprogram\n .command('dashboard')\n .description('Display monitoring dashboard in terminal')\n .option('-w, --watch', 'Auto-refresh dashboard')\n .option('-i, --interval <seconds>', 'Refresh interval in seconds', '5')\n .action(async (options) => {\n const { dashboardCommand } = await import('./commands/dashboard.js');\n await dashboardCommand.handler(options);\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n}\n\n// Only parse when running as main module (not when imported for testing)\nconst isMainModule =\n import.meta.url === `file://${process.argv[1]}` ||\n process.argv[1]?.endsWith('/stackmemory') ||\n process.argv[1]?.endsWith('index.ts') ||\n process.argv[1]?.includes('tsx');\n\nif (isMainModule) {\n program.parse();\n}\n\nexport { program };\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["require", "mkdirSync", "existsSync"]
|
|
7
7
|
}
|
|
@@ -10,6 +10,9 @@ import {
|
|
|
10
10
|
import { logger } from "../monitoring/logger.js";
|
|
11
11
|
import { LazyContextLoader } from "../performance/lazy-context-loader.js";
|
|
12
12
|
import { ContextCache } from "../performance/context-cache.js";
|
|
13
|
+
import { createLLMProvider } from "./llm-provider.js";
|
|
14
|
+
import { RetrievalAuditStore } from "./retrieval-audit.js";
|
|
15
|
+
import { LLMProvider as LLMProvider2 } from "./llm-provider.js";
|
|
13
16
|
class HeuristicAnalyzer {
|
|
14
17
|
analyze(query, summary, parsedQuery) {
|
|
15
18
|
const framesToRetrieve = [];
|
|
@@ -165,12 +168,20 @@ class LLMContextRetrieval {
|
|
|
165
168
|
projectId;
|
|
166
169
|
lazyLoader;
|
|
167
170
|
contextCache;
|
|
171
|
+
auditStore;
|
|
172
|
+
enableAudit;
|
|
168
173
|
constructor(db, frameManager, projectId, config = {}, llmProvider) {
|
|
169
174
|
this.db = db;
|
|
170
175
|
this.frameManager = frameManager;
|
|
171
176
|
this.projectId = projectId;
|
|
172
177
|
this.config = { ...DEFAULT_RETRIEVAL_CONFIG, ...config };
|
|
173
|
-
this.llmProvider = llmProvider;
|
|
178
|
+
this.llmProvider = llmProvider ?? createLLMProvider();
|
|
179
|
+
if (this.llmProvider) {
|
|
180
|
+
logger.info("LLM provider configured for context retrieval", {
|
|
181
|
+
projectId,
|
|
182
|
+
provider: this.config.llmConfig.provider
|
|
183
|
+
});
|
|
184
|
+
}
|
|
174
185
|
this.summaryGenerator = new CompressedSummaryGenerator(
|
|
175
186
|
db,
|
|
176
187
|
frameManager,
|
|
@@ -179,6 +190,8 @@ class LLMContextRetrieval {
|
|
|
179
190
|
);
|
|
180
191
|
this.queryParser = new QueryParser();
|
|
181
192
|
this.heuristicAnalyzer = new HeuristicAnalyzer();
|
|
193
|
+
this.auditStore = new RetrievalAuditStore(db, projectId);
|
|
194
|
+
this.enableAudit = true;
|
|
182
195
|
this.lazyLoader = new LazyContextLoader(db, projectId);
|
|
183
196
|
this.contextCache = new ContextCache({
|
|
184
197
|
maxSize: 50 * 1024 * 1024,
|
|
@@ -189,6 +202,18 @@ class LLMContextRetrieval {
|
|
|
189
202
|
});
|
|
190
203
|
this.contextCache.startCleanup(6e4);
|
|
191
204
|
}
|
|
205
|
+
/**
|
|
206
|
+
* Get the audit store for external access
|
|
207
|
+
*/
|
|
208
|
+
getAuditStore() {
|
|
209
|
+
return this.auditStore;
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* Check if LLM provider is available
|
|
213
|
+
*/
|
|
214
|
+
hasLLMProvider() {
|
|
215
|
+
return !!this.llmProvider;
|
|
216
|
+
}
|
|
192
217
|
/**
|
|
193
218
|
* Retrieve context based on query using LLM analysis (with caching)
|
|
194
219
|
*/
|
|
@@ -255,6 +280,14 @@ class LLMContextRetrieval {
|
|
|
255
280
|
},
|
|
256
281
|
metadata
|
|
257
282
|
};
|
|
283
|
+
if (this.enableAudit) {
|
|
284
|
+
const provider = analysis.metadata.fallbackUsed ? "heuristic" : this.llmProvider ? "anthropic" : "heuristic";
|
|
285
|
+
this.auditStore.record(query, analysis, {
|
|
286
|
+
tokensUsed,
|
|
287
|
+
tokenBudget,
|
|
288
|
+
provider
|
|
289
|
+
});
|
|
290
|
+
}
|
|
258
291
|
if (!options.forceRefresh) {
|
|
259
292
|
const cacheKey = `${query}:${tokenBudget}:${JSON.stringify(options.hints || {})}`;
|
|
260
293
|
this.contextCache.set(cacheKey, result, {
|
|
@@ -576,6 +609,7 @@ Respond with only the JSON object, no other text.`;
|
|
|
576
609
|
}
|
|
577
610
|
}
|
|
578
611
|
export {
|
|
579
|
-
LLMContextRetrieval
|
|
612
|
+
LLMContextRetrieval,
|
|
613
|
+
LLMProvider2 as LLMProvider
|
|
580
614
|
};
|
|
581
615
|
//# sourceMappingURL=llm-context-retrieval.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
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/frame-manager.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';\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 * 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\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 this.llmProvider = llmProvider;\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 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 * 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 // 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": []
|
|
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/frame-manager.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 for external use\nexport { 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": ["LLMProvider"]
|
|
7
7
|
}
|