@dollhousemcp/mcp-server 2.0.27-rc.8 → 2.0.27
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 +1 -1
- package/dist/config/env.d.ts +0 -10
- package/dist/config/env.d.ts.map +1 -1
- package/dist/config/env.js +1 -31
- package/dist/elements/ensembles/EnsembleManager.d.ts +0 -18
- package/dist/elements/ensembles/EnsembleManager.d.ts.map +1 -1
- package/dist/elements/ensembles/EnsembleManager.js +5 -37
- package/dist/generated/version.d.ts +2 -2
- package/dist/generated/version.d.ts.map +1 -1
- package/dist/generated/version.js +3 -3
- package/dist/logging/LogHooks.d.ts.map +1 -1
- package/dist/logging/LogHooks.js +1 -33
- package/dist/web/console/IngestRoutes.d.ts +0 -2
- package/dist/web/console/IngestRoutes.d.ts.map +1 -1
- package/dist/web/console/IngestRoutes.js +2 -49
- package/dist/web/console/LeaderElection.d.ts +5 -6
- package/dist/web/console/LeaderElection.d.ts.map +1 -1
- package/dist/web/console/LeaderElection.js +21 -24
- package/dist/web/console/SessionNames.d.ts +0 -6
- package/dist/web/console/SessionNames.d.ts.map +1 -1
- package/dist/web/console/SessionNames.js +1 -20
- package/dist/web/console/UnifiedConsole.d.ts +2 -37
- package/dist/web/console/UnifiedConsole.d.ts.map +1 -1
- package/dist/web/console/UnifiedConsole.js +15 -374
- package/dist/web/contentPipeline.d.ts +0 -1
- package/dist/web/contentPipeline.d.ts.map +1 -1
- package/dist/web/contentPipeline.js +4 -48
- package/dist/web/public/app.js +83 -196
- package/dist/web/public/index.html +7 -16
- package/dist/web/public/logs.css +1 -157
- package/dist/web/public/logs.js +8 -56
- package/dist/web/public/sessions.css +1 -2
- package/dist/web/public/styles.css +34 -247
- package/dist/web/routes/permissionRoutes.d.ts.map +1 -1
- package/dist/web/routes/permissionRoutes.js +4 -18
- package/dist/web/server.d.ts +0 -6
- package/dist/web/server.d.ts.map +1 -1
- package/dist/web/server.js +14 -62
- package/package.json +3 -1
- package/scripts/permission-port-discovery.sh +79 -0
- package/server.json +2 -2
package/CHANGELOG.md
CHANGED
package/dist/config/env.d.ts
CHANGED
|
@@ -80,11 +80,6 @@ declare const envSchema: z.ZodObject<{
|
|
|
80
80
|
DOLLHOUSE_CONSOLE_LEADER_LOCK_FILE: z.ZodOptional<z.ZodString>;
|
|
81
81
|
DOLLHOUSE_CONSOLE_BIND_RETRY_DELAYS: z.ZodPipe<z.ZodOptional<z.ZodString>, z.ZodTransform<number[] | undefined, string | undefined>>;
|
|
82
82
|
DOLLHOUSE_CONSOLE_MAX_FORWARD_FAILURES: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
83
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_MS: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
84
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_JITTER_MS: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
85
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_FAILURE_THRESHOLD: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
86
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_FAILURE_COOLDOWN_MS: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
87
|
-
DOLLHOUSE_CONSOLE_LEADER_DISCOVERY_TIMEOUT_MS: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
88
83
|
DOLLHOUSE_CONSOLE_ROTATION_REQUIRE_CONFIRMATION: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
89
84
|
DOLLHOUSE_GATEKEEPER_ENABLED: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
90
85
|
DOLLHOUSE_GATEKEEPER_ELEMENT_POLICY_OVERRIDES: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
@@ -146,11 +141,6 @@ export declare const env: {
|
|
|
146
141
|
DOLLHOUSE_WEB_AUTH_ENABLED: boolean;
|
|
147
142
|
DOLLHOUSE_CONSOLE_BIND_RETRY_DELAYS: number[] | undefined;
|
|
148
143
|
DOLLHOUSE_CONSOLE_MAX_FORWARD_FAILURES: number;
|
|
149
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_MS: number;
|
|
150
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_JITTER_MS: number;
|
|
151
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_FAILURE_THRESHOLD: number;
|
|
152
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_FAILURE_COOLDOWN_MS: number;
|
|
153
|
-
DOLLHOUSE_CONSOLE_LEADER_DISCOVERY_TIMEOUT_MS: number;
|
|
154
144
|
DOLLHOUSE_CONSOLE_ROTATION_REQUIRE_CONFIRMATION: boolean;
|
|
155
145
|
DOLLHOUSE_GATEKEEPER_ENABLED: boolean;
|
|
156
146
|
DOLLHOUSE_GATEKEEPER_ELEMENT_POLICY_OVERRIDES: boolean;
|
package/dist/config/env.d.ts.map
CHANGED
|
@@ -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;AAuBxB;;GAEG;AACH,QAAA,MAAM,SAAS
|
|
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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAuQb,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"}
|
package/dist/config/env.js
CHANGED
|
@@ -196,36 +196,6 @@ const envSchema = z.object({
|
|
|
196
196
|
* Default: 10.
|
|
197
197
|
*/
|
|
198
198
|
DOLLHOUSE_CONSOLE_MAX_FORWARD_FAILURES: z.coerce.number().int().min(1).max(100).default(10),
|
|
199
|
-
/**
|
|
200
|
-
* How often a follower re-evaluates whether it should take over console
|
|
201
|
-
* leadership in a heterogeneous mixed-version environment.
|
|
202
|
-
* Default: 15000ms.
|
|
203
|
-
*/
|
|
204
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_MS: z.coerce.number().int().min(1_000).max(300_000).default(15_000),
|
|
205
|
-
/**
|
|
206
|
-
* Additional per-session jitter added to authority rechecks so large mixed
|
|
207
|
-
* fleets do not all wake up in the same instant.
|
|
208
|
-
* Default: 5000ms.
|
|
209
|
-
*/
|
|
210
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_JITTER_MS: z.coerce.number().int().min(0).max(60_000).default(5_000),
|
|
211
|
-
/**
|
|
212
|
-
* Number of consecutive authority recheck failures before the follower opens
|
|
213
|
-
* its local circuit breaker and stops retrying until the cooldown expires.
|
|
214
|
-
* Default: 3.
|
|
215
|
-
*/
|
|
216
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_FAILURE_THRESHOLD: z.coerce.number().int().min(1).max(100).default(3),
|
|
217
|
-
/**
|
|
218
|
-
* Cooldown period after the follower authority monitor opens its circuit
|
|
219
|
-
* breaker due to repeated failures.
|
|
220
|
-
* Default: 60000ms.
|
|
221
|
-
*/
|
|
222
|
-
DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_FAILURE_COOLDOWN_MS: z.coerce.number().int().min(1_000).max(900_000).default(60_000),
|
|
223
|
-
/**
|
|
224
|
-
* Timeout for leader-discovery HTTP probes against /api/sessions before the
|
|
225
|
-
* caller falls back to lock-file or synthetic-owner heuristics.
|
|
226
|
-
* Default: 2000ms.
|
|
227
|
-
*/
|
|
228
|
-
DOLLHOUSE_CONSOLE_LEADER_DISCOVERY_TIMEOUT_MS: z.coerce.number().int().min(250).max(30_000).default(2_000),
|
|
229
199
|
/**
|
|
230
200
|
* Issue #1780: Phase 2 — require a confirmation code (OS dialog or TOTP)
|
|
231
201
|
* for privileged actions like token rotation. Default is true for safety;
|
|
@@ -324,4 +294,4 @@ if (isDevelopment || isTest) {
|
|
|
324
294
|
HAS_GITHUB_TEST_TOKEN: !!env.GITHUB_TEST_TOKEN,
|
|
325
295
|
});
|
|
326
296
|
}
|
|
327
|
-
//# 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.\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  // Permission Server Configuration\n  // ============================================================================\n  /**\n   * Enable the HTTP permission evaluation server for PreToolUse hooks.\n   * When true, starts an HTTP endpoint on a dynamic port after deferred\n   * setup completes. Writes port to ~/.dollhouse/run/permission-server.port\n   * for hook script discovery. Required for autonomous agent permission\n   * management via Claude Code hooks.\n   */\n  DOLLHOUSE_PERMISSION_SERVER: z.coerce.boolean().default(true),\n\n  // Web Console Configuration\n  // ============================================================================\n  /** Enable the unified web console (logs + metrics tabs) */\n  DOLLHOUSE_WEB_CONSOLE: z.coerce.boolean().default(true),\n\n  /**\n   * Port the web console leader binds to (#1794, #1798).\n   *\n   * Default: 41715 — \"AILIS\" on a phone keypad, after the AI Layer\n   * Interface Specification that DollhouseMCP implements. Also \"Alice\"\n   * in Gaelic.\n   *\n   * Port selection criteria (verified 2026-04-06):\n   *   - Not registered with IANA (no entry in the service name registry)\n   *   - Not in nmap services database (never observed in the wild)\n   *   - No known application, security tool, or malware associations\n   *   - Below the macOS ephemeral range (49152-65535), so `bind()`\n   *     does not race with kernel-allocated source ports\n   *   - In the IANA user port range (1024-49151)\n   *   - Not adjacent to the pre-authentication default (3939)\n   *\n   * Previous default was 5907 (\"LOGS\" upside down on a calculator),\n   * which conflicted with Stellar Cyber's HTTP GKE log parser.\n   *\n   * Override via env var if 41715 collides with something in your\n   * environment — every runtime reference reads from this single value.\n   */\n  DOLLHOUSE_WEB_CONSOLE_PORT: z.coerce.number().int().min(1024).max(65535).default(41715),\n\n  /**\n   * Issue #1780: Enforce Bearer token authentication on the web console API.\n   * When true, all protected endpoints require a valid token from the\n   * console token file. When false (the pre-Phase-2 default), the token\n   * file is still generated but the middleware does not enforce — this\n   * lets the infrastructure land without breaking existing consumers.\n   * Will flip to default `true` in a follow-up PR once all consumers\n   * (browser, followers, bridge) have been updated to attach tokens.\n   */\n  DOLLHOUSE_WEB_AUTH_ENABLED: z.coerce.boolean().default(false),\n\n  /**\n   * Issue #1780: Optional override for the console token file location.\n   * When unset, `ConsoleTokenStore` falls back to its built-in default\n   * under `~/.dollhouse/run/`. Mainly useful for tests and for enterprise\n   * deployments that mount a shared token file from a secrets volume.\n   */\n  DOLLHOUSE_CONSOLE_TOKEN_FILE: z.string().optional(),\n\n  /**\n   * Optional override for the console leader lock file location (#1794).\n   * When unset, `LeaderElection` falls back to its built-in default under\n   * `~/.dollhouse/run/`. Primarily useful for tests that need isolation\n   * between runs and for deployments that split runtime state across\n   * multiple installations on the same machine.\n   */\n  DOLLHOUSE_CONSOLE_LEADER_LOCK_FILE: z.string().optional(),\n\n  // Leader/Follower Recovery (#1850)\n  // ============================================================================\n\n  /**\n   * Issue #1850: Retry delays (in ms) when the leader fails to bind the console\n   * port due to EADDRINUSE. Each value is a successive backoff delay.\n   * Default: 1s, 2s, 4s (7s total). Increase for slow or remote environments.\n   */\n  DOLLHOUSE_CONSOLE_BIND_RETRY_DELAYS: z.string()\n    .optional()\n    .transform(v => v ? v.split(',').map(Number).filter(n => !Number.isNaN(n) && n > 0) : undefined),\n\n  /**\n   * Issue #1850: Number of consecutive forwarding failures before a follower\n   * declares the leader dead and attempts self-promotion. Higher values reduce\n   * false positives in high-latency environments but delay recovery.\n   * Default: 10.\n   */\n  DOLLHOUSE_CONSOLE_MAX_FORWARD_FAILURES: z.coerce.number().int().min(1).max(100).default(10),\n\n  /**\n   * How often a follower re-evaluates whether it should take over console\n   * leadership in a heterogeneous mixed-version environment.\n   * Default: 15000ms.\n   */\n  DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_MS: z.coerce.number().int().min(1_000).max(300_000).default(15_000),\n\n  /**\n   * Additional per-session jitter added to authority rechecks so large mixed\n   * fleets do not all wake up in the same instant.\n   * Default: 5000ms.\n   */\n  DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_JITTER_MS: z.coerce.number().int().min(0).max(60_000).default(5_000),\n\n  /**\n   * Number of consecutive authority recheck failures before the follower opens\n   * its local circuit breaker and stops retrying until the cooldown expires.\n   * Default: 3.\n   */\n  DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_FAILURE_THRESHOLD: z.coerce.number().int().min(1).max(100).default(3),\n\n  /**\n   * Cooldown period after the follower authority monitor opens its circuit\n   * breaker due to repeated failures.\n   * Default: 60000ms.\n   */\n  DOLLHOUSE_CONSOLE_AUTHORITY_RECHECK_FAILURE_COOLDOWN_MS: z.coerce.number().int().min(1_000).max(900_000).default(60_000),\n\n  /**\n   * Timeout for leader-discovery HTTP probes against /api/sessions before the\n   * caller falls back to lock-file or synthetic-owner heuristics.\n   * Default: 2000ms.\n   */\n  DOLLHOUSE_CONSOLE_LEADER_DISCOVERY_TIMEOUT_MS: z.coerce.number().int().min(250).max(30_000).default(2_000),\n\n  /**\n   * Issue #1780: Phase 2 — require a confirmation code (OS dialog or TOTP)\n   * for privileged actions like token rotation. Default is true for safety;\n   * set to false for headless CI and scripted deployments that need to rotate\n   * without human interaction.\n   */\n  DOLLHOUSE_CONSOLE_ROTATION_REQUIRE_CONFIRMATION: 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  // Token encryption secret (SEC-01, #1735)\n  // When set, replaces the predictable machine-derived passphrase for token encryption.\n  // Strongly recommended for any shared or multi-user environment.\n  // Minimum 32 characters enforced to prevent weak passphrases.\n  DOLLHOUSE_TOKEN_SECRET: z.string().min(32).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"]}
|
|
297
|
+
//# 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.\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  // Permission Server Configuration\n  // ============================================================================\n  /**\n   * Enable the HTTP permission evaluation server for PreToolUse hooks.\n   * When true, starts an HTTP endpoint on a dynamic port after deferred\n   * setup completes. Writes port to ~/.dollhouse/run/permission-server.port\n   * for hook script discovery. Required for autonomous agent permission\n   * management via Claude Code hooks.\n   */\n  DOLLHOUSE_PERMISSION_SERVER: z.coerce.boolean().default(true),\n\n  // Web Console Configuration\n  // ============================================================================\n  /** Enable the unified web console (logs + metrics tabs) */\n  DOLLHOUSE_WEB_CONSOLE: z.coerce.boolean().default(true),\n\n  /**\n   * Port the web console leader binds to (#1794, #1798).\n   *\n   * Default: 41715 — \"AILIS\" on a phone keypad, after the AI Layer\n   * Interface Specification that DollhouseMCP implements. Also \"Alice\"\n   * in Gaelic.\n   *\n   * Port selection criteria (verified 2026-04-06):\n   *   - Not registered with IANA (no entry in the service name registry)\n   *   - Not in nmap services database (never observed in the wild)\n   *   - No known application, security tool, or malware associations\n   *   - Below the macOS ephemeral range (49152-65535), so `bind()`\n   *     does not race with kernel-allocated source ports\n   *   - In the IANA user port range (1024-49151)\n   *   - Not adjacent to the pre-authentication default (3939)\n   *\n   * Previous default was 5907 (\"LOGS\" upside down on a calculator),\n   * which conflicted with Stellar Cyber's HTTP GKE log parser.\n   *\n   * Override via env var if 41715 collides with something in your\n   * environment — every runtime reference reads from this single value.\n   */\n  DOLLHOUSE_WEB_CONSOLE_PORT: z.coerce.number().int().min(1024).max(65535).default(41715),\n\n  /**\n   * Issue #1780: Enforce Bearer token authentication on the web console API.\n   * When true, all protected endpoints require a valid token from the\n   * console token file. When false (the pre-Phase-2 default), the token\n   * file is still generated but the middleware does not enforce — this\n   * lets the infrastructure land without breaking existing consumers.\n   * Will flip to default `true` in a follow-up PR once all consumers\n   * (browser, followers, bridge) have been updated to attach tokens.\n   */\n  DOLLHOUSE_WEB_AUTH_ENABLED: z.coerce.boolean().default(false),\n\n  /**\n   * Issue #1780: Optional override for the console token file location.\n   * When unset, `ConsoleTokenStore` falls back to its built-in default\n   * under `~/.dollhouse/run/`. Mainly useful for tests and for enterprise\n   * deployments that mount a shared token file from a secrets volume.\n   */\n  DOLLHOUSE_CONSOLE_TOKEN_FILE: z.string().optional(),\n\n  /**\n   * Optional override for the console leader lock file location (#1794).\n   * When unset, `LeaderElection` falls back to its built-in default under\n   * `~/.dollhouse/run/`. Primarily useful for tests that need isolation\n   * between runs and for deployments that split runtime state across\n   * multiple installations on the same machine.\n   */\n  DOLLHOUSE_CONSOLE_LEADER_LOCK_FILE: z.string().optional(),\n\n  // Leader/Follower Recovery (#1850)\n  // ============================================================================\n\n  /**\n   * Issue #1850: Retry delays (in ms) when the leader fails to bind the console\n   * port due to EADDRINUSE. Each value is a successive backoff delay.\n   * Default: 1s, 2s, 4s (7s total). Increase for slow or remote environments.\n   */\n  DOLLHOUSE_CONSOLE_BIND_RETRY_DELAYS: z.string()\n    .optional()\n    .transform(v => v ? v.split(',').map(Number).filter(n => !Number.isNaN(n) && n > 0) : undefined),\n\n  /**\n   * Issue #1850: Number of consecutive forwarding failures before a follower\n   * declares the leader dead and attempts self-promotion. Higher values reduce\n   * false positives in high-latency environments but delay recovery.\n   * Default: 10.\n   */\n  DOLLHOUSE_CONSOLE_MAX_FORWARD_FAILURES: z.coerce.number().int().min(1).max(100).default(10),\n\n  /**\n   * Issue #1780: Phase 2 — require a confirmation code (OS dialog or TOTP)\n   * for privileged actions like token rotation. Default is true for safety;\n   * set to false for headless CI and scripted deployments that need to rotate\n   * without human interaction.\n   */\n  DOLLHOUSE_CONSOLE_ROTATION_REQUIRE_CONFIRMATION: 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  // Token encryption secret (SEC-01, #1735)\n  // When set, replaces the predictable machine-derived passphrase for token encryption.\n  // Strongly recommended for any shared or multi-user environment.\n  // Minimum 32 characters enforced to prevent weak passphrases.\n  DOLLHOUSE_TOKEN_SECRET: z.string().min(32).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"]}
|
|
@@ -38,14 +38,6 @@ export declare const resolveEnsembleElementTypes: typeof resolveElementTypes;
|
|
|
38
38
|
* - Ensemble creation and validation
|
|
39
39
|
* - Element reference management
|
|
40
40
|
* - Import/export in multiple formats
|
|
41
|
-
*
|
|
42
|
-
* MEMORY BEHAVIOR:
|
|
43
|
-
* - Tracks warned legacy element-field fingerprints in memory so repeated parses
|
|
44
|
-
* of the same ensemble/element/field combination do not keep spamming logs.
|
|
45
|
-
* - Fingerprints are scoped to the manager lifetime and grow with the number of
|
|
46
|
-
* unique legacy field sightings.
|
|
47
|
-
* - Long-running servers can clear this history explicitly with
|
|
48
|
-
* clearLegacyElementWarningHistory(), and dispose() also clears it.
|
|
49
41
|
*/
|
|
50
42
|
export declare class EnsembleManager extends BaseElementManager<Ensemble> {
|
|
51
43
|
private metadataService;
|
|
@@ -53,18 +45,8 @@ export declare class EnsembleManager extends BaseElementManager<Ensemble> {
|
|
|
53
45
|
private validationService;
|
|
54
46
|
private serializationService;
|
|
55
47
|
private activeEnsembleNames;
|
|
56
|
-
private readonly legacyElementFieldWarnings;
|
|
57
48
|
constructor(portfolioManager: PortfolioManager, fileLockManager: FileLockManager, fileOperationsService: FileOperationsService, validationRegistry: ValidationRegistry, serializationService: SerializationService, metadataService: MetadataService, fileWatchService?: FileWatchService, memoryBudget?: import('../../cache/CacheMemoryBudget.js').CacheMemoryBudget, backupService?: import('../../services/BackupService.js').BackupService);
|
|
58
49
|
protected getElementLabel(): string;
|
|
59
|
-
/**
|
|
60
|
-
* Clear warn-once state for legacy ensemble element fields.
|
|
61
|
-
*
|
|
62
|
-
* Useful for long-lived processes that want to cap in-memory warning history
|
|
63
|
-
* or intentionally re-emit migration guidance after a maintenance boundary.
|
|
64
|
-
*/
|
|
65
|
-
clearLegacyElementWarningHistory(): void;
|
|
66
|
-
dispose(): void;
|
|
67
|
-
private warnOnceForLegacyElementField;
|
|
68
50
|
/**
|
|
69
51
|
* Parse metadata from YAML frontmatter
|
|
70
52
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EnsembleManager.d.ts","sourceRoot":"","sources":["../../../src/elements/ensembles/EnsembleManager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAmB,MAAM,eAAe,CAAC;AAC5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAG3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAcpE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AAErF,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AAStE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,mBAAmB,EAAE,KAAK,4BAA4B,EAAE,MAAM,oCAAoC,CAAC;AAE5G,oFAAoF;AACpF,eAAO,MAAM,2BAA2B,4BAAsB,CAAC;AAE/D
|
|
1
|
+
{"version":3,"file":"EnsembleManager.d.ts","sourceRoot":"","sources":["../../../src/elements/ensembles/EnsembleManager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAmB,MAAM,eAAe,CAAC;AAC5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAG3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAcpE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AAErF,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AAStE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,mBAAmB,EAAE,KAAK,4BAA4B,EAAE,MAAM,oCAAoC,CAAC;AAE5G,oFAAoF;AACpF,eAAO,MAAM,2BAA2B,4BAAsB,CAAC;AAE/D;;;;;;;;GAQG;AACH,qBAAa,eAAgB,SAAQ,kBAAkB,CAAC,QAAQ,CAAC;IAY7D,OAAO,CAAC,eAAe;IAXzB,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,OAAO,CAAC,oBAAoB,CAAuB;IACnD,OAAO,CAAC,mBAAmB,CAA0B;gBAGnD,gBAAgB,EAAE,gBAAgB,EAClC,eAAe,EAAE,eAAe,EAChC,qBAAqB,EAAE,qBAAqB,EAC5C,kBAAkB,EAAE,kBAAkB,EACtC,oBAAoB,EAAE,oBAAoB,EAClC,eAAe,EAAE,eAAe,EACxC,gBAAgB,CAAC,EAAE,gBAAgB,EACnC,YAAY,CAAC,EAAE,OAAO,kCAAkC,EAAE,iBAAiB,EAC3E,aAAa,CAAC,EAAE,OAAO,iCAAiC,EAAE,aAAa;cAQtD,eAAe,IAAI,MAAM;IAI5C;;;;;;;;;;OAUG;cACsB,aAAa,CAAC,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAgS5E;;;;;;OAMG;cACgB,aAAa,CAAC,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,GAAG,QAAQ;IAWxF;;;;;;;;;OASG;cACsB,gBAAgB,CAAC,OAAO,EAAE,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC;IA4E7E,OAAO,CAAC,gBAAgB;IAcxB;;OAEG;IACM,gBAAgB,IAAI,MAAM;IAInC;;;;;;;;;;;OAWG;IACY,aAAa,CAC1B,IAAI,EAAE,MAAM,EACZ,MAAM,GAAE,MAAM,GAAG,MAAM,GAAG,UAAuB,GAChD,OAAO,CAAC,QAAQ,CAAC;IA+CpB;;;;;;OAMG;IACY,aAAa,CAC1B,OAAO,EAAE,QAAQ,EACjB,MAAM,GAAE,MAAM,GAAG,MAAM,GAAG,UAAuB,GAChD,OAAO,CAAC,MAAM,CAAC;IASlB;;;;;OAKG;IACG,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,gBAAgB,CAAC,GAAG;QAAE,YAAY,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,QAAQ,CAAC;IA+HlH;;;;;;OAMG;IACM,QAAQ,CAAC,OAAO,EAAE,QAAQ,GAAG,uBAAuB;IAI7D;;OAEG;IACY,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAYvE;;OAEG;IACY,MAAM,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBtD;;OAEG;IACY,IAAI,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;IAc1C;;;;;;;;;OASG;IACG,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,QAAQ,CAAA;KAAE,CAAC;IAwC/G;;;;;;;;OAQG;IACG,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,QAAQ,CAAA;KAAE,CAAC;IAuCjH;;;;OAIG;IACG,kBAAkB,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;IAS/C;;;;OAIG;IACH,OAAO,CAAC,wBAAwB;IA2BhC;;;;OAIG;YACW,2BAA2B;CA8C1C"}
|