@dollhousemcp/mcp-server 2.0.6 → 2.0.8

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/CHANGELOG.md CHANGED
@@ -1,5 +1,31 @@
1
1
  # Changelog
2
2
 
3
+ ## [2.0.7] - 2026-04-02
4
+
5
+ ### Clean terminal output for `--web` mode
6
+
7
+ Running `npx @dollhousemcp/mcp-server --web` now shows only the console URL:
8
+
9
+ ```
10
+ DollhouseMCP Management Console
11
+ http://dollhouse.localhost:3939
12
+ http://127.0.0.1:3939 (fallback)
13
+ ```
14
+
15
+ Previously, startup dumped ~80 lines of internal log output (dotenv injection, persona loading, memory seeding, cache stats, leader election, etc.) that looked like errors to new users. All of that output is still captured and visible in the management console's **Logs** tab — it's just no longer printed to the terminal.
16
+
17
+ Set `DOLLHOUSE_DEBUG=1` to restore verbose terminal output for troubleshooting.
18
+
19
+ ## [2.0.6] - 2026-04-02
20
+
21
+ ### Web console logs & metrics fix + operation aliases
22
+
23
+ - **Fix**: Standalone `--web` mode now starts with log and metrics sinks — Logs and Metrics tabs work on first use
24
+ - **Fix**: Port 3939 conflicts handled gracefully (opens existing console instead of crashing)
25
+ - **Feature**: Operation aliases — `open_console`, `open_dollhouse_mcp`, `open_logs`, `open_metrics`, `open_setup`, and 15+ more
26
+ - **Feature**: Console tab deep-linking via URL hash (`/#logs`, `/#metrics`, etc.)
27
+ - **Feature**: Aliases surfaced in `introspect` responses for LLM discovery
28
+
3
29
  ## [2.0.5] - 2026-04-02
4
30
 
5
31
  ### Hotfix: `--web` mode UX improvements
