@stackmemoryai/stackmemory 0.5.48 → 0.5.51
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 +17 -3
- package/dist/cli/claude-sm.js +246 -5
- package/dist/cli/claude-sm.js.map +3 -3
- package/dist/cli/commands/handoff.js +5 -5
- package/dist/cli/commands/handoff.js.map +2 -2
- package/dist/cli/commands/sweep.js +190 -421
- package/dist/cli/commands/sweep.js.map +3 -3
- package/dist/cli/index.js +8 -2
- package/dist/cli/index.js.map +2 -2
- package/dist/core/config/feature-flags.js +13 -1
- package/dist/core/config/feature-flags.js.map +2 -2
- package/dist/core/context/enhanced-rehydration.js +355 -9
- package/dist/core/context/enhanced-rehydration.js.map +3 -3
- package/dist/core/context/shared-context-layer.js +229 -0
- package/dist/core/context/shared-context-layer.js.map +2 -2
- package/dist/features/sweep/index.js +20 -0
- package/dist/features/sweep/index.js.map +7 -0
- package/dist/features/sweep/prediction-client.js +155 -0
- package/dist/features/sweep/prediction-client.js.map +7 -0
- package/dist/features/sweep/prompt-builder.js +85 -0
- package/dist/features/sweep/prompt-builder.js.map +7 -0
- package/dist/features/sweep/pty-wrapper.js +171 -0
- package/dist/features/sweep/pty-wrapper.js.map +7 -0
- package/dist/features/sweep/state-watcher.js +87 -0
- package/dist/features/sweep/state-watcher.js.map +7 -0
- package/dist/features/sweep/status-bar.js +88 -0
- package/dist/features/sweep/status-bar.js.map +7 -0
- package/dist/features/sweep/sweep-server-manager.js +226 -0
- package/dist/features/sweep/sweep-server-manager.js.map +7 -0
- package/dist/features/sweep/tab-interceptor.js +38 -0
- package/dist/features/sweep/tab-interceptor.js.map +7 -0
- package/dist/features/sweep/types.js +18 -0
- package/dist/features/sweep/types.js.map +7 -0
- package/package.json +1 -1
- package/scripts/test-setup-e2e.sh +154 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/cli/commands/sweep.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Sweep command for StackMemory\n * Provides next-edit predictions using the Sweep 1.5B model\n *\n * Usage:\n * stackmemory sweep setup Install dependencies and optionally download model\n * stackmemory sweep status Check if Sweep addon is properly configured\n * stackmemory sweep predict <file> Run prediction on a file\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n existsSync,\n readFileSync,\n writeFileSync,\n mkdirSync,\n copyFileSync,\n chmodSync,\n} from 'fs';\nimport { join } from 'path';\nimport { spawn, execSync } from 'child_process';\n\n// __filename and __dirname are provided by esbuild banner for ESM compatibility\n\ninterface SweepStatus {\n installed: boolean;\n model_downloaded: boolean;\n python_path?: string;\n model_path?: string;\n error?: string;\n}\n\ninterface SweepPredictResult {\n success: boolean;\n predicted_content?: string;\n file_path?: string;\n latency_ms?: number;\n tokens_generated?: number;\n error?: string;\n message?: string;\n}\n\nfunction findPythonScript(): string | null {\n const locations = [\n join(\n process.cwd(),\n 'packages',\n 'sweep-addon',\n 'python',\n 'sweep_predict.py'\n ),\n join(\n process.cwd(),\n 'node_modules',\n '@stackmemoryai',\n 'sweep-addon',\n 'python',\n 'sweep_predict.py'\n ),\n join(process.env.HOME || '', '.stackmemory', 'sweep', 'sweep_predict.py'),\n ];\n\n for (const loc of locations) {\n if (existsSync(loc)) {\n return loc;\n }\n }\n return null;\n}\n\nfunction findHookSource(): string | null {\n const locations = [\n join(process.cwd(), 'templates', 'claude-hooks', 'post-edit-sweep.js'),\n join(\n process.cwd(),\n 'node_modules',\n '@stackmemoryai',\n 'stackmemory',\n 'templates',\n 'claude-hooks',\n 'post-edit-sweep.js'\n ),\n join(\n dirname(dirname(dirname(__dirname))),\n 'templates',\n 'claude-hooks',\n 'post-edit-sweep.js'\n ),\n ];\n\n for (const loc of locations) {\n if (existsSync(loc)) {\n return loc;\n }\n }\n return null;\n}\n\nasync function findPython(): Promise<string | null> {\n const candidates = ['python3', 'python'];\n\n for (const cmd of candidates) {\n try {\n execSync(`${cmd} --version`, { stdio: 'pipe' });\n return cmd;\n } catch {\n continue;\n }\n }\n return null;\n}\n\nasync function checkSweepStatus(): Promise<SweepStatus> {\n const pythonPath = await findPython();\n if (!pythonPath) {\n return {\n installed: false,\n model_downloaded: false,\n error: 'Python not found. Install Python 3.10+',\n };\n }\n\n const scriptPath = findPythonScript();\n if (!scriptPath) {\n return {\n installed: false,\n model_downloaded: false,\n python_path: pythonPath,\n error: 'Sweep addon not installed. Run: stackmemory sweep setup',\n };\n }\n\n const homeDir = process.env.HOME || '';\n const modelPath = join(\n homeDir,\n '.stackmemory',\n 'models',\n 'sweep',\n 'sweep-next-edit-1.5b.q8_0.v2.gguf'\n );\n const modelDownloaded = existsSync(modelPath);\n\n return {\n installed: true,\n model_downloaded: modelDownloaded,\n python_path: pythonPath,\n model_path: modelDownloaded ? modelPath : undefined,\n };\n}\n\nasync function runPrediction(\n filePath: string,\n pythonPath: string,\n scriptPath: string\n): Promise<SweepPredictResult> {\n if (!existsSync(filePath)) {\n return {\n success: false,\n error: 'file_not_found',\n message: `File not found: ${filePath}`,\n };\n }\n\n const currentContent = readFileSync(filePath, 'utf-8');\n\n const input = {\n file_path: filePath,\n current_content: currentContent,\n };\n\n return new Promise((resolve) => {\n const proc = spawn(pythonPath, [scriptPath], {\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n\n let stdout = '';\n let stderr = '';\n\n proc.stdout.on('data', (data) => (stdout += data));\n proc.stderr.on('data', (data) => (stderr += data));\n\n proc.on('close', (code) => {\n try {\n if (stdout.trim()) {\n const result = JSON.parse(stdout.trim());\n resolve(result);\n } else if (code !== 0) {\n resolve({\n success: false,\n error: 'process_error',\n message: stderr || `Process exited with code ${code}`,\n });\n } else {\n resolve({\n success: false,\n error: 'no_output',\n message: 'No output from prediction script',\n });\n }\n } catch {\n resolve({\n success: false,\n error: 'parse_error',\n message: `Failed to parse output: ${stdout}`,\n });\n }\n });\n\n proc.on('error', (error) => {\n resolve({\n success: false,\n error: 'spawn_error',\n message: error.message,\n });\n });\n\n proc.stdin.write(JSON.stringify(input));\n proc.stdin.end();\n });\n}\n\nexport function createSweepCommand(): Command {\n const cmd = new Command('sweep')\n .description(\n 'Next-edit predictions using Sweep 1.5B model (optional addon)'\n )\n .addHelpText(\n 'after',\n `\nExamples:\n stackmemory sweep setup Install Python dependencies\n stackmemory sweep setup --download Also download the model (1.5GB)\n stackmemory sweep status Check addon status\n stackmemory sweep predict src/app.ts Predict next edit for a file\n\nRequirements:\n - Python 3.10+\n - pip packages: huggingface_hub, llama-cpp-python\n\nThe Sweep 1.5B model predicts what code changes you'll make next based on:\n - Current file content\n - Recent changes (diffs)\n - Context from other files\n\nModel is downloaded from HuggingFace on first prediction (~1.5GB).\n`\n );\n\n cmd\n .command('setup')\n .description('Install Python dependencies for Sweep addon')\n .option('--download', 'Also download the model now')\n .action(async (options) => {\n const spinner = ora('Checking Python...').start();\n\n const pythonPath = await findPython();\n if (!pythonPath) {\n spinner.fail(chalk.red('Python not found'));\n console.log(chalk.gray('Please install Python 3.10+'));\n process.exit(1);\n }\n\n spinner.text = 'Installing Python dependencies...';\n\n try {\n execSync(\n `${pythonPath} -m pip install --quiet huggingface_hub llama-cpp-python`,\n {\n stdio: 'pipe',\n }\n );\n spinner.succeed(chalk.green('Python dependencies installed'));\n } catch {\n spinner.fail(chalk.red('Failed to install dependencies'));\n console.log(\n chalk.gray(\n `Run: ${pythonPath} -m pip install huggingface_hub llama-cpp-python`\n )\n );\n process.exit(1);\n }\n\n if (options.download) {\n const downloadSpinner = ora('Downloading Sweep 1.5B model...').start();\n downloadSpinner.text = 'Downloading model from HuggingFace (~1.5GB)...';\n\n try {\n execSync(\n `${pythonPath} -c \"\nfrom huggingface_hub import hf_hub_download\nimport os\nmodel_dir = os.path.expanduser('~/.stackmemory/models/sweep')\nos.makedirs(model_dir, exist_ok=True)\nhf_hub_download(\n repo_id='sweepai/sweep-next-edit-1.5B',\n filename='sweep-next-edit-1.5b.q8_0.v2.gguf',\n repo_type='model',\n local_dir=model_dir,\n local_dir_use_symlinks=False\n)\n\"`,\n { stdio: 'pipe', timeout: 600000 }\n );\n downloadSpinner.succeed(chalk.green('Model downloaded'));\n } catch {\n downloadSpinner.fail(chalk.red('Model download failed'));\n console.log(chalk.gray('Model will be downloaded on first use'));\n }\n } else {\n console.log(\n chalk.gray('\\nModel will be downloaded on first prediction (~1.5GB)')\n );\n console.log(chalk.gray('Or run: stackmemory sweep setup --download'));\n }\n\n console.log(chalk.bold('\\nSetup complete!'));\n });\n\n cmd\n .command('status')\n .description('Check Sweep addon status')\n .action(async () => {\n console.log(chalk.bold('\\nSweep 1.5B Addon Status\\n'));\n\n const status = await checkSweepStatus();\n\n if (status.error) {\n console.log(chalk.red(`Error: ${status.error}`));\n console.log('');\n }\n\n console.log(\n `Python: ${status.python_path ? chalk.green(status.python_path) : chalk.red('Not found')}`\n );\n console.log(\n `Addon installed: ${status.installed ? chalk.green('Yes') : chalk.yellow('No')}`\n );\n console.log(\n `Model downloaded: ${status.model_downloaded ? chalk.green('Yes') : chalk.yellow('No (will download on first use)')}`\n );\n\n if (status.model_path) {\n console.log(chalk.gray(`Model path: ${status.model_path}`));\n }\n\n if (!status.installed) {\n console.log(chalk.bold('\\nTo install:'));\n console.log(' stackmemory sweep setup');\n }\n });\n\n cmd\n .command('predict <file>')\n .description('Predict next edit for a file')\n .option('-o, --output <path>', 'Write prediction to file instead of stdout')\n .option('--json', 'Output raw JSON result')\n .action(async (file, options) => {\n const status = await checkSweepStatus();\n\n if (!status.installed) {\n console.error(chalk.red('Sweep addon not installed'));\n console.log(chalk.gray('Run: stackmemory sweep setup'));\n process.exit(1);\n }\n\n const scriptPath = findPythonScript();\n if (!scriptPath || !status.python_path) {\n console.error(chalk.red('Could not find Sweep prediction script'));\n process.exit(1);\n }\n\n const spinner = ora('Running prediction...').start();\n\n if (!status.model_downloaded) {\n spinner.text = 'Downloading model (first time only, ~1.5GB)...';\n }\n\n const result = await runPrediction(file, status.python_path, scriptPath);\n\n if (!result.success) {\n spinner.fail(\n chalk.red(`Prediction failed: ${result.message || result.error}`)\n );\n process.exit(1);\n }\n\n spinner.succeed(chalk.green('Prediction complete'));\n\n if (options.json) {\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n console.log(chalk.bold('\\nPredicted content:'));\n console.log(chalk.gray('\u2500'.repeat(50)));\n console.log(result.predicted_content);\n console.log(chalk.gray('\u2500'.repeat(50)));\n\n if (result.latency_ms) {\n console.log(chalk.gray(`Latency: ${result.latency_ms}ms`));\n }\n if (result.tokens_generated) {\n console.log(chalk.gray(`Tokens: ${result.tokens_generated}`));\n }\n\n if (options.output) {\n const { writeFileSync } = await import('fs');\n writeFileSync(options.output, result.predicted_content || '');\n console.log(chalk.green(`\\nWritten to: ${options.output}`));\n }\n });\n\n const hookCmd = cmd\n .command('hook')\n .description('Manage Claude Code integration hook');\n\n hookCmd\n .command('install')\n .description('Install Sweep prediction hook for Claude Code')\n .action(async () => {\n const spinner = ora('Installing Sweep hook...').start();\n\n const homeDir = process.env.HOME || '';\n const hookDir = join(homeDir, '.claude', 'hooks');\n const sweepDir = join(homeDir, '.stackmemory', 'sweep');\n const hooksJsonPath = join(homeDir, '.claude', 'hooks.json');\n\n try {\n mkdirSync(hookDir, { recursive: true });\n mkdirSync(sweepDir, { recursive: true });\n\n const hookSource = findHookSource();\n if (!hookSource) {\n spinner.fail(chalk.red('Hook template not found'));\n console.log(\n chalk.gray('Ensure stackmemory is installed from the repository')\n );\n process.exit(1);\n }\n\n const hookDest = join(hookDir, 'post-edit-sweep.js');\n copyFileSync(hookSource, hookDest);\n chmodSync(hookDest, '755');\n\n const pythonScriptSource = findPythonScript();\n if (pythonScriptSource) {\n const pythonDest = join(sweepDir, 'sweep_predict.py');\n copyFileSync(pythonScriptSource, pythonDest);\n }\n\n if (existsSync(hooksJsonPath)) {\n const hooks = JSON.parse(readFileSync(hooksJsonPath, 'utf-8'));\n if (!hooks['post-tool-use']) {\n hooks['post-tool-use'] = hookDest;\n writeFileSync(hooksJsonPath, JSON.stringify(hooks, null, 2));\n } else if (!hooks['post-tool-use'].includes('sweep')) {\n spinner.warn(chalk.yellow('post-tool-use hook already configured'));\n console.log(chalk.gray(`Existing: ${hooks['post-tool-use']}`));\n console.log(chalk.gray(`Hook installed at: ${hookDest}`));\n console.log(\n chalk.gray('You may need to manually configure the hook chain')\n );\n return;\n }\n } else {\n const hooks = { 'post-tool-use': hookDest };\n writeFileSync(hooksJsonPath, JSON.stringify(hooks, null, 2));\n }\n\n spinner.succeed(chalk.green('Sweep hook installed'));\n console.log(chalk.gray(`Hook: ${hookDest}`));\n console.log(chalk.gray(`Config: ${hooksJsonPath}`));\n console.log('');\n console.log(chalk.bold('Usage:'));\n console.log(' Hook runs automatically after Edit/Write operations');\n console.log(' Predictions appear after 2+ edits in session');\n console.log(' Disable: export SWEEP_ENABLED=false');\n } catch (error) {\n spinner.fail(chalk.red('Installation failed'));\n console.log(chalk.gray((error as Error).message));\n process.exit(1);\n }\n });\n\n hookCmd\n .command('status')\n .description('Check hook installation status')\n .action(async () => {\n const homeDir = process.env.HOME || '';\n const hookPath = join(homeDir, '.claude', 'hooks', 'post-edit-sweep.js');\n const hooksJsonPath = join(homeDir, '.claude', 'hooks.json');\n const statePath = join(homeDir, '.stackmemory', 'sweep-state.json');\n\n console.log(chalk.bold('\\nSweep Hook Status\\n'));\n\n const hookInstalled = existsSync(hookPath);\n console.log(\n `Hook installed: ${hookInstalled ? chalk.green('Yes') : chalk.yellow('No')}`\n );\n\n if (existsSync(hooksJsonPath)) {\n const hooks = JSON.parse(readFileSync(hooksJsonPath, 'utf-8'));\n const configured =\n hooks['post-tool-use'] && hooks['post-tool-use'].includes('sweep');\n console.log(\n `Hook configured: ${configured ? chalk.green('Yes') : chalk.yellow('No')}`\n );\n } else {\n console.log(`Hook configured: ${chalk.yellow('No hooks.json')}`);\n }\n\n const enabled = process.env.SWEEP_ENABLED !== 'false';\n console.log(\n `Enabled: ${enabled ? chalk.green('Yes') : chalk.yellow('Disabled (SWEEP_ENABLED=false)')}`\n );\n\n if (existsSync(statePath)) {\n try {\n const state = JSON.parse(readFileSync(statePath, 'utf-8'));\n console.log(\n chalk.gray(\n `\\nRecent diffs tracked: ${state.recentDiffs?.length || 0}`\n )\n );\n if (state.lastPrediction) {\n const age = Date.now() - state.lastPrediction.timestamp;\n const ageStr =\n age < 60000\n ? `${Math.round(age / 1000)}s ago`\n : `${Math.round(age / 60000)}m ago`;\n console.log(chalk.gray(`Last prediction: ${ageStr}`));\n }\n } catch {\n // Ignore parse errors\n }\n }\n\n if (!hookInstalled) {\n console.log(chalk.bold('\\nTo install: stackmemory sweep hook install'));\n }\n });\n\n hookCmd\n .command('disable')\n .description('Disable the Sweep hook')\n .action(() => {\n console.log(chalk.bold('\\nTo disable Sweep predictions:\\n'));\n console.log(' Temporarily: export SWEEP_ENABLED=false');\n console.log(' Permanently: Add to ~/.zshrc or ~/.bashrc');\n console.log('');\n console.log('Or remove the hook:');\n console.log(' rm ~/.claude/hooks/post-edit-sweep.js');\n });\n\n hookCmd\n .command('clear')\n .description('Clear hook state (recent diffs and predictions)')\n .action(() => {\n const homeDir = process.env.HOME || '';\n const statePath = join(homeDir, '.stackmemory', 'sweep-state.json');\n\n if (existsSync(statePath)) {\n writeFileSync(\n statePath,\n JSON.stringify(\n {\n recentDiffs: [],\n lastPrediction: null,\n pendingPrediction: null,\n fileContents: {},\n },\n null,\n 2\n )\n );\n console.log(chalk.green('Sweep state cleared'));\n } else {\n console.log(chalk.gray('No state file found'));\n }\n });\n\n cmd.action(async () => {\n const status = await checkSweepStatus();\n console.log(chalk.bold('\\nSweep 1.5B Addon Status\\n'));\n\n console.log(\n `Installed: ${status.installed ? chalk.green('Yes') : chalk.yellow('No')}`\n );\n console.log(\n `Model ready: ${status.model_downloaded ? chalk.green('Yes') : chalk.yellow('No')}`\n );\n\n if (!status.installed) {\n console.log(chalk.bold('\\nRun: stackmemory sweep setup'));\n } else {\n console.log(chalk.bold('\\nUsage: stackmemory sweep predict <file>'));\n }\n });\n\n return cmd;\n}\n\nexport default createSweepCommand();\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": [
|
|
4
|
+
"sourcesContent": ["/**\n * Sweep CLI Command\n * Manage Sweep Next-Edit prediction server\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { existsSync } from 'fs';\nimport { join } from 'path';\nimport {\n createServerManager,\n createPredictionClient,\n launchWrapper,\n SweepServerConfig,\n DEFAULT_SERVER_CONFIG,\n} from '../../features/sweep/index.js';\n\nconst HOME = process.env['HOME'] || '/tmp';\n\nexport function createSweepCommand(): Command {\n const cmd = new Command('sweep')\n .description('Manage Sweep Next-Edit prediction server')\n .addHelpText(\n 'after',\n `\nExamples:\n stackmemory sweep start Start the Sweep server\n stackmemory sweep stop Stop the Sweep server\n stackmemory sweep status Check server status\n stackmemory sweep predict Run a prediction manually\n stackmemory sweep hook Install/check Claude Code hook\n\nThe Sweep server uses the Sweep 1.5B model for next-edit predictions.\nPredictions are triggered after file edits via Claude Code hooks.\n`\n );\n\n // Start command\n cmd\n .command('start')\n .description('Start the Sweep prediction server')\n .option(\n '--port <number>',\n 'Server port',\n String(DEFAULT_SERVER_CONFIG.port)\n )\n .option('--model <path>', 'Path to GGUF model file')\n .option(\n '--context <size>',\n 'Context size',\n String(DEFAULT_SERVER_CONFIG.contextSize)\n )\n .option('--gpu-layers <n>', 'Number of GPU layers (0 for CPU only)', '0')\n .action(async (options) => {\n const spinner = ora('Starting Sweep server...').start();\n\n try {\n const config: Partial<SweepServerConfig> = {\n port: parseInt(options.port, 10),\n contextSize: parseInt(options.context, 10),\n gpuLayers: parseInt(options.gpuLayers, 10),\n };\n\n if (options.model) {\n config.modelPath = options.model;\n }\n\n const manager = createServerManager(config);\n const status = await manager.startServer();\n\n spinner.succeed(chalk.green('Sweep server started'));\n console.log(chalk.gray(` PID: ${status.pid}`));\n console.log(chalk.gray(` Port: ${status.port}`));\n console.log(chalk.gray(` Model: ${status.modelPath}`));\n } catch (error) {\n spinner.fail(chalk.red('Failed to start Sweep server'));\n console.error(chalk.red((error as Error).message));\n process.exit(1);\n }\n });\n\n // Stop command\n cmd\n .command('stop')\n .description('Stop the Sweep prediction server')\n .action(async () => {\n const spinner = ora('Stopping Sweep server...').start();\n\n try {\n const manager = createServerManager();\n await manager.stopServer();\n spinner.succeed(chalk.green('Sweep server stopped'));\n } catch (error) {\n spinner.fail(chalk.red('Failed to stop Sweep server'));\n console.error(chalk.red((error as Error).message));\n process.exit(1);\n }\n });\n\n // Status command\n cmd\n .command('status')\n .description('Check Sweep server status')\n .action(async () => {\n try {\n const manager = createServerManager();\n const status = await manager.getStatus();\n\n if (status.running) {\n console.log(chalk.green('Sweep server is running'));\n console.log(chalk.gray(` PID: ${status.pid}`));\n console.log(chalk.gray(` Port: ${status.port}`));\n console.log(chalk.gray(` Host: ${status.host}`));\n if (status.startedAt) {\n const uptime = Math.floor((Date.now() - status.startedAt) / 1000);\n console.log(chalk.gray(` Uptime: ${formatUptime(uptime)}`));\n }\n if (status.modelPath) {\n console.log(chalk.gray(` Model: ${status.modelPath}`));\n }\n } else {\n console.log(chalk.yellow('Sweep server is not running'));\n console.log(chalk.gray(' Start with: stackmemory sweep start'));\n }\n\n // Check model availability\n const defaultModelPath = join(\n HOME,\n '.stackmemory',\n 'models',\n 'sweep',\n 'sweep-next-edit-1.5b.q8_0.v2.gguf'\n );\n if (!existsSync(defaultModelPath)) {\n console.log('');\n console.log(chalk.yellow('Model not found at default location'));\n console.log(\n chalk.gray(\n ' Download with:\\n' +\n ' huggingface-cli download sweepai/sweep-next-edit-1.5B \\\\\\n' +\n ' sweep-next-edit-1.5b.q8_0.v2.gguf \\\\\\n' +\n ' --local-dir ~/.stackmemory/models/sweep'\n )\n );\n }\n } catch (error) {\n console.error(\n chalk.red('Error checking status:'),\n (error as Error).message\n );\n process.exit(1);\n }\n });\n\n // Predict command (for testing)\n cmd\n .command('predict')\n .description('Run a prediction manually (for testing)')\n .argument('<file>', 'File to predict edits for')\n .option(\n '--port <number>',\n 'Server port',\n String(DEFAULT_SERVER_CONFIG.port)\n )\n .action(async (file, options) => {\n const spinner = ora('Running prediction...').start();\n\n try {\n const { readFileSync } = await import('fs');\n const content = readFileSync(file, 'utf-8');\n\n const client = createPredictionClient({\n port: parseInt(options.port, 10),\n });\n\n // Check server\n const healthy = await client.checkHealth();\n if (!healthy) {\n spinner.fail(chalk.red('Server not running'));\n console.log(chalk.gray('Start with: stackmemory sweep start'));\n process.exit(1);\n }\n\n const result = await client.predict({\n file_path: file,\n current_content: content,\n recent_diffs: [],\n });\n\n spinner.stop();\n\n if (result.success && result.predicted_content) {\n console.log(chalk.green('Prediction complete'));\n console.log(chalk.gray(`Latency: ${result.latency_ms}ms`));\n console.log(chalk.gray(`Tokens: ${result.tokens_generated}`));\n console.log('');\n console.log(chalk.cyan('Predicted content:'));\n console.log(result.predicted_content.slice(0, 500));\n if (result.predicted_content.length > 500) {\n console.log(chalk.gray('... (truncated)'));\n }\n } else if (result.success) {\n console.log(chalk.yellow('No changes predicted'));\n } else {\n console.log(chalk.red('Prediction failed:'), result.message);\n }\n } catch (error) {\n spinner.fail(chalk.red('Prediction failed'));\n console.error(chalk.red((error as Error).message));\n process.exit(1);\n }\n });\n\n // Hook command\n cmd\n .command('hook')\n .description('Check Claude Code hook status')\n .action(async () => {\n const hookPath = join(HOME, '.claude', 'hooks', 'post-edit-sweep.js');\n const templatePath = join(\n process.cwd(),\n 'templates',\n 'claude-hooks',\n 'post-edit-sweep.js'\n );\n\n console.log(chalk.cyan('Sweep Hook Status'));\n console.log('');\n\n if (existsSync(hookPath)) {\n console.log(chalk.green('Hook installed:'), hookPath);\n } else {\n console.log(chalk.yellow('Hook not installed'));\n console.log(chalk.gray(` Copy from: ${templatePath}`));\n console.log(chalk.gray(` To: ${hookPath}`));\n }\n\n // Check settings.json\n const settingsPath = join(HOME, '.claude', 'settings.json');\n if (existsSync(settingsPath)) {\n try {\n const { readFileSync } = await import('fs');\n const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n const hasHook = JSON.stringify(settings).includes('post-edit-sweep');\n if (hasHook) {\n console.log(chalk.green('Hook registered in settings.json'));\n } else {\n console.log(chalk.yellow('Hook not registered in settings.json'));\n console.log(\n chalk.gray(\n ' Add to hooks.PostToolUse:\\n' +\n ' { \"matcher\": \"Edit\", \"hooks\": [{ \"type\": \"command\", \"command\": \"node ~/.claude/hooks/post-edit-sweep.js\" }] }'\n )\n );\n }\n } catch {\n console.log(chalk.yellow('Could not read settings.json'));\n }\n } else {\n console.log(chalk.yellow('settings.json not found'));\n }\n\n // Check state file\n const statePath = join(HOME, '.stackmemory', 'sweep-state.json');\n if (existsSync(statePath)) {\n try {\n const { readFileSync } = await import('fs');\n const state = JSON.parse(readFileSync(statePath, 'utf-8'));\n console.log(\n chalk.gray(\n ` Recent diffs tracked: ${state.recentDiffs?.length || 0}`\n )\n );\n if (state.lastPrediction) {\n const ago = Math.floor(\n (Date.now() - state.lastPrediction.timestamp) / 1000\n );\n console.log(\n chalk.gray(` Last prediction: ${formatUptime(ago)} ago`)\n );\n }\n } catch {\n // Ignore\n }\n }\n });\n\n // Wrap command\n cmd\n .command('wrap')\n .description('Launch Claude Code with Sweep prediction status bar')\n .option('--claude-bin <path>', 'Path to claude binary')\n .allowUnknownOption(true)\n .action(async (options, command) => {\n try {\n const claudeArgs = command.args || [];\n await launchWrapper({\n claudeBin: options.claudeBin,\n claudeArgs,\n });\n } catch (error) {\n console.error(chalk.red((error as Error).message));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\nfunction formatUptime(seconds: number): string {\n if (seconds < 60) return `${seconds}s`;\n if (seconds < 3600) return `${Math.floor(seconds / 60)}m ${seconds % 60}s`;\n const hours = Math.floor(seconds / 3600);\n const mins = Math.floor((seconds % 3600) / 60);\n return `${hours}h ${mins}m`;\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
7
|
}
|
package/dist/cli/index.js
CHANGED
|
@@ -30,13 +30,13 @@ import {
|
|
|
30
30
|
createMemoryCommand
|
|
31
31
|
} from "./commands/decision.js";
|
|
32
32
|
import clearCommand from "./commands/clear.js";
|
|
33
|
-
import createRalphCommand from "./commands/ralph.js";
|
|
34
33
|
import serviceCommand from "./commands/service.js";
|
|
35
34
|
import { registerLoginCommand } from "./commands/login.js";
|
|
36
35
|
import { registerSignupCommand } from "./commands/signup.js";
|
|
37
36
|
import { registerLogoutCommand, registerDbCommands } from "./commands/db.js";
|
|
38
37
|
import { createHooksCommand } from "./commands/hooks.js";
|
|
39
38
|
import { createDaemonCommand } from "./commands/daemon.js";
|
|
39
|
+
import { createSweepCommand } from "./commands/sweep.js";
|
|
40
40
|
import { createShellCommand } from "./commands/shell.js";
|
|
41
41
|
import { createAPICommand } from "./commands/api.js";
|
|
42
42
|
import { createCleanupProcessesCommand } from "./commands/cleanup-processes.js";
|
|
@@ -510,7 +510,6 @@ program.addCommand(createHandoffCommand());
|
|
|
510
510
|
program.addCommand(createDecisionCommand());
|
|
511
511
|
program.addCommand(createMemoryCommand());
|
|
512
512
|
program.addCommand(clearCommand);
|
|
513
|
-
program.addCommand(createRalphCommand());
|
|
514
513
|
program.addCommand(serviceCommand);
|
|
515
514
|
program.addCommand(createHooksCommand());
|
|
516
515
|
if (isFeatureEnabled("skills")) {
|
|
@@ -519,7 +518,14 @@ if (isFeatureEnabled("skills")) {
|
|
|
519
518
|
).catch(() => {
|
|
520
519
|
});
|
|
521
520
|
}
|
|
521
|
+
if (isFeatureEnabled("ralph")) {
|
|
522
|
+
import("./commands/ralph.js").then(
|
|
523
|
+
({ default: createRalphCommand }) => program.addCommand(createRalphCommand())
|
|
524
|
+
).catch(() => {
|
|
525
|
+
});
|
|
526
|
+
}
|
|
522
527
|
program.addCommand(createDaemonCommand());
|
|
528
|
+
program.addCommand(createSweepCommand());
|
|
523
529
|
program.addCommand(createShellCommand());
|
|
524
530
|
program.addCommand(createAPICommand());
|
|
525
531
|
program.addCommand(createCleanupProcessesCommand());
|
package/dist/cli/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/cli/index.ts"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory CLI\n * Command-line interface for StackMemory operations\n */\n\n// Set environment flag for CLI usage to skip async context bridge\nprocess.env['STACKMEMORY_CLI'] = 'true';\n\n// Load environment variables\nimport 'dotenv/config';\n\n// Initialize tracing system early\nimport { initializeTracing, trace } from '../core/trace/index.js';\ninitializeTracing();\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/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 { createHandoffCommand } from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport clearCommand from './commands/clear.js';\nimport createRalphCommand from './commands/ralph.js';\nimport serviceCommand from './commands/service.js';\nimport { registerLoginCommand } from './commands/login.js';\nimport { registerSignupCommand } from './commands/signup.js';\nimport { registerLogoutCommand, registerDbCommands } from './commands/db.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.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\nimport { createRequire } from 'module';\nconst require = createRequire(import.meta.url);\nconst pkg = require('../../package.json');\nconst VERSION = pkg.version;\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\n// Auto-start webhook and ngrok if notifications are enabled\nasync function startNotificationServices(): Promise<void> {\n // 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\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(createHandoffCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(createRalphCommand());\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}\nprogram.addCommand(createDaemonCommand());\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\nimport 'dotenv/config';\n\n// Initialize tracing system early\nimport { initializeTracing, trace } from '../core/trace/index.js';\ninitializeTracing();\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/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 { createHandoffCommand } 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\nimport { createRequire } from 'module';\nconst require = createRequire(import.meta.url);\nconst pkg = require('../../package.json');\nconst VERSION = pkg.version;\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\n// Auto-start webhook and ngrok if notifications are enabled\nasync function startNotificationServices(): Promise<void> {\n // 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\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(createHandoffCommand());\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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",
|
|
6
6
|
"names": ["require", "mkdirSync", "existsSync"]
|
|
7
7
|
}
|
|
@@ -19,6 +19,10 @@ function isFeatureEnabled(feature) {
|
|
|
19
19
|
return process.env["STACKMEMORY_AI"] !== "false" && (!!process.env["ANTHROPIC_API_KEY"] || !!process.env["OPENAI_API_KEY"]);
|
|
20
20
|
case "skills":
|
|
21
21
|
return process.env["STACKMEMORY_SKILLS"] === "true" || process.env["STACKMEMORY_SKILLS"] === "1";
|
|
22
|
+
case "ralph":
|
|
23
|
+
return process.env["STACKMEMORY_RALPH"] !== "false";
|
|
24
|
+
case "greptile":
|
|
25
|
+
return process.env["STACKMEMORY_GREPTILE"] !== "false" && !!process.env["GREPTILE_API_KEY"];
|
|
22
26
|
default:
|
|
23
27
|
return false;
|
|
24
28
|
}
|
|
@@ -30,7 +34,9 @@ function getFeatureFlags() {
|
|
|
30
34
|
whatsapp: isFeatureEnabled("whatsapp"),
|
|
31
35
|
chromadb: isFeatureEnabled("chromadb"),
|
|
32
36
|
aiSummaries: isFeatureEnabled("aiSummaries"),
|
|
33
|
-
skills: isFeatureEnabled("skills")
|
|
37
|
+
skills: isFeatureEnabled("skills"),
|
|
38
|
+
ralph: isFeatureEnabled("ralph"),
|
|
39
|
+
greptile: isFeatureEnabled("greptile")
|
|
34
40
|
};
|
|
35
41
|
}
|
|
36
42
|
function logFeatureStatus() {
|
|
@@ -53,6 +59,12 @@ function logFeatureStatus() {
|
|
|
53
59
|
console.log(
|
|
54
60
|
` Skills: ${flags.skills ? "enabled" : "disabled (set STACKMEMORY_SKILLS=true)"}`
|
|
55
61
|
);
|
|
62
|
+
console.log(
|
|
63
|
+
` Ralph: ${flags.ralph ? "enabled" : "disabled (set STACKMEMORY_RALPH=true)"}`
|
|
64
|
+
);
|
|
65
|
+
console.log(
|
|
66
|
+
` Greptile: ${flags.greptile ? "enabled" : "disabled (no GREPTILE_API_KEY)"}`
|
|
67
|
+
);
|
|
56
68
|
}
|
|
57
69
|
}
|
|
58
70
|
export {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/core/config/feature-flags.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Feature Flags Configuration\n * Controls which external integrations are enabled\n *\n * Set STACKMEMORY_LOCAL=true to run without any external services\n */\n\nexport interface FeatureFlags {\n // Core features (always available)\n core: true;\n\n // External integrations (can be disabled)\n linear: boolean;\n whatsapp: boolean;\n chromadb: boolean;\n aiSummaries: boolean;\n skills: boolean;\n}\n\n/**\n * Check if running in local-only mode\n * When true, all external service integrations are disabled\n */\nexport function isLocalOnly(): boolean {\n return (\n process.env['STACKMEMORY_LOCAL'] === 'true' ||\n process.env['STACKMEMORY_LOCAL'] === '1' ||\n process.env['LOCAL_ONLY'] === 'true'\n );\n}\n\n/**\n * Check if a specific feature is enabled\n */\nexport function isFeatureEnabled(feature: keyof FeatureFlags): boolean {\n if (feature === 'core') return true;\n\n // In local-only mode, external integrations are disabled\n if (isLocalOnly()) return false;\n\n // Check feature-specific env vars\n switch (feature) {\n case 'linear':\n return (\n process.env['STACKMEMORY_LINEAR'] !== 'false' &&\n (!!process.env['LINEAR_API_KEY'] || !!process.env['LINEAR_OAUTH_TOKEN'])\n );\n case 'whatsapp':\n return (\n process.env['STACKMEMORY_WHATSAPP'] !== 'false' &&\n !!process.env['TWILIO_ACCOUNT_SID']\n );\n case 'chromadb':\n return process.env['STACKMEMORY_CHROMADB'] === 'true';\n case 'aiSummaries':\n return (\n process.env['STACKMEMORY_AI'] !== 'false' &&\n (!!process.env['ANTHROPIC_API_KEY'] || !!process.env['OPENAI_API_KEY'])\n );\n case 'skills':\n // Skills enabled explicitly or when AI summaries available\n return (\n process.env['STACKMEMORY_SKILLS'] === 'true' ||\n process.env['STACKMEMORY_SKILLS'] === '1'\n );\n default:\n return false;\n }\n}\n\n/**\n * Get all feature flags\n */\nexport function getFeatureFlags(): FeatureFlags {\n return {\n core: true,\n linear: isFeatureEnabled('linear'),\n whatsapp: isFeatureEnabled('whatsapp'),\n chromadb: isFeatureEnabled('chromadb'),\n aiSummaries: isFeatureEnabled('aiSummaries'),\n skills: isFeatureEnabled('skills'),\n };\n}\n\n/**\n * Log feature flags status (for debugging)\n */\nexport function logFeatureStatus(): void {\n const flags = getFeatureFlags();\n const local = isLocalOnly();\n\n console.log(\n `StackMemory Mode: ${local ? 'LOCAL (no external services)' : 'FULL'}`\n );\n if (!local) {\n console.log(\n ` Linear: ${flags.linear ? 'enabled' : 'disabled (no API key)'}`\n );\n console.log(\n ` WhatsApp: ${flags.whatsapp ? 'enabled' : 'disabled (no Twilio)'}`\n );\n console.log(` ChromaDB: ${flags.chromadb ? 'enabled' : 'disabled'}`);\n console.log(\n ` AI Summaries: ${flags.aiSummaries ? 'enabled' : 'disabled (no API key)'}`\n );\n console.log(\n ` Skills: ${flags.skills ? 'enabled' : 'disabled (set STACKMEMORY_SKILLS=true)'}`\n );\n }\n}\n"],
|
|
5
|
-
"mappings": ";;;;
|
|
4
|
+
"sourcesContent": ["/**\n * Feature Flags Configuration\n * Controls which external integrations are enabled\n *\n * Set STACKMEMORY_LOCAL=true to run without any external services\n */\n\nexport interface FeatureFlags {\n // Core features (always available)\n core: true;\n\n // External integrations (can be disabled)\n linear: boolean;\n whatsapp: boolean;\n chromadb: boolean;\n aiSummaries: boolean;\n skills: boolean;\n ralph: boolean;\n greptile: boolean;\n}\n\n/**\n * Check if running in local-only mode\n * When true, all external service integrations are disabled\n */\nexport function isLocalOnly(): boolean {\n return (\n process.env['STACKMEMORY_LOCAL'] === 'true' ||\n process.env['STACKMEMORY_LOCAL'] === '1' ||\n process.env['LOCAL_ONLY'] === 'true'\n );\n}\n\n/**\n * Check if a specific feature is enabled\n */\nexport function isFeatureEnabled(feature: keyof FeatureFlags): boolean {\n if (feature === 'core') return true;\n\n // In local-only mode, external integrations are disabled\n if (isLocalOnly()) return false;\n\n // Check feature-specific env vars\n switch (feature) {\n case 'linear':\n return (\n process.env['STACKMEMORY_LINEAR'] !== 'false' &&\n (!!process.env['LINEAR_API_KEY'] || !!process.env['LINEAR_OAUTH_TOKEN'])\n );\n case 'whatsapp':\n return (\n process.env['STACKMEMORY_WHATSAPP'] !== 'false' &&\n !!process.env['TWILIO_ACCOUNT_SID']\n );\n case 'chromadb':\n return process.env['STACKMEMORY_CHROMADB'] === 'true';\n case 'aiSummaries':\n return (\n process.env['STACKMEMORY_AI'] !== 'false' &&\n (!!process.env['ANTHROPIC_API_KEY'] || !!process.env['OPENAI_API_KEY'])\n );\n case 'skills':\n // Skills enabled explicitly or when AI summaries available\n return (\n process.env['STACKMEMORY_SKILLS'] === 'true' ||\n process.env['STACKMEMORY_SKILLS'] === '1'\n );\n case 'ralph':\n // Ralph enabled by default in development (unless explicitly disabled)\n // For npm package users, must be explicitly enabled\n return process.env['STACKMEMORY_RALPH'] !== 'false';\n case 'greptile':\n // Greptile enabled when API key is available\n return (\n process.env['STACKMEMORY_GREPTILE'] !== 'false' &&\n !!process.env['GREPTILE_API_KEY']\n );\n default:\n return false;\n }\n}\n\n/**\n * Get all feature flags\n */\nexport function getFeatureFlags(): FeatureFlags {\n return {\n core: true,\n linear: isFeatureEnabled('linear'),\n whatsapp: isFeatureEnabled('whatsapp'),\n chromadb: isFeatureEnabled('chromadb'),\n aiSummaries: isFeatureEnabled('aiSummaries'),\n skills: isFeatureEnabled('skills'),\n ralph: isFeatureEnabled('ralph'),\n greptile: isFeatureEnabled('greptile'),\n };\n}\n\n/**\n * Log feature flags status (for debugging)\n */\nexport function logFeatureStatus(): void {\n const flags = getFeatureFlags();\n const local = isLocalOnly();\n\n console.log(\n `StackMemory Mode: ${local ? 'LOCAL (no external services)' : 'FULL'}`\n );\n if (!local) {\n console.log(\n ` Linear: ${flags.linear ? 'enabled' : 'disabled (no API key)'}`\n );\n console.log(\n ` WhatsApp: ${flags.whatsapp ? 'enabled' : 'disabled (no Twilio)'}`\n );\n console.log(` ChromaDB: ${flags.chromadb ? 'enabled' : 'disabled'}`);\n console.log(\n ` AI Summaries: ${flags.aiSummaries ? 'enabled' : 'disabled (no API key)'}`\n );\n console.log(\n ` Skills: ${flags.skills ? 'enabled' : 'disabled (set STACKMEMORY_SKILLS=true)'}`\n );\n console.log(\n ` Ralph: ${flags.ralph ? 'enabled' : 'disabled (set STACKMEMORY_RALPH=true)'}`\n );\n console.log(\n ` Greptile: ${flags.greptile ? 'enabled' : 'disabled (no GREPTILE_API_KEY)'}`\n );\n }\n}\n"],
|
|
5
|
+
"mappings": ";;;;AAyBO,SAAS,cAAuB;AACrC,SACE,QAAQ,IAAI,mBAAmB,MAAM,UACrC,QAAQ,IAAI,mBAAmB,MAAM,OACrC,QAAQ,IAAI,YAAY,MAAM;AAElC;AAKO,SAAS,iBAAiB,SAAsC;AACrE,MAAI,YAAY,OAAQ,QAAO;AAG/B,MAAI,YAAY,EAAG,QAAO;AAG1B,UAAQ,SAAS;AAAA,IACf,KAAK;AACH,aACE,QAAQ,IAAI,oBAAoB,MAAM,YACrC,CAAC,CAAC,QAAQ,IAAI,gBAAgB,KAAK,CAAC,CAAC,QAAQ,IAAI,oBAAoB;AAAA,IAE1E,KAAK;AACH,aACE,QAAQ,IAAI,sBAAsB,MAAM,WACxC,CAAC,CAAC,QAAQ,IAAI,oBAAoB;AAAA,IAEtC,KAAK;AACH,aAAO,QAAQ,IAAI,sBAAsB,MAAM;AAAA,IACjD,KAAK;AACH,aACE,QAAQ,IAAI,gBAAgB,MAAM,YACjC,CAAC,CAAC,QAAQ,IAAI,mBAAmB,KAAK,CAAC,CAAC,QAAQ,IAAI,gBAAgB;AAAA,IAEzE,KAAK;AAEH,aACE,QAAQ,IAAI,oBAAoB,MAAM,UACtC,QAAQ,IAAI,oBAAoB,MAAM;AAAA,IAE1C,KAAK;AAGH,aAAO,QAAQ,IAAI,mBAAmB,MAAM;AAAA,IAC9C,KAAK;AAEH,aACE,QAAQ,IAAI,sBAAsB,MAAM,WACxC,CAAC,CAAC,QAAQ,IAAI,kBAAkB;AAAA,IAEpC;AACE,aAAO;AAAA,EACX;AACF;AAKO,SAAS,kBAAgC;AAC9C,SAAO;AAAA,IACL,MAAM;AAAA,IACN,QAAQ,iBAAiB,QAAQ;AAAA,IACjC,UAAU,iBAAiB,UAAU;AAAA,IACrC,UAAU,iBAAiB,UAAU;AAAA,IACrC,aAAa,iBAAiB,aAAa;AAAA,IAC3C,QAAQ,iBAAiB,QAAQ;AAAA,IACjC,OAAO,iBAAiB,OAAO;AAAA,IAC/B,UAAU,iBAAiB,UAAU;AAAA,EACvC;AACF;AAKO,SAAS,mBAAyB;AACvC,QAAM,QAAQ,gBAAgB;AAC9B,QAAM,QAAQ,YAAY;AAE1B,UAAQ;AAAA,IACN,qBAAqB,QAAQ,iCAAiC,MAAM;AAAA,EACtE;AACA,MAAI,CAAC,OAAO;AACV,YAAQ;AAAA,MACN,aAAa,MAAM,SAAS,YAAY,uBAAuB;AAAA,IACjE;AACA,YAAQ;AAAA,MACN,eAAe,MAAM,WAAW,YAAY,sBAAsB;AAAA,IACpE;AACA,YAAQ,IAAI,eAAe,MAAM,WAAW,YAAY,UAAU,EAAE;AACpE,YAAQ;AAAA,MACN,mBAAmB,MAAM,cAAc,YAAY,uBAAuB;AAAA,IAC5E;AACA,YAAQ;AAAA,MACN,aAAa,MAAM,SAAS,YAAY,wCAAwC;AAAA,IAClF;AACA,YAAQ;AAAA,MACN,YAAY,MAAM,QAAQ,YAAY,uCAAuC;AAAA,IAC/E;AACA,YAAQ;AAAA,MACN,eAAe,MAAM,WAAW,YAAY,gCAAgC;AAAA,IAC9E;AAAA,EACF;AACF;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|