@dollhousemcp/mcp-server 1.3.2 → 1.3.3

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.
Files changed (64) hide show
  1. package/README.md +87 -5
  2. package/dist/collection/ElementInstaller.d.ts.map +1 -1
  3. package/dist/collection/ElementInstaller.js +3 -7
  4. package/dist/elements/index.d.ts +0 -2
  5. package/dist/elements/index.d.ts.map +1 -1
  6. package/dist/elements/index.js +1 -3
  7. package/dist/elements/skills/Skill.d.ts.map +1 -1
  8. package/dist/elements/skills/Skill.js +3 -2
  9. package/dist/elements/skills/SkillManager.d.ts +83 -0
  10. package/dist/elements/skills/SkillManager.d.ts.map +1 -0
  11. package/dist/elements/skills/SkillManager.js +383 -0
  12. package/dist/elements/skills/index.d.ts +1 -0
  13. package/dist/elements/skills/index.d.ts.map +1 -1
  14. package/dist/elements/skills/index.js +2 -1
  15. package/dist/index.d.ts +51 -0
  16. package/dist/index.d.ts.map +1 -1
  17. package/dist/index.js +577 -3
  18. package/dist/portfolio/PortfolioManager.d.ts.map +1 -1
  19. package/dist/portfolio/PortfolioManager.js +1 -3
  20. package/dist/portfolio/types.d.ts +1 -3
  21. package/dist/portfolio/types.d.ts.map +1 -1
  22. package/dist/portfolio/types.js +1 -3
  23. package/dist/security/audit/config/suppressions.d.ts.map +1 -1
  24. package/dist/security/audit/config/suppressions.js +6 -1
  25. package/dist/server/ServerSetup.d.ts.map +1 -1
  26. package/dist/server/ServerSetup.js +5 -2
  27. package/dist/server/tools/CollectionTools.js +6 -6
  28. package/dist/server/tools/ElementTools.d.ts +11 -0
  29. package/dist/server/tools/ElementTools.d.ts.map +1 -0
  30. package/dist/server/tools/ElementTools.js +174 -0
  31. package/dist/server/tools/index.d.ts +1 -0
  32. package/dist/server/tools/index.d.ts.map +1 -1
  33. package/dist/server/tools/index.js +2 -1
  34. package/dist/server/types.d.ts +8 -0
  35. package/dist/server/types.d.ts.map +1 -1
  36. package/dist/server/types.js +1 -1
  37. package/package.json +1 -1
  38. package/dist/elements/ensembles/Ensemble.d.ts +0 -144
  39. package/dist/elements/ensembles/Ensemble.d.ts.map +0 -1
  40. package/dist/elements/ensembles/Ensemble.js +0 -860
  41. package/dist/elements/ensembles/EnsembleManager.d.ts +0 -85
  42. package/dist/elements/ensembles/EnsembleManager.d.ts.map +0 -1
  43. package/dist/elements/ensembles/EnsembleManager.js +0 -378
  44. package/dist/elements/ensembles/constants.d.ts +0 -73
  45. package/dist/elements/ensembles/constants.d.ts.map +0 -1
  46. package/dist/elements/ensembles/constants.js +0 -92
  47. package/dist/elements/ensembles/index.d.ts +0 -8
  48. package/dist/elements/ensembles/index.d.ts.map +0 -1
  49. package/dist/elements/ensembles/index.js +0 -8
  50. package/dist/elements/ensembles/types.d.ts +0 -92
  51. package/dist/elements/ensembles/types.d.ts.map +0 -1
  52. package/dist/elements/ensembles/types.js +0 -8
  53. package/dist/elements/memories/Memory.d.ts +0 -110
  54. package/dist/elements/memories/Memory.d.ts.map +0 -1
  55. package/dist/elements/memories/Memory.js +0 -470
  56. package/dist/elements/memories/MemoryManager.d.ts +0 -86
  57. package/dist/elements/memories/MemoryManager.d.ts.map +0 -1
  58. package/dist/elements/memories/MemoryManager.js +0 -435
  59. package/dist/elements/memories/constants.d.ts +0 -42
  60. package/dist/elements/memories/constants.d.ts.map +0 -1
  61. package/dist/elements/memories/constants.js +0 -49
  62. package/dist/elements/memories/index.d.ts +0 -6
  63. package/dist/elements/memories/index.d.ts.map +0 -1
  64. package/dist/elements/memories/index.js +0 -6
package/README.md CHANGED
@@ -23,7 +23,7 @@ A comprehensive Model Context Protocol (MCP) server that enables dynamic AI pers
23
23
  **🏪 Collection**: https://github.com/DollhouseMCP/collection
24
24
  **📦 NPM Package**: https://www.npmjs.com/package/@dollhousemcp/mcp-server
25
25
  **🌍 Website**: https://dollhousemcp.com (planned)
26
- **📦 Version**: v1.3.0 (Ready for NPM publish)
26
+ **📦 Version**: v1.3.3
27
27
 
28
28
  > **⚠️ Breaking Change Notice**: Tool names have changed from "marketplace" to "collection" terminology. Old names still work but are deprecated. See [Migration Guide](docs/MIGRATION_GUIDE_COLLECTION_RENAME.md) for details.
29
29
 
@@ -56,7 +56,7 @@ Restart Claude Desktop and you're ready to use DollhouseMCP! Try `list_personas`
56
56
 
57
57
  | Feature | Description |
58
58
  |---------|-------------|
59
- | 🎭 **23 MCP Tools** | Complete persona lifecycle management through chat interface |
59
+ | 🎭 **30 MCP Tools** | Complete portfolio element management through chat interface |
60
60
  | 🏪 **GitHub Collection** | Browse, search, install, and submit personas to community collection |
61
61
  | 👤 **User Identity System** | Environment-based attribution for persona creators |
62
62
  | 🆔 **Unique ID System** | Advanced ID generation: `{type}_{name}_{author}_{YYYYMMDD}-{HHMMSS}` |
@@ -66,6 +66,76 @@ Restart Claude Desktop and you're ready to use DollhouseMCP! Try `list_personas`
66
66
  | 🛡️ **Data Protection** | Copy-on-write for default personas, comprehensive backup system |
67
67
  | 🏠 **Local-First Architecture** | Full functionality without cloud dependency |
68
68
 
69
+ ## 🎨 Portfolio Customization Elements (NEW! v1.3.3)
70
+
71
+ DollhouseMCP introduces a comprehensive portfolio system for customizing AI behavior. Your portfolio is your personal collection of AI customization elements that enhance and tailor your AI experience.
72
+
73
+ ### Portfolio Element Types
74
+
75
+ | Element | Purpose | Status |
76
+ |---------|---------|--------|
77
+ | 🎭 **Personas** | Define AI personality, tone, and behavioral characteristics | ✅ Available |
78
+ | 🛠️ **Skills** | Add specific capabilities like code review, data analysis, or creative writing | ✅ Available |
79
+ | 📝 **Templates** | Create reusable response formats for emails, reports, documentation | ✅ Available |
80
+ | 🤖 **Agents** | Build autonomous assistants that can pursue goals and make decisions | ✅ Available |
81
+
82
+ ### Managing Your Portfolio
83
+
84
+ Use these new generic tools to manage any element type in your portfolio:
85
+
86
+ - **`list_elements`** - Browse your portfolio elements by type
87
+ - **`activate_element`** - Activate elements to customize AI behavior
88
+ - **`get_active_elements`** - View currently active customizations
89
+ - **`deactivate_element`** - Deactivate specific customizations
90
+ - **`get_element_details`** - Examine element configuration and metadata
91
+ - **`reload_elements`** - Refresh portfolio from filesystem
92
+
93
+ ### Specialized Element Tools
94
+
95
+ Some portfolio elements have specialized operations:
96
+
97
+ - **`render_template`** - Generate content using template elements with variables
98
+ - **`execute_agent`** - Deploy agent elements to accomplish specific goals
99
+
100
+ ### Portfolio Examples
101
+
102
+ ```
103
+ # Browse your skill portfolio
104
+ list_elements type="skills"
105
+
106
+ # Activate a code review skill
107
+ activate_element name="code-review" type="skills"
108
+
109
+ # Activate a professional email template
110
+ activate_element name="email-professional" type="templates"
111
+
112
+ # Use a template to generate content
113
+ render_template name="project-update" variables='{"project": "DollhouseMCP", "status": "Released"}'
114
+
115
+ # Deploy an agent for a specific task
116
+ execute_agent name="project-manager" goal="Create a sprint plan for next week"
117
+ ```
118
+
119
+ ### Portfolio Structure
120
+
121
+ Your portfolio lives in `~/.dollhouse/portfolio/` with elements organized by type:
122
+
123
+ ```
124
+ ~/.dollhouse/portfolio/
125
+ ├── personas/ # Personality and behavior profiles
126
+ ├── skills/ # Specialized capabilities
127
+ ├── templates/ # Reusable content structures
128
+ └── agents/ # Autonomous assistants
129
+ ```
130
+
131
+ ### Legacy Persona Tools
132
+
133
+ For backward compatibility, the original persona-specific tools still work:
134
+ - `list_personas` → calls `list_elements type="personas"`
135
+ - `activate_persona` → calls `activate_element type="personas"`
136
+ - `get_active_persona` → calls `get_active_elements type="personas"`
137
+ - etc.
138
+
69
139
  ## 🔒 Enterprise-Grade Security (v1.2.4)