@@ -1 +1 @@
1
- {"version":3,"file":"env.d.ts","sourceRoot":"","sources":["../../src/config/env.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAgBxB;;GAEG;AACH,QAAA,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAsKb,CAAC;AAEH;;;GAGG;AACH,eAAO,MAAM,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAA+B,CAAC;AAEhD;;GAEG;AACH,MAAM,MAAM,GAAG,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,SAAS,CAAC,CAAC;AAE5C;;GAEG;AACH,eAAO,MAAM,MAAM,SAA0B,CAAC;AAC9C,eAAO,MAAM,aAAa,SAAiC,CAAC;AAC5D,eAAO,MAAM,YAAY,SAAgC,CAAC"}
1
+ {"version":3,"file":"env.d.ts","sourceRoot":"","sources":["../../src/config/env.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAuBxB;;GAEG;AACH,QAAA,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAsKb,CAAC;AAEH;;;GAGG;AACH,eAAO,MAAM,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAA+B,CAAC;AAEhD;;GAEG;AACH,MAAM,MAAM,GAAG,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,SAAS,CAAC,CAAC;AAE5C;;GAEG;AACH,eAAO,MAAM,MAAM,SAA0B,CAAC;AAC9C,eAAO,MAAM,aAAa,SAAiC,CAAC;AAC5D,eAAO,MAAM,YAAY,SAAgC,CAAC"}
@@ -21,10 +21,19 @@ import { logger } from '../utils/logger.js';
21
21
  // The MCP protocol requires that ONLY JSON-RPC messages go to stdout.
22
22
  // dotenv may output version info to stdout, which breaks Claude Desktop connection.
23
23
  // Solution: Temporarily redirect stdout to stderr during dotenv initialization.
24
+ // In --web mode, suppress both stdout AND stderr — the user only needs the
25
+ // console URL banner, not dotenv's injection summary. Logs go to the web viewer.
26
+ const isWebSilent = process.argv.includes('--web')
27
+ && !process.env.DOLLHOUSE_DEBUG && !process.env.ENABLE_DEBUG;
24
28
  const originalStdoutWrite = process.stdout.write.bind(process.stdout);
25
- process.stdout.write = process.stderr.write.bind(process.stderr);
29
+ const originalStderrWrite = process.stderr.write.bind(process.stderr);
30
+ process.stdout.write = (isWebSilent ? (() => true) : process.stderr.write.bind(process.stderr));
31
+ if (isWebSilent)
32
+ process.stderr.write = (() => true);
26
33
  dotenv.config({ path: ['.env.local', '.env'] });
27
34
  process.stdout.write = originalStdoutWrite;
35
+ if (isWebSilent)
36
+ process.stderr.write = originalStderrWrite;
28
37
  /**
29
38
  * Environment variable schema with validation
30
39
  */
@@ -198,4 +207,4 @@ if (isDevelopment || isTest) {
198
207
  HAS_GITHUB_TEST_TOKEN: !!env.GITHUB_TEST_TOKEN,
199
208
  });
200
209
  }
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"env.js","sourceRoot":"","sources":["../../src/config/env.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Centralized Environment Configuration\n *\n * This module provides type-safe access to environment variables with validation.\n * All environment variables should be accessed through this module rather than\n * directly via process.env to ensure type safety and validation.\n *\n * Usage:\n * ```typescript\n * import { env } from './config/env';\n * const token = env.GITHUB_TOKEN;  // Type: string\n * ```\n */\n\nimport { z } from 'zod';\nimport dotenv from 'dotenv';\nimport { logger } from '../utils/logger.js';\n\n// Load .env files with priority: .env.local (personal) > .env (shared defaults)\n// Both files are optional - no error if either doesn't exist\n//\n// MCP Protocol Compliance: Suppress dotenv's stdout output\n// The MCP protocol requires that ONLY JSON-RPC messages go to stdout.\n// dotenv may output version info to stdout, which breaks Claude Desktop connection.\n// Solution: Temporarily redirect stdout to stderr during dotenv initialization.\nconst originalStdoutWrite = process.stdout.write.bind(process.stdout);\nprocess.stdout.write = process.stderr.write.bind(process.stderr) as any;\ndotenv.config({ path: ['.env.local', '.env'] });\nprocess.stdout.write = originalStdoutWrite;\n\n/**\n * Environment variable schema with validation\n */\nconst envSchema = z.object({\n  // ============================================================================\n  // Environment\n  // ============================================================================\n  NODE_ENV: z.enum(['development', 'test', 'production']).default('development'),\n\n  // ============================================================================\n  // Production GitHub Credentials\n  // ============================================================================\n  // Used by production code (src/) for real GitHub operations\n  // Optional: Features requiring GitHub will fail gracefully if not set\n  GITHUB_TOKEN: z.string().optional(),\n  GITHUB_USERNAME: z.string().optional(),\n  GITHUB_REPOSITORY: z.string().optional(),\n\n  // ============================================================================\n  // Test GitHub Credentials (SEPARATE account!)\n  // ============================================================================\n  // Used by test code (tests/) - tests will skip if not provided\n  // IMPORTANT: Use a different GitHub account for testing!\n  GITHUB_TEST_TOKEN: z.string().optional(),\n  GITHUB_TEST_USERNAME: z.string().optional(),\n  GITHUB_TEST_REPOSITORY: z.string().optional(),\n\n  // ============================================================================\n  // Server Configuration\n  // ============================================================================\n  PORT: z.coerce.number().default(3000),\n  LOG_LEVEL: z.enum(['error', 'warn', 'info', 'debug']).default('info'),\n\n  // ============================================================================\n  // Test Configuration\n  // ============================================================================\n  TEST_BASE_DIR: z.string().optional(),\n  TEST_PERSONAS_DIR: z.string().optional(),\n  TEST_CACHE_DIR: z.string().optional(),\n  TEST_CONFIG_DIR: z.string().optional(),\n\n  // ============================================================================\n  // Feature Flags\n  // ============================================================================\n  DOLLHOUSE_AUTO_SUBMIT_TO_COLLECTION: z.coerce.boolean().default(false),\n  ENABLE_DEBUG: z.coerce.boolean().default(false),\n  TEST_VERBOSE_LOGGING: z.coerce.boolean().default(false),\n\n  // ============================================================================\n  // MCP Interface Configuration (Issue #237)\n  // ============================================================================\n  /**\n   * MCP interface mode - controls which tool interface is exposed to LLMs:\n   * - 'discrete': ~40 individual tools (list_elements, create_element, etc.) - ~3,000 tokens\n   * - 'mcpaql': Consolidated MCP-AQL interface - uses MCP_AQL_ENDPOINT_MODE for style\n   *\n   * Default: 'mcpaql' - recommended for token efficiency and cleaner tool discovery\n   */\n  MCP_INTERFACE_MODE: z.enum(['discrete', 'mcpaql']).default('mcpaql'),\n\n  /**\n   * MCP-AQL endpoint mode (only applies when MCP_INTERFACE_MODE='mcpaql'):\n   * - 'crude': 5 CRUDE tools (Create, Read, Update, Delete, Execute) - ~4,300 tokens\n   * - 'single': 1 tool (mcp_aql) - ~350 tokens, ideal for multi-server deployments\n   */\n  MCP_AQL_ENDPOINT_MODE: z.enum(['crude', 'single']).default('crude'),\n\n  // Backward compatibility alias for MCP_AQL_MODE (deprecated, use MCP_AQL_ENDPOINT_MODE)\n  MCP_AQL_MODE: z.enum(['crude', 'single']).optional(),\n\n  // ============================================================================\n  // Unified Logging Configuration (docs/LOGGING-DESIGN.md)\n  // ============================================================================\n  DOLLHOUSE_LOG_DIR: z.string().default('~/.dollhouse/logs/'),\n  DOLLHOUSE_LOG_FORMAT: z.enum(['text', 'jsonl']).default('text'),\n  DOLLHOUSE_LOG_RETENTION_DAYS: z.coerce.number().default(30),\n  DOLLHOUSE_LOG_SECURITY_RETENTION_DAYS: z.coerce.number().default(7),\n  DOLLHOUSE_LOG_FLUSH_INTERVAL_MS: z.coerce.number().default(5000),\n  // Buffer raised to 2000 to support the web console log viewer — the higher capacity\n  // reduces flush frequency and keeps more entries available for SSE backfill on connect.\n  DOLLHOUSE_LOG_BUFFER_SIZE: z.coerce.number().default(2000),\n  DOLLHOUSE_LOG_MEMORY_CAPACITY: z.coerce.number().default(5000),\n  DOLLHOUSE_LOG_MEMORY_APP_CAPACITY: z.coerce.number().default(10000),\n  DOLLHOUSE_LOG_MEMORY_SECURITY_CAPACITY: z.coerce.number().default(5000),\n  DOLLHOUSE_LOG_MEMORY_PERF_CAPACITY: z.coerce.number().default(2000),\n  DOLLHOUSE_LOG_MEMORY_TELEMETRY_CAPACITY: z.coerce.number().default(1000),\n  DOLLHOUSE_LOG_MAX_ENTRY_SIZE: z.coerce.number().default(16384),\n  DOLLHOUSE_LOG_IMMEDIATE_FLUSH_RATE: z.coerce.number().default(50),\n  DOLLHOUSE_LOG_FILE_MAX_SIZE: z.coerce.number().default(104857600),\n  DOLLHOUSE_LOG_MAX_DIR_SIZE_BYTES: z.coerce.number().default(0),\n  DOLLHOUSE_LOG_MAX_FILES_PER_CATEGORY: z.coerce.number().default(100),\n\n  // ============================================================================\n  // Web Console Configuration\n  // ============================================================================\n  /** Enable the unified web console (logs + metrics tabs on port 3939) */\n  DOLLHOUSE_WEB_CONSOLE: z.coerce.boolean().default(true),\n\n  // ============================================================================\n  // Security Configuration\n  // ============================================================================\n  /**\n   * Issue #452: Gatekeeper policy enforcement.\n   * When true (default), all MCP-AQL operations go through the 4-layer Gatekeeper\n   * enforce() pipeline. When false, falls back to route validation only.\n   * This is a user/operator setting — the LLM cannot bypass it.\n   */\n  DOLLHOUSE_GATEKEEPER_ENABLED: z.coerce.boolean().default(true),\n  /**\n   * Issue #679: Element policy layer kill switch.\n   * When true (default), active element gatekeeper policies (allow/confirm/deny/scopeRestrictions)\n   * can override default operation permission levels. When false, Layer 2 of Gatekeeper.enforce()\n   * is bypassed entirely — only route validation and default permission levels apply.\n   * Use for emergency lockdown, hardened deployments, or policy debugging.\n   * This is an operator/infrastructure setting — the LLM cannot bypass it.\n   */\n  DOLLHOUSE_GATEKEEPER_ELEMENT_POLICY_OVERRIDES: z.coerce.boolean().default(true),\n  /**\n   * Issue #799: Policy export opt-in flag.\n   * When true (default), PolicyExportService writes the security policy blueprint to\n   * ~/.dollhouse/bridge/imports/policies/ on activation changes. The DollhouseBridge\n   * permission-prompt server watches this file to evaluate permissions locally.\n   * Set to false to disable policy file export entirely.\n   */\n  DOLLHOUSE_POLICY_EXPORT_ENABLED: z.coerce.boolean().default(true),\n\n  // ============================================================================\n  // Storage Layer Configuration\n  // ============================================================================\n  DOLLHOUSE_SCAN_COOLDOWN_MS: z.coerce.number().default(1000),\n  DOLLHOUSE_INDEX_DEBOUNCE_MS: z.coerce.number().default(2000),\n  DOLLHOUSE_ELEMENT_CACHE_TTL_MS: z.coerce.number().default(3600000),\n  DOLLHOUSE_PATH_CACHE_TTL_MS: z.coerce.number().default(3600000),\n  DOLLHOUSE_TOOL_CACHE_TTL_MS: z.coerce.number().default(60000),\n  DOLLHOUSE_GLOBAL_CACHE_MEMORY_MB: z.coerce.number().default(150),\n\n  // ============================================================================\n  // Permission Prompt Configuration (Issue #625)\n  // ============================================================================\n\n  /** Maximum CLI approval records before LRU eviction (default: 50) */\n  DOLLHOUSE_CLI_APPROVAL_MAX: z.coerce.number().default(50),\n\n  /** Default TTL for CLI approval records in ms (default: 300000 = 5 min) */\n  DOLLHOUSE_CLI_APPROVAL_TTL_MS: z.coerce.number().default(300_000),\n\n  /** Permission prompt rate limit: max requests per window (default: 100) */\n  DOLLHOUSE_PERMISSION_PROMPT_RATE_LIMIT: z.coerce.number().default(100),\n\n  /** CLI approval creation rate limit: max requests per window (default: 20) */\n  DOLLHOUSE_CLI_APPROVAL_RATE_LIMIT: z.coerce.number().default(20),\n\n  /** Rate limit window in ms for permission prompt and CLI approvals (default: 60000 = 60s) */\n  DOLLHOUSE_PERMISSION_RATE_WINDOW_MS: z.coerce.number().default(60_000),\n\n  // ============================================================================\n  // Metrics Collection Configuration\n  // ============================================================================\n  DOLLHOUSE_METRICS_ENABLED: z.coerce.boolean().default(true),\n  DOLLHOUSE_METRICS_COLLECTION_INTERVAL_MS: z.coerce.number().min(1000).max(300000).default(15000),\n  DOLLHOUSE_METRICS_MAX_SNAPSHOT_SIZE: z.coerce.number().default(102400),\n  DOLLHOUSE_METRICS_COLLECTOR_FAILURE_THRESHOLD: z.coerce.number().min(1).max(100).default(10),\n  DOLLHOUSE_METRICS_COLLECTION_DURATION_WARN_MS: z.coerce.number().min(100).max(60000).default(5000),\n  DOLLHOUSE_METRICS_MEMORY_SNAPSHOT_CAPACITY: z.coerce.number().min(10).max(10000).default(240),\n\n  // Pattern encryption settings for Memory Security (Issue #1321)\n  DOLLHOUSE_DISABLE_ENCRYPTION: z.coerce.boolean().default(false),\n  DOLLHOUSE_ENCRYPTION_SECRET: z.string().optional(),\n  DOLLHOUSE_ENCRYPTION_SALT: z.string().optional(),\n});\n\n/**\n * Validated environment variables\n * Type is automatically inferred from the schema\n */\nexport const env = envSchema.parse(process.env);\n\n/**\n * Environment type (inferred from schema)\n */\nexport type Env = z.infer<typeof envSchema>;\n\n/**\n * Convenience helpers for environment detection\n */\nexport const isTest = env.NODE_ENV === 'test';\nexport const isDevelopment = env.NODE_ENV === 'development';\nexport const isProduction = env.NODE_ENV === 'production';\n\n/**\n * Log environment configuration (without secrets)\n */\nif (isDevelopment || isTest) {\n  logger.debug('Environment configuration loaded:', {\n    NODE_ENV: env.NODE_ENV,\n    PORT: env.PORT,\n    LOG_LEVEL: env.LOG_LEVEL,\n    HAS_GITHUB_TOKEN: !!env.GITHUB_TOKEN,\n    HAS_GITHUB_TEST_TOKEN: !!env.GITHUB_TEST_TOKEN,\n  });\n}\n"]}
210
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"env.js","sourceRoot":"","sources":["../../src/config/env.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,gFAAgF;AAChF,6DAA6D;AAC7D,EAAE;AACF,2DAA2D;AAC3D,sEAAsE;AACtE,oFAAoF;AACpF,gFAAgF;AAChF,2EAA2E;AAC3E,iFAAiF;AACjF,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;OAC7C,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC;AAC/D,MAAM,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;AACtE,MAAM,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;AACtE,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAQ,CAAC;AACvG,IAAI,WAAW;IAAE,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAQ,CAAC;AAC5D,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC,YAAY,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC;AAChD,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,mBAAmB,CAAC;AAC3C,IAAI,WAAW;IAAE,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,mBAAmB,CAAC;AAE5D;;GAEG;AACH,MAAM,SAAS,GAAG,CAAC,CAAC,MAAM,CAAC;IACzB,+EAA+E;IAC/E,cAAc;IACd,+EAA+E;IAC/E,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC;IAE9E,+EAA+E;IAC/E,gCAAgC;IAChC,+EAA+E;IAC/E,4DAA4D;IAC5D,sEAAsE;IACtE,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACnC,eAAe,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACtC,iBAAiB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAExC,+EAA+E;IAC/E,8CAA8C;IAC9C,+EAA+E;IAC/E,+DAA+D;IAC/D,yDAAyD;IACzD,iBAAiB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACxC,oBAAoB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3C,sBAAsB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAE7C,+EAA+E;IAC/E,uBAAuB;IACvB,+EAA+E;IAC/E,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACrC,SAAS,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;IAErE,+EAA+E;IAC/E,qBAAqB;IACrB,+EAA+E;IAC/E,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACpC,iBAAiB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACxC,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACrC,eAAe,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAEtC,+EAA+E;IAC/E,gBAAgB;IAChB,+EAA+E;IAC/E,mCAAmC,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IACtE,YAAY,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IAC/C,oBAAoB,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IAEvD,+EAA+E;IAC/E,2CAA2C;IAC3C,+EAA+E;IAC/E;;;;;;OAMG;IACH,kBAAkB,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC;IAEpE;;;;OAIG;IACH,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;IAEnE,wFAAwF;IACxF,YAAY,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE;IAEpD,+EAA+E;IAC/E,yDAAyD;IACzD,+EAA+E;IAC/E,iBAAiB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,oBAAoB,CAAC;IAC3D,oBAAoB,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;IAC/D,4BAA4B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;IAC3D,qCAAqC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IACnE,+BAA+B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAChE,oFAAoF;IACpF,wFAAwF;IACxF,yBAAyB,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAC1D,6BAA6B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAC9D,iCAAiC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IACnE,sCAAsC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACvE,kCAAkC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACnE,uCAAuC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACxE,4BAA4B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IAC9D,kCAAkC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;IACjE,2BAA2B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC;IACjE,gCAAgC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAC9D,oCAAoC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC;IAEpE,+EAA+E;IAC/E,4BAA4B;IAC5B,+EAA+E;IAC/E,wEAAwE;IACxE,qBAAqB,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAEvD,+EAA+E;IAC/E,yBAAyB;IACzB,+EAA+E;IAC/E;;;;;OAKG;IACH,4BAA4B,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAC9D;;;;;;;OAOG;IACH,6CAA6C,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAC/E;;;;;;OAMG;IACH,+BAA+B,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAEjE,+EAA+E;IAC/E,8BAA8B;IAC9B,+EAA+E;IAC/E,0BAA0B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAC3D,2BAA2B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAC5D,8BAA8B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;IAClE,2BAA2B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;IAC/D,2BAA2B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IAC7D,gCAAgC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC;IAEhE,+EAA+E;IAC/E,+CAA+C;IAC/C,+EAA+E;IAE/E,qEAAqE;IACrE,0BAA0B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;IAEzD,2EAA2E;IAC3E,6BAA6B,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;IAEjE,2EAA2E;IAC3E,sCAAsC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC;IAEtE,8EAA8E;IAC9E,iCAAiC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;IAEhE,6FAA6F;IAC7F,mCAAmC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;IAEtE,+EAA+E;IAC/E,mCAAmC;IACnC,+EAA+E;IAC/E,yBAAyB,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAC3D,wCAAwC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IAChG,mCAAmC,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;IACtE,6CAA6C,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;IAC5F,6CAA6C,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;IAClG,0CAA0C,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC;IAE7F,gEAAgE;IAChE,4BAA4B,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IAC/D,2BAA2B,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAClD,yBAAyB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACjD,CAAC,CAAC;AAEH;;;GAGG;AACH,MAAM,CAAC,MAAM,GAAG,GAAG,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;AAOhD;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAC,QAAQ,KAAK,MAAM,CAAC;AAC9C,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,CAAC,QAAQ,KAAK,aAAa,CAAC;AAC5D,MAAM,CAAC,MAAM,YAAY,GAAG,GAAG,CAAC,QAAQ,KAAK,YAAY,CAAC;AAE1D;;GAEG;AACH,IAAI,aAAa,IAAI,MAAM,EAAE,CAAC;IAC5B,MAAM,CAAC,KAAK,CAAC,mCAAmC,EAAE;QAChD,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,gBAAgB,EAAE,CAAC,CAAC,GAAG,CAAC,YAAY;QACpC,qBAAqB,EAAE,CAAC,CAAC,GAAG,CAAC,iBAAiB;KAC/C,CAAC,CAAC;AACL,CAAC","sourcesContent":["/**\n * Centralized Environment Configuration\n *\n * This module provides type-safe access to environment variables with validation.\n * All environment variables should be accessed through this module rather than\n * directly via process.env to ensure type safety and validation.\n *\n * Usage:\n * ```typescript\n * import { env } from './config/env';\n * const token = env.GITHUB_TOKEN;  // Type: string\n * ```\n */\n\nimport { z } from 'zod';\nimport dotenv from 'dotenv';\nimport { logger } from '../utils/logger.js';\n\n// Load .env files with priority: .env.local (personal) > .env (shared defaults)\n// Both files are optional - no error if either doesn't exist\n//\n// MCP Protocol Compliance: Suppress dotenv's stdout output\n// The MCP protocol requires that ONLY JSON-RPC messages go to stdout.\n// dotenv may output version info to stdout, which breaks Claude Desktop connection.\n// Solution: Temporarily redirect stdout to stderr during dotenv initialization.\n// In --web mode, suppress both stdout AND stderr — the user only needs the\n// console URL banner, not dotenv's injection summary. Logs go to the web viewer.\nconst isWebSilent = process.argv.includes('--web')\n  && !process.env.DOLLHOUSE_DEBUG && !process.env.ENABLE_DEBUG;\nconst originalStdoutWrite = process.stdout.write.bind(process.stdout);\nconst originalStderrWrite = process.stderr.write.bind(process.stderr);\nprocess.stdout.write = (isWebSilent ? (() => true) : process.stderr.write.bind(process.stderr)) as any;\nif (isWebSilent) process.stderr.write = (() => true) as any;\ndotenv.config({ path: ['.env.local', '.env'] });\nprocess.stdout.write = originalStdoutWrite;\nif (isWebSilent) process.stderr.write = originalStderrWrite;\n\n/**\n * Environment variable schema with validation\n */\nconst envSchema = z.object({\n  // ============================================================================\n  // Environment\n  // ============================================================================\n  NODE_ENV: z.enum(['development', 'test', 'production']).default('development'),\n\n  // ============================================================================\n  // Production GitHub Credentials\n  // ============================================================================\n  // Used by production code (src/) for real GitHub operations\n  // Optional: Features requiring GitHub will fail gracefully if not set\n  GITHUB_TOKEN: z.string().optional(),\n  GITHUB_USERNAME: z.string().optional(),\n  GITHUB_REPOSITORY: z.string().optional(),\n\n  // ============================================================================\n  // Test GitHub Credentials (SEPARATE account!)\n  // ============================================================================\n  // Used by test code (tests/) - tests will skip if not provided\n  // IMPORTANT: Use a different GitHub account for testing!\n  GITHUB_TEST_TOKEN: z.string().optional(),\n  GITHUB_TEST_USERNAME: z.string().optional(),\n  GITHUB_TEST_REPOSITORY: z.string().optional(),\n\n  // ============================================================================\n  // Server Configuration\n  // ============================================================================\n  PORT: z.coerce.number().default(3000),\n  LOG_LEVEL: z.enum(['error', 'warn', 'info', 'debug']).default('info'),\n\n  // ============================================================================\n  // Test Configuration\n  // ============================================================================\n  TEST_BASE_DIR: z.string().optional(),\n  TEST_PERSONAS_DIR: z.string().optional(),\n  TEST_CACHE_DIR: z.string().optional(),\n  TEST_CONFIG_DIR: z.string().optional(),\n\n  // ============================================================================\n  // Feature Flags\n  // ============================================================================\n  DOLLHOUSE_AUTO_SUBMIT_TO_COLLECTION: z.coerce.boolean().default(false),\n  ENABLE_DEBUG: z.coerce.boolean().default(false),\n  TEST_VERBOSE_LOGGING: z.coerce.boolean().default(false),\n\n  // ============================================================================\n  // MCP Interface Configuration (Issue #237)\n  // ============================================================================\n  /**\n   * MCP interface mode - controls which tool interface is exposed to LLMs:\n   * - 'discrete': ~40 individual tools (list_elements, create_element, etc.) - ~3,000 tokens\n   * - 'mcpaql': Consolidated MCP-AQL interface - uses MCP_AQL_ENDPOINT_MODE for style\n   *\n   * Default: 'mcpaql' - recommended for token efficiency and cleaner tool discovery\n   */\n  MCP_INTERFACE_MODE: z.enum(['discrete', 'mcpaql']).default('mcpaql'),\n\n  /**\n   * MCP-AQL endpoint mode (only applies when MCP_INTERFACE_MODE='mcpaql'):\n   * - 'crude': 5 CRUDE tools (Create, Read, Update, Delete, Execute) - ~4,300 tokens\n   * - 'single': 1 tool (mcp_aql) - ~350 tokens, ideal for multi-server deployments\n   */\n  MCP_AQL_ENDPOINT_MODE: z.enum(['crude', 'single']).default('crude'),\n\n  // Backward compatibility alias for MCP_AQL_MODE (deprecated, use MCP_AQL_ENDPOINT_MODE)\n  MCP_AQL_MODE: z.enum(['crude', 'single']).optional(),\n\n  // ============================================================================\n  // Unified Logging Configuration (docs/LOGGING-DESIGN.md)\n  // ============================================================================\n  DOLLHOUSE_LOG_DIR: z.string().default('~/.dollhouse/logs/'),\n  DOLLHOUSE_LOG_FORMAT: z.enum(['text', 'jsonl']).default('text'),\n  DOLLHOUSE_LOG_RETENTION_DAYS: z.coerce.number().default(30),\n  DOLLHOUSE_LOG_SECURITY_RETENTION_DAYS: z.coerce.number().default(7),\n  DOLLHOUSE_LOG_FLUSH_INTERVAL_MS: z.coerce.number().default(5000),\n  // Buffer raised to 2000 to support the web console log viewer — the higher capacity\n  // reduces flush frequency and keeps more entries available for SSE backfill on connect.\n  DOLLHOUSE_LOG_BUFFER_SIZE: z.coerce.number().default(2000),\n  DOLLHOUSE_LOG_MEMORY_CAPACITY: z.coerce.number().default(5000),\n  DOLLHOUSE_LOG_MEMORY_APP_CAPACITY: z.coerce.number().default(10000),\n  DOLLHOUSE_LOG_MEMORY_SECURITY_CAPACITY: z.coerce.number().default(5000),\n  DOLLHOUSE_LOG_MEMORY_PERF_CAPACITY: z.coerce.number().default(2000),\n  DOLLHOUSE_LOG_MEMORY_TELEMETRY_CAPACITY: z.coerce.number().default(1000),\n  DOLLHOUSE_LOG_MAX_ENTRY_SIZE: z.coerce.number().default(16384),\n  DOLLHOUSE_LOG_IMMEDIATE_FLUSH_RATE: z.coerce.number().default(50),\n  DOLLHOUSE_LOG_FILE_MAX_SIZE: z.coerce.number().default(104857600),\n  DOLLHOUSE_LOG_MAX_DIR_SIZE_BYTES: z.coerce.number().default(0),\n  DOLLHOUSE_LOG_MAX_FILES_PER_CATEGORY: z.coerce.number().default(100),\n\n  // ============================================================================\n  // Web Console Configuration\n  // ============================================================================\n  /** Enable the unified web console (logs + metrics tabs on port 3939) */\n  DOLLHOUSE_WEB_CONSOLE: z.coerce.boolean().default(true),\n\n  // ============================================================================\n  // Security Configuration\n  // ============================================================================\n  /**\n   * Issue #452: Gatekeeper policy enforcement.\n   * When true (default), all MCP-AQL operations go through the 4-layer Gatekeeper\n   * enforce() pipeline. When false, falls back to route validation only.\n   * This is a user/operator setting — the LLM cannot bypass it.\n   */\n  DOLLHOUSE_GATEKEEPER_ENABLED: z.coerce.boolean().default(true),\n  /**\n   * Issue #679: Element policy layer kill switch.\n   * When true (default), active element gatekeeper policies (allow/confirm/deny/scopeRestrictions)\n   * can override default operation permission levels. When false, Layer 2 of Gatekeeper.enforce()\n   * is bypassed entirely — only route validation and default permission levels apply.\n   * Use for emergency lockdown, hardened deployments, or policy debugging.\n   * This is an operator/infrastructure setting — the LLM cannot bypass it.\n   */\n  DOLLHOUSE_GATEKEEPER_ELEMENT_POLICY_OVERRIDES: z.coerce.boolean().default(true),\n  /**\n   * Issue #799: Policy export opt-in flag.\n   * When true (default), PolicyExportService writes the security policy blueprint to\n   * ~/.dollhouse/bridge/imports/policies/ on activation changes. The DollhouseBridge\n   * permission-prompt server watches this file to evaluate permissions locally.\n   * Set to false to disable policy file export entirely.\n   */\n  DOLLHOUSE_POLICY_EXPORT_ENABLED: z.coerce.boolean().default(true),\n\n  // ============================================================================\n  // Storage Layer Configuration\n  // ============================================================================\n  DOLLHOUSE_SCAN_COOLDOWN_MS: z.coerce.number().default(1000),\n  DOLLHOUSE_INDEX_DEBOUNCE_MS: z.coerce.number().default(2000),\n  DOLLHOUSE_ELEMENT_CACHE_TTL_MS: z.coerce.number().default(3600000),\n  DOLLHOUSE_PATH_CACHE_TTL_MS: z.coerce.number().default(3600000),\n  DOLLHOUSE_TOOL_CACHE_TTL_MS: z.coerce.number().default(60000),\n  DOLLHOUSE_GLOBAL_CACHE_MEMORY_MB: z.coerce.number().default(150),\n\n  // ============================================================================\n  // Permission Prompt Configuration (Issue #625)\n  // ============================================================================\n\n  /** Maximum CLI approval records before LRU eviction (default: 50) */\n  DOLLHOUSE_CLI_APPROVAL_MAX: z.coerce.number().default(50),\n\n  /** Default TTL for CLI approval records in ms (default: 300000 = 5 min) */\n  DOLLHOUSE_CLI_APPROVAL_TTL_MS: z.coerce.number().default(300_000),\n\n  /** Permission prompt rate limit: max requests per window (default: 100) */\n  DOLLHOUSE_PERMISSION_PROMPT_RATE_LIMIT: z.coerce.number().default(100),\n\n  /** CLI approval creation rate limit: max requests per window (default: 20) */\n  DOLLHOUSE_CLI_APPROVAL_RATE_LIMIT: z.coerce.number().default(20),\n\n  /** Rate limit window in ms for permission prompt and CLI approvals (default: 60000 = 60s) */\n  DOLLHOUSE_PERMISSION_RATE_WINDOW_MS: z.coerce.number().default(60_000),\n\n  // ============================================================================\n  // Metrics Collection Configuration\n  // ============================================================================\n  DOLLHOUSE_METRICS_ENABLED: z.coerce.boolean().default(true),\n  DOLLHOUSE_METRICS_COLLECTION_INTERVAL_MS: z.coerce.number().min(1000).max(300000).default(15000),\n  DOLLHOUSE_METRICS_MAX_SNAPSHOT_SIZE: z.coerce.number().default(102400),\n  DOLLHOUSE_METRICS_COLLECTOR_FAILURE_THRESHOLD: z.coerce.number().min(1).max(100).default(10),\n  DOLLHOUSE_METRICS_COLLECTION_DURATION_WARN_MS: z.coerce.number().min(100).max(60000).default(5000),\n  DOLLHOUSE_METRICS_MEMORY_SNAPSHOT_CAPACITY: z.coerce.number().min(10).max(10000).default(240),\n\n  // Pattern encryption settings for Memory Security (Issue #1321)\n  DOLLHOUSE_DISABLE_ENCRYPTION: z.coerce.boolean().default(false),\n  DOLLHOUSE_ENCRYPTION_SECRET: z.string().optional(),\n  DOLLHOUSE_ENCRYPTION_SALT: z.string().optional(),\n});\n\n/**\n * Validated environment variables\n * Type is automatically inferred from the schema\n */\nexport const env = envSchema.parse(process.env);\n\n/**\n * Environment type (inferred from schema)\n */\nexport type Env = z.infer<typeof envSchema>;\n\n/**\n * Convenience helpers for environment detection\n */\nexport const isTest = env.NODE_ENV === 'test';\nexport const isDevelopment = env.NODE_ENV === 'development';\nexport const isProduction = env.NODE_ENV === 'production';\n\n/**\n * Log environment configuration (without secrets)\n */\nif (isDevelopment || isTest) {\n  logger.debug('Environment configuration loaded:', {\n    NODE_ENV: env.NODE_ENV,\n    PORT: env.PORT,\n    LOG_LEVEL: env.LOG_LEVEL,\n    HAS_GITHUB_TOKEN: !!env.GITHUB_TOKEN,\n    HAS_GITHUB_TEST_TOKEN: !!env.GITHUB_TEST_TOKEN,\n  });\n}\n"]}
@@ -0,0 +1,3 @@
1
+ export declare const VERSION = "1.6.5";
2
+ export declare const BUILD_DATE = "2025-08-26T15:30:22.187Z";
3
+ //# sourceMappingURL=version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../src/constants/version.ts"],"names":[],"mappings":"AACA,eAAO,MAAM,OAAO,UAAU,CAAC;AAC/B,eAAO,MAAM,UAAU,6BAA6B,CAAC"}
@@ -0,0 +1,4 @@
1
+ // Auto-generated version constant
2
+ export const VERSION = "1.6.5";
3
+ export const BUILD_DATE = "2025-08-26T15:30:22.187Z";
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25zdGFudHMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxrQ0FBa0M7QUFDbEMsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQztBQUMvQixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBBdXRvLWdlbmVyYXRlZCB2ZXJzaW9uIGNvbnN0YW50XG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiMS42LjVcIjtcbmV4cG9ydCBjb25zdCBCVUlMRF9EQVRFID0gXCIyMDI1LTA4LTI2VDE1OjMwOjIyLjE4N1pcIjtcbiJdfQ==
@@ -2,8 +2,8 @@
2
2
  * Auto-generated file - DO NOT EDIT
