@dollhousemcp/mcp-server 2.0.5 → 2.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -640,12 +640,23 @@ if ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTes
640
640
  const port = portArg ? parseInt(portArg.split('=')[1], 10) : undefined;
641
641
  const noBrowser = process.argv.includes('--no-open');
642
642
  let mcpAqlHandler;
643
+ let memorySink;
644
+ let metricsSink;
643
645
  try {
644
646
  const container = new DollhouseContainer();
645
647
  await container.preparePortfolio();
646
648
  const bundle = await container.bootstrapHandlers();
647
649
  await container.completeDeferredSetup();
648
650
  mcpAqlHandler = bundle.mcpAqlHandler;
651
+ // Extract sinks from container — deferred setup may have already wired them
652
+ try {
653
+ memorySink = container.resolve('MemoryLogSink');
654
+ }
655
+ catch { /* not registered */ }
656
+ try {
657
+ metricsSink = container.resolve('MemoryMetricsSink');
658
+ }
659
+ catch { /* not registered */ }
649
660
  console.error("[DollhouseMCP] Container bootstrapped — web routes using MCP-AQL Gateway");
650
661
  }
651
662
  catch (err) {
@@ -653,8 +664,23 @@ if ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTes
653
664
  console.error("[DollhouseMCP] Reason:", err.message || err);
654
665
  console.error("[DollhouseMCP] This may indicate a corrupt portfolio or missing dependencies.");
655
666
  }
667
+ // Ensure sinks exist even if container bootstrap failed —
668
+ // standalone --web mode still needs working logs and metrics tabs
669
+ if (!memorySink) {
670
+ const { MemoryLogSink } = await import('./logging/sinks/MemoryLogSink.js');
671
+ memorySink = new MemoryLogSink({
672
+ appCapacity: 10000,
673
+ securityCapacity: 5000,
674
+ perfCapacity: 2000,
675
+ telemetryCapacity: 1000,
676
+ });
677
+ }
678
+ if (!metricsSink) {
679
+ const { MemoryMetricsSink } = await import('./metrics/sinks/MemoryMetricsSink.js');
680
+ metricsSink = new MemoryMetricsSink(240);
681
+ }
656
682
  const { startWebServer } = await import('./web/server.js');
657
- await startWebServer({ portfolioDir, port, openBrowser: !noBrowser, mcpAqlHandler });
683
+ await startWebServer({ portfolioDir, port, openBrowser: !noBrowser, mcpAqlHandler, memorySink, metricsSink });
658
684
  })().catch(err => {
659
685
  console.error("[DollhouseMCP] Web UI failed to start:", err);
660
686
  process.exit(1);
@@ -671,4 +697,4 @@ if ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTes
671
697
  });
672
698
  }
673
699
  }
674
- //# 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 debug output in --web mode unless DOLLHOUSE_DEBUG is set.\n    // The web console captures all logs in memory — no need to flood the terminal.\n    if (!process.env.DOLLHOUSE_DEBUG && !process.env.ENABLE_DEBUG) {\n      logger.setMinLevel('info');\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      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        console.error(\"[DollhouseMCP] Container bootstrapped — web routes using MCP-AQL Gateway\");\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      const { startWebServer } = await import('./web/server.js');\n      await startWebServer({ portfolioDir, port, openBrowser: !noBrowser, mcpAqlHandler });\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"]}
700
+ //# 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 debug output in --web mode unless DOLLHOUSE_DEBUG is set.\n    // The web console captures all logs in memory — no need to flood the terminal.\n    if (!process.env.DOLLHOUSE_DEBUG && !process.env.ENABLE_DEBUG) {\n      logger.setMinLevel('info');\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        console.error(\"[DollhouseMCP] Container bootstrapped — web routes using MCP-AQL Gateway\");\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    })().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"]}
@@ -314,6 +314,10 @@ Element operations:
314
314
  { operation: "render", params: { element_name: "meeting-notes", variables: { date: "2026-03-03" } } }
315
315
  { operation: "export_element", element_type: "persona", params: { element_name: "Tech-Writer" } }
316
316
  { operation: "open_portfolio_browser" }
317
+ { operation: "open_logs" }
318
+ { operation: "open_metrics" }
319
+ { operation: "open_permissions" }
320
+ { operation: "open_setup" }
317
321
 
318
322
  Memory-specific search (filter by tags):
319
323
  { operation: "search", params: { query: "*", type: "memory", filters: { tags: ["important"] } } }
@@ -517,4 +521,4 @@ Discover required parameters — use mcp_aql_read:
517
521
  }
518
522
  ];
519
523
  }