70
140
 
71
141
  DollhouseMCP implements comprehensive security measures to protect your personas and system:
@@ -195,11 +265,23 @@ Add DollhouseMCP to your Claude Desktop configuration:
195
265
  **🔄 After configuration:**
196
266
  1. Save the file
197
267
  2. Restart Claude Desktop completely
198
- 3. All 23 DollhouseMCP tools will be available
268
+ 3. All 30 DollhouseMCP tools will be available
269
+
270
+ ## 🛠️ Available Tools (30 Total)
271
+
272
+ ### Portfolio Element Management (NEW!)
273
+ - **`list_elements`** - List all elements of a specific type
274
+ - **`activate_element`** - Activate an element by name and type
275
+ - **`get_active_elements`** - Get currently active elements of a type
276
+ - **`deactivate_element`** - Deactivate a specific element
277
+ - **`get_element_details`** - View detailed information about an element
278
+ - **`reload_elements`** - Refresh elements from filesystem
199
279
 
200
- ## 🛠️ Available Tools (23 Total)
280
+ ### Element-Specific Operations (NEW!)
281
+ - **`render_template`** - Render a template element with provided variables
282
+ - **`execute_agent`** - Execute an agent element with a specific goal
201
283
 
202
- ### Core Persona Management
284
+ ### Core Persona Management (Legacy - Still Supported)
203
285
  - **`list_personas`** - Display all local personas with enhanced metadata
204
286
  - **`activate_persona`** - Activate by name, filename, or unique ID
205
287
  - **`get_active_persona`** - Get current persona information
