@dollhousemcp/mcp-server 2.0.17 → 2.0.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (78) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/elements/BaseElement.d.ts +1 -0
  3. package/dist/elements/BaseElement.d.ts.map +1 -1
  4. package/dist/elements/BaseElement.js +7 -1
  5. package/dist/elements/agents/AgentManager.js +2 -2
  6. package/dist/elements/base/ElementFileOperations.js +2 -2
  7. package/dist/elements/ensembles/EnsembleManager.js +3 -3
  8. package/dist/elements/memories/MemoryManager.js +2 -2
  9. package/dist/elements/skills/SkillManager.js +2 -2
  10. package/dist/elements/templates/TemplateManager.js +2 -2
  11. package/dist/generated/version.d.ts +2 -2
  12. package/dist/generated/version.js +3 -3
  13. package/dist/handlers/ElementCRUDHandler.d.ts +30 -0
  14. package/dist/handlers/ElementCRUDHandler.d.ts.map +1 -1
  15. package/dist/handlers/ElementCRUDHandler.js +142 -2
  16. package/dist/handlers/mcp-aql/MCPAQLHandler.d.ts +4 -0
  17. package/dist/handlers/mcp-aql/MCPAQLHandler.d.ts.map +1 -1
  18. package/dist/handlers/mcp-aql/MCPAQLHandler.js +132 -14
  19. package/dist/handlers/mcp-aql/OperationRouter.d.ts.map +1 -1
  20. package/dist/handlers/mcp-aql/OperationRouter.js +6 -1
  21. package/dist/handlers/mcp-aql/OperationSchema.d.ts.map +1 -1
  22. package/dist/handlers/mcp-aql/OperationSchema.js +17 -1
  23. package/dist/handlers/mcp-aql/policies/AgentToolPolicyTranslator.d.ts.map +1 -1
  24. package/dist/handlers/mcp-aql/policies/AgentToolPolicyTranslator.js +2 -1
  25. package/dist/handlers/mcp-aql/policies/ElementPolicies.d.ts +9 -1
  26. package/dist/handlers/mcp-aql/policies/ElementPolicies.d.ts.map +1 -1
  27. package/dist/handlers/mcp-aql/policies/ElementPolicies.js +64 -4
  28. package/dist/handlers/mcp-aql/policies/OperationPolicies.d.ts.map +1 -1
  29. package/dist/handlers/mcp-aql/policies/OperationPolicies.js +6 -1
  30. package/dist/handlers/mcp-aql/policies/ToolClassification.d.ts.map +1 -1
  31. package/dist/handlers/mcp-aql/policies/ToolClassification.js +2 -1
  32. package/dist/handlers/strategies/AgentActivationStrategy.d.ts.map +1 -1
  33. package/dist/handlers/strategies/AgentActivationStrategy.js +5 -1
  34. package/dist/handlers/strategies/BaseActivationStrategy.d.ts +1 -0
  35. package/dist/handlers/strategies/BaseActivationStrategy.d.ts.map +1 -1
  36. package/dist/handlers/strategies/BaseActivationStrategy.js +15 -1
  37. package/dist/handlers/strategies/EnsembleActivationStrategy.d.ts.map +1 -1
  38. package/dist/handlers/strategies/EnsembleActivationStrategy.js +5 -1
  39. package/dist/handlers/strategies/MemoryActivationStrategy.d.ts.map +1 -1
  40. package/dist/handlers/strategies/MemoryActivationStrategy.js +5 -1
  41. package/dist/handlers/strategies/PersonaActivationStrategy.d.ts.map +1 -1
  42. package/dist/handlers/strategies/PersonaActivationStrategy.js +5 -1
  43. package/dist/handlers/strategies/SkillActivationStrategy.d.ts.map +1 -1
  44. package/dist/handlers/strategies/SkillActivationStrategy.js +5 -1
  45. package/dist/handlers/strategies/TemplateActivationStrategy.d.ts.map +1 -1
  46. package/dist/handlers/strategies/TemplateActivationStrategy.js +7 -2
  47. package/dist/persona/PersonaElement.js +2 -2
  48. package/dist/server/tools/MCPAQLTools.js +2 -1
  49. package/dist/services/SerializationService.d.ts.map +1 -1
  50. package/dist/services/SerializationService.js +7 -1
  51. package/dist/types/elements/IElement.d.ts +9 -0
  52. package/dist/types/elements/IElement.d.ts.map +1 -1
  53. package/dist/types/elements/IElement.js +1 -1
  54. package/dist/web/console/IngestRoutes.d.ts +6 -0
  55. package/dist/web/console/IngestRoutes.d.ts.map +1 -1
  56. package/dist/web/console/IngestRoutes.js +38 -9
  57. package/dist/web/console/LeaderElection.d.ts +39 -0
  58. package/dist/web/console/LeaderElection.d.ts.map +1 -1
  59. package/dist/web/console/LeaderElection.js +147 -29
  60. package/dist/web/console/LeaderForwardingSink.d.ts.map +1 -1
  61. package/dist/web/console/LeaderForwardingSink.js +5 -1
  62. package/dist/web/console/PromotionManager.d.ts.map +1 -1
  63. package/dist/web/console/PromotionManager.js +3 -11
  64. package/dist/web/public/app.js +62 -1
  65. package/dist/web/public/index.html +19 -17
  66. package/dist/web/public/permissions.css +190 -2
  67. package/dist/web/public/permissions.js +171 -30
  68. package/dist/web/public/sessions.js +111 -0
  69. package/dist/web/public/setup.js +131 -60
  70. package/dist/web/routes/permissionRoutes.d.ts.map +1 -1
  71. package/dist/web/routes/permissionRoutes.js +77 -5
  72. package/dist/web/routes/setupRoutes.d.ts.map +1 -1
  73. package/dist/web/routes/setupRoutes.js +16 -2
  74. package/dist/web/server.d.ts.map +1 -1
  75. package/dist/web/server.js +12 -10
  76. package/package.json +1 -1
  77. package/scripts/pretooluse-dollhouse.sh +39 -1
  78. package/server.json +2 -2
@@ -17,6 +17,8 @@
17
17
  * @security-audit-suppress DMCP-SEC-006
18
18
  */
19
19
  import { ElementType } from '../portfolio/PortfolioManager.js';
20
+ import os from 'node:os';
21
+ import path from 'node:path';
20
22
  import { logger } from '../utils/logger.js';
21
23
  import { ElementNotFoundError } from '../utils/ErrorHandler.js';
22
24
  import { createElement as createElementCommand } from './element-crud/createElement.js';
@@ -30,6 +32,7 @@ import { SecurityMonitor } from '../security/securityMonitor.js';
30
32
  import { ELEMENT_TYPE_MAP } from '../utils/elementTypeNormalization.js';
31
33
  import { TemplateActivationStrategy, SkillActivationStrategy, AgentActivationStrategy, MemoryActivationStrategy, PersonaActivationStrategy, EnsembleActivationStrategy } from './strategies/index.js';
32
34
  import { formatValidationFailedError } from './element-crud/responseFormatter.js';
35
+ import { findConfirmAdvisoryElements, findConfirmDenyingElement, getGatekeeperDiagnostics, } from './mcp-aql/policies/ElementPolicies.js';
33
36
  export class ElementCRUDHandler {
34
37
  skillManager;
35
38
  templateManager;
@@ -119,7 +122,7 @@ export class ElementCRUDHandler {
119
122
  : '';
120
123
  }
121
124
  hasGatekeeperPolicy(metadata) {
122
- return Boolean(metadata?.['gatekeeper']);
125
+ return Boolean(metadata?.['gatekeeper'] || getGatekeeperDiagnostics(metadata));
123
126
  }
124
127
  toPolicyElementType(type) {
125
128
  const normalizedType = this.normalizeLookupValue(type).toLowerCase();
@@ -466,6 +469,143 @@ export class ElementCRUDHandler {
466
469
  : {}),
467
470
  }));
468
471
  }
