@stackmemoryai/stackmemory 0.3.7 → 0.3.9

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.
Files changed (202) hide show
  1. package/dist/agents/core/agent-task-manager.js +5 -5
  2. package/dist/agents/core/agent-task-manager.js.map +2 -2
  3. package/dist/agents/verifiers/base-verifier.js +2 -2
  4. package/dist/agents/verifiers/base-verifier.js.map +2 -2
  5. package/dist/cli/claude-sm.js +0 -11
  6. package/dist/cli/claude-sm.js.map +2 -2
  7. package/dist/cli/codex-sm.js +0 -11
  8. package/dist/cli/codex-sm.js.map +2 -2
  9. package/dist/cli/commands/chromadb.js +64 -34
  10. package/dist/cli/commands/chromadb.js.map +2 -2
  11. package/dist/cli/commands/clear.js +9 -13
  12. package/dist/cli/commands/clear.js.map +2 -2
  13. package/dist/cli/commands/config.js +43 -33
  14. package/dist/cli/commands/config.js.map +2 -2
  15. package/dist/cli/commands/context.js.map +2 -2
  16. package/dist/cli/commands/dashboard.js +41 -13
  17. package/dist/cli/commands/dashboard.js.map +2 -2
  18. package/dist/cli/commands/gc.js +69 -20
  19. package/dist/cli/commands/gc.js.map +2 -2
  20. package/dist/cli/commands/handoff.js.map +2 -2
  21. package/dist/cli/commands/infinite-storage.js +60 -19
  22. package/dist/cli/commands/infinite-storage.js.map +2 -2
  23. package/dist/cli/commands/linear-create.js +36 -8
  24. package/dist/cli/commands/linear-create.js.map +2 -2
  25. package/dist/cli/commands/linear-list.js +33 -10
  26. package/dist/cli/commands/linear-list.js.map +2 -2
  27. package/dist/cli/commands/linear-migrate.js +17 -4
  28. package/dist/cli/commands/linear-migrate.js.map +2 -2
  29. package/dist/cli/commands/linear-test.js +14 -6
  30. package/dist/cli/commands/linear-test.js.map +2 -2
  31. package/dist/cli/commands/linear-unified.js +123 -35
  32. package/dist/cli/commands/linear-unified.js.map +2 -2
  33. package/dist/cli/commands/linear.js.map +2 -2
  34. package/dist/cli/commands/monitor.js.map +2 -2
  35. package/dist/cli/commands/onboard.js +35 -8
  36. package/dist/cli/commands/onboard.js.map +2 -2
  37. package/dist/cli/commands/quality.js +2 -7
  38. package/dist/cli/commands/quality.js.map +2 -2
  39. package/dist/cli/commands/session.js +23 -6
  40. package/dist/cli/commands/session.js.map +2 -2
  41. package/dist/cli/commands/skills.js +72 -27
  42. package/dist/cli/commands/skills.js.map +2 -2
  43. package/dist/cli/commands/storage.js +108 -38
  44. package/dist/cli/commands/storage.js.map +2 -2
  45. package/dist/cli/commands/tui.js.map +2 -2
  46. package/dist/cli/commands/webhook.js +57 -18
  47. package/dist/cli/commands/webhook.js.map +2 -2
  48. package/dist/cli/commands/workflow.js +8 -15
  49. package/dist/cli/commands/workflow.js.map +2 -2
  50. package/dist/cli/commands/worktree.js +34 -13
  51. package/dist/cli/commands/worktree.js.map +2 -2
  52. package/dist/cli/index.js +0 -11
  53. package/dist/cli/index.js.map +2 -2
  54. package/dist/core/config/types.js.map +1 -1
  55. package/dist/core/context/auto-context.js +10 -6
  56. package/dist/core/context/auto-context.js.map +2 -2
  57. package/dist/core/context/context-bridge.js.map +2 -2
  58. package/dist/core/context/frame-database.js +13 -3
  59. package/dist/core/context/frame-database.js.map +2 -2
  60. package/dist/core/context/frame-digest.js +7 -5
  61. package/dist/core/context/frame-digest.js.map +2 -2
  62. package/dist/core/context/frame-manager.js.map +2 -2
  63. package/dist/core/context/frame-stack.js +16 -5
  64. package/dist/core/context/frame-stack.js.map +2 -2
  65. package/dist/core/context/incremental-gc.js +10 -3
  66. package/dist/core/context/incremental-gc.js.map +2 -2
  67. package/dist/core/context/index.js.map +1 -1
  68. package/dist/core/context/permission-manager.js.map +2 -2
  69. package/dist/core/context/recursive-context-manager.js +582 -0
  70. package/dist/core/context/recursive-context-manager.js.map +7 -0
  71. package/dist/core/context/refactored-frame-manager.js +12 -3
  72. package/dist/core/context/refactored-frame-manager.js.map +2 -2
  73. package/dist/core/context/shared-context-layer.js +4 -2
  74. package/dist/core/context/shared-context-layer.js.map +2 -2
  75. package/dist/core/database/batch-operations.js +112 -86
  76. package/dist/core/database/batch-operations.js.map +2 -2
  77. package/dist/core/database/query-cache.js +19 -9
  78. package/dist/core/database/query-cache.js.map +2 -2
  79. package/dist/core/database/sqlite-adapter.js +1 -1
  80. package/dist/core/database/sqlite-adapter.js.map +2 -2
  81. package/dist/core/digest/enhanced-hybrid-digest.js +8 -2
  82. package/dist/core/digest/enhanced-hybrid-digest.js.map +2 -2
  83. package/dist/core/errors/recovery.js +9 -2
  84. package/dist/core/errors/recovery.js.map +2 -2
  85. package/dist/core/execution/parallel-executor.js +254 -0
  86. package/dist/core/execution/parallel-executor.js.map +7 -0
  87. package/dist/core/frame/workflow-templates-stub.js.map +1 -1
  88. package/dist/core/frame/workflow-templates.js +40 -1
  89. package/dist/core/frame/workflow-templates.js.map +2 -2
  90. package/dist/core/monitoring/logger.js +6 -1
  91. package/dist/core/monitoring/logger.js.map +2 -2
  92. package/dist/core/monitoring/metrics.js.map +2 -2
  93. package/dist/core/monitoring/progress-tracker.js.map +2 -2
  94. package/dist/core/performance/context-cache.js.map +2 -2
  95. package/dist/core/performance/lazy-context-loader.js +24 -20
  96. package/dist/core/performance/lazy-context-loader.js.map +2 -2
  97. package/dist/core/performance/optimized-frame-context.js +27 -12
  98. package/dist/core/performance/optimized-frame-context.js.map +2 -2
  99. package/dist/core/performance/performance-benchmark.js +10 -6
  100. package/dist/core/performance/performance-benchmark.js.map +2 -2
  101. package/dist/core/performance/performance-profiler.js +51 -14
  102. package/dist/core/performance/performance-profiler.js.map +2 -2
  103. package/dist/core/performance/streaming-jsonl-parser.js +5 -1
  104. package/dist/core/performance/streaming-jsonl-parser.js.map +2 -2
  105. package/dist/core/projects/project-manager.js +14 -20
  106. package/dist/core/projects/project-manager.js.map +2 -2
  107. package/dist/core/retrieval/context-retriever.js.map +1 -1
  108. package/dist/core/retrieval/llm-context-retrieval.js.map +2 -2
  109. package/dist/core/session/clear-survival-stub.js +5 -1
  110. package/dist/core/session/clear-survival-stub.js.map +2 -2
  111. package/dist/core/session/clear-survival.js +35 -0
  112. package/dist/core/session/clear-survival.js.map +2 -2
  113. package/dist/core/session/index.js.map +1 -1
  114. package/dist/core/session/session-manager.js.map +2 -2
  115. package/dist/core/storage/chromadb-adapter.js +6 -2
  116. package/dist/core/storage/chromadb-adapter.js.map +2 -2
  117. package/dist/core/storage/chromadb-simple.js +17 -5
  118. package/dist/core/storage/chromadb-simple.js.map +2 -2
  119. package/dist/core/storage/infinite-storage.js +109 -46
  120. package/dist/core/storage/infinite-storage.js.map +2 -2
  121. package/dist/core/storage/railway-optimized-storage.js +48 -22
  122. package/dist/core/storage/railway-optimized-storage.js.map +2 -2
  123. package/dist/core/storage/remote-storage.js +41 -23
  124. package/dist/core/storage/remote-storage.js.map +2 -2
  125. package/dist/core/trace/cli-trace-wrapper.js +9 -2
  126. package/dist/core/trace/cli-trace-wrapper.js.map +2 -2
  127. package/dist/core/trace/db-trace-wrapper.js +96 -68
  128. package/dist/core/trace/db-trace-wrapper.js.map +2 -2
  129. package/dist/core/trace/debug-trace.js +25 -8
  130. package/dist/core/trace/debug-trace.js.map +2 -2
  131. package/dist/core/trace/index.js +6 -2
  132. package/dist/core/trace/index.js.map +2 -2
  133. package/dist/core/trace/linear-api-wrapper.js +10 -5
  134. package/dist/core/trace/linear-api-wrapper.js.map +2 -2
  135. package/dist/core/trace/trace-demo.js +14 -10
  136. package/dist/core/trace/trace-demo.js.map +2 -2
  137. package/dist/core/trace/trace-detector.js +9 -2
  138. package/dist/core/trace/trace-detector.js.map +2 -2
  139. package/dist/core/trace/types.js.map +1 -1
  140. package/dist/core/utils/compression.js.map +1 -1
  141. package/dist/core/utils/update-checker.js.map +1 -1
  142. package/dist/core/worktree/worktree-manager.js +18 -7
  143. package/dist/core/worktree/worktree-manager.js.map +2 -2
  144. package/dist/features/analytics/core/analytics-service.js.map +2 -2
  145. package/dist/features/analytics/queries/metrics-queries.js +1 -1
  146. package/dist/features/analytics/queries/metrics-queries.js.map +2 -2
  147. package/dist/features/tasks/pebbles-task-store.js.map +1 -1
  148. package/dist/features/tui/components/analytics-panel.js +36 -15
  149. package/dist/features/tui/components/analytics-panel.js.map +2 -2
  150. package/dist/features/tui/components/pr-tracker.js +19 -7
  151. package/dist/features/tui/components/pr-tracker.js.map +2 -2
  152. package/dist/features/tui/components/session-monitor.js +22 -9
  153. package/dist/features/tui/components/session-monitor.js.map +2 -2
  154. package/dist/features/tui/components/subagent-fleet.js +20 -13
  155. package/dist/features/tui/components/subagent-fleet.js.map +2 -2
  156. package/dist/features/tui/components/task-board.js +26 -10
  157. package/dist/features/tui/components/task-board.js.map +2 -2
  158. package/dist/features/tui/index.js.map +2 -2
  159. package/dist/features/tui/services/data-service.js +6 -2
  160. package/dist/features/tui/services/data-service.js.map +2 -2
  161. package/dist/features/tui/services/linear-task-reader.js +3 -1
  162. package/dist/features/tui/services/linear-task-reader.js.map +2 -2
  163. package/dist/features/tui/services/websocket-client.js +3 -1
  164. package/dist/features/tui/services/websocket-client.js.map +2 -2
  165. package/dist/features/tui/terminal-compat.js +6 -2
  166. package/dist/features/tui/terminal-compat.js.map +2 -2
  167. package/dist/features/web/client/stores/task-store.js.map +2 -2
  168. package/dist/features/web/server/index.js +18 -10
  169. package/dist/features/web/server/index.js.map +2 -2
  170. package/dist/integrations/anthropic/client.js +259 -0
  171. package/dist/integrations/anthropic/client.js.map +7 -0
  172. package/dist/integrations/claude-code/subagent-client.js +404 -0
  173. package/dist/integrations/claude-code/subagent-client.js.map +7 -0
  174. package/dist/integrations/linear/sync-service.js +12 -13
  175. package/dist/integrations/linear/sync-service.js.map +2 -2
  176. package/dist/integrations/linear/sync.js +174 -12
  177. package/dist/integrations/linear/sync.js.map +2 -2
  178. package/dist/integrations/linear/unified-sync.js +1 -1
  179. package/dist/integrations/linear/unified-sync.js.map +1 -1
  180. package/dist/integrations/linear/webhook-server.js +15 -16
  181. package/dist/integrations/linear/webhook-server.js.map +2 -2
  182. package/dist/mcp/stackmemory-mcp-server.js +0 -11
  183. package/dist/mcp/stackmemory-mcp-server.js.map +2 -2
  184. package/dist/servers/production/auth-middleware.js.map +2 -2
  185. package/dist/servers/railway/index.js.map +2 -2
  186. package/dist/services/config-service.js +6 -7
  187. package/dist/services/config-service.js.map +2 -2
  188. package/dist/services/context-service.js +11 -12
  189. package/dist/services/context-service.js.map +2 -2
  190. package/dist/skills/claude-skills.js +101 -2
  191. package/dist/skills/claude-skills.js.map +2 -2
  192. package/dist/skills/dashboard-launcher.js.map +2 -2
  193. package/dist/skills/recursive-agent-orchestrator.js +559 -0
  194. package/dist/skills/recursive-agent-orchestrator.js.map +7 -0
  195. package/dist/skills/repo-ingestion-skill.js.map +2 -2
  196. package/dist/skills/security-secrets-scanner.js +265 -0
  197. package/dist/skills/security-secrets-scanner.js.map +7 -0
  198. package/dist/utils/env.js +46 -0
  199. package/dist/utils/env.js.map +7 -0
  200. package/dist/utils/logger.js +0 -11
  201. package/dist/utils/logger.js.map +2 -2
  202. package/package.json +1 -1
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/commands/monitor.ts"],
4
- "sourcesContent": ["/**\n * Monitor command for StackMemory\n * Real-time monitoring of context and frame activity\n */\n\n/**\n * Monitor command for StackMemory\n * Runs background monitoring daemon for automatic triggers\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { SessionMonitor } from '../../core/monitoring/session-monitor.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport Database from 'better-sqlite3';\n// getProjectRoot function will be defined below\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { spawn } from 'child_process';\n\nexport function createMonitorCommand(): Command {\n const cmd = new Command('monitor')\n .description('Run background monitoring for automatic triggers')\n .option('--start', 'Start monitoring daemon')\n .option('--stop', 'Stop monitoring daemon')\n .option('--status', 'Check monitor status')\n .option('--config', 'Show monitor configuration')\n .option('--activity', 'Update activity timestamp')\n .option('--daemon', 'Run as daemon (background process)')\n .option('--foreground', 'Run in foreground (for testing)')\n .option('--interval <seconds>', 'Check interval in seconds', '30')\n .option('--idle <minutes>', 'Idle timeout in minutes', '5')\n .action(async (options) => {\n const spinner = ora();\n\n try {\n const projectRoot = await getProjectRoot();\n const dbPath = path.join(\n projectRoot,\n '.stackmemory',\n 'db',\n 'stackmemory.db'\n );\n\n // Check if StackMemory is initialized\n try {\n await fs.access(dbPath);\n } catch {\n console.error(chalk.red('\u2717 StackMemory not initialized'));\n console.log(chalk.yellow('Run: stackmemory init'));\n process.exit(1);\n }\n\n if (options.start) {\n await startMonitor(projectRoot, options, spinner);\n } else if (options.stop) {\n await stopMonitor(projectRoot, spinner);\n } else if (options.status) {\n await showStatus(projectRoot);\n } else if (options.config) {\n await showConfig(projectRoot);\n } else if (options.activity) {\n await updateActivity(projectRoot);\n } else if (options.daemon) {\n await runDaemon(projectRoot, options);\n } else if (options.foreground) {\n await runForeground(projectRoot, options);\n } else {\n // Default: show status\n await showStatus(projectRoot);\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Error: ${error}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\n/**\n * Start monitoring daemon\n */\nasync function startMonitor(\n projectRoot: string,\n options: any,\n spinner: any\n) {\n spinner.start('Starting monitor daemon...');\n\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n\n // Check if already running\n try {\n const pid = await fs.readFile(pidFile, 'utf-8');\n // Check if process is actually running\n try {\n process.kill(parseInt(pid), 0);\n spinner.fail(chalk.yellow('Monitor already running'));\n console.log(chalk.gray(`PID: ${pid}`));\n return;\n } catch {\n // Process not running, clean up stale PID file\n await fs.unlink(pidFile).catch(() => {});\n }\n } catch {\n // No PID file\n }\n\n // Spawn daemon process\n const daemon = spawn(\n process.execPath,\n [\n process.argv[1],\n 'monitor',\n '--daemon',\n '--interval',\n options.interval || '30',\n '--idle',\n options.idle || '5',\n ],\n {\n cwd: projectRoot,\n detached: true,\n stdio: ['ignore', 'ignore', 'ignore'],\n }\n );\n\n // Store PID\n await fs.writeFile(pidFile, daemon.pid!.toString(), 'utf-8');\n\n daemon.unref();\n\n spinner.succeed(chalk.green('\u2705 Monitor daemon started'));\n console.log(chalk.gray(`PID: ${daemon.pid}`));\n console.log(chalk.gray(`Check interval: ${options.interval || 30}s`));\n console.log(chalk.gray(`Idle timeout: ${options.idle || 5}min`));\n\n console.log(chalk.bold('\\n\uD83D\uDD0D Monitoring:'));\n console.log(' \u2022 Context usage (warns at 60%, saves at 85%)');\n console.log(' \u2022 Idle detection (handoff after 5min)');\n console.log(' \u2022 Session end (auto-save on exit)');\n\n console.log(chalk.gray('\\nStop with: stackmemory monitor --stop'));\n}\n\n/**\n * Stop monitoring daemon\n */\nasync function stopMonitor(projectRoot: string, spinner: ora.Ora) {\n spinner.start('Stopping monitor daemon...');\n\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n\n try {\n const pid = parseInt(await fs.readFile(pidFile, 'utf-8'));\n\n // Send termination signal\n process.kill(pid, 'SIGTERM');\n\n // Clean up PID file\n await fs.unlink(pidFile);\n\n spinner.succeed(chalk.green('\u2705 Monitor daemon stopped'));\n } catch (error: unknown) {\n spinner.fail(chalk.yellow('Monitor not running'));\n }\n}\n\n/**\n * Show monitor status\n */\nasync function showStatus(projectRoot: string) {\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n const statusFile = path.join(projectRoot, '.stackmemory', 'monitor.status');\n\n console.log(chalk.bold('\\n\uD83D\uDCCA Monitor Status\\n'));\n\n // Check if daemon is running\n let isRunning = false;\n let pid: number | undefined;\n\n try {\n pid = parseInt(await fs.readFile(pidFile, 'utf-8'));\n process.kill(pid, 0);\n isRunning = true;\n } catch {\n // Not running\n }\n\n if (isRunning && pid) {\n console.log(chalk.green('\u2705 Monitor is running'));\n console.log(chalk.gray(`PID: ${pid}`));\n\n // Try to read status file\n try {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n\n console.log(chalk.bold('\\nLast Check:'));\n console.log(` Time: ${new Date(status.lastCheck).toLocaleString()}`);\n console.log(` Context: ${Math.round(status.contextPercentage * 100)}%`);\n console.log(\n ` Status: ${getStatusEmoji(status.contextStatus)} ${status.contextStatus}`\n );\n\n if (status.lastActivity) {\n const idleMinutes = Math.round(\n (Date.now() - new Date(status.lastActivity).getTime()) / 60000\n );\n console.log(` Idle: ${idleMinutes} minutes`);\n }\n\n if (status.lastLedgerSave) {\n console.log(chalk.bold('\\nLast Ledger Save:'));\n console.log(` ${new Date(status.lastLedgerSave).toLocaleString()}`);\n }\n\n if (status.lastHandoff) {\n console.log(chalk.bold('\\nLast Handoff:'));\n console.log(` ${new Date(status.lastHandoff).toLocaleString()}`);\n }\n } catch {\n // No status file or invalid\n }\n } else {\n console.log(chalk.yellow('\u26A0\uFE0F Monitor is not running'));\n console.log(chalk.gray('Start with: stackmemory monitor --start'));\n }\n}\n\n/**\n * Show monitor configuration\n */\nasync function showConfig(projectRoot: string) {\n const configFile = path.join(projectRoot, '.stackmemory', 'config.json');\n\n console.log(chalk.bold('\\n\u2699\uFE0F Monitor Configuration\\n'));\n\n try {\n const config = JSON.parse(await fs.readFile(configFile, 'utf-8'));\n const monitorConfig = config.monitor || {};\n\n console.log('Context Thresholds:');\n console.log(\n ` Warning: ${(monitorConfig.contextWarningThreshold || 0.6) * 100}%`\n );\n console.log(\n ` Critical: ${(monitorConfig.contextCriticalThreshold || 0.7) * 100}%`\n );\n console.log(\n ` Auto-save: ${(monitorConfig.contextAutoSaveThreshold || 0.85) * 100}%`\n );\n\n console.log('\\nTimings:');\n console.log(\n ` Check interval: ${monitorConfig.checkIntervalSeconds || 30}s`\n );\n console.log(` Idle timeout: ${monitorConfig.idleTimeoutMinutes || 5}min`);\n\n console.log('\\nAuto Actions:');\n console.log(\n ` Auto-save ledger: ${monitorConfig.autoSaveLedger !== false ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Auto-generate handoff: ${monitorConfig.autoGenerateHandoff !== false ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Session-end handoff: ${monitorConfig.sessionEndHandoff !== false ? '\u2705' : '\u274C'}`\n );\n } catch {\n console.log(chalk.gray('Using default configuration'));\n console.log('\\nDefaults:');\n console.log(' Warning at 60%, Critical at 70%, Auto-save at 85%');\n console.log(' Check every 30s, Idle timeout 5min');\n console.log(' All auto-actions enabled');\n }\n}\n\n/**\n * Update activity timestamp\n */\nasync function updateActivity(projectRoot: string) {\n const activityFile = path.join(\n projectRoot,\n '.stackmemory',\n 'monitor.activity'\n );\n await fs.mkdir(path.dirname(activityFile), { recursive: true });\n await fs.writeFile(activityFile, new Date().toISOString(), 'utf-8');\n // Silent update - no output\n}\n\n/**\n * Run as daemon (background process)\n */\nasync function runDaemon(projectRoot: string, options: any) {\n const dbPath = path.join(projectRoot, '.stackmemory', 'db', 'stackmemory.db');\n const db = new Database(dbPath);\n\n const frameManager = new FrameManager(db, 'current');\n\n const monitor = new SessionMonitor(frameManager, db, projectRoot, {\n checkIntervalSeconds: parseInt(options.interval) || 30,\n idleTimeoutMinutes: parseInt(options.idle) || 5,\n autoSaveLedger: true,\n autoGenerateHandoff: true,\n sessionEndHandoff: true,\n });\n\n // Write status periodically\n const statusFile = path.join(projectRoot, '.stackmemory', 'monitor.status');\n const activityFile = path.join(\n projectRoot,\n '.stackmemory',\n 'monitor.activity'\n );\n\n monitor.on('context:usage', async (data) => {\n // Check for activity file updates\n try {\n const activityTime = await fs.readFile(activityFile, 'utf-8');\n monitor.updateActivity();\n } catch {\n // No activity file\n }\n\n // Write status\n const status = {\n lastCheck: new Date().toISOString(),\n contextPercentage: data.percentage,\n contextStatus: data.status,\n lastActivity: monitor.getStatus().lastActivity,\n };\n\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n monitor.on('context:ledger_saved', async () => {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n status.lastLedgerSave = new Date().toISOString();\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n monitor.on('handoff:generated', async () => {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n status.lastHandoff = new Date().toISOString();\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n // Start monitoring\n await monitor.start();\n\n // Keep process alive\n process.on('SIGTERM', async () => {\n await monitor.stop();\n process.exit(0);\n });\n}\n\n/**\n * Run in foreground (for testing)\n */\nasync function runForeground(projectRoot: string, options: any) {\n console.log(chalk.bold('\uD83D\uDD0D Running monitor in foreground...\\n'));\n\n const dbPath = path.join(projectRoot, '.stackmemory', 'db', 'stackmemory.db');\n const db = new Database(dbPath);\n\n const frameManager = new FrameManager(db, 'current');\n\n const monitor = new SessionMonitor(frameManager, db, projectRoot, {\n checkIntervalSeconds: parseInt(options.interval) || 30,\n idleTimeoutMinutes: parseInt(options.idle) || 5,\n autoSaveLedger: true,\n autoGenerateHandoff: true,\n sessionEndHandoff: true,\n });\n\n // Log all events\n monitor.on('context:usage', (data) => {\n console.log(\n `[${new Date().toLocaleTimeString()}] Context: ${Math.round(data.percentage * 100)}% (${data.status})`\n );\n });\n\n monitor.on('context:warning', () => {\n console.log(chalk.yellow('\u26A0\uFE0F Context warning threshold reached'));\n });\n\n monitor.on('context:high', () => {\n console.log(chalk.yellow('\uD83D\uDFE1 Context high - considering auto-save'));\n });\n\n monitor.on('context:ledger_saved', (data) => {\n console.log(\n chalk.green(`\u2705 Ledger saved (${data.compression}x compression)`)\n );\n });\n\n monitor.on('handoff:generated', (data) => {\n console.log(chalk.green(`\uD83D\uDCCB Handoff generated (${data.trigger})`));\n });\n\n // Start monitoring\n await monitor.start();\n\n console.log('Press Ctrl+C to stop\\n');\n\n // Handle exit\n process.on('SIGINT', async () => {\n console.log('\\nStopping monitor...');\n await monitor.stop();\n process.exit(0);\n });\n}\n\n// Helper functions\n\nasync function getProjectRoot(): Promise<string> {\n return process.cwd();\n}\n\nfunction getStatusEmoji(status: string): string {\n switch (status) {\n case 'ok':\n return '\uD83D\uDFE2';\n case 'warning':\n return '\uD83D\uDFE1';\n case 'high':\n return '\uD83D\uDFE0';\n case 'critical':\n return '\uD83D\uDD34';\n default:\n return '\u26AB';\n }\n}\n\n// Export for use in main CLI\nexport default createMonitorCommand();\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["/**\n * Monitor command for StackMemory\n * Real-time monitoring of context and frame activity\n */\n\n/**\n * Monitor command for StackMemory\n * Runs background monitoring daemon for automatic triggers\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { SessionMonitor } from '../../core/monitoring/session-monitor.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport Database from 'better-sqlite3';\n// getProjectRoot function will be defined below\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { spawn } from 'child_process';\n\nexport function createMonitorCommand(): Command {\n const cmd = new Command('monitor')\n .description('Run background monitoring for automatic triggers')\n .option('--start', 'Start monitoring daemon')\n .option('--stop', 'Stop monitoring daemon')\n .option('--status', 'Check monitor status')\n .option('--config', 'Show monitor configuration')\n .option('--activity', 'Update activity timestamp')\n .option('--daemon', 'Run as daemon (background process)')\n .option('--foreground', 'Run in foreground (for testing)')\n .option('--interval <seconds>', 'Check interval in seconds', '30')\n .option('--idle <minutes>', 'Idle timeout in minutes', '5')\n .action(async (options) => {\n const spinner = ora();\n\n try {\n const projectRoot = await getProjectRoot();\n const dbPath = path.join(\n projectRoot,\n '.stackmemory',\n 'db',\n 'stackmemory.db'\n );\n\n // Check if StackMemory is initialized\n try {\n await fs.access(dbPath);\n } catch {\n console.error(chalk.red('\u2717 StackMemory not initialized'));\n console.log(chalk.yellow('Run: stackmemory init'));\n process.exit(1);\n }\n\n if (options.start) {\n await startMonitor(projectRoot, options, spinner);\n } else if (options.stop) {\n await stopMonitor(projectRoot, spinner);\n } else if (options.status) {\n await showStatus(projectRoot);\n } else if (options.config) {\n await showConfig(projectRoot);\n } else if (options.activity) {\n await updateActivity(projectRoot);\n } else if (options.daemon) {\n await runDaemon(projectRoot, options);\n } else if (options.foreground) {\n await runForeground(projectRoot, options);\n } else {\n // Default: show status\n await showStatus(projectRoot);\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Error: ${error}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\n/**\n * Start monitoring daemon\n */\nasync function startMonitor(projectRoot: string, options: any, spinner: any) {\n spinner.start('Starting monitor daemon...');\n\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n\n // Check if already running\n try {\n const pid = await fs.readFile(pidFile, 'utf-8');\n // Check if process is actually running\n try {\n process.kill(parseInt(pid), 0);\n spinner.fail(chalk.yellow('Monitor already running'));\n console.log(chalk.gray(`PID: ${pid}`));\n return;\n } catch {\n // Process not running, clean up stale PID file\n await fs.unlink(pidFile).catch(() => {});\n }\n } catch {\n // No PID file\n }\n\n // Spawn daemon process\n const daemon = spawn(\n process.execPath,\n [\n process.argv[1],\n 'monitor',\n '--daemon',\n '--interval',\n options.interval || '30',\n '--idle',\n options.idle || '5',\n ],\n {\n cwd: projectRoot,\n detached: true,\n stdio: ['ignore', 'ignore', 'ignore'],\n }\n );\n\n // Store PID\n await fs.writeFile(pidFile, daemon.pid!.toString(), 'utf-8');\n\n daemon.unref();\n\n spinner.succeed(chalk.green('\u2705 Monitor daemon started'));\n console.log(chalk.gray(`PID: ${daemon.pid}`));\n console.log(chalk.gray(`Check interval: ${options.interval || 30}s`));\n console.log(chalk.gray(`Idle timeout: ${options.idle || 5}min`));\n\n console.log(chalk.bold('\\n\uD83D\uDD0D Monitoring:'));\n console.log(' \u2022 Context usage (warns at 60%, saves at 85%)');\n console.log(' \u2022 Idle detection (handoff after 5min)');\n console.log(' \u2022 Session end (auto-save on exit)');\n\n console.log(chalk.gray('\\nStop with: stackmemory monitor --stop'));\n}\n\n/**\n * Stop monitoring daemon\n */\nasync function stopMonitor(projectRoot: string, spinner: ora.Ora) {\n spinner.start('Stopping monitor daemon...');\n\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n\n try {\n const pid = parseInt(await fs.readFile(pidFile, 'utf-8'));\n\n // Send termination signal\n process.kill(pid, 'SIGTERM');\n\n // Clean up PID file\n await fs.unlink(pidFile);\n\n spinner.succeed(chalk.green('\u2705 Monitor daemon stopped'));\n } catch (error: unknown) {\n spinner.fail(chalk.yellow('Monitor not running'));\n }\n}\n\n/**\n * Show monitor status\n */\nasync function showStatus(projectRoot: string) {\n const pidFile = path.join(projectRoot, '.stackmemory', 'monitor.pid');\n const statusFile = path.join(projectRoot, '.stackmemory', 'monitor.status');\n\n console.log(chalk.bold('\\n\uD83D\uDCCA Monitor Status\\n'));\n\n // Check if daemon is running\n let isRunning = false;\n let pid: number | undefined;\n\n try {\n pid = parseInt(await fs.readFile(pidFile, 'utf-8'));\n process.kill(pid, 0);\n isRunning = true;\n } catch {\n // Not running\n }\n\n if (isRunning && pid) {\n console.log(chalk.green('\u2705 Monitor is running'));\n console.log(chalk.gray(`PID: ${pid}`));\n\n // Try to read status file\n try {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n\n console.log(chalk.bold('\\nLast Check:'));\n console.log(` Time: ${new Date(status.lastCheck).toLocaleString()}`);\n console.log(` Context: ${Math.round(status.contextPercentage * 100)}%`);\n console.log(\n ` Status: ${getStatusEmoji(status.contextStatus)} ${status.contextStatus}`\n );\n\n if (status.lastActivity) {\n const idleMinutes = Math.round(\n (Date.now() - new Date(status.lastActivity).getTime()) / 60000\n );\n console.log(` Idle: ${idleMinutes} minutes`);\n }\n\n if (status.lastLedgerSave) {\n console.log(chalk.bold('\\nLast Ledger Save:'));\n console.log(` ${new Date(status.lastLedgerSave).toLocaleString()}`);\n }\n\n if (status.lastHandoff) {\n console.log(chalk.bold('\\nLast Handoff:'));\n console.log(` ${new Date(status.lastHandoff).toLocaleString()}`);\n }\n } catch {\n // No status file or invalid\n }\n } else {\n console.log(chalk.yellow('\u26A0\uFE0F Monitor is not running'));\n console.log(chalk.gray('Start with: stackmemory monitor --start'));\n }\n}\n\n/**\n * Show monitor configuration\n */\nasync function showConfig(projectRoot: string) {\n const configFile = path.join(projectRoot, '.stackmemory', 'config.json');\n\n console.log(chalk.bold('\\n\u2699\uFE0F Monitor Configuration\\n'));\n\n try {\n const config = JSON.parse(await fs.readFile(configFile, 'utf-8'));\n const monitorConfig = config.monitor || {};\n\n console.log('Context Thresholds:');\n console.log(\n ` Warning: ${(monitorConfig.contextWarningThreshold || 0.6) * 100}%`\n );\n console.log(\n ` Critical: ${(monitorConfig.contextCriticalThreshold || 0.7) * 100}%`\n );\n console.log(\n ` Auto-save: ${(monitorConfig.contextAutoSaveThreshold || 0.85) * 100}%`\n );\n\n console.log('\\nTimings:');\n console.log(\n ` Check interval: ${monitorConfig.checkIntervalSeconds || 30}s`\n );\n console.log(` Idle timeout: ${monitorConfig.idleTimeoutMinutes || 5}min`);\n\n console.log('\\nAuto Actions:');\n console.log(\n ` Auto-save ledger: ${monitorConfig.autoSaveLedger !== false ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Auto-generate handoff: ${monitorConfig.autoGenerateHandoff !== false ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Session-end handoff: ${monitorConfig.sessionEndHandoff !== false ? '\u2705' : '\u274C'}`\n );\n } catch {\n console.log(chalk.gray('Using default configuration'));\n console.log('\\nDefaults:');\n console.log(' Warning at 60%, Critical at 70%, Auto-save at 85%');\n console.log(' Check every 30s, Idle timeout 5min');\n console.log(' All auto-actions enabled');\n }\n}\n\n/**\n * Update activity timestamp\n */\nasync function updateActivity(projectRoot: string) {\n const activityFile = path.join(\n projectRoot,\n '.stackmemory',\n 'monitor.activity'\n );\n await fs.mkdir(path.dirname(activityFile), { recursive: true });\n await fs.writeFile(activityFile, new Date().toISOString(), 'utf-8');\n // Silent update - no output\n}\n\n/**\n * Run as daemon (background process)\n */\nasync function runDaemon(projectRoot: string, options: any) {\n const dbPath = path.join(projectRoot, '.stackmemory', 'db', 'stackmemory.db');\n const db = new Database(dbPath);\n\n const frameManager = new FrameManager(db, 'current');\n\n const monitor = new SessionMonitor(frameManager, db, projectRoot, {\n checkIntervalSeconds: parseInt(options.interval) || 30,\n idleTimeoutMinutes: parseInt(options.idle) || 5,\n autoSaveLedger: true,\n autoGenerateHandoff: true,\n sessionEndHandoff: true,\n });\n\n // Write status periodically\n const statusFile = path.join(projectRoot, '.stackmemory', 'monitor.status');\n const activityFile = path.join(\n projectRoot,\n '.stackmemory',\n 'monitor.activity'\n );\n\n monitor.on('context:usage', async (data) => {\n // Check for activity file updates\n try {\n const activityTime = await fs.readFile(activityFile, 'utf-8');\n monitor.updateActivity();\n } catch {\n // No activity file\n }\n\n // Write status\n const status = {\n lastCheck: new Date().toISOString(),\n contextPercentage: data.percentage,\n contextStatus: data.status,\n lastActivity: monitor.getStatus().lastActivity,\n };\n\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n monitor.on('context:ledger_saved', async () => {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n status.lastLedgerSave = new Date().toISOString();\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n monitor.on('handoff:generated', async () => {\n const status = JSON.parse(await fs.readFile(statusFile, 'utf-8'));\n status.lastHandoff = new Date().toISOString();\n await fs.writeFile(statusFile, JSON.stringify(status, null, 2), 'utf-8');\n });\n\n // Start monitoring\n await monitor.start();\n\n // Keep process alive\n process.on('SIGTERM', async () => {\n await monitor.stop();\n process.exit(0);\n });\n}\n\n/**\n * Run in foreground (for testing)\n */\nasync function runForeground(projectRoot: string, options: any) {\n console.log(chalk.bold('\uD83D\uDD0D Running monitor in foreground...\\n'));\n\n const dbPath = path.join(projectRoot, '.stackmemory', 'db', 'stackmemory.db');\n const db = new Database(dbPath);\n\n const frameManager = new FrameManager(db, 'current');\n\n const monitor = new SessionMonitor(frameManager, db, projectRoot, {\n checkIntervalSeconds: parseInt(options.interval) || 30,\n idleTimeoutMinutes: parseInt(options.idle) || 5,\n autoSaveLedger: true,\n autoGenerateHandoff: true,\n sessionEndHandoff: true,\n });\n\n // Log all events\n monitor.on('context:usage', (data) => {\n console.log(\n `[${new Date().toLocaleTimeString()}] Context: ${Math.round(data.percentage * 100)}% (${data.status})`\n );\n });\n\n monitor.on('context:warning', () => {\n console.log(chalk.yellow('\u26A0\uFE0F Context warning threshold reached'));\n });\n\n monitor.on('context:high', () => {\n console.log(chalk.yellow('\uD83D\uDFE1 Context high - considering auto-save'));\n });\n\n monitor.on('context:ledger_saved', (data) => {\n console.log(\n chalk.green(`\u2705 Ledger saved (${data.compression}x compression)`)\n );\n });\n\n monitor.on('handoff:generated', (data) => {\n console.log(chalk.green(`\uD83D\uDCCB Handoff generated (${data.trigger})`));\n });\n\n // Start monitoring\n await monitor.start();\n\n console.log('Press Ctrl+C to stop\\n');\n\n // Handle exit\n process.on('SIGINT', async () => {\n console.log('\\nStopping monitor...');\n await monitor.stop();\n process.exit(0);\n });\n}\n\n// Helper functions\n\nasync function getProjectRoot(): Promise<string> {\n return process.cwd();\n}\n\nfunction getStatusEmoji(status: string): string {\n switch (status) {\n case 'ok':\n return '\uD83D\uDFE2';\n case 'warning':\n return '\uD83D\uDFE1';\n case 'high':\n return '\uD83D\uDFE0';\n case 'critical':\n return '\uD83D\uDD34';\n default:\n return '\u26AB';\n }\n}\n\n// Export for use in main CLI\nexport default createMonitorCommand();\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -29,11 +29,16 @@ function registerOnboardingCommand(program) {
29
29
  try {
30
30
  const config = await runOnboarding();
31
31
  await applyConfiguration(config);
32
- console.log(chalk.green("\n\u2705 StackMemory setup completed successfully!\n"));
32
+ console.log(
33
+ chalk.green("\n\u2705 StackMemory setup completed successfully!\n")
34
+ );
33
35
  showNextSteps(config);
34
36
  } catch (error) {
35
37
  logger.error("Onboarding failed", error);
36
- console.error(chalk.red("\n\u274C Setup failed:"), error.message);
38
+ console.error(
39
+ chalk.red("\n\u274C Setup failed:"),
40
+ error.message
41
+ );
37
42
  process.exit(1);
38
43
  }
39
44
  });
