@dollhousemcp/mcp-server 2.0.10 → 2.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/dist/auto-dollhouse/portDiscovery.d.ts +23 -0
  2. package/dist/auto-dollhouse/portDiscovery.d.ts.map +1 -0
  3. package/dist/auto-dollhouse/portDiscovery.js +77 -0
  4. package/dist/cli/console-token.d.ts +18 -0
  5. package/dist/cli/console-token.d.ts.map +1 -0
  6. package/dist/cli/console-token.js +187 -0
  7. package/dist/generated/version.d.ts +2 -2
  8. package/dist/generated/version.js +3 -3
  9. package/dist/index.d.ts.map +1 -1
  10. package/dist/index.js +24 -5
  11. package/dist/web/console/consoleToken.d.ts +403 -0
  12. package/dist/web/console/consoleToken.d.ts.map +1 -0
  13. package/dist/web/console/consoleToken.js +930 -0
  14. package/dist/web/middleware/authMiddleware.d.ts +64 -0
  15. package/dist/web/middleware/authMiddleware.d.ts.map +1 -0
  16. package/dist/web/middleware/authMiddleware.js +174 -0
  17. package/dist/web/routes/consoleRouteHelpers.d.ts +33 -0
  18. package/dist/web/routes/consoleRouteHelpers.d.ts.map +1 -0
  19. package/dist/web/routes/consoleRouteHelpers.js +60 -0
  20. package/dist/web/routes/tokenRoutes.d.ts +37 -0
  21. package/dist/web/routes/tokenRoutes.d.ts.map +1 -0
  22. package/dist/web/routes/tokenRoutes.js +95 -0
  23. package/dist/web/routes/totpRoutes.d.ts +45 -0
  24. package/dist/web/routes/totpRoutes.d.ts.map +1 -0
  25. package/dist/web/routes/totpRoutes.js +187 -0
  26. package/package.json +1 -1
  27. package/server.json +2 -2
  28. package/dist/constants/version.d.ts +0 -3
  29. package/dist/constants/version.d.ts.map +0 -1
  30. package/dist/constants/version.js +0 -4
  31. package/dist/logging/sinks/SSELogSink.d.ts +0 -35
  32. package/dist/logging/sinks/SSELogSink.d.ts.map +0 -1
  33. package/dist/logging/sinks/SSELogSink.js +0 -181
  34. package/dist/logging/viewer/viewerHtml.d.ts +0 -8
  35. package/dist/logging/viewer/viewerHtml.d.ts.map +0 -1
  36. package/dist/logging/viewer/viewerHtml.js +0 -204
package/dist/index.js CHANGED
@@ -3,6 +3,7 @@
3
3
  // This ensures .env.local and .env are loaded for all modules
4
4
  import { env } from './config/env.js';
5
5
  import * as path from 'path';
6
+ import { realpathSync } from 'node:fs';
6
7
  import { Server } from "@modelcontextprotocol/sdk/server/index.js";
7
8
  import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
8
9
  import { ErrorHandler } from "./utils/ErrorHandler.js";
@@ -588,11 +589,29 @@ export class DollhouseMCPServer {
588
589
  // Export is already at class declaration
589
590
  // Only start the server if this file is being run directly (not imported by tests)
590
591
  // Handle different execution methods (direct, npx, CLI)
591
- const scriptPath = process.argv?.[1] ? path.normalize(process.argv[1]) : '';
592
+ //
593
+ // Bug fix: npx creates symlinks in .bin/ (e.g. .bin/mcp-server → dist/index.js).
594
+ // Node.js keeps the symlink path in process.argv[1], so without resolving it,
595
+ // isDirectExecution missed the dist/index.js suffix and the server never started.
596
+ const rawScriptPath = process.argv?.[1] ?? '';
597
+ let scriptPath = rawScriptPath ? path.normalize(rawScriptPath) : '';
598
+ try {
599
+ scriptPath = realpathSync(scriptPath);
600
+ }
601
+ catch {
602
+ if (process.env.DOLLHOUSE_DEBUG) {
603
+ console.error(`[DEBUG] Symlink resolution failed for ${rawScriptPath} — using original path`);
604
+ }
605
+ }
592
606
  const isDirectExecution = scriptPath.endsWith(`${path.sep}dist${path.sep}index.js`) ||
593
607
  scriptPath.endsWith(`${path.sep}src${path.sep}index.ts`);
594
- const isNpxExecution = process.env.npm_execpath?.includes('npx');
595
- const isCliExecution = process.argv[1]?.endsWith('/dollhousemcp') || process.argv[1]?.endsWith('\\dollhousemcp');
608
+ // Modern npm (v7+) runs npx as "npm exec" — npm_execpath may point to
609
+ // npm-cli.js instead of npx-cli.js. Detect both legacy and modern npx.
610
+ const isNpxExecution = process.env.npm_execpath?.includes('npx') ||
611
+ process.env.npm_command === 'exec';
612
+ // Match all registered bin entry names from package.json "bin" field
613
+ const binName = path.basename(rawScriptPath);
614
+ const isCliExecution = binName === 'dollhousemcp' || binName === 'mcp-server';
596
615
  const isTest = process.env.JEST_WORKER_ID; // This is set when Jest runs tests
597
616
  const isTestMode = process.env.TEST_MODE === 'true'; // Check for TEST_MODE environment variable
598
617
  const dollhouseDebugFlag = process.env.DOLLHOUSE_DEBUG?.toLowerCase();
@@ -618,7 +637,7 @@ async function startServerWithRetry(retriesLeft = STARTUP_DELAYS.length) {
618
637
  }
619
638
  // Final failure - minimal error message for security
620
639
  // Note: Using console.error here is intentional as it's the final error before exit
621
- console.error("[DollhouseMCP] Server startup failed", error); // Added error object
640
+ console.error("[DollhouseMCP] Server startup failed", process.env.DOLLHOUSE_DEBUG ? error : error.message || 'unknown error');
622
641
  process.exit(1);
623
642
  }
624
643
  }
@@ -715,4 +734,4 @@ if ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTes
715
734
  });
716
735
  }
717
736
  }
