@stackmemoryai/stackmemory 0.5.66 → 0.6.0

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 (58) hide show
  1. package/README.md +139 -45
  2. package/bin/codex-sm +6 -0
  3. package/bin/opencode-sm +1 -1
  4. package/dist/src/cli/claude-sm.js +162 -25
  5. package/dist/src/cli/claude-sm.js.map +2 -2
  6. package/dist/src/cli/commands/ping.js +14 -0
  7. package/dist/src/cli/commands/ping.js.map +7 -0
  8. package/dist/src/cli/commands/ralph.js +103 -1
  9. package/dist/src/cli/commands/ralph.js.map +2 -2
  10. package/dist/src/cli/commands/retrieval.js +1 -1
  11. package/dist/src/cli/commands/retrieval.js.map +2 -2
  12. package/dist/src/cli/commands/skills.js +201 -6
  13. package/dist/src/cli/commands/skills.js.map +2 -2
  14. package/dist/src/cli/index.js +66 -27
  15. package/dist/src/cli/index.js.map +2 -2
  16. package/dist/src/core/digest/types.js +1 -1
  17. package/dist/src/core/digest/types.js.map +1 -1
  18. package/dist/src/core/extensions/provider-adapter.js +2 -5
  19. package/dist/src/core/extensions/provider-adapter.js.map +2 -2
  20. package/dist/src/core/retrieval/llm-provider.js +2 -2
  21. package/dist/src/core/retrieval/llm-provider.js.map +1 -1
  22. package/dist/src/core/retrieval/types.js +1 -1
  23. package/dist/src/core/retrieval/types.js.map +1 -1
  24. package/dist/src/features/sweep/pty-wrapper.js +15 -5
  25. package/dist/src/features/sweep/pty-wrapper.js.map +2 -2
  26. package/dist/src/features/workers/tmux-manager.js +71 -0
  27. package/dist/src/features/workers/tmux-manager.js.map +7 -0
  28. package/dist/src/features/workers/worker-registry.js +52 -0
  29. package/dist/src/features/workers/worker-registry.js.map +7 -0
  30. package/dist/src/integrations/linear/webhook-handler.js +82 -0
  31. package/dist/src/integrations/linear/webhook-handler.js.map +2 -2
  32. package/dist/src/integrations/mcp/server.js +16 -10
  33. package/dist/src/integrations/mcp/server.js.map +2 -2
  34. package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js +2 -2
  35. package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js.map +2 -2
  36. package/dist/src/orchestrators/multimodal/constants.js +1 -1
  37. package/dist/src/orchestrators/multimodal/constants.js.map +1 -1
  38. package/dist/src/orchestrators/multimodal/harness.js +28 -29
  39. package/dist/src/orchestrators/multimodal/harness.js.map +2 -2
  40. package/dist/src/orchestrators/multimodal/providers.js +35 -22
  41. package/dist/src/orchestrators/multimodal/providers.js.map +2 -2
  42. package/dist/src/skills/claude-skills.js +116 -1
  43. package/dist/src/skills/claude-skills.js.map +2 -2
  44. package/dist/src/skills/linear-task-runner.js +262 -0
  45. package/dist/src/skills/linear-task-runner.js.map +7 -0
  46. package/dist/src/skills/recursive-agent-orchestrator.js +114 -85
  47. package/dist/src/skills/recursive-agent-orchestrator.js.map +2 -2
  48. package/dist/src/skills/spec-generator-skill.js +441 -0
  49. package/dist/src/skills/spec-generator-skill.js.map +7 -0
  50. package/package.json +12 -5
  51. package/scripts/install-claude-hooks-auto.js +23 -9
  52. package/scripts/install-claude-hooks.sh +2 -2
  53. package/templates/claude-hooks/hooks.json +4 -2
  54. package/templates/claude-hooks/on-task-complete.js +91 -0
  55. package/templates/claude-hooks/post-edit-sweep.js +7 -10
  56. package/templates/claude-hooks/skill-eval.cjs +411 -0
  57. package/templates/claude-hooks/skill-eval.sh +31 -0
  58. package/templates/claude-hooks/skill-rules.json +274 -0
@@ -51,12 +51,12 @@ import { createRetrievalCommands } from "./commands/retrieval.js";
51
51
  import { createDiscoveryCommands } from "./commands/discovery.js";
52
52
  import { createModelCommand } from "./commands/model.js";
53
53
  import { registerSetupCommands } from "./commands/setup.js";
54
+ import { createPingCommand } from "./commands/ping.js";
54
55
  import chalk from "chalk";
55
56
  import * as fs from "fs";
56
57
  import * as path from "path";
57
58
  import { filterPending } from "../integrations/mcp/pending-utils.js";
58
59
  import { ProjectManager } from "../core/projects/project-manager.js";
59
- import Database from "better-sqlite3";
60
60
  import { join } from "path";
61
61
  import { existsSync, mkdirSync } from "fs";
62
62
  import inquirer from "inquirer";
@@ -82,6 +82,13 @@ function findPackageJson() {
82
82
  return { version: "0.0.0" };
83
83
  }
84
84
  const VERSION = findPackageJson().version;
85
+ async function openDatabase(dbPath) {
86
+ const { default: Database } = await import("better-sqlite3");
87
+ return new Database(dbPath);
88
+ }
89
+ function isTestEnv() {
90
+ return process.env["VITEST"] === "true" || process.env["NODE_ENV"] === "test" || process.env["STACKMEMORY_TEST_SKIP_DB"] === "1";
91
+ }
85
92
  UpdateChecker.checkForUpdates(VERSION, true).catch(() => {
86
93
  });
87
94
  async function startNotificationServices() {
@@ -186,13 +193,15 @@ program.command("init").description(
186
193
  }
187
194
  }
188
195
  const dbPath = join(dbDir, "context.db");
189
- const db = new Database(dbPath);
190
- new FrameManager(db, "cli-project");
196
+ if (!isTestEnv()) {
197
+ const db = await openDatabase(dbPath);
198
+ new FrameManager(db, "cli-project");
199
+ db.close();
200
+ }
191
201
  logger.info("StackMemory initialized successfully", { projectRoot });
192
202
  console.log(chalk.green("\n[OK] StackMemory initialized"));
193
203
  console.log(chalk.gray(` Project: ${projectRoot}`));
194
204
  console.log(chalk.gray(` Storage: SQLite (local)`));
195
- db.close();
196
205
  if (options.daemon) {
197
206
  console.log(chalk.cyan("\nInstalling background service..."));
198
207
  try {
@@ -276,6 +285,13 @@ program.command("status").description("Show current StackMemory status").option(
276
285
  );
277
286
  return;
278
287
  }
288
+ if (isTestEnv()) {
289
+ console.log("\u{1F4CA} StackMemory Status (test mode):");
290
+ console.log(" Frames: n/a");
291
+ console.log(" Events: n/a");
292
+ console.log(" Sessions: n/a");
293
+ return;
294
+ }
279
295
  await UpdateChecker.checkForUpdates(VERSION);
280
296
  await sessionManager.initialize();
281
297
  await sharedContextLayer.initialize();
@@ -304,7 +320,7 @@ program.command("status").description("Show current StackMemory status").option(
304
320
  );
305
321
  }
306
322
  }
307
- const db = new Database(dbPath);
323
+ const db = await openDatabase(dbPath);
308
324
  const frameManager = new FrameManager(db, session.projectId);
309
325
  if (options.all) {
310
326
  frameManager.setQueryMode(FrameQueryMode.ALL_ACTIVE);
@@ -493,7 +509,11 @@ program.command("context:test").description("Test context persistence by creatin
493
509
  );
494
510
  return;
495
511
  }
496
- const db = new Database(dbPath);
512
+ if (isTestEnv()) {
513
+ console.log("\u{1F4DD} [test] Skipping DB write in context:test");
514
+ return;
515
+ }
516
+ const db = await openDatabase(dbPath);
497
517
  const frameManager = new FrameManager(db, "cli-project");
498
518
  console.log("\u{1F4DD} Creating test context frames...");
