@dollhousemcp/mcp-server 2.0.11 → 2.0.12-rc.2
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 +33 -0
- package/dist/config/ConfigManager.d.ts +34 -0
- package/dist/config/ConfigManager.d.ts.map +1 -1
- package/dist/config/ConfigManager.js +46 -1
- package/dist/config/env.d.ts +18 -0
- package/dist/config/env.d.ts.map +1 -1
- package/dist/config/env.js +89 -2
- package/dist/di/Container.d.ts +1 -0
- package/dist/di/Container.d.ts.map +1 -1
- package/dist/di/Container.js +38 -2
- package/dist/elements/agents/AgentManager.js +2 -2
- 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/handlers/mcp-aql/GatekeeperSession.d.ts.map +1 -1
- package/dist/handlers/mcp-aql/GatekeeperSession.js +3 -2
- package/dist/handlers/mcp-aql/MCPAQLHandler.d.ts.map +1 -1
- package/dist/handlers/mcp-aql/MCPAQLHandler.js +11 -3
- package/dist/handlers/mcp-aql/OperationSchema.d.ts.map +1 -1
- package/dist/handlers/mcp-aql/OperationSchema.js +11 -6
- package/dist/handlers/mcp-aql/policies/ToolClassification.d.ts.map +1 -1
- package/dist/handlers/mcp-aql/policies/ToolClassification.js +8 -1
- package/dist/index.js +53 -3
- package/dist/security/InputNormalizer.d.ts +4 -6
- package/dist/security/InputNormalizer.d.ts.map +1 -1
- package/dist/security/InputNormalizer.js +10 -16
- package/dist/security/audit/config/suppressions.d.ts.map +1 -1
- package/dist/security/audit/config/suppressions.js +26 -1
- package/dist/security/constants.d.ts +7 -0
- package/dist/security/constants.d.ts.map +1 -1
- package/dist/security/constants.js +10 -1
- package/dist/security/contentValidator.d.ts.map +1 -1
- package/dist/security/contentValidator.js +14 -6
- package/dist/security/encryption/PatternEncryptor.d.ts.map +1 -1
- package/dist/security/encryption/PatternEncryptor.js +18 -10
- package/dist/security/securityMonitor.d.ts +1 -1
- package/dist/security/securityMonitor.d.ts.map +1 -1
- package/dist/security/securityMonitor.js +1 -1
- package/dist/security/tokenManager.d.ts +18 -2
- package/dist/security/tokenManager.d.ts.map +1 -1
- package/dist/security/tokenManager.js +47 -15
- package/dist/security/validators/unicodeValidator.d.ts +4 -5
- package/dist/security/validators/unicodeValidator.d.ts.map +1 -1
- package/dist/security/validators/unicodeValidator.js +19 -20
- package/dist/services/VerificationNotifier.d.ts.map +1 -1
- package/dist/services/VerificationNotifier.js +15 -13
- package/dist/services/validation/GenericElementValidator.js +5 -5
- package/dist/web/console/IngestRoutes.d.ts +14 -2
- package/dist/web/console/IngestRoutes.d.ts.map +1 -1
- package/dist/web/console/IngestRoutes.js +69 -5
- package/dist/web/console/LeaderElection.d.ts +37 -3
- package/dist/web/console/LeaderElection.d.ts.map +1 -1
- package/dist/web/console/LeaderElection.js +67 -7
- package/dist/web/console/LeaderForwardingSink.d.ts +19 -3
- package/dist/web/console/LeaderForwardingSink.d.ts.map +1 -1
- package/dist/web/console/LeaderForwardingSink.js +44 -9
- package/dist/web/console/PromotionManager.d.ts +29 -0
- package/dist/web/console/PromotionManager.d.ts.map +1 -0
- package/dist/web/console/PromotionManager.js +94 -0
- package/dist/web/console/SessionNames.d.ts +7 -0
- package/dist/web/console/SessionNames.d.ts.map +1 -1
- package/dist/web/console/SessionNames.js +10 -1
- package/dist/web/console/UnifiedConsole.d.ts +26 -1
- package/dist/web/console/UnifiedConsole.d.ts.map +1 -1
- package/dist/web/console/UnifiedConsole.js +143 -20
- package/dist/web/portDiscovery.d.ts +4 -3
- package/dist/web/portDiscovery.d.ts.map +1 -1
- package/dist/web/portDiscovery.js +7 -5
- package/dist/web/public/app.js +35 -18
- package/dist/web/public/consoleAuth.js +152 -0
- package/dist/web/public/index.html +243 -9
- package/dist/web/public/logs.js +1 -1
- package/dist/web/public/metrics.js +3 -3
- package/dist/web/public/permissions.js +1 -1
- package/dist/web/public/security.css +396 -0
- package/dist/web/public/security.js +393 -0
- package/dist/web/public/sessions.css +54 -4
- package/dist/web/public/sessions.js +46 -6
- package/dist/web/public/setup.css +439 -0
- package/dist/web/public/setup.js +490 -18
- package/dist/web/public/styles.css +10 -0
- package/dist/web/routes/permissionRoutes.d.ts.map +1 -1
- package/dist/web/routes/permissionRoutes.js +8 -3
- package/dist/web/routes/setupRoutes.d.ts +4 -0
- package/dist/web/routes/setupRoutes.d.ts.map +1 -1
- package/dist/web/routes/setupRoutes.js +418 -7
- package/dist/web/routes.d.ts.map +1 -1
- package/dist/web/routes.js +9 -5
- package/dist/web/server.d.ts +49 -3
- package/dist/web/server.d.ts.map +1 -1
- package/dist/web/server.js +282 -82
- package/package.json +11 -2
- package/server.json +2 -2
package/dist/config/env.d.ts
CHANGED
|
@@ -72,7 +72,15 @@ declare const envSchema: z.ZodObject<{
|
|
|
72
72
|
DOLLHOUSE_LOG_FILE_MAX_SIZE: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
73
73
|
DOLLHOUSE_LOG_MAX_DIR_SIZE_BYTES: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
74
74
|
DOLLHOUSE_LOG_MAX_FILES_PER_CATEGORY: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
75
|
+
DOLLHOUSE_PERMISSION_SERVER: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
75
76
|
DOLLHOUSE_WEB_CONSOLE: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
77
|
+
DOLLHOUSE_WEB_CONSOLE_PORT: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
78
|
+
DOLLHOUSE_WEB_AUTH_ENABLED: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
79
|
+
DOLLHOUSE_CONSOLE_TOKEN_FILE: z.ZodOptional<z.ZodString>;
|
|
80
|
+
DOLLHOUSE_CONSOLE_LEADER_LOCK_FILE: z.ZodOptional<z.ZodString>;
|
|
81
|
+
DOLLHOUSE_CONSOLE_BIND_RETRY_DELAYS: z.ZodPipe<z.ZodOptional<z.ZodString>, z.ZodTransform<number[] | undefined, string | undefined>>;
|
|
82
|
+
DOLLHOUSE_CONSOLE_MAX_FORWARD_FAILURES: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
|
|
83
|
+
DOLLHOUSE_CONSOLE_ROTATION_REQUIRE_CONFIRMATION: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
76
84
|
DOLLHOUSE_GATEKEEPER_ENABLED: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
77
85
|
DOLLHOUSE_GATEKEEPER_ELEMENT_POLICY_OVERRIDES: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
78
86
|
DOLLHOUSE_POLICY_EXPORT_ENABLED: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
@@ -96,6 +104,7 @@ declare const envSchema: z.ZodObject<{
|
|
|
96
104
|
DOLLHOUSE_DISABLE_ENCRYPTION: z.ZodDefault<z.ZodCoercedBoolean<unknown>>;
|
|
97
105
|
DOLLHOUSE_ENCRYPTION_SECRET: z.ZodOptional<z.ZodString>;
|
|
98
106
|
DOLLHOUSE_ENCRYPTION_SALT: z.ZodOptional<z.ZodString>;
|
|
107
|
+
DOLLHOUSE_TOKEN_SECRET: z.ZodOptional<z.ZodString>;
|
|
99
108
|
}, z.core.$strip>;
|
|
100
109
|
/**
|
|
101
110
|
* Validated environment variables
|
|
@@ -126,7 +135,13 @@ export declare const env: {
|
|
|
126
135
|
DOLLHOUSE_LOG_FILE_MAX_SIZE: number;
|
|
127
136
|
DOLLHOUSE_LOG_MAX_DIR_SIZE_BYTES: number;
|
|
128
137
|
DOLLHOUSE_LOG_MAX_FILES_PER_CATEGORY: number;
|
|
138
|
+
DOLLHOUSE_PERMISSION_SERVER: boolean;
|
|
129
139
|
DOLLHOUSE_WEB_CONSOLE: boolean;
|
|
140
|
+
DOLLHOUSE_WEB_CONSOLE_PORT: number;
|
|
141
|
+
DOLLHOUSE_WEB_AUTH_ENABLED: boolean;
|
|
142
|
+
DOLLHOUSE_CONSOLE_BIND_RETRY_DELAYS: number[] | undefined;
|
|
143
|
+
DOLLHOUSE_CONSOLE_MAX_FORWARD_FAILURES: number;
|
|
144
|
+
DOLLHOUSE_CONSOLE_ROTATION_REQUIRE_CONFIRMATION: boolean;
|
|
130
145
|
DOLLHOUSE_GATEKEEPER_ENABLED: boolean;
|
|
131
146
|
DOLLHOUSE_GATEKEEPER_ELEMENT_POLICY_OVERRIDES: boolean;
|
|
132
147
|
DOLLHOUSE_POLICY_EXPORT_ENABLED: boolean;
|
|
@@ -159,8 +174,11 @@ export declare const env: {
|
|
|
159
174
|
TEST_CACHE_DIR?: string | undefined;
|
|
160
175
|
TEST_CONFIG_DIR?: string | undefined;
|
|
161
176
|
MCP_AQL_MODE?: "single" | "crude" | undefined;
|
|
177
|
+
DOLLHOUSE_CONSOLE_TOKEN_FILE?: string | undefined;
|
|
178
|
+
DOLLHOUSE_CONSOLE_LEADER_LOCK_FILE?: string | undefined;
|
|
162
179
|
DOLLHOUSE_ENCRYPTION_SECRET?: string | undefined;
|
|
163
180
|
DOLLHOUSE_ENCRYPTION_SALT?: string | undefined;
|
|
181
|
+
DOLLHOUSE_TOKEN_SECRET?: string | undefined;
|
|
164
182
|
};
|
|
165
183
|
/**
|
|
166
184
|
* Environment type (inferred from schema)
|
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
|
@@ -117,10 +117,92 @@ const envSchema = z.object({
|
|
|
117
117
|
DOLLHOUSE_LOG_MAX_DIR_SIZE_BYTES: z.coerce.number().default(0),
|
|
118
118
|
DOLLHOUSE_LOG_MAX_FILES_PER_CATEGORY: z.coerce.number().default(100),
|
|
119
119
|
// ============================================================================
|
|
120
|
+
// Permission Server Configuration
|
|
121
|
+
// ============================================================================
|
|
122
|
+
/**
|
|
123
|
+
* Enable the HTTP permission evaluation server for PreToolUse hooks.
|
|
124
|
+
* When true, starts an HTTP endpoint on a dynamic port after deferred
|
|
125
|
+
* setup completes. Writes port to ~/.dollhouse/run/permission-server.port
|
|
126
|
+
* for hook script discovery. Required for autonomous agent permission
|
|
127
|
+
* management via Claude Code hooks.
|
|
128
|
+
*/
|
|
129
|
+
DOLLHOUSE_PERMISSION_SERVER: z.coerce.boolean().default(true),
|
|
120
130
|
// Web Console Configuration
|
|
121
131
|
// ============================================================================
|
|
122
|
-
/** Enable the unified web console (logs + metrics tabs
|
|
132
|
+
/** Enable the unified web console (logs + metrics tabs) */
|
|
123
133
|
DOLLHOUSE_WEB_CONSOLE: z.coerce.boolean().default(true),
|
|
134
|
+
/**
|
|
135
|
+
* Port the web console leader binds to (#1794, #1798).
|
|
136
|
+
*
|
|
137
|
+
* Default: 41715 — "AILIS" on a phone keypad, after the AI Layer
|
|
138
|
+
* Interface Specification that DollhouseMCP implements. Also "Alice"
|
|
139
|
+
* in Gaelic.
|
|
140
|
+
*
|
|
141
|
+
* Port selection criteria (verified 2026-04-06):
|
|
142
|
+
* - Not registered with IANA (no entry in the service name registry)
|
|
143
|
+
* - Not in nmap services database (never observed in the wild)
|
|
144
|
+
* - No known application, security tool, or malware associations
|
|
145
|
+
* - Below the macOS ephemeral range (49152-65535), so `bind()`
|
|
146
|
+
* does not race with kernel-allocated source ports
|
|
147
|
+
* - In the IANA user port range (1024-49151)
|
|
148
|
+
* - Not adjacent to the pre-authentication default (3939)
|
|
149
|
+
*
|
|
150
|
+
* Previous default was 5907 ("LOGS" upside down on a calculator),
|
|
151
|
+
* which conflicted with Stellar Cyber's HTTP GKE log parser.
|
|
152
|
+
*
|
|
153
|
+
* Override via env var if 41715 collides with something in your
|
|
154
|
+
* environment — every runtime reference reads from this single value.
|
|
155
|
+
*/
|
|
156
|
+
DOLLHOUSE_WEB_CONSOLE_PORT: z.coerce.number().int().min(1024).max(65535).default(41715),
|
|
157
|
+
/**
|
|
158
|
+
* Issue #1780: Enforce Bearer token authentication on the web console API.
|
|
159
|
+
* When true, all protected endpoints require a valid token from the
|
|
160
|
+
* console token file. When false (the pre-Phase-2 default), the token
|
|
161
|
+
* file is still generated but the middleware does not enforce — this
|
|
162
|
+
* lets the infrastructure land without breaking existing consumers.
|
|
163
|
+
* Will flip to default `true` in a follow-up PR once all consumers
|
|
164
|
+
* (browser, followers, bridge) have been updated to attach tokens.
|
|
165
|
+
*/
|
|
166
|
+
DOLLHOUSE_WEB_AUTH_ENABLED: z.coerce.boolean().default(false),
|
|
167
|
+
/**
|
|
168
|
+
* Issue #1780: Optional override for the console token file location.
|
|
169
|
+
* When unset, `ConsoleTokenStore` falls back to its built-in default
|
|
170
|
+
* under `~/.dollhouse/run/`. Mainly useful for tests and for enterprise
|
|
171
|
+
* deployments that mount a shared token file from a secrets volume.
|
|
172
|
+
*/
|
|
173
|
+
DOLLHOUSE_CONSOLE_TOKEN_FILE: z.string().optional(),
|
|
174
|
+
/**
|
|
175
|
+
* Optional override for the console leader lock file location (#1794).
|
|
176
|
+
* When unset, `LeaderElection` falls back to its built-in default under
|
|
177
|
+
* `~/.dollhouse/run/`. Primarily useful for tests that need isolation
|
|
178
|
+
* between runs and for deployments that split runtime state across
|
|
179
|
+
* multiple installations on the same machine.
|
|
180
|
+
*/
|
|
181
|
+
DOLLHOUSE_CONSOLE_LEADER_LOCK_FILE: z.string().optional(),
|
|
182
|
+
// Leader/Follower Recovery (#1850)
|
|
183
|
+
// ============================================================================
|
|
184
|
+
/**
|
|
185
|
+
* Issue #1850: Retry delays (in ms) when the leader fails to bind the console
|
|
186
|
+
* port due to EADDRINUSE. Each value is a successive backoff delay.
|
|
187
|
+
* Default: 1s, 2s, 4s (7s total). Increase for slow or remote environments.
|
|
188
|
+
*/
|
|
189
|
+
DOLLHOUSE_CONSOLE_BIND_RETRY_DELAYS: z.string()
|
|
190
|
+
.optional()
|
|
191
|
+
.transform(v => v ? v.split(',').map(Number).filter(n => !Number.isNaN(n) && n > 0) : undefined),
|
|
192
|
+
/**
|
|
193
|
+
* Issue #1850: Number of consecutive forwarding failures before a follower
|
|
194
|
+
* declares the leader dead and attempts self-promotion. Higher values reduce
|
|
195
|
+
* false positives in high-latency environments but delay recovery.
|
|
196
|
+
* Default: 10.
|
|
197
|
+
*/
|
|
198
|
+
DOLLHOUSE_CONSOLE_MAX_FORWARD_FAILURES: z.coerce.number().int().min(1).max(100).default(10),
|
|
199
|
+
/**
|
|
200
|
+
* Issue #1780: Phase 2 — require a confirmation code (OS dialog or TOTP)
|
|
201
|
+
* for privileged actions like token rotation. Default is true for safety;
|
|
202
|
+
* set to false for headless CI and scripted deployments that need to rotate
|
|
203
|
+
* without human interaction.
|
|
204
|
+
*/
|
|
205
|
+
DOLLHOUSE_CONSOLE_ROTATION_REQUIRE_CONFIRMATION: z.coerce.boolean().default(true),
|
|
124
206
|
// ============================================================================
|
|
125
207
|
// Security Configuration
|
|
126
208
|
// ============================================================================
|
|
@@ -183,6 +265,11 @@ const envSchema = z.object({
|
|
|
183
265
|
DOLLHOUSE_DISABLE_ENCRYPTION: z.coerce.boolean().default(false),
|
|
184
266
|
DOLLHOUSE_ENCRYPTION_SECRET: z.string().optional(),
|
|
185
267
|
DOLLHOUSE_ENCRYPTION_SALT: z.string().optional(),
|
|
268
|
+
// Token encryption secret (SEC-01, #1735)
|
|
269
|
+
// When set, replaces the predictable machine-derived passphrase for token encryption.
|
|
270
|
+
// Strongly recommended for any shared or multi-user environment.
|
|
271
|
+
// Minimum 32 characters enforced to prevent weak passphrases.
|
|
272
|
+
DOLLHOUSE_TOKEN_SECRET: z.string().min(32).optional(),
|
|
186
273
|
});
|
|
187
274
|
/**
|
|
188
275
|
* Validated environment variables
|
|
@@ -207,4 +294,4 @@ if (isDevelopment || isTest) {
|
|
|
207
294
|
HAS_GITHUB_TEST_TOKEN: !!env.GITHUB_TEST_TOKEN,
|
|
208
295
|
});
|
|
209
296
|
}
|
|
210
|
-
//# 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  // 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"]}
|
|
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"]}
|
package/dist/di/Container.d.ts
CHANGED
|
@@ -90,6 +90,7 @@ export declare class DollhouseContainer {
|
|
|
90
90
|
/** Wire SSE broadcast sinks for the web console */
|
|
91
91
|
private wireSSEBroadcasts;
|
|
92
92
|
private deferredWebConsole;
|
|
93
|
+
private deferredPermissionServer;
|
|
93
94
|
private deferredDangerZoneInit;
|
|
94
95
|
private deferredPatternEncryption;
|
|
95
96
|
private deferredBackgroundValidator;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Container.d.ts","sourceRoot":"","sources":["../../src/di/Container.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,MAAM,EAAE,MAAM,2CAA2C,CAAC;AAkBnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAwB,MAAM,sCAAsC,CAAC;AAa3F,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AAEnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAsF3D,MAAM,WAAW,aAAa;IAC5B,cAAc,EAAE,cAAc,CAAC;IAC/B,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,gBAAgB,EAAE,gBAAgB,CAAC;IACnC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,oBAAoB,EAAE,oBAAoB,CAAC;IAC3C,eAAe,EAAE,eAAe,CAAC;IACjC,aAAa,EAAE,aAAa,CAAC;IAC7B,WAAW,EAAE,WAAW,CAAC;IACzB,YAAY,EAAE,YAAY,CAAC;IAC3B,oBAAoB,EAAE,oBAAoB,CAAC;IAC3C,aAAa,EAAE,aAAa,CAAC;CAC9B;AAiBD,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAoC;IACpD,OAAO,CAAC,WAAW,CAAuB;IAC1C,qEAAqE;IAC9D,qBAAqB,UAAS;;IAarC;;;;;;;;;;;OAWG;IACI,QAAQ,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,EAAE,OAAO,GAAE;QAAE,SAAS,CAAC,EAAE,OAAO,CAAA;KAAwB,GAAG,IAAI;IAgBhH;;;;;;;;;;;;;OAaG;IACI,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC;IAgClC,OAAO,CAAC,gBAAgB;
|
|
1
|
+
{"version":3,"file":"Container.d.ts","sourceRoot":"","sources":["../../src/di/Container.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,MAAM,EAAE,MAAM,2CAA2C,CAAC;AAkBnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAwB,MAAM,sCAAsC,CAAC;AAa3F,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AAEnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAsF3D,MAAM,WAAW,aAAa;IAC5B,cAAc,EAAE,cAAc,CAAC;IAC/B,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,gBAAgB,EAAE,gBAAgB,CAAC;IACnC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,oBAAoB,EAAE,oBAAoB,CAAC;IAC3C,eAAe,EAAE,eAAe,CAAC;IACjC,aAAa,EAAE,aAAa,CAAC;IAC7B,WAAW,EAAE,WAAW,CAAC;IACzB,YAAY,EAAE,YAAY,CAAC;IAC3B,oBAAoB,EAAE,oBAAoB,CAAC;IAC3C,aAAa,EAAE,aAAa,CAAC;CAC9B;AAiBD,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAoC;IACpD,OAAO,CAAC,WAAW,CAAuB;IAC1C,qEAAqE;IAC9D,qBAAqB,UAAS;;IAarC;;;;;;;;;;;OAWG;IACI,QAAQ,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,EAAE,OAAO,GAAE;QAAE,SAAS,CAAC,EAAE,OAAO,CAAA;KAAwB,GAAG,IAAI;IAgBhH;;;;;;;;;;;;;OAaG;IACI,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC;IAgClC,OAAO,CAAC,gBAAgB;IA+djB,cAAc,IAAI,MAAM,GAAG,IAAI;IAItC;;;;;;;OAOG;IACU,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAgG9C;;;;;;OAMG;IACU,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;YA+BrC,sBAAsB;YA8BtB,yBAAyB;YAezB,oBAAoB;YASpB,gBAAgB;YAYhB,yBAAyB;IAavC,sEAAsE;IACtE,OAAO,CAAC,UAAU;IAIlB,mDAAmD;IACnD,OAAO,CAAC,iBAAiB;YAgBX,kBAAkB;YAoClB,wBAAwB;YAiCxB,sBAAsB;YAWtB,yBAAyB;YAYzB,2BAA2B;IAYzC;;;;;;;OAOG;YACW,kBAAkB;IAoHhC;;;;OAIG;IACU,iBAAiB,IAAI,OAAO,CAAC,aAAa,CAAC;IAqMxD;;;OAGG;IACU,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC;IAuDnE;;;;;;;;;;OAUG;IACH,OAAO,CAAC,iBAAiB;IA2EzB;;;OAGG;IACH,OAAO,CAAC,qBAAqB;IAkE7B,OAAO,CAAC,0BAA0B;IAqBrB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAkBrC,OAAO,CAAC,qBAAqB;IAc7B,OAAO,CAAC,sBAAsB;YAkBhB,yBAAyB;CAkBxC"}
|