520
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MCPAQLTools.js","sourceRoot":"","sources":["../../../src/server/tools/MCPAQLTools.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * MCP-AQL Tools - Unified query interface for AI agents\n *\n * Provides two endpoint modes configurable via MCP_AQL_ENDPOINT_MODE environment variable:\n *\n * ## Mode 1: CRUDE Endpoints (Default) - MCP_AQL_ENDPOINT_MODE=crude\n * 5 tools: mcp_aql_create, mcp_aql_read, mcp_aql_update, mcp_aql_delete, mcp_aql_execute (~4,300 tokens)\n *\n * ## Mode 2: Single Endpoint (Minimal) - MCP_AQL_ENDPOINT_MODE=single\n * 1 tool: mcp_aql (~350 tokens)\n * Ideal for multi-server deployments where token budget is constrained.\n *\n * Note: These tools are only registered when MCP_INTERFACE_MODE=mcpaql (default).\n * When MCP_INTERFACE_MODE=discrete, discrete tools are registered instead.\n *\n * ## Why 5 CRUDE Endpoints? (Default Mode)\n *\n * The 5-endpoint CRUDE pattern (Create, Read, Update, Delete, Execute) was chosen for:\n *\n * 1. **User Comprehension**: CRUDE extends CRUD with Execute for non-idempotent\n *    operations, making it easy for users to reason about what each endpoint can do.\n *\n * 2. **Platform Annotations**: MCP platforms like ChatGPT's apps require\n *    tool annotations that describe safety and destructiveness. The 5-endpoint\n *    split maps directly to distinct permission levels:\n *    - CREATE: additive, non-destructive (readOnlyHint: false, destructiveHint: false)\n *    - READ: safe, read-only (readOnlyHint: true, destructiveHint: false)\n *    - UPDATE: modifying, potentially destructive (readOnlyHint: false, destructiveHint: true)\n *    - DELETE: destructive (readOnlyHint: false, destructiveHint: true)\n *    - EXECUTE: non-idempotent, potentially destructive (readOnlyHint: false, destructiveHint: true)\n *\n * 3. **Granular Permission Control**: Users can grant READ endpoint full access\n *    while locking down CREATE, UPDATE, DELETE, and EXECUTE. This enables safe\n *    read-only integrations without exposing mutation capabilities.\n *\n * ## Why Single Endpoint? (Minimal Mode)\n *\n * The single-endpoint mode was added for:\n *\n * 1. **Token Efficiency**: ~350 tokens vs ~4,300 tokens (92% reduction)\n * 2. **Multi-Server Deployments**: When running multiple MCP servers, token\n *    budgets can be constrained. Single endpoint reduces overhead.\n * 3. **Simplified Integration**: Some clients prefer a single entry point.\n *\n * Security is maintained through server-side Gatekeeper enforcement - the\n * server determines which operation type is being executed and applies\n * appropriate permission checks.\n *\n * ## GraphQL-Style Introspection\n *\n * MCP-AQL follows GraphQL patterns for self-documentation. Tool descriptions\n * are generated dynamically from OPERATION_ROUTES, ensuring they always reflect\n * the current available operations.\n *\n * ### Introspection Examples\n *\n * List all available operations:\n * ```json\n * { \"operation\": \"introspect\", \"params\": { \"query\": \"operations\" } }\n * ```\n *\n * Get details for a specific operation (parameters, examples, return types):\n * ```json\n * { \"operation\": \"introspect\", \"params\": { \"query\": \"operations\", \"name\": \"create_element\" } }\n * ```\n *\n * Discover available types (e.g., ElementType enum values):\n * ```json\n * { \"operation\": \"introspect\", \"params\": { \"query\": \"types\", \"name\": \"ElementType\" } }\n * ```\n *\n * ### Design Philosophy\n *\n * - **Single source of truth**: OPERATION_ROUTES defines all operations\n * - **Dynamic descriptions**: Adding an operation to OPERATION_ROUTES automatically\n *   updates tool descriptions - no manual synchronization needed\n * - **Introspection-first**: LLMs discover parameters via introspect, not static docs\n * - **GraphQL heritage**: Patterns familiar to any LLM trained on GraphQL\n */\n\nimport type { MCPAQLHandler } from '../../handlers/mcp-aql/MCPAQLHandler.js';\nimport { UnifiedEndpoint } from '../../handlers/mcp-aql/UnifiedEndpoint.js';\nimport { getOperationsForEndpoint, type CRUDEndpoint } from '../../handlers/mcp-aql/OperationRouter.js';\nimport { ElementType } from '../../handlers/mcp-aql/types.js';\nimport type { ToolDefinition, ToolHandler } from '../../handlers/types/ToolTypes.js';\nimport { env } from '../../config/env.js';\n\n// ============================================================================\n// Dynamic Description Generation\n// ============================================================================\n\n/**\n * Get element types as a comma-separated string.\n * Derived from the ElementType enum to ensure consistency.\n */\nfunction getElementTypesString(): string {\n  return Object.values(ElementType).join(', ');\n}\n\n/**\n * Get operations for an endpoint as a comma-separated string.\n * Derived from OPERATION_ROUTES to ensure consistency.\n */\nfunction getOperationsString(endpoint: CRUDEndpoint): string {\n  return getOperationsForEndpoint(endpoint).join(', ');\n}\n\n// ============================================================================\n// Tool Schema\n// ============================================================================\n\n/**\n * Shared input schema for CRUD operations (create, read, update, delete)\n * All operations use the OperationInput structure from the GraphQL schema\n */\nconst operationInputSchema = {\n  type: \"object\" as const,\n  properties: {\n    operation: {\n      type: \"string\",\n      description: \"Operation name to execute\"\n    },\n    element_type: {\n      type: \"string\",\n      description: \"Target element type (optional)\"\n    },\n    params: {\n      type: \"object\",\n      description: \"Operation parameters\"\n    },\n    operations: {\n      type: \"array\",\n      description: \"Array of operations for batch execution\",\n      items: {\n        type: \"object\",\n        properties: {\n          operation: { type: \"string\" },\n          element_type: { type: \"string\" },\n          params: { type: \"object\" }\n        },\n        required: [\"operation\"]\n      }\n    }\n  },\n  required: [\"operation\" as const]\n};\n\n// ============================================================================\n// Tool Registration\n// ============================================================================\n\n/**\n * Get MCP-AQL tools for registration in the ToolRegistry.\n *\n * Returns different tools based on MCP_AQL_ENDPOINT_MODE environment variable:\n * - 'crude' (default): 5 CRUDE endpoints (Create, Read, Update, Delete, Execute) (~4,300 tokens)\n * - 'single': 1 unified endpoint (~350 tokens)\n *\n * Note: MCP_AQL_MODE is supported as a deprecated alias for backward compatibility.\n */\nexport function getMCPAQLTools(handler: MCPAQLHandler): Array<{ tool: ToolDefinition; handler: ToolHandler }> {\n  // Use MCP_AQL_ENDPOINT_MODE, falling back to deprecated MCP_AQL_MODE for backward compatibility\n  const mode = env.MCP_AQL_ENDPOINT_MODE ?? env.MCP_AQL_MODE ?? 'crude';\n\n  if (mode === 'single') {\n    return getUnifiedTools(handler);\n  }\n\n  // Default: CRUDE mode (5 endpoints)\n  return getCRUDETools(handler);\n}\n\n/**\n * Get the unified single endpoint tool (MCP_AQL_MODE=single)\n * Token footprint: ~300-400 tokens\n */\nfunction getUnifiedTools(handler: MCPAQLHandler): Array<{ tool: ToolDefinition; handler: ToolHandler }> {\n  const unifiedEndpoint = new UnifiedEndpoint(handler);\n\n  // Build dynamic description from OPERATION_ROUTES\n  const description = `DollhouseMCP unified API - GraphQL-style query interface for AI element management.\n\nCRUDE Operations:\n- CREATE: ${getOperationsString('CREATE')}\n- READ: ${getOperationsString('READ')}\n- UPDATE: ${getOperationsString('UPDATE')}\n- DELETE: ${getOperationsString('DELETE')}\n- EXECUTE: ${getOperationsString('EXECUTE')}\n\nElement types: ${getElementTypesString()}\n\nQuick start examples:\n{ operation: \"list_elements\", element_type: \"persona\" }\n{ operation: \"create_element\", element_type: \"persona\", params: { element_name: \"MyPersona\", description: \"A helpful assistant\", instructions: \"You ARE a helpful assistant. ALWAYS provide clear, accurate responses.\" } }\n{ operation: \"create_element\", element_type: \"agent\", params: { element_name: \"MyAgent\", description: \"Task executor\", instructions: \"Execute goals methodically. Report progress at each step.\", goal: { template: \"Complete: {objective}\", parameters: [{ name: \"objective\", type: \"string\", required: true }] } } }\n{ operation: \"create_element\", element_type: \"memory\", params: { element_name: \"session-notes\", description: \"Session context and notes\" } }\n{ operation: \"addEntry\", params: { element_name: \"session-notes\", content: \"Remember this fact\", tags: [\"important\"] } }\n{ operation: \"execute_agent\", params: { element_name: \"MyAgent\", parameters: { objective: \"Review code\" } } }\n\nGatekeeper: Some operations may return a confirmation prompt instead of executing immediately. Use confirm_operation to approve, then retry.\n\nDiscover all operations:\n{ operation: \"introspect\", params: { query: \"operations\" } }`;\n\n  return [\n    {\n      tool: {\n        name: \"mcp_aql\",\n        description,\n        inputSchema: operationInputSchema,\n        annotations: {\n          // Unified endpoint can perform any operation, so we use conservative hints\n          // The actual operation's safety is enforced server-side by Gatekeeper\n          readOnlyHint: false,\n          destructiveHint: true // Conservative: some operations are destructive\n        }\n      },\n      handler: async (args: any) => {\n        const result = await unifiedEndpoint.handle(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    }\n  ];\n}\n\n/**\n * Get the 5 CRUDE endpoint tools (MCP_AQL_ENDPOINT_MODE=crude, default)\n * CRUDE = Create, Read, Update, Delete, Execute\n * Token footprint: ~4,300 tokens (measured via Claude Code /context)\n *\n * Descriptions are generated dynamically from OPERATION_ROUTES to ensure\n * they always reflect the current available operations.\n */\nfunction getCRUDETools(handler: MCPAQLHandler): Array<{ tool: ToolDefinition; handler: ToolHandler }> {\n  const elementTypes = getElementTypesString();\n\n  return [\n    // mcp_aql_create - Additive, non-destructive operations\n    {\n      tool: {\n        name: \"mcp_aql_create\",\n        description: `Additive, non-destructive operations.\n\nSupported operations: ${getOperationsString('CREATE')}\n\nElement types: ${elementTypes}\n\nThese operations add new data without removing or overwriting existing content.\n\nQuick start examples:\n{ operation: \"create_element\", element_type: \"persona\", params: { element_name: \"MyPersona\", description: \"A helpful assistant\", instructions: \"You ARE a helpful assistant. ALWAYS provide clear, accurate responses.\" } }\n{ operation: \"create_element\", element_type: \"agent\", params: { element_name: \"MyAgent\", description: \"Task executor\", instructions: \"Execute goals methodically. Report progress at each step.\", goal: { template: \"Complete: {objective}\", parameters: [{ name: \"objective\", type: \"string\", required: true }] } } }\n{ operation: \"create_element\", element_type: \"memory\", params: { element_name: \"session-notes\", description: \"Session context and notes\" } }\n{ operation: \"addEntry\", params: { element_name: \"session-notes\", content: \"Remember this fact\", tags: [\"important\"] } }\n\nExecution lifecycle — record agent progress (appends step records, like addEntry):\n{ operation: \"record_execution_step\", params: { element_name: \"code-reviewer\", stepDescription: \"Analyzed files\", outcome: \"success\", findings: \"Found 3 issues\" } }\nResponse flow: record_execution_step returns { autonomy: { continue, factors, notifications? } }. Check autonomy.continue to decide whether to proceed. Check autonomy.notifications for permission_pending (gatekeeper blocks), autonomy_pause, or danger_zone alerts to relay to human operators.\n\nImport & portfolio:\n{ operation: \"import_element\", element_type: \"skill\", params: { element_name: \"code-formatter\", data: \"...\" } }\n{ operation: \"import_persona\", params: { source: \"/path/to/persona.md\" } }\n{ operation: \"install_collection_content\", params: { element_type: \"persona\", element_name: \"Creative-Writer\" } }\n{ operation: \"submit_collection_content\", params: { element_type: \"skill\", element_name: \"code-formatter\" } }\n{ operation: \"init_portfolio\" }\n{ operation: \"sync_portfolio\" }\n{ operation: \"portfolio_element_manager\", params: { action: \"push\", element_type: \"persona\", element_name: \"Tech-Writer\" } }\n\nAuth & verification:\n{ operation: \"setup_github_auth\" }\n{ operation: \"configure_oauth\", params: { client_id: \"your-client-id\" } }\n{ operation: \"verify_challenge\", params: { code: \"ABC123\" } }\n{ operation: \"beetlejuice_beetlejuice_beetlejuice\" }\n\nBatch operations: Use the operations array to execute multiple operations sequentially in a single request.\n{ operations: [{ operation: \"addEntry\", params: { element_name: \"log\", content: \"Step 1\" } }, { operation: \"addEntry\", params: { element_name: \"log\", content: \"Step 2\" } }] }\n\nDiscover required parameters — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"operations\", name: \"create_element\" } }\nDiscover element format specs (required fields, syntax, examples) — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"format\", name: \"template\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: false,\n          destructiveHint: false\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleCreate(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    },\n\n    // mcp_aql_read - Safe, read-only operations\n    {\n      tool: {\n        name: \"mcp_aql_read\",\n        description: `Safe, read-only operations.\n\nSupported operations: ${getOperationsString('READ')}\n\nElement types: ${elementTypes}\n\nThese queries only read data and never modify server state.\n\nQuick start examples:\n{ operation: \"list_elements\", element_type: \"persona\" }\n{ operation: \"get_active_elements\", element_type: \"persona\" }\n{ operation: \"search_elements\", params: { query: \"creative\" } }\n{ operation: \"get_element\", element_type: \"memory\", params: { element_name: \"session-notes\" } }\n\nElement operations:\n{ operation: \"activate_element\", element_type: \"persona\", params: { element_name: \"Default\" } }\n{ operation: \"deactivate_element\", element_type: \"persona\", params: { element_name: \"Default\" } }\n{ operation: \"get_element_details\", element_type: \"skill\", params: { element_name: \"code-review\" } }\n{ operation: \"query_elements\", element_type: \"persona\", params: { filters: { category: \"creative\" } } }\n{ operation: \"validate_element\", element_type: \"agent\", params: { element_name: \"task-planner\" } }\n{ operation: \"render\", params: { element_name: \"meeting-notes\", variables: { date: \"2026-03-03\" } } }\n{ operation: \"export_element\", element_type: \"persona\", params: { element_name: \"Tech-Writer\" } }\n{ operation: \"open_portfolio_browser\" }\n\nMemory-specific search (filter by tags):\n{ operation: \"search\", params: { query: \"*\", type: \"memory\", filters: { tags: [\"important\"] } } }\n\nExecution lifecycle — read-only queries:\n{ operation: \"get_execution_state\", params: { element_name: \"code-reviewer\" } }\n{ operation: \"get_gathered_data\", params: { element_name: \"code-reviewer\", goalId: \"goal-id\" } }\n\nCollection:\n{ operation: \"browse_collection\", params: { section: \"personas\" } }\n{ operation: \"search_collection\", params: { query: \"creative\" } }\n{ operation: \"search_collection_enhanced\", params: { query: \"creative\", page: 1 } }\n{ operation: \"get_collection_content\", params: { element_type: \"persona\", element_name: \"Creative-Writer\" } }\n{ operation: \"get_collection_cache_health\" }\n\nPortfolio:\n{ operation: \"portfolio_status\" }\n{ operation: \"portfolio_config\" }\n{ operation: \"search_portfolio\", params: { query: \"creative\" } }\n{ operation: \"search_all\", params: { query: \"creative\" } }\n\nSystem:\n{ operation: \"dollhouse_config\" }\n{ operation: \"get_build_info\" }\n{ operation: \"get_cache_budget_report\" }\n{ operation: \"query_logs\", params: { level: \"error\", limit: 10 } }\n{ operation: \"query_metrics\" }\n{ operation: \"query_metrics\", params: { names: [\"system.memory.*\"], type: \"gauge\" } }\n{ operation: \"convert_skill_format\", params: { direction: \"agent_to_dollhouse\", agent_skill: { \"SKILL.md\": \"---\\\\nname: my-skill\\\\ndescription: test\\\\n---\\\\n\\\\nUse this skill.\" } } }\n{ operation: \"convert_skill_format\", params: { direction: \"agent_to_dollhouse\", security_mode: \"warn\", path_mode: \"lossless\", agent_skill: { \"SKILL.md\": \"---\\\\nname: my-skill\\\\ndescription: test\\\\n---\\\\n\\\\nUse this skill.\" } } }\n{ operation: \"convert_skill_format\", params: { direction: \"dollhouse_to_agent\", path_mode: \"lossless\", dollhouse_markdown: \"---\\\\nname: my-skill\\\\ndescription: test\\\\ninstructions: Use this skill.\\\\n---\\\\n\\\\n### binaries/logo.png\\\\n(binary link: ./skills/binaries/logo.png)\" } }\n\nAuth:\n{ operation: \"check_github_auth\" }\n{ operation: \"oauth_helper_status\" }\n\nGatekeeper & CLI policies:\n{ operation: \"permission_prompt\", params: { tool: \"Bash\", prompt: \"run npm test\" } }\n{ operation: \"evaluate_permission\", params: { tool_name: \"Bash\", input: { command: \"git status\" }, platform: \"claude_code\" } }\n{ operation: \"get_effective_cli_policies\" }\n{ operation: \"get_pending_cli_approvals\" }\n\nEnhanced index:\n{ operation: \"find_similar_elements\", params: { element_type: \"persona\", element_name: \"Creative-Writer\" } }\n{ operation: \"get_element_relationships\", params: { element_type: \"skill\", element_name: \"code-review\" } }\n{ operation: \"search_by_verb\", params: { verb: \"review\" } }\n{ operation: \"get_relationship_stats\" }\n\nDiscover all operations and parameters:\n{ operation: \"introspect\", params: { query: \"operations\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: true,\n          destructiveHint: false\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleRead(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    },\n\n    // mcp_aql_update - Modifying operations that overwrite data\n    {\n      tool: {\n        name: \"mcp_aql_update\",\n        description: `Modifying operations that overwrite data.\n\nSupported operations: ${getOperationsString('UPDATE')}\n\nElement types: ${elementTypes}\n\nThese operations modify existing data, potentially overwriting previous values.\n\nNote: Memories are append-only and do not support edit_element. Use addEntry (CREATE) to add new entries.\n\nQuick start example:\n{ operation: \"edit_element\", element_type: \"persona\", params: { element_name: \"MyPersona\", input: { description: \"Updated description\" } } }\n{ operation: \"edit_element\", element_type: \"persona\", params: { element_name: \"Friendly-Teacher\", input: { instructions: \"Updated behavioral directives.\" } } }\n{ operation: \"edit_element\", element_type: \"agent\", params: { element_name: \"code-reviewer\", input: { instructions: \"Updated agent behavioral profile.\", goal: { template: \"Complete: {task}\" } } } }\n{ operation: \"upgrade_element\", element_type: \"agent\", params: { element_name: \"task-planner\" } }\n\nDiscover required parameters — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"operations\", name: \"edit_element\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: false,\n          destructiveHint: true\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleUpdate(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    },\n\n    // mcp_aql_delete - Destructive operations that remove data\n    {\n      tool: {\n        name: \"mcp_aql_delete\",\n        description: `Destructive operations that remove data.\n\nSupported operations: ${getOperationsString('DELETE')}\n\nElement types: ${elementTypes}\n\nThese operations remove data. Use with caution.\n\n⚠️ SECURITY: Do not auto-allow this endpoint in your host settings (e.g., Claude Code settings.json). Each delete operation should require explicit human approval. Auto-allowing bypasses the per-operation confirmation gate, leaving only element deny policies as protection against unintended data loss.\n\nQuick start examples:\n{ operation: \"delete_element\", element_type: \"persona\", params: { element_name: \"Old-Persona\" } }\n{ operation: \"clear\", params: { element_name: \"temp-notes\" } }\n{ operation: \"clear_github_auth\" }\n\nDiscover required parameters — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"operations\", name: \"delete_element\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: false,\n          destructiveHint: true\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleDelete(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    },\n\n    // mcp_aql_execute - Execution lifecycle operations (CRUDE's 'E')\n    {\n      tool: {\n        name: \"mcp_aql_execute\",\n        description: `Execution lifecycle operations for executable elements (agents, workflows, pipelines).\n\nSupported operations: ${getOperationsString('EXECUTE')}\n\nThese operations manage runtime execution state. Unlike CRUD operations (which manage definitions), Execute operations handle the execution lifecycle:\n- execute_agent: Start a new execution (returns goalId and stateVersion for tracking)\n- complete_execution: Signal successful completion\n- continue_execution: Resume from saved state\n- abort_execution: Abort a running execution, rejecting further operations\n- confirm_operation: Confirm a pending operation that requires user approval (Gatekeeper flow)\n- approve_cli_permission: Approve a pending CLI tool permission request\n- prepare_handoff: Serialize goal progress into a portable handoff block for session transfer\n- resume_from_handoff: Resume agent execution from a handoff block with integrity validation\n\nIMPORTANT: Execute operations are potentially destructive (agents can perform any action) and non-idempotent (calling execute_agent twice creates two separate executions).\n\n⚠️ SECURITY: Do not auto-allow this endpoint in your host settings (e.g., Claude Code settings.json). Each execution should require explicit human approval. Auto-allowing bypasses the per-operation confirmation gate. While DangerZone verification and element deny policies still provide protection, the primary human review checkpoint is lost.\n\nResponse flow: execute_agent returns { goalId, stateVersion, activeElements, safetyTier, ... }. Use goalId with record_execution_step and complete_execution. stateVersion enables optimistic locking. record_execution_step returns { autonomy: { continue, notifications? } } — check notifications for gatekeeper blocks and danger zone alerts.\n\nQuick start examples:\n{ operation: \"execute_agent\", params: { element_name: \"code-reviewer\", parameters: { objective: \"Review code\" } } }\n{ operation: \"complete_execution\", params: { element_name: \"code-reviewer\", outcome: \"success\", summary: \"Completed review\" } }\n{ operation: \"abort_execution\", params: { element_name: \"data-collector\", reason: \"User requested cancellation\" } }\n{ operation: \"continue_execution\", params: { element_name: \"code-reviewer\" } }\n{ operation: \"confirm_operation\", params: { operation: \"execute_agent\" } }\n{ operation: \"approve_cli_permission\", params: { request_id: \"req-123\", decision: \"allow\" } }\n{ operation: \"prepare_handoff\", params: { element_name: \"code-reviewer\" } }\n{ operation: \"resume_from_handoff\", params: { element_name: \"code-reviewer\", handoff_block: \"...\" } }\n\nDiscover required parameters — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"operations\", name: \"execute_agent\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: false,\n          destructiveHint: true  // Potentially destructive - agents can perform any action\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleExecute(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    }\n  ];\n}\n"]}
524
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MCPAQLTools.js","sourceRoot":"","sources":["../../../src/server/tools/MCPAQLTools.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * MCP-AQL Tools - Unified query interface for AI agents\n *\n * Provides two endpoint modes configurable via MCP_AQL_ENDPOINT_MODE environment variable:\n *\n * ## Mode 1: CRUDE Endpoints (Default) - MCP_AQL_ENDPOINT_MODE=crude\n * 5 tools: mcp_aql_create, mcp_aql_read, mcp_aql_update, mcp_aql_delete, mcp_aql_execute (~4,300 tokens)\n *\n * ## Mode 2: Single Endpoint (Minimal) - MCP_AQL_ENDPOINT_MODE=single\n * 1 tool: mcp_aql (~350 tokens)\n * Ideal for multi-server deployments where token budget is constrained.\n *\n * Note: These tools are only registered when MCP_INTERFACE_MODE=mcpaql (default).\n * When MCP_INTERFACE_MODE=discrete, discrete tools are registered instead.\n *\n * ## Why 5 CRUDE Endpoints? (Default Mode)\n *\n * The 5-endpoint CRUDE pattern (Create, Read, Update, Delete, Execute) was chosen for:\n *\n * 1. **User Comprehension**: CRUDE extends CRUD with Execute for non-idempotent\n *    operations, making it easy for users to reason about what each endpoint can do.\n *\n * 2. **Platform Annotations**: MCP platforms like ChatGPT's apps require\n *    tool annotations that describe safety and destructiveness. The 5-endpoint\n *    split maps directly to distinct permission levels:\n *    - CREATE: additive, non-destructive (readOnlyHint: false, destructiveHint: false)\n *    - READ: safe, read-only (readOnlyHint: true, destructiveHint: false)\n *    - UPDATE: modifying, potentially destructive (readOnlyHint: false, destructiveHint: true)\n *    - DELETE: destructive (readOnlyHint: false, destructiveHint: true)\n *    - EXECUTE: non-idempotent, potentially destructive (readOnlyHint: false, destructiveHint: true)\n *\n * 3. **Granular Permission Control**: Users can grant READ endpoint full access\n *    while locking down CREATE, UPDATE, DELETE, and EXECUTE. This enables safe\n *    read-only integrations without exposing mutation capabilities.\n *\n * ## Why Single Endpoint? (Minimal Mode)\n *\n * The single-endpoint mode was added for:\n *\n * 1. **Token Efficiency**: ~350 tokens vs ~4,300 tokens (92% reduction)\n * 2. **Multi-Server Deployments**: When running multiple MCP servers, token\n *    budgets can be constrained. Single endpoint reduces overhead.\n * 3. **Simplified Integration**: Some clients prefer a single entry point.\n *\n * Security is maintained through server-side Gatekeeper enforcement - the\n * server determines which operation type is being executed and applies\n * appropriate permission checks.\n *\n * ## GraphQL-Style Introspection\n *\n * MCP-AQL follows GraphQL patterns for self-documentation. Tool descriptions\n * are generated dynamically from OPERATION_ROUTES, ensuring they always reflect\n * the current available operations.\n *\n * ### Introspection Examples\n *\n * List all available operations:\n * ```json\n * { \"operation\": \"introspect\", \"params\": { \"query\": \"operations\" } }\n * ```\n *\n * Get details for a specific operation (parameters, examples, return types):\n * ```json\n * { \"operation\": \"introspect\", \"params\": { \"query\": \"operations\", \"name\": \"create_element\" } }\n * ```\n *\n * Discover available types (e.g., ElementType enum values):\n * ```json\n * { \"operation\": \"introspect\", \"params\": { \"query\": \"types\", \"name\": \"ElementType\" } }\n * ```\n *\n * ### Design Philosophy\n *\n * - **Single source of truth**: OPERATION_ROUTES defines all operations\n * - **Dynamic descriptions**: Adding an operation to OPERATION_ROUTES automatically\n *   updates tool descriptions - no manual synchronization needed\n * - **Introspection-first**: LLMs discover parameters via introspect, not static docs\n * - **GraphQL heritage**: Patterns familiar to any LLM trained on GraphQL\n */\n\nimport type { MCPAQLHandler } from '../../handlers/mcp-aql/MCPAQLHandler.js';\nimport { UnifiedEndpoint } from '../../handlers/mcp-aql/UnifiedEndpoint.js';\nimport { getOperationsForEndpoint, type CRUDEndpoint } from '../../handlers/mcp-aql/OperationRouter.js';\nimport { ElementType } from '../../handlers/mcp-aql/types.js';\nimport type { ToolDefinition, ToolHandler } from '../../handlers/types/ToolTypes.js';\nimport { env } from '../../config/env.js';\n\n// ============================================================================\n// Dynamic Description Generation\n// ============================================================================\n\n/**\n * Get element types as a comma-separated string.\n * Derived from the ElementType enum to ensure consistency.\n */\nfunction getElementTypesString(): string {\n  return Object.values(ElementType).join(', ');\n}\n\n/**\n * Get operations for an endpoint as a comma-separated string.\n * Derived from OPERATION_ROUTES to ensure consistency.\n */\nfunction getOperationsString(endpoint: CRUDEndpoint): string {\n  return getOperationsForEndpoint(endpoint).join(', ');\n}\n\n// ============================================================================\n// Tool Schema\n// ============================================================================\n\n/**\n * Shared input schema for CRUD operations (create, read, update, delete)\n * All operations use the OperationInput structure from the GraphQL schema\n */\nconst operationInputSchema = {\n  type: \"object\" as const,\n  properties: {\n    operation: {\n      type: \"string\",\n      description: \"Operation name to execute\"\n    },\n    element_type: {\n      type: \"string\",\n      description: \"Target element type (optional)\"\n    },\n    params: {\n      type: \"object\",\n      description: \"Operation parameters\"\n    },\n    operations: {\n      type: \"array\",\n      description: \"Array of operations for batch execution\",\n      items: {\n        type: \"object\",\n        properties: {\n          operation: { type: \"string\" },\n          element_type: { type: \"string\" },\n          params: { type: \"object\" }\n        },\n        required: [\"operation\"]\n      }\n    }\n  },\n  required: [\"operation\" as const]\n};\n\n// ============================================================================\n// Tool Registration\n// ============================================================================\n\n/**\n * Get MCP-AQL tools for registration in the ToolRegistry.\n *\n * Returns different tools based on MCP_AQL_ENDPOINT_MODE environment variable:\n * - 'crude' (default): 5 CRUDE endpoints (Create, Read, Update, Delete, Execute) (~4,300 tokens)\n * - 'single': 1 unified endpoint (~350 tokens)\n *\n * Note: MCP_AQL_MODE is supported as a deprecated alias for backward compatibility.\n */\nexport function getMCPAQLTools(handler: MCPAQLHandler): Array<{ tool: ToolDefinition; handler: ToolHandler }> {\n  // Use MCP_AQL_ENDPOINT_MODE, falling back to deprecated MCP_AQL_MODE for backward compatibility\n  const mode = env.MCP_AQL_ENDPOINT_MODE ?? env.MCP_AQL_MODE ?? 'crude';\n\n  if (mode === 'single') {\n    return getUnifiedTools(handler);\n  }\n\n  // Default: CRUDE mode (5 endpoints)\n  return getCRUDETools(handler);\n}\n\n/**\n * Get the unified single endpoint tool (MCP_AQL_MODE=single)\n * Token footprint: ~300-400 tokens\n */\nfunction getUnifiedTools(handler: MCPAQLHandler): Array<{ tool: ToolDefinition; handler: ToolHandler }> {\n  const unifiedEndpoint = new UnifiedEndpoint(handler);\n\n  // Build dynamic description from OPERATION_ROUTES\n  const description = `DollhouseMCP unified API - GraphQL-style query interface for AI element management.\n\nCRUDE Operations:\n- CREATE: ${getOperationsString('CREATE')}\n- READ: ${getOperationsString('READ')}\n- UPDATE: ${getOperationsString('UPDATE')}\n- DELETE: ${getOperationsString('DELETE')}\n- EXECUTE: ${getOperationsString('EXECUTE')}\n\nElement types: ${getElementTypesString()}\n\nQuick start examples:\n{ operation: \"list_elements\", element_type: \"persona\" }\n{ operation: \"create_element\", element_type: \"persona\", params: { element_name: \"MyPersona\", description: \"A helpful assistant\", instructions: \"You ARE a helpful assistant. ALWAYS provide clear, accurate responses.\" } }\n{ operation: \"create_element\", element_type: \"agent\", params: { element_name: \"MyAgent\", description: \"Task executor\", instructions: \"Execute goals methodically. Report progress at each step.\", goal: { template: \"Complete: {objective}\", parameters: [{ name: \"objective\", type: \"string\", required: true }] } } }\n{ operation: \"create_element\", element_type: \"memory\", params: { element_name: \"session-notes\", description: \"Session context and notes\" } }\n{ operation: \"addEntry\", params: { element_name: \"session-notes\", content: \"Remember this fact\", tags: [\"important\"] } }\n{ operation: \"execute_agent\", params: { element_name: \"MyAgent\", parameters: { objective: \"Review code\" } } }\n\nGatekeeper: Some operations may return a confirmation prompt instead of executing immediately. Use confirm_operation to approve, then retry.\n\nDiscover all operations:\n{ operation: \"introspect\", params: { query: \"operations\" } }`;\n\n  return [\n    {\n      tool: {\n        name: \"mcp_aql\",\n        description,\n        inputSchema: operationInputSchema,\n        annotations: {\n          // Unified endpoint can perform any operation, so we use conservative hints\n          // The actual operation's safety is enforced server-side by Gatekeeper\n          readOnlyHint: false,\n          destructiveHint: true // Conservative: some operations are destructive\n        }\n      },\n      handler: async (args: any) => {\n        const result = await unifiedEndpoint.handle(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    }\n  ];\n}\n\n/**\n * Get the 5 CRUDE endpoint tools (MCP_AQL_ENDPOINT_MODE=crude, default)\n * CRUDE = Create, Read, Update, Delete, Execute\n * Token footprint: ~4,300 tokens (measured via Claude Code /context)\n *\n * Descriptions are generated dynamically from OPERATION_ROUTES to ensure\n * they always reflect the current available operations.\n */\nfunction getCRUDETools(handler: MCPAQLHandler): Array<{ tool: ToolDefinition; handler: ToolHandler }> {\n  const elementTypes = getElementTypesString();\n\n  return [\n    // mcp_aql_create - Additive, non-destructive operations\n    {\n      tool: {\n        name: \"mcp_aql_create\",\n        description: `Additive, non-destructive operations.\n\nSupported operations: ${getOperationsString('CREATE')}\n\nElement types: ${elementTypes}\n\nThese operations add new data without removing or overwriting existing content.\n\nQuick start examples:\n{ operation: \"create_element\", element_type: \"persona\", params: { element_name: \"MyPersona\", description: \"A helpful assistant\", instructions: \"You ARE a helpful assistant. ALWAYS provide clear, accurate responses.\" } }\n{ operation: \"create_element\", element_type: \"agent\", params: { element_name: \"MyAgent\", description: \"Task executor\", instructions: \"Execute goals methodically. Report progress at each step.\", goal: { template: \"Complete: {objective}\", parameters: [{ name: \"objective\", type: \"string\", required: true }] } } }\n{ operation: \"create_element\", element_type: \"memory\", params: { element_name: \"session-notes\", description: \"Session context and notes\" } }\n{ operation: \"addEntry\", params: { element_name: \"session-notes\", content: \"Remember this fact\", tags: [\"important\"] } }\n\nExecution lifecycle — record agent progress (appends step records, like addEntry):\n{ operation: \"record_execution_step\", params: { element_name: \"code-reviewer\", stepDescription: \"Analyzed files\", outcome: \"success\", findings: \"Found 3 issues\" } }\nResponse flow: record_execution_step returns { autonomy: { continue, factors, notifications? } }. Check autonomy.continue to decide whether to proceed. Check autonomy.notifications for permission_pending (gatekeeper blocks), autonomy_pause, or danger_zone alerts to relay to human operators.\n\nImport & portfolio:\n{ operation: \"import_element\", element_type: \"skill\", params: { element_name: \"code-formatter\", data: \"...\" } }\n{ operation: \"import_persona\", params: { source: \"/path/to/persona.md\" } }\n{ operation: \"install_collection_content\", params: { element_type: \"persona\", element_name: \"Creative-Writer\" } }\n{ operation: \"submit_collection_content\", params: { element_type: \"skill\", element_name: \"code-formatter\" } }\n{ operation: \"init_portfolio\" }\n{ operation: \"sync_portfolio\" }\n{ operation: \"portfolio_element_manager\", params: { action: \"push\", element_type: \"persona\", element_name: \"Tech-Writer\" } }\n\nAuth & verification:\n{ operation: \"setup_github_auth\" }\n{ operation: \"configure_oauth\", params: { client_id: \"your-client-id\" } }\n{ operation: \"verify_challenge\", params: { code: \"ABC123\" } }\n{ operation: \"beetlejuice_beetlejuice_beetlejuice\" }\n\nBatch operations: Use the operations array to execute multiple operations sequentially in a single request.\n{ operations: [{ operation: \"addEntry\", params: { element_name: \"log\", content: \"Step 1\" } }, { operation: \"addEntry\", params: { element_name: \"log\", content: \"Step 2\" } }] }\n\nDiscover required parameters — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"operations\", name: \"create_element\" } }\nDiscover element format specs (required fields, syntax, examples) — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"format\", name: \"template\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: false,\n          destructiveHint: false\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleCreate(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    },\n\n    // mcp_aql_read - Safe, read-only operations\n    {\n      tool: {\n        name: \"mcp_aql_read\",\n        description: `Safe, read-only operations.\n\nSupported operations: ${getOperationsString('READ')}\n\nElement types: ${elementTypes}\n\nThese queries only read data and never modify server state.\n\nQuick start examples:\n{ operation: \"list_elements\", element_type: \"persona\" }\n{ operation: \"get_active_elements\", element_type: \"persona\" }\n{ operation: \"search_elements\", params: { query: \"creative\" } }\n{ operation: \"get_element\", element_type: \"memory\", params: { element_name: \"session-notes\" } }\n\nElement operations:\n{ operation: \"activate_element\", element_type: \"persona\", params: { element_name: \"Default\" } }\n{ operation: \"deactivate_element\", element_type: \"persona\", params: { element_name: \"Default\" } }\n{ operation: \"get_element_details\", element_type: \"skill\", params: { element_name: \"code-review\" } }\n{ operation: \"query_elements\", element_type: \"persona\", params: { filters: { category: \"creative\" } } }\n{ operation: \"validate_element\", element_type: \"agent\", params: { element_name: \"task-planner\" } }\n{ operation: \"render\", params: { element_name: \"meeting-notes\", variables: { date: \"2026-03-03\" } } }\n{ operation: \"export_element\", element_type: \"persona\", params: { element_name: \"Tech-Writer\" } }\n{ operation: \"open_portfolio_browser\" }\n{ operation: \"open_logs\" }\n{ operation: \"open_metrics\" }\n{ operation: \"open_permissions\" }\n{ operation: \"open_setup\" }\n\nMemory-specific search (filter by tags):\n{ operation: \"search\", params: { query: \"*\", type: \"memory\", filters: { tags: [\"important\"] } } }\n\nExecution lifecycle — read-only queries:\n{ operation: \"get_execution_state\", params: { element_name: \"code-reviewer\" } }\n{ operation: \"get_gathered_data\", params: { element_name: \"code-reviewer\", goalId: \"goal-id\" } }\n\nCollection:\n{ operation: \"browse_collection\", params: { section: \"personas\" } }\n{ operation: \"search_collection\", params: { query: \"creative\" } }\n{ operation: \"search_collection_enhanced\", params: { query: \"creative\", page: 1 } }\n{ operation: \"get_collection_content\", params: { element_type: \"persona\", element_name: \"Creative-Writer\" } }\n{ operation: \"get_collection_cache_health\" }\n\nPortfolio:\n{ operation: \"portfolio_status\" }\n{ operation: \"portfolio_config\" }\n{ operation: \"search_portfolio\", params: { query: \"creative\" } }\n{ operation: \"search_all\", params: { query: \"creative\" } }\n\nSystem:\n{ operation: \"dollhouse_config\" }\n{ operation: \"get_build_info\" }\n{ operation: \"get_cache_budget_report\" }\n{ operation: \"query_logs\", params: { level: \"error\", limit: 10 } }\n{ operation: \"query_metrics\" }\n{ operation: \"query_metrics\", params: { names: [\"system.memory.*\"], type: \"gauge\" } }\n{ operation: \"convert_skill_format\", params: { direction: \"agent_to_dollhouse\", agent_skill: { \"SKILL.md\": \"---\\\\nname: my-skill\\\\ndescription: test\\\\n---\\\\n\\\\nUse this skill.\" } } }\n{ operation: \"convert_skill_format\", params: { direction: \"agent_to_dollhouse\", security_mode: \"warn\", path_mode: \"lossless\", agent_skill: { \"SKILL.md\": \"---\\\\nname: my-skill\\\\ndescription: test\\\\n---\\\\n\\\\nUse this skill.\" } } }\n{ operation: \"convert_skill_format\", params: { direction: \"dollhouse_to_agent\", path_mode: \"lossless\", dollhouse_markdown: \"---\\\\nname: my-skill\\\\ndescription: test\\\\ninstructions: Use this skill.\\\\n---\\\\n\\\\n### binaries/logo.png\\\\n(binary link: ./skills/binaries/logo.png)\" } }\n\nAuth:\n{ operation: \"check_github_auth\" }\n{ operation: \"oauth_helper_status\" }\n\nGatekeeper & CLI policies:\n{ operation: \"permission_prompt\", params: { tool: \"Bash\", prompt: \"run npm test\" } }\n{ operation: \"evaluate_permission\", params: { tool_name: \"Bash\", input: { command: \"git status\" }, platform: \"claude_code\" } }\n{ operation: \"get_effective_cli_policies\" }\n{ operation: \"get_pending_cli_approvals\" }\n\nEnhanced index:\n{ operation: \"find_similar_elements\", params: { element_type: \"persona\", element_name: \"Creative-Writer\" } }\n{ operation: \"get_element_relationships\", params: { element_type: \"skill\", element_name: \"code-review\" } }\n{ operation: \"search_by_verb\", params: { verb: \"review\" } }\n{ operation: \"get_relationship_stats\" }\n\nDiscover all operations and parameters:\n{ operation: \"introspect\", params: { query: \"operations\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: true,\n          destructiveHint: false\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleRead(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    },\n\n    // mcp_aql_update - Modifying operations that overwrite data\n    {\n      tool: {\n        name: \"mcp_aql_update\",\n        description: `Modifying operations that overwrite data.\n\nSupported operations: ${getOperationsString('UPDATE')}\n\nElement types: ${elementTypes}\n\nThese operations modify existing data, potentially overwriting previous values.\n\nNote: Memories are append-only and do not support edit_element. Use addEntry (CREATE) to add new entries.\n\nQuick start example:\n{ operation: \"edit_element\", element_type: \"persona\", params: { element_name: \"MyPersona\", input: { description: \"Updated description\" } } }\n{ operation: \"edit_element\", element_type: \"persona\", params: { element_name: \"Friendly-Teacher\", input: { instructions: \"Updated behavioral directives.\" } } }\n{ operation: \"edit_element\", element_type: \"agent\", params: { element_name: \"code-reviewer\", input: { instructions: \"Updated agent behavioral profile.\", goal: { template: \"Complete: {task}\" } } } }\n{ operation: \"upgrade_element\", element_type: \"agent\", params: { element_name: \"task-planner\" } }\n\nDiscover required parameters — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"operations\", name: \"edit_element\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: false,\n          destructiveHint: true\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleUpdate(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    },\n\n    // mcp_aql_delete - Destructive operations that remove data\n    {\n      tool: {\n        name: \"mcp_aql_delete\",\n        description: `Destructive operations that remove data.\n\nSupported operations: ${getOperationsString('DELETE')}\n\nElement types: ${elementTypes}\n\nThese operations remove data. Use with caution.\n\n⚠️ SECURITY: Do not auto-allow this endpoint in your host settings (e.g., Claude Code settings.json). Each delete operation should require explicit human approval. Auto-allowing bypasses the per-operation confirmation gate, leaving only element deny policies as protection against unintended data loss.\n\nQuick start examples:\n{ operation: \"delete_element\", element_type: \"persona\", params: { element_name: \"Old-Persona\" } }\n{ operation: \"clear\", params: { element_name: \"temp-notes\" } }\n{ operation: \"clear_github_auth\" }\n\nDiscover required parameters — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"operations\", name: \"delete_element\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: false,\n          destructiveHint: true\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleDelete(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    },\n\n    // mcp_aql_execute - Execution lifecycle operations (CRUDE's 'E')\n    {\n      tool: {\n        name: \"mcp_aql_execute\",\n        description: `Execution lifecycle operations for executable elements (agents, workflows, pipelines).\n\nSupported operations: ${getOperationsString('EXECUTE')}\n\nThese operations manage runtime execution state. Unlike CRUD operations (which manage definitions), Execute operations handle the execution lifecycle:\n- execute_agent: Start a new execution (returns goalId and stateVersion for tracking)\n- complete_execution: Signal successful completion\n- continue_execution: Resume from saved state\n- abort_execution: Abort a running execution, rejecting further operations\n- confirm_operation: Confirm a pending operation that requires user approval (Gatekeeper flow)\n- approve_cli_permission: Approve a pending CLI tool permission request\n- prepare_handoff: Serialize goal progress into a portable handoff block for session transfer\n- resume_from_handoff: Resume agent execution from a handoff block with integrity validation\n\nIMPORTANT: Execute operations are potentially destructive (agents can perform any action) and non-idempotent (calling execute_agent twice creates two separate executions).\n\n⚠️ SECURITY: Do not auto-allow this endpoint in your host settings (e.g., Claude Code settings.json). Each execution should require explicit human approval. Auto-allowing bypasses the per-operation confirmation gate. While DangerZone verification and element deny policies still provide protection, the primary human review checkpoint is lost.\n\nResponse flow: execute_agent returns { goalId, stateVersion, activeElements, safetyTier, ... }. Use goalId with record_execution_step and complete_execution. stateVersion enables optimistic locking. record_execution_step returns { autonomy: { continue, notifications? } } — check notifications for gatekeeper blocks and danger zone alerts.\n\nQuick start examples:\n{ operation: \"execute_agent\", params: { element_name: \"code-reviewer\", parameters: { objective: \"Review code\" } } }\n{ operation: \"complete_execution\", params: { element_name: \"code-reviewer\", outcome: \"success\", summary: \"Completed review\" } }\n{ operation: \"abort_execution\", params: { element_name: \"data-collector\", reason: \"User requested cancellation\" } }\n{ operation: \"continue_execution\", params: { element_name: \"code-reviewer\" } }\n{ operation: \"confirm_operation\", params: { operation: \"execute_agent\" } }\n{ operation: \"approve_cli_permission\", params: { request_id: \"req-123\", decision: \"allow\" } }\n{ operation: \"prepare_handoff\", params: { element_name: \"code-reviewer\" } }\n{ operation: \"resume_from_handoff\", params: { element_name: \"code-reviewer\", handoff_block: \"...\" } }\n\nDiscover required parameters — use mcp_aql_read:\n{ operation: \"introspect\", params: { query: \"operations\", name: \"execute_agent\" } }`,\n        inputSchema: operationInputSchema,\n        annotations: {\n          readOnlyHint: false,\n          destructiveHint: true  // Potentially destructive - agents can perform any action\n        }\n      },\n      handler: async (args: any) => {\n        const result = await handler.handleExecute(args);\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: JSON.stringify(result, null, 2)\n            }\n          ]\n        };\n      }\n    }\n  ];\n}\n"]}