3
3
  * Generated at build time by scripts/generate-version.js
4
4
  */
5
- export declare const PACKAGE_VERSION = "2.0.6";
6
- export declare const BUILD_TIMESTAMP = "2026-04-02T20:49:12.821Z";
5
+ export declare const PACKAGE_VERSION = "2.0.8";
6
+ export declare const BUILD_TIMESTAMP = "2026-04-02T23:02:41.967Z";
7
7
  export declare const BUILD_TYPE: 'npm' | 'git';
8
8
  export declare const PACKAGE_NAME = "@dollhousemcp/mcp-server";
9
9
  //# sourceMappingURL=version.d.ts.map
@@ -2,8 +2,8 @@
2
2
  * Auto-generated file - DO NOT EDIT
3
3
  * Generated at build time by scripts/generate-version.js
4
4
  */
5
- export const PACKAGE_VERSION = '2.0.6';
6
- export const BUILD_TIMESTAMP = '2026-04-02T20:49:12.821Z';
5
+ export const PACKAGE_VERSION = '2.0.8';
6
+ export const BUILD_TIMESTAMP = '2026-04-02T23:02:41.967Z';
7
7
  export const BUILD_TYPE = 'npm';
8
8
  export const PACKAGE_NAME = '@dollhousemcp/mcp-server';
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW5lcmF0ZWQvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsT0FBTyxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRywwQkFBMEIsQ0FBQztBQUMxRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQWtCLEtBQUssQ0FBQztBQUMvQyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEF1dG8tZ2VuZXJhdGVkIGZpbGUgLSBETyBOT1QgRURJVFxuICogR2VuZXJhdGVkIGF0IGJ1aWxkIHRpbWUgYnkgc2NyaXB0cy9nZW5lcmF0ZS12ZXJzaW9uLmpzXG4gKi9cblxuZXhwb3J0IGNvbnN0IFBBQ0tBR0VfVkVSU0lPTiA9ICcyLjAuNic7XG5leHBvcnQgY29uc3QgQlVJTERfVElNRVNUQU1QID0gJzIwMjYtMDQtMDJUMjA6NDk6MTIuODIxWic7XG5leHBvcnQgY29uc3QgQlVJTERfVFlQRTogJ25wbScgfCAnZ2l0JyA9ICducG0nO1xuZXhwb3J0IGNvbnN0IFBBQ0tBR0VfTkFNRSA9ICdAZG9sbGhvdXNlbWNwL21jcC1zZXJ2ZXInO1xuIl19
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW5lcmF0ZWQvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsT0FBTyxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRywwQkFBMEIsQ0FBQztBQUMxRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQWtCLEtBQUssQ0FBQztBQUMvQyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEF1dG8tZ2VuZXJhdGVkIGZpbGUgLSBETyBOT1QgRURJVFxuICogR2VuZXJhdGVkIGF0IGJ1aWxkIHRpbWUgYnkgc2NyaXB0cy9nZW5lcmF0ZS12ZXJzaW9uLmpzXG4gKi9cblxuZXhwb3J0IGNvbnN0IFBBQ0tBR0VfVkVSU0lPTiA9ICcyLjAuOCc7XG5leHBvcnQgY29uc3QgQlVJTERfVElNRVNUQU1QID0gJzIwMjYtMDQtMDJUMjM6MDI6NDEuOTY3Wic7XG5leHBvcnQgY29uc3QgQlVJTERfVFlQRTogJ25wbScgfCAnZ2l0JyA9ICducG0nO1xuZXhwb3J0IGNvbnN0IFBBQ0tBR0VfTkFNRSA9ICdAZG9sbGhvdXNlbWNwL21jcC1zZXJ2ZXInO1xuIl19
package/dist/index.js CHANGED
@@ -629,10 +629,11 @@ if ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTes
629
629
  // Issue #796: Bootstrap DI container for web-only mode so API routes