@@ -1 +1 @@
1
- {"version":3,"file":"ElementInstaller.d.ts","sourceRoot":"","sources":["../../src/collection/ElementInstaller.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAMjE,OAAO,EAAoB,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAEjF,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,OAAO,CAAmE;gBAEtE,YAAY,EAAE,YAAY;IAKtC;;;OAGG;IACG,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC;QAC/C,OAAO,EAAE,OAAO,CAAC;QACjB,OAAO,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,gBAAgB,CAAC;QAC5B,WAAW,CAAC,EAAE,WAAW,CAAC;QAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;IA+FF;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAkBhC;;OAEG;IACH,oBAAoB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,MAAM;CAmBrG"}
1
+ {"version":3,"file":"ElementInstaller.d.ts","sourceRoot":"","sources":["../../src/collection/ElementInstaller.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAMjE,OAAO,EAAoB,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAEjF,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,OAAO,CAAmE;gBAEtE,YAAY,EAAE,YAAY;IAKtC;;;OAGG;IACG,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC;QAC/C,OAAO,EAAE,OAAO,CAAC;QACjB,OAAO,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,gBAAgB,CAAC;QAC5B,WAAW,CAAC,EAAE,WAAW,CAAC;QAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;IA+FF;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAgBhC;;OAEG;IACH,oBAAoB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,MAAM;CAiBrG"}
@@ -108,9 +108,7 @@ export class ElementInstaller {
108
108
  'personas': ElementType.PERSONA,
109
109
  'skills': ElementType.SKILL,
110
110
  'templates': ElementType.TEMPLATE,
111
- 'agents': ElementType.AGENT,
112
- 'memories': ElementType.MEMORY,
113
- 'ensembles': ElementType.ENSEMBLE
111
+ 'agents': ElementType.AGENT
114
112
  };
115
113
  const elementType = typeMap[typeStr];
116
114
  if (!elementType) {
@@ -126,9 +124,7 @@ export class ElementInstaller {
126
124
  [ElementType.PERSONA]: '🎭',
127
125
  [ElementType.SKILL]: '🎯',
128
126
  [ElementType.TEMPLATE]: '📄',
129
- [ElementType.AGENT]: '🤖',
130
- [ElementType.MEMORY]: '🧠',
131
- [ElementType.ENSEMBLE]: '🎼'
127
+ [ElementType.AGENT]: '🤖'
132
128
  };
133
129
  const emoji = typeEmojis[elementType] || '📦';
134
130
  const typeName = elementType.charAt(0).toUpperCase() + elementType.slice(1);
@@ -139,4 +135,4 @@ export class ElementInstaller {
139
135
  `🚀 **Ready to use!**`;
140
136
  }
141
137
  }
142
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ElementInstaller.js","sourceRoot":"","sources":["../../src/collection/ElementInstaller.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Install AI customization elements from collection\n * Supports all element types: personas, skills, templates, agents, memories, ensembles\n */\n\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { GitHubClient } from './GitHubClient.js';\nimport { IElementMetadata } from '../types/elements/IElement.js';\nimport { validatePath, validateFilename, validateContentSize } from '../security/InputValidator.js';\nimport { SECURITY_LIMITS } from '../security/constants.js';\nimport { ContentValidator } from '../security/contentValidator.js';\nimport { SecureYamlParser } from '../security/secureYamlParser.js';\nimport { SecurityError } from '../errors/SecurityError.js';\nimport { PortfolioManager, ElementType } from '../portfolio/PortfolioManager.js';\n\nexport class ElementInstaller {\n  private githubClient: GitHubClient;\n  private portfolioManager: PortfolioManager;\n  private baseUrl = 'https://api.github.com/repos/DollhouseMCP/collection/contents';\n  \n  constructor(githubClient: GitHubClient) {\n    this.githubClient = githubClient;\n    this.portfolioManager = PortfolioManager.getInstance();\n  }\n  \n  /**\n   * Install AI customization element from the collection\n   * Automatically detects element type from path structure\n   */\n  async installContent(inputPath: string): Promise<{ \n    success: boolean; \n    message: string;\n    metadata?: IElementMetadata;\n    elementType?: ElementType;\n    filename?: string;\n  }> {\n    // Validate and sanitize the input path\n    const sanitizedPath = validatePath(inputPath);\n    \n    // Detect element type from path structure\n    // Expected format: library/[element-type]/[category]/[element].md\n    const pathParts = sanitizedPath.split('/');\n    if (pathParts.length < 3 || pathParts[0] !== 'library') {\n      throw new Error('Invalid collection path format. Expected: library/[element-type]/[category]/[element].md');\n    }\n    \n    const elementTypeStr = pathParts[1];\n    const elementType = this.getElementTypeFromString(elementTypeStr);\n    \n    // Ensure the path ends with .md\n    if (!sanitizedPath.endsWith('.md')) {\n      throw new Error('Invalid file type. Only .md files are allowed.');\n    }\n    \n    const url = `${this.baseUrl}/${sanitizedPath}`;\n    const data = await this.githubClient.fetchFromGitHub(url);\n    \n    if (data.type !== 'file') {\n      throw new Error('Path does not point to a file');\n    }\n    \n    // Check file size before downloading\n    if (data.size > SECURITY_LIMITS.MAX_PERSONA_SIZE_BYTES) {\n      throw new Error(`File too large (${data.size} bytes, max ${SECURITY_LIMITS.MAX_PERSONA_SIZE_BYTES} bytes)`);\n    }\n    \n    // Decode Base64 content\n    const content = Buffer.from(data.content, 'base64').toString('utf-8');\n    \n    // Validate content size after decoding\n    validateContentSize(content, SECURITY_LIMITS.MAX_PERSONA_SIZE_BYTES);\n    \n    // Sanitize content for security threats\n    const sanitizedContent = ContentValidator.sanitizePersonaContent(content);\n    \n    // Use secure YAML parser\n    let parsed;\n    try {\n      parsed = SecureYamlParser.safeMatter(sanitizedContent);\n    } catch (error) {\n      if (error instanceof SecurityError) {\n        throw new Error(`Security threat in content: ${error.message}`);\n      }\n      throw error;\n    }\n    \n    const metadata = parsed.data as IElementMetadata;\n    \n    // Additional metadata validation for injection attacks\n    const metadataValidation = ContentValidator.validateMetadata(metadata);\n    if (!metadataValidation.isValid) {\n      throw new Error(`Security validation failed: ${metadataValidation.detectedPatterns?.join(', ')}`);\n    }\n    \n    // Validate metadata\n    if (!metadata.name || !metadata.description) {\n      throw new Error('Invalid content: missing required name or description');\n    }\n    \n    // Generate and validate local filename\n    const originalFilename = sanitizedPath.split('/').pop() || 'downloaded-element.md';\n    const filename = validateFilename(originalFilename);\n    \n    // Get appropriate directory for element type\n    const elementDir = this.portfolioManager.getElementDir(elementType);\n    const localPath = path.join(elementDir, filename);\n    \n    // Check if file already exists\n    try {\n      await fs.access(localPath);\n      return {\n        success: false,\n        message: `AI customization element already exists: ${filename}\\n\\nThe element has already been installed.`\n      };\n    } catch {\n      // File doesn't exist, proceed with installation\n    }\n    \n    // Write the sanitized file\n    await fs.writeFile(localPath, sanitizedContent, 'utf-8');\n    \n    return {\n      success: true,\n      message: `AI customization element installed successfully!`,\n      metadata,\n      filename,\n      elementType\n    };\n  }\n  \n  /**\n   * Get ElementType from string\n   */\n  private getElementTypeFromString(typeStr: string): ElementType {\n    const typeMap: Record<string, ElementType> = {\n      'personas': ElementType.PERSONA,\n      'skills': ElementType.SKILL,\n      'templates': ElementType.TEMPLATE,\n      'agents': ElementType.AGENT,\n      'memories': ElementType.MEMORY,\n      'ensembles': ElementType.ENSEMBLE\n    };\n    \n    const elementType = typeMap[typeStr];\n    if (!elementType) {\n      throw new Error(`Unknown element type: ${typeStr}. Valid types: ${Object.keys(typeMap).join(', ')}`);\n    }\n    \n    return elementType;\n  }\n  \n  /**\n   * Format installation success message\n   */\n  formatInstallSuccess(metadata: IElementMetadata, filename: string, elementType: ElementType): string {\n    const typeEmojis: Record<ElementType, string> = {\n      [ElementType.PERSONA]: '🎭',\n      [ElementType.SKILL]: '🎯',\n      [ElementType.TEMPLATE]: '📄',\n      [ElementType.AGENT]: '🤖',\n      [ElementType.MEMORY]: '🧠',\n      [ElementType.ENSEMBLE]: '🎼'\n    };\n    \n    const emoji = typeEmojis[elementType] || '📦';\n    const typeName = elementType.charAt(0).toUpperCase() + elementType.slice(1);\n    \n    return `✅ **AI Customization Element Installed Successfully!**\\n\\n` +\n      `${emoji} **${metadata.name}** ${metadata.author ? `by ${metadata.author}` : ''}\\n` +\n      `📁 Type: ${typeName}\\n` +\n      `📄 Saved as: ${filename}\\n\\n` +\n      `🚀 **Ready to use!**`;\n  }\n}"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ElementInstaller.js","sourceRoot":"","sources":["../../src/collection/ElementInstaller.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Install AI customization elements from collection\n * Supports all element types: personas, skills, templates, agents, memories, ensembles\n */\n\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { GitHubClient } from './GitHubClient.js';\nimport { IElementMetadata } from '../types/elements/IElement.js';\nimport { validatePath, validateFilename, validateContentSize } from '../security/InputValidator.js';\nimport { SECURITY_LIMITS } from '../security/constants.js';\nimport { ContentValidator } from '../security/contentValidator.js';\nimport { SecureYamlParser } from '../security/secureYamlParser.js';\nimport { SecurityError } from '../errors/SecurityError.js';\nimport { PortfolioManager, ElementType } from '../portfolio/PortfolioManager.js';\n\nexport class ElementInstaller {\n  private githubClient: GitHubClient;\n  private portfolioManager: PortfolioManager;\n  private baseUrl = 'https://api.github.com/repos/DollhouseMCP/collection/contents';\n  \n  constructor(githubClient: GitHubClient) {\n    this.githubClient = githubClient;\n    this.portfolioManager = PortfolioManager.getInstance();\n  }\n  \n  /**\n   * Install AI customization element from the collection\n   * Automatically detects element type from path structure\n   */\n  async installContent(inputPath: string): Promise<{ \n    success: boolean; \n    message: string;\n    metadata?: IElementMetadata;\n    elementType?: ElementType;\n    filename?: string;\n  }> {\n    // Validate and sanitize the input path\n    const sanitizedPath = validatePath(inputPath);\n    \n    // Detect element type from path structure\n    // Expected format: library/[element-type]/[category]/[element].md\n    const pathParts = sanitizedPath.split('/');\n    if (pathParts.length < 3 || pathParts[0] !== 'library') {\n      throw new Error('Invalid collection path format. Expected: library/[element-type]/[category]/[element].md');\n    }\n    \n    const elementTypeStr = pathParts[1];\n    const elementType = this.getElementTypeFromString(elementTypeStr);\n    \n    // Ensure the path ends with .md\n    if (!sanitizedPath.endsWith('.md')) {\n      throw new Error('Invalid file type. Only .md files are allowed.');\n    }\n    \n    const url = `${this.baseUrl}/${sanitizedPath}`;\n    const data = await this.githubClient.fetchFromGitHub(url);\n    \n    if (data.type !== 'file') {\n      throw new Error('Path does not point to a file');\n    }\n    \n    // Check file size before downloading\n    if (data.size > SECURITY_LIMITS.MAX_PERSONA_SIZE_BYTES) {\n      throw new Error(`File too large (${data.size} bytes, max ${SECURITY_LIMITS.MAX_PERSONA_SIZE_BYTES} bytes)`);\n    }\n    \n    // Decode Base64 content\n    const content = Buffer.from(data.content, 'base64').toString('utf-8');\n    \n    // Validate content size after decoding\n    validateContentSize(content, SECURITY_LIMITS.MAX_PERSONA_SIZE_BYTES);\n    \n    // Sanitize content for security threats\n    const sanitizedContent = ContentValidator.sanitizePersonaContent(content);\n    \n    // Use secure YAML parser\n    let parsed;\n    try {\n      parsed = SecureYamlParser.safeMatter(sanitizedContent);\n    } catch (error) {\n      if (error instanceof SecurityError) {\n        throw new Error(`Security threat in content: ${error.message}`);\n      }\n      throw error;\n    }\n    \n    const metadata = parsed.data as IElementMetadata;\n    \n    // Additional metadata validation for injection attacks\n    const metadataValidation = ContentValidator.validateMetadata(metadata);\n    if (!metadataValidation.isValid) {\n      throw new Error(`Security validation failed: ${metadataValidation.detectedPatterns?.join(', ')}`);\n    }\n    \n    // Validate metadata\n    if (!metadata.name || !metadata.description) {\n      throw new Error('Invalid content: missing required name or description');\n    }\n    \n    // Generate and validate local filename\n    const originalFilename = sanitizedPath.split('/').pop() || 'downloaded-element.md';\n    const filename = validateFilename(originalFilename);\n    \n    // Get appropriate directory for element type\n    const elementDir = this.portfolioManager.getElementDir(elementType);\n    const localPath = path.join(elementDir, filename);\n    \n    // Check if file already exists\n    try {\n      await fs.access(localPath);\n      return {\n        success: false,\n        message: `AI customization element already exists: ${filename}\\n\\nThe element has already been installed.`\n      };\n    } catch {\n      // File doesn't exist, proceed with installation\n    }\n    \n    // Write the sanitized file\n    await fs.writeFile(localPath, sanitizedContent, 'utf-8');\n    \n    return {\n      success: true,\n      message: `AI customization element installed successfully!`,\n      metadata,\n      filename,\n      elementType\n    };\n  }\n  \n  /**\n   * Get ElementType from string\n   */\n  private getElementTypeFromString(typeStr: string): ElementType {\n    const typeMap: Record<string, ElementType> = {\n      'personas': ElementType.PERSONA,\n      'skills': ElementType.SKILL,\n      'templates': ElementType.TEMPLATE,\n      'agents': ElementType.AGENT\n    };\n    \n    const elementType = typeMap[typeStr];\n    if (!elementType) {\n      throw new Error(`Unknown element type: ${typeStr}. Valid types: ${Object.keys(typeMap).join(', ')}`);\n    }\n    \n    return elementType;\n  }\n  \n  /**\n   * Format installation success message\n   */\n  formatInstallSuccess(metadata: IElementMetadata, filename: string, elementType: ElementType): string {\n    const typeEmojis: Record<ElementType, string> = {\n      [ElementType.PERSONA]: '🎭',\n      [ElementType.SKILL]: '🎯',\n      [ElementType.TEMPLATE]: '📄',\n      [ElementType.AGENT]: '🤖'\n    };\n    \n    const emoji = typeEmojis[elementType] || '📦';\n    const typeName = elementType.charAt(0).toUpperCase() + elementType.slice(1);\n    \n    return `✅ **AI Customization Element Installed Successfully!**\\n\\n` +\n      `${emoji} **${metadata.name}** ${metadata.author ? `by ${metadata.author}` : ''}\\n` +\n      `📁 Type: ${typeName}\\n` +\n      `📄 Saved as: ${filename}\\n\\n` +\n      `🚀 **Ready to use!**`;\n  }\n}"]}
@@ -6,6 +6,4 @@ export * from './FeedbackProcessor.js';
6
6
  export * from './agents/index.js';
7
7
  export * from './templates/index.js';
8
8
  export * from './skills/index.js';
9
- export * from './memories/index.js';
10
- export * from './ensembles/index.js';
11
9
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/elements/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,kBAAkB,CAAC;AACjC,cAAc,wBAAwB,CAAC;AAGvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/elements/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,kBAAkB,CAAC;AACjC,cAAc,wBAAwB,CAAC;AAGvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC"}
@@ -7,6 +7,4 @@ export * from './FeedbackProcessor.js';
7
7
  export * from './agents/index.js';
8
8
  export * from './templates/index.js';
9
9
  export * from './skills/index.js';
10
- export * from './memories/index.js';
11
- export * from './ensembles/index.js';
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZWxlbWVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsd0JBQXdCLENBQUM7QUFFdkMsdUJBQXVCO0FBQ3ZCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ2VudHJhbCBleHBvcnQgZm9yIGVsZW1lbnQgaW1wbGVtZW50YXRpb25zLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vQmFzZUVsZW1lbnQuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9GZWVkYmFja1Byb2Nlc3Nvci5qcyc7XG5cbi8vIEVsZW1lbnQgdHlwZSBleHBvcnRzXG5leHBvcnQgKiBmcm9tICcuL2FnZW50cy9pbmRleC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL3RlbXBsYXRlcy9pbmRleC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL3NraWxscy9pbmRleC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL21lbW9yaWVzL2luZGV4LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vZW5zZW1ibGVzL2luZGV4LmpzJzsiXX0=
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZWxlbWVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsd0JBQXdCLENBQUM7QUFFdkMsdUJBQXVCO0FBQ3ZCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDZW50cmFsIGV4cG9ydCBmb3IgZWxlbWVudCBpbXBsZW1lbnRhdGlvbnMuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9CYXNlRWxlbWVudC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL0ZlZWRiYWNrUHJvY2Vzc29yLmpzJztcblxuLy8gRWxlbWVudCB0eXBlIGV4cG9ydHNcbmV4cG9ydCAqIGZyb20gJy4vYWdlbnRzL2luZGV4LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdGVtcGxhdGVzL2luZGV4LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vc2tpbGxzL2luZGV4LmpzJzsiXX0=
@@ -1 +1 @@
1
- {"version":3,"file":"Skill.d.ts","sourceRoot":"","sources":["../../../src/elements/skills/Skill.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,MAAM,+BAA+B,CAAC;AAQpG,MAAM,WAAW,aAAc,SAAQ,gBAAgB;IACrD,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,CAAC,EAAE,UAAU,GAAG,cAAc,GAAG,UAAU,GAAG,QAAQ,CAAC;IACjE,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,UAAU,CAAC,EAAE,cAAc,EAAE,CAAC;IAC9B,QAAQ,CAAC,EAAE,YAAY,EAAE,CAAC;IAC1B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,MAAM,CAAC;IAC/C,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,MAAM,CAAC,EAAE,GAAG,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,qBAAa,KAAM,SAAQ,WAAY,YAAW,QAAQ;IACzC,QAAQ,EAAE,aAAa,CAAC;IAChC,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAa;IAKhD,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAO;IAC3C,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAS;gBAEhC,QAAQ,EAAE,OAAO,CAAC,aAAa,CAAC,EAAE,YAAY,GAAE,MAAW;IA0CvE;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAU5B;;;;;OAKG;IACH,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,IAAI;IA0E5C;;OAEG;IACH,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,GAAG;IAI/B;;OAEG;IACH,gBAAgB,IAAI,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAIvC;;OAEG;IACH,OAAO,CAAC,sBAAsB;IAmB9B;;OAEG;IACG,OAAO,CAAC,KAAK,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;IAwBxC;;OAEG;IACa,QAAQ,IAAI,uBAAuB;IAiFnD;;OAEG;IACa,SAAS,IAAI,MAAM;IAgBnC;;OAEG;IACa,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAkC/C;;OAEG;IACmB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAY/C;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,KAAK;IAkBjD;;;;OAIG;IACmB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAUjD;;;;;OAKG;IACH,eAAe,IAAI,IAAI;CAIxB"}
1
+ {"version":3,"file":"Skill.d.ts","sourceRoot":"","sources":["../../../src/elements/skills/Skill.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,MAAM,+BAA+B,CAAC;AAQpG,MAAM,WAAW,aAAc,SAAQ,gBAAgB;IACrD,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,CAAC,EAAE,UAAU,GAAG,cAAc,GAAG,UAAU,GAAG,QAAQ,CAAC;IACjE,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,UAAU,CAAC,EAAE,cAAc,EAAE,CAAC;IAC9B,QAAQ,CAAC,EAAE,YAAY,EAAE,CAAC;IAC1B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,MAAM,CAAC;IAC/C,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,MAAM,CAAC,EAAE,GAAG,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,qBAAa,KAAM,SAAQ,WAAY,YAAW,QAAQ;IACzC,QAAQ,EAAE,aAAa,CAAC;IAChC,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAa;IAKhD,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAO;IAC3C,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAS;gBAEhC,QAAQ,EAAE,OAAO,CAAC,aAAa,CAAC,EAAE,YAAY,GAAE,MAAW;IA2CvE;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAU5B;;;;;OAKG;IACH,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,IAAI;IA0E5C;;OAEG;IACH,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,GAAG;IAI/B;;OAEG;IACH,gBAAgB,IAAI,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAIvC;;OAEG;IACH,OAAO,CAAC,sBAAsB;IAmB9B;;OAEG;IACG,OAAO,CAAC,KAAK,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;IAwBxC;;OAEG;IACa,QAAQ,IAAI,uBAAuB;IAiFnD;;OAEG;IACa,SAAS,IAAI,MAAM;IAgBnC;;OAEG;IACa,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAkC/C;;OAEG;IACmB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAY/C;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,KAAK;IAkBjD;;;;OAIG;IACmB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAUjD;;;;;OAKG;IACH,eAAe,IAAI,IAAI;CAIxB"}
@@ -36,7 +36,8 @@ export class Skill extends BaseElement {
36
36
  description: metadata.description ? sanitizeInput(UnicodeValidator.normalize(metadata.description).normalizedContent, 500) : undefined
37
37
  };
38
38
  super(ElementType.SKILL, sanitizedMetadata);
39
- this.instructions = instructions ? sanitizeInput(UnicodeValidator.normalize(instructions).normalizedContent, 10000) : '';
39
+ // Ensure instructions is always a string, even if empty
40
+ this.instructions = instructions && instructions.trim() ? sanitizeInput(UnicodeValidator.normalize(instructions).normalizedContent, 10000) : '';
40
41
  // Ensure skill-specific metadata
41
42
  this.metadata = {
42
43
  ...this.metadata,
@@ -378,4 +379,4 @@ export class Skill extends BaseElement {
378
379
  logger.debug(`Cleared all parameters for skill: ${this.metadata.name}`);
379
380
  }
380
381
  }
381
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Skill.js","sourceRoot":"","sources":["../../../src/elements/skills/Skill.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Skill element class implementing IElement interface.\n * Represents a discrete capability for specific tasks.\n * \n * SECURITY FIXES IMPLEMENTED (PR #319):\n * 1. CRITICAL: Added comprehensive input validation for all skill parameters\n * 2. MEDIUM: Implemented Unicode normalization to prevent homograph attacks\n * 3. MEDIUM: Added audit logging for security events via SecurityMonitor\n * 4. MEDIUM: Implemented memory management to prevent unbounded growth\n * 5. MEDIUM: Added XSS protection through input sanitization\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 { sanitizeInput, validatePath } from '../../security/InputValidator.js';\nimport { UnicodeValidator } from '../../security/validators/unicodeValidator.js';\nimport { SecurityMonitor } from '../../security/securityMonitor.js';\n\n// Extend IElementMetadata with skill-specific fields\nexport interface SkillMetadata extends IElementMetadata {\n  languages?: string[];           // Programming/spoken languages this skill works with\n  complexity?: 'beginner' | 'intermediate' | 'advanced' | 'expert';\n  domains?: string[];             // Domain categories (e.g., web-dev, data-science, writing)\n  prerequisites?: string[];       // Required knowledge or other skills\n  parameters?: SkillParameter[];  // Configurable parameters\n  examples?: SkillExample[];      // Usage examples\n  certification?: string;         // External certification or validation\n  proficiency_level?: number;     // 1-100 proficiency level\n}\n\nexport interface SkillParameter {\n  name: string;\n  type: 'string' | 'number' | 'boolean' | 'enum';\n  description: string;\n  required?: boolean;\n  default?: any;\n  options?: string[];  // For enum type\n  min?: number;        // For number type\n  max?: number;        // For number type\n}\n\nexport interface SkillExample {\n  title: string;\n  description: string;\n  input?: any;\n  output?: any;\n  code?: string;\n}\n\nexport class Skill extends BaseElement implements IElement {\n  public declare metadata: SkillMetadata;\n  public instructions: string;\n  public parameters: Map<string, any> = new Map();\n  \n  // SECURITY FIX #4: Memory management constants to prevent unbounded growth\n  // Previously: No limits on parameter storage, could lead to memory exhaustion\n  // Now: Enforced limits on both count and size\n  private readonly MAX_PARAMETER_COUNT = 100;\n  private readonly MAX_PARAMETER_SIZE = 10000; // Max size per parameter value\n\n  constructor(metadata: Partial<SkillMetadata>, instructions: string = '') {\n    // SECURITY FIX #2: Validate and sanitize ALL metadata fields\n    // Previously: metadata was used directly without validation\n    // Now: All string inputs are Unicode normalized and sanitized to prevent:\n    // - XSS attacks through malicious metadata\n    // - Unicode homograph attacks\n    // - Buffer overflow attempts\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    };\n    \n    super(ElementType.SKILL, sanitizedMetadata);\n    this.instructions = instructions ? sanitizeInput(UnicodeValidator.normalize(instructions).normalizedContent, 10000) : '';\n    \n    // Ensure skill-specific metadata\n    this.metadata = {\n      ...this.metadata,\n      languages: metadata.languages || [],\n      complexity: metadata.complexity || 'beginner',\n      domains: metadata.domains || [],\n      prerequisites: metadata.prerequisites || [],\n      parameters: metadata.parameters || [],\n      examples: metadata.examples || [],\n      proficiency_level: metadata.proficiency_level || 0\n    };\n\n    // Validate parameter definitions\n    if (this.metadata.parameters) {\n      this.metadata.parameters = this.metadata.parameters.map(param => ({\n        ...param,\n        name: sanitizeInput(UnicodeValidator.normalize(param.name).normalizedContent, 50),\n        description: sanitizeInput(UnicodeValidator.normalize(param.description).normalizedContent, 200),\n        options: param.options?.map(opt => sanitizeInput(opt, 100))\n      }));\n    }\n\n    // Initialize parameter values with defaults\n    this.initializeParameters();\n  }\n\n  /**\n   * Initialize parameters with default values\n   */\n  private initializeParameters(): void {\n    if (this.metadata.parameters) {\n      this.metadata.parameters.forEach(param => {\n        if (param.default !== undefined) {\n          this.parameters.set(param.name, param.default);\n        }\n      });\n    }\n  }\n\n  /**\n   * Set a parameter value\n   * SECURITY FIX #1: Comprehensive input validation for all skill parameters\n   * Previously: Parameters were set without validation, creating security risks\n   * Now: Full validation pipeline including sanitization, type checking, and size limits\n   */\n  setParameter(name: string, value: any): void {\n    // CRITICAL FIX: Sanitize parameter name to prevent injection attacks\n    const sanitizedName = sanitizeInput(name, 50);\n    \n    const param = this.metadata.parameters?.find(p => p.name === sanitizedName);\n    if (!param) {\n      // SECURITY FIX #3: Log audit events for security monitoring\n      // This helps detect potential attack patterns or misconfigurations\n      SecurityMonitor.logSecurityEvent({\n        type: 'YAML_PARSING_WARNING',\n        severity: 'MEDIUM',\n        source: 'Skill.setParameter',\n        details: `Attempt to set unknown parameter: ${sanitizedName} for skill: ${this.metadata.name}`\n      });\n      throw new Error(`Parameter '${sanitizedName}' not found in skill definition`);\n    }\n\n    // CRITICAL FIX: Sanitize and validate the value based on type\n    let sanitizedValue = value;\n    \n    if (param.type === 'string') {\n      // SECURITY FIX #2 & #5: Normalize Unicode and sanitize string values\n      // Previously: String values were used directly without validation\n      // Now: Full validation pipeline:\n      // 1. Unicode normalization prevents homograph attacks\n      // 2. sanitizeInput() strips dangerous HTML/JS content\n      // 3. Length limits prevent buffer overflow attacks\n      const normalized = UnicodeValidator.normalize(String(value));\n      sanitizedValue = sanitizeInput(normalized.normalizedContent, param.max || 1000);\n      \n      // SECURITY FIX #5: Additional XSS protection\n      // Check for common XSS patterns even after sanitization\n      // This provides defense-in-depth against sophisticated attacks\n      if (sanitizedValue.includes('<script') || sanitizedValue.includes('javascript:')) {\n        // SECURITY FIX #3: Log high-severity security events\n        SecurityMonitor.logSecurityEvent({\n          type: 'CONTENT_INJECTION_ATTEMPT',\n          severity: 'HIGH',\n          source: 'Skill.setParameter',\n          details: `Potential XSS attempt in skill parameter: ${sanitizedName} for skill: ${this.metadata.name}`\n        });\n        throw new Error('Invalid characters in parameter value');\n      }\n    }\n\n    // Type validation\n    if (!this.validateParameterValue(param, sanitizedValue)) {\n      throw new Error(`Invalid value for parameter '${sanitizedName}': expected ${param.type}`);\n    }\n\n    // SECURITY FIX #4: Memory management - check parameter count\n    // Previously: No limits on parameter storage, could lead to memory exhaustion attacks\n    // Now: Enforced limits prevent attackers from consuming unlimited memory\n    if (this.parameters.size >= this.MAX_PARAMETER_COUNT && !this.parameters.has(sanitizedName)) {\n      // SECURITY FIX #3: Log rate limit violations for security monitoring\n      SecurityMonitor.logSecurityEvent({\n        type: 'RATE_LIMIT_EXCEEDED',\n        severity: 'MEDIUM',\n        source: 'Skill.setParameter',\n        details: `Parameter limit exceeded for skill: ${this.metadata.name}. Max: ${this.MAX_PARAMETER_COUNT}`\n      });\n      throw new Error(`Parameter limit exceeded. Maximum ${this.MAX_PARAMETER_COUNT} parameters allowed`);\n    }\n    \n    // SECURITY FIX #4: Check parameter value size for strings\n    // This prevents attackers from storing massive strings that could exhaust memory\n    if (param.type === 'string' && sanitizedValue.length > this.MAX_PARAMETER_SIZE) {\n      throw new Error(`Parameter value too large. Maximum ${this.MAX_PARAMETER_SIZE} characters allowed`);\n    }\n\n    this.parameters.set(sanitizedName, sanitizedValue);\n    logger.debug(`Set parameter ${sanitizedName} = ${sanitizedValue} for skill ${this.metadata.name}`);\n  }\n\n  /**\n   * Get a parameter value\n   */\n  getParameter(name: string): any {\n    return this.parameters.get(name);\n  }\n\n  /**\n   * Get all parameters as object\n   */\n  getAllParameters(): Record<string, any> {\n    return Object.fromEntries(this.parameters);\n  }\n\n  /**\n   * Validate parameter value against its definition\n   */\n  private validateParameterValue(param: SkillParameter, value: any): boolean {\n    switch (param.type) {\n      case 'string':\n        return typeof value === 'string';\n      case 'number':\n        const num = Number(value);\n        if (isNaN(num)) return false;\n        if (param.min !== undefined && num < param.min) return false;\n        if (param.max !== undefined && num > param.max) return false;\n        return true;\n      case 'boolean':\n        return typeof value === 'boolean';\n      case 'enum':\n        return param.options?.includes(String(value)) || false;\n      default:\n        return true;\n    }\n  }\n\n  /**\n   * Execute the skill with current parameters\n   */\n  async execute(input?: any): Promise<any> {\n    logger.info(`Executing skill: ${this.metadata.name}`);\n    \n    // Validate required parameters\n    const missingRequired = this.metadata.parameters\n      ?.filter(p => p.required && !this.parameters.has(p.name))\n      .map(p => p.name) || [];\n    \n    if (missingRequired.length > 0) {\n      throw new Error(`Missing required parameters: ${missingRequired.join(', ')}`);\n    }\n\n    // Skills don't have built-in execution logic - this would be implemented\n    // by specific skill types or through a plugin system\n    logger.debug(`Skill ${this.metadata.name} executed with parameters:`, this.getAllParameters());\n    \n    return {\n      skill: this.metadata.name,\n      parameters: this.getAllParameters(),\n      input,\n      executed_at: new Date().toISOString()\n    };\n  }\n\n  /**\n   * Skill-specific validation\n   */\n  public override validate(): ElementValidationResult {\n    const result = super.validate();\n    \n    // Initialize arrays if not present\n    if (!result.errors) result.errors = [];\n    if (!result.warnings) result.warnings = [];\n    \n    // Instructions should not be empty\n    if (!this.instructions || this.instructions.trim().length === 0) {\n      result.errors.push({\n        field: 'instructions',\n        message: 'Skill instructions cannot be empty',\n        code: 'EMPTY_INSTRUCTIONS'\n      });\n    }\n\n    // Validate complexity level\n    const validComplexity = ['beginner', 'intermediate', 'advanced', 'expert'];\n    if (this.metadata.complexity && !validComplexity.includes(this.metadata.complexity)) {\n      result.errors.push({\n        field: 'complexity',\n        message: `Complexity must be one of: ${validComplexity.join(', ')}`,\n        code: 'INVALID_COMPLEXITY'\n      });\n    }\n\n    // Validate proficiency level\n    if (this.metadata.proficiency_level !== undefined) {\n      if (this.metadata.proficiency_level < 0 || this.metadata.proficiency_level > 100) {\n        result.errors.push({\n          field: 'proficiency_level',\n          message: 'Proficiency level must be between 0 and 100',\n          code: 'INVALID_PROFICIENCY'\n        });\n      }\n    }\n\n    // Validate parameters\n    if (this.metadata.parameters) {\n      this.metadata.parameters.forEach((param, index) => {\n        if (!param.name || param.name.trim() === '') {\n          result.errors!.push({\n            field: `parameters[${index}].name`,\n            message: 'Parameter name is required',\n            code: 'MISSING_PARAMETER_NAME'\n          });\n        }\n        \n        if (param.type === 'enum' && (!param.options || param.options.length === 0)) {\n          result.errors!.push({\n            field: `parameters[${index}].options`,\n            message: 'Enum parameter must have options defined',\n            code: 'MISSING_ENUM_OPTIONS'\n          });\n        }\n      });\n    }\n\n    // Warnings for best practices\n    if (!this.metadata.domains || this.metadata.domains.length === 0) {\n      result.warnings.push({\n        field: 'domains',\n        message: 'Consider adding domain categories for better organization',\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 usage examples improves skill 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 skill to JSON format\n   */\n  public override serialize(): string {\n    const data = {\n      id: this.id,\n      type: this.type,\n      version: this.version,\n      metadata: this.metadata,\n      instructions: this.instructions,\n      parameters: this.getAllParameters(),\n      references: this.references,\n      extensions: this.extensions,\n      ratings: this.ratings\n    };\n\n    return JSON.stringify(data, null, 2);\n  }\n\n  /**\n   * Deserialize skill 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 other properties\n      this.instructions = parsed.instructions || '';\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      // Restore parameters\n      if (parsed.parameters) {\n        this.parameters.clear();\n        Object.entries(parsed.parameters).forEach(([key, value]) => {\n          this.parameters.set(key, value);\n        });\n      }\n      \n      this._isDirty = true;\n      logger.debug(`Deserialized skill: ${this.metadata.name}`);\n      \n    } catch (error) {\n      logger.error(`Failed to deserialize skill: ${error}`);\n      throw new Error(`Deserialization failed: ${error}`);\n    }\n  }\n\n  /**\n   * Skill activation lifecycle\n   */\n  public override async activate(): Promise<void> {\n    logger.info(`Activating skill: ${this.metadata.name} (${this.id})`);\n    \n    // Validate that all required parameters are set\n    const validation = this.validate();\n    if (!validation.valid) {\n      throw new Error(`Cannot activate skill with validation errors: ${validation.errors?.map(e => e.message).join(', ')}`);\n    }\n    \n    await super.activate?.();\n  }\n\n  /**\n   * Clone the skill with different parameters\n   */\n  clone(newParameters?: Record<string, any>): Skill {\n    const cloned = new Skill(this.metadata, this.instructions);\n    \n    // Copy current parameters\n    this.parameters.forEach((value, key) => {\n      cloned.parameters.set(key, value);\n    });\n    \n    // Override with new parameters if provided\n    if (newParameters) {\n      Object.entries(newParameters).forEach(([key, value]) => {\n        cloned.setParameter(key, value);\n      });\n    }\n    \n    return cloned;\n  }\n  \n  /**\n   * Skill deactivation lifecycle\n   * SECURITY FIX #4: Automatically clears parameters on deactivation\n   * to prevent memory leaks in long-running processes\n   */\n  public override async deactivate(): Promise<void> {\n    logger.info(`Deactivating skill: ${this.metadata.name} (${this.id})`);\n    \n    // SECURITY FIX #4: Clear parameters to free memory and prevent leaks\n    // This ensures skills don't retain data after deactivation\n    this.clearParameters();\n    \n    await super.deactivate?.();\n  }\n  \n  /**\n   * Clear all parameters (for memory management)\n   * SECURITY FIX #4: Added method to clear parameters and prevent memory leaks\n   * Previously: Parameters accumulated indefinitely in long-running processes\n   * Now: Provides explicit cleanup mechanism called during deactivation\n   */\n  clearParameters(): void {\n    this.parameters.clear();\n    logger.debug(`Cleared all parameters for skill: ${this.metadata.name}`);\n  }\n}"]}
382
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Skill.js","sourceRoot":"","sources":["../../../src/elements/skills/Skill.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Skill element class implementing IElement interface.\n * Represents a discrete capability for specific tasks.\n * \n * SECURITY FIXES IMPLEMENTED (PR #319):\n * 1. CRITICAL: Added comprehensive input validation for all skill parameters\n * 2. MEDIUM: Implemented Unicode normalization to prevent homograph attacks\n * 3. MEDIUM: Added audit logging for security events via SecurityMonitor\n * 4. MEDIUM: Implemented memory management to prevent unbounded growth\n * 5. MEDIUM: Added XSS protection through input sanitization\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 { sanitizeInput, validatePath } from '../../security/InputValidator.js';\nimport { UnicodeValidator } from '../../security/validators/unicodeValidator.js';\nimport { SecurityMonitor } from '../../security/securityMonitor.js';\n\n// Extend IElementMetadata with skill-specific fields\nexport interface SkillMetadata extends IElementMetadata {\n  languages?: string[];           // Programming/spoken languages this skill works with\n  complexity?: 'beginner' | 'intermediate' | 'advanced' | 'expert';\n  domains?: string[];             // Domain categories (e.g., web-dev, data-science, writing)\n  prerequisites?: string[];       // Required knowledge or other skills\n  parameters?: SkillParameter[];  // Configurable parameters\n  examples?: SkillExample[];      // Usage examples\n  certification?: string;         // External certification or validation\n  proficiency_level?: number;     // 1-100 proficiency level\n}\n\nexport interface SkillParameter {\n  name: string;\n  type: 'string' | 'number' | 'boolean' | 'enum';\n  description: string;\n  required?: boolean;\n  default?: any;\n  options?: string[];  // For enum type\n  min?: number;        // For number type\n  max?: number;        // For number type\n}\n\nexport interface SkillExample {\n  title: string;\n  description: string;\n  input?: any;\n  output?: any;\n  code?: string;\n}\n\nexport class Skill extends BaseElement implements IElement {\n  public declare metadata: SkillMetadata;\n  public instructions: string;\n  public parameters: Map<string, any> = new Map();\n  \n  // SECURITY FIX #4: Memory management constants to prevent unbounded growth\n  // Previously: No limits on parameter storage, could lead to memory exhaustion\n  // Now: Enforced limits on both count and size\n  private readonly MAX_PARAMETER_COUNT = 100;\n  private readonly MAX_PARAMETER_SIZE = 10000; // Max size per parameter value\n\n  constructor(metadata: Partial<SkillMetadata>, instructions: string = '') {\n    // SECURITY FIX #2: Validate and sanitize ALL metadata fields\n    // Previously: metadata was used directly without validation\n    // Now: All string inputs are Unicode normalized and sanitized to prevent:\n    // - XSS attacks through malicious metadata\n    // - Unicode homograph attacks\n    // - Buffer overflow attempts\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    };\n    \n    super(ElementType.SKILL, sanitizedMetadata);\n    // Ensure instructions is always a string, even if empty\n    this.instructions = instructions && instructions.trim() ? sanitizeInput(UnicodeValidator.normalize(instructions).normalizedContent, 10000) : '';\n    \n    // Ensure skill-specific metadata\n    this.metadata = {\n      ...this.metadata,\n      languages: metadata.languages || [],\n      complexity: metadata.complexity || 'beginner',\n      domains: metadata.domains || [],\n      prerequisites: metadata.prerequisites || [],\n      parameters: metadata.parameters || [],\n      examples: metadata.examples || [],\n      proficiency_level: metadata.proficiency_level || 0\n    };\n\n    // Validate parameter definitions\n    if (this.metadata.parameters) {\n      this.metadata.parameters = this.metadata.parameters.map(param => ({\n        ...param,\n        name: sanitizeInput(UnicodeValidator.normalize(param.name).normalizedContent, 50),\n        description: sanitizeInput(UnicodeValidator.normalize(param.description).normalizedContent, 200),\n        options: param.options?.map(opt => sanitizeInput(opt, 100))\n      }));\n    }\n\n    // Initialize parameter values with defaults\n    this.initializeParameters();\n  }\n\n  /**\n   * Initialize parameters with default values\n   */\n  private initializeParameters(): void {\n    if (this.metadata.parameters) {\n      this.metadata.parameters.forEach(param => {\n        if (param.default !== undefined) {\n          this.parameters.set(param.name, param.default);\n        }\n      });\n    }\n  }\n\n  /**\n   * Set a parameter value\n   * SECURITY FIX #1: Comprehensive input validation for all skill parameters\n   * Previously: Parameters were set without validation, creating security risks\n   * Now: Full validation pipeline including sanitization, type checking, and size limits\n   */\n  setParameter(name: string, value: any): void {\n    // CRITICAL FIX: Sanitize parameter name to prevent injection attacks\n    const sanitizedName = sanitizeInput(name, 50);\n    \n    const param = this.metadata.parameters?.find(p => p.name === sanitizedName);\n    if (!param) {\n      // SECURITY FIX #3: Log audit events for security monitoring\n      // This helps detect potential attack patterns or misconfigurations\n      SecurityMonitor.logSecurityEvent({\n        type: 'YAML_PARSING_WARNING',\n        severity: 'MEDIUM',\n        source: 'Skill.setParameter',\n        details: `Attempt to set unknown parameter: ${sanitizedName} for skill: ${this.metadata.name}`\n      });\n      throw new Error(`Parameter '${sanitizedName}' not found in skill definition`);\n    }\n\n    // CRITICAL FIX: Sanitize and validate the value based on type\n    let sanitizedValue = value;\n    \n    if (param.type === 'string') {\n      // SECURITY FIX #2 & #5: Normalize Unicode and sanitize string values\n      // Previously: String values were used directly without validation\n      // Now: Full validation pipeline:\n      // 1. Unicode normalization prevents homograph attacks\n      // 2. sanitizeInput() strips dangerous HTML/JS content\n      // 3. Length limits prevent buffer overflow attacks\n      const normalized = UnicodeValidator.normalize(String(value));\n      sanitizedValue = sanitizeInput(normalized.normalizedContent, param.max || 1000);\n      \n      // SECURITY FIX #5: Additional XSS protection\n      // Check for common XSS patterns even after sanitization\n      // This provides defense-in-depth against sophisticated attacks\n      if (sanitizedValue.includes('<script') || sanitizedValue.includes('javascript:')) {\n        // SECURITY FIX #3: Log high-severity security events\n        SecurityMonitor.logSecurityEvent({\n          type: 'CONTENT_INJECTION_ATTEMPT',\n          severity: 'HIGH',\n          source: 'Skill.setParameter',\n          details: `Potential XSS attempt in skill parameter: ${sanitizedName} for skill: ${this.metadata.name}`\n        });\n        throw new Error('Invalid characters in parameter value');\n      }\n    }\n\n    // Type validation\n    if (!this.validateParameterValue(param, sanitizedValue)) {\n      throw new Error(`Invalid value for parameter '${sanitizedName}': expected ${param.type}`);\n    }\n\n    // SECURITY FIX #4: Memory management - check parameter count\n    // Previously: No limits on parameter storage, could lead to memory exhaustion attacks\n    // Now: Enforced limits prevent attackers from consuming unlimited memory\n    if (this.parameters.size >= this.MAX_PARAMETER_COUNT && !this.parameters.has(sanitizedName)) {\n      // SECURITY FIX #3: Log rate limit violations for security monitoring\n      SecurityMonitor.logSecurityEvent({\n        type: 'RATE_LIMIT_EXCEEDED',\n        severity: 'MEDIUM',\n        source: 'Skill.setParameter',\n        details: `Parameter limit exceeded for skill: ${this.metadata.name}. Max: ${this.MAX_PARAMETER_COUNT}`\n      });\n      throw new Error(`Parameter limit exceeded. Maximum ${this.MAX_PARAMETER_COUNT} parameters allowed`);\n    }\n    \n    // SECURITY FIX #4: Check parameter value size for strings\n    // This prevents attackers from storing massive strings that could exhaust memory\n    if (param.type === 'string' && sanitizedValue.length > this.MAX_PARAMETER_SIZE) {\n      throw new Error(`Parameter value too large. Maximum ${this.MAX_PARAMETER_SIZE} characters allowed`);\n    }\n\n    this.parameters.set(sanitizedName, sanitizedValue);\n    logger.debug(`Set parameter ${sanitizedName} = ${sanitizedValue} for skill ${this.metadata.name}`);\n  }\n\n  /**\n   * Get a parameter value\n   */\n  getParameter(name: string): any {\n    return this.parameters.get(name);\n  }\n\n  /**\n   * Get all parameters as object\n   */\n  getAllParameters(): Record<string, any> {\n    return Object.fromEntries(this.parameters);\n  }\n\n  /**\n   * Validate parameter value against its definition\n   */\n  private validateParameterValue(param: SkillParameter, value: any): boolean {\n    switch (param.type) {\n      case 'string':\n        return typeof value === 'string';\n      case 'number':\n        const num = Number(value);\n        if (isNaN(num)) return false;\n        if (param.min !== undefined && num < param.min) return false;\n        if (param.max !== undefined && num > param.max) return false;\n        return true;\n      case 'boolean':\n        return typeof value === 'boolean';\n      case 'enum':\n        return param.options?.includes(String(value)) || false;\n      default:\n        return true;\n    }\n  }\n\n  /**\n   * Execute the skill with current parameters\n   */\n  async execute(input?: any): Promise<any> {\n    logger.info(`Executing skill: ${this.metadata.name}`);\n    \n    // Validate required parameters\n    const missingRequired = this.metadata.parameters\n      ?.filter(p => p.required && !this.parameters.has(p.name))\n      .map(p => p.name) || [];\n    \n    if (missingRequired.length > 0) {\n      throw new Error(`Missing required parameters: ${missingRequired.join(', ')}`);\n    }\n\n    // Skills don't have built-in execution logic - this would be implemented\n    // by specific skill types or through a plugin system\n    logger.debug(`Skill ${this.metadata.name} executed with parameters:`, this.getAllParameters());\n    \n    return {\n      skill: this.metadata.name,\n      parameters: this.getAllParameters(),\n      input,\n      executed_at: new Date().toISOString()\n    };\n  }\n\n  /**\n   * Skill-specific validation\n   */\n  public override validate(): ElementValidationResult {\n    const result = super.validate();\n    \n    // Initialize arrays if not present\n    if (!result.errors) result.errors = [];\n    if (!result.warnings) result.warnings = [];\n    \n    // Instructions should not be empty\n    if (!this.instructions || this.instructions.trim().length === 0) {\n      result.errors.push({\n        field: 'instructions',\n        message: 'Skill instructions cannot be empty',\n        code: 'EMPTY_INSTRUCTIONS'\n      });\n    }\n\n    // Validate complexity level\n    const validComplexity = ['beginner', 'intermediate', 'advanced', 'expert'];\n    if (this.metadata.complexity && !validComplexity.includes(this.metadata.complexity)) {\n      result.errors.push({\n        field: 'complexity',\n        message: `Complexity must be one of: ${validComplexity.join(', ')}`,\n        code: 'INVALID_COMPLEXITY'\n      });\n    }\n\n    // Validate proficiency level\n    if (this.metadata.proficiency_level !== undefined) {\n      if (this.metadata.proficiency_level < 0 || this.metadata.proficiency_level > 100) {\n        result.errors.push({\n          field: 'proficiency_level',\n          message: 'Proficiency level must be between 0 and 100',\n          code: 'INVALID_PROFICIENCY'\n        });\n      }\n    }\n\n    // Validate parameters\n    if (this.metadata.parameters) {\n      this.metadata.parameters.forEach((param, index) => {\n        if (!param.name || param.name.trim() === '') {\n          result.errors!.push({\n            field: `parameters[${index}].name`,\n            message: 'Parameter name is required',\n            code: 'MISSING_PARAMETER_NAME'\n          });\n        }\n        \n        if (param.type === 'enum' && (!param.options || param.options.length === 0)) {\n          result.errors!.push({\n            field: `parameters[${index}].options`,\n            message: 'Enum parameter must have options defined',\n            code: 'MISSING_ENUM_OPTIONS'\n          });\n        }\n      });\n    }\n\n    // Warnings for best practices\n    if (!this.metadata.domains || this.metadata.domains.length === 0) {\n      result.warnings.push({\n        field: 'domains',\n        message: 'Consider adding domain categories for better organization',\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 usage examples improves skill 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 skill to JSON format\n   */\n  public override serialize(): string {\n    const data = {\n      id: this.id,\n      type: this.type,\n      version: this.version,\n      metadata: this.metadata,\n      instructions: this.instructions,\n      parameters: this.getAllParameters(),\n      references: this.references,\n      extensions: this.extensions,\n      ratings: this.ratings\n    };\n\n    return JSON.stringify(data, null, 2);\n  }\n\n  /**\n   * Deserialize skill 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 other properties\n      this.instructions = parsed.instructions || '';\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      // Restore parameters\n      if (parsed.parameters) {\n        this.parameters.clear();\n        Object.entries(parsed.parameters).forEach(([key, value]) => {\n          this.parameters.set(key, value);\n        });\n      }\n      \n      this._isDirty = true;\n      logger.debug(`Deserialized skill: ${this.metadata.name}`);\n      \n    } catch (error) {\n      logger.error(`Failed to deserialize skill: ${error}`);\n      throw new Error(`Deserialization failed: ${error}`);\n    }\n  }\n\n  /**\n   * Skill activation lifecycle\n   */\n  public override async activate(): Promise<void> {\n    logger.info(`Activating skill: ${this.metadata.name} (${this.id})`);\n    \n    // Validate that all required parameters are set\n    const validation = this.validate();\n    if (!validation.valid) {\n      throw new Error(`Cannot activate skill with validation errors: ${validation.errors?.map(e => e.message).join(', ')}`);\n    }\n    \n    await super.activate?.();\n  }\n\n  /**\n   * Clone the skill with different parameters\n   */\n  clone(newParameters?: Record<string, any>): Skill {\n    const cloned = new Skill(this.metadata, this.instructions);\n    \n    // Copy current parameters\n    this.parameters.forEach((value, key) => {\n      cloned.parameters.set(key, value);\n    });\n    \n    // Override with new parameters if provided\n    if (newParameters) {\n      Object.entries(newParameters).forEach(([key, value]) => {\n        cloned.setParameter(key, value);\n      });\n    }\n    \n    return cloned;\n  }\n  \n  /**\n   * Skill deactivation lifecycle\n   * SECURITY FIX #4: Automatically clears parameters on deactivation\n   * to prevent memory leaks in long-running processes\n   */\n  public override async deactivate(): Promise<void> {\n    logger.info(`Deactivating skill: ${this.metadata.name} (${this.id})`);\n    \n    // SECURITY FIX #4: Clear parameters to free memory and prevent leaks\n    // This ensures skills don't retain data after deactivation\n    this.clearParameters();\n    \n    await super.deactivate?.();\n  }\n  \n  /**\n   * Clear all parameters (for memory management)\n   * SECURITY FIX #4: Added method to clear parameters and prevent memory leaks\n   * Previously: Parameters accumulated indefinitely in long-running processes\n   * Now: Provides explicit cleanup mechanism called during deactivation\n   */\n  clearParameters(): void {\n    this.parameters.clear();\n    logger.debug(`Cleared all parameters for skill: ${this.metadata.name}`);\n  }\n}"]}
@@ -0,0 +1,83 @@
1
+ /**
2
+ * SkillManager - Implementation of IElementManager for Skill elements
3
+ * Handles CRUD operations and lifecycle management for skills implementing IElement
4
+ *
5
+ * SECURITY FIXES IMPLEMENTED (Following PR #319 patterns):
6
+ * 1. CRITICAL: Fixed race conditions in file operations by using FileLockManager for atomic reads/writes
7
+ * 2. CRITICAL: Fixed dynamic require() statements by using static imports
8
+ * 3. HIGH: Fixed unvalidated YAML parsing vulnerability by using SecureYamlParser
9
+ * 4. MEDIUM: All user inputs are now validated and sanitized
10
+ * 5. MEDIUM: Audit logging added for security operations
11
+ * 6. MEDIUM: Path traversal prevention for all file operations
12
+ */
13
+ import { IElementManager } from '../../types/elements/IElementManager.js';
14
+ import { ElementValidationResult } from '../../types/elements/IElement.js';
15
+ import { Skill } from './Skill.js';
16
+ import { ElementType } from '../../portfolio/types.js';
17
+ export declare class SkillManager implements IElementManager<Skill> {
18
+ private portfolioManager;
19
+ private skillsDir;
20
+ private skills;
21
+ constructor();
22
+ /**
23
+ * Load a skill from file
24
+ * SECURITY FIX #1: Uses FileLockManager.atomicReadFile() instead of fs.readFile()
25
+ * to prevent race conditions and ensure atomic file operations
26
+ */
27
+ load(filePath: string): Promise<Skill>;
28
+ /**
29
+ * Save a skill to file
30
+ * SECURITY FIX #1: Uses FileLockManager.atomicWriteFile() for atomic operations
31
+ */
32
+ save(element: Skill, filePath: string): Promise<void>;
33
+ /**
34
+ * List all available skills
35
+ */
36
+ list(): Promise<Skill[]>;
37
+ /**
38
+ * Find a skill by predicate
39
+ */
40
+ find(predicate: (element: Skill) => boolean): Promise<Skill | undefined>;
41
+ /**
42
+ * Validate a skill
43
+ */
44
+ validate(element: Skill): ElementValidationResult;
45
+ /**
46
+ * Delete a skill
47
+ */
48
+ delete(filePath: string): Promise<void>;
49
+ /**
50
+ * Import a skill from YAML/JSON
51
+ * SECURITY FIX #3: Uses SecureYamlParser to prevent YAML injection
52
+ */
53
+ importElement(data: string, format: 'yaml' | 'json'): Promise<Skill>;
54
+ /**
55
+ * Export a skill to YAML/JSON
56
+ */
57
+ exportElement(element: Skill, format: 'yaml' | 'json'): Promise<string>;
58
+ /**
59
+ * Clear all cached skills
60
+ */
61
+ clearCache(): void;
62
+ /**
63
+ * Check if a skill exists
64
+ */
65
+ exists(filePath: string): Promise<boolean>;
66
+ /**
67
+ * Find multiple skills by predicate
68
+ */
69
+ findMany(predicate: (element: Skill) => boolean): Promise<Skill[]>;
70
+ /**
71
+ * Validate a file path
72
+ */
73
+ validatePath(filePath: string): boolean;
74
+ /**
75
+ * Get the element type
76
+ */
77
+ getElementType(): ElementType;
78
+ /**
79
+ * Get the file extension for skills
80
+ */
81
+ getFileExtension(): string;
82
+ }
83
+ //# sourceMappingURL=SkillManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SkillManager.d.ts","sourceRoot":"","sources":["../../../src/elements/skills/SkillManager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,yCAAyC,CAAC;AAC1E,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAC3E,OAAO,EAAE,KAAK,EAAiB,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAavD,qBAAa,YAAa,YAAW,eAAe,CAAC,KAAK,CAAC;IACzD,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,MAAM,CAAiC;;IAO/C;;;;OAIG;IACG,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;IAwD5C;;;OAGG;IACG,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAgD3D;;OAEG;IACG,IAAI,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAyB9B;;OAEG;IACG,IAAI,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,KAAK,KAAK,OAAO,GAAG,OAAO,CAAC,KAAK,GAAG,SAAS,CAAC;IAK9E;;OAEG;IACH,QAAQ,CAAC,OAAO,EAAE,KAAK,GAAG,uBAAuB;IASjD;;OAEG;IACG,MAAM,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwC7C;;;OAGG;IACG,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;IAmG1E;;OAEG;IACG,aAAa,CAAC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAyB7E;;OAEG;IACH,UAAU,IAAI,IAAI;IAIlB;;OAEG;IACG,MAAM,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAWhD;;OAEG;IACG,QAAQ,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,KAAK,KAAK,OAAO,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAKxE;;OAEG;IACH,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IASvC;;OAEG;IACH,cAAc,IAAI,WAAW;IAI7B;;OAEG;IACH,gBAAgB,IAAI,MAAM;CAG3B"}