472
+ async releaseDeadlock() {
473
+ const activeElements = await this.collectActiveElementsForDeadlockRelief();
474
+ const activePolicyElements = await this.getActiveElementsForPolicy();
475
+ const sandboxingElement = findConfirmDenyingElement(activePolicyElements);
476
+ const advisoryElements = findConfirmAdvisoryElements(activePolicyElements);
477
+ const deactivated = [];
478
+ const failed = [];
479
+ for (const element of activeElements) {
480
+ const strategy = this.strategies.get(element.type);
481
+ if (!strategy) {
482
+ failed.push({
483
+ type: element.type,
484
+ name: element.name,
485
+ error: `No activation strategy registered for type '${element.type}'`,
486
+ });
487
+ continue;
488
+ }
489
+ try {
490
+ await strategy.deactivate(element.name);
491
+ deactivated.push(element);
492
+ }
493
+ catch (error) {
494
+ failed.push({
495
+ type: element.type,
496
+ name: element.name,
497
+ error: error instanceof Error ? error.message : String(error),
498
+ });
499
+ }
500
+ }
501
+ const persistedStateCleared = Boolean(this.activationStore?.isEnabled());
502
+ const snapshotFile = await this.writeDeadlockReliefSnapshot({
503
+ sessionId: this.activationStore?.getSessionId(),
504
+ activeBeforeReset: activeElements,
505
+ deactivated,
506
+ failed,
507
+ likelyDeadlockCause: {
508
+ ...(sandboxingElement ? { sandboxingElement } : {}),
509
+ advisoryElements,
510
+ },
511
+ persistedStateCleared,
512
+ });
513
+ this.activationStore?.clearAll();
514
+ this.policyExportService?.exportPolicies().catch(() => { });
515
+ const failureSummary = failed.length > 0 ? ` with ${failed.length} failure(s)` : '';
516
+ SecurityMonitor.logSecurityEvent({
517
+ type: 'ELEMENT_DEACTIVATED',
518
+ severity: failed.length > 0 ? 'MEDIUM' : 'LOW',
519
+ source: 'ElementCRUDHandler.releaseDeadlock',
520
+ details: `Deadlock relief deactivated ${deactivated.length} element(s)${failureSummary}`,
521
+ additionalData: {
522
+ sessionId: this.activationStore?.getSessionId(),
523
+ activeBeforeReset: activeElements,
524
+ deactivated,
525
+ failed,
526
+ persistedStateCleared,
527
+ likelyDeadlockCause: {
528
+ ...(sandboxingElement ? { sandboxingElement } : {}),
529
+ advisoryElements,
530
+ },
531
+ snapshotFile,
532
+ },
533
+ });
534
+ return {
535
+ ...(this.activationStore?.getSessionId()
536
+ ? { sessionId: this.activationStore.getSessionId() }
537
+ : {}),
538
+ activeBeforeReset: activeElements,
539
+ deactivated,
540
+ failed,
541
+ persistedStateCleared,
542
+ likelyDeadlockCause: {
543
+ ...(sandboxingElement ? { sandboxingElement } : {}),
544
+ advisoryElements,
545
+ },
546
+ ...(snapshotFile ? { snapshotFile } : {}),
547
+ };
548
+ }
549
+ async collectActiveElementsForDeadlockRelief() {
550
+ const activeElements = [];
551
+ const activePersonas = this.personaManager.getActivePersonas();
552
+ activeElements.push(...activePersonas.map((persona) => ({
553
+ type: ElementType.PERSONA,
554
+ name: persona.metadata.name,
555
+ })));
556
+ const activeSkills = await this.skillManager.getActiveSkills();
557
+ activeElements.push(...activeSkills.map((skill) => ({
558
+ type: ElementType.SKILL,
559
+ name: skill.metadata.name,
560
+ })));
561
+ const activeAgents = await this.agentManager.getActiveAgents();
562
+ activeElements.push(...activeAgents.map((agent) => ({
563
+ type: ElementType.AGENT,
564
+ name: agent.metadata.name,
565
+ })));
566
+ const activeMemories = await this.memoryManager.getActiveMemories();
567
+ activeElements.push(...activeMemories.map((memory) => ({
568
+ type: ElementType.MEMORY,
569
+ name: memory.metadata.name,
570
+ })));
571
+ const activeEnsembles = await this.ensembleManager.getActiveEnsembles();
572
+ activeElements.push(...activeEnsembles.map((ensemble) => ({
573
+ type: ElementType.ENSEMBLE,
574
+ name: ensemble.metadata.name,
575
+ })));
576
+ const seen = new Set();
577
+ return activeElements.filter((element) => {
578
+ const key = `${element.type}:${element.name}`;
579
+ if (seen.has(key)) {
580
+ return false;
581
+ }
582
+ seen.add(key);
583
+ return true;
584
+ });
585
+ }
586
+ async writeDeadlockReliefSnapshot(snapshot) {
587
+ const snapshotDir = path.join(os.homedir(), '.dollhouse', 'state', 'deadlock-relief');
588
+ const safeSessionId = (snapshot.sessionId ?? 'session')
589
+ .replaceAll(/[^a-zA-Z0-9_-]/g, '-')
590
+ .slice(0, 64);
591
+ const timestamp = new Date().toISOString().replaceAll(/[:.]/g, '-');
592
+ const snapshotFile = path.join(snapshotDir, `deadlock-relief-${safeSessionId}-${timestamp}.json`);
593
+ try {
594
+ await this.fileOperations.createDirectory(snapshotDir);
595
+ await this.fileOperations.writeFile(snapshotFile, JSON.stringify({
596
+ createdAt: new Date().toISOString(),
597
+ ...snapshot,
598
+ }, null, 2), { source: 'ElementCRUDHandler.releaseDeadlock' });
599
+ return snapshotFile;
600
+ }
601
+ catch (error) {
602
+ logger.warn('Failed to write deadlock relief snapshot', {
603
+ snapshotFile,
604
+ error: error instanceof Error ? error.message : String(error),
605
+ });
606
+ return undefined;
607
+ }
608
+ }
469
609
  async mergePersistedPolicyState(state, addElement, findPersistedElement) {
470
610
  const pending = [];
471
611
  for (const [type, activations] of Object.entries(state.activations)) {
@@ -859,4 +999,4 @@ export class ElementCRUDHandler {
859
999
  };
860
1000
  }
861
1001
  }