630
630
  // go through MCPAQLHandler (validated, cached, gatekeeper-checked)
631
631
  //
632
- // Suppress debug output in --web mode unless DOLLHOUSE_DEBUG is set.
633
- // The web console captures all logs in memory no need to flood the terminal.
632
+ // Suppress terminal output in --web mode unless DOLLHOUSE_DEBUG is set.
633
+ // All logs are still captured in MemoryLogSink and visible in the Logs tab
634
+ // the terminal only needs the console URL banner, not a wall of startup noise.
634
635
  if (!process.env.DOLLHOUSE_DEBUG && !process.env.ENABLE_DEBUG) {
635
- logger.setMinLevel('info');
636
+ logger.setMinLevel('error');
636
637
  }
637
638
  (async () => {
638
639
  const portfolioDir = path.join(os.homedir(), '.dollhouse', 'portfolio');
@@ -657,7 +658,6 @@ if ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTes
657
658
  metricsSink = container.resolve('MemoryMetricsSink');
658
659
  }
659
660
  catch { /* not registered */ }
660
- console.error("[DollhouseMCP] Container bootstrapped — web routes using MCP-AQL Gateway");
661
661
  }
662
662
  catch (err) {
663
663
  console.error("[DollhouseMCP] Container bootstrap failed — web routes will use direct filesystem access.");
@@ -697,4 +697,4 @@ if ((isDirectExecution || isNpxExecution || isCliExecution) && (!isTest || isTes
697
697
  });
698
698
  }
