@dollhousemcp/mcp-server 2.0.12-rc.9 → 2.0.13
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 +66 -0
- package/README.md +4 -4
- package/README.md.backup +5 -5
- package/README.npm.md +4 -4
- package/dist/di/Container.d.ts +14 -0
- package/dist/di/Container.d.ts.map +1 -1
- package/dist/di/Container.js +43 -26
- package/dist/elements/agents/AgentManager.d.ts +11 -4
- package/dist/elements/agents/AgentManager.d.ts.map +1 -1
- package/dist/elements/agents/AgentManager.js +38 -11
- package/dist/elements/base/BaseElementManager.d.ts +10 -0
- package/dist/elements/base/BaseElementManager.d.ts.map +1 -1
- package/dist/elements/base/BaseElementManager.js +26 -1
- package/dist/elements/ensembles/EnsembleManager.d.ts +1 -0
- package/dist/elements/ensembles/EnsembleManager.d.ts.map +1 -1
- package/dist/elements/ensembles/EnsembleManager.js +13 -2
- package/dist/elements/templates/Template.d.ts +33 -1
- package/dist/elements/templates/Template.d.ts.map +1 -1
- package/dist/elements/templates/Template.js +74 -15
- package/dist/elements/templates/TemplateManager.d.ts.map +1 -1
- package/dist/elements/templates/TemplateManager.js +8 -1
- 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/element-crud/createElement.js +2 -2
- package/dist/handlers/mcp-aql/SchemaDispatcher.d.ts.map +1 -1
- package/dist/handlers/mcp-aql/SchemaDispatcher.js +8 -1
- package/dist/handlers/strategies/EnsembleActivationStrategy.d.ts +3 -0
- package/dist/handlers/strategies/EnsembleActivationStrategy.d.ts.map +1 -1
- package/dist/handlers/strategies/EnsembleActivationStrategy.js +48 -9
- package/dist/index.js +19 -13
- package/dist/portfolio/DefaultElementProvider.d.ts +8 -0
- package/dist/portfolio/DefaultElementProvider.d.ts.map +1 -1
- package/dist/portfolio/DefaultElementProvider.js +43 -1
- package/dist/security/contentValidator.d.ts +15 -0
- package/dist/security/contentValidator.d.ts.map +1 -1
- package/dist/security/contentValidator.js +40 -2
- package/dist/utils/TemplateRenderer.d.ts +9 -0
- package/dist/utils/TemplateRenderer.d.ts.map +1 -1
- package/dist/utils/TemplateRenderer.js +21 -1
- package/dist/web/console/IngestRoutes.d.ts.map +1 -1
- package/dist/web/console/IngestRoutes.js +193 -59
- package/dist/web/console/SessionNames.d.ts +18 -5
- package/dist/web/console/SessionNames.d.ts.map +1 -1
- package/dist/web/console/SessionNames.js +63 -8
- package/dist/web/console/StaleProcessRecovery.d.ts.map +1 -1
- package/dist/web/console/StaleProcessRecovery.js +5 -4
- package/dist/web/console/UnifiedConsole.js +3 -3
- package/dist/web/console/consoleToken.js +3 -3
- package/dist/web/portDiscovery.d.ts +1 -1
- package/dist/web/portDiscovery.d.ts.map +1 -1
- package/dist/web/portDiscovery.js +2 -2
- package/dist/web/public/app.js +65 -11
- package/dist/web/public/index.html +2 -0
- package/dist/web/public/logs.js +24 -2
- package/dist/web/public/metrics.js +22 -4
- package/dist/web/public/sessions.js +55 -8
- package/dist/web/public/setup.js +11 -2
- package/dist/web/public/styles.css +12 -0
- package/dist/web/routes/permissionRoutes.js +2 -2
- package/dist/web/routes/setupRoutes.d.ts +67 -1
- package/dist/web/routes/setupRoutes.d.ts.map +1 -1
- package/dist/web/routes/setupRoutes.js +298 -6
- package/dist/web/routes.d.ts.map +1 -1
- package/dist/web/routes.js +4 -2
- package/dist/web/server.d.ts.map +1 -1
- package/dist/web/server.js +14 -5
- package/package.json +5 -3
- package/server.json +2 -2
|
@@ -28,7 +28,7 @@ export class Template extends BaseElement {
|
|
|
28
28
|
// SECURITY FIX #4: Memory management constants
|
|
29
29
|
// Prevents unbounded template size and variable count that could exhaust memory
|
|
30
30
|
MAX_TEMPLATE_SIZE = 100 * 1024; // 100KB max template size
|
|
31
|
-
MAX_VARIABLE_COUNT = 100; // Max variables per template
|
|
31
|
+
static MAX_VARIABLE_COUNT = 100; // Max variables per template
|
|
32
32
|
MAX_INCLUDE_DEPTH = 5; // Prevent infinite include loops
|
|
33
33
|
MAX_STRING_LENGTH = 10000; // Max length for string variables
|
|
34
34
|
constructor(metadata, content = '', metadataService) {
|
|
@@ -74,8 +74,8 @@ export class Template extends BaseElement {
|
|
|
74
74
|
};
|
|
75
75
|
// SECURITY FIX #3 & #4: Validate variables
|
|
76
76
|
if (this.metadata.variables) {
|
|
77
|
-
if (this.metadata.variables.length >
|
|
78
|
-
throw ErrorHandler.createError(`Variable count ${this.metadata.variables.length} exceeds maximum ${
|
|
77
|
+
if (this.metadata.variables.length > Template.MAX_VARIABLE_COUNT) {
|
|
78
|
+
throw ErrorHandler.createError(`Variable count ${this.metadata.variables.length} exceeds maximum ${Template.MAX_VARIABLE_COUNT}`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.TOO_MANY_VARIABLES);
|
|
79
79
|
}
|
|
80
80
|
this.metadata.variables = this.metadata.variables.map(variable => ({
|
|
81
81
|
...variable,
|
|
@@ -174,6 +174,65 @@ export class Template extends BaseElement {
|
|
|
174
174
|
}
|
|
175
175
|
return this.parsedSections;
|
|
176
176
|
}
|
|
177
|
+
/**
|
|
178
|
+
* Scan `content` for `{{placeholder}}` patterns and return a merged variable
|
|
179
|
+
* list. Existing entries are preserved unchanged (user-set descriptions,
|
|
180
|
+
* types, required flags, etc.); new placeholders are added with defaults:
|
|
181
|
+
* `type: 'string'`, `required: false`. (#1896)
|
|
182
|
+
*
|
|
183
|
+
* Respects section mode — only the `<template>` section is scanned,
|
|
184
|
+
* matching the substitution engine's scope.
|
|
185
|
+
*
|
|
186
|
+
* **Performance:** Single-pass regex scan — O(n) in content length.
|
|
187
|
+
* Called by `TemplateManager.save()` on every create/edit, so content
|
|
188
|
+
* is already validated and size-bounded (≤ 100 KB) before reaching here.
|
|
189
|
+
*
|
|
190
|
+
* @param content - Raw template content (may include section tags)
|
|
191
|
+
* @param existingVariables - Already-declared variables; never overwritten
|
|
192
|
+
* @returns Merged variable list: existing entries first, new entries appended
|
|
193
|
+
*
|
|
194
|
+
* @example
|
|
195
|
+
* // New template — empty schema gets fully populated
|
|
196
|
+
* deriveVariablesFromContent('Hello {{name}}, score: {{score}}')
|
|
197
|
+
* // → [{ name: 'name', type: 'string', required: false },
|
|
198
|
+
* // { name: 'score', type: 'string', required: false }]
|
|
199
|
+
*
|
|
200
|
+
* @example
|
|
201
|
+
* // Existing entry preserved; only the missing placeholder is added
|
|
202
|
+
* deriveVariablesFromContent('{{name}} earns {{points}}', [
|
|
203
|
+
* { name: 'name', type: 'string', required: true, description: 'Display name' }
|
|
204
|
+
* ])
|
|
205
|
+
* // → [{ name: 'name', type: 'string', required: true, description: 'Display name' },
|
|
206
|
+
* // { name: 'points', type: 'string', required: false }]
|
|
207
|
+
*/
|
|
208
|
+
static deriveVariablesFromContent(content, existingVariables = []) {
|
|
209
|
+
const { isSectionMode, templateSection } = Template.parseSections(content);
|
|
210
|
+
const scanContent = isSectionMode ? templateSection : content;
|
|
211
|
+
const pattern = /\{\{\s*([a-zA-Z_]\w*(?:\.[a-zA-Z_]\w*)*)\s*\}\}/g;
|
|
212
|
+
const seen = new Set();
|
|
213
|
+
let match;
|
|
214
|
+
while ((match = pattern.exec(scanContent)) !== null) {
|
|
215
|
+
seen.add(match[1]);
|
|
216
|
+
}
|
|
217
|
+
const existingNames = new Set(existingVariables.map(v => v.name));
|
|
218
|
+
const result = [...existingVariables];
|
|
219
|
+
for (const name of seen) {
|
|
220
|
+
if (!existingNames.has(name)) {
|
|
221
|
+
result.push({ name, type: 'string', required: false });
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
// Enforce the same MAX_VARIABLE_COUNT limit as the constructor.
|
|
225
|
+
// When auto-derive would exceed the cap, truncate and surface a structured
|
|
226
|
+
// error so the calling LLM knows to split the content across templates.
|
|
227
|
+
if (result.length > Template.MAX_VARIABLE_COUNT) {
|
|
228
|
+
const overflow = result.splice(Template.MAX_VARIABLE_COUNT);
|
|
229
|
+
const overflowNames = overflow.map(v => v.name).join(', ');
|
|
230
|
+
throw ErrorHandler.createError(`Auto-derive reached the ${Template.MAX_VARIABLE_COUNT}-variable limit. ` +
|
|
231
|
+
`${overflow.length} placeholder(s) were not registered: ${overflowNames}. ` +
|
|
232
|
+
`Split this content across multiple templates and combine them in an ensemble.`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.TOO_MANY_VARIABLES);
|
|
233
|
+
}
|
|
234
|
+
return result;
|
|
235
|
+
}
|
|
177
236
|
compile() {
|
|
178
237
|
if (this.compiledTemplate) {
|
|
179
238
|
return this.compiledTemplate;
|
|
@@ -577,13 +636,13 @@ export class Template extends BaseElement {
|
|
|
577
636
|
*/
|
|
578
637
|
validate() {
|
|
579
638
|
const result = super.validate();
|
|
580
|
-
//
|
|
581
|
-
//
|
|
582
|
-
result.errors ??= [];
|
|
583
|
-
result.warnings ??= [];
|
|
639
|
+
// Capture arrays as locals so TypeScript knows they're always defined
|
|
640
|
+
// and call sites never need ! or inline ??= expressions (S1121, S6606).
|
|
641
|
+
const errors = result.errors ??= [];
|
|
642
|
+
const warnings = result.warnings ??= [];
|
|
584
643
|
// Content validation
|
|
585
644
|
if (!this.content || this.content.trim().length === 0) {
|
|
586
|
-
|
|
645
|
+
errors.push({
|
|
587
646
|
field: 'content',
|
|
588
647
|
message: 'Template content cannot be empty',
|
|
589
648
|
code: 'EMPTY_CONTENT'
|
|
@@ -598,7 +657,7 @@ export class Template extends BaseElement {
|
|
|
598
657
|
const openTokens = (tokenCheckContent.match(/\{\{/g) || []).length;
|
|
599
658
|
const closeTokens = (tokenCheckContent.match(/\}\}/g) || []).length;
|
|
600
659
|
if (openTokens !== closeTokens) {
|
|
601
|
-
|
|
660
|
+
errors.push({
|
|
602
661
|
field: 'content',
|
|
603
662
|
message: 'Template has unmatched variable tokens',
|
|
604
663
|
code: 'UNMATCHED_TOKENS'
|
|
@@ -607,7 +666,7 @@ export class Template extends BaseElement {
|
|
|
607
666
|
// Validate output format
|
|
608
667
|
const validFormats = ['markdown', 'html', 'json', 'yaml', 'text', 'xml'];
|
|
609
668
|
if (this.metadata.output_format && !validFormats.includes(this.metadata.output_format)) {
|
|
610
|
-
|
|
669
|
+
warnings.push({
|
|
611
670
|
field: 'output_format',
|
|
612
671
|
message: `Unknown output format '${this.metadata.output_format}'. Common formats: ${validFormats.join(', ')}`,
|
|
613
672
|
severity: 'low'
|
|
@@ -619,7 +678,7 @@ export class Template extends BaseElement {
|
|
|
619
678
|
this.metadata.variables.forEach((variable, index) => {
|
|
620
679
|
// Check for duplicate names
|
|
621
680
|
if (variableNames.has(variable.name)) {
|
|
622
|
-
|
|
681
|
+
errors.push({
|
|
623
682
|
field: `variables[${index}].name`,
|
|
624
683
|
message: `Duplicate variable name '${variable.name}'`,
|
|
625
684
|
code: 'DUPLICATE_VARIABLE'
|
|
@@ -632,7 +691,7 @@ export class Template extends BaseElement {
|
|
|
632
691
|
new RegExp(variable.validation);
|
|
633
692
|
}
|
|
634
693
|
catch (e) {
|
|
635
|
-
|
|
694
|
+
errors.push({
|
|
636
695
|
field: `variables[${index}].validation`,
|
|
637
696
|
message: `Invalid regex pattern: ${e}`,
|
|
638
697
|
code: 'INVALID_REGEX'
|
|
@@ -644,10 +703,10 @@ export class Template extends BaseElement {
|
|
|
644
703
|
// Check if all tokens have corresponding variable definitions
|
|
645
704
|
const compiled = this.compile();
|
|
646
705
|
const definedVars = new Set(this.metadata.variables?.map(v => v.name) || []);
|
|
647
|
-
const usedVars = new Set(compiled.tokens.map(t => t.variable
|
|
706
|
+
const usedVars = new Set(compiled.tokens.map(t => t.variable));
|
|
648
707
|
usedVars.forEach(varName => {
|
|
649
708
|
if (!definedVars.has(varName)) {
|
|
650
|
-
|
|
709
|
+
warnings.push({
|
|
651
710
|
field: 'variables',
|
|
652
711
|
message: `Template uses undefined variable '${varName}'`,
|
|
653
712
|
severity: 'medium'
|
|
@@ -785,4 +844,4 @@ export class Template extends BaseElement {
|
|
|
785
844
|
await super.deactivate?.();
|
|
786
845
|
}
|
|
787
846
|
}
|
|
788
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Template.js","sourceRoot":"","sources":["../../../src/elements/templates/Template.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Template element class implementing IElement interface.\n * Represents reusable content structures with variable substitution and dynamic content.\n * \n * SECURITY FIXES IMPLEMENTED (Following PR #319 patterns):\n * 1. CRITICAL: Template injection prevention - no eval() or Function() constructor\n * 2. CRITICAL: Path traversal prevention for template includes\n * 3. HIGH: Input validation and sanitization for all template variables\n * 4. MEDIUM: Memory limits to prevent resource exhaustion (100KB templates, 100 variables)\n * 5. MEDIUM: Audit logging for all security operations via SecurityMonitor\n * 6. MEDIUM: Unicode normalization to prevent homograph attacks\n */\n\nimport { BaseElement } from '../BaseElement.js';\nimport { IElement, IElementMetadata, ElementValidationResult } from '../../types/elements/index.js';\nimport { ElementType } from '../../portfolio/types.js';\nimport { logger } from '../../utils/logger.js';\nimport { ErrorHandler, ErrorCategory } from '../../utils/ErrorHandler.js';\nimport { ValidationErrorCodes } from '../../utils/errorCodes.js';\nimport { sanitizeInput } from '../../security/InputValidator.js';\nimport { UnicodeValidator } from '../../security/validators/unicodeValidator.js';\nimport { ContentValidator } from '../../security/contentValidator.js';\nimport { SecurityMonitor } from '../../security/securityMonitor.js';\nimport * as path from 'path';\nimport { MetadataService } from '../../services/MetadataService.js';\n\n// Extend IElementMetadata with template-specific fields\nexport interface TemplateMetadata extends IElementMetadata {\n  type?: ElementType.TEMPLATE;             // Template type constraint for type safety\n  category?: string;              // Template category (documents, emails, code, etc.)\n  output_format?: string;         // Output format (markdown, html, json, yaml, etc.)\n  variables?: TemplateVariable[]; // Variable definitions\n  includes?: string[];            // Other templates to include\n  tags?: string[];               // Searchable tags\n  usage_count?: number;          // Track popularity\n  last_used?: string;            // ISO date string\n  examples?: TemplateExample[];   // Usage examples\n\n  /**\n   * Action verbs that trigger this template (e.g., \"create\", \"generate\", \"draft\")\n   * Used by Enhanced Capability Index for intelligent template suggestions\n   * @since v1.9.10\n   */\n  triggers?: string[];\n}\n\nexport interface TemplateVariable {\n  name: string;                   // Variable name (e.g., \"project_name\")\n  type: 'string' | 'number' | 'boolean' | 'date' | 'array' | 'object';\n  description?: string;           // Help text for the variable\n  required?: boolean;             // Is this variable required?\n  default?: unknown;              // Default value if not provided (type-safe)\n  validation?: string;            // Regex pattern for validation (string type only)\n  options?: string[];             // For enum-like strings\n  format?: string;                // Date format string (date type only)\n}\n\nexport interface TemplateExample {\n  title: string;\n  description?: string;\n  variables: Record<string, unknown>;\n  output?: string;\n}\n\n/** Parsed result of a section-format template (issue #705). */\nexport interface TemplateSections {\n  /** True when the content contains at least one bare section tag. */\n  isSectionMode: boolean;\n  /** Content of the <template> block — the only section that receives variable substitution. */\n  templateSection: string;\n  /** Raw content of the <style> block — passed through without variable substitution. */\n  styleSection: string;\n  /** Raw content of the <script> block — passed through without variable substitution. */\n  scriptSection: string;\n}\n\nexport class Template extends BaseElement implements IElement {\n  public declare metadata: TemplateMetadata;\n  // instructions and content inherited from BaseElement (v2.0 dual-field architecture)\n  private compiledTemplate?: CompiledTemplate;\n  // Issue #705: Cache parsed sections to avoid re-running regex on every render/validate\n  private parsedSections?: TemplateSections;\n  \n  // SECURITY FIX #4: Memory management constants\n  // Prevents unbounded template size and variable count that could exhaust memory\n  private readonly MAX_TEMPLATE_SIZE = 100 * 1024; // 100KB max template size\n  private readonly MAX_VARIABLE_COUNT = 100;       // Max variables per template\n  private readonly MAX_INCLUDE_DEPTH = 5;          // Prevent infinite include loops\n  private readonly MAX_STRING_LENGTH = 10000;      // Max length for string variables\n\n  constructor(metadata: Partial<TemplateMetadata>, content: string = '', metadataService: MetadataService) {\n    // SECURITY FIX #3 & #6: Validate and sanitize ALL metadata fields\n    // Unicode normalization prevents homograph attacks\n    // Input sanitization prevents XSS and injection attacks\n    const sanitizedMetadata = {\n      ...metadata,\n      name: metadata.name ? sanitizeInput(UnicodeValidator.normalize(metadata.name).normalizedContent, 100) : undefined,\n      description: metadata.description ? sanitizeInput(UnicodeValidator.normalize(metadata.description).normalizedContent, 500) : undefined,\n      category: metadata.category ? sanitizeInput(UnicodeValidator.normalize(metadata.category).normalizedContent, 50) : undefined,\n      output_format: metadata.output_format ? sanitizeInput(metadata.output_format, 20) : undefined\n    };\n\n    super(ElementType.TEMPLATE, sanitizedMetadata, metadataService);\n    \n    // SECURITY FIX #4: Enforce template size limit\n    if (content.length > this.MAX_TEMPLATE_SIZE) {\n      SecurityMonitor.logSecurityEvent({\n        type: 'CONTENT_SIZE_EXCEEDED',\n        severity: 'HIGH',\n        source: 'Template.constructor',\n        details: `Template size ${content.length} exceeds maximum ${this.MAX_TEMPLATE_SIZE}`\n      });\n      throw ErrorHandler.createError(`Template content exceeds maximum size of ${this.MAX_TEMPLATE_SIZE} bytes`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.TEMPLATE_TOO_LARGE);\n    }\n    \n    // SECURITY FIX #3: Sanitize template content\n    // ContentValidator with contentContext: 'template' allows code patterns (eval, exec, etc.)\n    // while still catching prompt injection, credentials, and path traversal.\n    const contentValidation = ContentValidator.validateAndSanitize(content, {\n      maxLength: this.MAX_TEMPLATE_SIZE,\n      contentContext: 'template',\n    });\n    this.content = contentValidation.sanitizedContent || UnicodeValidator.normalize(content).normalizedContent;\n    \n    // Ensure template-specific metadata\n    this.metadata = {\n      ...this.metadata,\n      category: sanitizedMetadata.category || 'general',\n      output_format: sanitizedMetadata.output_format || 'markdown',\n      variables: metadata.variables || [],\n      includes: metadata.includes || [],\n      tags: metadata.tags || [],\n      usage_count: metadata.usage_count || 0,\n      examples: metadata.examples || []\n    };\n\n    // SECURITY FIX #3 & #4: Validate variables\n    if (this.metadata.variables) {\n      if (this.metadata.variables.length > this.MAX_VARIABLE_COUNT) {\n        throw ErrorHandler.createError(`Variable count ${this.metadata.variables.length} exceeds maximum ${this.MAX_VARIABLE_COUNT}`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.TOO_MANY_VARIABLES);\n      }\n      \n      this.metadata.variables = this.metadata.variables.map(variable => ({\n        ...variable,\n        name: sanitizeInput(UnicodeValidator.normalize(variable.name).normalizedContent, 50),\n        description: variable.description ? sanitizeInput(UnicodeValidator.normalize(variable.description).normalizedContent, 200) : undefined,\n        validation: variable.validation ? sanitizeInput(variable.validation, 200) : undefined\n      }));\n    }\n\n    // SECURITY FIX #2: Validate include paths\n    if (this.metadata.includes) {\n      this.metadata.includes = this.metadata.includes.map(includePath => {\n        const sanitizedPath = sanitizeInput(includePath, 200);\n        // Prevent path traversal attacks\n        if (!this.isValidIncludePath(sanitizedPath)) {\n          SecurityMonitor.logSecurityEvent({\n            type: 'PATH_TRAVERSAL_ATTEMPT',\n            severity: 'CRITICAL',\n            source: 'Template.constructor',\n            details: `Invalid include path: ${sanitizedPath}`\n          });\n          throw ErrorHandler.createError(`Invalid include path: ${sanitizedPath}`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_INCLUDE_PATH);\n        }\n        return sanitizedPath;\n      });\n    }\n  }\n\n  /**\n   * Validate include paths to prevent directory traversal\n   * SECURITY FIX #2: Prevents accessing files outside template directory\n   */\n  private isValidIncludePath(includePath: string): boolean {\n    // Normalize the path\n    const normalized = path.normalize(includePath);\n    \n    // Check for path traversal patterns\n    if (normalized.includes('..') || normalized.includes('~') || path.isAbsolute(normalized)) {\n      return false;\n    }\n    \n    // Only allow alphanumeric, dash, underscore, forward slash, backslash (for Windows), and .md extension\n    // Note: We test against the original path to preserve cross-platform compatibility\n    // FIX: Remove unnecessary escape for / (SonarCloud S6535)\n    const validPathPattern = /^[a-zA-Z0-9\\-_/\\\\]+\\.md$/;\n    return validPathPattern.test(includePath);\n  }\n\n  /**\n   * Compile the template for efficient rendering\n   * SECURITY FIX #1: Safe template compilation without eval() or Function()\n   * Uses regex-based token replacement instead of dynamic code execution\n   */\n  /**\n   * Parse section-mode content into named sections.\n   *\n   * Section mode is active when the content contains any <template>, <style>, or\n   * <script> block. In section mode only the <template> section is processed by the\n   * variable substitution engine; <style> and <script> are raw passthrough so that\n   * CSS/JS `}}` characters never trigger unmatched-token errors.\n   *\n   * @see Issue #705 — structured section support for page templates\n   */\n  static parseSections(content: string): TemplateSections {\n    // Matches bare section tags: <template>, <style>, <script> (no attributes).\n    // Tags with attributes (e.g. <template id=\"x\">) are treated as plain HTML,\n    // not section markers — this is intentional for forward compatibility.\n    const pattern = /<(template|style|script)>([\\s\\S]*?)<\\/\\1>/gi;\n    const sections: Record<string, string> = {};\n    let found = false;\n    let match;\n\n    while ((match = pattern.exec(content)) !== null) {\n      found = true;\n      sections[match[1].toLowerCase()] = match[2];\n    }\n\n    // Issue #705 forward-compat: warn when a bare <template> tag appears inside\n    // the <template> section — nested section markers aren't supported yet and\n    // the lazy regex would silently produce incorrect results.\n    const templateSection = sections['template'] ?? '';\n    if (found && templateSection && /<template>/i.test(templateSection)) {\n      logger.warn(\n        'Template section contains a nested bare <template> tag. ' +\n        'Nested section markers are not supported — only the outermost ' +\n        '<template>...</template> block is rendered. ' +\n        'Use <template id=\"...\"> (with an attribute) for inner HTML template elements.'\n      );\n    }\n\n    return {\n      isSectionMode: found,\n      templateSection,\n      styleSection: sections['style'] ?? '',\n      scriptSection: sections['script'] ?? '',\n    };\n  }\n\n  /**\n   * Return the parsed sections for this template's content.\n   * Result is cached per-instance and cleared whenever content changes.\n   * Used by TemplateRenderer to serve section-specific render results.\n   */\n  getSections(): TemplateSections {\n    if (!this.parsedSections) {\n      this.parsedSections = Template.parseSections(this.content);\n    }\n    return this.parsedSections;\n  }\n\n  private compile(): CompiledTemplate {\n    if (this.compiledTemplate) {\n      return this.compiledTemplate;\n    }\n\n    // Issue #705: In section mode, only compile the <template> section.\n    // Tokens in <style> and <script> are never substituted.\n    // getSections() returns the cached result — no repeated regex execution.\n    const { isSectionMode, templateSection } = this.getSections();\n    const compileContent = isSectionMode ? templateSection : this.content;\n\n    // Extract all variable tokens from the template\n    // FIX: Use \\w shorthand instead of [a-zA-Z0-9_] (SonarCloud S6353)\n    const variablePattern = /\\{\\{\\s*([a-zA-Z_]\\w*(?:\\.[a-zA-Z_]\\w*)*)\\s*\\}\\}/g;\n    const tokens: TemplateToken[] = [];\n    let match;\n\n    while ((match = variablePattern.exec(compileContent)) !== null) {\n      tokens.push({\n        token: match[0],\n        variable: match[1],\n        position: match.index\n      });\n    }\n\n    this.compiledTemplate = {\n      content: compileContent,\n      tokens,\n      variables: this.metadata.variables || []\n    };\n\n    return this.compiledTemplate;\n  }\n\n  /**\n   * Render the template with provided variables\n   * SECURITY FIX #1: Safe rendering without code execution\n   * SECURITY FIX #3: All variables are validated and sanitized\n   * TYPE SAFETY: Strong typing for variables with runtime validation\n   */\n  async render<T extends Record<string, unknown>>(\n    variables: T = {} as T, \n    includeDepth: number = 0\n  ): Promise<string> {\n    // SECURITY FIX #4: Prevent infinite include loops\n    if (includeDepth > this.MAX_INCLUDE_DEPTH) {\n      SecurityMonitor.logSecurityEvent({\n        type: 'INCLUDE_DEPTH_EXCEEDED',\n        severity: 'HIGH',\n        source: 'Template.render',\n        details: `Include depth ${includeDepth} exceeds maximum ${this.MAX_INCLUDE_DEPTH}`\n      });\n      throw ErrorHandler.createError('Maximum template include depth exceeded', ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.MAX_INCLUDE_DEPTH);\n    }\n\n    // Compile the template\n    const compiled = this.compile();\n    \n    // Validate and sanitize all provided variables\n    const sanitizedVariables = await this.validateAndSanitizeVariables(variables);\n    \n    // Start with the template content\n    let rendered = compiled.content;\n    \n    // Replace tokens in reverse order to maintain positions\n    const sortedTokens = [...compiled.tokens].sort((a, b) => b.position - a.position);\n    \n    for (const token of sortedTokens) {\n      const value = this.resolveVariable(token.variable, sanitizedVariables);\n      const stringValue = this.formatValue(value);\n      \n      // Replace the token with the sanitized value\n      rendered = rendered.substring(0, token.position) + \n                 stringValue + \n                 rendered.substring(token.position + token.token.length);\n    }\n    \n    // Process includes if any\n    if (this.metadata.includes && this.metadata.includes.length > 0) {\n      rendered = await this.processIncludes(rendered, sanitizedVariables, includeDepth);\n    }\n    \n    // Update usage statistics\n    // NOTE: These updates are not atomic and may have race conditions under concurrent access\n    // This is acceptable for usage statistics which don't require perfect accuracy\n    // For production systems requiring atomic counters, consider using a database or atomic operations\n    this.metadata.usage_count = (this.metadata.usage_count || 0) + 1;\n    this.metadata.last_used = new Date().toISOString();\n    \n    // SECURITY FIX #5: Log template usage for audit trail\n    SecurityMonitor.logSecurityEvent({\n      type: 'TEMPLATE_RENDERED',\n      severity: 'LOW',\n      source: 'Template.render',\n      details: `Template ${this.metadata.name} rendered with ${Object.keys(sanitizedVariables).length} variables`\n    });\n    \n    return rendered;\n  }\n\n  /**\n   * Validate and sanitize variables according to their definitions\n   * SECURITY FIX #3: Comprehensive validation of all input variables\n   * TYPE SAFETY: Improved type safety for variable validation\n   */\n  private async validateAndSanitizeVariables(\n    variables: Record<string, unknown>\n  ): Promise<Record<string, unknown>> {\n    const sanitized: Record<string, unknown> = {};\n    \n    // Check required variables\n    for (const varDef of this.metadata.variables || []) {\n      if (varDef.required && !(varDef.name in variables)) {\n        if (varDef.default !== undefined) {\n          sanitized[varDef.name] = varDef.default;\n        } else {\n          throw ErrorHandler.createError(`Required variable '${varDef.name}' not provided`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.REQUIRED_VARIABLE);\n        }\n      }\n    }\n    \n    // Validate and sanitize provided variables\n    for (const [name, value] of Object.entries(variables)) {\n      const varDef = this.metadata.variables?.find(v => v.name === name);\n      \n      if (!varDef) {\n        // Skip unknown variables (they won't be used anyway)\n        logger.warn(`Unknown variable '${name}' provided to template`);\n        continue;\n      }\n      \n      // Type validation and sanitization\n      const sanitizedValue = await this.sanitizeVariableValue(value, varDef);\n      sanitized[name] = sanitizedValue;\n    }\n    \n    // Apply defaults for missing optional variables\n    for (const varDef of this.metadata.variables || []) {\n      if (!varDef.required && !(varDef.name in sanitized) && varDef.default !== undefined) {\n        sanitized[varDef.name] = varDef.default;\n      }\n    }\n    \n    return sanitized;\n  }\n\n  /**\n   * Sanitize a single variable value according to its definition\n   * SECURITY FIX #3 & #6: Type-specific validation and Unicode normalization\n   */\n  private async sanitizeVariableValue(value: any, varDef: TemplateVariable): Promise<any> {\n    switch (varDef.type) {\n      case 'string': {\n        // SECURITY FIX #6: Unicode normalization\n        const normalized = UnicodeValidator.normalize(String(value));\n        let stringValue = sanitizeInput(normalized.normalizedContent, this.MAX_STRING_LENGTH);\n        \n        // Apply regex validation if specified\n        if (varDef.validation) {\n          // SECURITY FIX: Validate regex complexity to prevent ReDoS attacks\n          // Previously: User-provided regex executed without limits\n          // Now: Check for dangerous patterns and limit execution time\n          try {\n            // Check for dangerous regex patterns\n            if (this.isDangerousRegex(varDef.validation)) {\n              throw ErrorHandler.createError(`Variable '${varDef.name}' has potentially dangerous validation pattern`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.DANGEROUS_PATTERN);\n            }\n            \n            const regex = new RegExp(varDef.validation);\n            // Use a simple timeout mechanism - in production, consider using a worker thread\n            const startTime = Date.now();\n            const result = regex.test(stringValue);\n            const duration = Date.now() - startTime;\n            \n            // If regex takes too long, it might be malicious\n            if (duration > 100) { // 100ms threshold\n              SecurityMonitor.logSecurityEvent({\n                type: 'CONTENT_INJECTION_ATTEMPT',\n                severity: 'HIGH',\n                source: 'Template.sanitizeVariableValue',\n                details: `Regex validation took ${duration}ms for variable '${varDef.name}', possible ReDoS`\n              });\n              throw ErrorHandler.createError(`Variable '${varDef.name}' validation pattern is too complex`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.PATTERN_TOO_COMPLEX);\n            }\n            \n            if (!result) {\n              throw ErrorHandler.createError(`Variable '${varDef.name}' does not match validation pattern`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.PATTERN_MISMATCH);\n            }\n          } catch (e) {\n            if (e instanceof SyntaxError) {\n              throw ErrorHandler.createError(`Variable '${varDef.name}' has invalid validation pattern`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_PATTERN);\n            }\n            throw e;\n          }\n        }\n        \n        // Check enum options if specified\n        if (varDef.options && !varDef.options.includes(stringValue)) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be one of: ${varDef.options.join(', ')}`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_OPTIONS);\n        }\n        \n        return stringValue;\n      }\n\n      case 'number': {\n        const num = Number(value);\n        if (Number.isNaN(num)) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be a number`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_NUMBER);\n        }\n        return num;\n      }\n\n      case 'boolean':\n        return Boolean(value);\n\n      case 'date': {\n        const date = new Date(value);\n        if (Number.isNaN(date.getTime())) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be a valid date`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_DATE);\n        }\n        return date;\n      }\n\n      case 'array': {\n        if (!Array.isArray(value)) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be an array`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_ARRAY);\n        }\n        // SECURITY FIX: Limit array size to prevent memory exhaustion attacks\n        // Previously: No limit on array size could lead to DoS\n        // Now: Enforces reasonable size limit with logging\n        const MAX_ARRAY_SIZE = 1000;\n        if (value.length > MAX_ARRAY_SIZE) {\n          SecurityMonitor.logSecurityEvent({\n            type: 'CONTENT_SIZE_EXCEEDED',\n            severity: 'MEDIUM',\n            source: 'Template.sanitizeVariableValue',\n            details: `Array variable '${varDef.name}' has ${value.length} items, limiting to ${MAX_ARRAY_SIZE}`\n          });\n          value = value.slice(0, MAX_ARRAY_SIZE);\n        }\n        // Sanitize string elements in arrays\n        return value.map((item: any) =>\n          typeof item === 'string' ? sanitizeInput(item, 1000) : item\n        );\n      }\n\n      case 'object':\n        if (typeof value !== 'object' || value === null) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be an object`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_OBJECT);\n        }\n        // Deep sanitize string values in objects\n        return this.sanitizeObject(value);\n        \n      default:\n        return value;\n    }\n  }\n\n  /**\n   * Recursively sanitize string values in objects\n   * SECURITY FIX: Truncate deep nesting instead of throwing to prevent DoS\n   */\n  private sanitizeObject(obj: any, depth: number = 0): any {\n    // SECURITY FIX: Return safe default instead of throwing to prevent DoS attacks\n    // Previously: Threw error on deep nesting which could be exploited\n    // Now: Returns string representation for excessively nested objects\n    if (depth > 10) {\n      SecurityMonitor.logSecurityEvent({\n        type: 'CONTENT_SIZE_EXCEEDED',\n        severity: 'MEDIUM',\n        source: 'Template.sanitizeObject',\n        details: 'Object nesting depth exceeded, truncating to string representation'\n      });\n      return '[Object too deeply nested]';\n    }\n    \n    if (typeof obj !== 'object' || obj === null) {\n      return obj;\n    }\n    \n    if (Array.isArray(obj)) {\n      // SECURITY FIX: Limit array size to prevent memory exhaustion\n      const MAX_ARRAY_SIZE = 1000;\n      if (obj.length > MAX_ARRAY_SIZE) {\n        SecurityMonitor.logSecurityEvent({\n          type: 'CONTENT_SIZE_EXCEEDED',\n          severity: 'MEDIUM',\n          source: 'Template.sanitizeObject',\n          details: `Array size ${obj.length} exceeds maximum ${MAX_ARRAY_SIZE}, truncating`\n        });\n        obj = obj.slice(0, MAX_ARRAY_SIZE);\n      }\n      return obj.map((item: any) => this.sanitizeObject(item, depth + 1));\n    }\n    \n    const sanitized: Record<string, any> = {};\n    // SECURITY FIX: Limit number of object properties to prevent memory exhaustion\n    const MAX_OBJECT_KEYS = 100;\n    const entries = Object.entries(obj);\n    if (entries.length > MAX_OBJECT_KEYS) {\n      SecurityMonitor.logSecurityEvent({\n        type: 'CONTENT_SIZE_EXCEEDED',\n        severity: 'MEDIUM',\n        source: 'Template.sanitizeObject',\n        details: `Object has ${entries.length} keys, limiting to ${MAX_OBJECT_KEYS}`\n      });\n    }\n    \n    for (let i = 0; i < Math.min(entries.length, MAX_OBJECT_KEYS); i++) {\n      const [key, value] = entries[i];\n      const sanitizedKey = sanitizeInput(key, 50);\n      if (typeof value === 'string') {\n        sanitized[sanitizedKey] = sanitizeInput(value, 1000);\n      } else if (typeof value === 'object') {\n        sanitized[sanitizedKey] = this.sanitizeObject(value, depth + 1);\n      } else {\n        sanitized[sanitizedKey] = value;\n      }\n    }\n    \n    return sanitized;\n  }\n\n  /**\n   * Resolve nested variable paths (e.g., \"user.name\")\n   * TYPE SAFETY: Improved type safety for variable resolution\n   */\n  private resolveVariable(path: string, variables: Record<string, unknown>): unknown {\n    const parts = path.split('.');\n    let value: unknown = variables;\n    \n    for (const part of parts) {\n      if (value && typeof value === 'object' && value !== null && part in value) {\n        // Type assertion with runtime check - safe because we verified the property exists\n        value = (value as Record<string, unknown>)[part];\n      } else {\n        return undefined;\n      }\n    }\n    \n    return value;\n  }\n\n  /**\n   * Check if a regex pattern is potentially dangerous (ReDoS)\n   * SECURITY FIX: Detect patterns that could cause exponential backtracking\n   */\n  private isDangerousRegex(pattern: string): boolean {\n    // Check for nested quantifiers which can cause exponential backtracking\n    // SECURITY FIX: Use safe, specific patterns to detect dangerous regex constructs\n    // Previously: Used [^)]* patterns that could cause ReDoS in detection itself\n    // Now: Use safer, bounded character classes and specific string checks\n    // FIX: Use character class and remove unnecessary escape (SonarCloud S6035, S6535)\n    const dangerousPatterns = [\n      /[+*]{2,}/,                      // Multiple consecutive quantifiers\n      /\\(.{0,50}\\+\\)[+*]/,             // Quantified groups with quantifiers inside (bounded)\n      /\\[[^\\]]{0,20}\\+\\][+*]/,         // Quantified character classes with quantifiers (bounded)\n      /(\\\\[dws])\\1{2,}/,               // Repeated character classes\n      /\\(\\?<[!=][^)]{0,30}\\)/,         // Complex lookbehinds (bounded)\n    ];\n\n    // String-based checks for common catastrophic patterns (safer than regex)\n    const dangerousStringPatterns = [\n      '(.+)+',    // (.+)+ catastrophic backtracking\n      '(.*)++',   // (.*)++\n      '(.*)*',    // (.*)* catastrophic backtracking\n      '(.+)*',    // (.+)*\n      '(a+)+',    // (a+)+ type patterns\n      '(a*)*',    // (a*)* type patterns\n      '(a|a)*',   // Overlapping alternation\n      '(a|b)*+',  // Possessive quantifiers with alternation\n    ];\n    \n    // Check regex-based dangerous patterns\n    for (const dangerous of dangerousPatterns) {\n      if (dangerous.test(pattern)) {\n        return true;\n      }\n    }\n\n    // Check string-based dangerous patterns (safer than complex regex)\n    for (const dangerousString of dangerousStringPatterns) {\n      if (pattern.includes(dangerousString)) {\n        return true;\n      }\n    }\n\n    // Check for excessive backtracking potential\n    // Count groups and quantifiers (using safe, simple regex)\n    const groups = (pattern.match(/\\(/g) || []).length;\n    const quantifiers = (pattern.match(/[+*?{]/g) || []).length;\n\n    // If there are many groups and quantifiers, it's potentially dangerous\n    if (groups > 5 && quantifiers > 5) {\n      return true;\n    }\n    \n    return false;\n  }\n\n  /**\n   * Format a value for template output\n   */\n  private formatValue(value: any): string {\n    if (value === undefined || value === null) {\n      return '';\n    }\n    \n    if (value instanceof Date) {\n      return value.toISOString();\n    }\n    \n    if (Array.isArray(value)) {\n      return value.join(', ');\n    }\n    \n    if (typeof value === 'object') {\n      return JSON.stringify(value, null, 2);\n    }\n    \n    return String(value);\n  }\n\n  /**\n   * Process template includes\n   * SECURITY FIX #2: Safe include processing with path validation\n   * \n   * TODO: Implement actual include processing functionality\n   * This is currently a placeholder that validates the security model\n   * but does not actually load and render included templates.\n   * \n   * Future implementation should:\n   * 1. Load templates from validated paths\n   * 2. Render them with current variables\n   * 3. Replace include markers in content\n   * 4. Respect includeDepth limit\n   */\n  private async processIncludes(\n    content: string, \n    variables: Record<string, unknown>, \n    includeDepth: number\n  ): Promise<string> {\n    // TODO: Implement actual template include processing\n    // Current implementation only validates the security model\n    \n    if (!this.metadata.includes || this.metadata.includes.length === 0) {\n      return content;\n    }\n    \n    // Log security event for audit trail\n    SecurityMonitor.logSecurityEvent({\n      type: 'TEMPLATE_INCLUDE',\n      severity: 'LOW',\n      source: 'Template.processIncludes',\n      details: `Processing ${this.metadata.includes.length} includes at depth ${includeDepth}`\n    });\n    \n    // TODO: Future implementation would:\n    // for (const includePath of this.metadata.includes) {\n    //   const template = await this.loadIncludedTemplate(includePath);\n    //   const rendered = await template.render(variables, includeDepth + 1);\n    //   content = content.replace(`{{include:${includePath}}}`, rendered);\n    // }\n    \n    return content;\n  }\n\n  /**\n   * Template-specific validation\n   */\n  public override validate(): ElementValidationResult {\n    const result = super.validate();\n\n    // Initialize arrays if not present\n    // FIX: Use nullish coalescing assignment (SonarCloud S6606)\n    result.errors ??= [];\n    result.warnings ??= [];\n    \n    // Content validation\n    if (!this.content || this.content.trim().length === 0) {\n      result.errors.push({\n        field: 'content',\n        message: 'Template content cannot be empty',\n        code: 'EMPTY_CONTENT'\n      });\n    }\n    \n    // Check for unmatched tokens.\n    // Issue #705: In section mode, only count tokens within the <template> section —\n    // <style> and <script> sections are raw passthrough where }} is intentional.\n    // getSections() returns the cached result — no repeated regex execution.\n    const { isSectionMode, templateSection } = this.getSections();\n    const tokenCheckContent = isSectionMode ? templateSection : this.content;\n    const openTokens = (tokenCheckContent.match(/\\{\\{/g) || []).length;\n    const closeTokens = (tokenCheckContent.match(/\\}\\}/g) || []).length;\n    if (openTokens !== closeTokens) {\n      result.errors.push({\n        field: 'content',\n        message: 'Template has unmatched variable tokens',\n        code: 'UNMATCHED_TOKENS'\n      });\n    }\n    \n    // Validate output format\n    const validFormats = ['markdown', 'html', 'json', 'yaml', 'text', 'xml'];\n    if (this.metadata.output_format && !validFormats.includes(this.metadata.output_format)) {\n      result.warnings.push({\n        field: 'output_format',\n        message: `Unknown output format '${this.metadata.output_format}'. Common formats: ${validFormats.join(', ')}`,\n        severity: 'low'\n      });\n    }\n    \n    // Validate variables\n    if (this.metadata.variables) {\n      const variableNames = new Set<string>();\n      \n      this.metadata.variables.forEach((variable, index) => {\n        // Check for duplicate names\n        if (variableNames.has(variable.name)) {\n          result.errors!.push({\n            field: `variables[${index}].name`,\n            message: `Duplicate variable name '${variable.name}'`,\n            code: 'DUPLICATE_VARIABLE'\n          });\n        }\n        variableNames.add(variable.name);\n        \n        // Validate regex patterns\n        if (variable.validation) {\n          try {\n            new RegExp(variable.validation);\n          } catch (e) {\n            result.errors!.push({\n              field: `variables[${index}].validation`,\n              message: `Invalid regex pattern: ${e}`,\n              code: 'INVALID_REGEX'\n            });\n          }\n        }\n      });\n    }\n    \n    // Check if all tokens have corresponding variable definitions\n    const compiled = this.compile();\n    const definedVars = new Set(this.metadata.variables?.map(v => v.name) || []);\n    const usedVars = new Set(compiled.tokens.map(t => t.variable.split('.')[0]));\n    \n    usedVars.forEach(varName => {\n      if (!definedVars.has(varName)) {\n        result.warnings!.push({\n          field: 'variables',\n          message: `Template uses undefined variable '${varName}'`,\n          severity: 'medium'\n        });\n      }\n    });\n    \n    // Warnings for best practices\n    // FIX: Remove unnecessary non-null assertion (SonarCloud S4325)\n    if (!this.metadata.tags || this.metadata.tags.length === 0) {\n      result.warnings.push({\n        field: 'tags',\n        message: 'Consider adding tags for better searchability',\n        severity: 'low'\n      });\n    }\n\n    if (!this.metadata.examples || this.metadata.examples.length === 0) {\n      result.warnings.push({\n        field: 'examples',\n        message: 'Adding examples improves template usability',\n        severity: 'medium'\n      });\n    }\n    \n    // Update the valid flag based on final errors\n    result.valid = (result.errors?.length || 0) === 0;\n    \n    return result;\n  }\n\n  /**\n   * Serialize to JSON format for internal use and testing\n   */\n  public override serializeToJSON(): string {\n    const data = {\n      id: this.id,\n      type: this.type,\n      version: this.version,\n      metadata: this.metadata,\n      content: this.content,\n      references: this.references,\n      extensions: this.extensions,\n      ratings: this.ratings\n    };\n    return JSON.stringify(data, null, 2);\n  }\n\n  /**\n   * Get content for serialization\n   */\n  protected override getContent(): string {\n    return this.content;\n  }\n\n  /**\n   * Serialize template to markdown format with YAML frontmatter\n   * FIX: Changed from JSON to markdown for GitHub portfolio compatibility\n   */\n  public override serialize(): string {\n    // Template content is already the main content\n    // Just use base class serialize which outputs markdown\n    return super.serialize();\n  }\n\n  /**\n   * Deserialize template from JSON format\n   */\n  public override deserialize(data: string): void {\n    try {\n      const parsed = JSON.parse(data);\n      \n      // Update metadata\n      this.metadata = { ...this.metadata, ...parsed.metadata };\n      \n      // Update content\n      this.content = parsed.content || '';\n      \n      // Update other properties\n      this.references = parsed.references || [];\n      this.extensions = parsed.extensions || {};\n      this.ratings = parsed.ratings || this.ratings;\n      \n      // Update ID and version if provided\n      if (parsed.id) this.id = parsed.id;\n      if (parsed.version) this.version = parsed.version;\n      \n      // Clear compiled template and section caches (content changed)\n      this.compiledTemplate = undefined;\n      this.parsedSections = undefined;\n\n      this._isDirty = true;\n      logger.debug(`Deserialized template: ${this.metadata.name}`);\n      \n    } catch (error) {\n      logger.error(`Failed to deserialize template: ${error}`);\n      throw ErrorHandler.wrapError(error, 'Template deserialization failed', ErrorCategory.SYSTEM_ERROR);\n    }\n  }\n\n  /**\n   * Get a preview of the template with sample data\n   */\n  async preview(): Promise<string> {\n    const sampleVars: Record<string, any> = {};\n    \n    // Generate sample data for each variable\n    for (const varDef of this.metadata.variables || []) {\n      switch (varDef.type) {\n        case 'string':\n          sampleVars[varDef.name] = varDef.default || `[${varDef.name}]`;\n          break;\n        case 'number':\n          sampleVars[varDef.name] = varDef.default || 42;\n          break;\n        case 'boolean':\n          sampleVars[varDef.name] = varDef.default || true;\n          break;\n        case 'date':\n          sampleVars[varDef.name] = varDef.default || new Date();\n          break;\n        case 'array':\n          sampleVars[varDef.name] = varDef.default || ['item1', 'item2'];\n          break;\n        case 'object':\n          sampleVars[varDef.name] = varDef.default || { key: 'value' };\n          break;\n      }\n    }\n    \n    return this.render(sampleVars);\n  }\n\n  /**\n   * Template activation lifecycle\n   */\n  public override async activate(): Promise<void> {\n    logger.info(`Activating template: ${this.metadata.name} (${this.id})`);\n    \n    // Compile the template to check for errors\n    this.compile();\n    \n    await super.activate?.();\n  }\n\n  /**\n   * Template deactivation lifecycle\n   */\n  public override async deactivate(): Promise<void> {\n    logger.info(`Deactivating template: ${this.metadata.name} (${this.id})`);\n    \n    // Clear compiled template and section caches\n    this.compiledTemplate = undefined;\n    this.parsedSections = undefined;\n\n    await super.deactivate?.();\n  }\n}\n\n// Internal types for template compilation\ninterface CompiledTemplate {\n  content: string;\n  tokens: TemplateToken[];\n  variables: TemplateVariable[];\n}\n\ninterface TemplateToken {\n  token: string;      // The full token including braces (e.g., \"{{ name }}\")\n  variable: string;   // The variable path (e.g., \"user.name\")\n  position: number;   // Position in the template string\n}"]}
|
|
847
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Template.js","sourceRoot":"","sources":["../../../src/elements/templates/Template.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Template element class implementing IElement interface.\n * Represents reusable content structures with variable substitution and dynamic content.\n * \n * SECURITY FIXES IMPLEMENTED (Following PR #319 patterns):\n * 1. CRITICAL: Template injection prevention - no eval() or Function() constructor\n * 2. CRITICAL: Path traversal prevention for template includes\n * 3. HIGH: Input validation and sanitization for all template variables\n * 4. MEDIUM: Memory limits to prevent resource exhaustion (100KB templates, 100 variables)\n * 5. MEDIUM: Audit logging for all security operations via SecurityMonitor\n * 6. MEDIUM: Unicode normalization to prevent homograph attacks\n */\n\nimport { BaseElement } from '../BaseElement.js';\nimport { IElement, IElementMetadata, ElementValidationResult } from '../../types/elements/index.js';\nimport { ElementType } from '../../portfolio/types.js';\nimport { logger } from '../../utils/logger.js';\nimport { ErrorHandler, ErrorCategory } from '../../utils/ErrorHandler.js';\nimport { ValidationErrorCodes } from '../../utils/errorCodes.js';\nimport { sanitizeInput } from '../../security/InputValidator.js';\nimport { UnicodeValidator } from '../../security/validators/unicodeValidator.js';\nimport { ContentValidator } from '../../security/contentValidator.js';\nimport { SecurityMonitor } from '../../security/securityMonitor.js';\nimport * as path from 'path';\nimport { MetadataService } from '../../services/MetadataService.js';\n\n// Extend IElementMetadata with template-specific fields\nexport interface TemplateMetadata extends IElementMetadata {\n  type?: ElementType.TEMPLATE;             // Template type constraint for type safety\n  category?: string;              // Template category (documents, emails, code, etc.)\n  output_format?: string;         // Output format (markdown, html, json, yaml, etc.)\n  variables?: TemplateVariable[]; // Variable definitions\n  includes?: string[];            // Other templates to include\n  tags?: string[];               // Searchable tags\n  usage_count?: number;          // Track popularity\n  last_used?: string;            // ISO date string\n  examples?: TemplateExample[];   // Usage examples\n\n  /**\n   * Action verbs that trigger this template (e.g., \"create\", \"generate\", \"draft\")\n   * Used by Enhanced Capability Index for intelligent template suggestions\n   * @since v1.9.10\n   */\n  triggers?: string[];\n}\n\nexport interface TemplateVariable {\n  name: string;                   // Variable name (e.g., \"project_name\")\n  type: 'string' | 'number' | 'boolean' | 'date' | 'array' | 'object';\n  description?: string;           // Help text for the variable\n  required?: boolean;             // Is this variable required?\n  default?: unknown;              // Default value if not provided (type-safe)\n  validation?: string;            // Regex pattern for validation (string type only)\n  options?: string[];             // For enum-like strings\n  format?: string;                // Date format string (date type only)\n}\n\nexport interface TemplateExample {\n  title: string;\n  description?: string;\n  variables: Record<string, unknown>;\n  output?: string;\n}\n\n/** Parsed result of a section-format template (issue #705). */\nexport interface TemplateSections {\n  /** True when the content contains at least one bare section tag. */\n  isSectionMode: boolean;\n  /** Content of the <template> block — the only section that receives variable substitution. */\n  templateSection: string;\n  /** Raw content of the <style> block — passed through without variable substitution. */\n  styleSection: string;\n  /** Raw content of the <script> block — passed through without variable substitution. */\n  scriptSection: string;\n}\n\nexport class Template extends BaseElement implements IElement {\n  public declare metadata: TemplateMetadata;\n  // instructions and content inherited from BaseElement (v2.0 dual-field architecture)\n  private compiledTemplate?: CompiledTemplate;\n  // Issue #705: Cache parsed sections to avoid re-running regex on every render/validate\n  private parsedSections?: TemplateSections;\n  \n  // SECURITY FIX #4: Memory management constants\n  // Prevents unbounded template size and variable count that could exhaust memory\n  private readonly MAX_TEMPLATE_SIZE = 100 * 1024; // 100KB max template size\n  private static readonly MAX_VARIABLE_COUNT = 100; // Max variables per template\n  private readonly MAX_INCLUDE_DEPTH = 5;          // Prevent infinite include loops\n  private readonly MAX_STRING_LENGTH = 10000;      // Max length for string variables\n\n  constructor(metadata: Partial<TemplateMetadata>, content: string = '', metadataService: MetadataService) {\n    // SECURITY FIX #3 & #6: Validate and sanitize ALL metadata fields\n    // Unicode normalization prevents homograph attacks\n    // Input sanitization prevents XSS and injection attacks\n    const sanitizedMetadata = {\n      ...metadata,\n      name: metadata.name ? sanitizeInput(UnicodeValidator.normalize(metadata.name).normalizedContent, 100) : undefined,\n      description: metadata.description ? sanitizeInput(UnicodeValidator.normalize(metadata.description).normalizedContent, 500) : undefined,\n      category: metadata.category ? sanitizeInput(UnicodeValidator.normalize(metadata.category).normalizedContent, 50) : undefined,\n      output_format: metadata.output_format ? sanitizeInput(metadata.output_format, 20) : undefined\n    };\n\n    super(ElementType.TEMPLATE, sanitizedMetadata, metadataService);\n    \n    // SECURITY FIX #4: Enforce template size limit\n    if (content.length > this.MAX_TEMPLATE_SIZE) {\n      SecurityMonitor.logSecurityEvent({\n        type: 'CONTENT_SIZE_EXCEEDED',\n        severity: 'HIGH',\n        source: 'Template.constructor',\n        details: `Template size ${content.length} exceeds maximum ${this.MAX_TEMPLATE_SIZE}`\n      });\n      throw ErrorHandler.createError(`Template content exceeds maximum size of ${this.MAX_TEMPLATE_SIZE} bytes`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.TEMPLATE_TOO_LARGE);\n    }\n    \n    // SECURITY FIX #3: Sanitize template content\n    // ContentValidator with contentContext: 'template' allows code patterns (eval, exec, etc.)\n    // while still catching prompt injection, credentials, and path traversal.\n    const contentValidation = ContentValidator.validateAndSanitize(content, {\n      maxLength: this.MAX_TEMPLATE_SIZE,\n      contentContext: 'template',\n    });\n    this.content = contentValidation.sanitizedContent || UnicodeValidator.normalize(content).normalizedContent;\n    \n    // Ensure template-specific metadata\n    this.metadata = {\n      ...this.metadata,\n      category: sanitizedMetadata.category || 'general',\n      output_format: sanitizedMetadata.output_format || 'markdown',\n      variables: metadata.variables || [],\n      includes: metadata.includes || [],\n      tags: metadata.tags || [],\n      usage_count: metadata.usage_count || 0,\n      examples: metadata.examples || []\n    };\n\n    // SECURITY FIX #3 & #4: Validate variables\n    if (this.metadata.variables) {\n      if (this.metadata.variables.length > Template.MAX_VARIABLE_COUNT) {\n        throw ErrorHandler.createError(`Variable count ${this.metadata.variables.length} exceeds maximum ${Template.MAX_VARIABLE_COUNT}`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.TOO_MANY_VARIABLES);\n      }\n      \n      this.metadata.variables = this.metadata.variables.map(variable => ({\n        ...variable,\n        name: sanitizeInput(UnicodeValidator.normalize(variable.name).normalizedContent, 50),\n        description: variable.description ? sanitizeInput(UnicodeValidator.normalize(variable.description).normalizedContent, 200) : undefined,\n        validation: variable.validation ? sanitizeInput(variable.validation, 200) : undefined\n      }));\n    }\n\n    // SECURITY FIX #2: Validate include paths\n    if (this.metadata.includes) {\n      this.metadata.includes = this.metadata.includes.map(includePath => {\n        const sanitizedPath = sanitizeInput(includePath, 200);\n        // Prevent path traversal attacks\n        if (!this.isValidIncludePath(sanitizedPath)) {\n          SecurityMonitor.logSecurityEvent({\n            type: 'PATH_TRAVERSAL_ATTEMPT',\n            severity: 'CRITICAL',\n            source: 'Template.constructor',\n            details: `Invalid include path: ${sanitizedPath}`\n          });\n          throw ErrorHandler.createError(`Invalid include path: ${sanitizedPath}`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_INCLUDE_PATH);\n        }\n        return sanitizedPath;\n      });\n    }\n  }\n\n  /**\n   * Validate include paths to prevent directory traversal\n   * SECURITY FIX #2: Prevents accessing files outside template directory\n   */\n  private isValidIncludePath(includePath: string): boolean {\n    // Normalize the path\n    const normalized = path.normalize(includePath);\n    \n    // Check for path traversal patterns\n    if (normalized.includes('..') || normalized.includes('~') || path.isAbsolute(normalized)) {\n      return false;\n    }\n    \n    // Only allow alphanumeric, dash, underscore, forward slash, backslash (for Windows), and .md extension\n    // Note: We test against the original path to preserve cross-platform compatibility\n    // FIX: Remove unnecessary escape for / (SonarCloud S6535)\n    const validPathPattern = /^[a-zA-Z0-9\\-_/\\\\]+\\.md$/;\n    return validPathPattern.test(includePath);\n  }\n\n  /**\n   * Compile the template for efficient rendering\n   * SECURITY FIX #1: Safe template compilation without eval() or Function()\n   * Uses regex-based token replacement instead of dynamic code execution\n   */\n  /**\n   * Parse section-mode content into named sections.\n   *\n   * Section mode is active when the content contains any <template>, <style>, or\n   * <script> block. In section mode only the <template> section is processed by the\n   * variable substitution engine; <style> and <script> are raw passthrough so that\n   * CSS/JS `}}` characters never trigger unmatched-token errors.\n   *\n   * @see Issue #705 — structured section support for page templates\n   */\n  static parseSections(content: string): TemplateSections {\n    // Matches bare section tags: <template>, <style>, <script> (no attributes).\n    // Tags with attributes (e.g. <template id=\"x\">) are treated as plain HTML,\n    // not section markers — this is intentional for forward compatibility.\n    const pattern = /<(template|style|script)>([\\s\\S]*?)<\\/\\1>/gi;\n    const sections: Record<string, string> = {};\n    let found = false;\n    let match;\n\n    while ((match = pattern.exec(content)) !== null) {\n      found = true;\n      sections[match[1].toLowerCase()] = match[2];\n    }\n\n    // Issue #705 forward-compat: warn when a bare <template> tag appears inside\n    // the <template> section — nested section markers aren't supported yet and\n    // the lazy regex would silently produce incorrect results.\n    const templateSection = sections['template'] ?? '';\n    if (found && templateSection && /<template>/i.test(templateSection)) {\n      logger.warn(\n        'Template section contains a nested bare <template> tag. ' +\n        'Nested section markers are not supported — only the outermost ' +\n        '<template>...</template> block is rendered. ' +\n        'Use <template id=\"...\"> (with an attribute) for inner HTML template elements.'\n      );\n    }\n\n    return {\n      isSectionMode: found,\n      templateSection,\n      styleSection: sections['style'] ?? '',\n      scriptSection: sections['script'] ?? '',\n    };\n  }\n\n  /**\n   * Return the parsed sections for this template's content.\n   * Result is cached per-instance and cleared whenever content changes.\n   * Used by TemplateRenderer to serve section-specific render results.\n   */\n  getSections(): TemplateSections {\n    if (!this.parsedSections) {\n      this.parsedSections = Template.parseSections(this.content);\n    }\n    return this.parsedSections;\n  }\n\n  /**\n   * Scan `content` for `{{placeholder}}` patterns and return a merged variable\n   * list. Existing entries are preserved unchanged (user-set descriptions,\n   * types, required flags, etc.); new placeholders are added with defaults:\n   * `type: 'string'`, `required: false`. (#1896)\n   *\n   * Respects section mode — only the `<template>` section is scanned,\n   * matching the substitution engine's scope.\n   *\n   * **Performance:** Single-pass regex scan — O(n) in content length.\n   * Called by `TemplateManager.save()` on every create/edit, so content\n   * is already validated and size-bounded (≤ 100 KB) before reaching here.\n   *\n   * @param content - Raw template content (may include section tags)\n   * @param existingVariables - Already-declared variables; never overwritten\n   * @returns Merged variable list: existing entries first, new entries appended\n   *\n   * @example\n   * // New template — empty schema gets fully populated\n   * deriveVariablesFromContent('Hello {{name}}, score: {{score}}')\n   * // → [{ name: 'name', type: 'string', required: false },\n   * //    { name: 'score', type: 'string', required: false }]\n   *\n   * @example\n   * // Existing entry preserved; only the missing placeholder is added\n   * deriveVariablesFromContent('{{name}} earns {{points}}', [\n   *   { name: 'name', type: 'string', required: true, description: 'Display name' }\n   * ])\n   * // → [{ name: 'name', type: 'string', required: true, description: 'Display name' },\n   * //    { name: 'points', type: 'string', required: false }]\n   */\n  static deriveVariablesFromContent(\n    content: string,\n    existingVariables: TemplateVariable[] = []\n  ): TemplateVariable[] {\n    const { isSectionMode, templateSection } = Template.parseSections(content);\n    const scanContent = isSectionMode ? templateSection : content;\n\n    const pattern = /\\{\\{\\s*([a-zA-Z_]\\w*(?:\\.[a-zA-Z_]\\w*)*)\\s*\\}\\}/g;\n    const seen = new Set<string>();\n    let match;\n    while ((match = pattern.exec(scanContent)) !== null) {\n      seen.add(match[1]);\n    }\n\n    const existingNames = new Set(existingVariables.map(v => v.name));\n    const result: TemplateVariable[] = [...existingVariables];\n\n    for (const name of seen) {\n      if (!existingNames.has(name)) {\n        result.push({ name, type: 'string', required: false });\n      }\n    }\n\n    // Enforce the same MAX_VARIABLE_COUNT limit as the constructor.\n    // When auto-derive would exceed the cap, truncate and surface a structured\n    // error so the calling LLM knows to split the content across templates.\n    if (result.length > Template.MAX_VARIABLE_COUNT) {\n      const overflow = result.splice(Template.MAX_VARIABLE_COUNT);\n      const overflowNames = overflow.map(v => v.name).join(', ');\n      throw ErrorHandler.createError(\n        `Auto-derive reached the ${Template.MAX_VARIABLE_COUNT}-variable limit. ` +\n        `${overflow.length} placeholder(s) were not registered: ${overflowNames}. ` +\n        `Split this content across multiple templates and combine them in an ensemble.`,\n        ErrorCategory.VALIDATION_ERROR,\n        ValidationErrorCodes.TOO_MANY_VARIABLES\n      );\n    }\n\n    return result;\n  }\n\n  private compile(): CompiledTemplate {\n    if (this.compiledTemplate) {\n      return this.compiledTemplate;\n    }\n\n    // Issue #705: In section mode, only compile the <template> section.\n    // Tokens in <style> and <script> are never substituted.\n    // getSections() returns the cached result — no repeated regex execution.\n    const { isSectionMode, templateSection } = this.getSections();\n    const compileContent = isSectionMode ? templateSection : this.content;\n\n    // Extract all variable tokens from the template\n    // FIX: Use \\w shorthand instead of [a-zA-Z0-9_] (SonarCloud S6353)\n    const variablePattern = /\\{\\{\\s*([a-zA-Z_]\\w*(?:\\.[a-zA-Z_]\\w*)*)\\s*\\}\\}/g;\n    const tokens: TemplateToken[] = [];\n    let match;\n\n    while ((match = variablePattern.exec(compileContent)) !== null) {\n      tokens.push({\n        token: match[0],\n        variable: match[1],\n        position: match.index\n      });\n    }\n\n    this.compiledTemplate = {\n      content: compileContent,\n      tokens,\n      variables: this.metadata.variables || []\n    };\n\n    return this.compiledTemplate;\n  }\n\n  /**\n   * Render the template with provided variables\n   * SECURITY FIX #1: Safe rendering without code execution\n   * SECURITY FIX #3: All variables are validated and sanitized\n   * TYPE SAFETY: Strong typing for variables with runtime validation\n   */\n  async render<T extends Record<string, unknown>>(\n    variables: T = {} as T, \n    includeDepth: number = 0\n  ): Promise<string> {\n    // SECURITY FIX #4: Prevent infinite include loops\n    if (includeDepth > this.MAX_INCLUDE_DEPTH) {\n      SecurityMonitor.logSecurityEvent({\n        type: 'INCLUDE_DEPTH_EXCEEDED',\n        severity: 'HIGH',\n        source: 'Template.render',\n        details: `Include depth ${includeDepth} exceeds maximum ${this.MAX_INCLUDE_DEPTH}`\n      });\n      throw ErrorHandler.createError('Maximum template include depth exceeded', ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.MAX_INCLUDE_DEPTH);\n    }\n\n    // Compile the template\n    const compiled = this.compile();\n    \n    // Validate and sanitize all provided variables\n    const sanitizedVariables = await this.validateAndSanitizeVariables(variables);\n    \n    // Start with the template content\n    let rendered = compiled.content;\n    \n    // Replace tokens in reverse order to maintain positions\n    const sortedTokens = [...compiled.tokens].sort((a, b) => b.position - a.position);\n    \n    for (const token of sortedTokens) {\n      const value = this.resolveVariable(token.variable, sanitizedVariables);\n      const stringValue = this.formatValue(value);\n      \n      // Replace the token with the sanitized value\n      rendered = rendered.substring(0, token.position) + \n                 stringValue + \n                 rendered.substring(token.position + token.token.length);\n    }\n    \n    // Process includes if any\n    if (this.metadata.includes && this.metadata.includes.length > 0) {\n      rendered = await this.processIncludes(rendered, sanitizedVariables, includeDepth);\n    }\n    \n    // Update usage statistics\n    // NOTE: These updates are not atomic and may have race conditions under concurrent access\n    // This is acceptable for usage statistics which don't require perfect accuracy\n    // For production systems requiring atomic counters, consider using a database or atomic operations\n    this.metadata.usage_count = (this.metadata.usage_count || 0) + 1;\n    this.metadata.last_used = new Date().toISOString();\n    \n    // SECURITY FIX #5: Log template usage for audit trail\n    SecurityMonitor.logSecurityEvent({\n      type: 'TEMPLATE_RENDERED',\n      severity: 'LOW',\n      source: 'Template.render',\n      details: `Template ${this.metadata.name} rendered with ${Object.keys(sanitizedVariables).length} variables`\n    });\n    \n    return rendered;\n  }\n\n  /**\n   * Validate and sanitize variables according to their definitions\n   * SECURITY FIX #3: Comprehensive validation of all input variables\n   * TYPE SAFETY: Improved type safety for variable validation\n   */\n  private async validateAndSanitizeVariables(\n    variables: Record<string, unknown>\n  ): Promise<Record<string, unknown>> {\n    const sanitized: Record<string, unknown> = {};\n    \n    // Check required variables\n    for (const varDef of this.metadata.variables || []) {\n      if (varDef.required && !(varDef.name in variables)) {\n        if (varDef.default !== undefined) {\n          sanitized[varDef.name] = varDef.default;\n        } else {\n          throw ErrorHandler.createError(`Required variable '${varDef.name}' not provided`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.REQUIRED_VARIABLE);\n        }\n      }\n    }\n    \n    // Validate and sanitize provided variables\n    for (const [name, value] of Object.entries(variables)) {\n      const varDef = this.metadata.variables?.find(v => v.name === name);\n      \n      if (!varDef) {\n        // Skip unknown variables (they won't be used anyway)\n        logger.warn(`Unknown variable '${name}' provided to template`);\n        continue;\n      }\n      \n      // Type validation and sanitization\n      const sanitizedValue = await this.sanitizeVariableValue(value, varDef);\n      sanitized[name] = sanitizedValue;\n    }\n    \n    // Apply defaults for missing optional variables\n    for (const varDef of this.metadata.variables || []) {\n      if (!varDef.required && !(varDef.name in sanitized) && varDef.default !== undefined) {\n        sanitized[varDef.name] = varDef.default;\n      }\n    }\n    \n    return sanitized;\n  }\n\n  /**\n   * Sanitize a single variable value according to its definition\n   * SECURITY FIX #3 & #6: Type-specific validation and Unicode normalization\n   */\n  private async sanitizeVariableValue(value: any, varDef: TemplateVariable): Promise<any> {\n    switch (varDef.type) {\n      case 'string': {\n        // SECURITY FIX #6: Unicode normalization\n        const normalized = UnicodeValidator.normalize(String(value));\n        let stringValue = sanitizeInput(normalized.normalizedContent, this.MAX_STRING_LENGTH);\n        \n        // Apply regex validation if specified\n        if (varDef.validation) {\n          // SECURITY FIX: Validate regex complexity to prevent ReDoS attacks\n          // Previously: User-provided regex executed without limits\n          // Now: Check for dangerous patterns and limit execution time\n          try {\n            // Check for dangerous regex patterns\n            if (this.isDangerousRegex(varDef.validation)) {\n              throw ErrorHandler.createError(`Variable '${varDef.name}' has potentially dangerous validation pattern`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.DANGEROUS_PATTERN);\n            }\n            \n            const regex = new RegExp(varDef.validation);\n            // Use a simple timeout mechanism - in production, consider using a worker thread\n            const startTime = Date.now();\n            const result = regex.test(stringValue);\n            const duration = Date.now() - startTime;\n            \n            // If regex takes too long, it might be malicious\n            if (duration > 100) { // 100ms threshold\n              SecurityMonitor.logSecurityEvent({\n                type: 'CONTENT_INJECTION_ATTEMPT',\n                severity: 'HIGH',\n                source: 'Template.sanitizeVariableValue',\n                details: `Regex validation took ${duration}ms for variable '${varDef.name}', possible ReDoS`\n              });\n              throw ErrorHandler.createError(`Variable '${varDef.name}' validation pattern is too complex`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.PATTERN_TOO_COMPLEX);\n            }\n            \n            if (!result) {\n              throw ErrorHandler.createError(`Variable '${varDef.name}' does not match validation pattern`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.PATTERN_MISMATCH);\n            }\n          } catch (e) {\n            if (e instanceof SyntaxError) {\n              throw ErrorHandler.createError(`Variable '${varDef.name}' has invalid validation pattern`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_PATTERN);\n            }\n            throw e;\n          }\n        }\n        \n        // Check enum options if specified\n        if (varDef.options && !varDef.options.includes(stringValue)) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be one of: ${varDef.options.join(', ')}`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_OPTIONS);\n        }\n        \n        return stringValue;\n      }\n\n      case 'number': {\n        const num = Number(value);\n        if (Number.isNaN(num)) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be a number`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_NUMBER);\n        }\n        return num;\n      }\n\n      case 'boolean':\n        return Boolean(value);\n\n      case 'date': {\n        const date = new Date(value);\n        if (Number.isNaN(date.getTime())) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be a valid date`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_DATE);\n        }\n        return date;\n      }\n\n      case 'array': {\n        if (!Array.isArray(value)) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be an array`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_ARRAY);\n        }\n        // SECURITY FIX: Limit array size to prevent memory exhaustion attacks\n        // Previously: No limit on array size could lead to DoS\n        // Now: Enforces reasonable size limit with logging\n        const MAX_ARRAY_SIZE = 1000;\n        if (value.length > MAX_ARRAY_SIZE) {\n          SecurityMonitor.logSecurityEvent({\n            type: 'CONTENT_SIZE_EXCEEDED',\n            severity: 'MEDIUM',\n            source: 'Template.sanitizeVariableValue',\n            details: `Array variable '${varDef.name}' has ${value.length} items, limiting to ${MAX_ARRAY_SIZE}`\n          });\n          value = value.slice(0, MAX_ARRAY_SIZE);\n        }\n        // Sanitize string elements in arrays\n        return value.map((item: any) =>\n          typeof item === 'string' ? sanitizeInput(item, 1000) : item\n        );\n      }\n\n      case 'object':\n        if (typeof value !== 'object' || value === null) {\n          throw ErrorHandler.createError(`Variable '${varDef.name}' must be an object`, ErrorCategory.VALIDATION_ERROR, ValidationErrorCodes.INVALID_OBJECT);\n        }\n        // Deep sanitize string values in objects\n        return this.sanitizeObject(value);\n        \n      default:\n        return value;\n    }\n  }\n\n  /**\n   * Recursively sanitize string values in objects\n   * SECURITY FIX: Truncate deep nesting instead of throwing to prevent DoS\n   */\n  private sanitizeObject(obj: any, depth: number = 0): any {\n    // SECURITY FIX: Return safe default instead of throwing to prevent DoS attacks\n    // Previously: Threw error on deep nesting which could be exploited\n    // Now: Returns string representation for excessively nested objects\n    if (depth > 10) {\n      SecurityMonitor.logSecurityEvent({\n        type: 'CONTENT_SIZE_EXCEEDED',\n        severity: 'MEDIUM',\n        source: 'Template.sanitizeObject',\n        details: 'Object nesting depth exceeded, truncating to string representation'\n      });\n      return '[Object too deeply nested]';\n    }\n    \n    if (typeof obj !== 'object' || obj === null) {\n      return obj;\n    }\n    \n    if (Array.isArray(obj)) {\n      // SECURITY FIX: Limit array size to prevent memory exhaustion\n      const MAX_ARRAY_SIZE = 1000;\n      if (obj.length > MAX_ARRAY_SIZE) {\n        SecurityMonitor.logSecurityEvent({\n          type: 'CONTENT_SIZE_EXCEEDED',\n          severity: 'MEDIUM',\n          source: 'Template.sanitizeObject',\n          details: `Array size ${obj.length} exceeds maximum ${MAX_ARRAY_SIZE}, truncating`\n        });\n        obj = obj.slice(0, MAX_ARRAY_SIZE);\n      }\n      return obj.map((item: any) => this.sanitizeObject(item, depth + 1));\n    }\n    \n    const sanitized: Record<string, any> = {};\n    // SECURITY FIX: Limit number of object properties to prevent memory exhaustion\n    const MAX_OBJECT_KEYS = 100;\n    const entries = Object.entries(obj);\n    if (entries.length > MAX_OBJECT_KEYS) {\n      SecurityMonitor.logSecurityEvent({\n        type: 'CONTENT_SIZE_EXCEEDED',\n        severity: 'MEDIUM',\n        source: 'Template.sanitizeObject',\n        details: `Object has ${entries.length} keys, limiting to ${MAX_OBJECT_KEYS}`\n      });\n    }\n    \n    for (let i = 0; i < Math.min(entries.length, MAX_OBJECT_KEYS); i++) {\n      const [key, value] = entries[i];\n      const sanitizedKey = sanitizeInput(key, 50);\n      if (typeof value === 'string') {\n        sanitized[sanitizedKey] = sanitizeInput(value, 1000);\n      } else if (typeof value === 'object') {\n        sanitized[sanitizedKey] = this.sanitizeObject(value, depth + 1);\n      } else {\n        sanitized[sanitizedKey] = value;\n      }\n    }\n    \n    return sanitized;\n  }\n\n  /**\n   * Resolve nested variable paths (e.g., \"user.name\")\n   * TYPE SAFETY: Improved type safety for variable resolution\n   */\n  private resolveVariable(path: string, variables: Record<string, unknown>): unknown {\n    const parts = path.split('.');\n    let value: unknown = variables;\n    \n    for (const part of parts) {\n      if (value && typeof value === 'object' && value !== null && part in value) {\n        // Type assertion with runtime check - safe because we verified the property exists\n        value = (value as Record<string, unknown>)[part];\n      } else {\n        return undefined;\n      }\n    }\n    \n    return value;\n  }\n\n  /**\n   * Check if a regex pattern is potentially dangerous (ReDoS)\n   * SECURITY FIX: Detect patterns that could cause exponential backtracking\n   */\n  private isDangerousRegex(pattern: string): boolean {\n    // Check for nested quantifiers which can cause exponential backtracking\n    // SECURITY FIX: Use safe, specific patterns to detect dangerous regex constructs\n    // Previously: Used [^)]* patterns that could cause ReDoS in detection itself\n    // Now: Use safer, bounded character classes and specific string checks\n    // FIX: Use character class and remove unnecessary escape (SonarCloud S6035, S6535)\n    const dangerousPatterns = [\n      /[+*]{2,}/,                      // Multiple consecutive quantifiers\n      /\\(.{0,50}\\+\\)[+*]/,             // Quantified groups with quantifiers inside (bounded)\n      /\\[[^\\]]{0,20}\\+\\][+*]/,         // Quantified character classes with quantifiers (bounded)\n      /(\\\\[dws])\\1{2,}/,               // Repeated character classes\n      /\\(\\?<[!=][^)]{0,30}\\)/,         // Complex lookbehinds (bounded)\n    ];\n\n    // String-based checks for common catastrophic patterns (safer than regex)\n    const dangerousStringPatterns = [\n      '(.+)+',    // (.+)+ catastrophic backtracking\n      '(.*)++',   // (.*)++\n      '(.*)*',    // (.*)* catastrophic backtracking\n      '(.+)*',    // (.+)*\n      '(a+)+',    // (a+)+ type patterns\n      '(a*)*',    // (a*)* type patterns\n      '(a|a)*',   // Overlapping alternation\n      '(a|b)*+',  // Possessive quantifiers with alternation\n    ];\n    \n    // Check regex-based dangerous patterns\n    for (const dangerous of dangerousPatterns) {\n      if (dangerous.test(pattern)) {\n        return true;\n      }\n    }\n\n    // Check string-based dangerous patterns (safer than complex regex)\n    for (const dangerousString of dangerousStringPatterns) {\n      if (pattern.includes(dangerousString)) {\n        return true;\n      }\n    }\n\n    // Check for excessive backtracking potential\n    // Count groups and quantifiers (using safe, simple regex)\n    const groups = (pattern.match(/\\(/g) || []).length;\n    const quantifiers = (pattern.match(/[+*?{]/g) || []).length;\n\n    // If there are many groups and quantifiers, it's potentially dangerous\n    if (groups > 5 && quantifiers > 5) {\n      return true;\n    }\n    \n    return false;\n  }\n\n  /**\n   * Format a value for template output\n   */\n  private formatValue(value: any): string {\n    if (value === undefined || value === null) {\n      return '';\n    }\n    \n    if (value instanceof Date) {\n      return value.toISOString();\n    }\n    \n    if (Array.isArray(value)) {\n      return value.join(', ');\n    }\n    \n    if (typeof value === 'object') {\n      return JSON.stringify(value, null, 2);\n    }\n    \n    return String(value);\n  }\n\n  /**\n   * Process template includes\n   * SECURITY FIX #2: Safe include processing with path validation\n   * \n   * TODO: Implement actual include processing functionality\n   * This is currently a placeholder that validates the security model\n   * but does not actually load and render included templates.\n   * \n   * Future implementation should:\n   * 1. Load templates from validated paths\n   * 2. Render them with current variables\n   * 3. Replace include markers in content\n   * 4. Respect includeDepth limit\n   */\n  private async processIncludes(\n    content: string, \n    variables: Record<string, unknown>, \n    includeDepth: number\n  ): Promise<string> {\n    // TODO: Implement actual template include processing\n    // Current implementation only validates the security model\n    \n    if (!this.metadata.includes || this.metadata.includes.length === 0) {\n      return content;\n    }\n    \n    // Log security event for audit trail\n    SecurityMonitor.logSecurityEvent({\n      type: 'TEMPLATE_INCLUDE',\n      severity: 'LOW',\n      source: 'Template.processIncludes',\n      details: `Processing ${this.metadata.includes.length} includes at depth ${includeDepth}`\n    });\n    \n    // TODO: Future implementation would:\n    // for (const includePath of this.metadata.includes) {\n    //   const template = await this.loadIncludedTemplate(includePath);\n    //   const rendered = await template.render(variables, includeDepth + 1);\n    //   content = content.replace(`{{include:${includePath}}}`, rendered);\n    // }\n    \n    return content;\n  }\n\n  /**\n   * Template-specific validation\n   */\n  public override validate(): ElementValidationResult {\n    const result = super.validate();\n\n    // Capture arrays as locals so TypeScript knows they're always defined\n    // and call sites never need ! or inline ??= expressions (S1121, S6606).\n    const errors = result.errors ??= [];\n    const warnings = result.warnings ??= [];\n\n    // Content validation\n    if (!this.content || this.content.trim().length === 0) {\n      errors.push({\n        field: 'content',\n        message: 'Template content cannot be empty',\n        code: 'EMPTY_CONTENT'\n      });\n    }\n\n    // Check for unmatched tokens.\n    // Issue #705: In section mode, only count tokens within the <template> section —\n    // <style> and <script> sections are raw passthrough where }} is intentional.\n    // getSections() returns the cached result — no repeated regex execution.\n    const { isSectionMode, templateSection } = this.getSections();\n    const tokenCheckContent = isSectionMode ? templateSection : this.content;\n    const openTokens = (tokenCheckContent.match(/\\{\\{/g) || []).length;\n    const closeTokens = (tokenCheckContent.match(/\\}\\}/g) || []).length;\n    if (openTokens !== closeTokens) {\n      errors.push({\n        field: 'content',\n        message: 'Template has unmatched variable tokens',\n        code: 'UNMATCHED_TOKENS'\n      });\n    }\n\n    // Validate output format\n    const validFormats = ['markdown', 'html', 'json', 'yaml', 'text', 'xml'];\n    if (this.metadata.output_format && !validFormats.includes(this.metadata.output_format)) {\n      warnings.push({\n        field: 'output_format',\n        message: `Unknown output format '${this.metadata.output_format}'. Common formats: ${validFormats.join(', ')}`,\n        severity: 'low'\n      });\n    }\n\n    // Validate variables\n    if (this.metadata.variables) {\n      const variableNames = new Set<string>();\n\n      this.metadata.variables.forEach((variable, index) => {\n        // Check for duplicate names\n        if (variableNames.has(variable.name)) {\n          errors.push({\n            field: `variables[${index}].name`,\n            message: `Duplicate variable name '${variable.name}'`,\n            code: 'DUPLICATE_VARIABLE'\n          });\n        }\n        variableNames.add(variable.name);\n\n        // Validate regex patterns\n        if (variable.validation) {\n          try {\n            new RegExp(variable.validation);\n          } catch (e) {\n            errors.push({\n              field: `variables[${index}].validation`,\n              message: `Invalid regex pattern: ${e}`,\n              code: 'INVALID_REGEX'\n            });\n          }\n        }\n      });\n    }\n\n    // Check if all tokens have corresponding variable definitions\n    const compiled = this.compile();\n    const definedVars = new Set(this.metadata.variables?.map(v => v.name) || []);\n    const usedVars = new Set(compiled.tokens.map(t => t.variable));\n\n    usedVars.forEach(varName => {\n      if (!definedVars.has(varName)) {\n        warnings.push({\n          field: 'variables',\n          message: `Template uses undefined variable '${varName}'`,\n          severity: 'medium'\n        });\n      }\n    });\n    \n    // Warnings for best practices\n    // FIX: Remove unnecessary non-null assertion (SonarCloud S4325)\n    if (!this.metadata.tags || this.metadata.tags.length === 0) {\n      result.warnings.push({\n        field: 'tags',\n        message: 'Consider adding tags for better searchability',\n        severity: 'low'\n      });\n    }\n\n    if (!this.metadata.examples || this.metadata.examples.length === 0) {\n      result.warnings.push({\n        field: 'examples',\n        message: 'Adding examples improves template usability',\n        severity: 'medium'\n      });\n    }\n    \n    // Update the valid flag based on final errors\n    result.valid = (result.errors?.length || 0) === 0;\n    \n    return result;\n  }\n\n  /**\n   * Serialize to JSON format for internal use and testing\n   */\n  public override serializeToJSON(): string {\n    const data = {\n      id: this.id,\n      type: this.type,\n      version: this.version,\n      metadata: this.metadata,\n      content: this.content,\n      references: this.references,\n      extensions: this.extensions,\n      ratings: this.ratings\n    };\n    return JSON.stringify(data, null, 2);\n  }\n\n  /**\n   * Get content for serialization\n   */\n  protected override getContent(): string {\n    return this.content;\n  }\n\n  /**\n   * Serialize template to markdown format with YAML frontmatter\n   * FIX: Changed from JSON to markdown for GitHub portfolio compatibility\n   */\n  public override serialize(): string {\n    // Template content is already the main content\n    // Just use base class serialize which outputs markdown\n    return super.serialize();\n  }\n\n  /**\n   * Deserialize template from JSON format\n   */\n  public override deserialize(data: string): void {\n    try {\n      const parsed = JSON.parse(data);\n      \n      // Update metadata\n      this.metadata = { ...this.metadata, ...parsed.metadata };\n      \n      // Update content\n      this.content = parsed.content || '';\n      \n      // Update other properties\n      this.references = parsed.references || [];\n      this.extensions = parsed.extensions || {};\n      this.ratings = parsed.ratings || this.ratings;\n      \n      // Update ID and version if provided\n      if (parsed.id) this.id = parsed.id;\n      if (parsed.version) this.version = parsed.version;\n      \n      // Clear compiled template and section caches (content changed)\n      this.compiledTemplate = undefined;\n      this.parsedSections = undefined;\n\n      this._isDirty = true;\n      logger.debug(`Deserialized template: ${this.metadata.name}`);\n      \n    } catch (error) {\n      logger.error(`Failed to deserialize template: ${error}`);\n      throw ErrorHandler.wrapError(error, 'Template deserialization failed', ErrorCategory.SYSTEM_ERROR);\n    }\n  }\n\n  /**\n   * Get a preview of the template with sample data\n   */\n  async preview(): Promise<string> {\n    const sampleVars: Record<string, any> = {};\n    \n    // Generate sample data for each variable\n    for (const varDef of this.metadata.variables || []) {\n      switch (varDef.type) {\n        case 'string':\n          sampleVars[varDef.name] = varDef.default || `[${varDef.name}]`;\n          break;\n        case 'number':\n          sampleVars[varDef.name] = varDef.default || 42;\n          break;\n        case 'boolean':\n          sampleVars[varDef.name] = varDef.default || true;\n          break;\n        case 'date':\n          sampleVars[varDef.name] = varDef.default || new Date();\n          break;\n        case 'array':\n          sampleVars[varDef.name] = varDef.default || ['item1', 'item2'];\n          break;\n        case 'object':\n          sampleVars[varDef.name] = varDef.default || { key: 'value' };\n          break;\n      }\n    }\n    \n    return this.render(sampleVars);\n  }\n\n  /**\n   * Template activation lifecycle\n   */\n  public override async activate(): Promise<void> {\n    logger.info(`Activating template: ${this.metadata.name} (${this.id})`);\n    \n    // Compile the template to check for errors\n    this.compile();\n    \n    await super.activate?.();\n  }\n\n  /**\n   * Template deactivation lifecycle\n   */\n  public override async deactivate(): Promise<void> {\n    logger.info(`Deactivating template: ${this.metadata.name} (${this.id})`);\n    \n    // Clear compiled template and section caches\n    this.compiledTemplate = undefined;\n    this.parsedSections = undefined;\n\n    await super.deactivate?.();\n  }\n}\n\n// Internal types for template compilation\ninterface CompiledTemplate {\n  content: string;\n  tokens: TemplateToken[];\n  variables: TemplateVariable[];\n}\n\ninterface TemplateToken {\n  token: string;      // The full token including braces (e.g., \"{{ name }}\")\n  variable: string;   // The variable path (e.g., \"user.name\")\n  position: number;   // Position in the template string\n}"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TemplateManager.d.ts","sourceRoot":"","sources":["../../../src/elements/templates/TemplateManager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AASH,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAEpE,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AAGrF,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;AAItE,qBAAa,eAAgB,SAAQ,kBAAkB,CAAC,QAAQ,CAAC;IAW7D,OAAO,CAAC,eAAe;IAVzB,OAAO,CAAC,wBAAwB,CAA2B;IAC3D,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,OAAO,CAAC,oBAAoB,CAAuB;gBAGjD,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;IAI7B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAazC,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"TemplateManager.d.ts","sourceRoot":"","sources":["../../../src/elements/templates/TemplateManager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AASH,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAEpE,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AAGrF,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;AAItE,qBAAa,eAAgB,SAAQ,kBAAkB,CAAC,QAAQ,CAAC;IAW7D,OAAO,CAAC,eAAe;IAVzB,OAAO,CAAC,wBAAwB,CAA2B;IAC3D,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,OAAO,CAAC,oBAAoB,CAAuB;gBAGjD,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;IAI7B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAazC,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBzD,MAAM,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAahD,MAAM,CAAC,IAAI,EAAE;QACjB,IAAI,EAAE,MAAM,CAAC;QACb,WAAW,EAAE,MAAM,CAAC;QACpB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,QAAQ,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;KACtC,GAAG,OAAO,CAAC,QAAQ,CAAC;IAkEf,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAE,MAAM,GAAG,MAAM,GAAG,UAAuB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAuDjG,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,GAAE,MAAM,GAAG,MAAM,GAAG,UAAuB,GAAG,OAAO,CAAC,MAAM,CAAC;IA4CrG,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAMrD,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAM3C,WAAW,CAAC,KAAK,GAAE,MAAW,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAejD,gBAAgB,IAAI,MAAM;cAIV,aAAa,CAAC,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,gBAAgB,CAAC;cAOzD,aAAa,CAAC,QAAQ,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,GAAG,QAAQ;IAY3F,OAAO,CAAC,gBAAgB;cA4BC,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC;YA0BhE,gBAAgB;CAiF/B"}
|