@@ -156,11 +161,23 @@ async function runOnboarding() {
156
161
  choices: [
157
162
  { name: "~/Dev", value: join(homedir(), "Dev"), checked: true },
158
163
  { name: "~/dev", value: join(homedir(), "dev"), checked: true },
159
- { name: "~/Projects", value: join(homedir(), "Projects"), checked: true },
160
- { name: "~/projects", value: join(homedir(), "projects"), checked: true },
164
+ {
165
+ name: "~/Projects",
166
+ value: join(homedir(), "Projects"),
167
+ checked: true
168
+ },
169
+ {
170
+ name: "~/projects",
171
+ value: join(homedir(), "projects"),
172
+ checked: true
173
+ },
161
174
  { name: "~/Work", value: join(homedir(), "Work"), checked: false },
162
175
  { name: "~/code", value: join(homedir(), "code"), checked: true },
163
- { name: "~/Documents/GitHub", value: join(homedir(), "Documents/GitHub"), checked: false }
176
+ {
177
+ name: "~/Documents/GitHub",
178
+ value: join(homedir(), "Documents/GitHub"),
179
+ checked: false
180
+ }
164
181
  ],
165
182
  when: () => projectDetailAnswers.scanProjects
166
183
  }
@@ -316,7 +333,9 @@ exec stackmemory "$@"
316
333
  console.log(chalk.green(" \u2713 Created claude-sm command"));