699
699
  }
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"]}
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 terminal output in --web mode unless DOLLHOUSE_DEBUG is set.\n    // All logs are still captured in MemoryLogSink and visible in the Logs tab —\n    // the terminal only needs the console URL banner, not a wall of startup noise.\n    if (!process.env.DOLLHOUSE_DEBUG && !process.env.ENABLE_DEBUG) {\n      logger.setMinLevel('error');\n    }\n\n    (async () => {\n      const portfolioDir = path.join(os.homedir(), '.dollhouse', 'portfolio');\n      const portArg = process.argv.find(a => a.startsWith('--port='));\n      const port = portArg ? parseInt(portArg.split('=')[1], 10) : undefined;\n      const noBrowser = process.argv.includes('--no-open');\n\n      let mcpAqlHandler;\n      let memorySink: import('./logging/sinks/MemoryLogSink.js').MemoryLogSink | undefined;\n      let metricsSink: import('./metrics/sinks/MemoryMetricsSink.js').MemoryMetricsSink | undefined;\n      try {\n        const container = new DollhouseContainer();\n        await container.preparePortfolio();\n        const bundle = await container.bootstrapHandlers();\n        await container.completeDeferredSetup();\n        mcpAqlHandler = bundle.mcpAqlHandler;\n        // Extract sinks from container — deferred setup may have already wired them\n        try { memorySink = container.resolve<import('./logging/sinks/MemoryLogSink.js').MemoryLogSink>('MemoryLogSink'); } catch { /* not registered */ }\n        try { metricsSink = container.resolve<import('./metrics/sinks/MemoryMetricsSink.js').MemoryMetricsSink>('MemoryMetricsSink'); } catch { /* not registered */ }\n      } catch (err) {\n        console.error(\"[DollhouseMCP] Container bootstrap failed — web routes will use direct filesystem access.\");\n        console.error(\"[DollhouseMCP] Reason:\", (err as Error).message || err);\n        console.error(\"[DollhouseMCP] This may indicate a corrupt portfolio or missing dependencies.\");\n      }\n\n      // Ensure sinks exist even if container bootstrap failed —\n      // standalone --web mode still needs working logs and metrics tabs\n      if (!memorySink) {\n        const { MemoryLogSink } = await import('./logging/sinks/MemoryLogSink.js');\n        memorySink = new MemoryLogSink({\n          appCapacity: 10000,\n          securityCapacity: 5000,\n          perfCapacity: 2000,\n          telemetryCapacity: 1000,\n        });\n      }\n      if (!metricsSink) {\n        const { MemoryMetricsSink } = await import('./metrics/sinks/MemoryMetricsSink.js');\n        metricsSink = new MemoryMetricsSink(240);\n      }\n\n      const { startWebServer } = await import('./web/server.js');\n      await startWebServer({ portfolioDir, port, openBrowser: !noBrowser, mcpAqlHandler, memorySink, metricsSink });\n    })().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"]}