@dollhousemcp/mcp-server 1.5.0 → 1.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +49 -1
- package/README.md +27 -16
- package/dist/auth/GitHubAuthManager.js +2 -2
- package/dist/cache/CollectionCache.d.ts +65 -0
- package/dist/cache/CollectionCache.d.ts.map +1 -0
- package/dist/cache/CollectionCache.js +162 -0
- package/dist/cache/index.d.ts +1 -0
- package/dist/cache/index.d.ts.map +1 -1
- package/dist/cache/index.js +2 -1
- package/dist/collection/CollectionBrowser.d.ts +24 -1
- package/dist/collection/CollectionBrowser.d.ts.map +1 -1
- package/dist/collection/CollectionBrowser.js +135 -23
- package/dist/collection/CollectionSearch.d.ts +20 -1
- package/dist/collection/CollectionSearch.d.ts.map +1 -1
- package/dist/collection/CollectionSearch.js +110 -6
- package/dist/collection/CollectionSeeder.d.ts +36 -0
- package/dist/collection/CollectionSeeder.d.ts.map +1 -0
- package/dist/collection/CollectionSeeder.js +230 -0
- package/dist/collection/GitHubClient.d.ts.map +1 -1
- package/dist/collection/GitHubClient.js +8 -4
- package/dist/collection/PersonaSubmitter.d.ts +48 -1
- package/dist/collection/PersonaSubmitter.d.ts.map +1 -1
- package/dist/collection/PersonaSubmitter.js +170 -34
- package/dist/collection/index.d.ts +1 -0
- package/dist/collection/index.d.ts.map +1 -1
- package/dist/collection/index.js +2 -1
- package/dist/generated/version.d.ts +2 -2
- package/dist/generated/version.js +3 -3
- package/dist/index.d.ts +12 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +165 -54
- package/dist/server/tools/CollectionTools.d.ts.map +1 -1
- package/dist/server/tools/CollectionTools.js +12 -1
- package/dist/server/tools/PersonaTools.d.ts.map +1 -1
- package/dist/server/tools/PersonaTools.js +3 -7
- package/dist/server/types.d.ts +1 -0
- package/dist/server/types.d.ts.map +1 -1
- package/dist/server/types.js +1 -1
- package/dist/utils/searchUtils.d.ts +23 -0
- package/dist/utils/searchUtils.d.ts.map +1 -0
- package/dist/utils/searchUtils.js +57 -0
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -17,8 +17,8 @@ import { loadIndicatorConfig, formatIndicator, validateCustomFormat } from './co
|
|
|
17
17
|
import { SecureYamlParser } from './security/secureYamlParser.js';
|
|
18
18
|
import { SecurityError } from './errors/SecurityError.js';
|
|
19
19
|
import { SecureErrorHandler } from './security/errorHandler.js';
|
|
20
|
-
import { APICache } from './cache/
|
|
21
|
-
import { validateFilename, sanitizeInput, validateContentSize, validateUsername,
|
|
20
|
+
import { APICache, CollectionCache } from './cache/index.js';
|
|
21
|
+
import { validateFilename, sanitizeInput, validateContentSize, validateUsername, MCPInputValidator } from './security/InputValidator.js';
|
|
22
22
|
import { SECURITY_LIMITS, VALIDATION_PATTERNS } from './security/constants.js';
|
|
23
23
|
import { ContentValidator } from './security/contentValidator.js';
|
|
24
24
|
import { PathValidator } from './security/pathValidator.js';
|
|
@@ -55,6 +55,7 @@ export class DollhouseMCPServer {
|
|
|
55
55
|
activePersona = null;
|
|
56
56
|
currentUser = null;
|
|
57
57
|
apiCache = new APICache();
|
|
58
|
+
collectionCache = new CollectionCache();
|
|
58
59
|
rateLimitTracker = new Map();
|
|
59
60
|
indicatorConfig;
|
|
60
61
|
githubClient;
|
|
@@ -105,8 +106,8 @@ export class DollhouseMCPServer {
|
|
|
105
106
|
// Initialize collection modules
|
|
106
107
|
this.githubClient = new GitHubClient(this.apiCache, this.rateLimitTracker);
|
|
107
108
|
this.githubAuthManager = new GitHubAuthManager(this.apiCache);
|
|
108
|
-
this.collectionBrowser = new CollectionBrowser(this.githubClient);
|
|
109
|
-
this.collectionSearch = new CollectionSearch(this.githubClient);
|
|
109
|
+
this.collectionBrowser = new CollectionBrowser(this.githubClient, this.collectionCache);
|
|
110
|
+
this.collectionSearch = new CollectionSearch(this.githubClient, this.collectionCache);
|
|
110
111
|
this.personaDetails = new PersonaDetails(this.githubClient);
|
|
111
112
|
this.elementInstaller = new ElementInstaller(this.githubClient);
|
|
112
113
|
this.personaSubmitter = new PersonaSubmitter();
|
|
@@ -169,6 +170,31 @@ export class DollhouseMCPServer {
|
|
|
169
170
|
logger.info('Creating portfolio directory structure...');
|
|
170
171
|
await this.portfolioManager.initialize();
|
|
171
172
|
}
|
|
173
|
+
// Initialize collection cache for anonymous access
|
|
174
|
+
await this.initializeCollectionCache();
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Initialize collection cache with seed data for anonymous browsing
|
|
178
|
+
*/
|
|
179
|
+
async initializeCollectionCache() {
|
|
180
|
+
try {
|
|
181
|
+
const isCacheValid = await this.collectionCache.isCacheValid();
|
|
182
|
+
if (!isCacheValid) {
|
|
183
|
+
logger.info('Initializing collection cache with seed data...');
|
|
184
|
+
const { CollectionSeeder } = await import('./collection/CollectionSeeder.js');
|
|
185
|
+
const seedData = CollectionSeeder.getSeedData();
|
|
186
|
+
await this.collectionCache.saveCache(seedData);
|
|
187
|
+
logger.info(`Collection cache initialized with ${seedData.length} items`);
|
|
188
|
+
}
|
|
189
|
+
else {
|
|
190
|
+
const stats = await this.collectionCache.getCacheStats();
|
|
191
|
+
logger.debug(`Collection cache already valid with ${stats.itemCount} items`);
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
catch (error) {
|
|
195
|
+
logger.error(`Failed to initialize collection cache: ${error}`);
|
|
196
|
+
// Don't throw - cache failures shouldn't prevent server startup
|
|
197
|
+
}
|
|
172
198
|
}
|
|
173
199
|
// Tool handler methods - now public for access from tool modules
|
|
174
200
|
getPersonaIndicator() {
|
|
@@ -1078,7 +1104,7 @@ export class DollhouseMCPServer {
|
|
|
1078
1104
|
switch (type) {
|
|
1079
1105
|
case ElementType.PERSONA:
|
|
1080
1106
|
// Use existing persona creation logic
|
|
1081
|
-
return this.createPersona(validatedName, validatedDescription,
|
|
1107
|
+
return this.createPersona(validatedName, validatedDescription, content || '', sanitizedMetadata?.triggers);
|
|
1082
1108
|
case ElementType.SKILL:
|
|
1083
1109
|
const skill = await this.skillManager.create({
|
|
1084
1110
|
name: validatedName,
|
|
@@ -1587,9 +1613,24 @@ export class DollhouseMCPServer {
|
|
|
1587
1613
|
// checkRateLimit and fetchFromGitHub are now handled by GitHubClient
|
|
1588
1614
|
async browseCollection(section, type) {
|
|
1589
1615
|
try {
|
|
1590
|
-
//
|
|
1591
|
-
|
|
1592
|
-
|
|
1616
|
+
// FIX #471: Replace legacy category validation with proper section/type validation
|
|
1617
|
+
// Valid sections: library, showcase, catalog
|
|
1618
|
+
// Valid types: personas, skills, agents, prompts, templates, tools, ensembles, memories
|
|
1619
|
+
const validSections = ['library', 'showcase', 'catalog'];
|
|
1620
|
+
const validTypes = ['personas', 'skills', 'agents', 'prompts', 'templates', 'tools', 'ensembles', 'memories'];
|
|
1621
|
+
// Validate section if provided
|
|
1622
|
+
const validatedSection = section ? sanitizeInput(section.toLowerCase()) : undefined;
|
|
1623
|
+
if (validatedSection && !validSections.includes(validatedSection)) {
|
|
1624
|
+
throw new Error(`Invalid section '${validatedSection}'. Must be one of: ${validSections.join(', ')}`);
|
|
1625
|
+
}
|
|
1626
|
+
// Validate type if provided (only valid when section is 'library')
|
|
1627
|
+
const validatedType = type ? sanitizeInput(type.toLowerCase()) : undefined;
|
|
1628
|
+
if (validatedType && validatedSection === 'library' && !validTypes.includes(validatedType)) {
|
|
1629
|
+
throw new Error(`Invalid type '${validatedType}'. Must be one of: ${validTypes.join(', ')}`);
|
|
1630
|
+
}
|
|
1631
|
+
if (validatedType && validatedSection !== 'library') {
|
|
1632
|
+
throw new Error('Type parameter is only valid when section is "library"');
|
|
1633
|
+
}
|
|
1593
1634
|
const result = await this.collectionBrowser.browseCollection(validatedSection, validatedType);
|
|
1594
1635
|
// Handle sections view
|
|
1595
1636
|
const items = result.items;
|
|
@@ -1710,24 +1751,7 @@ export class DollhouseMCPServer {
|
|
|
1710
1751
|
async submitContent(contentIdentifier) {
|
|
1711
1752
|
// Check GitHub authentication first
|
|
1712
1753
|
const authStatus = await this.githubAuthManager.getAuthStatus();
|
|
1713
|
-
|
|
1714
|
-
return {
|
|
1715
|
-
content: [
|
|
1716
|
-
{
|
|
1717
|
-
type: "text",
|
|
1718
|
-
text: `${this.getPersonaIndicator()}🔐 **GitHub Authentication Required**\n\n` +
|
|
1719
|
-
`To submit content to the DollhouseMCP collection, you need to connect to GitHub.\n\n` +
|
|
1720
|
-
`**Why GitHub?**\n` +
|
|
1721
|
-
`• It's where our community shares content\n` +
|
|
1722
|
-
`• Free account with millions of developers\n` +
|
|
1723
|
-
`• Secure and reliable platform\n\n` +
|
|
1724
|
-
`**To get started:**\n` +
|
|
1725
|
-
`Just say "connect to GitHub" or "set up GitHub"\n\n` +
|
|
1726
|
-
`Don't have a GitHub account? No problem! You'll be guided through creating one.`,
|
|
1727
|
-
},
|
|
1728
|
-
],
|
|
1729
|
-
};
|
|
1730
|
-
}
|
|
1754
|
+
const isAuthenticated = authStatus.isAuthenticated;
|
|
1731
1755
|
// Find the content in local collection
|
|
1732
1756
|
let persona = this.personas.get(contentIdentifier);
|
|
1733
1757
|
if (!persona) {
|
|
@@ -1791,17 +1815,122 @@ export class DollhouseMCPServer {
|
|
|
1791
1815
|
],
|
|
1792
1816
|
};
|
|
1793
1817
|
}
|
|
1794
|
-
|
|
1795
|
-
|
|
1818
|
+
// Generate submission issue with rate limiting
|
|
1819
|
+
let githubIssueUrl;
|
|
1820
|
+
let rateLimitStatus;
|
|
1821
|
+
try {
|
|
1822
|
+
const submissionResult = this.personaSubmitter.generateSubmissionIssue(persona);
|
|
1823
|
+
githubIssueUrl = submissionResult.githubIssueUrl;
|
|
1824
|
+
rateLimitStatus = submissionResult.rateLimitStatus;
|
|
1825
|
+
}
|
|
1826
|
+
catch (error) {
|
|
1827
|
+
// Handle rate limiting error specifically
|
|
1828
|
+
if (error.message.includes('rate limit')) {
|
|
1829
|
+
return {
|
|
1830
|
+
content: [
|
|
1831
|
+
{
|
|
1832
|
+
type: "text",
|
|
1833
|
+
text: `${this.getPersonaIndicator()}⏳ **Rate Limit Reached**\n\n` +
|
|
1834
|
+
`${error.message}\n\n` +
|
|
1835
|
+
`This protection ensures the quality and integrity of our collection.`,
|
|
1836
|
+
},
|
|
1837
|
+
],
|
|
1838
|
+
};
|
|
1839
|
+
}
|
|
1840
|
+
throw error; // Re-throw other errors
|
|
1841
|
+
}
|
|
1842
|
+
// Choose response format based on authentication status
|
|
1843
|
+
const text = isAuthenticated
|
|
1844
|
+
? this.personaSubmitter.formatSubmissionResponse(persona, githubIssueUrl, this.getPersonaIndicator())
|
|
1845
|
+
: this.personaSubmitter.formatAnonymousSubmissionResponse(persona, githubIssueUrl, this.getPersonaIndicator());
|
|
1846
|
+
// Add rate limit info if available
|
|
1847
|
+
const rateLimitInfo = rateLimitStatus
|
|
1848
|
+
? `\n\n📊 **Rate Limit Status:** ${rateLimitStatus.remainingTokens} submissions remaining this hour`
|
|
1849
|
+
: '';
|
|
1796
1850
|
return {
|
|
1797
1851
|
content: [
|
|
1798
1852
|
{
|
|
1799
1853
|
type: "text",
|
|
1800
|
-
text: text,
|
|
1854
|
+
text: text + rateLimitInfo,
|
|
1801
1855
|
},
|
|
1802
1856
|
],
|
|
1803
1857
|
};
|
|
1804
1858
|
}
|
|
1859
|
+
async getCollectionCacheHealth() {
|
|
1860
|
+
try {
|
|
1861
|
+
// Get cache statistics
|
|
1862
|
+
const stats = await this.collectionCache.getCacheStats();
|
|
1863
|
+
// Check if cache directory exists
|
|
1864
|
+
const cacheDir = path.join(process.cwd(), '.dollhousemcp', 'cache');
|
|
1865
|
+
let cacheFileExists = false;
|
|
1866
|
+
let cacheFileSize = 0;
|
|
1867
|
+
try {
|
|
1868
|
+
const cacheFile = path.join(cacheDir, 'collection-cache.json');
|
|
1869
|
+
const fileStats = await fs.stat(cacheFile);
|
|
1870
|
+
cacheFileExists = true;
|
|
1871
|
+
cacheFileSize = fileStats.size;
|
|
1872
|
+
}
|
|
1873
|
+
catch (error) {
|
|
1874
|
+
// Cache file doesn't exist yet
|
|
1875
|
+
}
|
|
1876
|
+
// Format cache age
|
|
1877
|
+
const formatAge = (ageMs) => {
|
|
1878
|
+
if (ageMs === 0)
|
|
1879
|
+
return 'Not cached';
|
|
1880
|
+
const hours = Math.floor(ageMs / (1000 * 60 * 60));
|
|
1881
|
+
const minutes = Math.floor((ageMs % (1000 * 60 * 60)) / (1000 * 60));
|
|
1882
|
+
if (hours > 0) {
|
|
1883
|
+
return `${hours}h ${minutes}m old`;
|
|
1884
|
+
}
|
|
1885
|
+
return `${minutes}m old`;
|
|
1886
|
+
};
|
|
1887
|
+
// Build health report
|
|
1888
|
+
const healthReport = {
|
|
1889
|
+
status: stats.isValid ? 'healthy' : (cacheFileExists ? 'expired' : 'empty'),
|
|
1890
|
+
cacheExists: cacheFileExists,
|
|
1891
|
+
itemCount: stats.itemCount,
|
|
1892
|
+
cacheAge: formatAge(stats.cacheAge),
|
|
1893
|
+
cacheAgeMs: stats.cacheAge,
|
|
1894
|
+
isValid: stats.isValid,
|
|
1895
|
+
cacheFileSize: cacheFileSize,
|
|
1896
|
+
cacheFileSizeFormatted: cacheFileSize > 0 ? `${(cacheFileSize / 1024).toFixed(2)} KB` : '0 KB',
|
|
1897
|
+
ttlRemaining: stats.isValid ? formatAge(24 * 60 * 60 * 1000 - stats.cacheAge) : 'Expired',
|
|
1898
|
+
recommendation: stats.isValid
|
|
1899
|
+
? 'Cache is healthy and serving content'
|
|
1900
|
+
: cacheFileExists
|
|
1901
|
+
? 'Cache has expired. Will refresh on next collection access.'
|
|
1902
|
+
: 'No cache present. Will be created on first collection access.'
|
|
1903
|
+
};
|
|
1904
|
+
return {
|
|
1905
|
+
content: [
|
|
1906
|
+
{
|
|
1907
|
+
type: "text",
|
|
1908
|
+
text: `${this.getPersonaIndicator()}📊 **Collection Cache Health Check**\n\n` +
|
|
1909
|
+
`**Status**: ${healthReport.status === 'healthy' ? '✅' : healthReport.status === 'expired' ? '⚠️' : '📦'} ${healthReport.status.toUpperCase()}\n` +
|
|
1910
|
+
`**Items Cached**: ${healthReport.itemCount}\n` +
|
|
1911
|
+
`**Cache Age**: ${healthReport.cacheAge}\n` +
|
|
1912
|
+
`**Cache Size**: ${healthReport.cacheFileSizeFormatted}\n` +
|
|
1913
|
+
`**Valid**: ${healthReport.isValid ? 'Yes ✓' : 'No ✗'}\n` +
|
|
1914
|
+
`**TTL Remaining**: ${healthReport.ttlRemaining}\n\n` +
|
|
1915
|
+
`**Recommendation**: ${healthReport.recommendation}\n\n` +
|
|
1916
|
+
`Cache enables offline browsing and faster collection access.`,
|
|
1917
|
+
},
|
|
1918
|
+
],
|
|
1919
|
+
};
|
|
1920
|
+
}
|
|
1921
|
+
catch (error) {
|
|
1922
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
1923
|
+
logger.error(`Failed to get cache health: ${errorMessage}`);
|
|
1924
|
+
return {
|
|
1925
|
+
content: [
|
|
1926
|
+
{
|
|
1927
|
+
type: "text",
|
|
1928
|
+
text: `${this.getPersonaIndicator()}❌ Failed to get cache health: ${errorMessage}`,
|
|
1929
|
+
},
|
|
1930
|
+
],
|
|
1931
|
+
};
|
|
1932
|
+
}
|
|
1933
|
+
}
|
|
1805
1934
|
// User identity management
|
|
1806
1935
|
async setUserIdentity(username, email) {
|
|
1807
1936
|
try {
|
|
@@ -2070,10 +2199,10 @@ export class DollhouseMCPServer {
|
|
|
2070
2199
|
}
|
|
2071
2200
|
}
|
|
2072
2201
|
// Chat-based persona management tools
|
|
2073
|
-
async createPersona(name, description,
|
|
2202
|
+
async createPersona(name, description, instructions, triggers) {
|
|
2074
2203
|
try {
|
|
2075
2204
|
// Validate required fields
|
|
2076
|
-
if (!name || !description || !
|
|
2205
|
+
if (!name || !description || !instructions) {
|
|
2077
2206
|
return {
|
|
2078
2207
|
content: [
|
|
2079
2208
|
{
|
|
@@ -2082,7 +2211,6 @@ export class DollhouseMCPServer {
|
|
|
2082
2211
|
`Please provide all required fields:\n` +
|
|
2083
2212
|
`• **name**: Display name for the persona\n` +
|
|
2084
2213
|
`• **description**: Brief description of what it does\n` +
|
|
2085
|
-
`• **category**: creative, professional, educational, gaming, or personal\n` +
|
|
2086
2214
|
`• **instructions**: The persona's behavioral guidelines\n\n` +
|
|
2087
2215
|
`**Optional:**\n` +
|
|
2088
2216
|
`• **triggers**: Comma-separated keywords for activation`,
|
|
@@ -2099,8 +2227,7 @@ export class DollhouseMCPServer {
|
|
|
2099
2227
|
if (sanitizedName.length < 2) {
|
|
2100
2228
|
throw new Error('Persona name must be at least 2 characters long');
|
|
2101
2229
|
}
|
|
2102
|
-
//
|
|
2103
|
-
const validatedCategory = validateCategory(category);
|
|
2230
|
+
// No category validation needed - categories are deprecated
|
|
2104
2231
|
// Validate content sizes
|
|
2105
2232
|
validateContentSize(sanitizedInstructions, SECURITY_LIMITS.MAX_CONTENT_LENGTH);
|
|
2106
2233
|
validateContentSize(sanitizedDescription, 2000); // 2KB max for description
|
|
@@ -2152,7 +2279,6 @@ export class DollhouseMCPServer {
|
|
|
2152
2279
|
author,
|
|
2153
2280
|
triggers: triggerList,
|
|
2154
2281
|
version: "1.0",
|
|
2155
|
-
category: validatedCategory,
|
|
2156
2282
|
age_rating: "all",
|
|
2157
2283
|
content_flags: ["user-created"],
|
|
2158
2284
|
ai_generated: true,
|
|
@@ -2211,7 +2337,6 @@ ${sanitizedInstructions}
|
|
|
2211
2337
|
type: "text",
|
|
2212
2338
|
text: `${this.getPersonaIndicator()}✅ **Persona Created Successfully!**\n\n` +
|
|
2213
2339
|
`🎭 **${sanitizedName}** by ${author}\n` +
|
|
2214
|
-
`📁 Category: ${category}\n` +
|
|
2215
2340
|
`🆔 Unique ID: ${uniqueId}\n` +
|
|
2216
2341
|
`📄 Saved as: ${filename}\n` +
|
|
2217
2342
|
`📊 Total personas: ${this.personas.size}\n\n` +
|
|
@@ -2261,7 +2386,6 @@ ${sanitizedInstructions}
|
|
|
2261
2386
|
`**Editable fields:**\n` +
|
|
2262
2387
|
`• **name** - Display name\n` +
|
|
2263
2388
|
`• **description** - Brief description\n` +
|
|
2264
|
-
`• **category** - creative, professional, educational, gaming, personal\n` +
|
|
2265
2389
|
`• **instructions** - Main persona content\n` +
|
|
2266
2390
|
`• **triggers** - Comma-separated keywords\n` +
|
|
2267
2391
|
`• **version** - Version number`,
|
|
@@ -2287,7 +2411,7 @@ ${sanitizedInstructions}
|
|
|
2287
2411
|
],
|
|
2288
2412
|
};
|
|
2289
2413
|
}
|
|
2290
|
-
const validFields = ['name', 'description', '
|
|
2414
|
+
const validFields = ['name', 'description', 'instructions', 'triggers', 'version'];
|
|
2291
2415
|
if (!validFields.includes(field.toLowerCase())) {
|
|
2292
2416
|
return {
|
|
2293
2417
|
content: [
|
|
@@ -2373,21 +2497,8 @@ ${sanitizedInstructions}
|
|
|
2373
2497
|
parsed.data[normalizedField] = sanitizedValue.split(',').map(t => t.trim()).filter(t => t.length > 0);
|
|
2374
2498
|
}
|
|
2375
2499
|
else if (normalizedField === 'category') {
|
|
2376
|
-
//
|
|
2377
|
-
|
|
2378
|
-
if (!validCategories.includes(sanitizedValue.toLowerCase())) {
|
|
2379
|
-
return {
|
|
2380
|
-
content: [
|
|
2381
|
-
{
|
|
2382
|
-
type: "text",
|
|
2383
|
-
text: `${this.getPersonaIndicator()}❌ **Invalid Category**\n\n` +
|
|
2384
|
-
`Category must be one of: ${validCategories.join(', ')}\n` +
|
|
2385
|
-
`You provided: "${sanitizedValue}"`,
|
|
2386
|
-
},
|
|
2387
|
-
],
|
|
2388
|
-
};
|
|
2389
|
-
}
|
|
2390
|
-
parsed.data[normalizedField] = sanitizedValue.toLowerCase();
|
|
2500
|
+
// Category field is deprecated but still editable for backward compatibility
|
|
2501
|
+
parsed.data[normalizedField] = sanitizedValue;
|
|
2391
2502
|
}
|
|
2392
2503
|
else {
|
|
2393
2504
|
// Update metadata field
|
|
@@ -3091,4 +3202,4 @@ if ((isDirectExecution || isNpxExecution || isCliExecution) && !isTest) {
|
|
|
3091
3202
|
process.exit(1);
|
|
3092
3203
|
});
|
|
3093
3204
|
}
|
|
3094
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\n// Defensive error handling for npx/CLI execution\nprocess.on('uncaughtException', (error) => {\n  console.error('[DollhouseMCP] Server startup failed');\n  process.exit(1);\n});\n\nprocess.on('unhandledRejection', (reason, promise) => {\n  console.error('[DollhouseMCP] Server startup failed');\n  process.exit(1);\n});\n\nimport { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport { StdioServerTransport } from \"@modelcontextprotocol/sdk/server/stdio.js\";\nimport { McpError, ErrorCode } from \"@modelcontextprotocol/sdk/types.js\";\nimport * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport { loadIndicatorConfig, formatIndicator, validateCustomFormat, type IndicatorConfig } from './config/indicator-config.js';\nimport { SecureYamlParser } from './security/secureYamlParser.js';\nimport { SecurityError } from './errors/SecurityError.js';\nimport { SecureErrorHandler } from './security/errorHandler.js';\n\n// Import modularized components\nimport { Persona, PersonaMetadata } from './types/persona.js';\nimport { APICache } from './cache/APICache.js';\nimport { validateFilename, sanitizeInput, validateContentSize, validateUsername, validateCategory, MCPInputValidator } from './security/InputValidator.js';\nimport { SECURITY_LIMITS, VALIDATION_PATTERNS } from './security/constants.js';\nimport { ContentValidator } from './security/contentValidator.js';\nimport { PathValidator } from './security/pathValidator.js';\nimport { FileLockManager } from './security/fileLockManager.js';\nimport { generateAnonymousId, generateUniqueId, slugify } from './utils/filesystem.js';\nimport { GitHubClient, CollectionBrowser, CollectionSearch, PersonaDetails, PersonaSubmitter, ElementInstaller } from './collection/index.js';\nimport { UpdateManager } from './update/index.js';\nimport { ServerSetup, IToolHandler } from './server/index.js';\nimport { GitHubAuthManager } from './auth/GitHubAuthManager.js';\nimport { logger } from './utils/logger.js';\nimport { PersonaExporter, PersonaImporter, PersonaSharer } from './persona/export-import/index.js';\nimport { isDefaultPersona } from './constants/defaultPersonas.js';\nimport { PortfolioManager, ElementType } from './portfolio/PortfolioManager.js';\nimport { MigrationManager } from './portfolio/MigrationManager.js';\nimport { SkillManager } from './elements/skills/index.js';\nimport { TemplateManager } from './elements/templates/TemplateManager.js';\nimport { AgentManager } from './elements/agents/AgentManager.js';\n\n\n\n// Detect execution environment\nconst EXECUTION_ENV = {\n  isNpx: process.env.npm_execpath?.includes('npx') || false,\n  isCli: process.argv[1]?.endsWith('/dollhousemcp') || false,\n  isDirect: !process.env.npm_execpath,\n  cwd: process.cwd(),\n  scriptPath: process.argv[1],\n};\n\n// Only log execution environment in debug mode\nif (process.env.DOLLHOUSE_DEBUG) {\n  console.error('[DollhouseMCP] Debug mode enabled');\n}\n\nexport class DollhouseMCPServer implements IToolHandler {\n  private server: Server;\n  private personasDir: string;\n  private personas: Map<string, Persona> = new Map();\n  private activePersona: string | null = null;\n  private currentUser: string | null = null;\n  private apiCache: APICache = new APICache();\n  private rateLimitTracker = new Map<string, number[]>();\n  private indicatorConfig: IndicatorConfig;\n  private githubClient: GitHubClient;\n  private githubAuthManager: GitHubAuthManager;\n  private collectionBrowser: CollectionBrowser;\n  private collectionSearch: CollectionSearch;\n  private personaDetails: PersonaDetails;\n  private elementInstaller: ElementInstaller;\n  private personaSubmitter: PersonaSubmitter;\n  private updateManager?: UpdateManager;\n  private serverSetup: ServerSetup;\n  private personaExporter: PersonaExporter;\n  private personaImporter?: PersonaImporter;\n  private personaSharer: PersonaSharer;\n  private portfolioManager: PortfolioManager;\n  private migrationManager: MigrationManager;\n  private skillManager: SkillManager;\n  private templateManager: TemplateManager;\n  private agentManager: AgentManager;\n\n  constructor() {\n    this.server = new Server(\n      {\n        name: \"dollhousemcp\",\n        version: \"1.0.0\",\n      },\n      {\n        capabilities: {\n          tools: {},\n        },\n      }\n    );\n\n    // Initialize portfolio system\n    this.portfolioManager = PortfolioManager.getInstance();\n    this.migrationManager = new MigrationManager(this.portfolioManager);\n    \n    // CRITICAL FIX: Don't access directories until after migration runs\n    // Previously: this.personasDir was set here, creating directories before migration could fix them\n    // Now: We delay directory access until initializePortfolio() completes\n    this.personasDir = ''; // Temporary - will be set after migration\n    \n    // Initialize element managers\n    this.skillManager = new SkillManager();\n    this.templateManager = new TemplateManager();\n    this.agentManager = new AgentManager(this.portfolioManager.getBaseDir());\n    \n    // Log resolved path for debugging\n    logger.info(`Personas directory resolved to: ${this.personasDir}`);\n    \n    // PathValidator will be initialized after migration completes\n    \n    // Load user identity from environment variables\n    this.currentUser = process.env.DOLLHOUSE_USER || null;\n    \n    // Load indicator configuration\n    this.indicatorConfig = loadIndicatorConfig();\n    \n    // Initialize persona manager\n    \n    // Initialize collection modules\n    this.githubClient = new GitHubClient(this.apiCache, this.rateLimitTracker);\n    this.githubAuthManager = new GitHubAuthManager(this.apiCache);\n    this.collectionBrowser = new CollectionBrowser(this.githubClient);\n    this.collectionSearch = new CollectionSearch(this.githubClient);\n    this.personaDetails = new PersonaDetails(this.githubClient);\n    this.elementInstaller = new ElementInstaller(this.githubClient);\n    this.personaSubmitter = new PersonaSubmitter();\n    \n    // Update manager will be initialized after migration completes to avoid jsdom crash\n    \n    // Initialize export/import/share modules\n    this.personaExporter = new PersonaExporter(this.currentUser);\n    // PersonaImporter will be initialized after migration completes\n    this.personaSharer = new PersonaSharer(this.githubClient, this.currentUser);\n    \n    // Initialize server setup\n    this.serverSetup = new ServerSetup();\n    this.serverSetup.setupServer(this.server, this);\n    \n    // Initialize portfolio and perform migration if needed\n    this.initializePortfolio().then(() => {\n      // NOW safe to access directories after migration\n      this.personasDir = this.portfolioManager.getElementDir(ElementType.PERSONA);\n      \n      // Log resolved path for debugging\n      logger.info(`Personas directory resolved to: ${this.personasDir}`);\n      \n      // Initialize PathValidator with the personas directory\n      PathValidator.initialize(this.personasDir);\n      \n      // Initialize update manager with safe directory\n      // Use the parent of personas directory to avoid production check\n      const safeDir = path.dirname(this.personasDir);\n      try {\n        this.updateManager = new UpdateManager(safeDir);\n      } catch (error) {\n        console.error('[DollhouseMCP] Failed to initialize UpdateManager:', error);\n        logger.error(`Failed to initialize UpdateManager: ${error}`);\n        // Continue without update functionality\n      }\n      \n      // Initialize import module that depends on personasDir\n      this.personaImporter = new PersonaImporter(this.personasDir, this.currentUser);\n      \n      this.loadPersonas();\n    }).catch(error => {\n      // Don't use CRITICAL in the error message as it triggers Docker test failures\n      console.error('[DollhouseMCP] Failed to initialize portfolio:', error);\n      logger.error(`Failed to initialize portfolio: ${error}`);\n    });\n  }\n  \n  private async initializePortfolio(): Promise<void> {\n    // Check if migration is needed\n    const needsMigration = await this.migrationManager.needsMigration();\n    \n    if (needsMigration) {\n      logger.info('Legacy personas detected. Starting migration...');\n      \n      const result = await this.migrationManager.migrate({ backup: true });\n      \n      if (result.success) {\n        logger.info(`Successfully migrated ${result.migratedCount} personas`);\n        if (result.backedUp && result.backupPath) {\n          logger.info(`Backup created at: ${result.backupPath}`);\n        }\n      } else {\n        logger.error('Migration completed with errors:');\n        result.errors.forEach(err => logger.error(`  - ${err}`));\n      }\n    }\n    \n    // Ensure portfolio structure exists\n    const portfolioExists = await this.portfolioManager.exists();\n    if (!portfolioExists) {\n      logger.info('Creating portfolio directory structure...');\n      await this.portfolioManager.initialize();\n    }\n  }\n\n  // Tool handler methods - now public for access from tool modules\n  \n  private getPersonaIndicator(): string {\n    if (!this.activePersona) {\n      return \"\";\n    }\n\n    const persona = this.personas.get(this.activePersona);\n    if (!persona) {\n      return \"\";\n    }\n\n    return formatIndicator(this.indicatorConfig, {\n      name: persona.metadata.name,\n      version: persona.metadata.version,\n      author: persona.metadata.author,\n      category: persona.metadata.category\n    });\n  }\n\n  /**\n   * Normalize element type to handle both singular (new) and plural (legacy) forms\n   * This provides backward compatibility during the transition to v1.4.0\n   */\n  private normalizeElementType(type: string): string {\n    // Map plural forms to singular ElementType values\n    const pluralToSingularMap: Record<string, string> = {\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    // If it's already a valid ElementType value, return as-is\n    if (Object.values(ElementType).includes(type as ElementType)) {\n      return type;\n    }\n    \n    // If it's a plural form, convert to singular\n    if (pluralToSingularMap[type]) {\n      // Log deprecation warning\n      logger.warn(`Using plural element type '${type}' is deprecated. Please use singular form '${pluralToSingularMap[type]}' instead.`);\n      return pluralToSingularMap[type];\n    }\n    \n    // Unknown type - return as-is and let validation handle it\n    return type;\n  }\n\n  /**\n   * Sanitize metadata object to prevent prototype pollution\n   * Removes any dangerous properties that could affect Object.prototype\n   */\n  private sanitizeMetadata(metadata: Record<string, any>): Record<string, any> {\n    if (!metadata || typeof metadata !== 'object') {\n      return {};\n    }\n    \n    const dangerousProperties = ['__proto__', 'constructor', 'prototype'];\n    const sanitized: Record<string, any> = {};\n    \n    for (const [key, value] of Object.entries(metadata)) {\n      if (!dangerousProperties.includes(key)) {\n        // Recursively sanitize nested objects\n        if (value && typeof value === 'object' && !Array.isArray(value)) {\n          sanitized[key] = this.sanitizeMetadata(value);\n        } else {\n          sanitized[key] = value;\n        }\n      }\n    }\n    \n    return sanitized;\n  }\n\n  private async loadPersonas() {\n    // Validate the personas directory path\n    if (!path.isAbsolute(this.personasDir)) {\n      logger.warn(`Personas directory path is not absolute: ${this.personasDir}`);\n    }\n    \n    try {\n      await fs.access(this.personasDir);\n    } catch (error) {\n      // Create personas directory if it doesn't exist\n      try {\n        await fs.mkdir(this.personasDir, { recursive: true });\n        logger.info(`Created personas directory at: ${this.personasDir}`);\n        // Continue to try loading (directory will be empty)\n      } catch (mkdirError: any) {\n        logger.error(`Failed to create personas directory at ${this.personasDir}: ${mkdirError.message}`);\n        // Don't throw - empty portfolio is valid\n        this.personas.clear();\n        return;\n      }\n    }\n\n    try {\n      const files = await fs.readdir(this.personasDir);\n      const markdownFiles = files.filter(file => file.endsWith('.md'));\n\n      this.personas.clear();\n      \n      if (markdownFiles.length === 0) {\n        logger.info('[DollhouseMCP] No personas found in portfolio. Use browse_collection to install some!');\n      }\n\n      for (const file of markdownFiles) {\n        try {\n          const filePath = path.join(this.personasDir, file);\n          const fileContent = await PathValidator.safeReadFile(filePath);\n          \n          // Use secure YAML parser\n          let parsed;\n          try {\n            parsed = SecureYamlParser.safeMatter(fileContent);\n          } catch (error) {\n            if (error instanceof SecurityError) {\n              logger.warn(`Security threat detected in persona ${file}: ${error.message}`);\n              continue;\n            }\n            throw error;\n          }\n          \n          const metadata = parsed.data as PersonaMetadata;\n          const content = parsed.content;\n\n          if (!metadata.name) {\n            metadata.name = path.basename(file, '.md');\n          }\n\n          // Generate unique ID if not present\n          let uniqueId = metadata.unique_id;\n          if (!uniqueId) {\n            const authorForId = metadata.author || this.getCurrentUserForAttribution();\n            uniqueId = generateUniqueId(metadata.name, authorForId);\n            logger.debug(`Generated unique ID for ${metadata.name}: ${uniqueId}`);\n          }\n\n          // Set default values for new metadata fields\n          if (!metadata.category) metadata.category = 'general';\n          if (!metadata.age_rating) metadata.age_rating = 'all';\n          if (!metadata.content_flags) metadata.content_flags = [];\n          if (metadata.ai_generated === undefined) metadata.ai_generated = false;\n          if (!metadata.generation_method) metadata.generation_method = 'human';\n          if (!metadata.price) metadata.price = 'free';\n          if (!metadata.license) metadata.license = 'CC-BY-SA-4.0';\n\n          const persona: Persona = {\n            metadata,\n            content,\n            filename: file,\n            unique_id: uniqueId,\n          };\n\n          this.personas.set(file, persona);\n          logger.debug(`Loaded persona: ${metadata.name} (${uniqueId}`);\n        } catch (error) {\n          logger.error(`Error loading persona ${file}: ${error}`);\n        }\n      }\n    } catch (error) {\n      // Handle ENOENT gracefully - directory might not exist yet\n      if ((error as any).code === 'ENOENT') {\n        logger.info('[DollhouseMCP] Personas directory does not exist yet - portfolio is empty');\n        this.personas.clear();\n        return;\n      }\n      logger.error(`Error reading personas directory: ${error}`);\n      this.personas.clear();\n    }\n  }\n\n  async listPersonas() {\n    const personaList = Array.from(this.personas.values()).map(persona => ({\n      filename: persona.filename,\n      unique_id: persona.unique_id,\n      name: persona.metadata.name,\n      description: persona.metadata.description,\n      triggers: persona.metadata.triggers || [],\n      version: persona.metadata.version || \"1.0\",\n      author: persona.metadata.author || \"Unknown\",\n      category: persona.metadata.category || 'general',\n      age_rating: persona.metadata.age_rating || 'all',\n      price: persona.metadata.price || 'free',\n      ai_generated: persona.metadata.ai_generated || false,\n      active: this.activePersona === persona.filename,\n    }));\n\n    if (personaList.length === 0) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}You don't have any personas installed yet. Would you like to browse the DollhouseMCP collection on GitHub to see what's available? I can show you personas for creative writing, technical analysis, and more. Just say \"yes\" or use 'browse_collection'.`,\n          },\n        ],\n      };\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}Available Personas (${personaList.length}):\\n\\n` +\n            personaList.map(p => \n              `${p.active ? '🔹 ' : '▫️ '}**${p.name}** (${p.unique_id})\\n` +\n              `   ${p.description}\\n` +\n              `   📁 ${p.category} | 🎭 ${p.author} | 🔖 ${p.price} | ${p.ai_generated ? '🤖 AI' : '👤 Human'}\\n` +\n              `   Age: ${p.age_rating} | Version: ${p.version}\\n` +\n              `   Triggers: ${p.triggers.join(', ') || 'None'}\\n`\n            ).join('\\n'),\n        },\n      ],\n    };\n  }\n\n  async activatePersona(personaIdentifier: string) {\n    // Enhanced input validation for persona identifier\n    const validatedIdentifier = MCPInputValidator.validatePersonaIdentifier(personaIdentifier);\n    \n    // Try to find persona by filename first, then by name\n    let persona = this.personas.get(validatedIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === validatedIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      throw new McpError(\n        ErrorCode.InvalidParams,\n        `Persona not found: ${personaIdentifier}`\n      );\n    }\n\n    this.activePersona = persona.filename;\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}Persona Activated: **${persona.metadata.name}**\\n\\n` +\n            `${persona.metadata.description}\\n\\n` +\n            `**Instructions:**\\n${persona.content}`,\n        },\n      ],\n    };\n  }\n\n  async getActivePersona() {\n    if (!this.activePersona) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}No persona is currently active.`,\n          },\n        ],\n      };\n    }\n\n    const persona = this.personas.get(this.activePersona);\n    if (!persona) {\n      this.activePersona = null;\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}Active persona not found. Deactivated.`,\n          },\n        ],\n      };\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}Active Persona: **${persona.metadata.name}**\\n\\n` +\n            `${persona.metadata.description}\\n\\n` +\n            `File: ${persona.filename}\\n` +\n            `Version: ${persona.metadata.version || '1.0'}\\n` +\n            `Author: ${persona.metadata.author || 'Unknown'}`,\n        },\n      ],\n    };\n  }\n\n  async deactivatePersona() {\n    const wasActive = this.activePersona !== null;\n    const indicator = this.getPersonaIndicator();\n    this.activePersona = null;\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: wasActive \n            ? `${indicator}✅ Persona deactivated. Back to default mode.`\n            : \"No persona was active.\",\n        },\n      ],\n    };\n  }\n\n  async getPersonaDetails(personaIdentifier: string) {\n    // Try to find persona by filename first, then by name\n    let persona = this.personas.get(personaIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === personaIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      throw new McpError(\n        ErrorCode.InvalidParams,\n        `Persona not found: ${personaIdentifier}`\n      );\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}📋 **${persona.metadata.name}** Details\\n\\n` +\n            `**Description:** ${persona.metadata.description}\\n` +\n            `**File:** ${persona.filename}\\n` +\n            `**Version:** ${persona.metadata.version || '1.0'}\\n` +\n            `**Author:** ${persona.metadata.author || 'Unknown'}\\n` +\n            `**Triggers:** ${persona.metadata.triggers?.join(', ') || 'None'}\\n\\n` +\n            `**Full Content:**\\n\\`\\`\\`\\n${persona.content}\\n\\`\\`\\``,\n        },\n      ],\n    };\n  }\n\n  async reloadPersonas() {\n    await this.loadPersonas();\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}🔄 Reloaded ${this.personas.size} personas from ${this.personasDir}`,\n        },\n      ],\n    };\n  }\n\n  // ===== Element Methods (Generic for all element types) =====\n  \n  async listElements(type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.listPersonas();\n          \n        case ElementType.SKILL: {\n          const skills = await this.skillManager.list();\n          if (skills.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"No skills are currently installed. The DollhouseMCP collection has skills for code review, data analysis, creative writing and more. Would you like me to show you what's available? Just say \\\"yes\\\" or I can help you create a custom skill.\"\n              }]\n            };\n          }\n          \n          const skillList = skills.map(skill => {\n            const complexity = skill.metadata.complexity || 'beginner';\n            const domains = skill.metadata.domains?.join(', ') || 'general';\n            return `🛠️ ${skill.metadata.name} - ${skill.metadata.description}\\n   Complexity: ${complexity} | Domains: ${domains}`;\n          }).join('\\n\\n');\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `📚 Available Skills:\\n\\n${skillList}`\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          const templates = await this.templateManager.list();\n          if (templates.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"You haven't installed any templates yet. Would you like to see available templates for emails, reports, and documentation? I can show you examples from the collection or help you create your own. What would you prefer?\"\n              }]\n            };\n          }\n          \n          const templateList = templates.map(template => {\n            const variables = template.metadata.variables?.map(v => v.name).join(', ') || 'none';\n            return `📄 ${template.metadata.name} - ${template.metadata.description}\\n   Variables: ${variables}`;\n          }).join('\\n\\n');\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `📝 Available Templates:\\n\\n${templateList}`\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agents = await this.agentManager.list();\n          if (agents.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"No agents installed yet. Agents are autonomous helpers that can work on tasks independently. The DollhouseMCP collection includes task managers, research assistants, and more. Would you like to browse available agents or learn how to create your own?\"\n              }]\n            };\n          }\n          \n          const agentList = agents.map(agent => {\n            const specializations = (agent.metadata as any).specializations?.join(', ') || 'general';\n            const status = agent.getStatus();\n            return `🤖 ${agent.metadata.name} - ${agent.metadata.description}\\n   Status: ${status} | Specializations: ${specializations}`;\n          }).join('\\n\\n');\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `🤖 Available Agents:\\n\\n${agentList}`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'. Available types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to list ${type} elements:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to list ${type}: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async activateElement(name: string, type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.activatePersona(name);\n          \n        case ElementType.SKILL: {\n          const skill = await this.skillManager.find(s => s.metadata.name === name);\n          if (!skill) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Skill '${name}' not found`\n              }]\n            };\n          }\n          \n          // Activate the skill\n          await skill.activate?.();\n          \n          return {\n            content: [{\n                type: \"text\",\n                text: `✅ Skill '${name}' activated\\n\\n${skill.instructions}`\n              }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          const template = await this.templateManager.find(t => t.metadata.name === name);\n          if (!template) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Template '${name}' not found`\n              }]\n            };\n          }\n          \n          const variables = template.metadata.variables?.map(v => v.name).join(', ') || 'none';\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Template '${name}' ready to use\\nVariables: ${variables}\\n\\nUse 'render_template' to generate content with this template.`\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agent = await this.agentManager.find(a => a.metadata.name === name);\n          if (!agent) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Agent '${name}' not found`\n              }]\n            };\n          }\n          \n          // Activate the agent\n          await agent.activate();\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Agent '${name}' activated and ready\\nSpecializations: ${(agent.metadata as any).specializations?.join(', ') || 'general'}\\n\\nUse 'execute_agent' to give this agent a goal.`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to activate ${type} '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to activate ${type} '${name}': ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async getActiveElements(type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.getActivePersona();\n          \n        case ElementType.SKILL: {\n          const skills = await this.skillManager.list();\n          const activeSkills = skills.filter(s => s.getStatus() === 'active');\n          \n          if (activeSkills.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"📋 No active skills\"\n              }]\n            };\n          }\n          \n          const skillList = activeSkills.map(s => `🛠️ ${s.metadata.name}`).join(', ');\n          return {\n            content: [{\n              type: \"text\",\n              text: `Active skills: ${skillList}`\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          return {\n            content: [{\n              type: \"text\",\n              text: \"📝 Templates are stateless and activated on-demand when rendering\"\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agents = await this.agentManager.list();\n          const activeAgents = agents.filter(a => a.getStatus() === 'active');\n          \n          if (activeAgents.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"🤖 No active agents\"\n              }]\n            };\n          }\n          \n          const agentList = activeAgents.map(a => {\n            const goals = (a as any).state?.goals?.length || 0;\n            return `🤖 ${a.metadata.name} (${goals} active goals)`;\n          }).join('\\n');\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `Active agents:\\n${agentList}`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to get active ${type}:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get active ${type}: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async deactivateElement(name: string, type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.deactivatePersona();\n          \n        case ElementType.SKILL: {\n          const skill = await this.skillManager.find(s => s.metadata.name === name);\n          if (!skill) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Skill '${name}' not found`\n              }]\n            };\n          }\n          \n          await skill.deactivate?.();\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Skill '${name}' deactivated`\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          return {\n            content: [{\n              type: \"text\",\n              text: \"📝 Templates are stateless - nothing to deactivate\"\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agent = await this.agentManager.find(a => a.metadata.name === name);\n          if (!agent) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Agent '${name}' not found`\n              }]\n            };\n          }\n          \n          await agent.deactivate();\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Agent '${name}' deactivated`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to deactivate ${type} '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to deactivate ${type} '${name}': ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async getElementDetails(name: string, type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.getPersonaDetails(name);\n          \n        case ElementType.SKILL: {\n          const skill = await this.skillManager.find(s => s.metadata.name === name);\n          if (!skill) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Skill '${name}' not found`\n              }]\n            };\n          }\n          \n          const details = [\n            `🛠️ **${skill.metadata.name}**`,\n            `${skill.metadata.description}`,\n            ``,\n            `**Complexity**: ${skill.metadata.complexity || 'beginner'}`,\n            `**Domains**: ${skill.metadata.domains?.join(', ') || 'general'}`,\n            `**Languages**: ${skill.metadata.languages?.join(', ') || 'any'}`,\n            `**Prerequisites**: ${skill.metadata.prerequisites?.join(', ') || 'none'}`,\n            ``,\n            `**Instructions**:`,\n            skill.instructions\n          ];\n          \n          if (skill.metadata.parameters && skill.metadata.parameters.length > 0) {\n            details.push('', '**Parameters**:');\n            skill.metadata.parameters.forEach(p => {\n              details.push(`- ${p.name} (${p.type}): ${p.description}`);\n            });\n          }\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: details.join('\\n')\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          const template = await this.templateManager.find(t => t.metadata.name === name);\n          if (!template) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Template '${name}' not found`\n              }]\n            };\n          }\n          \n          const details = [\n            `📄 **${template.metadata.name}**`,\n            `${template.metadata.description}`,\n            ``,\n            `**Output Format**: ${(template.metadata as any).output_format || 'text'}`,\n            `**Template Content**:`,\n            '```',\n            template.content,\n            '```'\n          ];\n          \n          if (template.metadata.variables && template.metadata.variables.length > 0) {\n            details.push('', '**Variables**:');\n            template.metadata.variables.forEach(v => {\n              details.push(`- ${v.name} (${v.type}): ${v.description}`);\n            });\n          }\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: details.join('\\n')\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agent = await this.agentManager.find(a => a.metadata.name === name);\n          if (!agent) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Agent '${name}' not found`\n              }]\n            };\n          }\n          \n          const details = [\n            `🤖 **${agent.metadata.name}**`,\n            `${agent.metadata.description}`,\n            ``,\n            `**Status**: ${agent.getStatus()}`,\n            `**Specializations**: ${(agent.metadata as any).specializations?.join(', ') || 'general'}`,\n            `**Decision Framework**: ${(agent.metadata as any).decisionFramework || 'rule-based'}`,\n            `**Risk Tolerance**: ${(agent.metadata as any).riskTolerance || 'low'}`,\n            ``,\n            `**Instructions**:`,\n            (agent as any).instructions || 'No instructions available'\n          ];\n          \n          const agentState = (agent as any).state;\n          if (agentState?.goals && agentState.goals.length > 0) {\n            details.push('', '**Current Goals**:');\n            agentState.goals.forEach((g: any) => {\n              details.push(`- ${g.description} (${g.status})`);\n            });\n          }\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: details.join('\\n')\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to get ${type} details for '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get ${type} details: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async reloadElements(type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.reloadPersonas();\n          \n        case ElementType.SKILL: {\n          this.skillManager.clearCache();\n          const skills = await this.skillManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${skills.length} skills from portfolio`\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          // Template manager doesn't have clearCache, just list\n          const templates = await this.templateManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${templates.length} templates from portfolio`\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          // Agent manager doesn't have clearCache, just list\n          const agents = await this.agentManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${agents.length} agents from portfolio`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to reload ${type}:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to reload ${type}: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  // Element-specific methods\n  async renderTemplate(name: string, variables: Record<string, any>) {\n    try {\n      const template = await this.templateManager.find(t => t.metadata.name === name);\n      if (!template) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Template '${name}' not found`\n          }]\n        };\n      }\n      \n      // Simple template rendering - replace variables in content\n      let rendered = template.content;\n      for (const [key, value] of Object.entries(variables)) {\n        const regex = new RegExp(`\\\\{\\\\{\\\\s*${key}\\\\s*\\\\}\\\\}`, 'g');\n        rendered = rendered.replace(regex, String(value));\n      }\n      return {\n        content: [{\n          type: \"text\",\n          text: `📄 Rendered template '${name}':\\n\\n${rendered}`\n        }]\n      };\n    } catch (error) {\n      logger.error(`Failed to render template '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to render template: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async executeAgent(name: string, goal: string) {\n    try {\n      const agent = await this.agentManager.find(a => a.metadata.name === name);\n      if (!agent) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Agent '${name}' not found`\n          }]\n        };\n      }\n      \n      // Simple agent execution simulation\n      const result = {\n        summary: `Agent '${name}' is now working on: ${goal}`,\n        status: 'in-progress',\n        actionsTaken: 1\n      };\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: `🤖 Agent '${name}' execution result:\\n\\n${result.summary}\\n\\nStatus: ${result.status}\\nActions taken: ${result.actionsTaken || 0}`\n        }]\n      };\n    } catch (error) {\n      logger.error(`Failed to execute agent '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to execute agent: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async createElement(args: {name: string; type: string; description: string; content?: string; metadata?: Record<string, any>}) {\n    try {\n      const { name, type, description, content, metadata } = args;\n      \n      // Validate element type\n      if (!Object.values(ElementType).includes(type as ElementType)) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Invalid element type '${type}'. Valid types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n          }]\n        };\n      }\n      \n      // Validate inputs\n      const validatedName = validateFilename(name);\n      const validatedDescription = sanitizeInput(description, SECURITY_LIMITS.MAX_METADATA_FIELD_LENGTH);\n      \n      // SECURITY FIX: Sanitize metadata to prevent prototype pollution\n      const sanitizedMetadata = this.sanitizeMetadata(metadata || {});\n      \n      // Create element based on type\n      switch (type as ElementType) {\n        case ElementType.PERSONA:\n          // Use existing persona creation logic\n          return this.createPersona(\n            validatedName, \n            validatedDescription, \n            sanitizedMetadata?.category || 'general',\n            content || '',\n            sanitizedMetadata?.triggers\n          );\n          \n        case ElementType.SKILL:\n          const skill = await this.skillManager.create({\n            name: validatedName,\n            description: validatedDescription,\n            ...sanitizedMetadata,\n            content: content || ''\n          });\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Created skill '${skill.metadata.name}' successfully`\n            }]\n          };\n          \n        case ElementType.TEMPLATE:\n          const template = await this.templateManager.create({\n            name: validatedName,\n            description: validatedDescription,\n            content: content || '',\n            ...sanitizedMetadata\n          });\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Created template '${template.metadata.name}' successfully`\n            }]\n          };\n          \n        case ElementType.AGENT:\n          const agentResult = await this.agentManager.create(\n            validatedName,\n            validatedDescription,\n            content || '',\n            sanitizedMetadata\n          );\n          if (!agentResult.success) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ ${agentResult.message}`\n              }]\n            };\n          }\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Created agent '${validatedName}' successfully`\n            }]\n          };\n          \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Element type '${type}' is not yet supported for creation`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to create element:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to create element: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async editElement(args: {name: string; type: string; field: string; value: string | number | boolean | Record<string, any> | any[]}) {\n    try {\n      const { name, type, field, value } = args;\n      \n      // Validate element type\n      if (!Object.values(ElementType).includes(type as ElementType)) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Invalid element type '${type}'. Valid types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n          }]\n        };\n      }\n      \n      // For personas, use existing edit logic\n      if (type === ElementType.PERSONA) {\n        return this.editPersona(name, field, String(value));\n      }\n      \n      // Get the appropriate manager based on type\n      let manager: SkillManager | TemplateManager | AgentManager | null = null;\n      switch (type as ElementType) {\n        case ElementType.SKILL:\n          manager = this.skillManager;\n          break;\n        case ElementType.TEMPLATE:\n          manager = this.templateManager;\n          break;\n        case ElementType.AGENT:\n          manager = this.agentManager;\n          break;\n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Element type '${type}' is not yet supported for editing`\n            }]\n          };\n      }\n      \n      // Find the element\n      const element = await manager!.find((e: any) => e.metadata.name === name);\n      if (!element) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ ${type} '${name}' not found`\n          }]\n        };\n      }\n      \n      // Handle nested field updates (e.g., \"metadata.author\")\n      const fieldParts = field.split('.');\n      \n      // SECURITY FIX: Validate field names to prevent prototype pollution\n      const dangerousProperties = ['__proto__', 'constructor', 'prototype'];\n      for (const part of fieldParts) {\n        if (dangerousProperties.includes(part)) {\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Invalid field name: '${part}' is not allowed for security reasons`\n            }]\n          };\n        }\n      }\n      \n      let target: any = element;\n      for (let i = 0; i < fieldParts.length - 1; i++) {\n        // SECURITY: Additional check to prevent prototype pollution\n        if (typeof target !== 'object' || target === null) {\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Cannot set property '${fieldParts[i]}' on non-object`\n            }]\n          };\n        }\n        \n        if (!target[fieldParts[i]]) {\n          // SECURITY: Use Object.defineProperty to avoid prototype chain pollution\n          Object.defineProperty(target, fieldParts[i], {\n            value: {},\n            writable: true,\n            enumerable: true,\n            configurable: true\n          });\n        }\n        target = target[fieldParts[i]];\n      }\n      \n      // Update the field\n      const lastField = fieldParts[fieldParts.length - 1];\n      // SECURITY: Use Object.defineProperty for the final assignment too\n      Object.defineProperty(target, lastField, {\n        value: value,\n        writable: true,\n        enumerable: true,\n        configurable: true\n      });\n      \n      // Update version - handle various version formats\n      if (element.version) {\n        const versionParts = element.version.split('.');\n        if (versionParts.length >= 3) {\n          // Standard semver format (e.g., 1.0.0)\n          const patch = parseInt(versionParts[2]) || 0;\n          versionParts[2] = String(patch + 1);\n          element.version = versionParts.join('.');\n        } else if (versionParts.length === 2) {\n          // Two-part version (e.g., 1.0) - add patch version\n          element.version = `${element.version}.1`;\n        } else if (versionParts.length === 1 && /^\\d+$/.test(versionParts[0])) {\n          // Single number version (e.g., 1) - convert to semver\n          element.version = `${element.version}.0.1`;\n        } else {\n          // Non-standard version - append or replace with standard format\n          element.version = '1.0.1';\n        }\n      } else {\n        // No version - set initial version\n        element.version = '1.0.0';\n      }\n      \n      // Save the element - need to determine filename\n      const filename = `${element.metadata.name.toLowerCase().replace(/[^a-z0-9-]/g, '-')}.md`;\n      await manager!.save(element as any, filename);\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: `✅ Updated ${type} '${name}' - ${field} set to: ${JSON.stringify(value)}`\n        }]\n      };\n    } catch (error) {\n      logger.error(`Failed to edit element:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to edit element: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async validateElement(args: {name: string; type: string; strict?: boolean}) {\n    try {\n      const { name, type, strict = false } = args;\n      \n      // Validate element type\n      if (!Object.values(ElementType).includes(type as ElementType)) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Invalid element type '${type}'. Valid types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n          }]\n        };\n      }\n      \n      // For personas, use existing validation logic\n      if (type === ElementType.PERSONA) {\n        return this.validatePersona(name);\n      }\n      \n      // Get the appropriate manager based on type\n      let manager: SkillManager | TemplateManager | AgentManager | null = null;\n      switch (type as ElementType) {\n        case ElementType.SKILL:\n          manager = this.skillManager;\n          break;\n        case ElementType.TEMPLATE:\n          manager = this.templateManager;\n          break;\n        case ElementType.AGENT:\n          manager = this.agentManager;\n          break;\n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Element type '${type}' is not yet supported for validation`\n            }]\n          };\n      }\n      \n      // Find the element\n      const element = await manager!.find((e: any) => e.metadata.name === name);\n      if (!element) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ ${type} '${name}' not found`\n          }]\n        };\n      }\n      \n      // Perform validation\n      const validationResult = element.validate();\n      \n      // Format validation report\n      let report = `🔍 Validation Report for ${type} '${name}':\\n`;\n      report += `${validationResult.valid ? '✅' : '❌'} Status: ${validationResult.valid ? 'Valid' : 'Invalid'}\\n\\n`;\n      \n      if (validationResult.errors && validationResult.errors.length > 0) {\n        report += `❌ Errors (${validationResult.errors.length}):\\n`;\n        validationResult.errors.forEach((error: any) => {\n          report += `   • ${error.field || 'General'}: ${error.message}\\n`;\n          if (error.fix) {\n            report += `     💡 Fix: ${error.fix}\\n`;\n          }\n        });\n        report += '\\n';\n      }\n      \n      if (validationResult.warnings && validationResult.warnings.length > 0) {\n        report += `⚠️  Warnings (${validationResult.warnings.length}):\\n`;\n        validationResult.warnings.forEach((warning: any) => {\n          report += `   • ${warning.field || 'General'}: ${warning.message}\\n`;\n          if (warning.suggestion) {\n            report += `     💡 Suggestion: ${warning.suggestion}\\n`;\n          }\n        });\n        report += '\\n';\n      }\n      \n      if (validationResult.suggestions && validationResult.suggestions.length > 0) {\n        report += `💡 Suggestions:\\n`;\n        validationResult.suggestions.forEach((suggestion: string) => {\n          report += `   • ${suggestion}\\n`;\n        });\n      }\n      \n      // Add strict mode additional checks if requested\n      if (strict) {\n        report += '\\n📋 Strict Mode: Additional quality checks applied';\n      }\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: report\n        }]\n      };\n    } catch (error) {\n      logger.error(`Failed to validate element:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to validate element: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async deleteElement(args: {name: string; type: string; deleteData?: boolean}) {\n    try {\n      const { name, type, deleteData } = args;\n      \n      // Validate element type\n      if (!Object.values(ElementType).includes(type as ElementType)) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Invalid element type: ${type}\\nValid types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n          }]\n        };\n      }\n      \n      // Get the appropriate manager based on type\n      let manager: SkillManager | TemplateManager | AgentManager | null = null;\n      switch (type as ElementType) {\n        case ElementType.SKILL:\n          manager = this.skillManager;\n          break;\n        case ElementType.TEMPLATE:\n          manager = this.templateManager;\n          break;\n        case ElementType.AGENT:\n          manager = this.agentManager;\n          break;\n        case ElementType.PERSONA:\n          // For personas, use a different approach\n          const personaPath = path.join(this.personasDir, `${name}.md`);\n          try {\n            await fs.access(personaPath);\n            await fs.unlink(personaPath);\n            \n            // Reload personas to update the cache\n            await this.loadPersonas();\n            \n            return {\n              content: [{\n                type: \"text\",\n                text: `✅ Successfully deleted persona '${name}'`\n              }]\n            };\n          } catch (error) {\n            if ((error as any).code === 'ENOENT') {\n              return {\n                content: [{\n                  type: \"text\",\n                  text: `❌ Persona '${name}' not found`\n                }]\n              };\n            }\n            throw error;\n          }\n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Element type '${type}' is not yet supported for deletion`\n            }]\n          };\n      }\n      \n      // Ensure manager was assigned (TypeScript type safety)\n      if (!manager) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Element type '${type}' is not supported for deletion`\n          }]\n        };\n      }\n      \n      // Find the element first to check if it exists\n      const element = await manager!.find((e: any) => e.metadata.name === name);\n      if (!element) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ ${type} '${name}' not found`\n          }]\n        };\n      }\n      \n      // Check for associated data files\n      let dataFiles: string[] = [];\n      \n      // Agent-specific: Check for state files\n      if (type === ElementType.AGENT) {\n        const stateDir = path.join(this.portfolioManager.getElementDir(ElementType.AGENT), '.state');\n        const stateFile = path.join(stateDir, `${name}-state.json`);\n        try {\n          const stat = await fs.stat(stateFile);\n          dataFiles.push(`- .state/${name}-state.json (${(stat.size / 1024).toFixed(2)} KB)`);\n        } catch (error) {\n          // No state file exists, which is fine\n        }\n      }\n      \n      // Memory-specific: Check for storage files\n      if (type === ElementType.MEMORY) {\n        const storageDir = path.join(this.portfolioManager.getElementDir(ElementType.MEMORY), '.storage');\n        const storageFile = path.join(storageDir, `${name}-memory.json`);\n        try {\n          const stat = await fs.stat(storageFile);\n          dataFiles.push(`- .storage/${name}-memory.json (${(stat.size / 1024).toFixed(2)} KB)`);\n        } catch (error) {\n          // No storage file exists, which is fine\n        }\n      }\n      \n      // Ensemble-specific: Check for config files\n      if (type === ElementType.ENSEMBLE) {\n        const configDir = path.join(this.portfolioManager.getElementDir(ElementType.ENSEMBLE), '.configs');\n        const configFile = path.join(configDir, `${name}-config.json`);\n        try {\n          const stat = await fs.stat(configFile);\n          dataFiles.push(`- .configs/${name}-config.json (${(stat.size / 1024).toFixed(2)} KB)`);\n        } catch (error) {\n          // No config file exists, which is fine\n        }\n      }\n      \n      // If data files exist and deleteData is not specified, we need to inform the user\n      if (dataFiles.length > 0 && deleteData === undefined) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `⚠️  This ${type} has associated data files:\\n${dataFiles.join('\\n')}\\n\\nWould you like to delete these data files as well?\\n\\n• To delete everything (element + data), say: \"Yes, delete all data\"\\n• To keep the data files, say: \"No, keep the data\"\\n• To cancel, say: \"Cancel\"`\n          }]\n        };\n      }\n      \n      // Delete the main element file\n      const filename = `${slugify(name)}.md`;\n      const filepath = path.join(this.portfolioManager.getElementDir(type as ElementType), filename);\n      \n      try {\n        await fs.unlink(filepath);\n      } catch (error) {\n        if ((error as any).code === 'ENOENT') {\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ ${type} file '${filename}' not found`\n            }]\n          };\n        }\n        throw error;\n      }\n      \n      // Delete associated data files if requested\n      if (deleteData && dataFiles.length > 0) {\n        const updatedDataFiles: string[] = [];\n        \n        if (type === ElementType.AGENT) {\n          const stateFile = path.join(this.portfolioManager.getElementDir(ElementType.AGENT), '.state', `${name}-state.json`);\n          try {\n            await fs.unlink(stateFile);\n            updatedDataFiles.push(`${dataFiles[0]} ✓ deleted`);\n          } catch (error) {\n            // Log but don't fail if state file deletion fails\n            logger.warn(`Failed to delete agent state file: ${error}`);\n            updatedDataFiles.push(`${dataFiles[0]} ⚠️ deletion failed`);\n          }\n        } else if (type === ElementType.MEMORY) {\n          const storageFile = path.join(this.portfolioManager.getElementDir(ElementType.MEMORY), '.storage', `${name}-memory.json`);\n          try {\n            await fs.unlink(storageFile);\n            updatedDataFiles.push(`${dataFiles[0]} ✓ deleted`);\n          } catch (error) {\n            // Log but don't fail if storage file deletion fails\n            logger.warn(`Failed to delete memory storage file: ${error}`);\n            updatedDataFiles.push(`${dataFiles[0]} ⚠️ deletion failed`);\n          }\n        } else if (type === ElementType.ENSEMBLE) {\n          const configFile = path.join(this.portfolioManager.getElementDir(ElementType.ENSEMBLE), '.configs', `${name}-config.json`);\n          try {\n            await fs.unlink(configFile);\n            updatedDataFiles.push(`${dataFiles[0]} ✓ deleted`);\n          } catch (error) {\n            // Log but don't fail if config file deletion fails\n            logger.warn(`Failed to delete ensemble config file: ${error}`);\n            updatedDataFiles.push(`${dataFiles[0]} ⚠️ deletion failed`);\n          }\n        }\n        \n        dataFiles = updatedDataFiles;\n      }\n      \n      // Build success message\n      let message = `✅ Successfully deleted ${type} '${name}'`;\n      if (dataFiles.length > 0) {\n        if (deleteData) {\n          message += `\\n\\nAssociated data files:\\n${dataFiles.join('\\n')}`;\n        } else {\n          message += `\\n\\n⚠️ Associated data files were preserved:\\n${dataFiles.join('\\n')}`;\n        }\n      }\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: message\n        }]\n      };\n      \n    } catch (error) {\n      logger.error(`Failed to delete element:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to delete element: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  // checkRateLimit and fetchFromGitHub are now handled by GitHubClient\n\n  async browseCollection(section?: string, type?: string) {\n    try {\n      // Enhanced input validation for section and type\n      const validatedSection = section ? validateCategory(section) : undefined;\n      const validatedType = type ? validateCategory(type) : undefined;\n      \n      const result = await this.collectionBrowser.browseCollection(validatedSection, validatedType);\n      \n      // Handle sections view\n      const items = result.items;\n      const categories = result.sections || result.categories;\n      \n      const text = this.collectionBrowser.formatBrowseResults(\n        items, \n        categories, \n        validatedSection, \n        validatedType, \n        this.getPersonaIndicator()\n      );\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: text,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Collection browsing failed: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n  }\n\n  async searchCollection(query: string) {\n    try {\n      // Enhanced input validation for search query\n      const validatedQuery = MCPInputValidator.validateSearchQuery(query);\n      \n      const items = await this.collectionSearch.searchCollection(validatedQuery);\n      const text = this.collectionSearch.formatSearchResults(items, validatedQuery, this.getPersonaIndicator());\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: text,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error searching collection: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n  }\n\n  async getCollectionContent(path: string) {\n    try {\n      const { metadata, content } = await this.personaDetails.getCollectionContent(path);\n      const text = this.personaDetails.formatPersonaDetails(metadata, content, path, this.getPersonaIndicator());\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: text,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error fetching content: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n  }\n\n  async installContent(inputPath: string) {\n    try {\n      const result = await this.elementInstaller.installContent(inputPath);\n      \n      if (!result.success) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `⚠️ ${result.message}`,\n            },\n          ],\n        };\n      }\n      \n      // If it's a persona, reload personas\n      if (result.elementType === ElementType.PERSONA) {\n        await this.loadPersonas();\n      }\n      \n      const text = this.elementInstaller.formatInstallSuccess(\n        result.metadata!, \n        result.filename!,\n        result.elementType!\n      );\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: text,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error installing AI customization element: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n  }\n\n  async submitContent(contentIdentifier: string) {\n    // Check GitHub authentication first\n    const authStatus = await this.githubAuthManager.getAuthStatus();\n    \n    if (!authStatus.isAuthenticated) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}🔐 **GitHub Authentication Required**\\n\\n` +\n                  `To submit content to the DollhouseMCP collection, you need to connect to GitHub.\\n\\n` +\n                  `**Why GitHub?**\\n` +\n                  `• It's where our community shares content\\n` +\n                  `• Free account with millions of developers\\n` +\n                  `• Secure and reliable platform\\n\\n` +\n                  `**To get started:**\\n` +\n                  `Just say \"connect to GitHub\" or \"set up GitHub\"\\n\\n` +\n                  `Don't have a GitHub account? No problem! You'll be guided through creating one.`,\n          },\n        ],\n      };\n    }\n    \n    // Find the content in local collection\n    let persona = this.personas.get(contentIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === contentIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Content not found: ${contentIdentifier}`,\n          },\n        ],\n      };\n    }\n\n    // Validate persona content before submission\n    try {\n      // Read the full persona file content\n      const fullPath = path.join(this.personasDir, persona.filename);\n      const fileContent = await PathValidator.safeReadFile(fullPath);\n      \n      // Validate content for security threats\n      const contentValidation = ContentValidator.validateAndSanitize(fileContent);\n      if (!contentValidation.isValid && contentValidation.severity === 'critical') {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ **Security Validation Failed**\\n\\n` +\n              `This persona contains content that could be used for prompt injection attacks:\\n` +\n              `• ${contentValidation.detectedPatterns?.join('\\n• ')}\\n\\n` +\n              `Please remove these patterns before submitting to the collection.`,\n            },\n          ],\n        };\n      }\n      \n      // Validate metadata\n      const metadataValidation = ContentValidator.validateMetadata(persona.metadata);\n      if (!metadataValidation.isValid) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}⚠️ **Metadata Security Warning**\\n\\n` +\n              `The persona metadata contains potentially problematic content:\\n` +\n              `• ${metadataValidation.detectedPatterns?.join('\\n• ')}\\n\\n` +\n              `Please fix these issues before submitting.`,\n            },\n          ],\n        };\n      }\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error validating persona: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n\n    const { githubIssueUrl } = this.personaSubmitter.generateSubmissionIssue(persona);\n    const text = this.personaSubmitter.formatSubmissionResponse(persona, githubIssueUrl, this.getPersonaIndicator());\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: text,\n        },\n      ],\n    };\n  }\n\n  // User identity management\n  async setUserIdentity(username: string, email?: string) {\n    try {\n      if (!username || username.trim().length === 0) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ Username cannot be empty`,\n            },\n          ],\n        };\n      }\n\n      // Validate and sanitize username\n      const validatedUsername = validateUsername(username);\n      \n      // Validate email if provided\n      let validatedEmail: string | undefined;\n      if (email) {\n        const sanitizedEmail = sanitizeInput(email, 100);\n        if (!VALIDATION_PATTERNS.SAFE_EMAIL.test(sanitizedEmail)) {\n          throw new Error('Invalid email format');\n        }\n        validatedEmail = sanitizedEmail;\n      }\n\n      // Set the validated user identity\n      this.currentUser = validatedUsername;\n      if (validatedEmail) {\n        process.env.DOLLHOUSE_EMAIL = validatedEmail;\n      }\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **User Identity Set**\\n\\n` +\n            `👤 **Username:** ${validatedUsername}\\n` +\n            `${validatedEmail ? `📧 **Email:** ${validatedEmail}\\n` : ''}` +\n            `\\n🎯 **Next Steps:**\\n` +\n            `• New personas you create will be attributed to \"${validatedUsername}\"\\n` +\n            `• Set environment variable \\`DOLLHOUSE_USER=${validatedUsername}\\` to persist this setting\\n` +\n            `${validatedEmail ? `• Set environment variable \\`DOLLHOUSE_EMAIL=${validatedEmail}\\` for contact info\\n` : ''}` +\n            `• Use \\`clear_user_identity\\` to return to anonymous mode`,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Validation Error**\\n\\n` +\n              `${sanitized.message}\\n\\n` +\n              `Please provide a valid username (alphanumeric characters, hyphens, underscores, dots only).`,\n          },\n        ],\n      };\n    }\n  }\n\n  async getUserIdentity() {\n    const email = process.env.DOLLHOUSE_EMAIL;\n    \n    if (!this.currentUser) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}👤 **User Identity: Anonymous**\\n\\n` +\n            `🔒 **Status:** Anonymous mode\\n` +\n            `📝 **Attribution:** Personas will use anonymous IDs\\n\\n` +\n            `**To set your identity:**\\n` +\n            `• Use: \\`set_user_identity \"your-username\"\\`\\n` +\n            `• Or set environment variable: \\`DOLLHOUSE_USER=your-username\\``,\n          },\n        ],\n      };\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}👤 **User Identity: ${this.currentUser}**\\n\\n` +\n          `✅ **Status:** Authenticated\\n` +\n          `👤 **Username:** ${this.currentUser}\\n` +\n          `${email ? `📧 **Email:** ${email}\\n` : ''}` +\n          `📝 **Attribution:** New personas will be credited to \"${this.currentUser}\"\\n\\n` +\n          `**Environment Variables:**\\n` +\n          `• \\`DOLLHOUSE_USER=${this.currentUser}\\`\\n` +\n          `${email ? `• \\`DOLLHOUSE_EMAIL=${email}\\`\\n` : ''}` +\n          `\\n**Management:**\\n` +\n          `• Use \\`clear_user_identity\\` to return to anonymous mode\\n` +\n          `• Use \\`set_user_identity \"new-username\"\\` to change username`,\n        },\n      ],\n    };\n  }\n\n  async clearUserIdentity() {\n    const wasSet = this.currentUser !== null;\n    const previousUser = this.currentUser;\n    this.currentUser = null;\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: wasSet \n            ? `${this.getPersonaIndicator()}✅ **User Identity Cleared**\\n\\n` +\n              `👤 **Previous:** ${previousUser}\\n` +\n              `🔒 **Current:** Anonymous mode\\n\\n` +\n              `📝 **Effect:** New personas will use anonymous IDs\\n\\n` +\n              `⚠️ **Note:** This only affects the current session.\\n` +\n              `To persist this change, unset the \\`DOLLHOUSE_USER\\` environment variable.`\n            : `${this.getPersonaIndicator()}ℹ️ **Already in Anonymous Mode**\\n\\n` +\n              `👤 No user identity was set.\\n\\n` +\n              `Use \\`set_user_identity \"username\"\\` to set your identity.`,\n        },\n      ],\n    };\n  }\n\n  private getCurrentUserForAttribution(): string {\n    return this.currentUser || generateAnonymousId();\n  }\n\n  // GitHub authentication management\n  async setupGitHubAuth() {\n    try {\n      // Check current auth status first\n      const currentStatus = await this.githubAuthManager.getAuthStatus();\n      \n      if (currentStatus.isAuthenticated) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **Already Connected to GitHub**\\n\\n` +\n                  `👤 **Username:** ${currentStatus.username}\\n` +\n                  `🔑 **Permissions:** ${currentStatus.scopes?.join(', ') || 'basic access'}\\n\\n` +\n                  `You're all set! You can:\\n` +\n                  `• Browse the collection\\n` +\n                  `• Install content\\n` +\n                  `• Submit your creations\\n\\n` +\n                  `To disconnect, say \"disconnect from GitHub\"`\n          }]\n        };\n      }\n      \n      // Initiate device flow\n      const deviceResponse = await this.githubAuthManager.initiateDeviceFlow();\n      \n      // Start polling in background\n      this.pollForAuthCompletion(deviceResponse.device_code, deviceResponse.interval);\n      \n      // Return instructions to user\n      return {\n        content: [{\n          type: \"text\",\n          text: this.githubAuthManager.formatAuthInstructions(deviceResponse)\n        }]\n      };\n    } catch (error) {\n      logger.error('Failed to setup GitHub auth', { error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ **Authentication Setup Failed**\\n\\n` +\n                `Unable to start GitHub authentication: ${error instanceof Error ? error.message : 'Unknown error'}\\n\\n` +\n                `Please check your internet connection and try again.`\n        }]\n      };\n    }\n  }\n  \n  async checkGitHubAuth() {\n    try {\n      const status = await this.githubAuthManager.getAuthStatus();\n      \n      if (status.isAuthenticated) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **GitHub Connected**\\n\\n` +\n                  `👤 **Username:** ${status.username}\\n` +\n                  `🔑 **Permissions:** ${status.scopes?.join(', ') || 'basic access'}\\n\\n` +\n                  `**Available Actions:**\\n` +\n                  `✅ Browse collection\\n` +\n                  `✅ Install content\\n` +\n                  `✅ Submit content\\n\\n` +\n                  `Everything is working properly!`\n          }]\n        };\n      } else if (status.hasToken) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}⚠️ **GitHub Token Invalid**\\n\\n` +\n                  `A GitHub token was found but it appears to be invalid or expired.\\n\\n` +\n                  `**To fix this:**\\n` +\n                  `1. Say \"set up GitHub\" to authenticate again\\n` +\n                  `2. Or check your GITHUB_TOKEN environment variable\\n\\n` +\n                  `Note: Browse and install still work without authentication!`\n          }]\n        };\n      } else {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}🔒 **Not Connected to GitHub**\\n\\n` +\n                  `You're not currently authenticated with GitHub.\\n\\n` +\n                  `**What works without auth:**\\n` +\n                  `✅ Browse the public collection\\n` +\n                  `✅ Install community content\\n` +\n                  `❌ Submit your own content (requires auth)\\n\\n` +\n                  `To connect, just say \"set up GitHub\" or \"connect to GitHub\"`\n          }]\n        };\n      }\n    } catch (error) {\n      logger.error('Failed to check GitHub auth', { error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ **Unable to Check Authentication**\\n\\n` +\n                `Error: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async clearGitHubAuth() {\n    try {\n      await this.githubAuthManager.clearAuthentication();\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}✅ **GitHub Disconnected**\\n\\n` +\n                `Your GitHub connection has been cleared.\\n\\n` +\n                `**What still works:**\\n` +\n                `✅ Browse the public collection\\n` +\n                `✅ Install community content\\n` +\n                `❌ Submit content (requires reconnection)\\n\\n` +\n                `To reconnect later, just say \"connect to GitHub\"\\n\\n` +\n                `⚠️ **Note:** To fully remove authentication, also unset the GITHUB_TOKEN environment variable.`\n        }]\n      };\n    } catch (error) {\n      logger.error('Failed to clear GitHub auth', { error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ **Failed to Clear Authentication**\\n\\n` +\n                `Error: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  /**\n   * Poll for auth completion in the background\n   */\n  private async pollForAuthCompletion(deviceCode: string, interval: number): Promise<void> {\n    try {\n      const tokenResponse = await this.githubAuthManager.pollForToken(deviceCode, interval);\n      const authStatus = await this.githubAuthManager.completeAuthentication(tokenResponse);\n      \n      // Log success (user will see this in their next interaction)\n      logger.info('GitHub authentication completed successfully', { \n        username: authStatus.username,\n        scopes: authStatus.scopes \n      });\n    } catch (error) {\n      // Log error but don't throw - this runs in background\n      logger.error('GitHub authentication polling failed', { error });\n    }\n  }\n\n  // Chat-based persona management tools\n  async createPersona(name: string, description: string, category: string, instructions: string, triggers?: string) {\n    try {\n      // Validate required fields\n      if (!name || !description || !category || !instructions) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ **Missing Required Fields**\\n\\n` +\n                `Please provide all required fields:\\n` +\n                `• **name**: Display name for the persona\\n` +\n                `• **description**: Brief description of what it does\\n` +\n                `• **category**: creative, professional, educational, gaming, or personal\\n` +\n                `• **instructions**: The persona's behavioral guidelines\\n\\n` +\n                `**Optional:**\\n` +\n                `• **triggers**: Comma-separated keywords for activation`,\n            },\n          ],\n        };\n      }\n\n      // Sanitize and validate inputs\n      const sanitizedName = sanitizeInput(name, 100);\n      const sanitizedDescription = sanitizeInput(description, 500);\n      const sanitizedInstructions = sanitizeInput(instructions);\n      const sanitizedTriggers = triggers ? sanitizeInput(triggers, 200) : '';\n\n      // Validate name length and format\n      if (sanitizedName.length < 2) {\n        throw new Error('Persona name must be at least 2 characters long');\n      }\n\n      // Validate category\n      const validatedCategory = validateCategory(category);\n\n      // Validate content sizes\n      validateContentSize(sanitizedInstructions, SECURITY_LIMITS.MAX_CONTENT_LENGTH);\n      validateContentSize(sanitizedDescription, 2000); // 2KB max for description\n\n      // Validate content for security threats\n      const nameValidation = ContentValidator.validateAndSanitize(sanitizedName);\n      if (!nameValidation.isValid) {\n        throw new Error(`Name contains prohibited content: ${nameValidation.detectedPatterns?.join(', ')}`);\n      }\n\n      const descValidation = ContentValidator.validateAndSanitize(sanitizedDescription);\n      if (!descValidation.isValid) {\n        throw new Error(`Description contains prohibited content: ${descValidation.detectedPatterns?.join(', ')}`);\n      }\n\n      const instructionsValidation = ContentValidator.validateAndSanitize(sanitizedInstructions);\n      if (!instructionsValidation.isValid && instructionsValidation.severity === 'critical') {\n        throw new Error(`Instructions contain security threats: ${instructionsValidation.detectedPatterns?.join(', ')}`);\n      }\n\n      // Generate metadata\n      const author = this.getCurrentUserForAttribution();\n      const uniqueId = generateUniqueId(sanitizedName, this.currentUser || undefined);\n      const filename = validateFilename(`${slugify(sanitizedName)}.md`);\n      const filePath = path.join(this.personasDir, filename);\n\n    // Check if file already exists\n    try {\n      await PathValidator.validatePersonaPath(filePath);\n      await fs.access(filePath);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}⚠️ **Persona Already Exists**\\n\\n` +\n              `A persona file named \"${filename}\" already exists.\\n` +\n              `Use \\`edit_persona\\` to modify it, or choose a different name.`,\n          },\n        ],\n      };\n    } catch {\n      // File doesn't exist, proceed with creation\n    }\n\n      // Parse and sanitize triggers\n      const triggerList = sanitizedTriggers ? \n        sanitizedTriggers.split(',').map(t => sanitizeInput(t.trim(), 50)).filter(t => t.length > 0) : \n        [];\n\n      // Create persona metadata with sanitized values\n      const metadata: PersonaMetadata = {\n        name: sanitizedName,\n        description: sanitizedDescription,\n        unique_id: uniqueId,\n        author,\n        triggers: triggerList,\n        version: \"1.0\",\n        category: validatedCategory,\n        age_rating: \"all\",\n        content_flags: [\"user-created\"],\n        ai_generated: true,\n        generation_method: \"Claude\",\n        price: \"free\",\n        revenue_split: \"80/20\",\n        license: \"CC-BY-SA-4.0\",\n        created_date: new Date().toISOString().slice(0, 10)\n      };\n\n      // Create full persona content with sanitized values\n      const frontmatter = Object.entries(metadata)\n        .map(([key, value]) => `${key}: ${JSON.stringify(value)}`)\n        .join('\\n');\n\n      const personaContent = `---\n${frontmatter}\n---\n\n# ${sanitizedName}\n\n${sanitizedInstructions}\n\n## Response Style\n- Follow the behavioral guidelines above\n- Maintain consistency with the persona's character\n- Adapt responses to match the intended purpose\n\n## Usage Notes\n- Created via DollhouseMCP chat interface\n- Author: ${author}\n- Version: 1.0`;\n\n      // Validate final content size\n      validateContentSize(personaContent, SECURITY_LIMITS.MAX_PERSONA_SIZE_BYTES);\n\n    try {\n      // Use file locking to prevent race conditions\n      await FileLockManager.withLock(`persona:${sanitizedName}`, async () => {\n        // Double-check file doesn't exist (in case of race condition)\n        try {\n          await fs.access(filePath);\n          throw new Error(`Persona file \"${filename}\" already exists`);\n        } catch (error: any) {\n          // If error is not ENOENT (file not found), re-throw it\n          if (error.code !== 'ENOENT' && error.message?.includes('already exists')) {\n            throw error;\n          }\n          // File doesn't exist, proceed\n        }\n        \n        // Write the file atomically\n        await FileLockManager.atomicWriteFile(filePath, personaContent);\n      });\n      \n      // Reload personas to include the new one\n      await this.loadPersonas();\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **Persona Created Successfully!**\\n\\n` +\n              `🎭 **${sanitizedName}** by ${author}\\n` +\n              `📁 Category: ${category}\\n` +\n              `🆔 Unique ID: ${uniqueId}\\n` +\n              `📄 Saved as: ${filename}\\n` +\n              `📊 Total personas: ${this.personas.size}\\n\\n` +\n              `🎯 **Ready to use:** \\`activate_persona \"${sanitizedName}\"\\`\\n` +\n              `📤 **Share it:** \\`submit_content \"${sanitizedName}\"\\`\\n` +\n              `✏️ **Edit it:** \\`edit_persona \"${sanitizedName}\" \"field\" \"new value\"\\``,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Error Creating Persona**\\n\\n` +\n              `Failed to write persona file: ${sanitized.message}\\n\\n` +\n              `Please check permissions and try again.`,\n          },\n        ],\n      };\n    }\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Validation Error**\\n\\n` +\n              `${sanitized.message}\\n\\n` +\n              `Please fix the issue and try again.`,\n          },\n        ],\n      };\n    }\n  }\n\n  async editPersona(personaIdentifier: string, field: string, value: string) {\n    if (!personaIdentifier || !field || !value) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Missing Parameters**\\n\\n` +\n              `Usage: \\`edit_persona \"persona_name\" \"field\" \"new_value\"\\`\\n\\n` +\n              `**Editable fields:**\\n` +\n              `• **name** - Display name\\n` +\n              `• **description** - Brief description\\n` +\n              `• **category** - creative, professional, educational, gaming, personal\\n` +\n              `• **instructions** - Main persona content\\n` +\n              `• **triggers** - Comma-separated keywords\\n` +\n              `• **version** - Version number`,\n          },\n        ],\n      };\n    }\n\n    // Find the persona\n    let persona = this.personas.get(personaIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === personaIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Persona Not Found**\\n\\n` +\n              `Could not find persona: \"${personaIdentifier}\"\\n\\n` +\n              `Use \\`list_personas\\` to see available personas.`,\n          },\n        ],\n      };\n    }\n\n    const validFields = ['name', 'description', 'category', 'instructions', 'triggers', 'version'];\n    if (!validFields.includes(field.toLowerCase())) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Invalid Field**\\n\\n` +\n              `Field \"${field}\" is not editable.\\n\\n` +\n              `**Valid fields:** ${validFields.join(', ')}`,\n          },\n        ],\n      };\n    }\n\n    let filePath = path.join(this.personasDir, persona.filename);\n    let isDefault = isDefaultPersona(persona.filename);\n\n    try {\n      // Read current file\n      const fileContent = await PathValidator.safeReadFile(filePath);\n      \n      // Use secure YAML parser\n      let parsed;\n      try {\n        parsed = SecureYamlParser.safeMatter(fileContent);\n      } catch (error) {\n        if (error instanceof SecurityError) {\n          return {\n            content: [\n              {\n                type: \"text\",\n                text: `${this.getPersonaIndicator()}❌ **Security Error**\\n\\n` +\n                  `Cannot edit persona due to security threat: ${error.message}`,\n              },\n            ],\n          };\n        }\n        throw error;\n      }\n      \n      // If editing a default persona, create a copy instead\n      if (isDefault) {\n        // Generate unique ID for the copy\n        const author = this.currentUser || generateAnonymousId();\n        const uniqueId = generateUniqueId(persona.metadata.name, author);\n        const newFilename = `${uniqueId}.md`;\n        const newFilePath = path.join(this.personasDir, newFilename);\n        \n        // Create copy of the default persona\n        const content = await PathValidator.safeReadFile(filePath);\n        \n        // Use file locking to prevent race conditions when creating the copy\n        await FileLockManager.withLock(`persona:${persona.metadata.name}-copy`, async () => {\n          await FileLockManager.atomicWriteFile(newFilePath, content);\n        });\n        \n        // Update file path to point to the copy\n        filePath = newFilePath;\n        \n        // Update the unique_id in the metadata\n        parsed.data.unique_id = uniqueId;\n        parsed.data.author = author;\n      }\n      \n      // Update the appropriate field\n      const normalizedField = field.toLowerCase();\n      \n      // Validate the new value for security threats\n      const valueValidation = ContentValidator.validateAndSanitize(value);\n      if (!valueValidation.isValid && valueValidation.severity === 'critical') {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ **Security Validation Failed**\\n\\n` +\n              `The new value contains prohibited content:\\n` +\n              `• ${valueValidation.detectedPatterns?.join('\\n• ')}\\n\\n` +\n              `Please remove these patterns and try again.`,\n            },\n          ],\n        };\n      }\n      \n      // Use sanitized value if needed\n      let sanitizedValue = valueValidation.sanitizedContent || value;\n      \n      // Always remove shell metacharacters from display output\n      const displayValue = sanitizedValue.replace(/[;&|`$()]/g, '');\n      \n      if (normalizedField === 'instructions') {\n        // Update the main content\n        parsed.content = sanitizedValue;\n      } else if (normalizedField === 'triggers') {\n        // Parse triggers as comma-separated list\n        parsed.data[normalizedField] = sanitizedValue.split(',').map(t => t.trim()).filter(t => t.length > 0);\n      } else if (normalizedField === 'category') {\n        // Validate category\n        const validCategories = ['creative', 'professional', 'educational', 'gaming', 'personal'];\n        if (!validCategories.includes(sanitizedValue.toLowerCase())) {\n          return {\n            content: [\n              {\n                type: \"text\",\n                text: `${this.getPersonaIndicator()}❌ **Invalid Category**\\n\\n` +\n                    `Category must be one of: ${validCategories.join(', ')}\\n` +\n                    `You provided: \"${sanitizedValue}\"`,\n              },\n            ],\n          };\n        }\n        parsed.data[normalizedField] = sanitizedValue.toLowerCase();\n      } else {\n        // Update metadata field\n        // For name field, apply additional sanitization to remove shell metacharacters\n        if (normalizedField === 'name') {\n          parsed.data[normalizedField] = sanitizeInput(sanitizedValue, 100);\n        } else {\n          parsed.data[normalizedField] = sanitizedValue;\n        }\n      }\n\n      // Update version and modification info\n      if (normalizedField !== 'version') {\n        const currentVersion = parsed.data.version || '1.0';\n        const versionParts = currentVersion.split('.').map(Number);\n        versionParts[1] = (versionParts[1] || 0) + 1;\n        parsed.data.version = versionParts.join('.');\n      }\n\n      // Regenerate file content\n      // Use secure YAML stringification\n      const secureParser = SecureYamlParser.createSecureMatterParser();\n      const updatedContent = secureParser.stringify(parsed.content, parsed.data);\n      \n      // Use file locking to prevent race conditions\n      await FileLockManager.withLock(`persona:${persona.metadata.name}`, async () => {\n        // Write updated file atomically\n        await FileLockManager.atomicWriteFile(filePath, updatedContent);\n      });\n      \n      // Reload personas\n      await this.loadPersonas();\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **Persona Updated Successfully!**\\n\\n` +\n              (isDefault ? `📋 **Note:** Created a copy of the default persona to preserve the original.\\n\\n` : '') +\n              `🎭 **${(parsed.data.name || persona.metadata.name || '').replace(/[;&|`$()]/g, '')}**\\n` +\n              `📝 **Field Updated:** ${field}\\n` +\n              `🔄 **New Value:** ${normalizedField === 'instructions' ? 'Content updated' : displayValue}\\n` +\n              `📊 **Version:** ${parsed.data.version}\\n` +\n              (isDefault ? `🆔 **New ID:** ${parsed.data.unique_id}\\n` : '') +\n              `\\n` +\n              `Use \\`get_persona_details \"${(parsed.data.name || persona.metadata.name || '').replace(/[;&|`$()]/g, '')}\"\\` to see all changes.`,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Error Updating Persona**\\n\\n` +\n              `Failed to update persona: ${sanitized.message}\\n\\n` +\n              `Please check file permissions and try again.`,\n          },\n        ],\n      };\n    }\n  }\n\n  async validatePersona(personaIdentifier: string) {\n    if (!personaIdentifier) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Missing Persona Identifier**\\n\\n` +\n              `Usage: \\`validate_persona \"persona_name\"\\`\\n\\n` +\n              `Use \\`list_personas\\` to see available personas.`,\n          },\n        ],\n      };\n    }\n\n    // Find the persona\n    let persona = this.personas.get(personaIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === personaIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Persona Not Found**\\n\\n` +\n              `Could not find persona: \"${personaIdentifier}\"\\n\\n` +\n              `Use \\`list_personas\\` to see available personas.`,\n          },\n        ],\n      };\n    }\n\n    // Validation checks\n    const issues: string[] = [];\n    const warnings: string[] = [];\n    const metadata = persona.metadata;\n\n    // Required field checks\n    if (!metadata.name || metadata.name.trim().length === 0) {\n      issues.push(\"Missing or empty 'name' field\");\n    }\n    if (!metadata.description || metadata.description.trim().length === 0) {\n      issues.push(\"Missing or empty 'description' field\");\n    }\n    if (!persona.content || persona.content.trim().length < 50) {\n      issues.push(\"Persona content is too short (minimum 50 characters)\");\n    }\n\n    // Category validation\n    const validCategories = ['creative', 'professional', 'educational', 'gaming', 'personal', 'general'];\n    if (metadata.category && !validCategories.includes(metadata.category)) {\n      issues.push(`Invalid category '${metadata.category}'. Must be one of: ${validCategories.join(', ')}`);\n    }\n\n    // Age rating validation\n    const validAgeRatings = ['all', '13+', '18+'];\n    if (metadata.age_rating && !validAgeRatings.includes(metadata.age_rating)) {\n      warnings.push(`Invalid age_rating '${metadata.age_rating}'. Should be one of: ${validAgeRatings.join(', ')}`);\n    }\n\n    // Optional field warnings\n    if (!metadata.triggers || metadata.triggers.length === 0) {\n      warnings.push(\"No trigger keywords defined - users may have difficulty finding this persona\");\n    }\n    if (!metadata.version) {\n      warnings.push(\"No version specified - defaulting to '1.0'\");\n    }\n    if (!metadata.unique_id) {\n      warnings.push(\"No unique_id - one will be generated automatically\");\n    }\n\n    // Content quality checks\n    if (persona.content.length > 5000) {\n      warnings.push(\"Persona content is very long - consider breaking it into sections\");\n    }\n    if (metadata.name && metadata.name.length > 50) {\n      warnings.push(\"Persona name is very long - consider shortening for better display\");\n    }\n    if (metadata.description && metadata.description.length > 200) {\n      warnings.push(\"Description is very long - consider keeping it under 200 characters\");\n    }\n\n    // Generate validation report\n    let report = `${this.getPersonaIndicator()}📋 **Validation Report: ${persona.metadata.name}**\\n\\n`;\n    \n    if (issues.length === 0 && warnings.length === 0) {\n      report += `✅ **All Checks Passed!**\\n\\n` +\n        `🎭 **Persona:** ${metadata.name}\\n` +\n        `📁 **Category:** ${metadata.category || 'general'}\\n` +\n        `📊 **Version:** ${metadata.version || '1.0'}\\n` +\n        `📝 **Content Length:** ${persona.content.length} characters\\n` +\n        `🔗 **Triggers:** ${metadata.triggers?.length || 0} keywords\\n\\n` +\n        `This persona meets all validation requirements and is ready for use!`;\n    } else {\n      if (issues.length > 0) {\n        report += `❌ **Issues Found (${issues.length}):**\\n`;\n        issues.forEach((issue, i) => {\n          report += `   ${i + 1}. ${issue}\\n`;\n        });\n        report += '\\n';\n      }\n\n      if (warnings.length > 0) {\n        report += `⚠️ **Warnings (${warnings.length}):**\\n`;\n        warnings.forEach((warning, i) => {\n          report += `   ${i + 1}. ${warning}\\n`;\n        });\n        report += '\\n';\n      }\n\n      if (issues.length > 0) {\n        report += `**Recommendation:** Fix the issues above before using this persona.\\n`;\n        report += `Use \\`edit_persona \"${persona.metadata.name}\" \"field\" \"value\"\\` to make corrections.`;\n      } else {\n        report += `**Status:** Persona is functional but could be improved.\\n`;\n        report += `Address warnings above for optimal performance.`;\n      }\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: report,\n        },\n      ],\n    };\n  }\n\n  // retryNetworkOperation is now handled by UpdateChecker\n\n  // Auto-update management tools\n  async checkForUpdates() {\n    if (!this.updateManager) {\n      return {\n        content: [{ type: \"text\", text: this.getPersonaIndicator() + \"❌ Update functionality not available (initialization failed)\" }]\n      };\n    }\n    const { text } = await this.updateManager.checkForUpdates();\n    return {\n      content: [{ type: \"text\", text: this.getPersonaIndicator() + text }]\n    };\n  }\n\n  // Update helper methods are now handled by UpdateManager\n\n  async updateServer(confirm: boolean) {\n    if (!confirm) {\n      return {\n        content: [{\n          type: \"text\",\n          text: this.getPersonaIndicator() + \n            '⚠️ **Update Confirmation Required**\\n\\n' +\n            'To proceed with the update, you must confirm:\\n' +\n            '`update_server true`\\n\\n' +\n            '**What will happen:**\\n' +\n            '• Backup current version\\n' +\n            '• Pull latest changes from GitHub\\n' +\n            '• Update dependencies\\n' +\n            '• Rebuild TypeScript\\n' +\n            '• Restart server (will disconnect temporarily)\\n\\n' +\n            '**Prerequisites:**\\n' +\n            '• Git repository must be clean (no uncommitted changes)\\n' +\n            '• Network connection required\\n' +\n            '• Sufficient disk space for backup'\n        }]\n      };\n    }\n\n    if (!this.updateManager) {\n      return {\n        content: [{ type: \"text\", text: this.getPersonaIndicator() + \"❌ Update functionality not available (initialization failed)\" }]\n      };\n    }\n    const { text } = await this.updateManager.updateServer(confirm, this.getPersonaIndicator());\n    return {\n      content: [{ type: \"text\", text }]\n    };\n  }\n\n  // Rollback helper methods are now handled by UpdateManager\n\n  async rollbackUpdate(confirm: boolean) {\n    if (!this.updateManager) {\n      return {\n        content: [{ type: \"text\", text: this.getPersonaIndicator() + \"❌ Update functionality not available (initialization failed)\" }]\n      };\n    }\n    const { text } = await this.updateManager.rollbackUpdate(confirm, this.getPersonaIndicator());\n    return {\n      content: [{ type: \"text\", text }]\n    };\n  }\n\n  // Version and git info methods are now handled by UpdateManager\n\n  // Status helper methods are now handled by UpdateManager\n\n  async getServerStatus() {\n    // Add persona information to the status\n    const personaInfo = `\n**🎭 Persona Information:**\n• **Total Personas:** ${this.personas.size}\n• **Active Persona:** ${this.activePersona || 'None'}\n• **User Identity:** ${this.currentUser || 'Anonymous'}\n• **Personas Directory:** ${this.personasDir}`;\n    \n    if (!this.updateManager) {\n      const errorMessage = `${this.getPersonaIndicator()}❌ Update functionality not available (initialization failed)\\n\\n${personaInfo}`;\n      return {\n        content: [{ type: \"text\", text: errorMessage }]\n      };\n    }\n    const { text } = await this.updateManager.getServerStatus(this.getPersonaIndicator());\n    // Insert persona info into the status text\n    const updatedText = text.replace('**Available Commands:**', personaInfo + '\\n\\n**Available Commands:**');\n    \n    return {\n      content: [{ type: \"text\", text: updatedText }]\n    };\n  }\n\n  async convertToGitInstallation(targetDir?: string, confirm: boolean = false) {\n    if (!this.updateManager) {\n      return {\n        content: [{ type: \"text\", text: this.getPersonaIndicator() + \"❌ Update functionality not available (initialization failed)\" }]\n      };\n    }\n    const result = await this.updateManager.convertToGitInstallation(targetDir, confirm, this.getPersonaIndicator());\n    return {\n      content: [{ type: \"text\", text: result.text }]\n    };\n  }\n\n  // Version and dependency methods are now handled by UpdateManager\n\n\n  /**\n   * Configure indicator settings\n   */\n  async configureIndicator(config: Partial<IndicatorConfig>) {\n    try {\n      // Update the configuration\n      if (config.enabled !== undefined) {\n        this.indicatorConfig.enabled = config.enabled;\n      }\n      if (config.style !== undefined) {\n        this.indicatorConfig.style = config.style;\n      }\n      if (config.customFormat !== undefined) {\n        // Validate custom format before applying\n        const validation = validateCustomFormat(config.customFormat);\n        if (!validation.valid) {\n          return {\n            content: [\n              {\n                type: \"text\",\n                text: `${this.getPersonaIndicator()}❌ Invalid custom format: ${validation.error}`\n              }\n            ]\n          };\n        }\n        this.indicatorConfig.customFormat = config.customFormat;\n      }\n      if (config.showVersion !== undefined) {\n        this.indicatorConfig.showVersion = config.showVersion;\n      }\n      if (config.showAuthor !== undefined) {\n        this.indicatorConfig.showAuthor = config.showAuthor;\n      }\n      if (config.showCategory !== undefined) {\n        this.indicatorConfig.showCategory = config.showCategory;\n      }\n      if (config.emoji !== undefined) {\n        this.indicatorConfig.emoji = config.emoji;\n      }\n      if (config.bracketStyle !== undefined) {\n        this.indicatorConfig.bracketStyle = config.bracketStyle;\n      }\n\n      // Show example of what the indicator would look like\n      let exampleIndicator = \"\";\n      if (this.activePersona) {\n        const persona = this.personas.get(this.activePersona);\n        if (persona) {\n          exampleIndicator = formatIndicator(this.indicatorConfig, {\n            name: persona.metadata.name,\n            version: persona.metadata.version,\n            author: persona.metadata.author,\n            category: persona.metadata.category\n          });\n        }\n      } else {\n        // Show example with sample data\n        exampleIndicator = formatIndicator(this.indicatorConfig, {\n          name: \"Example Persona\",\n          version: \"1.0\",\n          author: \"@username\",\n          category: \"creative\"\n        });\n      }\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ Indicator configuration updated successfully!\n\nCurrent settings:\n- Enabled: ${this.indicatorConfig.enabled}\n- Style: ${this.indicatorConfig.style}\n- Show Version: ${this.indicatorConfig.showVersion}\n- Show Author: ${this.indicatorConfig.showAuthor}\n- Show Category: ${this.indicatorConfig.showCategory}\n- Emoji: ${this.indicatorConfig.emoji}\n- Brackets: ${this.indicatorConfig.bracketStyle}\n${this.indicatorConfig.customFormat ? `- Custom Format: ${this.indicatorConfig.customFormat}` : ''}\n\nExample indicator: ${exampleIndicator || \"(none - indicators disabled)\"}\n\nNote: Configuration is temporary for this session. To make permanent, set environment variables:\n- DOLLHOUSE_INDICATOR_ENABLED=true/false\n- DOLLHOUSE_INDICATOR_STYLE=full/minimal/compact/custom\n- DOLLHOUSE_INDICATOR_FORMAT=\"custom format template\"\n- DOLLHOUSE_INDICATOR_SHOW_VERSION=true/false\n- DOLLHOUSE_INDICATOR_SHOW_AUTHOR=true/false\n- DOLLHOUSE_INDICATOR_SHOW_CATEGORY=true/false\n- DOLLHOUSE_INDICATOR_EMOJI=🎭\n- DOLLHOUSE_INDICATOR_BRACKETS=square/round/curly/angle/none`\n          }\n        ]\n      };\n    } catch (error) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error configuring indicator: ${SecureErrorHandler.sanitizeError(error).message}`\n          }\n        ]\n      };\n    }\n  }\n\n  /**\n   * Get current indicator configuration\n   */\n  async getIndicatorConfig() {\n    // Show current configuration and example\n    let exampleIndicator = \"\";\n    if (this.activePersona) {\n      const persona = this.personas.get(this.activePersona);\n      if (persona) {\n        exampleIndicator = formatIndicator(this.indicatorConfig, {\n          name: persona.metadata.name,\n          version: persona.metadata.version,\n          author: persona.metadata.author,\n          category: persona.metadata.category\n        });\n      }\n    } else {\n      // Show example with sample data\n      exampleIndicator = formatIndicator(this.indicatorConfig, {\n        name: \"Example Persona\",\n        version: \"1.0\",\n        author: \"@username\",\n        category: \"creative\"\n      });\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}📊 Current Indicator Configuration:\n\nSettings:\n- Enabled: ${this.indicatorConfig.enabled}\n- Style: ${this.indicatorConfig.style}\n- Show Version: ${this.indicatorConfig.showVersion}\n- Show Author: ${this.indicatorConfig.showAuthor}\n- Show Category: ${this.indicatorConfig.showCategory}\n- Emoji: ${this.indicatorConfig.emoji}\n- Brackets: ${this.indicatorConfig.bracketStyle}\n- Separator: \"${this.indicatorConfig.separator}\"\n${this.indicatorConfig.customFormat ? `- Custom Format: ${this.indicatorConfig.customFormat}` : ''}\n\nAvailable styles:\n- full: [🎭 Persona Name v1.0 by @author]\n- minimal: 🎭 Persona Name\n- compact: [Persona Name v1.0]\n- custom: Use your own format with placeholders\n\nExample with current settings: ${exampleIndicator || \"(none - indicators disabled)\"}\n\nPlaceholders for custom format:\n- {emoji} - The configured emoji\n- {name} - Persona name\n- {version} - Persona version\n- {author} - Persona author\n- {category} - Persona category`\n        }\n      ]\n    };\n  }\n\n\n  /**\n   * Export a single persona\n   */\n  async exportPersona(personaName: string) {\n    try {\n      // Use a single lookup to avoid race conditions\n      let persona = this.personas.get(personaName);\n      if (!persona) {\n        // Try by filename\n        persona = Array.from(this.personas.values()).find(p => p.filename === personaName);\n        if (!persona) {\n          return {\n            content: [{\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ Persona not found: ${personaName}`\n            }]\n          };\n        }\n      }\n\n      const exportData = this.personaExporter.exportPersona(persona);\n      const base64 = this.personaExporter.toBase64(exportData);\n      const result = this.personaExporter.formatExportResult(persona, base64);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}${result}`\n        }]\n      };\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Export failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Export all personas\n   */\n  async exportAllPersonas(includeDefaults = true) {\n    try {\n      const personasArray = Array.from(this.personas.values());\n      const bundle = this.personaExporter.exportBundle(personasArray, includeDefaults);\n      const base64 = this.personaExporter.toBase64(bundle);\n      const result = this.personaExporter.formatBundleResult(bundle, base64);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}${result}`\n        }]\n      };\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Export failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Import a persona\n   */\n  async importPersona(source: string, overwrite = false) {\n    try {\n      if (!this.personaImporter) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Import functionality not available (initialization in progress)`\n          }]\n        };\n      }\n      const result = await this.personaImporter.importPersona(source, this.personas, overwrite);\n      \n      if (result.success) {\n        // Reload personas to include the new one\n        await this.loadPersonas();\n        \n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ ${result.message}\\n\\nPersona \"${result.persona?.metadata.name}\" is now available.\\nTotal personas: ${this.personas.size}`\n          }]\n        };\n      } else {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ ${result.message}`\n          }]\n        };\n      }\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Import failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Share a persona via URL\n   */\n  async sharePersona(personaName: string, expiryDays = 7) {\n    try {\n      // Enhanced input validation\n      const validatedPersonaName = MCPInputValidator.validatePersonaIdentifier(personaName);\n      const validatedExpiryDays = MCPInputValidator.validateExpiryDays(expiryDays);\n      \n      const persona = this.personas.get(validatedPersonaName);\n      if (!persona) {\n        // Try by filename\n        const byFilename = Array.from(this.personas.values()).find(p => p.filename === validatedPersonaName);\n        if (!byFilename) {\n          return {\n            content: [{\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ Persona not found: ${validatedPersonaName}`\n            }]\n          };\n        }\n        personaName = byFilename.metadata.name;\n      }\n\n      const result = await this.personaSharer.sharePersona(this.personas.get(personaName)!, validatedExpiryDays);\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}${result.message}`\n        }]\n      };\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Share failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Import from a shared URL\n   */\n  async importFromUrl(url: string, overwrite = false) {\n    try {\n      // Enhanced input validation for URL\n      const validatedUrl = MCPInputValidator.validateImportUrl(url);\n      \n      const fetchResult = await this.personaSharer.importFromUrl(validatedUrl);\n      \n      if (!fetchResult.success) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ ${fetchResult.message}`\n          }]\n        };\n      }\n\n      // Import the fetched data\n      if (!this.personaImporter) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Import functionality not available (initialization in progress)`\n          }]\n        };\n      }\n      const importResult = await this.personaImporter.importPersona(\n        JSON.stringify(fetchResult.data),\n        this.personas,\n        overwrite\n      );\n\n      if (importResult.success) {\n        // Reload personas\n        await this.loadPersonas();\n        \n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ Successfully imported from URL!\\n\\n${importResult.message}\\nTotal personas: ${this.personas.size}`\n          }]\n        };\n      } else {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ ${importResult.message}`\n          }]\n        };\n      }\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Import from URL failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  async run() {\n    const transport = new StdioServerTransport();\n    logger.info(\"Starting DollhouseMCP server...\");\n    \n    // Set up graceful shutdown handlers\n    const cleanup = async () => {\n      logger.info(\"Shutting down DollhouseMCP server...\");\n      \n      try {\n        // Clean up GitHub auth manager\n        if (this.githubAuthManager) {\n          await this.githubAuthManager.cleanup();\n        }\n        \n        // Clean up any other resources\n        if (this.updateManager) {\n          // UpdateManager might have active operations too\n          logger.debug(\"Cleaning up update manager...\");\n        }\n        \n        logger.info(\"Cleanup completed\");\n      } catch (error) {\n        logger.error(\"Error during cleanup\", { error });\n      }\n      \n      process.exit(0);\n    };\n    \n    // Register shutdown handlers\n    process.on('SIGINT', cleanup);\n    process.on('SIGTERM', cleanup);\n    process.on('SIGHUP', cleanup);\n    \n    await this.server.connect(transport);\n    // Mark that MCP is now connected - no more console output allowed\n    logger.setMCPConnected();\n    logger.info(\"DollhouseMCP server running on stdio\");\n  }\n}\n\n// Export is already at class declaration\n\n// Only start the server if this file is being run directly (not imported by tests)\n// Handle different execution methods (direct, npx, CLI)\nconst isDirectExecution = import.meta.url === `file://${process.argv[1]}`;\nconst isNpxExecution = process.env.npm_execpath?.includes('npx');\nconst isCliExecution = process.argv[1]?.endsWith('/dollhousemcp') || process.argv[1]?.endsWith('\\\\dollhousemcp');\nconst isTest = process.env.JEST_WORKER_ID;\n\n// Progressive startup with retries for npx/CLI execution\nconst STARTUP_DELAYS = [10, 50, 100, 200]; // Progressive delays in ms\n\nasync function startServerWithRetry(retriesLeft = STARTUP_DELAYS.length): Promise<void> {\n  try {\n    const server = new DollhouseMCPServer();\n    await server.run();\n  } catch (error) {\n    if (retriesLeft > 0 && (isNpxExecution || isCliExecution)) {\n      // Try again with a longer delay\n      const delayIndex = STARTUP_DELAYS.length - retriesLeft;\n      const delay = STARTUP_DELAYS[delayIndex];\n      await new Promise(resolve => setTimeout(resolve, delay));\n      return startServerWithRetry(retriesLeft - 1);\n    }\n    // Final failure - minimal error message for security\n    console.error(\"[DollhouseMCP] Server startup failed\");\n    process.exit(1);\n  }\n}\n\nif ((isDirectExecution || isNpxExecution || isCliExecution) && !isTest) {\n  startServerWithRetry().catch(() => {\n    console.error(\"[DollhouseMCP] Server startup failed\");\n    process.exit(1);\n  });\n}"]}
|
|
3205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\n// Defensive error handling for npx/CLI execution\nprocess.on('uncaughtException', (error) => {\n  console.error('[DollhouseMCP] Server startup failed');\n  process.exit(1);\n});\n\nprocess.on('unhandledRejection', (reason, promise) => {\n  console.error('[DollhouseMCP] Server startup failed');\n  process.exit(1);\n});\n\nimport { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport { StdioServerTransport } from \"@modelcontextprotocol/sdk/server/stdio.js\";\nimport { McpError, ErrorCode } from \"@modelcontextprotocol/sdk/types.js\";\nimport * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport { loadIndicatorConfig, formatIndicator, validateCustomFormat, type IndicatorConfig } from './config/indicator-config.js';\nimport { SecureYamlParser } from './security/secureYamlParser.js';\nimport { SecurityError } from './errors/SecurityError.js';\nimport { SecureErrorHandler } from './security/errorHandler.js';\n\n// Import modularized components\nimport { Persona, PersonaMetadata } from './types/persona.js';\nimport { APICache, CollectionCache } from './cache/index.js';\nimport { validateFilename, sanitizeInput, validateContentSize, validateUsername, MCPInputValidator } from './security/InputValidator.js';\nimport { SECURITY_LIMITS, VALIDATION_PATTERNS } from './security/constants.js';\nimport { ContentValidator } from './security/contentValidator.js';\nimport { PathValidator } from './security/pathValidator.js';\nimport { FileLockManager } from './security/fileLockManager.js';\nimport { generateAnonymousId, generateUniqueId, slugify } from './utils/filesystem.js';\nimport { GitHubClient, CollectionBrowser, CollectionSearch, PersonaDetails, PersonaSubmitter, ElementInstaller } from './collection/index.js';\nimport { UpdateManager } from './update/index.js';\nimport { ServerSetup, IToolHandler } from './server/index.js';\nimport { GitHubAuthManager } from './auth/GitHubAuthManager.js';\nimport { logger } from './utils/logger.js';\nimport { PersonaExporter, PersonaImporter, PersonaSharer } from './persona/export-import/index.js';\nimport { isDefaultPersona } from './constants/defaultPersonas.js';\nimport { PortfolioManager, ElementType } from './portfolio/PortfolioManager.js';\nimport { MigrationManager } from './portfolio/MigrationManager.js';\nimport { SkillManager } from './elements/skills/index.js';\nimport { TemplateManager } from './elements/templates/TemplateManager.js';\nimport { AgentManager } from './elements/agents/AgentManager.js';\n\n\n\n// Detect execution environment\nconst EXECUTION_ENV = {\n  isNpx: process.env.npm_execpath?.includes('npx') || false,\n  isCli: process.argv[1]?.endsWith('/dollhousemcp') || false,\n  isDirect: !process.env.npm_execpath,\n  cwd: process.cwd(),\n  scriptPath: process.argv[1],\n};\n\n// Only log execution environment in debug mode\nif (process.env.DOLLHOUSE_DEBUG) {\n  console.error('[DollhouseMCP] Debug mode enabled');\n}\n\nexport class DollhouseMCPServer implements IToolHandler {\n  private server: Server;\n  private personasDir: string;\n  private personas: Map<string, Persona> = new Map();\n  private activePersona: string | null = null;\n  private currentUser: string | null = null;\n  private apiCache: APICache = new APICache();\n  private collectionCache: CollectionCache = new CollectionCache();\n  private rateLimitTracker = new Map<string, number[]>();\n  private indicatorConfig: IndicatorConfig;\n  private githubClient: GitHubClient;\n  private githubAuthManager: GitHubAuthManager;\n  private collectionBrowser: CollectionBrowser;\n  private collectionSearch: CollectionSearch;\n  private personaDetails: PersonaDetails;\n  private elementInstaller: ElementInstaller;\n  private personaSubmitter: PersonaSubmitter;\n  private updateManager?: UpdateManager;\n  private serverSetup: ServerSetup;\n  private personaExporter: PersonaExporter;\n  private personaImporter?: PersonaImporter;\n  private personaSharer: PersonaSharer;\n  private portfolioManager: PortfolioManager;\n  private migrationManager: MigrationManager;\n  private skillManager: SkillManager;\n  private templateManager: TemplateManager;\n  private agentManager: AgentManager;\n\n  constructor() {\n    this.server = new Server(\n      {\n        name: \"dollhousemcp\",\n        version: \"1.0.0\",\n      },\n      {\n        capabilities: {\n          tools: {},\n        },\n      }\n    );\n\n    // Initialize portfolio system\n    this.portfolioManager = PortfolioManager.getInstance();\n    this.migrationManager = new MigrationManager(this.portfolioManager);\n    \n    // CRITICAL FIX: Don't access directories until after migration runs\n    // Previously: this.personasDir was set here, creating directories before migration could fix them\n    // Now: We delay directory access until initializePortfolio() completes\n    this.personasDir = ''; // Temporary - will be set after migration\n    \n    // Initialize element managers\n    this.skillManager = new SkillManager();\n    this.templateManager = new TemplateManager();\n    this.agentManager = new AgentManager(this.portfolioManager.getBaseDir());\n    \n    // Log resolved path for debugging\n    logger.info(`Personas directory resolved to: ${this.personasDir}`);\n    \n    // PathValidator will be initialized after migration completes\n    \n    // Load user identity from environment variables\n    this.currentUser = process.env.DOLLHOUSE_USER || null;\n    \n    // Load indicator configuration\n    this.indicatorConfig = loadIndicatorConfig();\n    \n    // Initialize persona manager\n    \n    // Initialize collection modules\n    this.githubClient = new GitHubClient(this.apiCache, this.rateLimitTracker);\n    this.githubAuthManager = new GitHubAuthManager(this.apiCache);\n    this.collectionBrowser = new CollectionBrowser(this.githubClient, this.collectionCache);\n    this.collectionSearch = new CollectionSearch(this.githubClient, this.collectionCache);\n    this.personaDetails = new PersonaDetails(this.githubClient);\n    this.elementInstaller = new ElementInstaller(this.githubClient);\n    this.personaSubmitter = new PersonaSubmitter();\n    \n    // Update manager will be initialized after migration completes to avoid jsdom crash\n    \n    // Initialize export/import/share modules\n    this.personaExporter = new PersonaExporter(this.currentUser);\n    // PersonaImporter will be initialized after migration completes\n    this.personaSharer = new PersonaSharer(this.githubClient, this.currentUser);\n    \n    // Initialize server setup\n    this.serverSetup = new ServerSetup();\n    this.serverSetup.setupServer(this.server, this);\n    \n    // Initialize portfolio and perform migration if needed\n    this.initializePortfolio().then(() => {\n      // NOW safe to access directories after migration\n      this.personasDir = this.portfolioManager.getElementDir(ElementType.PERSONA);\n      \n      // Log resolved path for debugging\n      logger.info(`Personas directory resolved to: ${this.personasDir}`);\n      \n      // Initialize PathValidator with the personas directory\n      PathValidator.initialize(this.personasDir);\n      \n      // Initialize update manager with safe directory\n      // Use the parent of personas directory to avoid production check\n      const safeDir = path.dirname(this.personasDir);\n      try {\n        this.updateManager = new UpdateManager(safeDir);\n      } catch (error) {\n        console.error('[DollhouseMCP] Failed to initialize UpdateManager:', error);\n        logger.error(`Failed to initialize UpdateManager: ${error}`);\n        // Continue without update functionality\n      }\n      \n      // Initialize import module that depends on personasDir\n      this.personaImporter = new PersonaImporter(this.personasDir, this.currentUser);\n      \n      this.loadPersonas();\n    }).catch(error => {\n      // Don't use CRITICAL in the error message as it triggers Docker test failures\n      console.error('[DollhouseMCP] Failed to initialize portfolio:', error);\n      logger.error(`Failed to initialize portfolio: ${error}`);\n    });\n  }\n  \n  private async initializePortfolio(): Promise<void> {\n    // Check if migration is needed\n    const needsMigration = await this.migrationManager.needsMigration();\n    \n    if (needsMigration) {\n      logger.info('Legacy personas detected. Starting migration...');\n      \n      const result = await this.migrationManager.migrate({ backup: true });\n      \n      if (result.success) {\n        logger.info(`Successfully migrated ${result.migratedCount} personas`);\n        if (result.backedUp && result.backupPath) {\n          logger.info(`Backup created at: ${result.backupPath}`);\n        }\n      } else {\n        logger.error('Migration completed with errors:');\n        result.errors.forEach(err => logger.error(`  - ${err}`));\n      }\n    }\n    \n    // Ensure portfolio structure exists\n    const portfolioExists = await this.portfolioManager.exists();\n    if (!portfolioExists) {\n      logger.info('Creating portfolio directory structure...');\n      await this.portfolioManager.initialize();\n    }\n    \n    // Initialize collection cache for anonymous access\n    await this.initializeCollectionCache();\n  }\n  \n  /**\n   * Initialize collection cache with seed data for anonymous browsing\n   */\n  private async initializeCollectionCache(): Promise<void> {\n    try {\n      const isCacheValid = await this.collectionCache.isCacheValid();\n      if (!isCacheValid) {\n        logger.info('Initializing collection cache with seed data...');\n        const { CollectionSeeder } = await import('./collection/CollectionSeeder.js');\n        const seedData = CollectionSeeder.getSeedData();\n        await this.collectionCache.saveCache(seedData);\n        logger.info(`Collection cache initialized with ${seedData.length} items`);\n      } else {\n        const stats = await this.collectionCache.getCacheStats();\n        logger.debug(`Collection cache already valid with ${stats.itemCount} items`);\n      }\n    } catch (error) {\n      logger.error(`Failed to initialize collection cache: ${error}`);\n      // Don't throw - cache failures shouldn't prevent server startup\n    }\n  }\n\n  // Tool handler methods - now public for access from tool modules\n  \n  private getPersonaIndicator(): string {\n    if (!this.activePersona) {\n      return \"\";\n    }\n\n    const persona = this.personas.get(this.activePersona);\n    if (!persona) {\n      return \"\";\n    }\n\n    return formatIndicator(this.indicatorConfig, {\n      name: persona.metadata.name,\n      version: persona.metadata.version,\n      author: persona.metadata.author,\n      category: persona.metadata.category\n    });\n  }\n\n  /**\n   * Normalize element type to handle both singular (new) and plural (legacy) forms\n   * This provides backward compatibility during the transition to v1.4.0\n   */\n  private normalizeElementType(type: string): string {\n    // Map plural forms to singular ElementType values\n    const pluralToSingularMap: Record<string, string> = {\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    // If it's already a valid ElementType value, return as-is\n    if (Object.values(ElementType).includes(type as ElementType)) {\n      return type;\n    }\n    \n    // If it's a plural form, convert to singular\n    if (pluralToSingularMap[type]) {\n      // Log deprecation warning\n      logger.warn(`Using plural element type '${type}' is deprecated. Please use singular form '${pluralToSingularMap[type]}' instead.`);\n      return pluralToSingularMap[type];\n    }\n    \n    // Unknown type - return as-is and let validation handle it\n    return type;\n  }\n\n  /**\n   * Sanitize metadata object to prevent prototype pollution\n   * Removes any dangerous properties that could affect Object.prototype\n   */\n  private sanitizeMetadata(metadata: Record<string, any>): Record<string, any> {\n    if (!metadata || typeof metadata !== 'object') {\n      return {};\n    }\n    \n    const dangerousProperties = ['__proto__', 'constructor', 'prototype'];\n    const sanitized: Record<string, any> = {};\n    \n    for (const [key, value] of Object.entries(metadata)) {\n      if (!dangerousProperties.includes(key)) {\n        // Recursively sanitize nested objects\n        if (value && typeof value === 'object' && !Array.isArray(value)) {\n          sanitized[key] = this.sanitizeMetadata(value);\n        } else {\n          sanitized[key] = value;\n        }\n      }\n    }\n    \n    return sanitized;\n  }\n\n  private async loadPersonas() {\n    // Validate the personas directory path\n    if (!path.isAbsolute(this.personasDir)) {\n      logger.warn(`Personas directory path is not absolute: ${this.personasDir}`);\n    }\n    \n    try {\n      await fs.access(this.personasDir);\n    } catch (error) {\n      // Create personas directory if it doesn't exist\n      try {\n        await fs.mkdir(this.personasDir, { recursive: true });\n        logger.info(`Created personas directory at: ${this.personasDir}`);\n        // Continue to try loading (directory will be empty)\n      } catch (mkdirError: any) {\n        logger.error(`Failed to create personas directory at ${this.personasDir}: ${mkdirError.message}`);\n        // Don't throw - empty portfolio is valid\n        this.personas.clear();\n        return;\n      }\n    }\n\n    try {\n      const files = await fs.readdir(this.personasDir);\n      const markdownFiles = files.filter(file => file.endsWith('.md'));\n\n      this.personas.clear();\n      \n      if (markdownFiles.length === 0) {\n        logger.info('[DollhouseMCP] No personas found in portfolio. Use browse_collection to install some!');\n      }\n\n      for (const file of markdownFiles) {\n        try {\n          const filePath = path.join(this.personasDir, file);\n          const fileContent = await PathValidator.safeReadFile(filePath);\n          \n          // Use secure YAML parser\n          let parsed;\n          try {\n            parsed = SecureYamlParser.safeMatter(fileContent);\n          } catch (error) {\n            if (error instanceof SecurityError) {\n              logger.warn(`Security threat detected in persona ${file}: ${error.message}`);\n              continue;\n            }\n            throw error;\n          }\n          \n          const metadata = parsed.data as PersonaMetadata;\n          const content = parsed.content;\n\n          if (!metadata.name) {\n            metadata.name = path.basename(file, '.md');\n          }\n\n          // Generate unique ID if not present\n          let uniqueId = metadata.unique_id;\n          if (!uniqueId) {\n            const authorForId = metadata.author || this.getCurrentUserForAttribution();\n            uniqueId = generateUniqueId(metadata.name, authorForId);\n            logger.debug(`Generated unique ID for ${metadata.name}: ${uniqueId}`);\n          }\n\n          // Set default values for new metadata fields\n          if (!metadata.category) metadata.category = 'general';\n          if (!metadata.age_rating) metadata.age_rating = 'all';\n          if (!metadata.content_flags) metadata.content_flags = [];\n          if (metadata.ai_generated === undefined) metadata.ai_generated = false;\n          if (!metadata.generation_method) metadata.generation_method = 'human';\n          if (!metadata.price) metadata.price = 'free';\n          if (!metadata.license) metadata.license = 'CC-BY-SA-4.0';\n\n          const persona: Persona = {\n            metadata,\n            content,\n            filename: file,\n            unique_id: uniqueId,\n          };\n\n          this.personas.set(file, persona);\n          logger.debug(`Loaded persona: ${metadata.name} (${uniqueId}`);\n        } catch (error) {\n          logger.error(`Error loading persona ${file}: ${error}`);\n        }\n      }\n    } catch (error) {\n      // Handle ENOENT gracefully - directory might not exist yet\n      if ((error as any).code === 'ENOENT') {\n        logger.info('[DollhouseMCP] Personas directory does not exist yet - portfolio is empty');\n        this.personas.clear();\n        return;\n      }\n      logger.error(`Error reading personas directory: ${error}`);\n      this.personas.clear();\n    }\n  }\n\n  async listPersonas() {\n    const personaList = Array.from(this.personas.values()).map(persona => ({\n      filename: persona.filename,\n      unique_id: persona.unique_id,\n      name: persona.metadata.name,\n      description: persona.metadata.description,\n      triggers: persona.metadata.triggers || [],\n      version: persona.metadata.version || \"1.0\",\n      author: persona.metadata.author || \"Unknown\",\n      category: persona.metadata.category || 'general',\n      age_rating: persona.metadata.age_rating || 'all',\n      price: persona.metadata.price || 'free',\n      ai_generated: persona.metadata.ai_generated || false,\n      active: this.activePersona === persona.filename,\n    }));\n\n    if (personaList.length === 0) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}You don't have any personas installed yet. Would you like to browse the DollhouseMCP collection on GitHub to see what's available? I can show you personas for creative writing, technical analysis, and more. Just say \"yes\" or use 'browse_collection'.`,\n          },\n        ],\n      };\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}Available Personas (${personaList.length}):\\n\\n` +\n            personaList.map(p => \n              `${p.active ? '🔹 ' : '▫️ '}**${p.name}** (${p.unique_id})\\n` +\n              `   ${p.description}\\n` +\n              `   📁 ${p.category} | 🎭 ${p.author} | 🔖 ${p.price} | ${p.ai_generated ? '🤖 AI' : '👤 Human'}\\n` +\n              `   Age: ${p.age_rating} | Version: ${p.version}\\n` +\n              `   Triggers: ${p.triggers.join(', ') || 'None'}\\n`\n            ).join('\\n'),\n        },\n      ],\n    };\n  }\n\n  async activatePersona(personaIdentifier: string) {\n    // Enhanced input validation for persona identifier\n    const validatedIdentifier = MCPInputValidator.validatePersonaIdentifier(personaIdentifier);\n    \n    // Try to find persona by filename first, then by name\n    let persona = this.personas.get(validatedIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === validatedIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      throw new McpError(\n        ErrorCode.InvalidParams,\n        `Persona not found: ${personaIdentifier}`\n      );\n    }\n\n    this.activePersona = persona.filename;\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}Persona Activated: **${persona.metadata.name}**\\n\\n` +\n            `${persona.metadata.description}\\n\\n` +\n            `**Instructions:**\\n${persona.content}`,\n        },\n      ],\n    };\n  }\n\n  async getActivePersona() {\n    if (!this.activePersona) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}No persona is currently active.`,\n          },\n        ],\n      };\n    }\n\n    const persona = this.personas.get(this.activePersona);\n    if (!persona) {\n      this.activePersona = null;\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}Active persona not found. Deactivated.`,\n          },\n        ],\n      };\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}Active Persona: **${persona.metadata.name}**\\n\\n` +\n            `${persona.metadata.description}\\n\\n` +\n            `File: ${persona.filename}\\n` +\n            `Version: ${persona.metadata.version || '1.0'}\\n` +\n            `Author: ${persona.metadata.author || 'Unknown'}`,\n        },\n      ],\n    };\n  }\n\n  async deactivatePersona() {\n    const wasActive = this.activePersona !== null;\n    const indicator = this.getPersonaIndicator();\n    this.activePersona = null;\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: wasActive \n            ? `${indicator}✅ Persona deactivated. Back to default mode.`\n            : \"No persona was active.\",\n        },\n      ],\n    };\n  }\n\n  async getPersonaDetails(personaIdentifier: string) {\n    // Try to find persona by filename first, then by name\n    let persona = this.personas.get(personaIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === personaIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      throw new McpError(\n        ErrorCode.InvalidParams,\n        `Persona not found: ${personaIdentifier}`\n      );\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}📋 **${persona.metadata.name}** Details\\n\\n` +\n            `**Description:** ${persona.metadata.description}\\n` +\n            `**File:** ${persona.filename}\\n` +\n            `**Version:** ${persona.metadata.version || '1.0'}\\n` +\n            `**Author:** ${persona.metadata.author || 'Unknown'}\\n` +\n            `**Triggers:** ${persona.metadata.triggers?.join(', ') || 'None'}\\n\\n` +\n            `**Full Content:**\\n\\`\\`\\`\\n${persona.content}\\n\\`\\`\\``,\n        },\n      ],\n    };\n  }\n\n  async reloadPersonas() {\n    await this.loadPersonas();\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}🔄 Reloaded ${this.personas.size} personas from ${this.personasDir}`,\n        },\n      ],\n    };\n  }\n\n  // ===== Element Methods (Generic for all element types) =====\n  \n  async listElements(type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.listPersonas();\n          \n        case ElementType.SKILL: {\n          const skills = await this.skillManager.list();\n          if (skills.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"No skills are currently installed. The DollhouseMCP collection has skills for code review, data analysis, creative writing and more. Would you like me to show you what's available? Just say \\\"yes\\\" or I can help you create a custom skill.\"\n              }]\n            };\n          }\n          \n          const skillList = skills.map(skill => {\n            const complexity = skill.metadata.complexity || 'beginner';\n            const domains = skill.metadata.domains?.join(', ') || 'general';\n            return `🛠️ ${skill.metadata.name} - ${skill.metadata.description}\\n   Complexity: ${complexity} | Domains: ${domains}`;\n          }).join('\\n\\n');\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `📚 Available Skills:\\n\\n${skillList}`\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          const templates = await this.templateManager.list();\n          if (templates.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"You haven't installed any templates yet. Would you like to see available templates for emails, reports, and documentation? I can show you examples from the collection or help you create your own. What would you prefer?\"\n              }]\n            };\n          }\n          \n          const templateList = templates.map(template => {\n            const variables = template.metadata.variables?.map(v => v.name).join(', ') || 'none';\n            return `📄 ${template.metadata.name} - ${template.metadata.description}\\n   Variables: ${variables}`;\n          }).join('\\n\\n');\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `📝 Available Templates:\\n\\n${templateList}`\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agents = await this.agentManager.list();\n          if (agents.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"No agents installed yet. Agents are autonomous helpers that can work on tasks independently. The DollhouseMCP collection includes task managers, research assistants, and more. Would you like to browse available agents or learn how to create your own?\"\n              }]\n            };\n          }\n          \n          const agentList = agents.map(agent => {\n            const specializations = (agent.metadata as any).specializations?.join(', ') || 'general';\n            const status = agent.getStatus();\n            return `🤖 ${agent.metadata.name} - ${agent.metadata.description}\\n   Status: ${status} | Specializations: ${specializations}`;\n          }).join('\\n\\n');\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `🤖 Available Agents:\\n\\n${agentList}`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'. Available types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to list ${type} elements:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to list ${type}: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async activateElement(name: string, type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.activatePersona(name);\n          \n        case ElementType.SKILL: {\n          const skill = await this.skillManager.find(s => s.metadata.name === name);\n          if (!skill) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Skill '${name}' not found`\n              }]\n            };\n          }\n          \n          // Activate the skill\n          await skill.activate?.();\n          \n          return {\n            content: [{\n                type: \"text\",\n                text: `✅ Skill '${name}' activated\\n\\n${skill.instructions}`\n              }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          const template = await this.templateManager.find(t => t.metadata.name === name);\n          if (!template) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Template '${name}' not found`\n              }]\n            };\n          }\n          \n          const variables = template.metadata.variables?.map(v => v.name).join(', ') || 'none';\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Template '${name}' ready to use\\nVariables: ${variables}\\n\\nUse 'render_template' to generate content with this template.`\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agent = await this.agentManager.find(a => a.metadata.name === name);\n          if (!agent) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Agent '${name}' not found`\n              }]\n            };\n          }\n          \n          // Activate the agent\n          await agent.activate();\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Agent '${name}' activated and ready\\nSpecializations: ${(agent.metadata as any).specializations?.join(', ') || 'general'}\\n\\nUse 'execute_agent' to give this agent a goal.`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to activate ${type} '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to activate ${type} '${name}': ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async getActiveElements(type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.getActivePersona();\n          \n        case ElementType.SKILL: {\n          const skills = await this.skillManager.list();\n          const activeSkills = skills.filter(s => s.getStatus() === 'active');\n          \n          if (activeSkills.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"📋 No active skills\"\n              }]\n            };\n          }\n          \n          const skillList = activeSkills.map(s => `🛠️ ${s.metadata.name}`).join(', ');\n          return {\n            content: [{\n              type: \"text\",\n              text: `Active skills: ${skillList}`\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          return {\n            content: [{\n              type: \"text\",\n              text: \"📝 Templates are stateless and activated on-demand when rendering\"\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agents = await this.agentManager.list();\n          const activeAgents = agents.filter(a => a.getStatus() === 'active');\n          \n          if (activeAgents.length === 0) {\n            return {\n              content: [{\n                type: \"text\",\n                text: \"🤖 No active agents\"\n              }]\n            };\n          }\n          \n          const agentList = activeAgents.map(a => {\n            const goals = (a as any).state?.goals?.length || 0;\n            return `🤖 ${a.metadata.name} (${goals} active goals)`;\n          }).join('\\n');\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: `Active agents:\\n${agentList}`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to get active ${type}:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get active ${type}: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async deactivateElement(name: string, type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.deactivatePersona();\n          \n        case ElementType.SKILL: {\n          const skill = await this.skillManager.find(s => s.metadata.name === name);\n          if (!skill) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Skill '${name}' not found`\n              }]\n            };\n          }\n          \n          await skill.deactivate?.();\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Skill '${name}' deactivated`\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          return {\n            content: [{\n              type: \"text\",\n              text: \"📝 Templates are stateless - nothing to deactivate\"\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agent = await this.agentManager.find(a => a.metadata.name === name);\n          if (!agent) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Agent '${name}' not found`\n              }]\n            };\n          }\n          \n          await agent.deactivate();\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Agent '${name}' deactivated`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to deactivate ${type} '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to deactivate ${type} '${name}': ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async getElementDetails(name: string, type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.getPersonaDetails(name);\n          \n        case ElementType.SKILL: {\n          const skill = await this.skillManager.find(s => s.metadata.name === name);\n          if (!skill) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Skill '${name}' not found`\n              }]\n            };\n          }\n          \n          const details = [\n            `🛠️ **${skill.metadata.name}**`,\n            `${skill.metadata.description}`,\n            ``,\n            `**Complexity**: ${skill.metadata.complexity || 'beginner'}`,\n            `**Domains**: ${skill.metadata.domains?.join(', ') || 'general'}`,\n            `**Languages**: ${skill.metadata.languages?.join(', ') || 'any'}`,\n            `**Prerequisites**: ${skill.metadata.prerequisites?.join(', ') || 'none'}`,\n            ``,\n            `**Instructions**:`,\n            skill.instructions\n          ];\n          \n          if (skill.metadata.parameters && skill.metadata.parameters.length > 0) {\n            details.push('', '**Parameters**:');\n            skill.metadata.parameters.forEach(p => {\n              details.push(`- ${p.name} (${p.type}): ${p.description}`);\n            });\n          }\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: details.join('\\n')\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          const template = await this.templateManager.find(t => t.metadata.name === name);\n          if (!template) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Template '${name}' not found`\n              }]\n            };\n          }\n          \n          const details = [\n            `📄 **${template.metadata.name}**`,\n            `${template.metadata.description}`,\n            ``,\n            `**Output Format**: ${(template.metadata as any).output_format || 'text'}`,\n            `**Template Content**:`,\n            '```',\n            template.content,\n            '```'\n          ];\n          \n          if (template.metadata.variables && template.metadata.variables.length > 0) {\n            details.push('', '**Variables**:');\n            template.metadata.variables.forEach(v => {\n              details.push(`- ${v.name} (${v.type}): ${v.description}`);\n            });\n          }\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: details.join('\\n')\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          const agent = await this.agentManager.find(a => a.metadata.name === name);\n          if (!agent) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ Agent '${name}' not found`\n              }]\n            };\n          }\n          \n          const details = [\n            `🤖 **${agent.metadata.name}**`,\n            `${agent.metadata.description}`,\n            ``,\n            `**Status**: ${agent.getStatus()}`,\n            `**Specializations**: ${(agent.metadata as any).specializations?.join(', ') || 'general'}`,\n            `**Decision Framework**: ${(agent.metadata as any).decisionFramework || 'rule-based'}`,\n            `**Risk Tolerance**: ${(agent.metadata as any).riskTolerance || 'low'}`,\n            ``,\n            `**Instructions**:`,\n            (agent as any).instructions || 'No instructions available'\n          ];\n          \n          const agentState = (agent as any).state;\n          if (agentState?.goals && agentState.goals.length > 0) {\n            details.push('', '**Current Goals**:');\n            agentState.goals.forEach((g: any) => {\n              details.push(`- ${g.description} (${g.status})`);\n            });\n          }\n          \n          return {\n            content: [{\n              type: \"text\",\n              text: details.join('\\n')\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to get ${type} details for '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get ${type} details: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async reloadElements(type: string) {\n    try {\n      // Normalize the type to handle both plural and singular forms\n      const normalizedType = this.normalizeElementType(type);\n      \n      switch (normalizedType) {\n        case ElementType.PERSONA:\n          return this.reloadPersonas();\n          \n        case ElementType.SKILL: {\n          this.skillManager.clearCache();\n          const skills = await this.skillManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${skills.length} skills from portfolio`\n            }]\n          };\n        }\n        \n        case ElementType.TEMPLATE: {\n          // Template manager doesn't have clearCache, just list\n          const templates = await this.templateManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${templates.length} templates from portfolio`\n            }]\n          };\n        }\n        \n        case ElementType.AGENT: {\n          // Agent manager doesn't have clearCache, just list\n          const agents = await this.agentManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${agents.length} agents from portfolio`\n            }]\n          };\n        }\n        \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Unknown element type '${type}'`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to reload ${type}:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to reload ${type}: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  // Element-specific methods\n  async renderTemplate(name: string, variables: Record<string, any>) {\n    try {\n      const template = await this.templateManager.find(t => t.metadata.name === name);\n      if (!template) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Template '${name}' not found`\n          }]\n        };\n      }\n      \n      // Simple template rendering - replace variables in content\n      let rendered = template.content;\n      for (const [key, value] of Object.entries(variables)) {\n        const regex = new RegExp(`\\\\{\\\\{\\\\s*${key}\\\\s*\\\\}\\\\}`, 'g');\n        rendered = rendered.replace(regex, String(value));\n      }\n      return {\n        content: [{\n          type: \"text\",\n          text: `📄 Rendered template '${name}':\\n\\n${rendered}`\n        }]\n      };\n    } catch (error) {\n      logger.error(`Failed to render template '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to render template: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async executeAgent(name: string, goal: string) {\n    try {\n      const agent = await this.agentManager.find(a => a.metadata.name === name);\n      if (!agent) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Agent '${name}' not found`\n          }]\n        };\n      }\n      \n      // Simple agent execution simulation\n      const result = {\n        summary: `Agent '${name}' is now working on: ${goal}`,\n        status: 'in-progress',\n        actionsTaken: 1\n      };\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: `🤖 Agent '${name}' execution result:\\n\\n${result.summary}\\n\\nStatus: ${result.status}\\nActions taken: ${result.actionsTaken || 0}`\n        }]\n      };\n    } catch (error) {\n      logger.error(`Failed to execute agent '${name}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to execute agent: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async createElement(args: {name: string; type: string; description: string; content?: string; metadata?: Record<string, any>}) {\n    try {\n      const { name, type, description, content, metadata } = args;\n      \n      // Validate element type\n      if (!Object.values(ElementType).includes(type as ElementType)) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Invalid element type '${type}'. Valid types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n          }]\n        };\n      }\n      \n      // Validate inputs\n      const validatedName = validateFilename(name);\n      const validatedDescription = sanitizeInput(description, SECURITY_LIMITS.MAX_METADATA_FIELD_LENGTH);\n      \n      // SECURITY FIX: Sanitize metadata to prevent prototype pollution\n      const sanitizedMetadata = this.sanitizeMetadata(metadata || {});\n      \n      // Create element based on type\n      switch (type as ElementType) {\n        case ElementType.PERSONA:\n          // Use existing persona creation logic\n          return this.createPersona(\n            validatedName, \n            validatedDescription, \n            content || '',\n            sanitizedMetadata?.triggers\n          );\n          \n        case ElementType.SKILL:\n          const skill = await this.skillManager.create({\n            name: validatedName,\n            description: validatedDescription,\n            ...sanitizedMetadata,\n            content: content || ''\n          });\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Created skill '${skill.metadata.name}' successfully`\n            }]\n          };\n          \n        case ElementType.TEMPLATE:\n          const template = await this.templateManager.create({\n            name: validatedName,\n            description: validatedDescription,\n            content: content || '',\n            ...sanitizedMetadata\n          });\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Created template '${template.metadata.name}' successfully`\n            }]\n          };\n          \n        case ElementType.AGENT:\n          const agentResult = await this.agentManager.create(\n            validatedName,\n            validatedDescription,\n            content || '',\n            sanitizedMetadata\n          );\n          if (!agentResult.success) {\n            return {\n              content: [{\n                type: \"text\",\n                text: `❌ ${agentResult.message}`\n              }]\n            };\n          }\n          return {\n            content: [{\n              type: \"text\",\n              text: `✅ Created agent '${validatedName}' successfully`\n            }]\n          };\n          \n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Element type '${type}' is not yet supported for creation`\n            }]\n          };\n      }\n    } catch (error) {\n      logger.error(`Failed to create element:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to create element: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async editElement(args: {name: string; type: string; field: string; value: string | number | boolean | Record<string, any> | any[]}) {\n    try {\n      const { name, type, field, value } = args;\n      \n      // Validate element type\n      if (!Object.values(ElementType).includes(type as ElementType)) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Invalid element type '${type}'. Valid types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n          }]\n        };\n      }\n      \n      // For personas, use existing edit logic\n      if (type === ElementType.PERSONA) {\n        return this.editPersona(name, field, String(value));\n      }\n      \n      // Get the appropriate manager based on type\n      let manager: SkillManager | TemplateManager | AgentManager | null = null;\n      switch (type as ElementType) {\n        case ElementType.SKILL:\n          manager = this.skillManager;\n          break;\n        case ElementType.TEMPLATE:\n          manager = this.templateManager;\n          break;\n        case ElementType.AGENT:\n          manager = this.agentManager;\n          break;\n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Element type '${type}' is not yet supported for editing`\n            }]\n          };\n      }\n      \n      // Find the element\n      const element = await manager!.find((e: any) => e.metadata.name === name);\n      if (!element) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ ${type} '${name}' not found`\n          }]\n        };\n      }\n      \n      // Handle nested field updates (e.g., \"metadata.author\")\n      const fieldParts = field.split('.');\n      \n      // SECURITY FIX: Validate field names to prevent prototype pollution\n      const dangerousProperties = ['__proto__', 'constructor', 'prototype'];\n      for (const part of fieldParts) {\n        if (dangerousProperties.includes(part)) {\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Invalid field name: '${part}' is not allowed for security reasons`\n            }]\n          };\n        }\n      }\n      \n      let target: any = element;\n      for (let i = 0; i < fieldParts.length - 1; i++) {\n        // SECURITY: Additional check to prevent prototype pollution\n        if (typeof target !== 'object' || target === null) {\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Cannot set property '${fieldParts[i]}' on non-object`\n            }]\n          };\n        }\n        \n        if (!target[fieldParts[i]]) {\n          // SECURITY: Use Object.defineProperty to avoid prototype chain pollution\n          Object.defineProperty(target, fieldParts[i], {\n            value: {},\n            writable: true,\n            enumerable: true,\n            configurable: true\n          });\n        }\n        target = target[fieldParts[i]];\n      }\n      \n      // Update the field\n      const lastField = fieldParts[fieldParts.length - 1];\n      // SECURITY: Use Object.defineProperty for the final assignment too\n      Object.defineProperty(target, lastField, {\n        value: value,\n        writable: true,\n        enumerable: true,\n        configurable: true\n      });\n      \n      // Update version - handle various version formats\n      if (element.version) {\n        const versionParts = element.version.split('.');\n        if (versionParts.length >= 3) {\n          // Standard semver format (e.g., 1.0.0)\n          const patch = parseInt(versionParts[2]) || 0;\n          versionParts[2] = String(patch + 1);\n          element.version = versionParts.join('.');\n        } else if (versionParts.length === 2) {\n          // Two-part version (e.g., 1.0) - add patch version\n          element.version = `${element.version}.1`;\n        } else if (versionParts.length === 1 && /^\\d+$/.test(versionParts[0])) {\n          // Single number version (e.g., 1) - convert to semver\n          element.version = `${element.version}.0.1`;\n        } else {\n          // Non-standard version - append or replace with standard format\n          element.version = '1.0.1';\n        }\n      } else {\n        // No version - set initial version\n        element.version = '1.0.0';\n      }\n      \n      // Save the element - need to determine filename\n      const filename = `${element.metadata.name.toLowerCase().replace(/[^a-z0-9-]/g, '-')}.md`;\n      await manager!.save(element as any, filename);\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: `✅ Updated ${type} '${name}' - ${field} set to: ${JSON.stringify(value)}`\n        }]\n      };\n    } catch (error) {\n      logger.error(`Failed to edit element:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to edit element: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async validateElement(args: {name: string; type: string; strict?: boolean}) {\n    try {\n      const { name, type, strict = false } = args;\n      \n      // Validate element type\n      if (!Object.values(ElementType).includes(type as ElementType)) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Invalid element type '${type}'. Valid types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n          }]\n        };\n      }\n      \n      // For personas, use existing validation logic\n      if (type === ElementType.PERSONA) {\n        return this.validatePersona(name);\n      }\n      \n      // Get the appropriate manager based on type\n      let manager: SkillManager | TemplateManager | AgentManager | null = null;\n      switch (type as ElementType) {\n        case ElementType.SKILL:\n          manager = this.skillManager;\n          break;\n        case ElementType.TEMPLATE:\n          manager = this.templateManager;\n          break;\n        case ElementType.AGENT:\n          manager = this.agentManager;\n          break;\n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Element type '${type}' is not yet supported for validation`\n            }]\n          };\n      }\n      \n      // Find the element\n      const element = await manager!.find((e: any) => e.metadata.name === name);\n      if (!element) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ ${type} '${name}' not found`\n          }]\n        };\n      }\n      \n      // Perform validation\n      const validationResult = element.validate();\n      \n      // Format validation report\n      let report = `🔍 Validation Report for ${type} '${name}':\\n`;\n      report += `${validationResult.valid ? '✅' : '❌'} Status: ${validationResult.valid ? 'Valid' : 'Invalid'}\\n\\n`;\n      \n      if (validationResult.errors && validationResult.errors.length > 0) {\n        report += `❌ Errors (${validationResult.errors.length}):\\n`;\n        validationResult.errors.forEach((error: any) => {\n          report += `   • ${error.field || 'General'}: ${error.message}\\n`;\n          if (error.fix) {\n            report += `     💡 Fix: ${error.fix}\\n`;\n          }\n        });\n        report += '\\n';\n      }\n      \n      if (validationResult.warnings && validationResult.warnings.length > 0) {\n        report += `⚠️  Warnings (${validationResult.warnings.length}):\\n`;\n        validationResult.warnings.forEach((warning: any) => {\n          report += `   • ${warning.field || 'General'}: ${warning.message}\\n`;\n          if (warning.suggestion) {\n            report += `     💡 Suggestion: ${warning.suggestion}\\n`;\n          }\n        });\n        report += '\\n';\n      }\n      \n      if (validationResult.suggestions && validationResult.suggestions.length > 0) {\n        report += `💡 Suggestions:\\n`;\n        validationResult.suggestions.forEach((suggestion: string) => {\n          report += `   • ${suggestion}\\n`;\n        });\n      }\n      \n      // Add strict mode additional checks if requested\n      if (strict) {\n        report += '\\n📋 Strict Mode: Additional quality checks applied';\n      }\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: report\n        }]\n      };\n    } catch (error) {\n      logger.error(`Failed to validate element:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to validate element: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async deleteElement(args: {name: string; type: string; deleteData?: boolean}) {\n    try {\n      const { name, type, deleteData } = args;\n      \n      // Validate element type\n      if (!Object.values(ElementType).includes(type as ElementType)) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Invalid element type: ${type}\\nValid types: ${Object.values(ElementType).join(', ')} (or legacy plural forms: personas, skills, templates, agents)`\n          }]\n        };\n      }\n      \n      // Get the appropriate manager based on type\n      let manager: SkillManager | TemplateManager | AgentManager | null = null;\n      switch (type as ElementType) {\n        case ElementType.SKILL:\n          manager = this.skillManager;\n          break;\n        case ElementType.TEMPLATE:\n          manager = this.templateManager;\n          break;\n        case ElementType.AGENT:\n          manager = this.agentManager;\n          break;\n        case ElementType.PERSONA:\n          // For personas, use a different approach\n          const personaPath = path.join(this.personasDir, `${name}.md`);\n          try {\n            await fs.access(personaPath);\n            await fs.unlink(personaPath);\n            \n            // Reload personas to update the cache\n            await this.loadPersonas();\n            \n            return {\n              content: [{\n                type: \"text\",\n                text: `✅ Successfully deleted persona '${name}'`\n              }]\n            };\n          } catch (error) {\n            if ((error as any).code === 'ENOENT') {\n              return {\n                content: [{\n                  type: \"text\",\n                  text: `❌ Persona '${name}' not found`\n                }]\n              };\n            }\n            throw error;\n          }\n        default:\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ Element type '${type}' is not yet supported for deletion`\n            }]\n          };\n      }\n      \n      // Ensure manager was assigned (TypeScript type safety)\n      if (!manager) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Element type '${type}' is not supported for deletion`\n          }]\n        };\n      }\n      \n      // Find the element first to check if it exists\n      const element = await manager!.find((e: any) => e.metadata.name === name);\n      if (!element) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ ${type} '${name}' not found`\n          }]\n        };\n      }\n      \n      // Check for associated data files\n      let dataFiles: string[] = [];\n      \n      // Agent-specific: Check for state files\n      if (type === ElementType.AGENT) {\n        const stateDir = path.join(this.portfolioManager.getElementDir(ElementType.AGENT), '.state');\n        const stateFile = path.join(stateDir, `${name}-state.json`);\n        try {\n          const stat = await fs.stat(stateFile);\n          dataFiles.push(`- .state/${name}-state.json (${(stat.size / 1024).toFixed(2)} KB)`);\n        } catch (error) {\n          // No state file exists, which is fine\n        }\n      }\n      \n      // Memory-specific: Check for storage files\n      if (type === ElementType.MEMORY) {\n        const storageDir = path.join(this.portfolioManager.getElementDir(ElementType.MEMORY), '.storage');\n        const storageFile = path.join(storageDir, `${name}-memory.json`);\n        try {\n          const stat = await fs.stat(storageFile);\n          dataFiles.push(`- .storage/${name}-memory.json (${(stat.size / 1024).toFixed(2)} KB)`);\n        } catch (error) {\n          // No storage file exists, which is fine\n        }\n      }\n      \n      // Ensemble-specific: Check for config files\n      if (type === ElementType.ENSEMBLE) {\n        const configDir = path.join(this.portfolioManager.getElementDir(ElementType.ENSEMBLE), '.configs');\n        const configFile = path.join(configDir, `${name}-config.json`);\n        try {\n          const stat = await fs.stat(configFile);\n          dataFiles.push(`- .configs/${name}-config.json (${(stat.size / 1024).toFixed(2)} KB)`);\n        } catch (error) {\n          // No config file exists, which is fine\n        }\n      }\n      \n      // If data files exist and deleteData is not specified, we need to inform the user\n      if (dataFiles.length > 0 && deleteData === undefined) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `⚠️  This ${type} has associated data files:\\n${dataFiles.join('\\n')}\\n\\nWould you like to delete these data files as well?\\n\\n• To delete everything (element + data), say: \"Yes, delete all data\"\\n• To keep the data files, say: \"No, keep the data\"\\n• To cancel, say: \"Cancel\"`\n          }]\n        };\n      }\n      \n      // Delete the main element file\n      const filename = `${slugify(name)}.md`;\n      const filepath = path.join(this.portfolioManager.getElementDir(type as ElementType), filename);\n      \n      try {\n        await fs.unlink(filepath);\n      } catch (error) {\n        if ((error as any).code === 'ENOENT') {\n          return {\n            content: [{\n              type: \"text\",\n              text: `❌ ${type} file '${filename}' not found`\n            }]\n          };\n        }\n        throw error;\n      }\n      \n      // Delete associated data files if requested\n      if (deleteData && dataFiles.length > 0) {\n        const updatedDataFiles: string[] = [];\n        \n        if (type === ElementType.AGENT) {\n          const stateFile = path.join(this.portfolioManager.getElementDir(ElementType.AGENT), '.state', `${name}-state.json`);\n          try {\n            await fs.unlink(stateFile);\n            updatedDataFiles.push(`${dataFiles[0]} ✓ deleted`);\n          } catch (error) {\n            // Log but don't fail if state file deletion fails\n            logger.warn(`Failed to delete agent state file: ${error}`);\n            updatedDataFiles.push(`${dataFiles[0]} ⚠️ deletion failed`);\n          }\n        } else if (type === ElementType.MEMORY) {\n          const storageFile = path.join(this.portfolioManager.getElementDir(ElementType.MEMORY), '.storage', `${name}-memory.json`);\n          try {\n            await fs.unlink(storageFile);\n            updatedDataFiles.push(`${dataFiles[0]} ✓ deleted`);\n          } catch (error) {\n            // Log but don't fail if storage file deletion fails\n            logger.warn(`Failed to delete memory storage file: ${error}`);\n            updatedDataFiles.push(`${dataFiles[0]} ⚠️ deletion failed`);\n          }\n        } else if (type === ElementType.ENSEMBLE) {\n          const configFile = path.join(this.portfolioManager.getElementDir(ElementType.ENSEMBLE), '.configs', `${name}-config.json`);\n          try {\n            await fs.unlink(configFile);\n            updatedDataFiles.push(`${dataFiles[0]} ✓ deleted`);\n          } catch (error) {\n            // Log but don't fail if config file deletion fails\n            logger.warn(`Failed to delete ensemble config file: ${error}`);\n            updatedDataFiles.push(`${dataFiles[0]} ⚠️ deletion failed`);\n          }\n        }\n        \n        dataFiles = updatedDataFiles;\n      }\n      \n      // Build success message\n      let message = `✅ Successfully deleted ${type} '${name}'`;\n      if (dataFiles.length > 0) {\n        if (deleteData) {\n          message += `\\n\\nAssociated data files:\\n${dataFiles.join('\\n')}`;\n        } else {\n          message += `\\n\\n⚠️ Associated data files were preserved:\\n${dataFiles.join('\\n')}`;\n        }\n      }\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: message\n        }]\n      };\n      \n    } catch (error) {\n      logger.error(`Failed to delete element:`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to delete element: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  // checkRateLimit and fetchFromGitHub are now handled by GitHubClient\n\n  async browseCollection(section?: string, type?: string) {\n    try {\n      // FIX #471: Replace legacy category validation with proper section/type validation\n      // Valid sections: library, showcase, catalog\n      // Valid types: personas, skills, agents, prompts, templates, tools, ensembles, memories\n      const validSections = ['library', 'showcase', 'catalog'];\n      const validTypes = ['personas', 'skills', 'agents', 'prompts', 'templates', 'tools', 'ensembles', 'memories'];\n      \n      // Validate section if provided\n      const validatedSection = section ? sanitizeInput(section.toLowerCase()) : undefined;\n      if (validatedSection && !validSections.includes(validatedSection)) {\n        throw new Error(`Invalid section '${validatedSection}'. Must be one of: ${validSections.join(', ')}`);\n      }\n      \n      // Validate type if provided (only valid when section is 'library')\n      const validatedType = type ? sanitizeInput(type.toLowerCase()) : undefined;\n      if (validatedType && validatedSection === 'library' && !validTypes.includes(validatedType)) {\n        throw new Error(`Invalid type '${validatedType}'. Must be one of: ${validTypes.join(', ')}`);\n      }\n      if (validatedType && validatedSection !== 'library') {\n        throw new Error('Type parameter is only valid when section is \"library\"');\n      }\n      \n      const result = await this.collectionBrowser.browseCollection(validatedSection, validatedType);\n      \n      // Handle sections view\n      const items = result.items;\n      const categories = result.sections || result.categories;\n      \n      const text = this.collectionBrowser.formatBrowseResults(\n        items, \n        categories, \n        validatedSection, \n        validatedType, \n        this.getPersonaIndicator()\n      );\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: text,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Collection browsing failed: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n  }\n\n  async searchCollection(query: string) {\n    try {\n      // Enhanced input validation for search query\n      const validatedQuery = MCPInputValidator.validateSearchQuery(query);\n      \n      const items = await this.collectionSearch.searchCollection(validatedQuery);\n      const text = this.collectionSearch.formatSearchResults(items, validatedQuery, this.getPersonaIndicator());\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: text,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error searching collection: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n  }\n\n  async getCollectionContent(path: string) {\n    try {\n      const { metadata, content } = await this.personaDetails.getCollectionContent(path);\n      const text = this.personaDetails.formatPersonaDetails(metadata, content, path, this.getPersonaIndicator());\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: text,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error fetching content: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n  }\n\n  async installContent(inputPath: string) {\n    try {\n      const result = await this.elementInstaller.installContent(inputPath);\n      \n      if (!result.success) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `⚠️ ${result.message}`,\n            },\n          ],\n        };\n      }\n      \n      // If it's a persona, reload personas\n      if (result.elementType === ElementType.PERSONA) {\n        await this.loadPersonas();\n      }\n      \n      const text = this.elementInstaller.formatInstallSuccess(\n        result.metadata!, \n        result.filename!,\n        result.elementType!\n      );\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: text,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error installing AI customization element: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n  }\n\n  async submitContent(contentIdentifier: string) {\n    // Check GitHub authentication first\n    const authStatus = await this.githubAuthManager.getAuthStatus();\n    const isAuthenticated = authStatus.isAuthenticated;\n    \n    // Find the content in local collection\n    let persona = this.personas.get(contentIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === contentIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Content not found: ${contentIdentifier}`,\n          },\n        ],\n      };\n    }\n\n    // Validate persona content before submission\n    try {\n      // Read the full persona file content\n      const fullPath = path.join(this.personasDir, persona.filename);\n      const fileContent = await PathValidator.safeReadFile(fullPath);\n      \n      // Validate content for security threats\n      const contentValidation = ContentValidator.validateAndSanitize(fileContent);\n      if (!contentValidation.isValid && contentValidation.severity === 'critical') {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ **Security Validation Failed**\\n\\n` +\n              `This persona contains content that could be used for prompt injection attacks:\\n` +\n              `• ${contentValidation.detectedPatterns?.join('\\n• ')}\\n\\n` +\n              `Please remove these patterns before submitting to the collection.`,\n            },\n          ],\n        };\n      }\n      \n      // Validate metadata\n      const metadataValidation = ContentValidator.validateMetadata(persona.metadata);\n      if (!metadataValidation.isValid) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}⚠️ **Metadata Security Warning**\\n\\n` +\n              `The persona metadata contains potentially problematic content:\\n` +\n              `• ${metadataValidation.detectedPatterns?.join('\\n• ')}\\n\\n` +\n              `Please fix these issues before submitting.`,\n            },\n          ],\n        };\n      }\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error validating persona: ${sanitized.message}`,\n          },\n        ],\n      };\n    }\n\n    // Generate submission issue with rate limiting\n    let githubIssueUrl: string;\n    let rateLimitStatus: any;\n    \n    try {\n      const submissionResult = this.personaSubmitter.generateSubmissionIssue(persona);\n      githubIssueUrl = submissionResult.githubIssueUrl;\n      rateLimitStatus = submissionResult.rateLimitStatus;\n    } catch (error: any) {\n      // Handle rate limiting error specifically\n      if (error.message.includes('rate limit')) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}⏳ **Rate Limit Reached**\\n\\n` +\n                `${error.message}\\n\\n` +\n                `This protection ensures the quality and integrity of our collection.`,\n            },\n          ],\n        };\n      }\n      throw error; // Re-throw other errors\n    }\n    \n    // Choose response format based on authentication status\n    const text = isAuthenticated \n      ? this.personaSubmitter.formatSubmissionResponse(persona, githubIssueUrl, this.getPersonaIndicator())\n      : this.personaSubmitter.formatAnonymousSubmissionResponse(persona, githubIssueUrl, this.getPersonaIndicator());\n    \n    // Add rate limit info if available\n    const rateLimitInfo = rateLimitStatus \n      ? `\\n\\n📊 **Rate Limit Status:** ${rateLimitStatus.remainingTokens} submissions remaining this hour`\n      : '';\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: text + rateLimitInfo,\n        },\n      ],\n    };\n  }\n\n  async getCollectionCacheHealth() {\n    try {\n      // Get cache statistics\n      const stats = await this.collectionCache.getCacheStats();\n      \n      // Check if cache directory exists\n      const cacheDir = path.join(process.cwd(), '.dollhousemcp', 'cache');\n      let cacheFileExists = false;\n      let cacheFileSize = 0;\n      \n      try {\n        const cacheFile = path.join(cacheDir, 'collection-cache.json');\n        const fileStats = await fs.stat(cacheFile);\n        cacheFileExists = true;\n        cacheFileSize = fileStats.size;\n      } catch (error) {\n        // Cache file doesn't exist yet\n      }\n      \n      // Format cache age\n      const formatAge = (ageMs: number): string => {\n        if (ageMs === 0) return 'Not cached';\n        const hours = Math.floor(ageMs / (1000 * 60 * 60));\n        const minutes = Math.floor((ageMs % (1000 * 60 * 60)) / (1000 * 60));\n        if (hours > 0) {\n          return `${hours}h ${minutes}m old`;\n        }\n        return `${minutes}m old`;\n      };\n      \n      // Build health report\n      const healthReport = {\n        status: stats.isValid ? 'healthy' : (cacheFileExists ? 'expired' : 'empty'),\n        cacheExists: cacheFileExists,\n        itemCount: stats.itemCount,\n        cacheAge: formatAge(stats.cacheAge),\n        cacheAgeMs: stats.cacheAge,\n        isValid: stats.isValid,\n        cacheFileSize: cacheFileSize,\n        cacheFileSizeFormatted: cacheFileSize > 0 ? `${(cacheFileSize / 1024).toFixed(2)} KB` : '0 KB',\n        ttlRemaining: stats.isValid ? formatAge(24 * 60 * 60 * 1000 - stats.cacheAge) : 'Expired',\n        recommendation: stats.isValid \n          ? 'Cache is healthy and serving content' \n          : cacheFileExists \n            ? 'Cache has expired. Will refresh on next collection access.'\n            : 'No cache present. Will be created on first collection access.'\n      };\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}📊 **Collection Cache Health Check**\\n\\n` +\n              `**Status**: ${healthReport.status === 'healthy' ? '✅' : healthReport.status === 'expired' ? '⚠️' : '📦'} ${healthReport.status.toUpperCase()}\\n` +\n              `**Items Cached**: ${healthReport.itemCount}\\n` +\n              `**Cache Age**: ${healthReport.cacheAge}\\n` +\n              `**Cache Size**: ${healthReport.cacheFileSizeFormatted}\\n` +\n              `**Valid**: ${healthReport.isValid ? 'Yes ✓' : 'No ✗'}\\n` +\n              `**TTL Remaining**: ${healthReport.ttlRemaining}\\n\\n` +\n              `**Recommendation**: ${healthReport.recommendation}\\n\\n` +\n              `Cache enables offline browsing and faster collection access.`,\n          },\n        ],\n      };\n    } catch (error) {\n      const errorMessage = error instanceof Error ? error.message : String(error);\n      logger.error(`Failed to get cache health: ${errorMessage}`);\n      \n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Failed to get cache health: ${errorMessage}`,\n          },\n        ],\n      };\n    }\n  }\n\n  // User identity management\n  async setUserIdentity(username: string, email?: string) {\n    try {\n      if (!username || username.trim().length === 0) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ Username cannot be empty`,\n            },\n          ],\n        };\n      }\n\n      // Validate and sanitize username\n      const validatedUsername = validateUsername(username);\n      \n      // Validate email if provided\n      let validatedEmail: string | undefined;\n      if (email) {\n        const sanitizedEmail = sanitizeInput(email, 100);\n        if (!VALIDATION_PATTERNS.SAFE_EMAIL.test(sanitizedEmail)) {\n          throw new Error('Invalid email format');\n        }\n        validatedEmail = sanitizedEmail;\n      }\n\n      // Set the validated user identity\n      this.currentUser = validatedUsername;\n      if (validatedEmail) {\n        process.env.DOLLHOUSE_EMAIL = validatedEmail;\n      }\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **User Identity Set**\\n\\n` +\n            `👤 **Username:** ${validatedUsername}\\n` +\n            `${validatedEmail ? `📧 **Email:** ${validatedEmail}\\n` : ''}` +\n            `\\n🎯 **Next Steps:**\\n` +\n            `• New personas you create will be attributed to \"${validatedUsername}\"\\n` +\n            `• Set environment variable \\`DOLLHOUSE_USER=${validatedUsername}\\` to persist this setting\\n` +\n            `${validatedEmail ? `• Set environment variable \\`DOLLHOUSE_EMAIL=${validatedEmail}\\` for contact info\\n` : ''}` +\n            `• Use \\`clear_user_identity\\` to return to anonymous mode`,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Validation Error**\\n\\n` +\n              `${sanitized.message}\\n\\n` +\n              `Please provide a valid username (alphanumeric characters, hyphens, underscores, dots only).`,\n          },\n        ],\n      };\n    }\n  }\n\n  async getUserIdentity() {\n    const email = process.env.DOLLHOUSE_EMAIL;\n    \n    if (!this.currentUser) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}👤 **User Identity: Anonymous**\\n\\n` +\n            `🔒 **Status:** Anonymous mode\\n` +\n            `📝 **Attribution:** Personas will use anonymous IDs\\n\\n` +\n            `**To set your identity:**\\n` +\n            `• Use: \\`set_user_identity \"your-username\"\\`\\n` +\n            `• Or set environment variable: \\`DOLLHOUSE_USER=your-username\\``,\n          },\n        ],\n      };\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}👤 **User Identity: ${this.currentUser}**\\n\\n` +\n          `✅ **Status:** Authenticated\\n` +\n          `👤 **Username:** ${this.currentUser}\\n` +\n          `${email ? `📧 **Email:** ${email}\\n` : ''}` +\n          `📝 **Attribution:** New personas will be credited to \"${this.currentUser}\"\\n\\n` +\n          `**Environment Variables:**\\n` +\n          `• \\`DOLLHOUSE_USER=${this.currentUser}\\`\\n` +\n          `${email ? `• \\`DOLLHOUSE_EMAIL=${email}\\`\\n` : ''}` +\n          `\\n**Management:**\\n` +\n          `• Use \\`clear_user_identity\\` to return to anonymous mode\\n` +\n          `• Use \\`set_user_identity \"new-username\"\\` to change username`,\n        },\n      ],\n    };\n  }\n\n  async clearUserIdentity() {\n    const wasSet = this.currentUser !== null;\n    const previousUser = this.currentUser;\n    this.currentUser = null;\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: wasSet \n            ? `${this.getPersonaIndicator()}✅ **User Identity Cleared**\\n\\n` +\n              `👤 **Previous:** ${previousUser}\\n` +\n              `🔒 **Current:** Anonymous mode\\n\\n` +\n              `📝 **Effect:** New personas will use anonymous IDs\\n\\n` +\n              `⚠️ **Note:** This only affects the current session.\\n` +\n              `To persist this change, unset the \\`DOLLHOUSE_USER\\` environment variable.`\n            : `${this.getPersonaIndicator()}ℹ️ **Already in Anonymous Mode**\\n\\n` +\n              `👤 No user identity was set.\\n\\n` +\n              `Use \\`set_user_identity \"username\"\\` to set your identity.`,\n        },\n      ],\n    };\n  }\n\n  private getCurrentUserForAttribution(): string {\n    return this.currentUser || generateAnonymousId();\n  }\n\n  // GitHub authentication management\n  async setupGitHubAuth() {\n    try {\n      // Check current auth status first\n      const currentStatus = await this.githubAuthManager.getAuthStatus();\n      \n      if (currentStatus.isAuthenticated) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **Already Connected to GitHub**\\n\\n` +\n                  `👤 **Username:** ${currentStatus.username}\\n` +\n                  `🔑 **Permissions:** ${currentStatus.scopes?.join(', ') || 'basic access'}\\n\\n` +\n                  `You're all set! You can:\\n` +\n                  `• Browse the collection\\n` +\n                  `• Install content\\n` +\n                  `• Submit your creations\\n\\n` +\n                  `To disconnect, say \"disconnect from GitHub\"`\n          }]\n        };\n      }\n      \n      // Initiate device flow\n      const deviceResponse = await this.githubAuthManager.initiateDeviceFlow();\n      \n      // Start polling in background\n      this.pollForAuthCompletion(deviceResponse.device_code, deviceResponse.interval);\n      \n      // Return instructions to user\n      return {\n        content: [{\n          type: \"text\",\n          text: this.githubAuthManager.formatAuthInstructions(deviceResponse)\n        }]\n      };\n    } catch (error) {\n      logger.error('Failed to setup GitHub auth', { error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ **Authentication Setup Failed**\\n\\n` +\n                `Unable to start GitHub authentication: ${error instanceof Error ? error.message : 'Unknown error'}\\n\\n` +\n                `Please check your internet connection and try again.`\n        }]\n      };\n    }\n  }\n  \n  async checkGitHubAuth() {\n    try {\n      const status = await this.githubAuthManager.getAuthStatus();\n      \n      if (status.isAuthenticated) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **GitHub Connected**\\n\\n` +\n                  `👤 **Username:** ${status.username}\\n` +\n                  `🔑 **Permissions:** ${status.scopes?.join(', ') || 'basic access'}\\n\\n` +\n                  `**Available Actions:**\\n` +\n                  `✅ Browse collection\\n` +\n                  `✅ Install content\\n` +\n                  `✅ Submit content\\n\\n` +\n                  `Everything is working properly!`\n          }]\n        };\n      } else if (status.hasToken) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}⚠️ **GitHub Token Invalid**\\n\\n` +\n                  `A GitHub token was found but it appears to be invalid or expired.\\n\\n` +\n                  `**To fix this:**\\n` +\n                  `1. Say \"set up GitHub\" to authenticate again\\n` +\n                  `2. Or check your GITHUB_TOKEN environment variable\\n\\n` +\n                  `Note: Browse and install still work without authentication!`\n          }]\n        };\n      } else {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}🔒 **Not Connected to GitHub**\\n\\n` +\n                  `You're not currently authenticated with GitHub.\\n\\n` +\n                  `**What works without auth:**\\n` +\n                  `✅ Browse the public collection\\n` +\n                  `✅ Install community content\\n` +\n                  `❌ Submit your own content (requires auth)\\n\\n` +\n                  `To connect, just say \"set up GitHub\" or \"connect to GitHub\"`\n          }]\n        };\n      }\n    } catch (error) {\n      logger.error('Failed to check GitHub auth', { error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ **Unable to Check Authentication**\\n\\n` +\n                `Error: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  async clearGitHubAuth() {\n    try {\n      await this.githubAuthManager.clearAuthentication();\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}✅ **GitHub Disconnected**\\n\\n` +\n                `Your GitHub connection has been cleared.\\n\\n` +\n                `**What still works:**\\n` +\n                `✅ Browse the public collection\\n` +\n                `✅ Install community content\\n` +\n                `❌ Submit content (requires reconnection)\\n\\n` +\n                `To reconnect later, just say \"connect to GitHub\"\\n\\n` +\n                `⚠️ **Note:** To fully remove authentication, also unset the GITHUB_TOKEN environment variable.`\n        }]\n      };\n    } catch (error) {\n      logger.error('Failed to clear GitHub auth', { error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ **Failed to Clear Authentication**\\n\\n` +\n                `Error: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n  \n  /**\n   * Poll for auth completion in the background\n   */\n  private async pollForAuthCompletion(deviceCode: string, interval: number): Promise<void> {\n    try {\n      const tokenResponse = await this.githubAuthManager.pollForToken(deviceCode, interval);\n      const authStatus = await this.githubAuthManager.completeAuthentication(tokenResponse);\n      \n      // Log success (user will see this in their next interaction)\n      logger.info('GitHub authentication completed successfully', { \n        username: authStatus.username,\n        scopes: authStatus.scopes \n      });\n    } catch (error) {\n      // Log error but don't throw - this runs in background\n      logger.error('GitHub authentication polling failed', { error });\n    }\n  }\n\n  // Chat-based persona management tools\n  async createPersona(name: string, description: string, instructions: string, triggers?: string) {\n    try {\n      // Validate required fields\n      if (!name || !description || !instructions) {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ **Missing Required Fields**\\n\\n` +\n                `Please provide all required fields:\\n` +\n                `• **name**: Display name for the persona\\n` +\n                `• **description**: Brief description of what it does\\n` +\n                `• **instructions**: The persona's behavioral guidelines\\n\\n` +\n                `**Optional:**\\n` +\n                `• **triggers**: Comma-separated keywords for activation`,\n            },\n          ],\n        };\n      }\n\n      // Sanitize and validate inputs\n      const sanitizedName = sanitizeInput(name, 100);\n      const sanitizedDescription = sanitizeInput(description, 500);\n      const sanitizedInstructions = sanitizeInput(instructions);\n      const sanitizedTriggers = triggers ? sanitizeInput(triggers, 200) : '';\n\n      // Validate name length and format\n      if (sanitizedName.length < 2) {\n        throw new Error('Persona name must be at least 2 characters long');\n      }\n\n      // No category validation needed - categories are deprecated\n\n      // Validate content sizes\n      validateContentSize(sanitizedInstructions, SECURITY_LIMITS.MAX_CONTENT_LENGTH);\n      validateContentSize(sanitizedDescription, 2000); // 2KB max for description\n\n      // Validate content for security threats\n      const nameValidation = ContentValidator.validateAndSanitize(sanitizedName);\n      if (!nameValidation.isValid) {\n        throw new Error(`Name contains prohibited content: ${nameValidation.detectedPatterns?.join(', ')}`);\n      }\n\n      const descValidation = ContentValidator.validateAndSanitize(sanitizedDescription);\n      if (!descValidation.isValid) {\n        throw new Error(`Description contains prohibited content: ${descValidation.detectedPatterns?.join(', ')}`);\n      }\n\n      const instructionsValidation = ContentValidator.validateAndSanitize(sanitizedInstructions);\n      if (!instructionsValidation.isValid && instructionsValidation.severity === 'critical') {\n        throw new Error(`Instructions contain security threats: ${instructionsValidation.detectedPatterns?.join(', ')}`);\n      }\n\n      // Generate metadata\n      const author = this.getCurrentUserForAttribution();\n      const uniqueId = generateUniqueId(sanitizedName, this.currentUser || undefined);\n      const filename = validateFilename(`${slugify(sanitizedName)}.md`);\n      const filePath = path.join(this.personasDir, filename);\n\n    // Check if file already exists\n    try {\n      await PathValidator.validatePersonaPath(filePath);\n      await fs.access(filePath);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}⚠️ **Persona Already Exists**\\n\\n` +\n              `A persona file named \"${filename}\" already exists.\\n` +\n              `Use \\`edit_persona\\` to modify it, or choose a different name.`,\n          },\n        ],\n      };\n    } catch {\n      // File doesn't exist, proceed with creation\n    }\n\n      // Parse and sanitize triggers\n      const triggerList = sanitizedTriggers ? \n        sanitizedTriggers.split(',').map(t => sanitizeInput(t.trim(), 50)).filter(t => t.length > 0) : \n        [];\n\n      // Create persona metadata with sanitized values\n      const metadata: PersonaMetadata = {\n        name: sanitizedName,\n        description: sanitizedDescription,\n        unique_id: uniqueId,\n        author,\n        triggers: triggerList,\n        version: \"1.0\",\n        age_rating: \"all\",\n        content_flags: [\"user-created\"],\n        ai_generated: true,\n        generation_method: \"Claude\",\n        price: \"free\",\n        revenue_split: \"80/20\",\n        license: \"CC-BY-SA-4.0\",\n        created_date: new Date().toISOString().slice(0, 10)\n      };\n\n      // Create full persona content with sanitized values\n      const frontmatter = Object.entries(metadata)\n        .map(([key, value]) => `${key}: ${JSON.stringify(value)}`)\n        .join('\\n');\n\n      const personaContent = `---\n${frontmatter}\n---\n\n# ${sanitizedName}\n\n${sanitizedInstructions}\n\n## Response Style\n- Follow the behavioral guidelines above\n- Maintain consistency with the persona's character\n- Adapt responses to match the intended purpose\n\n## Usage Notes\n- Created via DollhouseMCP chat interface\n- Author: ${author}\n- Version: 1.0`;\n\n      // Validate final content size\n      validateContentSize(personaContent, SECURITY_LIMITS.MAX_PERSONA_SIZE_BYTES);\n\n    try {\n      // Use file locking to prevent race conditions\n      await FileLockManager.withLock(`persona:${sanitizedName}`, async () => {\n        // Double-check file doesn't exist (in case of race condition)\n        try {\n          await fs.access(filePath);\n          throw new Error(`Persona file \"${filename}\" already exists`);\n        } catch (error: any) {\n          // If error is not ENOENT (file not found), re-throw it\n          if (error.code !== 'ENOENT' && error.message?.includes('already exists')) {\n            throw error;\n          }\n          // File doesn't exist, proceed\n        }\n        \n        // Write the file atomically\n        await FileLockManager.atomicWriteFile(filePath, personaContent);\n      });\n      \n      // Reload personas to include the new one\n      await this.loadPersonas();\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **Persona Created Successfully!**\\n\\n` +\n              `🎭 **${sanitizedName}** by ${author}\\n` +\n              `🆔 Unique ID: ${uniqueId}\\n` +\n              `📄 Saved as: ${filename}\\n` +\n              `📊 Total personas: ${this.personas.size}\\n\\n` +\n              `🎯 **Ready to use:** \\`activate_persona \"${sanitizedName}\"\\`\\n` +\n              `📤 **Share it:** \\`submit_content \"${sanitizedName}\"\\`\\n` +\n              `✏️ **Edit it:** \\`edit_persona \"${sanitizedName}\" \"field\" \"new value\"\\``,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Error Creating Persona**\\n\\n` +\n              `Failed to write persona file: ${sanitized.message}\\n\\n` +\n              `Please check permissions and try again.`,\n          },\n        ],\n      };\n    }\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Validation Error**\\n\\n` +\n              `${sanitized.message}\\n\\n` +\n              `Please fix the issue and try again.`,\n          },\n        ],\n      };\n    }\n  }\n\n  async editPersona(personaIdentifier: string, field: string, value: string) {\n    if (!personaIdentifier || !field || !value) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Missing Parameters**\\n\\n` +\n              `Usage: \\`edit_persona \"persona_name\" \"field\" \"new_value\"\\`\\n\\n` +\n              `**Editable fields:**\\n` +\n              `• **name** - Display name\\n` +\n              `• **description** - Brief description\\n` +\n              `• **instructions** - Main persona content\\n` +\n              `• **triggers** - Comma-separated keywords\\n` +\n              `• **version** - Version number`,\n          },\n        ],\n      };\n    }\n\n    // Find the persona\n    let persona = this.personas.get(personaIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === personaIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Persona Not Found**\\n\\n` +\n              `Could not find persona: \"${personaIdentifier}\"\\n\\n` +\n              `Use \\`list_personas\\` to see available personas.`,\n          },\n        ],\n      };\n    }\n\n    const validFields = ['name', 'description', 'instructions', 'triggers', 'version'];\n    if (!validFields.includes(field.toLowerCase())) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Invalid Field**\\n\\n` +\n              `Field \"${field}\" is not editable.\\n\\n` +\n              `**Valid fields:** ${validFields.join(', ')}`,\n          },\n        ],\n      };\n    }\n\n    let filePath = path.join(this.personasDir, persona.filename);\n    let isDefault = isDefaultPersona(persona.filename);\n\n    try {\n      // Read current file\n      const fileContent = await PathValidator.safeReadFile(filePath);\n      \n      // Use secure YAML parser\n      let parsed;\n      try {\n        parsed = SecureYamlParser.safeMatter(fileContent);\n      } catch (error) {\n        if (error instanceof SecurityError) {\n          return {\n            content: [\n              {\n                type: \"text\",\n                text: `${this.getPersonaIndicator()}❌ **Security Error**\\n\\n` +\n                  `Cannot edit persona due to security threat: ${error.message}`,\n              },\n            ],\n          };\n        }\n        throw error;\n      }\n      \n      // If editing a default persona, create a copy instead\n      if (isDefault) {\n        // Generate unique ID for the copy\n        const author = this.currentUser || generateAnonymousId();\n        const uniqueId = generateUniqueId(persona.metadata.name, author);\n        const newFilename = `${uniqueId}.md`;\n        const newFilePath = path.join(this.personasDir, newFilename);\n        \n        // Create copy of the default persona\n        const content = await PathValidator.safeReadFile(filePath);\n        \n        // Use file locking to prevent race conditions when creating the copy\n        await FileLockManager.withLock(`persona:${persona.metadata.name}-copy`, async () => {\n          await FileLockManager.atomicWriteFile(newFilePath, content);\n        });\n        \n        // Update file path to point to the copy\n        filePath = newFilePath;\n        \n        // Update the unique_id in the metadata\n        parsed.data.unique_id = uniqueId;\n        parsed.data.author = author;\n      }\n      \n      // Update the appropriate field\n      const normalizedField = field.toLowerCase();\n      \n      // Validate the new value for security threats\n      const valueValidation = ContentValidator.validateAndSanitize(value);\n      if (!valueValidation.isValid && valueValidation.severity === 'critical') {\n        return {\n          content: [\n            {\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ **Security Validation Failed**\\n\\n` +\n              `The new value contains prohibited content:\\n` +\n              `• ${valueValidation.detectedPatterns?.join('\\n• ')}\\n\\n` +\n              `Please remove these patterns and try again.`,\n            },\n          ],\n        };\n      }\n      \n      // Use sanitized value if needed\n      let sanitizedValue = valueValidation.sanitizedContent || value;\n      \n      // Always remove shell metacharacters from display output\n      const displayValue = sanitizedValue.replace(/[;&|`$()]/g, '');\n      \n      if (normalizedField === 'instructions') {\n        // Update the main content\n        parsed.content = sanitizedValue;\n      } else if (normalizedField === 'triggers') {\n        // Parse triggers as comma-separated list\n        parsed.data[normalizedField] = sanitizedValue.split(',').map(t => t.trim()).filter(t => t.length > 0);\n      } else if (normalizedField === 'category') {\n        // Category field is deprecated but still editable for backward compatibility\n        parsed.data[normalizedField] = sanitizedValue;\n      } else {\n        // Update metadata field\n        // For name field, apply additional sanitization to remove shell metacharacters\n        if (normalizedField === 'name') {\n          parsed.data[normalizedField] = sanitizeInput(sanitizedValue, 100);\n        } else {\n          parsed.data[normalizedField] = sanitizedValue;\n        }\n      }\n\n      // Update version and modification info\n      if (normalizedField !== 'version') {\n        const currentVersion = parsed.data.version || '1.0';\n        const versionParts = currentVersion.split('.').map(Number);\n        versionParts[1] = (versionParts[1] || 0) + 1;\n        parsed.data.version = versionParts.join('.');\n      }\n\n      // Regenerate file content\n      // Use secure YAML stringification\n      const secureParser = SecureYamlParser.createSecureMatterParser();\n      const updatedContent = secureParser.stringify(parsed.content, parsed.data);\n      \n      // Use file locking to prevent race conditions\n      await FileLockManager.withLock(`persona:${persona.metadata.name}`, async () => {\n        // Write updated file atomically\n        await FileLockManager.atomicWriteFile(filePath, updatedContent);\n      });\n      \n      // Reload personas\n      await this.loadPersonas();\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ **Persona Updated Successfully!**\\n\\n` +\n              (isDefault ? `📋 **Note:** Created a copy of the default persona to preserve the original.\\n\\n` : '') +\n              `🎭 **${(parsed.data.name || persona.metadata.name || '').replace(/[;&|`$()]/g, '')}**\\n` +\n              `📝 **Field Updated:** ${field}\\n` +\n              `🔄 **New Value:** ${normalizedField === 'instructions' ? 'Content updated' : displayValue}\\n` +\n              `📊 **Version:** ${parsed.data.version}\\n` +\n              (isDefault ? `🆔 **New ID:** ${parsed.data.unique_id}\\n` : '') +\n              `\\n` +\n              `Use \\`get_persona_details \"${(parsed.data.name || persona.metadata.name || '').replace(/[;&|`$()]/g, '')}\"\\` to see all changes.`,\n          },\n        ],\n      };\n    } catch (error) {\n      const sanitized = SecureErrorHandler.sanitizeError(error);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Error Updating Persona**\\n\\n` +\n              `Failed to update persona: ${sanitized.message}\\n\\n` +\n              `Please check file permissions and try again.`,\n          },\n        ],\n      };\n    }\n  }\n\n  async validatePersona(personaIdentifier: string) {\n    if (!personaIdentifier) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Missing Persona Identifier**\\n\\n` +\n              `Usage: \\`validate_persona \"persona_name\"\\`\\n\\n` +\n              `Use \\`list_personas\\` to see available personas.`,\n          },\n        ],\n      };\n    }\n\n    // Find the persona\n    let persona = this.personas.get(personaIdentifier);\n    \n    if (!persona) {\n      // Search by name\n      persona = Array.from(this.personas.values()).find(p => \n        p.metadata.name.toLowerCase() === personaIdentifier.toLowerCase()\n      );\n    }\n\n    if (!persona) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ **Persona Not Found**\\n\\n` +\n              `Could not find persona: \"${personaIdentifier}\"\\n\\n` +\n              `Use \\`list_personas\\` to see available personas.`,\n          },\n        ],\n      };\n    }\n\n    // Validation checks\n    const issues: string[] = [];\n    const warnings: string[] = [];\n    const metadata = persona.metadata;\n\n    // Required field checks\n    if (!metadata.name || metadata.name.trim().length === 0) {\n      issues.push(\"Missing or empty 'name' field\");\n    }\n    if (!metadata.description || metadata.description.trim().length === 0) {\n      issues.push(\"Missing or empty 'description' field\");\n    }\n    if (!persona.content || persona.content.trim().length < 50) {\n      issues.push(\"Persona content is too short (minimum 50 characters)\");\n    }\n\n    // Category validation\n    const validCategories = ['creative', 'professional', 'educational', 'gaming', 'personal', 'general'];\n    if (metadata.category && !validCategories.includes(metadata.category)) {\n      issues.push(`Invalid category '${metadata.category}'. Must be one of: ${validCategories.join(', ')}`);\n    }\n\n    // Age rating validation\n    const validAgeRatings = ['all', '13+', '18+'];\n    if (metadata.age_rating && !validAgeRatings.includes(metadata.age_rating)) {\n      warnings.push(`Invalid age_rating '${metadata.age_rating}'. Should be one of: ${validAgeRatings.join(', ')}`);\n    }\n\n    // Optional field warnings\n    if (!metadata.triggers || metadata.triggers.length === 0) {\n      warnings.push(\"No trigger keywords defined - users may have difficulty finding this persona\");\n    }\n    if (!metadata.version) {\n      warnings.push(\"No version specified - defaulting to '1.0'\");\n    }\n    if (!metadata.unique_id) {\n      warnings.push(\"No unique_id - one will be generated automatically\");\n    }\n\n    // Content quality checks\n    if (persona.content.length > 5000) {\n      warnings.push(\"Persona content is very long - consider breaking it into sections\");\n    }\n    if (metadata.name && metadata.name.length > 50) {\n      warnings.push(\"Persona name is very long - consider shortening for better display\");\n    }\n    if (metadata.description && metadata.description.length > 200) {\n      warnings.push(\"Description is very long - consider keeping it under 200 characters\");\n    }\n\n    // Generate validation report\n    let report = `${this.getPersonaIndicator()}📋 **Validation Report: ${persona.metadata.name}**\\n\\n`;\n    \n    if (issues.length === 0 && warnings.length === 0) {\n      report += `✅ **All Checks Passed!**\\n\\n` +\n        `🎭 **Persona:** ${metadata.name}\\n` +\n        `📁 **Category:** ${metadata.category || 'general'}\\n` +\n        `📊 **Version:** ${metadata.version || '1.0'}\\n` +\n        `📝 **Content Length:** ${persona.content.length} characters\\n` +\n        `🔗 **Triggers:** ${metadata.triggers?.length || 0} keywords\\n\\n` +\n        `This persona meets all validation requirements and is ready for use!`;\n    } else {\n      if (issues.length > 0) {\n        report += `❌ **Issues Found (${issues.length}):**\\n`;\n        issues.forEach((issue, i) => {\n          report += `   ${i + 1}. ${issue}\\n`;\n        });\n        report += '\\n';\n      }\n\n      if (warnings.length > 0) {\n        report += `⚠️ **Warnings (${warnings.length}):**\\n`;\n        warnings.forEach((warning, i) => {\n          report += `   ${i + 1}. ${warning}\\n`;\n        });\n        report += '\\n';\n      }\n\n      if (issues.length > 0) {\n        report += `**Recommendation:** Fix the issues above before using this persona.\\n`;\n        report += `Use \\`edit_persona \"${persona.metadata.name}\" \"field\" \"value\"\\` to make corrections.`;\n      } else {\n        report += `**Status:** Persona is functional but could be improved.\\n`;\n        report += `Address warnings above for optimal performance.`;\n      }\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: report,\n        },\n      ],\n    };\n  }\n\n  // retryNetworkOperation is now handled by UpdateChecker\n\n  // Auto-update management tools\n  async checkForUpdates() {\n    if (!this.updateManager) {\n      return {\n        content: [{ type: \"text\", text: this.getPersonaIndicator() + \"❌ Update functionality not available (initialization failed)\" }]\n      };\n    }\n    const { text } = await this.updateManager.checkForUpdates();\n    return {\n      content: [{ type: \"text\", text: this.getPersonaIndicator() + text }]\n    };\n  }\n\n  // Update helper methods are now handled by UpdateManager\n\n  async updateServer(confirm: boolean) {\n    if (!confirm) {\n      return {\n        content: [{\n          type: \"text\",\n          text: this.getPersonaIndicator() + \n            '⚠️ **Update Confirmation Required**\\n\\n' +\n            'To proceed with the update, you must confirm:\\n' +\n            '`update_server true`\\n\\n' +\n            '**What will happen:**\\n' +\n            '• Backup current version\\n' +\n            '• Pull latest changes from GitHub\\n' +\n            '• Update dependencies\\n' +\n            '• Rebuild TypeScript\\n' +\n            '• Restart server (will disconnect temporarily)\\n\\n' +\n            '**Prerequisites:**\\n' +\n            '• Git repository must be clean (no uncommitted changes)\\n' +\n            '• Network connection required\\n' +\n            '• Sufficient disk space for backup'\n        }]\n      };\n    }\n\n    if (!this.updateManager) {\n      return {\n        content: [{ type: \"text\", text: this.getPersonaIndicator() + \"❌ Update functionality not available (initialization failed)\" }]\n      };\n    }\n    const { text } = await this.updateManager.updateServer(confirm, this.getPersonaIndicator());\n    return {\n      content: [{ type: \"text\", text }]\n    };\n  }\n\n  // Rollback helper methods are now handled by UpdateManager\n\n  async rollbackUpdate(confirm: boolean) {\n    if (!this.updateManager) {\n      return {\n        content: [{ type: \"text\", text: this.getPersonaIndicator() + \"❌ Update functionality not available (initialization failed)\" }]\n      };\n    }\n    const { text } = await this.updateManager.rollbackUpdate(confirm, this.getPersonaIndicator());\n    return {\n      content: [{ type: \"text\", text }]\n    };\n  }\n\n  // Version and git info methods are now handled by UpdateManager\n\n  // Status helper methods are now handled by UpdateManager\n\n  async getServerStatus() {\n    // Add persona information to the status\n    const personaInfo = `\n**🎭 Persona Information:**\n• **Total Personas:** ${this.personas.size}\n• **Active Persona:** ${this.activePersona || 'None'}\n• **User Identity:** ${this.currentUser || 'Anonymous'}\n• **Personas Directory:** ${this.personasDir}`;\n    \n    if (!this.updateManager) {\n      const errorMessage = `${this.getPersonaIndicator()}❌ Update functionality not available (initialization failed)\\n\\n${personaInfo}`;\n      return {\n        content: [{ type: \"text\", text: errorMessage }]\n      };\n    }\n    const { text } = await this.updateManager.getServerStatus(this.getPersonaIndicator());\n    // Insert persona info into the status text\n    const updatedText = text.replace('**Available Commands:**', personaInfo + '\\n\\n**Available Commands:**');\n    \n    return {\n      content: [{ type: \"text\", text: updatedText }]\n    };\n  }\n\n  async convertToGitInstallation(targetDir?: string, confirm: boolean = false) {\n    if (!this.updateManager) {\n      return {\n        content: [{ type: \"text\", text: this.getPersonaIndicator() + \"❌ Update functionality not available (initialization failed)\" }]\n      };\n    }\n    const result = await this.updateManager.convertToGitInstallation(targetDir, confirm, this.getPersonaIndicator());\n    return {\n      content: [{ type: \"text\", text: result.text }]\n    };\n  }\n\n  // Version and dependency methods are now handled by UpdateManager\n\n\n  /**\n   * Configure indicator settings\n   */\n  async configureIndicator(config: Partial<IndicatorConfig>) {\n    try {\n      // Update the configuration\n      if (config.enabled !== undefined) {\n        this.indicatorConfig.enabled = config.enabled;\n      }\n      if (config.style !== undefined) {\n        this.indicatorConfig.style = config.style;\n      }\n      if (config.customFormat !== undefined) {\n        // Validate custom format before applying\n        const validation = validateCustomFormat(config.customFormat);\n        if (!validation.valid) {\n          return {\n            content: [\n              {\n                type: \"text\",\n                text: `${this.getPersonaIndicator()}❌ Invalid custom format: ${validation.error}`\n              }\n            ]\n          };\n        }\n        this.indicatorConfig.customFormat = config.customFormat;\n      }\n      if (config.showVersion !== undefined) {\n        this.indicatorConfig.showVersion = config.showVersion;\n      }\n      if (config.showAuthor !== undefined) {\n        this.indicatorConfig.showAuthor = config.showAuthor;\n      }\n      if (config.showCategory !== undefined) {\n        this.indicatorConfig.showCategory = config.showCategory;\n      }\n      if (config.emoji !== undefined) {\n        this.indicatorConfig.emoji = config.emoji;\n      }\n      if (config.bracketStyle !== undefined) {\n        this.indicatorConfig.bracketStyle = config.bracketStyle;\n      }\n\n      // Show example of what the indicator would look like\n      let exampleIndicator = \"\";\n      if (this.activePersona) {\n        const persona = this.personas.get(this.activePersona);\n        if (persona) {\n          exampleIndicator = formatIndicator(this.indicatorConfig, {\n            name: persona.metadata.name,\n            version: persona.metadata.version,\n            author: persona.metadata.author,\n            category: persona.metadata.category\n          });\n        }\n      } else {\n        // Show example with sample data\n        exampleIndicator = formatIndicator(this.indicatorConfig, {\n          name: \"Example Persona\",\n          version: \"1.0\",\n          author: \"@username\",\n          category: \"creative\"\n        });\n      }\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ Indicator configuration updated successfully!\n\nCurrent settings:\n- Enabled: ${this.indicatorConfig.enabled}\n- Style: ${this.indicatorConfig.style}\n- Show Version: ${this.indicatorConfig.showVersion}\n- Show Author: ${this.indicatorConfig.showAuthor}\n- Show Category: ${this.indicatorConfig.showCategory}\n- Emoji: ${this.indicatorConfig.emoji}\n- Brackets: ${this.indicatorConfig.bracketStyle}\n${this.indicatorConfig.customFormat ? `- Custom Format: ${this.indicatorConfig.customFormat}` : ''}\n\nExample indicator: ${exampleIndicator || \"(none - indicators disabled)\"}\n\nNote: Configuration is temporary for this session. To make permanent, set environment variables:\n- DOLLHOUSE_INDICATOR_ENABLED=true/false\n- DOLLHOUSE_INDICATOR_STYLE=full/minimal/compact/custom\n- DOLLHOUSE_INDICATOR_FORMAT=\"custom format template\"\n- DOLLHOUSE_INDICATOR_SHOW_VERSION=true/false\n- DOLLHOUSE_INDICATOR_SHOW_AUTHOR=true/false\n- DOLLHOUSE_INDICATOR_SHOW_CATEGORY=true/false\n- DOLLHOUSE_INDICATOR_EMOJI=🎭\n- DOLLHOUSE_INDICATOR_BRACKETS=square/round/curly/angle/none`\n          }\n        ]\n      };\n    } catch (error) {\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Error configuring indicator: ${SecureErrorHandler.sanitizeError(error).message}`\n          }\n        ]\n      };\n    }\n  }\n\n  /**\n   * Get current indicator configuration\n   */\n  async getIndicatorConfig() {\n    // Show current configuration and example\n    let exampleIndicator = \"\";\n    if (this.activePersona) {\n      const persona = this.personas.get(this.activePersona);\n      if (persona) {\n        exampleIndicator = formatIndicator(this.indicatorConfig, {\n          name: persona.metadata.name,\n          version: persona.metadata.version,\n          author: persona.metadata.author,\n          category: persona.metadata.category\n        });\n      }\n    } else {\n      // Show example with sample data\n      exampleIndicator = formatIndicator(this.indicatorConfig, {\n        name: \"Example Persona\",\n        version: \"1.0\",\n        author: \"@username\",\n        category: \"creative\"\n      });\n    }\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}📊 Current Indicator Configuration:\n\nSettings:\n- Enabled: ${this.indicatorConfig.enabled}\n- Style: ${this.indicatorConfig.style}\n- Show Version: ${this.indicatorConfig.showVersion}\n- Show Author: ${this.indicatorConfig.showAuthor}\n- Show Category: ${this.indicatorConfig.showCategory}\n- Emoji: ${this.indicatorConfig.emoji}\n- Brackets: ${this.indicatorConfig.bracketStyle}\n- Separator: \"${this.indicatorConfig.separator}\"\n${this.indicatorConfig.customFormat ? `- Custom Format: ${this.indicatorConfig.customFormat}` : ''}\n\nAvailable styles:\n- full: [🎭 Persona Name v1.0 by @author]\n- minimal: 🎭 Persona Name\n- compact: [Persona Name v1.0]\n- custom: Use your own format with placeholders\n\nExample with current settings: ${exampleIndicator || \"(none - indicators disabled)\"}\n\nPlaceholders for custom format:\n- {emoji} - The configured emoji\n- {name} - Persona name\n- {version} - Persona version\n- {author} - Persona author\n- {category} - Persona category`\n        }\n      ]\n    };\n  }\n\n\n  /**\n   * Export a single persona\n   */\n  async exportPersona(personaName: string) {\n    try {\n      // Use a single lookup to avoid race conditions\n      let persona = this.personas.get(personaName);\n      if (!persona) {\n        // Try by filename\n        persona = Array.from(this.personas.values()).find(p => p.filename === personaName);\n        if (!persona) {\n          return {\n            content: [{\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ Persona not found: ${personaName}`\n            }]\n          };\n        }\n      }\n\n      const exportData = this.personaExporter.exportPersona(persona);\n      const base64 = this.personaExporter.toBase64(exportData);\n      const result = this.personaExporter.formatExportResult(persona, base64);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}${result}`\n        }]\n      };\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Export failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Export all personas\n   */\n  async exportAllPersonas(includeDefaults = true) {\n    try {\n      const personasArray = Array.from(this.personas.values());\n      const bundle = this.personaExporter.exportBundle(personasArray, includeDefaults);\n      const base64 = this.personaExporter.toBase64(bundle);\n      const result = this.personaExporter.formatBundleResult(bundle, base64);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}${result}`\n        }]\n      };\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Export failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Import a persona\n   */\n  async importPersona(source: string, overwrite = false) {\n    try {\n      if (!this.personaImporter) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Import functionality not available (initialization in progress)`\n          }]\n        };\n      }\n      const result = await this.personaImporter.importPersona(source, this.personas, overwrite);\n      \n      if (result.success) {\n        // Reload personas to include the new one\n        await this.loadPersonas();\n        \n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ ${result.message}\\n\\nPersona \"${result.persona?.metadata.name}\" is now available.\\nTotal personas: ${this.personas.size}`\n          }]\n        };\n      } else {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ ${result.message}`\n          }]\n        };\n      }\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Import failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Share a persona via URL\n   */\n  async sharePersona(personaName: string, expiryDays = 7) {\n    try {\n      // Enhanced input validation\n      const validatedPersonaName = MCPInputValidator.validatePersonaIdentifier(personaName);\n      const validatedExpiryDays = MCPInputValidator.validateExpiryDays(expiryDays);\n      \n      const persona = this.personas.get(validatedPersonaName);\n      if (!persona) {\n        // Try by filename\n        const byFilename = Array.from(this.personas.values()).find(p => p.filename === validatedPersonaName);\n        if (!byFilename) {\n          return {\n            content: [{\n              type: \"text\",\n              text: `${this.getPersonaIndicator()}❌ Persona not found: ${validatedPersonaName}`\n            }]\n          };\n        }\n        personaName = byFilename.metadata.name;\n      }\n\n      const result = await this.personaSharer.sharePersona(this.personas.get(personaName)!, validatedExpiryDays);\n      \n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}${result.message}`\n        }]\n      };\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Share failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Import from a shared URL\n   */\n  async importFromUrl(url: string, overwrite = false) {\n    try {\n      // Enhanced input validation for URL\n      const validatedUrl = MCPInputValidator.validateImportUrl(url);\n      \n      const fetchResult = await this.personaSharer.importFromUrl(validatedUrl);\n      \n      if (!fetchResult.success) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ ${fetchResult.message}`\n          }]\n        };\n      }\n\n      // Import the fetched data\n      if (!this.personaImporter) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ Import functionality not available (initialization in progress)`\n          }]\n        };\n      }\n      const importResult = await this.personaImporter.importPersona(\n        JSON.stringify(fetchResult.data),\n        this.personas,\n        overwrite\n      );\n\n      if (importResult.success) {\n        // Reload personas\n        await this.loadPersonas();\n        \n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}✅ Successfully imported from URL!\\n\\n${importResult.message}\\nTotal personas: ${this.personas.size}`\n          }]\n        };\n      } else {\n        return {\n          content: [{\n            type: \"text\",\n            text: `${this.getPersonaIndicator()}❌ ${importResult.message}`\n          }]\n        };\n      }\n    } catch (error) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `${this.getPersonaIndicator()}❌ Import from URL failed: ${SecureErrorHandler.sanitizeError(error).message}`\n        }]\n      };\n    }\n  }\n\n  async run() {\n    const transport = new StdioServerTransport();\n    logger.info(\"Starting DollhouseMCP server...\");\n    \n    // Set up graceful shutdown handlers\n    const cleanup = async () => {\n      logger.info(\"Shutting down DollhouseMCP server...\");\n      \n      try {\n        // Clean up GitHub auth manager\n        if (this.githubAuthManager) {\n          await this.githubAuthManager.cleanup();\n        }\n        \n        // Clean up any other resources\n        if (this.updateManager) {\n          // UpdateManager might have active operations too\n          logger.debug(\"Cleaning up update manager...\");\n        }\n        \n        logger.info(\"Cleanup completed\");\n      } catch (error) {\n        logger.error(\"Error during cleanup\", { error });\n      }\n      \n      process.exit(0);\n    };\n    \n    // Register shutdown handlers\n    process.on('SIGINT', cleanup);\n    process.on('SIGTERM', cleanup);\n    process.on('SIGHUP', cleanup);\n    \n    await this.server.connect(transport);\n    // Mark that MCP is now connected - no more console output allowed\n    logger.setMCPConnected();\n    logger.info(\"DollhouseMCP server running on stdio\");\n  }\n}\n\n// Export is already at class declaration\n\n// Only start the server if this file is being run directly (not imported by tests)\n// Handle different execution methods (direct, npx, CLI)\nconst isDirectExecution = import.meta.url === `file://${process.argv[1]}`;\nconst isNpxExecution = process.env.npm_execpath?.includes('npx');\nconst isCliExecution = process.argv[1]?.endsWith('/dollhousemcp') || process.argv[1]?.endsWith('\\\\dollhousemcp');\nconst isTest = process.env.JEST_WORKER_ID;\n\n// Progressive startup with retries for npx/CLI execution\nconst STARTUP_DELAYS = [10, 50, 100, 200]; // Progressive delays in ms\n\nasync function startServerWithRetry(retriesLeft = STARTUP_DELAYS.length): Promise<void> {\n  try {\n    const server = new DollhouseMCPServer();\n    await server.run();\n  } catch (error) {\n    if (retriesLeft > 0 && (isNpxExecution || isCliExecution)) {\n      // Try again with a longer delay\n      const delayIndex = STARTUP_DELAYS.length - retriesLeft;\n      const delay = STARTUP_DELAYS[delayIndex];\n      await new Promise(resolve => setTimeout(resolve, delay));\n      return startServerWithRetry(retriesLeft - 1);\n    }\n    // Final failure - minimal error message for security\n    console.error(\"[DollhouseMCP] Server startup failed\");\n    process.exit(1);\n  }\n}\n\nif ((isDirectExecution || isNpxExecution || isCliExecution) && !isTest) {\n  startServerWithRetry().catch(() => {\n    console.error(\"[DollhouseMCP] Server startup failed\");\n    process.exit(1);\n  });\n}"]}
|