@stackmemoryai/stackmemory 0.3.9 → 0.3.11
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 +54 -0
- package/dist/agents/core/agent-task-manager.js +12 -1
- package/dist/agents/core/agent-task-manager.js.map +3 -3
- package/dist/agents/testing-agent.js +610 -0
- package/dist/agents/testing-agent.js.map +7 -0
- package/dist/cli/browser-test.js +4 -4
- package/dist/cli/browser-test.js.map +2 -2
- package/dist/cli/claude-sm.js +2 -2
- package/dist/cli/claude-sm.js.map +2 -2
- package/dist/cli/codex-sm.js +5 -5
- package/dist/cli/codex-sm.js.map +2 -2
- package/dist/cli/commands/agent.js +3 -3
- package/dist/cli/commands/agent.js.map +2 -2
- package/dist/cli/commands/handoff.js +67 -20
- package/dist/cli/commands/handoff.js.map +3 -3
- package/dist/cli/commands/linear-unified.js +3 -3
- package/dist/cli/commands/linear-unified.js.map +2 -2
- package/dist/cli/commands/linear.js +2 -2
- package/dist/cli/commands/linear.js.map +2 -2
- package/dist/cli/commands/onboard.js +3 -3
- package/dist/cli/commands/onboard.js.map +2 -2
- package/dist/cli/commands/quality.js +2 -2
- package/dist/cli/commands/quality.js.map +2 -2
- package/dist/cli/commands/skills.js +113 -28
- package/dist/cli/commands/skills.js.map +2 -2
- package/dist/cli/commands/tasks.js +3 -3
- package/dist/cli/commands/tasks.js.map +2 -2
- package/dist/cli/commands/test.js +282 -0
- package/dist/cli/commands/test.js.map +7 -0
- package/dist/cli/commands/worktree.js +28 -10
- package/dist/cli/commands/worktree.js.map +2 -2
- package/dist/cli/index.js +5 -3
- package/dist/cli/index.js.map +2 -2
- package/dist/cli/utils/viewer.js +9 -9
- package/dist/cli/utils/viewer.js.map +2 -2
- package/dist/core/config/config-manager.js +26 -0
- package/dist/core/config/config-manager.js.map +3 -3
- package/dist/core/context/frame-handoff-manager.js +4 -4
- package/dist/core/context/frame-handoff-manager.js.map +1 -1
- package/dist/core/context/frame-manager.js +139 -0
- package/dist/core/context/frame-manager.js.map +2 -2
- package/dist/core/context/refactored-frame-manager.js +180 -1
- package/dist/core/context/refactored-frame-manager.js.map +2 -2
- package/dist/core/projects/project-isolation.js +197 -0
- package/dist/core/projects/project-isolation.js.map +7 -0
- package/dist/core/trace/debug-trace.js +1 -1
- package/dist/core/trace/debug-trace.js.map +2 -2
- package/dist/core/trace/index.js +4 -4
- package/dist/core/trace/index.js.map +2 -2
- package/dist/core/trace/trace-demo.js +8 -8
- package/dist/core/trace/trace-demo.js.map +2 -2
- package/dist/core/trace/trace-detector.demo.js +5 -5
- package/dist/core/trace/trace-detector.demo.js.map +2 -2
- package/dist/core/utils/update-checker.js +2 -2
- package/dist/core/utils/update-checker.js.map +2 -2
- package/dist/features/analytics/core/analytics-service.js +2 -2
- package/dist/features/analytics/core/analytics-service.js.map +2 -2
- package/dist/features/tasks/linear-task-manager.js +483 -0
- package/dist/features/tasks/linear-task-manager.js.map +7 -0
- package/dist/integrations/claude-code/subagent-client-stub.js +16 -0
- package/dist/integrations/claude-code/subagent-client-stub.js.map +7 -0
- package/dist/integrations/linear/auto-sync.js +2 -2
- package/dist/integrations/linear/auto-sync.js.map +2 -2
- package/dist/integrations/linear/config.js +12 -1
- package/dist/integrations/linear/config.js.map +2 -2
- package/dist/integrations/linear/sync-manager.js.map +1 -1
- package/dist/integrations/linear/sync.js.map +1 -1
- package/dist/integrations/linear/unified-sync.js.map +1 -1
- package/dist/integrations/linear/webhook-handler.js.map +2 -2
- package/dist/integrations/linear/webhook.js.map +2 -2
- package/dist/integrations/mcp/handlers/linear-handlers.js.map +1 -1
- package/dist/integrations/mcp/handlers/task-handlers.js.map +1 -1
- package/dist/integrations/mcp/refactored-server.js +2 -2
- package/dist/integrations/mcp/refactored-server.js.map +2 -2
- package/dist/integrations/mcp/server.js +3 -3
- package/dist/integrations/mcp/server.js.map +2 -2
- package/dist/mcp/stackmemory-mcp-server.js +3 -3
- package/dist/mcp/stackmemory-mcp-server.js.map +2 -2
- package/dist/skills/claude-skills.js +99 -5
- package/dist/skills/claude-skills.js.map +2 -2
- package/dist/skills/recursive-agent-orchestrator.js.map +1 -1
- package/dist/skills/security-secrets-scanner.js +21 -6
- package/dist/skills/security-secrets-scanner.js.map +2 -2
- package/dist/skills/unified-rlm-orchestrator.js +400 -0
- package/dist/skills/unified-rlm-orchestrator.js.map +7 -0
- package/package.json +4 -5
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\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/frame-manager.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { PebblesTaskStore } from '../features/tasks/pebbles-task-store.js';\nimport {\n LinearAuthManager,\n LinearOAuthSetup,\n} from '../integrations/linear/auth.js';\nimport {\n LinearSyncEngine,\n DEFAULT_SYNC_CONFIG,\n} from '../integrations/linear/sync.js';\nimport {\n initializeAutoSync,\n getAutoSyncService,\n stopAutoSync,\n} from '../integrations/linear/auto-sync.js';\nimport { LinearConfigManager } from '../integrations/linear/config.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { registerLinearCommands } from './commands/linear.js';\nimport { registerLinearTestCommand } from './commands/linear-test.js';\nimport { registerLinearListCommand } from './commands/linear-list.js';\nimport { registerLinearMigrateCommand } from './commands/linear-migrate.js';\nimport { registerLinearCreateCommand } from './commands/linear-create.js';\nimport { createChromaDBCommand } from './commands/chromadb.js';\nimport { createInfiniteStorageCommand } from './commands/infinite-storage.js';\nimport { createGCCommand } from './commands/gc.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { webhookCommand } from './commands/webhook.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 { createAgentCommand } from './commands/agent.js';\nimport { createHandoffCommand } from './commands/handoff.js';\nimport { createStorageCommand } from './commands/storage.js';\nimport { createSkillsCommand } from './commands/skills.js';\nimport clearCommand from './commands/clear.js';\nimport createWorkflowCommand from './commands/workflow.js';\nimport monitorCommand from './commands/monitor.js';\nimport qualityCommand from './commands/quality.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\n\nconst VERSION = '0.3.1';\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\nprogram\n .name('stackmemory')\n .description('Lossless memory runtime for AI coding tools')\n .version(VERSION);\n\nprogram\n .command('init')\n .description('Initialize StackMemory in current project')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n 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('\u2705 StackMemory initialized in', projectRoot);\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error('\u274C Initialization failed:', (error as Error).message);\n process.exit(1);\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 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(` Cached contexts: ${contextCount.count || 0} (global)`);\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(` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`);\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// Linear Integration Commands\nconst linearCommand = program\n .command('linear')\n .description('Linear API integration commands');\n\nlinearCommand\n .command('setup')\n .description('Setup Linear OAuth integration')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const linearSetup = new LinearOAuthSetup(projectRoot);\n\n const { authUrl, instructions } = await linearSetup.setupInteractive();\n\n console.log('\uD83D\uDD17 Linear OAuth Setup\\n');\n\n instructions.forEach((instruction) => {\n console.log(instruction);\n });\n\n if (authUrl) {\n console.log('\\n\uD83D\uDCCB Next step: Complete authorization and run:');\n console.log('stackmemory linear authorize <auth-code>');\n }\n } catch (error: unknown) {\n logger.error('Linear setup failed', error as Error);\n console.error('\u274C Setup failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('authorize')\n .description('Complete Linear OAuth authorization')\n .argument('<code>', 'Authorization code from Linear')\n .action(async (authCode: string) => {\n try {\n const projectRoot = process.cwd();\n const linearSetup = new LinearOAuthSetup(projectRoot);\n\n const success = await linearSetup.completeAuth(authCode);\n\n if (success) {\n console.log('\u2705 Linear integration authorized successfully!');\n console.log('\uD83E\uDDEA Testing connection...');\n\n const connectionOk = await linearSetup.testConnection();\n if (connectionOk) {\n console.log('\u2705 Linear connection test passed!');\n console.log('\\n\uD83D\uDE80 You can now use:');\n console.log('- stackmemory linear sync');\n console.log('- stackmemory linear status');\n } else {\n console.log(\n '\u26A0\uFE0F Linear connection test failed. Check your configuration.'\n );\n }\n } else {\n console.error('\u274C Authorization failed. Please try again.');\n process.exit(1);\n }\n } catch (error: unknown) {\n logger.error('Linear authorization failed', error as Error);\n console.error('\u274C Authorization failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('status')\n .description('Show Linear integration status')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const authManager = new LinearAuthManager(projectRoot);\n\n const isConfigured = authManager.isConfigured();\n\n console.log('\uD83D\uDCCA Linear Integration Status:');\n console.log(` Configured: ${isConfigured ? '\u2705' : '\u274C'}`);\n\n if (isConfigured) {\n const config = authManager.loadConfig();\n const tokens = authManager.loadTokens();\n\n console.log(\n ` Client ID: ${config?.clientId ? config.clientId.substring(0, 8) + '...' : 'Not set'}`\n );\n console.log(` Tokens: ${tokens ? '\u2705 Valid' : '\u274C Missing'}`);\n\n if (tokens) {\n const expiresIn = Math.floor(\n (tokens.expiresAt - Date.now()) / 1000 / 60\n );\n console.log(\n ` Token expires: ${expiresIn > 0 ? `${expiresIn} minutes` : 'Expired'}`\n );\n }\n\n // Test connection\n console.log('\\n\uD83E\uDDEA Testing connection...');\n const linearSetup = new LinearOAuthSetup(projectRoot);\n const connectionOk = await linearSetup.testConnection();\n console.log(` Connection: ${connectionOk ? '\u2705 OK' : '\u274C Failed'}`);\n } else {\n console.log('\\n\uD83D\uDCA1 Run \"stackmemory linear setup\" to get started');\n }\n } catch (error: unknown) {\n logger.error('Linear status check failed', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('sync')\n .description('Sync tasks with Linear')\n .option(\n '-d, --direction <direction>',\n 'Sync direction: bidirectional, to_linear, from_linear',\n 'bidirectional'\n )\n .action(async (options) => {\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 authManager = new LinearAuthManager(projectRoot);\n\n // Check for API key from environment first\n if (!process.env['LINEAR_API_KEY'] && !authManager.isConfigured()) {\n console.log(\n '\u274C Linear not configured. Set LINEAR_API_KEY environment variable or run \"stackmemory linear setup\" first.'\n );\n return;\n }\n\n const db = new Database(dbPath);\n const taskStore = new PebblesTaskStore(projectRoot, db);\n\n const syncConfig = {\n ...DEFAULT_SYNC_CONFIG,\n enabled: true,\n direction: options.direction,\n };\n\n const linearSync = new LinearSyncEngine(\n taskStore,\n authManager,\n syncConfig\n );\n\n console.log(`\uD83D\uDD04 Starting ${options.direction} sync with Linear...`);\n\n const result = await linearSync.sync();\n\n // Track progress\n const progress = new ProgressTracker(projectRoot);\n\n if (result.success) {\n console.log('\u2705 Sync completed successfully!');\n console.log(` To Linear: ${result.synced.toLinear} created`);\n console.log(` From Linear: ${result.synced.fromLinear} created`);\n console.log(` Updated: ${result.synced.updated}`);\n\n // Update progress tracker\n progress.updateLinearStatus({\n lastSync: new Date().toISOString(),\n tasksSynced:\n result.synced.toLinear +\n result.synced.fromLinear +\n result.synced.updated,\n });\n\n if (result.conflicts.length > 0) {\n console.log(`\\n\u26A0\uFE0F Conflicts detected: ${result.conflicts.length}`);\n result.conflicts.forEach((conflict) => {\n console.log(` - ${conflict.taskId}: ${conflict.reason}`);\n });\n }\n } else {\n console.log('\u274C Sync failed');\n if (result.errors.length > 0) {\n result.errors.forEach((error) => {\n console.log(` Error: ${error}`);\n });\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Linear sync failed', error as Error);\n console.error('\u274C Sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Auto-sync commands\nlinearCommand\n .command('auto-sync')\n .description('Manage automatic synchronization')\n .option('--start', 'Start auto-sync service')\n .option('--stop', 'Stop auto-sync service')\n .option('--status', 'Show auto-sync status')\n .option('--interval <minutes>', 'Set sync interval in minutes', '5')\n .option(\n '--direction <direction>',\n 'Set sync direction: bidirectional, to_linear, from_linear',\n 'bidirectional'\n )\n .option('--quiet-start <hour>', 'Start of quiet hours (0-23)', '22')\n .option('--quiet-end <hour>', 'End of quiet hours (0-23)', '7')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n\n if (options.status) {\n const service = getAutoSyncService();\n if (service) {\n const status = service.getStatus();\n console.log('\uD83D\uDCCA Linear Auto-Sync Status:');\n console.log(` Running: ${status.running ? '\u2705' : '\u274C'}`);\n console.log(` Direction: ${status.config.direction}`);\n console.log(` Interval: ${status.config.interval} minutes`);\n console.log(\n ` Conflict Resolution: ${status.config.conflictResolution}`\n );\n\n if (status.lastSyncTime > 0) {\n const lastSync = new Date(status.lastSyncTime);\n console.log(` Last Sync: ${lastSync.toLocaleString()}`);\n }\n\n if (status.nextSyncTime) {\n const nextSync = new Date(status.nextSyncTime);\n console.log(` Next Sync: ${nextSync.toLocaleString()}`);\n }\n\n if (status.config.quietHours) {\n console.log(\n ` Quiet Hours: ${status.config.quietHours.start}:00 - ${status.config.quietHours.end}:00`\n );\n }\n\n if (status.retryCount > 0) {\n console.log(` \u26A0\uFE0F Retry Count: ${status.retryCount}`);\n }\n } else {\n console.log('\uD83D\uDCCA Linear Auto-Sync Status: \u274C Not running');\n }\n return;\n }\n\n if (options.start) {\n const authManager = new LinearAuthManager(projectRoot);\n if (!authManager.isConfigured()) {\n console.log(\n '\u274C Linear not configured. Run \"stackmemory linear setup\" first.'\n );\n return;\n }\n\n const config = {\n interval: parseInt(options.interval),\n direction: options.direction,\n quietHours: {\n start: parseInt(options.quietStart),\n end: parseInt(options.quietEnd),\n },\n };\n\n const service = initializeAutoSync(projectRoot, config);\n await service.start();\n\n console.log('\u2705 Linear auto-sync started');\n console.log(` Interval: ${config.interval} minutes`);\n console.log(` Direction: ${config.direction}`);\n console.log(\n ` Quiet Hours: ${config.quietHours.start}:00 - ${config.quietHours.end}:00`\n );\n console.log(\n '\\n\uD83D\uDCA1 Use \"stackmemory linear auto-sync --status\" to check status'\n );\n\n // Keep process alive for auto-sync\n process.on('SIGINT', () => {\n console.log('\\n\uD83D\uDED1 Stopping auto-sync service...');\n service.stop();\n process.exit(0);\n });\n\n console.log('\uD83D\uDD04 Auto-sync running... Press Ctrl+C to stop');\n // Keep the process running\n await new Promise(() => {}); // Intentionally never resolves\n }\n\n if (options.stop) {\n stopAutoSync();\n console.log('\uD83D\uDED1 Linear auto-sync stopped');\n }\n\n if (!options.start && !options.stop && !options.status) {\n console.log('\uD83D\uDCA1 Usage:');\n console.log(' --start Start auto-sync service');\n console.log(' --stop Stop auto-sync service');\n console.log(' --status Show current status');\n console.log(\n '\\nExample: stackmemory linear auto-sync --start --interval 10'\n );\n }\n } catch (error: unknown) {\n logger.error('Linear auto-sync command failed', error as Error);\n console.error('\u274C Auto-sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('force-sync')\n .description('Force immediate synchronization')\n .action(async () => {\n try {\n const service = getAutoSyncService();\n if (service) {\n console.log('\uD83D\uDD04 Forcing immediate sync...');\n await service.forceSync();\n console.log('\u2705 Sync completed');\n } else {\n console.log(\n '\u274C Auto-sync service not running. Use manual sync instead:'\n );\n console.log(' stackmemory linear sync');\n }\n } catch (error: unknown) {\n logger.error('Force sync failed', error as Error);\n console.error('\u274C Force sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('update <issueId>')\n .description('Update Linear task status')\n .option(\n '-s, --status <status>',\n 'New status (todo, in-progress, done, canceled)'\n )\n .option('-t, --title <title>', 'Update task title')\n .option('-d, --description <desc>', 'Update task description')\n .option(\n '-p, --priority <priority>',\n 'Set priority (1=urgent, 2=high, 3=medium, 4=low)'\n )\n .action(async (issueId, options) => {\n try {\n const projectRoot = process.cwd();\n const authManager = new LinearAuthManager(projectRoot);\n const tokens = authManager.loadTokens();\n\n if (!tokens) {\n console.error('\u274C Not authenticated. Run: stackmemory linear setup');\n process.exit(1);\n }\n\n const { LinearClient } = await import('../integrations/linear/client.js');\n const client = new LinearClient({\n apiKey: tokens.accessToken,\n useBearer: true,\n onUnauthorized: async () => {\n const refreshed = await authManager.refreshAccessToken();\n return refreshed.accessToken;\n },\n });\n\n // Find the issue first\n let issue = await client.getIssue(issueId);\n if (!issue) {\n // Try finding by identifier\n issue = await client.findIssueByIdentifier(issueId);\n }\n\n if (!issue) {\n console.error(`\u274C Issue ${issueId} not found`);\n process.exit(1);\n }\n\n const updates: Record<string, unknown> = {};\n\n // Handle status update\n if (options.status) {\n const team = await client.getTeam();\n const states = await client.getWorkflowStates(team.id);\n\n const statusMap: Record<string, string> = {\n todo: 'unstarted',\n 'in-progress': 'started',\n done: 'completed',\n canceled: 'cancelled',\n };\n\n const targetType =\n statusMap[options.status.toLowerCase()] || options.status;\n const targetState = states.find(\n (s: { type: string }) => s.type === targetType\n );\n\n if (!targetState) {\n console.error(`\u274C Invalid status: ${options.status}`);\n console.log('Available states:');\n states.forEach((s: { name: string; type: string }) =>\n console.log(` - ${s.name} (${s.type})`)\n );\n process.exit(1);\n }\n\n updates.stateId = targetState.id;\n }\n\n if (options.title) updates.title = options.title;\n if (options.description) updates.description = options.description;\n if (options.priority) updates.priority = parseInt(options.priority);\n\n // Perform update\n const updatedIssue = await client.updateIssue(issue.id, updates);\n\n console.log(\n `\u2705 Updated ${updatedIssue.identifier}: ${updatedIssue.title}`\n );\n if (options.status) {\n console.log(` Status: ${updatedIssue.state.name}`);\n }\n console.log(` ${updatedIssue.url}`);\n\n // Auto-sync to local tasks after update\n console.log('\\n\uD83D\uDD04 Syncing to local tasks...');\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n if (existsSync(dbPath)) {\n const db = new Database(dbPath);\n const taskStore = new PebblesTaskStore(projectRoot, db);\n const { LinearSyncEngine, DEFAULT_SYNC_CONFIG } =\n await import('../integrations/linear/sync.js');\n const syncEngine = new LinearSyncEngine(\n taskStore,\n authManager,\n { ...DEFAULT_SYNC_CONFIG, enabled: true, direction: 'from_linear' },\n projectRoot\n );\n const syncResult = await syncEngine.sync();\n if (syncResult.success) {\n console.log(\n ` \u2705 Local tasks synced (${syncResult.synced.fromLinear} new, ${syncResult.synced.updated} updated)`\n );\n }\n db.close();\n }\n } catch (error: unknown) {\n logger.error('Failed to update Linear task', error as Error);\n console.error('\u274C Failed to update task:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('config')\n .description('Configure auto-sync settings')\n .option('--show', 'Show current configuration')\n .option('--set-interval <minutes>', 'Set sync interval in minutes')\n .option(\n '--set-direction <direction>',\n 'Set sync direction: bidirectional, to_linear, from_linear'\n )\n .option(\n '--set-conflict-resolution <strategy>',\n 'Set conflict resolution: newest_wins, linear_wins, stackmemory_wins, manual'\n )\n .option('--set-quiet-start <hour>', 'Set start of quiet hours (0-23)')\n .option('--set-quiet-end <hour>', 'Set end of quiet hours (0-23)')\n .option('--enable', 'Enable auto-sync')\n .option('--disable', 'Disable auto-sync')\n .option('--reset', 'Reset to default configuration')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const configManager = new LinearConfigManager(projectRoot);\n\n if (options.reset) {\n configManager.resetConfig();\n console.log('\u2705 Configuration reset to defaults');\n return;\n }\n\n if (options.show) {\n const config = configManager.loadConfig();\n if (config) {\n console.log('\uD83D\uDCCA Linear Auto-Sync Configuration:');\n console.log(` Enabled: ${config.enabled ? '\u2705' : '\u274C'}`);\n console.log(` Interval: ${config.interval} minutes`);\n console.log(` Direction: ${config.direction}`);\n console.log(` Conflict Resolution: ${config.conflictResolution}`);\n console.log(` Retry Attempts: ${config.retryAttempts}`);\n console.log(` Retry Delay: ${config.retryDelay / 1000}s`);\n\n if (config.quietHours) {\n console.log(\n ` Quiet Hours: ${config.quietHours.start}:00 - ${config.quietHours.end}:00`\n );\n }\n\n const lastUpdated = new Date(config.lastUpdated);\n console.log(` Last Updated: ${lastUpdated.toLocaleString()}`);\n } else {\n console.log('\uD83D\uDCCA No configuration found. Using defaults.');\n const defaultConfig = configManager.getDefaultConfig();\n console.log(` Default interval: ${defaultConfig.interval} minutes`);\n console.log(` Default direction: ${defaultConfig.direction}`);\n }\n return;\n }\n\n // Update configuration\n const updates: Record<string, unknown> = {};\n\n if (options.setInterval) {\n const interval = parseInt(options.setInterval);\n if (isNaN(interval) || interval < 1) {\n console.error('\u274C Interval must be a positive number');\n process.exit(1);\n }\n updates.interval = interval;\n console.log(`\u2705 Set interval to ${interval} minutes`);\n }\n\n if (options.setDirection) {\n const validDirections = ['bidirectional', 'to_linear', 'from_linear'];\n if (!validDirections.includes(options.setDirection)) {\n console.error(\n `\u274C Invalid direction. Must be one of: ${validDirections.join(', ')}`\n );\n process.exit(1);\n }\n updates.direction = options.setDirection;\n console.log(`\u2705 Set direction to ${options.setDirection}`);\n }\n\n if (options.setConflictResolution) {\n const validStrategies = [\n 'newest_wins',\n 'linear_wins',\n 'stackmemory_wins',\n 'manual',\n ];\n if (!validStrategies.includes(options.setConflictResolution)) {\n console.error(\n `\u274C Invalid strategy. Must be one of: ${validStrategies.join(', ')}`\n );\n process.exit(1);\n }\n updates.conflictResolution = options.setConflictResolution;\n console.log(\n `\u2705 Set conflict resolution to ${options.setConflictResolution}`\n );\n }\n\n if (options.setQuietStart) {\n const hour = parseInt(options.setQuietStart);\n if (isNaN(hour) || hour < 0 || hour > 23) {\n console.error('\u274C Quiet start hour must be between 0 and 23');\n process.exit(1);\n }\n const currentConfig =\n configManager.loadConfig() || configManager.getDefaultConfig();\n updates.quietHours = {\n start: hour,\n end: currentConfig.quietHours?.end || 7,\n };\n console.log(`\u2705 Set quiet hours start to ${hour}:00`);\n }\n\n if (options.setQuietEnd) {\n const hour = parseInt(options.setQuietEnd);\n if (isNaN(hour) || hour < 0 || hour > 23) {\n console.error('\u274C Quiet end hour must be between 0 and 23');\n process.exit(1);\n }\n const currentConfig =\n configManager.loadConfig() || configManager.getDefaultConfig();\n updates.quietHours = {\n start: currentConfig.quietHours?.start || 22,\n end: hour,\n };\n console.log(`\u2705 Set quiet hours end to ${hour}:00`);\n }\n\n if (options.enable) {\n updates.enabled = true;\n console.log('\u2705 Auto-sync enabled');\n }\n\n if (options.disable) {\n updates.enabled = false;\n console.log('\u274C Auto-sync disabled');\n }\n\n if (Object.keys(updates).length > 0) {\n configManager.saveConfig(updates);\n console.log(\n '\\n\uD83D\uDCA1 Configuration updated. Restart auto-sync service to apply changes.'\n );\n } else if (!options.show) {\n console.log('\uD83D\uDCA1 Use --show to view current configuration');\n console.log('\uD83D\uDCA1 Use --help to see all configuration options');\n }\n } catch (error: unknown) {\n logger.error('Linear config command failed', error as Error);\n console.error('\u274C Config failed:', (error as Error).message);\n process.exit(1);\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('analytics')\n .description('Launch task analytics dashboard')\n .option('-p, --port <port>', 'Port for dashboard server', '3000')\n .option('-o, --open', 'Open dashboard in browser')\n .option('--export <format>', 'Export metrics (json|csv)')\n .option('--sync', 'Sync with Linear before launching')\n .option('--view', 'Show analytics in terminal')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n if (options.view) {\n const { displayAnalyticsDashboard } = await import('./utils/viewer.js');\n await displayAnalyticsDashboard(projectRoot);\n return;\n }\n\n if (options.export) {\n const { AnalyticsService } =\n await import('../features/analytics/index.js');\n const service = new AnalyticsService(projectRoot);\n\n if (options.sync) {\n console.log('\uD83D\uDD04 Syncing with Linear...');\n await service.syncLinearTasks();\n }\n\n const state = await service.getDashboardState();\n\n if (options.export === 'csv') {\n console.log('\uD83D\uDCCA Exporting metrics as CSV...');\n // Convert to CSV format\n const tasks = state.recentTasks;\n const headers = [\n 'ID',\n 'Title',\n 'State',\n 'Priority',\n 'Created',\n 'Completed',\n ];\n const rows = tasks.map((t) => [\n t.id,\n t.title,\n t.state,\n t.priority,\n t.createdAt.toISOString(),\n t.completedAt?.toISOString() || '',\n ]);\n console.log(headers.join(','));\n rows.forEach((r) => console.log(r.join(',')));\n } else {\n console.log(JSON.stringify(state, null, 2));\n }\n\n service.close();\n return;\n }\n\n // Launch dashboard server\n console.log(\n `\uD83D\uDE80 Launching analytics dashboard on port ${options.port}...`\n );\n\n const express = (await import('express')).default;\n const { AnalyticsAPI } = await import('../features/analytics/index.js');\n const { createServer } = await import('http');\n\n const app = express();\n\n // Add error handling middleware\n app.use(\n (\n err: Error,\n _req: import('express').Request,\n res: import('express').Response,\n _next: import('express').NextFunction\n ) => {\n console.error('Express error:', err);\n res.status(500).json({ error: err.message });\n }\n );\n\n const analyticsAPI = new AnalyticsAPI(projectRoot);\n\n if (options.sync) {\n console.log('\uD83D\uDD04 Syncing with Linear...');\n const service = new (\n await import('../features/analytics/index.js')\n ).AnalyticsService(projectRoot);\n await service.syncLinearTasks();\n service.close();\n }\n\n app.use('/api/analytics', analyticsAPI.getRouter());\n\n // Serve the HTML dashboard\n app.get('/', async (req, res) => {\n // Try multiple paths for the dashboard HTML\n const possiblePaths = [\n join(projectRoot, 'src/features/analytics/dashboard.html'),\n join(projectRoot, 'dist/features/analytics/dashboard.html'),\n ];\n\n for (const dashboardPath of possiblePaths) {\n if (existsSync(dashboardPath)) {\n res.sendFile(dashboardPath);\n return;\n }\n }\n\n // Inline fallback dashboard\n res.send(`<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>StackMemory Analytics</title>\n <script src=\"https://cdn.jsdelivr.net/npm/chart.js\"></script>\n <style>\n * { margin: 0; padding: 0; box-sizing: border-box; }\n body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: #1a1a2e; color: #eee; padding: 20px; }\n .container { max-width: 1200px; margin: 0 auto; }\n h1 { color: #667eea; margin-bottom: 20px; }\n .grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; margin-bottom: 30px; }\n .card { background: #16213e; border-radius: 12px; padding: 20px; }\n .metric-value { font-size: 2.5em; font-weight: bold; color: #667eea; }\n .metric-label { color: #888; text-transform: uppercase; font-size: 0.8em; }\n .task-list { max-height: 400px; overflow-y: auto; }\n .task-item { padding: 10px; border-left: 3px solid #667eea; margin-bottom: 8px; background: #1a1a2e; }\n .task-item.completed { border-color: #22c55e; }\n .task-item.in_progress { border-color: #f59e0b; }\n .status { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 0.8em; margin-right: 8px; }\n .status.completed { background: #22c55e30; color: #22c55e; }\n .status.in_progress { background: #f59e0b30; color: #f59e0b; }\n .status.todo { background: #667eea30; color: #667eea; }\n </style>\n</head>\n<body>\n <div class=\"container\">\n <h1>\uD83D\uDCCA StackMemory Analytics</h1>\n <div class=\"grid\" id=\"metrics\"></div>\n <div class=\"card\"><h3>Recent Tasks</h3><div class=\"task-list\" id=\"tasks\">Loading...</div></div>\n </div>\n <script>\n async function load() {\n const metrics = await fetch('/api/analytics/metrics').then(r => r.json());\n const tasks = await fetch('/api/analytics/tasks').then(r => r.json());\n \n document.getElementById('metrics').innerHTML = \\`\n <div class=\"card\"><div class=\"metric-label\">Total</div><div class=\"metric-value\">\\${metrics.data.metrics.totalTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">Completed</div><div class=\"metric-value\">\\${metrics.data.metrics.completedTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">In Progress</div><div class=\"metric-value\">\\${metrics.data.metrics.inProgressTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">Completion</div><div class=\"metric-value\">\\${metrics.data.metrics.completionRate.toFixed(0)}%</div></div>\n \\`;\n \n document.getElementById('tasks').innerHTML = tasks.data.tasks.slice(0, 10).map((t: any) => \\`\n <div class=\"task-item \\${t.state}\">\n <span class=\"status \\${t.state}\">\\${t.state}</span>\n <strong>\\${t.title}</strong>\n </div>\n \\`).join('');\n }\n load();\n setInterval(load, 30000);\n </script>\n</body>\n</html>`);\n });\n\n const server = createServer(app);\n analyticsAPI.setupWebSocket(server);\n\n server.listen(options.port, async () => {\n console.log(\n `\u2705 Analytics dashboard running at http://localhost:${options.port}`\n );\n\n if (options.open) {\n const { exec } = await import('child_process');\n const url = `http://localhost:${options.port}`;\n const command =\n process.platform === 'darwin'\n ? `open ${url}`\n : process.platform === 'win32'\n ? `start ${url}`\n : `xdg-open ${url}`;\n exec(command);\n }\n });\n\n process.on('SIGINT', () => {\n console.log('\\n\uD83D\uDC4B Shutting down analytics dashboard...');\n analyticsAPI.close();\n server.close();\n process.exit(0);\n });\n\n // Keep the process alive\n await new Promise(() => {});\n } catch (error: unknown) {\n logger.error('Analytics command failed', error as Error);\n console.error('\u274C Analytics 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);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands\nregisterLinearCommands(program);\nregisterLinearTestCommand(program);\nregisterLinearListCommand(program);\nregisterLinearMigrateCommand(program);\nregisterLinearCreateCommand(program);\n\n// Add ChromaDB command\nprogram.addCommand(createChromaDBCommand());\n\n// Add Infinite Storage command\nprogram.addCommand(createInfiniteStorageCommand());\nprogram.addCommand(createGCCommand());\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register webhook command\nprogram.addCommand(webhookCommand());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createAgentCommand());\nprogram.addCommand(createHandoffCommand());\nprogram.addCommand(createStorageCommand());\nprogram.addCommand(createSkillsCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(createWorkflowCommand());\nprogram.addCommand(monitorCommand);\nprogram.addCommand(qualityCommand);\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// Register TUI command (advanced terminal UI - requires blessed)\nprogram\n .command('tui')\n .description('Launch interactive TUI monitoring dashboard (requires blessed)')\n .option('-s, --server', 'Start WebSocket server for real-time updates')\n .option('-w, --ws-url <url>', 'WebSocket server URL', 'ws://localhost:8080')\n .option('-r, --refresh <ms>', 'Auto-refresh interval in milliseconds', '2000')\n .action(async (options) => {\n try {\n // Check if blessed is installed by trying to import it\n try {\n await import('blessed');\n } catch {\n console.log(\n '\u274C The TUI requires the blessed package. Install it with:'\n );\n console.log(' npm install blessed blessed-contrib');\n console.log(\n '\\n\uD83D\uDCA1 Alternatively, use \"stackmemory dashboard\" for a simpler view'\n );\n process.exit(1);\n }\n\n const { spawn } = await import('child_process');\n const { fileURLToPath } = await import('url');\n const { dirname, join } = await import('path');\n\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n\n console.log('\uD83D\uDE80 Launching StackMemory TUI Dashboard...');\n\n // Set environment variables\n process.env['STACKMEMORY_WS_URL'] = options.wsUrl;\n\n // Get TUI module path\n const tuiPath = join(__dirname, '../features/tui/index.js');\n\n // Launch TUI directly\n const tui = spawn('node', [tuiPath], {\n stdio: 'inherit',\n env: {\n ...process.env,\n STACKMEMORY_WS_URL: options.wsUrl,\n },\n });\n\n tui.on('error', (error) => {\n console.error('Failed to launch TUI:', error);\n console.log('\\n\uD83D\uDCA1 Try \"stackmemory dashboard\" instead');\n process.exit(1);\n });\n\n tui.on('exit', (code) => {\n if (code !== 0) {\n console.error(`TUI exited with code ${code}`);\n process.exit(code || 1);\n }\n });\n } catch (error: unknown) {\n console.error('\u274C Failed to launch TUI:', (error as Error).message);\n console.log('\\n\uD83D\uDCA1 Try \"stackmemory dashboard\" for a simpler view');\n process.exit(1);\n }\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n}\n\n// Only parse when running as main module (not when imported for testing)\nconst isMainModule =\n import.meta.url === `file://${process.argv[1]}` ||\n process.argv[1]?.endsWith('/stackmemory') ||\n process.argv[1]?.endsWith('index.ts') ||\n process.argv[1]?.includes('tsx');\n\nif (isMainModule) {\n program.parse();\n}\n\nexport { program };\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory CLI\n * Command-line interface for StackMemory operations\n */\n\n// Set environment flag for CLI usage to skip async context bridge\nprocess.env['STACKMEMORY_CLI'] = 'true';\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/frame-manager.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { LinearTaskManager } from '../features/tasks/linear-task-manager.js';\nimport {\n LinearAuthManager,\n LinearOAuthSetup,\n} from '../integrations/linear/auth.js';\nimport {\n LinearSyncEngine,\n DEFAULT_SYNC_CONFIG,\n} from '../integrations/linear/sync.js';\nimport {\n initializeAutoSync,\n getAutoSyncService,\n stopAutoSync,\n} from '../integrations/linear/auto-sync.js';\nimport { LinearConfigManager } from '../integrations/linear/config.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { registerLinearCommands } from './commands/linear.js';\nimport { registerLinearTestCommand } from './commands/linear-test.js';\nimport { registerLinearListCommand } from './commands/linear-list.js';\nimport { registerLinearMigrateCommand } from './commands/linear-migrate.js';\nimport { registerLinearCreateCommand } from './commands/linear-create.js';\nimport { createChromaDBCommand } from './commands/chromadb.js';\nimport { createInfiniteStorageCommand } from './commands/infinite-storage.js';\nimport { createGCCommand } from './commands/gc.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { webhookCommand } from './commands/webhook.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 { createAgentCommand } from './commands/agent.js';\nimport { createHandoffCommand } from './commands/handoff.js';\nimport { createStorageCommand } from './commands/storage.js';\nimport { createSkillsCommand } from './commands/skills.js';\nimport { createTestCommand } from './commands/test.js';\nimport clearCommand from './commands/clear.js';\nimport createWorkflowCommand from './commands/workflow.js';\nimport monitorCommand from './commands/monitor.js';\nimport qualityCommand from './commands/quality.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\n\nconst VERSION = '0.3.1';\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\nprogram\n .name('stackmemory')\n .description('Lossless memory runtime for AI coding tools')\n .version(VERSION);\n\nprogram\n .command('init')\n .description('Initialize StackMemory in current project')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n 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('\u2705 StackMemory initialized in', projectRoot);\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error('\u274C Initialization failed:', (error as Error).message);\n process.exit(1);\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 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(` Cached contexts: ${contextCount.count || 0} (global)`);\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(` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`);\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// Linear Integration Commands\nconst linearCommand = program\n .command('linear')\n .description('Linear API integration commands');\n\nlinearCommand\n .command('setup')\n .description('Setup Linear OAuth integration')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const linearSetup = new LinearOAuthSetup(projectRoot);\n\n const { authUrl, instructions } = await linearSetup.setupInteractive();\n\n console.log('\uD83D\uDD17 Linear OAuth Setup\\n');\n\n instructions.forEach((instruction) => {\n console.log(instruction);\n });\n\n if (authUrl) {\n console.log('\\n\uD83D\uDCCB Next step: Complete authorization and run:');\n console.log('stackmemory linear authorize <auth-code>');\n }\n } catch (error: unknown) {\n logger.error('Linear setup failed', error as Error);\n console.error('\u274C Setup failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('authorize')\n .description('Complete Linear OAuth authorization')\n .argument('<code>', 'Authorization code from Linear')\n .action(async (authCode: string) => {\n try {\n const projectRoot = process.cwd();\n const linearSetup = new LinearOAuthSetup(projectRoot);\n\n const success = await linearSetup.completeAuth(authCode);\n\n if (success) {\n console.log('\u2705 Linear integration authorized successfully!');\n console.log('\uD83E\uDDEA Testing connection...');\n\n const connectionOk = await linearSetup.testConnection();\n if (connectionOk) {\n console.log('\u2705 Linear connection test passed!');\n console.log('\\n\uD83D\uDE80 You can now use:');\n console.log('- stackmemory linear sync');\n console.log('- stackmemory linear status');\n } else {\n console.log(\n '\u26A0\uFE0F Linear connection test failed. Check your configuration.'\n );\n }\n } else {\n console.error('\u274C Authorization failed. Please try again.');\n process.exit(1);\n }\n } catch (error: unknown) {\n logger.error('Linear authorization failed', error as Error);\n console.error('\u274C Authorization failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('status')\n .description('Show Linear integration status')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const authManager = new LinearAuthManager(projectRoot);\n\n const isConfigured = authManager.isConfigured();\n\n console.log('\uD83D\uDCCA Linear Integration Status:');\n console.log(` Configured: ${isConfigured ? '\u2705' : '\u274C'}`);\n\n if (isConfigured) {\n const config = authManager.loadConfig();\n const tokens = authManager.loadTokens();\n\n console.log(\n ` Client ID: ${config?.clientId ? config.clientId.substring(0, 8) + '...' : 'Not set'}`\n );\n console.log(` Tokens: ${tokens ? '\u2705 Valid' : '\u274C Missing'}`);\n\n if (tokens) {\n const expiresIn = Math.floor(\n (tokens.expiresAt - Date.now()) / 1000 / 60\n );\n console.log(\n ` Token expires: ${expiresIn > 0 ? `${expiresIn} minutes` : 'Expired'}`\n );\n }\n\n // Test connection\n console.log('\\n\uD83E\uDDEA Testing connection...');\n const linearSetup = new LinearOAuthSetup(projectRoot);\n const connectionOk = await linearSetup.testConnection();\n console.log(` Connection: ${connectionOk ? '\u2705 OK' : '\u274C Failed'}`);\n } else {\n console.log('\\n\uD83D\uDCA1 Run \"stackmemory linear setup\" to get started');\n }\n } catch (error: unknown) {\n logger.error('Linear status check failed', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('sync')\n .description('Sync tasks with Linear')\n .option(\n '-d, --direction <direction>',\n 'Sync direction: bidirectional, to_linear, from_linear',\n 'bidirectional'\n )\n .action(async (options) => {\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 authManager = new LinearAuthManager(projectRoot);\n\n // Check for API key from environment first\n if (!process.env['LINEAR_API_KEY'] && !authManager.isConfigured()) {\n console.log(\n '\u274C Linear not configured. Set LINEAR_API_KEY environment variable or run \"stackmemory linear setup\" first.'\n );\n return;\n }\n\n const db = new Database(dbPath);\n const taskStore = new LinearTaskManager(projectRoot, db);\n\n const syncConfig = {\n ...DEFAULT_SYNC_CONFIG,\n enabled: true,\n direction: options.direction,\n };\n\n const linearSync = new LinearSyncEngine(\n taskStore,\n authManager,\n syncConfig\n );\n\n console.log(`\uD83D\uDD04 Starting ${options.direction} sync with Linear...`);\n\n const result = await linearSync.sync();\n\n // Track progress\n const progress = new ProgressTracker(projectRoot);\n\n if (result.success) {\n console.log('\u2705 Sync completed successfully!');\n console.log(` To Linear: ${result.synced.toLinear} created`);\n console.log(` From Linear: ${result.synced.fromLinear} created`);\n console.log(` Updated: ${result.synced.updated}`);\n\n // Update progress tracker\n progress.updateLinearStatus({\n lastSync: new Date().toISOString(),\n tasksSynced:\n result.synced.toLinear +\n result.synced.fromLinear +\n result.synced.updated,\n });\n\n if (result.conflicts.length > 0) {\n console.log(`\\n\u26A0\uFE0F Conflicts detected: ${result.conflicts.length}`);\n result.conflicts.forEach((conflict) => {\n console.log(` - ${conflict.taskId}: ${conflict.reason}`);\n });\n }\n } else {\n console.log('\u274C Sync failed');\n if (result.errors.length > 0) {\n result.errors.forEach((error) => {\n console.log(` Error: ${error}`);\n });\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Linear sync failed', error as Error);\n console.error('\u274C Sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Auto-sync commands\nlinearCommand\n .command('auto-sync')\n .description('Manage automatic synchronization')\n .option('--start', 'Start auto-sync service')\n .option('--stop', 'Stop auto-sync service')\n .option('--status', 'Show auto-sync status')\n .option('--interval <minutes>', 'Set sync interval in minutes', '5')\n .option(\n '--direction <direction>',\n 'Set sync direction: bidirectional, to_linear, from_linear',\n 'bidirectional'\n )\n .option('--quiet-start <hour>', 'Start of quiet hours (0-23)', '22')\n .option('--quiet-end <hour>', 'End of quiet hours (0-23)', '7')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n\n if (options.status) {\n const service = getAutoSyncService();\n if (service) {\n const status = service.getStatus();\n console.log('\uD83D\uDCCA Linear Auto-Sync Status:');\n console.log(` Running: ${status.running ? '\u2705' : '\u274C'}`);\n console.log(` Direction: ${status.config.direction}`);\n console.log(` Interval: ${status.config.interval} minutes`);\n console.log(\n ` Conflict Resolution: ${status.config.conflictResolution}`\n );\n\n if (status.lastSyncTime > 0) {\n const lastSync = new Date(status.lastSyncTime);\n console.log(` Last Sync: ${lastSync.toLocaleString()}`);\n }\n\n if (status.nextSyncTime) {\n const nextSync = new Date(status.nextSyncTime);\n console.log(` Next Sync: ${nextSync.toLocaleString()}`);\n }\n\n if (status.config.quietHours) {\n console.log(\n ` Quiet Hours: ${status.config.quietHours.start}:00 - ${status.config.quietHours.end}:00`\n );\n }\n\n if (status.retryCount > 0) {\n console.log(` \u26A0\uFE0F Retry Count: ${status.retryCount}`);\n }\n } else {\n console.log('\uD83D\uDCCA Linear Auto-Sync Status: \u274C Not running');\n }\n return;\n }\n\n if (options.start) {\n const authManager = new LinearAuthManager(projectRoot);\n if (!authManager.isConfigured()) {\n console.log(\n '\u274C Linear not configured. Run \"stackmemory linear setup\" first.'\n );\n return;\n }\n\n const config = {\n interval: parseInt(options.interval),\n direction: options.direction,\n quietHours: {\n start: parseInt(options.quietStart),\n end: parseInt(options.quietEnd),\n },\n };\n\n const service = initializeAutoSync(projectRoot, config);\n await service.start();\n\n console.log('\u2705 Linear auto-sync started');\n console.log(` Interval: ${config.interval} minutes`);\n console.log(` Direction: ${config.direction}`);\n console.log(\n ` Quiet Hours: ${config.quietHours.start}:00 - ${config.quietHours.end}:00`\n );\n console.log(\n '\\n\uD83D\uDCA1 Use \"stackmemory linear auto-sync --status\" to check status'\n );\n\n // Keep process alive for auto-sync\n process.on('SIGINT', () => {\n console.log('\\n\uD83D\uDED1 Stopping auto-sync service...');\n service.stop();\n process.exit(0);\n });\n\n console.log('\uD83D\uDD04 Auto-sync running... Press Ctrl+C to stop');\n // Keep the process running\n await new Promise(() => {}); // Intentionally never resolves\n }\n\n if (options.stop) {\n stopAutoSync();\n console.log('\uD83D\uDED1 Linear auto-sync stopped');\n }\n\n if (!options.start && !options.stop && !options.status) {\n console.log('\uD83D\uDCA1 Usage:');\n console.log(' --start Start auto-sync service');\n console.log(' --stop Stop auto-sync service');\n console.log(' --status Show current status');\n console.log(\n '\\nExample: stackmemory linear auto-sync --start --interval 10'\n );\n }\n } catch (error: unknown) {\n logger.error('Linear auto-sync command failed', error as Error);\n console.error('\u274C Auto-sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('force-sync')\n .description('Force immediate synchronization')\n .action(async () => {\n try {\n const service = getAutoSyncService();\n if (service) {\n console.log('\uD83D\uDD04 Forcing immediate sync...');\n await service.forceSync();\n console.log('\u2705 Sync completed');\n } else {\n console.log(\n '\u274C Auto-sync service not running. Use manual sync instead:'\n );\n console.log(' stackmemory linear sync');\n }\n } catch (error: unknown) {\n logger.error('Force sync failed', error as Error);\n console.error('\u274C Force sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('update <issueId>')\n .description('Update Linear task status')\n .option(\n '-s, --status <status>',\n 'New status (todo, in-progress, done, canceled)'\n )\n .option('-t, --title <title>', 'Update task title')\n .option('-d, --description <desc>', 'Update task description')\n .option(\n '-p, --priority <priority>',\n 'Set priority (1=urgent, 2=high, 3=medium, 4=low)'\n )\n .action(async (issueId, options) => {\n try {\n const projectRoot = process.cwd();\n const authManager = new LinearAuthManager(projectRoot);\n const tokens = authManager.loadTokens();\n\n if (!tokens) {\n console.error('\u274C Not authenticated. Run: stackmemory linear setup');\n process.exit(1);\n }\n\n const { LinearClient } = await import('../integrations/linear/client.js');\n const client = new LinearClient({\n apiKey: tokens.accessToken,\n useBearer: true,\n onUnauthorized: async () => {\n const refreshed = await authManager.refreshAccessToken();\n return refreshed.accessToken;\n },\n });\n\n // Find the issue first\n let issue = await client.getIssue(issueId);\n if (!issue) {\n // Try finding by identifier\n issue = await client.findIssueByIdentifier(issueId);\n }\n\n if (!issue) {\n console.error(`\u274C Issue ${issueId} not found`);\n process.exit(1);\n }\n\n const updates: Record<string, unknown> = {};\n\n // Handle status update\n if (options.status) {\n const team = await client.getTeam();\n const states = await client.getWorkflowStates(team.id);\n\n const statusMap: Record<string, string> = {\n todo: 'unstarted',\n 'in-progress': 'started',\n done: 'completed',\n canceled: 'cancelled',\n };\n\n const targetType =\n statusMap[options.status.toLowerCase()] || options.status;\n const targetState = states.find(\n (s: { type: string }) => s.type === targetType\n );\n\n if (!targetState) {\n console.error(`\u274C Invalid status: ${options.status}`);\n console.log('Available states:');\n states.forEach((s: { name: string; type: string }) =>\n console.log(` - ${s.name} (${s.type})`)\n );\n process.exit(1);\n }\n\n updates.stateId = targetState.id;\n }\n\n if (options.title) updates.title = options.title;\n if (options.description) updates.description = options.description;\n if (options.priority) updates.priority = parseInt(options.priority);\n\n // Perform update\n const updatedIssue = await client.updateIssue(issue.id, updates);\n\n console.log(\n `\u2705 Updated ${updatedIssue.identifier}: ${updatedIssue.title}`\n );\n if (options.status) {\n console.log(` Status: ${updatedIssue.state.name}`);\n }\n console.log(` ${updatedIssue.url}`);\n\n // Auto-sync to local tasks after update\n console.log('\\n\uD83D\uDD04 Syncing to local tasks...');\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n if (existsSync(dbPath)) {\n const db = new Database(dbPath);\n const taskStore = new LinearTaskManager(projectRoot, db);\n const { LinearSyncEngine, DEFAULT_SYNC_CONFIG } =\n await import('../integrations/linear/sync.js');\n const syncEngine = new LinearSyncEngine(\n taskStore,\n authManager,\n { ...DEFAULT_SYNC_CONFIG, enabled: true, direction: 'from_linear' },\n projectRoot\n );\n const syncResult = await syncEngine.sync();\n if (syncResult.success) {\n console.log(\n ` \u2705 Local tasks synced (${syncResult.synced.fromLinear} new, ${syncResult.synced.updated} updated)`\n );\n }\n db.close();\n }\n } catch (error: unknown) {\n logger.error('Failed to update Linear task', error as Error);\n console.error('\u274C Failed to update task:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('config')\n .description('Configure auto-sync settings')\n .option('--show', 'Show current configuration')\n .option('--set-interval <minutes>', 'Set sync interval in minutes')\n .option(\n '--set-direction <direction>',\n 'Set sync direction: bidirectional, to_linear, from_linear'\n )\n .option(\n '--set-conflict-resolution <strategy>',\n 'Set conflict resolution: newest_wins, linear_wins, stackmemory_wins, manual'\n )\n .option('--set-quiet-start <hour>', 'Set start of quiet hours (0-23)')\n .option('--set-quiet-end <hour>', 'Set end of quiet hours (0-23)')\n .option('--enable', 'Enable auto-sync')\n .option('--disable', 'Disable auto-sync')\n .option('--reset', 'Reset to default configuration')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const configManager = new LinearConfigManager(projectRoot);\n\n if (options.reset) {\n configManager.resetConfig();\n console.log('\u2705 Configuration reset to defaults');\n return;\n }\n\n if (options.show) {\n const config = configManager.loadConfig();\n if (config) {\n console.log('\uD83D\uDCCA Linear Auto-Sync Configuration:');\n console.log(` Enabled: ${config.enabled ? '\u2705' : '\u274C'}`);\n console.log(` Interval: ${config.interval} minutes`);\n console.log(` Direction: ${config.direction}`);\n console.log(` Conflict Resolution: ${config.conflictResolution}`);\n console.log(` Retry Attempts: ${config.retryAttempts}`);\n console.log(` Retry Delay: ${config.retryDelay / 1000}s`);\n\n if (config.quietHours) {\n console.log(\n ` Quiet Hours: ${config.quietHours.start}:00 - ${config.quietHours.end}:00`\n );\n }\n\n const lastUpdated = new Date(config.lastUpdated);\n console.log(` Last Updated: ${lastUpdated.toLocaleString()}`);\n } else {\n console.log('\uD83D\uDCCA No configuration found. Using defaults.');\n const defaultConfig = configManager.getDefaultConfig();\n console.log(` Default interval: ${defaultConfig.interval} minutes`);\n console.log(` Default direction: ${defaultConfig.direction}`);\n }\n return;\n }\n\n // Update configuration\n const updates: Record<string, unknown> = {};\n\n if (options.setInterval) {\n const interval = parseInt(options.setInterval);\n if (isNaN(interval) || interval < 1) {\n console.error('\u274C Interval must be a positive number');\n process.exit(1);\n }\n updates.interval = interval;\n console.log(`\u2705 Set interval to ${interval} minutes`);\n }\n\n if (options.setDirection) {\n const validDirections = ['bidirectional', 'to_linear', 'from_linear'];\n if (!validDirections.includes(options.setDirection)) {\n console.error(\n `\u274C Invalid direction. Must be one of: ${validDirections.join(', ')}`\n );\n process.exit(1);\n }\n updates.direction = options.setDirection;\n console.log(`\u2705 Set direction to ${options.setDirection}`);\n }\n\n if (options.setConflictResolution) {\n const validStrategies = [\n 'newest_wins',\n 'linear_wins',\n 'stackmemory_wins',\n 'manual',\n ];\n if (!validStrategies.includes(options.setConflictResolution)) {\n console.error(\n `\u274C Invalid strategy. Must be one of: ${validStrategies.join(', ')}`\n );\n process.exit(1);\n }\n updates.conflictResolution = options.setConflictResolution;\n console.log(\n `\u2705 Set conflict resolution to ${options.setConflictResolution}`\n );\n }\n\n if (options.setQuietStart) {\n const hour = parseInt(options.setQuietStart);\n if (isNaN(hour) || hour < 0 || hour > 23) {\n console.error('\u274C Quiet start hour must be between 0 and 23');\n process.exit(1);\n }\n const currentConfig =\n configManager.loadConfig() || configManager.getDefaultConfig();\n updates.quietHours = {\n start: hour,\n end: currentConfig.quietHours?.end || 7,\n };\n console.log(`\u2705 Set quiet hours start to ${hour}:00`);\n }\n\n if (options.setQuietEnd) {\n const hour = parseInt(options.setQuietEnd);\n if (isNaN(hour) || hour < 0 || hour > 23) {\n console.error('\u274C Quiet end hour must be between 0 and 23');\n process.exit(1);\n }\n const currentConfig =\n configManager.loadConfig() || configManager.getDefaultConfig();\n updates.quietHours = {\n start: currentConfig.quietHours?.start || 22,\n end: hour,\n };\n console.log(`\u2705 Set quiet hours end to ${hour}:00`);\n }\n\n if (options.enable) {\n updates.enabled = true;\n console.log('\u2705 Auto-sync enabled');\n }\n\n if (options.disable) {\n updates.enabled = false;\n console.log('\u274C Auto-sync disabled');\n }\n\n if (Object.keys(updates).length > 0) {\n configManager.saveConfig(updates);\n console.log(\n '\\n\uD83D\uDCA1 Configuration updated. Restart auto-sync service to apply changes.'\n );\n } else if (!options.show) {\n console.log('\uD83D\uDCA1 Use --show to view current configuration');\n console.log('\uD83D\uDCA1 Use --help to see all configuration options');\n }\n } catch (error: unknown) {\n logger.error('Linear config command failed', error as Error);\n console.error('\u274C Config failed:', (error as Error).message);\n process.exit(1);\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('analytics')\n .description('Launch task analytics dashboard')\n .option('-p, --port <port>', 'Port for dashboard server', '3000')\n .option('-o, --open', 'Open dashboard in browser')\n .option('--export <format>', 'Export metrics (json|csv)')\n .option('--sync', 'Sync with Linear before launching')\n .option('--view', 'Show analytics in terminal')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n if (options.view) {\n const { displayAnalyticsDashboard } = await import('./utils/viewer.js');\n await displayAnalyticsDashboard(projectRoot);\n return;\n }\n\n if (options.export) {\n const { AnalyticsService } =\n await import('../features/analytics/index.js');\n const service = new AnalyticsService(projectRoot);\n\n if (options.sync) {\n console.log('\uD83D\uDD04 Syncing with Linear...');\n await service.syncLinearTasks();\n }\n\n const state = await service.getDashboardState();\n\n if (options.export === 'csv') {\n console.log('\uD83D\uDCCA Exporting metrics as CSV...');\n // Convert to CSV format\n const tasks = state.recentTasks;\n const headers = [\n 'ID',\n 'Title',\n 'State',\n 'Priority',\n 'Created',\n 'Completed',\n ];\n const rows = tasks.map((t) => [\n t.id,\n t.title,\n t.state,\n t.priority,\n t.createdAt.toISOString(),\n t.completedAt?.toISOString() || '',\n ]);\n console.log(headers.join(','));\n rows.forEach((r) => console.log(r.join(',')));\n } else {\n console.log(JSON.stringify(state, null, 2));\n }\n\n service.close();\n return;\n }\n\n // Launch dashboard server\n console.log(\n `\uD83D\uDE80 Launching analytics dashboard on port ${options.port}...`\n );\n\n const express = (await import('express')).default;\n const { AnalyticsAPI } = await import('../features/analytics/index.js');\n const { createServer } = await import('http');\n\n const app = express();\n\n // Add error handling middleware\n app.use(\n (\n err: Error,\n _req: import('express').Request,\n res: import('express').Response,\n _next: import('express').NextFunction\n ) => {\n console.error('Express error:', err);\n res.status(500).json({ error: err.message });\n }\n );\n\n const analyticsAPI = new AnalyticsAPI(projectRoot);\n\n if (options.sync) {\n console.log('\uD83D\uDD04 Syncing with Linear...');\n const service = new (\n await import('../features/analytics/index.js')\n ).AnalyticsService(projectRoot);\n await service.syncLinearTasks();\n service.close();\n }\n\n app.use('/api/analytics', analyticsAPI.getRouter());\n\n // Serve the HTML dashboard\n app.get('/', async (req, res) => {\n // Try multiple paths for the dashboard HTML\n const possiblePaths = [\n join(projectRoot, 'src/features/analytics/dashboard.html'),\n join(projectRoot, 'dist/features/analytics/dashboard.html'),\n ];\n\n for (const dashboardPath of possiblePaths) {\n if (existsSync(dashboardPath)) {\n res.sendFile(dashboardPath);\n return;\n }\n }\n\n // Inline fallback dashboard\n res.send(`<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>StackMemory Analytics</title>\n <script src=\"https://cdn.jsdelivr.net/npm/chart.js\"></script>\n <style>\n * { margin: 0; padding: 0; box-sizing: border-box; }\n body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: #1a1a2e; color: #eee; padding: 20px; }\n .container { max-width: 1200px; margin: 0 auto; }\n h1 { color: #667eea; margin-bottom: 20px; }\n .grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; margin-bottom: 30px; }\n .card { background: #16213e; border-radius: 12px; padding: 20px; }\n .metric-value { font-size: 2.5em; font-weight: bold; color: #667eea; }\n .metric-label { color: #888; text-transform: uppercase; font-size: 0.8em; }\n .task-list { max-height: 400px; overflow-y: auto; }\n .task-item { padding: 10px; border-left: 3px solid #667eea; margin-bottom: 8px; background: #1a1a2e; }\n .task-item.completed { border-color: #22c55e; }\n .task-item.in_progress { border-color: #f59e0b; }\n .status { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 0.8em; margin-right: 8px; }\n .status.completed { background: #22c55e30; color: #22c55e; }\n .status.in_progress { background: #f59e0b30; color: #f59e0b; }\n .status.todo { background: #667eea30; color: #667eea; }\n </style>\n</head>\n<body>\n <div class=\"container\">\n <h1>\uD83D\uDCCA StackMemory Analytics</h1>\n <div class=\"grid\" id=\"metrics\"></div>\n <div class=\"card\"><h3>Recent Tasks</h3><div class=\"task-list\" id=\"tasks\">Loading...</div></div>\n </div>\n <script>\n async function load() {\n const metrics = await fetch('/api/analytics/metrics').then(r => r.json());\n const tasks = await fetch('/api/analytics/tasks').then(r => r.json());\n \n document.getElementById('metrics').innerHTML = \\`\n <div class=\"card\"><div class=\"metric-label\">Total</div><div class=\"metric-value\">\\${metrics.data.metrics.totalTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">Completed</div><div class=\"metric-value\">\\${metrics.data.metrics.completedTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">In Progress</div><div class=\"metric-value\">\\${metrics.data.metrics.inProgressTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">Completion</div><div class=\"metric-value\">\\${metrics.data.metrics.completionRate.toFixed(0)}%</div></div>\n \\`;\n \n document.getElementById('tasks').innerHTML = tasks.data.tasks.slice(0, 10).map((t: any) => \\`\n <div class=\"task-item \\${t.state}\">\n <span class=\"status \\${t.state}\">\\${t.state}</span>\n <strong>\\${t.title}</strong>\n </div>\n \\`).join('');\n }\n load();\n setInterval(load, 30000);\n </script>\n</body>\n</html>`);\n });\n\n const server = createServer(app);\n analyticsAPI.setupWebSocket(server);\n\n server.listen(options.port, async () => {\n console.log(\n `\u2705 Analytics dashboard running at http://localhost:${options.port}`\n );\n\n if (options.open) {\n const { exec } = await import('child_process');\n const url = `http://localhost:${options.port}`;\n const command =\n process.platform === 'darwin'\n ? `open ${url}`\n : process.platform === 'win32'\n ? `start ${url}`\n : `xdg-open ${url}`;\n exec(command);\n }\n });\n\n process.on('SIGINT', () => {\n console.log('\\n\uD83D\uDC4B Shutting down analytics dashboard...');\n analyticsAPI.close();\n server.close();\n process.exit(0);\n });\n\n // Keep the process alive\n await new Promise(() => {});\n } catch (error: unknown) {\n logger.error('Analytics command failed', error as Error);\n console.error('\u274C Analytics 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);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands\nregisterLinearCommands(program);\nregisterLinearTestCommand(program);\nregisterLinearListCommand(program);\nregisterLinearMigrateCommand(program);\nregisterLinearCreateCommand(program);\n\n// Add ChromaDB command\nprogram.addCommand(createChromaDBCommand());\n\n// Add Infinite Storage command\nprogram.addCommand(createInfiniteStorageCommand());\nprogram.addCommand(createGCCommand());\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register webhook command\nprogram.addCommand(webhookCommand());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createAgentCommand());\nprogram.addCommand(createHandoffCommand());\nprogram.addCommand(createStorageCommand());\nprogram.addCommand(createSkillsCommand());\nprogram.addCommand(createTestCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(createWorkflowCommand());\nprogram.addCommand(monitorCommand);\nprogram.addCommand(qualityCommand);\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// Register TUI command (advanced terminal UI - requires blessed)\nprogram\n .command('tui')\n .description('Launch interactive TUI monitoring dashboard (requires blessed)')\n .option('-s, --server', 'Start WebSocket server for real-time updates')\n .option('-w, --ws-url <url>', 'WebSocket server URL', 'ws://localhost:8080')\n .option('-r, --refresh <ms>', 'Auto-refresh interval in milliseconds', '2000')\n .action(async (options) => {\n try {\n // Check if blessed is installed by trying to import it\n try {\n await import('blessed');\n } catch {\n console.log(\n '\u274C The TUI requires the blessed package. Install it with:'\n );\n console.log(' npm install blessed blessed-contrib');\n console.log(\n '\\n\uD83D\uDCA1 Alternatively, use \"stackmemory dashboard\" for a simpler view'\n );\n process.exit(1);\n }\n\n const { spawn } = await import('child_process');\n const { fileURLToPath } = await import('url');\n const { dirname, join } = await import('path');\n\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n\n console.log('\uD83D\uDE80 Launching StackMemory TUI Dashboard...');\n\n // Set environment variables\n process.env['STACKMEMORY_WS_URL'] = options.wsUrl;\n\n // Get TUI module path\n const tuiPath = join(__dirname, '../features/tui/index.js');\n\n // Launch TUI directly\n const tui = spawn('node', [tuiPath], {\n stdio: 'inherit',\n env: {\n ...process.env,\n STACKMEMORY_WS_URL: options.wsUrl,\n },\n });\n\n tui.on('error', (error) => {\n console.error('Failed to launch TUI:', error);\n console.log('\\n\uD83D\uDCA1 Try \"stackmemory dashboard\" instead');\n process.exit(1);\n });\n\n tui.on('exit', (code) => {\n if (code !== 0) {\n console.error(`TUI exited with code ${code}`);\n process.exit(code || 1);\n }\n });\n } catch (error: unknown) {\n console.error('\u274C Failed to launch TUI:', (error as Error).message);\n console.log('\\n\uD83D\uDCA1 Try \"stackmemory dashboard\" for a simpler view');\n process.exit(1);\n }\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n}\n\n// Only parse when running as main module (not when imported for testing)\nconst isMainModule =\n import.meta.url === `file://${process.argv[1]}` ||\n process.argv[1]?.endsWith('/stackmemory') ||\n process.argv[1]?.endsWith('index.ts') ||\n process.argv[1]?.includes('tsx');\n\nif (isMainModule) {\n program.parse();\n}\n\nexport { program };\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["LinearSyncEngine", "DEFAULT_SYNC_CONFIG", "join"]
|
|
7
7
|
}
|
package/dist/cli/utils/viewer.js
CHANGED
|
@@ -8,9 +8,9 @@ async function displayAnalyticsDashboard(projectPath) {
|
|
|
8
8
|
const state = await service.getDashboardState();
|
|
9
9
|
const { metrics, recentTasks, teamMetrics } = state;
|
|
10
10
|
console.clear();
|
|
11
|
-
console.log(chalk.bold.cyan("\
|
|
11
|
+
console.log(chalk.bold.cyan("\nStackMemory Analytics Dashboard\n"));
|
|
12
12
|
console.log(chalk.gray("\u2500".repeat(50)));
|
|
13
|
-
console.log(chalk.bold.white("\
|
|
13
|
+
console.log(chalk.bold.white("\nKey Metrics\n"));
|
|
14
14
|
const metricsDisplay = [
|
|
15
15
|
["Total Tasks", metrics.totalTasks],
|
|
16
16
|
["Completed", chalk.green(metrics.completedTasks)],
|
|
@@ -38,13 +38,13 @@ async function displayAnalyticsDashboard(projectPath) {
|
|
|
38
38
|
});
|
|
39
39
|
}
|
|
40
40
|
if (recentTasks.length > 0) {
|
|
41
|
-
console.log(chalk.bold.white("\
|
|
41
|
+
console.log(chalk.bold.white("\nRecent Tasks\n"));
|
|
42
42
|
recentTasks.slice(0, 5).forEach((task) => {
|
|
43
|
-
const
|
|
44
|
-
completed: "
|
|
45
|
-
in_progress: "
|
|
46
|
-
blocked: "
|
|
47
|
-
todo: "
|
|
43
|
+
const statePrefix = {
|
|
44
|
+
completed: "[DONE]",
|
|
45
|
+
in_progress: "[PROG]",
|
|
46
|
+
blocked: "[BLCK]",
|
|
47
|
+
todo: "[TODO]"
|
|
48
48
|
}[task.state];
|
|
49
49
|
const priorityColor = {
|
|
50
50
|
urgent: chalk.red,
|
|
@@ -53,7 +53,7 @@ async function displayAnalyticsDashboard(projectPath) {
|
|
|
53
53
|
low: chalk.gray
|
|
54
54
|
}[task.priority];
|
|
55
55
|
console.log(
|
|
56
|
-
` ${
|
|
56
|
+
` ${statePrefix} ${priorityColor(`[${task.priority.toUpperCase()}]`)} ${task.title.slice(0, 50)}`
|
|
57
57
|
);
|
|
58
58
|
});
|
|
59
59
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/cli/utils/viewer.ts"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env node\nimport chalk from 'chalk';\nimport { AnalyticsService } from '../../features/analytics/core/analytics-service.js';\n\nexport async function displayAnalyticsDashboard(\n projectPath?: string\n): Promise<void> {\n const service = new AnalyticsService(projectPath || process.cwd());\n\n try {\n // Sync from task store before displaying\n await service.syncFromTaskStore();\n const state = await service.getDashboardState();\n const { metrics, recentTasks, teamMetrics } = state;\n\n console.clear();\n console.log(chalk.bold.cyan('\\
|
|
5
|
-
"mappings": ";AACA,OAAO,WAAW;AAClB,SAAS,wBAAwB;AAEjC,eAAsB,0BACpB,aACe;AACf,QAAM,UAAU,IAAI,iBAAiB,eAAe,QAAQ,IAAI,CAAC;AAEjE,MAAI;AAEF,UAAM,QAAQ,kBAAkB;AAChC,UAAM,QAAQ,MAAM,QAAQ,kBAAkB;AAC9C,UAAM,EAAE,SAAS,aAAa,YAAY,IAAI;AAE9C,YAAQ,MAAM;AACd,YAAQ,IAAI,MAAM,KAAK,KAAK
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\nimport chalk from 'chalk';\nimport { AnalyticsService } from '../../features/analytics/core/analytics-service.js';\n\nexport async function displayAnalyticsDashboard(\n projectPath?: string\n): Promise<void> {\n const service = new AnalyticsService(projectPath || process.cwd());\n\n try {\n // Sync from task store before displaying\n await service.syncFromTaskStore();\n const state = await service.getDashboardState();\n const { metrics, recentTasks, teamMetrics } = state;\n\n console.clear();\n console.log(chalk.bold.cyan('\\nStackMemory Analytics Dashboard\\n'));\n console.log(chalk.gray('\u2500'.repeat(50)));\n\n // Key Metrics\n console.log(chalk.bold.white('\\nKey Metrics\\n'));\n\n const metricsDisplay = [\n ['Total Tasks', metrics.totalTasks],\n ['Completed', chalk.green(metrics.completedTasks)],\n ['In Progress', chalk.yellow(metrics.inProgressTasks)],\n ['Blocked', chalk.red(metrics.blockedTasks)],\n ['Completion Rate', `${metrics.completionRate.toFixed(1)}%`],\n ['Avg Time to Complete', formatDuration(metrics.averageTimeToComplete)],\n ['Effort Accuracy', `${metrics.effortAccuracy.toFixed(0)}%`],\n ['Blocking Issues', metrics.blockingIssuesCount],\n ];\n\n metricsDisplay.forEach(([label, value]) => {\n console.log(` ${chalk.gray(String(label).padEnd(20))} ${value}`);\n });\n\n // Velocity Trend (mini chart)\n if (metrics.velocityTrend.length > 0) {\n console.log(chalk.bold.white('\\n\uD83D\uDCC9 Velocity Trend (last 7 days)\\n'));\n const maxVelocity = Math.max(...metrics.velocityTrend);\n const scale = maxVelocity > 0 ? 10 / maxVelocity : 1;\n\n metrics.velocityTrend.slice(-7).forEach((velocity, i) => {\n const bar = '\u2588'.repeat(Math.round(velocity * scale));\n const day = new Date();\n day.setDate(day.getDate() - (6 - i));\n console.log(\n ` ${day.toLocaleDateString('en', { weekday: 'short' }).padEnd(4)} ${bar} ${velocity}`\n );\n });\n }\n\n // Recent Tasks\n if (recentTasks.length > 0) {\n console.log(chalk.bold.white('\\nRecent Tasks\\n'));\n recentTasks.slice(0, 5).forEach((task) => {\n const statePrefix = {\n completed: '[DONE]',\n in_progress: '[PROG]',\n blocked: '[BLCK]',\n todo: '[TODO]',\n }[task.state];\n\n const priorityColor = {\n urgent: chalk.red,\n high: chalk.yellow,\n medium: chalk.blue,\n low: chalk.gray,\n }[task.priority];\n\n console.log(\n ` ${statePrefix} ${priorityColor(`[${task.priority.toUpperCase()}]`)} ${task.title.slice(0, 50)}`\n );\n });\n }\n\n // Team Performance\n if (teamMetrics.length > 0) {\n console.log(chalk.bold.white('\\n\uD83D\uDC65 Team Performance\\n'));\n teamMetrics.slice(0, 3).forEach((member) => {\n const bar = '\u2593'.repeat(Math.round(member.contributionPercentage / 10));\n console.log(\n ` ${member.userName.padEnd(15)} ${bar} ${member.contributionPercentage.toFixed(0)}% (${member.individualMetrics.completedTasks} tasks)`\n );\n });\n }\n\n console.log(chalk.gray('\\n' + '\u2500'.repeat(50)));\n console.log(\n chalk.gray(`Last updated: ${state.lastUpdated.toLocaleString()}`)\n );\n console.log();\n } finally {\n service.close();\n }\n}\n\nfunction formatDuration(ms: number): string {\n if (ms === 0) return 'N/A';\n const hours = Math.floor(ms / 3600000);\n const days = Math.floor(hours / 24);\n if (days > 0) return `${days}d ${hours % 24}h`;\n if (hours > 0) return `${hours}h`;\n return '<1h';\n}\n\n// Allow direct execution\nif (import.meta.url === `file://${process.argv[1]}`) {\n displayAnalyticsDashboard().catch(console.error);\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -6,6 +6,7 @@ import {
|
|
|
6
6
|
PRESET_PROFILES
|
|
7
7
|
} from "./types.js";
|
|
8
8
|
class ConfigManager {
|
|
9
|
+
static instance = null;
|
|
9
10
|
config;
|
|
10
11
|
configPath;
|
|
11
12
|
fileWatcher;
|
|
@@ -14,6 +15,15 @@ class ConfigManager {
|
|
|
14
15
|
this.configPath = configPath || path.join(process.cwd(), ".stackmemory", "config.yaml");
|
|
15
16
|
this.config = this.loadConfig();
|
|
16
17
|
}
|
|
18
|
+
/**
|
|
19
|
+
* Get singleton instance of ConfigManager
|
|
20
|
+
*/
|
|
21
|
+
static getInstance(configPath) {
|
|
22
|
+
if (!ConfigManager.instance) {
|
|
23
|
+
ConfigManager.instance = new ConfigManager(configPath);
|
|
24
|
+
}
|
|
25
|
+
return ConfigManager.instance;
|
|
26
|
+
}
|
|
17
27
|
/**
|
|
18
28
|
* Load configuration from file or use defaults
|
|
19
29
|
*/
|
|
@@ -248,6 +258,22 @@ class ConfigManager {
|
|
|
248
258
|
getConfig() {
|
|
249
259
|
return { ...this.config };
|
|
250
260
|
}
|
|
261
|
+
/**
|
|
262
|
+
* Get a specific configuration value by path
|
|
263
|
+
* Example: config.get('project.id') returns config.project.id
|
|
264
|
+
*/
|
|
265
|
+
get(path2) {
|
|
266
|
+
const keys = path2.split(".");
|
|
267
|
+
let value = this.config;
|
|
268
|
+
for (const key of keys) {
|
|
269
|
+
if (value && typeof value === "object" && key in value) {
|
|
270
|
+
value = value[key];
|
|
271
|
+
} else {
|
|
272
|
+
return void 0;
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
return value;
|
|
276
|
+
}
|
|
251
277
|
/**
|
|
252
278
|
* Set active profile
|
|
253
279
|
*/
|