@stackmemoryai/stackmemory 0.5.31 → 0.5.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli/claude-sm.js +199 -16
- package/dist/cli/claude-sm.js.map +2 -2
- package/dist/cli/commands/context.js +0 -11
- package/dist/cli/commands/context.js.map +2 -2
- package/dist/cli/commands/linear.js +1 -14
- package/dist/cli/commands/linear.js.map +2 -2
- package/dist/cli/commands/login.js +32 -10
- package/dist/cli/commands/login.js.map +2 -2
- package/dist/cli/commands/migrate.js +80 -22
- package/dist/cli/commands/migrate.js.map +2 -2
- package/dist/cli/commands/model.js +533 -0
- package/dist/cli/commands/model.js.map +7 -0
- package/dist/cli/commands/ralph.js +93 -28
- package/dist/cli/commands/ralph.js.map +2 -2
- package/dist/cli/commands/service.js +10 -3
- package/dist/cli/commands/service.js.map +2 -2
- package/dist/cli/commands/skills.js +60 -10
- package/dist/cli/commands/skills.js.map +2 -2
- package/dist/cli/commands/sms-notify.js +342 -22
- package/dist/cli/commands/sms-notify.js.map +3 -3
- package/dist/cli/index.js +2 -0
- package/dist/cli/index.js.map +2 -2
- package/dist/core/context/dual-stack-manager.js +23 -7
- package/dist/core/context/dual-stack-manager.js.map +2 -2
- package/dist/core/context/frame-database.js +33 -5
- package/dist/core/context/frame-database.js.map +2 -2
- package/dist/core/context/frame-digest.js +6 -1
- package/dist/core/context/frame-digest.js.map +2 -2
- package/dist/core/context/frame-manager.js +56 -9
- package/dist/core/context/frame-manager.js.map +2 -2
- package/dist/core/context/permission-manager.js +0 -11
- package/dist/core/context/permission-manager.js.map +2 -2
- package/dist/core/context/recursive-context-manager.js +15 -9
- package/dist/core/context/recursive-context-manager.js.map +2 -2
- package/dist/core/context/shared-context-layer.js +0 -11
- package/dist/core/context/shared-context-layer.js.map +2 -2
- package/dist/core/context/validation.js +6 -1
- package/dist/core/context/validation.js.map +2 -2
- package/dist/core/models/fallback-monitor.js +229 -0
- package/dist/core/models/fallback-monitor.js.map +7 -0
- package/dist/core/models/model-router.js +331 -0
- package/dist/core/models/model-router.js.map +7 -0
- package/dist/hooks/claude-code-whatsapp-hook.js +197 -0
- package/dist/hooks/claude-code-whatsapp-hook.js.map +7 -0
- package/dist/hooks/linear-task-picker.js +1 -1
- package/dist/hooks/linear-task-picker.js.map +2 -2
- package/dist/hooks/schemas.js +55 -1
- package/dist/hooks/schemas.js.map +2 -2
- package/dist/hooks/session-summary.js +5 -1
- package/dist/hooks/session-summary.js.map +2 -2
- package/dist/hooks/sms-action-runner.js +12 -1
- package/dist/hooks/sms-action-runner.js.map +2 -2
- package/dist/hooks/sms-notify.js +4 -2
- package/dist/hooks/sms-notify.js.map +2 -2
- package/dist/hooks/sms-webhook.js +23 -2
- package/dist/hooks/sms-webhook.js.map +2 -2
- package/dist/hooks/whatsapp-commands.js +376 -0
- package/dist/hooks/whatsapp-commands.js.map +7 -0
- package/dist/hooks/whatsapp-scheduler.js +317 -0
- package/dist/hooks/whatsapp-scheduler.js.map +7 -0
- package/dist/hooks/whatsapp-sync.js +375 -0
- package/dist/hooks/whatsapp-sync.js.map +7 -0
- package/package.json +2 -3
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/cli/commands/service.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Service command for StackMemory\n * Manages OS-level service installation for the guardian daemon\n *\n * The guardian service monitors ~/.stackmemory/sessions/ for active sessions\n * and starts context sync when activity is detected.\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { spawn, execSync } from 'child_process';\nimport { existsSync, readFileSync } from 'fs';\n\ninterface ServiceConfig {\n platform: 'darwin' | 'linux' | 'unsupported';\n serviceDir: string;\n serviceName: string;\n serviceFile: string;\n logDir: string;\n}\n\nfunction getServiceConfig(): ServiceConfig {\n const home = process.env.HOME || '';\n const platform = process.platform;\n\n if (platform === 'darwin') {\n return {\n platform: 'darwin',\n serviceDir: path.join(home, 'Library', 'LaunchAgents'),\n serviceName: 'com.stackmemory.guardian',\n serviceFile: path.join(\n home,\n 'Library',\n 'LaunchAgents',\n 'com.stackmemory.guardian.plist'\n ),\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n } else if (platform === 'linux') {\n return {\n platform: 'linux',\n serviceDir: path.join(home, '.config', 'systemd', 'user'),\n serviceName: 'stackmemory-guardian',\n serviceFile: path.join(\n home,\n '.config',\n 'systemd',\n 'user',\n 'stackmemory-guardian.service'\n ),\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n }\n\n return {\n platform: 'unsupported',\n serviceDir: '',\n serviceName: '',\n serviceFile: '',\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n}\n\nfunction _getStackMemoryBinPath(): string {\n const localBin = path.join(process.cwd(), 'dist', 'cli', 'index.js');\n if (existsSync(localBin)) {\n return localBin;\n }\n const globalBin = path.join(\n process.env.HOME || '',\n '.stackmemory',\n 'bin',\n 'stackmemory'\n );\n if (existsSync(globalBin)) {\n return globalBin;\n }\n return 'npx stackmemory';\n}\nvoid _getStackMemoryBinPath;\n\nfunction getNodePath(): string {\n try {\n const nodePath = execSync('which node', { encoding: 'utf-8' }).trim();\n return nodePath;\n } catch {\n return '/usr/local/bin/node';\n }\n}\n\nfunction generateMacOSPlist(config: ServiceConfig): string {\n const home = process.env.HOME || '';\n const nodePath = getNodePath();\n const guardianScript = path.join(home, '.stackmemory', 'guardian.js');\n\n return `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n <key>Label</key>\n <string>${config.serviceName}</string>\n\n <key>ProgramArguments</key>\n <array>\n <string>${nodePath}</string>\n <string>${guardianScript}</string>\n </array>\n\n <key>RunAtLoad</key>\n <true/>\n\n <key>KeepAlive</key>\n <dict>\n <key>SuccessfulExit</key>\n <false/>\n </dict>\n\n <key>WorkingDirectory</key>\n <string>${home}/.stackmemory</string>\n\n <key>StandardOutPath</key>\n <string>${config.logDir}/guardian.log</string>\n\n <key>StandardErrorPath</key>\n <string>${config.logDir}/guardian.error.log</string>\n\n <key>EnvironmentVariables</key>\n <dict>\n <key>HOME</key>\n <string>${home}</string>\n <key>PATH</key>\n <string>/usr/local/bin:/usr/bin:/bin</string>\n </dict>\n\n <key>ThrottleInterval</key>\n <integer>30</integer>\n</dict>\n</plist>`;\n}\n\nfunction generateLinuxSystemdService(config: ServiceConfig): string {\n const home = process.env.HOME || '';\n const nodePath = getNodePath();\n const guardianScript = path.join(home, '.stackmemory', 'guardian.js');\n\n return `[Unit]\nDescription=StackMemory Guardian Service\nDocumentation=https://github.com/stackmemoryai/stackmemory\nAfter=network.target\n\n[Service]\nType=simple\nExecStart=${nodePath} ${guardianScript}\nRestart=on-failure\nRestartSec=30\nWorkingDirectory=${home}/.stackmemory\n\nEnvironment=HOME=${home}\nEnvironment=PATH=/usr/local/bin:/usr/bin:/bin\n\nStandardOutput=append:${config.logDir}/guardian.log\nStandardError=append:${config.logDir}/guardian.error.log\n\n[Install]\nWantedBy=default.target`;\n}\n\nfunction generateGuardianScript(): string {\n return `#!/usr/bin/env node\n/**\n * StackMemory Guardian Service\n * Monitors ~/.stackmemory/sessions/ for active sessions\n * and manages context sync accordingly.\n */\n\nconst fs = require('fs');\nconst path = require('path');\nconst { spawn } = require('child_process');\n\nconst HOME = process.env.HOME || '';\nconst SESSIONS_DIR = path.join(HOME, '.stackmemory', 'sessions');\nconst STATE_FILE = path.join(HOME, '.stackmemory', 'guardian.state');\nconst IDLE_TIMEOUT_MS = 30 * 60 * 1000; // 30 minutes\n\nclass Guardian {\n constructor() {\n this.syncProcess = null;\n this.lastActivityTime = Date.now();\n this.activeSessions = new Set();\n this.checkInterval = null;\n }\n\n log(message, level = 'INFO') {\n const timestamp = new Date().toISOString();\n console.log('[' + timestamp + '] [' + level + '] ' + message);\n }\n\n async getActiveSessions() {\n const sessions = new Set();\n\n try {\n if (!fs.existsSync(SESSIONS_DIR)) {\n return sessions;\n }\n\n const files = fs.readdirSync(SESSIONS_DIR);\n\n for (const file of files) {\n if (!file.endsWith('.json')) continue;\n\n const filePath = path.join(SESSIONS_DIR, file);\n try {\n const content = fs.readFileSync(filePath, 'utf8');\n const session = JSON.parse(content);\n\n // Check if session is active (updated within last 5 minutes)\n const lastUpdate = new Date(session.lastActiveAt || session.startedAt).getTime();\n const fiveMinutesAgo = Date.now() - (5 * 60 * 1000);\n\n if (session.state === 'active' && lastUpdate > fiveMinutesAgo) {\n sessions.add(session.sessionId);\n }\n } catch (err) {\n // Skip invalid session files\n }\n }\n } catch (err) {\n this.log('Error reading sessions: ' + err.message, 'ERROR');\n }\n\n return sessions;\n }\n\n startContextSync() {\n if (this.syncProcess) {\n this.log('Context sync already running');\n return;\n }\n\n this.log('Starting context sync...');\n\n // Find stackmemory binary\n const stackmemoryPaths = [\n path.join(HOME, '.stackmemory', 'bin', 'stackmemory'),\n 'npx'\n ];\n\n let binPath = null;\n for (const p of stackmemoryPaths) {\n if (p === 'npx' || fs.existsSync(p)) {\n binPath = p;\n break;\n }\n }\n\n if (!binPath) {\n this.log('Cannot find stackmemory binary', 'ERROR');\n return;\n }\n\n const args = binPath === 'npx'\n ? ['stackmemory', 'monitor', '--daemon']\n : ['monitor', '--daemon'];\n\n this.syncProcess = spawn(binPath, args, {\n detached: true,\n stdio: ['ignore', 'pipe', 'pipe']\n });\n\n this.syncProcess.stdout.on('data', (data) => {\n this.log('sync: ' + data.toString().trim());\n });\n\n this.syncProcess.stderr.on('data', (data) => {\n this.log('sync error: ' + data.toString().trim(), 'WARN');\n });\n\n this.syncProcess.on('exit', (code) => {\n this.log('Context sync exited with code: ' + code);\n this.syncProcess = null;\n });\n\n this.log('Context sync started');\n }\n\n stopContextSync() {\n if (!this.syncProcess) {\n return;\n }\n\n this.log('Stopping context sync...');\n\n try {\n this.syncProcess.kill('SIGTERM');\n this.syncProcess = null;\n this.log('Context sync stopped');\n } catch (err) {\n this.log('Error stopping sync: ' + err.message, 'ERROR');\n }\n }\n\n saveState() {\n const state = {\n lastCheck: new Date().toISOString(),\n activeSessions: Array.from(this.activeSessions),\n syncRunning: this.syncProcess !== null,\n lastActivity: new Date(this.lastActivityTime).toISOString()\n };\n\n try {\n fs.writeFileSync(STATE_FILE, JSON.stringify(state, null, 2));\n } catch (err) {\n this.log('Error saving state: ' + err.message, 'ERROR');\n }\n }\n\n async check() {\n const currentSessions = await this.getActiveSessions();\n const hadActivity = currentSessions.size > 0;\n\n if (hadActivity) {\n this.lastActivityTime = Date.now();\n }\n\n // Detect session changes\n const newSessions = [...currentSessions].filter(s => !this.activeSessions.has(s));\n const closedSessions = [...this.activeSessions].filter(s => !currentSessions.has(s));\n\n if (newSessions.length > 0) {\n this.log('New sessions detected: ' + newSessions.join(', '));\n if (!this.syncProcess) {\n this.startContextSync();\n }\n }\n\n if (closedSessions.length > 0) {\n this.log('Sessions closed: ' + closedSessions.join(', '));\n }\n\n this.activeSessions = currentSessions;\n\n // Check idle timeout\n const idleTime = Date.now() - this.lastActivityTime;\n if (this.syncProcess && currentSessions.size === 0 && idleTime > IDLE_TIMEOUT_MS) {\n this.log('No activity for 30 minutes, stopping sync');\n this.stopContextSync();\n }\n\n this.saveState();\n }\n\n async start() {\n this.log('StackMemory Guardian starting...');\n this.log('Monitoring: ' + SESSIONS_DIR);\n\n // Ensure directories exist\n const dirs = [\n SESSIONS_DIR,\n path.join(HOME, '.stackmemory', 'logs')\n ];\n\n for (const dir of dirs) {\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n }\n\n // Initial check\n await this.check();\n\n // Start monitoring loop (every 30 seconds)\n this.checkInterval = setInterval(() => this.check(), 30 * 1000);\n\n this.log('Guardian started successfully');\n\n // Handle shutdown signals\n process.on('SIGTERM', () => this.stop());\n process.on('SIGINT', () => this.stop());\n }\n\n stop() {\n this.log('Guardian stopping...');\n\n if (this.checkInterval) {\n clearInterval(this.checkInterval);\n }\n\n this.stopContextSync();\n\n // Clean up state file\n try {\n if (fs.existsSync(STATE_FILE)) {\n fs.unlinkSync(STATE_FILE);\n }\n } catch (err) {\n // Ignore\n }\n\n this.log('Guardian stopped');\n process.exit(0);\n }\n}\n\nconst guardian = new Guardian();\nguardian.start().catch(err => {\n console.error('Guardian failed to start:', err);\n process.exit(1);\n});\n`;\n}\n\nasync function installService(\n config: ServiceConfig,\n spinner: ora.Ora\n): Promise<void> {\n const home = process.env.HOME || '';\n\n // Create directories\n await fs.mkdir(config.serviceDir, { recursive: true });\n await fs.mkdir(config.logDir, { recursive: true });\n\n // Write guardian script\n const guardianPath = path.join(home, '.stackmemory', 'guardian.js');\n await fs.writeFile(guardianPath, generateGuardianScript(), 'utf-8');\n await fs.chmod(guardianPath, 0o755);\n\n if (config.platform === 'darwin') {\n // Write launchd plist\n const plistContent = generateMacOSPlist(config);\n await fs.writeFile(config.serviceFile, plistContent, 'utf-8');\n\n spinner.text = 'Loading service...';\n\n // Load the service\n try {\n execSync(`launchctl load -w \"${config.serviceFile}\"`, { stdio: 'pipe' });\n } catch {\n // Service might already be loaded, try unload first\n try {\n execSync(`launchctl unload \"${config.serviceFile}\"`, { stdio: 'pipe' });\n execSync(`launchctl load -w \"${config.serviceFile}\"`, {\n stdio: 'pipe',\n });\n } catch {\n throw new Error('Failed to load launchd service');\n }\n }\n\n spinner.succeed(chalk.green('Guardian service installed and started'));\n console.log(chalk.gray(`Service file: ${config.serviceFile}`));\n console.log(chalk.gray(`Guardian script: ${guardianPath}`));\n console.log(chalk.gray(`Logs: ${config.logDir}/guardian.log`));\n } else if (config.platform === 'linux') {\n // Write systemd service\n const serviceContent = generateLinuxSystemdService(config);\n await fs.writeFile(config.serviceFile, serviceContent, 'utf-8');\n\n spinner.text = 'Enabling service...';\n\n // Reload systemd and enable service\n try {\n execSync('systemctl --user daemon-reload', { stdio: 'pipe' });\n execSync(`systemctl --user enable ${config.serviceName}`, {\n stdio: 'pipe',\n });\n execSync(`systemctl --user start ${config.serviceName}`, {\n stdio: 'pipe',\n });\n } catch {\n throw new Error(\n 'Failed to enable systemd service. Make sure systemd user session is available.'\n );\n }\n\n spinner.succeed(chalk.green('Guardian service installed and started'));\n console.log(chalk.gray(`Service file: ${config.serviceFile}`));\n console.log(chalk.gray(`Guardian script: ${guardianPath}`));\n console.log(chalk.gray(`Logs: ${config.logDir}/guardian.log`));\n }\n}\n\nasync function uninstallService(\n config: ServiceConfig,\n spinner: ora.Ora\n): Promise<void> {\n const home = process.env.HOME || '';\n const guardianPath = path.join(home, '.stackmemory', 'guardian.js');\n\n if (config.platform === 'darwin') {\n spinner.text = 'Unloading service...';\n\n try {\n execSync(`launchctl unload \"${config.serviceFile}\"`, { stdio: 'pipe' });\n } catch {\n // Service might not be loaded\n }\n\n // Remove plist file\n try {\n await fs.unlink(config.serviceFile);\n } catch {\n // File might not exist\n }\n\n // Remove guardian script\n try {\n await fs.unlink(guardianPath);\n } catch {\n // File might not exist\n }\n\n spinner.succeed(chalk.green('Guardian service uninstalled'));\n } else if (config.platform === 'linux') {\n spinner.text = 'Stopping service...';\n\n try {\n execSync(`systemctl --user stop ${config.serviceName}`, {\n stdio: 'pipe',\n });\n execSync(`systemctl --user disable ${config.serviceName}`, {\n stdio: 'pipe',\n });\n } catch {\n // Service might not be running\n }\n\n // Remove service file\n try {\n await fs.unlink(config.serviceFile);\n } catch {\n // File might not exist\n }\n\n // Remove guardian script\n try {\n await fs.unlink(guardianPath);\n } catch {\n // File might not exist\n }\n\n // Reload systemd\n try {\n execSync('systemctl --user daemon-reload', { stdio: 'pipe' });\n } catch {\n // Ignore\n }\n\n spinner.succeed(chalk.green('Guardian service uninstalled'));\n }\n}\n\nasync function showServiceStatus(config: ServiceConfig): Promise<void> {\n const home = process.env.HOME || '';\n const stateFile = path.join(home, '.stackmemory', 'guardian.state');\n\n console.log(chalk.bold('\\nStackMemory Guardian Service Status\\n'));\n\n if (config.platform === 'unsupported') {\n console.log(chalk.red('Platform not supported for service installation'));\n console.log(\n chalk.gray('Supported platforms: macOS (launchd), Linux (systemd)')\n );\n return;\n }\n\n // Check if service file exists\n if (!existsSync(config.serviceFile)) {\n console.log(chalk.yellow('Service not installed'));\n console.log(chalk.gray('Install with: stackmemory service install'));\n return;\n }\n\n let isRunning = false;\n let serviceOutput = '';\n\n if (config.platform === 'darwin') {\n try {\n serviceOutput = execSync(`launchctl list | grep ${config.serviceName}`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n isRunning = serviceOutput.includes(config.serviceName);\n } catch {\n isRunning = false;\n }\n } else if (config.platform === 'linux') {\n try {\n serviceOutput = execSync(\n `systemctl --user is-active ${config.serviceName}`,\n { encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] }\n ).trim();\n isRunning = serviceOutput === 'active';\n } catch {\n isRunning = false;\n }\n }\n\n if (isRunning) {\n console.log(chalk.green('Status: Running'));\n } else {\n console.log(chalk.yellow('Status: Stopped'));\n }\n\n console.log(chalk.gray(`Platform: ${config.platform}`));\n console.log(chalk.gray(`Service: ${config.serviceName}`));\n console.log(chalk.gray(`Config: ${config.serviceFile}`));\n\n // Try to read guardian state\n if (existsSync(stateFile)) {\n try {\n const state = JSON.parse(readFileSync(stateFile, 'utf-8'));\n console.log(chalk.bold('\\nGuardian State:'));\n console.log(` Last check: ${state.lastCheck}`);\n console.log(` Active sessions: ${state.activeSessions?.length || 0}`);\n console.log(` Sync running: ${state.syncRunning ? 'Yes' : 'No'}`);\n console.log(` Last activity: ${state.lastActivity}`);\n } catch {\n // Invalid state file\n }\n }\n}\n\nasync function showServiceLogs(\n config: ServiceConfig,\n lines: number\n): Promise<void> {\n console.log(\n chalk.bold(`\\nStackMemory Guardian Logs (last ${lines} lines)\\n`)\n );\n\n const logFile = path.join(config.logDir, 'guardian.log');\n\n if (!existsSync(logFile)) {\n console.log(chalk.yellow('No logs found'));\n console.log(chalk.gray(`Expected at: ${logFile}`));\n return;\n }\n\n try {\n const content = readFileSync(logFile, 'utf-8');\n const logLines = content.split('\\n').filter(Boolean);\n const lastLines = logLines.slice(-lines);\n\n lastLines.forEach((line) => {\n if (line.includes('[ERROR]')) {\n console.log(chalk.red(line));\n } else if (line.includes('[WARN]')) {\n console.log(chalk.yellow(line));\n } else {\n console.log(chalk.gray(line));\n }\n });\n\n console.log(chalk.gray(`\\nFull log: ${logFile}`));\n } catch (err) {\n console.log(chalk.red(`Failed to read logs: ${(err as Error).message}`));\n }\n}\n\nexport function createServiceCommand(): Command {\n const cmd = new Command('service')\n .description('Manage StackMemory guardian OS service (auto-start on login)')\n .addHelpText(\n 'after',\n `\nExamples:\n stackmemory service install Install and start the guardian service\n stackmemory service uninstall Remove the guardian service\n stackmemory service status Show service status\n stackmemory service logs Show recent service logs\n stackmemory service logs -n 50 Show last 50 log lines\n\nThe guardian service:\n - Monitors ~/.stackmemory/sessions/ for active sessions\n - Starts context sync when an active session is detected\n - Stops gracefully after 30 minutes of inactivity\n - Runs automatically on system login (opt-in)\n`\n );\n\n cmd\n .command('install')\n .description('Install the guardian service (starts on login)')\n .action(async () => {\n const spinner = ora('Installing guardian service...').start();\n\n try {\n const config = getServiceConfig();\n\n if (config.platform === 'unsupported') {\n spinner.fail(chalk.red('Platform not supported'));\n console.log(\n chalk.gray('Supported: macOS (launchd), Linux (systemd)')\n );\n process.exit(1);\n }\n\n await installService(config, spinner);\n\n console.log(chalk.bold('\\nGuardian service will:'));\n console.log(' - Start automatically on login');\n console.log(' - Monitor for active StackMemory sessions');\n console.log(' - Manage context sync based on activity');\n console.log(' - Stop gracefully after 30 min idle');\n } catch (err) {\n spinner.fail(\n chalk.red(`Installation failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('uninstall')\n .description('Remove the guardian service')\n .action(async () => {\n const spinner = ora('Uninstalling guardian service...').start();\n\n try {\n const config = getServiceConfig();\n\n if (config.platform === 'unsupported') {\n spinner.fail(chalk.red('Platform not supported'));\n process.exit(1);\n }\n\n await uninstallService(config, spinner);\n } catch (err) {\n spinner.fail(\n chalk.red(`Uninstallation failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('status')\n .description('Show guardian service status')\n .action(async () => {\n try {\n const config = getServiceConfig();\n await showServiceStatus(config);\n } catch (err) {\n console.error(\n chalk.red(`Status check failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('logs')\n .description('Show recent guardian service logs')\n .option('-n, --lines <number>', 'Number of log lines to show', '20')\n .option('-f, --follow', 'Follow log output (tail -f style)')\n .action(async (options) => {\n try {\n const config = getServiceConfig();\n const lines = parseInt(options.lines) || 20;\n\n if (options.follow) {\n // Use tail -f for live following\n const logFile = path.join(config.logDir, 'guardian.log');\n console.log(chalk.bold(`Following ${logFile} (Ctrl+C to stop)\\n`));\n\n const tail = spawn('tail', ['-f', '-n', lines.toString(), logFile], {\n stdio: 'inherit',\n });\n\n process.on('SIGINT', () => {\n tail.kill();\n process.exit(0);\n });\n } else {\n await showServiceLogs(config, lines);\n }\n } catch (err) {\n console.error(\n chalk.red(`Failed to show logs: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n // Default action - show status\n cmd.action(async () => {\n try {\n const config = getServiceConfig();\n await showServiceStatus(config);\n } catch (err) {\n console.error(\n chalk.red(`Status check failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\nexport default createServiceCommand();\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["/**\n * Service command for StackMemory\n * Manages OS-level service installation for the guardian daemon\n *\n * The guardian service monitors ~/.stackmemory/sessions/ for active sessions\n * and starts context sync when activity is detected.\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { spawn, execSync } from 'child_process';\nimport { existsSync, readFileSync } from 'fs';\nimport { SystemError, ErrorCode } from '../../core/errors/index.js';\n\ninterface ServiceConfig {\n platform: 'darwin' | 'linux' | 'unsupported';\n serviceDir: string;\n serviceName: string;\n serviceFile: string;\n logDir: string;\n}\n\nfunction getServiceConfig(): ServiceConfig {\n const home = process.env.HOME || '';\n const platform = process.platform;\n\n if (platform === 'darwin') {\n return {\n platform: 'darwin',\n serviceDir: path.join(home, 'Library', 'LaunchAgents'),\n serviceName: 'com.stackmemory.guardian',\n serviceFile: path.join(\n home,\n 'Library',\n 'LaunchAgents',\n 'com.stackmemory.guardian.plist'\n ),\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n } else if (platform === 'linux') {\n return {\n platform: 'linux',\n serviceDir: path.join(home, '.config', 'systemd', 'user'),\n serviceName: 'stackmemory-guardian',\n serviceFile: path.join(\n home,\n '.config',\n 'systemd',\n 'user',\n 'stackmemory-guardian.service'\n ),\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n }\n\n return {\n platform: 'unsupported',\n serviceDir: '',\n serviceName: '',\n serviceFile: '',\n logDir: path.join(home, '.stackmemory', 'logs'),\n };\n}\n\nfunction _getStackMemoryBinPath(): string {\n const localBin = path.join(process.cwd(), 'dist', 'cli', 'index.js');\n if (existsSync(localBin)) {\n return localBin;\n }\n const globalBin = path.join(\n process.env.HOME || '',\n '.stackmemory',\n 'bin',\n 'stackmemory'\n );\n if (existsSync(globalBin)) {\n return globalBin;\n }\n return 'npx stackmemory';\n}\nvoid _getStackMemoryBinPath;\n\nfunction getNodePath(): string {\n try {\n const nodePath = execSync('which node', { encoding: 'utf-8' }).trim();\n return nodePath;\n } catch {\n return '/usr/local/bin/node';\n }\n}\n\nfunction generateMacOSPlist(config: ServiceConfig): string {\n const home = process.env.HOME || '';\n const nodePath = getNodePath();\n const guardianScript = path.join(home, '.stackmemory', 'guardian.js');\n\n return `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n <key>Label</key>\n <string>${config.serviceName}</string>\n\n <key>ProgramArguments</key>\n <array>\n <string>${nodePath}</string>\n <string>${guardianScript}</string>\n </array>\n\n <key>RunAtLoad</key>\n <true/>\n\n <key>KeepAlive</key>\n <dict>\n <key>SuccessfulExit</key>\n <false/>\n </dict>\n\n <key>WorkingDirectory</key>\n <string>${home}/.stackmemory</string>\n\n <key>StandardOutPath</key>\n <string>${config.logDir}/guardian.log</string>\n\n <key>StandardErrorPath</key>\n <string>${config.logDir}/guardian.error.log</string>\n\n <key>EnvironmentVariables</key>\n <dict>\n <key>HOME</key>\n <string>${home}</string>\n <key>PATH</key>\n <string>/usr/local/bin:/usr/bin:/bin</string>\n </dict>\n\n <key>ThrottleInterval</key>\n <integer>30</integer>\n</dict>\n</plist>`;\n}\n\nfunction generateLinuxSystemdService(config: ServiceConfig): string {\n const home = process.env.HOME || '';\n const nodePath = getNodePath();\n const guardianScript = path.join(home, '.stackmemory', 'guardian.js');\n\n return `[Unit]\nDescription=StackMemory Guardian Service\nDocumentation=https://github.com/stackmemoryai/stackmemory\nAfter=network.target\n\n[Service]\nType=simple\nExecStart=${nodePath} ${guardianScript}\nRestart=on-failure\nRestartSec=30\nWorkingDirectory=${home}/.stackmemory\n\nEnvironment=HOME=${home}\nEnvironment=PATH=/usr/local/bin:/usr/bin:/bin\n\nStandardOutput=append:${config.logDir}/guardian.log\nStandardError=append:${config.logDir}/guardian.error.log\n\n[Install]\nWantedBy=default.target`;\n}\n\nfunction generateGuardianScript(): string {\n return `#!/usr/bin/env node\n/**\n * StackMemory Guardian Service\n * Monitors ~/.stackmemory/sessions/ for active sessions\n * and manages context sync accordingly.\n */\n\nconst fs = require('fs');\nconst path = require('path');\nconst { spawn } = require('child_process');\n\nconst HOME = process.env.HOME || '';\nconst SESSIONS_DIR = path.join(HOME, '.stackmemory', 'sessions');\nconst STATE_FILE = path.join(HOME, '.stackmemory', 'guardian.state');\nconst IDLE_TIMEOUT_MS = 30 * 60 * 1000; // 30 minutes\n\nclass Guardian {\n constructor() {\n this.syncProcess = null;\n this.lastActivityTime = Date.now();\n this.activeSessions = new Set();\n this.checkInterval = null;\n }\n\n log(message, level = 'INFO') {\n const timestamp = new Date().toISOString();\n console.log('[' + timestamp + '] [' + level + '] ' + message);\n }\n\n async getActiveSessions() {\n const sessions = new Set();\n\n try {\n if (!fs.existsSync(SESSIONS_DIR)) {\n return sessions;\n }\n\n const files = fs.readdirSync(SESSIONS_DIR);\n\n for (const file of files) {\n if (!file.endsWith('.json')) continue;\n\n const filePath = path.join(SESSIONS_DIR, file);\n try {\n const content = fs.readFileSync(filePath, 'utf8');\n const session = JSON.parse(content);\n\n // Check if session is active (updated within last 5 minutes)\n const lastUpdate = new Date(session.lastActiveAt || session.startedAt).getTime();\n const fiveMinutesAgo = Date.now() - (5 * 60 * 1000);\n\n if (session.state === 'active' && lastUpdate > fiveMinutesAgo) {\n sessions.add(session.sessionId);\n }\n } catch (err) {\n // Skip invalid session files\n }\n }\n } catch (err) {\n this.log('Error reading sessions: ' + err.message, 'ERROR');\n }\n\n return sessions;\n }\n\n startContextSync() {\n if (this.syncProcess) {\n this.log('Context sync already running');\n return;\n }\n\n this.log('Starting context sync...');\n\n // Find stackmemory binary\n const stackmemoryPaths = [\n path.join(HOME, '.stackmemory', 'bin', 'stackmemory'),\n 'npx'\n ];\n\n let binPath = null;\n for (const p of stackmemoryPaths) {\n if (p === 'npx' || fs.existsSync(p)) {\n binPath = p;\n break;\n }\n }\n\n if (!binPath) {\n this.log('Cannot find stackmemory binary', 'ERROR');\n return;\n }\n\n const args = binPath === 'npx'\n ? ['stackmemory', 'monitor', '--daemon']\n : ['monitor', '--daemon'];\n\n this.syncProcess = spawn(binPath, args, {\n detached: true,\n stdio: ['ignore', 'pipe', 'pipe']\n });\n\n this.syncProcess.stdout.on('data', (data) => {\n this.log('sync: ' + data.toString().trim());\n });\n\n this.syncProcess.stderr.on('data', (data) => {\n this.log('sync error: ' + data.toString().trim(), 'WARN');\n });\n\n this.syncProcess.on('exit', (code) => {\n this.log('Context sync exited with code: ' + code);\n this.syncProcess = null;\n });\n\n this.log('Context sync started');\n }\n\n stopContextSync() {\n if (!this.syncProcess) {\n return;\n }\n\n this.log('Stopping context sync...');\n\n try {\n this.syncProcess.kill('SIGTERM');\n this.syncProcess = null;\n this.log('Context sync stopped');\n } catch (err) {\n this.log('Error stopping sync: ' + err.message, 'ERROR');\n }\n }\n\n saveState() {\n const state = {\n lastCheck: new Date().toISOString(),\n activeSessions: Array.from(this.activeSessions),\n syncRunning: this.syncProcess !== null,\n lastActivity: new Date(this.lastActivityTime).toISOString()\n };\n\n try {\n fs.writeFileSync(STATE_FILE, JSON.stringify(state, null, 2));\n } catch (err) {\n this.log('Error saving state: ' + err.message, 'ERROR');\n }\n }\n\n async check() {\n const currentSessions = await this.getActiveSessions();\n const hadActivity = currentSessions.size > 0;\n\n if (hadActivity) {\n this.lastActivityTime = Date.now();\n }\n\n // Detect session changes\n const newSessions = [...currentSessions].filter(s => !this.activeSessions.has(s));\n const closedSessions = [...this.activeSessions].filter(s => !currentSessions.has(s));\n\n if (newSessions.length > 0) {\n this.log('New sessions detected: ' + newSessions.join(', '));\n if (!this.syncProcess) {\n this.startContextSync();\n }\n }\n\n if (closedSessions.length > 0) {\n this.log('Sessions closed: ' + closedSessions.join(', '));\n }\n\n this.activeSessions = currentSessions;\n\n // Check idle timeout\n const idleTime = Date.now() - this.lastActivityTime;\n if (this.syncProcess && currentSessions.size === 0 && idleTime > IDLE_TIMEOUT_MS) {\n this.log('No activity for 30 minutes, stopping sync');\n this.stopContextSync();\n }\n\n this.saveState();\n }\n\n async start() {\n this.log('StackMemory Guardian starting...');\n this.log('Monitoring: ' + SESSIONS_DIR);\n\n // Ensure directories exist\n const dirs = [\n SESSIONS_DIR,\n path.join(HOME, '.stackmemory', 'logs')\n ];\n\n for (const dir of dirs) {\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n }\n\n // Initial check\n await this.check();\n\n // Start monitoring loop (every 30 seconds)\n this.checkInterval = setInterval(() => this.check(), 30 * 1000);\n\n this.log('Guardian started successfully');\n\n // Handle shutdown signals\n process.on('SIGTERM', () => this.stop());\n process.on('SIGINT', () => this.stop());\n }\n\n stop() {\n this.log('Guardian stopping...');\n\n if (this.checkInterval) {\n clearInterval(this.checkInterval);\n }\n\n this.stopContextSync();\n\n // Clean up state file\n try {\n if (fs.existsSync(STATE_FILE)) {\n fs.unlinkSync(STATE_FILE);\n }\n } catch (err) {\n // Ignore\n }\n\n this.log('Guardian stopped');\n process.exit(0);\n }\n}\n\nconst guardian = new Guardian();\nguardian.start().catch(err => {\n console.error('Guardian failed to start:', err);\n process.exit(1);\n});\n`;\n}\n\nasync function installService(\n config: ServiceConfig,\n spinner: ora.Ora\n): Promise<void> {\n const home = process.env.HOME || '';\n\n // Create directories\n await fs.mkdir(config.serviceDir, { recursive: true });\n await fs.mkdir(config.logDir, { recursive: true });\n\n // Write guardian script\n const guardianPath = path.join(home, '.stackmemory', 'guardian.js');\n await fs.writeFile(guardianPath, generateGuardianScript(), 'utf-8');\n await fs.chmod(guardianPath, 0o755);\n\n if (config.platform === 'darwin') {\n // Write launchd plist\n const plistContent = generateMacOSPlist(config);\n await fs.writeFile(config.serviceFile, plistContent, 'utf-8');\n\n spinner.text = 'Loading service...';\n\n // Load the service\n try {\n execSync(`launchctl load -w \"${config.serviceFile}\"`, { stdio: 'pipe' });\n } catch {\n // Service might already be loaded, try unload first\n try {\n execSync(`launchctl unload \"${config.serviceFile}\"`, { stdio: 'pipe' });\n execSync(`launchctl load -w \"${config.serviceFile}\"`, {\n stdio: 'pipe',\n });\n } catch {\n throw new SystemError(\n 'Failed to load launchd service',\n ErrorCode.SERVICE_UNAVAILABLE,\n { platform: 'darwin', serviceFile: config.serviceFile }\n );\n }\n }\n\n spinner.succeed(chalk.green('Guardian service installed and started'));\n console.log(chalk.gray(`Service file: ${config.serviceFile}`));\n console.log(chalk.gray(`Guardian script: ${guardianPath}`));\n console.log(chalk.gray(`Logs: ${config.logDir}/guardian.log`));\n } else if (config.platform === 'linux') {\n // Write systemd service\n const serviceContent = generateLinuxSystemdService(config);\n await fs.writeFile(config.serviceFile, serviceContent, 'utf-8');\n\n spinner.text = 'Enabling service...';\n\n // Reload systemd and enable service\n try {\n execSync('systemctl --user daemon-reload', { stdio: 'pipe' });\n execSync(`systemctl --user enable ${config.serviceName}`, {\n stdio: 'pipe',\n });\n execSync(`systemctl --user start ${config.serviceName}`, {\n stdio: 'pipe',\n });\n } catch {\n throw new SystemError(\n 'Failed to enable systemd service. Make sure systemd user session is available.',\n ErrorCode.SERVICE_UNAVAILABLE,\n { platform: 'linux', serviceName: config.serviceName }\n );\n }\n\n spinner.succeed(chalk.green('Guardian service installed and started'));\n console.log(chalk.gray(`Service file: ${config.serviceFile}`));\n console.log(chalk.gray(`Guardian script: ${guardianPath}`));\n console.log(chalk.gray(`Logs: ${config.logDir}/guardian.log`));\n }\n}\n\nasync function uninstallService(\n config: ServiceConfig,\n spinner: ora.Ora\n): Promise<void> {\n const home = process.env.HOME || '';\n const guardianPath = path.join(home, '.stackmemory', 'guardian.js');\n\n if (config.platform === 'darwin') {\n spinner.text = 'Unloading service...';\n\n try {\n execSync(`launchctl unload \"${config.serviceFile}\"`, { stdio: 'pipe' });\n } catch {\n // Service might not be loaded\n }\n\n // Remove plist file\n try {\n await fs.unlink(config.serviceFile);\n } catch {\n // File might not exist\n }\n\n // Remove guardian script\n try {\n await fs.unlink(guardianPath);\n } catch {\n // File might not exist\n }\n\n spinner.succeed(chalk.green('Guardian service uninstalled'));\n } else if (config.platform === 'linux') {\n spinner.text = 'Stopping service...';\n\n try {\n execSync(`systemctl --user stop ${config.serviceName}`, {\n stdio: 'pipe',\n });\n execSync(`systemctl --user disable ${config.serviceName}`, {\n stdio: 'pipe',\n });\n } catch {\n // Service might not be running\n }\n\n // Remove service file\n try {\n await fs.unlink(config.serviceFile);\n } catch {\n // File might not exist\n }\n\n // Remove guardian script\n try {\n await fs.unlink(guardianPath);\n } catch {\n // File might not exist\n }\n\n // Reload systemd\n try {\n execSync('systemctl --user daemon-reload', { stdio: 'pipe' });\n } catch {\n // Ignore\n }\n\n spinner.succeed(chalk.green('Guardian service uninstalled'));\n }\n}\n\nasync function showServiceStatus(config: ServiceConfig): Promise<void> {\n const home = process.env.HOME || '';\n const stateFile = path.join(home, '.stackmemory', 'guardian.state');\n\n console.log(chalk.bold('\\nStackMemory Guardian Service Status\\n'));\n\n if (config.platform === 'unsupported') {\n console.log(chalk.red('Platform not supported for service installation'));\n console.log(\n chalk.gray('Supported platforms: macOS (launchd), Linux (systemd)')\n );\n return;\n }\n\n // Check if service file exists\n if (!existsSync(config.serviceFile)) {\n console.log(chalk.yellow('Service not installed'));\n console.log(chalk.gray('Install with: stackmemory service install'));\n return;\n }\n\n let isRunning = false;\n let serviceOutput = '';\n\n if (config.platform === 'darwin') {\n try {\n serviceOutput = execSync(`launchctl list | grep ${config.serviceName}`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n isRunning = serviceOutput.includes(config.serviceName);\n } catch {\n isRunning = false;\n }\n } else if (config.platform === 'linux') {\n try {\n serviceOutput = execSync(\n `systemctl --user is-active ${config.serviceName}`,\n { encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] }\n ).trim();\n isRunning = serviceOutput === 'active';\n } catch {\n isRunning = false;\n }\n }\n\n if (isRunning) {\n console.log(chalk.green('Status: Running'));\n } else {\n console.log(chalk.yellow('Status: Stopped'));\n }\n\n console.log(chalk.gray(`Platform: ${config.platform}`));\n console.log(chalk.gray(`Service: ${config.serviceName}`));\n console.log(chalk.gray(`Config: ${config.serviceFile}`));\n\n // Try to read guardian state\n if (existsSync(stateFile)) {\n try {\n const state = JSON.parse(readFileSync(stateFile, 'utf-8'));\n console.log(chalk.bold('\\nGuardian State:'));\n console.log(` Last check: ${state.lastCheck}`);\n console.log(` Active sessions: ${state.activeSessions?.length || 0}`);\n console.log(` Sync running: ${state.syncRunning ? 'Yes' : 'No'}`);\n console.log(` Last activity: ${state.lastActivity}`);\n } catch {\n // Invalid state file\n }\n }\n}\n\nasync function showServiceLogs(\n config: ServiceConfig,\n lines: number\n): Promise<void> {\n console.log(\n chalk.bold(`\\nStackMemory Guardian Logs (last ${lines} lines)\\n`)\n );\n\n const logFile = path.join(config.logDir, 'guardian.log');\n\n if (!existsSync(logFile)) {\n console.log(chalk.yellow('No logs found'));\n console.log(chalk.gray(`Expected at: ${logFile}`));\n return;\n }\n\n try {\n const content = readFileSync(logFile, 'utf-8');\n const logLines = content.split('\\n').filter(Boolean);\n const lastLines = logLines.slice(-lines);\n\n lastLines.forEach((line) => {\n if (line.includes('[ERROR]')) {\n console.log(chalk.red(line));\n } else if (line.includes('[WARN]')) {\n console.log(chalk.yellow(line));\n } else {\n console.log(chalk.gray(line));\n }\n });\n\n console.log(chalk.gray(`\\nFull log: ${logFile}`));\n } catch (err) {\n console.log(chalk.red(`Failed to read logs: ${(err as Error).message}`));\n }\n}\n\nexport function createServiceCommand(): Command {\n const cmd = new Command('service')\n .description('Manage StackMemory guardian OS service (auto-start on login)')\n .addHelpText(\n 'after',\n `\nExamples:\n stackmemory service install Install and start the guardian service\n stackmemory service uninstall Remove the guardian service\n stackmemory service status Show service status\n stackmemory service logs Show recent service logs\n stackmemory service logs -n 50 Show last 50 log lines\n\nThe guardian service:\n - Monitors ~/.stackmemory/sessions/ for active sessions\n - Starts context sync when an active session is detected\n - Stops gracefully after 30 minutes of inactivity\n - Runs automatically on system login (opt-in)\n`\n );\n\n cmd\n .command('install')\n .description('Install the guardian service (starts on login)')\n .action(async () => {\n const spinner = ora('Installing guardian service...').start();\n\n try {\n const config = getServiceConfig();\n\n if (config.platform === 'unsupported') {\n spinner.fail(chalk.red('Platform not supported'));\n console.log(\n chalk.gray('Supported: macOS (launchd), Linux (systemd)')\n );\n process.exit(1);\n }\n\n await installService(config, spinner);\n\n console.log(chalk.bold('\\nGuardian service will:'));\n console.log(' - Start automatically on login');\n console.log(' - Monitor for active StackMemory sessions');\n console.log(' - Manage context sync based on activity');\n console.log(' - Stop gracefully after 30 min idle');\n } catch (err) {\n spinner.fail(\n chalk.red(`Installation failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('uninstall')\n .description('Remove the guardian service')\n .action(async () => {\n const spinner = ora('Uninstalling guardian service...').start();\n\n try {\n const config = getServiceConfig();\n\n if (config.platform === 'unsupported') {\n spinner.fail(chalk.red('Platform not supported'));\n process.exit(1);\n }\n\n await uninstallService(config, spinner);\n } catch (err) {\n spinner.fail(\n chalk.red(`Uninstallation failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('status')\n .description('Show guardian service status')\n .action(async () => {\n try {\n const config = getServiceConfig();\n await showServiceStatus(config);\n } catch (err) {\n console.error(\n chalk.red(`Status check failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n cmd\n .command('logs')\n .description('Show recent guardian service logs')\n .option('-n, --lines <number>', 'Number of log lines to show', '20')\n .option('-f, --follow', 'Follow log output (tail -f style)')\n .action(async (options) => {\n try {\n const config = getServiceConfig();\n const lines = parseInt(options.lines) || 20;\n\n if (options.follow) {\n // Use tail -f for live following\n const logFile = path.join(config.logDir, 'guardian.log');\n console.log(chalk.bold(`Following ${logFile} (Ctrl+C to stop)\\n`));\n\n const tail = spawn('tail', ['-f', '-n', lines.toString(), logFile], {\n stdio: 'inherit',\n });\n\n process.on('SIGINT', () => {\n tail.kill();\n process.exit(0);\n });\n } else {\n await showServiceLogs(config, lines);\n }\n } catch (err) {\n console.error(\n chalk.red(`Failed to show logs: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n // Default action - show status\n cmd.action(async () => {\n try {\n const config = getServiceConfig();\n await showServiceStatus(config);\n } catch (err) {\n console.error(\n chalk.red(`Status check failed: ${(err as Error).message}`)\n );\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\nexport default createServiceCommand();\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -18,11 +18,20 @@ import { LinearTaskManager } from "../../features/tasks/linear-task-manager.js";
|
|
|
18
18
|
import { ConfigManager } from "../../core/config/config-manager.js";
|
|
19
19
|
import * as path from "path";
|
|
20
20
|
import * as os from "os";
|
|
21
|
+
import {
|
|
22
|
+
SystemError,
|
|
23
|
+
DatabaseError,
|
|
24
|
+
ErrorCode
|
|
25
|
+
} from "../../core/errors/index.js";
|
|
21
26
|
function getEnv(key, defaultValue) {
|
|
22
27
|
const value = process.env[key];
|
|
23
28
|
if (value === void 0) {
|
|
24
29
|
if (defaultValue !== void 0) return defaultValue;
|
|
25
|
-
throw new
|
|
30
|
+
throw new SystemError(
|
|
31
|
+
`Environment variable ${key} is required`,
|
|
32
|
+
ErrorCode.CONFIGURATION_ERROR,
|
|
33
|
+
{ variable: key }
|
|
34
|
+
);
|
|
26
35
|
}
|
|
27
36
|
return value;
|
|
28
37
|
}
|
|
@@ -44,15 +53,28 @@ async function initializeSkillContext() {
|
|
|
44
53
|
await database.connect();
|
|
45
54
|
const rawDatabase = database.getRawDatabase();
|
|
46
55
|
if (!rawDatabase) {
|
|
47
|
-
throw new
|
|
56
|
+
throw new DatabaseError(
|
|
57
|
+
"Failed to get raw database connection",
|
|
58
|
+
ErrorCode.DB_CONNECTION_FAILED,
|
|
59
|
+
{ projectId, operation: "initializeSkillContext" }
|
|
60
|
+
);
|
|
48
61
|
}
|
|
49
62
|
if (typeof rawDatabase.exec !== "function") {
|
|
50
|
-
throw new
|
|
63
|
+
throw new DatabaseError(
|
|
64
|
+
`Invalid database instance: missing exec() method. Got: ${typeof rawDatabase.exec}`,
|
|
65
|
+
ErrorCode.DB_CONNECTION_FAILED,
|
|
66
|
+
{ projectId, operation: "initializeSkillContext" }
|
|
67
|
+
);
|
|
51
68
|
}
|
|
52
69
|
try {
|
|
53
70
|
rawDatabase.exec("SELECT 1");
|
|
54
71
|
} catch (err) {
|
|
55
|
-
throw new
|
|
72
|
+
throw new DatabaseError(
|
|
73
|
+
`Database connection test failed: ${err.message}`,
|
|
74
|
+
ErrorCode.DB_CONNECTION_FAILED,
|
|
75
|
+
{ projectId, operation: "initializeSkillContext" },
|
|
76
|
+
err
|
|
77
|
+
);
|
|
56
78
|
}
|
|
57
79
|
const dualStackManager = new DualStackManager(database, projectId, userId);
|
|
58
80
|
const handoffManager = new FrameHandoffManager(dualStackManager);
|
|
@@ -315,7 +337,23 @@ Searched ${result.data.timeRange.from} to ${result.data.timeRange.to}`
|
|
|
315
337
|
process.exit(1);
|
|
316
338
|
}
|
|
317
339
|
});
|
|
318
|
-
skillsCmd.command("rlm <task>").description("Execute complex tasks with recursive agent orchestration").option("--max-parallel <number>", "Maximum concurrent subagents", "5").option("--max-recursion <number>", "Maximum recursion depth", "4").option(
|
|
340
|
+
skillsCmd.command("rlm <task>").description("Execute complex tasks with recursive agent orchestration").option("--max-parallel <number>", "Maximum concurrent subagents", "5").option("--max-recursion <number>", "Maximum recursion depth", "4").option(
|
|
341
|
+
"--max-tokens-per-agent <number>",
|
|
342
|
+
"Token budget per subagent",
|
|
343
|
+
"30000"
|
|
344
|
+
).option("--review-stages <number>", "Number of review iterations", "3").option(
|
|
345
|
+
"--quality-threshold <number>",
|
|
346
|
+
"Target quality score (0-1)",
|
|
347
|
+
"0.85"
|
|
348
|
+
).option(
|
|
349
|
+
"--test-mode <mode>",
|
|
350
|
+
"Test generation mode (unit/integration/e2e/all)",
|
|
351
|
+
"all"
|
|
352
|
+
).option("--verbose", "Show all recursive operations", false).option(
|
|
353
|
+
"--share-context-realtime",
|
|
354
|
+
"Share discoveries between agents",
|
|
355
|
+
true
|
|
356
|
+
).option("--retry-failed-agents", "Retry on failure", true).option("--timeout-per-agent <number>", "Timeout in seconds", "300").action(async (task, options) => {
|
|
319
357
|
const spinner = ora("Initializing RLM orchestrator...").start();
|
|
320
358
|
try {
|
|
321
359
|
const { context, unifiedOrchestrator } = await initializeSkillContext();
|
|
@@ -338,7 +376,9 @@ Searched ${result.data.timeRange.from} to ${result.data.timeRange.to}`
|
|
|
338
376
|
if (result.data) {
|
|
339
377
|
console.log(chalk.cyan("\nExecution Summary:"));
|
|
340
378
|
console.log(` Total tokens: ${result.data.totalTokens}`);
|
|
341
|
-
console.log(
|
|
379
|
+
console.log(
|
|
380
|
+
` Estimated cost: $${result.data.totalCost.toFixed(2)}`
|
|
381
|
+
);
|
|
342
382
|
console.log(` Duration: ${result.data.duration}ms`);
|
|
343
383
|
console.log(` Tests generated: ${result.data.testsGenerated}`);
|
|
344
384
|
console.log(` Issues found: ${result.data.issuesFound}`);
|
|
@@ -391,22 +431,32 @@ Options:
|
|
|
391
431
|
`);
|
|
392
432
|
break;
|
|
393
433
|
default:
|
|
394
|
-
console.log(
|
|
434
|
+
console.log(
|
|
435
|
+
`Unknown skill: ${skill}. Use "stackmemory skills help" to see all available skills.`
|
|
436
|
+
);
|
|
395
437
|
}
|
|
396
438
|
} else {
|
|
397
|
-
console.log(
|
|
439
|
+
console.log(
|
|
440
|
+
chalk.cyan("Available Claude Skills (RLM-Orchestrated):\n")
|
|
441
|
+
);
|
|
398
442
|
console.log(
|
|
399
443
|
" handoff - Streamline frame handoffs between team members"
|
|
400
444
|
);
|
|
401
445
|
console.log(" checkpoint - Create and manage recovery points");
|
|
402
446
|
console.log(" dig - Deep historical context retrieval");
|
|
403
|
-
console.log(
|
|
447
|
+
console.log(
|
|
448
|
+
" lint - Comprehensive code linting and quality checks"
|
|
449
|
+
);
|
|
404
450
|
console.log(" test - Generate comprehensive test suites");
|
|
405
451
|
console.log(" review - Multi-stage code review and improvements");
|
|
406
452
|
console.log(" refactor - Refactor code for better architecture");
|
|
407
453
|
console.log(" publish - Prepare and execute releases");
|
|
408
454
|
console.log(" rlm - Direct recursive agent orchestration\n");
|
|
409
|
-
console.log(
|
|
455
|
+
console.log(
|
|
456
|
+
chalk.yellow(
|
|
457
|
+
"\nAll skills now use RLM orchestration for intelligent task decomposition"
|
|
458
|
+
)
|
|
459
|
+
);
|
|
410
460
|
console.log(
|
|
411
461
|
'Use "stackmemory skills help <skill>" for detailed help on each skill'
|
|
412
462
|
);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/cli/commands/skills.ts"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env node\n/**\n * Claude Skills CLI Commands\n * Integrates Claude skills into the stackmemory CLI\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n ClaudeSkillsManager,\n type SkillContext,\n} from '../../skills/claude-skills.js';\nimport { \n UnifiedRLMOrchestrator, \n initializeUnifiedOrchestrator \n} from '../../skills/unified-rlm-orchestrator.js';\nimport { DualStackManager } from '../../core/context/dual-stack-manager.js';\nimport { FrameHandoffManager } from '../../core/context/frame-handoff-manager.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport { ContextRetriever } from '../../core/retrieval/context-retriever.js';\nimport { SQLiteAdapter } from '../../core/database/sqlite-adapter.js';\nimport { LinearTaskManager } from '../../features/tasks/linear-task-manager.js';\nimport { ConfigManager } from '../../core/config/config-manager.js';\nimport * as path from 'path';\nimport * as os from 'os';\n// Type-safe environment variable access\nfunction getEnv(key: string, defaultValue?: string): string {\n const value = process.env[key];\n if (value === undefined) {\n if (defaultValue !== undefined) return defaultValue;\n throw new Error(`Environment variable ${key} is required`);\n }\n return value;\n}\n\nfunction getOptionalEnv(key: string): string | undefined {\n return process.env[key];\n}\n\nasync function initializeSkillContext(): Promise<{ \n context: SkillContext;\n unifiedOrchestrator: UnifiedRLMOrchestrator;\n}> {\n const config = ConfigManager.getInstance();\n const projectId = config.get('project.id') || 'default-project';\n const userId = config.get('user.id') || process.env['USER'] || 'default';\n\n const dbPath = path.join(\n os.homedir(),\n '.stackmemory',\n 'data',\n projectId,\n 'stackmemory.db'\n );\n\n const database = new SQLiteAdapter(projectId, { dbPath });\n await database.connect();\n\n // Get raw database for FrameManager\n const rawDatabase = database.getRawDatabase();\n if (!rawDatabase) {\n throw new Error('Failed to get raw database connection');\n }\n \n // Validate database has required methods\n if (typeof rawDatabase.exec !== 'function') {\n throw new Error(`Invalid database instance: missing exec() method. Got: ${typeof rawDatabase.exec}`);\n }\n \n // Test database connectivity\n try {\n rawDatabase.exec('SELECT 1');\n } catch (err) {\n throw new Error(`Database connection test failed: ${err.message}`);\n }\n\n const dualStackManager = new DualStackManager(database, projectId, userId);\n const handoffManager = new FrameHandoffManager(dualStackManager);\n const contextRetriever = new ContextRetriever(database);\n const frameManager = new FrameManager(rawDatabase, projectId);\n const taskStore = new LinearTaskManager();\n\n const context: SkillContext = {\n projectId,\n userId,\n dualStackManager,\n handoffManager,\n contextRetriever,\n database,\n frameManager,\n };\n \n // Initialize unified RLM orchestrator\n const unifiedOrchestrator = initializeUnifiedOrchestrator(\n frameManager,\n dualStackManager,\n contextRetriever,\n taskStore,\n context\n );\n\n return { context, unifiedOrchestrator };\n}\n\nexport function createSkillsCommand(): Command {\n const skillsCmd = new Command('skills').description(\n 'Execute Claude skills for enhanced workflow'\n );\n\n // Handoff skill command\n skillsCmd\n .command('handoff <targetUser> <message>')\n .description('Streamline frame handoffs between team members')\n .option(\n '-p, --priority <level>',\n 'Set priority (low, medium, high, critical)',\n 'medium'\n )\n .option('-f, --frames <frames...>', 'Specific frames to handoff')\n .option('--no-auto-detect', 'Disable auto-detection of frames')\n .action(async (targetUser, message, options) => {\n const spinner = ora('Initiating handoff...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n // Use unified RLM orchestrator for RLM-first execution\n const result = await unifiedOrchestrator.executeSkill(\n 'handoff',\n [targetUser, message],\n {\n priority: options.priority,\n frames: options.frames,\n autoDetect: options.autoDetect !== false,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nHandoff Details:'));\n console.log(` ID: ${result.data.handoffId}`);\n console.log(` Frames: ${result.data.frameCount}`);\n console.log(` Priority: ${result.data.priority}`);\n if (result.data.actionItems?.length > 0) {\n console.log(chalk.yellow('\\n Action Items:'));\n result.data.actionItems.forEach((item) => {\n console.log(` \u2022 ${item}`);\n });\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Checkpoint skill commands\n const checkpointCmd = skillsCmd\n .command('checkpoint')\n .description('Create and manage recovery points');\n\n checkpointCmd\n .command('create <description>')\n .description('Create a new checkpoint')\n .option('--files <files...>', 'Include specific files in checkpoint')\n .option('--auto-detect-risky', 'Auto-detect risky operations')\n .action(async (description, options) => {\n const spinner = ora('Creating checkpoint...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill(\n 'checkpoint',\n ['create', description],\n {\n includeFiles: options.files,\n autoDetectRisky: options.autoDetectRisky,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nCheckpoint Info:'));\n console.log(` ID: ${result.data.checkpointId}`);\n console.log(` Time: ${result.data.timestamp}`);\n console.log(` Frames: ${result.data.frameCount}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('restore <checkpointId>')\n .description('Restore from a checkpoint')\n .action(async (checkpointId) => {\n const spinner = ora('Restoring checkpoint...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('checkpoint', [\n 'restore',\n checkpointId,\n ]);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nRestored:'));\n console.log(` Frames: ${result.data.frameCount}`);\n console.log(` Files: ${result.data.filesRestored}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('list')\n .description('List available checkpoints')\n .option('-l, --limit <number>', 'Limit number of results', '10')\n .option('-s, --since <date>', 'Show checkpoints since date')\n .action(async (options) => {\n const spinner = ora('Loading checkpoints...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill(\n 'checkpoint',\n ['list'],\n {\n limit: parseInt(options.limit),\n since: options.since ? new Date(options.since) : undefined,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.cyan('Available Checkpoints:\\n'));\n if (result.data && result.data.length > 0) {\n result.data.forEach((cp: any) => {\n const riskIndicator = cp.risky ? chalk.yellow(' [RISKY]') : '';\n console.log(`${chalk.bold(cp.id)}${riskIndicator}`);\n console.log(` ${cp.description}`);\n console.log(\n chalk.gray(` ${cp.timestamp} (${cp.frameCount} frames)\\n`)\n );\n });\n } else {\n console.log(chalk.gray('No checkpoints found'));\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('diff <checkpoint1> <checkpoint2>')\n .description('Show differences between two checkpoints')\n .action(async (checkpoint1, checkpoint2) => {\n const spinner = ora('Comparing checkpoints...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('checkpoint', [\n 'diff',\n checkpoint1,\n checkpoint2,\n ]);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.cyan('Checkpoint Diff:\\n'));\n if (result.data) {\n console.log(` Time difference: ${result.data.timeDiff}`);\n console.log(` Frame difference: ${result.data.framesDiff}`);\n console.log(` New frames: ${result.data.newFrames}`);\n console.log(` Removed frames: ${result.data.removedFrames}`);\n console.log(` Modified frames: ${result.data.modifiedFrames}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Context Archaeologist skill command\n skillsCmd\n .command('dig <query>')\n .description('Deep historical context retrieval')\n .option(\n '-d, --depth <depth>',\n 'Search depth (e.g., 30days, 6months, all)',\n '30days'\n )\n .option('--patterns', 'Extract patterns from results')\n .option('--decisions', 'Extract key decisions')\n .option('--timeline', 'Generate activity timeline')\n .action(async (query, options) => {\n const spinner = ora('Digging through context...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('dig', [query], {\n depth: options.depth,\n patterns: options.patterns,\n decisions: options.decisions,\n timeline: options.timeline,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n\n if (result.data) {\n console.log(\n chalk.cyan(\n `\\nSearched ${result.data.timeRange.from} to ${result.data.timeRange.to}`\n )\n );\n\n if (result.data.summary) {\n console.log('\\n' + result.data.summary);\n } else {\n // Display top results\n if (result.data.topResults?.length > 0) {\n console.log(chalk.cyan('\\nTop Results:'));\n result.data.topResults.forEach((r: any) => {\n console.log(\n ` ${chalk.yellow(`[${r.score.toFixed(2)}]`)} ${r.summary}`\n );\n });\n }\n\n // Display patterns if found\n if (result.data.patterns?.length > 0) {\n console.log(chalk.cyan('\\nDetected Patterns:'));\n result.data.patterns.forEach((p: any) => {\n console.log(` ${p.name}: ${p.count} occurrences`);\n });\n }\n\n // Display decisions if found\n if (result.data.decisions?.length > 0) {\n console.log(chalk.cyan('\\nKey Decisions:'));\n result.data.decisions.slice(0, 5).forEach((d: any) => {\n console.log(\n ` ${chalk.gray(new Date(d.timestamp).toLocaleDateString())}: ${d.decision}`\n );\n });\n }\n\n // Display timeline if generated\n if (result.data.timeline?.length > 0) {\n console.log(chalk.cyan('\\nActivity Timeline:'));\n result.data.timeline.slice(0, 5).forEach((t: any) => {\n console.log(` ${t.date}: ${t.itemCount} activities`);\n });\n }\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // RLM (Recursive Language Model) skill command\n skillsCmd\n .command('rlm <task>')\n .description('Execute complex tasks with recursive agent orchestration')\n .option('--max-parallel <number>', 'Maximum concurrent subagents', '5')\n .option('--max-recursion <number>', 'Maximum recursion depth', '4')\n .option('--max-tokens-per-agent <number>', 'Token budget per subagent', '30000')\n .option('--review-stages <number>', 'Number of review iterations', '3')\n .option('--quality-threshold <number>', 'Target quality score (0-1)', '0.85')\n .option('--test-mode <mode>', 'Test generation mode (unit/integration/e2e/all)', 'all')\n .option('--verbose', 'Show all recursive operations', false)\n .option('--share-context-realtime', 'Share discoveries between agents', true)\n .option('--retry-failed-agents', 'Retry on failure', true)\n .option('--timeout-per-agent <number>', 'Timeout in seconds', '300')\n .action(async (task, options) => {\n const spinner = ora('Initializing RLM orchestrator...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n spinner.text = 'Decomposing task...';\n \n const result = await unifiedOrchestrator.executeSkill('rlm', [task], {\n maxParallel: parseInt(options.maxParallel),\n maxRecursionDepth: parseInt(options.maxRecursion),\n maxTokensPerAgent: parseInt(options.maxTokensPerAgent),\n reviewStages: parseInt(options.reviewStages),\n qualityThreshold: parseFloat(options.qualityThreshold),\n testGenerationMode: options.testMode,\n verboseLogging: options.verbose,\n shareContextRealtime: options.shareContextRealtime,\n retryFailedAgents: options.retryFailedAgents,\n timeoutPerAgent: parseInt(options.timeoutPerAgent) * 1000,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), 'RLM execution completed');\n \n if (result.data) {\n console.log(chalk.cyan('\\nExecution Summary:'));\n console.log(` Total tokens: ${result.data.totalTokens}`);\n console.log(` Estimated cost: $${result.data.totalCost.toFixed(2)}`);\n console.log(` Duration: ${result.data.duration}ms`);\n console.log(` Tests generated: ${result.data.testsGenerated}`);\n console.log(` Issues found: ${result.data.issuesFound}`);\n console.log(` Issues fixed: ${result.data.issuesFixed}`);\n \n if (result.data.improvements?.length > 0) {\n console.log(chalk.cyan('\\nImprovements:'));\n result.data.improvements.forEach((imp: string) => {\n console.log(` \u2022 ${imp}`);\n });\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Help command for skills\n skillsCmd\n .command('help [skill]')\n .description('Show help for a specific skill')\n .action(async (skill) => {\n if (skill) {\n // Show specific skill help\n switch (skill) {\n case 'lint':\n console.log(`\nlint (RLM-Orchestrated)\nPrimary Agent: linting\nSecondary Agents: improve\n\nComprehensive linting of code: Check syntax, types, formatting, security, performance, and dead code. Provide fixes.\n\nThis skill is executed through RLM orchestration for:\n- Automatic task decomposition\n- Parallel agent execution\n- Multi-stage quality review\n- Comprehensive result aggregation\n\nUsage:\n stackmemory skills lint # Lint current directory\n stackmemory skills lint src/ # Lint specific directory\n stackmemory skills lint src/file.ts # Lint specific file\n\nOptions:\n --fix Automatically fix issues where possible\n --format Focus on formatting issues\n --security Focus on security vulnerabilities\n --performance Focus on performance issues\n --verbose Show detailed output\n`);\n break;\n default:\n console.log(`Unknown skill: ${skill}. Use \"stackmemory skills help\" to see all available skills.`);\n }\n } else {\n console.log(chalk.cyan('Available Claude Skills (RLM-Orchestrated):\\n'));\n console.log(\n ' handoff - Streamline frame handoffs between team members'\n );\n console.log(' checkpoint - Create and manage recovery points');\n console.log(' dig - Deep historical context retrieval');\n console.log(' lint - Comprehensive code linting and quality checks');\n console.log(' test - Generate comprehensive test suites');\n console.log(' review - Multi-stage code review and improvements');\n console.log(' refactor - Refactor code for better architecture');\n console.log(' publish - Prepare and execute releases');\n console.log(' rlm - Direct recursive agent orchestration\\n');\n console.log(chalk.yellow('\\nAll skills now use RLM orchestration for intelligent task decomposition'));\n console.log(\n 'Use \"stackmemory skills help <skill>\" for detailed help on each skill'\n );\n }\n });\n\n return skillsCmd;\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\n/**\n * Claude Skills CLI Commands\n * Integrates Claude skills into the stackmemory CLI\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n ClaudeSkillsManager,\n type SkillContext,\n} from '../../skills/claude-skills.js';\nimport {\n UnifiedRLMOrchestrator,\n initializeUnifiedOrchestrator,\n} from '../../skills/unified-rlm-orchestrator.js';\nimport { DualStackManager } from '../../core/context/dual-stack-manager.js';\nimport { FrameHandoffManager } from '../../core/context/frame-handoff-manager.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport { ContextRetriever } from '../../core/retrieval/context-retriever.js';\nimport { SQLiteAdapter } from '../../core/database/sqlite-adapter.js';\nimport { LinearTaskManager } from '../../features/tasks/linear-task-manager.js';\nimport { ConfigManager } from '../../core/config/config-manager.js';\nimport * as path from 'path';\nimport * as os from 'os';\nimport {\n SystemError,\n DatabaseError,\n ErrorCode,\n} from '../../core/errors/index.js';\n\n// Type-safe environment variable access\nfunction getEnv(key: string, defaultValue?: string): string {\n const value = process.env[key];\n if (value === undefined) {\n if (defaultValue !== undefined) return defaultValue;\n throw new SystemError(\n `Environment variable ${key} is required`,\n ErrorCode.CONFIGURATION_ERROR,\n { variable: key }\n );\n }\n return value;\n}\n\nfunction getOptionalEnv(key: string): string | undefined {\n return process.env[key];\n}\n\nasync function initializeSkillContext(): Promise<{\n context: SkillContext;\n unifiedOrchestrator: UnifiedRLMOrchestrator;\n}> {\n const config = ConfigManager.getInstance();\n const projectId = config.get('project.id') || 'default-project';\n const userId = config.get('user.id') || process.env['USER'] || 'default';\n\n const dbPath = path.join(\n os.homedir(),\n '.stackmemory',\n 'data',\n projectId,\n 'stackmemory.db'\n );\n\n const database = new SQLiteAdapter(projectId, { dbPath });\n await database.connect();\n\n // Get raw database for FrameManager\n const rawDatabase = database.getRawDatabase();\n if (!rawDatabase) {\n throw new DatabaseError(\n 'Failed to get raw database connection',\n ErrorCode.DB_CONNECTION_FAILED,\n { projectId, operation: 'initializeSkillContext' }\n );\n }\n\n // Validate database has required methods\n if (typeof rawDatabase.exec !== 'function') {\n throw new DatabaseError(\n `Invalid database instance: missing exec() method. Got: ${typeof rawDatabase.exec}`,\n ErrorCode.DB_CONNECTION_FAILED,\n { projectId, operation: 'initializeSkillContext' }\n );\n }\n\n // Test database connectivity\n try {\n rawDatabase.exec('SELECT 1');\n } catch (err) {\n throw new DatabaseError(\n `Database connection test failed: ${(err as Error).message}`,\n ErrorCode.DB_CONNECTION_FAILED,\n { projectId, operation: 'initializeSkillContext' },\n err as Error\n );\n }\n\n const dualStackManager = new DualStackManager(database, projectId, userId);\n const handoffManager = new FrameHandoffManager(dualStackManager);\n const contextRetriever = new ContextRetriever(database);\n const frameManager = new FrameManager(rawDatabase, projectId);\n const taskStore = new LinearTaskManager();\n\n const context: SkillContext = {\n projectId,\n userId,\n dualStackManager,\n handoffManager,\n contextRetriever,\n database,\n frameManager,\n };\n\n // Initialize unified RLM orchestrator\n const unifiedOrchestrator = initializeUnifiedOrchestrator(\n frameManager,\n dualStackManager,\n contextRetriever,\n taskStore,\n context\n );\n\n return { context, unifiedOrchestrator };\n}\n\nexport function createSkillsCommand(): Command {\n const skillsCmd = new Command('skills').description(\n 'Execute Claude skills for enhanced workflow'\n );\n\n // Handoff skill command\n skillsCmd\n .command('handoff <targetUser> <message>')\n .description('Streamline frame handoffs between team members')\n .option(\n '-p, --priority <level>',\n 'Set priority (low, medium, high, critical)',\n 'medium'\n )\n .option('-f, --frames <frames...>', 'Specific frames to handoff')\n .option('--no-auto-detect', 'Disable auto-detection of frames')\n .action(async (targetUser, message, options) => {\n const spinner = ora('Initiating handoff...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n // Use unified RLM orchestrator for RLM-first execution\n const result = await unifiedOrchestrator.executeSkill(\n 'handoff',\n [targetUser, message],\n {\n priority: options.priority,\n frames: options.frames,\n autoDetect: options.autoDetect !== false,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nHandoff Details:'));\n console.log(` ID: ${result.data.handoffId}`);\n console.log(` Frames: ${result.data.frameCount}`);\n console.log(` Priority: ${result.data.priority}`);\n if (result.data.actionItems?.length > 0) {\n console.log(chalk.yellow('\\n Action Items:'));\n result.data.actionItems.forEach((item) => {\n console.log(` \u2022 ${item}`);\n });\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Checkpoint skill commands\n const checkpointCmd = skillsCmd\n .command('checkpoint')\n .description('Create and manage recovery points');\n\n checkpointCmd\n .command('create <description>')\n .description('Create a new checkpoint')\n .option('--files <files...>', 'Include specific files in checkpoint')\n .option('--auto-detect-risky', 'Auto-detect risky operations')\n .action(async (description, options) => {\n const spinner = ora('Creating checkpoint...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill(\n 'checkpoint',\n ['create', description],\n {\n includeFiles: options.files,\n autoDetectRisky: options.autoDetectRisky,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nCheckpoint Info:'));\n console.log(` ID: ${result.data.checkpointId}`);\n console.log(` Time: ${result.data.timestamp}`);\n console.log(` Frames: ${result.data.frameCount}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('restore <checkpointId>')\n .description('Restore from a checkpoint')\n .action(async (checkpointId) => {\n const spinner = ora('Restoring checkpoint...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('checkpoint', [\n 'restore',\n checkpointId,\n ]);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n if (result.data) {\n console.log(chalk.cyan('\\nRestored:'));\n console.log(` Frames: ${result.data.frameCount}`);\n console.log(` Files: ${result.data.filesRestored}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('list')\n .description('List available checkpoints')\n .option('-l, --limit <number>', 'Limit number of results', '10')\n .option('-s, --since <date>', 'Show checkpoints since date')\n .action(async (options) => {\n const spinner = ora('Loading checkpoints...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill(\n 'checkpoint',\n ['list'],\n {\n limit: parseInt(options.limit),\n since: options.since ? new Date(options.since) : undefined,\n }\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.cyan('Available Checkpoints:\\n'));\n if (result.data && result.data.length > 0) {\n result.data.forEach((cp: any) => {\n const riskIndicator = cp.risky ? chalk.yellow(' [RISKY]') : '';\n console.log(`${chalk.bold(cp.id)}${riskIndicator}`);\n console.log(` ${cp.description}`);\n console.log(\n chalk.gray(` ${cp.timestamp} (${cp.frameCount} frames)\\n`)\n );\n });\n } else {\n console.log(chalk.gray('No checkpoints found'));\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n checkpointCmd\n .command('diff <checkpoint1> <checkpoint2>')\n .description('Show differences between two checkpoints')\n .action(async (checkpoint1, checkpoint2) => {\n const spinner = ora('Comparing checkpoints...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('checkpoint', [\n 'diff',\n checkpoint1,\n checkpoint2,\n ]);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.cyan('Checkpoint Diff:\\n'));\n if (result.data) {\n console.log(` Time difference: ${result.data.timeDiff}`);\n console.log(` Frame difference: ${result.data.framesDiff}`);\n console.log(` New frames: ${result.data.newFrames}`);\n console.log(` Removed frames: ${result.data.removedFrames}`);\n console.log(` Modified frames: ${result.data.modifiedFrames}`);\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Context Archaeologist skill command\n skillsCmd\n .command('dig <query>')\n .description('Deep historical context retrieval')\n .option(\n '-d, --depth <depth>',\n 'Search depth (e.g., 30days, 6months, all)',\n '30days'\n )\n .option('--patterns', 'Extract patterns from results')\n .option('--decisions', 'Extract key decisions')\n .option('--timeline', 'Generate activity timeline')\n .action(async (query, options) => {\n const spinner = ora('Digging through context...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n const result = await unifiedOrchestrator.executeSkill('dig', [query], {\n depth: options.depth,\n patterns: options.patterns,\n decisions: options.decisions,\n timeline: options.timeline,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), result.message);\n\n if (result.data) {\n console.log(\n chalk.cyan(\n `\\nSearched ${result.data.timeRange.from} to ${result.data.timeRange.to}`\n )\n );\n\n if (result.data.summary) {\n console.log('\\n' + result.data.summary);\n } else {\n // Display top results\n if (result.data.topResults?.length > 0) {\n console.log(chalk.cyan('\\nTop Results:'));\n result.data.topResults.forEach((r: any) => {\n console.log(\n ` ${chalk.yellow(`[${r.score.toFixed(2)}]`)} ${r.summary}`\n );\n });\n }\n\n // Display patterns if found\n if (result.data.patterns?.length > 0) {\n console.log(chalk.cyan('\\nDetected Patterns:'));\n result.data.patterns.forEach((p: any) => {\n console.log(` ${p.name}: ${p.count} occurrences`);\n });\n }\n\n // Display decisions if found\n if (result.data.decisions?.length > 0) {\n console.log(chalk.cyan('\\nKey Decisions:'));\n result.data.decisions.slice(0, 5).forEach((d: any) => {\n console.log(\n ` ${chalk.gray(new Date(d.timestamp).toLocaleDateString())}: ${d.decision}`\n );\n });\n }\n\n // Display timeline if generated\n if (result.data.timeline?.length > 0) {\n console.log(chalk.cyan('\\nActivity Timeline:'));\n result.data.timeline.slice(0, 5).forEach((t: any) => {\n console.log(` ${t.date}: ${t.itemCount} activities`);\n });\n }\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // RLM (Recursive Language Model) skill command\n skillsCmd\n .command('rlm <task>')\n .description('Execute complex tasks with recursive agent orchestration')\n .option('--max-parallel <number>', 'Maximum concurrent subagents', '5')\n .option('--max-recursion <number>', 'Maximum recursion depth', '4')\n .option(\n '--max-tokens-per-agent <number>',\n 'Token budget per subagent',\n '30000'\n )\n .option('--review-stages <number>', 'Number of review iterations', '3')\n .option(\n '--quality-threshold <number>',\n 'Target quality score (0-1)',\n '0.85'\n )\n .option(\n '--test-mode <mode>',\n 'Test generation mode (unit/integration/e2e/all)',\n 'all'\n )\n .option('--verbose', 'Show all recursive operations', false)\n .option(\n '--share-context-realtime',\n 'Share discoveries between agents',\n true\n )\n .option('--retry-failed-agents', 'Retry on failure', true)\n .option('--timeout-per-agent <number>', 'Timeout in seconds', '300')\n .action(async (task, options) => {\n const spinner = ora('Initializing RLM orchestrator...').start();\n\n try {\n const { context, unifiedOrchestrator } = await initializeSkillContext();\n\n spinner.text = 'Decomposing task...';\n\n const result = await unifiedOrchestrator.executeSkill('rlm', [task], {\n maxParallel: parseInt(options.maxParallel),\n maxRecursionDepth: parseInt(options.maxRecursion),\n maxTokensPerAgent: parseInt(options.maxTokensPerAgent),\n reviewStages: parseInt(options.reviewStages),\n qualityThreshold: parseFloat(options.qualityThreshold),\n testGenerationMode: options.testMode,\n verboseLogging: options.verbose,\n shareContextRealtime: options.shareContextRealtime,\n retryFailedAgents: options.retryFailedAgents,\n timeoutPerAgent: parseInt(options.timeoutPerAgent) * 1000,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green('\u2713'), 'RLM execution completed');\n\n if (result.data) {\n console.log(chalk.cyan('\\nExecution Summary:'));\n console.log(` Total tokens: ${result.data.totalTokens}`);\n console.log(\n ` Estimated cost: $${result.data.totalCost.toFixed(2)}`\n );\n console.log(` Duration: ${result.data.duration}ms`);\n console.log(` Tests generated: ${result.data.testsGenerated}`);\n console.log(` Issues found: ${result.data.issuesFound}`);\n console.log(` Issues fixed: ${result.data.issuesFixed}`);\n\n if (result.data.improvements?.length > 0) {\n console.log(chalk.cyan('\\nImprovements:'));\n result.data.improvements.forEach((imp: string) => {\n console.log(` \u2022 ${imp}`);\n });\n }\n }\n } else {\n console.log(chalk.red('\u2717'), result.message);\n }\n\n await context.database.disconnect();\n } catch (error: unknown) {\n spinner.stop();\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n // Help command for skills\n skillsCmd\n .command('help [skill]')\n .description('Show help for a specific skill')\n .action(async (skill) => {\n if (skill) {\n // Show specific skill help\n switch (skill) {\n case 'lint':\n console.log(`\nlint (RLM-Orchestrated)\nPrimary Agent: linting\nSecondary Agents: improve\n\nComprehensive linting of code: Check syntax, types, formatting, security, performance, and dead code. Provide fixes.\n\nThis skill is executed through RLM orchestration for:\n- Automatic task decomposition\n- Parallel agent execution\n- Multi-stage quality review\n- Comprehensive result aggregation\n\nUsage:\n stackmemory skills lint # Lint current directory\n stackmemory skills lint src/ # Lint specific directory\n stackmemory skills lint src/file.ts # Lint specific file\n\nOptions:\n --fix Automatically fix issues where possible\n --format Focus on formatting issues\n --security Focus on security vulnerabilities\n --performance Focus on performance issues\n --verbose Show detailed output\n`);\n break;\n default:\n console.log(\n `Unknown skill: ${skill}. Use \"stackmemory skills help\" to see all available skills.`\n );\n }\n } else {\n console.log(\n chalk.cyan('Available Claude Skills (RLM-Orchestrated):\\n')\n );\n console.log(\n ' handoff - Streamline frame handoffs between team members'\n );\n console.log(' checkpoint - Create and manage recovery points');\n console.log(' dig - Deep historical context retrieval');\n console.log(\n ' lint - Comprehensive code linting and quality checks'\n );\n console.log(' test - Generate comprehensive test suites');\n console.log(' review - Multi-stage code review and improvements');\n console.log(' refactor - Refactor code for better architecture');\n console.log(' publish - Prepare and execute releases');\n console.log(' rlm - Direct recursive agent orchestration\\n');\n console.log(\n chalk.yellow(\n '\\nAll skills now use RLM orchestration for intelligent task decomposition'\n )\n );\n console.log(\n 'Use \"stackmemory skills help <skill>\" for detailed help on each skill'\n );\n }\n });\n\n return skillsCmd;\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|