718
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\n// Load environment variables from .env files BEFORE anything else\n// This ensures .env.local and .env are loaded for all modules\nimport { env } from './config/env.js';\n\nimport * as path from 'path';\nimport { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport { StdioServerTransport } from \"@modelcontextprotocol/sdk/server/stdio.js\";\nimport { ErrorHandler } from \"./utils/ErrorHandler.js\";\nimport { logger } from \"./utils/logger.js\";\nimport { DollhouseContainer } from \"./di/Container.js\";\nimport { ElementType } from \"./portfolio/PortfolioManager.js\";\nimport { OperationalTelemetry, StartupTimer } from \"./telemetry/index.js\";\nimport { PACKAGE_VERSION } from \"./generated/version.js\";\nimport type { IndicatorConfig } from \"./config/indicator-config.js\";\nimport type { IToolHandler } from \"./server/index.js\";\nimport type { ToolRegistry } from \"./handlers/ToolRegistry.js\";\nimport type { PersonaHandler } from \"./handlers/PersonaHandler.js\";\nimport type { ElementCRUDHandler } from \"./handlers/ElementCRUDHandler.js\";\nimport type { CollectionHandler } from \"./handlers/CollectionHandler.js\";\nimport type { PortfolioHandler } from \"./handlers/PortfolioHandler.js\";\nimport type { GitHubAuthHandler } from \"./handlers/GitHubAuthHandler.js\";\nimport type { DisplayConfigHandler } from \"./handlers/DisplayConfigHandler.js\";\nimport type { IdentityHandler } from \"./handlers/IdentityHandler.js\";\nimport type { ConfigHandler } from \"./handlers/ConfigHandler.js\";\nimport type { SyncHandler } from \"./handlers/SyncHandlerV2.js\";\nimport type { EnhancedIndexHandler } from \"./handlers/EnhancedIndexHandler.js\";\nimport { ConfigManager } from \"./config/ConfigManager.js\";\nimport { FileOperationsService } from \"./services/FileOperationsService.js\";\nimport { FileLockManager } from \"./security/fileLockManager.js\";\nimport * as os from \"os\";\nimport type { EnsembleElement } from \"./elements/ensembles/types.js\";\n\n// Defensive error handling for npx/CLI execution\nprocess.on('uncaughtException', (error) => {\n  logger.error('Unhandled exception detected', {\n    error: error instanceof Error ? error.message : String(error),\n    stack: error instanceof Error ? error.stack : undefined\n  });\n  console.error('[DollhouseMCP] Server startup failed');\n  process.exit(1);\n});\n\nprocess.on('unhandledRejection', (reason, promise) => {\n  logger.error('Unhandled promise rejection detected', {\n    reason: reason instanceof Error ? reason.message : String(reason),\n    stack: reason instanceof Error ? reason.stack : undefined,\n    promise\n  });\n  console.error('[DollhouseMCP] Server startup failed');\n  process.exit(1);\n});\n\n// Only log execution environment in debug mode\nif (process.env.DOLLHOUSE_DEBUG) {\n  console.error('[DollhouseMCP] Debug mode enabled');\n}\n\nexport class DollhouseMCPServer implements IToolHandler {\n  private server: Server;\n  public personasDir: string | null;\n  private currentUser: string | null = null;\n  private isInitialized: boolean = false;\n  private initializationPromise: Promise<void> | null = null;\n  private container: DollhouseContainer;\n  private toolRegistry?: ToolRegistry;\n  private enhancedIndexHandler?: EnhancedIndexHandler;\n  private personaHandler?: PersonaHandler;\n  private elementCRUDHandler?: ElementCRUDHandler;\n  private collectionHandler?: CollectionHandler;\n  private portfolioHandler?: PortfolioHandler;\n  private githubAuthHandler?: GitHubAuthHandler;\n  private displayConfigHandler?: DisplayConfigHandler;\n  private identityHandler?: IdentityHandler;\n  private configHandler?: ConfigHandler;\n  private syncHandler?: SyncHandler;\n  private resourceHandler?: import('./handlers/ResourceHandler.js').ResourceHandler;\n\n  /**\n   * Create a new DollhouseMCPServer instance\n   *\n   * @param container DollhouseContainer instance for dependency injection.\n   *                  Use `new DollhouseContainer()` for production or\n   *                  `createIntegrationContainer().container` for tests.\n   */\n  constructor(container: DollhouseContainer) {\n    // Build capabilities object conditionally based on configuration\n    // Resources are disabled by default (advertise_resources: false)\n    const capabilities: any = {\n      tools: {},\n    };\n\n    // Check if resources should be advertised\n    // This is a future-proof implementation - resources are opt-in\n    try {\n      // Initialize ConfigManager to check resource settings\n      // Note: Config may not be fully initialized yet, so we check synchronously\n      // If config is not initialized, defaults (advertise_resources: false) apply\n      const fileLockManager = new FileLockManager();\n      const fileOperations = new FileOperationsService(fileLockManager);\n      const configManager = new ConfigManager(fileOperations, os);\n      const resourcesConfig = configManager.getSetting<any>('elements.enhanced_index.resources');\n\n      if (resourcesConfig?.advertise_resources === true) {\n        capabilities.resources = {};\n        logger.info('[DollhouseMCP] MCP Resources capability advertised (enabled via config)');\n      } else {\n        logger.info('[DollhouseMCP] MCP Resources capability NOT advertised (disabled by default)');\n      }\n    } catch (error) {\n      // Config not initialized yet - use safe default (no resources)\n      const errorMessage = error instanceof Error ? error.message : String(error);\n      logger.debug(`[DollhouseMCP] Config not initialized yet, resources capability disabled by default: ${errorMessage}`);\n    }\n\n    this.server = new Server(\n      {\n        name: \"dollhousemcp\",\n        version: PACKAGE_VERSION,\n      },\n      {\n        capabilities,\n      }\n    );\n\n    this.personasDir = null;\n    this.currentUser = process.env.DOLLHOUSE_USER || null;\n    this.container = container;\n  }\n  \n  private async initializePortfolio(): Promise<void> {\n    await this.container.preparePortfolio();\n    this.personasDir = this.container.getPersonasDir();\n  }\n  \n  /**\n   * Complete initialization after portfolio is ready\n   * FIX #610: This was previously in a .then() callback in the constructor\n   * Now called synchronously from run() to prevent race condition\n   */\n  private async completeInitialization(): Promise<void> {\n    // Create handlers with server instance - all state managed by services\n    const handlers = await this.container.createHandlers(this.server);\n\n    this.personaHandler = handlers.personaHandler;\n    this.elementCRUDHandler = handlers.elementCrudHandler;\n    this.collectionHandler = handlers.collectionHandler;\n    this.portfolioHandler = handlers.portfolioHandler;\n    this.githubAuthHandler = handlers.githubAuthHandler;\n    this.displayConfigHandler = handlers.displayConfigHandler;\n    this.identityHandler = handlers.identityHandler;\n    this.configHandler = handlers.configHandler;\n    this.syncHandler = handlers.syncHandler;\n    this.toolRegistry = handlers.toolRegistry;\n    this.enhancedIndexHandler = handlers.enhancedIndexHandler;\n\n    // Initialize and register resource handlers\n    // Resources are disabled by default and require explicit configuration\n    await this.initializeResourceHandlers();\n\n    this.isInitialized = true;\n  }\n\n  /**\n   * Initialize MCP Resources handlers if enabled in configuration\n   * This is separate from other handlers because it requires dynamic import\n   * and conditional registration based on configuration\n   */\n  private async initializeResourceHandlers(): Promise<void> {\n    try {\n      const { ResourceHandler } = await import('./handlers/ResourceHandler.js');\n      const configManager = this.container.resolve<ConfigManager>('ConfigManager');\n\n      this.resourceHandler = new ResourceHandler(configManager);\n      await this.resourceHandler.initialize(this.server);\n    } catch (error) {\n      // Resources are optional - don't fail server startup if they can't be initialized\n      logger.warn('[DollhouseMCP] Failed to initialize resource handlers, continuing without resources');\n      logger.debug(`Resource initialization error: ${error}`);\n    }\n  }\n  \n  /**\n   * Ensure server is initialized before any operation\n   * FIX #610: Added for test compatibility - tests don't call run()\n   */\n  private async ensureInitialized(): Promise<void> {\n    if (this.isInitialized) {\n      return;\n    }\n    \n    // If initialization is already in progress, wait for it\n    if (this.initializationPromise) {\n      await this.initializationPromise;\n      return;\n    }\n    \n    // Start initialization\n    this.initializationPromise = (async () => {\n      try {\n        await this.initializePortfolio();\n        await this.completeInitialization();\n        logger.info(\"Portfolio and personas initialized successfully (lazy)\");\n      } catch (error) {\n        ErrorHandler.logError('DollhouseMCPServer.ensureInitialized', error);\n        throw error;\n      }\n    })();\n    \n    await this.initializationPromise;\n  }\n  \n  // Tool handler methods - now public for access from tool modules\n  \n  async listPersonas() {\n    await this.ensureInitialized();\n    return this.personaHandler!.listPersonas();\n  }\n\n  // Use activateElement(name, 'persona'), deactivateElement(name, 'persona'),\n  // getActiveElements('persona'), and getElementDetails(name, 'persona') instead.\n  // These were removed to normalize persona handling through the generic element API.\n\n  async reloadPersonas() {\n    await this.ensureInitialized();\n    return this.personaHandler!.reloadPersonas();\n  }\n\n  // ===== Element Methods (Generic for all element types) =====\n  \n  async listElements(type: string) {\n    try {\n      const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n      if (normalizedType === ElementType.PERSONA) {\n        return this.listPersonas();\n      }\n      return this.elementCRUDHandler!.listElements(normalizedType);\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.listElements', error, { type });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to list ${type}: ${ErrorHandler.getUserMessage(error)}`\n        }]\n      };\n    }\n  }\n  \n  async activateElement(name: string, type: string, context?: Record<string, any>) {\n    try {\n      // FIX: Issue #281 - Route all element types through elementCRUDHandler\n      // PersonaHandler.activatePersona is deprecated; PersonaActivationStrategy handles personas\n      const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n      return this.elementCRUDHandler!.activateElement(name, normalizedType, context);\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.activateElement', error, { type, name });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to activate ${type} '${name}': ${ErrorHandler.getUserMessage(error)}`\n        }]\n      };\n    }\n  }\n  \n  async getActiveElements(type: string) {\n    try {\n      // FIX: Issue #281 - Route all element types through elementCRUDHandler\n      // PersonaHandler.getActivePersona is deprecated; PersonaActivationStrategy handles personas\n      const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n      return this.elementCRUDHandler!.getActiveElements(normalizedType);\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.getActiveElements', error, { type });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get active ${type}: ${ErrorHandler.getUserMessage(error)}`\n        }]\n      };\n    }\n  }\n  \n  async deactivateElement(name: string, type: string) {\n    try {\n      // FIX: Issue #281 - Route all element types through elementCRUDHandler\n      // PersonaHandler.deactivatePersona is deprecated; PersonaActivationStrategy handles personas\n      const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n      return this.elementCRUDHandler!.deactivateElement(name, normalizedType);\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.deactivateElement', error, { type, name });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to deactivate ${type} '${name}': ${ErrorHandler.getUserMessage(error)}`\n        }]\n      };\n    }\n  }\n  \n  async getElementDetails(name: string, type: string) {\n    // FIX: Issue #276 - Route all element types through elementCRUDHandler for consistent error handling\n    // PersonaHandler.getPersonaDetails is deprecated; PersonaActivationStrategy handles personas\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n    return this.elementCRUDHandler!.getElementDetails(name, normalizedType);\n  }\n  \n  async reloadElements(type: string) {\n    await this.ensureInitialized();\n    return this.elementCRUDHandler!.reloadElements(type);\n  }\n\n  // Element-specific methods\n  async renderTemplate(name: string, variables: Record<string, any>) {\n    await this.ensureInitialized();\n    return this.elementCRUDHandler!.renderTemplate(name, variables);\n  }\n\n  async executeAgent(name: string, parameters: Record<string, any>) {\n    await this.ensureInitialized();\n    return this.elementCRUDHandler!.executeAgent(name, parameters);\n  }\n  \n  /**\n   * Create a new element in the portfolio.\n   * @param args.elements - For ensembles: array of element references (Issue #278)\n   */\n  async createElement(args: {name: string; type: string; description: string; content?: string; instructions?: string; metadata?: Record<string, unknown>; elements?: EnsembleElement[]}) {\n    await this.ensureInitialized();\n    // FIX: Issue #20 - Remove persona special case, route all element creation through ElementCRUDHandler\n    // This ensures consistent duplicate checking and error handling for all element types\n    // FIX: Issue #278 - Support elements parameter for ensembles\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(args.type);\n    return this.elementCRUDHandler!.createElement({...args, type: normalizedType});\n  }\n\n  async editElement(args: {name: string; type: string; input: Record<string, unknown>}) {\n    await this.ensureInitialized();\n    // FIX: Issue #276 - Route all element types through elementCRUDHandler for consistent error handling\n    // PersonaHandler.editPersona is deprecated; elementCRUDHandler handles personas via PersonaActivationStrategy\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(args.type);\n    return this.elementCRUDHandler!.editElement({...args, type: normalizedType});\n  }\n\n  async validateElement(args: {name: string; type: string; strict?: boolean}) {\n    await this.ensureInitialized();\n    // FIX: Issue #276 - Route all element types through elementCRUDHandler for consistent error handling\n    // PersonaHandler.validatePersona is deprecated; elementCRUDHandler handles personas\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(args.type);\n    return this.elementCRUDHandler!.validateElement({...args, type: normalizedType});\n  }\n\n  async deleteElement(args: {name: string; type: string; deleteData?: boolean}) {\n    await this.ensureInitialized();\n    // FIX: Issue #276 - Route all element types through elementCRUDHandler for consistent error handling\n    // PersonaHandler.deletePersona is deprecated; elementCRUDHandler handles personas via dedicated delete path\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(args.type);\n    return this.elementCRUDHandler!.deleteElement({...args, type: normalizedType});\n  }\n\n  async browseCollection(section?: string, type?: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.browseCollection(section, type);\n  }\n\n  async searchCollection(query: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.searchCollection(query);\n  }\n\n  async searchCollectionEnhanced(query: string, options: any = {}) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.searchCollectionEnhanced(query, options);\n  }\n\n  async getCollectionContent(path: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.getCollectionContent(path);\n  }\n\n  async installContent(inputPath: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.installContent(inputPath);\n  }\n\n  async submitContent(contentIdentifier: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.submitContent(contentIdentifier);\n  }\n\n  async getCollectionCacheHealth() {\n    await this.ensureInitialized();\n    return this.collectionHandler!.getCollectionCacheHealth();\n  }\n\n  // User identity management - delegated to IdentityHandler\n  async setUserIdentity(username: string, email?: string) {\n    await this.ensureInitialized();\n    return this.identityHandler!.setUserIdentity(username, email);\n  }\n\n  async getUserIdentity() {\n    await this.ensureInitialized();\n    return this.identityHandler!.getUserIdentity();\n  }\n\n  async clearUserIdentity() {\n    await this.ensureInitialized();\n    return this.identityHandler!.clearUserIdentity();\n  }\n\n  private getCurrentUserForAttribution(): string {\n    return this.identityHandler!.getCurrentUserForAttribution();\n  }\n\n  // GitHub authentication management\n  async setupGitHubAuth() {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.setupGitHubAuth();\n  }\n  \n  async checkGitHubAuth() {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.checkGitHubAuth();\n  }\n  \n  async getOAuthHelperStatus(verbose: boolean = false) {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.getOAuthHelperStatus(verbose);\n  }\n  \n\n  \n  async clearGitHubAuth() {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.clearGitHubAuth();\n  }\n\n  // OAuth configuration management\n  async configureOAuth(client_id?: string) {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.configureOAuth(client_id);\n  }\n\n\n\n\n\n\n\n\n\n\n  /**\n   * Configure indicator settings (delegated to DisplayConfigHandler)\n   */\n  async configureIndicator(config: Partial<IndicatorConfig>) {\n    await this.ensureInitialized();\n    return this.displayConfigHandler!.configureIndicator(config);\n  }\n\n  /**\n   * Get current indicator configuration (delegated to DisplayConfigHandler)\n   */\n  async getIndicatorConfig() {\n    await this.ensureInitialized();\n    return this.displayConfigHandler!.getIndicatorConfig();\n  }\n\n  /**\n   * Configure collection submission settings (delegated to CollectionHandler)\n   */\n  async configureCollectionSubmission(autoSubmit: boolean) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.configureCollectionSubmission(autoSubmit);\n  }\n\n  /**\n   * Get collection submission configuration (delegated to CollectionHandler)\n   */\n  async getCollectionSubmissionConfig() {\n    await this.ensureInitialized();\n    return this.collectionHandler!.getCollectionSubmissionConfig();\n  }\n\n\n  /**\n   * Export a single persona\n   */\n  async exportPersona(personaName: string) {\n    await this.ensureInitialized();\n    return this.personaHandler!.exportPersona(personaName);\n  }\n\n  /**\n   * Export all personas\n   */\n  async exportAllPersonas(includeDefaults = true) {\n    await this.ensureInitialized();\n    return this.personaHandler!.exportAllPersonas(includeDefaults);\n  }\n\n  /**\n   * Import a persona\n   */\n  async importPersona(source: string, overwrite = false) {\n    await this.ensureInitialized();\n    return this.personaHandler!.importPersona(source, overwrite);\n  }\n\n\n  /**\n   * Portfolio management methods\n   */\n\n  /**\n   * Check portfolio status including repository existence and sync information\n   */\n  async portfolioStatus(username?: string) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.portfolioStatus(username);\n  }\n\n  /**\n   * Initialize a new GitHub portfolio repository\n   */\n  async initPortfolio(options: {repositoryName?: string; private?: boolean; description?: string}) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.initPortfolio(options);\n  }\n\n  /**\n   * Configure portfolio settings\n   */\n  async portfolioConfig(options: {autoSync?: boolean; defaultVisibility?: string; autoSubmit?: boolean; repositoryName?: string}) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.portfolioConfig(options);\n  }\n\n  /**\n   * Sync portfolio with GitHub\n   */\n  async syncPortfolio(options: {\n    direction: string;\n    mode?: string;\n    force: boolean;\n    dryRun: boolean;\n    confirmDeletions?: boolean;\n  }) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.syncPortfolio(options);\n  }\n\n  /**\n   * Handle configuration operations - delegates to ConfigHandler\n  */\n  async handleConfigOperation(options: any) {\n    await this.ensureInitialized();\n    return this.configHandler!.handleConfigOperation(options);\n  }\n\n  /**\n   * Handle sync operations - delegates to SyncHandler\n   */\n  async handleSyncOperation(options: any) {\n    await this.ensureInitialized();\n    return this.syncHandler!.handleSyncOperation(options);\n  }\n\n  async dispose(): Promise<void> {\n    await this.container.dispose();\n  }\n\n  /**\n   * Search local portfolio using the metadata index system\n   * This provides fast, comprehensive search across all element types\n   */\n  async searchPortfolio(options: {\n    query: string; \n    elementType?: string; \n    fuzzyMatch?: boolean; \n    maxResults?: number; \n    includeKeywords?: boolean; \n    includeTags?: boolean; \n    includeTriggers?: boolean; \n    includeDescriptions?: boolean;\n  }) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.searchPortfolio(options);\n  }\n\n  /**\n   * Search across all sources (local, GitHub, collection) using UnifiedIndexManager\n   * This provides comprehensive search with duplicate detection and version comparison\n   */\n  async searchAll(options: {\n    query: string;\n    sources?: string[];\n    elementType?: string;\n    page?: number;\n    pageSize?: number;\n    sortBy?: string;\n  }) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.searchAll(options);\n  }\n\n  /**\n   * Find semantically similar elements using Enhanced Index\n   */\n  async findSimilarElements(options: {\n    elementName: string;\n    elementType?: string;\n    limit: number;\n    threshold: number;\n  }) {\n    return this.enhancedIndexHandler!.findSimilarElements(options);\n  }\n\n  /**\n   * Get all relationships for a specific element\n   */\n  async getElementRelationships(options: {\n    elementName: string;\n    elementType?: string;\n    relationshipTypes?: string[];\n  }) {\n    return this.enhancedIndexHandler!.getElementRelationships(options);\n  }\n\n  /**\n   * Search for elements by action verb\n   */\n  async searchByVerb(options: {\n    verb: string;\n    limit: number;\n  }) {\n    return this.enhancedIndexHandler!.searchByVerb(options);\n  }\n\n  /**\n   * Get statistics about Enhanced Index relationships\n   */\n  async getRelationshipStats() {\n    return this.enhancedIndexHandler!.getRelationshipStats();\n  }\n\n  async run() {\n    logger.debug(\"DollhouseMCPServer.run() started\");\n    logger.info(\"Starting DollhouseMCP server...\");\n\n    const timer = this.container.resolve<StartupTimer>('StartupTimer');\n\n    // Issue #706: Critical path only — get to connect() as fast as possible\n    // Non-critical work (memory auto-load, activation restore, etc.) is\n    // deferred to completeDeferredSetup() which runs post-connect.\n    try {\n      timer.startPhase('portfolio_prepare', true);\n      await this.initializePortfolio();\n      timer.endPhase('portfolio_prepare');\n\n      timer.startPhase('handler_creation', true);\n      await this.completeInitialization();\n      timer.endPhase('handler_creation');\n\n      // Initialize operational telemetry (async, non-blocking, never throws)\n      const operationalTelemetry = this.container.resolve<OperationalTelemetry>('OperationalTelemetry');\n      operationalTelemetry.initialize().catch(() => {\n        // Telemetry errors are logged internally, safe to ignore here\n      });\n\n      logger.info(\"Portfolio and personas initialized successfully\");\n\n      if (!env.DOLLHOUSE_GATEKEEPER_ENABLED) {\n        logger.warn(\"⚠️  Gatekeeper is DISABLED (DOLLHOUSE_GATEKEEPER_ENABLED=false). All permission checks are bypassed.\");\n      }\n\n      logger.info(\"DollhouseMCP server ready - waiting for MCP connection on stdio\");\n      logger.debug(\"DollhouseMCPServer.run() completed initialization\");\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.run.initialization', error);\n      throw error; // Re-throw to prevent server from starting with incomplete initialization\n    }\n\n    const transport = new StdioServerTransport();\n\n    // Set up graceful shutdown handlers\n    const cleanup = async () => {\n      logger.info(\"Shutting down DollhouseMCP server...\");\n\n      try {\n        await this.container.dispose();\n        logger.info(\"Cleanup completed\");\n      } catch (error) {\n        logger.error(\"Error during cleanup\", { error });\n      }\n\n      process.exit(0);\n    };\n\n    // Register shutdown handlers\n    process.on('SIGINT', cleanup);\n    process.on('SIGTERM', cleanup);\n    process.on('SIGHUP', cleanup);\n\n    // Connect ASAP — tools are registered, server can accept requests\n    timer.startPhase('mcp_connect', true);\n    await this.server.connect(transport);\n    timer.endPhase('mcp_connect');\n    timer.markConnect();\n\n    // Mark that MCP is now connected - no more console output allowed\n    logger.setMCPConnected();\n\n    // Issue #706 Phase 3: Emit READY sentinel for bridge clients\n    process.stderr.write('DOLLHOUSEMCP_READY\\n');\n\n    logger.info(\"DollhouseMCP server running on stdio\");\n\n    // Issue #706 Phase 2: Deferred setup — runs post-connect, non-blocking\n    // Pattern encryption, background validator, memory auto-load, activation\n    // restore, log hooks, danger zone init all move here.\n    const deferredPromise = this.container.completeDeferredSetup();\n    deferredPromise.catch(err => logger.warn('[Startup] Deferred setup error:', err));\n\n    // Issue #706 Phase 4: Wire deferred promise into ServerSetup for request buffering\n    const serverSetup = this.container.resolve<import('./server/ServerSetup.js').ServerSetup>('ServerSetup');\n    serverSetup.setDeferredSetupPromise(deferredPromise);\n\n    // Log startup timing after deferred setup completes\n    deferredPromise.then(async () => {\n      const report = timer.getReport();\n      logger.info(`[Startup] Full report: connect at ${report.connectAtMs}ms, ` +\n        `critical ${report.criticalPathMs}ms, deferred ${report.deferredMs}ms, ` +\n        `total ${report.totalMs}ms`);\n    }).catch(() => { /* already logged */ });\n\n  }\n}\n\n// Export is already at class declaration\n\n// Only start the server if this file is being run directly (not imported by tests)\n// Handle different execution methods (direct, npx, CLI)\nconst scriptPath = process.argv?.[1] ? path.normalize(process.argv[1]) : '';\nconst isDirectExecution =\n  scriptPath.endsWith(`${path.sep}dist${path.sep}index.js`) ||\n  scriptPath.endsWith(`${path.sep}src${path.sep}index.ts`);\nconst isNpxExecution = process.env.npm_execpath?.includes('npx');\nconst isCliExecution = process.argv[1]?.endsWith('/dollhousemcp') || process.argv[1]?.endsWith('\\\\dollhousemcp');\nconst isTest = process.env.JEST_WORKER_ID; // This is set when Jest runs tests\nconst isTestMode = process.env.TEST_MODE === 'true'; // Check for TEST_MODE environment variable\nconst dollhouseDebugFlag = process.env.DOLLHOUSE_DEBUG?.toLowerCase();\nconst isDebugStartupLogging = dollhouseDebugFlag === 'true' || dollhouseDebugFlag === '1';\n\n// Progressive startup with retries for npx/CLI execution\nconst STARTUP_DELAYS = [10, 50, 100, 200]; // Progressive delays in ms\n\nasync function startServerWithRetry(retriesLeft = STARTUP_DELAYS.length): Promise<void> {\n  if (isDebugStartupLogging) {\n    console.error(\"DEBUG: startServerWithRetry called.\");\n  }\n  try {\n    const container = new DollhouseContainer();\n    const server = new DollhouseMCPServer(container);\n    await server.run();\n  } catch (error) {\n    if (retriesLeft > 0 && (isNpxExecution || isCliExecution)) {\n      // Try again with a longer delay\n      const delayIndex = STARTUP_DELAYS.length - retriesLeft;\n      const delay = STARTUP_DELAYS[delayIndex];\n      await new Promise(resolve => setTimeout(resolve, delay));\n      return startServerWithRetry(retriesLeft - 1);\n    }\n    // Final failure - minimal error message for security\n    // Note: Using console.error here is intentional as it's the final error before exit\n    console.error(\"[DollhouseMCP] Server startup failed\", error); // Added error object\n    process.exit(1);\n  }\n}\n\nif ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTestMode)) {\n  // Issue #704: --web flag starts the portfolio web UI instead of MCP server\n  const isWebMode = process.argv.includes('--web');\n  if (isWebMode) {\n    // Issue #796: Bootstrap DI container for web-only mode so API routes\n    // go through MCPAQLHandler (validated, cached, gatekeeper-checked)\n    //\n    // Suppress terminal output in --web mode unless DOLLHOUSE_DEBUG is set.\n    // All logs are still captured in MemoryLogSink and visible in the Logs tab —\n    // the terminal only needs the console URL banner, not a wall of startup noise.\n    if (!process.env.DOLLHOUSE_DEBUG && !process.env.ENABLE_DEBUG) {\n      logger.setMinLevel('error');\n    }\n\n    (async () => {\n      const portfolioDir = path.join(os.homedir(), '.dollhouse', 'portfolio');\n      const portArg = process.argv.find(a => a.startsWith('--port='));\n      const port = portArg ? parseInt(portArg.split('=')[1], 10) : undefined;\n      const noBrowser = process.argv.includes('--no-open');\n\n      let mcpAqlHandler;\n      let memorySink: import('./logging/sinks/MemoryLogSink.js').MemoryLogSink | undefined;\n      let metricsSink: import('./metrics/sinks/MemoryMetricsSink.js').MemoryMetricsSink | undefined;\n      try {\n        const container = new DollhouseContainer();\n        await container.preparePortfolio();\n        const bundle = await container.bootstrapHandlers();\n        await container.completeDeferredSetup();\n        mcpAqlHandler = bundle.mcpAqlHandler;\n        // Extract sinks from container — deferred setup may have already wired them\n        try { memorySink = container.resolve<import('./logging/sinks/MemoryLogSink.js').MemoryLogSink>('MemoryLogSink'); } catch { /* not registered */ }\n        try { metricsSink = container.resolve<import('./metrics/sinks/MemoryMetricsSink.js').MemoryMetricsSink>('MemoryMetricsSink'); } catch { /* not registered */ }\n      } catch (err) {\n        console.error(\"[DollhouseMCP] Container bootstrap failed — web routes will use direct filesystem access.\");\n        console.error(\"[DollhouseMCP] Reason:\", (err as Error).message || err);\n        console.error(\"[DollhouseMCP] This may indicate a corrupt portfolio or missing dependencies.\");\n      }\n\n      // Ensure sinks exist even if container bootstrap failed —\n      // standalone --web mode still needs working logs and metrics tabs\n      if (!memorySink) {\n        const { MemoryLogSink } = await import('./logging/sinks/MemoryLogSink.js');\n        memorySink = new MemoryLogSink({\n          appCapacity: 10000,\n          securityCapacity: 5000,\n          perfCapacity: 2000,\n          telemetryCapacity: 1000,\n        });\n      }\n      if (!metricsSink) {\n        const { MemoryMetricsSink } = await import('./metrics/sinks/MemoryMetricsSink.js');\n        metricsSink = new MemoryMetricsSink(240);\n      }\n\n      const { startWebServer } = await import('./web/server.js');\n      await startWebServer({ portfolioDir, port, openBrowser: !noBrowser, mcpAqlHandler, memorySink, metricsSink });\n\n      // Listen for quit commands on stdin (standalone --web mode only).\n      // In MCP stdio mode, stdin is consumed by the JSON-RPC transport.\n      if (process.stdin.isTTY) {\n        process.stdin.setEncoding('utf-8');\n        process.stdin.resume();\n        let quitDebounce: ReturnType<typeof setTimeout> | null = null;\n        process.stdin.on('data', (data: string) => {\n          const cmd = data.trim().toLowerCase();\n          if (cmd === 'q' || cmd === 'quit' || cmd === 'exit') {\n            // Debounce rapid inputs (e.g., accidental double-tap)\n            if (quitDebounce) return;\n            quitDebounce = setTimeout(() => { quitDebounce = null; }, 200);\n            console.error('\\n  Shutting down DollhouseMCP...\\n');\n            process.exit(0);\n          }\n        });\n      }\n    })().catch(err => {\n      console.error(\"[DollhouseMCP] Web UI failed to start:\", err);\n      process.exit(1);\n    });\n  } else {\n    if (isDebugStartupLogging) {\n      console.error(\"DEBUG: Server startup condition met. Calling startServerWithRetry.\");\n    }\n    startServerWithRetry().catch(() => {\n      // Note: Using console.error here is intentional as it's the final error before exit\n      console.error(\"[DollhouseMCP] Server startup failed\");\n      process.exit(1);\n    });\n  }\n}\n"]}
737
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\n// Load environment variables from .env files BEFORE anything else\n// This ensures .env.local and .env are loaded for all modules\nimport { env } from './config/env.js';\n\nimport * as path from 'path';\nimport { realpathSync } from 'node:fs';\nimport { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport { StdioServerTransport } from \"@modelcontextprotocol/sdk/server/stdio.js\";\nimport { ErrorHandler } from \"./utils/ErrorHandler.js\";\nimport { logger } from \"./utils/logger.js\";\nimport { DollhouseContainer } from \"./di/Container.js\";\nimport { ElementType } from \"./portfolio/PortfolioManager.js\";\nimport { OperationalTelemetry, StartupTimer } from \"./telemetry/index.js\";\nimport { PACKAGE_VERSION } from \"./generated/version.js\";\nimport type { IndicatorConfig } from \"./config/indicator-config.js\";\nimport type { IToolHandler } from \"./server/index.js\";\nimport type { ToolRegistry } from \"./handlers/ToolRegistry.js\";\nimport type { PersonaHandler } from \"./handlers/PersonaHandler.js\";\nimport type { ElementCRUDHandler } from \"./handlers/ElementCRUDHandler.js\";\nimport type { CollectionHandler } from \"./handlers/CollectionHandler.js\";\nimport type { PortfolioHandler } from \"./handlers/PortfolioHandler.js\";\nimport type { GitHubAuthHandler } from \"./handlers/GitHubAuthHandler.js\";\nimport type { DisplayConfigHandler } from \"./handlers/DisplayConfigHandler.js\";\nimport type { IdentityHandler } from \"./handlers/IdentityHandler.js\";\nimport type { ConfigHandler } from \"./handlers/ConfigHandler.js\";\nimport type { SyncHandler } from \"./handlers/SyncHandlerV2.js\";\nimport type { EnhancedIndexHandler } from \"./handlers/EnhancedIndexHandler.js\";\nimport { ConfigManager } from \"./config/ConfigManager.js\";\nimport { FileOperationsService } from \"./services/FileOperationsService.js\";\nimport { FileLockManager } from \"./security/fileLockManager.js\";\nimport * as os from \"os\";\nimport type { EnsembleElement } from \"./elements/ensembles/types.js\";\n\n// Defensive error handling for npx/CLI execution\nprocess.on('uncaughtException', (error) => {\n  logger.error('Unhandled exception detected', {\n    error: error instanceof Error ? error.message : String(error),\n    stack: error instanceof Error ? error.stack : undefined\n  });\n  console.error('[DollhouseMCP] Server startup failed');\n  process.exit(1);\n});\n\nprocess.on('unhandledRejection', (reason, promise) => {\n  logger.error('Unhandled promise rejection detected', {\n    reason: reason instanceof Error ? reason.message : String(reason),\n    stack: reason instanceof Error ? reason.stack : undefined,\n    promise\n  });\n  console.error('[DollhouseMCP] Server startup failed');\n  process.exit(1);\n});\n\n// Only log execution environment in debug mode\nif (process.env.DOLLHOUSE_DEBUG) {\n  console.error('[DollhouseMCP] Debug mode enabled');\n}\n\nexport class DollhouseMCPServer implements IToolHandler {\n  private server: Server;\n  public personasDir: string | null;\n  private currentUser: string | null = null;\n  private isInitialized: boolean = false;\n  private initializationPromise: Promise<void> | null = null;\n  private container: DollhouseContainer;\n  private toolRegistry?: ToolRegistry;\n  private enhancedIndexHandler?: EnhancedIndexHandler;\n  private personaHandler?: PersonaHandler;\n  private elementCRUDHandler?: ElementCRUDHandler;\n  private collectionHandler?: CollectionHandler;\n  private portfolioHandler?: PortfolioHandler;\n  private githubAuthHandler?: GitHubAuthHandler;\n  private displayConfigHandler?: DisplayConfigHandler;\n  private identityHandler?: IdentityHandler;\n  private configHandler?: ConfigHandler;\n  private syncHandler?: SyncHandler;\n  private resourceHandler?: import('./handlers/ResourceHandler.js').ResourceHandler;\n\n  /**\n   * Create a new DollhouseMCPServer instance\n   *\n   * @param container DollhouseContainer instance for dependency injection.\n   *                  Use `new DollhouseContainer()` for production or\n   *                  `createIntegrationContainer().container` for tests.\n   */\n  constructor(container: DollhouseContainer) {\n    // Build capabilities object conditionally based on configuration\n    // Resources are disabled by default (advertise_resources: false)\n    const capabilities: any = {\n      tools: {},\n    };\n\n    // Check if resources should be advertised\n    // This is a future-proof implementation - resources are opt-in\n    try {\n      // Initialize ConfigManager to check resource settings\n      // Note: Config may not be fully initialized yet, so we check synchronously\n      // If config is not initialized, defaults (advertise_resources: false) apply\n      const fileLockManager = new FileLockManager();\n      const fileOperations = new FileOperationsService(fileLockManager);\n      const configManager = new ConfigManager(fileOperations, os);\n      const resourcesConfig = configManager.getSetting<any>('elements.enhanced_index.resources');\n\n      if (resourcesConfig?.advertise_resources === true) {\n        capabilities.resources = {};\n        logger.info('[DollhouseMCP] MCP Resources capability advertised (enabled via config)');\n      } else {\n        logger.info('[DollhouseMCP] MCP Resources capability NOT advertised (disabled by default)');\n      }\n    } catch (error) {\n      // Config not initialized yet - use safe default (no resources)\n      const errorMessage = error instanceof Error ? error.message : String(error);\n      logger.debug(`[DollhouseMCP] Config not initialized yet, resources capability disabled by default: ${errorMessage}`);\n    }\n\n    this.server = new Server(\n      {\n        name: \"dollhousemcp\",\n        version: PACKAGE_VERSION,\n      },\n      {\n        capabilities,\n      }\n    );\n\n    this.personasDir = null;\n    this.currentUser = process.env.DOLLHOUSE_USER || null;\n    this.container = container;\n  }\n  \n  private async initializePortfolio(): Promise<void> {\n    await this.container.preparePortfolio();\n    this.personasDir = this.container.getPersonasDir();\n  }\n  \n  /**\n   * Complete initialization after portfolio is ready\n   * FIX #610: This was previously in a .then() callback in the constructor\n   * Now called synchronously from run() to prevent race condition\n   */\n  private async completeInitialization(): Promise<void> {\n    // Create handlers with server instance - all state managed by services\n    const handlers = await this.container.createHandlers(this.server);\n\n    this.personaHandler = handlers.personaHandler;\n    this.elementCRUDHandler = handlers.elementCrudHandler;\n    this.collectionHandler = handlers.collectionHandler;\n    this.portfolioHandler = handlers.portfolioHandler;\n    this.githubAuthHandler = handlers.githubAuthHandler;\n    this.displayConfigHandler = handlers.displayConfigHandler;\n    this.identityHandler = handlers.identityHandler;\n    this.configHandler = handlers.configHandler;\n    this.syncHandler = handlers.syncHandler;\n    this.toolRegistry = handlers.toolRegistry;\n    this.enhancedIndexHandler = handlers.enhancedIndexHandler;\n\n    // Initialize and register resource handlers\n    // Resources are disabled by default and require explicit configuration\n    await this.initializeResourceHandlers();\n\n    this.isInitialized = true;\n  }\n\n  /**\n   * Initialize MCP Resources handlers if enabled in configuration\n   * This is separate from other handlers because it requires dynamic import\n   * and conditional registration based on configuration\n   */\n  private async initializeResourceHandlers(): Promise<void> {\n    try {\n      const { ResourceHandler } = await import('./handlers/ResourceHandler.js');\n      const configManager = this.container.resolve<ConfigManager>('ConfigManager');\n\n      this.resourceHandler = new ResourceHandler(configManager);\n      await this.resourceHandler.initialize(this.server);\n    } catch (error) {\n      // Resources are optional - don't fail server startup if they can't be initialized\n      logger.warn('[DollhouseMCP] Failed to initialize resource handlers, continuing without resources');\n      logger.debug(`Resource initialization error: ${error}`);\n    }\n  }\n  \n  /**\n   * Ensure server is initialized before any operation\n   * FIX #610: Added for test compatibility - tests don't call run()\n   */\n  private async ensureInitialized(): Promise<void> {\n    if (this.isInitialized) {\n      return;\n    }\n    \n    // If initialization is already in progress, wait for it\n    if (this.initializationPromise) {\n      await this.initializationPromise;\n      return;\n    }\n    \n    // Start initialization\n    this.initializationPromise = (async () => {\n      try {\n        await this.initializePortfolio();\n        await this.completeInitialization();\n        logger.info(\"Portfolio and personas initialized successfully (lazy)\");\n      } catch (error) {\n        ErrorHandler.logError('DollhouseMCPServer.ensureInitialized', error);\n        throw error;\n      }\n    })();\n    \n    await this.initializationPromise;\n  }\n  \n  // Tool handler methods - now public for access from tool modules\n  \n  async listPersonas() {\n    await this.ensureInitialized();\n    return this.personaHandler!.listPersonas();\n  }\n\n  // Use activateElement(name, 'persona'), deactivateElement(name, 'persona'),\n  // getActiveElements('persona'), and getElementDetails(name, 'persona') instead.\n  // These were removed to normalize persona handling through the generic element API.\n\n  async reloadPersonas() {\n    await this.ensureInitialized();\n    return this.personaHandler!.reloadPersonas();\n  }\n\n  // ===== Element Methods (Generic for all element types) =====\n  \n  async listElements(type: string) {\n    try {\n      const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n      if (normalizedType === ElementType.PERSONA) {\n        return this.listPersonas();\n      }\n      return this.elementCRUDHandler!.listElements(normalizedType);\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.listElements', error, { type });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to list ${type}: ${ErrorHandler.getUserMessage(error)}`\n        }]\n      };\n    }\n  }\n  \n  async activateElement(name: string, type: string, context?: Record<string, any>) {\n    try {\n      // FIX: Issue #281 - Route all element types through elementCRUDHandler\n      // PersonaHandler.activatePersona is deprecated; PersonaActivationStrategy handles personas\n      const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n      return this.elementCRUDHandler!.activateElement(name, normalizedType, context);\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.activateElement', error, { type, name });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to activate ${type} '${name}': ${ErrorHandler.getUserMessage(error)}`\n        }]\n      };\n    }\n  }\n  \n  async getActiveElements(type: string) {\n    try {\n      // FIX: Issue #281 - Route all element types through elementCRUDHandler\n      // PersonaHandler.getActivePersona is deprecated; PersonaActivationStrategy handles personas\n      const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n      return this.elementCRUDHandler!.getActiveElements(normalizedType);\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.getActiveElements', error, { type });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get active ${type}: ${ErrorHandler.getUserMessage(error)}`\n        }]\n      };\n    }\n  }\n  \n  async deactivateElement(name: string, type: string) {\n    try {\n      // FIX: Issue #281 - Route all element types through elementCRUDHandler\n      // PersonaHandler.deactivatePersona is deprecated; PersonaActivationStrategy handles personas\n      const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n      return this.elementCRUDHandler!.deactivateElement(name, normalizedType);\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.deactivateElement', error, { type, name });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to deactivate ${type} '${name}': ${ErrorHandler.getUserMessage(error)}`\n        }]\n      };\n    }\n  }\n  \n  async getElementDetails(name: string, type: string) {\n    // FIX: Issue #276 - Route all element types through elementCRUDHandler for consistent error handling\n    // PersonaHandler.getPersonaDetails is deprecated; PersonaActivationStrategy handles personas\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(type);\n    return this.elementCRUDHandler!.getElementDetails(name, normalizedType);\n  }\n  \n  async reloadElements(type: string) {\n    await this.ensureInitialized();\n    return this.elementCRUDHandler!.reloadElements(type);\n  }\n\n  // Element-specific methods\n  async renderTemplate(name: string, variables: Record<string, any>) {\n    await this.ensureInitialized();\n    return this.elementCRUDHandler!.renderTemplate(name, variables);\n  }\n\n  async executeAgent(name: string, parameters: Record<string, any>) {\n    await this.ensureInitialized();\n    return this.elementCRUDHandler!.executeAgent(name, parameters);\n  }\n  \n  /**\n   * Create a new element in the portfolio.\n   * @param args.elements - For ensembles: array of element references (Issue #278)\n   */\n  async createElement(args: {name: string; type: string; description: string; content?: string; instructions?: string; metadata?: Record<string, unknown>; elements?: EnsembleElement[]}) {\n    await this.ensureInitialized();\n    // FIX: Issue #20 - Remove persona special case, route all element creation through ElementCRUDHandler\n    // This ensures consistent duplicate checking and error handling for all element types\n    // FIX: Issue #278 - Support elements parameter for ensembles\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(args.type);\n    return this.elementCRUDHandler!.createElement({...args, type: normalizedType});\n  }\n\n  async editElement(args: {name: string; type: string; input: Record<string, unknown>}) {\n    await this.ensureInitialized();\n    // FIX: Issue #276 - Route all element types through elementCRUDHandler for consistent error handling\n    // PersonaHandler.editPersona is deprecated; elementCRUDHandler handles personas via PersonaActivationStrategy\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(args.type);\n    return this.elementCRUDHandler!.editElement({...args, type: normalizedType});\n  }\n\n  async validateElement(args: {name: string; type: string; strict?: boolean}) {\n    await this.ensureInitialized();\n    // FIX: Issue #276 - Route all element types through elementCRUDHandler for consistent error handling\n    // PersonaHandler.validatePersona is deprecated; elementCRUDHandler handles personas\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(args.type);\n    return this.elementCRUDHandler!.validateElement({...args, type: normalizedType});\n  }\n\n  async deleteElement(args: {name: string; type: string; deleteData?: boolean}) {\n    await this.ensureInitialized();\n    // FIX: Issue #276 - Route all element types through elementCRUDHandler for consistent error handling\n    // PersonaHandler.deletePersona is deprecated; elementCRUDHandler handles personas via dedicated delete path\n    const normalizedType = this.elementCRUDHandler!.normalizeElementType(args.type);\n    return this.elementCRUDHandler!.deleteElement({...args, type: normalizedType});\n  }\n\n  async browseCollection(section?: string, type?: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.browseCollection(section, type);\n  }\n\n  async searchCollection(query: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.searchCollection(query);\n  }\n\n  async searchCollectionEnhanced(query: string, options: any = {}) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.searchCollectionEnhanced(query, options);\n  }\n\n  async getCollectionContent(path: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.getCollectionContent(path);\n  }\n\n  async installContent(inputPath: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.installContent(inputPath);\n  }\n\n  async submitContent(contentIdentifier: string) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.submitContent(contentIdentifier);\n  }\n\n  async getCollectionCacheHealth() {\n    await this.ensureInitialized();\n    return this.collectionHandler!.getCollectionCacheHealth();\n  }\n\n  // User identity management - delegated to IdentityHandler\n  async setUserIdentity(username: string, email?: string) {\n    await this.ensureInitialized();\n    return this.identityHandler!.setUserIdentity(username, email);\n  }\n\n  async getUserIdentity() {\n    await this.ensureInitialized();\n    return this.identityHandler!.getUserIdentity();\n  }\n\n  async clearUserIdentity() {\n    await this.ensureInitialized();\n    return this.identityHandler!.clearUserIdentity();\n  }\n\n  private getCurrentUserForAttribution(): string {\n    return this.identityHandler!.getCurrentUserForAttribution();\n  }\n\n  // GitHub authentication management\n  async setupGitHubAuth() {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.setupGitHubAuth();\n  }\n  \n  async checkGitHubAuth() {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.checkGitHubAuth();\n  }\n  \n  async getOAuthHelperStatus(verbose: boolean = false) {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.getOAuthHelperStatus(verbose);\n  }\n  \n\n  \n  async clearGitHubAuth() {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.clearGitHubAuth();\n  }\n\n  // OAuth configuration management\n  async configureOAuth(client_id?: string) {\n    await this.ensureInitialized();\n    return this.githubAuthHandler!.configureOAuth(client_id);\n  }\n\n\n\n\n\n\n\n\n\n\n  /**\n   * Configure indicator settings (delegated to DisplayConfigHandler)\n   */\n  async configureIndicator(config: Partial<IndicatorConfig>) {\n    await this.ensureInitialized();\n    return this.displayConfigHandler!.configureIndicator(config);\n  }\n\n  /**\n   * Get current indicator configuration (delegated to DisplayConfigHandler)\n   */\n  async getIndicatorConfig() {\n    await this.ensureInitialized();\n    return this.displayConfigHandler!.getIndicatorConfig();\n  }\n\n  /**\n   * Configure collection submission settings (delegated to CollectionHandler)\n   */\n  async configureCollectionSubmission(autoSubmit: boolean) {\n    await this.ensureInitialized();\n    return this.collectionHandler!.configureCollectionSubmission(autoSubmit);\n  }\n\n  /**\n   * Get collection submission configuration (delegated to CollectionHandler)\n   */\n  async getCollectionSubmissionConfig() {\n    await this.ensureInitialized();\n    return this.collectionHandler!.getCollectionSubmissionConfig();\n  }\n\n\n  /**\n   * Export a single persona\n   */\n  async exportPersona(personaName: string) {\n    await this.ensureInitialized();\n    return this.personaHandler!.exportPersona(personaName);\n  }\n\n  /**\n   * Export all personas\n   */\n  async exportAllPersonas(includeDefaults = true) {\n    await this.ensureInitialized();\n    return this.personaHandler!.exportAllPersonas(includeDefaults);\n  }\n\n  /**\n   * Import a persona\n   */\n  async importPersona(source: string, overwrite = false) {\n    await this.ensureInitialized();\n    return this.personaHandler!.importPersona(source, overwrite);\n  }\n\n\n  /**\n   * Portfolio management methods\n   */\n\n  /**\n   * Check portfolio status including repository existence and sync information\n   */\n  async portfolioStatus(username?: string) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.portfolioStatus(username);\n  }\n\n  /**\n   * Initialize a new GitHub portfolio repository\n   */\n  async initPortfolio(options: {repositoryName?: string; private?: boolean; description?: string}) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.initPortfolio(options);\n  }\n\n  /**\n   * Configure portfolio settings\n   */\n  async portfolioConfig(options: {autoSync?: boolean; defaultVisibility?: string; autoSubmit?: boolean; repositoryName?: string}) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.portfolioConfig(options);\n  }\n\n  /**\n   * Sync portfolio with GitHub\n   */\n  async syncPortfolio(options: {\n    direction: string;\n    mode?: string;\n    force: boolean;\n    dryRun: boolean;\n    confirmDeletions?: boolean;\n  }) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.syncPortfolio(options);\n  }\n\n  /**\n   * Handle configuration operations - delegates to ConfigHandler\n  */\n  async handleConfigOperation(options: any) {\n    await this.ensureInitialized();\n    return this.configHandler!.handleConfigOperation(options);\n  }\n\n  /**\n   * Handle sync operations - delegates to SyncHandler\n   */\n  async handleSyncOperation(options: any) {\n    await this.ensureInitialized();\n    return this.syncHandler!.handleSyncOperation(options);\n  }\n\n  async dispose(): Promise<void> {\n    await this.container.dispose();\n  }\n\n  /**\n   * Search local portfolio using the metadata index system\n   * This provides fast, comprehensive search across all element types\n   */\n  async searchPortfolio(options: {\n    query: string; \n    elementType?: string; \n    fuzzyMatch?: boolean; \n    maxResults?: number; \n    includeKeywords?: boolean; \n    includeTags?: boolean; \n    includeTriggers?: boolean; \n    includeDescriptions?: boolean;\n  }) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.searchPortfolio(options);\n  }\n\n  /**\n   * Search across all sources (local, GitHub, collection) using UnifiedIndexManager\n   * This provides comprehensive search with duplicate detection and version comparison\n   */\n  async searchAll(options: {\n    query: string;\n    sources?: string[];\n    elementType?: string;\n    page?: number;\n    pageSize?: number;\n    sortBy?: string;\n  }) {\n    await this.ensureInitialized();\n    return this.portfolioHandler!.searchAll(options);\n  }\n\n  /**\n   * Find semantically similar elements using Enhanced Index\n   */\n  async findSimilarElements(options: {\n    elementName: string;\n    elementType?: string;\n    limit: number;\n    threshold: number;\n  }) {\n    return this.enhancedIndexHandler!.findSimilarElements(options);\n  }\n\n  /**\n   * Get all relationships for a specific element\n   */\n  async getElementRelationships(options: {\n    elementName: string;\n    elementType?: string;\n    relationshipTypes?: string[];\n  }) {\n    return this.enhancedIndexHandler!.getElementRelationships(options);\n  }\n\n  /**\n   * Search for elements by action verb\n   */\n  async searchByVerb(options: {\n    verb: string;\n    limit: number;\n  }) {\n    return this.enhancedIndexHandler!.searchByVerb(options);\n  }\n\n  /**\n   * Get statistics about Enhanced Index relationships\n   */\n  async getRelationshipStats() {\n    return this.enhancedIndexHandler!.getRelationshipStats();\n  }\n\n  async run() {\n    logger.debug(\"DollhouseMCPServer.run() started\");\n    logger.info(\"Starting DollhouseMCP server...\");\n\n    const timer = this.container.resolve<StartupTimer>('StartupTimer');\n\n    // Issue #706: Critical path only — get to connect() as fast as possible\n    // Non-critical work (memory auto-load, activation restore, etc.) is\n    // deferred to completeDeferredSetup() which runs post-connect.\n    try {\n      timer.startPhase('portfolio_prepare', true);\n      await this.initializePortfolio();\n      timer.endPhase('portfolio_prepare');\n\n      timer.startPhase('handler_creation', true);\n      await this.completeInitialization();\n      timer.endPhase('handler_creation');\n\n      // Initialize operational telemetry (async, non-blocking, never throws)\n      const operationalTelemetry = this.container.resolve<OperationalTelemetry>('OperationalTelemetry');\n      operationalTelemetry.initialize().catch(() => {\n        // Telemetry errors are logged internally, safe to ignore here\n      });\n\n      logger.info(\"Portfolio and personas initialized successfully\");\n\n      if (!env.DOLLHOUSE_GATEKEEPER_ENABLED) {\n        logger.warn(\"⚠️  Gatekeeper is DISABLED (DOLLHOUSE_GATEKEEPER_ENABLED=false). All permission checks are bypassed.\");\n      }\n\n      logger.info(\"DollhouseMCP server ready - waiting for MCP connection on stdio\");\n      logger.debug(\"DollhouseMCPServer.run() completed initialization\");\n    } catch (error) {\n      ErrorHandler.logError('DollhouseMCPServer.run.initialization', error);\n      throw error; // Re-throw to prevent server from starting with incomplete initialization\n    }\n\n    const transport = new StdioServerTransport();\n\n    // Set up graceful shutdown handlers\n    const cleanup = async () => {\n      logger.info(\"Shutting down DollhouseMCP server...\");\n\n      try {\n        await this.container.dispose();\n        logger.info(\"Cleanup completed\");\n      } catch (error) {\n        logger.error(\"Error during cleanup\", { error });\n      }\n\n      process.exit(0);\n    };\n\n    // Register shutdown handlers\n    process.on('SIGINT', cleanup);\n    process.on('SIGTERM', cleanup);\n    process.on('SIGHUP', cleanup);\n\n    // Connect ASAP — tools are registered, server can accept requests\n    timer.startPhase('mcp_connect', true);\n    await this.server.connect(transport);\n    timer.endPhase('mcp_connect');\n    timer.markConnect();\n\n    // Mark that MCP is now connected - no more console output allowed\n    logger.setMCPConnected();\n\n    // Issue #706 Phase 3: Emit READY sentinel for bridge clients\n    process.stderr.write('DOLLHOUSEMCP_READY\\n');\n\n    logger.info(\"DollhouseMCP server running on stdio\");\n\n    // Issue #706 Phase 2: Deferred setup — runs post-connect, non-blocking\n    // Pattern encryption, background validator, memory auto-load, activation\n    // restore, log hooks, danger zone init all move here.\n    const deferredPromise = this.container.completeDeferredSetup();\n    deferredPromise.catch(err => logger.warn('[Startup] Deferred setup error:', err));\n\n    // Issue #706 Phase 4: Wire deferred promise into ServerSetup for request buffering\n    const serverSetup = this.container.resolve<import('./server/ServerSetup.js').ServerSetup>('ServerSetup');\n    serverSetup.setDeferredSetupPromise(deferredPromise);\n\n    // Log startup timing after deferred setup completes\n    deferredPromise.then(async () => {\n      const report = timer.getReport();\n      logger.info(`[Startup] Full report: connect at ${report.connectAtMs}ms, ` +\n        `critical ${report.criticalPathMs}ms, deferred ${report.deferredMs}ms, ` +\n        `total ${report.totalMs}ms`);\n    }).catch(() => { /* already logged */ });\n\n  }\n}\n\n// Export is already at class declaration\n\n// Only start the server if this file is being run directly (not imported by tests)\n// Handle different execution methods (direct, npx, CLI)\n//\n// Bug fix: npx creates symlinks in .bin/ (e.g. .bin/mcp-server → dist/index.js).\n// Node.js keeps the symlink path in process.argv[1], so without resolving it,\n// isDirectExecution missed the dist/index.js suffix and the server never started.\nconst rawScriptPath = process.argv?.[1] ?? '';\nlet scriptPath = rawScriptPath ? path.normalize(rawScriptPath) : '';\ntry {\n  scriptPath = realpathSync(scriptPath);\n} catch {\n  if (process.env.DOLLHOUSE_DEBUG) {\n    console.error(`[DEBUG] Symlink resolution failed for ${rawScriptPath} — using original path`);\n  }\n}\nconst isDirectExecution =\n  scriptPath.endsWith(`${path.sep}dist${path.sep}index.js`) ||\n  scriptPath.endsWith(`${path.sep}src${path.sep}index.ts`);\n// Modern npm (v7+) runs npx as \"npm exec\" — npm_execpath may point to\n// npm-cli.js instead of npx-cli.js. Detect both legacy and modern npx.\nconst isNpxExecution =\n  process.env.npm_execpath?.includes('npx') ||\n  process.env.npm_command === 'exec';\n// Match all registered bin entry names from package.json \"bin\" field\nconst binName = path.basename(rawScriptPath);\nconst isCliExecution = binName === 'dollhousemcp' || binName === 'mcp-server';\nconst isTest = process.env.JEST_WORKER_ID; // This is set when Jest runs tests\nconst isTestMode = process.env.TEST_MODE === 'true'; // Check for TEST_MODE environment variable\nconst dollhouseDebugFlag = process.env.DOLLHOUSE_DEBUG?.toLowerCase();\nconst isDebugStartupLogging = dollhouseDebugFlag === 'true' || dollhouseDebugFlag === '1';\n\n// Progressive startup with retries for npx/CLI execution\nconst STARTUP_DELAYS = [10, 50, 100, 200]; // Progressive delays in ms\n\nasync function startServerWithRetry(retriesLeft = STARTUP_DELAYS.length): Promise<void> {\n  if (isDebugStartupLogging) {\n    console.error(\"DEBUG: startServerWithRetry called.\");\n  }\n  try {\n    const container = new DollhouseContainer();\n    const server = new DollhouseMCPServer(container);\n    await server.run();\n  } catch (error) {\n    if (retriesLeft > 0 && (isNpxExecution || isCliExecution)) {\n      // Try again with a longer delay\n      const delayIndex = STARTUP_DELAYS.length - retriesLeft;\n      const delay = STARTUP_DELAYS[delayIndex];\n      await new Promise(resolve => setTimeout(resolve, delay));\n      return startServerWithRetry(retriesLeft - 1);\n    }\n    // Final failure - minimal error message for security\n    // Note: Using console.error here is intentional as it's the final error before exit\n    console.error(\"[DollhouseMCP] Server startup failed\",\n      process.env.DOLLHOUSE_DEBUG ? error : (error as Error).message || 'unknown error');\n    process.exit(1);\n  }\n}\n\nif ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTestMode)) {\n  // Issue #704: --web flag starts the portfolio web UI instead of MCP server\n  const isWebMode = process.argv.includes('--web');\n  if (isWebMode) {\n    // Issue #796: Bootstrap DI container for web-only mode so API routes\n    // go through MCPAQLHandler (validated, cached, gatekeeper-checked)\n    //\n    // Suppress terminal output in --web mode unless DOLLHOUSE_DEBUG is set.\n    // All logs are still captured in MemoryLogSink and visible in the Logs tab —\n    // the terminal only needs the console URL banner, not a wall of startup noise.\n    if (!process.env.DOLLHOUSE_DEBUG && !process.env.ENABLE_DEBUG) {\n      logger.setMinLevel('error');\n    }\n\n    (async () => {\n      const portfolioDir = path.join(os.homedir(), '.dollhouse', 'portfolio');\n      const portArg = process.argv.find(a => a.startsWith('--port='));\n      const port = portArg ? parseInt(portArg.split('=')[1], 10) : undefined;\n      const noBrowser = process.argv.includes('--no-open');\n\n      let mcpAqlHandler;\n      let memorySink: import('./logging/sinks/MemoryLogSink.js').MemoryLogSink | undefined;\n      let metricsSink: import('./metrics/sinks/MemoryMetricsSink.js').MemoryMetricsSink | undefined;\n      try {\n        const container = new DollhouseContainer();\n        await container.preparePortfolio();\n        const bundle = await container.bootstrapHandlers();\n        await container.completeDeferredSetup();\n        mcpAqlHandler = bundle.mcpAqlHandler;\n        // Extract sinks from container — deferred setup may have already wired them\n        try { memorySink = container.resolve<import('./logging/sinks/MemoryLogSink.js').MemoryLogSink>('MemoryLogSink'); } catch { /* not registered */ }\n        try { metricsSink = container.resolve<import('./metrics/sinks/MemoryMetricsSink.js').MemoryMetricsSink>('MemoryMetricsSink'); } catch { /* not registered */ }\n      } catch (err) {\n        console.error(\"[DollhouseMCP] Container bootstrap failed — web routes will use direct filesystem access.\");\n        console.error(\"[DollhouseMCP] Reason:\", (err as Error).message || err);\n        console.error(\"[DollhouseMCP] This may indicate a corrupt portfolio or missing dependencies.\");\n      }\n\n      // Ensure sinks exist even if container bootstrap failed —\n      // standalone --web mode still needs working logs and metrics tabs\n      if (!memorySink) {\n        const { MemoryLogSink } = await import('./logging/sinks/MemoryLogSink.js');\n        memorySink = new MemoryLogSink({\n          appCapacity: 10000,\n          securityCapacity: 5000,\n          perfCapacity: 2000,\n          telemetryCapacity: 1000,\n        });\n      }\n      if (!metricsSink) {\n        const { MemoryMetricsSink } = await import('./metrics/sinks/MemoryMetricsSink.js');\n        metricsSink = new MemoryMetricsSink(240);\n      }\n\n      const { startWebServer } = await import('./web/server.js');\n      await startWebServer({ portfolioDir, port, openBrowser: !noBrowser, mcpAqlHandler, memorySink, metricsSink });\n\n      // Listen for quit commands on stdin (standalone --web mode only).\n      // In MCP stdio mode, stdin is consumed by the JSON-RPC transport.\n      if (process.stdin.isTTY) {\n        process.stdin.setEncoding('utf-8');\n        process.stdin.resume();\n        let quitDebounce: ReturnType<typeof setTimeout> | null = null;\n        process.stdin.on('data', (data: string) => {\n          const cmd = data.trim().toLowerCase();\n          if (cmd === 'q' || cmd === 'quit' || cmd === 'exit') {\n            // Debounce rapid inputs (e.g., accidental double-tap)\n            if (quitDebounce) return;\n            quitDebounce = setTimeout(() => { quitDebounce = null; }, 200);\n            console.error('\\n  Shutting down DollhouseMCP...\\n');\n            process.exit(0);\n          }\n        });\n      }\n    })().catch(err => {\n      console.error(\"[DollhouseMCP] Web UI failed to start:\", err);\n      process.exit(1);\n    });\n  } else {\n    if (isDebugStartupLogging) {\n      console.error(\"DEBUG: Server startup condition met. Calling startServerWithRetry.\");\n    }\n    startServerWithRetry().catch(() => {\n      // Note: Using console.error here is intentional as it's the final error before exit\n      console.error(\"[DollhouseMCP] Server startup failed\");\n      process.exit(1);\n    });\n  }\n}\n"]}