862
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ElementCRUDHandler.js","sourceRoot":"","sources":["../../src/handlers/ElementCRUDHandler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ElementCRUDHandler - Handles all generic element CRUD operations\n *\n * Provides create, edit, validate, and delete operations for all element types\n * (personas, skills, templates, agents, memories).\n *\n * Uses dependency injection for all services:\n * - InitializationService for setup tasks\n * - PersonaIndicatorService for persona indicator formatting\n * - Element managers (SkillManager, TemplateManager, AgentManager, MemoryManager)\n * - PersonaManager for persona operations\n * - PortfolioManager for portfolio operations\n *\n * FIX: DMCP-SEC-006 - Security audit suppression\n * This handler delegates all operations to specialized element managers.\n * Audit logging happens in the element managers themselves.\n * @security-audit-suppress DMCP-SEC-006\n */\n\nimport { ElementType, PortfolioManager } from '../portfolio/PortfolioManager.js';\nimport { SkillManager } from '../elements/skills/index.js';\nimport { TemplateManager } from '../elements/templates/TemplateManager.js';\nimport { TemplateRenderer } from '../utils/TemplateRenderer.js';\nimport { AgentManager } from '../elements/agents/AgentManager.js';\nimport { MemoryManager } from '../elements/memories/MemoryManager.js';\nimport { EnsembleManager } from '../elements/ensembles/EnsembleManager.js';\nimport { logger } from '../utils/logger.js';\nimport { ElementNotFoundError } from '../utils/ErrorHandler.js';\nimport { createElement as createElementCommand } from './element-crud/createElement.js';\nimport { deleteElement as deleteElementCommand } from './element-crud/deleteElement.js';\nimport { editElement as editElementCommand } from './element-crud/editElement.js';\nimport { upgradeElement as upgradeElementCommand } from './element-crud/upgradeElement.js';\nimport { listElements as listElementsCommand } from './element-crud/listElements.js';\nimport { findElementFlexibly, sanitizeMetadata as sanitizeMetadataRecord } from './element-crud/helpers.js';\nimport { validateElement as validateElementCommand } from './element-crud/validateElement.js';\nimport { ElementCrudContext } from './element-crud/types.js';\nimport { InitializationService } from '../services/InitializationService.js';\nimport { PersonaIndicatorService } from '../services/PersonaIndicatorService.js';\nimport { PersonaManager } from '../persona/PersonaManager.js';\nimport { SecurityMonitor } from '../security/securityMonitor.js';\nimport { ELEMENT_TYPE_MAP } from '../utils/elementTypeNormalization.js';\nimport type { IFileOperationsService } from '../services/FileOperationsService.js';\nimport type { ElementActivationStrategy, MCPResponse } from './strategies/index.js';\nimport {\n  TemplateActivationStrategy,\n  SkillActivationStrategy,\n  AgentActivationStrategy,\n  MemoryActivationStrategy,\n  PersonaActivationStrategy,\n  EnsembleActivationStrategy\n} from './strategies/index.js';\nimport { ElementQueryService } from '../services/query/ElementQueryService.js';\nimport { ValidationRegistry } from '../services/validation/ValidationRegistry.js';\nimport type { ActivationStore, PersistedActivation, PersistedActivationStateSnapshot } from '../services/ActivationStore.js';\nimport type { BackupService } from '../services/BackupService.js';\nimport type { PolicyExportService } from '../services/PolicyExportService.js';\nimport type { BaseElementManager } from '../elements/base/BaseElementManager.js';\nimport { formatValidationFailedError } from './element-crud/responseFormatter.js';\n\nexport class ElementCRUDHandler {\n  private readonly strategies: Map<string, ElementActivationStrategy>;\n\n  constructor(\n    private readonly skillManager: SkillManager,\n    private readonly templateManager: TemplateManager,\n    private readonly templateRenderer: TemplateRenderer,\n    private readonly agentManager: AgentManager,\n    private readonly memoryManager: MemoryManager,\n    private readonly ensembleManager: EnsembleManager,\n    private readonly personaManager: PersonaManager,\n    private readonly portfolioManager: PortfolioManager,\n    private readonly initService: InitializationService,\n    private readonly indicatorService: PersonaIndicatorService,\n    private readonly fileOperations: IFileOperationsService,\n    private readonly elementQueryService: ElementQueryService,\n    private readonly validationRegistry: ValidationRegistry,\n    private readonly activationStore?: ActivationStore,\n    private readonly backupService?: BackupService,\n    private readonly policyExportService?: PolicyExportService\n  ) {\n    // Initialize strategy map with all element type strategies\n    this.strategies = new Map<string, ElementActivationStrategy>([\n      [ElementType.PERSONA, new PersonaActivationStrategy(personaManager, indicatorService)],\n      [ElementType.SKILL, new SkillActivationStrategy(skillManager)],\n      [ElementType.TEMPLATE, new TemplateActivationStrategy(templateManager)],\n      [ElementType.AGENT, new AgentActivationStrategy(agentManager)],\n      [ElementType.MEMORY, new MemoryActivationStrategy(memoryManager)],\n      [ElementType.ENSEMBLE, new EnsembleActivationStrategy(\n        ensembleManager,\n        portfolioManager,\n        skillManager,\n        templateManager,\n        agentManager,\n        memoryManager,\n        personaManager\n      )]\n    ]);\n  }\n\n  private async ensureInitialized(): Promise<void> {\n    await this.initService.ensureInitialized();\n  }\n\n  private getPersonaIndicator(): string {\n    return this.indicatorService.getPersonaIndicator();\n  }\n\n  private getContext(): ElementCrudContext {\n    return {\n      ensureInitialized: () => this.ensureInitialized(),\n      getPersonaIndicator: () => this.getPersonaIndicator(),\n      skillManager: this.skillManager,\n      templateManager: this.templateManager,\n      templateRenderer: this.templateRenderer,\n      agentManager: this.agentManager,\n      memoryManager: this.memoryManager,\n      ensembleManager: this.ensembleManager,\n      portfolioManager: this.portfolioManager,\n      personaManager: this.personaManager,\n      fileOperations: this.fileOperations,\n      elementQueryService: this.elementQueryService,\n      validationRegistry: this.validationRegistry,\n      backupService: this.backupService,\n    };\n  }\n\n  /**\n   * Find an element by name, supporting both exact display name and filename (slug) matching\n   * Helper method extracted from index.ts:346-379\n   */\n  private async findElementFlexibly(name: string, elementList: any[]): Promise<any> {\n    return findElementFlexibly(name, elementList);\n  }\n\n  /**\n   * Sanitize metadata object to prevent prototype pollution\n   * Helper method extracted from index.ts:390-410\n   */\n  private sanitizeMetadata(metadata: Record<string, any>): Record<string, any> {\n    return sanitizeMetadataRecord(metadata);\n  }\n\n  private normalizeLookupValue(value: unknown): string {\n    return typeof value === 'string'\n      ? value.normalize('NFC').trim()\n      : '';\n  }\n\n  private hasGatekeeperPolicy(metadata: Record<string, unknown> | undefined): boolean {\n    return Boolean(metadata?.['gatekeeper']);\n  }\n\n  private toPolicyElementType(type: string): string {\n    const normalizedType = this.normalizeLookupValue(type).toLowerCase();\n    switch (normalizedType) {\n      case 'personas':\n        return 'persona';\n      case 'skills':\n        return 'skill';\n      case 'agents':\n        return 'agent';\n      case 'memories':\n        return 'memory';\n      case 'ensembles':\n        return 'ensemble';\n      default:\n        return normalizedType;\n    }\n  }\n\n  /**\n   * Create a new element\n   * Extracted from index.ts:1492-1631 (140 lines - exact copy)\n   */\n  async createElement(args: {name: string; type: string; description: string; content?: string; instructions?: string; metadata?: Record<string, any>}) {\n    return createElementCommand(this.getContext(), args);\n  }\n\n  /**\n   * Edit an existing element using GraphQL-aligned nested input objects.\n   *\n   * @example\n   * await handler.editElement({\n   *   name: 'my-skill',\n   *   type: 'skills',\n   *   input: {\n   *     description: 'Updated',\n   *     metadata: { triggers: ['code'] }\n   *   }\n   * });\n   */\n  async editElement(args: {name: string; type: string; input: Record<string, unknown>}) {\n    return editElementCommand(this.getContext(), args);\n  }\n\n  /**\n   * Upgrade element from v1 single-body to v2 dual-field format (instructions + content)\n   */\n  async upgradeElement(args: {name: string; type: string; dry_run?: boolean; instructions_override?: string; content_override?: string}) {\n    return upgradeElementCommand(this.getContext(), args);\n  }\n\n  /**\n   * Validate an element\n   * Extracted from index.ts:1941-2054 (114 lines - exact copy)\n   */\n  async validateElement(args: {name: string; type: string; strict?: boolean}) {\n    return validateElementCommand(this.getContext(), args);\n  }\n\n  /**\n   * Delete an element\n   * Extracted from index.ts:2056-2310 (255 lines - exact copy, split for readability)\n   */\n  async deleteElement(args: {name: string; type: string; deleteData?: boolean}) {\n    return deleteElementCommand(this.getContext(), args);\n  }\n\n  public normalizeElementType(type: string | undefined | null): string {\n    // Issue #501: Guard against null/undefined to match shared utility pattern\n    if (type == null || typeof type !== 'string' || type.trim() === '') {\n      return '';\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    // Use shared normalization map (Issue #433)\n    const normalized = ELEMENT_TYPE_MAP[type.trim().toLowerCase()];\n    if (normalized) {\n      return normalized;\n    }\n\n    // Unknown type - return as-is and let validation handle it\n    return type;\n  }\n\n  async listElements(type: string, options?: import('../services/query/types.js').QueryOptions) {\n    return listElementsCommand(this.getContext(), type, options);\n  }\n\n  /**\n   * Get raw elements array for a given type.\n   * Unlike listElements which returns MCPResponse format, this returns raw element objects.\n   *\n   * @param type - Element type (persona, skill, template, agent, memory, ensemble)\n   * @returns Array of raw element objects\n   */\n  async getElements(type: string): Promise<unknown[]> {\n    await this.ensureInitialized();\n    const normalizedType = this.normalizeElementType(type);\n\n    switch (normalizedType) {\n      case ElementType.PERSONA:\n        return this.personaManager.list();\n      case ElementType.SKILL:\n        return this.skillManager.list();\n      case ElementType.TEMPLATE:\n        return this.templateManager.list();\n      case ElementType.AGENT:\n        return this.agentManager.list();\n      case ElementType.MEMORY:\n        return this.memoryManager.list();\n      case ElementType.ENSEMBLE:\n        return this.ensembleManager.list();\n      default:\n        return [];\n    }\n  }\n\n  async activateElement(name: string, type: string, context?: Record<string, any>) {\n    try {\n      // FIX: DMCP-SEC-006 - Add security audit logging for element activation\n      SecurityMonitor.logSecurityEvent({\n        type: 'ELEMENT_ACTIVATED',\n        severity: 'LOW',\n        source: 'ElementCRUDHandler.activateElement',\n        details: `Element activation requested: ${type}/${name}`,\n        additionalData: { elementType: type, elementName: name, contextProvided: !!context }\n      });\n\n      const normalizedType = this.normalizeElementType(type);\n      const strategy = this.strategies.get(normalizedType);\n\n      if (!strategy) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Unknown element type '${type}'`\n          }]\n        };\n      }\n\n      const result = await strategy.activate(name, context);\n\n      // Issue #598: Persist activation state for session restore\n      if (this.activationStore) {\n        const filename = normalizedType === ElementType.PERSONA\n          ? this.personaManager.findPersona(name)?.filename\n          : undefined;\n        this.activationStore.recordActivation(normalizedType, name, filename);\n      }\n\n      // Issue #762: Export policies to bridge after activation\n      this.policyExportService?.exportPolicies().catch(() => {});\n\n      return result;\n    } catch (error) {\n      logger.error(`Failed to activate element:`, { 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      // Issue #501: When type is omitted, aggregate active elements across all types\n      if (!type || type.trim() === '') {\n        return this.aggregateActiveElements();\n      }\n\n      const normalizedType = this.normalizeElementType(type);\n      const strategy = this.strategies.get(normalizedType);\n\n      if (!strategy) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Unknown element type '${type}'`\n          }]\n        };\n      }\n\n      return await strategy.getActiveElements();\n    } catch (error) {\n      logger.error(`Failed to get active elements:`, { type, error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get active ${type || 'all'}: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Get raw active elements for Gatekeeper policy evaluation.\n   * Returns active personas, skills, and ensembles with their metadata\n   * mapped to the shape expected by the Gatekeeper's ActiveElement interface.\n   *\n   * Issue #452: Provides active element context for enforce() policy checks.\n   */\n  async getActiveElementsForPolicy(): Promise<Array<{ type: string; name: string; metadata: Record<string, unknown> }>> {\n    const result: Array<{ type: string; name: string; metadata: Record<string, unknown> }> = [];\n    const seen = new Set<string>();\n\n    try {\n      // Active personas (sync)\n      const personas = this.personaManager.getActivePersonas();\n      for (const p of personas) {\n        const key = `persona:${p.metadata.name}`;\n        seen.add(key);\n        result.push({\n          type: 'persona',\n          name: p.metadata.name,\n          metadata: p.metadata as unknown as Record<string, unknown>,\n        });\n      }\n    } catch (error) {\n      logger.warn('Failed to gather active personas for policy evaluation', { error });\n    }\n\n    try {\n      // Active skills (async)\n      const skills = await this.skillManager.getActiveSkills();\n      for (const s of skills) {\n        const key = `skill:${s.metadata.name}`;\n        seen.add(key);\n        result.push({\n          type: 'skill',\n          name: s.metadata.name,\n          metadata: s.metadata as unknown as Record<string, unknown>,\n        });\n      }\n    } catch (error) {\n      logger.warn('Failed to gather active skills for policy evaluation', { error });\n    }\n\n    try {\n      // Active agents (async)\n      const agents = await this.agentManager.getActiveAgents();\n      for (const agent of agents) {\n        const key = `agent:${agent.metadata.name}`;\n        seen.add(key);\n        result.push({\n          type: 'agent',\n          name: agent.metadata.name,\n          metadata: agent.metadata as unknown as Record<string, unknown>,\n        });\n      }\n    } catch (error) {\n      logger.warn('Failed to gather active agents for policy evaluation', { error });\n    }\n\n    try {\n      // Active ensembles (async)\n      const ensembles = await this.ensembleManager.getActiveEnsembles();\n      for (const e of ensembles) {\n        const ensembleKey = `ensemble:${e.metadata.name}`;\n        seen.add(ensembleKey);\n        result.push({\n          type: 'ensemble',\n          name: e.metadata.name,\n          metadata: e.metadata as unknown as Record<string, unknown>,\n        });\n\n        // Issue #625 Phase 4: Resolve ensemble member gatekeeper policies\n        const members = (e.metadata as unknown as Record<string, unknown>)?.elements as\n          Array<{ element_name: string; element_type: string }> | undefined;\n        if (Array.isArray(members)) {\n          for (const member of members) {\n            const memberKey = `${member.element_type}:${member.element_name}`;\n            if (seen.has(memberKey)) continue; // Already active individually\n            try {\n              const memberElements = await this.getElements(member.element_type);\n              const found = (memberElements as Array<{ metadata: Record<string, unknown> }>).find(\n                el => (el?.metadata as Record<string, unknown>)?.name === member.element_name\n              );\n              if (found?.metadata && (found.metadata as Record<string, unknown>)?.gatekeeper) {\n                seen.add(memberKey);\n                result.push({\n                  type: member.element_type,\n                  name: member.element_name,\n                  metadata: found.metadata as Record<string, unknown>,\n                });\n              }\n            } catch {\n              // Non-fatal: skip member if element type lookup fails\n            }\n          }\n        }\n      }\n    } catch (error) {\n      logger.warn('Failed to gather active ensembles for policy evaluation', { error });\n    }\n\n    return result;\n  }\n\n  async getPolicyElementsForReport(sessionId?: string): Promise<Array<{\n    type: string;\n    name: string;\n    metadata: Record<string, unknown>;\n    sessionIds?: string[];\n  }>> {\n    const merged = new Map<string, {\n      type: string;\n      name: string;\n      metadata: Record<string, unknown>;\n      sessionIds: Set<string>;\n    }>();\n\n    const addElement = (\n      element: { type: string; name: string; metadata: Record<string, unknown> },\n      sessionIds: string[] = [],\n    ): void => {\n      if (!this.hasGatekeeperPolicy(element.metadata)) {\n        return;\n      }\n\n      const key = `${element.type}:${element.name}`;\n      const existing = merged.get(key);\n      if (existing) {\n        sessionIds.forEach(id => existing.sessionIds.add(id));\n        return;\n      }\n\n      merged.set(key, {\n        type: element.type,\n        name: element.name,\n        metadata: element.metadata,\n        sessionIds: new Set(sessionIds),\n      });\n    };\n\n    const currentSessionId = this.activationStore?.getSessionId();\n    const includeCurrentSession = !sessionId || !currentSessionId || currentSessionId === sessionId;\n\n    if (includeCurrentSession) {\n      for (const activeElement of await this.getActiveElementsForPolicy()) {\n        addElement(activeElement, currentSessionId ? [currentSessionId] : []);\n      }\n    }\n\n    if (this.activationStore?.isEnabled()) {\n      const persistedStates = await this.activationStore.listPersistedActivationStates(sessionId);\n      const catalogs = new Map<string, Array<{ metadata?: Record<string, unknown>; filename?: string }>>();\n\n      const getCatalog = async (type: string) => {\n        const normalizedType = this.normalizeElementType(type);\n        if (!catalogs.has(normalizedType)) {\n          catalogs.set(\n            normalizedType,\n            (await this.getElements(normalizedType)) as Array<{ metadata?: Record<string, unknown>; filename?: string }>,\n          );\n        }\n        return catalogs.get(normalizedType) ?? [];\n      };\n\n      const findPersistedElement = async (\n        type: string,\n        activation: PersistedActivation,\n      ): Promise<{ type: string; name: string; metadata: Record<string, unknown> } | null> => {\n        const catalog = await getCatalog(type);\n        const normalizedName = this.normalizeLookupValue(activation.name);\n        const normalizedFilename = this.normalizeLookupValue(activation.filename);\n\n        const found = catalog.find((element) => {\n          const metadata = element.metadata ?? {};\n          const elementName = this.normalizeLookupValue(metadata['name']);\n          const elementFilename = this.normalizeLookupValue(\n            element.filename ?? metadata['filename'] ?? metadata['sourceFile'],\n          );\n\n          return elementName === normalizedName || (normalizedFilename !== '' && elementFilename === normalizedFilename);\n        });\n\n        if (!found?.metadata || !this.hasGatekeeperPolicy(found.metadata)) {\n          return null;\n        }\n\n        return {\n          type: this.toPolicyElementType(type),\n          name: (found.metadata['name'] as string) ?? activation.name,\n          metadata: found.metadata,\n        };\n      };\n\n      for (const state of persistedStates) {\n        await this.mergePersistedPolicyState(state, addElement, findPersistedElement);\n      }\n    }\n\n    return Array.from(merged.values()).map((entry) => ({\n      type: entry.type,\n      name: entry.name,\n      metadata: entry.metadata,\n      ...(entry.sessionIds.size > 0\n        ? { sessionIds: Array.from(entry.sessionIds).sort((a, b) => a.localeCompare(b)) }\n        : {}),\n    }));\n  }\n\n  private async mergePersistedPolicyState(\n    state: PersistedActivationStateSnapshot,\n    addElement: (element: { type: string; name: string; metadata: Record<string, unknown> }, sessionIds?: string[]) => void,\n    findPersistedElement: (type: string, activation: PersistedActivation) => Promise<{ type: string; name: string; metadata: Record<string, unknown> } | null>,\n  ): Promise<void> {\n    const pending: Promise<void>[] = [];\n\n    for (const [type, activations] of Object.entries(state.activations)) {\n      for (const activation of activations ?? []) {\n        pending.push((async () => {\n          const found = await findPersistedElement(type, activation);\n          if (found) {\n            addElement(found, [state.sessionId]);\n          }\n        })());\n      }\n    }\n\n    if (pending.length === 0) {\n      return;\n    }\n\n    await Promise.allSettled(pending);\n  }\n\n  async deactivateElement(name: string, type: string) {\n    try {\n      SecurityMonitor.logSecurityEvent({\n        type: 'ELEMENT_DEACTIVATED',\n        severity: 'LOW',\n        source: 'ElementCRUDHandler.deactivateElement',\n        details: `Element deactivation requested: ${type}/${name}`,\n        additionalData: { elementType: type, elementName: name }\n      });\n\n      const normalizedType = this.normalizeElementType(type);\n      const strategy = this.strategies.get(normalizedType);\n\n      if (!strategy) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Unknown element type '${type}'`\n          }]\n        };\n      }\n\n      const result = await strategy.deactivate(name);\n\n      // Issue #598: Persist deactivation state for session restore\n      if (this.activationStore) {\n        this.activationStore.recordDeactivation(normalizedType, name);\n      }\n\n      // Issue #762: Export policies to bridge after deactivation\n      this.policyExportService?.exportPolicies().catch(() => {});\n\n      return result;\n    } catch (error) {\n      // Re-throw ElementNotFoundError to propagate to MCP-AQL layer\n      // This ensures operations return success=false instead of success=true with error text\n      // Issue #275: Handlers return success=true for missing elements\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n\n      // Also re-throw validation errors (e.g., missing required parameters)\n      // so they result in success=false instead of success=true with error content\n      if (error instanceof Error && error.message.includes('parameter is required')) {\n        throw error;\n      }\n\n      logger.error(`Failed to deactivate element:`, { 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  /**\n   * Issue #708: Get the element manager for a normalized type.\n   * Used to check invalid element records when an element is \"not found\".\n   */\n  private getManagerForType(normalizedType: string): BaseElementManager<any> | undefined {\n    switch (normalizedType) {\n      case ElementType.PERSONA: return this.personaManager as unknown as BaseElementManager<any>;\n      case ElementType.SKILL: return this.skillManager;\n      case ElementType.TEMPLATE: return this.templateManager;\n      case ElementType.AGENT: return this.agentManager;\n      case ElementType.MEMORY: return this.memoryManager;\n      case ElementType.ENSEMBLE: return this.ensembleManager;\n      default: return undefined;\n    }\n  }\n\n  async getElementDetails(name: string, type: string) {\n    try {\n      const normalizedType = this.normalizeElementType(type);\n      const strategy = this.strategies.get(normalizedType);\n\n      if (!strategy) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Unknown element type '${type}'`\n          }]\n        };\n      }\n\n      return await strategy.getElementDetails(name);\n    } catch (error) {\n      // Issue #708: When element is \"not found\", check if it actually exists\n      // on disk but failed validation. Return a distinct error in that case.\n      if (error instanceof ElementNotFoundError) {\n        const normalizedType = this.normalizeElementType(type);\n        const manager = this.getManagerForType(normalizedType);\n        if (manager && typeof manager.getInvalidElement === 'function') {\n          const invalidRecord = manager.getInvalidElement(name);\n          if (invalidRecord) {\n            return formatValidationFailedError(\n              normalizedType as ElementType,\n              name,\n              invalidRecord.reason,\n              invalidRecord.filePath\n            );\n          }\n        }\n        throw error;\n      }\n\n      logger.error(`Failed to get element details:`, { type, name, error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get ${type} details for '${name}': ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Reload elements of a specific type from the filesystem\n   * Extracted from index.ts:609-679 (exact copy, adapted for handler pattern)\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.personaManager.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        case ElementType.MEMORY: {\n          // Memory manager doesn't have clearCache, just list\n          const memories = await this.memoryManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${memories.length} memories from portfolio`\n            }]\n          };\n        }\n\n        case ElementType.ENSEMBLE: {\n          // Ensemble manager doesn't have clearCache, just list\n          const ensembles = await this.ensembleManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${ensembles.length} ensembles 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  /**\n   * Render a template with variables\n   * Extracted from index.ts:682-701 (exact copy)\n   *\n   * @throws {ElementNotFoundError} When template does not exist\n   * @see Issue #275 - Handlers return success=true for missing elements\n   */\n  async renderTemplate(name: string, variables: Record<string, any>) {\n    // Use the new TemplateRenderer utility for cleaner code and better validation\n    const result = await this.templateRenderer.render(name, variables);\n\n    if (result.success && result.content) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `📄 Rendered template '${name}':\\n\\n${result.content}`\n        }]\n      };\n    } else {\n      // Issue #275: Throw error for missing templates instead of returning content\n      if (result.error?.includes('not found')) {\n        throw new ElementNotFoundError('Template', name);\n      }\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ ${result.error || 'Failed to render template'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Execute an agent with goal parameters\n   * Returns context for LLM to drive the agentic loop\n   */\n  async executeAgent(name: string, parameters: Record<string, any>) {\n    try {\n      const result = await this.agentManager.executeAgent(name, parameters);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\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  /**\n   * Record a step in agent execution\n   */\n  async recordAgentStep(args: {\n    agentName: string;\n    stepDescription: string;\n    outcome: \"success\" | \"failure\" | \"partial\";\n    findings?: string;\n    confidence?: number;\n    nextActionHint?: string;\n    riskScore?: number;\n  }) {\n    try {\n      const result = await this.agentManager.recordAgentStep(args);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n      logger.error(`Failed to record agent step for '${args.agentName}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to record step: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Complete an agent goal\n   */\n  async completeAgentGoal(args: {\n    agentName: string;\n    goalId?: string;\n    outcome: \"success\" | \"failure\" | \"partial\";\n    summary: string;\n  }) {\n    try {\n      const result = await this.agentManager.completeAgentGoal(args);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n      logger.error(`Failed to complete agent goal for '${args.agentName}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to complete goal: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Get agent state\n   */\n  async getAgentState(args: {\n    agentName: string;\n    includeDecisionHistory?: boolean;\n    includeContext?: boolean;\n  }) {\n    try {\n      const result = await this.agentManager.getAgentState(args);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n      logger.error(`Failed to get agent state for '${args.agentName}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get state: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Continue agent execution from previous state\n   */\n  async continueAgentExecution(args: {\n    agentName: string;\n    parameters?: Record<string, any>;\n    previousStepResult?: string;\n  }) {\n    try {\n      const result = await this.agentManager.continueAgentExecution(args);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n      logger.error(`Failed to continue agent execution for '${args.agentName}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to continue execution: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Aggregate active elements across all registered element types.\n   * Issue #501: Called when get_active_elements is invoked without element_type.\n   */\n  private async aggregateActiveElements(): Promise<MCPResponse> {\n    const sections: string[] = [];\n\n    for (const [elementType, strategy] of this.strategies) {\n      try {\n        const result = await strategy.getActiveElements();\n        const text = result.content[0]?.text;\n        if (text) {\n          sections.push(`[${elementType}]\\n${text}`);\n        }\n      } catch (err) {\n        logger.debug(`Failed to get active ${elementType} elements`, { error: err });\n      }\n    }\n\n    return {\n      content: [{\n        type: \"text\",\n        text: sections.length > 0\n          ? sections.join('\\n\\n')\n          : 'No active elements found.'\n      }]\n    };\n  }\n\n}\n"]}
1002
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ElementCRUDHandler.js","sourceRoot":"","sources":["../../src/handlers/ElementCRUDHandler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ElementCRUDHandler - Handles all generic element CRUD operations\n *\n * Provides create, edit, validate, and delete operations for all element types\n * (personas, skills, templates, agents, memories).\n *\n * Uses dependency injection for all services:\n * - InitializationService for setup tasks\n * - PersonaIndicatorService for persona indicator formatting\n * - Element managers (SkillManager, TemplateManager, AgentManager, MemoryManager)\n * - PersonaManager for persona operations\n * - PortfolioManager for portfolio operations\n *\n * FIX: DMCP-SEC-006 - Security audit suppression\n * This handler delegates all operations to specialized element managers.\n * Audit logging happens in the element managers themselves.\n * @security-audit-suppress DMCP-SEC-006\n */\n\nimport { ElementType, PortfolioManager } from '../portfolio/PortfolioManager.js';\nimport os from 'node:os';\nimport path from 'node:path';\nimport { SkillManager } from '../elements/skills/index.js';\nimport { TemplateManager } from '../elements/templates/TemplateManager.js';\nimport { TemplateRenderer } from '../utils/TemplateRenderer.js';\nimport { AgentManager } from '../elements/agents/AgentManager.js';\nimport { MemoryManager } from '../elements/memories/MemoryManager.js';\nimport { EnsembleManager } from '../elements/ensembles/EnsembleManager.js';\nimport { logger } from '../utils/logger.js';\nimport { ElementNotFoundError } from '../utils/ErrorHandler.js';\nimport { createElement as createElementCommand } from './element-crud/createElement.js';\nimport { deleteElement as deleteElementCommand } from './element-crud/deleteElement.js';\nimport { editElement as editElementCommand } from './element-crud/editElement.js';\nimport { upgradeElement as upgradeElementCommand } from './element-crud/upgradeElement.js';\nimport { listElements as listElementsCommand } from './element-crud/listElements.js';\nimport { findElementFlexibly, sanitizeMetadata as sanitizeMetadataRecord } from './element-crud/helpers.js';\nimport { validateElement as validateElementCommand } from './element-crud/validateElement.js';\nimport { ElementCrudContext } from './element-crud/types.js';\nimport { InitializationService } from '../services/InitializationService.js';\nimport { PersonaIndicatorService } from '../services/PersonaIndicatorService.js';\nimport { PersonaManager } from '../persona/PersonaManager.js';\nimport { SecurityMonitor } from '../security/securityMonitor.js';\nimport { ELEMENT_TYPE_MAP } from '../utils/elementTypeNormalization.js';\nimport type { IFileOperationsService } from '../services/FileOperationsService.js';\nimport type { ElementActivationStrategy, MCPResponse } from './strategies/index.js';\nimport {\n  TemplateActivationStrategy,\n  SkillActivationStrategy,\n  AgentActivationStrategy,\n  MemoryActivationStrategy,\n  PersonaActivationStrategy,\n  EnsembleActivationStrategy\n} from './strategies/index.js';\nimport { ElementQueryService } from '../services/query/ElementQueryService.js';\nimport { ValidationRegistry } from '../services/validation/ValidationRegistry.js';\nimport type { ActivationStore, PersistedActivation, PersistedActivationStateSnapshot } from '../services/ActivationStore.js';\nimport type { BackupService } from '../services/BackupService.js';\nimport type { PolicyExportService } from '../services/PolicyExportService.js';\nimport type { BaseElementManager } from '../elements/base/BaseElementManager.js';\nimport { formatValidationFailedError } from './element-crud/responseFormatter.js';\nimport {\n  findConfirmAdvisoryElements,\n  findConfirmDenyingElement,\n  getGatekeeperDiagnostics,\n} from './mcp-aql/policies/ElementPolicies.js';\n\nexport class ElementCRUDHandler {\n  private readonly strategies: Map<string, ElementActivationStrategy>;\n\n  constructor(\n    private readonly skillManager: SkillManager,\n    private readonly templateManager: TemplateManager,\n    private readonly templateRenderer: TemplateRenderer,\n    private readonly agentManager: AgentManager,\n    private readonly memoryManager: MemoryManager,\n    private readonly ensembleManager: EnsembleManager,\n    private readonly personaManager: PersonaManager,\n    private readonly portfolioManager: PortfolioManager,\n    private readonly initService: InitializationService,\n    private readonly indicatorService: PersonaIndicatorService,\n    private readonly fileOperations: IFileOperationsService,\n    private readonly elementQueryService: ElementQueryService,\n    private readonly validationRegistry: ValidationRegistry,\n    private readonly activationStore?: ActivationStore,\n    private readonly backupService?: BackupService,\n    private readonly policyExportService?: PolicyExportService\n  ) {\n    // Initialize strategy map with all element type strategies\n    this.strategies = new Map<string, ElementActivationStrategy>([\n      [ElementType.PERSONA, new PersonaActivationStrategy(personaManager, indicatorService)],\n      [ElementType.SKILL, new SkillActivationStrategy(skillManager)],\n      [ElementType.TEMPLATE, new TemplateActivationStrategy(templateManager)],\n      [ElementType.AGENT, new AgentActivationStrategy(agentManager)],\n      [ElementType.MEMORY, new MemoryActivationStrategy(memoryManager)],\n      [ElementType.ENSEMBLE, new EnsembleActivationStrategy(\n        ensembleManager,\n        portfolioManager,\n        skillManager,\n        templateManager,\n        agentManager,\n        memoryManager,\n        personaManager\n      )]\n    ]);\n  }\n\n  private async ensureInitialized(): Promise<void> {\n    await this.initService.ensureInitialized();\n  }\n\n  private getPersonaIndicator(): string {\n    return this.indicatorService.getPersonaIndicator();\n  }\n\n  private getContext(): ElementCrudContext {\n    return {\n      ensureInitialized: () => this.ensureInitialized(),\n      getPersonaIndicator: () => this.getPersonaIndicator(),\n      skillManager: this.skillManager,\n      templateManager: this.templateManager,\n      templateRenderer: this.templateRenderer,\n      agentManager: this.agentManager,\n      memoryManager: this.memoryManager,\n      ensembleManager: this.ensembleManager,\n      portfolioManager: this.portfolioManager,\n      personaManager: this.personaManager,\n      fileOperations: this.fileOperations,\n      elementQueryService: this.elementQueryService,\n      validationRegistry: this.validationRegistry,\n      backupService: this.backupService,\n    };\n  }\n\n  /**\n   * Find an element by name, supporting both exact display name and filename (slug) matching\n   * Helper method extracted from index.ts:346-379\n   */\n  private async findElementFlexibly(name: string, elementList: any[]): Promise<any> {\n    return findElementFlexibly(name, elementList);\n  }\n\n  /**\n   * Sanitize metadata object to prevent prototype pollution\n   * Helper method extracted from index.ts:390-410\n   */\n  private sanitizeMetadata(metadata: Record<string, any>): Record<string, any> {\n    return sanitizeMetadataRecord(metadata);\n  }\n\n  private normalizeLookupValue(value: unknown): string {\n    return typeof value === 'string'\n      ? value.normalize('NFC').trim()\n      : '';\n  }\n\n  private hasGatekeeperPolicy(metadata: Record<string, unknown> | undefined): boolean {\n    return Boolean(metadata?.['gatekeeper'] || getGatekeeperDiagnostics(metadata));\n  }\n\n  private toPolicyElementType(type: string): string {\n    const normalizedType = this.normalizeLookupValue(type).toLowerCase();\n    switch (normalizedType) {\n      case 'personas':\n        return 'persona';\n      case 'skills':\n        return 'skill';\n      case 'agents':\n        return 'agent';\n      case 'memories':\n        return 'memory';\n      case 'ensembles':\n        return 'ensemble';\n      default:\n        return normalizedType;\n    }\n  }\n\n  /**\n   * Create a new element\n   * Extracted from index.ts:1492-1631 (140 lines - exact copy)\n   */\n  async createElement(args: {name: string; type: string; description: string; content?: string; instructions?: string; metadata?: Record<string, any>}) {\n    return createElementCommand(this.getContext(), args);\n  }\n\n  /**\n   * Edit an existing element using GraphQL-aligned nested input objects.\n   *\n   * @example\n   * await handler.editElement({\n   *   name: 'my-skill',\n   *   type: 'skills',\n   *   input: {\n   *     description: 'Updated',\n   *     metadata: { triggers: ['code'] }\n   *   }\n   * });\n   */\n  async editElement(args: {name: string; type: string; input: Record<string, unknown>}) {\n    return editElementCommand(this.getContext(), args);\n  }\n\n  /**\n   * Upgrade element from v1 single-body to v2 dual-field format (instructions + content)\n   */\n  async upgradeElement(args: {name: string; type: string; dry_run?: boolean; instructions_override?: string; content_override?: string}) {\n    return upgradeElementCommand(this.getContext(), args);\n  }\n\n  /**\n   * Validate an element\n   * Extracted from index.ts:1941-2054 (114 lines - exact copy)\n   */\n  async validateElement(args: {name: string; type: string; strict?: boolean}) {\n    return validateElementCommand(this.getContext(), args);\n  }\n\n  /**\n   * Delete an element\n   * Extracted from index.ts:2056-2310 (255 lines - exact copy, split for readability)\n   */\n  async deleteElement(args: {name: string; type: string; deleteData?: boolean}) {\n    return deleteElementCommand(this.getContext(), args);\n  }\n\n  public normalizeElementType(type: string | undefined | null): string {\n    // Issue #501: Guard against null/undefined to match shared utility pattern\n    if (type == null || typeof type !== 'string' || type.trim() === '') {\n      return '';\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    // Use shared normalization map (Issue #433)\n    const normalized = ELEMENT_TYPE_MAP[type.trim().toLowerCase()];\n    if (normalized) {\n      return normalized;\n    }\n\n    // Unknown type - return as-is and let validation handle it\n    return type;\n  }\n\n  async listElements(type: string, options?: import('../services/query/types.js').QueryOptions) {\n    return listElementsCommand(this.getContext(), type, options);\n  }\n\n  /**\n   * Get raw elements array for a given type.\n   * Unlike listElements which returns MCPResponse format, this returns raw element objects.\n   *\n   * @param type - Element type (persona, skill, template, agent, memory, ensemble)\n   * @returns Array of raw element objects\n   */\n  async getElements(type: string): Promise<unknown[]> {\n    await this.ensureInitialized();\n    const normalizedType = this.normalizeElementType(type);\n\n    switch (normalizedType) {\n      case ElementType.PERSONA:\n        return this.personaManager.list();\n      case ElementType.SKILL:\n        return this.skillManager.list();\n      case ElementType.TEMPLATE:\n        return this.templateManager.list();\n      case ElementType.AGENT:\n        return this.agentManager.list();\n      case ElementType.MEMORY:\n        return this.memoryManager.list();\n      case ElementType.ENSEMBLE:\n        return this.ensembleManager.list();\n      default:\n        return [];\n    }\n  }\n\n  async activateElement(name: string, type: string, context?: Record<string, any>) {\n    try {\n      // FIX: DMCP-SEC-006 - Add security audit logging for element activation\n      SecurityMonitor.logSecurityEvent({\n        type: 'ELEMENT_ACTIVATED',\n        severity: 'LOW',\n        source: 'ElementCRUDHandler.activateElement',\n        details: `Element activation requested: ${type}/${name}`,\n        additionalData: { elementType: type, elementName: name, contextProvided: !!context }\n      });\n\n      const normalizedType = this.normalizeElementType(type);\n      const strategy = this.strategies.get(normalizedType);\n\n      if (!strategy) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Unknown element type '${type}'`\n          }]\n        };\n      }\n\n      const result = await strategy.activate(name, context);\n\n      // Issue #598: Persist activation state for session restore\n      if (this.activationStore) {\n        const filename = normalizedType === ElementType.PERSONA\n          ? this.personaManager.findPersona(name)?.filename\n          : undefined;\n        this.activationStore.recordActivation(normalizedType, name, filename);\n      }\n\n      // Issue #762: Export policies to bridge after activation\n      this.policyExportService?.exportPolicies().catch(() => {});\n\n      return result;\n    } catch (error) {\n      logger.error(`Failed to activate element:`, { 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      // Issue #501: When type is omitted, aggregate active elements across all types\n      if (!type || type.trim() === '') {\n        return this.aggregateActiveElements();\n      }\n\n      const normalizedType = this.normalizeElementType(type);\n      const strategy = this.strategies.get(normalizedType);\n\n      if (!strategy) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Unknown element type '${type}'`\n          }]\n        };\n      }\n\n      return await strategy.getActiveElements();\n    } catch (error) {\n      logger.error(`Failed to get active elements:`, { type, error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get active ${type || 'all'}: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Get raw active elements for Gatekeeper policy evaluation.\n   * Returns active personas, skills, and ensembles with their metadata\n   * mapped to the shape expected by the Gatekeeper's ActiveElement interface.\n   *\n   * Issue #452: Provides active element context for enforce() policy checks.\n   */\n  async getActiveElementsForPolicy(): Promise<Array<{ type: string; name: string; metadata: Record<string, unknown> }>> {\n    const result: Array<{ type: string; name: string; metadata: Record<string, unknown> }> = [];\n    const seen = new Set<string>();\n\n    try {\n      // Active personas (sync)\n      const personas = this.personaManager.getActivePersonas();\n      for (const p of personas) {\n        const key = `persona:${p.metadata.name}`;\n        seen.add(key);\n        result.push({\n          type: 'persona',\n          name: p.metadata.name,\n          metadata: p.metadata as unknown as Record<string, unknown>,\n        });\n      }\n    } catch (error) {\n      logger.warn('Failed to gather active personas for policy evaluation', { error });\n    }\n\n    try {\n      // Active skills (async)\n      const skills = await this.skillManager.getActiveSkills();\n      for (const s of skills) {\n        const key = `skill:${s.metadata.name}`;\n        seen.add(key);\n        result.push({\n          type: 'skill',\n          name: s.metadata.name,\n          metadata: s.metadata as unknown as Record<string, unknown>,\n        });\n      }\n    } catch (error) {\n      logger.warn('Failed to gather active skills for policy evaluation', { error });\n    }\n\n    try {\n      // Active agents (async)\n      const agents = await this.agentManager.getActiveAgents();\n      for (const agent of agents) {\n        const key = `agent:${agent.metadata.name}`;\n        seen.add(key);\n        result.push({\n          type: 'agent',\n          name: agent.metadata.name,\n          metadata: agent.metadata as unknown as Record<string, unknown>,\n        });\n      }\n    } catch (error) {\n      logger.warn('Failed to gather active agents for policy evaluation', { error });\n    }\n\n    try {\n      // Active ensembles (async)\n      const ensembles = await this.ensembleManager.getActiveEnsembles();\n      for (const e of ensembles) {\n        const ensembleKey = `ensemble:${e.metadata.name}`;\n        seen.add(ensembleKey);\n        result.push({\n          type: 'ensemble',\n          name: e.metadata.name,\n          metadata: e.metadata as unknown as Record<string, unknown>,\n        });\n\n        // Issue #625 Phase 4: Resolve ensemble member gatekeeper policies\n        const members = (e.metadata as unknown as Record<string, unknown>)?.elements as\n          Array<{ element_name: string; element_type: string }> | undefined;\n        if (Array.isArray(members)) {\n          for (const member of members) {\n            const memberKey = `${member.element_type}:${member.element_name}`;\n            if (seen.has(memberKey)) continue; // Already active individually\n            try {\n              const memberElements = await this.getElements(member.element_type);\n              const found = (memberElements as Array<{ metadata: Record<string, unknown> }>).find(\n                el => (el?.metadata as Record<string, unknown>)?.name === member.element_name\n              );\n              if (found?.metadata && (found.metadata as Record<string, unknown>)?.gatekeeper) {\n                seen.add(memberKey);\n                result.push({\n                  type: member.element_type,\n                  name: member.element_name,\n                  metadata: found.metadata as Record<string, unknown>,\n                });\n              }\n            } catch {\n              // Non-fatal: skip member if element type lookup fails\n            }\n          }\n        }\n      }\n    } catch (error) {\n      logger.warn('Failed to gather active ensembles for policy evaluation', { error });\n    }\n\n    return result;\n  }\n\n  async getPolicyElementsForReport(sessionId?: string): Promise<Array<{\n    type: string;\n    name: string;\n    metadata: Record<string, unknown>;\n    sessionIds?: string[];\n  }>> {\n    const merged = new Map<string, {\n      type: string;\n      name: string;\n      metadata: Record<string, unknown>;\n      sessionIds: Set<string>;\n    }>();\n\n    const addElement = (\n      element: { type: string; name: string; metadata: Record<string, unknown> },\n      sessionIds: string[] = [],\n    ): void => {\n      if (!this.hasGatekeeperPolicy(element.metadata)) {\n        return;\n      }\n\n      const key = `${element.type}:${element.name}`;\n      const existing = merged.get(key);\n      if (existing) {\n        sessionIds.forEach(id => existing.sessionIds.add(id));\n        return;\n      }\n\n      merged.set(key, {\n        type: element.type,\n        name: element.name,\n        metadata: element.metadata,\n        sessionIds: new Set(sessionIds),\n      });\n    };\n\n    const currentSessionId = this.activationStore?.getSessionId();\n    const includeCurrentSession = !sessionId || !currentSessionId || currentSessionId === sessionId;\n\n    if (includeCurrentSession) {\n      for (const activeElement of await this.getActiveElementsForPolicy()) {\n        addElement(activeElement, currentSessionId ? [currentSessionId] : []);\n      }\n    }\n\n    if (this.activationStore?.isEnabled()) {\n      const persistedStates = await this.activationStore.listPersistedActivationStates(sessionId);\n      const catalogs = new Map<string, Array<{ metadata?: Record<string, unknown>; filename?: string }>>();\n\n      const getCatalog = async (type: string) => {\n        const normalizedType = this.normalizeElementType(type);\n        if (!catalogs.has(normalizedType)) {\n          catalogs.set(\n            normalizedType,\n            (await this.getElements(normalizedType)) as Array<{ metadata?: Record<string, unknown>; filename?: string }>,\n          );\n        }\n        return catalogs.get(normalizedType) ?? [];\n      };\n\n      const findPersistedElement = async (\n        type: string,\n        activation: PersistedActivation,\n      ): Promise<{ type: string; name: string; metadata: Record<string, unknown> } | null> => {\n        const catalog = await getCatalog(type);\n        const normalizedName = this.normalizeLookupValue(activation.name);\n        const normalizedFilename = this.normalizeLookupValue(activation.filename);\n\n        const found = catalog.find((element) => {\n          const metadata = element.metadata ?? {};\n          const elementName = this.normalizeLookupValue(metadata['name']);\n          const elementFilename = this.normalizeLookupValue(\n            element.filename ?? metadata['filename'] ?? metadata['sourceFile'],\n          );\n\n          return elementName === normalizedName || (normalizedFilename !== '' && elementFilename === normalizedFilename);\n        });\n\n        if (!found?.metadata || !this.hasGatekeeperPolicy(found.metadata)) {\n          return null;\n        }\n\n        return {\n          type: this.toPolicyElementType(type),\n          name: (found.metadata['name'] as string) ?? activation.name,\n          metadata: found.metadata,\n        };\n      };\n\n      for (const state of persistedStates) {\n        await this.mergePersistedPolicyState(state, addElement, findPersistedElement);\n      }\n    }\n\n    return Array.from(merged.values()).map((entry) => ({\n      type: entry.type,\n      name: entry.name,\n      metadata: entry.metadata,\n      ...(entry.sessionIds.size > 0\n        ? { sessionIds: Array.from(entry.sessionIds).sort((a, b) => a.localeCompare(b)) }\n        : {}),\n    }));\n  }\n\n  async releaseDeadlock(): Promise<{\n    sessionId?: string;\n    activeBeforeReset: Array<{ type: string; name: string }>;\n    deactivated: Array<{ type: string; name: string }>;\n    failed: Array<{ type: string; name: string; error: string }>;\n    persistedStateCleared: boolean;\n    likelyDeadlockCause: {\n      sandboxingElement?: { type: string; name: string };\n      advisoryElements: Array<{ type: string; name: string }>;\n    };\n    snapshotFile?: string;\n  }> {\n    const activeElements = await this.collectActiveElementsForDeadlockRelief();\n    const activePolicyElements = await this.getActiveElementsForPolicy();\n    const sandboxingElement = findConfirmDenyingElement(activePolicyElements);\n    const advisoryElements = findConfirmAdvisoryElements(activePolicyElements);\n    const deactivated: Array<{ type: string; name: string }> = [];\n    const failed: Array<{ type: string; name: string; error: string }> = [];\n\n    for (const element of activeElements) {\n      const strategy = this.strategies.get(element.type);\n      if (!strategy) {\n        failed.push({\n          type: element.type,\n          name: element.name,\n          error: `No activation strategy registered for type '${element.type}'`,\n        });\n        continue;\n      }\n\n      try {\n        await strategy.deactivate(element.name);\n        deactivated.push(element);\n      } catch (error) {\n        failed.push({\n          type: element.type,\n          name: element.name,\n          error: error instanceof Error ? error.message : String(error),\n        });\n      }\n    }\n\n    const persistedStateCleared = Boolean(this.activationStore?.isEnabled());\n    const snapshotFile = await this.writeDeadlockReliefSnapshot({\n      sessionId: this.activationStore?.getSessionId(),\n      activeBeforeReset: activeElements,\n      deactivated,\n      failed,\n      likelyDeadlockCause: {\n        ...(sandboxingElement ? { sandboxingElement } : {}),\n        advisoryElements,\n      },\n      persistedStateCleared,\n    });\n\n    this.activationStore?.clearAll();\n    this.policyExportService?.exportPolicies().catch(() => {});\n\n    const failureSummary = failed.length > 0 ? ` with ${failed.length} failure(s)` : '';\n\n    SecurityMonitor.logSecurityEvent({\n      type: 'ELEMENT_DEACTIVATED',\n      severity: failed.length > 0 ? 'MEDIUM' : 'LOW',\n      source: 'ElementCRUDHandler.releaseDeadlock',\n      details: `Deadlock relief deactivated ${deactivated.length} element(s)${failureSummary}`,\n      additionalData: {\n        sessionId: this.activationStore?.getSessionId(),\n        activeBeforeReset: activeElements,\n        deactivated,\n        failed,\n        persistedStateCleared,\n        likelyDeadlockCause: {\n          ...(sandboxingElement ? { sandboxingElement } : {}),\n          advisoryElements,\n        },\n        snapshotFile,\n      },\n    });\n\n    return {\n      ...(this.activationStore?.getSessionId()\n        ? { sessionId: this.activationStore.getSessionId() }\n        : {}),\n      activeBeforeReset: activeElements,\n      deactivated,\n      failed,\n      persistedStateCleared,\n      likelyDeadlockCause: {\n        ...(sandboxingElement ? { sandboxingElement } : {}),\n        advisoryElements,\n      },\n      ...(snapshotFile ? { snapshotFile } : {}),\n    };\n  }\n\n  private async collectActiveElementsForDeadlockRelief(): Promise<Array<{ type: string; name: string }>> {\n    const activeElements: Array<{ type: string; name: string }> = [];\n\n    const activePersonas = this.personaManager.getActivePersonas();\n    activeElements.push(...activePersonas.map((persona) => ({\n      type: ElementType.PERSONA,\n      name: persona.metadata.name,\n    })));\n\n    const activeSkills = await this.skillManager.getActiveSkills();\n    activeElements.push(...activeSkills.map((skill) => ({\n      type: ElementType.SKILL,\n      name: skill.metadata.name,\n    })));\n\n    const activeAgents = await this.agentManager.getActiveAgents();\n    activeElements.push(...activeAgents.map((agent) => ({\n      type: ElementType.AGENT,\n      name: agent.metadata.name,\n    })));\n\n    const activeMemories = await this.memoryManager.getActiveMemories();\n    activeElements.push(...activeMemories.map((memory) => ({\n      type: ElementType.MEMORY,\n      name: memory.metadata.name,\n    })));\n\n    const activeEnsembles = await this.ensembleManager.getActiveEnsembles();\n    activeElements.push(...activeEnsembles.map((ensemble) => ({\n      type: ElementType.ENSEMBLE,\n      name: ensemble.metadata.name,\n    })));\n\n    const seen = new Set<string>();\n    return activeElements.filter((element) => {\n      const key = `${element.type}:${element.name}`;\n      if (seen.has(key)) {\n        return false;\n      }\n      seen.add(key);\n      return true;\n    });\n  }\n\n  private async writeDeadlockReliefSnapshot(snapshot: {\n    sessionId?: string;\n    activeBeforeReset: Array<{ type: string; name: string }>;\n    deactivated: Array<{ type: string; name: string }>;\n    failed: Array<{ type: string; name: string; error: string }>;\n    likelyDeadlockCause: {\n      sandboxingElement?: { type: string; name: string };\n      advisoryElements: Array<{ type: string; name: string }>;\n    };\n    persistedStateCleared: boolean;\n  }): Promise<string | undefined> {\n    const snapshotDir = path.join(os.homedir(), '.dollhouse', 'state', 'deadlock-relief');\n    const safeSessionId = (snapshot.sessionId ?? 'session')\n      .replaceAll(/[^a-zA-Z0-9_-]/g, '-')\n      .slice(0, 64);\n    const timestamp = new Date().toISOString().replaceAll(/[:.]/g, '-');\n    const snapshotFile = path.join(snapshotDir, `deadlock-relief-${safeSessionId}-${timestamp}.json`);\n\n    try {\n      await this.fileOperations.createDirectory(snapshotDir);\n      await this.fileOperations.writeFile(\n        snapshotFile,\n        JSON.stringify({\n          createdAt: new Date().toISOString(),\n          ...snapshot,\n        }, null, 2),\n        { source: 'ElementCRUDHandler.releaseDeadlock' },\n      );\n      return snapshotFile;\n    } catch (error) {\n      logger.warn('Failed to write deadlock relief snapshot', {\n        snapshotFile,\n        error: error instanceof Error ? error.message : String(error),\n      });\n      return undefined;\n    }\n  }\n\n  private async mergePersistedPolicyState(\n    state: PersistedActivationStateSnapshot,\n    addElement: (element: { type: string; name: string; metadata: Record<string, unknown> }, sessionIds?: string[]) => void,\n    findPersistedElement: (type: string, activation: PersistedActivation) => Promise<{ type: string; name: string; metadata: Record<string, unknown> } | null>,\n  ): Promise<void> {\n    const pending: Promise<void>[] = [];\n\n    for (const [type, activations] of Object.entries(state.activations)) {\n      for (const activation of activations ?? []) {\n        pending.push((async () => {\n          const found = await findPersistedElement(type, activation);\n          if (found) {\n            addElement(found, [state.sessionId]);\n          }\n        })());\n      }\n    }\n\n    if (pending.length === 0) {\n      return;\n    }\n\n    await Promise.allSettled(pending);\n  }\n\n  async deactivateElement(name: string, type: string) {\n    try {\n      SecurityMonitor.logSecurityEvent({\n        type: 'ELEMENT_DEACTIVATED',\n        severity: 'LOW',\n        source: 'ElementCRUDHandler.deactivateElement',\n        details: `Element deactivation requested: ${type}/${name}`,\n        additionalData: { elementType: type, elementName: name }\n      });\n\n      const normalizedType = this.normalizeElementType(type);\n      const strategy = this.strategies.get(normalizedType);\n\n      if (!strategy) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Unknown element type '${type}'`\n          }]\n        };\n      }\n\n      const result = await strategy.deactivate(name);\n\n      // Issue #598: Persist deactivation state for session restore\n      if (this.activationStore) {\n        this.activationStore.recordDeactivation(normalizedType, name);\n      }\n\n      // Issue #762: Export policies to bridge after deactivation\n      this.policyExportService?.exportPolicies().catch(() => {});\n\n      return result;\n    } catch (error) {\n      // Re-throw ElementNotFoundError to propagate to MCP-AQL layer\n      // This ensures operations return success=false instead of success=true with error text\n      // Issue #275: Handlers return success=true for missing elements\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n\n      // Also re-throw validation errors (e.g., missing required parameters)\n      // so they result in success=false instead of success=true with error content\n      if (error instanceof Error && error.message.includes('parameter is required')) {\n        throw error;\n      }\n\n      logger.error(`Failed to deactivate element:`, { 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  /**\n   * Issue #708: Get the element manager for a normalized type.\n   * Used to check invalid element records when an element is \"not found\".\n   */\n  private getManagerForType(normalizedType: string): BaseElementManager<any> | undefined {\n    switch (normalizedType) {\n      case ElementType.PERSONA: return this.personaManager as unknown as BaseElementManager<any>;\n      case ElementType.SKILL: return this.skillManager;\n      case ElementType.TEMPLATE: return this.templateManager;\n      case ElementType.AGENT: return this.agentManager;\n      case ElementType.MEMORY: return this.memoryManager;\n      case ElementType.ENSEMBLE: return this.ensembleManager;\n      default: return undefined;\n    }\n  }\n\n  async getElementDetails(name: string, type: string) {\n    try {\n      const normalizedType = this.normalizeElementType(type);\n      const strategy = this.strategies.get(normalizedType);\n\n      if (!strategy) {\n        return {\n          content: [{\n            type: \"text\",\n            text: `❌ Unknown element type '${type}'`\n          }]\n        };\n      }\n\n      return await strategy.getElementDetails(name);\n    } catch (error) {\n      // Issue #708: When element is \"not found\", check if it actually exists\n      // on disk but failed validation. Return a distinct error in that case.\n      if (error instanceof ElementNotFoundError) {\n        const normalizedType = this.normalizeElementType(type);\n        const manager = this.getManagerForType(normalizedType);\n        if (manager && typeof manager.getInvalidElement === 'function') {\n          const invalidRecord = manager.getInvalidElement(name);\n          if (invalidRecord) {\n            return formatValidationFailedError(\n              normalizedType as ElementType,\n              name,\n              invalidRecord.reason,\n              invalidRecord.filePath\n            );\n          }\n        }\n        throw error;\n      }\n\n      logger.error(`Failed to get element details:`, { type, name, error });\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get ${type} details for '${name}': ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Reload elements of a specific type from the filesystem\n   * Extracted from index.ts:609-679 (exact copy, adapted for handler pattern)\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.personaManager.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        case ElementType.MEMORY: {\n          // Memory manager doesn't have clearCache, just list\n          const memories = await this.memoryManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${memories.length} memories from portfolio`\n            }]\n          };\n        }\n\n        case ElementType.ENSEMBLE: {\n          // Ensemble manager doesn't have clearCache, just list\n          const ensembles = await this.ensembleManager.list();\n          return {\n            content: [{\n              type: \"text\",\n              text: `🔄 Reloaded ${ensembles.length} ensembles 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  /**\n   * Render a template with variables\n   * Extracted from index.ts:682-701 (exact copy)\n   *\n   * @throws {ElementNotFoundError} When template does not exist\n   * @see Issue #275 - Handlers return success=true for missing elements\n   */\n  async renderTemplate(name: string, variables: Record<string, any>) {\n    // Use the new TemplateRenderer utility for cleaner code and better validation\n    const result = await this.templateRenderer.render(name, variables);\n\n    if (result.success && result.content) {\n      return {\n        content: [{\n          type: \"text\",\n          text: `📄 Rendered template '${name}':\\n\\n${result.content}`\n        }]\n      };\n    } else {\n      // Issue #275: Throw error for missing templates instead of returning content\n      if (result.error?.includes('not found')) {\n        throw new ElementNotFoundError('Template', name);\n      }\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ ${result.error || 'Failed to render template'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Execute an agent with goal parameters\n   * Returns context for LLM to drive the agentic loop\n   */\n  async executeAgent(name: string, parameters: Record<string, any>) {\n    try {\n      const result = await this.agentManager.executeAgent(name, parameters);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\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  /**\n   * Record a step in agent execution\n   */\n  async recordAgentStep(args: {\n    agentName: string;\n    stepDescription: string;\n    outcome: \"success\" | \"failure\" | \"partial\";\n    findings?: string;\n    confidence?: number;\n    nextActionHint?: string;\n    riskScore?: number;\n  }) {\n    try {\n      const result = await this.agentManager.recordAgentStep(args);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n      logger.error(`Failed to record agent step for '${args.agentName}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to record step: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Complete an agent goal\n   */\n  async completeAgentGoal(args: {\n    agentName: string;\n    goalId?: string;\n    outcome: \"success\" | \"failure\" | \"partial\";\n    summary: string;\n  }) {\n    try {\n      const result = await this.agentManager.completeAgentGoal(args);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n      logger.error(`Failed to complete agent goal for '${args.agentName}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to complete goal: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Get agent state\n   */\n  async getAgentState(args: {\n    agentName: string;\n    includeDecisionHistory?: boolean;\n    includeContext?: boolean;\n  }) {\n    try {\n      const result = await this.agentManager.getAgentState(args);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n      logger.error(`Failed to get agent state for '${args.agentName}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to get state: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Continue agent execution from previous state\n   */\n  async continueAgentExecution(args: {\n    agentName: string;\n    parameters?: Record<string, any>;\n    previousStepResult?: string;\n  }) {\n    try {\n      const result = await this.agentManager.continueAgentExecution(args);\n\n      return {\n        content: [{\n          type: \"text\",\n          text: JSON.stringify(result, null, 2)\n        }]\n      };\n    } catch (error) {\n      // FIX: Issue #275 - Re-throw ElementNotFoundError for consistent error handling\n      if (error instanceof ElementNotFoundError) {\n        throw error;\n      }\n      logger.error(`Failed to continue agent execution for '${args.agentName}':`, error);\n      return {\n        content: [{\n          type: \"text\",\n          text: `❌ Failed to continue execution: ${error instanceof Error ? error.message : 'Unknown error'}`\n        }]\n      };\n    }\n  }\n\n  /**\n   * Aggregate active elements across all registered element types.\n   * Issue #501: Called when get_active_elements is invoked without element_type.\n   */\n  private async aggregateActiveElements(): Promise<MCPResponse> {\n    const sections: string[] = [];\n\n    for (const [elementType, strategy] of this.strategies) {\n      try {\n        const result = await strategy.getActiveElements();\n        const text = result.content[0]?.text;\n        if (text) {\n          sections.push(`[${elementType}]\\n${text}`);\n        }\n      } catch (err) {\n        logger.debug(`Failed to get active ${elementType} elements`, { error: err });\n      }\n    }\n\n    return {\n      content: [{\n        type: \"text\",\n        text: sections.length > 0\n          ? sections.join('\\n\\n')\n          : 'No active elements found.'\n      }]\n    };\n  }\n\n}\n"]}
@@ -201,6 +201,7 @@ export declare class MCPAQLHandler {
201
201
  */
202
202
  private getActiveElements;
203
203
  private getPolicyReportElements;
204
+ private copyGatekeeperDiagnostics;
204
205
  /**
205
206
  * Handle CREATE operations (additive, non-destructive)
206
207
  *
@@ -449,6 +450,9 @@ export declare class MCPAQLHandler {
449
450
  * Dispatch Persona operations to PersonaHandler
450
451
  */
451
452
  private dispatchPersona;
453
+ private challengeIsForDeadlockRelief;
454
+ private issueDeadlockReliefChallenge;
455
+ private completeDeadlockRelief;
452
456
  /**
453
457
  * Dispatch Gatekeeper operations for confirmation management.
454
458
  *