499
519
  const rootFrame = frameManager.createFrame({
@@ -561,17 +581,22 @@ program.addCommand(createMemoryCommand());
561
581
  program.addCommand(clearCommand);
562
582
  program.addCommand(serviceCommand);
563
583
  program.addCommand(createHooksCommand());
584
+ const lazyCommands = [];
564
585
  if (isFeatureEnabled("skills")) {
565
- import("./commands/skills.js").then(
566
- ({ createSkillsCommand }) => program.addCommand(createSkillsCommand())
567
- ).catch(() => {
568
- });
586
+ lazyCommands.push(
587
+ import("./commands/skills.js").then(
588
+ ({ createSkillsCommand }) => program.addCommand(createSkillsCommand())
589
+ ).catch(() => {
590
+ })
591
+ );
569
592
  }
570
593
  if (isFeatureEnabled("ralph")) {
571
- import("./commands/ralph.js").then(
572
- ({ default: createRalphCommand }) => program.addCommand(createRalphCommand())
573
- ).catch(() => {
574
- });
594
+ lazyCommands.push(
595
+ import("./commands/ralph.js").then(
596
+ ({ default: createRalphCommand }) => program.addCommand(createRalphCommand())
597
+ ).catch(() => {
598
+ })
599
+ );
575
600
  }
576
601
  program.addCommand(createDaemonCommand());
577
602
  program.addCommand(createSweepCommand());
@@ -580,11 +605,14 @@ program.addCommand(createAPICommand());
580
605
  program.addCommand(createCleanupProcessesCommand());
581
606
  program.addCommand(createAutoBackgroundCommand());
582
607
  program.addCommand(createSettingsCommand());
608
+ program.addCommand(createPingCommand());
583
609
  if (isFeatureEnabled("whatsapp")) {
584
- import("./commands/sms-notify.js").then(
585
- ({ createSMSNotifyCommand }) => program.addCommand(createSMSNotifyCommand())
586
- ).catch(() => {
587
- });
610
+ lazyCommands.push(
611
+ import("./commands/sms-notify.js").then(
612
+ ({ createSMSNotifyCommand }) => program.addCommand(createSMSNotifyCommand())
613
+ ).catch(() => {
614
+ })
615
+ );
588
616
  }
589
617
  program.addCommand(createRetrievalCommands());
590
618
  program.addCommand(createDiscoveryCommands());
@@ -599,11 +627,11 @@ program.command("mm-spike").description(
599
627
  ).option(
600
628
  "--planner-model <name>",
601
629
  "Claude model for planning",
602
- "claude-3-5-sonnet-latest"
630
+ "claude-sonnet-4-20250514"
603
631
  ).option(
604
632
  "--reviewer-model <name>",
605
633
  "Claude model for review",
606
- "claude-3-5-sonnet-latest"
634
+ "claude-sonnet-4-20250514"
607
635
  ).option(
608
636
  "--execute",
609
637
  "Execute implementer (codex-sm) instead of dry-run",
@@ -680,12 +708,12 @@ program.command("build").description(
680
708
  ).option(
681
709
  "--planner-model <name>",
682
710
  "Claude model for planning",
683
- "claude-3-5-sonnet-latest"
711
+ "claude-sonnet-4-20250514"
684
712
  ).option(
685
713
  "--reviewer-model <name>",
686
714
  "Claude model for review",
687
- "claude-3-5-sonnet-latest"
688
- ).option("--execute", "Execute implementer (default: true)", true).option("--dry-run", "Skip execution, show commands only").option("--implementer <name>", "codex|claude", "codex").option("--max-iters <n>", "Retry loop iterations", "2").option("--audit-dir <path>", "Persist spike results to directory").option("--record-frame", "Record as real frame with anchors").option("--record", "Record plan & critique into StackMemory context").option("--json", "Emit single JSON result (UI-friendly)").option("--quiet", "Minimal output").option("--verbose", "Verbose sectioned output").option("--log", "Pretty print interaction log (default: true)", true).action(async (taskArg, opts) => {
715
+ "claude-sonnet-4-20250514"
716
+ ).option("--execute", "Execute implementer (default: true)", true).option("--dry-run", "Skip execution, show commands only").option("--implementer <name>", "codex|claude", "codex").option("--max-iters <n>", "Retry loop iterations", "2").option("--audit-dir <path>", "Persist spike results to directory").option("--record-frame", "Record as real frame with anchors").option("--record", "Record plan & critique into StackMemory context").option("--json", "Emit single JSON result (UI-friendly)").option("--quiet", "Minimal output").option("--verbose", "Verbose sectioned output").option("--log", "Pretty print interaction log (default: true)", true).option("-C, --cwd <path>", "Working directory for implementation").action(async (taskArg, opts) => {
689
717
  try {
690
718
  const task = typeof taskArg === "string" && taskArg.length > 0 ? taskArg : opts.task;
691
719
  if (!task) {
@@ -701,8 +729,19 @@ program.command("build").description(
701
729
  }
702
730
  const { runSpike } = await import("../orchestrators/multimodal/harness.js");
703
731
  const dryRun = opts.dryRun === true || opts.execute === false;
732
+ const findGitRoot = (startDir) => {
733
+ let dir = startDir;
734
+ while (dir !== "/") {
735
+ if (existsSync(join(dir, ".git"))) {
736
+ return dir;
737
+ }
738
+ dir = path.dirname(dir);
739
+ }
740
+ return startDir;
741
+ };
742
+ const repoPath = opts.cwd ? path.resolve(opts.cwd) : findGitRoot(process.cwd());
704
743
  const result = await runSpike(
705
- { task, repoPath: process.cwd() },
744
+ { task, repoPath },
706
745
  {
707
746
  plannerModel: opts.plannerModel,
708
747
  reviewerModel: opts.reviewerModel,
@@ -837,7 +876,7 @@ program.command("pending:list").description(
837
876
  }
838
877
  const items = Object.entries(pending).map(([approvalId, data]) => ({
839
878
  approvalId,
840
- task: data?.task,
879
+ task: data?.task ?? "",
841
880
  createdAt: Number(data?.createdAt || 0) || null
842
881
  }));
843
882
  const filters = {
@@ -861,7 +900,7 @@ program.command("pending:list").description(
861
900
  program.command("plan").description("Generate an implementation plan (no code execution)").option("-t, --task <desc>", "Task description", "Plan a small change").option(
862
901
  "--planner-model <name>",
863
902
  "Claude model for planning",
864
- "claude-3-5-sonnet-latest"
903
+ "claude-sonnet-4-20250514"
865
904
  ).option("--json", "Emit JSON (default)", true).option("--pretty", "Pretty-print JSON", false).option(
866
905
  "--compact",
867
906
  "Compact output (summary + step titles + criteria)",
@@ -904,7 +943,7 @@ if (process.argv.length > 2) {
904
943
  }
905
944
  const isMainModule = import.meta.url === `file://${process.argv[1]}` || process.argv[1]?.endsWith("/stackmemory") || process.argv[1]?.endsWith("index.ts") || process.argv[1]?.includes("tsx");
906
945
  if (isMainModule) {
907
- program.parse();
946
+ Promise.all(lazyCommands).then(() => program.parse());
908
947
  }
909
948
  export {
910
949
  program
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/index.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory CLI\n * Command-line interface for StackMemory operations\n */\n\n// Set environment flag for CLI usage to skip async context bridge\nprocess.env['STACKMEMORY_CLI'] = 'true';\n\n// Load environment variables (quiet mode to suppress logging)\nimport { config as loadDotenv } from 'dotenv';\nloadDotenv({ quiet: true });\n\n// Initialize tracing system early\nimport { initializeTracing, trace } from '../core/trace/index.js';\ninitializeTracing();\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/index.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { isFeatureEnabled, isLocalOnly } from '../core/config/feature-flags.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { createTaskCommands } from './commands/tasks.js';\nimport { createSearchCommand } from './commands/search.js';\nimport { createLogCommand } from './commands/log.js';\nimport { createContextCommands } from './commands/context.js';\nimport { createConfigCommand } from './commands/config.js';\nimport {\n createCaptureCommand,\n createRestoreCommand,\n createAutoCaptureCommand,\n} from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport clearCommand from './commands/clear.js';\nimport serviceCommand from './commands/service.js';\nimport { registerLoginCommand } from './commands/login.js';\nimport { registerSignupCommand } from './commands/signup.js';\nimport { registerLogoutCommand, registerDbCommands } from './commands/db.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.js';\nimport { createSweepCommand } from './commands/sweep.js';\nimport { createShellCommand } from './commands/shell.js';\nimport { createAPICommand } from './commands/api.js';\nimport { createCleanupProcessesCommand } from './commands/cleanup-processes.js';\nimport { createAutoBackgroundCommand } from './commands/auto-background.js';\nimport { createSettingsCommand } from './commands/settings.js';\nimport { createRetrievalCommands } from './commands/retrieval.js';\nimport { createDiscoveryCommands } from './commands/discovery.js';\nimport { createModelCommand } from './commands/model.js';\nimport { registerSetupCommands } from './commands/setup.js';\nimport chalk from 'chalk';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { filterPending } from '../integrations/mcp/pending-utils.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\nimport inquirer from 'inquirer';\nimport { enableChromaDB } from '../core/config/storage-config.js';\nimport { spawn } from 'child_process';\nimport type {\n HarnessResult,\n PlanStep,\n} from '../orchestrators/multimodal/types.js';\nimport { homedir } from 'os';\n\n// Read version from package.json - works from both src/ and dist/src/\nimport { createRequire } from 'module';\nimport { fileURLToPath } from 'url';\nimport * as pathModule from 'path';\nconst localRequire = createRequire(import.meta.url);\nconst currentFilePath = fileURLToPath(import.meta.url);\nconst currentDirPath = pathModule.dirname(currentFilePath);\n\n// Find package.json by walking up directories\nfunction findPackageJson(): { version: string } {\n let dir = currentDirPath;\n for (let i = 0; i < 5; i++) {\n const pkgPath = pathModule.join(dir, 'package.json');\n try {\n return localRequire(pkgPath);\n } catch {\n dir = pathModule.dirname(dir);\n }\n }\n return { version: '0.0.0' };\n}\nconst VERSION = findPackageJson().version;\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\n// Auto-start webhook and ngrok if notifications are enabled\nasync function startNotificationServices(): Promise<void> {\n // Skip in local-only mode\n if (isLocalOnly() || !isFeatureEnabled('whatsapp')) return;\n\n try {\n const { loadSMSConfig } = await import('../hooks/sms-notify.js');\n const config = loadSMSConfig();\n if (!config.enabled) return;\n\n const WEBHOOK_PORT = 3456;\n let webhookStarted = false;\n let ngrokStarted = false;\n\n // Check if webhook is already running\n const webhookRunning = await fetch(\n `http://localhost:${WEBHOOK_PORT}/health`\n )\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!webhookRunning) {\n // Start webhook in background using the dist path\n const webhookPath = join(__dirname, '../hooks/sms-webhook.js');\n const webhookProcess = spawn('node', [webhookPath], {\n detached: true,\n stdio: 'ignore',\n env: { ...process.env, SMS_WEBHOOK_PORT: String(WEBHOOK_PORT) },\n });\n webhookProcess.unref();\n webhookStarted = true;\n }\n\n // Check if ngrok is running\n const ngrokRunning = await fetch('http://localhost:4040/api/tunnels')\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!ngrokRunning) {\n // Start ngrok in background\n const ngrokProcess = spawn('ngrok', ['http', String(WEBHOOK_PORT)], {\n detached: true,\n stdio: 'ignore',\n });\n ngrokProcess.unref();\n ngrokStarted = true;\n }\n\n // Save ngrok URL after startup\n if (webhookStarted || ngrokStarted) {\n setTimeout(async () => {\n try {\n const tunnels = await fetch('http://localhost:4040/api/tunnels').then(\n (r) =>\n r.json() as Promise<{ tunnels: Array<{ public_url: string }> }>\n );\n const publicUrl = tunnels?.tunnels?.[0]?.public_url;\n if (publicUrl) {\n const configDir = join(homedir(), '.stackmemory');\n const configPath = join(configDir, 'ngrok-url.txt');\n const { writeFileSync, mkdirSync, existsSync } = await import('fs');\n if (!existsSync(configDir)) {\n mkdirSync(configDir, { recursive: true });\n }\n writeFileSync(configPath, publicUrl);\n console.log(\n chalk.gray(`[notify] Webhook: ${publicUrl}/sms/incoming`)\n );\n }\n } catch {\n // Ignore errors\n }\n }, 4000);\n }\n } catch {\n // Silently ignore - notifications are optional\n }\n}\n\nstartNotificationServices();\n\nprogram\n .name('stackmemory')\n .description(\n 'Lossless memory runtime for AI coding tools - organizes context as a call stack instead of linear chat logs, with team collaboration and infinite retention'\n )\n .version(VERSION);\n\nprogram\n .command('init')\n .description(\n 'Initialize StackMemory in current project (zero-config by default)'\n )\n .option('-i, --interactive', 'Interactive mode with configuration prompts')\n .option(\n '--chromadb',\n 'Enable ChromaDB for semantic search (prompts for API key)'\n )\n .option('--daemon', 'Start the background daemon after initialization')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n // Check if already initialized\n const alreadyInit = existsSync(join(dbDir, 'context.db'));\n if (alreadyInit && !options.interactive) {\n console.log(chalk.yellow('StackMemory already initialized.'));\n console.log(chalk.gray('Run with --interactive to reconfigure.'));\n return;\n }\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n // Zero-config by default - just use SQLite, no questions\n if (options.chromadb) {\n await promptAndEnableChromaDB();\n } else if (options.interactive && process.stdin.isTTY) {\n // Only ask questions in interactive mode\n console.log(chalk.cyan('\\nStorage Configuration'));\n console.log(\n chalk.gray('SQLite (default) is fast and requires no setup.')\n );\n console.log(\n chalk.gray('ChromaDB adds semantic search but requires an API key.\\n')\n );\n\n const { enableChroma } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableChroma',\n message: 'Enable ChromaDB for semantic search?',\n default: false,\n },\n ]);\n\n if (enableChroma) {\n await promptAndEnableChromaDB();\n }\n }\n\n // Initialize SQLite database\n const dbPath = join(dbDir, 'context.db');\n const db = new Database(dbPath);\n new FrameManager(db, 'cli-project');\n\n logger.info('StackMemory initialized successfully', { projectRoot });\n console.log(chalk.green('\\n[OK] StackMemory initialized'));\n console.log(chalk.gray(` Project: ${projectRoot}`));\n console.log(chalk.gray(` Storage: SQLite (local)`));\n\n db.close();\n\n // Install daemon service if requested\n if (options.daemon) {\n console.log(chalk.cyan('\\nInstalling background service...'));\n try {\n const { installServiceSilent } =\n await import('./commands/service.js');\n const success = await installServiceSilent();\n if (success) {\n console.log(chalk.green('[OK] Guardian service installed'));\n console.log(chalk.gray(' Auto-starts on login'));\n console.log(\n chalk.gray(' Check status: stackmemory service status')\n );\n } else {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n } catch {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n }\n\n // Show next steps\n console.log(chalk.cyan('\\nNext steps:'));\n console.log(\n chalk.white(' 1. stackmemory setup-mcp') +\n chalk.gray(' # Configure Claude Code integration')\n );\n console.log(\n chalk.white(' 2. stackmemory status') +\n chalk.gray(' # Check status')\n );\n console.log(\n chalk.white(' 3. stackmemory doctor') +\n chalk.gray(' # Diagnose issues')\n );\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error(chalk.red('\\n[ERROR] Initialization failed'));\n console.error(chalk.gray(` Reason: ${(error as Error).message}`));\n console.error(\n chalk.gray(\n ' Fix: Ensure you have write permissions to the current directory'\n )\n );\n console.error(chalk.gray(' Run: stackmemory doctor'));\n process.exit(1);\n }\n });\n\n/**\n * Prompt user for ChromaDB configuration and enable it\n */\nasync function promptAndEnableChromaDB(): Promise<void> {\n const answers = await inquirer.prompt([\n {\n type: 'password',\n name: 'apiKey',\n message: 'Enter your ChromaDB API key:',\n validate: (input: string) => {\n if (!input || input.trim().length === 0) {\n return 'API key is required for ChromaDB';\n }\n return true;\n },\n },\n {\n type: 'input',\n name: 'apiUrl',\n message: 'ChromaDB API URL (press Enter for default):',\n default: 'https://api.trychroma.com',\n },\n ]);\n\n enableChromaDB({\n apiKey: answers.apiKey,\n apiUrl: answers.apiUrl,\n });\n\n console.log(chalk.green('[OK] ChromaDB enabled for semantic search.'));\n console.log(\n chalk.gray('API key saved to ~/.stackmemory/storage-config.json')\n );\n}\n\nprogram\n .command('status')\n .description('Show current StackMemory status')\n .option('--all', 'Show all active frames across sessions')\n .option('--project', 'Show all active frames in current project')\n .option('--session <id>', 'Show frames for specific session')\n .action(async (options) => {\n return trace.command('stackmemory-status', options, async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n // Check for updates and display if available\n await UpdateChecker.checkForUpdates(VERSION);\n\n // Initialize session manager and shared context\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n const session = await sessionManager.getOrCreateSession({\n projectPath: projectRoot,\n sessionId: options.session,\n });\n\n // Auto-discover shared context on startup\n const contextDiscovery = await sharedContextLayer.autoDiscoverContext();\n\n // Show context hints if available\n if (\n contextDiscovery.hasSharedContext &&\n contextDiscovery.sessionCount > 1\n ) {\n console.log(`\\n\uD83D\uDCA1 Shared Context Available:`);\n console.log(\n ` ${contextDiscovery.sessionCount} sessions with shared context`\n );\n\n if (contextDiscovery.recentPatterns.length > 0) {\n console.log(` Recent patterns:`);\n contextDiscovery.recentPatterns.slice(0, 3).forEach((p) => {\n console.log(\n ` \u2022 ${p.type}: ${p.pattern.slice(0, 50)} (${p.frequency}x)`\n );\n });\n }\n\n if (contextDiscovery.lastDecisions.length > 0) {\n console.log(\n ` Last decision: ${contextDiscovery.lastDecisions[0].decision.slice(0, 60)}`\n );\n }\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db, session.projectId);\n\n // Set query mode based on options\n if (options.all) {\n frameManager.setQueryMode(FrameQueryMode.ALL_ACTIVE);\n } else if (options.project) {\n frameManager.setQueryMode(FrameQueryMode.PROJECT_ACTIVE);\n }\n\n const activeFrames = frameManager.getActiveFramePath();\n const stackDepth = frameManager.getStackDepth();\n\n // Always get total counts across all sessions\n const totalStats = db\n .prepare(\n `\n SELECT \n COUNT(*) as total_frames,\n SUM(CASE WHEN state = 'active' THEN 1 ELSE 0 END) as active_frames,\n SUM(CASE WHEN state = 'closed' THEN 1 ELSE 0 END) as closed_frames,\n COUNT(DISTINCT run_id) as total_sessions\n FROM frames\n WHERE project_id = ?\n `\n )\n .get(session.projectId) as {\n total_frames: number;\n active_frames: number;\n closed_frames: number;\n total_sessions: number;\n };\n\n const contextCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM contexts\n `\n )\n .get() as { count: number };\n\n const eventCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ?\n `\n )\n .get(session.projectId) as { count: number };\n\n console.log('\uD83D\uDCCA StackMemory Status:');\n console.log(\n ` Session: ${session.sessionId.slice(0, 8)} (${session.state}, ${Math.round((Date.now() - session.startedAt) / 1000 / 60)}min old)`\n );\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n\n // Show total database statistics\n console.log(`\\n Database Statistics (this project):`);\n console.log(\n ` Frames: ${totalStats.total_frames || 0} (${totalStats.active_frames || 0} active, ${totalStats.closed_frames || 0} closed)`\n );\n console.log(` Events: ${eventCount.count || 0}`);\n console.log(` Sessions: ${totalStats.total_sessions || 0}`);\n console.log(\n ` Cached contexts: ${contextCount.count || 0} (global)`\n );\n\n // Show recent activity\n const recentFrames = db\n .prepare(\n `\n SELECT name, type, state, datetime(created_at, 'unixepoch') as created\n FROM frames\n WHERE project_id = ?\n ORDER BY created_at DESC\n LIMIT 3\n `\n )\n .all(session.projectId) as Array<{\n name: string;\n type: string;\n state: string;\n created: string;\n }>;\n\n if (recentFrames.length > 0) {\n console.log(`\\n Recent Activity:`);\n recentFrames.forEach((f) => {\n const stateIcon = f.state === 'active' ? '\uD83D\uDFE2' : '\u26AB';\n console.log(\n ` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`\n );\n });\n }\n\n console.log(`\\n Current Session:`);\n console.log(` Stack depth: ${stackDepth}`);\n console.log(` Active frames: ${activeFrames.length}`);\n\n if (activeFrames.length > 0) {\n activeFrames.forEach((frame, i) => {\n const indent = ' ' + ' '.repeat(frame.depth || i);\n const prefix = i === 0 ? '\u2514\u2500' : ' \u2514\u2500';\n console.log(`${indent}${prefix} ${frame.name} [${frame.type}]`);\n });\n }\n\n // Show other sessions if in default mode\n if (!options.all && !options.project) {\n const otherSessions = await sessionManager.listSessions({\n projectId: session.projectId,\n state: 'active',\n });\n\n const otherActive = otherSessions.filter(\n (s) => s.sessionId !== session.sessionId\n );\n if (otherActive.length > 0) {\n console.log(`\\n Other Active Sessions (same project):`);\n otherActive.forEach((s) => {\n const age = Math.round(\n (Date.now() - s.lastActiveAt) / 1000 / 60 / 60\n );\n console.log(\n ` - ${s.sessionId.slice(0, 8)}: ${s.branch || 'main'}, ${age}h old`\n );\n });\n console.log(`\\n Tip: Use --all to see frames across sessions`);\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to get status', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n });\n\nprogram\n .command('update-check')\n .description('Check for StackMemory updates')\n .action(async () => {\n try {\n console.log('\uD83D\uDD0D Checking for updates...');\n await UpdateChecker.forceCheck(VERSION);\n } catch (error: unknown) {\n logger.error('Update check failed', error as Error);\n console.error('\u274C Update check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('progress')\n .description('Show current progress and recent changes')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const progress = new ProgressTracker(projectRoot);\n console.log(progress.getSummary());\n } catch (error: unknown) {\n logger.error('Failed to show progress', error as Error);\n console.error('\u274C Failed to show progress:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-server')\n .description('Start StackMemory MCP server for Claude Desktop')\n .option('-p, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runMCPServer } = await import('../integrations/mcp/server.js');\n\n // Set project root\n process.env['PROJECT_ROOT'] = options.project;\n\n console.log('\uD83D\uDE80 Starting StackMemory MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n\n // Check for updates silently\n UpdateChecker.checkForUpdates(VERSION, true).catch(() => {});\n\n // Start the MCP server\n await runMCPServer();\n } catch (error: unknown) {\n logger.error('Failed to start MCP server', error as Error);\n console.error('\u274C MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-remote')\n .description(\n 'Start StackMemory Remote MCP server (HTTP/SSE) for Claude.ai web'\n )\n .option('-p, --port <number>', 'Port to listen on', '3847')\n .option('-d, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runRemoteMCPServer } =\n await import('../integrations/mcp/remote-server.js');\n\n const port = parseInt(options.port, 10);\n\n console.log('Starting StackMemory Remote MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n console.log('');\n\n await runRemoteMCPServer(port, options.project);\n\n console.log('');\n console.log('For Claude.ai web connector:');\n console.log(` URL: http://localhost:${port}/sse`);\n console.log('');\n console.log('For external access (ngrok):');\n console.log(` ngrok http ${port}`);\n console.log(' Then use the ngrok URL + /sse in Claude.ai');\n } catch (error: unknown) {\n logger.error('Failed to start remote MCP server', error as Error);\n console.error('Remote MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Add test context command\nprogram\n .command('context:test')\n .description('Test context persistence by creating sample frames')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db, 'cli-project');\n\n // Create test frames\n console.log('\uD83D\uDCDD Creating test context frames...');\n\n const rootFrame = frameManager.createFrame({\n type: 'task',\n name: 'Test Session',\n inputs: { test: true, timestamp: new Date().toISOString() },\n });\n\n const taskFrame = frameManager.createFrame({\n type: 'subtask',\n name: 'Sample Task',\n inputs: { description: 'Testing context persistence' },\n parentFrameId: rootFrame,\n });\n\n const commandFrame = frameManager.createFrame({\n type: 'tool_scope',\n name: 'test-command',\n inputs: { args: ['--test'] },\n parentFrameId: taskFrame,\n });\n\n // Add some events\n frameManager.addEvent(\n 'observation',\n {\n message: 'Test event recorded',\n },\n commandFrame\n );\n\n console.log('\u2705 Test frames created!');\n console.log(`\uD83D\uDCCA Stack depth: ${frameManager.getStackDepth()}`);\n console.log(\n `\uD83D\uDD04 Active frames: ${frameManager.getActiveFramePath().length}`\n );\n\n // Close one frame to test state changes\n frameManager.closeFrame(commandFrame);\n console.log(\n `\uD83D\uDCCA After closing command frame: depth = ${frameManager.getStackDepth()}`\n );\n\n db.close();\n } catch (error: unknown) {\n logger.error('Test context failed', error as Error);\n console.error('\u274C Test failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register project management commands\n// Register command modules\nregisterOnboardingCommand(program);\nregisterSignupCommand(program);\nregisterLoginCommand(program);\nregisterLogoutCommand(program);\nregisterDbCommands(program);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands (lazy-loaded, optional)\nif (isFeatureEnabled('linear')) {\n import('./commands/linear.js')\n .then(({ registerLinearCommands }) => registerLinearCommands(program))\n .catch(() => {\n // Linear integration not available - silently skip\n });\n}\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createCaptureCommand());\nprogram.addCommand(createRestoreCommand());\nprogram.addCommand(createAutoCaptureCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(serviceCommand);\nprogram.addCommand(createHooksCommand());\n\n// Register skills commands (optional, lazy-loaded)\nif (isFeatureEnabled('skills')) {\n import('./commands/skills.js')\n .then(({ createSkillsCommand }) =>\n program.addCommand(createSkillsCommand())\n )\n .catch(() => {\n // Skills integration not available - silently skip\n });\n}\n\n// Register ralph commands (feature-flagged, lazy-loaded)\n// Default ON for development, OFF for npm package users\nif (isFeatureEnabled('ralph')) {\n import('./commands/ralph.js')\n .then(({ default: createRalphCommand }) =>\n program.addCommand(createRalphCommand())\n )\n .catch(() => {\n // Ralph integration not available - silently skip\n });\n}\nprogram.addCommand(createDaemonCommand());\nprogram.addCommand(createSweepCommand());\nprogram.addCommand(createShellCommand());\nprogram.addCommand(createAPICommand());\nprogram.addCommand(createCleanupProcessesCommand());\nprogram.addCommand(createAutoBackgroundCommand());\nprogram.addCommand(createSettingsCommand());\n\n// Register WhatsApp/SMS commands (lazy-loaded, optional)\nif (isFeatureEnabled('whatsapp')) {\n import('./commands/sms-notify.js')\n .then(({ createSMSNotifyCommand }) =>\n program.addCommand(createSMSNotifyCommand())\n )\n .catch(() => {\n // WhatsApp integration not available - silently skip\n });\n}\nprogram.addCommand(createRetrievalCommands());\nprogram.addCommand(createDiscoveryCommands());\nprogram.addCommand(createModelCommand());\n\n// Register setup and diagnostic commands\nregisterSetupCommands(program);\n\n// Multi-modal spike: planner (Claude), implementer (Codex), critic (Claude)\nprogram\n .command('mm-spike')\n .description(\n 'Run multi-agent planning/implementation spike (planner/implementer/critic)'\n )\n .option(\n '-t, --task <desc>',\n 'Task description',\n 'Add multi-agent spike harness'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-3-5-sonnet-latest'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-3-5-sonnet-latest'\n )\n .option(\n '--execute',\n 'Execute implementer (codex-sm) instead of dry-run',\n false\n )\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors', false)\n .option('--record', 'Record plan & critique into StackMemory context', false)\n .option('--json', 'Emit single JSON result (UI-friendly)', false)\n .option('--quiet', 'Minimal output (default)', true)\n .option('--verbose', 'Verbose sectioned output', false)\n .option(\n '--log',\n 'Pretty print interaction log (planner/implementer/critic)',\n false\n )\n .action(async (opts) => {\n try {\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const result = await runSpike(\n {\n task: opts.task,\n repoPath: process.cwd(),\n },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun: !opts.execute,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task: opts.task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: Boolean(opts.execute),\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n // brief human-readable summary\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('mm-spike failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Alias: build (same behavior as mm-spike)\nprogram\n .command('build')\n .description(\n 'Plan + code: planner (Claude), implementer (Codex/Claude), critic (Claude) with optional log/json output'\n )\n .argument('[task]', 'Task description (positional)')\n .option(\n '-t, --task <desc>',\n 'Task description (required if no positional arg)'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-3-5-sonnet-latest'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-3-5-sonnet-latest'\n )\n .option('--execute', 'Execute implementer (default: true)', true)\n .option('--dry-run', 'Skip execution, show commands only')\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors')\n .option('--record', 'Record plan & critique into StackMemory context')\n .option('--json', 'Emit single JSON result (UI-friendly)')\n .option('--quiet', 'Minimal output')\n .option('--verbose', 'Verbose sectioned output')\n .option('--log', 'Pretty print interaction log (default: true)', true)\n .action(async (taskArg, opts) => {\n try {\n // Resolve task from positional arg or --task option\n const task =\n typeof taskArg === 'string' && taskArg.length > 0 ? taskArg : opts.task;\n\n if (!task) {\n console.error(\n chalk.red(\n 'Error: Task description required. Provide as argument or --task option.'\n )\n );\n console.error(\n chalk.gray(' Example: stackmemory build \"Add user authentication\"')\n );\n process.exit(1);\n }\n\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const dryRun = opts.dryRun === true || opts.execute === false;\n const result = await runSpike(\n { task, repoPath: process.cwd() },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: !dryRun,\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('build failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\ninterface BuildLogMeta {\n task: string;\n plannerModel: string;\n reviewerModel: string;\n implementer: string;\n execute: boolean;\n}\n\nfunction printInteractionLog(meta: BuildLogMeta, result: HarnessResult): void {\n const divider = chalk.gray(\n '\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500'\n );\n console.log(chalk.cyan.bold('\\nPlan & Code Session'));\n console.log(`${chalk.gray('Task:')} ${meta.task}`);\n console.log(`${chalk.gray('Planner:')} ${meta.plannerModel}`);\n console.log(`${chalk.gray('Reviewer:')} ${meta.reviewerModel}`);\n console.log(\n `${chalk.gray('Implementer:')} ${meta.implementer} ${\n meta.execute ? chalk.green('(execute)') : chalk.yellow('(dry-run)')\n }`\n );\n console.log(divider);\n\n // Plan summary\n if (result.plan) {\n console.log(\n chalk.bold('Plan Summary: '),\n result.plan.summary || '(no summary)'\n );\n const steps: PlanStep[] = result.plan.steps.slice(0, 6);\n if (steps.length) {\n console.log(chalk.bold('\\nSteps:'));\n steps.forEach((s, idx) => {\n console.log(`${chalk.gray(String(idx + 1) + '.')} ${s.title || s.id}`);\n const ac = s.acceptanceCriteria || [];\n if (ac.length) {\n ac.slice(0, 3).forEach((c) => console.log(chalk.gray(` - ${c}`)));\n if (ac.length > 3) console.log(chalk.gray(' - ...'));\n }\n });\n }\n if (result.plan.risks?.length) {\n console.log(chalk.bold('\\nRisks:'));\n result.plan.risks\n .slice(0, 5)\n .forEach((r) => console.log(chalk.gray(` - ${r}`)));\n }\n }\n\n console.log(`\\n${divider}`);\n const iters = result.iterations || [];\n if (iters.length) {\n iters.forEach((it, i) => {\n console.log(chalk.magenta(`Attempt ${i + 1}`));\n console.log(`${chalk.gray('Command:')} ${it.command}`);\n console.log(\n `${chalk.gray('OK:')} ${it.ok ? chalk.green('true') : chalk.red('false')}`\n );\n const issues = it.critique?.issues || [];\n const sugg = it.critique?.suggestions || [];\n if (issues.length) {\n console.log(chalk.bold('Issues:'));\n issues.slice(0, 5).forEach((x) => console.log(chalk.red(` - ${x}`)));\n }\n if (sugg.length) {\n console.log(chalk.bold('Suggestions:'));\n sugg.slice(0, 5).forEach((x) => console.log(chalk.yellow(` - ${x}`)));\n }\n console.log(divider);\n });\n }\n\n const approved = result.critique?.approved ?? false;\n console.log(\n `${chalk.bold('Final:')} ${\n approved ? chalk.green('Approved') : chalk.yellow('Needs changes')\n }`\n );\n console.log('');\n}\n\n// Pending approvals: list with optional filters (CLI helper)\nprogram\n .command('pending:list')\n .description(\n 'List pending approval-gated plans (from .stackmemory/build/pending.json)'\n )\n .option('--task-contains <substr>', 'Filter tasks containing this substring')\n .option('--older-than-ms <number>', 'Only items older than this age (ms)')\n .option('--newer-than-ms <number>', 'Only items newer than this age (ms)')\n .option('--sort <asc|desc>', 'Sort by createdAt', 'desc')\n .option('--limit <number>', 'Max items to return', '20')\n .option('--pretty', 'Pretty-print JSON output', false)\n .action(async (opts) => {\n try {\n const storePath = path.join(\n process.cwd(),\n '.stackmemory',\n 'build',\n 'pending.json'\n );\n let pending: Record<string, any> = {};\n if (fs.existsSync(storePath)) {\n try {\n pending = JSON.parse(fs.readFileSync(storePath, 'utf-8'));\n } catch {}\n }\n const items = Object.entries(pending).map(([approvalId, data]) => ({\n approvalId,\n task: (data as any)?.task as string,\n createdAt: Number((data as any)?.createdAt || 0) || null,\n }));\n const filters = {\n taskContains: opts.taskContains as string | undefined,\n olderThanMs: opts.olderThanMs ? Number(opts.olderThanMs) : undefined,\n newerThanMs: opts.newerThanMs ? Number(opts.newerThanMs) : undefined,\n sort: (opts.sort as 'asc' | 'desc') || undefined,\n limit: opts.limit ? Number(opts.limit) : undefined,\n };\n const out = filterPending(items, filters);\n console.log(\n JSON.stringify({ ok: true, pending: out }, null, opts.pretty ? 2 : 0)\n );\n } catch (error) {\n console.error(\n JSON.stringify({ ok: false, error: (error as Error).message })\n );\n process.exit(1);\n }\n });\n\n// Lightweight planner: output only plan (JSON-friendly)\nprogram\n .command('plan')\n .description('Generate an implementation plan (no code execution)')\n .option('-t, --task <desc>', 'Task description', 'Plan a small change')\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-3-5-sonnet-latest'\n )\n .option('--json', 'Emit JSON (default)', true)\n .option('--pretty', 'Pretty-print JSON', false)\n .option(\n '--compact',\n 'Compact output (summary + step titles + criteria)',\n false\n )\n .action(async (opts) => {\n try {\n const { runPlanOnly } =\n await import('../orchestrators/multimodal/harness.js');\n const plan = await runPlanOnly(\n { task: opts.task, repoPath: process.cwd() },\n { plannerModel: opts.plannerModel }\n );\n const typedPlan = plan as {\n summary?: string;\n steps?: Array<{\n id: string;\n title: string;\n acceptanceCriteria: string[];\n }>;\n risks?: string[];\n };\n const compacted = opts.compact\n ? {\n summary: typedPlan?.summary,\n steps: Array.isArray(typedPlan?.steps)\n ? typedPlan.steps.map((s) => ({\n id: s.id,\n title: s.title,\n acceptanceCriteria: s.acceptanceCriteria,\n }))\n : [],\n risks: typedPlan?.risks,\n }\n : plan;\n const payload = JSON.stringify(compacted, null, opts.pretty ? 2 : 0);\n console.log(payload);\n } catch (error) {\n console.error('plan failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register dashboard command\nprogram\n .command('dashboard')\n .description('Display monitoring dashboard in terminal')\n .option('-w, --watch', 'Auto-refresh dashboard')\n .option('-i, --interval <seconds>', 'Refresh interval in seconds', '5')\n .action(async (options) => {\n const { dashboardCommand } = await import('./commands/dashboard.js');\n await dashboardCommand.handler(options);\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n try {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n } catch {\n // Silently fail if database initialization fails (e.g., native module version mismatch)\n }\n}\n\n// Only parse when running as main module (not when imported for testing)\nconst isMainModule =\n import.meta.url === `file://${process.argv[1]}` ||\n process.argv[1]?.endsWith('/stackmemory') ||\n process.argv[1]?.endsWith('index.ts') ||\n process.argv[1]?.includes('tsx');\n\nif (isMainModule) {\n program.parse();\n}\n\nexport { program };\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory CLI\n * Command-line interface for StackMemory operations\n */\n\n// Set environment flag for CLI usage to skip async context bridge\nprocess.env['STACKMEMORY_CLI'] = 'true';\n\n// Load environment variables (quiet mode to suppress logging)\nimport { config as loadDotenv } from 'dotenv';\nloadDotenv({ quiet: true });\n\n// Initialize tracing system early\nimport { initializeTracing, trace } from '../core/trace/index.js';\ninitializeTracing();\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/index.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { isFeatureEnabled, isLocalOnly } from '../core/config/feature-flags.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { createTaskCommands } from './commands/tasks.js';\nimport { createSearchCommand } from './commands/search.js';\nimport { createLogCommand } from './commands/log.js';\nimport { createContextCommands } from './commands/context.js';\nimport { createConfigCommand } from './commands/config.js';\nimport {\n createCaptureCommand,\n createRestoreCommand,\n createAutoCaptureCommand,\n} from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport clearCommand from './commands/clear.js';\nimport serviceCommand from './commands/service.js';\nimport { registerLoginCommand } from './commands/login.js';\nimport { registerSignupCommand } from './commands/signup.js';\nimport { registerLogoutCommand, registerDbCommands } from './commands/db.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.js';\nimport { createSweepCommand } from './commands/sweep.js';\nimport { createShellCommand } from './commands/shell.js';\nimport { createAPICommand } from './commands/api.js';\nimport { createCleanupProcessesCommand } from './commands/cleanup-processes.js';\nimport { createAutoBackgroundCommand } from './commands/auto-background.js';\nimport { createSettingsCommand } from './commands/settings.js';\nimport { createRetrievalCommands } from './commands/retrieval.js';\nimport { createDiscoveryCommands } from './commands/discovery.js';\nimport { createModelCommand } from './commands/model.js';\nimport { registerSetupCommands } from './commands/setup.js';\nimport { createPingCommand } from './commands/ping.js';\nimport chalk from 'chalk';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { filterPending } from '../integrations/mcp/pending-utils.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\nimport inquirer from 'inquirer';\nimport { enableChromaDB } from '../core/config/storage-config.js';\nimport { spawn } from 'child_process';\nimport type {\n HarnessResult,\n PlanStep,\n} from '../orchestrators/multimodal/types.js';\nimport { homedir } from 'os';\n\n// Read version from package.json - works from both src/ and dist/src/\nimport { createRequire } from 'module';\nimport { fileURLToPath } from 'url';\nimport * as pathModule from 'path';\nconst localRequire = createRequire(import.meta.url);\nconst currentFilePath = fileURLToPath(import.meta.url);\nconst currentDirPath = pathModule.dirname(currentFilePath);\n\n// Find package.json by walking up directories\nfunction findPackageJson(): { version: string } {\n let dir = currentDirPath;\n for (let i = 0; i < 5; i++) {\n const pkgPath = pathModule.join(dir, 'package.json');\n try {\n return localRequire(pkgPath);\n } catch {\n dir = pathModule.dirname(dir);\n }\n }\n return { version: '0.0.0' };\n}\nconst VERSION = findPackageJson().version;\n\n// Lazy DB opener to avoid loading native module at import time (test-friendly)\nasync function openDatabase(dbPath: string) {\n const { default: Database } = await import('better-sqlite3');\n return new Database(dbPath);\n}\n\nfunction isTestEnv(): boolean {\n return (\n process.env['VITEST'] === 'true' ||\n process.env['NODE_ENV'] === 'test' ||\n process.env['STACKMEMORY_TEST_SKIP_DB'] === '1'\n );\n}\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\n// Auto-start webhook and ngrok if notifications are enabled\nasync function startNotificationServices(): Promise<void> {\n // Skip in local-only mode\n if (isLocalOnly() || !isFeatureEnabled('whatsapp')) return;\n\n try {\n const { loadSMSConfig } = await import('../hooks/sms-notify.js');\n const config = loadSMSConfig();\n if (!config.enabled) return;\n\n const WEBHOOK_PORT = 3456;\n let webhookStarted = false;\n let ngrokStarted = false;\n\n // Check if webhook is already running\n const webhookRunning = await fetch(\n `http://localhost:${WEBHOOK_PORT}/health`\n )\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!webhookRunning) {\n // Start webhook in background using the dist path\n const webhookPath = join(__dirname, '../hooks/sms-webhook.js');\n const webhookProcess = spawn('node', [webhookPath], {\n detached: true,\n stdio: 'ignore',\n env: { ...process.env, SMS_WEBHOOK_PORT: String(WEBHOOK_PORT) },\n });\n webhookProcess.unref();\n webhookStarted = true;\n }\n\n // Check if ngrok is running\n const ngrokRunning = await fetch('http://localhost:4040/api/tunnels')\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!ngrokRunning) {\n // Start ngrok in background\n const ngrokProcess = spawn('ngrok', ['http', String(WEBHOOK_PORT)], {\n detached: true,\n stdio: 'ignore',\n });\n ngrokProcess.unref();\n ngrokStarted = true;\n }\n\n // Save ngrok URL after startup\n if (webhookStarted || ngrokStarted) {\n setTimeout(async () => {\n try {\n const tunnels = await fetch('http://localhost:4040/api/tunnels').then(\n (r) =>\n r.json() as Promise<{ tunnels: Array<{ public_url: string }> }>\n );\n const publicUrl = tunnels?.tunnels?.[0]?.public_url;\n if (publicUrl) {\n const configDir = join(homedir(), '.stackmemory');\n const configPath = join(configDir, 'ngrok-url.txt');\n const { writeFileSync, mkdirSync, existsSync } = await import('fs');\n if (!existsSync(configDir)) {\n mkdirSync(configDir, { recursive: true });\n }\n writeFileSync(configPath, publicUrl);\n console.log(\n chalk.gray(`[notify] Webhook: ${publicUrl}/sms/incoming`)\n );\n }\n } catch {\n // Ignore errors\n }\n }, 4000);\n }\n } catch {\n // Silently ignore - notifications are optional\n }\n}\n\nstartNotificationServices();\n\nprogram\n .name('stackmemory')\n .description(\n 'Lossless memory runtime for AI coding tools - organizes context as a call stack instead of linear chat logs, with team collaboration and infinite retention'\n )\n .version(VERSION);\n\nprogram\n .command('init')\n .description(\n 'Initialize StackMemory in current project (zero-config by default)'\n )\n .option('-i, --interactive', 'Interactive mode with configuration prompts')\n .option(\n '--chromadb',\n 'Enable ChromaDB for semantic search (prompts for API key)'\n )\n .option('--daemon', 'Start the background daemon after initialization')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n // Check if already initialized\n const alreadyInit = existsSync(join(dbDir, 'context.db'));\n if (alreadyInit && !options.interactive) {\n console.log(chalk.yellow('StackMemory already initialized.'));\n console.log(chalk.gray('Run with --interactive to reconfigure.'));\n return;\n }\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n // Zero-config by default - just use SQLite, no questions\n if (options.chromadb) {\n await promptAndEnableChromaDB();\n } else if (options.interactive && process.stdin.isTTY) {\n // Only ask questions in interactive mode\n console.log(chalk.cyan('\\nStorage Configuration'));\n console.log(\n chalk.gray('SQLite (default) is fast and requires no setup.')\n );\n console.log(\n chalk.gray('ChromaDB adds semantic search but requires an API key.\\n')\n );\n\n const { enableChroma } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableChroma',\n message: 'Enable ChromaDB for semantic search?',\n default: false,\n },\n ]);\n\n if (enableChroma) {\n await promptAndEnableChromaDB();\n }\n }\n\n // Initialize SQLite database (skip in test env)\n const dbPath = join(dbDir, 'context.db');\n if (!isTestEnv()) {\n const db = await openDatabase(dbPath);\n new FrameManager(db, 'cli-project');\n db.close();\n }\n\n logger.info('StackMemory initialized successfully', { projectRoot });\n console.log(chalk.green('\\n[OK] StackMemory initialized'));\n console.log(chalk.gray(` Project: ${projectRoot}`));\n console.log(chalk.gray(` Storage: SQLite (local)`));\n\n // Install daemon service if requested\n if (options.daemon) {\n console.log(chalk.cyan('\\nInstalling background service...'));\n try {\n const { installServiceSilent } =\n await import('./commands/service.js');\n const success = await installServiceSilent();\n if (success) {\n console.log(chalk.green('[OK] Guardian service installed'));\n console.log(chalk.gray(' Auto-starts on login'));\n console.log(\n chalk.gray(' Check status: stackmemory service status')\n );\n } else {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n } catch {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n }\n\n // Show next steps\n console.log(chalk.cyan('\\nNext steps:'));\n console.log(\n chalk.white(' 1. stackmemory setup-mcp') +\n chalk.gray(' # Configure Claude Code integration')\n );\n console.log(\n chalk.white(' 2. stackmemory status') +\n chalk.gray(' # Check status')\n );\n console.log(\n chalk.white(' 3. stackmemory doctor') +\n chalk.gray(' # Diagnose issues')\n );\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error(chalk.red('\\n[ERROR] Initialization failed'));\n console.error(chalk.gray(` Reason: ${(error as Error).message}`));\n console.error(\n chalk.gray(\n ' Fix: Ensure you have write permissions to the current directory'\n )\n );\n console.error(chalk.gray(' Run: stackmemory doctor'));\n process.exit(1);\n }\n });\n\n/**\n * Prompt user for ChromaDB configuration and enable it\n */\nasync function promptAndEnableChromaDB(): Promise<void> {\n const answers = await inquirer.prompt([\n {\n type: 'password',\n name: 'apiKey',\n message: 'Enter your ChromaDB API key:',\n validate: (input: string) => {\n if (!input || input.trim().length === 0) {\n return 'API key is required for ChromaDB';\n }\n return true;\n },\n },\n {\n type: 'input',\n name: 'apiUrl',\n message: 'ChromaDB API URL (press Enter for default):',\n default: 'https://api.trychroma.com',\n },\n ]);\n\n enableChromaDB({\n apiKey: answers.apiKey,\n apiUrl: answers.apiUrl,\n });\n\n console.log(chalk.green('[OK] ChromaDB enabled for semantic search.'));\n console.log(\n chalk.gray('API key saved to ~/.stackmemory/storage-config.json')\n );\n}\n\nprogram\n .command('status')\n .description('Show current StackMemory status')\n .option('--all', 'Show all active frames across sessions')\n .option('--project', 'Show all active frames in current project')\n .option('--session <id>', 'Show frames for specific session')\n .action(async (options) => {\n return trace.command('stackmemory-status', options, async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n if (isTestEnv()) {\n console.log('\uD83D\uDCCA StackMemory Status (test mode):');\n console.log(' Frames: n/a');\n console.log(' Events: n/a');\n console.log(' Sessions: n/a');\n return;\n }\n\n // Check for updates and display if available\n await UpdateChecker.checkForUpdates(VERSION);\n\n // Initialize session manager and shared context\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n const session = await sessionManager.getOrCreateSession({\n projectPath: projectRoot,\n sessionId: options.session,\n });\n\n // Auto-discover shared context on startup\n const contextDiscovery = await sharedContextLayer.autoDiscoverContext();\n\n // Show context hints if available\n if (\n contextDiscovery.hasSharedContext &&\n contextDiscovery.sessionCount > 1\n ) {\n console.log(`\\n\uD83D\uDCA1 Shared Context Available:`);\n console.log(\n ` ${contextDiscovery.sessionCount} sessions with shared context`\n );\n\n if (contextDiscovery.recentPatterns.length > 0) {\n console.log(` Recent patterns:`);\n contextDiscovery.recentPatterns.slice(0, 3).forEach((p) => {\n console.log(\n ` \u2022 ${p.type}: ${p.pattern.slice(0, 50)} (${p.frequency}x)`\n );\n });\n }\n\n if (contextDiscovery.lastDecisions.length > 0) {\n console.log(\n ` Last decision: ${contextDiscovery.lastDecisions[0].decision.slice(0, 60)}`\n );\n }\n }\n\n const db = await openDatabase(dbPath);\n const frameManager = new FrameManager(db, session.projectId);\n\n // Set query mode based on options\n if (options.all) {\n frameManager.setQueryMode(FrameQueryMode.ALL_ACTIVE);\n } else if (options.project) {\n frameManager.setQueryMode(FrameQueryMode.PROJECT_ACTIVE);\n }\n\n const activeFrames = frameManager.getActiveFramePath();\n const stackDepth = frameManager.getStackDepth();\n\n // Always get total counts across all sessions\n const totalStats = db\n .prepare(\n `\n SELECT \n COUNT(*) as total_frames,\n SUM(CASE WHEN state = 'active' THEN 1 ELSE 0 END) as active_frames,\n SUM(CASE WHEN state = 'closed' THEN 1 ELSE 0 END) as closed_frames,\n COUNT(DISTINCT run_id) as total_sessions\n FROM frames\n WHERE project_id = ?\n `\n )\n .get(session.projectId) as {\n total_frames: number;\n active_frames: number;\n closed_frames: number;\n total_sessions: number;\n };\n\n const contextCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM contexts\n `\n )\n .get() as { count: number };\n\n const eventCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ?\n `\n )\n .get(session.projectId) as { count: number };\n\n console.log('\uD83D\uDCCA StackMemory Status:');\n console.log(\n ` Session: ${session.sessionId.slice(0, 8)} (${session.state}, ${Math.round((Date.now() - session.startedAt) / 1000 / 60)}min old)`\n );\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n\n // Show total database statistics\n console.log(`\\n Database Statistics (this project):`);\n console.log(\n ` Frames: ${totalStats.total_frames || 0} (${totalStats.active_frames || 0} active, ${totalStats.closed_frames || 0} closed)`\n );\n console.log(` Events: ${eventCount.count || 0}`);\n console.log(` Sessions: ${totalStats.total_sessions || 0}`);\n console.log(\n ` Cached contexts: ${contextCount.count || 0} (global)`\n );\n\n // Show recent activity\n const recentFrames = db\n .prepare(\n `\n SELECT name, type, state, datetime(created_at, 'unixepoch') as created\n FROM frames\n WHERE project_id = ?\n ORDER BY created_at DESC\n LIMIT 3\n `\n )\n .all(session.projectId) as Array<{\n name: string;\n type: string;\n state: string;\n created: string;\n }>;\n\n if (recentFrames.length > 0) {\n console.log(`\\n Recent Activity:`);\n recentFrames.forEach((f) => {\n const stateIcon = f.state === 'active' ? '\uD83D\uDFE2' : '\u26AB';\n console.log(\n ` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`\n );\n });\n }\n\n console.log(`\\n Current Session:`);\n console.log(` Stack depth: ${stackDepth}`);\n console.log(` Active frames: ${activeFrames.length}`);\n\n if (activeFrames.length > 0) {\n activeFrames.forEach((frame, i) => {\n const indent = ' ' + ' '.repeat(frame.depth || i);\n const prefix = i === 0 ? '\u2514\u2500' : ' \u2514\u2500';\n console.log(`${indent}${prefix} ${frame.name} [${frame.type}]`);\n });\n }\n\n // Show other sessions if in default mode\n if (!options.all && !options.project) {\n const otherSessions = await sessionManager.listSessions({\n projectId: session.projectId,\n state: 'active',\n });\n\n const otherActive = otherSessions.filter(\n (s) => s.sessionId !== session.sessionId\n );\n if (otherActive.length > 0) {\n console.log(`\\n Other Active Sessions (same project):`);\n otherActive.forEach((s) => {\n const age = Math.round(\n (Date.now() - s.lastActiveAt) / 1000 / 60 / 60\n );\n console.log(\n ` - ${s.sessionId.slice(0, 8)}: ${s.branch || 'main'}, ${age}h old`\n );\n });\n console.log(`\\n Tip: Use --all to see frames across sessions`);\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to get status', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n });\n\nprogram\n .command('update-check')\n .description('Check for StackMemory updates')\n .action(async () => {\n try {\n console.log('\uD83D\uDD0D Checking for updates...');\n await UpdateChecker.forceCheck(VERSION);\n } catch (error: unknown) {\n logger.error('Update check failed', error as Error);\n console.error('\u274C Update check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('progress')\n .description('Show current progress and recent changes')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const progress = new ProgressTracker(projectRoot);\n console.log(progress.getSummary());\n } catch (error: unknown) {\n logger.error('Failed to show progress', error as Error);\n console.error('\u274C Failed to show progress:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-server')\n .description('Start StackMemory MCP server for Claude Desktop')\n .option('-p, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runMCPServer } = await import('../integrations/mcp/server.js');\n\n // Set project root\n process.env['PROJECT_ROOT'] = options.project;\n\n console.log('\uD83D\uDE80 Starting StackMemory MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n\n // Check for updates silently\n UpdateChecker.checkForUpdates(VERSION, true).catch(() => {});\n\n // Start the MCP server\n await runMCPServer();\n } catch (error: unknown) {\n logger.error('Failed to start MCP server', error as Error);\n console.error('\u274C MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-remote')\n .description(\n 'Start StackMemory Remote MCP server (HTTP/SSE) for Claude.ai web'\n )\n .option('-p, --port <number>', 'Port to listen on', '3847')\n .option('-d, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runRemoteMCPServer } =\n await import('../integrations/mcp/remote-server.js');\n\n const port = parseInt(options.port, 10);\n\n console.log('Starting StackMemory Remote MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n console.log('');\n\n await runRemoteMCPServer(port, options.project);\n\n console.log('');\n console.log('For Claude.ai web connector:');\n console.log(` URL: http://localhost:${port}/sse`);\n console.log('');\n console.log('For external access (ngrok):');\n console.log(` ngrok http ${port}`);\n console.log(' Then use the ngrok URL + /sse in Claude.ai');\n } catch (error: unknown) {\n logger.error('Failed to start remote MCP server', error as Error);\n console.error('Remote MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Add test context command\nprogram\n .command('context:test')\n .description('Test context persistence by creating sample frames')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n if (isTestEnv()) {\n console.log('\uD83D\uDCDD [test] Skipping DB write in context:test');\n return;\n }\n\n const db = await openDatabase(dbPath);\n const frameManager = new FrameManager(db, 'cli-project');\n\n // Create test frames\n console.log('\uD83D\uDCDD Creating test context frames...');\n\n const rootFrame = frameManager.createFrame({\n type: 'task',\n name: 'Test Session',\n inputs: { test: true, timestamp: new Date().toISOString() },\n });\n\n const taskFrame = frameManager.createFrame({\n type: 'subtask',\n name: 'Sample Task',\n inputs: { description: 'Testing context persistence' },\n parentFrameId: rootFrame,\n });\n\n const commandFrame = frameManager.createFrame({\n type: 'tool_scope',\n name: 'test-command',\n inputs: { args: ['--test'] },\n parentFrameId: taskFrame,\n });\n\n // Add some events\n frameManager.addEvent(\n 'observation',\n {\n message: 'Test event recorded',\n },\n commandFrame\n );\n\n console.log('\u2705 Test frames created!');\n console.log(`\uD83D\uDCCA Stack depth: ${frameManager.getStackDepth()}`);\n console.log(\n `\uD83D\uDD04 Active frames: ${frameManager.getActiveFramePath().length}`\n );\n\n // Close one frame to test state changes\n frameManager.closeFrame(commandFrame);\n console.log(\n `\uD83D\uDCCA After closing command frame: depth = ${frameManager.getStackDepth()}`\n );\n\n db.close();\n } catch (error: unknown) {\n logger.error('Test context failed', error as Error);\n console.error('\u274C Test failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register project management commands\n// Register command modules\nregisterOnboardingCommand(program);\nregisterSignupCommand(program);\nregisterLoginCommand(program);\nregisterLogoutCommand(program);\nregisterDbCommands(program);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands (lazy-loaded, optional)\nif (isFeatureEnabled('linear')) {\n import('./commands/linear.js')\n .then(({ registerLinearCommands }) => registerLinearCommands(program))\n .catch(() => {\n // Linear integration not available - silently skip\n });\n}\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createCaptureCommand());\nprogram.addCommand(createRestoreCommand());\nprogram.addCommand(createAutoCaptureCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(serviceCommand);\nprogram.addCommand(createHooksCommand());\n\n// Register feature-flagged commands (awaited before parse)\nconst lazyCommands: Promise<void>[] = [];\n\nif (isFeatureEnabled('skills')) {\n lazyCommands.push(\n import('./commands/skills.js')\n .then(({ createSkillsCommand }) =>\n program.addCommand(createSkillsCommand())\n )\n .catch(() => {\n // Skills integration not available - silently skip\n })\n );\n}\n\n// Register ralph commands (feature-flagged)\n// Default ON for development, OFF for npm package users\nif (isFeatureEnabled('ralph')) {\n lazyCommands.push(\n import('./commands/ralph.js')\n .then(({ default: createRalphCommand }) =>\n program.addCommand(createRalphCommand())\n )\n .catch(() => {\n // Ralph integration not available - silently skip\n })\n );\n}\nprogram.addCommand(createDaemonCommand());\nprogram.addCommand(createSweepCommand());\nprogram.addCommand(createShellCommand());\nprogram.addCommand(createAPICommand());\nprogram.addCommand(createCleanupProcessesCommand());\nprogram.addCommand(createAutoBackgroundCommand());\nprogram.addCommand(createSettingsCommand());\nprogram.addCommand(createPingCommand());\n\n// Register WhatsApp/SMS commands (lazy-loaded, optional)\nif (isFeatureEnabled('whatsapp')) {\n lazyCommands.push(\n import('./commands/sms-notify.js')\n .then(({ createSMSNotifyCommand }) =>\n program.addCommand(createSMSNotifyCommand())\n )\n .catch(() => {\n // WhatsApp integration not available - silently skip\n })\n );\n}\nprogram.addCommand(createRetrievalCommands());\nprogram.addCommand(createDiscoveryCommands());\nprogram.addCommand(createModelCommand());\n\n// Register setup and diagnostic commands\nregisterSetupCommands(program);\n\n// Multi-modal spike: planner (Claude), implementer (Codex), critic (Claude)\nprogram\n .command('mm-spike')\n .description(\n 'Run multi-agent planning/implementation spike (planner/implementer/critic)'\n )\n .option(\n '-t, --task <desc>',\n 'Task description',\n 'Add multi-agent spike harness'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--execute',\n 'Execute implementer (codex-sm) instead of dry-run',\n false\n )\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors', false)\n .option('--record', 'Record plan & critique into StackMemory context', false)\n .option('--json', 'Emit single JSON result (UI-friendly)', false)\n .option('--quiet', 'Minimal output (default)', true)\n .option('--verbose', 'Verbose sectioned output', false)\n .option(\n '--log',\n 'Pretty print interaction log (planner/implementer/critic)',\n false\n )\n .action(async (opts) => {\n try {\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const result = await runSpike(\n {\n task: opts.task,\n repoPath: process.cwd(),\n },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun: !opts.execute,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task: opts.task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: Boolean(opts.execute),\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n // brief human-readable summary\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('mm-spike failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Alias: build (same behavior as mm-spike)\nprogram\n .command('build')\n .description(\n 'Plan + code: planner (Claude), implementer (Codex/Claude), critic (Claude) with optional log/json output'\n )\n .argument('[task]', 'Task description (positional)')\n .option(\n '-t, --task <desc>',\n 'Task description (required if no positional arg)'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-sonnet-4-20250514'\n )\n .option('--execute', 'Execute implementer (default: true)', true)\n .option('--dry-run', 'Skip execution, show commands only')\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors')\n .option('--record', 'Record plan & critique into StackMemory context')\n .option('--json', 'Emit single JSON result (UI-friendly)')\n .option('--quiet', 'Minimal output')\n .option('--verbose', 'Verbose sectioned output')\n .option('--log', 'Pretty print interaction log (default: true)', true)\n .option('-C, --cwd <path>', 'Working directory for implementation')\n .action(async (taskArg, opts) => {\n try {\n // Resolve task from positional arg or --task option\n const task =\n typeof taskArg === 'string' && taskArg.length > 0 ? taskArg : opts.task;\n\n if (!task) {\n console.error(\n chalk.red(\n 'Error: Task description required. Provide as argument or --task option.'\n )\n );\n console.error(\n chalk.gray(' Example: stackmemory build \"Add user authentication\"')\n );\n process.exit(1);\n }\n\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const dryRun = opts.dryRun === true || opts.execute === false;\n\n // Find git root for proper working directory\n const findGitRoot = (startDir: string): string => {\n let dir = startDir;\n while (dir !== '/') {\n if (existsSync(join(dir, '.git'))) {\n return dir;\n }\n dir = path.dirname(dir);\n }\n return startDir;\n };\n // Use --cwd if provided, otherwise find git root from cwd\n const repoPath = opts.cwd\n ? path.resolve(opts.cwd)\n : findGitRoot(process.cwd());\n\n const result = await runSpike(\n { task, repoPath },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: !dryRun,\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('build failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\ninterface BuildLogMeta {\n task: string;\n plannerModel: string;\n reviewerModel: string;\n implementer: string;\n execute: boolean;\n}\n\nfunction printInteractionLog(meta: BuildLogMeta, result: HarnessResult): void {\n const divider = chalk.gray(\n '\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500'\n );\n console.log(chalk.cyan.bold('\\nPlan & Code Session'));\n console.log(`${chalk.gray('Task:')} ${meta.task}`);\n console.log(`${chalk.gray('Planner:')} ${meta.plannerModel}`);\n console.log(`${chalk.gray('Reviewer:')} ${meta.reviewerModel}`);\n console.log(\n `${chalk.gray('Implementer:')} ${meta.implementer} ${\n meta.execute ? chalk.green('(execute)') : chalk.yellow('(dry-run)')\n }`\n );\n console.log(divider);\n\n // Plan summary\n if (result.plan) {\n console.log(\n chalk.bold('Plan Summary: '),\n result.plan.summary || '(no summary)'\n );\n const steps: PlanStep[] = result.plan.steps.slice(0, 6);\n if (steps.length) {\n console.log(chalk.bold('\\nSteps:'));\n steps.forEach((s, idx) => {\n console.log(`${chalk.gray(String(idx + 1) + '.')} ${s.title || s.id}`);\n const ac = s.acceptanceCriteria || [];\n if (ac.length) {\n ac.slice(0, 3).forEach((c) => console.log(chalk.gray(` - ${c}`)));\n if (ac.length > 3) console.log(chalk.gray(' - ...'));\n }\n });\n }\n if (result.plan.risks?.length) {\n console.log(chalk.bold('\\nRisks:'));\n result.plan.risks\n .slice(0, 5)\n .forEach((r) => console.log(chalk.gray(` - ${r}`)));\n }\n }\n\n console.log(`\\n${divider}`);\n const iters = result.iterations || [];\n if (iters.length) {\n iters.forEach((it, i) => {\n console.log(chalk.magenta(`Attempt ${i + 1}`));\n console.log(`${chalk.gray('Command:')} ${it.command}`);\n console.log(\n `${chalk.gray('OK:')} ${it.ok ? chalk.green('true') : chalk.red('false')}`\n );\n const issues = it.critique?.issues || [];\n const sugg = it.critique?.suggestions || [];\n if (issues.length) {\n console.log(chalk.bold('Issues:'));\n issues.slice(0, 5).forEach((x) => console.log(chalk.red(` - ${x}`)));\n }\n if (sugg.length) {\n console.log(chalk.bold('Suggestions:'));\n sugg.slice(0, 5).forEach((x) => console.log(chalk.yellow(` - ${x}`)));\n }\n console.log(divider);\n });\n }\n\n const approved = result.critique?.approved ?? false;\n console.log(\n `${chalk.bold('Final:')} ${\n approved ? chalk.green('Approved') : chalk.yellow('Needs changes')\n }`\n );\n console.log('');\n}\n\n// Pending approvals: list with optional filters (CLI helper)\nprogram\n .command('pending:list')\n .description(\n 'List pending approval-gated plans (from .stackmemory/build/pending.json)'\n )\n .option('--task-contains <substr>', 'Filter tasks containing this substring')\n .option('--older-than-ms <number>', 'Only items older than this age (ms)')\n .option('--newer-than-ms <number>', 'Only items newer than this age (ms)')\n .option('--sort <asc|desc>', 'Sort by createdAt', 'desc')\n .option('--limit <number>', 'Max items to return', '20')\n .option('--pretty', 'Pretty-print JSON output', false)\n .action(async (opts) => {\n try {\n const storePath = path.join(\n process.cwd(),\n '.stackmemory',\n 'build',\n 'pending.json'\n );\n let pending: Record<string, { task?: string; createdAt?: number }> = {};\n if (fs.existsSync(storePath)) {\n try {\n pending = JSON.parse(fs.readFileSync(storePath, 'utf-8'));\n } catch {}\n }\n const items = Object.entries(pending).map(([approvalId, data]) => ({\n approvalId,\n task: data?.task ?? '',\n createdAt: Number(data?.createdAt || 0) || null,\n }));\n const filters = {\n taskContains: opts.taskContains as string | undefined,\n olderThanMs: opts.olderThanMs ? Number(opts.olderThanMs) : undefined,\n newerThanMs: opts.newerThanMs ? Number(opts.newerThanMs) : undefined,\n sort: (opts.sort as 'asc' | 'desc') || undefined,\n limit: opts.limit ? Number(opts.limit) : undefined,\n };\n const out = filterPending(items, filters);\n console.log(\n JSON.stringify({ ok: true, pending: out }, null, opts.pretty ? 2 : 0)\n );\n } catch (error) {\n console.error(\n JSON.stringify({ ok: false, error: (error as Error).message })\n );\n process.exit(1);\n }\n });\n\n// Lightweight planner: output only plan (JSON-friendly)\nprogram\n .command('plan')\n .description('Generate an implementation plan (no code execution)')\n .option('-t, --task <desc>', 'Task description', 'Plan a small change')\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option('--json', 'Emit JSON (default)', true)\n .option('--pretty', 'Pretty-print JSON', false)\n .option(\n '--compact',\n 'Compact output (summary + step titles + criteria)',\n false\n )\n .action(async (opts) => {\n try {\n const { runPlanOnly } =\n await import('../orchestrators/multimodal/harness.js');\n const plan = await runPlanOnly(\n { task: opts.task, repoPath: process.cwd() },\n { plannerModel: opts.plannerModel }\n );\n const typedPlan = plan as {\n summary?: string;\n steps?: Array<{\n id: string;\n title: string;\n acceptanceCriteria: string[];\n }>;\n risks?: string[];\n };\n const compacted = opts.compact\n ? {\n summary: typedPlan?.summary,\n steps: Array.isArray(typedPlan?.steps)\n ? typedPlan.steps.map((s) => ({\n id: s.id,\n title: s.title,\n acceptanceCriteria: s.acceptanceCriteria,\n }))\n : [],\n risks: typedPlan?.risks,\n }\n : plan;\n const payload = JSON.stringify(compacted, null, opts.pretty ? 2 : 0);\n console.log(payload);\n } catch (error) {\n console.error('plan failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register dashboard command\nprogram\n .command('dashboard')\n .description('Display monitoring dashboard in terminal')\n .option('-w, --watch', 'Auto-refresh dashboard')\n .option('-i, --interval <seconds>', 'Refresh interval in seconds', '5')\n .action(async (options) => {\n const { dashboardCommand } = await import('./commands/dashboard.js');\n await dashboardCommand.handler(options);\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n try {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n } catch {\n // Silently fail if database initialization fails (e.g., native module version mismatch)\n }\n}\n\n// Only parse when running as main module (not when imported for testing)\nconst isMainModule =\n import.meta.url === `file://${process.argv[1]}` ||\n process.argv[1]?.endsWith('/stackmemory') ||\n process.argv[1]?.endsWith('index.ts') ||\n process.argv[1]?.includes('tsx');\n\nif (isMainModule) {\n Promise.all(lazyCommands).then(() => program.parse());\n}\n\nexport { program };\n"],
5
+ "mappings": "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",
6
6
  "names": ["mkdirSync", "existsSync"]
7
7
  }
@@ -14,7 +14,7 @@ const DEFAULT_DIGEST_CONFIG = {
14
14
  retryDelayMs: 1e3,
15
15
  llmConfig: {
16
16
  provider: "anthropic",
17
- model: "claude-3-haiku-20240307",
17
+ model: "claude-3-5-haiku-20241022",
18
18
  temperature: 0.2
19
19
  // Lower for more consistent output
20
20
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/core/digest/types.ts"],
4
- "sourcesContent": ["/**\n * Types for Hybrid Digest Generation System\n * 80% deterministic extraction, 20% AI-generated review/insights\n */\n\nimport { Frame, Anchor, Event } from '../context/index.js';\n\n/**\n * Deterministic fields extracted directly from frame data (60%)\n */\nexport interface DeterministicDigest {\n /** Files that were modified during this frame */\n filesModified: FileModification[];\n /** Tests that were run */\n testsRun: TestResult[];\n /** Errors encountered */\n errorsEncountered: ErrorInfo[];\n /** Number of tool calls made */\n toolCallCount: number;\n /** Tool calls by type */\n toolCallsByType: Record<string, number>;\n /** Frame duration in seconds */\n durationSeconds: number;\n /** Exit status */\n exitStatus: 'success' | 'failure' | 'partial' | 'cancelled';\n /** Anchors by type */\n anchorCounts: Record<string, number>;\n /** Key decisions made (extracted from DECISION anchors) */\n decisions: string[];\n /** Constraints established (extracted from CONSTRAINT anchors) */\n constraints: string[];\n /** Risks identified (extracted from RISK anchors) */\n risks: string[];\n}\n\nexport interface FileModification {\n path: string;\n operation: 'create' | 'modify' | 'delete' | 'read';\n linesChanged?: number;\n}\n\nexport interface TestResult {\n name: string;\n status: 'passed' | 'failed' | 'skipped';\n duration?: number;\n}\n\nexport interface ErrorInfo {\n type: string;\n message: string;\n resolved: boolean;\n count: number;\n}\n\n/**\n * AI-generated review fields (20%)\n * Focused on high-value insights only\n */\nexport interface AIGeneratedDigest {\n /** One-line summary of what was accomplished */\n summary: string;\n /** Key insight or learning (if any) */\n insight?: string;\n /** Potential issue or risk spotted */\n flaggedIssue?: string;\n /** Generated at timestamp */\n generatedAt: number;\n /** Model used for generation */\n modelUsed?: string;\n /** Tokens used */\n tokensUsed?: number;\n}\n\n/**\n * Complete hybrid digest combining both approaches\n */\nexport interface HybridDigest {\n /** Frame identifier */\n frameId: string;\n /** Frame name/goal */\n frameName: string;\n /** Frame type */\n frameType: string;\n /** Deterministic fields (always available) */\n deterministic: DeterministicDigest;\n /** AI-generated fields (may be pending) */\n aiGenerated?: AIGeneratedDigest;\n /** Processing status */\n status: DigestStatus;\n /** Human-readable text representation */\n text: string;\n /** Version for schema evolution */\n version: number;\n /** Created timestamp */\n createdAt: number;\n /** Last updated timestamp */\n updatedAt: number;\n}\n\nexport type DigestStatus =\n | 'deterministic_only' // Only deterministic fields populated\n | 'ai_pending' // Queued for AI generation\n | 'ai_processing' // Currently being processed by AI\n | 'complete' // Both deterministic and AI fields populated\n | 'ai_failed'; // AI generation failed, falling back to deterministic\n\n/**\n * Digest generation request for the queue\n */\nexport interface DigestGenerationRequest {\n frameId: string;\n frameName: string;\n frameType: string;\n priority: 'low' | 'normal' | 'high';\n createdAt: number;\n retryCount: number;\n maxRetries: number;\n}\n\n/**\n * Configuration for the digest generator\n */\nexport interface DigestConfig {\n /** Enable AI generation (can be disabled for deterministic-only mode) */\n enableAIGeneration: boolean;\n /** Maximum tokens for AI summary */\n maxTokens: number;\n /** Batch size for idle processing */\n batchSize: number;\n /** Idle threshold in ms before processing queue */\n idleThresholdMs: number;\n /** Maximum retries for failed AI generation */\n maxRetries: number;\n /** Retry delay in ms */\n retryDelayMs: number;\n /** LLM provider configuration */\n llmConfig: {\n provider: 'anthropic' | 'openai' | 'local' | 'none';\n model: string;\n temperature: number;\n };\n}\n\nexport const DEFAULT_DIGEST_CONFIG: DigestConfig = {\n enableAIGeneration: true,\n maxTokens: 100, // Reduced for 20% AI contribution\n batchSize: 10, // Process more at once since smaller\n idleThresholdMs: 3000, // 3 seconds of idle time\n maxRetries: 2,\n retryDelayMs: 1000,\n llmConfig: {\n provider: 'anthropic',\n model: 'claude-3-haiku-20240307',\n temperature: 0.2, // Lower for more consistent output\n },\n};\n\n/**\n * Input for digest generation\n */\nexport interface DigestInput {\n frame: Frame;\n anchors: Anchor[];\n events: Event[];\n parentDigest?: HybridDigest;\n}\n\n/**\n * LLM provider interface for AI digest generation\n */\nexport interface DigestLLMProvider {\n generateSummary(\n input: DigestInput,\n deterministic: DeterministicDigest,\n maxTokens: number\n ): Promise<AIGeneratedDigest>;\n}\n\n/**\n * Digest queue statistics\n */\nexport interface DigestQueueStats {\n pending: number;\n processing: number;\n completed: number;\n failed: number;\n avgProcessingTimeMs: number;\n}\n"],
4
+ "sourcesContent": ["/**\n * Types for Hybrid Digest Generation System\n * 80% deterministic extraction, 20% AI-generated review/insights\n */\n\nimport { Frame, Anchor, Event } from '../context/index.js';\n\n/**\n * Deterministic fields extracted directly from frame data (60%)\n */\nexport interface DeterministicDigest {\n /** Files that were modified during this frame */\n filesModified: FileModification[];\n /** Tests that were run */\n testsRun: TestResult[];\n /** Errors encountered */\n errorsEncountered: ErrorInfo[];\n /** Number of tool calls made */\n toolCallCount: number;\n /** Tool calls by type */\n toolCallsByType: Record<string, number>;\n /** Frame duration in seconds */\n durationSeconds: number;\n /** Exit status */\n exitStatus: 'success' | 'failure' | 'partial' | 'cancelled';\n /** Anchors by type */\n anchorCounts: Record<string, number>;\n /** Key decisions made (extracted from DECISION anchors) */\n decisions: string[];\n /** Constraints established (extracted from CONSTRAINT anchors) */\n constraints: string[];\n /** Risks identified (extracted from RISK anchors) */\n risks: string[];\n}\n\nexport interface FileModification {\n path: string;\n operation: 'create' | 'modify' | 'delete' | 'read';\n linesChanged?: number;\n}\n\nexport interface TestResult {\n name: string;\n status: 'passed' | 'failed' | 'skipped';\n duration?: number;\n}\n\nexport interface ErrorInfo {\n type: string;\n message: string;\n resolved: boolean;\n count: number;\n}\n\n/**\n * AI-generated review fields (20%)\n * Focused on high-value insights only\n */\nexport interface AIGeneratedDigest {\n /** One-line summary of what was accomplished */\n summary: string;\n /** Key insight or learning (if any) */\n insight?: string;\n /** Potential issue or risk spotted */\n flaggedIssue?: string;\n /** Generated at timestamp */\n generatedAt: number;\n /** Model used for generation */\n modelUsed?: string;\n /** Tokens used */\n tokensUsed?: number;\n}\n\n/**\n * Complete hybrid digest combining both approaches\n */\nexport interface HybridDigest {\n /** Frame identifier */\n frameId: string;\n /** Frame name/goal */\n frameName: string;\n /** Frame type */\n frameType: string;\n /** Deterministic fields (always available) */\n deterministic: DeterministicDigest;\n /** AI-generated fields (may be pending) */\n aiGenerated?: AIGeneratedDigest;\n /** Processing status */\n status: DigestStatus;\n /** Human-readable text representation */\n text: string;\n /** Version for schema evolution */\n version: number;\n /** Created timestamp */\n createdAt: number;\n /** Last updated timestamp */\n updatedAt: number;\n}\n\nexport type DigestStatus =\n | 'deterministic_only' // Only deterministic fields populated\n | 'ai_pending' // Queued for AI generation\n | 'ai_processing' // Currently being processed by AI\n | 'complete' // Both deterministic and AI fields populated\n | 'ai_failed'; // AI generation failed, falling back to deterministic\n\n/**\n * Digest generation request for the queue\n */\nexport interface DigestGenerationRequest {\n frameId: string;\n frameName: string;\n frameType: string;\n priority: 'low' | 'normal' | 'high';\n createdAt: number;\n retryCount: number;\n maxRetries: number;\n}\n\n/**\n * Configuration for the digest generator\n */\nexport interface DigestConfig {\n /** Enable AI generation (can be disabled for deterministic-only mode) */\n enableAIGeneration: boolean;\n /** Maximum tokens for AI summary */\n maxTokens: number;\n /** Batch size for idle processing */\n batchSize: number;\n /** Idle threshold in ms before processing queue */\n idleThresholdMs: number;\n /** Maximum retries for failed AI generation */\n maxRetries: number;\n /** Retry delay in ms */\n retryDelayMs: number;\n /** LLM provider configuration */\n llmConfig: {\n provider: 'anthropic' | 'openai' | 'local' | 'none';\n model: string;\n temperature: number;\n };\n}\n\nexport const DEFAULT_DIGEST_CONFIG: DigestConfig = {\n enableAIGeneration: true,\n maxTokens: 100, // Reduced for 20% AI contribution\n batchSize: 10, // Process more at once since smaller\n idleThresholdMs: 3000, // 3 seconds of idle time\n maxRetries: 2,\n retryDelayMs: 1000,\n llmConfig: {\n provider: 'anthropic',\n model: 'claude-3-5-haiku-20241022',\n temperature: 0.2, // Lower for more consistent output\n },\n};\n\n/**\n * Input for digest generation\n */\nexport interface DigestInput {\n frame: Frame;\n anchors: Anchor[];\n events: Event[];\n parentDigest?: HybridDigest;\n}\n\n/**\n * LLM provider interface for AI digest generation\n */\nexport interface DigestLLMProvider {\n generateSummary(\n input: DigestInput,\n deterministic: DeterministicDigest,\n maxTokens: number\n ): Promise<AIGeneratedDigest>;\n}\n\n/**\n * Digest queue statistics\n */\nexport interface DigestQueueStats {\n pending: number;\n processing: number;\n completed: number;\n failed: number;\n avgProcessingTimeMs: number;\n}\n"],
5
5
  "mappings": ";;;;AA+IO,MAAM,wBAAsC;AAAA,EACjD,oBAAoB;AAAA,EACpB,WAAW;AAAA;AAAA,EACX,WAAW;AAAA;AAAA,EACX,iBAAiB;AAAA;AAAA,EACjB,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,WAAW;AAAA,IACT,UAAU;AAAA,IACV,OAAO;AAAA,IACP,aAAa;AAAA;AAAA,EACf;AACF;",
6
6
  "names": []
7
7
  }
@@ -111,7 +111,7 @@ class ClaudeAdapter {
111
111
  "anthropic-version": "2023-06-01"
112
112
  },
113
113
  body: JSON.stringify({
114
- model: "claude-3-haiku-20240307",
114
+ model: "claude-3-5-haiku-20241022",
115
115
  max_tokens: 1,
116
116
  messages: [{ role: "user", content: "hi" }]
117
117
  })
@@ -125,11 +125,8 @@ class ClaudeAdapter {
125
125
  return [
126
126
  "claude-opus-4-20250514",
127
127
  "claude-sonnet-4-20250514",
128
- "claude-3-5-sonnet-20241022",
129
128
  "claude-3-5-haiku-20241022",
130
- "claude-3-opus-20240229",
131
- "claude-3-sonnet-20240229",
132
- "claude-3-haiku-20240307"
129
+ "claude-3-opus-20240229"
133
130
  ];
134
131
  }
135
132
  buildRequestBody(messages, options) {