@stackmemoryai/stackmemory 0.5.64 → 0.5.67
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +69 -346
- package/bin/claude-sm +1 -1
- package/bin/claude-smd +1 -1
- package/bin/codex-sm +6 -0
- package/bin/codex-smd +1 -1
- package/bin/opencode-sm +1 -1
- package/dist/src/cli/claude-sm.js +162 -25
- package/dist/src/cli/claude-sm.js.map +2 -2
- package/dist/src/cli/commands/ping.js +14 -0
- package/dist/src/cli/commands/ping.js.map +7 -0
- package/dist/src/cli/commands/ralph.js +103 -1
- package/dist/src/cli/commands/ralph.js.map +2 -2
- package/dist/src/cli/commands/retrieval.js +1 -1
- package/dist/src/cli/commands/retrieval.js.map +2 -2
- package/dist/src/cli/commands/skills.js +300 -1
- package/dist/src/cli/commands/skills.js.map +2 -2
- package/dist/src/cli/index.js +362 -20
- package/dist/src/cli/index.js.map +2 -2
- package/dist/src/core/digest/types.js +1 -1
- package/dist/src/core/digest/types.js.map +1 -1
- package/dist/src/core/extensions/provider-adapter.js +2 -5
- package/dist/src/core/extensions/provider-adapter.js.map +2 -2
- package/dist/src/core/retrieval/llm-provider.js +2 -2
- package/dist/src/core/retrieval/llm-provider.js.map +1 -1
- package/dist/src/core/retrieval/types.js +1 -1
- package/dist/src/core/retrieval/types.js.map +1 -1
- package/dist/src/features/sweep/pty-wrapper.js +15 -5
- package/dist/src/features/sweep/pty-wrapper.js.map +2 -2
- package/dist/src/features/workers/tmux-manager.js +71 -0
- package/dist/src/features/workers/tmux-manager.js.map +7 -0
- package/dist/src/features/workers/worker-registry.js +52 -0
- package/dist/src/features/workers/worker-registry.js.map +7 -0
- package/dist/src/integrations/linear/webhook-handler.js +82 -0
- package/dist/src/integrations/linear/webhook-handler.js.map +2 -2
- package/dist/src/integrations/mcp/pending-utils.js +33 -0
- package/dist/src/integrations/mcp/pending-utils.js.map +7 -0
- package/dist/src/integrations/mcp/server.js +571 -1
- package/dist/src/integrations/mcp/server.js.map +2 -2
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js +2 -2
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js.map +2 -2
- package/dist/src/orchestrators/multimodal/constants.js +17 -0
- package/dist/src/orchestrators/multimodal/constants.js.map +7 -0
- package/dist/src/orchestrators/multimodal/harness.js +292 -0
- package/dist/src/orchestrators/multimodal/harness.js.map +7 -0
- package/dist/src/orchestrators/multimodal/providers.js +98 -0
- package/dist/src/orchestrators/multimodal/providers.js.map +7 -0
- package/dist/src/orchestrators/multimodal/types.js +5 -0
- package/dist/src/orchestrators/multimodal/types.js.map +7 -0
- package/dist/src/orchestrators/multimodal/utils.js +25 -0
- package/dist/src/orchestrators/multimodal/utils.js.map +7 -0
- package/dist/src/skills/claude-skills.js +116 -1
- package/dist/src/skills/claude-skills.js.map +2 -2
- package/dist/src/skills/linear-task-runner.js +262 -0
- package/dist/src/skills/linear-task-runner.js.map +7 -0
- package/dist/src/skills/recursive-agent-orchestrator.js +114 -85
- package/dist/src/skills/recursive-agent-orchestrator.js.map +2 -2
- package/dist/src/skills/spec-generator-skill.js +441 -0
- package/dist/src/skills/spec-generator-skill.js.map +7 -0
- package/package.json +14 -9
- package/scripts/claude-code-wrapper.sh +18 -30
- package/scripts/demos/ralph-integration-demo.ts +14 -13
- package/scripts/demos/trace-demo.ts +7 -21
- package/scripts/demos/trace-test.ts +20 -8
- package/scripts/install-claude-hooks.sh +2 -2
- package/scripts/verify-dist.cjs +83 -0
- package/templates/claude-hooks/post-edit-sweep.js +7 -10
|
@@ -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 (quiet mode to suppress logging)\nimport { config as loadDotenv } from 'dotenv';\nloadDotenv({ quiet: true });\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/index.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 { createSessionCommands } from './commands/session.js';\nimport { isFeatureEnabled, isLocalOnly } from '../core/config/feature-flags.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 {\n createCaptureCommand,\n createRestoreCommand,\n createAutoCaptureCommand,\n} from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport clearCommand from './commands/clear.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 { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.js';\nimport { createSweepCommand } from './commands/sweep.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 { createSettingsCommand } from './commands/settings.js';\nimport { createRetrievalCommands } from './commands/retrieval.js';\nimport { createDiscoveryCommands } from './commands/discovery.js';\nimport { createModelCommand } from './commands/model.js';\nimport { registerSetupCommands } from './commands/setup.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 { enableChromaDB } from '../core/config/storage-config.js';\nimport { spawn } from 'child_process';\nimport { homedir } from 'os';\n\n// Read version from package.json - works from both src/ and dist/src/\nimport { createRequire } from 'module';\nimport { fileURLToPath } from 'url';\nimport * as pathModule from 'path';\nconst localRequire = createRequire(import.meta.url);\nconst currentFilePath = fileURLToPath(import.meta.url);\nconst currentDirPath = pathModule.dirname(currentFilePath);\n\n// Find package.json by walking up directories\nfunction findPackageJson(): { version: string } {\n let dir = currentDirPath;\n for (let i = 0; i < 5; i++) {\n const pkgPath = pathModule.join(dir, 'package.json');\n try {\n return localRequire(pkgPath);\n } catch {\n dir = pathModule.dirname(dir);\n }\n }\n return { version: '0.0.0' };\n}\nconst VERSION = findPackageJson().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 // Skip in local-only mode\n if (isLocalOnly() || !isFeatureEnabled('whatsapp')) return;\n\n try {\n const { loadSMSConfig } = await import('../hooks/sms-notify.js');\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 (zero-config by default)'\n )\n .option('-i, --interactive', 'Interactive mode with configuration prompts')\n .option(\n '--chromadb',\n 'Enable ChromaDB for semantic search (prompts for API key)'\n )\n .option('--daemon', 'Start the background daemon after initialization')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n // Check if already initialized\n const alreadyInit = existsSync(join(dbDir, 'context.db'));\n if (alreadyInit && !options.interactive) {\n console.log(chalk.yellow('StackMemory already initialized.'));\n console.log(chalk.gray('Run with --interactive to reconfigure.'));\n return;\n }\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n // Zero-config by default - just use SQLite, no questions\n if (options.chromadb) {\n await promptAndEnableChromaDB();\n } else if (options.interactive && process.stdin.isTTY) {\n // Only ask questions in interactive mode\n console.log(chalk.cyan('\\nStorage Configuration'));\n console.log(\n chalk.gray('SQLite (default) is fast and requires no setup.')\n );\n console.log(\n chalk.gray('ChromaDB adds semantic search but requires an API key.\\n')\n );\n\n const { enableChroma } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableChroma',\n message: 'Enable ChromaDB for semantic search?',\n default: false,\n },\n ]);\n\n if (enableChroma) {\n await promptAndEnableChromaDB();\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(chalk.green('\\n[OK] StackMemory initialized'));\n console.log(chalk.gray(` Project: ${projectRoot}`));\n console.log(chalk.gray(` Storage: SQLite (local)`));\n\n db.close();\n\n // Install daemon service if requested\n if (options.daemon) {\n console.log(chalk.cyan('\\nInstalling background service...'));\n try {\n const { installServiceSilent } =\n await import('./commands/service.js');\n const success = await installServiceSilent();\n if (success) {\n console.log(chalk.green('[OK] Guardian service installed'));\n console.log(chalk.gray(' Auto-starts on login'));\n console.log(\n chalk.gray(' Check status: stackmemory service status')\n );\n } else {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n } catch {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n }\n\n // Show next steps\n console.log(chalk.cyan('\\nNext steps:'));\n console.log(\n chalk.white(' 1. stackmemory setup-mcp') +\n chalk.gray(' # Configure Claude Code integration')\n );\n console.log(\n chalk.white(' 2. stackmemory status') +\n chalk.gray(' # Check status')\n );\n console.log(\n chalk.white(' 3. stackmemory doctor') +\n chalk.gray(' # Diagnose issues')\n );\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error(chalk.red('\\n[ERROR] Initialization failed'));\n console.error(chalk.gray(` Reason: ${(error as Error).message}`));\n console.error(\n chalk.gray(\n ' Fix: Ensure you have write permissions to the current directory'\n )\n );\n console.error(chalk.gray(' Run: stackmemory doctor'));\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\nprogram\n .command('mcp-remote')\n .description(\n 'Start StackMemory Remote MCP server (HTTP/SSE) for Claude.ai web'\n )\n .option('-p, --port <number>', 'Port to listen on', '3847')\n .option('-d, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runRemoteMCPServer } =\n await import('../integrations/mcp/remote-server.js');\n\n const port = parseInt(options.port, 10);\n\n console.log('Starting StackMemory Remote MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n console.log('');\n\n await runRemoteMCPServer(port, options.project);\n\n console.log('');\n console.log('For Claude.ai web connector:');\n console.log(` URL: http://localhost:${port}/sse`);\n console.log('');\n console.log('For external access (ngrok):');\n console.log(` ngrok http ${port}`);\n console.log(' Then use the ngrok URL + /sse in Claude.ai');\n } catch (error: unknown) {\n logger.error('Failed to start remote MCP server', error as Error);\n console.error('Remote 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 (lazy-loaded, optional)\nif (isFeatureEnabled('linear')) {\n import('./commands/linear.js')\n .then(({ registerLinearCommands }) => registerLinearCommands(program))\n .catch(() => {\n // Linear integration not available - silently skip\n });\n}\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(createCaptureCommand());\nprogram.addCommand(createRestoreCommand());\nprogram.addCommand(createAutoCaptureCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(serviceCommand);\nprogram.addCommand(createHooksCommand());\n\n// Register skills commands (optional, lazy-loaded)\nif (isFeatureEnabled('skills')) {\n import('./commands/skills.js')\n .then(({ createSkillsCommand }) =>\n program.addCommand(createSkillsCommand())\n )\n .catch(() => {\n // Skills integration not available - silently skip\n });\n}\n\n// Register ralph commands (feature-flagged, lazy-loaded)\n// Default ON for development, OFF for npm package users\nif (isFeatureEnabled('ralph')) {\n import('./commands/ralph.js')\n .then(({ default: createRalphCommand }) =>\n program.addCommand(createRalphCommand())\n )\n .catch(() => {\n // Ralph integration not available - silently skip\n });\n}\nprogram.addCommand(createDaemonCommand());\nprogram.addCommand(createSweepCommand());\nprogram.addCommand(createShellCommand());\nprogram.addCommand(createAPICommand());\nprogram.addCommand(createCleanupProcessesCommand());\nprogram.addCommand(createAutoBackgroundCommand());\nprogram.addCommand(createSettingsCommand());\n\n// Register WhatsApp/SMS commands (lazy-loaded, optional)\nif (isFeatureEnabled('whatsapp')) {\n import('./commands/sms-notify.js')\n .then(({ createSMSNotifyCommand }) =>\n program.addCommand(createSMSNotifyCommand())\n )\n .catch(() => {\n // WhatsApp integration not available - silently skip\n });\n}\nprogram.addCommand(createRetrievalCommands());\nprogram.addCommand(createDiscoveryCommands());\nprogram.addCommand(createModelCommand());\n\n// Register setup and diagnostic commands\nregisterSetupCommands(program);\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 try {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n } catch {\n // Silently fail if database initialization fails (e.g., native module version mismatch)\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 (quiet mode to suppress logging)\nimport { config as loadDotenv } from 'dotenv';\nloadDotenv({ quiet: true });\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/index.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 { createSessionCommands } from './commands/session.js';\nimport { isFeatureEnabled, isLocalOnly } from '../core/config/feature-flags.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 {\n createCaptureCommand,\n createRestoreCommand,\n createAutoCaptureCommand,\n} from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport clearCommand from './commands/clear.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 { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.js';\nimport { createSweepCommand } from './commands/sweep.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 { createSettingsCommand } from './commands/settings.js';\nimport { createRetrievalCommands } from './commands/retrieval.js';\nimport { createDiscoveryCommands } from './commands/discovery.js';\nimport { createModelCommand } from './commands/model.js';\nimport { registerSetupCommands } from './commands/setup.js';\nimport { createPingCommand } from './commands/ping.js';\nimport chalk from 'chalk';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { filterPending } from '../integrations/mcp/pending-utils.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\nimport inquirer from 'inquirer';\nimport { enableChromaDB } from '../core/config/storage-config.js';\nimport { spawn } from 'child_process';\nimport type {\n HarnessResult,\n PlanStep,\n} from '../orchestrators/multimodal/types.js';\nimport { homedir } from 'os';\n\n// Read version from package.json - works from both src/ and dist/src/\nimport { createRequire } from 'module';\nimport { fileURLToPath } from 'url';\nimport * as pathModule from 'path';\nconst localRequire = createRequire(import.meta.url);\nconst currentFilePath = fileURLToPath(import.meta.url);\nconst currentDirPath = pathModule.dirname(currentFilePath);\n\n// Find package.json by walking up directories\nfunction findPackageJson(): { version: string } {\n let dir = currentDirPath;\n for (let i = 0; i < 5; i++) {\n const pkgPath = pathModule.join(dir, 'package.json');\n try {\n return localRequire(pkgPath);\n } catch {\n dir = pathModule.dirname(dir);\n }\n }\n return { version: '0.0.0' };\n}\nconst VERSION = findPackageJson().version;\n\n// Lazy DB opener to avoid loading native module at import time (test-friendly)\nasync function openDatabase(dbPath: string) {\n const { default: Database } = await import('better-sqlite3');\n return new Database(dbPath);\n}\n\nfunction isTestEnv(): boolean {\n return (\n process.env['VITEST'] === 'true' ||\n process.env['NODE_ENV'] === 'test' ||\n process.env['STACKMEMORY_TEST_SKIP_DB'] === '1'\n );\n}\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 // Skip in local-only mode\n if (isLocalOnly() || !isFeatureEnabled('whatsapp')) return;\n\n try {\n const { loadSMSConfig } = await import('../hooks/sms-notify.js');\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 (zero-config by default)'\n )\n .option('-i, --interactive', 'Interactive mode with configuration prompts')\n .option(\n '--chromadb',\n 'Enable ChromaDB for semantic search (prompts for API key)'\n )\n .option('--daemon', 'Start the background daemon after initialization')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n // Check if already initialized\n const alreadyInit = existsSync(join(dbDir, 'context.db'));\n if (alreadyInit && !options.interactive) {\n console.log(chalk.yellow('StackMemory already initialized.'));\n console.log(chalk.gray('Run with --interactive to reconfigure.'));\n return;\n }\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n // Zero-config by default - just use SQLite, no questions\n if (options.chromadb) {\n await promptAndEnableChromaDB();\n } else if (options.interactive && process.stdin.isTTY) {\n // Only ask questions in interactive mode\n console.log(chalk.cyan('\\nStorage Configuration'));\n console.log(\n chalk.gray('SQLite (default) is fast and requires no setup.')\n );\n console.log(\n chalk.gray('ChromaDB adds semantic search but requires an API key.\\n')\n );\n\n const { enableChroma } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableChroma',\n message: 'Enable ChromaDB for semantic search?',\n default: false,\n },\n ]);\n\n if (enableChroma) {\n await promptAndEnableChromaDB();\n }\n }\n\n // Initialize SQLite database (skip in test env)\n const dbPath = join(dbDir, 'context.db');\n if (!isTestEnv()) {\n const db = await openDatabase(dbPath);\n new FrameManager(db, 'cli-project');\n db.close();\n }\n\n logger.info('StackMemory initialized successfully', { projectRoot });\n console.log(chalk.green('\\n[OK] StackMemory initialized'));\n console.log(chalk.gray(` Project: ${projectRoot}`));\n console.log(chalk.gray(` Storage: SQLite (local)`));\n\n // Install daemon service if requested\n if (options.daemon) {\n console.log(chalk.cyan('\\nInstalling background service...'));\n try {\n const { installServiceSilent } =\n await import('./commands/service.js');\n const success = await installServiceSilent();\n if (success) {\n console.log(chalk.green('[OK] Guardian service installed'));\n console.log(chalk.gray(' Auto-starts on login'));\n console.log(\n chalk.gray(' Check status: stackmemory service status')\n );\n } else {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n } catch {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n }\n\n // Show next steps\n console.log(chalk.cyan('\\nNext steps:'));\n console.log(\n chalk.white(' 1. stackmemory setup-mcp') +\n chalk.gray(' # Configure Claude Code integration')\n );\n console.log(\n chalk.white(' 2. stackmemory status') +\n chalk.gray(' # Check status')\n );\n console.log(\n chalk.white(' 3. stackmemory doctor') +\n chalk.gray(' # Diagnose issues')\n );\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error(chalk.red('\\n[ERROR] Initialization failed'));\n console.error(chalk.gray(` Reason: ${(error as Error).message}`));\n console.error(\n chalk.gray(\n ' Fix: Ensure you have write permissions to the current directory'\n )\n );\n console.error(chalk.gray(' Run: stackmemory doctor'));\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 if (isTestEnv()) {\n console.log('\uD83D\uDCCA StackMemory Status (test mode):');\n console.log(' Frames: n/a');\n console.log(' Events: n/a');\n console.log(' Sessions: n/a');\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 = await openDatabase(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\nprogram\n .command('mcp-remote')\n .description(\n 'Start StackMemory Remote MCP server (HTTP/SSE) for Claude.ai web'\n )\n .option('-p, --port <number>', 'Port to listen on', '3847')\n .option('-d, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runRemoteMCPServer } =\n await import('../integrations/mcp/remote-server.js');\n\n const port = parseInt(options.port, 10);\n\n console.log('Starting StackMemory Remote MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n console.log('');\n\n await runRemoteMCPServer(port, options.project);\n\n console.log('');\n console.log('For Claude.ai web connector:');\n console.log(` URL: http://localhost:${port}/sse`);\n console.log('');\n console.log('For external access (ngrok):');\n console.log(` ngrok http ${port}`);\n console.log(' Then use the ngrok URL + /sse in Claude.ai');\n } catch (error: unknown) {\n logger.error('Failed to start remote MCP server', error as Error);\n console.error('Remote 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 if (isTestEnv()) {\n console.log('\uD83D\uDCDD [test] Skipping DB write in context:test');\n return;\n }\n\n const db = await openDatabase(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 (lazy-loaded, optional)\nif (isFeatureEnabled('linear')) {\n import('./commands/linear.js')\n .then(({ registerLinearCommands }) => registerLinearCommands(program))\n .catch(() => {\n // Linear integration not available - silently skip\n });\n}\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(createCaptureCommand());\nprogram.addCommand(createRestoreCommand());\nprogram.addCommand(createAutoCaptureCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(serviceCommand);\nprogram.addCommand(createHooksCommand());\n\n// Register feature-flagged commands (awaited before parse)\nconst lazyCommands: Promise<void>[] = [];\n\nif (isFeatureEnabled('skills')) {\n lazyCommands.push(\n import('./commands/skills.js')\n .then(({ createSkillsCommand }) =>\n program.addCommand(createSkillsCommand())\n )\n .catch(() => {\n // Skills integration not available - silently skip\n })\n );\n}\n\n// Register ralph commands (feature-flagged)\n// Default ON for development, OFF for npm package users\nif (isFeatureEnabled('ralph')) {\n lazyCommands.push(\n import('./commands/ralph.js')\n .then(({ default: createRalphCommand }) =>\n program.addCommand(createRalphCommand())\n )\n .catch(() => {\n // Ralph integration not available - silently skip\n })\n );\n}\nprogram.addCommand(createDaemonCommand());\nprogram.addCommand(createSweepCommand());\nprogram.addCommand(createShellCommand());\nprogram.addCommand(createAPICommand());\nprogram.addCommand(createCleanupProcessesCommand());\nprogram.addCommand(createAutoBackgroundCommand());\nprogram.addCommand(createSettingsCommand());\nprogram.addCommand(createPingCommand());\n\n// Register WhatsApp/SMS commands (lazy-loaded, optional)\nif (isFeatureEnabled('whatsapp')) {\n lazyCommands.push(\n import('./commands/sms-notify.js')\n .then(({ createSMSNotifyCommand }) =>\n program.addCommand(createSMSNotifyCommand())\n )\n .catch(() => {\n // WhatsApp integration not available - silently skip\n })\n );\n}\nprogram.addCommand(createRetrievalCommands());\nprogram.addCommand(createDiscoveryCommands());\nprogram.addCommand(createModelCommand());\n\n// Register setup and diagnostic commands\nregisterSetupCommands(program);\n\n// Multi-modal spike: planner (Claude), implementer (Codex), critic (Claude)\nprogram\n .command('mm-spike')\n .description(\n 'Run multi-agent planning/implementation spike (planner/implementer/critic)'\n )\n .option(\n '-t, --task <desc>',\n 'Task description',\n 'Add multi-agent spike harness'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--execute',\n 'Execute implementer (codex-sm) instead of dry-run',\n false\n )\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors', false)\n .option('--record', 'Record plan & critique into StackMemory context', false)\n .option('--json', 'Emit single JSON result (UI-friendly)', false)\n .option('--quiet', 'Minimal output (default)', true)\n .option('--verbose', 'Verbose sectioned output', false)\n .option(\n '--log',\n 'Pretty print interaction log (planner/implementer/critic)',\n false\n )\n .action(async (opts) => {\n try {\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const result = await runSpike(\n {\n task: opts.task,\n repoPath: process.cwd(),\n },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun: !opts.execute,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task: opts.task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: Boolean(opts.execute),\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n // brief human-readable summary\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('mm-spike failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Alias: build (same behavior as mm-spike)\nprogram\n .command('build')\n .description(\n 'Plan + code: planner (Claude), implementer (Codex/Claude), critic (Claude) with optional log/json output'\n )\n .argument('[task]', 'Task description (positional)')\n .option(\n '-t, --task <desc>',\n 'Task description (required if no positional arg)'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-sonnet-4-20250514'\n )\n .option('--execute', 'Execute implementer (default: true)', true)\n .option('--dry-run', 'Skip execution, show commands only')\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors')\n .option('--record', 'Record plan & critique into StackMemory context')\n .option('--json', 'Emit single JSON result (UI-friendly)')\n .option('--quiet', 'Minimal output')\n .option('--verbose', 'Verbose sectioned output')\n .option('--log', 'Pretty print interaction log (default: true)', true)\n .option('-C, --cwd <path>', 'Working directory for implementation')\n .action(async (taskArg, opts) => {\n try {\n // Resolve task from positional arg or --task option\n const task =\n typeof taskArg === 'string' && taskArg.length > 0 ? taskArg : opts.task;\n\n if (!task) {\n console.error(\n chalk.red(\n 'Error: Task description required. Provide as argument or --task option.'\n )\n );\n console.error(\n chalk.gray(' Example: stackmemory build \"Add user authentication\"')\n );\n process.exit(1);\n }\n\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const dryRun = opts.dryRun === true || opts.execute === false;\n\n // Find git root for proper working directory\n const findGitRoot = (startDir: string): string => {\n let dir = startDir;\n while (dir !== '/') {\n if (existsSync(join(dir, '.git'))) {\n return dir;\n }\n dir = path.dirname(dir);\n }\n return startDir;\n };\n // Use --cwd if provided, otherwise find git root from cwd\n const repoPath = opts.cwd\n ? path.resolve(opts.cwd)\n : findGitRoot(process.cwd());\n\n const result = await runSpike(\n { task, repoPath },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: !dryRun,\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('build failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\ninterface BuildLogMeta {\n task: string;\n plannerModel: string;\n reviewerModel: string;\n implementer: string;\n execute: boolean;\n}\n\nfunction printInteractionLog(meta: BuildLogMeta, result: HarnessResult): void {\n const divider = chalk.gray(\n '\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500'\n );\n console.log(chalk.cyan.bold('\\nPlan & Code Session'));\n console.log(`${chalk.gray('Task:')} ${meta.task}`);\n console.log(`${chalk.gray('Planner:')} ${meta.plannerModel}`);\n console.log(`${chalk.gray('Reviewer:')} ${meta.reviewerModel}`);\n console.log(\n `${chalk.gray('Implementer:')} ${meta.implementer} ${\n meta.execute ? chalk.green('(execute)') : chalk.yellow('(dry-run)')\n }`\n );\n console.log(divider);\n\n // Plan summary\n if (result.plan) {\n console.log(\n chalk.bold('Plan Summary: '),\n result.plan.summary || '(no summary)'\n );\n const steps: PlanStep[] = result.plan.steps.slice(0, 6);\n if (steps.length) {\n console.log(chalk.bold('\\nSteps:'));\n steps.forEach((s, idx) => {\n console.log(`${chalk.gray(String(idx + 1) + '.')} ${s.title || s.id}`);\n const ac = s.acceptanceCriteria || [];\n if (ac.length) {\n ac.slice(0, 3).forEach((c) => console.log(chalk.gray(` - ${c}`)));\n if (ac.length > 3) console.log(chalk.gray(' - ...'));\n }\n });\n }\n if (result.plan.risks?.length) {\n console.log(chalk.bold('\\nRisks:'));\n result.plan.risks\n .slice(0, 5)\n .forEach((r) => console.log(chalk.gray(` - ${r}`)));\n }\n }\n\n console.log(`\\n${divider}`);\n const iters = result.iterations || [];\n if (iters.length) {\n iters.forEach((it, i) => {\n console.log(chalk.magenta(`Attempt ${i + 1}`));\n console.log(`${chalk.gray('Command:')} ${it.command}`);\n console.log(\n `${chalk.gray('OK:')} ${it.ok ? chalk.green('true') : chalk.red('false')}`\n );\n const issues = it.critique?.issues || [];\n const sugg = it.critique?.suggestions || [];\n if (issues.length) {\n console.log(chalk.bold('Issues:'));\n issues.slice(0, 5).forEach((x) => console.log(chalk.red(` - ${x}`)));\n }\n if (sugg.length) {\n console.log(chalk.bold('Suggestions:'));\n sugg.slice(0, 5).forEach((x) => console.log(chalk.yellow(` - ${x}`)));\n }\n console.log(divider);\n });\n }\n\n const approved = result.critique?.approved ?? false;\n console.log(\n `${chalk.bold('Final:')} ${\n approved ? chalk.green('Approved') : chalk.yellow('Needs changes')\n }`\n );\n console.log('');\n}\n\n// Pending approvals: list with optional filters (CLI helper)\nprogram\n .command('pending:list')\n .description(\n 'List pending approval-gated plans (from .stackmemory/build/pending.json)'\n )\n .option('--task-contains <substr>', 'Filter tasks containing this substring')\n .option('--older-than-ms <number>', 'Only items older than this age (ms)')\n .option('--newer-than-ms <number>', 'Only items newer than this age (ms)')\n .option('--sort <asc|desc>', 'Sort by createdAt', 'desc')\n .option('--limit <number>', 'Max items to return', '20')\n .option('--pretty', 'Pretty-print JSON output', false)\n .action(async (opts) => {\n try {\n const storePath = path.join(\n process.cwd(),\n '.stackmemory',\n 'build',\n 'pending.json'\n );\n let pending: Record<string, { task?: string; createdAt?: number }> = {};\n if (fs.existsSync(storePath)) {\n try {\n pending = JSON.parse(fs.readFileSync(storePath, 'utf-8'));\n } catch {}\n }\n const items = Object.entries(pending).map(([approvalId, data]) => ({\n approvalId,\n task: data?.task ?? '',\n createdAt: Number(data?.createdAt || 0) || null,\n }));\n const filters = {\n taskContains: opts.taskContains as string | undefined,\n olderThanMs: opts.olderThanMs ? Number(opts.olderThanMs) : undefined,\n newerThanMs: opts.newerThanMs ? Number(opts.newerThanMs) : undefined,\n sort: (opts.sort as 'asc' | 'desc') || undefined,\n limit: opts.limit ? Number(opts.limit) : undefined,\n };\n const out = filterPending(items, filters);\n console.log(\n JSON.stringify({ ok: true, pending: out }, null, opts.pretty ? 2 : 0)\n );\n } catch (error) {\n console.error(\n JSON.stringify({ ok: false, error: (error as Error).message })\n );\n process.exit(1);\n }\n });\n\n// Lightweight planner: output only plan (JSON-friendly)\nprogram\n .command('plan')\n .description('Generate an implementation plan (no code execution)')\n .option('-t, --task <desc>', 'Task description', 'Plan a small change')\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option('--json', 'Emit JSON (default)', true)\n .option('--pretty', 'Pretty-print JSON', false)\n .option(\n '--compact',\n 'Compact output (summary + step titles + criteria)',\n false\n )\n .action(async (opts) => {\n try {\n const { runPlanOnly } =\n await import('../orchestrators/multimodal/harness.js');\n const plan = await runPlanOnly(\n { task: opts.task, repoPath: process.cwd() },\n { plannerModel: opts.plannerModel }\n );\n const typedPlan = plan as {\n summary?: string;\n steps?: Array<{\n id: string;\n title: string;\n acceptanceCriteria: string[];\n }>;\n risks?: string[];\n };\n const compacted = opts.compact\n ? {\n summary: typedPlan?.summary,\n steps: Array.isArray(typedPlan?.steps)\n ? typedPlan.steps.map((s) => ({\n id: s.id,\n title: s.title,\n acceptanceCriteria: s.acceptanceCriteria,\n }))\n : [],\n risks: typedPlan?.risks,\n }\n : plan;\n const payload = JSON.stringify(compacted, null, opts.pretty ? 2 : 0);\n console.log(payload);\n } catch (error) {\n console.error('plan failed:', (error as Error).message);\n process.exit(1);\n }\n });\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 try {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n } catch {\n // Silently fail if database initialization fails (e.g., native module version mismatch)\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 Promise.all(lazyCommands).then(() => program.parse());\n}\n\nexport { program };\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["mkdirSync", "existsSync"]
|
|
7
7
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/core/digest/types.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Types for Hybrid Digest Generation System\n * 80% deterministic extraction, 20% AI-generated review/insights\n */\n\nimport { Frame, Anchor, Event } from '../context/index.js';\n\n/**\n * Deterministic fields extracted directly from frame data (60%)\n */\nexport interface DeterministicDigest {\n /** Files that were modified during this frame */\n filesModified: FileModification[];\n /** Tests that were run */\n testsRun: TestResult[];\n /** Errors encountered */\n errorsEncountered: ErrorInfo[];\n /** Number of tool calls made */\n toolCallCount: number;\n /** Tool calls by type */\n toolCallsByType: Record<string, number>;\n /** Frame duration in seconds */\n durationSeconds: number;\n /** Exit status */\n exitStatus: 'success' | 'failure' | 'partial' | 'cancelled';\n /** Anchors by type */\n anchorCounts: Record<string, number>;\n /** Key decisions made (extracted from DECISION anchors) */\n decisions: string[];\n /** Constraints established (extracted from CONSTRAINT anchors) */\n constraints: string[];\n /** Risks identified (extracted from RISK anchors) */\n risks: string[];\n}\n\nexport interface FileModification {\n path: string;\n operation: 'create' | 'modify' | 'delete' | 'read';\n linesChanged?: number;\n}\n\nexport interface TestResult {\n name: string;\n status: 'passed' | 'failed' | 'skipped';\n duration?: number;\n}\n\nexport interface ErrorInfo {\n type: string;\n message: string;\n resolved: boolean;\n count: number;\n}\n\n/**\n * AI-generated review fields (20%)\n * Focused on high-value insights only\n */\nexport interface AIGeneratedDigest {\n /** One-line summary of what was accomplished */\n summary: string;\n /** Key insight or learning (if any) */\n insight?: string;\n /** Potential issue or risk spotted */\n flaggedIssue?: string;\n /** Generated at timestamp */\n generatedAt: number;\n /** Model used for generation */\n modelUsed?: string;\n /** Tokens used */\n tokensUsed?: number;\n}\n\n/**\n * Complete hybrid digest combining both approaches\n */\nexport interface HybridDigest {\n /** Frame identifier */\n frameId: string;\n /** Frame name/goal */\n frameName: string;\n /** Frame type */\n frameType: string;\n /** Deterministic fields (always available) */\n deterministic: DeterministicDigest;\n /** AI-generated fields (may be pending) */\n aiGenerated?: AIGeneratedDigest;\n /** Processing status */\n status: DigestStatus;\n /** Human-readable text representation */\n text: string;\n /** Version for schema evolution */\n version: number;\n /** Created timestamp */\n createdAt: number;\n /** Last updated timestamp */\n updatedAt: number;\n}\n\nexport type DigestStatus =\n | 'deterministic_only' // Only deterministic fields populated\n | 'ai_pending' // Queued for AI generation\n | 'ai_processing' // Currently being processed by AI\n | 'complete' // Both deterministic and AI fields populated\n | 'ai_failed'; // AI generation failed, falling back to deterministic\n\n/**\n * Digest generation request for the queue\n */\nexport interface DigestGenerationRequest {\n frameId: string;\n frameName: string;\n frameType: string;\n priority: 'low' | 'normal' | 'high';\n createdAt: number;\n retryCount: number;\n maxRetries: number;\n}\n\n/**\n * Configuration for the digest generator\n */\nexport interface DigestConfig {\n /** Enable AI generation (can be disabled for deterministic-only mode) */\n enableAIGeneration: boolean;\n /** Maximum tokens for AI summary */\n maxTokens: number;\n /** Batch size for idle processing */\n batchSize: number;\n /** Idle threshold in ms before processing queue */\n idleThresholdMs: number;\n /** Maximum retries for failed AI generation */\n maxRetries: number;\n /** Retry delay in ms */\n retryDelayMs: number;\n /** LLM provider configuration */\n llmConfig: {\n provider: 'anthropic' | 'openai' | 'local' | 'none';\n model: string;\n temperature: number;\n };\n}\n\nexport const DEFAULT_DIGEST_CONFIG: DigestConfig = {\n enableAIGeneration: true,\n maxTokens: 100, // Reduced for 20% AI contribution\n batchSize: 10, // Process more at once since smaller\n idleThresholdMs: 3000, // 3 seconds of idle time\n maxRetries: 2,\n retryDelayMs: 1000,\n llmConfig: {\n provider: 'anthropic',\n model: 'claude-3-haiku-
|
|
4
|
+
"sourcesContent": ["/**\n * Types for Hybrid Digest Generation System\n * 80% deterministic extraction, 20% AI-generated review/insights\n */\n\nimport { Frame, Anchor, Event } from '../context/index.js';\n\n/**\n * Deterministic fields extracted directly from frame data (60%)\n */\nexport interface DeterministicDigest {\n /** Files that were modified during this frame */\n filesModified: FileModification[];\n /** Tests that were run */\n testsRun: TestResult[];\n /** Errors encountered */\n errorsEncountered: ErrorInfo[];\n /** Number of tool calls made */\n toolCallCount: number;\n /** Tool calls by type */\n toolCallsByType: Record<string, number>;\n /** Frame duration in seconds */\n durationSeconds: number;\n /** Exit status */\n exitStatus: 'success' | 'failure' | 'partial' | 'cancelled';\n /** Anchors by type */\n anchorCounts: Record<string, number>;\n /** Key decisions made (extracted from DECISION anchors) */\n decisions: string[];\n /** Constraints established (extracted from CONSTRAINT anchors) */\n constraints: string[];\n /** Risks identified (extracted from RISK anchors) */\n risks: string[];\n}\n\nexport interface FileModification {\n path: string;\n operation: 'create' | 'modify' | 'delete' | 'read';\n linesChanged?: number;\n}\n\nexport interface TestResult {\n name: string;\n status: 'passed' | 'failed' | 'skipped';\n duration?: number;\n}\n\nexport interface ErrorInfo {\n type: string;\n message: string;\n resolved: boolean;\n count: number;\n}\n\n/**\n * AI-generated review fields (20%)\n * Focused on high-value insights only\n */\nexport interface AIGeneratedDigest {\n /** One-line summary of what was accomplished */\n summary: string;\n /** Key insight or learning (if any) */\n insight?: string;\n /** Potential issue or risk spotted */\n flaggedIssue?: string;\n /** Generated at timestamp */\n generatedAt: number;\n /** Model used for generation */\n modelUsed?: string;\n /** Tokens used */\n tokensUsed?: number;\n}\n\n/**\n * Complete hybrid digest combining both approaches\n */\nexport interface HybridDigest {\n /** Frame identifier */\n frameId: string;\n /** Frame name/goal */\n frameName: string;\n /** Frame type */\n frameType: string;\n /** Deterministic fields (always available) */\n deterministic: DeterministicDigest;\n /** AI-generated fields (may be pending) */\n aiGenerated?: AIGeneratedDigest;\n /** Processing status */\n status: DigestStatus;\n /** Human-readable text representation */\n text: string;\n /** Version for schema evolution */\n version: number;\n /** Created timestamp */\n createdAt: number;\n /** Last updated timestamp */\n updatedAt: number;\n}\n\nexport type DigestStatus =\n | 'deterministic_only' // Only deterministic fields populated\n | 'ai_pending' // Queued for AI generation\n | 'ai_processing' // Currently being processed by AI\n | 'complete' // Both deterministic and AI fields populated\n | 'ai_failed'; // AI generation failed, falling back to deterministic\n\n/**\n * Digest generation request for the queue\n */\nexport interface DigestGenerationRequest {\n frameId: string;\n frameName: string;\n frameType: string;\n priority: 'low' | 'normal' | 'high';\n createdAt: number;\n retryCount: number;\n maxRetries: number;\n}\n\n/**\n * Configuration for the digest generator\n */\nexport interface DigestConfig {\n /** Enable AI generation (can be disabled for deterministic-only mode) */\n enableAIGeneration: boolean;\n /** Maximum tokens for AI summary */\n maxTokens: number;\n /** Batch size for idle processing */\n batchSize: number;\n /** Idle threshold in ms before processing queue */\n idleThresholdMs: number;\n /** Maximum retries for failed AI generation */\n maxRetries: number;\n /** Retry delay in ms */\n retryDelayMs: number;\n /** LLM provider configuration */\n llmConfig: {\n provider: 'anthropic' | 'openai' | 'local' | 'none';\n model: string;\n temperature: number;\n };\n}\n\nexport const DEFAULT_DIGEST_CONFIG: DigestConfig = {\n enableAIGeneration: true,\n maxTokens: 100, // Reduced for 20% AI contribution\n batchSize: 10, // Process more at once since smaller\n idleThresholdMs: 3000, // 3 seconds of idle time\n maxRetries: 2,\n retryDelayMs: 1000,\n llmConfig: {\n provider: 'anthropic',\n model: 'claude-3-5-haiku-20241022',\n temperature: 0.2, // Lower for more consistent output\n },\n};\n\n/**\n * Input for digest generation\n */\nexport interface DigestInput {\n frame: Frame;\n anchors: Anchor[];\n events: Event[];\n parentDigest?: HybridDigest;\n}\n\n/**\n * LLM provider interface for AI digest generation\n */\nexport interface DigestLLMProvider {\n generateSummary(\n input: DigestInput,\n deterministic: DeterministicDigest,\n maxTokens: number\n ): Promise<AIGeneratedDigest>;\n}\n\n/**\n * Digest queue statistics\n */\nexport interface DigestQueueStats {\n pending: number;\n processing: number;\n completed: number;\n failed: number;\n avgProcessingTimeMs: number;\n}\n"],
|
|
5
5
|
"mappings": ";;;;AA+IO,MAAM,wBAAsC;AAAA,EACjD,oBAAoB;AAAA,EACpB,WAAW;AAAA;AAAA,EACX,WAAW;AAAA;AAAA,EACX,iBAAiB;AAAA;AAAA,EACjB,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,WAAW;AAAA,IACT,UAAU;AAAA,IACV,OAAO;AAAA,IACP,aAAa;AAAA;AAAA,EACf;AACF;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -111,7 +111,7 @@ class ClaudeAdapter {
|
|
|
111
111
|
"anthropic-version": "2023-06-01"
|
|
112
112
|
},
|
|
113
113
|
body: JSON.stringify({
|
|
114
|
-
model: "claude-3-haiku-
|
|
114
|
+
model: "claude-3-5-haiku-20241022",
|
|
115
115
|
max_tokens: 1,
|
|
116
116
|
messages: [{ role: "user", content: "hi" }]
|
|
117
117
|
})
|
|
@@ -125,11 +125,8 @@ class ClaudeAdapter {
|
|
|
125
125
|
return [
|
|
126
126
|
"claude-opus-4-20250514",
|
|
127
127
|
"claude-sonnet-4-20250514",
|
|
128
|
-
"claude-3-5-sonnet-20241022",
|
|
129
128
|
"claude-3-5-haiku-20241022",
|
|
130
|
-
"claude-3-opus-20240229"
|
|
131
|
-
"claude-3-sonnet-20240229",
|
|
132
|
-
"claude-3-haiku-20240307"
|
|
129
|
+
"claude-3-opus-20240229"
|
|
133
130
|
];
|
|
134
131
|
}
|
|
135
132
|
buildRequestBody(messages, options) {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/core/extensions/provider-adapter.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Provider Adapter Interface for StackMemory\n *\n * Philosophy: \"Standardize the intersection; expose the union\"\n * - Portable core stream API with shared semantics across all providers\n * - Provider-specific extensions available through explicit opt-in capabilities\n */\n\n// =============================================================================\n// Core Types - Portable across all providers\n// =============================================================================\n\n/**\n * Message role - intersection of all providers\n */\nexport type MessageRole = 'user' | 'assistant' | 'system';\n\n/**\n * Content block types - intersection of all providers\n */\nexport type ContentBlockType = 'text' | 'image' | 'tool_use' | 'tool_result';\n\n/**\n * Base content block\n */\nexport interface ContentBlock {\n type: ContentBlockType;\n}\n\nexport interface TextBlock extends ContentBlock {\n type: 'text';\n text: string;\n}\n\nexport interface ImageBlock extends ContentBlock {\n type: 'image';\n source: {\n type: 'base64' | 'url';\n mediaType: 'image/jpeg' | 'image/png' | 'image/gif' | 'image/webp';\n data: string;\n };\n}\n\nexport interface ToolUseBlock extends ContentBlock {\n type: 'tool_use';\n id: string;\n name: string;\n input: Record<string, unknown>;\n}\n\nexport interface ToolResultBlock extends ContentBlock {\n type: 'tool_result';\n toolUseId: string;\n content: string | ContentBlock[];\n isError?: boolean;\n}\n\nexport type AnyContentBlock =\n | TextBlock\n | ImageBlock\n | ToolUseBlock\n | ToolResultBlock;\n\n/**\n * Message - portable message format\n */\nexport interface Message {\n role: MessageRole;\n content: string | AnyContentBlock[];\n}\n\n/**\n * Tool definition - portable tool schema\n */\nexport interface ToolDefinition {\n name: string;\n description: string;\n inputSchema: {\n type: 'object';\n properties: Record<string, unknown>;\n required?: string[];\n };\n}\n\n/**\n * Stream options - core options for all providers\n */\nexport interface StreamOptions {\n model: string;\n maxTokens: number;\n temperature?: number;\n topP?: number;\n stopSequences?: string[];\n system?: string;\n tools?: ToolDefinition[];\n}\n\n// =============================================================================\n// Stream Events - Portable event types\n// =============================================================================\n\nexport type StreamEventType =\n | 'message_start'\n | 'content_block_start'\n | 'content_block_delta'\n | 'content_block_stop'\n | 'message_delta'\n | 'message_stop'\n | 'error';\n\nexport interface StreamEventBase {\n type: StreamEventType;\n}\n\nexport interface MessageStartEvent extends StreamEventBase {\n type: 'message_start';\n message: {\n id: string;\n model: string;\n role: 'assistant';\n usage?: {\n inputTokens: number;\n outputTokens: number;\n };\n };\n}\n\nexport interface ContentBlockStartEvent extends StreamEventBase {\n type: 'content_block_start';\n index: number;\n contentBlock: AnyContentBlock;\n}\n\nexport interface ContentBlockDeltaEvent extends StreamEventBase {\n type: 'content_block_delta';\n index: number;\n delta: {\n type: 'text_delta' | 'input_json_delta';\n text?: string;\n partialJson?: string;\n };\n}\n\nexport interface ContentBlockStopEvent extends StreamEventBase {\n type: 'content_block_stop';\n index: number;\n}\n\nexport interface MessageDeltaEvent extends StreamEventBase {\n type: 'message_delta';\n delta: {\n stopReason?: 'end_turn' | 'max_tokens' | 'stop_sequence' | 'tool_use';\n };\n usage?: {\n outputTokens: number;\n };\n}\n\nexport interface MessageStopEvent extends StreamEventBase {\n type: 'message_stop';\n}\n\nexport interface ErrorEvent extends StreamEventBase {\n type: 'error';\n error: {\n type: string;\n message: string;\n };\n}\n\nexport type StreamEvent =\n | MessageStartEvent\n | ContentBlockStartEvent\n | ContentBlockDeltaEvent\n | ContentBlockStopEvent\n | MessageDeltaEvent\n | MessageStopEvent\n | ErrorEvent;\n\n// =============================================================================\n// Provider Capabilities - Union of provider-specific features\n// =============================================================================\n\n/**\n * Claude-specific extensions\n */\nexport interface ClaudeExtensions {\n /**\n * Extended thinking - deep reasoning capability\n */\n extendedThinking?: {\n enabled: boolean;\n budgetTokens?: number;\n };\n\n /**\n * XML-structured output preference\n */\n xmlOutput?: {\n enabled: boolean;\n rootElement?: string;\n };\n\n /**\n * Computer use - desktop automation\n */\n computerUse?: {\n enabled: boolean;\n displaySize?: { width: number; height: number };\n };\n\n /**\n * PDF/document support\n */\n documentSupport?: {\n enabled: boolean;\n maxPages?: number;\n };\n}\n\n/**\n * OpenAI GPT-specific extensions\n */\nexport interface GPTExtensions {\n /**\n * Code interpreter - execute Python code\n */\n codeInterpreter?: {\n enabled: boolean;\n fileIds?: string[];\n };\n\n /**\n * Web browsing capability\n */\n browsing?: {\n enabled: boolean;\n };\n\n /**\n * DALL-E image generation\n */\n imageGeneration?: {\n enabled: boolean;\n size?: '256x256' | '512x512' | '1024x1024' | '1792x1024' | '1024x1792';\n quality?: 'standard' | 'hd';\n };\n\n /**\n * Function calling mode\n */\n functionCalling?: {\n mode: 'auto' | 'none' | 'required';\n };\n\n /**\n * JSON mode output\n */\n jsonMode?: {\n enabled: boolean;\n schema?: Record<string, unknown>;\n };\n}\n\n/**\n * Google Gemini-specific extensions\n */\nexport interface GeminiExtensions {\n /**\n * Grounding with Google Search\n */\n grounding?: {\n enabled: boolean;\n dynamicThreshold?: number;\n };\n\n /**\n * Native multimodal - video/audio support\n */\n multimodal?: {\n videoEnabled: boolean;\n audioEnabled: boolean;\n maxVideoDurationSec?: number;\n };\n\n /**\n * Code execution\n */\n codeExecution?: {\n enabled: boolean;\n };\n\n /**\n * Safety settings\n */\n safetySettings?: Array<{\n category: string;\n threshold: 'BLOCK_NONE' | 'BLOCK_LOW' | 'BLOCK_MEDIUM' | 'BLOCK_HIGH';\n }>;\n}\n\n/**\n * All provider extensions - union type\n */\nexport interface ProviderExtensions {\n claude?: ClaudeExtensions;\n gpt?: GPTExtensions;\n gemini?: GeminiExtensions;\n}\n\n// =============================================================================\n// Provider Adapter Interface\n// =============================================================================\n\n/**\n * Provider adapter interface - core contract for all providers\n */\nexport interface ProviderAdapter {\n /**\n * Unique provider identifier\n */\n readonly id: string;\n\n /**\n * Human-readable provider name\n */\n readonly name: string;\n\n /**\n * Provider version\n */\n readonly version: string;\n\n /**\n * Available extensions for this provider\n */\n readonly extensions: Partial<ProviderExtensions>;\n\n /**\n * Check if provider supports a specific extension\n */\n supportsExtension(extension: keyof ProviderExtensions): boolean;\n\n /**\n * Core streaming API - portable across all providers\n */\n stream(\n messages: Message[],\n options: StreamOptions\n ): AsyncIterable<StreamEvent>;\n\n /**\n * Non-streaming completion\n */\n complete(\n messages: Message[],\n options: StreamOptions\n ): Promise<{\n content: AnyContentBlock[];\n usage: { inputTokens: number; outputTokens: number };\n stopReason: string;\n }>;\n\n /**\n * Validate API key / connection\n */\n validateConnection(): Promise<boolean>;\n\n /**\n * Get available models for this provider\n */\n listModels(): Promise<string[]>;\n}\n\n// =============================================================================\n// Claude Adapter Implementation\n// =============================================================================\n\n/**\n * Extended stream options for Claude\n */\nexport interface ClaudeStreamOptions extends StreamOptions {\n extensions?: ClaudeExtensions;\n}\n\n/**\n * Claude-specific stream events\n */\nexport interface ThinkingBlockStartEvent extends StreamEventBase {\n type: 'content_block_start';\n index: number;\n contentBlock: {\n type: 'thinking';\n thinking: string;\n };\n}\n\nexport interface ThinkingBlockDeltaEvent extends StreamEventBase {\n type: 'content_block_delta';\n index: number;\n delta: {\n type: 'thinking_delta';\n thinking: string;\n };\n}\n\n/**\n * Claude adapter - full implementation with extensions\n */\nexport class ClaudeAdapter implements ProviderAdapter {\n readonly id = 'claude';\n readonly name = 'Anthropic Claude';\n readonly version = '1.0.0';\n\n readonly extensions: ProviderExtensions = {\n claude: {\n extendedThinking: { enabled: true, budgetTokens: 10000 },\n xmlOutput: { enabled: true },\n computerUse: { enabled: true },\n documentSupport: { enabled: true, maxPages: 100 },\n },\n };\n\n private apiKey: string;\n private baseUrl: string;\n\n constructor(config: { apiKey: string; baseUrl?: string }) {\n this.apiKey = config.apiKey;\n this.baseUrl = config.baseUrl || 'https://api.anthropic.com';\n }\n\n supportsExtension(extension: keyof ProviderExtensions): boolean {\n return extension === 'claude';\n }\n\n async *stream(\n messages: Message[],\n options: ClaudeStreamOptions\n ): AsyncIterable<StreamEvent> {\n const body = this.buildRequestBody(messages, options);\n\n const response = await fetch(`${this.baseUrl}/v1/messages`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'x-api-key': this.apiKey,\n 'anthropic-version': '2023-06-01',\n 'anthropic-beta': this.getBetaFlags(options.extensions),\n },\n body: JSON.stringify({ ...body, stream: true }),\n });\n\n if (!response.ok) {\n yield {\n type: 'error',\n error: {\n type: 'api_error',\n message: `Claude API error: ${response.status} ${response.statusText}`,\n },\n };\n return;\n }\n\n const reader = response.body?.getReader();\n if (!reader) {\n yield {\n type: 'error',\n error: { type: 'stream_error', message: 'No response body' },\n };\n return;\n }\n\n const decoder = new TextDecoder();\n let buffer = '';\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() || '';\n\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n const data = line.slice(6);\n if (data === '[DONE]') return;\n\n try {\n const event = JSON.parse(data) as StreamEvent;\n yield this.normalizeEvent(event);\n } catch {\n // Skip malformed events\n }\n }\n }\n }\n }\n\n async complete(\n messages: Message[],\n options: ClaudeStreamOptions\n ): Promise<{\n content: AnyContentBlock[];\n usage: { inputTokens: number; outputTokens: number };\n stopReason: string;\n }> {\n const body = this.buildRequestBody(messages, options);\n\n const response = await fetch(`${this.baseUrl}/v1/messages`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'x-api-key': this.apiKey,\n 'anthropic-version': '2023-06-01',\n 'anthropic-beta': this.getBetaFlags(options.extensions),\n },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n throw new Error(\n `Claude API error: ${response.status} ${response.statusText}`\n );\n }\n\n const data = await response.json();\n\n return {\n content: data.content as AnyContentBlock[],\n usage: {\n inputTokens: data.usage?.input_tokens ?? 0,\n outputTokens: data.usage?.output_tokens ?? 0,\n },\n stopReason: data.stop_reason ?? 'end_turn',\n };\n }\n\n async validateConnection(): Promise<boolean> {\n try {\n const response = await fetch(`${this.baseUrl}/v1/messages`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'x-api-key': this.apiKey,\n 'anthropic-version': '2023-06-01',\n },\n body: JSON.stringify({\n model: 'claude-3-haiku-20240307',\n max_tokens: 1,\n messages: [{ role: 'user', content: 'hi' }],\n }),\n });\n return response.ok || response.status === 400;\n } catch {\n return false;\n }\n }\n\n async listModels(): Promise<string[]> {\n return [\n 'claude-opus-4-20250514',\n 'claude-sonnet-4-20250514',\n 'claude-3-5-sonnet-20241022',\n 'claude-3-5-haiku-20241022',\n 'claude-3-opus-20240229',\n 'claude-3-sonnet-20240229',\n 'claude-3-haiku-20240307',\n ];\n }\n\n private buildRequestBody(\n messages: Message[],\n options: ClaudeStreamOptions\n ): Record<string, unknown> {\n const body: Record<string, unknown> = {\n model: options.model,\n max_tokens: options.maxTokens,\n messages: messages.map((m) => ({\n role: m.role,\n content: m.content,\n })),\n };\n\n if (options.temperature !== undefined) {\n body.temperature = options.temperature;\n }\n if (options.topP !== undefined) {\n body.top_p = options.topP;\n }\n if (options.stopSequences?.length) {\n body.stop_sequences = options.stopSequences;\n }\n if (options.system) {\n body.system = options.system;\n }\n if (options.tools?.length) {\n body.tools = options.tools.map((t) => ({\n name: t.name,\n description: t.description,\n input_schema: t.inputSchema,\n }));\n }\n\n // Claude extensions\n if (options.extensions?.extendedThinking?.enabled) {\n body.thinking = {\n type: 'enabled',\n budget_tokens:\n options.extensions.extendedThinking.budgetTokens || 10000,\n };\n // Extended thinking requires temperature = 1\n body.temperature = 1;\n }\n\n return body;\n }\n\n private getBetaFlags(extensions?: ClaudeExtensions): string {\n const flags: string[] = [];\n\n if (extensions?.extendedThinking?.enabled) {\n flags.push('interleaved-thinking-2025-05-14');\n }\n if (extensions?.computerUse?.enabled) {\n flags.push('computer-use-2024-10-22');\n }\n if (extensions?.documentSupport?.enabled) {\n flags.push('pdfs-2024-09-25');\n }\n\n return flags.join(',');\n }\n\n private normalizeEvent(event: StreamEvent): StreamEvent {\n // Normalize Claude-specific events to portable format\n return event;\n }\n}\n\n// =============================================================================\n// GPT Adapter Stub\n// =============================================================================\n\n/**\n * Extended stream options for GPT\n */\nexport interface GPTStreamOptions extends StreamOptions {\n extensions?: GPTExtensions;\n}\n\n/**\n * GPT adapter - stub implementation\n */\nexport class GPTAdapter implements ProviderAdapter {\n readonly id = 'gpt';\n readonly name = 'OpenAI GPT';\n readonly version = '1.0.0';\n\n readonly extensions: ProviderExtensions = {\n gpt: {\n codeInterpreter: { enabled: true },\n browsing: { enabled: true },\n imageGeneration: {\n enabled: true,\n size: '1024x1024',\n quality: 'standard',\n },\n functionCalling: { mode: 'auto' },\n jsonMode: { enabled: true },\n },\n };\n\n private apiKey: string;\n private baseUrl: string;\n\n constructor(config: { apiKey: string; baseUrl?: string }) {\n this.apiKey = config.apiKey;\n this.baseUrl = config.baseUrl || 'https://api.openai.com';\n }\n\n supportsExtension(extension: keyof ProviderExtensions): boolean {\n return extension === 'gpt';\n }\n\n async *stream(\n messages: Message[],\n options: GPTStreamOptions\n ): AsyncIterable<StreamEvent> {\n // Convert messages to OpenAI format\n const openaiMessages = messages.map((m) => ({\n role: m.role,\n content:\n typeof m.content === 'string'\n ? m.content\n : m.content\n .filter((c): c is TextBlock => c.type === 'text')\n .map((c) => c.text)\n .join(''),\n }));\n\n const body: Record<string, unknown> = {\n model: options.model,\n max_tokens: options.maxTokens,\n messages: openaiMessages,\n stream: true,\n };\n\n if (options.temperature !== undefined) {\n body.temperature = options.temperature;\n }\n if (options.topP !== undefined) {\n body.top_p = options.topP;\n }\n\n // GPT extensions\n if (options.extensions?.jsonMode?.enabled) {\n body.response_format = { type: 'json_object' };\n }\n\n if (options.tools?.length) {\n body.tools = options.tools.map((t) => ({\n type: 'function',\n function: {\n name: t.name,\n description: t.description,\n parameters: t.inputSchema,\n },\n }));\n\n if (options.extensions?.functionCalling?.mode) {\n body.tool_choice = options.extensions.functionCalling.mode;\n }\n }\n\n const response = await fetch(`${this.baseUrl}/v1/chat/completions`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${this.apiKey}`,\n },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n yield {\n type: 'error',\n error: {\n type: 'api_error',\n message: `GPT API error: ${response.status} ${response.statusText}`,\n },\n };\n return;\n }\n\n // Yield message start\n yield {\n type: 'message_start',\n message: {\n id: `msg_${Date.now()}`,\n model: options.model,\n role: 'assistant',\n },\n };\n\n const reader = response.body?.getReader();\n if (!reader) return;\n\n const decoder = new TextDecoder();\n let buffer = '';\n const blockIndex = 0;\n let blockStarted = false;\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() || '';\n\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n const data = line.slice(6);\n if (data === '[DONE]') {\n if (blockStarted) {\n yield { type: 'content_block_stop', index: blockIndex };\n }\n yield { type: 'message_stop' };\n return;\n }\n\n try {\n const parsed = JSON.parse(data);\n const delta = parsed.choices?.[0]?.delta;\n\n if (delta?.content && !blockStarted) {\n blockStarted = true;\n yield {\n type: 'content_block_start',\n index: blockIndex,\n contentBlock: { type: 'text', text: '' },\n };\n }\n\n if (delta?.content) {\n yield {\n type: 'content_block_delta',\n index: blockIndex,\n delta: { type: 'text_delta', text: delta.content },\n };\n }\n } catch {\n // Skip malformed events\n }\n }\n }\n }\n }\n\n async complete(\n messages: Message[],\n options: GPTStreamOptions\n ): Promise<{\n content: AnyContentBlock[];\n usage: { inputTokens: number; outputTokens: number };\n stopReason: string;\n }> {\n const openaiMessages = messages.map((m) => ({\n role: m.role,\n content:\n typeof m.content === 'string'\n ? m.content\n : m.content\n .filter((c): c is TextBlock => c.type === 'text')\n .map((c) => c.text)\n .join(''),\n }));\n\n const body: Record<string, unknown> = {\n model: options.model,\n max_tokens: options.maxTokens,\n messages: openaiMessages,\n };\n\n if (options.temperature !== undefined) {\n body.temperature = options.temperature;\n }\n\n const response = await fetch(`${this.baseUrl}/v1/chat/completions`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${this.apiKey}`,\n },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n throw new Error(\n `GPT API error: ${response.status} ${response.statusText}`\n );\n }\n\n const data = await response.json();\n const choice = data.choices?.[0];\n\n return {\n content: [{ type: 'text', text: choice?.message?.content ?? '' }],\n usage: {\n inputTokens: data.usage?.prompt_tokens ?? 0,\n outputTokens: data.usage?.completion_tokens ?? 0,\n },\n stopReason: choice?.finish_reason ?? 'stop',\n };\n }\n\n async validateConnection(): Promise<boolean> {\n try {\n const response = await fetch(`${this.baseUrl}/v1/models`, {\n headers: { Authorization: `Bearer ${this.apiKey}` },\n });\n return response.ok;\n } catch {\n return false;\n }\n }\n\n async listModels(): Promise<string[]> {\n return [\n 'gpt-4o',\n 'gpt-4o-mini',\n 'gpt-4-turbo',\n 'gpt-4',\n 'gpt-3.5-turbo',\n 'o1',\n 'o1-mini',\n 'o1-preview',\n ];\n }\n}\n\n// =============================================================================\n// Gemini Adapter Stub\n// =============================================================================\n\n/**\n * Extended stream options for Gemini\n */\nexport interface GeminiStreamOptions extends StreamOptions {\n extensions?: GeminiExtensions;\n}\n\n/**\n * Gemini adapter - stub implementation\n */\nexport class GeminiAdapter implements ProviderAdapter {\n readonly id = 'gemini';\n readonly name = 'Google Gemini';\n readonly version = '1.0.0';\n\n readonly extensions: ProviderExtensions = {\n gemini: {\n grounding: { enabled: true, dynamicThreshold: 0.3 },\n multimodal: {\n videoEnabled: true,\n audioEnabled: true,\n maxVideoDurationSec: 60,\n },\n codeExecution: { enabled: true },\n },\n };\n\n private apiKey: string;\n private baseUrl: string;\n\n constructor(config: { apiKey: string; baseUrl?: string }) {\n this.apiKey = config.apiKey;\n this.baseUrl =\n config.baseUrl || 'https://generativelanguage.googleapis.com/v1beta';\n }\n\n supportsExtension(extension: keyof ProviderExtensions): boolean {\n return extension === 'gemini';\n }\n\n async *stream(\n messages: Message[],\n options: GeminiStreamOptions\n ): AsyncIterable<StreamEvent> {\n // Convert messages to Gemini format\n const contents = messages\n .filter((m) => m.role !== 'system')\n .map((m) => ({\n role: m.role === 'assistant' ? 'model' : 'user',\n parts: [\n {\n text:\n typeof m.content === 'string'\n ? m.content\n : m.content\n .filter((c): c is TextBlock => c.type === 'text')\n .map((c) => c.text)\n .join(''),\n },\n ],\n }));\n\n const body: Record<string, unknown> = {\n contents,\n generationConfig: {\n maxOutputTokens: options.maxTokens,\n temperature: options.temperature,\n topP: options.topP,\n },\n };\n\n // System instruction\n const systemMsg = messages.find((m) => m.role === 'system');\n if (systemMsg || options.system) {\n body.systemInstruction = {\n parts: [\n {\n text:\n options.system ||\n (typeof systemMsg?.content === 'string' ? systemMsg.content : ''),\n },\n ],\n };\n }\n\n // Gemini extensions\n if (options.extensions?.grounding?.enabled) {\n body.tools = [\n {\n googleSearchRetrieval: {\n dynamicRetrievalConfig: {\n mode: 'MODE_DYNAMIC',\n dynamicThreshold: options.extensions.grounding.dynamicThreshold,\n },\n },\n },\n ];\n }\n\n if (options.extensions?.codeExecution?.enabled) {\n body.tools = [\n ...((body.tools as unknown[]) || []),\n { codeExecution: {} },\n ];\n }\n\n if (options.extensions?.safetySettings) {\n body.safetySettings = options.extensions.safetySettings;\n }\n\n const url = `${this.baseUrl}/models/${options.model}:streamGenerateContent?key=${this.apiKey}&alt=sse`;\n\n const response = await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n yield {\n type: 'error',\n error: {\n type: 'api_error',\n message: `Gemini API error: ${response.status} ${response.statusText}`,\n },\n };\n return;\n }\n\n yield {\n type: 'message_start',\n message: {\n id: `msg_${Date.now()}`,\n model: options.model,\n role: 'assistant',\n },\n };\n\n const reader = response.body?.getReader();\n if (!reader) return;\n\n const decoder = new TextDecoder();\n let buffer = '';\n const blockIndex = 0;\n let blockStarted = false;\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() || '';\n\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n try {\n const parsed = JSON.parse(line.slice(6));\n const text = parsed.candidates?.[0]?.content?.parts?.[0]?.text;\n\n if (text && !blockStarted) {\n blockStarted = true;\n yield {\n type: 'content_block_start',\n index: blockIndex,\n contentBlock: { type: 'text', text: '' },\n };\n }\n\n if (text) {\n yield {\n type: 'content_block_delta',\n index: blockIndex,\n delta: { type: 'text_delta', text },\n };\n }\n } catch {\n // Skip malformed events\n }\n }\n }\n }\n\n if (blockStarted) {\n yield { type: 'content_block_stop', index: blockIndex };\n }\n yield { type: 'message_stop' };\n }\n\n async complete(\n messages: Message[],\n options: GeminiStreamOptions\n ): Promise<{\n content: AnyContentBlock[];\n usage: { inputTokens: number; outputTokens: number };\n stopReason: string;\n }> {\n const contents = messages\n .filter((m) => m.role !== 'system')\n .map((m) => ({\n role: m.role === 'assistant' ? 'model' : 'user',\n parts: [\n {\n text:\n typeof m.content === 'string'\n ? m.content\n : m.content\n .filter((c): c is TextBlock => c.type === 'text')\n .map((c) => c.text)\n .join(''),\n },\n ],\n }));\n\n const body: Record<string, unknown> = {\n contents,\n generationConfig: {\n maxOutputTokens: options.maxTokens,\n temperature: options.temperature,\n },\n };\n\n const url = `${this.baseUrl}/models/${options.model}:generateContent?key=${this.apiKey}`;\n\n const response = await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n throw new Error(\n `Gemini API error: ${response.status} ${response.statusText}`\n );\n }\n\n const data = await response.json();\n const candidate = data.candidates?.[0];\n const text = candidate?.content?.parts?.[0]?.text ?? '';\n\n return {\n content: [{ type: 'text', text }],\n usage: {\n inputTokens: data.usageMetadata?.promptTokenCount ?? 0,\n outputTokens: data.usageMetadata?.candidatesTokenCount ?? 0,\n },\n stopReason: candidate?.finishReason ?? 'STOP',\n };\n }\n\n async validateConnection(): Promise<boolean> {\n try {\n const response = await fetch(`${this.baseUrl}/models?key=${this.apiKey}`);\n return response.ok;\n } catch {\n return false;\n }\n }\n\n async listModels(): Promise<string[]> {\n return [\n 'gemini-2.0-flash-exp',\n 'gemini-1.5-pro',\n 'gemini-1.5-flash',\n 'gemini-1.5-flash-8b',\n 'gemini-1.0-pro',\n ];\n }\n}\n\n// =============================================================================\n// Provider Registry\n// =============================================================================\n\nexport type ProviderId = 'claude' | 'gpt' | 'gemini';\n\n/**\n * Provider configuration\n */\nexport interface ProviderConfig {\n apiKey: string;\n baseUrl?: string;\n}\n\n/**\n * Create a provider adapter\n */\nexport function createProvider(\n id: ProviderId,\n config: ProviderConfig\n): ProviderAdapter {\n switch (id) {\n case 'claude':\n return new ClaudeAdapter(config);\n case 'gpt':\n return new GPTAdapter(config);\n case 'gemini':\n return new GeminiAdapter(config);\n default:\n throw new Error(`Unknown provider: ${id}`);\n }\n}\n\n/**\n * Provider registry for managing multiple providers\n */\nexport class ProviderRegistry {\n private providers = new Map<string, ProviderAdapter>();\n\n register(adapter: ProviderAdapter): void {\n this.providers.set(adapter.id, adapter);\n }\n\n get(id: string): ProviderAdapter | undefined {\n return this.providers.get(id);\n }\n\n list(): ProviderAdapter[] {\n return Array.from(this.providers.values());\n }\n\n has(id: string): boolean {\n return this.providers.has(id);\n }\n\n /**\n * Find providers that support a specific extension\n */\n findByExtension(extension: keyof ProviderExtensions): ProviderAdapter[] {\n return this.list().filter((p) => p.supportsExtension(extension));\n }\n}\n\n/**\n * Global provider registry\n */\nexport const providerRegistry = new ProviderRegistry();\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["/**\n * Provider Adapter Interface for StackMemory\n *\n * Philosophy: \"Standardize the intersection; expose the union\"\n * - Portable core stream API with shared semantics across all providers\n * - Provider-specific extensions available through explicit opt-in capabilities\n */\n\n// =============================================================================\n// Core Types - Portable across all providers\n// =============================================================================\n\n/**\n * Message role - intersection of all providers\n */\nexport type MessageRole = 'user' | 'assistant' | 'system';\n\n/**\n * Content block types - intersection of all providers\n */\nexport type ContentBlockType = 'text' | 'image' | 'tool_use' | 'tool_result';\n\n/**\n * Base content block\n */\nexport interface ContentBlock {\n type: ContentBlockType;\n}\n\nexport interface TextBlock extends ContentBlock {\n type: 'text';\n text: string;\n}\n\nexport interface ImageBlock extends ContentBlock {\n type: 'image';\n source: {\n type: 'base64' | 'url';\n mediaType: 'image/jpeg' | 'image/png' | 'image/gif' | 'image/webp';\n data: string;\n };\n}\n\nexport interface ToolUseBlock extends ContentBlock {\n type: 'tool_use';\n id: string;\n name: string;\n input: Record<string, unknown>;\n}\n\nexport interface ToolResultBlock extends ContentBlock {\n type: 'tool_result';\n toolUseId: string;\n content: string | ContentBlock[];\n isError?: boolean;\n}\n\nexport type AnyContentBlock =\n | TextBlock\n | ImageBlock\n | ToolUseBlock\n | ToolResultBlock;\n\n/**\n * Message - portable message format\n */\nexport interface Message {\n role: MessageRole;\n content: string | AnyContentBlock[];\n}\n\n/**\n * Tool definition - portable tool schema\n */\nexport interface ToolDefinition {\n name: string;\n description: string;\n inputSchema: {\n type: 'object';\n properties: Record<string, unknown>;\n required?: string[];\n };\n}\n\n/**\n * Stream options - core options for all providers\n */\nexport interface StreamOptions {\n model: string;\n maxTokens: number;\n temperature?: number;\n topP?: number;\n stopSequences?: string[];\n system?: string;\n tools?: ToolDefinition[];\n}\n\n// =============================================================================\n// Stream Events - Portable event types\n// =============================================================================\n\nexport type StreamEventType =\n | 'message_start'\n | 'content_block_start'\n | 'content_block_delta'\n | 'content_block_stop'\n | 'message_delta'\n | 'message_stop'\n | 'error';\n\nexport interface StreamEventBase {\n type: StreamEventType;\n}\n\nexport interface MessageStartEvent extends StreamEventBase {\n type: 'message_start';\n message: {\n id: string;\n model: string;\n role: 'assistant';\n usage?: {\n inputTokens: number;\n outputTokens: number;\n };\n };\n}\n\nexport interface ContentBlockStartEvent extends StreamEventBase {\n type: 'content_block_start';\n index: number;\n contentBlock: AnyContentBlock;\n}\n\nexport interface ContentBlockDeltaEvent extends StreamEventBase {\n type: 'content_block_delta';\n index: number;\n delta: {\n type: 'text_delta' | 'input_json_delta';\n text?: string;\n partialJson?: string;\n };\n}\n\nexport interface ContentBlockStopEvent extends StreamEventBase {\n type: 'content_block_stop';\n index: number;\n}\n\nexport interface MessageDeltaEvent extends StreamEventBase {\n type: 'message_delta';\n delta: {\n stopReason?: 'end_turn' | 'max_tokens' | 'stop_sequence' | 'tool_use';\n };\n usage?: {\n outputTokens: number;\n };\n}\n\nexport interface MessageStopEvent extends StreamEventBase {\n type: 'message_stop';\n}\n\nexport interface ErrorEvent extends StreamEventBase {\n type: 'error';\n error: {\n type: string;\n message: string;\n };\n}\n\nexport type StreamEvent =\n | MessageStartEvent\n | ContentBlockStartEvent\n | ContentBlockDeltaEvent\n | ContentBlockStopEvent\n | MessageDeltaEvent\n | MessageStopEvent\n | ErrorEvent;\n\n// =============================================================================\n// Provider Capabilities - Union of provider-specific features\n// =============================================================================\n\n/**\n * Claude-specific extensions\n */\nexport interface ClaudeExtensions {\n /**\n * Extended thinking - deep reasoning capability\n */\n extendedThinking?: {\n enabled: boolean;\n budgetTokens?: number;\n };\n\n /**\n * XML-structured output preference\n */\n xmlOutput?: {\n enabled: boolean;\n rootElement?: string;\n };\n\n /**\n * Computer use - desktop automation\n */\n computerUse?: {\n enabled: boolean;\n displaySize?: { width: number; height: number };\n };\n\n /**\n * PDF/document support\n */\n documentSupport?: {\n enabled: boolean;\n maxPages?: number;\n };\n}\n\n/**\n * OpenAI GPT-specific extensions\n */\nexport interface GPTExtensions {\n /**\n * Code interpreter - execute Python code\n */\n codeInterpreter?: {\n enabled: boolean;\n fileIds?: string[];\n };\n\n /**\n * Web browsing capability\n */\n browsing?: {\n enabled: boolean;\n };\n\n /**\n * DALL-E image generation\n */\n imageGeneration?: {\n enabled: boolean;\n size?: '256x256' | '512x512' | '1024x1024' | '1792x1024' | '1024x1792';\n quality?: 'standard' | 'hd';\n };\n\n /**\n * Function calling mode\n */\n functionCalling?: {\n mode: 'auto' | 'none' | 'required';\n };\n\n /**\n * JSON mode output\n */\n jsonMode?: {\n enabled: boolean;\n schema?: Record<string, unknown>;\n };\n}\n\n/**\n * Google Gemini-specific extensions\n */\nexport interface GeminiExtensions {\n /**\n * Grounding with Google Search\n */\n grounding?: {\n enabled: boolean;\n dynamicThreshold?: number;\n };\n\n /**\n * Native multimodal - video/audio support\n */\n multimodal?: {\n videoEnabled: boolean;\n audioEnabled: boolean;\n maxVideoDurationSec?: number;\n };\n\n /**\n * Code execution\n */\n codeExecution?: {\n enabled: boolean;\n };\n\n /**\n * Safety settings\n */\n safetySettings?: Array<{\n category: string;\n threshold: 'BLOCK_NONE' | 'BLOCK_LOW' | 'BLOCK_MEDIUM' | 'BLOCK_HIGH';\n }>;\n}\n\n/**\n * All provider extensions - union type\n */\nexport interface ProviderExtensions {\n claude?: ClaudeExtensions;\n gpt?: GPTExtensions;\n gemini?: GeminiExtensions;\n}\n\n// =============================================================================\n// Provider Adapter Interface\n// =============================================================================\n\n/**\n * Provider adapter interface - core contract for all providers\n */\nexport interface ProviderAdapter {\n /**\n * Unique provider identifier\n */\n readonly id: string;\n\n /**\n * Human-readable provider name\n */\n readonly name: string;\n\n /**\n * Provider version\n */\n readonly version: string;\n\n /**\n * Available extensions for this provider\n */\n readonly extensions: Partial<ProviderExtensions>;\n\n /**\n * Check if provider supports a specific extension\n */\n supportsExtension(extension: keyof ProviderExtensions): boolean;\n\n /**\n * Core streaming API - portable across all providers\n */\n stream(\n messages: Message[],\n options: StreamOptions\n ): AsyncIterable<StreamEvent>;\n\n /**\n * Non-streaming completion\n */\n complete(\n messages: Message[],\n options: StreamOptions\n ): Promise<{\n content: AnyContentBlock[];\n usage: { inputTokens: number; outputTokens: number };\n stopReason: string;\n }>;\n\n /**\n * Validate API key / connection\n */\n validateConnection(): Promise<boolean>;\n\n /**\n * Get available models for this provider\n */\n listModels(): Promise<string[]>;\n}\n\n// =============================================================================\n// Claude Adapter Implementation\n// =============================================================================\n\n/**\n * Extended stream options for Claude\n */\nexport interface ClaudeStreamOptions extends StreamOptions {\n extensions?: ClaudeExtensions;\n}\n\n/**\n * Claude-specific stream events\n */\nexport interface ThinkingBlockStartEvent extends StreamEventBase {\n type: 'content_block_start';\n index: number;\n contentBlock: {\n type: 'thinking';\n thinking: string;\n };\n}\n\nexport interface ThinkingBlockDeltaEvent extends StreamEventBase {\n type: 'content_block_delta';\n index: number;\n delta: {\n type: 'thinking_delta';\n thinking: string;\n };\n}\n\n/**\n * Claude adapter - full implementation with extensions\n */\nexport class ClaudeAdapter implements ProviderAdapter {\n readonly id = 'claude';\n readonly name = 'Anthropic Claude';\n readonly version = '1.0.0';\n\n readonly extensions: ProviderExtensions = {\n claude: {\n extendedThinking: { enabled: true, budgetTokens: 10000 },\n xmlOutput: { enabled: true },\n computerUse: { enabled: true },\n documentSupport: { enabled: true, maxPages: 100 },\n },\n };\n\n private apiKey: string;\n private baseUrl: string;\n\n constructor(config: { apiKey: string; baseUrl?: string }) {\n this.apiKey = config.apiKey;\n this.baseUrl = config.baseUrl || 'https://api.anthropic.com';\n }\n\n supportsExtension(extension: keyof ProviderExtensions): boolean {\n return extension === 'claude';\n }\n\n async *stream(\n messages: Message[],\n options: ClaudeStreamOptions\n ): AsyncIterable<StreamEvent> {\n const body = this.buildRequestBody(messages, options);\n\n const response = await fetch(`${this.baseUrl}/v1/messages`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'x-api-key': this.apiKey,\n 'anthropic-version': '2023-06-01',\n 'anthropic-beta': this.getBetaFlags(options.extensions),\n },\n body: JSON.stringify({ ...body, stream: true }),\n });\n\n if (!response.ok) {\n yield {\n type: 'error',\n error: {\n type: 'api_error',\n message: `Claude API error: ${response.status} ${response.statusText}`,\n },\n };\n return;\n }\n\n const reader = response.body?.getReader();\n if (!reader) {\n yield {\n type: 'error',\n error: { type: 'stream_error', message: 'No response body' },\n };\n return;\n }\n\n const decoder = new TextDecoder();\n let buffer = '';\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() || '';\n\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n const data = line.slice(6);\n if (data === '[DONE]') return;\n\n try {\n const event = JSON.parse(data) as StreamEvent;\n yield this.normalizeEvent(event);\n } catch {\n // Skip malformed events\n }\n }\n }\n }\n }\n\n async complete(\n messages: Message[],\n options: ClaudeStreamOptions\n ): Promise<{\n content: AnyContentBlock[];\n usage: { inputTokens: number; outputTokens: number };\n stopReason: string;\n }> {\n const body = this.buildRequestBody(messages, options);\n\n const response = await fetch(`${this.baseUrl}/v1/messages`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'x-api-key': this.apiKey,\n 'anthropic-version': '2023-06-01',\n 'anthropic-beta': this.getBetaFlags(options.extensions),\n },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n throw new Error(\n `Claude API error: ${response.status} ${response.statusText}`\n );\n }\n\n const data = await response.json();\n\n return {\n content: data.content as AnyContentBlock[],\n usage: {\n inputTokens: data.usage?.input_tokens ?? 0,\n outputTokens: data.usage?.output_tokens ?? 0,\n },\n stopReason: data.stop_reason ?? 'end_turn',\n };\n }\n\n async validateConnection(): Promise<boolean> {\n try {\n const response = await fetch(`${this.baseUrl}/v1/messages`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'x-api-key': this.apiKey,\n 'anthropic-version': '2023-06-01',\n },\n body: JSON.stringify({\n model: 'claude-3-5-haiku-20241022',\n max_tokens: 1,\n messages: [{ role: 'user', content: 'hi' }],\n }),\n });\n return response.ok || response.status === 400;\n } catch {\n return false;\n }\n }\n\n async listModels(): Promise<string[]> {\n return [\n 'claude-opus-4-20250514',\n 'claude-sonnet-4-20250514',\n 'claude-3-5-haiku-20241022',\n 'claude-3-opus-20240229',\n ];\n }\n\n private buildRequestBody(\n messages: Message[],\n options: ClaudeStreamOptions\n ): Record<string, unknown> {\n const body: Record<string, unknown> = {\n model: options.model,\n max_tokens: options.maxTokens,\n messages: messages.map((m) => ({\n role: m.role,\n content: m.content,\n })),\n };\n\n if (options.temperature !== undefined) {\n body.temperature = options.temperature;\n }\n if (options.topP !== undefined) {\n body.top_p = options.topP;\n }\n if (options.stopSequences?.length) {\n body.stop_sequences = options.stopSequences;\n }\n if (options.system) {\n body.system = options.system;\n }\n if (options.tools?.length) {\n body.tools = options.tools.map((t) => ({\n name: t.name,\n description: t.description,\n input_schema: t.inputSchema,\n }));\n }\n\n // Claude extensions\n if (options.extensions?.extendedThinking?.enabled) {\n body.thinking = {\n type: 'enabled',\n budget_tokens:\n options.extensions.extendedThinking.budgetTokens || 10000,\n };\n // Extended thinking requires temperature = 1\n body.temperature = 1;\n }\n\n return body;\n }\n\n private getBetaFlags(extensions?: ClaudeExtensions): string {\n const flags: string[] = [];\n\n if (extensions?.extendedThinking?.enabled) {\n flags.push('interleaved-thinking-2025-05-14');\n }\n if (extensions?.computerUse?.enabled) {\n flags.push('computer-use-2024-10-22');\n }\n if (extensions?.documentSupport?.enabled) {\n flags.push('pdfs-2024-09-25');\n }\n\n return flags.join(',');\n }\n\n private normalizeEvent(event: StreamEvent): StreamEvent {\n // Normalize Claude-specific events to portable format\n return event;\n }\n}\n\n// =============================================================================\n// GPT Adapter Stub\n// =============================================================================\n\n/**\n * Extended stream options for GPT\n */\nexport interface GPTStreamOptions extends StreamOptions {\n extensions?: GPTExtensions;\n}\n\n/**\n * GPT adapter - stub implementation\n */\nexport class GPTAdapter implements ProviderAdapter {\n readonly id = 'gpt';\n readonly name = 'OpenAI GPT';\n readonly version = '1.0.0';\n\n readonly extensions: ProviderExtensions = {\n gpt: {\n codeInterpreter: { enabled: true },\n browsing: { enabled: true },\n imageGeneration: {\n enabled: true,\n size: '1024x1024',\n quality: 'standard',\n },\n functionCalling: { mode: 'auto' },\n jsonMode: { enabled: true },\n },\n };\n\n private apiKey: string;\n private baseUrl: string;\n\n constructor(config: { apiKey: string; baseUrl?: string }) {\n this.apiKey = config.apiKey;\n this.baseUrl = config.baseUrl || 'https://api.openai.com';\n }\n\n supportsExtension(extension: keyof ProviderExtensions): boolean {\n return extension === 'gpt';\n }\n\n async *stream(\n messages: Message[],\n options: GPTStreamOptions\n ): AsyncIterable<StreamEvent> {\n // Convert messages to OpenAI format\n const openaiMessages = messages.map((m) => ({\n role: m.role,\n content:\n typeof m.content === 'string'\n ? m.content\n : m.content\n .filter((c): c is TextBlock => c.type === 'text')\n .map((c) => c.text)\n .join(''),\n }));\n\n const body: Record<string, unknown> = {\n model: options.model,\n max_tokens: options.maxTokens,\n messages: openaiMessages,\n stream: true,\n };\n\n if (options.temperature !== undefined) {\n body.temperature = options.temperature;\n }\n if (options.topP !== undefined) {\n body.top_p = options.topP;\n }\n\n // GPT extensions\n if (options.extensions?.jsonMode?.enabled) {\n body.response_format = { type: 'json_object' };\n }\n\n if (options.tools?.length) {\n body.tools = options.tools.map((t) => ({\n type: 'function',\n function: {\n name: t.name,\n description: t.description,\n parameters: t.inputSchema,\n },\n }));\n\n if (options.extensions?.functionCalling?.mode) {\n body.tool_choice = options.extensions.functionCalling.mode;\n }\n }\n\n const response = await fetch(`${this.baseUrl}/v1/chat/completions`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${this.apiKey}`,\n },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n yield {\n type: 'error',\n error: {\n type: 'api_error',\n message: `GPT API error: ${response.status} ${response.statusText}`,\n },\n };\n return;\n }\n\n // Yield message start\n yield {\n type: 'message_start',\n message: {\n id: `msg_${Date.now()}`,\n model: options.model,\n role: 'assistant',\n },\n };\n\n const reader = response.body?.getReader();\n if (!reader) return;\n\n const decoder = new TextDecoder();\n let buffer = '';\n const blockIndex = 0;\n let blockStarted = false;\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() || '';\n\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n const data = line.slice(6);\n if (data === '[DONE]') {\n if (blockStarted) {\n yield { type: 'content_block_stop', index: blockIndex };\n }\n yield { type: 'message_stop' };\n return;\n }\n\n try {\n const parsed = JSON.parse(data);\n const delta = parsed.choices?.[0]?.delta;\n\n if (delta?.content && !blockStarted) {\n blockStarted = true;\n yield {\n type: 'content_block_start',\n index: blockIndex,\n contentBlock: { type: 'text', text: '' },\n };\n }\n\n if (delta?.content) {\n yield {\n type: 'content_block_delta',\n index: blockIndex,\n delta: { type: 'text_delta', text: delta.content },\n };\n }\n } catch {\n // Skip malformed events\n }\n }\n }\n }\n }\n\n async complete(\n messages: Message[],\n options: GPTStreamOptions\n ): Promise<{\n content: AnyContentBlock[];\n usage: { inputTokens: number; outputTokens: number };\n stopReason: string;\n }> {\n const openaiMessages = messages.map((m) => ({\n role: m.role,\n content:\n typeof m.content === 'string'\n ? m.content\n : m.content\n .filter((c): c is TextBlock => c.type === 'text')\n .map((c) => c.text)\n .join(''),\n }));\n\n const body: Record<string, unknown> = {\n model: options.model,\n max_tokens: options.maxTokens,\n messages: openaiMessages,\n };\n\n if (options.temperature !== undefined) {\n body.temperature = options.temperature;\n }\n\n const response = await fetch(`${this.baseUrl}/v1/chat/completions`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${this.apiKey}`,\n },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n throw new Error(\n `GPT API error: ${response.status} ${response.statusText}`\n );\n }\n\n const data = await response.json();\n const choice = data.choices?.[0];\n\n return {\n content: [{ type: 'text', text: choice?.message?.content ?? '' }],\n usage: {\n inputTokens: data.usage?.prompt_tokens ?? 0,\n outputTokens: data.usage?.completion_tokens ?? 0,\n },\n stopReason: choice?.finish_reason ?? 'stop',\n };\n }\n\n async validateConnection(): Promise<boolean> {\n try {\n const response = await fetch(`${this.baseUrl}/v1/models`, {\n headers: { Authorization: `Bearer ${this.apiKey}` },\n });\n return response.ok;\n } catch {\n return false;\n }\n }\n\n async listModels(): Promise<string[]> {\n return [\n 'gpt-4o',\n 'gpt-4o-mini',\n 'gpt-4-turbo',\n 'gpt-4',\n 'gpt-3.5-turbo',\n 'o1',\n 'o1-mini',\n 'o1-preview',\n ];\n }\n}\n\n// =============================================================================\n// Gemini Adapter Stub\n// =============================================================================\n\n/**\n * Extended stream options for Gemini\n */\nexport interface GeminiStreamOptions extends StreamOptions {\n extensions?: GeminiExtensions;\n}\n\n/**\n * Gemini adapter - stub implementation\n */\nexport class GeminiAdapter implements ProviderAdapter {\n readonly id = 'gemini';\n readonly name = 'Google Gemini';\n readonly version = '1.0.0';\n\n readonly extensions: ProviderExtensions = {\n gemini: {\n grounding: { enabled: true, dynamicThreshold: 0.3 },\n multimodal: {\n videoEnabled: true,\n audioEnabled: true,\n maxVideoDurationSec: 60,\n },\n codeExecution: { enabled: true },\n },\n };\n\n private apiKey: string;\n private baseUrl: string;\n\n constructor(config: { apiKey: string; baseUrl?: string }) {\n this.apiKey = config.apiKey;\n this.baseUrl =\n config.baseUrl || 'https://generativelanguage.googleapis.com/v1beta';\n }\n\n supportsExtension(extension: keyof ProviderExtensions): boolean {\n return extension === 'gemini';\n }\n\n async *stream(\n messages: Message[],\n options: GeminiStreamOptions\n ): AsyncIterable<StreamEvent> {\n // Convert messages to Gemini format\n const contents = messages\n .filter((m) => m.role !== 'system')\n .map((m) => ({\n role: m.role === 'assistant' ? 'model' : 'user',\n parts: [\n {\n text:\n typeof m.content === 'string'\n ? m.content\n : m.content\n .filter((c): c is TextBlock => c.type === 'text')\n .map((c) => c.text)\n .join(''),\n },\n ],\n }));\n\n const body: Record<string, unknown> = {\n contents,\n generationConfig: {\n maxOutputTokens: options.maxTokens,\n temperature: options.temperature,\n topP: options.topP,\n },\n };\n\n // System instruction\n const systemMsg = messages.find((m) => m.role === 'system');\n if (systemMsg || options.system) {\n body.systemInstruction = {\n parts: [\n {\n text:\n options.system ||\n (typeof systemMsg?.content === 'string' ? systemMsg.content : ''),\n },\n ],\n };\n }\n\n // Gemini extensions\n if (options.extensions?.grounding?.enabled) {\n body.tools = [\n {\n googleSearchRetrieval: {\n dynamicRetrievalConfig: {\n mode: 'MODE_DYNAMIC',\n dynamicThreshold: options.extensions.grounding.dynamicThreshold,\n },\n },\n },\n ];\n }\n\n if (options.extensions?.codeExecution?.enabled) {\n body.tools = [\n ...((body.tools as unknown[]) || []),\n { codeExecution: {} },\n ];\n }\n\n if (options.extensions?.safetySettings) {\n body.safetySettings = options.extensions.safetySettings;\n }\n\n const url = `${this.baseUrl}/models/${options.model}:streamGenerateContent?key=${this.apiKey}&alt=sse`;\n\n const response = await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n yield {\n type: 'error',\n error: {\n type: 'api_error',\n message: `Gemini API error: ${response.status} ${response.statusText}`,\n },\n };\n return;\n }\n\n yield {\n type: 'message_start',\n message: {\n id: `msg_${Date.now()}`,\n model: options.model,\n role: 'assistant',\n },\n };\n\n const reader = response.body?.getReader();\n if (!reader) return;\n\n const decoder = new TextDecoder();\n let buffer = '';\n const blockIndex = 0;\n let blockStarted = false;\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() || '';\n\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n try {\n const parsed = JSON.parse(line.slice(6));\n const text = parsed.candidates?.[0]?.content?.parts?.[0]?.text;\n\n if (text && !blockStarted) {\n blockStarted = true;\n yield {\n type: 'content_block_start',\n index: blockIndex,\n contentBlock: { type: 'text', text: '' },\n };\n }\n\n if (text) {\n yield {\n type: 'content_block_delta',\n index: blockIndex,\n delta: { type: 'text_delta', text },\n };\n }\n } catch {\n // Skip malformed events\n }\n }\n }\n }\n\n if (blockStarted) {\n yield { type: 'content_block_stop', index: blockIndex };\n }\n yield { type: 'message_stop' };\n }\n\n async complete(\n messages: Message[],\n options: GeminiStreamOptions\n ): Promise<{\n content: AnyContentBlock[];\n usage: { inputTokens: number; outputTokens: number };\n stopReason: string;\n }> {\n const contents = messages\n .filter((m) => m.role !== 'system')\n .map((m) => ({\n role: m.role === 'assistant' ? 'model' : 'user',\n parts: [\n {\n text:\n typeof m.content === 'string'\n ? m.content\n : m.content\n .filter((c): c is TextBlock => c.type === 'text')\n .map((c) => c.text)\n .join(''),\n },\n ],\n }));\n\n const body: Record<string, unknown> = {\n contents,\n generationConfig: {\n maxOutputTokens: options.maxTokens,\n temperature: options.temperature,\n },\n };\n\n const url = `${this.baseUrl}/models/${options.model}:generateContent?key=${this.apiKey}`;\n\n const response = await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n throw new Error(\n `Gemini API error: ${response.status} ${response.statusText}`\n );\n }\n\n const data = await response.json();\n const candidate = data.candidates?.[0];\n const text = candidate?.content?.parts?.[0]?.text ?? '';\n\n return {\n content: [{ type: 'text', text }],\n usage: {\n inputTokens: data.usageMetadata?.promptTokenCount ?? 0,\n outputTokens: data.usageMetadata?.candidatesTokenCount ?? 0,\n },\n stopReason: candidate?.finishReason ?? 'STOP',\n };\n }\n\n async validateConnection(): Promise<boolean> {\n try {\n const response = await fetch(`${this.baseUrl}/models?key=${this.apiKey}`);\n return response.ok;\n } catch {\n return false;\n }\n }\n\n async listModels(): Promise<string[]> {\n return [\n 'gemini-2.0-flash-exp',\n 'gemini-1.5-pro',\n 'gemini-1.5-flash',\n 'gemini-1.5-flash-8b',\n 'gemini-1.0-pro',\n ];\n }\n}\n\n// =============================================================================\n// Provider Registry\n// =============================================================================\n\nexport type ProviderId = 'claude' | 'gpt' | 'gemini';\n\n/**\n * Provider configuration\n */\nexport interface ProviderConfig {\n apiKey: string;\n baseUrl?: string;\n}\n\n/**\n * Create a provider adapter\n */\nexport function createProvider(\n id: ProviderId,\n config: ProviderConfig\n): ProviderAdapter {\n switch (id) {\n case 'claude':\n return new ClaudeAdapter(config);\n case 'gpt':\n return new GPTAdapter(config);\n case 'gemini':\n return new GeminiAdapter(config);\n default:\n throw new Error(`Unknown provider: ${id}`);\n }\n}\n\n/**\n * Provider registry for managing multiple providers\n */\nexport class ProviderRegistry {\n private providers = new Map<string, ProviderAdapter>();\n\n register(adapter: ProviderAdapter): void {\n this.providers.set(adapter.id, adapter);\n }\n\n get(id: string): ProviderAdapter | undefined {\n return this.providers.get(id);\n }\n\n list(): ProviderAdapter[] {\n return Array.from(this.providers.values());\n }\n\n has(id: string): boolean {\n return this.providers.has(id);\n }\n\n /**\n * Find providers that support a specific extension\n */\n findByExtension(extension: keyof ProviderExtensions): ProviderAdapter[] {\n return this.list().filter((p) => p.supportsExtension(extension));\n }\n}\n\n/**\n * Global provider registry\n */\nexport const providerRegistry = new ProviderRegistry();\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -14,7 +14,7 @@ class AnthropicLLMProvider {
|
|
|
14
14
|
this.client = new Anthropic({
|
|
15
15
|
apiKey: config.apiKey
|
|
16
16
|
});
|
|
17
|
-
this.model = config.model || "claude-3-haiku-
|
|
17
|
+
this.model = config.model || "claude-3-5-haiku-20241022";
|
|
18
18
|
this.temperature = config.temperature ?? 0.3;
|
|
19
19
|
this.maxRetries = config.maxRetries ?? 2;
|
|
20
20
|
this.timeout = config.timeout ?? 3e4;
|
|
@@ -139,7 +139,7 @@ function createLLMProvider() {
|
|
|
139
139
|
}
|
|
140
140
|
return new AnthropicLLMProvider({
|
|
141
141
|
apiKey,
|
|
142
|
-
model: process.env["ANTHROPIC_MODEL"] || "claude-3-haiku-
|
|
142
|
+
model: process.env["ANTHROPIC_MODEL"] || "claude-3-5-haiku-20241022",
|
|
143
143
|
temperature: parseFloat(process.env["ANTHROPIC_TEMPERATURE"] || "0.3")
|
|
144
144
|
});
|
|
145
145
|
}
|