317
334
  }
318
335
  } catch (error) {
319
- console.log(chalk.yellow(" \u26A0 Could not create claude-sm symlink (may need sudo)"));
336
+ console.log(
337
+ chalk.yellow(" \u26A0 Could not create claude-sm symlink (may need sudo)")
338
+ );
320
339
  }
321
340
  }
322
341
  function showNextSteps(config) {
@@ -326,9 +345,17 @@ function showNextSteps(config) {
326
345
  console.log(chalk.gray(" stackmemory init\n"));
327
346
  if (config.enableWorktrees) {
328
347
  console.log("2. Create a new worktree:");
329
- console.log(chalk.gray(" git worktree add -b feature/new-feature ../project-feature"));
348
+ console.log(
349
+ chalk.gray(
350
+ " git worktree add -b feature/new-feature ../project-feature"
351
+ )
352
+ );
330
353
  console.log(chalk.gray(" cd ../project-feature"));
331
- console.log(chalk.gray(" stackmemory status # Isolated context for this worktree\n"));
354
+ console.log(
355
+ chalk.gray(
356
+ " stackmemory status # Isolated context for this worktree\n"
357
+ )
358
+ );
332
359
  }
333
360
  console.log("3. Use with Claude:");
334
361
  console.log(chalk.gray(" claude-sm # Or use stackmemory directly\n"));
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/commands/onboard.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory Onboarding CLI\n * Interactive setup for new StackMemory installations\n */\n\nimport { Command } from 'commander';\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport { homedir } from 'os';\nimport { join } from 'path';\nimport { existsSync, mkdirSync, writeFileSync } from 'fs';\nimport { execSync } from 'child_process';\nimport { WorktreeManager } from '../../core/worktree/worktree-manager.js';\nimport { ProjectManager } from '../../core/projects/project-manager.js';\nimport { logger } from '../../core/monitoring/logger.js';\n\ninterface OnboardingConfig {\n setupType: 'basic' | 'advanced';\n enableWorktrees: boolean;\n worktreeIsolation: boolean;\n enableProjects: boolean;\n scanProjects: boolean;\n enableLinear: boolean;\n linearApiKey?: string;\n enableAnalytics: boolean;\n defaultContextPath: string;\n}\n\nexport function registerOnboardingCommand(program: Command): void {\n program\n .command('onboard')\n .alias('setup')\n .description('Interactive setup for StackMemory')\n .option('--reset', 'Reset all configurations and start fresh')\n .action(async (options) => {\n console.log(chalk.cyan('\\n\uD83D\uDE80 Welcome to StackMemory Setup!\\n'));\n \n // Check if already configured\n const configPath = join(homedir(), '.stackmemory');\n if (existsSync(configPath) && !options.reset) {\n const { proceed } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'proceed',\n message: 'StackMemory is already configured. Do you want to reconfigure?',\n default: false,\n },\n ]);\n \n if (!proceed) {\n console.log(chalk.yellow('\\nSetup cancelled.'));\n return;\n }\n }\n\n try {\n const config = await runOnboarding();\n await applyConfiguration(config);\n \n console.log(chalk.green('\\n\u2705 StackMemory setup completed successfully!\\n'));\n showNextSteps(config);\n } catch (error: unknown) {\n logger.error('Onboarding failed', error as Error);\n console.error(chalk.red('\\n\u274C Setup failed:'), (error as Error).message);\n process.exit(1);\n }\n });\n}\n\nasync function runOnboarding(): Promise<OnboardingConfig> {\n // Basic or Advanced Setup\n const { setupType } = await inquirer.prompt([\n {\n type: 'list',\n name: 'setupType',\n message: 'Choose your setup type:',\n choices: [\n { name: 'Basic (Recommended for most users)', value: 'basic' },\n { name: 'Advanced (Full customization)', value: 'advanced' },\n ],\n default: 'basic',\n },\n ]);\n\n let config: OnboardingConfig = {\n setupType,\n enableWorktrees: false,\n worktreeIsolation: true,\n enableProjects: true,\n scanProjects: false,\n enableLinear: false,\n enableAnalytics: true,\n defaultContextPath: join(homedir(), '.stackmemory'),\n };\n\n if (setupType === 'basic') {\n // Basic setup with sensible defaults\n const basicAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableWorktrees',\n message: 'Enable Git worktree support? (Recommended for multi-branch workflows)',\n default: false,\n },\n {\n type: 'confirm',\n name: 'scanProjects',\n message: 'Scan and organize your existing projects?',\n default: true,\n },\n {\n type: 'confirm',\n name: 'enableLinear',\n message: 'Connect to Linear for task management?',\n default: false,\n },\n ]);\n\n config = { ...config, ...basicAnswers };\n\n if (basicAnswers.enableLinear) {\n const { linearApiKey } = await inquirer.prompt([\n {\n type: 'password',\n name: 'linearApiKey',\n message: 'Enter your Linear API key:',\n validate: (input: string) => input.length > 0 || 'API key is required',\n },\n ]);\n config.linearApiKey = linearApiKey;\n }\n } else {\n // Advanced setup with all options\n const advancedAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableWorktrees',\n message: 'Enable Git worktree support?',\n default: false,\n },\n ]);\n\n if (advancedAnswers.enableWorktrees) {\n const worktreeAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'worktreeIsolation',\n message: 'Isolate contexts between worktrees? (Recommended)',\n default: true,\n },\n {\n type: 'confirm',\n name: 'autoDetect',\n message: 'Auto-detect worktrees when switching directories?',\n default: true,\n },\n {\n type: 'confirm',\n name: 'shareGlobal',\n message: 'Share global context across worktrees?',\n default: false,\n },\n {\n type: 'number',\n name: 'syncInterval',\n message: 'Context sync interval in minutes (0 to disable):',\n default: 15,\n validate: (input: number) => input >= 0 || 'Must be 0 or positive',\n },\n ]);\n\n config = { ...config, ...advancedAnswers, ...worktreeAnswers };\n }\n\n const projectAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableProjects',\n message: 'Enable automatic project management?',\n default: true,\n },\n ]);\n\n if (projectAnswers.enableProjects) {\n const projectDetailAnswers: any = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'scanProjects',\n message: 'Scan for existing projects now?',\n default: true,\n },\n {\n type: 'checkbox',\n name: 'scanPaths',\n message: 'Select directories to scan:',\n choices: [\n { name: '~/Dev', value: join(homedir(), 'Dev'), checked: true },\n { name: '~/dev', value: join(homedir(), 'dev'), checked: true },\n { name: '~/Projects', value: join(homedir(), 'Projects'), checked: true },\n { name: '~/projects', value: join(homedir(), 'projects'), checked: true },\n { name: '~/Work', value: join(homedir(), 'Work'), checked: false },\n { name: '~/code', value: join(homedir(), 'code'), checked: true },\n { name: '~/Documents/GitHub', value: join(homedir(), 'Documents/GitHub'), checked: false },\n ],\n when: (): boolean => projectDetailAnswers.scanProjects,\n },\n ]);\n\n config = { ...config, ...projectAnswers, ...projectDetailAnswers };\n }\n\n const integrationAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableLinear',\n message: 'Enable Linear integration?',\n default: false,\n },\n {\n type: 'password',\n name: 'linearApiKey',\n message: 'Linear API key:',\n when: (answers: any) => answers.enableLinear,\n validate: (input: string) => input.length > 0 || 'API key is required',\n },\n {\n type: 'confirm',\n name: 'enableAnalytics',\n message: 'Enable usage analytics? (Local only)',\n default: true,\n },\n {\n type: 'input',\n name: 'defaultContextPath',\n message: 'Default context storage path:',\n default: join(homedir(), '.stackmemory'),\n validate: (input: string) => input.length > 0 || 'Path is required',\n },\n ]);\n\n config = { ...config, ...integrationAnswers };\n }\n\n return config;\n}\n\nasync function applyConfiguration(config: OnboardingConfig): Promise<void> {\n const configPath = join(homedir(), '.stackmemory');\n \n // Create base directory structure\n console.log(chalk.gray('\\nCreating directory structure...'));\n const dirs = [\n configPath,\n join(configPath, 'contexts'),\n join(configPath, 'projects'),\n join(configPath, 'worktrees'),\n join(configPath, 'bin'),\n join(configPath, 'logs'),\n join(configPath, 'analytics'),\n ];\n\n for (const dir of dirs) {\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n }\n\n // Configure git worktree support\n if (config.enableWorktrees) {\n console.log(chalk.gray('Configuring worktree support...'));\n const worktreeManager = WorktreeManager.getInstance();\n worktreeManager.saveConfig({\n enabled: true,\n autoDetect: true,\n isolateContexts: config.worktreeIsolation,\n shareGlobalContext: false,\n syncInterval: 15,\n });\n\n // Detect current worktrees\n const worktrees = worktreeManager.detectWorktrees();\n if (worktrees.length > 0) {\n console.log(chalk.green(` \u2713 Found ${worktrees.length} worktree(s)`));\n worktrees.forEach(wt => {\n console.log(chalk.gray(` - ${wt.branch} at ${wt.path}`));\n });\n }\n }\n\n // Scan and organize projects\n if (config.enableProjects && config.scanProjects) {\n console.log(chalk.gray('Scanning for projects...'));\n const projectManager = ProjectManager.getInstance();\n \n const scanPaths = (config as any).scanPaths || [\n join(homedir(), 'Dev'),\n join(homedir(), 'dev'),\n join(homedir(), 'Projects'),\n join(homedir(), 'projects'),\n join(homedir(), 'code'),\n ];\n \n await projectManager.scanAndCategorizeAllProjects(\n scanPaths.filter((p: string) => existsSync(p))\n );\n \n const projects = projectManager.getAllProjects();\n console.log(chalk.green(` \u2713 Found ${projects.length} project(s)`));\n \n // Show summary\n const byType: Record<string, number> = {};\n projects.forEach(p => {\n byType[p.accountType] = (byType[p.accountType] || 0) + 1;\n });\n \n Object.entries(byType).forEach(([type, count]) => {\n console.log(chalk.gray(` - ${type}: ${count} project(s)`));\n });\n }\n\n // Configure Linear integration\n if (config.enableLinear && config.linearApiKey) {\n console.log(chalk.gray('Configuring Linear integration...'));\n const linearConfig = {\n apiKey: config.linearApiKey,\n autoSync: true,\n syncInterval: 300000, // 5 minutes\n };\n \n writeFileSync(\n join(configPath, 'linear-config.json'),\n JSON.stringify(linearConfig, null, 2)\n );\n console.log(chalk.green(' \u2713 Linear configured'));\n }\n\n // Save main configuration\n const mainConfig = {\n version: '1.0.0',\n setupCompleted: new Date().toISOString(),\n features: {\n worktrees: config.enableWorktrees,\n projects: config.enableProjects,\n linear: config.enableLinear,\n analytics: config.enableAnalytics,\n },\n paths: {\n default: config.defaultContextPath,\n },\n };\n\n writeFileSync(\n join(configPath, 'config.json'),\n JSON.stringify(mainConfig, null, 2)\n );\n\n // Create claude-sm symlink for easy access\n const binPath = '/usr/local/bin/claude-sm';\n const sourcePath = join(configPath, 'bin', 'stackmemory');\n \n try {\n // Create wrapper script\n const wrapperScript = `#!/bin/bash\n# StackMemory CLI wrapper with worktree support\nCURRENT_DIR=$(pwd)\n\n# Auto-detect worktree if enabled\nif [ -f ~/.stackmemory/worktree-config.json ]; then\n WORKTREE_ENABLED=$(grep '\"enabled\": true' ~/.stackmemory/worktree-config.json)\n if [ ! -z \"$WORKTREE_ENABLED\" ]; then\n # Check if we're in a git worktree\n if git worktree list &>/dev/null; then\n export SM_WORKTREE_PATH=\"$CURRENT_DIR\"\n fi\n fi\nfi\n\n# Run StackMemory with context\nexec stackmemory \"$@\"\n`;\n\n writeFileSync(sourcePath, wrapperScript);\n execSync(`chmod +x ${sourcePath}`);\n\n // Create symlink if it doesn't exist\n if (!existsSync(binPath)) {\n execSync(`ln -s ${sourcePath} ${binPath}`);\n console.log(chalk.green(' \u2713 Created claude-sm command'));\n }\n } catch (error: unknown) {\n console.log(chalk.yellow(' \u26A0 Could not create claude-sm symlink (may need sudo)'));\n }\n}\n\nfunction showNextSteps(config: OnboardingConfig): void {\n console.log(chalk.cyan('\uD83C\uDF89 Next Steps:\\n'));\n\n console.log('1. Initialize StackMemory in your project:');\n console.log(chalk.gray(' cd your-project'));\n console.log(chalk.gray(' stackmemory init\\n'));\n\n if (config.enableWorktrees) {\n console.log('2. Create a new worktree:');\n console.log(chalk.gray(' git worktree add -b feature/new-feature ../project-feature'));\n console.log(chalk.gray(' cd ../project-feature'));\n console.log(chalk.gray(' stackmemory status # Isolated context for this worktree\\n'));\n }\n\n console.log('3. Use with Claude:');\n console.log(chalk.gray(' claude-sm # Or use stackmemory directly\\n'));\n\n if (config.enableLinear) {\n console.log('4. Sync with Linear:');\n console.log(chalk.gray(' stackmemory linear sync\\n'));\n }\n\n console.log('For more help:');\n console.log(chalk.gray(' stackmemory --help'));\n console.log(chalk.gray(' stackmemory projects --help'));\n if (config.enableWorktrees) {\n console.log(chalk.gray(' stackmemory worktree --help'));\n }\n}"],
5
- "mappings": "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",
4
+ "sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory Onboarding CLI\n * Interactive setup for new StackMemory installations\n */\n\nimport { Command } from 'commander';\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport { homedir } from 'os';\nimport { join } from 'path';\nimport { existsSync, mkdirSync, writeFileSync } from 'fs';\nimport { execSync } from 'child_process';\nimport { WorktreeManager } from '../../core/worktree/worktree-manager.js';\nimport { ProjectManager } from '../../core/projects/project-manager.js';\nimport { logger } from '../../core/monitoring/logger.js';\n\ninterface OnboardingConfig {\n setupType: 'basic' | 'advanced';\n enableWorktrees: boolean;\n worktreeIsolation: boolean;\n enableProjects: boolean;\n scanProjects: boolean;\n enableLinear: boolean;\n linearApiKey?: string;\n enableAnalytics: boolean;\n defaultContextPath: string;\n}\n\nexport function registerOnboardingCommand(program: Command): void {\n program\n .command('onboard')\n .alias('setup')\n .description('Interactive setup for StackMemory')\n .option('--reset', 'Reset all configurations and start fresh')\n .action(async (options) => {\n console.log(chalk.cyan('\\n\uD83D\uDE80 Welcome to StackMemory Setup!\\n'));\n\n // Check if already configured\n const configPath = join(homedir(), '.stackmemory');\n if (existsSync(configPath) && !options.reset) {\n const { proceed } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'proceed',\n message:\n 'StackMemory is already configured. Do you want to reconfigure?',\n default: false,\n },\n ]);\n\n if (!proceed) {\n console.log(chalk.yellow('\\nSetup cancelled.'));\n return;\n }\n }\n\n try {\n const config = await runOnboarding();\n await applyConfiguration(config);\n\n console.log(\n chalk.green('\\n\u2705 StackMemory setup completed successfully!\\n')\n );\n showNextSteps(config);\n } catch (error: unknown) {\n logger.error('Onboarding failed', error as Error);\n console.error(\n chalk.red('\\n\u274C Setup failed:'),\n (error as Error).message\n );\n process.exit(1);\n }\n });\n}\n\nasync function runOnboarding(): Promise<OnboardingConfig> {\n // Basic or Advanced Setup\n const { setupType } = await inquirer.prompt([\n {\n type: 'list',\n name: 'setupType',\n message: 'Choose your setup type:',\n choices: [\n { name: 'Basic (Recommended for most users)', value: 'basic' },\n { name: 'Advanced (Full customization)', value: 'advanced' },\n ],\n default: 'basic',\n },\n ]);\n\n let config: OnboardingConfig = {\n setupType,\n enableWorktrees: false,\n worktreeIsolation: true,\n enableProjects: true,\n scanProjects: false,\n enableLinear: false,\n enableAnalytics: true,\n defaultContextPath: join(homedir(), '.stackmemory'),\n };\n\n if (setupType === 'basic') {\n // Basic setup with sensible defaults\n const basicAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableWorktrees',\n message:\n 'Enable Git worktree support? (Recommended for multi-branch workflows)',\n default: false,\n },\n {\n type: 'confirm',\n name: 'scanProjects',\n message: 'Scan and organize your existing projects?',\n default: true,\n },\n {\n type: 'confirm',\n name: 'enableLinear',\n message: 'Connect to Linear for task management?',\n default: false,\n },\n ]);\n\n config = { ...config, ...basicAnswers };\n\n if (basicAnswers.enableLinear) {\n const { linearApiKey } = await inquirer.prompt([\n {\n type: 'password',\n name: 'linearApiKey',\n message: 'Enter your Linear API key:',\n validate: (input: string) =>\n input.length > 0 || 'API key is required',\n },\n ]);\n config.linearApiKey = linearApiKey;\n }\n } else {\n // Advanced setup with all options\n const advancedAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableWorktrees',\n message: 'Enable Git worktree support?',\n default: false,\n },\n ]);\n\n if (advancedAnswers.enableWorktrees) {\n const worktreeAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'worktreeIsolation',\n message: 'Isolate contexts between worktrees? (Recommended)',\n default: true,\n },\n {\n type: 'confirm',\n name: 'autoDetect',\n message: 'Auto-detect worktrees when switching directories?',\n default: true,\n },\n {\n type: 'confirm',\n name: 'shareGlobal',\n message: 'Share global context across worktrees?',\n default: false,\n },\n {\n type: 'number',\n name: 'syncInterval',\n message: 'Context sync interval in minutes (0 to disable):',\n default: 15,\n validate: (input: number) => input >= 0 || 'Must be 0 or positive',\n },\n ]);\n\n config = { ...config, ...advancedAnswers, ...worktreeAnswers };\n }\n\n const projectAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableProjects',\n message: 'Enable automatic project management?',\n default: true,\n },\n ]);\n\n if (projectAnswers.enableProjects) {\n const projectDetailAnswers: any = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'scanProjects',\n message: 'Scan for existing projects now?',\n default: true,\n },\n {\n type: 'checkbox',\n name: 'scanPaths',\n message: 'Select directories to scan:',\n choices: [\n { name: '~/Dev', value: join(homedir(), 'Dev'), checked: true },\n { name: '~/dev', value: join(homedir(), 'dev'), checked: true },\n {\n name: '~/Projects',\n value: join(homedir(), 'Projects'),\n checked: true,\n },\n {\n name: '~/projects',\n value: join(homedir(), 'projects'),\n checked: true,\n },\n { name: '~/Work', value: join(homedir(), 'Work'), checked: false },\n { name: '~/code', value: join(homedir(), 'code'), checked: true },\n {\n name: '~/Documents/GitHub',\n value: join(homedir(), 'Documents/GitHub'),\n checked: false,\n },\n ],\n when: (): boolean => projectDetailAnswers.scanProjects,\n },\n ]);\n\n config = { ...config, ...projectAnswers, ...projectDetailAnswers };\n }\n\n const integrationAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableLinear',\n message: 'Enable Linear integration?',\n default: false,\n },\n {\n type: 'password',\n name: 'linearApiKey',\n message: 'Linear API key:',\n when: (answers: any) => answers.enableLinear,\n validate: (input: string) => input.length > 0 || 'API key is required',\n },\n {\n type: 'confirm',\n name: 'enableAnalytics',\n message: 'Enable usage analytics? (Local only)',\n default: true,\n },\n {\n type: 'input',\n name: 'defaultContextPath',\n message: 'Default context storage path:',\n default: join(homedir(), '.stackmemory'),\n validate: (input: string) => input.length > 0 || 'Path is required',\n },\n ]);\n\n config = { ...config, ...integrationAnswers };\n }\n\n return config;\n}\n\nasync function applyConfiguration(config: OnboardingConfig): Promise<void> {\n const configPath = join(homedir(), '.stackmemory');\n\n // Create base directory structure\n console.log(chalk.gray('\\nCreating directory structure...'));\n const dirs = [\n configPath,\n join(configPath, 'contexts'),\n join(configPath, 'projects'),\n join(configPath, 'worktrees'),\n join(configPath, 'bin'),\n join(configPath, 'logs'),\n join(configPath, 'analytics'),\n ];\n\n for (const dir of dirs) {\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n }\n\n // Configure git worktree support\n if (config.enableWorktrees) {\n console.log(chalk.gray('Configuring worktree support...'));\n const worktreeManager = WorktreeManager.getInstance();\n worktreeManager.saveConfig({\n enabled: true,\n autoDetect: true,\n isolateContexts: config.worktreeIsolation,\n shareGlobalContext: false,\n syncInterval: 15,\n });\n\n // Detect current worktrees\n const worktrees = worktreeManager.detectWorktrees();\n if (worktrees.length > 0) {\n console.log(chalk.green(` \u2713 Found ${worktrees.length} worktree(s)`));\n worktrees.forEach((wt) => {\n console.log(chalk.gray(` - ${wt.branch} at ${wt.path}`));\n });\n }\n }\n\n // Scan and organize projects\n if (config.enableProjects && config.scanProjects) {\n console.log(chalk.gray('Scanning for projects...'));\n const projectManager = ProjectManager.getInstance();\n\n const scanPaths = (config as any).scanPaths || [\n join(homedir(), 'Dev'),\n join(homedir(), 'dev'),\n join(homedir(), 'Projects'),\n join(homedir(), 'projects'),\n join(homedir(), 'code'),\n ];\n\n await projectManager.scanAndCategorizeAllProjects(\n scanPaths.filter((p: string) => existsSync(p))\n );\n\n const projects = projectManager.getAllProjects();\n console.log(chalk.green(` \u2713 Found ${projects.length} project(s)`));\n\n // Show summary\n const byType: Record<string, number> = {};\n projects.forEach((p) => {\n byType[p.accountType] = (byType[p.accountType] || 0) + 1;\n });\n\n Object.entries(byType).forEach(([type, count]) => {\n console.log(chalk.gray(` - ${type}: ${count} project(s)`));\n });\n }\n\n // Configure Linear integration\n if (config.enableLinear && config.linearApiKey) {\n console.log(chalk.gray('Configuring Linear integration...'));\n const linearConfig = {\n apiKey: config.linearApiKey,\n autoSync: true,\n syncInterval: 300000, // 5 minutes\n };\n\n writeFileSync(\n join(configPath, 'linear-config.json'),\n JSON.stringify(linearConfig, null, 2)\n );\n console.log(chalk.green(' \u2713 Linear configured'));\n }\n\n // Save main configuration\n const mainConfig = {\n version: '1.0.0',\n setupCompleted: new Date().toISOString(),\n features: {\n worktrees: config.enableWorktrees,\n projects: config.enableProjects,\n linear: config.enableLinear,\n analytics: config.enableAnalytics,\n },\n paths: {\n default: config.defaultContextPath,\n },\n };\n\n writeFileSync(\n join(configPath, 'config.json'),\n JSON.stringify(mainConfig, null, 2)\n );\n\n // Create claude-sm symlink for easy access\n const binPath = '/usr/local/bin/claude-sm';\n const sourcePath = join(configPath, 'bin', 'stackmemory');\n\n try {\n // Create wrapper script\n const wrapperScript = `#!/bin/bash\n# StackMemory CLI wrapper with worktree support\nCURRENT_DIR=$(pwd)\n\n# Auto-detect worktree if enabled\nif [ -f ~/.stackmemory/worktree-config.json ]; then\n WORKTREE_ENABLED=$(grep '\"enabled\": true' ~/.stackmemory/worktree-config.json)\n if [ ! -z \"$WORKTREE_ENABLED\" ]; then\n # Check if we're in a git worktree\n if git worktree list &>/dev/null; then\n export SM_WORKTREE_PATH=\"$CURRENT_DIR\"\n fi\n fi\nfi\n\n# Run StackMemory with context\nexec stackmemory \"$@\"\n`;\n\n writeFileSync(sourcePath, wrapperScript);\n execSync(`chmod +x ${sourcePath}`);\n\n // Create symlink if it doesn't exist\n if (!existsSync(binPath)) {\n execSync(`ln -s ${sourcePath} ${binPath}`);\n console.log(chalk.green(' \u2713 Created claude-sm command'));\n }\n } catch (error: unknown) {\n console.log(\n chalk.yellow(' \u26A0 Could not create claude-sm symlink (may need sudo)')\n );\n }\n}\n\nfunction showNextSteps(config: OnboardingConfig): void {\n console.log(chalk.cyan('\uD83C\uDF89 Next Steps:\\n'));\n\n console.log('1. Initialize StackMemory in your project:');\n console.log(chalk.gray(' cd your-project'));\n console.log(chalk.gray(' stackmemory init\\n'));\n\n if (config.enableWorktrees) {\n console.log('2. Create a new worktree:');\n console.log(\n chalk.gray(\n ' git worktree add -b feature/new-feature ../project-feature'\n )\n );\n console.log(chalk.gray(' cd ../project-feature'));\n console.log(\n chalk.gray(\n ' stackmemory status # Isolated context for this worktree\\n'\n )\n );\n }\n\n console.log('3. Use with Claude:');\n console.log(chalk.gray(' claude-sm # Or use stackmemory directly\\n'));\n\n if (config.enableLinear) {\n console.log('4. Sync with Linear:');\n console.log(chalk.gray(' stackmemory linear sync\\n'));\n }\n\n console.log('For more help:');\n console.log(chalk.gray(' stackmemory --help'));\n console.log(chalk.gray(' stackmemory projects --help'));\n if (config.enableWorktrees) {\n console.log(chalk.gray(' stackmemory worktree --help'));\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -31,12 +31,7 @@ function createQualityCommand() {
31
31
  const db = new Database(dbPath);
32
32
  const frameManager = new FrameManager(db);
33
33
  if (options.enable) {
34
- await enableQualityGates(
35
- projectRoot,
36
- frameManager,
37
- db,
38
- spinner
39
- );
34
+ await enableQualityGates(projectRoot, frameManager, db, spinner);
40
35
  } else if (options.disable) {
41
36
  await disableQualityGates(projectRoot, spinner);
42
37
  } else if (options.status) {
@@ -298,7 +293,7 @@ async function setupWizard(projectRoot, frameManager, db) {
298
293
  );
299
294
  const packageJsonPath = path.join(projectRoot, "package.json");
300
295
  let projectType = "unknown";
301
- let detectedFrameworks = [];
296
+ const detectedFrameworks = [];
302
297
  try {
303
298
  const packageJson = JSON.parse(await fs.readFile(packageJsonPath, "utf-8"));
304
299
  const deps = {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/commands/quality.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n\n/**\n * Quality command for StackMemory\n * Manages post-task quality gates and code review automation\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport inquirer from 'inquirer';\nimport {\n PostTaskHooks,\n PostTaskConfig,\n QualityGateResult,\n} from '../../integrations/claude-code/post-task-hooks.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport Database from 'better-sqlite3';\n// getProjectRoot function will be defined below\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\n\nexport function createQualityCommand(): Command {\n const cmd = new Command('quality')\n .description('Manage post-task quality gates and automation')\n .option('--enable', 'Enable quality gates')\n .option('--disable', 'Disable quality gates')\n .option('--status', 'Show quality gate status')\n .option('--config', 'Configure quality gates')\n .option('--run', 'Run quality gates manually')\n .option('--history', 'Show quality gate history')\n .option('--setup', 'Interactive setup wizard')\n .action(async (options) => {\n const spinner = ora();\n\n try {\n const projectRoot = await getProjectRoot();\n const dbPath = path.join(\n projectRoot,\n '.stackmemory',\n 'db',\n 'stackmemory.db'\n );\n\n // Check if StackMemory is initialized\n try {\n await fs.access(dbPath);\n } catch {\n console.error(chalk.red('\u2717 StackMemory not initialized'));\n console.log(chalk.yellow('Run: stackmemory init'));\n process.exit(1);\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db);\n\n if (options.enable) {\n await enableQualityGates(\n projectRoot,\n frameManager,\n db,\n spinner\n );\n } else if (options.disable) {\n await disableQualityGates(projectRoot, spinner);\n } else if (options.status) {\n await showStatus(projectRoot, frameManager, db);\n } else if (options.config) {\n await configureQualityGates(projectRoot);\n } else if (options.run) {\n await runQualityGates(projectRoot, frameManager, db, spinner);\n } else if (options.history) {\n await showHistory(frameManager);\n } else if (options.setup) {\n await setupWizard(projectRoot, frameManager, db);\n } else {\n // Default: show status\n await showStatus(projectRoot, frameManager, db);\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Error: ${error}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\n/**\n * Enable quality gates\n */\nasync function enableQualityGates(\n projectRoot: string,\n frameManager: FrameManager,\n db: any,\n spinner: any\n) {\n spinner.start('Enabling quality gates...');\n\n try {\n // Load or create config\n const config = await loadConfig(projectRoot);\n config.qualityGates = {\n ...config.qualityGates,\n runTests: true,\n runCodeReview: true,\n runLinter: true,\n };\n\n // Initialize hooks\n const hooks = new PostTaskHooks(frameManager, db, config);\n await hooks.initialize();\n\n // Save config\n await saveConfig(projectRoot, config);\n\n // Create systemd-style service file for persistence\n await createServiceFile(projectRoot);\n\n spinner.succeed(chalk.green('\u2705 Quality gates enabled'));\n\n console.log(chalk.bold('\\n\uD83D\uDD0D Quality Gates Active:'));\n console.log(' \u2022 Auto-run tests after code changes');\n console.log(' \u2022 Auto-run linter on file saves');\n console.log(' \u2022 Auto-trigger code review on task completion');\n console.log(' \u2022 Real-time file change monitoring');\n\n console.log(chalk.gray('\\nDisable with: stackmemory quality --disable'));\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Failed to enable quality gates: ${error}`));\n }\n}\n\n/**\n * Disable quality gates\n */\nasync function disableQualityGates(projectRoot: string, spinner: ora.Ora) {\n spinner.start('Disabling quality gates...');\n\n try {\n const config = await loadConfig(projectRoot);\n config.qualityGates = {\n ...config.qualityGates,\n runTests: false,\n runCodeReview: false,\n runLinter: false,\n };\n\n await saveConfig(projectRoot, config);\n\n // Remove service file\n const serviceFile = path.join(\n projectRoot,\n '.stackmemory',\n 'quality.service'\n );\n try {\n await fs.unlink(serviceFile);\n } catch {\n // Service file doesn't exist\n }\n\n spinner.succeed(chalk.green('\u2705 Quality gates disabled'));\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Failed to disable quality gates: ${error}`));\n }\n}\n\n/**\n * Show quality gate status\n */\nasync function showStatus(\n projectRoot: string,\n frameManager: FrameManager,\n db: Database\n) {\n console.log(chalk.bold('\\n\uD83D\uDCCA Quality Gates Status\\n'));\n\n try {\n const config = await loadConfig(projectRoot);\n\n // Overall status\n const isEnabled =\n config.qualityGates?.runTests ||\n config.qualityGates?.runCodeReview ||\n config.qualityGates?.runLinter;\n console.log(\n `Status: ${isEnabled ? chalk.green('\u2705 Enabled') : chalk.yellow('\u26A0\uFE0F Disabled')}`\n );\n\n // Individual gates\n console.log('\\nGates:');\n console.log(\n ` Tests: ${config.qualityGates?.runTests ? '\u2705' : '\u274C'} ${getTestCommand(config)}`\n );\n console.log(\n ` Linter: ${config.qualityGates?.runLinter ? '\u2705' : '\u274C'} ${getLintCommand(config)}`\n );\n console.log(\n ` Code Review: ${config.qualityGates?.runCodeReview ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Coverage: ${config.qualityGates?.requireTestCoverage ? '\u2705' : '\u274C'}`\n );\n\n // Detected frameworks\n if (config.testFrameworks?.detected.length) {\n console.log('\\nDetected Frameworks:');\n config.testFrameworks.detected.forEach((fw) => {\n console.log(` \u2022 ${fw}`);\n });\n }\n\n // Recent quality results\n const recentResults = await getRecentQualityResults(frameManager);\n if (recentResults.length > 0) {\n console.log('\\nRecent Results:');\n recentResults.slice(0, 3).forEach((result) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n console.log(\n ` ${icon} ${result.frameName} (${new Date(result.timestamp).toLocaleString()})`\n );\n });\n }\n } catch (error: unknown) {\n console.error(chalk.red('Failed to get status:', error));\n }\n}\n\n/**\n * Configure quality gates\n */\nasync function configureQualityGates(projectRoot: string) {\n console.log(chalk.bold('\\n\u2699\uFE0F Quality Gates Configuration\\n'));\n\n try {\n const config = await loadConfig(projectRoot);\n\n const answers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'runTests',\n message: 'Auto-run tests after code changes?',\n default: config.qualityGates?.runTests ?? true,\n },\n {\n type: 'confirm',\n name: 'runLinter',\n message: 'Auto-run linter on file changes?',\n default: config.qualityGates?.runLinter ?? true,\n },\n {\n type: 'confirm',\n name: 'runCodeReview',\n message: 'Auto-trigger code review on task completion?',\n default: config.qualityGates?.runCodeReview ?? true,\n },\n {\n type: 'confirm',\n name: 'requireTestCoverage',\n message: 'Require test coverage checks?',\n default: config.qualityGates?.requireTestCoverage ?? false,\n },\n {\n type: 'confirm',\n name: 'blockOnFailure',\n message: 'Block further work when quality gates fail?',\n default: config.qualityGates?.blockOnFailure ?? false,\n },\n {\n type: 'input',\n name: 'testCommand',\n message: 'Custom test command (leave empty for auto-detect):',\n default: config.testFrameworks?.testCommand || '',\n },\n {\n type: 'input',\n name: 'lintCommand',\n message: 'Custom lint command (leave empty for auto-detect):',\n default: config.testFrameworks?.lintCommand || '',\n },\n ]);\n\n // Update config\n config.qualityGates = {\n runTests: answers.runTests,\n runLinter: answers.runLinter,\n runCodeReview: answers.runCodeReview,\n requireTestCoverage: answers.requireTestCoverage,\n blockOnFailure: answers.blockOnFailure,\n };\n\n config.testFrameworks = {\n ...config.testFrameworks,\n testCommand: answers.testCommand || config.testFrameworks?.testCommand,\n lintCommand: answers.lintCommand || config.testFrameworks?.lintCommand,\n };\n\n await saveConfig(projectRoot, config);\n\n console.log(chalk.green('\\n\u2705 Configuration saved'));\n console.log(chalk.gray('Enable with: stackmemory quality --enable'));\n } catch (error: unknown) {\n console.error(chalk.red('Configuration failed:', error));\n }\n}\n\n/**\n * Run quality gates manually\n */\nasync function runQualityGates(\n projectRoot: string,\n frameManager: FrameManager,\n db: any,\n spinner: any\n) {\n spinner.start('Running quality gates...');\n\n try {\n const config = await loadConfig(projectRoot);\n const hooks = new PostTaskHooks(frameManager, db, config);\n\n // Simulate a task completion event\n const mockEvent = {\n taskType: 'task_complete' as const,\n frameId: 'manual-run',\n frameName: 'Manual quality gate run',\n files: await getRecentlyModifiedFiles(projectRoot),\n changes: { added: 0, removed: 0, modified: 1 },\n metadata: { trigger: 'manual' },\n };\n\n // Run quality gates\n const results = await (hooks as any).runQualityGates(mockEvent);\n\n spinner.succeed(chalk.green('\u2705 Quality gates completed'));\n\n // Show results\n console.log(chalk.bold('\\n\uD83D\uDCCB Quality Gate Results:\\n'));\n\n results.forEach((result: QualityGateResult) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n const duration =\n result.duration < 1000\n ? `${result.duration}ms`\n : `${Math.round(result.duration / 1000)}s`;\n\n console.log(`${icon} ${result.gate} (${duration})`);\n\n if (!result.passed && result.issues) {\n result.issues.slice(0, 3).forEach((issue) => {\n console.log(\n ` ${issue.severity === 'error' ? '\u274C' : '\u26A0\uFE0F'} ${issue.message}`\n );\n });\n if (result.issues.length > 3) {\n console.log(\n chalk.gray(` ... and ${result.issues.length - 3} more issues`)\n );\n }\n }\n });\n\n const allPassed = results.every((r: QualityGateResult) => r.passed);\n if (allPassed) {\n console.log(chalk.green('\\n\uD83C\uDF89 All quality gates passed!'));\n } else {\n console.log(\n chalk.yellow('\\n\u26A0\uFE0F Some quality gates failed. See details above.')\n );\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Quality gates failed: ${error}`));\n }\n}\n\n/**\n * Show quality gate history\n */\nasync function showHistory(frameManager: FrameManager) {\n console.log(chalk.bold('\\n\uD83D\uDCC8 Quality Gate History\\n'));\n\n try {\n const results = await getRecentQualityResults(frameManager);\n\n if (results.length === 0) {\n console.log(chalk.gray('No quality gate history found'));\n return;\n }\n\n results.slice(0, 10).forEach((result, index) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n const date = new Date(result.timestamp).toLocaleDateString();\n const time = new Date(result.timestamp).toLocaleTimeString();\n\n console.log(`${icon} ${result.frameName}`);\n console.log(chalk.gray(` ${date} ${time} - ${result.duration}ms`));\n\n if (result.gates) {\n result.gates.forEach((gate: any) => {\n const gateIcon = gate.passed ? ' \u2713' : ' \u2717';\n console.log(chalk.gray(`${gateIcon} ${gate.gate}`));\n });\n }\n\n if (index < results.length - 1) console.log('');\n });\n } catch (error: unknown) {\n console.error(chalk.red('Failed to get history:', error));\n }\n}\n\n/**\n * Setup wizard\n */\nasync function setupWizard(\n projectRoot: string,\n frameManager: FrameManager,\n db: Database\n) {\n console.log(chalk.bold('\uD83E\uDDD9 Quality Gates Setup Wizard\\n'));\n\n console.log(\n 'This wizard will help you configure automatic quality gates for your project.'\n );\n console.log(\n 'Quality gates run automatically after Claude completes tasks.\\n'\n );\n\n // Detect project type\n const packageJsonPath = path.join(projectRoot, 'package.json');\n let projectType = 'unknown';\n let detectedFrameworks: string[] = [];\n\n try {\n const packageJson = JSON.parse(await fs.readFile(packageJsonPath, 'utf-8'));\n const deps = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies,\n };\n\n if (deps.react) projectType = 'React';\n else if (deps.vue) projectType = 'Vue';\n else if (deps.angular) projectType = 'Angular';\n else if (deps.express) projectType = 'Node.js API';\n else if (deps.nextjs) projectType = 'Next.js';\n\n if (deps.jest) detectedFrameworks.push('Jest');\n if (deps.vitest) detectedFrameworks.push('Vitest');\n if (deps.playwright) detectedFrameworks.push('Playwright');\n if (deps.eslint) detectedFrameworks.push('ESLint');\n } catch {\n // No package.json or invalid\n }\n\n console.log(`\uD83D\uDCE6 Detected project: ${chalk.cyan(projectType)}`);\n if (detectedFrameworks.length) {\n console.log(\n `\uD83D\uDD27 Detected tools: ${chalk.cyan(detectedFrameworks.join(', '))}`\n );\n }\n console.log('');\n\n const { proceed } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'proceed',\n message: 'Continue with setup?',\n default: true,\n },\n ]);\n\n if (!proceed) {\n console.log(chalk.gray('Setup cancelled'));\n return;\n }\n\n // Configure quality gates\n await configureQualityGates(projectRoot);\n\n // Enable quality gates\n const { enable } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enable',\n message: 'Enable quality gates now?',\n default: true,\n },\n ]);\n\n if (enable) {\n const spinner = ora();\n await enableQualityGates(projectRoot, frameManager, db, spinner);\n }\n\n console.log(chalk.bold('\\n\uD83C\uDF89 Setup Complete!\\n'));\n console.log(\n 'Quality gates will now run automatically after Claude completes tasks.'\n );\n console.log('Check status with: stackmemory quality --status');\n}\n\n// Helper functions\n\nasync function getProjectRoot(): Promise<string> {\n return process.cwd();\n}\n\nasync function loadConfig(\n projectRoot: string\n): Promise<Partial<PostTaskConfig>> {\n const configPath = path.join(projectRoot, '.stackmemory', 'config.json');\n\n try {\n const content = await fs.readFile(configPath, 'utf-8');\n return JSON.parse(content);\n } catch {\n return {};\n }\n}\n\nasync function saveConfig(\n projectRoot: string,\n config: Partial<PostTaskConfig>\n): Promise<void> {\n const configPath = path.join(projectRoot, '.stackmemory', 'config.json');\n await fs.mkdir(path.dirname(configPath), { recursive: true });\n await fs.writeFile(configPath, JSON.stringify(config, null, 2), 'utf-8');\n}\n\nfunction getTestCommand(config: Partial<PostTaskConfig>): string {\n if (config.testFrameworks?.testCommand) {\n return chalk.gray(`(${config.testFrameworks.testCommand})`);\n }\n return chalk.gray('(auto-detect)');\n}\n\nfunction getLintCommand(config: Partial<PostTaskConfig>): string {\n if (config.testFrameworks?.lintCommand) {\n return chalk.gray(`(${config.testFrameworks.lintCommand})`);\n }\n return chalk.gray('(auto-detect)');\n}\n\nasync function getRecentQualityResults(\n frameManager: FrameManager\n): Promise<any[]> {\n // This would query the frame metadata for quality gate results\n // For now, return empty array\n return [];\n}\n\nasync function getRecentlyModifiedFiles(\n projectRoot: string\n): Promise<string[]> {\n try {\n const { execSync } = await import('child_process');\n const output = execSync('git diff --name-only HEAD~1', {\n cwd: projectRoot,\n encoding: 'utf-8',\n });\n return output\n .trim()\n .split('\\n')\n .filter((f) => f.length > 0);\n } catch {\n return [];\n }\n}\n\nasync function createServiceFile(projectRoot: string): Promise<void> {\n const serviceContent = `# StackMemory Quality Gates Service\n# This file indicates quality gates are enabled\n# Created: ${new Date().toISOString()}\n`;\n\n const servicePath = path.join(projectRoot, '.stackmemory', 'quality.service');\n await fs.writeFile(servicePath, serviceContent, 'utf-8');\n}\n\n// Export for use in main CLI\nexport default createQualityCommand();\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["#!/usr/bin/env node\n\n/**\n * Quality command for StackMemory\n * Manages post-task quality gates and code review automation\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport inquirer from 'inquirer';\nimport {\n PostTaskHooks,\n PostTaskConfig,\n QualityGateResult,\n} from '../../integrations/claude-code/post-task-hooks.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport Database from 'better-sqlite3';\n// getProjectRoot function will be defined below\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\n\nexport function createQualityCommand(): Command {\n const cmd = new Command('quality')\n .description('Manage post-task quality gates and automation')\n .option('--enable', 'Enable quality gates')\n .option('--disable', 'Disable quality gates')\n .option('--status', 'Show quality gate status')\n .option('--config', 'Configure quality gates')\n .option('--run', 'Run quality gates manually')\n .option('--history', 'Show quality gate history')\n .option('--setup', 'Interactive setup wizard')\n .action(async (options) => {\n const spinner = ora();\n\n try {\n const projectRoot = await getProjectRoot();\n const dbPath = path.join(\n projectRoot,\n '.stackmemory',\n 'db',\n 'stackmemory.db'\n );\n\n // Check if StackMemory is initialized\n try {\n await fs.access(dbPath);\n } catch {\n console.error(chalk.red('\u2717 StackMemory not initialized'));\n console.log(chalk.yellow('Run: stackmemory init'));\n process.exit(1);\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db);\n\n if (options.enable) {\n await enableQualityGates(projectRoot, frameManager, db, spinner);\n } else if (options.disable) {\n await disableQualityGates(projectRoot, spinner);\n } else if (options.status) {\n await showStatus(projectRoot, frameManager, db);\n } else if (options.config) {\n await configureQualityGates(projectRoot);\n } else if (options.run) {\n await runQualityGates(projectRoot, frameManager, db, spinner);\n } else if (options.history) {\n await showHistory(frameManager);\n } else if (options.setup) {\n await setupWizard(projectRoot, frameManager, db);\n } else {\n // Default: show status\n await showStatus(projectRoot, frameManager, db);\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Error: ${error}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\n/**\n * Enable quality gates\n */\nasync function enableQualityGates(\n projectRoot: string,\n frameManager: FrameManager,\n db: any,\n spinner: any\n) {\n spinner.start('Enabling quality gates...');\n\n try {\n // Load or create config\n const config = await loadConfig(projectRoot);\n config.qualityGates = {\n ...config.qualityGates,\n runTests: true,\n runCodeReview: true,\n runLinter: true,\n };\n\n // Initialize hooks\n const hooks = new PostTaskHooks(frameManager, db, config);\n await hooks.initialize();\n\n // Save config\n await saveConfig(projectRoot, config);\n\n // Create systemd-style service file for persistence\n await createServiceFile(projectRoot);\n\n spinner.succeed(chalk.green('\u2705 Quality gates enabled'));\n\n console.log(chalk.bold('\\n\uD83D\uDD0D Quality Gates Active:'));\n console.log(' \u2022 Auto-run tests after code changes');\n console.log(' \u2022 Auto-run linter on file saves');\n console.log(' \u2022 Auto-trigger code review on task completion');\n console.log(' \u2022 Real-time file change monitoring');\n\n console.log(chalk.gray('\\nDisable with: stackmemory quality --disable'));\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Failed to enable quality gates: ${error}`));\n }\n}\n\n/**\n * Disable quality gates\n */\nasync function disableQualityGates(projectRoot: string, spinner: ora.Ora) {\n spinner.start('Disabling quality gates...');\n\n try {\n const config = await loadConfig(projectRoot);\n config.qualityGates = {\n ...config.qualityGates,\n runTests: false,\n runCodeReview: false,\n runLinter: false,\n };\n\n await saveConfig(projectRoot, config);\n\n // Remove service file\n const serviceFile = path.join(\n projectRoot,\n '.stackmemory',\n 'quality.service'\n );\n try {\n await fs.unlink(serviceFile);\n } catch {\n // Service file doesn't exist\n }\n\n spinner.succeed(chalk.green('\u2705 Quality gates disabled'));\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Failed to disable quality gates: ${error}`));\n }\n}\n\n/**\n * Show quality gate status\n */\nasync function showStatus(\n projectRoot: string,\n frameManager: FrameManager,\n db: Database\n) {\n console.log(chalk.bold('\\n\uD83D\uDCCA Quality Gates Status\\n'));\n\n try {\n const config = await loadConfig(projectRoot);\n\n // Overall status\n const isEnabled =\n config.qualityGates?.runTests ||\n config.qualityGates?.runCodeReview ||\n config.qualityGates?.runLinter;\n console.log(\n `Status: ${isEnabled ? chalk.green('\u2705 Enabled') : chalk.yellow('\u26A0\uFE0F Disabled')}`\n );\n\n // Individual gates\n console.log('\\nGates:');\n console.log(\n ` Tests: ${config.qualityGates?.runTests ? '\u2705' : '\u274C'} ${getTestCommand(config)}`\n );\n console.log(\n ` Linter: ${config.qualityGates?.runLinter ? '\u2705' : '\u274C'} ${getLintCommand(config)}`\n );\n console.log(\n ` Code Review: ${config.qualityGates?.runCodeReview ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Coverage: ${config.qualityGates?.requireTestCoverage ? '\u2705' : '\u274C'}`\n );\n\n // Detected frameworks\n if (config.testFrameworks?.detected.length) {\n console.log('\\nDetected Frameworks:');\n config.testFrameworks.detected.forEach((fw) => {\n console.log(` \u2022 ${fw}`);\n });\n }\n\n // Recent quality results\n const recentResults = await getRecentQualityResults(frameManager);\n if (recentResults.length > 0) {\n console.log('\\nRecent Results:');\n recentResults.slice(0, 3).forEach((result) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n console.log(\n ` ${icon} ${result.frameName} (${new Date(result.timestamp).toLocaleString()})`\n );\n });\n }\n } catch (error: unknown) {\n console.error(chalk.red('Failed to get status:', error));\n }\n}\n\n/**\n * Configure quality gates\n */\nasync function configureQualityGates(projectRoot: string) {\n console.log(chalk.bold('\\n\u2699\uFE0F Quality Gates Configuration\\n'));\n\n try {\n const config = await loadConfig(projectRoot);\n\n const answers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'runTests',\n message: 'Auto-run tests after code changes?',\n default: config.qualityGates?.runTests ?? true,\n },\n {\n type: 'confirm',\n name: 'runLinter',\n message: 'Auto-run linter on file changes?',\n default: config.qualityGates?.runLinter ?? true,\n },\n {\n type: 'confirm',\n name: 'runCodeReview',\n message: 'Auto-trigger code review on task completion?',\n default: config.qualityGates?.runCodeReview ?? true,\n },\n {\n type: 'confirm',\n name: 'requireTestCoverage',\n message: 'Require test coverage checks?',\n default: config.qualityGates?.requireTestCoverage ?? false,\n },\n {\n type: 'confirm',\n name: 'blockOnFailure',\n message: 'Block further work when quality gates fail?',\n default: config.qualityGates?.blockOnFailure ?? false,\n },\n {\n type: 'input',\n name: 'testCommand',\n message: 'Custom test command (leave empty for auto-detect):',\n default: config.testFrameworks?.testCommand || '',\n },\n {\n type: 'input',\n name: 'lintCommand',\n message: 'Custom lint command (leave empty for auto-detect):',\n default: config.testFrameworks?.lintCommand || '',\n },\n ]);\n\n // Update config\n config.qualityGates = {\n runTests: answers.runTests,\n runLinter: answers.runLinter,\n runCodeReview: answers.runCodeReview,\n requireTestCoverage: answers.requireTestCoverage,\n blockOnFailure: answers.blockOnFailure,\n };\n\n config.testFrameworks = {\n ...config.testFrameworks,\n testCommand: answers.testCommand || config.testFrameworks?.testCommand,\n lintCommand: answers.lintCommand || config.testFrameworks?.lintCommand,\n };\n\n await saveConfig(projectRoot, config);\n\n console.log(chalk.green('\\n\u2705 Configuration saved'));\n console.log(chalk.gray('Enable with: stackmemory quality --enable'));\n } catch (error: unknown) {\n console.error(chalk.red('Configuration failed:', error));\n }\n}\n\n/**\n * Run quality gates manually\n */\nasync function runQualityGates(\n projectRoot: string,\n frameManager: FrameManager,\n db: any,\n spinner: any\n) {\n spinner.start('Running quality gates...');\n\n try {\n const config = await loadConfig(projectRoot);\n const hooks = new PostTaskHooks(frameManager, db, config);\n\n // Simulate a task completion event\n const mockEvent = {\n taskType: 'task_complete' as const,\n frameId: 'manual-run',\n frameName: 'Manual quality gate run',\n files: await getRecentlyModifiedFiles(projectRoot),\n changes: { added: 0, removed: 0, modified: 1 },\n metadata: { trigger: 'manual' },\n };\n\n // Run quality gates\n const results = await (hooks as any).runQualityGates(mockEvent);\n\n spinner.succeed(chalk.green('\u2705 Quality gates completed'));\n\n // Show results\n console.log(chalk.bold('\\n\uD83D\uDCCB Quality Gate Results:\\n'));\n\n results.forEach((result: QualityGateResult) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n const duration =\n result.duration < 1000\n ? `${result.duration}ms`\n : `${Math.round(result.duration / 1000)}s`;\n\n console.log(`${icon} ${result.gate} (${duration})`);\n\n if (!result.passed && result.issues) {\n result.issues.slice(0, 3).forEach((issue) => {\n console.log(\n ` ${issue.severity === 'error' ? '\u274C' : '\u26A0\uFE0F'} ${issue.message}`\n );\n });\n if (result.issues.length > 3) {\n console.log(\n chalk.gray(` ... and ${result.issues.length - 3} more issues`)\n );\n }\n }\n });\n\n const allPassed = results.every((r: QualityGateResult) => r.passed);\n if (allPassed) {\n console.log(chalk.green('\\n\uD83C\uDF89 All quality gates passed!'));\n } else {\n console.log(\n chalk.yellow('\\n\u26A0\uFE0F Some quality gates failed. See details above.')\n );\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Quality gates failed: ${error}`));\n }\n}\n\n/**\n * Show quality gate history\n */\nasync function showHistory(frameManager: FrameManager) {\n console.log(chalk.bold('\\n\uD83D\uDCC8 Quality Gate History\\n'));\n\n try {\n const results = await getRecentQualityResults(frameManager);\n\n if (results.length === 0) {\n console.log(chalk.gray('No quality gate history found'));\n return;\n }\n\n results.slice(0, 10).forEach((result, index) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n const date = new Date(result.timestamp).toLocaleDateString();\n const time = new Date(result.timestamp).toLocaleTimeString();\n\n console.log(`${icon} ${result.frameName}`);\n console.log(chalk.gray(` ${date} ${time} - ${result.duration}ms`));\n\n if (result.gates) {\n result.gates.forEach((gate: any) => {\n const gateIcon = gate.passed ? ' \u2713' : ' \u2717';\n console.log(chalk.gray(`${gateIcon} ${gate.gate}`));\n });\n }\n\n if (index < results.length - 1) console.log('');\n });\n } catch (error: unknown) {\n console.error(chalk.red('Failed to get history:', error));\n }\n}\n\n/**\n * Setup wizard\n */\nasync function setupWizard(\n projectRoot: string,\n frameManager: FrameManager,\n db: Database\n) {\n console.log(chalk.bold('\uD83E\uDDD9 Quality Gates Setup Wizard\\n'));\n\n console.log(\n 'This wizard will help you configure automatic quality gates for your project.'\n );\n console.log(\n 'Quality gates run automatically after Claude completes tasks.\\n'\n );\n\n // Detect project type\n const packageJsonPath = path.join(projectRoot, 'package.json');\n let projectType = 'unknown';\n const detectedFrameworks: string[] = [];\n\n try {\n const packageJson = JSON.parse(await fs.readFile(packageJsonPath, 'utf-8'));\n const deps = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies,\n };\n\n if (deps.react) projectType = 'React';\n else if (deps.vue) projectType = 'Vue';\n else if (deps.angular) projectType = 'Angular';\n else if (deps.express) projectType = 'Node.js API';\n else if (deps.nextjs) projectType = 'Next.js';\n\n if (deps.jest) detectedFrameworks.push('Jest');\n if (deps.vitest) detectedFrameworks.push('Vitest');\n if (deps.playwright) detectedFrameworks.push('Playwright');\n if (deps.eslint) detectedFrameworks.push('ESLint');\n } catch {\n // No package.json or invalid\n }\n\n console.log(`\uD83D\uDCE6 Detected project: ${chalk.cyan(projectType)}`);\n if (detectedFrameworks.length) {\n console.log(\n `\uD83D\uDD27 Detected tools: ${chalk.cyan(detectedFrameworks.join(', '))}`\n );\n }\n console.log('');\n\n const { proceed } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'proceed',\n message: 'Continue with setup?',\n default: true,\n },\n ]);\n\n if (!proceed) {\n console.log(chalk.gray('Setup cancelled'));\n return;\n }\n\n // Configure quality gates\n await configureQualityGates(projectRoot);\n\n // Enable quality gates\n const { enable } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enable',\n message: 'Enable quality gates now?',\n default: true,\n },\n ]);\n\n if (enable) {\n const spinner = ora();\n await enableQualityGates(projectRoot, frameManager, db, spinner);\n }\n\n console.log(chalk.bold('\\n\uD83C\uDF89 Setup Complete!\\n'));\n console.log(\n 'Quality gates will now run automatically after Claude completes tasks.'\n );\n console.log('Check status with: stackmemory quality --status');\n}\n\n// Helper functions\n\nasync function getProjectRoot(): Promise<string> {\n return process.cwd();\n}\n\nasync function loadConfig(\n projectRoot: string\n): Promise<Partial<PostTaskConfig>> {\n const configPath = path.join(projectRoot, '.stackmemory', 'config.json');\n\n try {\n const content = await fs.readFile(configPath, 'utf-8');\n return JSON.parse(content);\n } catch {\n return {};\n }\n}\n\nasync function saveConfig(\n projectRoot: string,\n config: Partial<PostTaskConfig>\n): Promise<void> {\n const configPath = path.join(projectRoot, '.stackmemory', 'config.json');\n await fs.mkdir(path.dirname(configPath), { recursive: true });\n await fs.writeFile(configPath, JSON.stringify(config, null, 2), 'utf-8');\n}\n\nfunction getTestCommand(config: Partial<PostTaskConfig>): string {\n if (config.testFrameworks?.testCommand) {\n return chalk.gray(`(${config.testFrameworks.testCommand})`);\n }\n return chalk.gray('(auto-detect)');\n}\n\nfunction getLintCommand(config: Partial<PostTaskConfig>): string {\n if (config.testFrameworks?.lintCommand) {\n return chalk.gray(`(${config.testFrameworks.lintCommand})`);\n }\n return chalk.gray('(auto-detect)');\n}\n\nasync function getRecentQualityResults(\n frameManager: FrameManager\n): Promise<any[]> {\n // This would query the frame metadata for quality gate results\n // For now, return empty array\n return [];\n}\n\nasync function getRecentlyModifiedFiles(\n projectRoot: string\n): Promise<string[]> {\n try {\n const { execSync } = await import('child_process');\n const output = execSync('git diff --name-only HEAD~1', {\n cwd: projectRoot,\n encoding: 'utf-8',\n });\n return output\n .trim()\n .split('\\n')\n .filter((f) => f.length > 0);\n } catch {\n return [];\n }\n}\n\nasync function createServiceFile(projectRoot: string): Promise<void> {\n const serviceContent = `# StackMemory Quality Gates Service\n# This file indicates quality gates are enabled\n# Created: ${new Date().toISOString()}\n`;\n\n const servicePath = path.join(projectRoot, '.stackmemory', 'quality.service');\n await fs.writeFile(servicePath, serviceContent, 'utf-8');\n}\n\n// Export for use in main CLI\nexport default createQualityCommand();\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -3,7 +3,9 @@ import { sessionManager } from "../../core/session/index.js";
3
3
  import { logger } from "../../core/monitoring/logger.js";
4
4
  import chalk from "chalk";
5
5
  function createSessionCommands() {
6
- const sessionCommand = new Command("session").description("Manage StackMemory sessions");
6
+ const sessionCommand = new Command("session").description(
7
+ "Manage StackMemory sessions"
8
+ );
7
9
  sessionCommand.command("list").description("List all sessions").option("--project", "Show only sessions for current project").option("--active", "Show only active sessions").option("--all", "Show all sessions including closed").action(async (options) => {
8
10
  try {
9
11
  await sessionManager.initialize();
@@ -66,7 +68,10 @@ function createSessionCommands() {
66
68
  }
67
69
  } catch (error) {
68
70
  logger.error("Failed to show current session", error);
69
- console.error("\u274C Failed to show current session:", error.message);
71
+ console.error(
72
+ "\u274C Failed to show current session:",
73
+ error.message
74
+ );
70
75
  process.exit(1);
71
76
  }
72
77
  });
@@ -79,7 +84,11 @@ function createSessionCommands() {
79
84
  console.log(`Suspended session: ${current.sessionId.slice(0, 8)}`);
80
85
  }
81
86
  const session = await sessionManager.resumeSession(sessionId);
82
- console.log(chalk.green(`\u2705 Switched to session: ${session.sessionId.slice(0, 8)}`));
87
+ console.log(
88
+ chalk.green(
89
+ `\u2705 Switched to session: ${session.sessionId.slice(0, 8)}`
90
+ )
91
+ );
83
92
  console.log(` Project: ${session.projectId}`);
84
93
  if (session.branch) {
85
94
  console.log(` Branch: ${session.branch}`);
@@ -98,7 +107,10 @@ function createSessionCommands() {
98
107
  console.log(chalk.yellow(`\u23F8\uFE0F Suspended session: ${id?.slice(0, 8)}`));
99
108
  } catch (error) {
100
109
  logger.error("Failed to suspend session", error);
101
- console.error("\u274C Failed to suspend session:", error.message);
110
+ console.error(
111
+ "\u274C Failed to suspend session:",
112
+ error.message
113
+ );
102
114
  process.exit(1);
103
115
  }
104
116
  });
@@ -106,7 +118,9 @@ function createSessionCommands() {
106
118
  try {
107
119
  await sessionManager.initialize();
108
120
  const session = await sessionManager.resumeSession(sessionId);
109
- console.log(chalk.green(`\u25B6\uFE0F Resumed session: ${session.sessionId.slice(0, 8)}`));
121
+ console.log(
122
+ chalk.green(`\u25B6\uFE0F Resumed session: ${session.sessionId.slice(0, 8)}`)
123
+ );
110
124
  console.log(` Project: ${session.projectId}`);
111
125
  if (session.branch) {
112
126
  console.log(` Branch: ${session.branch}`);
@@ -139,7 +153,10 @@ function createSessionCommands() {
139
153
  console.log(chalk.green(`\u2705 Cleaned up ${cleaned} old session(s)`));
140
154
  } catch (error) {
141
155
  logger.error("Failed to cleanup sessions", error);
142
- console.error("\u274C Failed to cleanup sessions:", error.message);
156
+ console.error(
157
+ "\u274C Failed to cleanup sessions:",
158
+ error.message
159
+ );
143
160
  process.exit(1);
144
161
  }
145
162
  });